@property --cond-hue{syntax: "<number>"; inherits: true; initial-value: 210;}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}@font-face{font-family:Gilroy-Heavy;src:url(/assets/fonts/Gilroy-Heavy.ttf) format("truetype");font-display:swap}@font-face{font-family:Gilroy-Bold;src:url(/assets/fonts/Gilroy-Bold.ttf) format("truetype");font-display:swap}@font-face{font-family:Gilroy-Medium;src:url(/assets/fonts/Gilroy-Medium.ttf) format("truetype");font-display:swap}:root{--cond-hue: 210;--glass-bg: hsla(var(--cond-hue), 42%, 62%, .11);--glass-border: hsla(var(--cond-hue), 60%, 88%, .2);--glass-shadow: hsla(var(--cond-hue), 60%, 20%, .28);--glass-inset: rgba(255, 255, 255, .2);--tile-bg: hsla(var(--cond-hue), 32%, 55%, .13);--tile-border: hsla(var(--cond-hue), 50%, 82%, .2);--accent: hsl(var(--cond-hue) 95% 82%);--accent-dim: hsl(var(--cond-hue) 80% 80% / .7);--s-1: 4px;--s-2: 8px;--s-3: 12px;--s-4: 16px;--s-5: 20px;--s-6: 24px;--r-card: 24px;--r-tile: 16px;--r-pill: 999px;transition:--cond-hue 1.4s ease}body.light-bg{--glass-bg: rgba(6, 10, 24, .54);--glass-border: rgba(255, 255, 255, .24);--glass-shadow: rgba(0, 0, 0, .38);--tile-bg: rgba(6, 10, 24, .42);--tile-border: rgba(255, 255, 255, .2);--accent: hsl(var(--cond-hue) 90% 85%);--accent-dim: hsl(var(--cond-hue) 80% 84% / .78)}body{font-family:Gilroy-Bold,system-ui,sans-serif;min-height:100vh;background-color:#0d1526;background-image:linear-gradient(to bottom,#141e30,#243b55);background-attachment:fixed;transition:background-image .9s ease,background-color .9s ease;overflow-x:hidden}body:before{content:"";position:fixed;top:-15%;right:-15%;bottom:-15%;left:-15%;width:130%;height:130%;background:radial-gradient(ellipse 55% 50% at 22% 30%,hsla(var(--cond-hue),75%,62%,.38) 0%,transparent 68%),radial-gradient(ellipse 45% 55% at 78% 68%,hsla(calc(var(--cond-hue) + 38),65%,48%,.28) 0%,transparent 68%);animation:auroraShift 60s ease-in-out infinite alternate;z-index:-1;pointer-events:none;transition:background 1.4s ease;will-change:transform}@keyframes auroraShift{0%{transform:translate(0) scale(1)}33%{transform:translate(2.5%,-1.5%) scale(1.04)}66%{transform:translate(-1.5%,2%) scale(.97)}to{transform:translate(1%,1.5%) scale(1.02)}}.glass-card{background:var(--glass-bg);backdrop-filter:blur(22px) saturate(160%);-webkit-backdrop-filter:blur(22px) saturate(160%);border:1px solid var(--glass-border);border-radius:var(--r-card);box-shadow:0 8px 40px var(--glass-shadow),inset 0 1px 0 var(--glass-inset);transition:background .9s ease,border-color .9s ease,box-shadow .9s ease}@keyframes shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}.skeleton-text{background:linear-gradient(90deg,#ffffff12 25%,#fff3,#ffffff12 75%);background-size:1200px 100%;animation:shimmer 1.6s infinite linear;border-radius:6px;color:transparent!important;display:inline-block;min-width:60px;min-height:1em;-webkit-user-select:none;-moz-user-select:none;user-select:none}.skeleton-card{background:linear-gradient(90deg,#ffffff0d 25%,#ffffff24,#ffffff0d 75%);background-size:1200px 100%;animation:shimmer 1.6s infinite linear;border-radius:var(--r-tile)}.weather-app{display:grid;grid-template-areas:"sidebar" "main" "stats";grid-template-columns:1fr;gap:var(--s-4);min-height:100vh;min-height:100dvh;padding:var(--s-4);padding-top:max(var(--s-4),env(safe-area-inset-top));padding-bottom:max(var(--s-4),env(safe-area-inset-bottom));padding-left:max(var(--s-4),env(safe-area-inset-left));padding-right:max(var(--s-4),env(safe-area-inset-right))}@media (min-width: 1024px){.weather-app{grid-template-areas:"sidebar main stats";grid-template-columns:275px 1fr 315px;grid-template-rows:1fr;align-items:start;padding:var(--s-5);max-width:1440px;margin:0 auto}}.sidebar{grid-area:sidebar;background:radial-gradient(circle 280px at var(--gx, -500px) var(--gy, -500px),rgba(255,255,255,.05) 0%,transparent 60%),var(--glass-bg);backdrop-filter:blur(22px) saturate(160%);-webkit-backdrop-filter:blur(22px) saturate(160%);border:1px solid var(--glass-border);border-radius:var(--r-card);box-shadow:0 8px 40px var(--glass-shadow),inset 0 1px 0 var(--glass-inset);padding:var(--s-5);display:flex;flex-direction:column;gap:var(--s-4);position:relative;transition:border-color .9s ease,box-shadow .9s ease}@media (min-width: 1024px){.sidebar{position:sticky;top:var(--s-5);min-height:calc(100dvh - 2 * var(--s-5));max-height:calc(100dvh - 2 * var(--s-5));overflow:hidden;overflow-y:auto;scrollbar-width:none}.sidebar::-webkit-scrollbar{display:none}}.search{width:100%}.search-wrapper{position:relative;display:flex;align-items:center;gap:8px}.search-box{flex:1;min-width:0;padding:11px 16px;height:44px;border:none;outline:none;background:#ffffff1a;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#efefef;border-radius:var(--r-pill);font-family:Gilroy-Bold,sans-serif;font-size:14px;box-shadow:0 2px 12px #0003,inset 0 1px #ffffff1a;border:1px solid rgba(255,255,255,.12);transition:background .2s,border-color .2s}.search-box::-moz-placeholder{color:#efefef9e}.search-box::placeholder{color:#efefef9e}.search-box:focus{background:#ffffff2e;border-color:#ffffff40}.search-button{width:44px;height:44px;flex-shrink:0;border:1px solid rgba(255,255,255,.12);outline:none;cursor:pointer;border-radius:50%;background:#ffffff1a;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#efefef;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 12px #0003,inset 0 1px #ffffff1a;transition:background .2s,transform .15s}.search-button:hover{background:#ffffff38}.search-button:active{transform:scale(.92)}.search-button:disabled{opacity:.45;cursor:not-allowed;transform:none}.search-suggestions{position:absolute;top:calc(100% + 6px);left:0;right:48px;background:#0a101ef2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-tile);list-style:none;z-index:200;display:none;overflow:hidden;box-shadow:0 12px 40px #00000080}.search-suggestions.active{display:block}.search-suggestion-item{padding:10px 16px;color:#e0e0e0;cursor:pointer;font-size:13px;font-family:Gilroy-Medium,sans-serif;border-bottom:1px solid rgba(255,255,255,.06);transition:background .15s}.search-suggestion-item:last-child{border-bottom:none}.search-suggestion-item:hover,.search-suggestion-item:focus{background:#ffffff1a;outline:none}.locate-btn{display:flex;align-items:center;gap:7px;width:100%;padding:9px 14px;border:1px solid rgba(255,255,255,.12);border-radius:var(--r-pill);background:#ffffff12;color:#ffffffbf;font-family:Gilroy-Medium,sans-serif;font-size:13px;cursor:pointer;transition:background .2s,color .2s,transform .15s;text-align:left}.locate-btn:hover{background:#ffffff24;color:#fff}.locate-btn:active{transform:scale(.97)}.locate-btn:disabled{opacity:.4;cursor:not-allowed}.quick-cities-section{display:flex;flex-direction:column;gap:8px}@media (max-width: 1023px){.quick-cities-section{display:none}}@media (min-width: 1024px){.quick-cities-section{flex:1}}.section-label{font-size:11px;font-family:Gilroy-Bold,sans-serif;text-transform:uppercase;letter-spacing:1.4px;color:var(--accent-dim);margin-bottom:2px}.quick-city-list{display:flex;flex-direction:column;gap:6px;flex:1}.qc-skeleton{flex:1;min-height:64px;border-radius:var(--r-tile)}.quick-city-card{display:grid;grid-template-columns:42px 1fr auto;align-items:center;gap:10px;width:100%;flex:1;min-height:64px;padding:14px 16px;border:1px solid var(--tile-border);border-radius:var(--r-tile);background:var(--tile-bg);color:#fff;cursor:pointer;text-align:left;position:relative;overflow:hidden;transition:background .9s ease,border-color .9s ease,transform .2s ease}.quick-city-card:hover{background:#ffffff24;border-color:#ffffff40;transform:translate(4px)}.quick-city-card:active{transform:translate(2px) scale(.99)}.qc-icon{width:40px;height:40px;-o-object-fit:contain;object-fit:contain}.qc-info{display:flex;flex-direction:column;gap:1px;overflow:hidden}.qc-name{font-family:Gilroy-Bold,sans-serif;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.qc-desc{font-family:Gilroy-Medium,sans-serif;font-size:10px;color:var(--accent-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.qc-temp{font-family:Gilroy-Heavy,sans-serif;font-size:22px;color:#fff;white-space:nowrap}.qc-error{padding:10px 12px;font-size:12px;color:#ffffff4d;font-family:Gilroy-Medium,sans-serif}.main-panel{grid-area:main;background:radial-gradient(circle 480px at var(--gx, -500px) var(--gy, -500px),rgba(255,255,255,.04) 0%,transparent 60%),var(--glass-bg);backdrop-filter:blur(22px) saturate(160%);-webkit-backdrop-filter:blur(22px) saturate(160%);border:1px solid var(--glass-border);border-radius:var(--r-card);box-shadow:0 8px 40px var(--glass-shadow),inset 0 1px 0 var(--glass-inset);display:flex;flex-direction:column;align-items:center;gap:var(--s-5);padding:var(--s-6) var(--s-5);min-height:420px;position:relative;transition:background .9s ease,border-color .9s ease,box-shadow .9s ease}@media (min-width: 1024px){.main-panel{justify-content:safe center;gap:var(--s-5);padding:var(--s-6);min-height:calc(100dvh - 2 * var(--s-5));max-height:calc(100dvh - 2 * var(--s-5));overflow-y:auto;scrollbar-width:none}}.main-panel::-webkit-scrollbar{display:none}.center-header{display:flex;align-items:center;justify-content:space-between;width:100%;gap:10px;flex-wrap:wrap}.location-chip{display:flex;align-items:center;gap:9px;min-width:0}.pin-icon{width:26px;height:26px;flex-shrink:0;color:hsla(var(--cond-hue),85%,80%,1);filter:drop-shadow(0 0 8px hsla(var(--cond-hue),80%,70%,.65));transition:color .9s ease,filter .9s ease}.location-text{display:flex;align-items:center;flex-wrap:wrap;gap:var(--s-2);min-width:0}.city{font-family:Gilroy-Heavy,sans-serif;font-size:20px;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.35);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.country-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px 4px 6px;background:var(--tile-bg);border:1px solid var(--tile-border);border-radius:var(--r-pill);flex-shrink:0;transition:background .9s ease,border-color .9s ease}.country-flag{width:21px;height:15px;-o-object-fit:cover;object-fit:cover;border-radius:3px;display:block;box-shadow:0 1px 3px #00000059}.country-flag[hidden]{display:none}.country{font-family:Gilroy-Bold,sans-serif;font-size:12px;color:#ffffffd1;white-space:nowrap;letter-spacing:.2px}.header-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.dt-pills{display:flex;align-items:stretch;gap:7px;flex-shrink:0}.dt-pill{display:flex;align-items:center;gap:8px;background:var(--tile-bg);border:1px solid var(--tile-border);border-radius:var(--r-pill);padding:7px 13px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:background .9s ease,border-color .9s ease}.dt-icon{width:15px;height:15px;color:var(--accent);flex-shrink:0}.date{font-family:Gilroy-Bold,sans-serif;font-size:13px;color:#fff;white-space:nowrap;min-height:16px}.time-stack{display:flex;flex-direction:column;gap:1px}.time{font-family:Gilroy-Heavy,sans-serif;font-size:15px;color:#fff;line-height:1.1;min-height:18px}.part-of-day{font-family:Gilroy-Medium,sans-serif;font-size:10px;color:var(--accent-dim);font-style:italic;min-height:12px}.temp-stage{display:flex;flex-direction:column;align-items:center;gap:14px;width:100%}.unit-toggle{display:inline-flex;align-items:center;gap:3px;padding:4px 6px 4px 10px;background:var(--tile-bg);border:1px solid var(--tile-border);border-radius:var(--r-pill);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);position:relative;isolation:isolate}.unit-toggle:after{content:"";position:absolute;z-index:0;top:4px;bottom:4px;left:var(--unit-x, 0px);width:var(--unit-w, 0px);background:#fff3;border-radius:var(--r-pill);transition:left .28s cubic-bezier(.4,0,.2,1),width .28s cubic-bezier(.4,0,.2,1)}.unit-toggle-ico{width:14px;height:14px;color:var(--accent);margin-right:3px;flex-shrink:0}.unit-btn{position:relative;z-index:1;border:none;background:transparent;color:#fff9;border-radius:var(--r-pill);padding:4px 13px;font-size:13px;font-family:Gilroy-Bold,sans-serif;cursor:pointer;transition:color .2s}.unit-btn.active{color:#fff}.unit-btn:hover:not(.active){color:#ffffffe0}.hero-row{display:flex;align-items:center;justify-content:center;gap:clamp(10px,3.5vw,30px);width:100%;flex-wrap:wrap}.temperature-reading{color:#fff;font-size:clamp(78px,11vw,116px);font-family:Gilroy-Heavy,sans-serif;line-height:.95;text-shadow:0 6px 30px rgba(0,0,0,.35);letter-spacing:-2px}.weather-icon{width:132px;height:132px;-o-object-fit:contain;object-fit:contain;filter:drop-shadow(0 6px 26px rgba(0,0,0,.45))}.hero-side{display:flex;flex-direction:column;align-items:flex-start;gap:5px;text-align:left;min-width:130px}.weather{color:#fff;font-size:22px;font-style:italic;font-family:Gilroy-Medium,sans-serif;text-shadow:0 2px 10px rgba(0,0,0,.25);min-height:30px}.today-hl-val{font-family:Gilroy-Bold,sans-serif;font-size:14px;color:var(--accent);letter-spacing:.4px;min-height:18px}.temperature-real-feel{color:#ffffffc7;font-size:14px;font-family:Gilroy-Medium,sans-serif;min-height:20px}.chips-row{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap}.aqi-wrap{position:relative;display:inline-block}.aqi-badge{display:inline-block;padding:6px 14px;border-radius:var(--r-pill);font-size:11px;font-family:Gilroy-Bold,sans-serif;letter-spacing:.7px;text-transform:uppercase;min-height:22px;transition:background-color .5s;box-shadow:0 2px 12px #00000040}.aqi-badge:empty{display:none}.best-time-chip{display:inline-flex;align-items:center;padding:6px 14px;border-radius:var(--r-pill);font-size:11.5px;font-family:Gilroy-Bold,sans-serif;letter-spacing:.3px;color:var(--accent);background:hsl(var(--cond-hue) 60% 58% / .16);border:1px solid hsl(var(--cond-hue) 70% 75% / .34);white-space:nowrap}.best-time-chip:empty{display:none}.stats-rail{grid-area:stats;background:radial-gradient(circle 280px at var(--gx, -500px) var(--gy, -500px),rgba(255,255,255,.05) 0%,transparent 60%),var(--glass-bg);backdrop-filter:blur(22px) saturate(160%);-webkit-backdrop-filter:blur(22px) saturate(160%);border:1px solid var(--glass-border);border-radius:var(--r-card);box-shadow:0 8px 40px var(--glass-shadow),inset 0 1px 0 var(--glass-inset);padding:var(--s-5);display:flex;flex-direction:column;gap:var(--s-3);position:relative;transition:border-color .9s ease,box-shadow .9s ease}@media (min-width: 1024px){.stats-rail{position:sticky;top:var(--s-5);min-height:calc(100dvh - 2 * var(--s-5));max-height:calc(100dvh - 2 * var(--s-5));overflow:hidden}.stats-rail .stats-grid{flex:1;grid-template-rows:repeat(5,1fr)}}.stats-grid{display:grid;grid-template-columns:1fr 1fr;grid-auto-rows:minmax(72px,1fr);gap:var(--s-2)}.stat-tile--wide{grid-column:1 / -1}.stat-tile{background:var(--tile-bg);border:1px solid var(--tile-border);border-radius:var(--r-tile);padding:var(--s-3) var(--s-4);display:flex;flex-direction:column;justify-content:center;gap:5px;min-height:0;position:relative;overflow:hidden;transition:background .9s ease,border-color .9s ease,box-shadow .5s ease,transform .2s ease}.stat-tile:hover{background:#ffffff24;border-color:#ffffff47;box-shadow:0 12px 32px #00000040,inset 0 1px #ffffff47;transform:translateY(-4px);animation-play-state:paused}.stat-tile-label{font-size:10.5px;font-family:Gilroy-Bold,sans-serif;text-transform:uppercase;letter-spacing:1px;color:var(--accent-dim);white-space:nowrap}.stat-tile-value{font-family:Gilroy-Heavy,sans-serif;font-size:22px;color:#fff;text-shadow:0 1px 8px rgba(0,0,0,.3);line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stat-tile-main{display:flex;align-items:baseline;gap:6px;flex-wrap:nowrap;min-width:0;overflow:hidden}.stat-tile-main .stat-tile-value{flex-shrink:0}.stat-note{font-family:Gilroy-Medium,sans-serif;font-size:11.5px;color:var(--accent);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.uv-level[data-level=low]{color:#5bd16a}.uv-level[data-level=moderate]{color:#ffd600}.uv-level[data-level=high]{color:#ff9800}.uv-level[data-level=very-high]{color:#ff5b52}.uv-level[data-level=extreme]{color:#c879ff}.moon-emoji{font-size:16px;line-height:1;flex-shrink:0}.moon-phase-value{font-size:15px}.sun-times{display:flex;align-items:center;padding:14px 24px;background:var(--tile-bg);border:1px solid var(--tile-border);border-radius:var(--r-tile);width:100%;max-width:520px;transition:background .9s ease,border-color .9s ease}.sun-time-item{display:flex;align-items:center;gap:12px;flex:1;justify-content:center}.sun-time-icon{width:30px;height:30px;flex-shrink:0;color:#ffc24d;filter:drop-shadow(0 0 7px rgba(255,180,60,.55))}.sun-time-body{display:flex;flex-direction:column;gap:3px}.sun-time-label{font-size:11px;font-family:Gilroy-Bold,sans-serif;text-transform:uppercase;letter-spacing:1px;color:var(--accent-dim)}.sun-time-value{font-family:Gilroy-Heavy,sans-serif;font-size:22px;color:#fff;text-shadow:0 1px 8px rgba(0,0,0,.3);min-height:28px}.sun-divider{width:1px;height:40px;background:#ffffff26;flex-shrink:0;margin:0 4px}.forecast-section{display:flex;flex-direction:column;gap:10px;width:100%}.forecast-cards{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.forecast-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:14px 8px 12px;border-radius:var(--r-tile);background:var(--tile-bg);border:1px solid var(--tile-border);color:#fff;min-height:130px;gap:5px;position:relative;overflow:hidden;transition:background .9s ease,border-color .9s ease,transform .2s ease}.forecast-card:hover{background:#ffffff24;border-color:#ffffff3d;transform:translateY(-4px)}.forecast-day{font-size:13px;font-family:Gilroy-Bold,sans-serif;text-transform:uppercase;letter-spacing:.5px;color:#ffffffbf}.forecast-icon{width:36px;height:36px;-o-object-fit:contain;object-fit:contain}.forecast-meta{display:flex;flex-direction:column;gap:2px;align-items:center;width:100%;overflow:hidden}.forecast-desc{font-size:11px;font-family:Gilroy-Medium,sans-serif;color:#ffffffbd;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.forecast-rain{font-size:11px;font-family:Gilroy-Medium,sans-serif;color:#8cc3ffe6}.forecast-right{display:flex;flex-direction:column;align-items:center;gap:1px;margin-top:auto}.forecast-temps{display:flex;align-items:baseline;gap:4px;white-space:nowrap}.forecast-high{font-family:Gilroy-Heavy,sans-serif;font-size:16px;color:#fff}.forecast-low{font-family:Gilroy-Medium,sans-serif;color:#ffffff80;font-size:13px}.forecast-wind{font-size:10px;font-family:Gilroy-Medium,sans-serif;color:#ffffff61;white-space:nowrap}@media (max-width: 520px){.forecast-cards,.forecast-cards.hourly-mode{display:flex;grid-template-columns:none;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px}.forecast-cards::-webkit-scrollbar{display:none}.forecast-card{flex:0 0 auto;min-width:96px;scroll-snap-align:start}}.error-toast{position:fixed;bottom:calc(24px + env(safe-area-inset-bottom));left:50%;transform:translate(-50%);background:#b41e1ee6;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:#fff;padding:12px 24px;border-radius:var(--r-tile);font-size:14px;font-family:Gilroy-Medium,sans-serif;z-index:999;box-shadow:0 4px 24px #00000080;border:1px solid rgba(255,100,100,.3);animation:slideUp .3s ease;max-width:min(90vw,420px);width:-moz-max-content;width:max-content;text-align:center;line-height:1.4}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,16px)}to{opacity:1;transform:translate(-50%)}}body.home{display:flex;justify-content:center;align-items:center;min-height:100vh;background-image:url(/assets/images/bg.jpg);background-size:cover;background-position:center}.home-container{background:#00000080;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.12);padding:48px 40px;border-radius:24px;color:#fff;max-width:560px;text-align:center;box-shadow:0 12px 60px #0006,inset 0 1px #ffffff26}.home-logo{width:90px;margin-bottom:20px}.home-greeting{font-size:2.4rem;font-family:Gilroy-Heavy,sans-serif;margin-bottom:12px;text-shadow:0 2px 12px rgba(0,0,0,.5)}.home-tagline{font-size:1.05rem;font-family:Gilroy-Medium,sans-serif;color:#ffffffc7;margin-bottom:28px;line-height:1.5}.home-features{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin-bottom:32px}.home-feature-chip{background:#ffffff1a;border:1px solid rgba(255,255,255,.18);border-radius:var(--r-pill);padding:6px 14px;font-size:12px;font-family:Gilroy-Bold,sans-serif;letter-spacing:.4px;color:#ffffffe0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.home-button{display:inline-block;padding:16px 40px;font-size:1.1rem;font-family:Gilroy-Bold,sans-serif;color:#fff;background:linear-gradient(135deg,#3498db,#2271b3);border:none;border-radius:50px;text-decoration:none;cursor:pointer;box-shadow:0 6px 24px #3498db73;transition:transform .2s,box-shadow .2s}.home-button:hover{transform:translateY(-2px);box-shadow:0 12px 32px #3498db8c}.home-button:active{transform:translateY(0)}.stat-tile:after,.quick-city-card:after,.forecast-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:radial-gradient(circle 70px at var(--gx, -200px) var(--gy, -200px),rgba(255,255,255,.22) 0%,transparent 70%);pointer-events:none;z-index:0}@keyframes glassBreath{0%,to{box-shadow:0 2px 10px #00000014,inset 0 1px #ffffff14}50%{box-shadow:0 5px 22px #0000002e,inset 0 1px #fff3}}.stat-tile{animation:glassBreath 6s ease-in-out infinite}.stat-tile:nth-child(2){animation-delay:-.75s}.stat-tile:nth-child(3){animation-delay:-1.5s}.stat-tile:nth-child(4){animation-delay:-2.25s}.stat-tile:nth-child(5){animation-delay:-3s}.stat-tile:nth-child(6){animation-delay:-3.75s}.stat-tile:nth-child(7){animation-delay:-4.5s}.stat-tile:nth-child(8){animation-delay:-5.25s}.stat-tile:nth-child(9){animation-delay:-5.75s}.stat-tile:nth-child(10){animation-delay:-6.25s}.sidebar-brand{padding-bottom:var(--s-4);border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-brand-lockup{display:flex;align-items:center;gap:var(--s-3)}.sidebar-logo{width:34px;height:34px;-o-object-fit:contain;object-fit:contain;flex-shrink:0;filter:drop-shadow(0 0 10px hsla(var(--cond-hue),80%,70%,.75)) drop-shadow(0 2px 4px rgba(0,0,0,.4));transition:filter 1.4s ease}.sidebar-brand-text{display:flex;flex-direction:column;gap:2px}.sidebar-brand-name{display:block;font-family:Gilroy-Heavy,sans-serif;font-size:15px;letter-spacing:.15px;background:linear-gradient(125deg,hsla(var(--cond-hue),55%,88%,1),#fff 55%,hsla(calc(var(--cond-hue) + 30),50%,90%,.9));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;transition:background 1.4s ease}.sidebar-brand-tagline{display:block;font-family:Gilroy-Medium,sans-serif;font-size:9px;letter-spacing:1.8px;text-transform:uppercase;color:#ffffff61}@media (max-width: 520px){.weather-app{gap:var(--s-3);padding:var(--s-3);padding-top:max(var(--s-3),env(safe-area-inset-top));padding-bottom:max(var(--s-3),env(safe-area-inset-bottom));padding-left:max(var(--s-3),env(safe-area-inset-left));padding-right:max(var(--s-3),env(safe-area-inset-right))}.main-panel{padding:var(--s-5) var(--s-4) var(--s-4)}.hero-side{align-items:center;text-align:center;min-width:0}.sidebar,.stats-rail{padding:var(--s-4)}.stats-grid{grid-template-columns:1fr 1fr}.stat-tile{padding:var(--s-3)}.stat-tile-value{font-size:19px}.home-container{padding:36px 24px;margin:20px}.home-greeting{font-size:1.9rem}}@media (max-width: 380px){.city{font-size:16px}.weather{font-size:20px}.dt-pills{flex-direction:column;gap:5px}}@media (hover: none){.quick-city-card:hover,.stat-tile:hover,.forecast-card:hover{transform:none;background:var(--tile-bg);border-color:var(--tile-border);box-shadow:none}}@media (prefers-reduced-motion: reduce){.skeleton-text,.skeleton-card{animation:none}body:before,body:after{animation:none;transition:none}.stat-tile{animation:none}.quick-city-card,.stat-tile,.forecast-card,.home-button,.sun-dot{transition:none}.unit-toggle:after,.spark-cursor,.spark-tip{transition:none}}:root{--aurora-x: 0px;--aurora-y: 0px}body:after{content:"";position:fixed;top:-15%;right:-15%;bottom:-15%;left:-15%;width:130%;height:130%;background:radial-gradient(ellipse 50% 60% at 80% 20%,hsla(calc(var(--cond-hue) + 60),65%,55%,.22) 0%,transparent 68%);animation:auroraShift 80s ease-in-out infinite alternate-reverse;z-index:-1;pointer-events:none;transition:background 1.4s ease;will-change:transform;transform:translate(calc(var(--aurora-x) * -.025),calc(var(--aurora-y) * -.02))}body:before{transform:translate(calc(var(--aurora-x) * .04),calc(var(--aurora-y) * .03))}.sun-arc{flex:1;max-width:120px;height:65px;overflow:visible}.sun-arc-path{stroke:#ffc8502e}.sun-arc-progress{stroke-linecap:round}.sun-dot{fill:#ffd060;filter:drop-shadow(0 0 5px rgba(255,200,60,.9)) drop-shadow(0 0 12px rgba(255,160,20,.6))}.weather-icon-wrap{width:132px;height:132px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.sparkline-section{width:100%;max-width:520px;padding:var(--s-3) var(--s-4);background:var(--tile-bg);border:1px solid var(--tile-border);border-radius:var(--r-tile);display:flex;flex-direction:column;gap:var(--s-2);transition:background .9s ease,border-color .9s ease}.sparkline-head{display:flex;align-items:baseline;justify-content:space-between;gap:var(--s-3)}.sparkline-head .section-label{margin-bottom:0}.sparkline-range{font-family:Gilroy-Bold,sans-serif;font-size:11px;color:var(--accent-dim);display:inline-flex;align-items:baseline;gap:5px}.spark-max{color:#fff}.spark-sep{opacity:.5}.sparkline-plot{position:relative;width:100%;height:52px}.temp-sparkline{width:100%;height:52px;display:block;overflow:visible}.spark-dot{position:absolute;left:var(--dx, -100%);top:var(--dy, -100%);width:8px;height:8px;margin:-4px 0 0 -4px;border-radius:50%;background:#fff;box-shadow:0 0 0 3px hsl(var(--cond-hue) 90% 70% / .25),0 0 8px #ffffffe6;pointer-events:none;z-index:2}.spark-cursor{position:absolute;top:0;bottom:0;left:var(--cx, -100%);width:1px;background:#ffffff47;opacity:0;transition:opacity .15s;pointer-events:none;z-index:1}.spark-tip{position:absolute;left:var(--cx, -100%);bottom:calc(100% + 8px);transform:translate(-50%);padding:4px 9px;background:#0a0e1ef2;border:1px solid rgba(255,255,255,.14);border-radius:var(--r-pill);font-family:Gilroy-Bold,sans-serif;font-size:11px;color:#fff;white-space:nowrap;opacity:0;transition:opacity .15s;pointer-events:none;z-index:3}.sparkline-plot.is-hover .spark-cursor,.sparkline-plot.is-hover .spark-tip{opacity:1}.sparkline-axis{display:flex;justify-content:space-between}.spark-x{font-family:Gilroy-Medium,sans-serif;font-size:9.5px;letter-spacing:.6px;text-transform:uppercase;color:var(--accent-dim)}.spark-x-mid{transform:translate(-50%);margin-left:50%}.spark-x-end{text-align:right}.forecast-header{display:flex;align-items:center;justify-content:space-between;width:100%}.forecast-toggle{display:flex;background:var(--tile-bg);border:1px solid var(--tile-border);border-radius:var(--r-pill);padding:3px;gap:2px}.forecast-toggle-btn{border:none;background:transparent;color:#ffffffa6;border-radius:var(--r-tile);padding:4px 12px;font-size:12px;font-family:Gilroy-Bold,sans-serif;cursor:pointer;transition:background .2s,color .2s}.forecast-toggle-btn.active{background:#ffffff2e;color:#fff}.forecast-toggle-btn:hover:not(.active){color:#ffffffe6}.forecast-cards.hourly-mode{grid-template-columns:repeat(6,1fr)}@media (max-width: 600px){.forecast-cards.hourly-mode{grid-template-columns:repeat(4,1fr)}}.alerts-container{width:100%}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.alert-banner{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;background:#dc501e40;border:1px solid rgba(255,120,60,.4);border-radius:var(--r-tile);margin-bottom:8px;font-size:13px;font-family:Gilroy-Medium,sans-serif;color:#fff;animation:slideDown .3s ease}.alert-banner[data-severity=moderate]{background:#dca51e40;border-color:#ffc83c66}.alert-banner[data-severity=extreme],.alert-banner[data-severity=severe]{background:#b414144d;border-color:#ff3c3c73}.alert-icon{font-size:18px;line-height:1;flex-shrink:0;margin-top:1px}.alert-body{flex:1;min-width:0}.alert-body strong{display:block;font-family:Gilroy-Bold,sans-serif;font-size:13px;margin-bottom:3px}.alert-body p{font-size:12px;color:#ffffffbf;line-height:1.4;margin:0}.alert-dismiss{background:none;border:none;color:#ffffff8c;cursor:pointer;font-size:14px;line-height:1;padding:2px 4px;flex-shrink:0;transition:color .15s}.alert-dismiss:hover{color:#fff}.aqi-badge{cursor:pointer}.aqi-popover{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:#0a0e1ef2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-tile);padding:12px 16px;min-width:200px;z-index:50;display:grid;gap:6px;box-shadow:0 8px 32px #00000080;animation:slideDown .2s ease}.aqi-popover[hidden]{display:none}.aqi-row{display:flex;justify-content:space-between;align-items:center;gap:12px}.aqi-pollutant{font-family:Gilroy-Bold,sans-serif;font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:#ffffff8c}.aqi-value{font-family:Gilroy-Medium,sans-serif;font-size:12px;color:#ffffffe0;white-space:nowrap}.share-btn{width:38px;height:38px;flex-shrink:0;border-radius:var(--r-tile);background:#ffffff14;border:1px solid rgba(255,255,255,.13);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);color:#fffc;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s,transform .15s}.share-btn:hover{background:#ffffff2e;color:#fff}.share-btn:active{transform:scale(.92)}.share-menu{position:fixed;z-index:100;background:#0a0e1ef2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-tile);padding:6px;display:flex;flex-direction:column;gap:2px;box-shadow:0 8px 32px #00000080;animation:slideDown .2s ease;min-width:170px}.share-menu-btn{display:flex;align-items:center;gap:10px;padding:10px 14px;border:none;background:transparent;color:#ffffffd9;border-radius:10px;font-family:Gilroy-Medium,sans-serif;font-size:13px;cursor:pointer;text-decoration:none;transition:background .15s}.share-menu-btn:hover{background:#ffffff1a;color:#fff}
