:root{--bg: #faf8f4;--surface: #ffffff;--border-subtle: #ebe7de;--border: #d9d3c6;--text: #1a1814;--text-muted: #6b6660;--text-subtle: #9c968d;--accent: #1a2a38;--accent-soft: #e5e9ee;--accent-hover: #2a3c4d;--destructive: #8b3a2e;--destructive-soft: #f4ddd6;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--space-7: 48px;--space-8: 64px;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;--font-display: "Fraunces", "Times New Roman", Georgia, serif;--radius-sm: 4px;--radius: 8px;--radius-lg: 12px;--shadow-card: 0 1px 2px rgba(26, 24, 20, .04), 0 1px 1px rgba(26, 24, 20, .02);--shadow-hover: 0 2px 8px rgba(26, 24, 20, .06), 0 1px 2px rgba(26, 24, 20, .04);--shadow-popover: 0 8px 24px rgba(26, 24, 20, .08), 0 2px 6px rgba(26, 24, 20, .04);--ease: cubic-bezier(.2, 0, 0, 1);--t-fast: 80ms;--t-base: .15s;--t-slow: .25s}@media (prefers-reduced-motion: reduce){:root{--t-fast: 0ms;--t-base: 0ms;--t-slow: 0ms}}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;font-family:var(--font-sans);background:var(--bg);color:var(--text);font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}#root{min-height:100vh;display:flex;flex-direction:column}.app-shell{display:flex;flex-direction:column;min-height:100vh}.app{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.top-nav{position:sticky;top:0;z-index:20;background:var(--bg);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-6);-webkit-backdrop-filter:saturate(180%) blur(8px);backdrop-filter:saturate(180%) blur(8px)}.top-nav-brand{display:flex;align-items:center;gap:var(--space-3);background:transparent;border:none;cursor:pointer;padding:0;font-family:inherit;color:var(--text)}.brand-mark{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--accent);border-radius:var(--radius-sm);font-family:var(--font-display);font-weight:500;font-size:18px;color:var(--accent);background:var(--surface)}.brand-name{font-family:var(--font-display);font-weight:500;font-size:17px;letter-spacing:-.01em}.top-nav-links{display:flex;align-items:center;gap:var(--space-2)}.top-nav-link{background:transparent;border:none;font-family:inherit;font-size:14px;font-weight:500;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);transition:color var(--t-base) var(--ease),background-color var(--t-base) var(--ease)}.top-nav-link:hover{color:var(--text);background:var(--accent-soft)}.top-nav-link.active{color:var(--accent)}.bottom-nav{display:none;position:sticky;bottom:0;z-index:20;background:var(--surface);border-top:1px solid var(--border-subtle);padding:var(--space-2) var(--space-3) calc(var(--space-2) + env(safe-area-inset-bottom));align-items:center;justify-content:space-around;gap:var(--space-3);-webkit-backdrop-filter:saturate(180%) blur(8px);backdrop-filter:saturate(180%) blur(8px)}.bottom-nav-item{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:transparent;border:none;cursor:pointer;font-family:inherit;color:var(--text-subtle);font-size:11px;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);min-width:56px;transition:color var(--t-base) var(--ease)}.bottom-nav-item.active{color:var(--accent)}.bottom-nav-fab{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:50%;background:var(--accent);color:var(--surface);border:none;cursor:pointer;margin-top:-24px;box-shadow:0 4px 14px #1a2a3840;transition:background-color var(--t-base) var(--ease),transform var(--t-fast) var(--ease)}.bottom-nav-fab:hover{background:var(--accent-hover)}.bottom-nav-fab:active{transform:scale(.95)}.app-shell .main{flex:1;padding:var(--space-7) var(--space-6);max-width:1080px;width:100%;margin:0 auto}.page-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:var(--space-6);gap:var(--space-3)}.page-header h2{margin:0}.trip-section{margin-bottom:var(--space-7)}.trip-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-subtle);margin:0 0 var(--space-3)}.trip-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4)}.trip-card{background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-5);cursor:pointer;text-align:left;font-family:inherit;display:flex;flex-direction:column;gap:var(--space-3);box-shadow:var(--shadow-card);transition:transform var(--t-base) var(--ease),box-shadow var(--t-base) var(--ease),border-color var(--t-base) var(--ease)}.trip-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover);border-color:var(--border)}.trip-card.faded{opacity:.7}.trip-card.faded:hover{opacity:1}.trip-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3)}.trip-card-text{flex:1;min-width:0}.trip-card-name{font-family:var(--font-display);font-weight:500;font-size:22px;line-height:1.15;letter-spacing:-.01em;margin:0 0 var(--space-1);color:var(--text)}.trip-card-destination{font-size:13px;color:var(--text-muted);font-weight:400}.trip-card-badge{font-size:11px;font-weight:500;padding:4px 10px;border-radius:999px;white-space:nowrap;flex-shrink:0}.trip-card-badge.soon{background:var(--accent-soft);color:var(--accent)}.trip-card-badge.now{background:#f4ead6;color:#6f5512}.trip-card-meta{display:flex;align-items:center;gap:var(--space-2);font-size:13px;color:var(--text-muted);font-variant-numeric:tabular-nums}.trip-card-weather-dot{color:var(--text-subtle)}.trip-card-weather{display:inline-flex;align-items:center}.empty-state{text-align:center;padding:var(--space-8) var(--space-4);color:var(--text-muted)}.empty-state p{margin:0;font-size:16px}.trip-hero{margin-bottom:var(--space-6)}.back-link{display:inline-flex;align-items:center;gap:var(--space-1);background:transparent;border:none;cursor:pointer;font-family:inherit;font-size:13px;color:var(--text-muted);padding:var(--space-1) var(--space-2);margin-left:calc(-1 * var(--space-2));border-radius:var(--radius-sm);margin-bottom:var(--space-3);transition:color var(--t-base) var(--ease),background-color var(--t-base) var(--ease)}.back-link:hover{color:var(--accent);background:var(--accent-soft)}.trip-hero-body{display:flex;align-items:flex-start;gap:var(--space-4)}.trip-hero-text{flex:1;min-width:0}.trip-hero-name{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-subtle);margin-bottom:var(--space-2)}.trip-hero-destination{font-family:var(--font-display);font-weight:400;font-style:italic;font-size:44px;line-height:1.1;letter-spacing:-.02em;margin:0 0 var(--space-3);color:var(--text)}.trip-hero-dates{font-size:14px;color:var(--text-muted);font-variant-numeric:tabular-nums;margin-bottom:var(--space-1)}.trip-hero-weather{font-size:14px;color:var(--text-muted);font-variant-numeric:tabular-nums}.kebab-wrap{position:relative}.kebab-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;font-family:inherit;transition:background-color var(--t-base) var(--ease),color var(--t-base) var(--ease),border-color var(--t-base) var(--ease)}.kebab-btn:hover{background:var(--accent-soft);color:var(--accent);border-color:var(--accent)}.kebab-menu{position:absolute;top:calc(100% + var(--space-1));right:0;min-width:160px;background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius);box-shadow:var(--shadow-popover);padding:var(--space-1);z-index:30}.kebab-menu-item{display:block;width:100%;text-align:left;background:transparent;border:none;font-family:inherit;font-size:14px;color:var(--text);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--t-fast) var(--ease)}.kebab-menu-item:hover{background:var(--accent-soft)}.kebab-menu-item.destructive{color:var(--destructive)}.kebab-menu-item.destructive:hover{background:var(--destructive-soft)}@media (max-width: 768px){.top-nav{display:none}.bottom-nav{display:flex}.app-shell .main{padding:var(--space-4) var(--space-4) var(--space-7)}.trip-hero-destination{font-size:32px}h2{font-size:26px}.trip-grid{grid-template-columns:1fr}.new-trip-btn-desktop{display:none}.page-header{flex-direction:column;align-items:flex-start}.kebab-btn{width:44px;height:44px}.back-link{padding:var(--space-3) var(--space-3);font-size:14px}.row-remove{width:32px;height:32px;font-size:22px;opacity:.6}.btn{padding:var(--space-3) var(--space-4);min-height:44px}.form-row input,.form-row textarea,.form-row select{font-size:16px;min-height:44px}}@media (min-width: 769px){.new-trip-btn-desktop{display:inline-flex}}.sidebar{background:var(--surface);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;height:100vh;position:sticky;top:0;align-self:start}.sidebar-main{flex:1;overflow-y:auto;padding:var(--space-5) var(--space-4)}.sidebar-footer{border-top:1px solid var(--border-subtle);padding:var(--space-3) var(--space-3)}.sidebar h1{font-family:var(--font-display);font-weight:500;font-size:20px;letter-spacing:-.01em;margin:0 0 var(--space-5);color:var(--text)}.sidebar-section{margin-bottom:var(--space-5)}.sidebar-section h3{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-subtle);margin:0 0 var(--space-2);padding:0 var(--space-2)}.sidebar-link{display:block;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);color:var(--text);text-decoration:none;font-size:14px;cursor:pointer;border:1px solid transparent;background:transparent;width:100%;text-align:left;font-family:inherit;transition:background-color var(--t-base) var(--ease),color var(--t-base) var(--ease)}.sidebar-link:hover{background:var(--accent-soft)}.sidebar-link.active{background:var(--accent-soft);color:var(--accent);font-weight:500}.settings-btn{display:flex;align-items:center;gap:var(--space-3);background:transparent;border:1px solid transparent;color:var(--text-muted);font-family:inherit;font-size:14px;padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);cursor:pointer;width:100%;text-align:left;transition:background-color var(--t-base) var(--ease),color var(--t-base) var(--ease)}.settings-btn:hover{background:var(--accent-soft);color:var(--accent)}.settings-btn.active{background:var(--accent-soft);color:var(--accent);font-weight:500}.main{padding:var(--space-7) var(--space-7);max-width:920px;width:100%}h2{font-family:var(--font-display);font-weight:500;font-size:32px;letter-spacing:-.015em;line-height:1.15;margin:0 0 var(--space-2);color:var(--text)}.subtitle{color:var(--text-muted);margin:0 0 var(--space-6);font-size:14px;line-height:1.55}.card{background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-card);margin-bottom:var(--space-4)}.form-row{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}.form-row label{font-weight:500;font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.form-row input,.form-row textarea,.form-row select{font-family:inherit;font-size:15px;padding:var(--space-2) var(--space-3);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);transition:border-color var(--t-base) var(--ease),box-shadow var(--t-base) var(--ease)}.form-row input:focus,.form-row textarea:focus,.form-row select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.form-row textarea{resize:vertical;min-height:110px;line-height:1.55}.form-row input.invalid,.form-row textarea.invalid,.form-row select.invalid{border-color:var(--destructive);box-shadow:0 0 0 3px var(--destructive-soft)}.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.checkbox-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-2) var(--space-4);font-size:14px}.checkbox-grid label{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;font-weight:400;text-transform:none;letter-spacing:0;color:var(--text)}.autocomplete{position:absolute;top:100%;left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-popover);margin-top:var(--space-1);z-index:10;max-height:240px;overflow-y:auto}.autocomplete-item{display:block;width:100%;text-align:left;padding:var(--space-2) var(--space-3);background:transparent;border:none;font-family:inherit;font-size:14px;color:var(--text);cursor:pointer;border-bottom:1px solid var(--border-subtle);transition:background-color var(--t-fast) var(--ease)}.autocomplete-item:last-child{border-bottom:none}.autocomplete-item:hover{background:var(--accent-soft)}.btn{font-family:inherit;font-size:14px;font-weight:500;padding:var(--space-2) var(--space-4);border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;transition:background-color var(--t-base) var(--ease),border-color var(--t-base) var(--ease),transform var(--t-fast) var(--ease)}.btn:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.btn:active{transform:scale(.98)}.btn-primary{background:var(--accent);color:var(--surface);border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover);color:var(--surface)}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-row{display:flex;gap:var(--space-2);margin-top:var(--space-3)}.icon-btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-2);color:var(--text-muted);background:transparent;border:1px solid transparent;border-radius:var(--radius-sm)}.icon-btn:hover{background:var(--destructive-soft);color:var(--destructive);border-color:var(--destructive-soft)}.tab-row{display:flex;gap:var(--space-1);border-bottom:1px solid var(--border-subtle);margin-bottom:var(--space-5);align-items:flex-end}.tab-btn{padding:var(--space-2) var(--space-3);background:transparent;border:none;border-bottom:2px solid transparent;font-family:inherit;font-size:14px;font-weight:500;cursor:pointer;color:var(--text-muted);margin-bottom:-1px;transition:color var(--t-base) var(--ease),border-color var(--t-base) var(--ease)}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--text);border-bottom-color:var(--accent)}.day-card h4{margin:0 0 var(--space-1);font-size:15px;font-weight:500}.day-card .day-meta,.day-meta{font-size:13px;color:var(--text-muted);margin-bottom:var(--space-3)}.cat-block h3{margin:var(--space-4) 0 var(--space-2);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-subtle);font-weight:600}.cat-header{display:flex;align-items:center;gap:var(--space-3);margin:var(--space-5) 0 var(--space-2);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-subtle)}.cat-header .cat-name{flex:1}.cat-header .qty-header{font-size:10px;font-weight:600;letter-spacing:.08em;color:var(--text-subtle);min-width:40px;text-align:center}.cat-header .cat-header-spacer{width:24px;margin-left:var(--space-1)}.pack-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-1);border-bottom:1px solid var(--border-subtle);transition:background-color var(--t-fast) var(--ease)}.pack-row:last-child{border-bottom:none}.pack-row .name{flex:1;font-size:15px;color:var(--text)}.pack-row .qty{color:var(--text);font-size:16px;font-weight:500;min-width:40px;text-align:center;font-variant-numeric:tabular-nums}.pack-row .reason{color:var(--text-muted);font-size:12px;margin-left:var(--space-2)}.pack-row.checked .name{text-decoration:line-through;color:var(--text-subtle)}.qty{font-size:16px;font-weight:500;color:var(--text);font-variant-numeric:tabular-nums}.name-edit{font-family:inherit;font-size:15px;padding:2px var(--space-2);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);flex:1;outline:none}.name-edit:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.row-remove{background:transparent;border:none;color:var(--text-subtle);font-size:18px;line-height:1;width:24px;height:24px;border-radius:var(--radius-sm);cursor:pointer;padding:0;font-family:inherit;margin-left:var(--space-1);opacity:0;transition:opacity var(--t-base) var(--ease),background-color var(--t-fast) var(--ease),color var(--t-fast) var(--ease)}.pack-row:hover .row-remove{opacity:.6}.row-remove:hover{background:var(--destructive-soft);color:var(--destructive);opacity:1!important}.add-item-btn{display:block;background:transparent;border:1px dashed transparent;color:var(--text-subtle);font-family:inherit;font-size:13px;cursor:pointer;padding:var(--space-2) var(--space-2);width:100%;text-align:left;border-radius:var(--radius-sm);margin-top:var(--space-1);transition:color var(--t-base) var(--ease),background-color var(--t-base) var(--ease),border-color var(--t-base) var(--ease)}.add-item-btn:hover{color:var(--accent);background:var(--accent-soft);border-color:var(--accent)}.add-item-input{font-family:inherit;font-size:14px;padding:var(--space-2) var(--space-3);border:1px solid var(--accent);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);width:100%;margin-top:var(--space-1);outline:none;box-shadow:0 0 0 2px var(--accent-soft)}.global-add-row{display:flex;gap:var(--space-2);align-items:center;margin-top:var(--space-4)}.global-add-select{font-family:inherit;font-size:13px;padding:var(--space-2) var(--space-2);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);cursor:pointer}.editable-table{width:100%;border-collapse:collapse;font-size:14px}.editable-table th,.editable-table td{padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--border-subtle);text-align:left}.editable-table th{font-weight:600;color:var(--text-subtle);font-size:10px;text-transform:uppercase;letter-spacing:.08em;padding-bottom:var(--space-2)}.editable-table input,.editable-table select{font-family:inherit;font-size:14px;padding:var(--space-1) var(--space-2);border:1px solid transparent;background:transparent;color:var(--text);width:100%;border-radius:var(--radius-sm);transition:border-color var(--t-base) var(--ease),background-color var(--t-base) var(--ease)}.editable-table input:focus,.editable-table select:focus{outline:none;border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 2px var(--accent-soft)}.settings-rule-row{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) 0;border-bottom:1px solid var(--border-subtle);font-size:13px}.settings-rule-row:last-of-type{border-bottom:none}.settings-input{font-family:inherit;font-size:13px;padding:var(--space-1) var(--space-2);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);outline:none;transition:border-color var(--t-base) var(--ease)}.settings-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-soft)}.settings-select{font-family:inherit;font-size:13px;padding:var(--space-1) var(--space-2);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);cursor:pointer}.settings-unit{color:var(--text-subtle);font-size:12px;white-space:nowrap;min-width:60px}.settings-list{margin:var(--space-2) 0;padding-left:var(--space-5)}.settings-list li{margin:var(--space-2) 0;line-height:1.6;color:var(--text)}.settings-list code{background:var(--accent-soft);padding:1px 6px;border-radius:var(--radius-sm);font-size:12px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--accent)}.by-day-grid{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-4);align-items:start}.by-day-cards{display:flex;flex-direction:column;gap:var(--space-4)}.by-day-cards .card{margin-bottom:0}.by-day-aside{position:sticky;top:var(--space-4)}.trip-wide-card{margin-bottom:0}@media (max-width: 760px){.by-day-grid{grid-template-columns:1fr}.by-day-aside{position:static}}.error{background:var(--destructive-soft);color:var(--destructive);padding:var(--space-3) var(--space-4);border-radius:var(--radius);margin-bottom:var(--space-3);font-size:14px;border:1px solid #e8c0b6}.empty{color:var(--text-subtle);font-style:italic;padding:var(--space-5) 0;text-align:center}.rule-row{display:grid;grid-template-columns:1fr auto 1fr;gap:var(--space-3);align-items:center;padding:var(--space-2) 0;border-bottom:1px solid var(--border-subtle);font-size:14px}.rule-row:last-child{border-bottom:none}.rule-trigger{color:var(--text-muted)}.rule-arrow{color:var(--text-subtle);font-size:16px}.rule-result strong{font-weight:500}.rule-meta{color:var(--text-subtle);font-size:12px}
