*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0d1117;--surface:#161b22;--surface2:#1c2330;--border:#30363d;--text:#e6edf3;--text-muted:#7d8590;--accent:#58a6ff;--green:#3fb950;--yellow:#d29922;--orange:#db6d28;--red:#f85149;--font:system-ui, "Segoe UI", sans-serif;--mono:"Cascadia Code", "Fira Mono", ui-monospace, monospace}html,body,#root{background:var(--bg);height:100%;color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.app-shell{flex-direction:column;min-height:100vh;display:flex}.main-content{flex-direction:column;gap:16px;width:100%;max-width:1600px;margin:0 auto;padding:16px;display:flex}.card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:16px}.card-title{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:12px;font-size:11px;font-weight:600}.status-header{background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:20px;padding:10px 20px;display:flex}.site-title{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);font-size:11px;font-weight:700}.site-subtitle{color:var(--text-muted);opacity:.6;margin-top:1px;font-size:10px}.divider-v{background:var(--border);flex-shrink:0;width:1px;height:32px}.kpis-row{flex-wrap:wrap;align-items:center;gap:20px;display:flex}.kpi{flex-direction:column;gap:1px;display:flex}.kpi-label{letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted);font-size:10px}.kpi-value{font-size:18px;font-weight:700;font-family:var(--mono);color:var(--text);line-height:1.2}.kpi-unit{color:var(--text-muted);margin-left:3px;font-size:11px}.header-right{align-items:center;gap:12px;margin-left:auto;display:flex}.soc-bar-wrap{flex-direction:column;gap:3px;display:flex}.soc-bar{background:var(--border);border-radius:3px;width:72px;height:5px;overflow:hidden}.soc-bar-fill{border-radius:3px;height:100%;transition:width .6s,background-color .6s}.ws-status{color:var(--text-muted);align-items:center;gap:6px;font-size:11px;display:flex}.ws-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.ws-dot.connected{background:var(--green)}.ws-dot.connecting{background:var(--yellow);animation:1.2s infinite blink}.ws-dot.disconnected{background:var(--red)}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.mode-badge{letter-spacing:.07em;text-transform:uppercase;border:1px solid;border-radius:20px;align-items:center;gap:6px;padding:5px 14px;font-size:12px;font-weight:700;display:inline-flex}.mode-badge .dot{background:currentColor;border-radius:50%;width:7px;height:7px;animation:2s infinite blink}.mode-badge.mpp{color:#3fb950;background:#3fb9501a}.mode-badge.curtailment{color:#d29922;background:#d299221a}.mode-badge.drop1{color:#db6d28;background:#db6d281a}.mode-badge.drop2{color:#f85149;background:#f851491a}.mode-badge.unknown{color:var(--text-muted);border-color:var(--border);background:#7d85901a}.section-title{letter-spacing:.06em;text-transform:uppercase;color:var(--text);font-size:13px;font-weight:600}.card-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;display:flex}.card-head .card-title{margin:0}.card-head-right{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.hamburger{border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:8px;flex-direction:column;flex:none;justify-content:center;gap:4px;width:38px;height:38px;padding:0 9px;display:inline-flex}.hamburger:hover{background:var(--surface2)}.hamburger span{background:var(--text);border-radius:2px;width:100%;height:2px;display:block}.menu-backdrop{opacity:0;visibility:hidden;z-index:999;background:#00000080;transition:opacity .2s;position:fixed;inset:0}.menu-backdrop.open{opacity:1;visibility:visible}.side-menu{background:var(--surface);border-right:1px solid var(--border);z-index:1000;flex-direction:column;width:264px;max-width:80vw;transition:transform .22s;display:flex;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.side-menu.open{transform:translate(0)}.side-menu-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 18px;display:flex}.side-menu-title{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);font-size:12px;font-weight:600}.side-menu-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:16px;line-height:1}.side-menu-close:hover{color:var(--text)}.side-menu-list{flex-direction:column;gap:4px;margin:0;padding:10px;list-style:none;display:flex}.side-menu-item{text-align:left;width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:11px 14px;font-size:14px;font-weight:500}.side-menu-item:hover{background:var(--surface2)}.side-menu-item.active{background:var(--accent);color:#000;font-weight:600}.stats-grid{grid-template-columns:repeat(4,1fr);gap:12px;margin-top:16px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:14px 16px}.stat-head{align-items:center;gap:8px;margin-bottom:8px;display:flex}.stat-icon{display:inline-flex}.stat-label{letter-spacing:.03em;color:var(--text-muted);text-transform:uppercase;font-size:11px;font-weight:600}.stat-value{font-size:26px;font-weight:700;font-family:var(--mono);color:var(--text);line-height:1.1}.stat-unit{color:var(--text-muted);margin-left:4px;font-size:13px;font-weight:500}.stat-bar{background:var(--surface2);border-radius:3px;height:6px;margin-top:10px;overflow:hidden}.stat-bar-fill{border-radius:3px;height:100%}.stat-spark{margin-top:8px}.stat-spark-empty{height:34px}.stat-gauge-wrap{justify-content:center;padding:4px 0 2px;display:flex}.stat-gauge-svg{display:block}.stat-range{margin-top:10px}.stat-range-track{background:var(--surface2);border-radius:4px;height:8px;position:relative}.stat-range-span{opacity:.55;border-radius:4px;height:100%;position:absolute;top:0}.stat-range-marker{background:var(--text);border-radius:1px;width:2px;height:12px;position:absolute;top:-2px;transform:translate(-1px)}.stat-range-labels{color:var(--text-muted);font-size:10px;font-family:var(--mono);justify-content:space-between;margin-top:5px;display:flex}@media (width<=720px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=420px){.stats-grid{grid-template-columns:1fr}}.um-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.um-search{background:var(--bg);border:1px solid var(--border);min-width:200px;max-width:360px;color:var(--text);border-radius:8px;flex:1;padding:9px 12px;font-size:14px}.um-search:focus{border-color:var(--accent);outline:none}.um-add{white-space:nowrap;align-items:center;gap:7px;display:inline-flex}.um-add-plus{font-size:16px;font-weight:700;line-height:1}.op-list{flex-direction:column;gap:8px;display:flex}.op-card{background:var(--surface2);border:1px solid var(--border);border-radius:10px;align-items:center;gap:14px;padding:12px 14px;display:flex}.op-avatar{color:#fff;letter-spacing:.02em;border-radius:50%;flex:none;justify-content:center;align-items:center;width:40px;height:40px;font-size:14px;font-weight:700;display:flex}.op-main{flex:1;min-width:0}.op-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.op-email{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.op-date{color:var(--text-muted);white-space:nowrap;font-size:12px}.op-badge{letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;border-radius:999px;padding:3px 9px;font-size:10px;font-weight:700}.op-badge-active{color:#3fb950;background:#3fb95029}.op-badge-pending{color:#d29922;background:#d2992229}.op-badge-idle{background:var(--surface);color:var(--text-muted)}.op-delete{border:1px solid var(--border);width:34px;height:34px;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;flex:none;justify-content:center;align-items:center;display:inline-flex}.op-delete:hover{color:#f85149;background:#f8514914;border-color:#f85149}.um-footer{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-top:16px;display:flex}.um-count{color:var(--text-muted);font-size:12px}.um-pagination{color:var(--text-muted);align-items:center;gap:10px;font-size:13px;display:flex}.um-pagination button{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:6px;padding:5px 12px;font-size:13px}.um-pagination button:disabled{opacity:.4;cursor:not-allowed}.modal-backdrop{z-index:1100;background:#0009;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:100%;max-width:400px;overflow:hidden}.modal-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 18px;display:flex}.modal-title{color:var(--text);margin:0;font-size:16px;font-weight:600}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:16px;line-height:1}.modal-close:hover{color:var(--text)}.modal-body{flex-direction:column;gap:6px;padding:18px;display:flex}.modal-body .form-label{margin-top:8px}.modal-body input{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:7px;padding:9px 11px;font-size:14px}.modal-body input:focus{border-color:var(--accent);outline:none}.modal-actions{justify-content:flex-end;gap:10px;margin-top:18px;display:flex}.operador-msg{border-radius:6px;margin-top:14px;padding:9px 11px;font-size:13px}.operador-msg.ok{color:#3fb950;background:#3fb9501a;border:1px solid #3fb9504d}.operador-msg.err{color:#f85149;background:#f851491a;border:1px solid #f851494d}.auth-loading{min-height:100vh;color:var(--text-muted);justify-content:center;align-items:center;font-size:14px;display:flex}.login-shell{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:100%;max-width:380px;padding:28px}.login-brand{text-align:center;margin-bottom:30px}.brand-name{letter-spacing:.14em;color:var(--text);text-transform:uppercase;margin:0;font-size:44px;font-weight:300}.login-title{color:var(--text);margin:0 0 4px;font-size:18px;font-weight:600}.login-hint{color:var(--text-muted);margin:0 0 16px;font-size:12px}.login-form{flex-direction:column;gap:6px;display:flex}.login-form .form-label{margin-top:10px}.login-form input{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:7px;padding:9px 11px;font-size:14px}.login-form input:focus{border-color:var(--accent);outline:none}.login-submit{justify-content:center;width:100%;margin-top:18px}.login-error{color:#f85149;background:#f851491a;border:1px solid #f851494d;border-radius:6px;margin-top:12px;padding:8px 10px;font-size:13px}.user-box{align-items:center;gap:10px;display:flex}.user-meta{flex-direction:column;align-items:flex-end;gap:2px;display:flex}.user-name{color:var(--text);font-size:13px;font-weight:600}.role-badge{letter-spacing:.06em;text-transform:uppercase;border-radius:4px;padding:1px 6px;font-size:9px;font-weight:700}.role-admin{color:#bc8cff;background:#bc8cff2e}.role-operador{color:#58a6ff;background:#58a6ff29}.btn-admin{border:1px solid var(--border);background:var(--surface2);color:var(--text-muted);border-radius:6px;padding:5px 10px;font-size:12px}.btn-logout{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:6px;padding:5px 12px;font-size:12px;font-weight:600}.btn-logout:hover{color:#f85149;border-color:#f85149}.signal-chips{flex-wrap:wrap;gap:6px;margin-bottom:10px;display:flex}.signal-chip{border:1px solid var(--border);background:var(--surface);color:var(--text-muted);cursor:pointer;border-radius:6px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.signal-chip .dot{border-radius:50%;flex:none;width:9px;height:9px}.signal-chip:hover{color:var(--text)}.signal-chip.active{color:var(--text);background:var(--surface2);border-color:#484f58}.signal-chip:not(.active) .dot{opacity:.3}.soc-badge{font-size:11px;font-weight:600;font-family:var(--mono);white-space:nowrap;border-radius:6px;padding:3px 9px}.badge-charge{color:#3fb950;background:#3fb95026}.badge-discharge{color:#d29922;background:#d2992226}.badge-idle{background:var(--surface2);color:var(--text-muted)}.range-buttons{background:var(--surface);border:1px solid var(--border);border-radius:7px;gap:2px;padding:2px;display:inline-flex}.range-btn{color:var(--text-muted);font-size:11px;font-weight:600;font-family:var(--mono);background:0 0;border:1px solid #0000;border-radius:5px;padding:4px 10px}.range-btn:hover:not(:disabled){background:var(--surface2);color:var(--text)}.range-btn.active{background:var(--accent);color:#000}.range-btn.active:hover{color:#000;background:#79c0ff}.charts-grid{grid-template-columns:1fr;gap:16px;display:grid}@media (width>=1100px){.charts-grid{grid-template-columns:3fr 1fr}}.chart-legend{flex-wrap:wrap;gap:12px;margin-bottom:10px;display:flex}.legend-item{color:var(--text-muted);align-items:center;gap:5px;font-size:11px;display:flex}.legend-swatch{border-radius:2px;flex-shrink:0;width:12px;height:3px}.historico-controls{flex-wrap:wrap;align-items:flex-end;gap:10px;margin-bottom:16px;display:flex}.form-group{flex-direction:column;gap:4px;display:flex}.form-label{letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);font-size:10px}input[type=datetime-local]{background:var(--surface2);border:1px solid var(--border);color:var(--text);font-size:13px;font-family:var(--mono);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;border-radius:6px;outline:none;padding:7px 10px}input[type=datetime-local]:focus{border-color:var(--accent)}button{border:1px solid var(--border);background:var(--surface2);color:var(--text);cursor:pointer;border-radius:6px;align-items:center;gap:6px;padding:7px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:border-color .15s,background .15s;display:inline-flex}button:hover{border-color:var(--accent);background:#58a6ff12}button:disabled{opacity:.4;cursor:not-allowed}button.btn-primary{background:var(--accent);border-color:var(--accent);color:#000;font-weight:600}button.btn-primary:hover{background:#79c0ff;border-color:#79c0ff}.ct{background:var(--surface2);border:1px solid var(--border);border-radius:6px;min-width:140px;padding:8px 12px;font-size:12px;line-height:1.8}.ct-time{color:var(--text-muted);letter-spacing:.05em;margin-bottom:4px;font-size:10px}.ct-modo{border-bottom:1px solid var(--border);align-items:center;gap:6px;margin-bottom:5px;padding-bottom:5px;font-size:11px;font-weight:700;display:flex}.ct-modo-dot{border-radius:50%;flex:none;width:8px;height:8px}.ct-row{justify-content:space-between;gap:16px;display:flex}.ct-name{color:var(--text-muted)}.ct-val{font-family:var(--mono);color:var(--text);font-weight:600}.empty-state{height:120px;color:var(--text-muted);border:1px dashed var(--border);border-radius:6px;justify-content:center;align-items:center;font-size:13px;display:flex}
