:root{--bg:#0d0f12;--panel:#14171c;--panel-2:#1a1d23;--fg:#e8eaed;--dim:#5c6470;--accent:#7aa2f7;--good:#9ece6a;--warn:#e0af68;--danger:#f7768e;--border:#232830;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}*{box-sizing:border-box}html,body{background:var(--bg);height:100%;color:var(--fg);-webkit-font-smoothing:antialiased;margin:0;padding:0}#app{grid-template-rows:56px 1fr;width:100vw;height:100vh;display:grid}.hud{border-bottom:1px solid var(--border);background:var(--panel);align-items:center;gap:24px;padding:0 20px;display:flex}.hud .brand{letter-spacing:.02em;color:var(--fg);font-size:14px;font-weight:600}.hud .brand .dot{color:var(--accent);margin-right:6px}.hud .stat{flex-direction:column;min-width:80px;line-height:1.1;display:flex}.hud .stat .label{color:var(--dim);text-transform:uppercase;letter-spacing:.08em;font-size:10px}.hud .stat .value{color:var(--fg);margin-top:2px;font-size:16px}.hud .stat.freq.warn .value{color:var(--warn)}.hud .stat.freq.danger .value{color:var(--danger)}.hud .stat.freq.good .value{color:var(--good)}.hud .spacer{flex:1}.hud .btn{border:1px solid var(--border);background:var(--panel-2);color:var(--fg);font:inherit;cursor:pointer;border-radius:4px;padding:6px 12px;font-size:12px}.hud .btn:hover{border-color:var(--accent)}.hud .btn.primary{border-color:var(--accent);color:var(--accent)}.hud .btn.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}.main{grid-template-columns:300px 1fr;min-height:0;display:grid}.sidebar{background:var(--panel);border-right:1px solid var(--border);padding:16px;overflow-y:auto}.sidebar h2{color:var(--dim);text-transform:uppercase;letter-spacing:.08em;margin:0 0 12px;font-size:11px;font-weight:600}.gen-card{background:var(--panel-2);border:1px solid var(--border);border-radius:6px;margin-bottom:10px;padding:12px}.gen-card .head{align-items:center;gap:8px;margin-bottom:8px;display:flex}.gen-card .name{font-size:13px;font-weight:600}.gen-card .meta{color:var(--dim);font-size:10px}.gen-card .status-pill{text-transform:uppercase;letter-spacing:.05em;border-radius:3px;margin-left:auto;padding:2px 6px;font-size:10px}.gen-card .status-pill.on{color:var(--good);background:#9ece6a26}.gen-card .status-pill.off{color:var(--dim);background:#5c647033}.gen-card .status-pill.starting,.gen-card .status-pill.stopping{color:var(--warn);background:#e0af6826}.gen-card .status-pill.tripped{color:var(--danger);background:#f7768e33}.gen-card .output-row{align-items:baseline;gap:6px;margin-bottom:6px;font-size:12px;display:flex}.gen-card .output-row .mw{color:var(--accent);font-size:14px;font-weight:600}.gen-card .output-row .of{color:var(--dim)}.gen-card input[type=range]{width:100%;accent-color:var(--accent);margin:4px 0}.gen-card input[type=range]:disabled{opacity:.4}.gen-card .row{gap:6px;margin-top:8px;display:flex}.gen-card button{border:1px solid var(--border);color:var(--fg);font:inherit;cursor:pointer;background:0 0;border-radius:4px;flex:1;padding:6px 8px;font-size:11px}.gen-card button:hover{border-color:var(--accent)}.gen-card button.active{background:var(--accent);color:var(--bg);border-color:var(--accent)}.gen-card .info{color:var(--dim);justify-content:space-between;margin-top:8px;font-size:10px;display:flex}.viewport{min-height:0;position:relative}canvas{width:100%;height:100%;display:block}.overlay{z-index:10;background:#0d0f12eb;justify-content:center;align-items:center;padding:40px;display:flex;position:absolute;inset:0}.overlay .card{background:var(--panel);border:1px solid var(--border);border-radius:8px;width:100%;max-width:560px;padding:28px 32px}.overlay h1{margin:0 0 4px;font-size:22px}.overlay .sub{color:var(--dim);text-transform:uppercase;letter-spacing:.08em;margin-bottom:18px;font-size:12px}.overlay ul{color:var(--fg);padding-left:18px;font-size:13px;line-height:1.7}.overlay ul li{margin-bottom:4px}.overlay .actions{gap:10px;margin-top:22px;display:flex}.overlay .actions button{border:1px solid var(--border);background:var(--panel-2);color:var(--fg);cursor:pointer;font:inherit;border-radius:4px;padding:10px 18px;font-size:13px}.overlay .actions button.primary{background:var(--accent);border-color:var(--accent);color:var(--bg);font-weight:600}.overlay .actions button:hover{border-color:var(--accent)}.menu-grid{grid-template-columns:repeat(3,1fr);gap:10px;margin-top:12px;display:grid}.menu-card{background:var(--panel-2);border:1px solid var(--border);cursor:pointer;text-align:left;font:inherit;color:var(--fg);border-radius:6px;padding:14px}.menu-card:hover:not(:disabled){border-color:var(--accent)}.menu-card:disabled{opacity:.45;cursor:not-allowed}.menu-card .layer-num{color:var(--dim);letter-spacing:.1em;text-transform:uppercase;font-size:10px}.menu-card .layer-title{margin:4px 0;font-size:14px;font-weight:600}.menu-card .layer-sub{color:var(--dim);font-size:11px}.menu-card.locked .lock{color:var(--warn);margin-top:8px;font-size:10px}.event-toast{background:var(--panel-2);border:1px solid var(--warn);color:var(--warn);pointer-events:none;opacity:0;border-radius:4px;padding:8px 14px;font-size:12px;transition:opacity .3s;position:absolute;top:16px;left:50%;transform:translate(-50%)}.event-toast.show{opacity:1}.progress-bar{background:var(--panel-2);border-radius:2px;height:4px;position:absolute;bottom:8px;left:16px;right:16px;overflow:hidden}.progress-bar .fill{background:var(--good);width:0%;height:100%;transition:width .2s ease-out}
