:root{color-scheme:dark;--bg:#000;--page-bg:#191919;--surface:rgba(255,255,255,0.12);--surface-strong:rgba(255,255,255,0.18);--text:#fff;--muted:rgba(255,255,255,0.68);--summary-detail-text:rgba(255,255,255,0.68);--faint:rgba(255,255,255,0.4);--accent:#ffbe53;--rain:#4498f9;--line:rgba(255,255,255,0.18);--detail-divider:rgba(255,255,255,0.34);--forecast-secondary:lightgray;--forecast-icon-bg:rgba(255,255,255,0.15);--danger:#ff4343;--padding:16px;--gutter:20px}html[data-theme="light"],body[data-theme="light"]{color-scheme:light;--bg:#fff;--page-bg:#d8d8d8;--surface:rgba(0,0,0,0.08);--surface-strong:rgba(0,0,0,0.14);--text:#050505;--muted:rgba(0,0,0,0.62);--summary-detail-text:rgba(0,0,0,0.62);--faint:rgba(0,0,0,0.42);--line:rgba(0,0,0,0.16);--detail-divider:rgba(0,0,0,0.2);--forecast-secondary:darkgray;--forecast-icon-bg:rgba(225,225,225,0.5)}*{box-sizing:border-box}html,body{min-height:100%}body{margin:0;min-width:380px;background:var(--page-bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","Segoe UI",sans-serif}button,input{font:inherit}.app-shell{width:min(100%,1280px);min-height:100vh;margin:0 auto;padding:max(0px,env(safe-area-inset-top)) 0 max(32px,env(safe-area-inset-bottom));background:var(--bg)}.topbar{position:sticky;top:0;z-index:10;width:100vw;height:56px;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw);background:var(--bg);border-bottom:0;backdrop-filter:blur(18px)}.search{display:grid;grid-template-columns:auto minmax(180px,380px);gap:18px;align-items:center;width:min(100%,1280px);height:56px;margin:0 auto;padding:0 var(--padding);justify-content:space-between}.search-area{position:relative;min-width:0}.brand-mark{display:inline-flex;align-items:center;gap:8px;min-width:0;color:var(--text);font-family:"SF Pro Display",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-size:20px;font-weight:400;white-space:nowrap}.brand-logo{width:24px;height:24px;display:block}.search-box{display:grid;grid-template-columns:18px minmax(0,1fr) 16px;gap:10px;align-items:center;min-width:0;height:34px;padding:0 12px;border-radius:3px;background:#f8f8f8;color:#666}.search-loading{padding:12px 14px;color:var(--muted);font-size:14px}.search-inline-action{margin-left:10px;border:0;border-radius:6px;padding:4px 10px;background:var(--surface-strong);color:var(--text);font-size:13px;font-weight:700;cursor:pointer}.search-results{position:absolute;top:calc(100%+8px);left:0;right:0;z-index:30;overflow:hidden;border-radius:6px;background:color-mix(in srgb,var(--bg) 94%,var(--surface-strong));box-shadow:0 14px 36px rgba(0,0,0,0.42);border:1px solid var(--line)}.search-result{width:100%;border:0;display:grid;grid-template-columns:minmax(0,1fr) 28px;gap:2px;align-items:center;padding:10px 12px;background:transparent;color:var(--text);text-align:left;cursor:pointer}.search-result:hover,.search-result.is-active{background:var(--surface-strong)}.search-result-title{display:block;font-size:14px;font-weight:500}.search-result-subtitle{display:block;color:var(--muted);font-size:12px}.search-result-delete{width:28px;height:28px;border:0;border-radius:50%;background:transparent;color:var(--muted);cursor:pointer;font-size:20px;line-height:1}.search-result-delete:hover{background:var(--surface-strong);color:var(--text)}.search-box svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.search-spinner{width:14px;height:14px;border:2px solid rgba(0,0,0,0.18);border-top-color:rgba(0,0,0,0.62);border-radius:50%;opacity:0;animation:search-spin 0.75s linear infinite}.search-area.is-searching .search-spinner{opacity:1}.search input{width:100%;min-width:0;height:32px;border:0;border-radius:0;outline:0;padding:0;background:transparent;color:#1d1d1d;text-align:left;font-size:14px;font-weight:400}@keyframes search-spin{to{transform:rotate(360deg)}}.search input::placeholder{color:#8a8a8a}.nav-button{display:none;width:0;height:0;border:0;background:transparent;color:var(--text);opacity:0;pointer-events:none;overflow:hidden;font-size:17px;line-height:1}.nav-button svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}.nav-button:active{transform:scale(0.97)}@media (max-width:640px){.search{grid-template-columns:1fr;gap:8px;height:auto;padding:8px var(--padding)}.topbar{height:auto}.brand-mark{justify-self:center;font-size:18px}.search-box{width:100%}.search-area{width:100%}}.status{margin:0 0 14px;padding:10px 12px;border-radius:8px;background:var(--surface);color:var(--muted);text-align:center;font-size:15px}.state-card{grid-column:1 / -1;justify-self:center;width:min(720px,calc(100% - (var(--padding) * 2)));margin:0 auto;padding:36px 18px;border-radius:8px;background:var(--surface);color:var(--muted);text-align:center}.state-title{margin:0;color:var(--text);font-size:20px;font-weight:700}.state-copy{margin:10px auto 0;max-width:420px;font-size:15px;line-height:1.45}.state-action{margin-top:18px;height:34px;border:0;border-radius:8px;padding:0 18px;background:var(--surface-strong);color:var(--text);font-weight:700;cursor:pointer}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}.weather-feed{display:grid;grid-template-columns:1fr;gap:0;align-items:start}.column{display:grid;gap:0;align-content:start}.photo-card,.temperature-card,.text-card,.panel,.source-card{overflow:hidden}.photo-card{margin:0 var(--padding);aspect-ratio:1 / 1;height:auto;border-radius:8px;background:var(--surface);position:relative}.photo-image{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.photo-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(0,0,0,0.42));pointer-events:none}.photo-caption{position:absolute;left:14px;right:14px;bottom:12px;display:flex;justify-content:space-between;gap:12px;color:rgba(255,255,255,0.82);font-size:13px;z-index:1}.photo-state,.radar-state{position:absolute;inset:0;z-index:2;display:grid;align-content:center;justify-items:center;gap:10px;padding:18px;background:color-mix(in srgb,var(--bg) 66%,transparent);color:var(--text);text-align:center;font-size:14px;font-weight:700}.photo-state .state-action,.radar-state .state-action{margin-top:0;height:30px;font-size:13px}.photo-state.is-loading,.radar-state.is-loading{color:rgba(255,255,255,0.82)}.temperature-card{display:grid;gap:0;min-height:86px;padding:0 var(--padding);align-content:center}.temperature-row{display:flex;align-items:center;gap:6px;min-height:86px}.temp-big{font-size:72px;font-weight:100;line-height:0.95;letter-spacing:0}.temp-range{display:inline-grid;grid-template-columns:auto auto auto;align-items:center;column-gap:0;margin-left:2px;transform:translateY(0)}.temp-small,.temp-slash{font-size:27px;font-weight:100;color:var(--text);line-height:1}.temp-max{transform:translateY(-9px)}.temp-slash{transform:translateY(1px);margin:0 1px}.temp-min{transform:translateY(11px)}.alert-pill{position:relative;z-index:2;flex:0 0 28px;width:28px;height:28px;border:0;border-radius:50%;display:inline-grid;place-items:center;margin-left:auto;background:var(--danger);color:#fff;font-size:15px;font-weight:700;cursor:pointer}.text-card .date{padding:0 var(--padding);color:var(--muted);font-size:15px;font-weight:300;text-transform:uppercase}.text-card .city{padding:0 var(--padding);margin-top:5px;font-size:22px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.text-card .summary{padding:0 var(--padding);margin-top:3px;font-size:16px;line-height:1.4}.text-card .detail{padding:0 var(--padding);margin-top:12px;color:var(--summary-detail-text);font-size:15px;line-height:1.45}.detail-trigger-card{position:relative}.detail-trigger{position:absolute;inset:0;z-index:1;border:0;padding:0;background:transparent;cursor:pointer}.detail-trigger-card:hover .temp-big,.detail-trigger-card:hover .detail{opacity:0.86}.panel-title{margin:24px var(--padding) 16px;font-size:14px;font-weight:650;color:var(--text)}.detail-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:0;margin:24px var(--padding) 24px;padding:0;height:calc((380px - (var(--padding) * 2)) * 3 / 4);border-radius:6px;background:linear-gradient(90deg,transparent,var(--line) 18%,var(--detail-divider) 50%,var(--line) 82%,transparent) 16px 50% / calc(100% - 32px) 1px no-repeat,linear-gradient(180deg,transparent,var(--line) 18%,var(--detail-divider) 50%,var(--line) 82%,transparent) 33.333333% 16px / 1px calc(100% - 32px) no-repeat,linear-gradient(180deg,transparent,var(--line) 18%,var(--detail-divider) 50%,var(--line) 82%,transparent) 66.666667% 16px / 1px calc(100% - 32px) no-repeat,var(--surface);overflow:hidden}.detail-item{width:100%;padding:12px;border-radius:0;background:transparent;display:grid;align-content:center;justify-items:center;text-align:center}.detail-label{margin-top:6px;color:var(--text);font-size:13px}.detail-value{margin-top:8px;width:100%;font-size:clamp(17px,5.1vw,26px);font-weight:100;white-space:nowrap;overflow:hidden;text-overflow:clip}.hourly-strip{display:flex;gap:0;overflow-x:auto;overflow-y:hidden;margin-top:24px;padding:0 0 8px;scrollbar-width:none;-webkit-overflow-scrolling:touch;scroll-snap-type:x proximity;scroll-padding-left:var(--padding);cursor:grab;touch-action:pan-x;overscroll-behavior-x:contain;user-select:none}.hourly-strip.is-dragging{cursor:grabbing;scroll-snap-type:none}.hourly-strip::-webkit-scrollbar{display:none}.hourly-strip::after{content:"";flex:0 0 var(--padding)}.hourly-item{flex:0 0 70px;height:183px;border:0;appearance:none;background:transparent;color:inherit;font:inherit;display:grid;grid-template-rows:20px 17px 34px 24px 24px 24px;row-gap:4px;align-items:center;justify-items:center;text-align:center;padding:10px 2px;border-radius:6px;scroll-snap-align:start;cursor:pointer}.hourly-item:first-child{margin-left:var(--padding);background:var(--surface)}.hourly-item:hover,.hourly-item:focus-visible{background:var(--surface);outline:none}.hourly-temp{font-size:15px;font-weight:500}.rain{color:var(--rain);font-size:13px;margin-top:4px;min-height:17px}.weather-icon{width:31px;height:31px;display:grid;place-items:center;pointer-events:none}.weather-symbol{width:29px;height:29px;display:block;object-fit:contain;opacity:0.92;pointer-events:none}.hour{color:var(--muted);font-size:15px;font-weight:500}.hourly-wind-speed{color:var(--muted);font-size:13px;font-weight:500;min-height:18px}.hourly-wind-arrow{width:20px;height:20px;display:grid;place-items:center;color:var(--muted)}.wind-arrow-wrap{width:18px;height:18px;display:grid;place-items:center;transform:rotate(var(--wind-rotation));transform-origin:50% 50%}.wind-arrow{width:18px;height:18px;display:block;opacity:0.9;background:currentColor;mask:url("./assets/general-icons/wind-direction.png") center / contain no-repeat;-webkit-mask:url("./assets/general-icons/wind-direction.png") center / contain no-repeat}.daily-list{display:grid;grid-template-columns:repeat(var(--daily-count,7),minmax(0,1fr));gap:0;padding:0 calc(var(--padding) / 2) 8px}.daily-item{height:288px;border:0;appearance:none;background:transparent;color:inherit;font:inherit;display:grid;grid-template-rows:150px 24px 34px 24px 24px 24px;row-gap:4px;justify-items:center;align-items:center;font-size:15px;font-weight:500;border-radius:6px;cursor:pointer}.daily-item:hover,.daily-item:focus-visible{background:var(--surface);outline:none}.daily-rain{color:var(--rain);font-size:13px;min-height:17px}.daily-temp-cell{width:100%;height:150px;margin-top:0;position:relative;display:grid;justify-items:center}.daily-max,.daily-min{position:absolute;left:0;right:0;text-align:center;line-height:1}.daily-bar{width:5px;border-radius:999px;background:linear-gradient(0deg,#feb984,#ff5542);position:absolute;left:50%;transform:translateX(-50%)}.daily-wind-speed{color:var(--muted);font-size:13px;font-weight:500;line-height:1.2;white-space:nowrap}.daily-wind-arrow{width:20px;height:20px;display:grid;place-items:center;color:var(--muted)}.daily-time{color:var(--muted);font-size:15px;font-weight:500}.air-summary{display:flex;align-items:center;gap:14px;padding:0 var(--padding)}.air-index{font-size:66px;font-weight:100;line-height:1}.air-copy{min-width:0}.air-title{color:var(--text);font-size:20px;font-weight:500;line-height:1.1}.air-subtitle{margin-top:8px;color:var(--muted);font-size:15px;line-height:1.3}.detail-overlay{position:fixed;inset:0;z-index:80;display:grid;align-items:end;pointer-events:none}.detail-overlay[hidden]{display:none}.detail-backdrop{position:absolute;inset:0;background:rgba(0,0,0,0.48);opacity:0;transition:opacity 180ms ease}.detail-sheet{position:relative;z-index:1;width:100%;max-height:min(80vh,720px);overflow:auto;padding:22px var(--padding) max(28px,env(safe-area-inset-bottom));border-radius:18px 18px 0 0;background:color-mix(in srgb,var(--bg) 94%,var(--surface-strong));color:var(--text);box-shadow:0 -18px 48px rgba(0,0,0,0.34);transform:translateY(100%);transition:transform 220ms ease;pointer-events:auto}.detail-overlay.is-open{pointer-events:auto}.detail-overlay.is-open .detail-backdrop{opacity:1}.detail-overlay.is-open .detail-sheet{transform:translateY(0)}.has-detail-open{overflow:hidden}.detail-close{position:absolute;top:10px;right:10px;z-index:30;display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;padding:0;border:0;border-radius:50%;background:var(--surface-strong);color:var(--text);font-size:0;line-height:1;cursor:pointer;appearance:none}.detail-close::before{content:"×";display:grid;place-items:center;font-size:24px;line-height:1;width:100%;height:100%}.detail-sheet-body{width:min(100%,620px);margin:0 auto}.detail-overlay.is-radar-detail .detail-sheet-body{width:min(100%,860px)}.detail-overlay.is-radar-detail .detail-close{top:12px;right:12px;z-index:50}.detail-overlay.is-legal-detail .detail-sheet-body{width:min(100%,720px)}.detail-sheet-header{padding-right:42px}.detail-sheet-header h2{margin:0;font-size:24px;line-height:1.15;font-weight:650}.detail-sheet-header-compact h2{font-size:14px;line-height:1.2}.detail-sheet-header p{margin:7px 0 0;color:var(--muted);font-size:15px;line-height:1.35}.detail-sheet-hero{display:flex;align-items:center;gap:14px;margin-top:22px}.detail-sheet-icon .weather-icon{width:42px;height:42px}.detail-sheet-icon .weather-symbol{width:40px;height:40px}.detail-sheet-temp{font-size:clamp(42px,13vw,74px);font-weight:100;line-height:1}.detail-sheet-meta{color:var(--muted);font-size:18px;line-height:1.2}.detail-sheet-copy,.detail-sheet-alert{margin:18px 0 0;color:var(--muted);font-size:16px;line-height:1.45}.detail-sheet-alert{color:var(--danger);font-weight:650}.alert-detail-list{display:grid;gap:22px;margin-top:24px}.alert-detail-item{display:grid;grid-template-columns:44px minmax(0,1fr);gap:14px}.alert-detail-mark{width:36px;height:36px;display:grid;place-items:center;border-radius:50%;background:var(--danger);color:#fff;font-size:20px;font-weight:700;line-height:1}.alert-detail-copy h3{margin:2px 0 0;color:var(--text);font-size:18px;font-weight:650;line-height:1.25}.alert-detail-copy p{margin:10px 0 0;color:var(--summary-detail-text);font-size:15px;line-height:1.45}.alert-detail-meta,.alert-detail-times,.alert-detail-area{color:var(--muted);font-size:13px;line-height:1.35}.alert-detail-times{display:grid;gap:3px;margin-top:12px}.alert-detail-instruction{color:var(--text);font-weight:500}.legal-detail{display:grid;gap:20px;margin-top:24px}.legal-detail-section{display:grid;gap:7px}.legal-detail-section h3{margin:0;color:var(--text);font-size:16px;line-height:1.25;font-weight:700}.legal-detail-section p{margin:0;color:var(--summary-detail-text);font-size:15px;line-height:1.5}.detail-sheet-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1px;margin-top:22px;overflow:hidden;border-radius:8px;background:var(--line)}.detail-sheet-row{min-height:74px;display:grid;align-content:center;gap:8px;padding:13px 14px;background:var(--surface)}.detail-sheet-row span{color:var(--muted);font-size:13px;line-height:1.2}.detail-sheet-row strong{color:var(--text);font-size:20px;font-weight:400;line-height:1.15}.forecast-detail-list{display:grid;gap:20px;margin-top:22px}.forecast-detail-list-daily{gap:24px;margin-top:0}.forecast-detail-list-hourly{margin-top:0}.forecast-section{display:grid;gap:2px}.forecast-section-title{margin:0 0 6px var(--padding);color:var(--text);font-size:15px;font-weight:650;line-height:1.2;text-transform:uppercase}.forecast-detail-list-hourly .forecast-section-title{margin-left:0;margin-right:0}.forecast-section-items{display:grid}.forecast-item{display:grid;gap:12px;padding:14px;border-radius:10px;background:var(--surface)}.forecast-item.is-selected{background:var(--surface-strong)}.forecast-item-daily,.forecast-item-daily.is-selected,.forecast-item-hourly,.forecast-item-hourly.is-selected{grid-template-columns:56px minmax(0,1fr);align-items:start;gap:0 16px;padding:10px 0 22px;border-radius:0;background:transparent}.forecast-item-daily,.forecast-item-daily.is-selected{padding:6px 0 4px}.forecast-item-daily+.forecast-item-daily,.forecast-item-hourly+.forecast-item-hourly{border-top:0}.forecast-item-main{display:grid;grid-template-columns:48px minmax(0,1fr);align-items:center;gap:14px}.forecast-item-daily .forecast-item-main,.forecast-item-hourly .forecast-item-main{grid-column:1 / -1;display:contents}.forecast-icon-wrap{display:grid;justify-items:center;gap:4px;min-height:54px}.forecast-icon-wrap .weather-icon{width:42px;height:42px}.forecast-icon-wrap .weather-symbol{width:40px;height:40px}.forecast-item-daily .forecast-icon-wrap,.forecast-item-hourly .forecast-icon-wrap{grid-column:1;grid-row:1 / span 2;align-self:start;min-height:0;gap:11px;padding-top:0}.forecast-item-daily .weather-icon,.forecast-item-daily .weather-symbol,.forecast-item-hourly .weather-icon,.forecast-item-hourly .weather-symbol{width:40px;height:40px}.forecast-icon-circle{width:48px;height:48px;display:grid;place-items:center;border-radius:50%;background:var(--forecast-icon-bg)}.forecast-icon-circle .weather-icon,.forecast-icon-circle .weather-symbol{width:32px;height:32px}.forecast-icon-caption{color:var(--rain);font-size:13px;line-height:1}.forecast-title-block{grid-column:2;min-width:0}.forecast-item h3{margin:0;color:var(--text);font-size:18px;font-weight:650;line-height:1.35;white-space:pre-line}.forecast-item-daily h3,.forecast-item-hourly h3{font-size:15px;font-weight:500;line-height:1.25}.forecast-title-block strong{display:block;margin-top:2px;color:var(--text);font-size:15px;font-weight:500;line-height:1.25}.forecast-detail-lines{display:grid;gap:8px}.forecast-item-daily .forecast-detail-lines,.forecast-item-hourly .forecast-detail-lines{grid-column:2;margin-top:28px}.forecast-item-daily .forecast-detail-lines{gap:6px;margin-top:6px}.forecast-item-hourly .forecast-detail-lines{gap:4px;margin-top:4px}.forecast-detail-lines p{margin:0;color:var(--summary-detail-text);font-size:15px;line-height:1.45}.forecast-item-daily .forecast-detail-lines p,.forecast-item-hourly .forecast-detail-lines p{color:var(--summary-detail-text)}.forecast-item-daily .forecast-detail-lines p{color:var(--summary-detail-text);line-height:1.34}.forecast-item-hourly .forecast-detail-lines p{color:var(--summary-detail-text);line-height:1.3}.forecast-detail-lines p.is-padded{padding-top:2px}.forecast-item-hourly .forecast-detail-lines p.is-padded{padding-top:8px}.air-hourly-chart{position:relative;margin-top:8px;padding:6px var(--padding) 0}.air-hourly-plot{display:grid;grid-template-columns:36px minmax(0,1fr);column-gap:6px;align-items:end}.air-hourly-y-axis{position:relative;height:120px;color:var(--muted);font-size:15px;line-height:1}.air-hourly-y-axis span{position:absolute;left:0;transform:translateY(-50%)}.air-hourly-bars{height:120px;display:grid;grid-template-columns:repeat(24,minmax(0,1fr));gap:8px;align-items:end;justify-items:center;border-bottom:1px solid var(--line)}.air-hourly-bar{display:block;width:100%;max-width:10px;min-height:4px;border-radius:2px 2px 0 0}.air-hourly-axis{display:grid;grid-template-columns:repeat(7,1fr);margin-top:8px;margin-left:42px;color:var(--muted);font-size:15px}.air-hourly-axis span:last-child{text-align:right}.air-hourly-unit{margin-top:6px;margin-left:42px;color:var(--muted);font-size:15px;text-align:right}.air-scale{padding:12px var(--padding) 0}.air-scale-numbers{display:grid;grid-template-columns:repeat(7,1fr);color:var(--muted);font-size:15px}.air-scale-bar{position:relative;display:flex;height:6px;margin-top:10px}.air-scale-bar span{display:block}.air-scale-bar i{position:absolute;top:50%;width:8px;height:8px;border-radius:50%;background:var(--text);transform:translate(-50%,-50%)}.air-scale-labels{display:flex;justify-content:space-between;margin-top:8px;color:var(--muted);font-size:15px}.source-card{padding:0 var(--padding);display:grid;justify-items:center;text-align:center;color:var(--muted);font-size:15px}.sun-section{padding:0 var(--padding) 0;position:relative}.sun-arc{width:100%;height:148px;margin-top:-10px;overflow:visible;display:block}.sun-line{stroke:var(--line);stroke-width:1.2}.sun-path{fill:none;stroke-width:1.6;stroke-linecap:round;stroke-dasharray:0.012 0.028}.sun-path-muted{stroke:var(--line)}.sun-path-active{stroke:var(--accent);stroke-dasharray:var(--sun-progress) 1}.sun-dot,.sun-current{fill:var(--accent)}.sun-current{filter:drop-shadow(0 0 10px rgba(255,190,83,0.28))}.sun-time-text{color:var(--accent);fill:currentColor;font-size:18px;font-weight:500;text-anchor:middle}.section-title-spaced{margin-top:4px}.moon-list{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));padding:0 var(--padding) 0}.moon-item{display:grid;justify-items:center;text-align:center;min-width:0}.moon-svg{width:50px;height:50px;color:#ebe673}.moon-time{margin-top:10px;color:var(--muted);font-size:15px;font-weight:500}.moon-title{margin-top:8px;color:var(--text);font-size:15px;line-height:1.15;font-weight:500}.wind-showcase{position:relative;min-height:118px;margin:0 var(--padding) 0;border-bottom:1px solid var(--line);overflow:visible}.astro-panel .panel-title{margin-bottom:22px}.astro-panel .section-title-spaced{margin-bottom:26px}.wind-panel .panel-title{margin-top:22px;margin-bottom:0}.hourly-panel .panel-title{margin-top:24px}.daily-panel .panel-title{margin-top:28px}.radar-panel .panel-title{margin-top:28px;margin-bottom:0}.wind-illustration{position:absolute;left:0;bottom:0;width:min(44%,178px);height:132px;overflow:visible}.wind-ground{display:none}.wind-illustration .trunk{fill:#6c3f17}.wind-illustration .trunk.dark{fill:#271609}.wind-illustration .leaf.main{fill:#8bd33f}.wind-illustration .leaf.dark{fill:#375d16}.wind-illustration .tree{transform-box:fill-box;transform-origin:50% 100%;transform:translate(var(--tree-x),var(--tree-y))}.wind-illustration .tree-left{--tree-x:50px;--tree-y:0px}.wind-illustration .tree-main{--tree-x:94px;--tree-y:0px}.wind-illustration .tree-right{--tree-x:138px;--tree-y:0px}.wind-illustration.light-breeze .tree,.wind-illustration.moderate-breeze .tree,.wind-illustration.strong-breeze .tree,.wind-illustration.gale .tree,.wind-illustration.storm .tree,.wind-illustration.hurrican .tree{animation:tree-sway 1.9s ease-in-out infinite alternate}.wind-illustration.moderate-breeze .tree{animation-duration:1.45s}.wind-illustration.strong-breeze .tree,.wind-illustration.gale .tree,.wind-illustration.storm .tree,.wind-illustration.hurrican .tree{animation-duration:1.05s}.wind-readout{position:absolute;right:0;bottom:14px;text-align:right}.wind-speed-large{color:var(--muted);font-size:32px;font-weight:100;line-height:1.05}.wind-direction-large{margin-top:10px;color:var(--muted);font-size:16px;font-weight:400;white-space:nowrap}.radar-map{position:relative;display:grid;grid-template-columns:1fr 1fr;width:auto;justify-self:stretch;aspect-ratio:16 / 9;margin:20px var(--padding) 0;overflow:hidden;border-radius:6px;background:var(--surface)}.radar-map-trigger{cursor:pointer}.radar-detail-content .radar-map{position:relative;z-index:0;aspect-ratio:16 / 10;margin-top:0}.detail-overlay.is-radar-detail .radar-detail-content{position:relative;z-index:1;padding-top:46px}.radar-map::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent,rgba(0,0,0,0.08));pointer-events:none}.radar-map img{width:100%;height:100%;object-fit:cover}.radar-layer{position:absolute;inset:0;z-index:1;display:grid;grid-template-columns:1fr 1fr;opacity:0.72;pointer-events:none;mix-blend-mode:normal}.radar-layer img{width:100%;height:100%;object-fit:cover}@keyframes tree-sway{from{transform:translate(var(--tree-x),var(--tree-y)) rotate(-1.5deg) skewX(-1deg)}to{transform:translate(var(--tree-x),var(--tree-y)) rotate(4deg) skewX(2deg)}}.tw-icon-large{width:min(42vw,180px);height:min(42vw,180px)}.detail-symbol{display:block;width:24px;height:24px;opacity:0.95;background:currentColor;color:var(--text);mask:var(--detail-icon) center / contain no-repeat;-webkit-mask:var(--detail-icon) center / contain no-repeat}.detail-symbol-feelslike{--detail-icon:url("./assets/detail-icons/pack1/feelslike.png")}.detail-symbol-humidity{--detail-icon:url("./assets/detail-icons/pack1/humidity.png")}.detail-symbol-uv{--detail-icon:url("./assets/detail-icons/pack1/uv.png")}.detail-symbol-visibility{--detail-icon:url("./assets/detail-icons/pack1/visibility.png")}.detail-symbol-dewpoint{--detail-icon:url("./assets/detail-icons/pack1/dewpoint.png")}.detail-symbol-pressure{--detail-icon:url("./assets/detail-icons/pack1/pressure.png")}.symbol-icon{display:block;overflow:visible}.source-card{color:var(--faint);font-size:13px}.source-attribution{margin-top:32px}.source-actions,.settings-group{display:grid;justify-items:center;width:100%}.unit-switch,.theme-switch{display:inline-grid;grid-template-columns:repeat(2,44px);gap:2px;width:fit-content;margin-top:32px;padding:2px;border-radius:8px;background:var(--surface)}.theme-switch{grid-template-columns:repeat(3,78px);margin-top:12px}.unit-button{height:28px;border:0;border-radius:6px;padding:0 10px;background:transparent;color:var(--muted);font-size:14px;font-weight:700;line-height:1;white-space:nowrap;cursor:pointer}.unit-button.is-active{background:var(--surface-strong);color:var(--text)}.setting-select{display:grid;gap:8px;justify-items:center;margin-top:12px;color:var(--muted);font-size:13px}.setting-select select{width:min(240px,calc(100vw - 32px));height:32px;border:0;border-radius:8px;padding:0 12px;background:var(--surface);color:var(--text);font:inherit;outline:0}.app-download{display:grid;justify-items:center;gap:6px;width:min(360px,100%);margin-top:28px;color:var(--muted)}.app-download-title{color:var(--text);font-size:15px;font-weight:700}.app-download-copy{font-size:13px;line-height:1.35}.store-links{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:6px}.store-badge-link{display:inline-flex;align-items:center;justify-content:center;width:120px;height:40px;border-radius:6px;text-decoration:none}.store-badge-link:hover{filter:brightness(1.08)}.store-badge{display:block;width:120px;height:40px}.legal-footer{display:grid;justify-items:center;gap:8px;width:100%;margin-top:28px;color:var(--faint);font-size:13px;line-height:1.35}.legal-copy{max-width:720px}.legal-links{display:flex;flex-wrap:wrap;justify-content:center;gap:0;font-weight:700}.legal-links a{color:var(--faint);text-decoration:none}.legal-links a:hover{color:var(--muted);text-decoration:underline}.legal-links a+a::before{content:"|";margin:0 7px;color:var(--faint);font-weight:700}@media (max-width:420px){.theme-switch{grid-template-columns:repeat(3,70px)}.unit-button{font-size:13px}}.shimmer{min-height:120px;border-radius:8px;background:linear-gradient(100deg,var(--surface),var(--surface-strong),var(--surface));background-size:220% 100%;animation:shimmer 1.2s ease-in-out infinite}.loading-shimmer,.loading-line,.loading-detail-cell,.loading-hourly-item{border-radius:8px;background:linear-gradient(100deg,var(--surface),var(--surface-strong),var(--surface));background-size:220% 100%;animation:shimmer 1.2s ease-in-out infinite}.loading-shimmer{position:absolute;inset:0}.loading-temperature-card{min-height:210px;align-content:start;padding-top:22px}.loading-line{height:16px}.loading-temp{width:min(50vw,230px);height:64px}.loading-meta{width:110px;margin-top:14px}.loading-city{width:190px;height:24px;margin-top:12px}.loading-summary{width:min(80%,520px);margin-top:22px}.loading-detail-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1px;margin:24px var(--padding) 24px;height:calc((380px - (var(--padding) * 2)) * 3 / 4);border-radius:6px;overflow:hidden;background:var(--surface)}.loading-detail-cell{border-radius:0;min-height:90px}.loading-hourly-strip{display:flex;gap:16px;overflow:hidden;margin-top:24px;padding:0 var(--padding) 8px}.loading-hourly-item{flex:0 0 70px;height:183px}@keyframes shimmer{from{background-position:200% 0}to{background-position:-20% 0}}@media (min-width:560px) and (max-width:899px){.photo-card{aspect-ratio:auto;height:clamp(318px,calc(873.88px - 61.765vw),calc(100vw - 32px))}}@media (min-width:900px){.app-shell{width:min(calc(100% - 32px),1280px);padding-left:0;padding-right:0}.search{width:min(calc(100% - 32px),1280px)}.weather-feed{grid-template-columns:minmax(0,1fr) minmax(0,1fr);column-gap:var(--gutter);padding:0 var(--padding)}.photo-card{grid-column:1 / -1;aspect-ratio:2.63 / 1;height:auto;margin:0}.source-card{grid-column:1 / -1;margin:0 calc(-1 * var(--padding));padding-left:0;padding-right:0}.temperature-card,.text-card .date,.text-card .city,.text-card .summary,.text-card .detail,.air-summary,.air-hourly-chart,.air-scale,.sun-section{padding-left:0;padding-right:0}.panel-title{margin-left:0;margin-right:0}.air-quality-panel .panel-title{margin-top:14px}.hourly-strip{scroll-padding-left:0}.hourly-item:first-child{margin-left:0}.daily-list{padding-left:0;padding-right:0}.detail-grid{margin:24px 0 6px}.wind-showcase{margin-left:0;margin-right:0}.radar-map{margin-left:0;margin-right:0;width:100%}.detail-item{position:static}.detail-overlay{align-items:center;justify-items:center;padding:24px}.detail-sheet{width:min(620px,calc(100vw - 48px));max-height:min(82vh,760px);border-radius:12px;transform:translateY(16px) scale(0.98);opacity:0;transition:transform 180ms ease,opacity 180ms ease;box-shadow:0 24px 80px rgba(0,0,0,0.38)}.detail-overlay.is-open .detail-sheet{transform:translateY(0) scale(1);opacity:1}}.legal-page{min-width:380px;margin:0;background:var(--page-bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text","Segoe UI",sans-serif}.legal-page-shell{width:min(100%,960px);margin:0 auto;padding:32px var(--padding) 56px}.legal-page-brand{display:inline-flex;align-items:center;gap:10px;color:var(--text);text-decoration:none;font-size:18px;font-weight:600}.legal-page-brand img{width:28px;height:28px;display:block}.legal-page-card{margin-top:32px;padding:32px;border-radius:8px;background:var(--bg)}.legal-page-card h1{margin:0;font-size:34px;line-height:1.1}.legal-page-updated{margin:10px 0 0;color:var(--muted);font-size:15px}.legal-page-card section{margin-top:28px}.legal-page-card h2{margin:0 0 8px;font-size:18px;line-height:1.25}.legal-page-card p{margin:0;color:var(--summary-detail-text);font-size:16px;line-height:1.55}.legal-page-card a{color:var(--rain)}@media (max-width:560px){.legal-page-shell{padding-top:24px}.legal-page-card{padding:24px 18px}.legal-page-card h1{font-size:28px}}