:root{--abyss: #070e1a;--panel: #0e1a2b;--panel-2: #13243a;--line: #1e3450;--flow: #28c0e8;--flow-soft: #7fe0f5;--energy: #ffb020;--live: #2ee6a6;--warn: #ffb020;--alert: #ff5a5f;--ink: #eaf2fb;--ink-dim: #7e97b6;--ink-faint: #51688a;--display: "Space Grotesk", system-ui, sans-serif;--body: "Inter", system-ui, sans-serif;--mono: "IBM Plex Mono", ui-monospace, monospace;--r: 12px;--r-sm: 8px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:radial-gradient(1200px 600px at 80% -10%,rgba(40,192,232,.08),transparent 60%),radial-gradient(900px 500px at -10% 10%,rgba(255,176,32,.05),transparent 55%),var(--abyss);color:var(--ink);font-family:var(--body);-webkit-font-smoothing:antialiased}.login-wrap{min-height:100%;display:grid;place-items:center;padding:24px}.login-card{width:100%;max-width:360px;background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);border-radius:var(--r);padding:32px 28px;display:flex;flex-direction:column;gap:16px;box-shadow:0 30px 80px #00000073}.login-card h1{font-family:var(--display);font-size:26px;font-weight:700;letter-spacing:-.02em;margin:0 0 4px}.login-card h1 span{display:block;font-size:12px;font-weight:500;letter-spacing:.28em;text-transform:uppercase;color:var(--flow);margin-top:6px}.login-card label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--ink-dim)}.login-card input{background:var(--abyss);border:1px solid var(--line);border-radius:var(--r-sm);padding:11px 12px;color:var(--ink);font-family:var(--mono);font-size:14px}.login-card input:focus{outline:2px solid var(--flow);outline-offset:1px;border-color:transparent}.login-card button{margin-top:4px;background:linear-gradient(135deg,var(--flow),var(--flow-soft));color:#042231;border:none;border-radius:var(--r-sm);padding:12px;font-family:var(--display);font-weight:600;font-size:15px;cursor:pointer}.login-card button:disabled{opacity:.6;cursor:progress}.login-card .error{background:#ff5a5f1f;border:1px solid rgba(255,90,95,.4);color:#ffb3b5;border-radius:var(--r-sm);padding:9px 11px;font-size:13px}.shell{height:100vh;display:flex;flex-direction:column;overflow:hidden}.topbar{position:relative;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:10px 20px;background:#070e1ad9;border-bottom:1px solid var(--line)}.topbar-left{display:flex;align-items:center;gap:14px}.topbar-center{position:absolute;left:50%;transform:translate(-50%);pointer-events:none}.topbar-center .plant-select{pointer-events:auto}.topbar-right{display:flex;align-items:center;gap:20px}.brand{display:flex;align-items:baseline;gap:8px}.navtabs{display:inline-flex;background:var(--abyss);border:1px solid var(--line);border-radius:999px;padding:2px}.navtab{background:transparent;border:none;color:var(--ink-dim);font-family:var(--display);font-size:13px;font-weight:600;padding:5px 14px;border-radius:999px;cursor:pointer}.navtab:hover{color:var(--ink)}.navtab.active{background:var(--flow);color:#042231}.brand-mark{align-self:center;width:9px;height:18px;border-radius:3px;background:linear-gradient(180deg,var(--flow),var(--flow-soft));box-shadow:0 0 12px #28c0e899}.brand-name{font-family:var(--display);font-weight:700;font-size:18px}.brand-sub{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-dim)}.plant-select{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-sm);color:var(--ink);padding:6px 14px;font-family:var(--display);font-size:16px;font-weight:600;text-align:center}.plant-name{font-family:var(--display);font-size:18px;font-weight:700;letter-spacing:.01em;color:var(--ink);white-space:nowrap}.status-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:999px;font-family:var(--display);font-weight:600;font-size:13px;border:1px solid var(--line)}.status-pill .status-dot{width:9px;height:9px;border-radius:50%;background:var(--ink-faint)}.status-pill.on{background:#2ee6a61f;border-color:#2ee6a673;color:var(--live)}.status-pill.on .status-dot{background:var(--live);box-shadow:0 0 10px var(--live);animation:pulse 1.6s ease-in-out infinite}.status-pill.off{background:#ff5a5f1a;border-color:#ff5a5f66;color:#ff9a9d}.status-pill.off .status-dot{background:var(--alert)}@keyframes pulse{50%{opacity:.4}}.hstat{display:flex;flex-direction:column;line-height:1.15}.hstat-label{font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-dim)}.hstat-value{font-family:var(--mono);font-size:16px;font-weight:600}.hstat-value i{font-style:normal;font-size:10px;color:var(--ink-dim);margin-left:4px}.hstat-value.acc{color:var(--energy)}.hstat-value.today{color:var(--live)}.userbox{display:flex;flex-direction:column;align-items:flex-end;line-height:1.25}.user{font-size:12px;color:var(--ink)}.last-update{font-family:var(--mono);font-size:10px;color:var(--ink-faint)}.ghost{background:transparent;border:1px solid var(--line);color:var(--ink-dim);border-radius:var(--r-sm);padding:6px 14px;cursor:pointer;font-size:13px}.ghost:hover{color:var(--ink);border-color:var(--ink-dim)}.loading-state{padding:40px;color:var(--ink-dim);font-family:var(--mono)}.banner-error{margin:10px 20px 0;background:#ff5a5f1f;border:1px solid rgba(255,90,95,.4);color:#ffb3b5;border-radius:var(--r-sm);padding:10px 14px;font-size:13px}.board{flex:1;min-height:0;display:grid;grid-template-columns:440px minmax(0,.9fr) minmax(0,1.2fr);gap:12px;padding:10px 16px}.col{min-height:0;display:flex;flex-direction:column;gap:10px}.col-vitals,.col-readouts{overflow-y:auto;padding-right:4px}.col-vitals::-webkit-scrollbar,.col-readouts::-webkit-scrollbar{width:8px}.col-vitals::-webkit-scrollbar-thumb,.col-readouts::-webkit-scrollbar-thumb{background:var(--line);border-radius:8px}.col-temps{overflow:hidden}.vital-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:12px 14px;display:flex;flex-direction:column}.gauge-card{flex:1.2;min-height:210px}.level-chart{flex:1.5;min-height:200px;position:relative}.head-right{margin-left:auto;display:flex;align-items:center;gap:6px}.seg-sm .seg-btn{padding:3px 7px;font-size:11px}.gear-wrap{position:relative}.gear-btn{background:var(--abyss);border:1px solid var(--line);color:var(--ink-dim);border-radius:6px;width:22px;height:20px;cursor:pointer;font-size:12px;line-height:1;padding:0}.gear-btn:hover{color:var(--ink);border-color:var(--ink-dim)}.setpoint-pop{position:absolute;top:30px;right:0;z-index:20;width:184px;background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:0 18px 50px #00000080;padding:12px;display:flex;flex-direction:column;gap:10px}.pop-title{font-family:var(--display);font-size:12px;font-weight:600;color:var(--ink)}.ctl{display:flex;flex-direction:column;gap:4px}.ctl-key{font-size:11px;font-weight:500}.ctl input{background:var(--abyss);border:1px solid var(--line);border-radius:6px;color:var(--ink);font-family:var(--mono);font-size:13px;padding:6px 8px}.ctl input:focus{outline:1px solid var(--flow)}.level-chartbody{flex:1;min-height:0}.level-now{font-family:var(--mono);font-size:20px;font-weight:600;color:var(--flow-soft);line-height:1}.level-now i{font-style:normal;font-size:11px;color:var(--ink-dim);margin-left:3px}.window-tag{font-family:var(--mono);font-size:10px;color:var(--ink-faint);border:1px solid var(--line);border-radius:999px;padding:1px 7px}.vert-badge{font-family:var(--display);font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;border:1px solid var(--line);color:var(--ink-dim)}.vert-badge.yes{background:#28c0e824;border-color:#28c0e880;color:var(--flow-soft)}.vert-badge.no{background:#2ee6a61a;border-color:#2ee6a666;color:var(--live)}.vital-head{display:flex;align-items:center;flex-wrap:wrap;gap:6px 8px}.vital-label{font-family:var(--display);font-size:13px;font-weight:600;color:var(--ink)}.vital-max{font-family:var(--mono);font-size:10px;color:var(--ink-faint)}.gauge-body{flex:1;min-height:0}.gauge-foot{text-align:center;font-family:var(--mono);font-size:11px;color:var(--ink-dim)}.block{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:7px 14px}.block-head{display:flex;align-items:center;gap:10px;margin-bottom:2px}.block-eyebrow{font-family:var(--display);font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;padding-left:9px;border-left:3px solid var(--flow)}.block-eyebrow.accent-energy{border-left-color:var(--energy)}.block-eyebrow.accent-flow{border-left-color:var(--flow)}.block-eyebrow.accent-warn{border-left-color:var(--warn)}.block-eyebrow.accent-live{border-left-color:var(--live)}.block-count{font-family:var(--mono);font-size:10px;color:var(--ink-faint);border:1px solid var(--line);border-radius:999px;padding:1px 7px}.block.fill{flex:1;min-height:0;display:flex;flex-direction:column}.lines{flex:1;min-height:0;overflow-y:auto;padding-right:4px}.lines::-webkit-scrollbar{width:8px}.lines::-webkit-scrollbar-thumb{background:var(--line);border-radius:8px}.line-group{font-family:var(--display);font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-dim);padding-left:8px;border-left:3px solid var(--flow);margin:14px 0 4px}.line-group:first-child{margin-top:0}.line-group.accent-energy{border-left-color:var(--energy)}.line-group.accent-warn{border-left-color:var(--warn)}.line-group.accent-live{border-left-color:var(--live)}.lines-loose{display:flex;flex-direction:column}.line{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding:5px 2px;border-bottom:1px solid rgba(30,52,80,.5)}.lines-loose .line:last-child{border-bottom:none}.line-label{font-size:12px;color:var(--ink-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.line-value{font-family:var(--mono);font-size:15px;font-weight:500;white-space:nowrap;flex-shrink:0}.line-value.stale{color:var(--ink-faint)}.line-value.old{color:var(--ink-dim)}.line-unit{font-style:normal;font-size:10px;color:var(--ink-dim);margin-left:4px}.line-bool{font-family:var(--display);font-weight:600;font-size:13px}.line-bool.on{color:var(--live)}.line-bool.off{color:var(--ink-dim)}.thermo-grid{flex:1;min-height:0;overflow-y:auto;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:2px 16px;align-content:start;padding-right:4px}.thermo-grid::-webkit-scrollbar{width:8px}.thermo-grid::-webkit-scrollbar-thumb{background:var(--line);border-radius:8px}.titem{padding:5px 2px;border-radius:6px}.titem.state-alarm{background:#ffb02012}.titem.state-trip{background:#ff5a5f17}.titem-top{display:flex;align-items:center;gap:6px;margin-bottom:4px}.titem-label{flex:1;font-size:11px;color:var(--ink-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trow-tag{font-family:var(--display);font-size:9px;font-weight:700;letter-spacing:.08em;padding:1px 6px;border-radius:999px}.trow-tag.alarm{color:var(--energy);background:#ffb02029}.trow-tag.trip{color:var(--alert);background:#ff5a5f2e}.titem-value{font-family:var(--mono);font-size:15px;font-weight:600;flex-shrink:0}.titem-value.ok{color:var(--flow)}.titem-value.alarm{color:var(--energy)}.titem-value.trip{color:var(--alert)}.titem-value.none{color:var(--ink-faint)}.titem-unit{font-style:normal;font-size:10px;color:var(--ink-dim);margin-left:2px}.thermo-track{position:relative;height:7px;border-radius:999px;background:var(--abyss);border:1px solid var(--line)}.thermo-fill{height:100%;border-radius:999px;transition:width .5s ease}.thermo-fill.ok{background:linear-gradient(90deg,#1b7fb8,var(--flow))}.thermo-fill.alarm{background:linear-gradient(90deg,var(--flow),var(--energy))}.thermo-fill.trip{background:linear-gradient(90deg,var(--energy),var(--alert))}.thermo-fill.none{background:var(--line)}.thermo-mark{position:absolute;top:-1px;width:2px;height:9px;transform:translate(-1px)}.thermo-mark.alarm{background:var(--energy)}.thermo-mark.trip{background:var(--alert)}.thermo-scale{display:flex;justify-content:space-between;font-family:var(--mono);font-size:8px;color:var(--ink-faint);margin-top:2px}.col-readouts>.block{flex:1 1 auto}.energy-week{display:flex;flex-direction:column}.energy-week-chart{flex:1;min-height:130px}.energy-week .block-count{font-family:var(--mono);color:var(--live);font-size:12px}.panel-empty{height:100%;display:grid;place-items:center;color:var(--ink-dim);font-family:var(--mono);font-size:13px}.seg{display:inline-flex;align-self:flex-start;background:var(--abyss);border:1px solid var(--line);border-radius:999px;padding:2px}.seg-btn{background:transparent;border:none;color:var(--ink-dim);font-family:var(--mono);font-size:12px;padding:4px 11px;border-radius:999px;cursor:pointer}.seg-btn.active{background:var(--flow);color:#042231;font-weight:600}.reports{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:14px;padding:16px 20px 40px}.rep-controls{padding:16px 18px}.rep-title{font-family:var(--display);font-size:18px;font-weight:700;margin:0 0 12px}.rep-fields{display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap}.rep-fields .ctl input[type=date]{color-scheme:dark}.btn-primary{background:linear-gradient(135deg,var(--flow),var(--flow-soft));color:#042231;border:none;border-radius:var(--r-sm);padding:8px 18px;font-family:var(--display);font-weight:600;font-size:14px;cursor:pointer}.btn-primary:disabled{opacity:.6;cursor:progress}.ghost:disabled{opacity:.5;cursor:not-allowed}.rep-presets{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.chip{background:var(--abyss);border:1px solid var(--line);color:var(--ink-dim);border-radius:999px;padding:5px 14px;font-family:var(--display);font-size:13px;font-weight:500;cursor:pointer}.chip:hover{color:var(--ink);border-color:var(--ink-dim)}.chip.active{background:var(--flow);border-color:var(--flow);color:#042231;font-weight:600}.rep-summary{display:flex;gap:14px;flex-wrap:wrap}.rep-total,.rep-compare{display:flex;flex-direction:column;gap:4px;border:1px solid var(--line);border-radius:var(--r);padding:16px 22px;min-width:230px}.rep-total{background:linear-gradient(135deg,rgba(46,230,166,.12),var(--panel))}.rep-compare{background:var(--panel);justify-content:center}.rep-delta{font-family:var(--mono);font-size:26px;font-weight:700;line-height:1}.rep-delta.up{color:var(--live)}.rep-delta.down{color:var(--alert)}.rep-compare-sub{font-family:var(--mono);font-size:12px;color:var(--ink-dim)}.rep-total-label{font-size:12px;color:var(--ink-dim);text-transform:uppercase;letter-spacing:.06em}.rep-total-value{font-family:var(--mono);font-size:40px;font-weight:700;color:var(--live);line-height:1}.rep-total-value i{font-style:normal;font-size:16px;color:var(--ink-dim);margin-left:8px}.rep-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:14px;align-items:start}.rep-chart,.rep-tablewrap{padding:16px 18px}.rep-tablebody{max-height:360px;overflow-y:auto}.rep-table{width:100%;border-collapse:collapse;font-size:13px}.rep-table th,.rep-table td{text-align:left;padding:7px 8px;border-bottom:1px solid rgba(30,52,80,.5)}.rep-table th{font-family:var(--display);font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-dim);position:sticky;top:0;background:var(--panel)}.rep-table td{font-family:var(--mono);color:var(--ink)}.rep-table .num{text-align:right}.rep-table tfoot td{font-weight:700;color:var(--live);border-top:1px solid var(--line)}.picker{flex:1;min-height:0;overflow-y:auto;width:100%;max-width:1100px;margin:0 auto;padding:32px 24px 48px}.picker-search{width:320px;max-width:100%;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-sm);color:var(--ink);font-family:var(--body);font-size:14px;padding:10px 14px;margin-bottom:22px}.picker-search:focus{outline:2px solid var(--flow);outline-offset:1px}.picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.plant-card{text-align:left;background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);border-radius:var(--r);padding:20px;cursor:pointer;display:flex;flex-direction:column;gap:8px;min-height:140px;transition:border-color .15s ease,transform .1s ease}.plant-card:hover{border-color:var(--flow);transform:translateY(-2px)}.plant-card.disconnected{opacity:.6;cursor:not-allowed}.plant-card.disconnected:hover{border-color:var(--line);transform:none}.plant-card-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.plant-card-mark{width:34px;height:6px;border-radius:3px;background:linear-gradient(90deg,var(--flow),var(--flow-soft));box-shadow:0 0 12px #28c0e880}.conn-badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--display);font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;border:1px solid var(--line);color:var(--ink-dim)}.conn-badge .conn-dot{width:8px;height:8px;border-radius:50%;background:var(--ink-faint)}.conn-badge.on{background:#2ee6a61f;border-color:#2ee6a673;color:var(--live)}.conn-badge.on .conn-dot{background:var(--live);box-shadow:0 0 8px var(--live)}.conn-badge.off{color:var(--ink-dim)}.conn-badge.off .conn-dot{background:var(--alert)}.banner-notice{margin:10px 20px 0;background:#ffb0201f;border:1px solid rgba(255,176,32,.4);color:#ffd27a;border-radius:var(--r-sm);padding:10px 14px;font-size:13px}.plant-card-name{font-family:var(--display);font-size:19px;font-weight:700;color:var(--ink)}.plant-card-loc{font-size:13px;color:var(--ink-dim)}.plant-card-open{margin-top:auto;font-family:var(--mono);font-size:12px;color:var(--flow)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#04091299;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:grid;place-items:center;padding:24px}.modal-card{width:100%;max-width:360px;background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);border-radius:var(--r);padding:22px 22px 18px;box-shadow:0 30px 80px #00000080}.modal-title{font-family:var(--display);font-size:17px;font-weight:700;margin:0 0 8px}.modal-text{font-size:13px;color:var(--ink-dim);margin:0 0 18px;line-height:1.45}.modal-actions{display:flex;justify-content:flex-end;gap:10px}.btn-danger{background:var(--alert);border:none;color:#2a0608;border-radius:var(--r-sm);padding:8px 18px;font-family:var(--display);font-weight:600;font-size:14px;cursor:pointer}.btn-danger:hover{filter:brightness(1.08)}@media(max-width:1100px){.shell{height:auto;overflow:visible}.board{grid-template-columns:1fr}.col-readouts,.col-temps{overflow:visible}.rep-grid{grid-template-columns:1fr}}@media(prefers-reduced-motion:reduce){.status-pill.on .status-dot{animation:none}}
