/* ===========================================================
   BÉNIN · COCKPIT — thème glass-cockpit / EFIS
   =========================================================== */
:root{
  /* Palette nationale du Bénin : vert · or · rouge (drapeau). */
  --amber:#fcd116; --amber-dim:#c9a50f;   /* or béninois */
  --orange:#ff8c2e;
  --cyan:#2ed47e; --cyan-dim:#1a9e5c;      /* vert clair (chrome UI) */
  --green:#08b85e; --green-dim:#0a7d42;    /* vert béninois */
  --red:#ec1c2e; --magenta:#ff5cc8; --violet:#8b7bff;

  --bg:#04070c; --bg-2:#070b12;
  --panel:#0b1119; --panel-2:#0f1722; --panel-3:#13202e;
  --bezel:#1b2a3a; --bezel-hi:#28415a;
  --line:#15212e;
  --txt:#cfe0ee; --muted:#6f8aa3; --muted-2:#48607a;

  --mono:'Share Tech Mono',ui-monospace,monospace;
  --display:'Orbitron',sans-serif;
  --body:'Inter',system-ui,sans-serif;

  --radius:6px; --glow-amber:0 0 12px rgba(252,209,22,.45);
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:var(--body);color:var(--txt);font-size:14px;
  background:
    radial-gradient(1200px 700px at 78% -8%, rgba(46,212,126,.06), transparent 60%),
    radial-gradient(1000px 600px at 0% 110%, rgba(252,209,22,.05), transparent 55%),
    var(--bg);
  display:grid;grid-template-columns:262px 1fr;min-height:100vh;
}

/* ---- HUD overlay : scanlines + grille + vignette ---- */
.hud-overlay{position:fixed;inset:0;z-index:1;pointer-events:none;
  background:
    repeating-linear-gradient(0deg, rgba(255,255,255,.012) 0 1px, transparent 1px 3px),
    linear-gradient(transparent, rgba(0,0,0,.25) 92%),
    radial-gradient(120% 120% at 50% 50%, transparent 62%, rgba(0,0,0,.45));
  mix-blend-mode:screen;opacity:.6}
.hud-overlay::after{content:'';position:absolute;inset:0;
  background-image:linear-gradient(rgba(46,212,126,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(46,212,126,.04) 1px,transparent 1px);
  background-size:46px 46px;mix-blend-mode:overlay;opacity:.35}

/* ---------- Console latérale ---------- */
.sidebar{position:sticky;top:0;height:100vh;z-index:3;
  background:linear-gradient(180deg,#070d15,#04070c);
  border-right:1px solid var(--bezel);box-shadow:inset -1px 0 0 #0a121c, 6px 0 24px rgba(0,0,0,.5);
  display:flex;flex-direction:column;padding:18px 14px}
.brand{display:flex;gap:12px;align-items:center;padding:4px 6px 16px;border-bottom:1px solid var(--line)}
.brand-mark{width:44px;height:44px;border-radius:11px;overflow:hidden;flex:none;
  box-shadow:0 0 16px rgba(252,209,22,.30),0 2px 9px rgba(0,0,0,.55)}
.brand-mark svg{width:100%;height:100%;display:block}
.brand-text{display:flex;flex-direction:column;line-height:1.3}
.brand-text strong{font-family:var(--display);font-size:13px;letter-spacing:.06em;color:#eaf3fb}
.brand-text span{font-family:var(--mono);font-size:10.5px;color:var(--cyan-dim);letter-spacing:.04em}
.sys-status{margin:12px 6px 4px;font-family:var(--mono);font-size:10px;letter-spacing:.12em;color:var(--green);
  text-transform:uppercase;display:flex;align-items:center;gap:8px;text-shadow:0 0 8px rgba(8,184,94,.5)}
.lang-btn{font-weight:700;letter-spacing:.1em;color:var(--cyan-dim);border-color:var(--cyan-dim)}
.lang-btn:hover{color:var(--green);border-color:var(--green);box-shadow:0 0 10px rgba(8,184,94,.25)}
.sys-led{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 10px var(--green);animation:blink 2.4s infinite}
@keyframes blink{0%,92%,100%{opacity:1}94%{opacity:.25}}

.nav{display:flex;flex-direction:column;gap:4px;margin-top:18px}
.nav button{display:flex;align-items:center;gap:12px;background:transparent;border:1px solid transparent;
  color:var(--muted);text-align:left;padding:11px 12px;border-radius:var(--radius);cursor:pointer;
  font-family:var(--mono);font-size:12.5px;letter-spacing:.05em;text-transform:uppercase;
  transition:.16s;position:relative}
.nav button .ic{font-size:9px;width:14px;text-align:center;color:var(--muted-2)}
.nav button::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:3px;height:0;background:var(--amber);border-radius:2px;transition:.18s;box-shadow:0 0 8px var(--amber)}
.nav button:hover{color:var(--txt);background:var(--panel);border-color:var(--line)}
.nav button.active{color:#fff;background:linear-gradient(90deg,rgba(252,209,22,.12),rgba(252,209,22,.02));
  border-color:rgba(252,209,22,.3)}
.nav button.active::before{height:60%}
.nav button.active .ic{color:var(--amber);text-shadow:0 0 8px var(--amber)}

.sidebar-foot{margin-top:auto;padding:14px 8px 4px;font-size:10.5px;color:var(--muted-2);
  font-family:var(--mono);border-top:1px solid var(--line)}
.sidebar-foot p{margin:10px 0;line-height:1.6}
.badge-storage{display:inline-block;padding:4px 10px;border-radius:4px;background:var(--panel-2);
  color:var(--cyan-dim);font-size:10px;border:1px solid var(--bezel);letter-spacing:.08em}

/* ---------- Pont principal ---------- */
.main{min-width:0;padding:0 30px 70px;position:relative;z-index:2}
.topbar{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;
  padding:20px 0 16px;position:sticky;top:0;z-index:6;
  background:linear-gradient(180deg,var(--bg) 72%,transparent);
  border-bottom:1px solid var(--bezel);box-shadow:0 1px 0 #0a121c}
.topbar h1{margin:0;font-family:var(--display);font-size:21px;font-weight:700;letter-spacing:.02em;
  color:#eaf3fb;text-transform:uppercase}
.muted{color:var(--muted)}
#view-sub{margin:5px 0 0;font-family:var(--mono);font-size:11.5px;color:var(--cyan-dim);letter-spacing:.04em}
.topbar-actions{display:flex;gap:8px;align-items:center}
#search{background:var(--panel);border:1px solid var(--bezel);color:var(--txt);padding:9px 13px;
  border-radius:var(--radius);font-size:12.5px;width:230px;font-family:var(--mono)}
#search::placeholder{color:var(--muted-2)}
#search:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 1px var(--cyan),0 0 12px rgba(46,212,126,.25)}
.btn-ghost{background:var(--panel);border:1px solid var(--bezel);color:var(--muted);padding:9px 12px;
  border-radius:var(--radius);cursor:pointer;font-size:11px;font-family:var(--mono);letter-spacing:.06em;
  text-transform:uppercase;transition:.15s}
.btn-ghost:hover{color:var(--amber);border-color:var(--amber-dim);box-shadow:0 0 10px rgba(252,209,22,.2)}
.view{padding:22px 0}

/* bezel commun aux instruments */
.kpi,.block,.tbl-wrap,.mini-stat,.sim,.target-card,.callout{
  background:linear-gradient(180deg,var(--panel-2),var(--panel));
  border:1px solid var(--bezel);border-radius:var(--radius);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04),inset 0 0 24px rgba(0,0,0,.35),0 4px 18px rgba(0,0,0,.3)}

/* ---------- Instruments KPI ---------- */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:14px;margin-bottom:24px}
/* KPI regroupés par pilier */
.kpi-pillars{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}
.kpi-pillar{border-left:2px solid color-mix(in srgb,var(--c) 45%,transparent);padding-left:14px}
.kpi-pillar-head{display:flex;align-items:center;gap:9px;font-family:var(--display);font-size:12.5px;font-weight:700;
  letter-spacing:.07em;text-transform:uppercase;color:var(--c);margin:0 0 11px;
  text-shadow:0 0 12px color-mix(in srgb,var(--c) 45%,transparent)}
.kpp-dot{width:9px;height:9px;border-radius:50%;background:var(--c);box-shadow:0 0 10px var(--c)}
/* 3 KPI par ligne (cartes de largeur uniforme, alignées sur le synoptique) */
.kpi-pillar .kpi-grid{margin-bottom:0;grid-template-columns:repeat(3,1fr)}
@media(max-width:820px){.kpi-pillar .kpi-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.kpi-pillar .kpi-grid{grid-template-columns:1fr}}
.piloted-tag{font-family:var(--mono);font-size:8.5px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--green);border:1px solid var(--green);border-radius:3px;padding:1px 5px;vertical-align:middle;
  box-shadow:0 0 8px color-mix(in srgb,var(--green) 35%,transparent)}
/* Impact projeté d'un objectif */
.target-impact{display:flex;align-items:center;gap:11px;margin-top:13px;padding-top:13px;border-top:1px dashed var(--bezel)}
.ti-ico{font-family:var(--display);font-size:16px;color:var(--cyan);flex:none;text-shadow:0 0 8px var(--cyan)}
.ti-body{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}
.ti-cap{font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--cyan-dim)}
.ti-text{font-size:12.5px;color:#e7f1fa;line-height:1.45}
.ti-link{flex:none;background:var(--panel);border:1px solid var(--cyan-dim);color:var(--cyan);
  padding:6px 12px;border-radius:var(--radius);cursor:pointer;font-family:var(--mono);font-size:10.5px;
  letter-spacing:.05em;text-transform:uppercase;transition:.15s}
.ti-link:hover{border-color:var(--cyan);box-shadow:0 0 11px rgba(46,212,126,.25);color:#bdf5d8}
.kpi{padding:16px 18px;position:relative;overflow:hidden;display:flex;align-items:center;gap:16px}
.kpi::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent,var(--cyan));
  box-shadow:0 0 12px var(--accent,var(--cyan))}
.kpi-readout{flex:1;min-width:0}
.kpi .big{font-family:var(--display);font-size:25px;font-weight:700;line-height:1;letter-spacing:.01em;
  color:var(--accent,var(--amber));text-shadow:0 0 14px color-mix(in srgb,var(--accent,var(--amber)) 55%,transparent)}
.kpi .label{font-family:var(--mono);font-size:11px;color:var(--txt);margin-top:9px;letter-spacing:.05em;text-transform:uppercase}
.kpi .sub{font-size:11px;color:var(--muted);margin-top:4px;font-family:var(--mono)}
/* jauge ronde */
.gauge{width:62px;height:62px;flex:none;position:relative}
.gauge svg{width:100%;height:100%;transform:rotate(0)}
.gauge .g-val{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--mono);
  font-size:12px;color:var(--accent,var(--amber));text-shadow:0 0 8px color-mix(in srgb,var(--accent) 60%,transparent)}

/* ---------- Blocs ---------- */
.block{padding:18px 20px;margin-bottom:18px}
.block h2{margin:0 0 4px;font-family:var(--display);font-size:14px;font-weight:600;letter-spacing:.03em;
  text-transform:uppercase;color:#e7f1fa}
.block .h-sub{color:var(--muted);font-size:12px;margin:0 0 16px;font-family:var(--mono)}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:980px){.row-2{grid-template-columns:1fr}}

/* ---------- Tables ---------- */
.tbl-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13px}
thead th{background:var(--panel-3);text-align:left;padding:11px 14px;font-family:var(--mono);font-weight:400;
  color:var(--cyan-dim);font-size:10.5px;text-transform:uppercase;letter-spacing:.1em;cursor:pointer;
  white-space:nowrap;border-bottom:1px solid var(--bezel)}
thead th:hover{color:var(--cyan)}
thead th .arrow{opacity:.7;font-size:9px;margin-left:4px;color:var(--amber)}
tbody td{padding:12px 14px;border-top:1px solid var(--line);vertical-align:middle}
tbody tr{cursor:pointer;transition:.12s}
tbody tr:hover{background:linear-gradient(90deg,rgba(46,212,126,.06),transparent)}
.prod-cell{display:flex;align-items:center;gap:11px;font-weight:600;font-size:13px}
.dot{width:8px;height:8px;border-radius:50%;flex:none;box-shadow:0 0 8px currentColor}
.num{font-family:var(--mono);font-weight:400;letter-spacing:.02em;color:#dcebff;color:var(--txt)}
.sub-txt{color:var(--muted);font-size:11.5px;line-height:1.55}

/* LED segmentées (concentration / transformation / progress) */
.conc{display:flex;align-items:center;gap:8px;min-width:130px}
.conc-track{flex:1;height:9px;background:#060b11;border:1px solid var(--bezel);border-radius:3px;overflow:hidden}
.conc-fill,.s-fill,.prog-fill{height:100%;border-radius:2px;
  -webkit-mask-image:repeating-linear-gradient(90deg,#000 0 5px,transparent 5px 7px);
  mask-image:repeating-linear-gradient(90deg,#000 0 5px,transparent 5px 7px)}
.conc-fill{box-shadow:0 0 8px currentColor}
.conc-val{font-family:var(--mono);font-size:11.5px;color:var(--amber);width:36px;text-align:right;
  text-shadow:0 0 6px rgba(252,209,22,.4)}

/* ---------- Voyants annunciateurs (status) ---------- */
.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 11px 4px 9px;border-radius:4px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;
  border:1px solid currentColor;background:#080d13}
.pill::before{content:'';width:7px;height:7px;border-radius:50%;background:currentColor;box-shadow:0 0 8px currentColor}
.pill-critique{color:var(--red);animation:annun 1.3s infinite}
@keyframes annun{0%,100%{opacity:1}50%{opacity:.45}}
.pill-eleve{color:var(--amber)}
.pill-modere{color:var(--cyan)}
.pill-structure{color:var(--green)}
.pill-default{color:var(--muted)}

.tag{display:inline-flex;align-items:center;padding:3px 9px;border-radius:4px;font-size:11px;
  font-family:var(--mono);background:var(--panel-3);color:var(--cyan);border:1px solid var(--bezel);margin:3px 4px 3px 0}

/* ---------- Drawer supprimé : page détaillée ---------- */
.detail-page{padding:18px 0 40px;animation:boot .26s ease}
@keyframes boot{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.detail-top{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.back-btn{background:var(--panel);border:1px solid var(--bezel);color:var(--cyan);padding:9px 16px;
  border-radius:var(--radius);cursor:pointer;font-family:var(--mono);font-size:12px;letter-spacing:.06em;
  text-transform:uppercase;transition:.15s}
.back-btn:hover{border-color:var(--cyan);box-shadow:0 0 12px rgba(46,212,126,.25);color:#bff4ff}
.detail-crumb{font-family:var(--mono);font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.detail-hero{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;
  padding:0 0 16px 18px;border-left:4px solid var(--c,var(--amber));margin-bottom:6px;
  box-shadow:-1px 0 14px -4px var(--c,var(--amber))}
.detail-title{margin:0;font-family:var(--display);font-size:28px;font-weight:800;letter-spacing:.01em;
  color:#eef5fc;text-shadow:0 0 18px rgba(46,212,126,.18)}
.detail-pills{display:flex;gap:8px;flex-wrap:wrap;margin-top:13px}
.detail-note{color:var(--txt);font-size:13px;line-height:1.7;margin:0 0 24px;padding:14px 18px;
  background:var(--panel);border:1px solid var(--bezel);border-left:3px solid var(--amber);border-radius:var(--radius)}
.detail-grid{display:grid;grid-template-columns:1fr 360px;gap:24px;align-items:start}
.detail-main{min-width:0}
.detail-main .d-section{margin:0 0 26px}
.detail-aside{position:sticky;top:92px}
@media(max-width:920px){.detail-grid{grid-template-columns:1fr}.detail-aside{position:static}}

.d-section h3{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;
  color:var(--cyan-dim);margin:0 0 13px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.mini-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.mini-grid-4{grid-template-columns:1fr 1fr}
.mini-stat{padding:13px 14px}
.mini-stat .v{font-family:var(--display);font-size:18px;font-weight:600;color:var(--txt)}
.mini-stat .l{font-family:var(--mono);font-size:10px;color:var(--muted);margin-top:5px;text-transform:uppercase;letter-spacing:.06em}

.lever-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.lever-list li{background:var(--panel);border:1px solid var(--line);border-left:2px solid var(--amber-dim);
  border-radius:var(--radius);padding:11px 13px;font-size:12.5px;line-height:1.55;display:flex;gap:10px}
.lever-list li::before{content:'▸';color:var(--amber);flex:none}

.supplier-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-top:1px solid var(--line);font-size:12.5px}
.supplier-row:first-child{border-top:0}
.supplier-row .s-name{flex:1;font-weight:600}
.supplier-row .s-track{width:120px;height:9px;background:#060b11;border:1px solid var(--bezel);border-radius:3px;overflow:hidden}
.supplier-row .s-fill{background:var(--cyan);box-shadow:0 0 8px var(--cyan)}
.supplier-row .s-val{width:46px;text-align:right;color:var(--amber);font-family:var(--mono)}
.supplier-row .s-note{flex-basis:100%;color:var(--muted-2);font-size:11px;font-family:var(--mono)}

/* ---------- Simulateur ---------- */
.sim{padding:18px;border-color:var(--cyan-dim) !important;
  box-shadow:inset 0 0 30px rgba(46,212,126,.06),0 0 0 1px rgba(46,212,126,.06),0 6px 20px rgba(0,0,0,.4) !important}
.sim h3{font-family:var(--display);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;
  color:var(--cyan);margin:0 0 6px;border:0;padding:0}
.sim label{display:flex;justify-content:space-between;font-family:var(--mono);font-size:11.5px;margin:15px 0 8px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.sim label b{color:var(--amber);text-shadow:0 0 8px rgba(252,209,22,.4)}
.sim input[type=range]{width:100%;cursor:pointer;-webkit-appearance:none;appearance:none;height:6px;border-radius:3px;
  background:linear-gradient(90deg,var(--cyan-dim),#0a1620);border:1px solid var(--bezel)}
.sim input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;
  background:var(--amber);box-shadow:0 0 10px var(--amber),0 0 0 3px rgba(252,209,22,.2);cursor:pointer}
.sim input[type=range]::-moz-range-thumb{width:16px;height:16px;border:0;border-radius:50%;background:var(--amber);box-shadow:0 0 10px var(--amber)}
.sim-out{margin-top:18px;padding-top:14px;border-top:1px dashed var(--bezel);display:flex;justify-content:space-between;align-items:baseline}
.sim-out .ol{font-family:var(--mono);font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.sim-out .ov{font-family:var(--display);font-size:26px;font-weight:700;color:var(--green);text-shadow:0 0 16px rgba(8,184,94,.45)}
.sim-hint{font-size:11px;color:var(--muted-2);margin-top:9px;line-height:1.6;font-family:var(--mono)}

/* ---------- Objectifs ---------- */
.target-card{padding:16px 18px;margin-bottom:12px}
.target-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;margin-bottom:12px}
.target-head .t-label{font-weight:700;font-size:14px}
.target-head .t-meta{font-family:var(--mono);font-size:11px;color:var(--muted);margin-top:4px}
.target-axis{font-family:var(--mono);font-size:10px;font-weight:400;padding:3px 9px;border-radius:4px;
  text-transform:uppercase;letter-spacing:.06em;border:1px solid currentColor}
.axis-Import{color:var(--red)}
.axis-Export{color:var(--green)}
.prog-wrap{display:flex;align-items:center;gap:14px}
.prog-track{flex:1;height:11px;background:#060b11;border:1px solid var(--bezel);border-radius:4px;overflow:hidden}
.prog-fill{background:linear-gradient(90deg,var(--cyan),var(--green));box-shadow:0 0 10px var(--green);transition:width .3s}
.prog-nums{font-family:var(--mono);font-size:11.5px;color:var(--muted);white-space:nowrap}
.prog-nums b{color:var(--txt)}
.target-controls{display:flex;align-items:center;gap:10px;margin-top:14px;flex-wrap:wrap}
.target-controls label{font-family:var(--mono);font-size:11px;color:var(--muted);text-transform:uppercase}
.target-controls input[type=range]{flex:1;min-width:160px;-webkit-appearance:none;appearance:none;height:6px;border-radius:3px;
  background:linear-gradient(90deg,var(--green-dim),#0a1620);border:1px solid var(--bezel)}
.target-controls input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--green);box-shadow:0 0 10px var(--green);cursor:pointer}
.target-controls input[type=range]::-moz-range-thumb{width:16px;height:16px;border:0;border-radius:50%;background:var(--green)}
.target-controls .cur-val{font-family:var(--display);font-size:14px;font-weight:600;color:var(--green);width:74px;text-align:right}

/* ---------- Production : rôles ---------- */
.role-tag{font-family:var(--mono);font-size:10px;letter-spacing:.06em;padding:3px 8px;border-radius:4px;
  border:1px solid currentColor;text-transform:uppercase}
.role-NOURRIR{color:var(--green)}
.role-SUBSTITUER{color:var(--red)}
.role-STABILISER{color:var(--cyan)}
.axis-Production{color:var(--amber)}

/* ---------- Risques : panneau d'alarmes ---------- */
.risk-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px}
.risk-card{background:var(--panel);border:1px solid var(--bezel);border-radius:var(--radius);padding:14px 16px;
  border-left-width:3px;box-shadow:inset 0 0 20px rgba(0,0,0,.3)}
.risk-card.risk-hi{border-left-color:var(--red)}
.risk-card.risk-md{border-left-color:var(--amber)}
.risk-card.risk-lo{border-left-color:var(--green)}
.risk-head{display:flex;align-items:center;gap:9px;margin-bottom:7px}
.risk-led{width:9px;height:9px;border-radius:50%;flex:none}
.risk-hi .risk-led{background:var(--red);box-shadow:0 0 10px var(--red);animation:annun 1.3s infinite}
.risk-md .risk-led{background:var(--amber);box-shadow:0 0 10px var(--amber)}
.risk-lo .risk-led{background:var(--green);box-shadow:0 0 10px var(--green)}
.risk-name{font-weight:700;font-size:13px;flex:1;color:#e7f1fa}
.risk-prob{font-family:var(--mono);font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;
  border:1px solid var(--bezel);padding:2px 7px;border-radius:4px}
.risk-domain{font-family:var(--mono);font-size:10.5px;color:var(--cyan-dim);text-transform:uppercase;letter-spacing:.06em;margin-bottom:9px}
.risk-mit{font-size:12px;line-height:1.55;color:var(--muted)}
.risk-mit b{color:var(--txt)}

.redline{display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-top:1px solid var(--line)}
.redline:first-of-type{border-top:0}
.rl-num{font-family:var(--display);font-size:20px;font-weight:800;color:var(--red);
  text-shadow:0 0 12px rgba(236,28,46,.45);min-width:38px}
.rl-body{flex:1}
.rl-err{font-weight:700;font-size:13.5px;color:#f4dada}
.rl-cons{font-family:var(--mono);font-size:11.5px;color:var(--muted);margin-top:4px}

/* ---------- Climat & territoires ---------- */
.terr-map{display:flex;flex-direction:column;gap:8px;margin-top:6px}
.terr-band{background:linear-gradient(90deg,color-mix(in srgb,var(--c) 12%,var(--panel)),var(--panel));
  border:1px solid var(--bezel);border-left:4px solid var(--c);border-radius:var(--radius);padding:14px 18px}
.terr-head{display:flex;justify-content:space-between;align-items:baseline;gap:12px}
.terr-name{font-family:var(--display);font-size:16px;font-weight:700;color:var(--c);
  text-shadow:0 0 12px color-mix(in srgb,var(--c) 40%,transparent)}
.terr-rain{font-family:var(--mono);font-size:12px;color:var(--cyan)}
.terr-clim{font-family:var(--mono);font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-top:3px}
.terr-dept{font-size:11.5px;color:var(--muted-2);margin:6px 0}
.terr-vocation{font-weight:600;font-size:13px;color:#e7f1fa;margin-bottom:9px}
.terr-crops{display:flex;flex-wrap:wrap;margin-bottom:8px}
.terr-note{font-size:11.5px;color:var(--muted);line-height:1.55;border-top:1px dashed var(--bezel);padding-top:8px}

/* ---- Carte interactive du Bénin ---- */
.terr-mapwrap{display:grid;grid-template-columns:minmax(170px,240px) 1fr;gap:24px;align-items:center;margin-top:8px}
@media(max-width:760px){.terr-mapwrap{grid-template-columns:1fr;gap:16px}}
.terr-mapcol{display:flex;justify-content:center}
.benin-svg{width:100%;max-width:240px;height:auto;filter:drop-shadow(0 8px 22px rgba(0,0,0,.55))}
.benin-outline{fill:none;stroke:var(--bezel-hi);stroke-width:2.5;filter:drop-shadow(0 0 6px rgba(46,212,126,.3))}
.terr-zone{opacity:.32;cursor:pointer;transition:.18s;stroke:#04070c;stroke-width:1}
.terr-zone:hover{opacity:.7}
.terr-div{stroke:#04070c;stroke-width:2;opacity:.55}
.tz-name{font-family:var(--display);font-weight:800;font-size:14px;letter-spacing:.05em;pointer-events:none;
  paint-order:stroke;stroke:rgba(4,7,12,.85);stroke-width:3px}
.tz-rain{font-family:var(--mono);font-size:8.5px;fill:var(--txt);opacity:.9;pointer-events:none;
  paint-order:stroke;stroke:rgba(4,7,12,.85);stroke-width:2.5px}
.tz-hint{font-family:var(--mono);font-size:7.5px;fill:var(--cyan);letter-spacing:.12em;text-transform:uppercase;pointer-events:none}
.terr-legend{display:flex;flex-direction:column;gap:10px}
.terr-legrow{display:flex;gap:12px;align-items:flex-start;text-align:left;cursor:pointer;font-family:inherit;
  background:var(--panel);border:1px solid var(--bezel);border-left:3px solid var(--c);border-radius:var(--radius);
  padding:12px 14px;transition:.15s}
.terr-legrow:hover{border-color:var(--c);box-shadow:0 0 14px -2px var(--c);transform:translateX(2px)}
.tl-band{width:8px;align-self:stretch;min-height:38px;border-radius:3px;flex:none;background:var(--c);box-shadow:0 0 9px var(--c)}
.tl-body{display:flex;flex-direction:column;gap:3px;min-width:0}
.tl-name{font-family:var(--display);font-size:14px;font-weight:700;color:var(--c)}
.tl-voc{font-size:12px;color:#e7f1fa;line-height:1.4}
.tl-meta{font-family:var(--mono);font-size:10.5px;color:var(--muted)}

/* ---- Acteurs & sociétés ---- */
.actor-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(238px,1fr));gap:10px;margin-top:8px}
.actor-card{background:var(--panel);border:1px solid var(--bezel);border-left:3px solid var(--c);
  border-radius:var(--radius);padding:12px 14px;transition:.14s}
.actor-card:hover{border-left-color:var(--c);box-shadow:0 0 13px -3px var(--c);transform:translateY(-1px)}
.ac-head{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.ac-name{font-weight:700;font-size:13.5px;color:#e7f1fa}
.ac-country{font-family:var(--mono);font-size:9.5px;color:var(--c);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}
.ac-role{font-size:12px;color:var(--muted);line-height:1.5;margin:5px 0 7px}
.ac-prod{font-size:11.5px;color:var(--txt)}
.ac-lbl{font-family:var(--mono);font-size:9px;text-transform:uppercase;letter-spacing:.06em;color:var(--cyan-dim);margin-right:4px}

/* ---- Infrastructures : widgets groupés par priorité ---- */
.infra-group{margin-bottom:16px}
.infra-group:last-child{margin-bottom:0}
.infra-group-head{display:flex;align-items:center;gap:9px;font-family:var(--display);font-size:12px;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;color:var(--c);margin:14px 0 11px;
  text-shadow:0 0 12px color-mix(in srgb,var(--c) 45%,transparent)}
.igh-count{font-family:var(--mono);font-size:10px;color:var(--muted);border:1px solid var(--bezel);border-radius:10px;padding:1px 8px}
.infra-wgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(252px,1fr));gap:12px}
.infra-widget{background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--bezel);
  border-top:3px solid var(--c);border-radius:var(--radius);padding:14px 16px;text-align:left;font-family:inherit;
  color:inherit;cursor:pointer;display:flex;flex-direction:column;gap:7px;box-shadow:inset 0 0 20px rgba(0,0,0,.3);transition:.15s}
.infra-widget:hover{transform:translateY(-2px);box-shadow:0 0 16px -3px var(--c),inset 0 0 20px rgba(0,0,0,.3)}
.iw-top{display:flex;justify-content:space-between;align-items:center;gap:8px}
.iw-stars{font-family:var(--mono);font-size:12px;letter-spacing:1px}
.iw-cap{font-family:var(--mono);font-size:9px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}
.iw-name{font-family:var(--display);font-size:14px;font-weight:700;color:#eef5fc;line-height:1.2}
.iw-impact{font-size:11.5px;color:var(--muted);font-family:var(--mono)}
.iw-note{font-size:11.5px;color:var(--muted-2);line-height:1.5;border-top:1px dashed var(--bezel);padding-top:8px;flex:1}
.iw-horizon{font-family:var(--mono);font-size:9.5px;color:var(--c);text-transform:uppercase;letter-spacing:.06em}

/* ---------- Gouvernance & données ---------- */
.gov-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:6px}
@media(max-width:820px){.gov-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.gov-grid{grid-template-columns:1fr}}
.gov-domain{background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--bezel);
  border-top:3px solid var(--c);border-radius:var(--radius);padding:14px 16px;position:relative;box-shadow:inset 0 0 20px rgba(0,0,0,.3)}
.gov-dot{position:absolute;top:14px;right:14px;width:8px;height:8px;border-radius:50%;background:var(--c);box-shadow:0 0 9px var(--c)}
.gov-dname{font-family:var(--display);font-size:14px;font-weight:600;color:var(--c)}
.gov-dfocus{font-family:var(--mono);font-size:11px;color:var(--txt);margin:6px 0 6px;text-transform:uppercase;letter-spacing:.04em}
.gov-ddetail{font-size:11.5px;color:var(--muted);line-height:1.55}

/* ---------- Financement ---------- */
.fin-ladder{display:flex;align-items:stretch;gap:8px;margin-top:6px;flex-wrap:wrap}
.fin-step{flex:1;min-width:200px;background:linear-gradient(180deg,var(--panel-2),var(--panel));
  border:1px solid var(--bezel);border-left:3px solid var(--c);border-radius:var(--radius);padding:16px 18px;
  box-shadow:inset 0 0 22px rgba(0,0,0,.3)}
.fin-amount{font-family:var(--display);font-size:24px;font-weight:800;text-shadow:0 0 14px color-mix(in srgb,var(--c) 45%,transparent)}
.fin-phase{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--txt);margin:4px 0 8px}
.fin-instr{font-size:12px;color:var(--muted);line-height:1.55}
.fin-up{display:flex;align-items:center;font-family:var(--display);font-size:22px;color:var(--cyan);text-shadow:0 0 12px var(--cyan)}
@media(max-width:820px){.fin-up{transform:rotate(90deg)}.fin-step{min-width:140px}}
.fin-instr-row{display:flex;gap:13px;align-items:flex-start;padding:13px 0;border-top:1px solid var(--line)}
.fin-instr-row:first-of-type{border-top:0}
.fin-ico{color:var(--cyan);font-size:13px;margin-top:2px;text-shadow:0 0 8px var(--cyan);flex:none}
.fin-iname{font-weight:700;font-size:13.5px;color:#e7f1fa;margin-bottom:3px}
.fin-idesc{font-size:12px;color:var(--muted);line-height:1.6}
.fin-dfi-row{display:grid;grid-template-columns:1fr auto;gap:2px 12px;padding:10px 0;border-top:1px solid var(--line)}
.fin-dfi-row:first-of-type{border-top:0}
.fin-dfi-name{font-weight:700;font-size:12.5px;color:#e7f1fa}
.fin-dfi-ticket{font-family:var(--mono);font-size:12px;color:var(--amber);text-align:right}
.fin-dfi-note{grid-column:1/-1;font-size:11px;color:var(--muted);font-family:var(--mono)}

/* ---------- Roadmap / timeline ---------- */
.horizon-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:18px}
@media(max-width:920px){.horizon-grid{grid-template-columns:1fr}}
.horizon-col{border-top:3px solid var(--c,var(--cyan));display:flex;flex-direction:column}
.horizon-tag{font-family:var(--mono);font-size:10px;letter-spacing:.12em;color:var(--c);border:1px solid currentColor;
  padding:3px 9px;border-radius:4px;text-shadow:0 0 8px color-mix(in srgb,var(--c) 50%,transparent)}
.horizon-head h2{font-size:17px}
.tl-rail{position:relative;margin:16px 0 14px;padding-left:8px}
.tl-rail::before{content:'';position:absolute;left:11px;top:6px;bottom:6px;width:2px;
  background:linear-gradient(var(--c,var(--cyan)),transparent)}
.tl-step{display:flex;gap:13px;padding:7px 0;position:relative}
.tl-dot{width:9px;height:9px;border-radius:50%;background:var(--c,var(--cyan));margin-top:5px;flex:none;
  box-shadow:0 0 9px var(--c,var(--cyan));z-index:1}
.tl-period{font-family:var(--mono);font-size:10.5px;color:var(--amber);letter-spacing:.04em}
.tl-label{font-weight:700;font-size:13px;color:#e7f1fa;margin-top:1px}
.tl-sub{font-size:11.5px;color:var(--muted);line-height:1.5;margin-top:2px}
.horizon-deliv{margin-top:auto;padding-top:12px;border-top:1px dashed var(--bezel);font-size:11.5px;
  color:var(--muted);line-height:1.6}
.horizon-deliv b{color:var(--cyan)}

/* ---------- Écran de chargement ---------- */
.boot-splash{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:120px 20px;text-align:center}
.boot-ring{width:64px;height:64px;border-radius:50%;border:4px solid var(--bezel);border-top-color:var(--amber);
  box-shadow:0 0 18px rgba(252,209,22,.3);animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.boot-txt{font-family:var(--display);font-size:15px;letter-spacing:.12em;color:var(--amber);text-shadow:var(--glow-amber)}
.boot-sub{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.06em}

/* ---------- Marchés ---------- */
.market-card{border-top:3px solid var(--c,var(--cyan))}
.market-head{display:flex;justify-content:space-between;align-items:flex-start;gap:18px}
.market-head h2{font-size:16px}
.market-pot{text-align:right;flex:none}
.mp-val{font-family:var(--display);font-size:26px;font-weight:800;text-shadow:0 0 14px color-mix(in srgb,var(--c) 45%,transparent)}
.mp-lbl{font-family:var(--mono);font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.market-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:18px}
@media(max-width:760px){.market-grid{grid-template-columns:1fr}}
.mk-h{font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--cyan-dim);margin:0 0 9px}

/* ---------- Synoptique 3 piliers ---------- */
.pillar-flow{display:flex;align-items:stretch;gap:10px;margin-top:6px;flex-wrap:wrap}
.pillar-station{flex:1;min-width:200px;background:linear-gradient(180deg,var(--panel-2),var(--panel));
  border:1px solid var(--bezel);border-top:3px solid var(--c,var(--cyan));border-radius:var(--radius);
  padding:16px 18px;cursor:pointer;text-align:left;font-family:inherit;display:flex;flex-direction:column;gap:3px;
  transition:.16s;box-shadow:inset 0 0 22px rgba(0,0,0,.3)}
.pillar-station:hover{box-shadow:0 0 18px -2px var(--c),inset 0 0 22px rgba(0,0,0,.3);transform:translateY(-2px)}
.ps-num{font-family:var(--mono);font-size:11px;color:var(--muted-2)}
.ps-title{font-family:var(--display);font-size:15px;font-weight:700;color:var(--c);letter-spacing:.02em;
  text-shadow:0 0 12px color-mix(in srgb,var(--c) 45%,transparent)}
.ps-desc{font-size:12px;color:var(--muted);margin-bottom:8px}
.ps-stat{font-family:var(--display);font-size:22px;font-weight:800;color:#eef5fc}
.ps-sub{font-family:var(--mono);font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.pillar-arrow{display:flex;align-items:center;font-family:var(--display);font-size:24px;color:var(--cyan);
  text-shadow:0 0 12px var(--cyan);align-self:center}
@media(max-width:820px){.pillar-arrow{transform:rotate(90deg)};.pillar-station{min-width:140px}}

/* ---------- Liens système ---------- */
.link-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}
.link-card{display:flex;flex-direction:column;gap:6px;align-items:flex-start;text-align:left;cursor:pointer;
  background:var(--panel);border:1px solid var(--bezel);border-radius:var(--radius);padding:12px 14px;
  font-family:inherit;transition:.15s}
.link-card:hover{border-color:var(--cyan);box-shadow:0 0 14px rgba(46,212,126,.18);transform:translateY(-1px)}
.link-kind{font-family:var(--mono);font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;padding:2px 7px;
  border-radius:4px;border:1px solid currentColor}
.link-production{color:var(--amber)}.link-imports{color:var(--red)}.link-exports{color:var(--green)}.link-infra{color:var(--cyan)}
.link-markets{color:var(--cyan)}.link-risks{color:var(--red)}.link-targets{color:var(--violet)}
.link-financing{color:var(--green)}.link-roadmap{color:var(--cyan)}.link-governance{color:var(--violet)}.link-territories{color:var(--cyan)}.link-actors{color:var(--amber)}
.link-name{font-weight:700;font-size:13px;color:#e7f1fa}
.link-why{font-family:var(--mono);font-size:10.5px;color:var(--muted);line-height:1.4}

/* ---------- divers ---------- */
.flex{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.spacer{height:8px}
.empty{padding:40px;text-align:center;color:var(--muted);font-family:var(--mono)}
.callout{padding:14px 18px;font-size:12.5px;line-height:1.7;color:#d9e6f2;margin-bottom:22px;
  border-left:3px solid var(--amber) !important}
.callout b{color:var(--amber)}

/* infra */
.infra-item{display:grid;grid-template-columns:1fr auto;gap:8px 16px;align-items:center;padding:15px 10px;border-top:1px solid var(--line);margin:0 -10px}
.infra-item:first-child{border-top:0}
.infra-name{font-weight:700;font-size:13.5px;color:#e7f1fa}
.infra-impact{color:var(--muted);font-size:12px;margin-top:3px;font-family:var(--mono)}
.infra-note{grid-column:1/-1;color:var(--muted-2);font-size:11.5px;line-height:1.6;font-family:var(--mono)}
.stars{font-family:var(--mono);font-size:12px;letter-spacing:1px}
.horizon{font-family:var(--mono);font-size:10px;color:var(--muted);text-align:right;margin-top:3px;text-transform:uppercase;letter-spacing:.05em}

/* clic */
.clickable{cursor:pointer;transition:.12s;border-radius:var(--radius)}
.clickable:hover{background:linear-gradient(90deg,rgba(46,212,126,.06),transparent)}
.chev{color:var(--muted-2);font-weight:400;transition:.15s}
.clickable:hover .chev{color:var(--amber);text-shadow:0 0 8px var(--amber)}
/* cartes-objets devenues boutons (risques, domaines gouvernance) */
button.risk-card,button.gov-domain{font-family:inherit;text-align:left;width:100%;color:inherit}
button.risk-card.clickable:hover{background:var(--panel);transform:translateY(-2px)}
button.gov-domain.clickable:hover{background:linear-gradient(180deg,var(--panel-2),var(--panel));transform:translateY(-2px)}
tbody tr[data-id] td:first-child .prod-cell::after{content:'›';color:var(--muted-2);margin-left:auto;padding-left:10px;font-weight:700;opacity:0;transition:.12s}
tbody tr[data-id]:hover td:first-child .prod-cell::after{opacity:1;color:var(--amber)}

@media(max-width:760px){
  body{grid-template-columns:1fr}
  .sidebar{position:static;height:auto;flex-direction:row;align-items:center;overflow-x:auto;padding:10px}
  .nav{flex-direction:row}.sidebar-foot,.sys-status{display:none}.brand{border:0;padding-bottom:0}
  #search{width:130px}.main{padding:0 16px 50px}
}
