@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=Manrope:wght@500;600;700;800&display=swap";:root{font-family:DM Sans,sans-serif;color:#eaf5f1;background:#071a17;font-synthesis:none;--bg: #071a17;--panel: #0d2420;--panel-2: #112d27;--line: rgba(196, 232, 221, .12);--muted: #91aaa3;--mint: #45d6ae;--mint-dark: #123d33;--cream: #e9f3e8;--danger: #f05d62}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:var(--bg)}button,input,select{font:inherit}button{cursor:pointer}h1,h2,h3,p{margin-top:0}h1,h2,h3,strong{font-family:Manrope,sans-serif}.logo{display:flex;align-items:center;gap:11px;color:#fff}.logo-mark{width:42px;height:42px;display:grid;place-items:center;border-radius:13px;background:var(--mint);color:#06231c}.logo strong,.logo small{display:block;line-height:1.08}.logo strong{font-size:17px}.logo small{color:var(--muted);font-size:10px;letter-spacing:.16em;text-transform:uppercase;margin-top:4px}.eyebrow{margin-bottom:8px;color:var(--mint);text-transform:uppercase;letter-spacing:.16em;font-size:11px;font-weight:700}.primary-button{border:0;border-radius:12px;background:var(--mint);color:#06231c;min-height:48px;padding:0 20px;font-weight:700;display:inline-flex;justify-content:center;align-items:center;gap:9px;transition:.2s ease}.primary-button:hover{transform:translateY(-1px);background:#63e4c0}.primary-button:disabled{opacity:.55;cursor:wait;transform:none}.text-button{border:0;background:transparent;color:var(--mint);display:flex;gap:7px;align-items:center}.icon-button{border:0;background:transparent;color:inherit}.auth-page{min-height:100vh;display:grid;grid-template-columns:minmax(360px,45%) 1fr}.auth-visual{padding:44px 56px;display:flex;flex-direction:column;background:radial-gradient(circle at 72% 24%,rgba(69,214,174,.25),transparent 27%),linear-gradient(145deg,#0b2923,#061512);position:relative;overflow:hidden}.auth-visual:after{content:"";position:absolute;width:490px;height:490px;border:1px solid rgba(69,214,174,.12);border-radius:50%;bottom:-260px;right:-170px;box-shadow:0 0 0 60px #45d6ae06,0 0 0 120px #45d6ae05}.visual-copy{margin:auto 0;max-width:520px;position:relative;z-index:1}.visual-icon{display:grid;place-items:center;width:54px;height:54px;border:1px solid rgba(69,214,174,.35);border-radius:50%;color:var(--mint);margin-bottom:28px}.visual-copy h1{font-size:clamp(48px,5vw,78px);line-height:.98;letter-spacing:-.055em;margin-bottom:26px}.visual-copy>p:not(.eyebrow){color:#acc2bc;font-size:17px;line-height:1.65;max-width:470px}.auth-features{display:flex;flex-wrap:wrap;gap:12px;margin-top:32px}.auth-features span{display:flex;align-items:center;gap:8px;padding:10px 13px;border:1px solid var(--line);background:#ffffff09;border-radius:999px;font-size:13px}.copyright{color:#647f78;font-size:12px;margin:0;position:relative;z-index:1}.auth-form-panel{display:grid;place-items:center;padding:42px;background:#f3f6f1;color:#16231f;overflow-y:auto}.auth-card{width:min(440px,100%)}.auth-card h2{font-size:31px;letter-spacing:-.035em;margin-bottom:9px}.auth-card>p:not(.eyebrow):not(.form-message){color:#66736f;margin-bottom:28px}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;padding:4px;background:#e3e9e4;border-radius:12px;margin-bottom:22px}.auth-tabs button{border:0;padding:10px;border-radius:9px;color:#65716d;background:transparent;font-weight:600}.auth-tabs button.active{background:#fff;color:#10241e;box-shadow:0 3px 12px #0c261e14}label{display:block;color:inherit;font-size:13px;font-weight:600;margin-bottom:15px}label small{float:right;color:#82908b;font-weight:400}input,select{width:100%;min-height:46px;margin-top:7px;border:1px solid #ccd5d0;border-radius:10px;padding:0 13px;color:#172a24;background:#fff;outline:none}input:focus,select:focus{border-color:#22a985;box-shadow:0 0 0 3px #45d6ae26}.password-field{display:block;position:relative}.password-field input{padding-right:44px}.password-field button{position:absolute;right:11px;top:20px;border:0;background:transparent;color:#74817d}.auth-card .primary-button{width:100%;margin-top:4px}.form-message{padding:11px 13px;background:#fbe9e8;color:#9a342f;border-radius:9px;font-size:13px;line-height:1.4}.mobile-logo{display:none}.loading-screen,.config-screen{min-height:100vh;display:grid;place-items:center;text-align:center}.loading-screen{gap:22px;align-content:center}.spinner{width:30px;height:30px;border:3px solid rgba(69,214,174,.2);border-top-color:var(--mint);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.config-screen div{max-width:520px;padding:32px}.config-screen code{background:#15332c;padding:2px 6px;border-radius:5px}.onboarding-page{min-height:100vh;padding:34px 5vw;background:radial-gradient(circle at 50% 12%,rgba(69,214,174,.13),transparent 24%),var(--bg)}.onboarding-page header{max-width:1100px;margin:auto}.onboarding-card{width:min(560px,100%);margin:55px auto;background:#f2f5f0;color:#17251f;border-radius:24px;padding:42px;box-shadow:0 30px 80px #00000040}.onboarding-icon{width:54px;height:54px;display:grid;place-items:center;border-radius:15px;background:#d9f4e8;color:#128867;margin:18px 0}.step-pill{color:#158365;background:#dff4e9;border-radius:999px;padding:7px 11px;font-size:12px;font-weight:700}.onboarding-card h1{font-size:32px;letter-spacing:-.04em;margin-bottom:10px}.onboarding-card>p{color:#687771;line-height:1.55;margin-bottom:26px}.two-fields{display:grid;grid-template-columns:1fr 1fr;gap:14px}.privacy-note{display:flex;gap:8px;align-items:center;color:#698078;font-size:12px}.onboarding-card .primary-button{width:100%}.app-shell{min-height:100vh;display:grid;grid-template-columns:245px 1fr}.sidebar{position:sticky;top:0;height:100vh;padding:28px 22px;border-right:1px solid var(--line);background:#081d19;display:flex;flex-direction:column}.sidebar nav{margin-top:54px;display:grid;gap:6px}.nav-item{width:100%;display:flex;align-items:center;gap:12px;color:#87a19a;background:transparent;border:0;padding:12px 13px;border-radius:10px;text-align:left}.nav-item:hover,.nav-item.active{color:#eafff8;background:#45d6ae1a}.nav-item.active{box-shadow:inset 3px 0 var(--mint)}.sidebar-bottom{margin-top:auto;display:grid;gap:10px}.live-chip{display:flex;align-items:center;gap:8px;color:#739089;font-size:12px;padding:10px 13px}.live-chip span{width:7px;height:7px;background:var(--mint);border-radius:50%;box-shadow:0 0 0 4px #45d6ae1f}.main-panel{min-width:0}.topbar{min-height:126px;padding:30px 4vw 24px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:20px}.topbar h1{font-size:27px;letter-spacing:-.035em;margin-bottom:5px}.topbar>div>p:last-child{margin:0;color:var(--muted);font-size:14px}.role-pill{padding:8px 12px;border-radius:999px;color:var(--mint);background:#45d6ae1a;border:1px solid rgba(69,214,174,.18);font-size:12px;font-weight:700}.role-pill.admin{color:#f2c94c;background:#f2c94c14;border-color:#f2c94c2e}.dashboard-content{padding:30px 4vw 60px}.card{background:linear-gradient(145deg,#122f28eb,#0a201bf5);border:1px solid var(--line);border-radius:18px}.location-strip{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;color:var(--muted);font-size:14px}.location-strip>span{display:flex;align-items:center;gap:7px}.location-strip strong{color:#eaf5f1}.user-hero{display:grid;grid-template-columns:.9fr 1.1fr;min-height:330px;overflow:hidden}.user-hero>div{padding:34px}.user-hero>div:first-child{display:flex;flex-direction:column;align-items:center;justify-content:center;border-right:1px solid var(--line)}.user-hero .eyebrow{align-self:flex-start}.aqi-gauge{display:grid;justify-items:center}.gauge-ring{width:220px;height:220px;border-radius:50%;display:grid;place-items:center;transform:rotate(45deg)}.gauge-center{width:174px;height:174px;border-radius:50%;background:#0d2420;display:grid;place-content:center;justify-items:center;transform:rotate(-45deg);box-shadow:inset 0 0 35px #00000040}.gauge-center strong{font-size:57px;line-height:1}.gauge-center span{color:var(--muted);font-size:12px;letter-spacing:.18em;margin-top:4px}.aqi-label{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;margin-top:-6px}.aqi-label span{width:7px;height:7px;border-radius:50%}.aqi-gauge.compact .gauge-ring{width:128px;height:128px}.aqi-gauge.compact .gauge-center{width:100px;height:100px}.aqi-gauge.compact .gauge-center strong{font-size:34px}.aqi-gauge.compact .aqi-label{display:none}.last-updated{color:var(--muted);font-size:12px;margin:16px 0 0}.health-guidance{display:flex;flex-direction:column;justify-content:center;background:radial-gradient(circle at 100% 0,rgba(69,214,174,.12),transparent 38%)}.guidance-icon{width:48px;height:48px;display:grid;place-items:center;border-radius:13px;color:var(--mint);background:#45d6ae1c;margin-bottom:28px}.health-guidance h2{font-size:28px;letter-spacing:-.035em;margin-bottom:12px}.health-guidance>p:not(.eyebrow){color:#b4c6c1;line-height:1.65;max-width:520px}.profile-chip{align-self:flex-start;margin-top:14px;padding:8px 11px;border-radius:8px;background:#ffffff0d;color:#b4cbc5;font-size:12px}.section-block{margin-top:34px}.section-heading{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:18px;gap:15px}.section-heading h2{margin:0;font-size:21px;letter-spacing:-.025em}.section-heading>span{color:var(--muted);font-size:12px}.pollutant-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.pollutant-card{padding:20px;border:1px solid var(--line);border-radius:15px;background:#ffffff06}.pollutant-top{display:flex;align-items:center;justify-content:space-between;color:#b8cdc7;font-size:13px}.pollutant-top small{color:#69867f;font-size:10px}.pollutant-card>strong{display:inline-block;font-size:30px;margin:18px 6px 12px 0}.pollutant-card .unit{color:var(--muted);font-size:11px}.mini-track{height:3px;border-radius:3px;background:#ffffff14;overflow:hidden}.mini-track span{display:block;height:100%;border-radius:inherit;background:var(--mint)}.chart-card{margin-top:34px;padding:25px}.chart-wrap{height:280px}.prediction-chip{display:inline-flex;align-items:center;gap:6px;color:#a9bcb6!important}.empty-state{height:100%;display:grid;place-items:center;color:var(--muted)}.alert-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#020a08d6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:grid;place-items:center;padding:20px}.danger-alert{width:min(480px,100%);text-align:center;padding:42px;border-radius:24px;background:#f5f5ef;color:#251b1b;position:relative;box-shadow:0 30px 100px #0000008c;border-top:5px solid var(--danger)}.danger-alert .dismiss{position:absolute;right:17px;top:17px;color:#7f6d6d}.danger-icon{width:66px;height:66px;margin:0 auto 22px;display:grid;place-items:center;border-radius:50%;background:#f9dedd;color:#bd353a}.danger-alert h2{font-size:28px;letter-spacing:-.04em}.alert-aqi{display:inline-flex;align-items:baseline;gap:6px;color:#bd353a;font:800 56px Manrope}.alert-aqi span{font:700 12px DM Sans;letter-spacing:.14em}.alert-location{font-weight:700;margin-bottom:20px}.danger-alert>p:not(.eyebrow):not(.alert-location){color:#685958;line-height:1.55}.danger-button{width:100%;margin-top:14px;background:#bd353a;color:#fff}.danger-button:hover{background:#a82d32}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}.stat-card{min-height:105px;padding:20px;border:1px solid var(--line);border-radius:15px;background:#ffffff06;display:flex;gap:14px;align-items:center;color:var(--mint)}.stat-card strong,.stat-card span{display:block}.stat-card strong{color:#fff;font-size:23px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:170px}.stat-card span{color:var(--muted);font-size:12px;margin-top:3px}.admin-layout{display:grid;grid-template-columns:310px 1fr;gap:18px;align-items:start}.node-list,.control-panel{padding:22px}.node-options{display:grid;gap:8px}.node-option{border:1px solid transparent;background:transparent;color:inherit;padding:13px 11px;border-radius:11px;display:grid;grid-template-columns:8px 1fr auto;gap:11px;align-items:center;text-align:left}.node-option:hover{background:#ffffff09}.node-option.selected{background:#45d6ae14;border-color:#45d6ae33}.node-dot{width:7px;height:7px;border-radius:50%}.node-option strong,.node-option small{display:block}.node-option strong{font-size:13px}.node-option small{color:var(--muted);font-size:10px;margin-top:3px}.node-option b{font-size:16px}.control-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:22px;border-bottom:1px solid var(--line)}.control-header h2{margin-bottom:5px;font-size:25px}.control-header>div>p:last-child{color:var(--muted);margin:0;font-size:11px}.control-panel label{color:#a8bdb7}.control-panel input{background:#0b211c;border-color:#28463e;color:#eef8f5}.aqi-control{display:flex;align-items:end;gap:14px;padding:22px 0 8px}.aqi-control label{flex:1;margin:0}.aqi-control input{font:700 25px Manrope}.quick-buttons{display:flex;gap:6px}.quick-buttons button,.increment-button{min-height:42px;border-radius:9px;border:1px solid #2b4b42;color:var(--mint);background:#45d6ae0f;display:inline-flex;align-items:center;justify-content:center}.quick-buttons button{padding:0 10px}.admin-pollutants{margin-top:18px;display:grid;gap:8px}.pollutant-control{display:grid;grid-template-columns:80px 1fr 1fr 55px;gap:10px;align-items:end;padding:12px;border-radius:11px;background:#ffffff06}.pollutant-control>div strong,.pollutant-control>div span{display:block}.pollutant-control>div span{color:var(--muted);font-size:10px;margin-top:3px}.pollutant-control label{margin:0;font-size:10px}.pollutant-control input{min-height:38px;margin-top:4px}.increment-button{height:38px;gap:4px}.control-actions{display:flex;justify-content:space-between;align-items:center;gap:24px;margin-top:20px;padding-top:20px;border-top:1px solid var(--line)}.control-actions p{max-width:520px;color:var(--muted);font-size:11px;line-height:1.5;margin:0}.control-actions .primary-button{white-space:nowrap}.success-message{display:flex;align-items:center;gap:8px;color:#7ee5c6;background:#45d6ae14;padding:10px 12px;border-radius:9px;font-size:12px;margin:15px 0 0}@media(max-width:1100px){.pollutant-grid,.stat-grid{grid-template-columns:repeat(2,1fr)}.admin-layout{grid-template-columns:260px 1fr}.pollutant-control{grid-template-columns:65px 1fr 1fr}.increment-button{display:none}}@media(max-width:820px){.auth-page{display:block}.auth-visual{display:none}.auth-form-panel{min-height:100vh;padding:28px 20px;align-content:start}.mobile-logo{display:block;width:100%;margin-bottom:60px}.mobile-logo .logo{color:#14241f}.app-shell{display:block}.sidebar{position:static;height:auto;padding:18px 20px;flex-direction:row;align-items:center;justify-content:space-between}.sidebar nav,.sidebar .live-chip{display:none}.sidebar-bottom{margin:0}.sidebar-bottom .nav-item{width:auto;font-size:0}.topbar{min-height:105px;padding:22px 20px}.topbar h1{font-size:22px}.topbar>div>p:last-child{display:none}.dashboard-content{padding:22px 20px 50px}.user-hero{grid-template-columns:1fr}.user-hero>div:first-child{border-right:0;border-bottom:1px solid var(--line)}.admin-layout{grid-template-columns:1fr}.node-options{grid-template-columns:repeat(2,1fr)}}@media(max-width:560px){.pollutant-grid,.stat-grid{grid-template-columns:1fr 1fr;gap:9px}.pollutant-card{padding:15px}.pollutant-card>strong{font-size:24px}.stat-card{padding:14px;min-height:88px}.stat-card strong{font-size:19px;max-width:95px}.location-strip{align-items:flex-start}.location-strip .text-button{font-size:0}.user-hero>div{padding:24px}.gauge-ring{width:190px;height:190px}.gauge-center{width:150px;height:150px}.node-options{grid-template-columns:1fr}.control-header{align-items:flex-start}.aqi-gauge.compact{display:none}.aqi-control{display:block}.quick-buttons{margin-top:8px}.pollutant-control{grid-template-columns:56px 1fr 1fr;padding:9px;gap:7px}.control-actions{display:block}.control-actions .primary-button{width:100%;margin-top:15px}.danger-alert{padding:36px 24px 28px}.onboarding-card{padding:26px 20px}.two-fields{grid-template-columns:1fr;gap:0}}
