:root{--navy:#0b1f3a;--navy2:#13294b;--accent:#3aa0ff;--amber:#f1c40f;--ok:#2ecc71;
  --bad:#e74c3c;--ink:#e8eef7;--muted:#9fb3cd;--card:#13294b;--line:#27406b}
*{box-sizing:border-box}
body{margin:0;font-family:Segoe UI,Roboto,Arial,sans-serif;background:var(--navy);color:var(--ink)}
a{color:var(--accent)}
header.top{display:flex;align-items:center;gap:14px;padding:14px 22px;background:var(--navy2);
  border-bottom:1px solid var(--line)}
header.top img{height:34px}
header.top h1{font-size:18px;margin:0;font-weight:600}
nav.tabs{display:flex;gap:6px;flex-wrap:wrap;padding:10px 22px;background:var(--navy2);border-bottom:1px solid var(--line)}
nav.tabs a{color:var(--muted);text-decoration:none;padding:8px 14px;border-radius:8px;font-size:14px}
nav.tabs a:hover{background:#1c3a63}
nav.tabs a.active{background:var(--accent);color:#04122b;font-weight:600}
main{padding:22px;max-width:1280px;margin:0 auto}
.banner{background:#0e2244;border:1px solid var(--line);border-radius:12px;
  padding:14px 18px;margin-bottom:18px;color:var(--muted)}
.section-title{margin:26px 0 10px;font-size:15px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px}
.kpi .v{font-size:30px;font-weight:700}
.kpi .l{color:var(--muted);font-size:13px;margin-top:4px}
.kpi .s{color:var(--muted);font-size:11px;margin-top:6px;opacity:.8}
.kpi.good .v{color:var(--ok)} .kpi.bad .v{color:var(--bad)} .kpi.info .v{color:var(--accent)}
.kpi.detect .v{color:var(--amber)}
.bars{margin-top:26px}
.bar{display:flex;align-items:center;gap:10px;margin:6px 0}
.bar .name{width:70px;color:var(--muted);font-size:13px}
.bar .track{flex:1;background:#0c1d36;border-radius:6px;overflow:hidden;height:18px}
.bar .fill{background:var(--accent);height:100%}
.bar .num{width:60px;text-align:right;font-size:13px;color:var(--muted)}
footer.cc{padding:18px 22px;color:var(--muted);font-size:12px;border-top:1px solid var(--line);margin-top:30px}
.err{background:#3a1620;border:1px solid var(--bad);color:#ffd7dd;padding:12px;border-radius:8px}
/* graphe */
#cy{width:100%;height:74vh;background:#08152a;border:1px solid var(--line);border-radius:12px}
.controls{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:12px}
.controls input,.controls select,.controls button{background:var(--card);color:var(--ink);
  border:1px solid var(--line);border-radius:8px;padding:8px 10px;font-size:13px}
.controls button{cursor:pointer}
.side{position:fixed;right:0;top:0;width:340px;height:100%;background:var(--navy2);
  border-left:1px solid var(--line);padding:18px;overflow:auto;transform:translateX(100%);transition:.2s;z-index:10}
.side.open{transform:none}
.side h3{margin-top:0}
.search{width:100%;padding:10px;border-radius:8px;border:1px solid var(--line);background:var(--card);color:var(--ink)}
.list{margin-top:14px}
.item{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:12px;margin:8px 0}
.tag{display:inline-block;background:#0c1d36;color:var(--muted);border-radius:6px;
  padding:2px 8px;font-size:12px;margin-right:6px}
.cols{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-top:10px}
.col h4{color:var(--accent);margin:0 0 8px}
