:root{
  --bg:#0c0f14; --panel:#141a23; --panel2:#1b2330; --line:#26313f;
  --txt:#e7edf5; --mut:#8b9bb0; --acc:#4da3ff; --good:#39d98a;
  --warn:#ffcf5c; --bad:#ff5c6c; --srcA:#39d98a; --srcB:#c08bff;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--txt);
  font:14px/1.45 system-ui,-apple-system,Segoe UI,Roboto,sans-serif}
h2{font-size:15px;margin:0 0 12px;font-weight:600;display:flex;
  align-items:baseline;gap:10px}
.src{font-size:11px;color:var(--mut);font-weight:400}
code{background:#0a0d12;padding:1px 5px;border-radius:4px;color:var(--acc)}

/* bandeau prix */
#pricebar{position:sticky;top:0;z-index:10;display:flex;justify-content:space-between;
  align-items:center;padding:12px 22px;background:linear-gradient(180deg,#10151d,#0c0f14);
  border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:center;gap:10px}
.brand .sub{color:var(--mut);font-size:12px}
.dot{width:9px;height:9px;border-radius:50%;background:var(--bad);
  box-shadow:0 0 8px var(--bad)}
.dot.live{background:var(--good);box-shadow:0 0 10px var(--good)}
.prices{display:flex;gap:22px;align-items:center}
.price{display:flex;flex-direction:column;align-items:flex-end}
.price .lbl{font-size:10px;color:var(--mut);text-transform:uppercase;letter-spacing:.04em}
.price .val{font-size:18px;font-weight:700}
.price.mine .val{color:var(--acc)}
.srcB{font-size:10px;color:var(--srcB);border:1px solid var(--srcB);
  padding:3px 7px;border-radius:6px;opacity:.8}

#subbar{display:flex;gap:18px;align-items:center;justify-content:flex-end;
  padding:6px 22px;background:#0a0d12;border-bottom:1px solid var(--line);
  font-size:12px;color:var(--mut)}
#subbar b{color:var(--txt);font-weight:700}
#subbar .tagloue{color:var(--warn);margin-right:auto;font-weight:600}
#subbar .mut{opacity:.7}

main{max-width:1280px;margin:0 auto;padding:22px}
section{margin-bottom:26px}
.cols{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px}
@media(max-width:900px){.cols{grid-template-columns:1fr}}

/* grille GPU */
.gpugrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media(max-width:1000px){.gpugrid{grid-template-columns:repeat(2,1fr)}}
.gpu{background:var(--panel);border:1px solid var(--line);border-radius:12px;
  padding:14px;position:relative;overflow:hidden}
.gpu .hd{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.gpu .id{font-weight:700}
.gpu .pcie{font-size:10px;color:var(--mut)}
.gpu .pcie.warn{color:var(--warn)}
.temp{font-size:34px;font-weight:800;line-height:1;letter-spacing:-.02em}
.temp small{font-size:14px;font-weight:600;opacity:.7}
.temp.crit{animation:blink 1s steps(2,start) infinite}
@keyframes blink{50%{opacity:.25}}
.metrics{margin-top:12px;display:flex;flex-direction:column;gap:9px}
.bar{height:8px;background:#0a0d12;border-radius:5px;overflow:hidden}
.bar>i{display:block;height:100%;border-radius:5px;transition:width .4s}
.mrow{display:flex;justify-content:space-between;font-size:12px;color:var(--mut)}
.mrow b{color:var(--txt);font-weight:600}
.gpu .badge{position:absolute;top:12px;right:12px;font-size:10px;padding:2px 6px;
  border-radius:5px;background:#0a0d12;color:var(--mut)}
.gpu.busy{border-color:#2c4257}

/* sessions */
.sessions{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:14px}
.sess{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px}
.sess .top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.sess .proj{font-weight:700;font-size:15px}
.sess .meta{font-size:11px;color:var(--mut);margin-top:2px}
.tag{font-size:10px;padding:2px 7px;border-radius:20px;font-weight:600}
.tag.new{background:#27406b;color:#9cc4ff}
.tag.ret{background:#1d4733;color:#7ff0b4}
.prog{margin-top:12px}
.prog .bar{height:10px}
.prog .pl{display:flex;justify-content:space-between;font-size:11px;color:var(--mut);margin-top:5px}
.netrow{display:flex;gap:16px;margin-top:10px;font-size:12px}
.netrow .up{color:var(--warn)} .netrow .down{color:var(--good)}
.gpupill{display:inline-block;font-size:10px;background:#0a0d12;border:1px solid var(--line);
  padding:1px 6px;border-radius:5px;margin-right:3px}

/* kv (machine) */
.kv{display:grid;grid-template-columns:auto 1fr;gap:6px 14px;font-size:13px}
.kv .k{color:var(--mut)} .kv .v{text-align:right;font-weight:600}
.kv .v.ok{color:var(--good)} .kv .v.bad{color:var(--bad)}

/* heatmap */
.heatmap{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.hcell{aspect-ratio:1;border-radius:4px;background:#0a0d12;position:relative;
  font-size:9px;color:#55657a;display:flex;align-items:flex-start;justify-content:flex-end;
  padding:2px}
.hcell.peak{outline:2px solid var(--acc)}
.peak{margin-top:10px;font-size:12px;color:var(--mut)}

/* clients */
.clients{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}
.cl{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:12px}
.cl .nm{font-weight:700;display:flex;justify-content:space-between;align-items:center}
.cl .fp{font-size:10px;color:var(--mut);font-family:ui-monospace,monospace;margin:4px 0}
.cl .st{display:flex;gap:14px;font-size:12px;color:var(--mut);margin-top:6px}
.cl .st b{color:var(--txt)}

/* alertes */
#alerts{max-width:1280px;margin:0 auto;padding:0 22px}
#alerts:not(:empty){padding-top:12px}
.alert{padding:8px 14px;border-radius:8px;margin-bottom:6px;font-size:13px;font-weight:500;
  border:1px solid var(--line)}
.alert.crit{background:#3a1418;border-color:#ff5c6c;color:#ffd2d6}
.alert.warn{background:#33270a;border-color:#ffcf5c;color:#ffe9b0}
.alert.info{background:#10243a;border-color:#4da3ff;color:#bfe0ff}

/* sparkline GPU */
.gpu .spark{width:100%;height:30px;margin-top:10px;display:block}
.gpu .badge.bad{background:#3a1418;color:#ff8b95}

/* economics */
.bignet{font-size:30px;font-weight:800;margin-bottom:10px}
.bignet small{font-size:13px;font-weight:600;opacity:.6;margin-left:4px}
.bignet.ok{color:var(--good)} .bignet.bad{color:var(--bad)}
.bignet .margin{font-size:12px;color:var(--mut);font-weight:500;margin-left:10px}
.reco{margin-top:12px;background:#10243a;border:1px solid var(--acc);border-radius:8px;
  padding:9px 12px;font-size:13px}
.rates{margin-top:8px;font-size:11px;color:var(--mut)}
.rates b{color:var(--txt)}
.netrow .datarev{color:var(--good);font-weight:600}
.kv .v.warn{color:var(--warn)}

/* health */
.hgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;margin-bottom:12px}
.hgpu{background:#0a0d12;border:1px solid var(--line);border-radius:8px;padding:7px 9px;
  display:flex;gap:8px;align-items:center;font-size:11px;flex-wrap:wrap}
.hgpu b{font-size:12px}
.hgpu .ok{color:var(--good)} .hgpu .warn{color:var(--warn)} .hgpu .bad{color:var(--bad)}
.disk{margin-bottom:8px}
.disk .dsub{font-size:10px;color:#55657a;margin-top:2px}
.disk .ok{color:var(--good)} .disk .warn{color:var(--warn)} .disk .bad{color:var(--bad)}
.hrow{display:flex;justify-content:space-between;font-size:13px;padding:4px 0;border-top:1px solid var(--line)}
.hrow .ok{color:var(--good)} .hrow .warn{color:var(--warn)}
.rep{font-size:11px;color:var(--mut);font-style:italic;margin-top:4px}

/* onduleurs */
.upsgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}
.upscard{background:var(--panel2);border:1px solid var(--line);border-radius:12px;padding:14px}
.upscard.crit{border-color:var(--bad);animation:blink 1.1s ease-in-out infinite}
.upscard .uhd{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.upscard .unm{font-weight:700;font-size:15px}
.upscard .ust{font-size:11px;font-weight:600;padding:2px 8px;border-radius:6px;background:#0a0d12}
.upscard .ust.ok{color:var(--good)} .upscard .ust.bad{color:var(--bad)}
.upscard .ubig{font-size:30px;font-weight:800;margin:4px 0}
.upscard .ubig small{font-size:14px;opacity:.6}
.upscard .ubig.ok{color:var(--good)} .upscard .ubig.warn{color:var(--warn)} .upscard .ubig.bad{color:var(--bad)}
.upscard .urt{font-size:11px;color:var(--mut);font-weight:500;margin-left:8px}
.upscard .ukv{display:flex;justify-content:space-between;font-size:12px;color:var(--mut);margin-top:8px}
.upscard .ukv b{color:var(--txt)}
.upscard .ukv .bad{color:var(--bad)} .upscard .ukv .warn{color:var(--warn)}
.upscard .umodel{font-size:10px;color:#55657a;margin-top:6px}

/* charts */
canvas.trend{width:100%;height:180px;display:block}
canvas.bigchart{width:100%;height:300px;display:block;background:#0a0d12;border-radius:10px;
  border:1px solid var(--line)}
.spacer{flex:1}
.metricsel,.ranges{display:flex;gap:6px}
.ranges{margin:6px 0 10px}
.msel,.rng{background:#0a0d12;border:1px solid var(--line);color:var(--mut);
  padding:4px 12px;border-radius:7px;font-size:12px;cursor:pointer;font-weight:500}
.msel:hover,.rng:hover{color:var(--txt);border-color:#3a4a5e}
.msel.active,.rng.active{background:var(--acc);color:#04101e;border-color:var(--acc);font-weight:700}
.legend{display:flex;gap:16px;flex-wrap:wrap;margin-top:10px;font-size:12px;color:var(--mut)}
.legend .lg{display:flex;align-items:center;gap:6px}
.legend .lg i{width:12px;height:3px;border-radius:2px;display:inline-block}

.note{font-size:12px;color:var(--mut);background:var(--panel2);border:1px solid var(--line);
  border-radius:8px;padding:10px 12px;margin-bottom:12px}
footer{max-width:1280px;margin:0 auto;padding:0 22px 30px;color:var(--mut);font-size:11px}
.empty{color:var(--mut);font-size:13px;padding:14px;background:var(--panel);
  border:1px dashed var(--line);border-radius:10px}
