@import "https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=Space+Grotesk:wght@400;500;600;700&display=swap";:root{--bg-base:#f4f5fb;--bg-surface:#fff;--bg-card:#fff;--bg-card-hover:#f8f7ff;--bg-panel:#f0f0f8;--bg-glass:#6c63ff0a;--bg-glass-hover:#6c63ff14;--border:#6c63ff1a;--border-bright:#6c63ff38;--border-accent:#6c63ff66;--accent:#6c63ff;--accent-dim:#6c63ff1f;--accent-glow:#6c63ff40;--accent2:#a78bfa;--accent2-dim:#a78bfa26;--green:#10b981;--green-dim:#10b9811a;--green-glow:#10b98140;--orange:#f59e0b;--orange-dim:#f59e0b1a;--red:#ef4444;--red-dim:#ef444414;--yellow:#f59e0b;--yellow-dim:#f59e0b1f;--yellow-glow:#f59e0b4d;--text-primary:#1e1b4b;--text-secondary:#6b7280;--text-muted:#9ca3af;--text-accent:#6c63ff;--radius-xs:6px;--radius-sm:10px;--radius:14px;--radius-lg:20px;--radius-xl:28px;--shadow-sm:0 1px 4px #6c63ff14, 0 2px 8px #0000000d;--shadow:0 4px 20px #6c63ff1a, 0 8px 24px #0000000f;--shadow-lg:0 12px 40px #6c63ff26, 0 20px 60px #00000014;--shadow-accent:0 0 30px #6c63ff33;--sidebar-w:260px;--t-fast:all .15s ease;--t:all .25s cubic-bezier(.4, 0, .2, 1);--t-slow:all .4s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;font-family:Plus Jakarta Sans,sans-serif;overflow-x:hidden}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:6px}::-webkit-scrollbar-thumb:hover{background:#6c63ff59}a{color:var(--accent);transition:var(--t);text-decoration:none}a:hover{color:#5b52e8}.auth-bg{background:var(--bg-base);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative;overflow:hidden}.auth-bg:before{content:"";pointer-events:none;background:radial-gradient(70% 70% at 15% 40%,#6c63ff12 0%,#0000 65%),radial-gradient(50% 60% at 85% 15%,#a78bfa0f 0%,#0000 55%),radial-gradient(40% 50% at 50% 90%,#10b9810a 0%,#0000 50%);position:fixed;inset:0}.auth-card{background:var(--bg-card);border:1px solid var(--border-bright);border-radius:var(--radius-xl);width:100%;max-width:440px;box-shadow:var(--shadow-lg), 0 0 60px #6c63ff14;text-align:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:52px 44px;animation:.6s cubic-bezier(.16,1,.3,1) both authCardIn;position:relative;overflow:hidden}.auth-card:before{content:"";background:linear-gradient(90deg,#0000,#6c63ff80,#a78bfa66,#0000);height:1px;position:absolute;top:0;left:0;right:0}@keyframes authCardIn{0%{opacity:0;transform:translateY(40px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.auth-logo{justify-content:center;align-items:center;margin-bottom:20px;display:inline-flex;position:relative}.auth-logo-icon{filter:drop-shadow(0 0 20px #6c63ff66);font-size:56px;animation:4s ease-in-out infinite floatIcon}@keyframes floatIcon{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.auth-logo-ring{border:1.5px solid #6c63ff40;border-radius:50%;animation:2.5s ease-in-out infinite ringPulse;position:absolute;inset:-12px}@keyframes ringPulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}.auth-title{letter-spacing:-.5px;background:linear-gradient(135deg, #1e1b4b 0%, var(--accent) 55%, var(--accent2) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:6px;font-family:Space Grotesk,sans-serif;font-size:30px;font-weight:700;line-height:1.2}.auth-subtitle{color:var(--text-secondary);letter-spacing:.01em;margin-bottom:36px;font-size:14px;font-weight:400}.auth-form{text-align:left;flex-direction:column;gap:20px;display:flex}.input-group{flex-direction:column;gap:8px;display:flex}.input-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-size:12px;font-weight:600}.input-wrapper{position:relative}.input-icon{opacity:.5;pointer-events:none;font-size:16px;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.input-group input{border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);transition:var(--t);background:#f8f7ff;outline:none;padding:13px 16px 13px 42px;font-family:Plus Jakarta Sans,sans-serif;font-size:15px}.input-group input:focus{border-color:var(--accent);background:#6c63ff0a;box-shadow:0 0 0 3px #6c63ff1f}.input-group input::placeholder{color:var(--text-muted)}.btn-primary{background:linear-gradient(135deg, var(--accent) 0%, var(--accent2) 100%);color:#fff;border-radius:var(--radius-sm);cursor:pointer;transition:var(--t);letter-spacing:.03em;border:none;margin-top:4px;padding:15px;font-family:Plus Jakarta Sans,sans-serif;font-size:15px;font-weight:700;position:relative;overflow:hidden}.btn-primary:after{content:"";opacity:0;transition:var(--t);background:linear-gradient(135deg,#ffffff26,#0000);position:absolute;inset:0}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 28px #6c63ff66,0 4px 12px #a78bfa4d}.btn-primary:hover:after{opacity:1}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.auth-switch{color:var(--text-secondary);margin-top:28px;font-size:14px}.auth-divider{align-items:center;gap:12px;margin:4px 0;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.auth-divider span{color:var(--text-muted);font-size:12px}.alert-error{background:var(--red-dim);color:#dc2626;border-radius:var(--radius-sm);border:1px solid #ef444433;align-items:center;gap:8px;padding:12px 16px;font-size:13.5px;font-weight:500;display:flex}.alert-error:before{content:"⚠";flex-shrink:0}.alert-success{background:var(--green-dim);color:#065f46;border-radius:var(--radius-sm);border:1px solid #10b98140;padding:12px 16px;font-size:13.5px;font-weight:500}.dashboard{background:var(--bg-base);min-height:100vh;display:flex;position:relative}.dashboard:before{content:"";pointer-events:none;background:radial-gradient(circle,#6c63ff0d 0%,#0000 70%);width:600px;height:600px;position:fixed;top:-200px;left:-200px}.sidebar{width:var(--sidebar-w);background:var(--bg-surface);border-right:1px solid var(--border);z-index:200;min-height:100vh;transition:var(--t-slow);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-brand{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:24px 20px;display:flex}.sidebar-logo-wrap{background:linear-gradient(135deg, var(--accent), var(--accent2));border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:22px;display:flex;box-shadow:0 4px 16px #6c63ff59}.sidebar-brand-text{line-height:1}.sidebar-brand-name{color:var(--text-primary);letter-spacing:-.3px;font-family:Space Grotesk,sans-serif;font-size:16px;font-weight:700}.sidebar-brand-sub{color:var(--text-muted);margin-top:2px;font-size:11px;font-weight:400}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:20px 12px;display:flex}.nav-section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-top:8px;padding:8px 8px 6px;font-size:10px;font-weight:700}.nav-item{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:var(--t);border:1px solid #0000;align-items:center;gap:10px;padding:10px 12px;font-size:14px;font-weight:500;display:flex}.nav-item:hover{background:var(--bg-glass-hover);color:var(--text-primary);border-color:var(--border)}.nav-item.active{border-color:var(--border-accent);color:var(--accent);background:linear-gradient(135deg,#38bdf81f,#818cf814)}.nav-icon{flex-shrink:0;font-size:18px}.sidebar-footer{border-top:1px solid var(--border);padding:16px 12px}.user-profile-card{background:var(--bg-glass);border:1px solid var(--border);border-radius:var(--radius-sm);transition:var(--t);align-items:center;gap:12px;padding:12px;display:flex}.user-avatar{background:linear-gradient(135deg, var(--accent), var(--accent2));color:#04111e;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:15px;font-weight:700;display:flex}.user-info{flex:1;min-width:0}.user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.user-role-tag{text-transform:uppercase;letter-spacing:.06em;color:var(--accent);background:var(--accent-dim);border-radius:4px;margin-top:3px;padding:1px 6px;font-size:10px;font-weight:700;display:inline-block}.btn-icon-logout{cursor:pointer;opacity:.5;transition:var(--t);background:0 0;border:none;padding:4px;font-size:16px}.btn-icon-logout:hover{opacity:1;transform:scale(1.15)}.dash-main{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-height:100vh;display:flex}.dash-topbar{border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:100;background:#f8f7ffeb;justify-content:space-between;align-items:center;padding:18px 32px;display:flex;position:sticky;top:0}.topbar-title{flex-direction:column;display:flex}.topbar-heading{color:var(--text-primary);letter-spacing:-.3px;font-family:Space Grotesk,sans-serif;font-size:22px;font-weight:700}.topbar-sub{color:var(--text-muted);margin-top:2px;font-size:12.5px;font-weight:400}.topbar-right{align-items:center;gap:12px;display:flex}.topbar-badge{background:var(--green-dim);color:var(--green);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);border:1px solid #10b98133;border-radius:50px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:600;display:flex;box-shadow:0 4px 15px #10b9811a}.live-dot{background:var(--green);border-radius:50%;width:7px;height:7px;animation:2s ease-in-out infinite livePulse}@keyframes livePulse{0%,to{box-shadow:0 0 #10b98180}50%{box-shadow:0 0 0 5px #10b98100}}.stats-row{grid-template-columns:repeat(4,1fr);gap:16px;padding:24px 32px 0;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:var(--t);flex-direction:column;gap:12px;padding:20px;display:flex;position:relative;overflow:hidden}.stat-card:after{content:"";border-radius:0 var(--radius) 0 50%;opacity:.06;width:80px;height:80px;transition:var(--t);position:absolute;top:0;right:0}.stat-card:hover{border-color:var(--border-bright);box-shadow:var(--shadow);transform:translateY(-2px)}.stat-card:hover:after{opacity:.1}.stat-card.total:after{background:var(--accent)}.stat-card.active:after{background:var(--green)}.stat-card.power:after{background:var(--orange)}.stat-card.update:after{background:var(--accent2)}.stat-card.total{border-top:2px solid var(--accent)}.stat-card.active{border-top:2px solid var(--green)}.stat-card.power{border-top:2px solid var(--orange)}.stat-card.update{border-top:2px solid var(--accent2)}.stat-card-header{justify-content:space-between;align-items:center;display:flex}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;font-size:12px;font-weight:600}.stat-icon{opacity:.7;font-size:20px}.stat-num{letter-spacing:-1px;font-family:Space Grotesk,sans-serif;font-size:34px;font-weight:700;line-height:1}.stat-card.total .stat-num{color:var(--accent)}.stat-card.active .stat-num{color:var(--green)}.stat-card.power .stat-num{color:var(--orange)}.stat-card.update .stat-num{color:var(--accent2);letter-spacing:0;font-size:15px;line-height:1.6}.stat-trend{color:var(--text-muted);font-size:11.5px;font-weight:500}.dash-body{grid-template-columns:1fr 300px;align-items:start;gap:24px;padding:24px 32px 32px;display:grid}.section-header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.section-title{color:var(--text-primary);letter-spacing:-.2px;align-items:center;gap:8px;font-family:Space Grotesk,sans-serif;font-size:17px;font-weight:700;display:flex}.section-count{background:var(--bg-glass);border:1px solid var(--border);color:var(--text-muted);border-radius:50px;padding:2px 10px;font-size:12px;font-weight:600}.devices-grid{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.device-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);text-align:center;cursor:pointer;transition:var(--t);-webkit-user-select:none;user-select:none;flex-direction:column;align-items:center;gap:10px;padding:22px 16px 18px;display:flex;position:relative;overflow:hidden}.device-card:before{content:"";opacity:0;height:2px;transition:var(--t);position:absolute;top:0;left:0;right:0}.card-light:before{background:linear-gradient(90deg, transparent, var(--yellow), transparent)}.card-fan:before{background:linear-gradient(90deg, transparent, var(--accent), transparent)}.device-card:after{content:"";opacity:0;transition:var(--t);border-radius:var(--radius);position:absolute;inset:0}.card-light:after{background:radial-gradient(at top,#fbbf240f,#0000 70%)}.card-fan:after{background:radial-gradient(at top,#6c63ff0f,#0000 70%)}.device-card.device-on:before,.device-card.device-on:after{opacity:1}.device-card:hover{border-color:var(--border-bright);box-shadow:var(--shadow), 0 0 30px #6c63ff14;transform:translateY(-5px)}.device-card.device-on{background:var(--bg-card-hover);border-color:#6c63ff26}.device-icon-wrap{width:60px;height:60px;transition:var(--t);border-radius:50%;justify-content:center;align-items:center;font-size:28px;display:flex;position:relative}.card-light .device-icon-wrap{background:#fbbf2414;border:1.5px solid #fbbf241f}.card-fan .device-icon-wrap{background:#6c63ff14;border:1.5px solid #6c63ff26}.card-light.device-on .device-icon-wrap{background:#fbbf2424;border-color:#fbbf244d;box-shadow:0 0 20px #fbbf2440}.card-fan.device-on .device-icon-wrap{background:#6c63ff24;border-color:#6c63ff4d;box-shadow:0 0 20px #6c63ff33}.device-icon{transition:var(--t);font-size:28px;line-height:1}.device-icon.spin{animation:1.2s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.icon-light{color:#facc15;filter:drop-shadow(0 0 8px #facc1566)}.icon-fan{color:#22d3ee}.icon-ac{color:#38bdf8}.device-name{color:var(--text-primary);font-size:13.5px;font-weight:600;line-height:1.3}.power-badge{font-size:12px;font-weight:700}.card-light .power-badge{color:var(--yellow)}.card-fan .power-badge{color:var(--accent)}.device-card.device-off .power-badge{color:var(--text-muted)}.toggle-switch{cursor:pointer;background:#334155;border:1px solid #ffffff1a;border-radius:20px;width:48px;height:24px;margin:12px auto;transition:all .3s;position:relative}.toggle-knob{background:#f8fafc;border-radius:50%;width:18px;height:18px;transition:all .3s cubic-bezier(.4,0,.2,1);position:absolute;top:2px;left:3px;box-shadow:0 2px 4px #0003}.toggle-switch.toggle-on{background:#22c55e;border-color:#16a34a}.toggle-switch.toggle-on .toggle-knob{background:#fff;transform:translate(24px)}.device-status{letter-spacing:.1em;border-radius:50px;padding:3px 12px;font-size:10.5px;font-weight:700}.status-on{background:var(--green-dim);color:var(--green)}.status-off{color:#64748b;background:#f1f5f9}.gauge-section{flex-direction:column;gap:16px;margin-top:40px;display:flex;position:sticky;top:80px}.gauge-container{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;padding:24px 20px 20px;position:relative;overflow:hidden}.gauge-container:before{content:"";background:linear-gradient(90deg,#0000,#6c63ff59,#0000);height:1px;position:absolute;top:0;left:0;right:0}.gauge-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;justify-content:center;align-items:center;gap:6px;margin-bottom:16px;font-family:Space Grotesk,sans-serif;font-size:14px;font-weight:700;display:flex}.gauge-chart-wrap{width:200px;margin:0 auto;position:relative}.gauge-center{line-height:1;position:absolute;top:60%;left:50%;transform:translate(-50%,-50%)}.gauge-value{letter-spacing:-1px;font-family:Space Grotesk,sans-serif;font-size:32px;font-weight:700;line-height:1}.gauge-unit{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:5px;font-size:11px;font-weight:500}.gauge-percent{color:var(--text-secondary);margin-top:3px;font-size:12px;font-weight:600}.gauge-labels{color:var(--text-muted);justify-content:space-between;margin-top:10px;padding:0 12px;font-size:10.5px;font-weight:500;display:flex}.loading-wrap{min-height:280px;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.loading-full{justify-content:center;align-items:center;min-height:100vh;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:38px;height:38px;animation:.75s linear infinite spin}.dash-error{margin:20px 32px 0}.report-container{padding-bottom:30px;animation:.4s fadeIn}.report-card{border:1px solid #0000000f;padding:24px;animation:.4s fadeIn;box-shadow:0 10px 40px #0000000a}.card-inner-title{color:#0f172a;align-items:center;gap:10px;margin-bottom:24px;font-size:20px;font-weight:800;display:flex}.report-table{border-collapse:separate;border-spacing:0;color:#334155;width:100%}.report-table th{text-align:left;text-transform:uppercase;letter-spacing:.1em;color:#64748b;border-bottom:2px solid #0000000d;padding:14px 16px;font-size:12px;font-weight:700}.report-table td{color:#1e293b;border-bottom:1px solid #00000008;padding:18px 16px;font-size:14px;transition:all .2s}.report-table tr:last-child td{border-bottom:none}.report-table tr:hover td{color:#000;background:#f8fafc}.status-pill{text-transform:uppercase;border-radius:20px;padding:4px 10px;font-size:11px;font-weight:600}.status-pill.normal{color:#22c55e;background:#22c55e1a;border:1px solid #22c55e33}.status-pill.high{color:#ef4444;background:#ef44441a;border:1px solid #ef444433}.btn-bulk-off{color:#ef4444!important;background:#ef44441a!important;border:1px solid #ef44444d!important}.btn-bulk-off:hover{box-shadow:0 0 15px #ef444433;background:#ef444433!important}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.analytics-page{flex-direction:column;gap:24px;padding:28px 32px 40px;animation:.4s both fadeIn;display:flex}.an-hero{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.an-range-tabs{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-sm);gap:2px;padding:3px;display:flex}.an-range-btn{color:var(--text-muted);cursor:pointer;transition:var(--t);background:0 0;border:none;border-radius:7px;padding:6px 16px;font-family:Plus Jakarta Sans,sans-serif;font-size:13px;font-weight:600}.an-range-btn:hover{color:var(--text-primary);background:var(--bg-card)}.an-range-btn.active{background:var(--bg-card);color:var(--accent);box-shadow:var(--shadow-sm)}.an-error{margin-top:-8px}.an-stat-grid{grid-template-columns:repeat(4,1fr);gap:20px;display:grid}.an-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:var(--t);box-shadow:var(--shadow-sm);flex-direction:column;gap:12px;min-width:0;padding:20px 20px 16px;display:flex;position:relative;overflow:hidden}.an-stat-card:before{content:"";border-radius:var(--radius-lg) var(--radius-lg) 0 0;height:3px;position:absolute;top:0;left:0;right:0}.an-stat-card.temp-card:before{background:linear-gradient(90deg,#f97316,#fb923c)}.an-stat-card.hum-card:before{background:linear-gradient(90deg,#38bdf8,#7dd3fc)}.an-stat-card:hover{box-shadow:var(--shadow);border-color:var(--border-bright);transform:translateY(-3px)}.an-stat-header{justify-content:space-between;align-items:center;gap:8px;display:flex}.an-stat-icon-wrap{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;display:flex}.temp-card .an-stat-icon-wrap{background:#f973161a}.hum-card .an-stat-icon-wrap{background:#38bdf81a}.an-stat-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;font-weight:700;overflow:hidden}.an-stat-value{letter-spacing:-1.5px;white-space:nowrap;font-family:Space Grotesk,sans-serif;font-size:clamp(28px,3.5vw,42px);font-weight:700;line-height:1}.temp-card .an-stat-value{color:#f97316}.hum-card .an-stat-value{color:#38bdf8}.an-stat-unit{opacity:.7;letter-spacing:0;font-size:15px;font-weight:600}.an-stat-footer{border-top:1px solid var(--border);gap:0;padding-top:10px;display:flex}.an-stat-meta{text-align:center;flex-direction:column;flex:1;gap:2px;min-width:0;padding:0 4px;display:flex}.an-stat-meta:not(:last-child){border-right:1px solid var(--border)}.an-meta-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);font-size:9.5px;font-weight:700}.an-meta-val{color:var(--text-primary);white-space:nowrap;font-family:Space Grotesk,sans-serif;font-size:13px;font-weight:700}.an-charts-grid{grid-template-columns:1fr 1fr;gap:20px;display:grid}.an-chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:85vh;box-shadow:var(--shadow-sm);transition:var(--t);flex-direction:column;gap:20px;padding:24px;display:flex}.an-chart-card:hover{box-shadow:var(--shadow);border-color:var(--border-bright)}.an-chart-header{justify-content:space-between;align-items:center;display:flex}.an-chart-title-wrap{align-items:center;gap:8px;display:flex}.an-chart-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.an-chart-title{color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:16px;font-weight:700}.an-chart-unit{color:var(--text-muted);background:var(--bg-panel);border:1px solid var(--border);border-radius:6px;padding:2px 8px;font-size:12px;font-weight:600}.an-chart-badge{border-radius:var(--radius-sm);padding:4px 12px;font-family:Space Grotesk,sans-serif;font-size:18px;font-weight:700}.temp-badge{color:#f97316;background:#f973161a;border:1px solid #f9731633}.hum-badge{color:#38bdf8;background:#38bdf81a;border:1px solid #38bdf833}.an-chart-area{height:280px;position:relative}.temp-color{color:#f97316}.hum-color{color:#38bdf8}.hamburger-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:var(--t);flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:5px;padding:8px 10px;display:none}.hamburger-btn:hover{background:var(--bg-glass-hover);border-color:var(--border-bright)}.hamburger-btn span{background:var(--text-secondary);width:20px;height:2px;transition:var(--t);border-radius:2px;display:block}.sidebar.sidebar-open{box-shadow:8px 0 40px #00000026;transform:translate(0)!important}.sidebar-overlay{z-index:199;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000059;animation:.2s fadeIn;display:none;position:fixed;inset:0}.sidebar-overlay.active{display:block}@media (width<=1100px){.stats-row{grid-template-columns:repeat(2,1fr)}}@media (width<=900px){:root{--sidebar-w:0px}.hamburger-btn{display:flex}.sidebar{z-index:300;width:260px;transition:transform .3s cubic-bezier(.4,0,.2,1);transform:translate(-260px)}.dash-main{margin-left:0}.dash-body{grid-template-columns:1fr;padding:16px}.gauge-section{grid-template-columns:1fr 1fr;display:grid;position:static}.stats-row{padding:16px 16px 0}.dash-topbar{gap:10px;padding:12px 16px}.topbar-heading{font-size:18px}.topbar-sub{font-size:11px}.analytics-page{padding:20px 16px 32px}.an-stat-grid{grid-template-columns:repeat(2,1fr)}.an-charts-grid{grid-template-columns:1fr}.an-chart-area{height:220px}.report-container{overflow-x:auto}}@media (width<=620px){.stats-row{grid-template-columns:1fr 1fr;gap:10px;padding:12px 12px 0}.gauge-section{grid-template-columns:1fr}.devices-grid{grid-template-columns:repeat(2,1fr)}.auth-card{padding:36px 24px}.topbar-badge{display:none}.dash-topbar{gap:8px}.topbar-heading{font-size:16px}.an-stat-grid{grid-template-columns:1fr}.an-stat-value{font-size:32px}.an-hero{flex-direction:column;align-items:flex-start;gap:12px}.an-hero-right{width:100%}.an-chart-area{height:190px}.an-chart-title{font-size:14px}.an-chart-badge{padding:3px 9px;font-size:15px}.section-header{flex-wrap:wrap;gap:10px}}@media (width<=420px){.stats-row{grid-template-columns:1fr 1fr;gap:8px}.stat-num{font-size:26px}.devices-grid{grid-template-columns:1fr;gap:10px}.an-range-btn{padding:5px 10px;font-size:12px}.an-stat-grid{grid-template-columns:1fr;gap:12px}.an-stat-value{font-size:28px}.an-chart-area{height:170px}}
