.app{background:var(--bg-primary);display:flex;flex-direction:column;min-height:100vh}.header{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#0a0e1af2;border-bottom:1px solid var(--border);padding:0 24px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-inner{height:64px;justify-content:space-between;margin:0 auto;max-width:1100px}.header-inner,.logo{align-items:center;display:flex}.logo{gap:12px}.logo-icon{font-size:28px}.logo-title{color:var(--text-primary);font-size:18px;font-weight:800}.logo-sub{color:var(--text-muted);font-size:11px;letter-spacing:.05em}.header-controls{gap:16px}.header-controls,.toggle-label{align-items:center;display:flex}.toggle-label{cursor:pointer;gap:10px}.toggle-switch{border-radius:12px;cursor:pointer;height:24px;position:relative;transition:background .3s;width:44px}.toggle-thumb{background:#fff;border-radius:50%;box-shadow:0 2px 4px #0000004d;height:20px;position:absolute;top:2px;transition:transform .3s;width:20px}.main{flex:1 1;margin:0 auto;max-width:1100px;padding:32px 24px 48px;width:100%}.hero{align-items:center;display:flex;flex-direction:column;gap:16px;padding:32px 0 40px;text-align:center}.hero-title{color:var(--text-primary);font-size:clamp(28px,5vw,48px);font-weight:800;line-height:1.1}.gradient-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#38bdf8,#818cf8);-webkit-background-clip:text;background-clip:text}.hero-sub{color:var(--text-secondary);font-size:15px;max-width:480px}.filter-row{align-items:center;display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.filter-btn{background:#0000;border:1px solid var(--border);border-radius:16px;color:var(--text-secondary);cursor:pointer;font-family:Inter,sans-serif;font-size:12px;padding:4px 12px;transition:all .2s}.filter-btn.active{background:#38bdf826;color:#38bdf8}.filter-btn.active,.filter-btn:hover{border-color:#38bdf8}.filter-clear{background:#0000;border:1px solid #ef4444;border-radius:16px;color:#ef4444;cursor:pointer;font-family:Inter,sans-serif;font-size:11px;padding:4px 10px;transition:all .2s}.dashboard{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:16px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;transition:border-color .2s}.card:hover{border-color:#2a3d5e}.gauge-card{min-height:320px}.info-card{display:flex;flex-direction:column;gap:16px}.card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.card-header h3{color:var(--text-secondary);font-size:14px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.city-badge{background:#38bdf81a;border:1px solid #38bdf84d;border-radius:20px;color:#38bdf8;font-size:12px;padding:4px 10px}.recommendation{align-items:flex-start;background:#38bdf80d;border:1px solid #38bdf826;border-radius:10px;display:flex;gap:14px;padding:14px}.rec-icon{flex-shrink:0;font-size:24px}.recommendation p{color:var(--text-secondary);font-size:14px;line-height:1.5}.tab-nav{border-bottom:1px solid var(--border);flex-wrap:wrap;margin-bottom:16px}.tab-btn,.tab-nav{display:flex;gap:4px}.tab-btn{align-items:center;background:#0000;border:none;border-radius:8px 8px 0 0;color:var(--text-muted);cursor:pointer;font-family:Inter,sans-serif;font-size:13px;font-weight:500;padding:10px 16px;position:relative;transition:all .2s}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:#38bdf8}.tab-btn.active:after{background:#38bdf8;border-radius:2px 2px 0 0;bottom:-1px;content:"";height:2px;left:0;position:absolute;right:0}.alert-badge{background:#ef4444;border-radius:10px;color:#fff;font-size:10px;font-weight:700;padding:1px 6px}.pollutant-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.section-header{align-items:baseline;display:flex;gap:12px;margin-bottom:14px}.section-header h3{font-size:15px;font-weight:700}.section-sub{color:var(--text-muted);font-size:12px}.aqi-scale{display:flex;flex-direction:column;gap:10px}.scale-row{align-items:stretch;display:flex;gap:12px}.error-banner{align-items:flex-start;background:#ef44441a;border:1px solid #ef44444d;border-radius:10px;color:#fca5a5;display:flex;gap:14px;margin-bottom:16px;padding:16px}.error-banner strong{display:block;margin-bottom:4px}.error-banner p{color:#f87171;font-size:13px}.empty-state{color:var(--text-muted);font-size:14px;padding:40px;text-align:center}.empty-hero{align-items:center;display:flex;flex-direction:column;gap:12px;padding:80px 20px;text-align:center}.empty-hero h2{color:var(--text-secondary);font-size:20px}.empty-hero p{font-size:14px}.empty-hero p,.footer{color:var(--text-muted)}.footer{background:var(--bg-secondary);border-top:1px solid var(--border);display:flex;flex-direction:column;font-size:12px;gap:6px;padding:16px 24px;text-align:center}@media (max-width:600px){.header-inner{flex-direction:column;gap:8px;height:auto;padding:12px 0}.main{padding:16px 16px 32px}.hero{padding:16px 0 24px}.dashboard{grid-template-columns:1fr}}*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#0a0e1a;--bg-secondary:#0f1729;--bg-card:#131b2e;--bg-card-hover:#1a2540;--border:#1e2d4a;--text-primary:#e2e8f0;--text-secondary:#8b9ac0;--text-muted:#4a5880;--accent:#38bdf8;--accent-glow:#38bdf826;--good:#22c55e;--moderate:#eab308;--usg:#f97316;--unhealthy:#ef4444;--very-unhealthy:#a855f7;--hazardous:#991b1b;--radius:12px;--radius-sm:8px;--shadow:0 4px 24px #0006;--transition:0.2s ease}html{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;background:#0a0e1a;background:var(--bg-primary);color:#e2e8f0;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6;min-height:100vh}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:#0a0e1a;background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:#1e2d4a;background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#4a5880;background:var(--text-muted)}.font-mono{font-family:JetBrains Mono,monospace}@keyframes pulse-ring{0%{opacity:.8;transform:scale(.8)}to{opacity:0;transform:scale(1.4)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}.animate-fadeInUp{animation:fadeInUp .4s ease both}.skeleton{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,#131b2e 25%,#1a2540 50%,#131b2e 75%);background:linear-gradient(90deg,var(--bg-card) 25%,var(--bg-card-hover) 50%,var(--bg-card) 75%);background-size:200px 100%;border-radius:8px;border-radius:var(--radius-sm)}
/*# sourceMappingURL=main.d116e1b7.css.map*/