/* =========================================================================
   COCKPIT OTAWEB — outil de travail interne (tour de contrôle).
   Registre : sobre, pro, intuitif. Référence : Linear / Stripe / Vercel.
   La clarté EST le luxe : profondeur par la hiérarchie et l'espace,
   jamais par des effets lumineux. Fond OLED calme, séparations nettes,
   accent BLEU (liens/actif/sélection), ROUGE en signal fonctionnel seul.
   Une seule famille de police (system-ui) pour toute la data.
   ========================================================================= */

:root{
  /* --- Surfaces OLED (calme, plat-mais-pas-mort : 4 paliers d'élévation) --- */
  --oled:    #0a0c12;          /* fond de l'app */
  --void:    #070910;          /* zones en retrait (rail/topbar) */
  --card:    #11131b;          /* cartes / panneaux */
  --card-2:  #161924;          /* survol / élévation */
  --line:    rgba(255,255,255,.07);   /* séparations discrètes */
  --line-2:  rgba(255,255,255,.13);   /* séparations marquées / bordure survol */

  /* --- Texte & couleur --- */
  --white:   #eef1f7;          /* texte principal */
  --mute:    #b3b9c7;          /* texte secondaire */
  --faint:   #8a90a0;          /* labels discrets — AA sur OLED */
  --blue:    #4c7dff;          /* accent : liens, actif, sélection */
  --blue-lo: #87a4ff;          /* bleu clair (texte accentué) */
  --blue-bg: rgba(76,125,255,.12);
  --red:     #ff5a63;          /* signal fonctionnel : alerte / échéance critique */
  --red-bg:  rgba(255,90,99,.10);
  --ok:      #3fc98a;          /* santé / live */
  --ok-bg:   rgba(63,201,138,.10);
  --idle:    #6f7689;          /* veille / programmé */

  /* --- Motion : micro-interactions utiles seulement (états, ≤150ms) --- */
  --ease: cubic-bezier(.2,.8,.3,1);
  --t: .14s;

  /* --- Formes --- */
  --r:7px; --r-lg:11px; --r-pill:40px;

  /* --- Layout & rythme vertical unique --- */
  --rail-w: 248px;
  --top-h: 60px;
  --pad: clamp(18px,3vw,36px);
  --gap: clamp(14px,1.6vw,20px);
  --maxw: 1460px;

  /* --- Police UI unique : claire, neutre, native (zéro chargement) --- */
  --ui: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Inter, system-ui, sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
body{
  font-family:var(--ui);
  background:var(--oled); color:var(--white);
  -webkit-font-smoothing:antialiased; line-height:1.5;
  min-height:100vh; overflow-x:hidden;
  font-size:15px;
}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
a{color:inherit;text-decoration:none}
svg{display:block}
sup{font-size:.6em;vertical-align:.45em;font-weight:inherit}
small{font-size:.6em;font-weight:600;color:var(--mute)}

::selection{background:var(--blue-bg);color:var(--white)}
:focus-visible{outline:2px solid var(--blue);outline-offset:2px;border-radius:4px}

.sprite{position:absolute}
/* largeurs de barres de progression (valeurs maquette, pas d'inline-style) */
.w-12{width:12%}.w-38{width:38%}.w-60{width:60%}.w-100{width:100%}

.skip{position:fixed;left:-999px;top:0;z-index:300;background:var(--blue);color:#fff;
  padding:.7rem 1.1rem;border-radius:var(--r);font-size:.85rem;font-weight:600}
.skip:focus{left:1rem;top:1rem}

/* un seul "display" toléré : le titre de pan reste en police UI mais bold/serré */
.display{font-weight:650;letter-spacing:-.02em}
.kicker{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--faint);font-weight:600;display:inline-block}

/* =========================================================================
   SHELL — rail + topbar + vue (le fond reste calme : pas de couche animée)
   ========================================================================= */
.shell{display:grid;grid-template-columns:var(--rail-w) 1fr;
  grid-template-rows:var(--top-h) 1fr;grid-template-areas:"rail top" "rail view";
  min-height:100vh;min-height:100dvh}

/* ---------- RAIL (sidebar) ---------- */
.rail{grid-area:rail;position:sticky;top:0;height:100vh;height:100dvh;
  display:flex;flex-direction:column;
  padding:18px 12px;border-right:1px solid var(--line);
  background:var(--void);z-index:40}

.rail__brand{display:flex;align-items:center;gap:11px;padding:6px 10px 20px}
.rail__mark{color:var(--blue);flex:0 0 auto}
.rail__word{font-weight:700;font-size:1.02rem;letter-spacing:.06em;line-height:1;
  display:flex;flex-direction:column;gap:4px;color:var(--mute)}
.rail__word b{color:var(--white);font-weight:700}
.rail__word em{font-style:normal;font-size:.54rem;letter-spacing:.28em;
  text-transform:uppercase;color:var(--faint);font-weight:600}

.rail__nav{display:flex;flex-direction:column;gap:2px;margin-top:4px}
.nav-item{display:flex;align-items:center;gap:12px;width:100%;text-align:left;
  padding:10px 12px;border-radius:var(--r);color:var(--mute);font-size:.9rem;font-weight:500;
  position:relative;transition:color var(--t) var(--ease),background var(--t) var(--ease)}
.nav-item svg{width:19px;height:19px;flex:0 0 auto;opacity:.8;transition:opacity var(--t)}
.nav-item span{flex:1}
.nav-item:hover{color:var(--white);background:var(--card)}
.nav-item:hover svg{opacity:1}
.nav-item.is-active{color:var(--white);background:var(--card-2)}
.nav-item.is-active svg{opacity:1;color:var(--blue-lo)}
/* repère d'item actif : filet bleu net, sans glow */
.nav-item.is-active::before{content:"";position:absolute;left:-12px;top:8px;bottom:8px;width:3px;
  border-radius:0 3px 3px 0;background:var(--blue)}
.nav-item__count{font-style:normal;font-size:.72rem;font-weight:600;
  min-width:20px;height:20px;display:grid;place-items:center;padding:0 6px;border-radius:6px;
  background:var(--card-2);color:var(--mute);font-variant-numeric:tabular-nums}
.nav-item.is-active .nav-item__count{color:var(--white);background:var(--blue-bg)}
.nav-item__soon{font-style:normal;font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--faint);border:1px solid var(--line-2);border-radius:5px;padding:2px 6px}
.nav-item--soon{opacity:.65}

.rail__foot{margin-top:auto;padding-top:14px;border-top:1px solid var(--line)}
.pilot{display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;gap:0 11px;
  align-items:center;padding:8px 10px}
.pilot__dot{grid-row:1 / span 2;width:32px;height:32px;border-radius:50%;
  background:var(--blue);display:grid;place-items:center;color:#fff;font-weight:700;font-size:.82rem}
.pilot__dot::before{content:"R"}
.pilot__name{font-weight:600;font-size:.9rem;color:var(--white)}
.pilot__role{font-size:.68rem;color:var(--faint)}

/* ---------- TOPBAR ---------- */
.topbar{grid-area:top;position:sticky;top:0;z-index:35;
  display:flex;align-items:center;gap:16px;padding:0 var(--pad);
  border-bottom:1px solid var(--line);background:var(--void)}
.topbar__menu{display:none;width:38px;height:38px;border-radius:var(--r);color:var(--mute);
  align-items:center;justify-content:center;transition:background var(--t),color var(--t)}
.topbar__menu svg{width:21px;height:21px}
.topbar__menu:hover{background:var(--card);color:var(--white)}
.topbar__crumb{display:flex;align-items:center;gap:8px;font-size:.84rem}
.topbar__sys{color:var(--faint)}
.topbar__chev{width:14px;height:14px;color:var(--faint)}
.topbar__here{color:var(--white);font-weight:600}
.topbar__right{margin-left:auto;display:flex;align-items:center;gap:16px}
.health{display:flex;align-items:center;gap:8px;font-size:.78rem;color:var(--mute);
  padding:6px 12px;border:1px solid var(--line);border-radius:var(--r-pill)}
.health__pulse{width:7px;height:7px;border-radius:50%;background:var(--ok);flex:0 0 auto}
.topbar__clock{font-size:.84rem;font-weight:500;color:var(--mute);
  letter-spacing:.02em;font-variant-numeric:tabular-nums}

/* ---------- VUE ---------- */
.view{grid-area:view;padding:var(--pad);outline:none;max-width:var(--maxw);width:100%}
.pan{display:flex;flex-direction:column;gap:var(--gap)}
.pan[hidden]{display:none}

/* =========================================================================
   PAN HEAD (en-tête de chaque vue)
   ========================================================================= */
.pan-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;
  flex-wrap:wrap;padding-bottom:4px}
.pan-head__title{font-size:clamp(1.7rem,3.4vw,2.3rem);line-height:1.1;margin:.3rem 0 .45rem}
.pan-head__sub{color:var(--mute);max-width:64ch;font-size:.92rem}
.pan-head__meta{display:flex;flex-direction:column;align-items:flex-end;gap:8px}
.pan-head__since{font-size:.74rem;color:var(--faint)}

/* chips d'état */
.chip{display:inline-flex;align-items:center;gap:7px;font-size:.68rem;
  font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:5px 10px;border-radius:var(--r-pill);
  border:1px solid var(--line-2);color:var(--mute)}
.chip i{width:7px;height:7px;border-radius:50%;flex:0 0 auto}
.chip--live{color:var(--blue-lo);border-color:rgba(76,125,255,.3);background:var(--blue-bg)}
.chip--live i{background:var(--blue)}
.chip--ok{color:var(--ok);border-color:rgba(63,201,138,.28);background:var(--ok-bg)}
.chip--ok i{background:var(--ok)}

/* dots d'état réutilisables (plats, sans glow) */
.dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex:0 0 auto}
.dot--ok{background:var(--ok)}
.dot--run{background:var(--blue)}
.dot--idle{background:var(--idle)}

/* =========================================================================
   KPI CARDS
   ========================================================================= */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap)}
.kpi{padding:18px 18px 16px;border-radius:var(--r-lg);
  border:1px solid var(--line);background:var(--card);
  transition:border-color var(--t) var(--ease),background var(--t) var(--ease)}
.kpi:hover{border-color:var(--line-2);background:var(--card-2)}
.kpi__label{display:block;font-size:.72rem;letter-spacing:.02em;
  color:var(--faint);text-transform:uppercase;font-weight:600}
.kpi__value{display:block;font-weight:650;font-size:2.3rem;line-height:1;
  margin:.55rem 0 .5rem;color:var(--white);font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.kpi__value--blue{color:var(--blue-lo)}
.kpi__value--muted{color:var(--idle)}
.kpi__foot{font-size:.76rem;color:var(--mute);display:flex;align-items:center;gap:7px}

/* =========================================================================
   PANELS (panneaux génériques)
   ========================================================================= */
.grid-2{display:grid;grid-template-columns:1.7fr 1fr;gap:var(--gap);align-items:start}
.panel{border:1px solid var(--line);border-radius:var(--r-lg);background:var(--card);
  padding:18px;display:flex;flex-direction:column;gap:14px}
.panel__head{display:flex;justify-content:space-between;align-items:baseline;gap:12px;
  padding-bottom:13px;border-bottom:1px solid var(--line)}
.panel__title{font-size:1rem;font-weight:600;letter-spacing:-.01em}
.panel__hint{font-size:.72rem;color:var(--faint)}
.panel__foot{margin-top:auto;display:flex;align-items:center;gap:9px;padding-top:13px;
  border-top:1px solid var(--line);font-size:.76rem;color:var(--faint)}
.panel__foot b{color:var(--mute);font-weight:600}

/* =========================================================================
   ARBRE DE L'EMPIRE
   ========================================================================= */
.tree{display:flex;flex-direction:column;gap:13px}
.node__face{display:flex;align-items:center;gap:13px;padding:12px 14px;border-radius:var(--r);
  border:1px solid var(--line);background:var(--void);
  transition:border-color var(--t) var(--ease),background var(--t) var(--ease)}
.node__face:hover{border-color:var(--line-2);background:var(--card-2)}
.node--company > .node__face{border-color:rgba(76,125,255,.2);background:var(--blue-bg)}
.node__icon{width:34px;height:34px;border-radius:8px;display:grid;place-items:center;flex:0 0 auto;
  background:var(--blue-bg);color:var(--blue-lo)}
.node__icon svg{width:18px;height:18px}
.node__avatar{width:34px;height:34px;border-radius:8px;flex:0 0 auto;display:grid;place-items:center;
  font-weight:700;font-size:.8rem;color:var(--white);
  background:var(--card-2);border:1px solid var(--line-2)}
.node__avatar--lg{width:46px;height:46px;font-size:1rem;border-radius:11px}
.node__body{flex:1;min-width:0}
.node__name{display:block;font-weight:600;font-size:.94rem;color:var(--white)}
.node__owner{color:var(--mute);font-weight:400}
.node__tag{display:block;font-size:.76rem;color:var(--faint);margin-top:1px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* indentation des branches avec filet de connexion */
.branch{position:relative;margin-left:17px;padding-left:22px;margin-top:12px;
  display:flex;flex-direction:column;gap:11px}
.branch::before{content:"";position:absolute;left:0;top:-12px;bottom:14px;width:1px;background:var(--line-2)}
.branch > .node::before,.branch > .leaf::before{content:"";position:absolute;left:-22px;top:24px;
  width:18px;height:1px;background:var(--line-2)}
.branch > .node,.branch > .leaf{position:relative}
.branch--leaf{margin-top:11px}

.leaf{display:flex;align-items:center;gap:11px;padding:11px 14px;border-radius:var(--r);
  border:1px solid var(--line);background:var(--void);
  transition:border-color var(--t) var(--ease),background var(--t) var(--ease)}
a.leaf:hover{border-color:var(--line-2);background:var(--card-2)}
.leaf__name{font-weight:500;font-size:.88rem;color:var(--white)}
.leaf__meta{flex:1;font-size:.74rem;color:var(--faint);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.leaf__go{width:16px;height:16px;color:var(--faint);flex:0 0 auto;transition:color var(--t)}
a.leaf:hover .leaf__go{color:var(--blue-lo)}
.leaf__state{font-size:.64rem;letter-spacing:.06em;text-transform:uppercase;color:var(--mute);
  border:1px solid var(--line-2);border-radius:var(--r-pill);padding:3px 9px;flex:0 0 auto}

/* carte fantôme (société future) — bouton crédible, discret */
.node-ghost{display:flex;align-items:center;gap:14px;width:100%;text-align:left;
  padding:14px;border-radius:var(--r);border:1px dashed var(--line-2);
  color:var(--faint);transition:border-color var(--t) var(--ease),color var(--t) var(--ease),background var(--t) var(--ease)}
.node-ghost:hover{border-color:rgba(76,125,255,.4);color:var(--blue-lo);background:var(--blue-bg)}
.node-ghost__plus{width:34px;height:34px;border-radius:8px;display:grid;place-items:center;flex:0 0 auto;
  font-size:1.3rem;font-weight:300;border:1px dashed var(--line-2);color:inherit}
.node-ghost__txt{font-weight:500;font-size:.9rem;color:var(--mute)}
.node-ghost:hover .node-ghost__txt{color:var(--blue-lo)}
.node-ghost__hint{margin-left:auto;font-size:.72rem;color:var(--faint)}

/* =========================================================================
   FLOTTE (santé sites)
   ========================================================================= */
.fleet__row{display:flex;align-items:center;gap:12px;padding:6px 0}
.fleet__id{flex:1;min-width:0}
.fleet__name{display:block;font-weight:500;font-size:.86rem;color:var(--white)}
.fleet__sub{font-size:.72rem;color:var(--faint)}
.fleet__metric{display:flex;align-items:center;gap:10px}
.fleet__ms{font-weight:600;font-size:.94rem;color:var(--ok);font-variant-numeric:tabular-nums}
.fleet__ms small{color:var(--ok);opacity:.7}
.fleet__spark{width:64px;height:22px}
.fleet__spark svg{width:100%;height:100%}
.fleet__spark polyline{fill:none;stroke:var(--ok);stroke-width:1.5;opacity:.6;
  vector-effect:non-scaling-stroke;stroke-linejoin:round;stroke-linecap:round}

.mini{display:grid;grid-template-columns:1fr auto;align-items:center;gap:6px 12px;margin-top:2px}
.mini__label{font-size:.76rem;color:var(--mute)}
.mini__val{font-size:.78rem;font-weight:600;color:var(--white);font-variant-numeric:tabular-nums}
.mini__bar{grid-column:1 / -1;height:5px;border-radius:3px;background:var(--card-2);overflow:hidden}
.mini__bar span{display:block;height:100%;border-radius:3px;background:var(--blue)}

/* =========================================================================
   BEACON (signal fonctionnel : prochaine échéance — rouge autorisé ici)
   ========================================================================= */
.beacon{display:flex;align-items:center;gap:16px;padding:16px 20px;border-radius:var(--r-lg);
  border:1px solid rgba(255,90,99,.28);background:var(--red-bg)}
.beacon__spark{width:9px;height:9px;border-radius:50%;flex:0 0 auto;background:var(--red)}
.beacon__txt{flex:1}
.beacon__lead{display:block;font-size:.66rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--red);font-weight:600}
.beacon__main{display:block;font-size:.96rem;color:var(--white);margin-top:3px}
.beacon__main b{color:var(--white);font-weight:700}
.beacon__date{font-weight:700;font-size:1.02rem;letter-spacing:.02em;
  color:var(--white);font-variant-numeric:tabular-nums;flex:0 0 auto}

/* =========================================================================
   PAN CLIENTS
   ========================================================================= */
.clients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--gap)}
.client-card{border:1px solid var(--line);border-radius:var(--r-lg);background:var(--card);padding:20px;
  display:flex;flex-direction:column;gap:6px;transition:border-color var(--t),background var(--t)}
.client-card:hover{border-color:var(--line-2);background:var(--card-2)}
.client-card__top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:6px}
.client-card__name{font-weight:650;font-size:1.3rem;color:var(--white);letter-spacing:-.01em}
.client-card__who{font-size:.82rem;color:var(--mute)}
.client-card__stats{display:grid;grid-template-columns:1fr 1fr;gap:13px 16px;margin-top:14px;
  padding-top:14px;border-top:1px solid var(--line)}
.client-card__stats dt{font-size:.68rem;letter-spacing:.02em;text-transform:uppercase;color:var(--faint);font-weight:600}
.client-card__stats dd{font-weight:600;font-size:.92rem;color:var(--white);margin-top:2px}
.client-card__stats dd.ok{color:var(--ok)}
.client-card--ghost{flex-direction:row;align-items:center;gap:14px;border-style:dashed;justify-content:flex-start;
  border-color:var(--line-2);background:transparent}
.client-card--ghost:hover{border-color:rgba(76,125,255,.4);background:var(--blue-bg)}
.client-card--ghost .node-ghost__hint{margin-left:auto}

/* =========================================================================
   PAN PROJETS
   ========================================================================= */
.board{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:var(--gap)}
.task{border:1px solid var(--line);border-radius:var(--r-lg);background:var(--card);padding:18px 20px 20px;
  display:flex;flex-direction:column;gap:11px;transition:border-color var(--t),background var(--t)}
.task:hover{border-color:var(--line-2);background:var(--card-2)}
.task--meta{border-color:rgba(76,125,255,.2);background:var(--blue-bg)}
.task__head{display:flex;justify-content:space-between;align-items:center;gap:10px}
.task__name{font-weight:600;font-size:1rem;color:var(--white)}
.task__desc{font-size:.82rem;color:var(--mute);line-height:1.5}
.task__bar{height:6px;border-radius:3px;background:var(--card-2);overflow:hidden;margin-top:4px}
.task__bar span{display:block;height:100%;border-radius:3px;background:var(--blue)}
.task__pct{font-size:.72rem;font-weight:600;color:var(--blue-lo);align-self:flex-end;font-variant-numeric:tabular-nums}

.badge{font-size:.62rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  padding:4px 9px;border-radius:5px;border:1px solid var(--line-2);color:var(--mute);flex:0 0 auto}
.badge--build{color:var(--blue-lo);border-color:rgba(76,125,255,.3);background:var(--blue-bg)}
.badge--start{color:var(--idle);border-color:var(--line-2)}
.badge--ok{color:var(--ok);border-color:rgba(63,201,138,.28);background:var(--ok-bg)}
.badge--run{color:var(--blue-lo);border-color:rgba(76,125,255,.26)}

/* =========================================================================
   PAN AGENTS & ROUTINES
   ========================================================================= */
.agents{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.agent{display:flex;flex-direction:column;align-items:center;text-align:center;gap:7px;padding:18px 12px;
  border-radius:var(--r);border:1px solid var(--line);background:var(--void);
  transition:border-color var(--t),background var(--t)}
.agent:hover{border-color:var(--line-2);background:var(--card-2)}
.agent__avatar{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;
  font-weight:700;font-size:.92rem;color:var(--white);
  background:var(--card-2);border:1px solid var(--line-2)}
.agent--core{border-color:rgba(76,125,255,.28);background:var(--blue-bg);
  grid-column:1 / -1;flex-direction:row;justify-content:center;gap:14px;padding:16px}
.agent--core .agent__name,.agent--core .agent__role{text-align:left}
.agent__avatar--core{width:46px;height:46px;font-size:1.1rem;color:#fff;
  background:var(--blue);border:none}
.agent__name{font-weight:600;font-size:.9rem;color:var(--white)}
.agent__role{font-size:.7rem;color:var(--faint)}

.flows{display:flex;flex-direction:column;gap:9px}
.flow{display:flex;align-items:center;gap:13px;padding:12px 15px;border-radius:var(--r);
  border:1px solid var(--line);background:var(--void);transition:border-color var(--t),background var(--t)}
.flow:hover{border-color:var(--line-2);background:var(--card-2)}
.flow__id{flex:1;min-width:0}
.flow__name{display:block;font-weight:500;font-size:.88rem;color:var(--white)}
.flow__sub{font-size:.72rem;color:var(--faint)}
.flow__cad{font-size:.74rem;color:var(--mute);letter-spacing:.01em;flex:0 0 auto}

/* =========================================================================
   STUBS (placeholders honnêtes)
   ========================================================================= */
.stub-note{font-size:.82rem;color:var(--faint);text-align:center;padding:11px;
  border:1px dashed var(--line);border-radius:var(--r);background:var(--void)}
.stub-note b{color:var(--blue-lo);font-weight:600}

/* PAN CHAT */
.pan--chat{min-height:60vh;justify-content:center}
.chat-stub{display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;
  max-width:46ch;margin:0 auto;padding:40px 20px}
.chat-stub__orb{width:64px;height:64px;border-radius:50%;
  background:var(--card-2);border:1px solid var(--line-2);display:grid;place-items:center;color:var(--blue-lo)}
.chat-stub__orb::before{content:"";width:22px;height:22px;border-radius:50%;background:var(--blue);opacity:.55}
.chat-stub__title{font-size:clamp(1.5rem,3.2vw,2.1rem);color:var(--white);letter-spacing:-.01em}
.chat-stub__txt{color:var(--mute);font-size:.92rem}
.chat-stub__soon{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--blue-lo);border:1px solid rgba(76,125,255,.3);border-radius:var(--r-pill);padding:7px 16px;margin-top:4px;font-weight:600}

/* =========================================================================
   RESPONSIVE — mobile-first soigné (même exigence de sobriété)
   ========================================================================= */
@media (max-width:1080px){
  .grid-2{grid-template-columns:1fr}
  .kpis{grid-template-columns:repeat(2,1fr)}
}

@media (max-width:760px){
  :root{--top-h:56px}
  .shell{grid-template-columns:1fr;grid-template-areas:"top" "view"}
  /* rail devient un panneau coulissant */
  .rail{position:fixed;inset:0 auto 0 0;width:min(82vw,300px);transform:translateX(-104%);
    transition:transform var(--t) var(--ease);box-shadow:0 0 40px rgba(0,0,0,.5)}
  .rail.is-open{transform:none}
  .topbar__menu{display:flex}
  /* voile derrière le rail ouvert */
  .rail-scrim{position:fixed;inset:0;z-index:38;background:rgba(2,4,9,.6);opacity:0;visibility:hidden;
    transition:opacity var(--t),visibility var(--t)}
  .rail-scrim.is-open{opacity:1;visibility:visible}
  .health__txt{display:none}
  .health{padding:6px 10px}
  .pan-head{align-items:flex-start}
  .pan-head__meta{align-items:flex-start}
}

@media (max-width:520px){
  .kpis{grid-template-columns:1fr 1fr}
  .kpi__value{font-size:2rem}
  .beacon{flex-direction:column;align-items:flex-start;gap:12px}
  .beacon__date{align-self:flex-start}
  .node__tag,.leaf__meta{white-space:normal}
  .branch{margin-left:8px;padding-left:16px}
  .branch > .node::before,.branch > .leaf::before{width:12px;left:-16px}
  .leaf{flex-wrap:wrap}
  .leaf__meta{flex-basis:100%;order:3}
  .topbar__clock{display:none}
}

/* =========================================================================
   GARDE-FOU — prefers-reduced-motion (les transitions d'état restent triviales)
   ========================================================================= */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{transition-duration:.001ms!important;animation-duration:.001ms!important}
}
