@font-face{font-family:Weather Hub Sans;src:url(/fonts/zihunxinquhei.ttf)format("truetype");font-style:normal;font-weight:400 900;font-display:swap}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--sky-start:#cae8ff;--sky-mid:#e7f4ff;--sky-end:#f8fbff;--sky-glow:#ffffff59;--accent-glow:#f5a6232e;--primary:#00b8a0;--primary-dark:#009a86;--primary-light:#00b8a01f;--primary-glow:#00b8a02e;--accent:#f5a623;--accent-light:#f5a6231f;--text:#16293a;--text-light:#607589;--text-muted:#92a8bb;--bg:#fff;--bg-card:#ffffffd1;--bg-card-solid:#fff;--surface-elevated:#ffffffeb;--surface-soft:#ffffffb3;--surface-strong:#ffffffd6;--border:#97b5cc47;--shadow:0 8px 34px #005aaa1a;--shadow-hover:0 16px 48px #005aaa2e;--shadow-sm:0 2px 8px #005aaa0f;--radius:20px;--radius-sm:12px;--radius-xs:8px;--font:"Weather Hub Sans", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", system-ui, sans-serif;--font-display:"Weather Hub Sans", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", system-ui, sans-serif;--font-mono:"Weather Hub Sans", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", system-ui, sans-serif;--glass:#ffffffd1;--glass-blur:blur(12px);--glass-border:#ffffff80;--success-soft:#00b8a01f;--danger-soft:#dc262614;--danger-border:#f8717159;--danger-text:#dc2626;--info-soft:#22d3ee1a;--info-border:#22d3ee40;--info-text:#0f766e;--secure-canvas-filter:none;--transition:.35s cubic-bezier(.25, .8, .25, 1)}:root[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--sky-start:#08131f;--sky-mid:#0e1c2c;--sky-end:#15273a;--sky-glow:#53d6c314;--accent-glow:#f5a62314;--primary:#53d6c3;--primary-dark:#2fc2ae;--primary-light:#53d6c324;--primary-glow:#53d6c329;--accent:#f7bf56;--accent-light:#f7bf561f;--text:#e7eef7;--text-light:#acbfd0;--text-muted:#73879b;--bg:#0a1623;--bg-card:#0c1825d6;--bg-card-solid:#111f2d;--surface-elevated:#0e1b29f5;--surface-soft:#122232d1;--surface-strong:#101e2de6;--border:#a6bed32e;--shadow:0 14px 32px #00000057;--shadow-hover:0 20px 42px #0000006b;--shadow-sm:0 6px 18px #0000003d;--glass:#08141fc2;--glass-border:#a6bed31f;--success-soft:#15803d42;--danger-soft:#7f1d1d52;--danger-border:#f871713d;--danger-text:#fda4af;--info-soft:#082f49b3;--info-border:#38bdf838;--info-text:#7dd3fc;--secure-canvas-filter:brightness(0) invert(.94)}*{box-sizing:border-box;margin:0;padding:0}button,input,textarea,select{font:inherit}body{font-family:var(--font);color:var(--text);background:radial-gradient(circle at top left, var(--sky-glow) 0%, transparent 30%), radial-gradient(circle at top right, var(--accent-glow) 0%, transparent 26%), linear-gradient(180deg, var(--sky-start) 0%, var(--sky-mid) 42%, var(--sky-end) 100%);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;transition:background var(--transition), color var(--transition);background-attachment:fixed;line-height:1.6;overflow-x:hidden}#root{max-width:100%;min-height:100vh;margin:0 auto;position:relative}main{min-height:calc(100vh - 68px)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-light)}.navbar{z-index:100;background:var(--glass);-webkit-backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--glass-border);position:sticky;top:0;box-shadow:0 1px 12px #005aaa0f}.navbar-inner{justify-content:space-between;align-items:center;max-width:1320px;height:68px;margin:0 auto;padding:0 28px;display:flex}.navbar-brand{color:var(--text);font-family:var(--font-display);letter-spacing:1px;align-items:center;gap:10px;font-size:18px;font-weight:700;text-decoration:none;display:flex}.brand-icon{font-size:28px}.navbar-links{align-items:center;gap:6px;display:flex}.navbar-links a{color:var(--text-light);transition:all var(--transition);letter-spacing:.2px;border-radius:50px;padding:8px 18px;font-size:14px;font-weight:600;text-decoration:none}.navbar-links a:hover{color:var(--primary);background:var(--primary-light)}.lang-switch{background:var(--primary-light);border:1.5px solid var(--primary);color:var(--primary-dark);cursor:pointer;transition:all var(--transition);letter-spacing:.5px;border-radius:50px;padding:5px 14px;font-size:12px;font-weight:700}.lang-switch:hover{background:var(--primary);color:#fff}.theme-switch,.unit-switch{isolation:isolate;border:1px solid var(--border);background:var(--surface-soft);min-width:max-content;max-width:100%;min-height:38px;box-shadow:var(--shadow-sm);transition:all var(--transition);-webkit-user-select:none;user-select:none;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;gap:4px;margin-left:2px;padding:4px;display:inline-flex;position:relative;overflow:hidden}.theme-option,.unit-option{color:var(--text-light);cursor:pointer;letter-spacing:.2px;text-align:center;white-space:nowrap;font-variant-numeric:tabular-nums;z-index:0;min-height:30px;transition:all var(--transition);-webkit-user-select:none;user-select:none;background:0 0;border:none;border-radius:999px;outline:none;padding:6px 11px;font-size:12px;font-weight:700;line-height:1.2;position:relative;box-shadow:inset 0 0 0 1px #0000}.theme-option{min-width:54px}.unit-option{min-width:48px}.theme-option:hover,.unit-option:hover{color:var(--text)}.theme-option.active,.theme-option[aria-pressed=true],.unit-option.active,.unit-option[aria-pressed=true]{z-index:1;background:linear-gradient(135deg, var(--bg-card-solid) 0%, var(--surface-elevated) 100%);color:var(--primary-dark);box-shadow:inset 0 0 0 1px #00b8a02e,0 6px 14px #005aaa1a}:root[data-theme=dark] .theme-option.active,:root[data-theme=dark] .theme-option[aria-pressed=true],:root[data-theme=dark] .unit-option.active,:root[data-theme=dark] .unit-option[aria-pressed=true]{color:var(--primary);box-shadow:inset 0 0 0 1px #53d6c338,0 8px 18px #00000047}.unit-option:focus-visible,.theme-option:focus-visible{box-shadow:inset 0 0 0 1px #00b8a03d,0 0 0 2px #00b8a029}:root[data-theme=dark] .unit-option:focus-visible,:root[data-theme=dark] .theme-option:focus-visible{box-shadow:inset 0 0 0 1px #53d6c34d,0 0 0 2px #53d6c32e}.menu-toggle{cursor:pointer;color:var(--text);background:0 0;border:none;padding:8px;font-size:24px;display:none}.btn-text{color:var(--text-light);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:50px;padding:8px 18px;font-size:14px;font-weight:600}.btn-text:hover{color:var(--primary);background:var(--primary-light)}.btn-outline{border:2px solid var(--primary)!important;color:var(--primary)!important;border-radius:50px!important;padding:8px 20px!important;font-weight:700!important}.btn-outline:hover{background:var(--primary-light)!important}.btn-primary{cursor:pointer;transition:all var(--transition);text-align:center;letter-spacing:.3px;border:none;padding:10px 24px;font-size:14px;text-decoration:none;display:inline-block;box-shadow:0 4px 16px #00b8a04d;background:linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%)!important;color:#fff!important;border-radius:50px!important;font-weight:700!important}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 24px #00b8a073!important}.btn-disabled{opacity:.5!important;cursor:not-allowed!important;box-shadow:none!important;transform:none!important}.btn-secondary{border:2px solid var(--border);color:var(--text-light);cursor:pointer;transition:all var(--transition);background:0 0;border-radius:50px;margin-top:12px;padding:10px 24px;font-size:14px;font-weight:600}.btn-secondary:hover{color:#ef4444;background:var(--danger-soft);border-color:#ef4444}@media (width<=768px){.menu-toggle{display:block}.navbar-links{background:var(--surface-elevated);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);box-shadow:var(--shadow);flex-direction:column;gap:4px;padding:20px;display:none;position:absolute;top:68px;left:0;right:0}.navbar-links.open{display:flex}.navbar-links a{text-align:center;width:100%;padding:12px}.theme-switch,.unit-switch{justify-content:space-between;width:100%}.theme-option,.unit-option{flex:1 1 0}}.page{z-index:1;max-width:1320px;margin:0 auto;padding:32px 28px;position:relative}.status-page{place-items:center;min-height:calc(100vh - 180px);display:grid}.status-card{text-align:center;border-radius:var(--radius);background:var(--surface-elevated);border:1px solid var(--border);width:min(520px,100%);box-shadow:var(--shadow);justify-items:center;gap:16px;padding:40px 32px;display:grid}.status-icon{font-size:72px;line-height:1}.status-title{font-family:var(--font-display);color:var(--text-muted);font-size:clamp(40px,7vw,72px);line-height:1}.status-text{max-width:32ch;color:var(--text-light);font-size:17px}.hero{text-align:center;padding:56px 0 40px;position:relative}.hero h1{font-family:var(--font-display);letter-spacing:2px;background:linear-gradient(135deg, var(--text) 0%, var(--primary) 60%, var(--primary-dark) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:16px;font-size:44px;font-weight:800;animation:.8s ease-out fadeInUp}@keyframes fadeInUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.hero-sub{color:var(--text-light);max-width:600px;margin:0 auto 36px;font-size:17px;animation:.8s ease-out .15s both fadeInUp}@media (width<=768px){.hero h1{letter-spacing:1px;font-size:28px}}.search-section{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:32px;display:flex}.search-bar{flex:1;min-width:280px;position:relative}.search-bar input{width:100%;transition:all var(--transition);background:var(--glass);-webkit-backdrop-filter:var(--glass-blur);box-shadow:var(--shadow-sm);color:var(--text);border:2px solid #0000;border-radius:50px;outline:none;padding:14px 24px;font-size:15px}.search-bar input::placeholder{color:var(--text-muted)}.search-bar input:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-glow);background:var(--bg-card-solid)}.search-dropdown{background:var(--surface-elevated);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-hover);z-index:50;max-height:320px;margin-top:8px;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.search-item{cursor:pointer;border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:14px 24px;transition:background .2s;display:flex}.search-item:last-child{border-bottom:none}.search-item:hover{background:var(--primary-light)}.search-city-name{flex:1;font-weight:700}.search-icao{color:var(--primary);font-family:var(--font-mono);font-size:14px;font-weight:600}.search-country{color:var(--text-muted);font-size:13px}.btn-clear-filter{background:var(--primary-light);border:1.5px solid var(--primary);color:var(--primary-dark);cursor:pointer;white-space:nowrap;transition:all var(--transition);border-radius:50px;padding:8px 18px;font-size:13px;font-weight:600}.btn-clear-filter:hover{background:var(--primary);color:#fff}.home-city-sections{gap:22px;display:grid}.home-city-section{gap:14px;display:grid}.home-city-section-title{color:var(--text-light);letter-spacing:1.4px;text-transform:uppercase;margin:0;font-size:12px;font-weight:800}.city-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));align-items:stretch;gap:16px;display:grid}@media (width<=768px){.city-grid{grid-template-columns:1fr;gap:12px}}.city-card{background:var(--bg-card);-webkit-backdrop-filter:var(--glass-blur);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;transition:all var(--transition);border:1px solid var(--glass-border);box-sizing:border-box;grid-template-rows:auto minmax(86px,1fr) auto;min-height:232px;padding:18px;animation:.5s ease-out both cardFadeIn;display:grid;position:relative;overflow:hidden}@keyframes cardFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.city-grid .city-card:first-child{animation-delay:0s}.city-grid .city-card:nth-child(2){animation-delay:40ms}.city-grid .city-card:nth-child(3){animation-delay:80ms}.city-grid .city-card:nth-child(4){animation-delay:.12s}.city-grid .city-card:nth-child(5){animation-delay:.16s}.city-grid .city-card:nth-child(6){animation-delay:.2s}.city-grid .city-card:nth-child(7){animation-delay:.24s}.city-grid .city-card:nth-child(8){animation-delay:.28s}.city-grid .city-card:nth-child(9){animation-delay:.32s}.city-grid .city-card:nth-child(10){animation-delay:.36s}.city-grid .city-card:nth-child(11){animation-delay:.4s}.city-grid .city-card:nth-child(12){animation-delay:.44s}.city-grid .city-card:nth-child(n+13){animation-delay:.48s}.city-card:hover{background:var(--surface-elevated);border-color:#00b8a057;transform:translateY(-3px);box-shadow:0 1px 38px #005aaab3,0 0 4px 1px #00b8a0}.city-card.is-subscribed{border-color:#00b8a047;box-shadow:0 12px 30px #00b8a029}.city-card.is-subscribed:hover{background:var(--surface-elevated);border-color:#00b8a057;transform:translateY(-3px);box-shadow:0 1px 38px #005aaab3,0 0 4px 1px #00b8a0}.card-header{justify-content:space-between;align-items:flex-start;gap:12px;min-height:42px;margin-bottom:10px;display:flex}.card-city-info{flex:auto;min-width:0}.card-title-row{align-items:center;min-width:0;display:flex}.card-actions{flex:none;align-items:center;gap:8px;margin-left:auto;display:flex}.card-city-name{letter-spacing:.2px;-webkit-line-clamp:2;-webkit-box-orient:vertical;min-width:0;margin:0;font-size:20px;font-weight:800;line-height:1.25;display:-webkit-box;overflow:hidden}.card-icao{color:var(--primary);font-family:var(--font-mono);letter-spacing:1px;margin-top:2px;font-size:14px;font-weight:600}.card-updated-badge,.detail-time,.forecast-time,.forecast-date-time{color:var(--text-light);font-family:var(--font-mono);font-size:16px}.card-updated-badge{letter-spacing:1px;font-weight:800}.card-temp-label,.card-meta-label,.detail-label,.forecast-metric-label{color:var(--text-muted);font-weight:800}.card-temp-label{font-size:14px}.card-temp-block .card-temp-label,.detail-temp-stack .card-temp-label,.card-meta-label{letter-spacing:.8px;text-transform:uppercase}.card-main{grid-template-columns:58px minmax(0,1fr);align-items:center;gap:14px;min-width:0;margin-bottom:14px;display:grid}.card-weather-icon{justify-self:center}.card-temp-block{justify-items:center;gap:4px;min-width:0;display:grid}.card-temp{font-family:var(--font-display);letter-spacing:1px;color:var(--text);font-size:32px;font-weight:800;line-height:1}.card-phrase{min-height:18px;color:var(--text-light);text-align:center;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:13px;font-weight:500;line-height:1.35;display:-webkit-box;overflow:hidden}.card-meta,.card-meta--with-metar{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.card-meta-item{background:var(--surface-soft);border:1px solid var(--border);border-radius:14px;grid-template-rows:auto minmax(36px,1fr);align-items:end;gap:8px;min-width:0;min-height:96px;padding:12px 14px;display:grid;overflow:hidden}.card-meta-item--historical{text-align:center;justify-items:center}.card-meta-item--forecast-high{grid-column:1/-1}.card-meta-item--forecast-high>.card-meta-combined{flex-wrap:wrap;justify-content:space-evenly;align-items:center;gap:12px;min-width:0;min-height:32px;display:flex}.card-meta-combined-primary{color:var(--text);font-family:var(--font-mono);font-size:22px;font-weight:700;line-height:1.2}.card-meta-combined-primary-canvas{width:110px;height:28px}.card-meta-combined-secondary{color:var(--text-light);font-family:var(--font-mono);font-size:20px;font-weight:600;line-height:1.2}.card-meta-label{font-size:13px}.card-meta-value,.card-metar-temp,.card-metar-time{width:100%;min-width:0;color:var(--text);font-family:var(--font-mono);text-align:center;font-size:22px;font-weight:700;line-height:1.2;display:block}.card-metar-time{color:var(--text-light)}.card-metar-row{flex-wrap:wrap;justify-content:space-evenly;align-items:center;gap:10px;min-width:0;min-height:32px;line-height:1.2;display:flex}.card-metar-canvas{width:108px;height:28px}.card-meta-item>.card-meta-canvas{justify-self:center}.locked-metar-temp{justify-content:center;align-items:center;min-width:2.4em;padding:2px 6px 0;line-height:1;display:inline-flex;position:relative}.locked-metar-temp__value{filter:blur(4px);-webkit-user-select:none;user-select:none}.locked-metar-temp__badge{color:var(--primary);letter-spacing:.02em;white-space:nowrap;font-size:10px;font-weight:600;line-height:1;position:absolute;top:-.65em;right:-.55em}.subscribe-button{border:1px solid var(--border);background:var(--surface-soft);min-width:34px;min-height:34px;color:var(--text-light);cursor:pointer;transition:all var(--transition);border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:0 10px;font-size:16px;font-weight:800;display:inline-flex}.subscribe-button--icon{border-radius:14px;flex-shrink:0;gap:0;width:38px;min-width:38px;height:38px;min-height:38px;padding:0}.subscribe-button__icon{line-height:1;display:block;transform:translateY(-.5px)}.subscribe-button:hover{border-color:var(--primary);color:var(--primary)}.subscribe-button.active{background:var(--primary-light);color:var(--primary-dark);border-color:#00b8a047}.detail-subscribe-button{border-radius:14px;min-width:0;min-height:0;padding:10px 14px;font-size:13px}.card-temp-canvas,.detail-temp-canvas,.forecast-temp-canvas{font-family:var(--font-display)}.card-meta-canvas,.detail-value-canvas,.forecast-metric-canvas,.forecast-rain-canvas{font-family:var(--font-mono)}.card-temp-canvas,.card-meta-canvas,.detail-temp-canvas,.detail-value-canvas,.forecast-metric-canvas,.forecast-temp-canvas,.forecast-rain-canvas,.temperature-list-temp-canvas{filter:var(--secure-canvas-filter);transition:filter var(--transition);display:block}.card-meta-item .card-meta-canvas,.forecast-temp-canvas,.forecast-rain-canvas,.forecast-metric-canvas,.metar-temp-canvas{max-width:100%}.card-meta-item .card-meta-canvas{height:auto}.detail-label{color:var(--text-muted);font-weight:700}.detail-value{color:var(--text);font-size:13px;font-weight:700}.detail-value-row{flex-wrap:wrap;align-items:flex-start;gap:8px;min-height:32px;line-height:1.2;display:flex}@media (width<=768px){.home-city-sections{gap:18px}.home-city-section{gap:12px}.search-bar{min-width:100%}.city-card{padding:16px}.card-header{min-height:40px}.card-main{margin-bottom:12px}}@media (width<=520px){.card-header{align-items:flex-start}.card-actions{align-items:center}}.temp-cold{color:#3b82f6!important}.temp-cool{color:#06b6d4!important}.temp-mild{color:var(--text)!important}.temp-warm{color:#f59e0b!important}.temp-hot{color:#ef4444!important}.loading{text-align:center;padding:80px}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:44px;height:44px;margin:0 auto 16px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;color:var(--text-light);padding:80px;font-size:16px}.auth-page{justify-content:center;align-items:flex-start;padding-top:72px;display:flex}.auth-card{background:var(--glass);-webkit-backdrop-filter:var(--glass-blur);border-radius:var(--radius);width:100%;max-width:440px;box-shadow:var(--shadow);border:1px solid var(--glass-border);padding:44px;animation:.6s ease-out fadeInUp}.auth-card h2{font-size:28px;font-weight:800;font-family:var(--font-display);letter-spacing:1px;margin-bottom:28px}.form-group{margin-bottom:20px}.form-group label{color:var(--text);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:13px;font-weight:700;display:block}.form-group input{border:2px solid var(--border);border-radius:var(--radius-sm);width:100%;transition:all var(--transition);color:var(--text);background:#fffc;outline:none;padding:13px 18px;font-size:15px}.form-group input:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-glow);background:#fff}.form-hint{color:var(--text-muted);margin-top:6px;font-size:12px;display:block}.full-width{width:100%}.error-msg{background:var(--danger-soft);border:1px solid var(--danger-border);color:var(--danger-text);border-radius:var(--radius-xs);margin-bottom:20px;padding:12px 18px;font-size:14px;font-weight:500}.info-msg{background:var(--info-soft);border:1px solid var(--info-border);color:var(--info-text);border-radius:var(--radius-xs);margin-bottom:20px;padding:12px 18px;font-size:14px;font-weight:500}.form-actions-inline{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;display:flex}.cooldown-text{color:var(--text-muted);font-size:13px}.auth-footer{text-align:center;color:var(--text-light);margin-top:28px;font-size:14px}.auth-footer a{color:var(--primary);font-weight:700;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.success-box{background:var(--success-soft);border-radius:var(--radius-sm);border:1px solid #00b8a033;margin-bottom:24px;padding:24px}.api-key-display{margin:14px 0}.api-key-display label{color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:12px;font-weight:700;display:block}.api-key-display code{border-radius:var(--radius-xs);font-family:var(--font-mono);word-break:break-all;color:#a5f3fc;background:#1e293b;border:1px solid #334155;padding:14px;font-size:13px;display:block}.warning-text{color:var(--accent);margin-top:10px;font-size:13px;font-weight:700}.dashboard-page h1{font-family:var(--font-display);letter-spacing:1px;margin-bottom:32px;font-size:32px}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:20px;display:grid}.dash-card{background:var(--bg-card);-webkit-backdrop-filter:var(--glass-blur);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--glass-border);transition:all var(--transition);padding:28px}.dash-card:hover{box-shadow:var(--shadow-hover)}.dash-card h3{color:var(--text);text-transform:uppercase;letter-spacing:.5px;margin-bottom:18px;font-size:16px;font-weight:800}.dash-info>div{border-bottom:1px solid #0000000d;padding:10px 0;font-size:14px}.dash-info>div:last-child{border-bottom:none}.dash-label{color:var(--text-muted);margin-right:8px;font-size:13px;font-weight:500}.dash-hint{color:var(--text-muted);margin-top:14px;font-size:13px;line-height:1.5}.api-key-row{flex-direction:column;gap:12px;display:flex}.api-key-toggle{align-self:flex-start;margin-top:0}.dash-subscription-actions{flex-direction:column;gap:8px;margin-top:12px;display:flex}.dash-subscription-actions p{color:var(--text-light);margin-bottom:4px;font-size:14px}.subscription-card{border-radius:var(--radius-sm);background:var(--surface-soft);border:1px solid var(--border);box-shadow:var(--shadow-sm);gap:16px;padding:18px;display:grid}.subscription-summary,.subscription-expiry{justify-content:space-between;align-items:center;gap:16px;display:flex}.plan-badge{text-transform:uppercase;letter-spacing:1px;font-size:11px;font-weight:800;font-family:var(--font-mono);border-radius:50px;padding:3px 12px;display:inline-block}.plan-free{color:#475569;background:#f1f5f9}.plan-standard{color:#92400e;background:#fef3c7}.plan-premium{color:#065f46;background:#d1fae5}.plans-page{text-align:center}.plans-page h1{font-family:var(--font-display);letter-spacing:2px;margin-bottom:12px;font-size:36px}.plans-subtitle{color:var(--text-light);margin-bottom:48px;font-size:17px}.promo-banner{border-radius:var(--radius-sm);color:#9a5b00;background:linear-gradient(135deg,#f5a6232e,#fff4e0e0);border:1px solid #f5a62359;max-width:720px;margin:0 auto 24px;padding:14px 18px;font-size:14px;font-weight:700}.plans-message{border-radius:var(--radius-sm);max-width:600px;margin-bottom:28px;margin-left:auto;margin-right:auto;padding:14px 24px;font-size:14px;font-weight:600}.plans-message-success{background:var(--primary-light);color:var(--primary-dark);border:1px solid #00b8a04d}.plans-message-error{background:var(--danger-soft);border:1px solid var(--danger-border);color:var(--danger-text)}.plans-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));align-items:stretch;gap:24px;max-width:1000px;margin:0 auto;display:grid}.plan-card{background:var(--bg-card);-webkit-backdrop-filter:var(--glass-blur);border-radius:var(--radius);box-shadow:var(--shadow);border:2px solid var(--glass-border);text-align:left;transition:all var(--transition);flex-direction:column;min-height:100%;padding:36px 28px;display:flex;position:relative}.plan-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-4px)}.plan-featured{border-color:var(--primary);box-shadow:0 8px 34px #00b8a026}.plan-featured:hover{transform:translateY(-4px)}.plan-ribbon{background:linear-gradient(135deg, var(--primary), var(--primary-dark));color:#fff;letter-spacing:1px;text-transform:uppercase;border-radius:50px;padding:5px 20px;font-size:11px;font-weight:800;position:absolute;top:-14px;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #00b8a04d}.plan-card h3{margin-bottom:8px;font-size:22px;font-weight:800}.plan-price{margin-bottom:18px}.price-amount{font-family:var(--font-display);color:var(--text);letter-spacing:1px;font-size:44px;font-weight:900}.price-interval{color:var(--text-muted);font-size:15px}.plan-desc{color:var(--text-light);margin-bottom:24px;font-size:14px}.plan-features{flex:auto;margin-bottom:28px;list-style:none}.plan-features li{color:var(--text);border-bottom:1px solid #0000000a;padding:10px 0;font-size:14px;font-weight:500}.plan-features li:before{content:"✓";color:var(--primary);margin-right:10px;font-weight:800}.plan-card .btn-primary{margin-top:auto}.payment-panel{border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--glass-border);max-width:760px;box-shadow:var(--shadow);text-align:left;margin:0 auto 28px;padding:24px}.payment-panel h3{font-family:var(--font-display);margin-bottom:16px}.payment-row{gap:6px;margin-bottom:14px;display:grid}.payment-row span{color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:700}.payment-row code{border-radius:var(--radius-xs);color:#a5f3fc;word-break:break-all;background:#1e293b;padding:12px;display:block}.payment-choice{gap:12px;margin-top:auto;display:grid}.payment-choice label{color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;gap:8px;font-size:13px;font-weight:700;display:grid}.payment-choice select{border-radius:var(--radius-xs);border:1px solid var(--glass-border);background:var(--bg-card-solid);width:100%;color:var(--text);font:inherit;text-transform:none;letter-spacing:normal;padding:12px 14px}.nowpayments-widget{border:0;width:100%;max-width:410px;min-height:696px;margin:0 auto;display:block;overflow:hidden}.payment-actions{flex-wrap:wrap;gap:12px;margin-top:18px;display:flex}.payment-fee-note{color:var(--text-light);margin-top:4px;font-size:12px;line-height:1.45}.city-detail-page{animation:.6s ease-out fadeInUp}.back-link{color:var(--primary);background:var(--primary-light);transition:all var(--transition);border-radius:50px;align-items:center;gap:6px;margin-bottom:24px;padding:8px 16px;font-size:14px;font-weight:700;text-decoration:none;display:inline-flex}.back-link:hover{background:var(--primary);color:#fff}.detail-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;display:flex}.detail-heading{gap:4px;display:grid}.detail-header h1{font-family:var(--font-display);letter-spacing:1px;font-size:34px;font-weight:800}.detail-time{color:var(--text-muted);font-size:13px;font-family:var(--font-mono)}.detail-layout{grid-template-columns:minmax(0,1fr);align-items:start;gap:20px;display:grid}.detail-panel{background:var(--bg-card);-webkit-backdrop-filter:var(--glass-blur);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--glass-border);padding:24px}.detail-overview{gap:16px;margin-bottom:18px;display:grid}@media (width>=1180px){.detail-overview{grid-template-columns:minmax(0,1.1fr) minmax(320px,.95fr);align-items:stretch}}.detail-temp-main{flex-wrap:wrap;align-items:center;gap:16px;min-width:0;display:flex}.detail-temp-big{font-family:var(--font-display);color:var(--text);letter-spacing:2px;font-size:clamp(40px,6vw,60px);font-weight:900;line-height:1}.detail-temp-stack{flex:240px;gap:6px;min-width:0;display:grid}.detail-phrase{color:var(--text-light);font-size:14px;font-weight:500;line-height:1.45}.weather-icon{--weather-icon-size:52px;width:var(--weather-icon-size);height:var(--weather-icon-size);min-width:var(--weather-icon-size);flex-shrink:0;place-items:center;display:inline-grid}.weather-icon__image{background-image:var(--weather-icon-src-light);background-position:50%;background-repeat:no-repeat;background-size:contain;width:100%;height:100%}:root[data-theme=dark] .weather-icon__image{background-image:var(--weather-icon-src-dark,var(--weather-icon-src-light))}.weather-icon--compact{--weather-icon-size:32px}.weather-icon--card{--weather-icon-size:52px}.weather-icon--detail{--weather-icon-size:72px}.detail-highlights{grid-template-columns:repeat(auto-fit,minmax(148px,1fr));gap:10px;display:grid}.detail-highlight,.detail-item{background:var(--surface-soft);border:1px solid var(--border);min-width:0;transition:transform var(--transition), border-color var(--transition), background var(--transition);border-radius:16px;gap:6px;padding:12px 14px;display:grid}.detail-highlight:hover,.detail-item:hover{background:var(--surface-elevated);border-color:#00b8a047;transform:translateY(-1px)}.detail-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}@media (width>=900px){.detail-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}.detail-item .detail-label,.detail-highlight .detail-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:1.1px;font-size:11px;font-weight:800}.detail-item .detail-value,.detail-highlight .detail-value{color:var(--text);word-break:break-word;font-size:14px;font-weight:700}.detail-temp-canvas{flex:none}.detail-panel-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.detail-panel-header h2{font-family:var(--font-display);letter-spacing:1px;font-size:20px}.detail-loading{padding:18px 0 8px}.forecast-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px;display:grid}.forecast-hour{background:var(--surface-soft);border:1px solid var(--border);transition:all var(--transition);border-radius:20px;grid-template-rows:auto auto auto;gap:14px;min-width:0;padding:16px;display:grid}.forecast-row{justify-content:space-between;align-items:center;gap:16px;min-width:0;display:flex}.forecast-row--metrics,.forecast-row--actions{align-items:flex-start}.forecast-date-time{color:var(--text-muted);font-family:var(--font-mono);font-size:20px;font-weight:400;line-height:1.2}.forecast-inline-group{gap:8px;min-width:0;display:grid}.forecast-inline-group--temperature{justify-items:start}.forecast-inline-group--humidity{justify-items:stretch}.forecast-inline-group--humidity .forecast-inline-label{text-align:left;justify-self:start}.forecast-inline-group--humidity .forecast-inline-value{text-align:center;justify-self:center}.forecast-inline-group--wind{flex:auto}.forecast-inline-group--wind .forecast-inline-value{align-items:center;min-height:28px;line-height:1;display:flex}.forecast-row--actions .forecast-open-button{align-self:center;font-weight:400}.forecast-row--actions .forecast-inline-group--wind{align-self:center}.forecast-wind-block .forecast-metric-canvas{flex:none;height:28px;display:block}.forecast-wind-block>span{align-items:center;line-height:1;display:inline-flex}.forecast-wind-block canvas{vertical-align:middle}.forecast-wind-block .forecast-metric-canvas canvas{transform-origin:50%;transform:translateY(-1px)}.forecast-inline-label{color:var(--text-muted);letter-spacing:.4px;font-size:13px;font-weight:400}.forecast-inline-value{color:var(--text);font-size:16px;font-weight:400;line-height:1.2}.forecast-inline-value--temperature,.forecast-inline-value--temperature span,.forecast-inline-value--temperature canvas{font-weight:800}.forecast-wind-block{flex-wrap:wrap;align-items:center;gap:8px;min-height:28px;display:flex}.forecast-hour:hover{background:var(--surface-elevated);transform:translateY(-1px)}.forecast-time{color:var(--text-muted);font-size:12px;font-family:var(--font-mono)}.forecast-summary-item,.forecast-metric{gap:4px;min-width:0;display:grid}.forecast-metric-label{color:var(--text-muted);font-size:10px;font-family:var(--font-mono);letter-spacing:.7px;text-transform:uppercase}.forecast-metric-value{min-width:0;color:var(--text);word-break:break-word;font-size:12px;font-weight:700;line-height:1.25}.forecast-actions{justify-content:flex-end;margin-top:auto;display:flex}.forecast-open-button,.forecast-dialog-close{border:1px solid var(--border);background:var(--surface-elevated);color:var(--text);cursor:pointer;border-radius:999px;padding:8px 14px;font-size:12px;font-weight:700}.forecast-open-button:hover,.forecast-dialog-close:hover{border-color:#00b8a047}.forecast-dialog-backdrop{z-index:40;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#07101b94;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.forecast-dialog{background:var(--bg-card);border:1px solid var(--glass-border);width:min(720px,100%);max-height:min(82vh,760px);box-shadow:var(--shadow-hover);border-radius:20px;gap:16px;padding:20px;display:grid;overflow:auto}.forecast-dialog-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.forecast-dialog-heading{gap:6px;display:grid}.forecast-dialog-heading h3{font-family:var(--font-display);letter-spacing:.6px;font-size:22px}.forecast-dialog-overview{gap:8px;display:grid}.forecast-dialog-temp{min-height:24px;font-family:var(--font-display);align-items:center;font-size:18px;font-weight:800;display:flex}.forecast-summary-grid--dialog,.forecast-dialog-metrics{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 12px;display:grid}.forecast-dialog-metrics{border-top:1px solid var(--border);padding-top:16px}.metar-panel{overflow:hidden}.metar-table-wrap{width:100%;overflow-x:auto}.metar-table{border-collapse:collapse;width:100%;min-width:720px}.metar-table th,.metar-table td{border-bottom:1px solid var(--border);text-align:left;vertical-align:top;padding:10px 12px;font-size:13px}.metar-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;font-size:11px;font-weight:800}.metar-table td{color:var(--text);font-family:var(--font-mono)}.metar-temp{font-weight:700}@media (width<=520px){.metar-table th,.metar-table td{padding:8px 10px;font-size:12px}.metar-table{min-width:640px}.metar-temp-canvas{width:72px}.forecast-summary-grid,.forecast-summary-grid--dialog,.forecast-dialog-metrics{grid-template-columns:1fr}.forecast-dialog{border-radius:18px;padding:16px}.forecast-dialog-header{flex-direction:column}}@media (width<=768px){.detail-header{align-items:stretch}.detail-panel{padding:16px}.detail-overview{gap:12px;margin-bottom:14px}.detail-temp-main{gap:12px}.detail-highlight,.detail-item,.forecast-hour{border-radius:14px;padding:10px}.detail-grid,.forecast-grid{gap:8px}.detail-subscribe-button{justify-content:center;width:100%}}.forecast-row{gap:14px}.forecast-date-time{font-weight:400}.forecast-inline-label{font-size:13px;font-weight:400}.forecast-inline-value{font-size:16px;font-weight:400;line-height:1.2}.forecast-inline-value--temperature{font-weight:800}.detail-tabs-panel{flex-direction:column;gap:16px;display:flex}.detail-tabs-header{background:var(--surface-soft);border:1px solid var(--border);border-radius:14px;flex-wrap:wrap;gap:8px;padding:6px;display:flex}.detail-tab{min-width:110px;color:var(--text-light);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:10px;flex:140px;padding:10px 14px;font-family:inherit;font-size:14px;font-weight:600;transition:background .18s,color .18s,border-color .18s}.detail-tab:hover{color:var(--text);background:var(--surface-elevated)}.detail-tab.is-active{color:var(--primary-dark);background:var(--primary-light);border-color:var(--primary)}.detail-tabs-body{flex-direction:column;gap:16px;display:flex}.timeline-chart-scroll{width:100%;padding-bottom:6px;overflow-x:auto}.timeline-chart{background:var(--surface-soft);border:1px solid var(--border);border-radius:14px;padding:12px 12px 6px}.timeline-chart--empty{color:var(--text-muted);justify-content:center;align-items:center;font-size:14px;display:flex}.timeline-chart-tooltip{background:var(--bg-card-solid);border:1px solid var(--border);color:var(--text);border-radius:8px;flex-direction:column;gap:2px;padding:8px 10px;font-size:12px;display:flex;box-shadow:0 4px 14px #1018281f}.timeline-chart-tooltip-time{color:var(--text-light);font-family:var(--font-mono)}.timeline-chart-tooltip-value{font-family:var(--font-mono);font-size:16px;font-weight:700}.temperature-panel{flex-direction:column;gap:14px;display:flex}.temperature-list{border:1px solid var(--border);background:var(--surface-soft);border-radius:14px;margin:0;padding:0;list-style:none;overflow:hidden}.temperature-list--empty{text-align:center;color:var(--text-muted);padding:18px}.temperature-list-row{border-bottom:1px solid var(--border)}.temperature-list-row:last-child{border-bottom:none}.temperature-list-row--header{background:var(--surface-strong);color:var(--text-light);letter-spacing:.04em;text-transform:uppercase;font-size:12px}.temperature-list-row--header .temperature-list-cell{padding:10px 14px}.temperature-list-row:not(.temperature-list-row--header) .temperature-list-cells{grid-template-columns:minmax(120px,1.1fr) minmax(140px,1.2fr) minmax(160px,1.3fr) minmax(96px,.6fr);align-items:center;gap:12px;padding:10px 14px;display:grid}.temperature-list-row--header{grid-template-columns:minmax(120px,1.1fr) minmax(140px,1.2fr) minmax(160px,1.3fr) minmax(96px,.6fr);align-items:center;gap:12px;display:grid}.temperature-list-cell{min-width:0;font-family:var(--font-mono);color:var(--text);font-size:14px}.temperature-list-cell--temperature{font-size:18px;font-weight:700}.temperature-list-cell--fetched,.temperature-list-cell--observed{color:var(--text-light)}.temperature-list-cell--actions{text-align:right}.temperature-list-toggle{border:1px solid var(--border);color:var(--primary-dark);cursor:pointer;background:0 0;border-radius:8px;padding:6px 10px;font-family:inherit;font-size:12px;font-weight:600}.temperature-list-toggle:hover{background:var(--primary-light)}.temperature-list-temp{font-family:var(--font-mono);font-weight:700}.temperature-list-temp-canvas{display:inline-block}.temperature-list-details{background:var(--surface-strong);border-top:1px solid var(--border);grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px 14px;margin:0;padding:12px 14px 16px;display:grid}.temperature-list-detail{flex-direction:column;gap:2px;min-width:0;display:flex}.temperature-list-detail dt{color:var(--text-light);letter-spacing:.04em;text-transform:uppercase;font-size:11px}.temperature-list-detail dd{font-family:var(--font-mono);color:var(--text);word-break:break-word;margin:0;font-size:14px}.temperature-list-raw{font-family:var(--font-mono);color:var(--text-light);background:var(--bg-card-solid);border:1px solid var(--border);white-space:pre-wrap;word-break:break-all;border-radius:6px;padding:6px 8px;font-size:12px;display:block}@media (width<=720px){.temperature-list-row:not(.temperature-list-row--header) .temperature-list-cells{grid-template-columns:minmax(90px,1fr) minmax(96px,1fr) auto;grid-template-areas:"temp fetched actions""observed observed observed"}.temperature-list-cell--temperature{grid-area:temp}.temperature-list-cell--fetched{grid-area:fetched}.temperature-list-cell--actions{grid-area:actions}.temperature-list-cell--observed{grid-area:observed}.temperature-list-row--header{display:none}}.forecast-row--actions{align-items:center}.forecast-wind-block{min-height:28px}.forecast-open-button{flex:none}.forecast-temp-canvas{width:144px;height:30px}.forecast-metric-canvas{min-height:28px}.forecast-wind-block .forecast-metric-canvas{width:104px}.forecast-row--metrics .forecast-inline-group,.forecast-row--actions .forecast-inline-group{flex:1 1 0}.forecast-row--metrics .forecast-inline-group--temperature{flex:none}.forecast-row--metrics,.forecast-row--actions{justify-content:space-between}.forecast-row--time{justify-content:flex-start}.forecast-row--time .forecast-date-time+.forecast-date-time{margin-left:16px}.forecast-hour{padding:16px 18px}.forecast-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}@media (width<=680px){.forecast-grid{grid-template-columns:1fr}.forecast-row{gap:10px}.forecast-date-time,.forecast-inline-value,.forecast-open-button{font-size:18px}.forecast-inline-label{font-size:12px}.forecast-temp-canvas{width:132px;height:28px}.forecast-wind-block .forecast-metric-canvas{width:96px}}@media (width<=520px){.forecast-row--metrics,.forecast-row--actions{flex-wrap:wrap}.forecast-row--actions .forecast-open-button{text-align:center;justify-content:center;width:100%}}.detail-phrase{font-size:18px}.detail-item .detail-label,.detail-highlight .detail-label,.forecast-metric-label{font-size:13px}.detail-item .detail-value,.detail-highlight .detail-value,.forecast-metric-value{font-size:22px;line-height:1.2}.detail-temp-canvas{width:188px;height:40px}.forecast-temp{min-height:32px;font-size:22px;line-height:1.1}.forecast-open-button,.forecast-dialog-close{font-size:16px}.forecast-dialog-heading h3{font-size:28px}.forecast-dialog-temp{min-height:28px;font-size:22px}.metar-table th,.metar-table td{font-size:18px}.metar-table th{font-size:12px}.metar-temp{font-size:22px}.metar-temp-canvas,.forecast-metric-canvas,.forecast-rain-canvas,.detail-value-canvas{line-height:1.2}@media (width<=520px){.card-updated-badge,.detail-time,.forecast-time,.forecast-date-time{font-size:14px}.forecast-inline-value,.forecast-open-button{font-size:18px}.forecast-inline-label{font-size:12px}.forecast-temp-canvas{width:132px;height:28px}.forecast-wind-block .forecast-metric-canvas{width:96px}.card-meta-label,.detail-item .detail-label,.detail-highlight .detail-label,.forecast-metric-label{font-size:12px}.card-meta-value,.card-metar-temp,.card-metar-time,.detail-item .detail-value,.detail-highlight .detail-value,.forecast-metric-value,.metar-temp,.forecast-temp{font-size:18px}.detail-temp-canvas{width:168px;height:36px}.detail-phrase{font-size:16px}.forecast-dialog-heading h3{font-size:24px}.forecast-dialog-temp{font-size:18px}}.api-docs-page{max-width:860px}.api-docs-page h1{font-family:var(--font-display);letter-spacing:1px;margin-bottom:8px;font-size:36px}.docs-intro{color:var(--text-light);margin-bottom:40px;font-size:17px}.docs-section{margin-bottom:44px}.docs-section h2{border-bottom:2px solid var(--border);letter-spacing:.3px;margin-bottom:18px;padding-bottom:10px;font-size:22px;font-weight:800}.code-block{color:#a5f3fc;border-radius:var(--radius-sm);font-family:var(--font-mono);background:#0f172a;border:1px solid #1e293b;margin:14px 0;padding:18px 24px;font-size:13px;line-height:1.6;overflow-x:auto}.code-block code{color:inherit;font-size:inherit;background:0 0;padding:0}.endpoint{background:var(--bg-card);-webkit-backdrop-filter:var(--glass-blur);border-radius:var(--radius);border:1px solid var(--glass-border);box-shadow:var(--shadow-sm);transition:all var(--transition);margin-bottom:16px;padding:24px}.endpoint:hover{box-shadow:var(--shadow)}.endpoint-header{align-items:center;gap:14px;margin-bottom:12px;display:flex}.method{text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:800;font-family:var(--font-mono);border-radius:6px;padding:4px 12px}.method.get{color:#1d4ed8;background:#dbeafe}.method.post{color:#065f46;background:#d1fae5}.endpoint code{font-family:var(--font-mono);color:var(--text);font-size:14px;font-weight:600}.endpoint h4{text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);margin:18px 0 10px;font-size:13px;font-weight:700}.params-table{border-collapse:separate;border-spacing:0;border-radius:var(--radius-xs);border:1px solid var(--border);width:100%;margin:10px 0;font-size:14px;overflow:hidden}.params-table th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--text-light);background:linear-gradient(135deg,#c8e8ff66,#f5fbff99);padding:10px 16px;font-size:12px;font-weight:700}.params-table td{border-bottom:1px solid #0000000a;padding:10px 16px}.params-table tr:last-child td{border-bottom:none}.params-table code{font-size:13px;font-family:var(--font-mono);background:#0000000a;border-radius:4px;padding:2px 8px}.not-found{padding-block:56px}.not-found .status-card{gap:18px}
