:root{--bg:#0b1320;--surface:#111d2e;--surface-2:#16263b;--line:#243a55;--text:#dce7f2;--dim:#7e93ac;--blue:#2e86e0;--blue-soft:#174a7c;--cyan:#4fc3f7;--orange:#f5a623;--green:#2ebd85;--red:#e0635b;--mono:ui-monospace, "SFMono-Regular", Menlo, Consolas, monospace;--sans:system-ui, -apple-system, "Segoe UI", Helvetica, Arial, sans-serif;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}:root[data-theme=light]{--bg:#edf2f8;--surface:#fff;--surface-2:#e2eaf4;--line:#c2d2e4;--text:#1a2a3c;--dim:#5b7188;--blue:#2470c2;--blue-soft:#cfe2f6;--cyan:#0b7dbe;--orange:#b96e08;--green:#157a55;--red:#c0473f;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);font-family:var(--sans);margin:0;font-size:14px;line-height:1.45}#root{min-height:100dvh}.app{grid-template-columns:1fr;gap:12px;max-width:1100px;margin:0 auto;padding:12px;display:grid}header.brand{align-items:center;gap:10px;padding:4px 2px;display:flex}header.brand h1{align-items:center;margin:0;display:flex}header.brand h1 img{width:auto;height:44px}header.brand span{color:var(--dim);font-size:12px}.card{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:12px}.card h2{text-transform:uppercase;letter-spacing:.08em;color:var(--dim);margin:0 0 8px;font-size:11px;font-weight:600}.kpis{grid-template-columns:1fr 1fr;gap:12px;display:grid}.kpi .label{color:var(--dim);font-size:12px}.kpi .value{font-family:var(--mono);font-size:22px;font-weight:600}.kpi .value.pos{color:var(--green)}.kpi .value.neg{color:var(--red)}.kpi .delta{color:var(--dim);font-size:12px}.fleet-grid{grid-template-columns:repeat(2,1fr);gap:8px 16px;display:grid}.fleet-grid .label{color:var(--dim);font-size:12px}.fleet-grid .value{font-family:var(--mono);font-size:16px}.meter{background:var(--surface-2);border-radius:3px;height:6px;margin-top:4px;overflow:hidden}.meter>div{background:linear-gradient(90deg, var(--blue), var(--cyan));height:100%;transition:width .2s linear}.log{font-family:var(--mono);flex-direction:column-reverse;gap:2px;max-height:220px;font-size:12px;display:flex;overflow-y:auto}.log .row{white-space:nowrap;gap:8px;display:flex}.log .t{color:var(--dim)}.log .strat{color:var(--blue);width:9ch}.log .charge{color:var(--cyan)}.log .discharge{color:var(--green)}.controls{background:var(--surface);border:1px solid var(--line);border-radius:8px;flex-wrap:wrap;grid-column:1/-1;align-items:center;gap:8px;padding:10px 12px;display:flex}.controls select,.controls button{background:var(--surface-2);color:var(--text);border:1px solid var(--line);font-size:13px;font-family:var(--sans);border-radius:6px;padding:8px 12px}.controls .spacer{flex:1}.transport{align-items:center;gap:6px;display:flex}.controls .ctl{cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .15s,background .15s,color .15s}.controls .ctl:hover{border-color:var(--cyan);color:#fff;transform:translateY(-1px);box-shadow:0 0 0 1px #4fc3f759,0 6px 16px #4fc3f72e}.controls .ctl:active{box-shadow:none;transform:translateY(0)scale(.97)}.controls .play{letter-spacing:.02em;background:linear-gradient(135deg, var(--blue-soft), #12365c);border-color:var(--blue);justify-content:center;align-items:center;gap:8px;min-width:96px;padding:8px 16px;font-weight:700;display:inline-flex}.controls .play .glyph{font-size:11px;line-height:1}.controls .play.on{background:linear-gradient(135deg, var(--blue), var(--cyan));border-color:var(--cyan);color:#04121f;box-shadow:0 0 18px #4fc3f759}.seg{background:var(--surface-2);border:1px solid var(--line);border-radius:999px;gap:2px;padding:3px;display:flex}.controls .seg button{color:var(--dim);cursor:pointer;background:0 0;border:none;border-radius:999px;padding:6px 14px;font-weight:600;transition:background .15s,color .15s,box-shadow .15s}.controls .seg button:hover{color:var(--text);background:#4fc3f71a}.controls .seg button.active,.controls .seg button[aria-pressed=true]{background:linear-gradient(135deg, var(--blue), var(--cyan));color:#04121f;box-shadow:0 0 12px #4fc3f766}.pop{animation:.22s ctl-pop}@keyframes ctl-pop{40%{transform:scale(1.12)}}.tip{position:relative}.tip:after{content:attr(data-tip);border:1px solid var(--line);color:var(--text);letter-spacing:.02em;white-space:nowrap;opacity:0;pointer-events:none;z-index:6;background:#0a1828;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:500;transition:opacity .12s .15s,transform .12s .15s;position:absolute;bottom:calc(100% + 9px);left:50%;transform:translate(-50%)translateY(3px);box-shadow:0 8px 20px #00000073}.tip:hover:after{opacity:1;transform:translate(-50%)translateY(0)}@media (hover:none){.tip:after{display:none}}kbd{font-family:var(--mono);color:var(--cyan);background:var(--surface-2);border:1px solid var(--line);border-bottom-width:2px;border-radius:4px;margin:0 1px;padding:1px 5px;font-size:10px}.chart-host{height:280px}@media (width>=900px){.app{grid-template-columns:2fr 1fr}.span-2{grid-column:1/-1}.chart-host{height:340px}}.live-badge{vertical-align:middle;letter-spacing:.08em;border-radius:10px;margin-left:8px;padding:2px 8px;font-size:10px;font-weight:700}.live-badge.on{background:var(--green);color:var(--bg);animation:2s infinite pulse}.live-badge.stale{background:var(--orange);color:var(--bg)}.live-badge.connecting{background:var(--surface-2);color:var(--dim)}@keyframes pulse{50%{opacity:.6}}.tabs{gap:6px;margin-left:auto;display:flex}.tabs button{background:var(--surface-2);color:var(--text);border:1px solid var(--line);font-size:12px;font-family:var(--sans);cursor:pointer;border-radius:6px;padding:5px 14px}.tabs button[aria-pressed=true]{background:var(--blue-soft);border-color:var(--blue)}.lab-form{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.lab-form select,.lab-form input,.lab-form button{background:var(--surface-2);color:var(--text);border:1px solid var(--line);font-size:13px;font-family:var(--sans);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;border-radius:6px;padding:8px 12px}.lab-form button.primary{background:var(--blue-soft);border-color:var(--blue);cursor:pointer}.lab-form button:disabled{opacity:.5;cursor:default}.lab-progress{background:var(--surface-2);border-radius:2px;height:3px;margin-top:10px;overflow:hidden}.lab-progress>div{background:linear-gradient(90deg, var(--blue), var(--cyan));height:100%;transition:width .12s linear}.lab-error{color:var(--red);margin:8px 0 0;font-size:12px}.lab-table{border-collapse:collapse;width:100%;font-family:var(--mono);font-size:13px}.lab-table th{text-align:right;color:var(--dim);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--line);padding:4px 8px;font-size:11px;font-weight:600}.lab-table th:first-child,.lab-table td:first-child{text-align:left}.lab-table td{text-align:right;border-bottom:1px solid var(--line);padding:6px 8px}.lab-table .pos{color:var(--green)}.lab-table .neg{color:var(--red)}.lab-table tr.lab-oracle td{border-top:2px solid var(--line);color:var(--cyan);border-bottom:none}.lab-table tr.lab-oracle td.pos{color:var(--green)}.lab-points{float:right;color:var(--dim);text-transform:none;letter-spacing:0}.live-badge.storm-on{background:var(--orange);color:var(--bg);animation:1.2s infinite pulse}.app.storm .card{border-color:color-mix(in srgb, var(--orange) 35%, var(--line));transition:border-color .4s}@media (prefers-reduced-motion:reduce){.live-badge{animation:none!important}.app.storm .card{transition:none}}.wear-grid{grid-template-columns:1fr 1fr;gap:8px 16px;display:grid}.wear-grid .label{color:var(--dim);font-size:12px}.wear-grid .value{font-family:var(--mono);font-size:16px}.wear-grid .delta{color:var(--dim);font-size:12px}.export-btn{float:right;background:var(--surface-2);color:var(--text);border:1px solid var(--line);font-size:11px;font-family:var(--sans);cursor:pointer;text-transform:none;letter-spacing:0;border-radius:5px;margin-left:6px;padding:2px 10px}.designer-presets{flex-wrap:wrap;gap:6px;margin-bottom:10px;display:flex}.designer-presets button{background:var(--surface-2);color:var(--text);border:1px solid var(--line);cursor:pointer;border-radius:6px;padding:4px 10px;font-size:12px}.designer-presets button[aria-pressed=true]{background:var(--blue-soft);border-color:var(--blue)}.designer-units{gap:6px;display:grid}.designer-units label{color:var(--dim);justify-content:space-between;align-items:center;font-size:12px;display:flex}.designer-units input{background:var(--surface-2);width:72px;color:var(--text);border:1px solid var(--line);font-family:var(--mono);border-radius:5px;padding:4px 8px}.designer-totals{font-family:var(--mono);color:var(--cyan);margin-top:10px;font-size:12px}.dist{margin-top:12px}.dist-name{font-family:var(--mono);color:var(--dim);margin-bottom:4px;font-size:12px}.dist-bars{align-items:flex-end;gap:2px;height:64px;display:flex}.dist-bars>div{background:linear-gradient(180deg, var(--cyan), var(--blue));border-radius:2px 2px 0 0;flex:1;min-height:2px}.dist-stats{font-family:var(--mono);color:var(--dim);gap:14px;margin-top:4px;font-size:11px;display:flex}.dist-stats .oracle{color:var(--cyan);margin-left:auto}.stress-label{color:var(--dim);align-items:center;gap:6px;font-size:12px;display:flex}.stress-hint{color:var(--dim);margin:8px 0 0;font-size:11px}.hotkey-hint{color:var(--dim);margin-left:8px;font-size:11px;display:none}@media (width>=900px){.hotkey-hint{display:inline}}[data-theme=light] .controls .ctl:hover{color:var(--text)}[data-theme=light] .controls .play{color:#fff;background:linear-gradient(135deg,#3b82d8,#2470c2)}[data-theme=light] .controls .play.on,[data-theme=light] .controls .seg button.active,[data-theme=light] .controls .seg button[aria-pressed=true]{color:#fff}[data-theme=light] .controls .seg button:hover{background:#2470c21f}[data-theme=light] .tip:after{color:#f2f7fc;background:#1a2a3c;border-color:#1a2a3c;box-shadow:0 8px 20px #1a2a3c40}[data-theme=light] .lab-form select,[data-theme=light] .lab-form input,[data-theme=light] .lab-form button{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}[data-theme=light] .live-badge.on,[data-theme=light] .live-badge.stale,[data-theme=light] .live-badge.storm-on{color:#fff}.tabs .theme-toggle{min-width:34px;padding:5px 10px}
