
<!-- FILE: assets/css/dashboard.css -->
/*
  Thème clair/sombre via variables CSS.
  Par défaut: clair. Le mode sombre s'applique avec body[data-theme="dark"].
*/
:root{
  --bg: #f5f7fb;
  --panel: #ffffff;
  --muted: #6b7280;
  --text: #0f172a;
  --accent: #2563eb;
  --ok: #16a34a;
  --warn: #d97706;
  --bad: #dc2626;
  --card: #f8fafc;
  --border: #e5e7eb;
}
body[data-theme="dark"]{
  --bg: #0f172a;
  --panel: #111827;
  --muted: #94a3b8;
  --text: #e5e7eb;
  --accent: #60a5fa;
  --ok: #22c55e;
  --warn: #f59e0b;
  --bad: #ef4444;
  --card: #0b1220;
  --border: #1f2937;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font: 14px/1.5 system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, "Helvetica Neue", Arial, "Apple Color Emoji","Segoe UI Emoji";
  color:var(--text);
  background:var(--bg);
  background-image: linear-gradient(180deg, transparent, rgba(0,0,0,0.02));
}
header{position:sticky; top:0; z-index:10; background:color-mix(in oklab, var(--panel), transparent 10%); backdrop-filter:saturate(1.2) blur(8px); border-bottom:1px solid var(--border)}
.wrap{max-width:1400px;margin:0 auto;padding:12px 16px}
.topbar{display:flex;align-items:center;gap:16px;justify-content:space-between}
.title{display:flex;align-items:center;gap:12px}
.title h1{font-size:18px;margin:0}
.title small{color:var(--muted)}
.pill{border:1px solid var(--border);background:var(--card);padding:6px 10px;border-radius:999px;color:var(--muted)}

main{max-width:1400px;margin:16px auto;padding:0 16px;display:grid;grid-template-columns:300px 1fr;gap:16px}
@media (max-width: 1000px){ main{grid-template-columns:1fr} }

aside{display:flex;flex-direction:column;gap:12px}
.card{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:14px; box-shadow: 0 1px 2px rgba(0,0,0,.04)}
.kpis{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.kpi{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:12px}
.kpi h3{margin:0 0 8px 0;font-size:12px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.kpi .val{font-size:22px;font-weight:700}
.kpi .trend{font-size:12px}
.legend{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.dot{width:10px;height:10px;border-radius:2px;display:inline-block;margin-right:6px}
.checks{margin-top:10px;display:grid;gap:8px}
.map-panel{display:grid;grid-template-rows:420px auto;gap:12px}
#map{height:420px;width:100%;border-radius:14px;overflow:hidden;border:1px solid var(--border)}
.charts{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width: 900px){ .charts{grid-template-columns:1fr} }
.mb8{margin-bottom:8px}
.h{margin:0 0 10px 0;font-size:16px}
.small{font-size:12px;color:var(--muted)}
.bullets{margin:0;padding-left:18px;line-height:1.7}

/* table & ui */
table{width:100%;border-collapse:collapse}
th,td{padding:10px;border-bottom:1px solid var(--border);text-align:left}
th{color:var(--muted);font-weight:600}
.btn{appearance:none;border:1px solid var(--border);background:var(--card);color:var(--text);padding:8px 10px;border-radius:10px;cursor:pointer}
.btn:hover{filter:brightness(0.97)}
.row{display:flex;gap:8px;align-items:center;justify-content:space-between;flex-wrap:wrap}
.gap8{gap:8px}
.badge{padding:2px 8px;border-radius:999px;font-size:12px;border:1px solid var(--border);background:var(--card)}
.badge.ok{color:var(--ok)}
.badge.warn{color:var(--warn)}
.badge.bad{color:var(--bad)}
a{color:var(--accent);text-decoration:none}
