:root{--brand: oklch(.58 .18 18);--brand-deep: oklch(.42 .16 18);--brand-muted: oklch(.85 .035 18);--brand-ghost: oklch(.95 .008 18);--sky: oklch(.5 .14 255);--sky-muted: oklch(.9 .025 255);--teal: oklch(.55 .15 175);--teal-muted: oklch(.9 .03 175);--amber: oklch(.72 .16 80);--amber-muted: oklch(.92 .06 85);--surface: oklch(.985 0 0);--surface-elevated: oklch(1 0 0);--surface-subtle: oklch(.972 .002 18);--ink: oklch(.14 .005 260);--ink-secondary: oklch(.42 .01 260);--ink-tertiary: oklch(.6 .01 260);--border: oklch(.9 .005 260);--shadow-xs: 0 1px 2px oklch(0 0 0 / .04);--shadow-sm: 0 1px 3px oklch(0 0 0 / .05);--shadow-md: 0 4px 20px oklch(0 0 0 / .07);--shadow-lg: 0 16px 48px oklch(0 0 0 / .09);--radius-sm: 8px;--radius-md: 14px;--radius-lg: 20px;--radius-xl: 28px;--radius-full: 999px;--sidebar-w: 200px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Inter,system-ui,sans-serif;background:var(--surface);color:var(--ink);line-height:1.6;min-height:100vh}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background:radial-gradient(ellipse 55% 45% at 18% 0%,oklch(.58 .18 18 / .035),transparent),radial-gradient(ellipse 45% 45% at 85% 100%,oklch(.5 .14 255 / .025),transparent)}h1{font-size:2rem;font-weight:800;letter-spacing:-.04em;line-height:1.15}h2{font-size:1.35rem;font-weight:700;letter-spacing:-.025em}h3{font-size:1.05rem;font-weight:650}.hint{color:var(--ink-tertiary);font-size:.88rem}.btn{display:inline-flex;align-items:center;gap:7px;cursor:pointer;font-weight:650;font-family:inherit;border:none;text-decoration:none;transition:all .2s ease;white-space:nowrap}.btn-primary{background:var(--brand);color:#fff;padding:11px 26px;border-radius:var(--radius-full);font-size:.92rem;box-shadow:0 4px 18px #cf3f5047}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 24px #cf3f5061}.btn-lg{padding:14px 34px;font-size:1rem}.btn-secondary{background:var(--surface-elevated);color:var(--ink);padding:10px 20px;border-radius:var(--radius-full);font-size:.88rem;border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--brand);color:var(--brand)}.btn-outline{background:transparent;color:var(--brand);padding:10px 20px;border-radius:var(--radius-full);font-size:.88rem;border:2px solid var(--brand)}.btn-outline:hover{background:var(--brand);color:#fff}.back-link{display:inline-flex;align-items:center;gap:6px;font-size:.85rem;color:var(--ink-tertiary);cursor:pointer;margin-bottom:16px;transition:color .15s;border:none;background:none;font-family:inherit}.back-link:hover{color:var(--brand)}.toast{position:fixed;bottom:32px;left:50%;transform:translate(-50%);padding:10px 22px;border-radius:var(--radius-full);background:var(--ink);color:#fff;font-size:.82rem;font-weight:600;z-index:1000;opacity:0;transition:opacity .3s;pointer-events:none}.toast.show{opacity:1}.app-layout{display:flex;min-height:100vh;position:relative;z-index:1}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:#ffffffd1;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid var(--border);padding:24px 16px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.sidebar-logo{font-size:1.35rem;font-weight:800;letter-spacing:-.03em;color:var(--brand);margin-bottom:28px;padding:0 8px;cursor:pointer}.sidebar-logo span{color:var(--ink)}.side-nav{display:flex;flex-direction:column;gap:4px;flex:1}.side-nav a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);text-decoration:none;color:var(--ink-secondary);font-size:.9rem;font-weight:500;transition:all .15s ease}.side-nav a:hover{background:var(--surface-subtle);color:var(--ink)}.side-nav a.active{background:var(--brand-ghost);color:var(--brand);font-weight:650}.side-nav a .nav-icon{font-size:1.05rem;width:22px;text-align:center}.side-user{display:flex;align-items:center;gap:10px;padding-top:14px;border-top:1px solid var(--border);margin-top:auto}.side-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--brand),oklch(.52 .16 45));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.78rem;flex-shrink:0}.side-user-info{font-size:.78rem;line-height:1.3}.side-user-info strong{display:block;font-size:.8rem}.main{flex:1;min-width:0}.page{padding:32px 48px 60px 40px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.mobile-bar{display:none;align-items:center;justify-content:space-between;padding:12px 16px;background:#ffffffe0;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:200}.mobile-bar .mb-logo{font-size:1.2rem;font-weight:800;letter-spacing:-.03em;color:var(--brand);cursor:pointer}.mobile-bar .mb-logo span{color:var(--ink)}.mb-hamburger{width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-elevated);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer}.mb-hamburger span{display:block;width:18px;height:2px;background:var(--ink-secondary);border-radius:1px;transition:all .2s}.mb-hamburger.open span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}.mb-hamburger.open span:nth-child(2){opacity:0}.mb-hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:150}.sidebar-overlay.show{display:block}.add-btn{display:inline-flex;align-items:center;gap:3px;padding:5px 12px;border-radius:var(--radius-full);border:none;background:transparent;font-size:.78rem;font-weight:500;color:var(--ink-tertiary);cursor:pointer;transition:all .15s;font-family:inherit;margin-top:6px}.add-btn:hover{color:var(--brand);background:var(--brand-ghost)}.add-btn:before{content:"+";font-size:1rem;font-weight:400}.nl-modify{display:flex;align-items:center;gap:10px;padding:12px 16px;margin-bottom:20px;border-radius:var(--radius-lg);background:var(--surface-subtle);border:1px solid var(--border);transition:border-color .2s}.nl-modify:focus-within{border-color:var(--brand);box-shadow:0 0 0 3px #cf3f5014}.nl-icon{font-size:1.2rem;flex-shrink:0;opacity:.6}.nl-input{flex:1;border:none;background:transparent;font-size:.88rem;font-family:inherit;color:var(--ink);outline:none;padding:0}.nl-input::placeholder{color:var(--ink-tertiary)}.nl-send{width:32px;height:32px;border-radius:50%;border:none;background:var(--brand);color:#fff;font-size:1rem;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s;font-family:inherit}.nl-send:hover{background:var(--brand-deep);transform:scale(1.05)}.del-btn{width:22px;height:22px;border-radius:50%;border:1px solid transparent;background:transparent;color:var(--ink-tertiary);cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:all .15s;font-family:inherit;flex-shrink:0;opacity:0;padding:0;line-height:1}.pack-item:hover .del-btn{opacity:1}.del-btn:hover{background:#fa686a;color:#fff;border-color:#fa686a}.pack-item{position:relative}.pack-item .del-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);opacity:0}.spot-card{position:relative}.spot-card .spot-del{position:absolute;top:10px;left:10px;z-index:2;width:28px;height:28px;border-radius:50%;background:#00000073;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#fff;border:none;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:all .15s;opacity:0}.spot-card:hover .spot-del{opacity:1}.spot-card .spot-del:hover{background:#fa686a}.steps-bar{display:flex;align-items:center;gap:8px;margin-bottom:28px}.step-item{display:flex;align-items:center;gap:8px}.step-circle{width:26px;height:26px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:var(--ink-tertiary);background:var(--surface-subtle);border:2px solid var(--border)}.step-circle.done{background:var(--brand);border-color:var(--brand);color:#fff}.step-circle.current{border-color:var(--brand);color:var(--brand);background:var(--brand-ghost)}.step-line{width:28px;height:2px;background:var(--border);border-radius:1px}.step-line.done{background:var(--brand)}.step-label{font-size:.82rem;color:var(--ink-tertiary)}.step-label.active{color:var(--ink);font-weight:650}.step-label.done{color:var(--brand)}.home-hero{padding:60px 0 48px;text-align:center;position:relative}.home-hero h1{font-size:2.6rem;max-width:600px;margin:0 auto 10px}.home-hero .highlight{color:var(--brand);position:relative;display:inline-block}.home-hero .highlight:after{content:"";position:absolute;bottom:2px;left:0;right:0;height:10px;background:var(--brand-muted);border-radius:5px;z-index:-1;opacity:.7}.home-hero p{font-size:1rem;color:var(--ink-secondary);max-width:440px;margin:0 auto 24px}.my-trips-section{margin-top:8px}.my-trips-section .section-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:16px}.my-trips-section .section-head a{color:var(--brand);font-size:.85rem;font-weight:600;text-decoration:none;cursor:pointer}.trip-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.trip-card{background:var(--surface-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:all .2s ease}.trip-card:hover{border-color:var(--brand);box-shadow:var(--shadow-md);transform:translateY(-2px)}.trip-card .card-img{height:130px;background-size:cover;background-position:center;position:relative}.trip-card .card-status{position:absolute;top:10px;right:10px;padding:4px 10px;border-radius:var(--radius-full);font-size:.68rem;font-weight:650}.trip-card .card-status.draft{background:#ffffffd9;color:var(--ink-secondary);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.trip-card .card-status.confirmed{background:var(--teal);color:#fff}.trip-card .card-body{padding:14px 16px}.trip-card .card-body h4{font-size:.92rem;margin-bottom:2px}.trip-card .card-body p{font-size:.78rem;color:var(--ink-tertiary)}.trip-card-new{border:2px dashed var(--border);background:var(--surface-subtle);display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:180px;gap:8px;cursor:pointer;transition:all .2s ease;border-radius:var(--radius-lg)}.trip-card-new:hover{border-color:var(--brand);background:var(--brand-ghost)}.trip-card-new .plus{font-size:2rem;color:var(--ink-tertiary)}.trip-card-new p{font-size:.85rem;color:var(--ink-tertiary)}.start-form-wrap{display:flex;gap:36px;align-items:flex-start}.start-form{flex:1;max-width:540px}.form-card{background:var(--surface-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:.83rem;font-weight:600;color:var(--ink-secondary);margin-bottom:5px}.form-group input,.form-group select{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.9rem;font-family:inherit;color:var(--ink);background:var(--surface-subtle);transition:border-color .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px #cf3f501a}.form-group input[type=date]{color:var(--ink);font-family:inherit}.chip-row{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:16px}.chip{padding:7px 15px;border-radius:var(--radius-full);border:1px solid var(--border);font-size:.83rem;cursor:pointer;transition:all .15s;background:var(--surface-elevated);-webkit-user-select:none;user-select:none;font-family:inherit}.chip.selected{background:var(--brand);color:#fff;border-color:var(--brand)}.chip:hover:not(.selected){border-color:var(--brand)}.slider-wrap{margin-bottom:16px}.slider-wrap input[type=range]{width:100%;accent-color:var(--brand)}.slider-labels{display:flex;justify-content:space-between;font-size:.73rem;color:var(--ink-tertiary);margin-top:3px}.pref-sliders{display:flex;flex-direction:column;gap:10px}.pref-row{display:flex;align-items:center;gap:10px}.pref-label{font-size:.85rem;flex-shrink:0;width:90px;color:var(--ink-secondary)}.pref-row input[type=range]{flex:1;min-width:0;width:100%;accent-color:var(--brand);-moz-appearance:none;appearance:none;-webkit-appearance:none;background:transparent;margin:0;padding:0}.pref-row input[type=range]::-webkit-slider-runnable-track{height:6px;border-radius:3px;background:var(--border)}.pref-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--brand);margin-top:-6px;cursor:pointer;box-shadow:0 1px 4px #00000026}.pref-row input[type=range]::-moz-range-track{height:6px;border-radius:3px;background:var(--border);border:none}.pref-row input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--brand);border:none;cursor:pointer}.pref-val{font-size:.8rem;font-weight:700;color:var(--brand);min-width:32px;text-align:right;flex-shrink:0}.gen-preview{flex:0 0 300px;position:sticky;top:80px}.gen-card{background:var(--surface-subtle);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;text-align:center;display:none}.gen-card.show{display:block}.gen-card .spinner{width:46px;height:46px;border-radius:50%;border:3px solid var(--border);border-top-color:var(--brand);animation:spin .8s linear infinite;margin:0 auto 14px}@keyframes spin{to{transform:rotate(360deg)}}.gen-card p{font-size:.88rem;color:var(--ink-secondary)}.gen-steps{font-size:.78rem;color:var(--ink-tertiary);margin-top:6px}.dest-scroll{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:16px;align-items:start}.dest-preview{background:var(--surface-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:all .2s;display:flex;flex-direction:column}.dest-preview:hover{border-color:var(--brand);box-shadow:var(--shadow-md)}.dest-preview.recommended{border:2px solid var(--brand)}.dp-hero{height:160px;background-size:cover;background-position:center;position:relative;display:flex;align-items:flex-end;padding:12px}.dp-badge{position:absolute;top:10px;right:10px;padding:3px 10px;border-radius:var(--radius-full);background:var(--brand);color:#fff;font-size:.7rem;font-weight:700}.dp-body{padding:16px;display:flex;flex-direction:column;flex:1}.dp-header{margin-bottom:10px}.dp-header h3{font-size:1rem;margin-bottom:1px}.dp-header p{font-size:.75rem;color:var(--ink-tertiary)}.dp-price{font-size:1.15rem;font-weight:800;color:var(--brand);margin:8px 0}.dp-price span{font-size:.72rem;color:var(--ink-tertiary);font-weight:400}.dp-tags{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:10px}.dp-tags .chip{font-size:.7rem;padding:3px 9px}.dp-reason{font-size:.78rem;color:var(--ink-secondary);line-height:1.5;margin-bottom:12px}.dp-sneak{background:var(--surface-subtle);border-radius:var(--radius-sm);padding:10px 12px;margin-bottom:10px}.dp-sneak h4{font-size:.73rem;color:var(--ink-tertiary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.03em}.dp-stops{display:flex;flex-direction:column;gap:5px}.dp-stop{font-size:.76rem;color:var(--ink);display:flex;gap:6px;align-items:baseline;line-height:1.4}.dp-stop span{font-size:.62rem;font-weight:700;padding:1px 6px;border-radius:var(--radius-full);background:var(--brand);color:#fff;flex-shrink:0}.dp-highlights{display:flex;gap:4px;flex-wrap:wrap}.dp-highlights span{padding:3px 8px;border-radius:var(--radius-full);background:var(--surface-elevated);border:1px solid var(--border);font-size:.72rem;color:var(--ink-secondary)}.dp-actions{display:flex;flex-direction:column;gap:6px;margin-top:auto;padding-top:12px}.dp-actions .btn{width:100%;justify-content:center;font-size:.8rem;padding:9px 0}.compare-layout{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-bottom:24px}.compare-card{background:var(--surface-elevated);border:2px solid var(--border);border-radius:var(--radius-lg);padding:28px;cursor:pointer;transition:all .2s;position:relative}.compare-card:hover{border-color:var(--brand)}.compare-card.selected{border-color:var(--brand);background:var(--brand-ghost)}.compare-card h2{margin-bottom:2px}.compare-card .subtitle{font-size:.85rem;color:var(--ink-tertiary);margin-bottom:14px}.compare-card .price{font-size:1.8rem;font-weight:800;color:var(--brand);margin-bottom:14px}.compare-card .price small{font-size:.72rem;color:var(--ink-tertiary);font-weight:400}.compare-metrics{display:flex;flex-direction:column;gap:10px}.metric-row{display:flex;align-items:center;gap:8px;font-size:.85rem}.metric-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.metric-dot.high{background:var(--teal)}.metric-dot.mid{background:var(--sky)}.metric-dot.low{background:var(--brand-muted)}.detail-header{margin-bottom:24px}.detail-header h1{margin-bottom:4px}.detail-meta{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}.detail-meta span{padding:5px 12px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--surface-elevated);font-size:.8rem;color:var(--ink-secondary)}.sub-tabs{display:flex;gap:4px;margin-bottom:24px;border-bottom:1px solid var(--border);padding-bottom:0}.sub-tab{padding:10px 18px;font-size:.85rem;font-weight:600;color:var(--ink-tertiary);cursor:pointer;transition:all .15s ease;border:none;background:none;font-family:inherit;border-bottom:2px solid transparent;margin-bottom:-1px}.sub-tab:hover{color:var(--ink-secondary)}.sub-tab.active{color:var(--brand);border-bottom-color:var(--brand)}.sub-panel{animation:fadeIn .25s ease}.day-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}.day-panel{background:var(--surface-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.day-panel-header{padding:14px 18px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border)}.day-num{width:38px;height:38px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.82rem;color:#fff;flex-shrink:0}.day-num.d1{background:var(--brand)}.day-num.d2{background:var(--sky)}.day-panel-header h4{font-size:.88rem}.day-panel-header p{font-size:.74rem;color:var(--ink-tertiary)}.stop-list{padding:12px;display:flex;flex-direction:column;gap:8px}.stop-card{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--surface-elevated);cursor:grab;transition:all .15s;position:relative}.stop-card:hover{border-color:var(--brand);box-shadow:var(--shadow-xs)}.stop-card:active{cursor:grabbing}.stop-card.dragging{opacity:.4;border-style:dashed}.stop-card.drag-over{border-color:var(--brand);background:var(--brand-ghost);box-shadow:0 0 0 2px #cf3f5026}.stop-handle{color:var(--ink-tertiary);font-size:1rem;cursor:grab;flex-shrink:0;-webkit-user-select:none;user-select:none;line-height:1;padding:0 2px}.stop-time{font-size:.78rem;font-weight:650;color:var(--brand);width:42px;flex-shrink:0;font-variant-numeric:tabular-nums;background:var(--brand-ghost);padding:4px 0;border-radius:var(--radius-sm);text-align:center}.stop-body{flex:1;min-width:0}.stop-body strong{display:block;font-size:.85rem}.stop-body span{font-size:.74rem;color:var(--ink-tertiary)}.stop-actions{display:flex;gap:2px;flex-shrink:0}.stop-act{width:28px;height:28px;border-radius:50%;border:1px solid var(--border);background:var(--surface-elevated);cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center;transition:all .15s;font-family:inherit;padding:0}.stop-act:hover{border-color:var(--brand);background:var(--brand-ghost)}.stop-act.del:hover{border-color:#d6464d;background:#f8d4d2;color:#bd4045}.add-stop-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px;border-radius:var(--radius-md);border:1.5px dashed var(--border);background:transparent;font-size:.84rem;color:var(--ink-tertiary);cursor:pointer;transition:all .2s;font-family:inherit;width:100%}.add-stop-btn:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-ghost)}.add-stop-btn .plus-circle{width:22px;height:22px;border-radius:50%;border:1.5px dashed var(--ink-tertiary);display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:all .2s}.add-stop-btn:hover .plus-circle{border-color:var(--brand)}.budget-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;padding:18px 22px;border-radius:var(--radius-md);background:var(--surface-subtle);border:1px solid var(--border);text-align:center;margin-bottom:18px}.budget-strip .item{font-size:.8rem;color:var(--ink-secondary)}.budget-strip .item strong{display:block;font-size:1.05rem;color:var(--brand);margin-top:2px}.notes-bar{padding:14px 18px;border-radius:var(--radius-md);background:var(--sky-muted);font-size:.82rem;color:var(--ink-secondary);line-height:1.6}.outfit-top-row{display:flex;gap:32px;margin-bottom:24px;align-items:flex-start}.outfit-intro{flex:1}.weather-badge{flex:0 0 260px;padding:16px 20px;border-radius:var(--radius-lg);background:var(--sky-muted);display:flex;gap:12px;align-items:center;font-size:.82rem}.weather-badge .icon{font-size:2.2rem}.weather-badge strong{display:block;font-size:.85rem}.style-bar{display:flex;gap:7px;margin-bottom:24px}.style-chip{padding:8px 18px;border-radius:var(--radius-full);border:1.5px solid var(--border);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s;background:var(--surface-elevated);font-family:inherit}.style-chip:hover{border-color:var(--brand);color:var(--brand)}.style-chip.active{background:var(--brand);color:#fff;border-color:var(--brand)}.outfit-day{margin-bottom:30px}.outfit-day h3{margin-bottom:14px;display:flex;align-items:center;gap:8px}.outfit-day h3 .day-badge{padding:4px 12px;border-radius:var(--radius-full);font-size:.72rem;font-weight:700;color:#fff}.outfit-day h3 .day-badge.d1{background:var(--brand)}.outfit-day h3 .day-badge.d2{background:var(--sky)}.outfit-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.outfit-card{background:var(--surface-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:all .15s;cursor:pointer}.outfit-card:hover{border-color:var(--brand);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.outfit-visual{height:140px;display:flex;align-items:flex-end;justify-content:center;padding:14px;position:relative}.outfit-visual .scene-tag{position:absolute;top:8px;left:8px;padding:2px 8px;border-radius:var(--radius-full);background:#0006;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);color:#fff;font-size:.66rem;font-weight:600}.outfit-visual .emoji{font-size:3rem;filter:drop-shadow(0 3px 8px rgba(0,0,0,.1))}.outfit-body{padding:12px 14px}.outfit-body h5{font-size:.84rem;margin-bottom:2px}.outfit-body p{font-size:.75rem;color:var(--ink-tertiary);line-height:1.4}.essentials-block{margin-top:32px}.essentials-block h3{margin-bottom:12px}.essentials-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.ess-item{padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-elevated);font-size:.82rem;display:flex;align-items:center;gap:7px;cursor:pointer;transition:all .15s}.ess-item:hover{border-color:var(--brand)}.ess-item.checked{background:var(--brand-ghost);border-color:var(--brand-muted);text-decoration:line-through;text-decoration-color:var(--brand)}.spot-mode-bar{display:flex;gap:6px;margin-bottom:22px}.spot-mode{padding:8px 18px;border-radius:var(--radius-full);border:1.5px solid var(--border);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .15s;background:var(--surface-elevated);font-family:inherit}.spot-mode:hover{border-color:var(--brand);color:var(--brand)}.spot-mode.active{background:var(--brand);color:#fff;border-color:var(--brand)}.spots-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.spot-card{background:var(--surface-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:all .2s;cursor:pointer}.spot-card:hover{border-color:var(--brand);box-shadow:var(--shadow-md);transform:translateY(-2px)}.spot-hero{height:180px;display:flex;align-items:flex-end;padding:16px;position:relative}.spot-hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(transparent 40%,#00000080)}.spot-hero-text{position:relative;z-index:1;color:#fff}.spot-hero-text h3{font-size:1.05rem;margin-bottom:1px}.spot-hero-text p{font-size:.78rem;opacity:.9}.spot-time-pill{position:absolute;top:12px;right:12px;z-index:1;padding:4px 12px;border-radius:var(--radius-full);background:#ffffffe0;-webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px);font-size:.72rem;font-weight:700;color:var(--brand)}.spot-body{padding:16px 18px}.spot-tip{margin-bottom:10px}.spot-tip h5{font-size:.8rem;color:var(--ink-secondary);margin-bottom:3px;display:flex;align-items:center;gap:4px}.spot-tip p{font-size:.78rem;color:var(--ink-secondary);line-height:1.5}.spot-tags{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:14px}.spot-tag{padding:3px 9px;border-radius:var(--radius-full);font-size:.7rem;font-weight:650}.spot-tag.best{background:var(--amber-muted);color:#946900;color:oklch(.55 .14 80)}.spot-tag.angle{background:var(--sky-muted);color:#1f5596}.spot-tag.gear{background:var(--teal-muted);color:#006b53;color:oklch(.47 .12 170)}.spot-tag.style{background:var(--brand-ghost);color:var(--brand)}.pack-layout{display:grid;grid-template-columns:1fr 280px;gap:28px;align-items:start}.pack-category{margin-bottom:22px}.pack-category h4{font-size:.75rem;color:var(--ink-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.pack-items{display:grid;grid-template-columns:1fr 1fr;gap:7px}.pack-item{display:flex;align-items:center;gap:9px;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-elevated);cursor:pointer;transition:all .15s;font-size:.83rem}.pack-item:hover{border-color:var(--brand)}.pack-item.packed{background:var(--brand-ghost);border-color:var(--brand-muted)}.pack-item.packed .item-name{text-decoration:line-through;text-decoration-color:var(--brand)}.pack-check{width:18px;height:18px;border-radius:50%;border:2px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:.55rem;transition:all .15s}.pack-item.packed .pack-check{background:var(--brand);border-color:var(--brand);color:#fff}.pack-add-row{display:flex;gap:6px;margin-top:8px}.pack-input{flex:1;padding:8px 12px;border:1px dashed var(--border);border-radius:var(--radius-sm);font-size:.82rem;font-family:inherit;background:var(--surface-subtle);color:var(--ink);transition:border-color .15s}.pack-input:focus{outline:none;border-color:var(--brand);border-style:solid}.pack-input::placeholder{color:var(--ink-tertiary)}.pack-sidebar-card{position:sticky;top:24px;background:var(--surface-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.pack-sidebar-card h4{font-size:.8rem;color:var(--ink-secondary);margin-bottom:10px}.pack-sidebar-card .bar{height:7px;background:var(--border);border-radius:4px;overflow:hidden;margin-bottom:6px}.pack-sidebar-card .bar-fill{height:100%;border-radius:4px;background:var(--brand);transition:width .3s}.pack-count{font-size:1.4rem;font-weight:800;color:var(--brand)}.pack-count small{font-size:.76rem;color:var(--ink-tertiary);font-weight:400}.community-header{margin-bottom:24px}.community-header h2{margin-bottom:4px}.community-tags{display:flex;gap:7px;margin-bottom:22px;flex-wrap:wrap}.community-tags .chip{font-size:.82rem;padding:7px 16px}.community-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.post-card{background:var(--surface-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:all .2s}.post-card:hover{border-color:var(--brand);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.post-card .post-img{height:150px;background-size:cover;background-position:center}.post-card .post-body{padding:14px}.post-card .post-body h4{font-size:.88rem;margin-bottom:3px}.post-card .post-body p{font-size:.76rem;color:var(--ink-tertiary)}.post-card .post-author{display:flex;align-items:center;gap:8px;padding:0 14px 14px;font-size:.78rem;color:var(--ink-secondary)}.post-card .post-author .pa{width:22px;height:22px;border-radius:50%;background:var(--brand-muted)}.detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:500;opacity:0;pointer-events:none;transition:opacity .25s;display:flex;align-items:center;justify-content:center}.detail-overlay.show{opacity:1;pointer-events:auto}.detail-panel{background:var(--surface);border-radius:var(--radius-xl);width:560px;max-width:94vw;max-height:85vh;overflow-y:auto;box-shadow:0 24px 64px #0000002e;transform:scale(.92) translateY(16px);opacity:0;transition:all .3s cubic-bezier(.4,0,.2,1)}.detail-overlay.show .detail-panel{transform:scale(1) translateY(0);opacity:1}.dp-close{position:sticky;top:12px;float:right;z-index:10;margin-right:12px;width:34px;height:34px;border-radius:50%;border:none;background:#ffffffd9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink);transition:all .15s;box-shadow:var(--shadow-sm);font-family:inherit}.dp-close:hover{background:var(--ink);color:#fff}.dp-hero-img{width:100%;height:220px;background-size:cover;background-position:center;border-radius:var(--radius-xl) var(--radius-xl) 0 0;margin-top:-48px}.dp-content{padding:20px 28px 32px}.dp-content h2{font-size:1.25rem;margin-bottom:4px}.dp-content .dp-subtitle{font-size:.85rem;color:var(--ink-tertiary);margin-bottom:16px}.dp-metrics{display:flex;gap:14px;margin-bottom:18px}.dp-metric{flex:1;text-align:center;padding:12px 8px;border-radius:var(--radius-md);background:var(--surface-subtle)}.dp-metric .val{font-size:1.2rem;font-weight:800;color:var(--brand)}.dp-metric .lbl{font-size:.7rem;color:var(--ink-tertiary);margin-top:2px}.dp-metric.stars .val{font-size:.95rem;letter-spacing:2px}.dp-section{margin-bottom:18px}.dp-section h4{font-size:.76rem;color:var(--ink-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}.dp-section p{font-size:.86rem;color:var(--ink-secondary);line-height:1.7}.dp-location{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:var(--radius-md);background:var(--surface-subtle);margin-bottom:18px;font-size:.86rem}.dp-location .pin{font-size:1.1rem}.dp-tags-row{display:flex;gap:5px;flex-wrap:wrap;margin-top:16px}.dp-link-card{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-radius:var(--radius-md);border:1px solid var(--border);cursor:pointer;transition:all .15s;margin-bottom:8px;background:var(--surface-elevated)}.dp-link-card:hover{border-color:var(--brand);background:var(--brand-ghost)}.dp-link-card .link-label{font-size:.84rem;font-weight:600}.dp-link-card .link-arrow{color:var(--brand);font-size:1.1rem}.dp-items-list{display:flex;flex-direction:column;gap:5px}.dp-item-row{display:flex;align-items:center;gap:8px;padding:7px 12px;border-radius:var(--radius-sm);background:var(--surface-subtle);font-size:.84rem}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative;z-index:1}.login-card{background:var(--surface-elevated);border:1px solid var(--border);border-radius:var(--radius-xl);padding:36px 32px;width:100%;max-width:420px;box-shadow:var(--shadow-md)}.login-logo{font-size:1.6rem;font-weight:800;letter-spacing:-.03em;color:var(--brand);text-align:center;margin-bottom:6px}.login-logo span{color:var(--ink)}.login-subtitle{text-align:center;font-size:.88rem;color:var(--ink-tertiary);margin-bottom:24px}.login-tabs{display:flex;gap:4px;margin-bottom:22px;background:var(--surface-subtle);border-radius:var(--radius-full);padding:4px}.login-tab{flex:1;padding:9px 0;border:none;background:transparent;border-radius:var(--radius-full);font-size:.88rem;font-weight:600;color:var(--ink-tertiary);cursor:pointer;transition:all .15s;font-family:inherit}.login-tab.active{background:var(--surface-elevated);color:var(--brand);box-shadow:var(--shadow-xs)}.login-error{padding:10px 14px;border-radius:var(--radius-sm);background:#ffdbd9;color:#9b1d29;font-size:.82rem;margin-bottom:14px;border:1px solid oklch(.85 .05 22)}.login-form-error{font-size:.74rem;color:#ac3037;margin-top:3px}.login-back{display:block;text-align:center;margin-top:18px;font-size:.82rem;color:var(--ink-tertiary);text-decoration:none;cursor:pointer}.login-back:hover{color:var(--brand)}@media (max-width: 1200px){.page{padding:28px 28px 50px}.dest-scroll{grid-template-columns:repeat(2,1fr);gap:14px}.dp-hero{height:130px}.trip-cards,.community-grid{grid-template-columns:repeat(2,1fr)}.essentials-grid{grid-template-columns:repeat(3,1fr)}.home-hero{padding:44px 0 36px}.home-hero h1{font-size:2.2rem}}@media (max-width: 900px){.sidebar{display:none}.sidebar-overlay.show{display:block}.mobile-bar{display:flex}.page{padding:20px 18px 40px}.app-layout{display:block}.home-hero{padding:36px 0 28px;text-align:left}.home-hero h1{font-size:1.85rem;max-width:100%}.home-hero p{max-width:100%}.trip-cards,.community-grid{grid-template-columns:1fr 1fr;gap:12px}.dest-scroll{grid-template-columns:1fr;gap:16px}.dp-hero{height:180px}.dp-body{padding:16px}.compare-layout,.day-grid,.spots-grid{grid-template-columns:1fr;gap:14px}.outfit-cards{grid-template-columns:1fr 1fr;gap:10px}.essentials-grid{grid-template-columns:repeat(2,1fr)}.start-form-wrap{flex-direction:column}.start-form{max-width:100%}.gen-preview{position:static;width:100%;flex:0 0 auto}.budget-strip{grid-template-columns:repeat(3,1fr);gap:10px}.pack-layout{grid-template-columns:1fr}.outfit-top-row{flex-direction:column;gap:16px}.weather-badge{flex:0 0 auto;width:100%}.sub-tabs{overflow-x:auto;scrollbar-width:none;flex-wrap:nowrap}.sub-tabs::-webkit-scrollbar{display:none}.sub-tab{white-space:nowrap;flex-shrink:0}.style-bar,.spot-mode-bar{flex-wrap:wrap}.sidebar{display:flex;position:fixed;top:0;left:0;height:100vh;z-index:160;transform:translate(-100%);transition:transform .25s ease;box-shadow:var(--shadow-lg)}.sidebar.open{transform:translate(0)}}@media (max-width: 540px){.page{padding:16px 14px 36px}h1{font-size:1.5rem}h2{font-size:1.15rem}.home-hero h1{font-size:1.55rem}.home-hero p{font-size:.9rem}.btn-lg{padding:12px 24px;font-size:.9rem}.trip-cards,.community-grid,.outfit-cards{grid-template-columns:1fr}.essentials-grid{grid-template-columns:1fr 1fr}.budget-strip{grid-template-columns:repeat(2,1fr)}.pack-items,.form-row{grid-template-columns:1fr}.detail-meta{gap:6px}.detail-meta span{font-size:.75rem;padding:4px 10px}.steps-bar{flex-wrap:wrap;gap:4px}.step-line{width:16px}.step-label{font-size:.74rem}.compare-metrics{gap:6px}.compare-card .price{font-size:1.4rem}.chip-row{gap:5px}.chip,.style-chip,.spot-mode{font-size:.78rem;padding:6px 12px}.pref-label{width:70px;font-size:.78rem}.nl-input{font-size:.8rem}.nl-modify{padding:10px 12px;gap:6px}.detail-panel{width:100vw;max-width:100vw;border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:90vh}.dp-hero-img{height:180px;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.dp-content{padding:16px 18px 28px}}@media (min-width: 1400px){.trip-cards,.community-grid,.outfit-cards{grid-template-columns:repeat(4,1fr)}.essentials-grid{grid-template-columns:repeat(6,1fr)}.spots-grid{grid-template-columns:repeat(3,1fr)}.dp-hero{height:200px}}@media (min-width: 1800px){.spots-grid{grid-template-columns:repeat(4,1fr)}.trip-cards,.community-grid,.outfit-cards{grid-template-columns:repeat(5,1fr)}.dp-hero{height:240px}}
