:root{--bg:#0a0a0f;--bg2:#111118;--bg3:#1a1a24;--border:#2a2a3a;--accent:#00e5ff;--accent2:#ff6b35;--accent3:#b388ff;--text:#e8e8f0;--text2:#88a;--text3:#555570;--good:#4ade80;--warn:#facc15;--danger:#f87171;--card-radius:12px;--font-display:"Syne",sans-serif;--font-mono:"Space Mono",monospace}*{box-sizing:border-box;margin:0;padding:0}body{background:#0a0a0f;background:var(--bg);color:#e8e8f0;color:var(--text);font-family:Syne,sans-serif;font-family:var(--font-display);overflow-x:hidden}.app,body{min-height:100vh}.app{display:flex;flex-direction:column}.app-header{background:#111118;background:var(--bg2);border-bottom:1px solid #2a2a3a;border-bottom:1px solid var(--border);gap:12px;justify-content:space-between;padding:16px 24px;position:sticky;top:0;z-index:100}.app-header,.header-left{align-items:center;display:flex;flex-wrap:wrap}.header-left{gap:16px}.logo{color:#00e5ff;color:var(--accent);font-family:Syne,sans-serif;font-family:var(--font-display);font-size:1.2rem;font-weight:800;letter-spacing:.08em}.loc-badge{border:1px solid #2a2a3a;border:1px solid var(--border);border-radius:20px;color:#88a;color:var(--text2);font-family:Space Mono,monospace;font-family:var(--font-mono);font-size:.72rem;padding:4px 10px}.app-nav,.loc-badge{background:#1a1a24;background:var(--bg3)}.app-nav{border:1px solid #2a2a3a;border:1px solid var(--border);border-radius:8px;display:flex;gap:4px;padding:4px}.nav-btn{background:#0000;border:none;border-radius:6px;color:#88a;color:var(--text2);cursor:pointer;font-family:Syne,sans-serif;font-family:var(--font-display);font-size:.75rem;font-weight:700;letter-spacing:.1em;padding:8px 20px;transition:all .2s}.nav-btn.active{background:#00e5ff;background:var(--accent);color:#0a0a0f;color:var(--bg)}.nav-btn:hover:not(.active){background:#2a2a3a;background:var(--border);color:#e8e8f0;color:var(--text)}.loc-error{background:#2a1a0a;border-bottom:1px solid #ff6b3540;color:#ff6b35;color:var(--accent2);font-family:Space Mono,monospace;font-family:var(--font-mono);font-size:.75rem;padding:8px 24px;text-align:center}.app-main{flex:1 1;margin:0 auto;max-width:1400px;padding:24px;width:100%}.loading-screen{align-items:center;color:#88a;color:var(--text2);display:flex;flex-direction:column;font-family:Space Mono,monospace;font-family:var(--font-mono);font-size:.85rem;gap:20px;height:60vh;justify-content:center}.loader-ring{animation:spin .8s linear infinite;border:3px solid #2a2a3a;border-top-color:#00e5ff;border:3px solid var(--border);border-radius:50%;border-top-color:var(--accent);height:48px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.card{background:#111118;background:var(--bg2);border:1px solid #2a2a3a;border:1px solid var(--border);border-radius:12px;border-radius:var(--card-radius);padding:20px}.card-label{color:#555570;color:var(--text3);font-size:.65rem;letter-spacing:.12em;margin-bottom:6px;text-transform:uppercase}.card-label,.card-value{font-family:Space Mono,monospace;font-family:var(--font-mono)}.card-value{color:#e8e8f0;color:var(--text);font-size:1.4rem;font-weight:700}.card-unit{color:#88a;color:var(--text2);font-size:.75rem;margin-left:4px}.stat-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));margin-bottom:24px}.stat-card{background:#111118;background:var(--bg2);border:1px solid #2a2a3a;border:1px solid var(--border);border-radius:12px;border-radius:var(--card-radius);padding:16px;transition:border-color .2s}.stat-card:hover{border-color:#00e5ff;border-color:var(--accent)}.stat-card .label{color:#555570;color:var(--text3);font-size:.6rem;letter-spacing:.1em;margin-bottom:8px;text-transform:uppercase}.stat-card .label,.stat-card .value{font-family:Space Mono,monospace;font-family:var(--font-mono)}.stat-card .value{color:#e8e8f0;color:var(--text);font-size:1.3rem;font-weight:700;line-height:1}.stat-card .unit{color:#88a;color:var(--text2);font-size:.65rem;margin-left:3px}.stat-card .icon{display:block;font-size:1.4rem;margin-bottom:8px}.section-title{align-items:center;color:#88a;color:var(--text2);display:flex;font-family:Syne,sans-serif;font-family:var(--font-display);font-size:.8rem;font-weight:800;gap:10px;letter-spacing:.15em;margin-bottom:16px;text-transform:uppercase}.section-title:after{background:#2a2a3a;background:var(--border);content:"";flex:1 1;height:1px}.chart-wrap{background:#111118;background:var(--bg2);border:1px solid #2a2a3a;border:1px solid var(--border);border-radius:12px;border-radius:var(--card-radius);margin-bottom:16px;overflow-x:auto;padding:20px}.chart-title{color:#88a;color:var(--text2);font-family:Space Mono,monospace;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.08em;margin-bottom:14px;text-transform:uppercase}.chart-inner{min-width:600px}.date-row{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px}.date-label{color:#88a;color:var(--text2);font-size:.72rem}.date-input,.date-label{font-family:Space Mono,monospace;font-family:var(--font-mono)}.date-input{background:#1a1a24;background:var(--bg3);border:1px solid #2a2a3a;border:1px solid var(--border);border-radius:8px;color:#e8e8f0;color:var(--text);font-size:.8rem;outline:none;padding:8px 14px;transition:border-color .2s}.date-input:focus{border-color:#00e5ff;border-color:var(--accent)}.toggle-row{align-items:center;display:flex;gap:8px;margin-left:auto}.toggle-label{color:#88a;color:var(--text2)}.toggle-btn,.toggle-label{font-family:Space Mono,monospace;font-family:var(--font-mono);font-size:.7rem}.toggle-btn{background:#1a1a24;background:var(--bg3);border:1px solid #2a2a3a;border:1px solid var(--border);border-radius:20px;color:#e8e8f0;color:var(--text);cursor:pointer;padding:5px 14px;transition:all .2s}.toggle-btn.on{background:#00e5ff;background:var(--accent);border-color:#00e5ff;border-color:var(--accent);color:#0a0a0f;color:var(--bg)}.aqi-badge{align-items:center;border-radius:20px;display:inline-flex;font-family:Space Mono,monospace;font-family:var(--font-mono);font-size:.75rem;font-weight:700;gap:6px;padding:4px 12px}.temp-hero{align-items:center;background:linear-gradient(135deg,#0d1a2a,#0a0f1e);border:1px solid #1a3050;border-radius:16px;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;margin-bottom:24px;padding:32px}.temp-current{color:#00e5ff;color:var(--accent);font-size:4rem;font-weight:700;line-height:1}.temp-current,.temp-range{font-family:Space Mono,monospace;font-family:var(--font-mono)}.temp-range{color:#88a;color:var(--text2);font-size:.85rem;margin-top:8px}.temp-meta{text-align:right}.temp-date{color:#e8e8f0;color:var(--text);font-family:Syne,sans-serif;font-family:var(--font-display);font-size:1.1rem;font-weight:700}.temp-loc{color:#88a;color:var(--text2);font-family:Space Mono,monospace;font-family:var(--font-mono);font-size:.75rem;margin-top:4px}.hist-controls{align-items:flex-end;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px}.hist-control-group{display:flex;flex-direction:column;gap:6px}.hist-control-group label{color:#555570;color:var(--text3);font-family:Space Mono,monospace;font-family:var(--font-mono);font-size:.65rem;letter-spacing:.08em;text-transform:uppercase}.fetch-btn{align-self:flex-end;background:#00e5ff;background:var(--accent);border:none;border-radius:8px;color:#0a0a0f;color:var(--bg);cursor:pointer;font-family:Syne,sans-serif;font-family:var(--font-display);font-size:.8rem;font-weight:700;letter-spacing:.05em;padding:10px 24px;transition:opacity .2s}.fetch-btn:hover{opacity:.85}.fetch-btn:disabled{cursor:not-allowed;opacity:.4}@media (max-width:600px){.app-main{padding:16px}.temp-hero{padding:20px}.temp-current{font-size:2.8rem}.stat-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.app-header{padding:12px 16px}}
/*# sourceMappingURL=main.3ec987c5.css.map*/