:root{--abyss: #eef2f7;--panel: #ffffff;--panel-2: #f3f6fa;--line: #e2e8f0;--flow: #0ea5c4;--flow-soft: #38bdf8;--energy: #f59e0b;--live: #16a34a;--warn: #f59e0b;--alert: #ef4444;--ink: #1f2a37;--ink-dim: #5b6675;--ink-faint: #94a3b8;--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(14,165,196,.06),transparent 60%),radial-gradient(900px 500px at -10% 10%,rgba(245,158,11,.04),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:#ffffffe6;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(--card-bg);border:1px solid var(--card-line);border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;box-shadow:0 1px 2px #0f172a0a,0 1px 3px #0f172a0f}.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-read{flex-direction:row;align-items:center;gap:8px}.ctl-read .ctl-key{flex:0 0 46px}.ctl-read .ctl-val{flex:1 1 auto;font-family:var(--mono);font-size:13px;color:var(--ink)}.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)}input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.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-value{text-align:center;font-family:var(--mono);font-size:30px;font-weight:600;color:var(--ink);line-height:1;margin-top:2px}.gauge-unit{font-size:14px;font-weight:400;color:var(--ink-dim);margin-left:6px}.gauge-foot{text-align:center;font-family:var(--mono);font-size:11px;color:var(--ink-dim);margin-top:4px}.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-carousel .thermo-expand{margin-left:auto;background:none;border:1px solid var(--card-line);border-radius:6px;color:var(--ink-dim);font-size:13px;line-height:1;padding:3px 7px;cursor:pointer}.thermo-carousel .thermo-expand:hover{color:var(--flow);border-color:var(--flow)}.thermo-carousel-body{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px 16px}.carousel-nav{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:6px}.carousel-nav button{background:none;border:1px solid var(--card-line);border-radius:6px;color:var(--ink-dim);font-size:14px;line-height:1;width:22px;height:22px;cursor:pointer}.carousel-nav button:hover{color:var(--flow);border-color:var(--flow)}.carousel-count{font-family:var(--mono);font-size:11px;color:var(--ink-faint);min-width:36px;text-align:center}.modal-card.thermo-modal{max-width:1340px;width:98vw;max-height:94vh}.tgauge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;padding-right:2px}.tgauge{display:flex;flex-direction:column;align-items:center;border:1px solid var(--card-line);border-radius:10px;padding:8px 6px 6px;background:var(--card-bg)}.tgauge.state-alarm{border-color:#f59e0b99}.tgauge.state-trip{border-color:#ef444499}.tgauge-title{font-size:11px;font-weight:600;color:var(--ink-dim);text-align:center;line-height:1.2;min-height:26px;display:flex;align-items:center}.tgauge-body{width:100%}.tgauge-limits{display:flex;flex-direction:column;gap:4px;width:100%;margin-top:6px}.splimit{display:flex;align-items:center;gap:6px;width:100%;padding:4px 8px;border:1px solid var(--card-line);border-left-width:3px;border-radius:7px;background:var(--panel-2);cursor:default;text-align:left;transition:border-color .15s ease,background .15s ease}.splimit.editable{cursor:pointer}.splimit.editable:hover{background:#0ea5c412}.splimit.alarm{border-left-color:var(--warn)}.splimit.trip{border-left-color:var(--alert)}.splimit.max{border-left-color:var(--flow)}.splimit.min{border-left-color:var(--ink-faint)}.splimit-key{flex:1 1 auto;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-dim)}.splimit-val{flex:0 0 auto;font-family:var(--mono);font-size:13px;font-weight:600;color:var(--ink);white-space:nowrap}.splimit-unit{font-style:normal;font-size:9px;color:var(--ink-dim);margin-left:3px}.splimit-pen{flex:0 0 auto;font-size:11px;color:var(--ink-faint)}.splimit.editable:hover .splimit-pen{color:var(--flow)}.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,.op-main{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:14px;padding:16px 20px 40px}.op-section{padding:16px 18px}.op-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px 22px;margin-top:10px}.op-block{display:flex;flex-direction:column;gap:8px}.op-leds{display:flex;flex-direction:column;gap:6px}.op-led{display:flex;align-items:center;gap:9px}.op-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;background:var(--ink-faint);border:1px solid var(--line)}.op-dot.on{background:var(--live);border-color:var(--live);box-shadow:0 0 8px var(--live)}.op-dot.off{background:var(--ink-faint)}.op-dot.unknown{background:transparent}.op-led-label{font-size:12px;color:var(--ink-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sp-edit{background:transparent;border:none;color:var(--flow);cursor:pointer;font-size:13px;margin-left:8px;padding:0 4px}.sp-edit:hover{color:var(--flow-soft)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#070e1ab3;display:grid;place-items:center;z-index:50}.modal{width:100%;max-width:380px;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:18px;margin:0 0 2px}.modal-sub{color:var(--ink-dim);font-size:13px;margin:0 0 14px}.modal-row{display:flex;justify-content:space-between;font-size:13px;color:var(--ink-dim);margin-bottom:12px}.modal-row strong{color:var(--ink);font-family:var(--mono)}.modal .ctl input[type=number]{width:100%}.modal-hint{display:block;font-size:11px;color:var(--ink-faint);margin-top:4px}.modal-warn{font-size:12px;color:var(--warn);margin:12px 0 8px}.modal-ok{font-size:13px;color:var(--live);margin:12px 0 8px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:8px}.rep-controls{padding:16px 18px}.rep-title{font-family:var(--display);font-size:18px;font-weight:700;margin:0 0 12px}.rep-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.rep-title-row .rep-title{margin-bottom:0}.pld-import{display:flex;align-items:center;gap:10px;margin-bottom:12px}.pld-import-msg{font-size:12px;color:var(--flow)}.pld-dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:4px;vertical-align:middle}.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}.btn-pdf{background:linear-gradient(135deg,#ffc43d,var(--warn));color:#2a1c00;border:none;border-radius:var(--r-sm);padding:8px 18px;font-family:var(--display);font-weight:700;font-size:14px;cursor:pointer;box-shadow:0 0 0 1px #ffb02066,0 6px 18px #ffb02047;transition:transform .08s ease,box-shadow .2s ease}.btn-pdf:hover{box-shadow:0 0 0 1px #ffb02099,0 8px 22px #ffb02073;transform:translateY(-1px)}.btn-pdf:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.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}.chip:disabled{opacity:.35;cursor:not-allowed}.chip:disabled:hover{color:var(--ink-dim);border-color:var(--line)}.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-total-value.money{font-size:28px}.rep-params{margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}.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)}.ctl select{background:var(--abyss);border:1px solid var(--line);border-radius:6px;color:var(--ink);font-family:var(--mono);font-size:13px;padding:6px 8px;min-width:220px;color-scheme:dark}.ctl select:focus{outline:1px solid var(--flow)}.rep-fields .ctl input[type=datetime-local]{color-scheme:dark}.rep-period{align-self:flex-end}.rep-presets-inline{margin:0}.rep-linechart{margin-top:16px}.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}}.plant-card-wrap{position:relative;display:flex}.plant-card-wrap>.plant-card{width:100%}.plant-edit-btn{position:absolute;top:10px;right:10px;width:28px;height:28px;border-radius:7px;border:1px solid var(--line);background:#ffffffe6;color:var(--ink-dim);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .15s ease,border-color .15s ease,background .15s ease}.plant-edit-btn:hover{color:var(--flow);border-color:var(--flow);background:var(--panel)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#02060ea8;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:50;padding:20px}.modal-card{width:100%;max-width:460px;max-height:88vh;overflow-y:auto;background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);border-radius:var(--r);box-shadow:0 24px 60px #00000080}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--line)}.modal-title{font-family:var(--display);font-size:16px;font-weight:700;margin:0}.modal-x{background:none;border:none;color:var(--ink-dim);font-size:16px;cursor:pointer}.modal-x:hover{color:var(--ink)}.modal-body{padding:18px;display:flex;flex-direction:column;gap:14px}.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:14px 18px;border-top:1px solid var(--line)}.unit-list{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}.unit-empty{font-size:12px;color:var(--ink-faint);padding:4px 0}.unit-row{display:flex;gap:8px;align-items:center}.unit-row 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}.unit-row input:focus{outline:1px solid var(--flow)}.unit-name{flex:1}.unit-power{width:84px}.unit-del{width:28px;height:28px;flex:none;border-radius:6px;border:1px solid var(--line);background:none;color:var(--ink-dim);cursor:pointer}.unit-del:hover{color:var(--alert);border-color:var(--alert)}.unit-add{align-self:flex-start;background:none;border:1px dashed var(--line);border-radius:6px;color:var(--flow);font-size:13px;padding:6px 12px;cursor:pointer}.unit-add:hover{border-color:var(--flow)}.setpoint-note{margin:2px 0 0;font-size:11px;line-height:1.4;color:var(--ink-dim)}:root{--card-bg: #ffffff;--card-line: #e6eaf0;--card-title: #64748b}.sup-board{flex:1;min-height:0;display:flex;gap:10px;padding:10px 12px;overflow:auto}.sup-col{display:flex;flex-direction:column;gap:10px;min-height:0}.sup-left{flex:0 0 340px}.sup-center{flex:1 1 620px;min-width:0;display:flex;flex-direction:column;gap:10px}.sup-center-top{flex:0 0 auto;display:flex;align-items:stretch;gap:10px}.sup-inst{flex:0 0 320px}.sup-status{flex:1 1 340px;min-width:0}.sup-inst>*{flex:1 1 auto}.sup-status>:last-child{margin-top:auto}.sup-cmd{flex:0 0 280px}.sup-steps{flex:0 0 36px;align-items:center}.sup-params{flex:0 0 320px;overflow-y:auto}.card{background:var(--card-bg);border:1px solid var(--card-line);border-radius:10px;padding:10px 12px;box-shadow:0 1px 2px #0f172a0a,0 1px 3px #0f172a0f}.card-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.card-title{font-family:var(--display);font-size:13px;font-weight:600;color:var(--card-title)}.card-gear{color:var(--ink-faint);font-size:13px}.status-card .status-leds{display:grid;grid-template-columns:1fr 1fr;gap:5px 14px}.led-row{display:flex;align-items:center;gap:8px;min-width:0}.led{width:11px;height:11px;border-radius:50%;flex-shrink:0;background:var(--ink-faint);border:1px solid var(--line)}.led.on{background:var(--live);border-color:var(--live);box-shadow:0 0 7px var(--live)}.led.off{background:var(--ink-faint)}.led.alert{background:var(--alert);border-color:var(--alert);box-shadow:0 0 7px var(--alert)}.led.unknown{background:transparent}.led-label{font-size:12px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.led-label.dim{color:var(--ink-faint)}.sp-card .sp-big{font-family:var(--mono);font-size:30px;font-weight:600;color:var(--flow)}.sp-card .sp-big i{font-style:normal;font-size:13px;color:var(--ink-dim);margin-left:6px}.emerg-btn{width:100%;max-width:360px;height:60px;display:flex;align-items:center;justify-content:center;border:1px solid #7d1414;border-radius:var(--r-sm);background:linear-gradient(180deg,#e23b3b,#b71c1c);box-shadow:inset 0 1px #ffffff2e,0 2px 6px #00000059;color:#fff;font-family:var(--display);font-weight:700;font-size:15px;letter-spacing:.04em;text-shadow:0 1px 2px rgba(0,0,0,.4);cursor:not-allowed}.emerg-btn:disabled{opacity:.85}.emerg-card .emerg-leds{display:flex;flex-direction:column;gap:5px;margin-top:8px}.sp-rows{display:flex;flex-direction:column}.sp-row{display:flex;align-items:baseline;justify-content:space-between;gap:10px;padding:5px 0;border-bottom:1px solid rgba(126,151,182,.08)}.sp-row:last-child{border-bottom:none}.sp-row-label{font-size:12px;color:var(--ink-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sp-row-value{font-family:var(--mono);font-size:13px;color:var(--ink);white-space:nowrap}.sp-row-value i{font-style:normal;font-size:10px;color:var(--ink-dim);margin-left:3px}.param-switch{position:relative;flex:none;width:34px;height:18px;padding:0;border:none;border-radius:9px;background:#7e97b638;transition:background .15s ease;cursor:not-allowed}.param-switch.clickable{cursor:pointer}.param-switch.clickable:hover{outline:2px solid var(--flow);outline-offset:1px}.param-switch-knob{position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#c8d3e0;transition:transform .15s ease,background .15s ease}.param-switch.on{background:#2ecc718c}.param-switch.on .param-switch-knob{transform:translate(16px);background:#2ecc71}.param-switch.unknown{background:#7e97b61f}.param-switch.unknown .param-switch-knob{background:var(--ink-faint)}.placeholder-card{border-style:dashed;opacity:.7}.placeholder-note{margin:8px 0 0;font-size:12px;color:var(--ink-faint)}.sup-alarms{flex:0 0 auto;margin:0 12px 10px;padding:10px 12px;display:flex;align-items:center;gap:14px;background:var(--card-bg, rgba(46, 230, 166, .04));border:1px solid var(--card-line, rgba(126, 151, 182, .18));border-radius:8px}.sup-alarms-head{display:flex;align-items:center;gap:8px;flex:0 0 auto}.sup-alarms-title{font-family:var(--display);font-size:13px;font-weight:600;color:var(--ink)}.sup-alarms-list{flex:1 1 auto;min-width:0;display:flex;align-items:center;gap:12px;overflow:hidden;white-space:nowrap}.sup-alarms-actions{flex:0 0 auto;display:flex;gap:7px}.sup-alarms-actions .cmd-btn{padding:7px 14px}.status-cols{display:flex;gap:14px;align-items:flex-start}.status-col{display:flex;flex-direction:column;gap:5px;min-width:0;flex:1}.status-readings{margin-top:8px;padding-top:8px;border-top:1px solid var(--card-title);display:flex;flex-direction:column;gap:4px}.status-reading{display:flex;justify-content:space-between;font-size:12px;color:var(--ink)}.status-reading strong{font-family:var(--mono)}.sup-cmd .unit-card{flex:1 1 0;display:flex;flex-direction:column}.unit-body{flex:1 1 auto;display:flex;align-items:stretch;gap:12px}.unit-btn{flex:0 0 64px;display:flex;align-items:center;justify-content:center;text-align:center;border:1px solid var(--card-line);background:#7e97b614;color:var(--ink-dim);border-radius:var(--r-sm);padding:8px 4px;font-family:var(--display);font-size:13px;font-weight:700;letter-spacing:.03em;cursor:pointer;flex-direction:column;gap:3px}.unit-btn:hover:not(:disabled){border-color:var(--flow);background:#0ea5c41a}.unit-btn:disabled{opacity:.7;cursor:not-allowed}.unit-btn.arrived{border-color:var(--live);background:#16a34a1f;color:var(--live)}.unit-btn.target{border-color:var(--warn);background:#f59e0b1f;color:#b27400}.unit-mark.ok{font-size:13px;line-height:1;color:var(--live)}.unit-mark.spin{width:13px;height:13px;border-radius:50%;border:2px solid rgba(245,158,11,.3);border-top-color:var(--warn);animation:unitSpin .8s linear infinite}@keyframes unitSpin{to{transform:rotate(360deg)}}.unit-statuses{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;justify-content:flex-start;gap:5px}.sup-steps .steps-track{display:flex;flex-direction:column;align-items:center;height:100%}.step-pad{flex:.5 1 0}.step-dot.big{flex:0 0 auto;width:15px;height:15px;border-radius:50%;background:#7e97b659;border:1px solid var(--card-line);transition:background .2s ease,border-color .2s ease}.step-dot.big.arrived{background:var(--live);border-color:var(--live)}.step-dot.big.target{background:var(--warn);border-color:var(--warn);animation:dotPulse 1.2s ease-in-out infinite}@keyframes dotPulse{0%,to{box-shadow:0 0 #f59e0b8c}50%{box-shadow:0 0 0 5px #f59e0b00}}.step-conn{flex:1 1 0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px}.step-conn i{width:6px;height:6px;border-radius:50%;background:#7e97b638}.step-conn.active i{animation:stepFlow 1.1s ease-in-out infinite}.step-conn.active i:nth-child(1){animation-delay:0s}.step-conn.active i:nth-child(2){animation-delay:.18s}.step-conn.active i:nth-child(3){animation-delay:.36s}.step-conn.active.rev i:nth-child(1){animation-delay:.36s}.step-conn.active.rev i:nth-child(2){animation-delay:.18s}.step-conn.active.rev i:nth-child(3){animation-delay:0s}@keyframes stepFlow{0%,to{background:#f59e0b33;transform:scale(1)}50%{background:var(--warn);transform:scale(1.35)}}.cmd-open-btn{flex:0 0 auto;border:1px solid var(--card-line);background:var(--card-bg);color:var(--ink);border-radius:var(--r-sm);padding:9px 10px;font-family:var(--display);font-size:13px;font-weight:600;cursor:pointer;box-shadow:0 1px 2px #0f172a0d}.cmd-open-btn:hover{border-color:var(--flow);color:var(--flow)}.cmds-modal{max-width:640px}.cmds-groups{display:flex;flex-direction:column;gap:14px}.cmds-group{display:flex;flex-direction:column;gap:7px}.cmds-group-title{font-family:var(--display);font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-dim)}.cmds-group-status{display:flex;flex-wrap:wrap;gap:4px 16px;margin-top:2px;padding-left:2px}.cmd-soon{font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint);border:1px solid var(--line);border-radius:999px;padding:1px 7px}.cmd-btns{display:grid;grid-template-columns:1fr 1fr;gap:7px}.cmd-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid var(--line);background:var(--panel-2);color:var(--ink-dim);border-radius:var(--r-sm);padding:9px 8px;font-family:var(--display);font-size:12px;font-weight:600;cursor:pointer}.cmd-btn.go{border-color:#2ee6a666;color:var(--live)}.cmd-btn.stop{border-color:#ef444466;color:var(--alert)}.cmd-btn:disabled{opacity:.5;cursor:not-allowed}.cmd-dot{flex:0 0 auto;width:8px;height:8px;border-radius:50%;background:var(--ink-faint)}.cmd-btn.go .cmd-dot.on{background:var(--live);box-shadow:0 0 6px var(--live)}.cmd-btn.stop .cmd-dot.on{background:var(--alert);box-shadow:0 0 6px var(--alert)}.cmd-btn.active.go{background:#16a34a1f;border-color:var(--live)}.cmd-btn.active.stop{background:#ef44441f;border-color:var(--alert)}
