:root{color:#172429;background:#f5f7f6;font-family:Segoe UI Variable,Segoe UI,Arial,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;letter-spacing:0;--surface: #ffffff;--surface-soft: #edf2f0;--ink: #172429;--muted: #53666b;--border: #dbe4e1;--accent: #076d68;--accent-strong: #075853;--accent-soft: #ddf1ed;--highlight: #f9c35b;--warning: #a83c28;--warning-soft: #fff1e8;--success: #237452;--success-soft: #e7f5ec;--weather-top: #e5f4f2;--weather-bottom: #f7f8f4}*{box-sizing:border-box;letter-spacing:0}html,body{width:100%;max-width:100%;overflow-x:hidden}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;max-width:100%;overflow-x:hidden}button,input,select{font:inherit;color:inherit;letter-spacing:0}button{border:0;cursor:pointer}button:disabled{cursor:default;opacity:.55}h1,h2,p{margin:0}.theme-rain{--weather-top: #d7e8ed;--weather-bottom: #f4f7f7;--accent: #176783;--accent-soft: #dceef5}.theme-storm,.theme-wind{--weather-top: #dce3e6;--weather-bottom: #f4f5f2;--accent: #325a67;--accent-soft: #e0eaee}.theme-heat{--weather-top: #ffe9d5;--weather-bottom: #f6f7f5;--accent: #c54d2c;--accent-soft: #ffe7da}.theme-cold,.theme-snow{--weather-top: #e3f0f6;--weather-bottom: #fafcff;--accent: #17658b;--accent-soft: #e2f2fb}.theme-fog{--weather-top: #e1e9e8;--weather-bottom: #f5f7f5;--accent: #426467;--accent-soft: #e1ebeb}.theme-cloudy{--weather-top: #e7efed;--weather-bottom: #f7f8f6}.app.mode-dark{color-scheme:dark;--surface: #101719;--surface-soft: #182326;--ink: #edf7f4;--muted: #a9bbb8;--border: #283a3d;--accent: #5fcfc4;--accent-strong: #9de7df;--accent-soft: #173f3d;--highlight: #f3c95f;--warning: #f0a08c;--warning-soft: #3a211d;--success: #7bd8aa;--success-soft: #153126;--weather-top: #132528;--weather-bottom: #0b1113}.app.mode-dark.theme-rain{--weather-top: #142832;--weather-bottom: #0b1216}.app.mode-dark.theme-storm,.app.mode-dark.theme-wind{--weather-top: #182329;--weather-bottom: #0c1114}.app.mode-dark.theme-heat{--weather-top: #2e1c17;--weather-bottom: #101010;--accent: #f08b65;--accent-soft: #3a241d}.app.mode-dark.theme-cold,.app.mode-dark.theme-snow{--weather-top: #122634;--weather-bottom: #091116}.app.mode-dark.theme-fog,.app.mode-dark.theme-cloudy{--weather-top: #172527;--weather-bottom: #0d1213}.app{min-height:100vh;max-width:100%;overflow-x:hidden;background:var(--weather-bottom);color:var(--ink)}.topbar{height:68px;padding:0 24px;display:flex;align-items:center;justify-content:space-between;gap:20px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20}.brand{display:flex;align-items:center;gap:10px;font-size:21px;font-weight:700;color:var(--accent-strong);white-space:nowrap}.topbar-actions{display:flex;align-items:center;gap:8px}.location-button,.language-control{height:42px;display:inline-flex;align-items:center;gap:8px;padding:0 12px;border-radius:8px;background:var(--surface-soft);color:var(--ink)}.location-button span{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}.language-control select{border:0;background:transparent;font-weight:600;outline:none}.theme-switch{min-height:42px;display:inline-flex;align-items:center;gap:10px;padding:0 12px;border-radius:8px;background:var(--surface-soft);color:var(--ink);font-weight:700}.theme-switch-compact{width:58px;padding:0 8px;justify-content:center}.theme-switch-track{position:relative;width:42px;height:24px;display:inline-flex;align-items:center;justify-content:space-between;padding:0 5px;border-radius:999px;background:var(--accent-soft);color:var(--accent-strong)}.theme-switch-thumb{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:var(--surface);border:1px solid var(--border);transition:transform .16s ease}.theme-switch[aria-checked=true] .theme-switch-thumb{transform:translate(18px)}.icon-button{width:42px;height:42px;display:inline-grid;place-items:center;border-radius:8px;background:var(--surface-soft);color:var(--muted)}.location-button:hover,.icon-button:hover,.language-control:hover,.theme-switch:hover{background:var(--accent-soft);color:var(--accent-strong)}.tabs{height:58px;display:flex;justify-content:center;gap:4px;padding:8px 24px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:68px;z-index:19}.tabs button{height:42px;min-width:120px;padding:0 16px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;gap:8px;background:transparent;color:var(--muted);font-weight:600}.tabs svg{width:19px;height:19px}.tabs button.active{background:var(--accent-soft);color:var(--accent-strong)}main{max-width:1120px;margin:0 auto;padding:18px 24px 42px}.alerts-band{min-height:54px;display:flex;align-items:flex-start;gap:12px;padding:15px 18px;margin-bottom:16px;border:1px solid var(--border);border-radius:8px;font-size:14px}.alerts-band.clear{color:var(--success);background:var(--success-soft);border-color:#c9e8d6}.alerts-band.neutral{color:var(--muted);background:var(--surface)}.alerts-band.warning{color:var(--warning);background:var(--warning-soft);border-color:#f3cbb9}.alerts-band strong{display:block;margin-bottom:4px}.alerts-band p{margin-bottom:3px;font-weight:600}.alert-link{display:block;padding:4px 0;background:transparent;color:inherit;font-weight:650;text-align:left}.alert-link:hover{text-decoration:underline}.alerts-band small{color:var(--muted)}.weather-summary{position:relative;display:grid;grid-template-columns:minmax(330px,.86fr) minmax(520px,1.14fr);grid-template-areas:"summary outfit" "metrics outfit" "trend outfit" "environment outfit";gap:20px 28px;align-items:stretch;padding:26px 30px 72px;border-radius:8px;background:linear-gradient(118deg,var(--weather-top),var(--weather-bottom));border:1px solid var(--border)}.summary-title{grid-area:summary}.summary-day-nav{position:absolute;right:30px;bottom:24px;display:inline-flex;align-items:center;gap:10px;margin-bottom:0;z-index:2}.summary-day-nav p{color:var(--muted);font-size:14px;margin-bottom:0;font-weight:700}.day-nav-button{width:30px;min-height:30px;height:30px;padding:0;display:grid;place-items:center;color:var(--accent-strong);background:#ffffff9e;border-radius:8px}.day-nav-button:disabled{opacity:.45}.summary-heading{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:15px}.summary-title p{color:var(--muted);font-size:14px;margin-bottom:0;font-weight:700}.summary-title h1{font-size:32px;line-height:1.16;margin-bottom:0;min-width:0}.summary-weather-line{display:flex;align-items:center;flex-wrap:wrap;gap:8px 13px;min-height:32px}.condition-label{display:inline-flex;align-items:center;gap:8px;color:var(--accent-strong);font-weight:600}.daylight-info{display:inline-flex;align-items:center;gap:7px;color:var(--muted);font-size:13px;font-weight:650}.daylight-info svg{color:var(--accent)}.temperature{flex:0 0 auto;display:flex;flex-direction:column;text-align:right}.temperature strong{font-size:64px;font-weight:500;line-height:.95}.temperature span{color:var(--muted);margin-top:8px;font-weight:600}.metric-row{grid-area:metrics;display:grid;grid-template-columns:repeat(3,minmax(100px,142px));gap:8px}.weather-trend{grid-area:trend;align-self:end;padding:14px 16px;background:#ffffff8a;border:1px solid rgba(255,255,255,.78);border-radius:8px}.environment-strip{grid-area:environment;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.environment-item{min-height:78px;display:grid;grid-template-columns:24px 1fr;grid-template-rows:auto auto auto;column-gap:8px;padding:11px 12px;background:#ffffff94;border:1px solid rgba(255,255,255,.82);border-radius:8px}.environment-item svg{grid-row:1 / -1;align-self:center;width:19px;color:var(--accent)}.environment-item span,.environment-item small{color:var(--muted);font-size:12px}.environment-item strong{font-size:14px;line-height:1.25}.app.mode-dark .day-nav-button,.app.mode-dark .weather-trend,.app.mode-dark .environment-item,.app.mode-dark .metric,.app.mode-dark .style-dayparts span,.app.mode-dark .hour-tile,.app.mode-dark .day-tile,.app.mode-dark .memory-fact,.app.mode-dark .route-point,.app.mode-dark .service-kpis>div{background:#101719b8;border-color:#9de7df29}.app.mode-dark .outfit-narrative{border-top-color:#9de7df29}.weather-trend strong{display:block;margin-bottom:5px;color:var(--accent-strong);font-size:13px}.weather-trend p{color:var(--ink);font-size:15px;line-height:1.35}.metric{min-height:64px;display:grid;grid-template-columns:24px 1fr;grid-template-rows:1fr 1fr;column-gap:7px;padding:11px 12px;background:#ffffffb3;border-radius:8px}.metric svg{grid-row:1 / -1;align-self:center;width:19px;color:var(--accent)}.metric span{color:var(--muted);font-size:12px}.metric strong{font-size:15px}.forecast-band{padding:28px 0 0}.home-disclaimer{max-width:840px;margin:20px auto 0;color:var(--muted);font-size:12px;line-height:1.45;text-align:center}.forecast-slider{margin-bottom:22px}.forecast-slider:last-child{margin-bottom:26px}.forecast-slider-heading{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:13px}.forecast-band h2,.memory-preview h2,.outfit-copy h2,.summary-outfit h2,.route-results h2{font-size:18px;line-height:1.3;margin-bottom:13px;display:flex;align-items:center;gap:8px}.forecast-slider-heading h2{margin-bottom:0}.forecast-title-actions{display:flex;align-items:center;gap:8px;min-width:0}.slider-actions{display:flex;gap:6px}.slider-button,.view-toggle-button{width:34px;min-height:34px;height:34px;padding:0;display:grid;place-items:center;color:var(--accent-strong);background:var(--surface);border:1px solid var(--border);border-radius:8px}.view-toggle-button{color:var(--ink)}.slider-button:not(:disabled):hover,.view-toggle-button:hover{background:var(--surface-soft)}.slider-button:disabled{opacity:.38;cursor:not-allowed}.hourly-list{display:flex;gap:8px;overflow-x:auto;padding:1px;scrollbar-width:none;scroll-snap-type:x mandatory}.hour-day-group{flex:0 0 auto;scroll-snap-align:start}.hour-day-label{margin:0 0 8px;padding:0 3px 7px;border-bottom:2px solid var(--accent-soft);color:var(--accent-strong);font-size:12px;font-weight:650;text-transform:capitalize}.hour-day-hours{display:flex;gap:8px}.hourly-list::-webkit-scrollbar,.daily-list::-webkit-scrollbar{display:none}.hour-tile{flex:0 0 84px;min-height:112px;padding:12px 8px;border:1px solid var(--border);border-radius:8px;background:var(--surface);display:flex;flex-direction:column;align-items:center;justify-content:space-between;scroll-snap-align:start}.hour-tile time,.hour-tile span{color:var(--muted);font-size:12px}.hour-tile svg{color:var(--accent)}.hourly-bars{min-height:220px;display:flex;align-items:flex-end;gap:9px;overflow-x:auto;padding:10px 2px 2px;scrollbar-width:none;scroll-snap-type:x mandatory}.hourly-bars::-webkit-scrollbar{display:none}.hour-bar-tile{flex:0 0 56px;min-height:198px;display:grid;grid-template-rows:23px 1fr 23px 18px;justify-items:center;align-items:end;gap:5px;scroll-snap-align:start}.hour-bar-tile strong{align-self:start;font-size:13px}.hour-bar{position:relative;width:28px;height:var(--bar-height);min-height:42px;max-height:140px;overflow:hidden;border-radius:999px 999px 7px 7px;background:#ffffff9e;border:1px solid rgba(255,255,255,.84)}.hour-bar-temperature{position:absolute;inset:0;background:linear-gradient(180deg,var(--temperature-color-soft),var(--temperature-color))}.hour-bar-rain{position:absolute;left:0;right:0;bottom:0;height:var(--rain-height);background:linear-gradient(180deg,#2390b852,#006c8fd1)}.hour-bar-tile svg{color:var(--accent)}.hour-bar-tile time{color:var(--muted);font-size:12px}.daily-list{display:flex;gap:8px;overflow-x:auto;padding:1px;scrollbar-width:none;scroll-snap-type:x mandatory}.day-tile{flex:0 0 160px;min-height:105px;padding:12px;display:flex;flex-direction:column;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:8px;font-size:13px;scroll-snap-align:start}.day-tile header,.day-values{display:flex;align-items:center;justify-content:space-between;gap:6px}.day-tile header svg{color:var(--accent);flex:0 0 auto}.day-values small{margin-right:auto}.day-tile small,.day-tile .rain{color:var(--muted)}.day-tile .rain{display:inline-flex;align-items:center;gap:3px}.outfit-band{display:grid;grid-template-columns:minmax(280px,1fr) minmax(250px,390px);min-height:300px;margin:12px 0 22px;background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden}.outfit-copy{padding:29px 30px;display:flex;flex-direction:column;justify-content:center;gap:16px}.outfit-copy h2{margin:0}.outfit-copy .lifestyle{font-size:25px;line-height:1.26;font-weight:650}.garments{display:flex;flex-wrap:wrap;gap:8px}.garments span{padding:7px 11px;background:var(--accent-soft);color:var(--accent-strong);border-radius:6px;font-size:14px;font-weight:600}.outfit-copy small{color:var(--muted)}.outfit-band img{width:100%;height:100%;min-height:300px;object-fit:cover}.summary-outfit{grid-area:outfit;display:grid;grid-template-columns:minmax(190px,240px) minmax(0,1fr);gap:22px;align-items:stretch;min-height:330px}.summary-outfit img{width:100%;height:100%;min-height:310px;aspect-ratio:4 / 5;object-fit:cover;border-radius:7px;background:var(--surface-soft)}.summary-outfit-copy{min-width:0;display:flex;flex-direction:column;justify-content:center;gap:12px}.summary-outfit h2{margin-bottom:8px}.summary-outfit .lifestyle{max-width:42rem;font-size:21px;line-height:1.25;font-weight:650}.summary-outfit small{color:var(--muted)}.outfit-narrative{margin-top:2px;padding-top:11px;border-top:1px solid rgba(7,72,74,.14);color:var(--muted);font-size:14px;line-height:1.42}.outfit-controls{display:grid;grid-template-columns:repeat(2,minmax(132px,146px));gap:10px}.outfit-controls label{min-width:135px;display:flex;flex-direction:column;gap:6px;color:var(--muted);font-size:12px;font-weight:650}.outfit-controls select{height:38px;padding:0 10px;border:1px solid var(--border);background:var(--surface);color:var(--ink);border-radius:8px}.memory-preview{padding:21px 25px;background:var(--surface);border:1px solid var(--border);border-radius:8px}.memory-preview-heading{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.memory-preview p{margin-top:7px;color:var(--muted)}.empty-location{min-height:calc(100vh - 185px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;text-align:center;color:var(--muted)}.empty-location svg{color:var(--accent)}.command-row{display:flex;gap:10px}.command-row button,.primary{min-height:44px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 18px;border-radius:8px;background:var(--surface);border:1px solid var(--border);font-weight:600}.primary{background:var(--accent);color:#fff;border-color:var(--accent)}.primary:hover{background:var(--accent-strong)}.section-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding-bottom:22px}.section-header h1,.settings-view h1{font-size:27px;margin-bottom:7px}.section-header p{color:var(--muted)}.memory-view,.settings-view{max-width:770px;margin:0 auto;padding-top:12px}.route-view{max-width:1060px;margin:0 auto;padding-top:12px}.route-planner-panel,.route-results{max-width:770px;margin-right:auto;margin-left:auto}.world-view{max-width:1060px;margin:0 auto;padding-top:12px}.map-view{padding-top:12px}.date-field,.time-field,.settings-view label{display:flex;flex-direction:column;gap:8px;margin-bottom:20px;color:var(--muted);font-size:14px;font-weight:600}.settings-switch-row{max-width:300px;min-height:56px;display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:20px;color:var(--muted);font-size:14px;font-weight:700}.date-field input,.time-field input,.settings-view select{height:48px;max-width:300px;padding:0 13px;border:1px solid var(--border);background:var(--surface);border-radius:8px;color:var(--ink)}.world-header{align-items:center}.world-count{min-width:150px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 14px;background:var(--accent-soft);color:var(--accent-strong);border-radius:8px}.world-controls{display:grid;grid-template-columns:minmax(220px,1fr) minmax(180px,260px);gap:12px;margin-bottom:18px}.world-controls label{display:flex;flex-direction:column;gap:8px;color:var(--muted);font-size:14px;font-weight:650}.world-controls input,.world-controls select{height:48px;padding:0 13px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--ink)}.world-grid{display:grid;grid-template-columns:minmax(240px,310px) minmax(0,1fr);gap:18px;align-items:start}.world-list{max-height:760px;display:grid;gap:8px;overflow:auto;padding-right:4px}.world-card{display:grid;gap:3px;width:100%;padding:13px 14px;text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:8px}.world-card span{color:var(--muted);font-size:13px}.world-card strong{color:var(--ink);font-size:15px}.world-card small{color:var(--accent);font-weight:650}.world-card:hover,.world-card.active{border-color:var(--accent);background:var(--accent-soft)}.world-detail{padding:24px;background:linear-gradient(145deg,#ffffff,var(--weather-top));border:1px solid var(--border);border-radius:8px}.world-detail header{display:flex;justify-content:space-between;gap:16px;margin-bottom:18px}.world-detail h2{font-size:34px;line-height:1.05;margin:5px 0}.world-detail p,.world-region,.world-source{color:var(--muted)}.world-region{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.world-badge{align-self:flex-start;white-space:nowrap;padding:8px 11px;background:var(--surface);color:var(--accent-strong);border:1px solid var(--border);border-radius:999px;font-size:13px;font-weight:700}.world-metrics{display:grid;grid-template-columns:repeat(2,minmax(140px,1fr));gap:8px;margin:0 0 22px}.world-forecast{margin:0 0 22px;padding:17px;background:#ffffffc2;border:1px solid rgba(255,255,255,.88);border-radius:8px}.world-forecast h3{margin:0;font-size:18px}.world-forecast-days{align-self:flex-start;padding:7px 10px;border-radius:999px;background:var(--accent-soft);color:var(--accent-strong);font-size:12px;font-weight:800;white-space:nowrap}.world-current{display:grid;grid-template-columns:40px minmax(0,1fr) auto;gap:12px;align-items:center;margin-bottom:14px;padding:13px;background:var(--accent-soft);color:var(--accent-strong);border-radius:8px}.world-current strong{display:block;font-size:24px;line-height:1.1}.world-current span,.world-current small{font-size:13px;font-weight:650}.world-daily-forecast{display:grid;grid-template-columns:repeat(7,minmax(82px,1fr));gap:8px;overflow-x:auto}.world-day{min-width:82px;display:grid;gap:5px;justify-items:center;padding:12px 9px;background:var(--surface);border:1px solid var(--border);border-radius:8px;text-align:center}.world-day time,.world-day span,.world-day small{color:var(--muted);font-size:12px}.world-day strong{display:grid;gap:2px;font-size:17px}.world-day>span{display:grid;gap:2px}.world-day strong small,.world-day>span small{color:var(--muted);font-size:10px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.world-chart{margin-top:18px;padding:17px;background:#ffffffad;border:1px solid rgba(255,255,255,.82);border-radius:8px}.world-chart h3{margin:0 0 14px;font-size:16px}.world-bars{display:grid;grid-template-columns:repeat(12,minmax(38px,1fr));align-items:end;gap:7px;overflow-x:auto}.world-bar{min-width:38px;display:grid;grid-template-rows:22px 118px 18px;align-items:end;justify-items:center;gap:5px}.world-bar span,.world-bar small{color:var(--muted);font-size:11px;white-space:nowrap}.world-bar i{width:22px;height:var(--bar-height);min-height:6px;max-height:110px;border-radius:999px 999px 6px 6px;background:linear-gradient(180deg,#f9c35b,#c54d2c)}.world-chart.rain .world-bar i{background:linear-gradient(180deg,#9ed7f0,#176783)}.world-source,.world-empty{margin-top:16px;font-size:13px}.observation{min-height:184px;padding:25px;background:var(--surface);border:1px solid var(--border);border-radius:8px}.observed-temperature{display:flex;align-items:baseline;gap:12px;margin-bottom:19px;color:var(--accent)}.observed-temperature strong{font-size:44px;color:var(--ink)}.observed-temperature span{font-size:22px;color:var(--muted)}.observation p{padding:6px 0}.style-dayparts{display:grid;gap:7px;margin-top:4px}.style-dayparts span{display:flex;flex-wrap:wrap;gap:6px;align-items:baseline;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:#ffffffad;color:var(--muted);font-size:13px}.style-dayparts strong{color:var(--ink);font-size:12px;text-transform:uppercase}.memory-query-error{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.memory-query-error .error-state{flex:1 1 360px;padding:18px}.climate-context{margin-top:20px;padding:22px;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.section-header.compact{align-items:center;padding-bottom:0}.section-header.compact h2{margin:0 0 5px;font-size:18px}.section-header.compact p{max-width:400px;font-size:14px}.context-facts{margin-top:18px;padding-top:14px;border-top:1px solid var(--border);color:var(--muted)}.memory-facts-list p+p,.memory-insights p+p{margin-top:9px}.memory-chart-legend{margin:18px 0 4px;font-size:13px;font-weight:700;color:var(--accent-strong)}.memory-chart{margin-top:16px;padding:16px;border:1px solid var(--border);border-radius:8px;background:#ffffffb8}.memory-chart h3,.memory-insights h3{margin:0 0 14px;color:var(--ink);font-size:16px}.memory-bars{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(58px,72px);align-items:end;gap:8px;overflow-x:auto;padding-bottom:6px}.memory-bar{min-width:58px;display:grid;grid-template-rows:28px 136px 18px;align-items:end;justify-items:center;gap:5px;text-align:center}.memory-bar span,.memory-bar small{color:var(--muted);font-size:11px;white-space:nowrap}.memory-bar i{width:24px;height:var(--bar-height);min-height:6px;max-height:130px;border-radius:999px 999px 6px 6px;background:linear-gradient(180deg,#f9c35b,#c54d2c)}.memory-chart.rain .memory-bar i{background:linear-gradient(180deg,#9ed7f0,#176783)}.memory-insights{margin-top:16px;padding:16px;border:1px solid var(--border);border-radius:8px;background:var(--accent-soft)}.route-points{position:relative;display:flex;flex-direction:column;gap:8px;margin-bottom:17px}.route-point{min-height:48px;display:flex;align-items:center;gap:10px;padding:0 12px;border:1px solid var(--border);background:var(--surface);border-radius:8px;font-weight:600}.route-point svg{color:var(--accent)}.route-point button{width:34px;height:34px;display:grid;place-items:center;margin-left:auto;color:var(--muted);background:transparent}.search-field{min-height:50px;display:flex;align-items:center;gap:10px;padding:0 14px;margin-bottom:8px;background:var(--surface);border:1px solid var(--border);border-radius:8px;font-weight:600;color:var(--muted)}.search-field input{flex:1;min-width:0;height:44px;border:0;outline:none;background:transparent}.suggestions{display:flex;flex-direction:column;gap:3px;padding:6px;margin-bottom:12px;background:var(--surface);border:1px solid var(--border);border-radius:8px}.suggestions button{min-height:42px;display:flex;align-items:center;gap:9px;padding:0 10px;background:transparent;text-align:left}.suggestions button:hover{background:var(--surface-soft)}.route-view .analyze{margin-top:16px}.route-hint{display:inline-block;margin-left:16px;color:var(--muted);font-size:13px}.route-results{margin-top:30px}.route-map-panel{margin-top:24px}.route-map-panel .map-view{padding-top:0}.route-map-panel .map-surface{height:clamp(340px,48vh,560px)}.route-spatial-alerts{padding:14px 16px;margin-bottom:14px;border-radius:8px;border:1px solid #f3cbb9;background:var(--warning-soft)}.route-spatial-alerts h3{margin:0 0 9px;color:var(--warning);font-size:15px}.route-verdict{padding:14px 16px;margin-bottom:14px;border-radius:8px;color:var(--success);background:var(--success-soft)}.route-verdict p{padding-top:5px;font-size:13px}.route-verdict.verdict-caution,.route-verdict.verdict-changeTime{color:#925112;background:#fff2e1}.route-verdict.verdict-avoid,.route-verdict.verdict-uncertain{color:var(--warning);background:var(--warning-soft)}.stop-result{display:grid;grid-template-columns:76px 1fr auto;align-items:center;gap:8px 16px;min-height:72px;padding:13px 15px;margin-bottom:8px;border-left:4px solid var(--success);background:var(--surface);border-radius:6px}.stop-result time{color:var(--muted);font-weight:600}.stop-result p{grid-column:2 / -1;color:var(--muted);font-size:13px}.stop-alert-link{grid-column:2 / -1;display:inline-flex;align-items:center;gap:6px;width:fit-content;padding:5px 0;background:transparent;color:var(--warning);font-size:13px;font-weight:650;text-align:left}.stop-alert-link:hover{text-decoration:underline}.stop-result.severity-medium{border-left-color:#cb7620}.stop-result.severity-high{border-left-color:var(--warning)}.settings-view h1{margin-bottom:27px}.settings-view label small{color:var(--muted);font-weight:400}.location-again{margin:4px 8px 32px 0}.secondary-action,.danger-action{min-height:44px;display:inline-flex;align-items:center;gap:8px;padding:0 16px;border-radius:8px;font-weight:600;background:var(--surface);border:1px solid var(--border)}.secondary-action:hover{background:var(--surface-soft)}.danger-action{margin-top:15px;color:var(--warning);border-color:#e8c7c1;background:var(--warning-soft)}.data-source{padding:23px 0;border-top:1px solid var(--border)}.data-source h2{margin:0 0 14px;font-size:18px}.data-source p{margin-bottom:8px;color:var(--muted)}.service-status-panel{padding:23px 0 0;border-top:1px solid var(--border)}.service-status-panel header{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:15px}.service-status-panel h2{margin:0 0 5px;font-size:18px}.service-status-panel p,.service-status-panel small{color:var(--muted)}.service-alert{color:var(--warning)!important;font-weight:700}.service-kpis,.service-family-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:14px}.service-family-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.service-kpis div,.service-family{min-height:92px;padding:13px;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.service-kpis span,.service-family span,.service-job span{color:var(--muted);font-size:12px}.service-kpis strong{display:block;margin:4px 0;font-size:19px}.service-kpis small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.service-family{display:grid;gap:5px}.service-family.has-alert{border-color:#e8c7c1;background:var(--warning-soft)}.service-family small{color:var(--warning);font-weight:650}.service-jobs{margin-top:4px}.service-jobs h3{margin:0 0 9px;font-size:15px}.service-job{min-height:38px;display:grid;grid-template-columns:minmax(90px,1fr) minmax(120px,1fr) 80px 70px;align-items:center;gap:8px;padding:8px 0;border-top:1px solid var(--border)}.service-job.status-failed span:nth-child(3),.service-job.status-limited span:nth-child(3),.service-job.status-interrupted span:nth-child(3){color:var(--warning);font-weight:700}.map-controls{min-height:54px;display:flex;align-items:center;gap:8px;margin-bottom:12px}.map-controls label{min-height:44px;display:inline-flex;align-items:center;gap:8px;padding:0 13px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--muted);font-weight:600;font-size:14px}.map-controls label:has(input:checked){color:var(--accent-strong);background:var(--accent-soft);border-color:#beddd7}.map-controls input{accent-color:var(--accent)}.radar-timeline{margin-bottom:12px;padding:12px 15px 10px;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.radar-timeline-heading,.radar-timeline-range{display:flex;align-items:center;justify-content:space-between;gap:12px}.radar-timeline-heading{margin-bottom:9px;font-size:14px}.radar-timeline-heading span{display:inline-flex;align-items:center;gap:7px;color:var(--muted);font-weight:600}.radar-timeline-heading strong{color:var(--ink);font-size:14px}.timeline-actions{display:inline-flex;align-items:center;gap:6px}.timeline-actions strong{margin-right:4px}.timeline-actions button{width:31px;min-height:31px;height:31px;display:inline-grid;place-items:center;padding:0;border:1px solid var(--border);border-radius:7px;background:var(--surface);color:var(--accent-strong)}.timeline-actions button:not(:disabled):hover{background:var(--accent-soft)}.timeline-actions .timeline-toggle.active{border-color:#beddd7;background:var(--accent-soft)}.timeline-actions button:disabled{opacity:.4}.radar-timeline input[type=range]{width:100%;height:24px;margin:0;accent-color:var(--accent)}.radar-timeline-range{color:var(--muted);font-size:12px}.precipitation-mode{display:flex;align-items:center;flex-wrap:wrap;gap:6px;margin-bottom:12px}.precipitation-mode button{min-height:38px;padding:0 14px;border:1px solid var(--border);border-radius:20px;background:var(--surface);color:var(--muted);font-size:13px;font-weight:600;line-height:1.2}.precipitation-mode button.active{border-color:#beddd7;background:var(--accent-soft);color:var(--accent-strong)}.forecast-model-note{margin:-3px 0 12px;padding:10px 13px;border-radius:8px;background:#f1f8f6;color:var(--muted);font-size:12px;line-height:1.4}.forecast-model-note a{display:inline-flex;align-items:center;gap:4px;color:var(--accent-strong);font-weight:600}.map-surface{position:relative;width:100%;height:clamp(360px,calc(100vh - 388px),610px);overflow:hidden;border:1px solid var(--border);border-radius:8px;background:var(--surface-soft)}.map-surface .map-canvas{position:absolute;inset:0;width:100%;height:100%}.map-status{display:flex;flex-wrap:wrap;gap:8px 18px;padding:13px 2px 9px;color:var(--muted);font-size:13px}.map-status .map-error{color:var(--warning)}.map-error-row{display:inline-flex;align-items:center;gap:8px}.map-error-row button{min-height:30px;display:inline-flex;align-items:center;gap:5px;padding:0 10px;border:1px solid #e8c7c1;border-radius:8px;background:var(--warning-soft);color:var(--warning);font-weight:600}.map-error-row button:hover:not(:disabled){background:#ffe5db}.map-legend{display:flex;flex-wrap:wrap;gap:8px 20px;min-height:40px;align-items:center;color:var(--muted);font-size:13px}.map-legend span{display:inline-flex;align-items:center;gap:7px}.map-legend i{width:18px;height:10px;display:inline-block;border-radius:3px;background:#ebbc2c}.map-legend i.radar{background:#1c8de0}.map-legend i.orange{background:#ec7c27}.map-legend i.red{background:#c73532}.maplibregl-ctrl-group{border-radius:8px;overflow:hidden}.error-state{padding:26px 18px;color:var(--warning);background:var(--warning-soft);border-radius:8px}.loading-state{padding:42px 18px;color:var(--muted);text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:8px}.modal-backdrop{position:fixed;inset:0;z-index:50;display:grid;place-items:center;padding:16px;background:#0e1d2166}.picker,.station-dialog{width:min(480px,100%);max-height:min(640px,calc(100vh - 32px));padding:21px;background:var(--surface);border-radius:8px;overflow:auto}.picker header,.station-dialog header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:15px}.picker h2,.station-dialog h2{font-size:21px}.picker p,.station-dialog p{color:var(--muted);line-height:1.5;margin-bottom:18px}.station-dialog small{color:var(--muted)}.alert-dialog strong{display:block;margin-bottom:10px;color:var(--warning)}.search-box{height:50px;display:flex;align-items:center;gap:9px;padding:0 13px;border:1px solid var(--border);border-radius:8px}.search-box svg{color:var(--muted)}.search-box input{flex:1;min-width:0;border:0;outline:none}.picker-results{padding-top:10px}.picker-results h3{padding:4px 13px 7px;color:var(--muted);font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.picker-results button{width:100%;min-height:53px;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;padding:6px 13px;border-radius:6px;background:transparent}.picker-results button:hover{background:var(--surface-soft)}.picker-results small{color:var(--muted)}@media(max-width:760px){.topbar{height:60px;padding:0 14px;gap:8px}.brand span{display:none}.location-button{max-width:calc(100vw - 196px);height:40px;padding:0 9px}.location-button span{max-width:none}.language-control{display:none}.icon-button{width:40px;height:40px}.theme-switch-compact{width:50px;min-height:40px;padding:0 5px}main{width:100%;max-width:100vw;overflow-x:hidden;padding:12px 12px 86px}.tabs{position:fixed;inset:auto 0 0;width:100vw;max-width:100vw;height:68px;overflow:hidden;padding:6px 5px calc(6px + env(safe-area-inset-bottom));gap:0;border-top:1px solid var(--border);border-bottom:0;z-index:30}.tabs button{min-width:0;flex:1;height:55px;padding:4px 2px;gap:4px;flex-direction:column;font-size:11px;overflow:hidden}.tabs button span{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.alerts-band{padding:12px;margin-bottom:11px}.weather-summary{grid-template-columns:1fr auto;grid-template-areas:"summary summary" "metrics metrics" "trend trend" "environment environment" "outfit outfit";padding:20px 18px 72px;gap:18px 12px}.summary-heading{align-items:flex-start;gap:12px;margin-top:14px}.summary-day-nav{gap:8px;right:18px;top:16px;bottom:auto}.day-nav-button{width:28px;min-height:28px;height:28px}.summary-title h1{font-size:25px}.temperature strong{font-size:48px}.metric-row{grid-template-columns:repeat(3,1fr)}.environment-strip{grid-template-columns:1fr}.metric{min-height:61px;padding:8px;grid-template-columns:19px 1fr;column-gap:5px}.metric strong{font-size:13px}.summary-outfit{grid-template-columns:96px minmax(0,1fr);gap:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.68);min-height:0}.summary-outfit img{min-height:0}.summary-outfit .lifestyle{font-size:16px}.outfit-narrative{font-size:13px}.summary-outfit h2{font-size:15px}.outfit-controls{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.outfit-controls label{min-width:0}.forecast-band{padding-top:22px}.daily-list{padding-bottom:1px}.day-tile{flex:0 0 112px}.outfit-band{display:flex;flex-direction:column-reverse;margin-top:4px}.outfit-band img{height:auto;min-height:0;object-fit:contain}.outfit-copy{padding:20px 18px 22px;gap:12px}.outfit-copy .lifestyle{font-size:21px}.radar-timeline-heading{align-items:flex-start;flex-direction:column}.memory-preview{padding:18px}.memory-view,.route-view,.settings-view,.world-view,.map-view{padding-top:8px}.service-kpis,.service-family-grid{grid-template-columns:1fr}.service-job{grid-template-columns:1fr 1fr}.world-view,.world-controls,.world-grid,.world-detail,.world-forecast,.world-chart{min-width:0;max-width:100%}.world-header{display:block}.world-count{margin-top:12px}.world-controls,.world-grid,.world-metrics{grid-template-columns:1fr}.world-controls label:last-child,.world-list{width:min(100%,260px);max-width:260px;justify-self:start}.world-current{grid-template-columns:36px minmax(0,1fr)}.world-current small{grid-column:1 / -1}.world-daily-forecast{width:100%;max-width:100%;grid-template-columns:repeat(7,92px)}.world-list{max-height:340px;grid-template-columns:1fr;padding-right:0}.world-card{min-height:auto}.world-detail{padding:18px}.world-detail header{display:block}.world-detail h2{font-size:28px}.world-badge{display:inline-flex;margin-top:12px}.world-bars{width:100%;max-width:100%;grid-template-columns:repeat(12,42px)}.section-header h1,.settings-view h1{font-size:24px}.stop-result{grid-template-columns:64px 1fr}.stop-result>span{grid-column:2}.route-hint{display:block;margin:12px 0 0}.section-header.compact{display:block}.section-header.compact .primary{margin-top:14px}.map-controls{overflow-x:auto;padding-bottom:3px;scrollbar-width:none}.map-controls::-webkit-scrollbar{display:none}.map-controls label{flex:0 0 auto}.map-surface{height:calc(100vh - 382px);min-height:330px}}
