:root{--bg-primary:#050505;--bg-card:#0a0a0a;--bg-surface:#121212;--bg-hover:#1a1a1a;--accent-primary:#10b981;--accent-hover:#059669;--color-normal:#10b981;--color-warning:#f59e0b;--color-danger:#ef4444;--color-info:#3b82f6;--text-primary:#fafafa;--text-secondary:#a1a1aa;--text-muted:#52525b;--border-light:#1a1a1a;--border-medium:#27272a;--border-focus:#3f3f46;--gap-xs:4px;--gap-sm:8px;--gap-md:16px;--gap-lg:24px;--gap-xl:32px;--radius-sm:4px;--radius-md:6px;--radius-lg:10px;--radius-full:9999px;--font-main:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", ui-monospace, monospace}:root[data-theme=light]{--bg-primary:#f4f4f5;--bg-card:#fff;--bg-surface:#f4f4f5;--bg-hover:#e4e4e7;--border-light:#e4e4e7;--border-medium:#d4d4d8;--border-focus:#a1a1aa;--text-primary:#09090b;--text-secondary:#52525b;--text-muted:#a1a1aa}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px}body{font-family:var(--font-main);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;margin:0}.hidden{display:none!important}.loading-screen{background:var(--bg-primary);z-index:10000;justify-content:center;align-items:center;transition:opacity .5s;display:flex;position:fixed;inset:0}.loading-screen.fade-out{opacity:0;pointer-events:none}.loading-content{text-align:center}.loading-title{color:var(--text-primary);letter-spacing:-.01em;margin-bottom:var(--gap-lg);font-size:1.2rem;font-weight:600}.loading-bar{background:var(--bg-surface);width:240px;height:2px;margin:0 auto var(--gap-md);overflow:hidden}.loading-bar-fill{background:var(--accent-primary);width:0%;height:100%;animation:2s forwards load}@keyframes load{0%{width:0%}50%{width:60%}to{width:100%}}.loading-text{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.app-header{padding:0 var(--gap-xl);background:var(--bg-card);border-bottom:1px solid var(--border-light);z-index:100;justify-content:space-between;align-items:center;height:64px;display:flex;position:sticky;top:0}.header-left{align-items:center;gap:var(--gap-md);display:flex}.logo{color:var(--text-primary);align-items:center;display:flex}.header-text h1{letter-spacing:-.01em;color:var(--text-primary);font-size:1.1rem;font-weight:600}.header-subtitle{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem}.header-right{align-items:center;gap:var(--gap-lg);display:flex}.system-status{align-items:center;gap:var(--gap-sm);border-radius:var(--radius-full);letter-spacing:.05em;background:var(--bg-surface);border:1px solid var(--border-medium);padding:4px 12px;font-size:.7rem;font-weight:600;display:flex}.status-dot{border-radius:var(--radius-full);width:6px;height:6px}@keyframes blink-live{0%{opacity:1;box-shadow:0 0 4px var(--color-normal)}50%{opacity:.2;box-shadow:0 0 0 var(--color-normal)}to{opacity:1;box-shadow:0 0 4px var(--color-normal)}}@keyframes blink-fault{0%{opacity:1;box-shadow:0 0 8px var(--color-danger)}50%{opacity:.1;box-shadow:0 0 0 var(--color-danger)}to{opacity:1;box-shadow:0 0 8px var(--color-danger)}}.status-normal .status-dot{background:var(--color-normal);animation:2s ease-in-out infinite blink-live}.status-warning .status-dot{background:var(--color-warning)}.status-fault .status-dot{background:var(--color-danger);animation:.5s ease-in-out infinite blink-fault}.header-meta{gap:var(--gap-lg);display:flex}.meta-item{flex-direction:column;align-items:flex-end;display:flex}.meta-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.65rem}.meta-value{font-size:.85rem;font-family:var(--font-mono);color:var(--text-primary)}.connection-btn,.theme-toggle-btn{border-radius:var(--radius-md);border:1px solid var(--border-medium);background:var(--bg-surface);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;justify-content:center;align-items:center;transition:all .2s;display:flex}.connection-btn:hover,.theme-toggle-btn:hover{background:var(--bg-hover);border-color:var(--border-focus)}.connection-btn.connected{color:var(--color-normal)}.connection-btn.disconnected{color:var(--color-danger)}.dashboard{max-width:1400px;padding:var(--gap-xl);gap:var(--gap-lg);flex-direction:column;margin:0 auto;display:flex}.section-title{color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--gap-md);font-size:.85rem;font-weight:600}.card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg)}.sensor-cards{gap:var(--gap-md);grid-template-columns:repeat(5,1fr);display:grid}.sensor-card{padding:var(--gap-lg);flex-direction:column;display:flex}.card-header{align-items:center;gap:var(--gap-sm);margin-bottom:var(--gap-md);display:flex}.card-icon{width:24px;height:24px;color:var(--text-secondary);justify-content:center;align-items:center;display:flex}.card-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:500}.card-value{align-items:baseline;gap:var(--gap-xs);margin-bottom:var(--gap-md);display:flex}.value-number{font-size:2rem;font-weight:500;font-family:var(--font-mono);letter-spacing:-.02em;color:var(--text-primary)}.value-unit{color:var(--text-muted);font-size:.85rem}.card-sparkline{height:40px;margin-bottom:var(--gap-sm)}.card-footer{justify-content:flex-end;display:flex}.card-trend{font-size:.7rem;font-family:var(--font-mono);align-items:center;gap:4px;display:flex}.card-trend.up{color:var(--color-normal)}.card-trend.down{color:var(--color-danger)}.card-trend.neutral{color:var(--text-muted)}.charts-controls-row{gap:var(--gap-md);grid-template-columns:1fr 340px;display:grid}.charts-panel,.controls-panel{gap:var(--gap-md);flex-direction:column;display:flex}.chart-card{padding:var(--gap-lg);flex:1}.chart-header{margin-bottom:var(--gap-lg);justify-content:space-between;align-items:center;display:flex}.chart-tabs{background:var(--bg-surface);border:1px solid var(--border-medium);border-radius:var(--radius-md);padding:2px;display:flex}.chart-tab{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;padding:4px 12px;font-size:.75rem;transition:all .2s}.chart-tab:hover{color:var(--text-primary)}.chart-tab.active{background:var(--border-focus);color:var(--text-primary);font-weight:500}.chart-container{height:320px}.relay-card,.energy-card,.alerts-card,.limits-card{padding:var(--gap-lg)}.card-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-primary);margin-bottom:var(--gap-lg);border-bottom:1px solid var(--border-light);padding-bottom:var(--gap-sm);font-size:.75rem;font-weight:600}.relay-visual{align-items:center;gap:var(--gap-md);flex-direction:column;display:flex}.relay-ring{border-radius:var(--radius-full);border:2px solid var(--border-medium);background:var(--bg-surface);justify-content:center;align-items:center;width:64px;height:64px;transition:border-color .2s;display:flex}.relay-ring.on{border-color:var(--color-normal);color:var(--color-normal)}.relay-ring.off{border-color:var(--border-focus);color:var(--text-secondary)}.relay-status-text{font-family:var(--font-mono);letter-spacing:.1em;font-size:.8rem;font-weight:600}.toggle-switch{margin:var(--gap-lg) auto var(--gap-md);cursor:pointer;width:60px;height:32px;display:block;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{background:var(--bg-surface);border:2px solid var(--text-muted);border-radius:var(--radius-full);transition:all .3s cubic-bezier(.4,0,.2,1);position:absolute;inset:0}.toggle-slider:before{content:"";background:var(--text-secondary);border-radius:var(--radius-full);width:24px;height:24px;transition:all .3s cubic-bezier(.4,0,.2,1);position:absolute;bottom:2px;left:2px;box-shadow:0 2px 4px #0000004d}.toggle-switch:hover .toggle-slider{border-color:var(--text-secondary)}.toggle-switch input:checked+.toggle-slider{background:var(--color-normal);border-color:var(--color-normal);box-shadow:0 0 12px #10b9814d}.toggle-switch input:checked+.toggle-slider:before{background:#fff;transform:translate(28px)}.relay-note{color:var(--text-muted);text-align:center;font-size:.7rem}.energy-input-group label{color:var(--text-secondary);margin-bottom:var(--gap-xs);font-size:.75rem;display:block}.input-row{gap:var(--gap-sm);margin-bottom:var(--gap-lg);display:flex}.input-row input{background:var(--bg-surface);border:1px solid var(--border-medium);color:var(--text-primary);font-family:var(--font-mono);border-radius:var(--radius-sm);outline:none;flex:1;padding:8px 12px;font-size:.85rem}.input-row input:focus{border-color:var(--accent-primary)}.btn-primary{background:var(--text-primary);color:var(--bg-primary);border-radius:var(--radius-sm);cursor:pointer;border:none;padding:0 16px;font-size:.8rem;font-weight:500;transition:all .2s}.btn-primary:hover{opacity:.9}.stat-row{margin-bottom:var(--gap-sm);justify-content:space-between;font-size:.8rem;display:flex}.stat-label{color:var(--text-secondary)}.stat-value{font-family:var(--font-mono);color:var(--text-primary)}.energy-progress-container{margin-top:var(--gap-md)}.progress-bar{background:var(--bg-surface);border-radius:var(--radius-full);height:6px;margin-bottom:var(--gap-xs);overflow:hidden}.progress-fill{background:var(--accent-primary);height:100%;transition:width .3s}.energy-percent{font-size:.7rem;font-family:var(--font-mono);color:var(--text-secondary);text-align:right;display:block}.alerts-card{flex-direction:column;max-height:400px;display:flex}.alerts-header{margin-bottom:var(--gap-md);border-bottom:1px solid var(--border-light);padding-bottom:var(--gap-sm);justify-content:space-between;align-items:center;display:flex}.alerts-header .card-title{border-bottom:none;margin-bottom:0;padding-bottom:0}.btn-text{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;font-size:.75rem}.btn-text:hover{color:var(--text-primary)}.alerts-list{gap:var(--gap-sm);flex-direction:column;flex:1;display:flex;overflow-y:auto}.alert-item{align-items:flex-start;gap:var(--gap-sm);padding:var(--gap-sm);background:var(--bg-surface);border:1px solid var(--border-medium);border-radius:var(--radius-sm);display:flex}.alert-icon{font-size:.9rem}.alert-content{flex:1}.alert-message{color:var(--text-primary);margin-bottom:4px;font-size:.8rem}.alert-time{color:var(--text-muted);font-size:.7rem;font-family:var(--font-mono)}.alert-type-badge{background:var(--bg-primary);color:var(--text-secondary);text-transform:uppercase;border-radius:4px;padding:2px 6px;font-size:.65rem}.alert-empty{text-align:center;color:var(--text-muted);padding:var(--gap-xl) 0;font-size:.8rem}.alert-flash{pointer-events:none;z-index:9999;background:#ef444433;position:fixed;inset:0}.toast{bottom:var(--gap-lg);right:var(--gap-lg);background:var(--text-primary);color:var(--bg-primary);border-radius:var(--radius-sm);z-index:1000;padding:12px 20px;font-size:.85rem;font-weight:500;animation:.3s cubic-bezier(.2,.8,.2,1) toast-in;position:fixed;box-shadow:0 4px 12px #00000080}@keyframes toast-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.app-footer{text-align:center;padding:var(--gap-lg) 0 0 0;margin-top:var(--gap-md);border-top:1px solid var(--border-light)}.app-footer p{color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;font-size:.75rem}.app-footer a{color:var(--accent-primary);font-weight:600;text-decoration:none;transition:opacity .2s}.app-footer a:hover{opacity:.8}.value-updated{animation:.4s ease-out value-flash}@keyframes value-flash{0%{color:var(--accent-primary)}to{color:var(--text-primary)}}.connection-btn.reconnecting{color:var(--color-warning);border-color:var(--color-warning);animation:1.2s ease-in-out infinite reconnect-pulse}@keyframes reconnect-pulse{0%,to{opacity:1;box-shadow:0 0 #f59e0b66}50%{opacity:.6;box-shadow:0 0 8px 2px #f59e0b4d}}.sensor-card.stale{border-color:#f59e0b4d;animation:2s ease-in-out infinite stale-glow}@keyframes stale-glow{0%,to{border-color:#f59e0b4d}50%{border-color:#f59e0b1a}}.sensor-card.stale .card-label:after{content:" • STALE";color:var(--color-warning);letter-spacing:.08em;font-size:.6rem}.relay-ring.loading{position:relative}.relay-ring.loading:after{content:"";border-radius:var(--radius-full);border:2px solid #0000;border-top-color:var(--accent-primary);animation:.8s linear infinite relay-spin;position:absolute;inset:-4px}@keyframes relay-spin{to{transform:rotate(360deg)}}.energy-stats{gap:var(--gap-sm);margin-bottom:var(--gap-md);flex-direction:column;display:flex}.energy-stat{justify-content:space-between;align-items:center;display:flex}.energy-label{color:var(--text-secondary);font-size:.75rem}.energy-value{font-size:.85rem;font-family:var(--font-mono);color:var(--text-primary)}.energy-value.accent{color:var(--accent-primary);font-weight:600}.energy-progress-wrapper{align-items:center;gap:var(--gap-sm);display:flex}.energy-progress-bar{background:var(--bg-surface);border-radius:var(--radius-full);flex:1;height:6px;overflow:hidden}.energy-progress-fill{background:var(--accent-primary);border-radius:var(--radius-full);height:100%;transition:width .3s}.btn-ghost{border:1px solid var(--border-medium);color:var(--text-secondary);border-radius:var(--radius-sm);cursor:pointer;text-transform:uppercase;letter-spacing:.03em;background:0 0;padding:4px 10px;font-size:.7rem;transition:all .2s}.btn-ghost:hover{color:var(--text-primary);border-color:var(--border-focus);background:var(--bg-hover)}@keyframes toast-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(20px)}}.card-glow{display:none}@media (width<=1200px){.sensor-cards{grid-template-columns:repeat(3,1fr)}.charts-controls-row{grid-template-columns:1fr}}@media (width<=768px){.dashboard{padding:var(--gap-md)}.sensor-cards{grid-template-columns:1fr 1fr}.app-header{padding:0 var(--gap-md)}.header-meta,.status-text{display:none}.header-text h1{font-size:.9rem}}@media (width<=480px){.dashboard{padding:var(--gap-sm)}.sensor-cards{grid-template-columns:1fr}}
