/* ═══════════════════════════════════════════════════════════
 * egis-theme.css — re-skin du viewer panorama au langage visuel
 * de la maquette de référence de Thomas (Use_Cases_Panorama_V2805).
 *
 * Chargé APRÈS tokens.css + viewer.css → surcharge tout.
 * Parti pris : palette teal/lime corporate Egis, Inter, coins
 * arrondis (8/12/16/24) + ombres douces (vs le skin précédent,
 * carré/hairline). Héro dégradé teal sombre, cartes à bord gauche
 * coloré par niveau qui se soulèvent au survol, chips pill.
 *
 * On NE touche qu'à ce fichier : aucune classe inventée, on ne
 * surcharge que des sélecteurs présents dans viewer.html / app.js.
 * ═══════════════════════════════════════════════════════════ */

@import url("https://fonts.googleapis.com/css2?family=Inter:ital,wght@0,400..800;1,400..600&display=swap");

/* ════════════════════════════════════════════
 * TOKENS — palette + radius + shadow + typo (maquette Thomas)
 * On remappe les tokens Otomata consommés par viewer.css/app.js.
 * ════════════════════════════════════════════ */
:root {
  /* palette maquette */
  --primary:        #00617E;
  --primary-dark:   #00465C;
  --primary-darker: #002F3F;
  --accent:         #ABC022;
  --accent-dark:    #8DA01C;

  --bg:      #F0F4F8;
  --bg-alt:  #F7FAFC;
  --card:    #FFFFFF;

  /* niveaux maquette */
  --niv0: #94A3B8;
  --niv1: #10B981;
  --niv2: #3B82F6;
  --niv3: #F59E0B;

  /* radius + ombres */
  --r-sm: 8px; --r-md: 12px; --r-lg: 16px; --r-xl: 24px;
  --shadow-xs: 0 1px 2px rgba(15,23,42,.04);
  --shadow-sm: 0 2px 4px rgba(15,23,42,.06);
  --shadow-md: 0 6px 18px rgba(15,23,42,.08);
  --shadow-lg: 0 16px 48px rgba(15,23,42,.16);

  /* ── remap des tokens Otomata vers la palette froide ── */
  --color-bg:        #F0F4F8;
  --color-paper:     #F0F4F8;
  --color-paper-2:   #EEF3F8;   /* hover doux */
  --color-paper-3:   #E2E8F0;   /* tracks / hover marqué */
  --color-surface:   #FFFFFF;

  --color-ink:       #0F172A;   /* texte fort */
  --color-ink-soft:  #475569;   /* corps */
  --color-mute:      #64748B;   /* méta */
  --color-faint:     #94A3B8;   /* placeholder / désactivé */
  --color-hair:        #E2E8F0; /* bordure */
  --color-hair-soft:   #EDF1F6; /* bordure secondaire */
  --color-hair-classic:#CBD5E1; /* bordure marquée (hover) */

  /* accent marque (consommé par viewer.css : meter, lockup, tabs, drawer…) */
  --egis:       #00617E;
  --egis-ink:   #002F3F;
  --egis-soft:  #CCE0E6;
  --egis-deep:  #002F3F;
  --egis-bright:#ABC022;

  /* remaps sémantiques (niveaux, statuts, diffs) sur la palette maquette */
  --color-cobalt:      #3B82F6; --color-cobalt-ink: #1E3A8A; --color-cobalt-soft:#DBEAFE;
  --color-saffron:     #F59E0B; --color-saffron-ink:#B45309; --color-saffron-soft:#FEF0D5;
  --color-olive:       #10B981; --color-olive-ink: #047857; --color-olive-soft:#D1FAE5;
  --color-terra:       #EF4444; --color-terra-ink: #B91C1C; --color-terra-soft:#FEE2E2;

  --grid-line: rgba(15, 23, 42, 0.025);
  --ring-focus: 2px solid var(--primary);

  /* typo */
  --font-sans:    "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  --font-display: "Inter", system-ui, sans-serif;
}

/* fond plat clair, sans quadrillage (la maquette est unie) */
body { background-image: none; background-color: var(--color-bg); }
html[data-grid="off"] body { background-image: none; }

h1, h2, h3, h4 { text-transform: none; letter-spacing: -0.022em; }
::selection { background: var(--primary); color: #fff; }

/* ════════════════════════════════════════════
 * TOP BAR — bandeau teal profond, sticky conservé
 * ════════════════════════════════════════════ */
.topbar {
  background: var(--primary-darker);
  border-bottom: 0;
  backdrop-filter: none;
  box-shadow: var(--shadow-sm);
}
.topbar .wrap { padding-top: 15px; padding-bottom: 15px; }
.lockup .mark {
  font-family: var(--font-display); font-weight: 800; font-size: 26px;
  letter-spacing: -0.04em; color: #fff;
}
.lockup .cross { color: rgba(255,255,255,.4); font-style: normal; }
.lockup .behr {
  font-family: var(--font-display); font-weight: 800; font-size: 22px;
  letter-spacing: -0.04em; color: var(--accent);
}
.lockup .tag { border-left-color: rgba(255,255,255,.2); }
.lockup .tag b { color: #fff; }
.lockup .tag span { color: rgba(255,255,255,.55); }
.live-pill {
  color: rgba(255,255,255,.78); border-color: rgba(255,255,255,.24);
  border-radius: 999px; white-space: nowrap;
}
.live-dot { background: var(--accent); }
.actor-pill {
  color: rgba(255,255,255,.9); border-color: rgba(255,255,255,.24);
  border-radius: 999px; white-space: nowrap;
}
.actor-pill .av { background: var(--accent); color: var(--primary-darker); font-weight: 800; }

/* nav auth (guide / accès / déconnexion) dans le bandeau */
.topbar-right { display: flex; align-items: center; gap: 14px; }
.tnav {
  font-family: var(--font-sans); font-size: 11.5px; font-weight: 600;
  letter-spacing: 0.04em; text-transform: uppercase; color: rgba(255,255,255,.66);
  border-bottom: 1px solid transparent; padding-bottom: 1px; white-space: nowrap;
}
.tnav:hover { color: #fff; border-bottom-color: var(--accent); }
.tnav.logout { color: rgba(255,255,255,.85); }
@media (max-width: 880px) { .tnav.opt { display: none; } }

/* ════════════════════════════════════════════
 * HERO — dégradé teal sombre (radial + linear), eyebrow lime
 * ════════════════════════════════════════════ */
.hero {
  position: relative; overflow: hidden; color: #fff;
  padding: clamp(40px, 5vw, 64px) 0 clamp(48px, 6vw, 72px);
  background:
    radial-gradient(ellipse at 78% -10%, rgba(171,192,34,.22), transparent 60%),
    radial-gradient(ellipse at -12% 115%, rgba(0,97,126,.55), transparent 60%),
    linear-gradient(135deg, var(--primary-darker) 0%, var(--primary) 68%, var(--primary-dark) 100%);
}
.hero .wrap { position: relative; z-index: 1; }

/* eyebrow → pill lime */
.hero-kick .eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(171,192,34,.20); border: 1px solid rgba(171,192,34,.4);
  color: var(--accent); padding: 7px 15px; border-radius: 999px;
  font-family: var(--font-sans); font-size: 11px; font-weight: 700;
  letter-spacing: 0.08em; text-transform: uppercase;
}
.hero-kick .eyebrow::before {
  content: ''; width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent); box-shadow: 0 0 12px var(--accent);
}
.hero-kick p { color: rgba(255,255,255,.78); font-style: normal; }

.hero h1 { letter-spacing: -0.03em; color: #fff; font-weight: 800; }
.hero h1 .period { color: var(--accent); }
/* la keyline (soulignement) passe en lime sur fond sombre */
.hero h1 .keyline {
  color: var(--accent);
  background-image: none; padding-bottom: 0;
}

/* KPI strip → cartes "verre" arrondies sur le héro sombre */
.kpis {
  margin-top: clamp(26px, 4vw, 40px);
  border: 0; gap: 12px;
  grid-template-columns: 1.5fr 1fr 1fr 1fr 1.1fr;
}
.kpi {
  background: rgba(255,255,255,.08); backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.18); border-radius: var(--r-md);
  padding: 16px 18px;
}
.kpi:first-child { padding-left: 18px; }
.kpi .klabel {
  font-family: var(--font-sans); font-weight: 700; font-size: 11px;
  letter-spacing: 0.06em; text-transform: uppercase; color: rgba(255,255,255,.66);
  margin-bottom: 8px;
}
.kpi .kval { font-family: var(--font-display); font-weight: 800; color: #fff; }
.kpi .kval small { color: rgba(255,255,255,.7); }
.kpi .ksub { color: rgba(255,255,255,.66); font-style: normal; }
.kpi.verrous .kval { color: var(--niv3); }

/* meter d'avancement → lime */
.meter .fill { background: var(--accent); }
.meter .track { background: rgba(255,255,255,.18); }

/* barre de maturité dans le héro */
.nivbar-head .eyebrow {
  background: none; border: 0; padding: 0; color: rgba(255,255,255,.66);
  letter-spacing: 0.06em; text-transform: uppercase; font-weight: 700; white-space: nowrap;
}
.nivbar-head .eyebrow::before { content: none; }
.nivbar-head .hint { color: rgba(255,255,255,.55); }
.nivbar { background: rgba(255,255,255,.18); border-radius: 999px; }
.nivseg {
  background: rgba(255,255,255,.08); color: rgba(255,255,255,.85);
  border: 1px solid rgba(255,255,255,.22); border-radius: 999px;
}
.nivseg:hover { background: rgba(255,255,255,.16); }
.nivseg.active { background: var(--accent); color: var(--primary-darker); border-color: var(--accent); }
.nivseg .nn { font-family: var(--font-sans); opacity: .8; }

/* ════════════════════════════════════════════
 * TABS — soulignement teal épais, casse normale
 * ════════════════════════════════════════════ */
/* onglets = menu dans la topbar, sur sa PROPRE ligne pleine largeur (robuste, ne déborde jamais) */
.topbar .wrap { flex-wrap: wrap; row-gap: 6px; }
.topnav {
  display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
  order: 3; flex-basis: 100%;
  border-bottom: 0 !important;
  border-top: 1px solid rgba(255, 255, 255, .12) !important;
  margin: 4px 0 0 !important; padding: 9px 0 0 !important;
}
.topnav .tab {
  text-transform: none; font-weight: 700; font-family: var(--font-sans);
  color: rgba(255,255,255,.66); font-size: 13px;
  padding: 7px 13px; border-radius: 999px; border: 0; background: none;
}
.topnav .tab::after { display: none !important; }
.topnav .tab:hover { color: #fff; background: rgba(255,255,255,.08); }
.topnav .tab.active { color: #fff; background: rgba(171,192,34,.20); }
.topnav .tab .cnt {
  font-family: var(--font-sans); color: rgba(255,255,255,.5);
  margin-left: 5px; font-size: 11px;
}
.topnav .tab.active .cnt { color: var(--accent); }

/* ════════════════════════════════════════════
 * TOOLBAR / FILTRES — pills arrondies, focus teal
 * ════════════════════════════════════════════ */
.search input {
  border: 1px solid var(--color-hair-classic); border-radius: var(--r-md);
  background: #fff; font-family: var(--font-sans);
  transition: border-color .15s, box-shadow .15s;
}
.search input:focus {
  border-color: var(--primary); outline: none;
  box-shadow: 0 0 0 3px rgba(0,97,126,.12);
}
select.sel, button.btn-tool {
  border: 1px solid var(--color-hair-classic); border-radius: var(--r-md);
  background: #fff; font-family: var(--font-sans); font-weight: 600;
  transition: all .15s;
}
select.sel:hover, button.btn-tool:hover {
  background: var(--bg); border-color: var(--primary); color: var(--primary);
}
.viewtoggle { border: 1px solid var(--color-hair-classic); border-radius: var(--r-md); }
.viewtoggle button { font-family: var(--font-sans); font-weight: 700; letter-spacing: 0.04em; }
.viewtoggle button.active { background: var(--primary); color: #fff; }
.reset { font-style: normal; font-weight: 600; }

/* layout toolbar : recherche plafonnée, selects bornés (sinon débordement à droite) */
.toolbar { gap: 10px 10px; padding: 20px 0 14px; }
.search { flex: 1 1 300px; min-width: 220px; max-width: 460px; }
.search input { box-sizing: border-box; }  /* sinon width:100% + padding-left déborde sur le select voisin */
select.sel { flex: 0 1 auto; min-width: 0; max-width: 190px; padding: 9px 30px 9px 13px; }
.btn-tool { flex: 0 0 auto; padding: 9px 13px; }
.result-count {
  font-family: var(--font-sans); font-weight: 700; letter-spacing: 0.04em;
  color: var(--color-mute);
}

/* boutons toggle filtre actifs → teal */
#f-qw.active, #f-rex.active {
  background: var(--primary) !important; color: #fff !important; border-color: var(--primary) !important;
}
#f-ddpo.active {
  background: var(--ddpo) !important; color: #fff !important; border-color: var(--ddpo) !important;
}

/* filtre par lettre de famille (A–H) — pastilles arrondies */
:root { --ddpo: #6D5AE0; --ddpo-soft: #E4DEF8; --ddpo-ink: #2F2470; }
/* niveau + familles sur la MÊME ligne (deux groupes côte à côte, wrap si étroit) */
.filterchips { display: flex; flex-wrap: wrap; align-items: center; gap: 8px 22px; padding: 0 0 6px; }
.famletters { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; padding: 0; }
.famletters .fll {
  font-family: var(--font-sans); font-size: 12px; font-weight: 700; letter-spacing: 0.02em;
  width: 28px; height: 28px; display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--color-hair); border-radius: var(--r-sm); color: var(--color-mute);
  background: #fff; cursor: pointer; transition: all var(--t-fast);
}
.famletters .fll:hover { border-color: var(--primary); color: var(--primary); }
.famletters .fll.active { background: var(--primary); color: #fff; border-color: var(--primary); }
.famletters .fll-label {
  font-family: var(--font-sans); font-size: 11px; font-weight: 700; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--color-faint); margin-right: 4px;
}

/* chips de filtre actif (activechips) → pill */
.fchip {
  background: var(--bg-alt); border: 1px solid var(--color-hair); border-radius: 999px;
  color: var(--color-ink-soft); font-family: var(--font-sans); font-weight: 600;
}
.fchip button:hover { color: var(--color-terra); }

/* ════════════════════════════════════════════
 * CARTES / GRILLE — fond blanc, bord gauche niveau, ombre, hover soulève
 * ════════════════════════════════════════════ */
.card {
  background: var(--card); border: 1px solid var(--color-hair);
  border-left: 4px solid var(--ncol, var(--color-hair));
  border-radius: var(--r-lg); box-shadow: var(--shadow-sm);
  transition: transform .12s, box-shadow .12s, border-color .12s;
}
.card:hover {
  transform: translateY(-3px); box-shadow: var(--shadow-md);
  border-color: var(--color-hair); border-left-color: var(--ncol, var(--primary));
}
.card h3 { letter-spacing: -0.015em; font-weight: 700; }
.card .fam { font-family: var(--font-sans); font-weight: 700; color: var(--color-mute); }

.uc-id {
  font-family: ui-monospace, "JetBrains Mono", monospace; font-weight: 800;
  font-size: 11px; color: var(--color-ink-soft);
  background: var(--bg); padding: 3px 9px; border-radius: 6px; letter-spacing: 0.04em;
}

/* badge niveau (carte + drawer) → pastille pleine couleur du niveau */
.niv {
  border-radius: 6px; text-transform: none; font-family: var(--font-sans);
  font-weight: 800; font-size: 11px; letter-spacing: 0.04em;
  border: 0; color: #fff; padding: 3px 9px;
}
.niv .nd { width: 6px; height: 6px; }
.niv.N0 { background: var(--niv0); }   .niv.N0 .nd { background: rgba(255,255,255,.85); }
.niv.N1 { background: var(--niv1); }   .niv.N1 .nd { background: rgba(255,255,255,.85); }
.niv.N2 { background: var(--niv2); }   .niv.N2 .nd { background: rgba(255,255,255,.85); }
.niv.N3 { background: var(--niv3); }   .niv.N3 .nd { background: rgba(255,255,255,.85); }

/* marqueurs quick win / rex */
.qw {
  color: var(--color-saffron-ink); font-family: var(--font-sans);
  font-weight: 700; text-transform: none; letter-spacing: 0;
}
.qw .star { color: var(--niv3); }
.rex { color: var(--niv2); font-family: var(--font-sans); font-weight: 700; }
.rex .rd { background: var(--niv2); }

/* chips de bas de carte → pill */
.chip {
  font-family: var(--font-sans); font-weight: 600; border-radius: 999px;
  border: 1px solid var(--color-hair); background: var(--bg); color: var(--color-ink-soft);
  white-space: nowrap;
}
.chip.statut { color: var(--color-ink); }
.chip.act {
  color: var(--accent-dark); border-color: transparent;
  background: rgba(171,192,34,.16); font-weight: 700;
}
/* badge DDPO — pastille violette (gouvernance) */
.chip.ddpo {
  color: var(--ddpo-ink); border-color: transparent;
  background: var(--ddpo-soft); font-weight: 700;
}
.chip.ddpo .dd {
  width: 6px; height: 6px; border-radius: 999px; background: var(--ddpo);
  display: inline-block; margin-right: 5px; vertical-align: middle;
}

/* ════════════════════════════════════════════
 * TABLE
 * ════════════════════════════════════════════ */
/* table = carte blanche (comme la grille), au lieu d'être à nu sur le fond */
.tablewrap {
  background: var(--card); border: 1px solid var(--color-hair);
  border-radius: var(--r-lg); box-shadow: var(--shadow-sm);
  padding: 4px 20px 8px; margin-bottom: 80px; overflow-x: auto;
}
table.dense thead th {
  text-transform: none; font-family: var(--font-sans); font-weight: 700;
  font-size: 11px; letter-spacing: 0.02em; color: var(--color-mute);
  background: transparent;  /* sur carte blanche */
  /* sticky top:64px se calait sur .tablewrap (scroll-container via overflow-x) → header
     poussé à +64px et chevauchant la 1ère ligne. En-tête en flux normal = pas de chevauchement. */
  position: static; top: auto; border-bottom: 1px solid var(--color-hair);
}
table.dense tbody tr:last-child td { border-bottom: 0; }
table.dense thead th .arr { color: var(--primary); }
table.dense tbody tr:hover { background: var(--bg-alt); }
table.dense td.t-id {
  font-family: ui-monospace, "JetBrains Mono", monospace; font-weight: 800; color: var(--color-ink-soft);
}
table.dense td.t-titre { font-weight: 700; }

/* ════════════════════════════════════════════
 * PILOTES / CLUSTERS / CHANGELOG
 * ════════════════════════════════════════════ */
.pcard, .ccard {
  border-radius: var(--r-lg); border: 1px solid var(--color-hair);
  box-shadow: var(--shadow-sm); transition: transform .12s, box-shadow .12s;
}
.pcard:hover, .ccard:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.pcard .pname { font-family: var(--font-display); font-weight: 800; text-transform: none; }
.pcard .ppays { font-family: var(--font-sans); font-weight: 700; text-transform: none; letter-spacing: 0.04em; }
.ccard h3 { text-transform: none; font-weight: 800; }
.ccard .cpain { font-style: normal; }
.ccard .cnb { font-family: var(--font-display); font-weight: 800; color: var(--primary); }
.ccard .cnb small { font-family: var(--font-sans); }
.pcard .pmeta .k, .ccard .cid {
  font-family: var(--font-sans); font-weight: 700; letter-spacing: 0.04em;
  text-transform: uppercase; color: var(--color-faint);
}
.verrou-box {
  border-radius: var(--r-md);
  background: var(--color-terra-soft);
  border-color: transparent; border-left: 4px solid var(--color-terra);
}
.verrou-box .vd { background: var(--color-terra); }
.verrou-box .vt b { font-family: var(--font-sans); font-weight: 700; letter-spacing: 0.04em; }
.pstat { font-family: var(--font-sans); font-weight: 700; letter-spacing: 0.04em; }

/* rail de gradation cluster → couleurs niveaux maquette */
.grad .step.on0 { background: var(--niv0); }
.grad .step.on1 { background: var(--niv1); }
.grad .step.on2 { background: var(--niv2); }
.grad .step.on3 { background: var(--niv3); }

/* changelog */
.cl-day {
  font-family: var(--font-sans); font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.04em; color: var(--color-mute);
}
.cl-row:hover { background: var(--bg-alt); }
.cl-time { font-family: ui-monospace, "JetBrains Mono", monospace; color: var(--color-faint); }
.cl-main .cl-line .op, .cl-actor { font-family: var(--font-sans); font-weight: 700; }
.op.update { background: var(--color-cobalt-soft); color: var(--color-cobalt-ink); }
.op.import { background: var(--color-paper-3); color: var(--color-mute); }
.op.create { background: var(--color-olive-soft); color: var(--color-olive-ink); }
.op.delete { background: var(--color-terra-soft); color: var(--color-terra-ink); }

/* ════════════════════════════════════════════
 * DRAWER — slide latéral conservé ; sections style maquette
 * ════════════════════════════════════════════ */
.overlay { background: rgba(15,23,42,.55); backdrop-filter: blur(6px); }

/* UC → grande modale d'aperçu centrée (au lieu du panneau latéral) */
.drawer {
  position: fixed; inset: auto; top: 50%; left: 50%; right: auto; bottom: auto;
  width: min(900px, 94vw); max-width: 94vw; height: auto; max-height: 92vh;
  transform: translate(-50%, -47%) scale(.97);
  border-radius: var(--r-xl); border-left: 0;
  box-shadow: var(--shadow-lg);
  display: flex; flex-direction: column; overflow: hidden;
  opacity: 0; visibility: hidden;
  transition: opacity .2s ease, transform .2s ease, visibility .2s;
}
.drawer.open { transform: translate(-50%, -50%) scale(1); opacity: 1; visibility: visible; }
.dr-body { flex: 1; overflow: hidden; }  /* aperçu = pas de scroll */
/* champs longs de l'aperçu : tronqués (la fiche complète montre tout) */
.drawer .dr-body .v.lead { display: -webkit-box; -webkit-line-clamp: 5; -webkit-box-orient: vertical; overflow: hidden; }
.dr-head { border-bottom: 1px solid var(--color-hair); border-radius: var(--r-xl) var(--r-xl) 0 0; }
.dr-head .drtop .uc-id { font-size: 11px; }
.dr-head h2 { font-family: var(--font-sans); font-weight: 800; text-transform: none; }
.dr-head .drfam { font-family: var(--font-sans); font-weight: 600; text-transform: none; letter-spacing: 0.04em; }
.dr-close {
  border: 1px solid var(--color-hair); border-radius: 999px;
}
.dr-close:hover { background: var(--bg-alt); color: var(--color-ink); }

/* libellé de section → primary uppercase (maquette .ms-label) */
.dr-section-h {
  font-family: var(--font-sans); font-weight: 800; font-size: 11px;
  letter-spacing: 0.06em; text-transform: uppercase; color: var(--primary);
  border-bottom: 1px solid var(--color-hair);
}
.field .k {
  font-family: var(--font-sans); font-weight: 700; font-size: 10.5px;
  letter-spacing: 0.04em; text-transform: uppercase; color: var(--color-faint);
}
.field .v { color: var(--color-ink); }

/* blocs de contenu type maquette (.ms-body) : fond léger, bord gauche.
   On habille les champs "pleine largeur" (pain/solution/bénéfice) comme
   les blocs colorés de la maquette via leur libellé. Sans hook par-champ
   dans le markup, on pose un traitement générique cohérent : carte douce. */
.field.full {
  background: var(--bg-alt); border-radius: var(--r-sm);
  border-left: 3px solid var(--primary);
  padding: 12px 15px;
}
.field.full .k { color: var(--primary); }
.field.full .v.lead { color: var(--color-ink); font-size: 14px; line-height: 1.6; }

/* timeline historique */
.tl-ev { border-left-color: var(--color-hair); }
.tl-ev::before { border-color: var(--primary); background: var(--card); }
.tl-ev.import::before { border-color: var(--color-faint); }
.tl-ev .tl-op { font-family: var(--font-sans); font-weight: 700; }
.tl-ev .tl-op.update { background: var(--color-cobalt-soft); color: var(--color-cobalt-ink); }
.tl-ev .tl-when { font-family: ui-monospace, "JetBrains Mono", monospace; }
.tl-ev .tl-diff {
  font-family: ui-monospace, "JetBrains Mono", monospace;
  background: var(--bg-alt); border: 1px solid var(--color-hair); border-radius: var(--r-sm);
}
.tl-ev .tl-diff .o { color: var(--color-terra); }
.tl-ev .tl-diff .n { color: var(--color-olive-ink); }

/* ════════════════════════════════════════════
 * NOTES utilisateur (drawer) — cohérent thème
 * ════════════════════════════════════════════ */
.notes { display: flex; flex-direction: column; gap: 12px; margin-bottom: 8px; }
.note-mine .k {
  font-family: var(--font-sans); font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .04em; color: var(--color-mute); margin-bottom: 4px;
}
.note-input {
  width: 100%; box-sizing: border-box; resize: vertical; padding: 9px 11px;
  border: 1px solid var(--color-hair-classic); border-radius: var(--r-sm);
  background: #fff; color: var(--color-ink); font: inherit; font-size: 13px; line-height: 1.45;
  transition: border-color .15s, box-shadow .15s;
}
.note-input:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px rgba(0,97,126,.12); }
.note-actions { display: flex; gap: 8px; margin-top: 6px; }
.note-save, .note-del {
  font: inherit; font-size: 12px; font-weight: 700; padding: 6px 14px; cursor: pointer;
  border: 1px solid transparent; border-radius: var(--r-sm);
}
.note-save { background: var(--primary); color: #fff; }
.note-save:hover { background: var(--primary-dark); }
.note-del { background: #fff; border-color: var(--color-hair-classic); color: var(--color-mute); }
.note-del:hover { border-color: var(--color-terra); color: var(--color-terra); }
.note-other {
  border-left: 3px solid var(--accent); background: rgba(171,192,34,.07);
  border-radius: var(--r-sm); padding: 10px 12px;
}
.note-meta { font-size: 11px; color: var(--color-mute); margin-bottom: 3px; font-weight: 600; }
.note-text { font-size: 13px; line-height: 1.45; white-space: pre-wrap; color: var(--color-ink); }

/* Note : les pages /howto et /admin embarquent leur propre <style> inline
 * et ne chargent PAS egis-theme.css — pas de règle ici pour elles. */

/* ════════════════════════════════════════════
 * RESPONSIVE — KPI passe en cartes empilées sur le héro sombre
 * ════════════════════════════════════════════ */
@media (max-width: 880px) {
  .kpis { grid-template-columns: 1fr 1fr; }
  .kpi { border: 1px solid rgba(255,255,255,.18); padding: 14px 16px; }
  .kpi:first-child, .kpi:nth-child(2) { border-top: 1px solid rgba(255,255,255,.18); }
}
@media (max-width: 560px) {
  .kpi { padding: 13px 14px; }
}

/* ════════════════════════════════════════════
 * CHIPS NIVEAU (filtre dans la toolbar) — pill liseré couleur niveau
 * ════════════════════════════════════════════ */
#nivchips .nvchip {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 11px; border-radius: 999px;
  font-family: var(--font-sans); font-size: 11.5px; font-weight: 800; letter-spacing: .02em;
  background: var(--card); color: var(--color-ink-soft);
  border: 1px solid var(--color-hair); cursor: pointer;
  box-shadow: inset 0 0 0 2px var(--nc); transition: all .12s;
}
#nivchips .nvchip:hover { background: var(--bg-alt); }
#nivchips .nvchip .ct {
  font-size: 10.5px; font-weight: 700; color: var(--color-faint);
  background: rgba(15,23,42,.06); padding: 1px 6px; border-radius: 999px;
}
#nivchips .nvchip.active { background: var(--nc); color: #fff; border-color: var(--nc); }
#nivchips .nvchip.active .ct { background: rgba(255,255,255,.22); color: rgba(255,255,255,.92); }

/* ════════════════════════════════════════════
 * PAGE COMPLÈTE D'UN UC (#/uc/ID) + quick-view
 * ════════════════════════════════════════════ */
body.on-ucpage .panorama-only { display: none !important; }
#uc-page { display: none; }
body.on-ucpage #uc-page { display: block; }

.ucp { padding: 26px 0 90px; }
.ucp-back {
  display: inline-flex; align-items: center; gap: 6px; margin-bottom: 18px;
  background: var(--card); border: 1px solid var(--color-hair); border-radius: 999px;
  padding: 7px 14px; font: inherit; font-size: 12.5px; font-weight: 700; color: var(--primary);
  cursor: pointer;
}
.ucp-back:hover { background: var(--bg-alt); }
.ucp-head { margin-bottom: 8px; }
.ucp-head h1 { font-size: clamp(20px, 3vw, 28px); font-weight: 800; letter-spacing: -0.02em; margin: 12px 0 6px; }
.ucp-head .drfam { color: var(--color-mute); font-size: 12.5px; }
.ucp-body { background: var(--card); border: 1px solid var(--color-hair); border-radius: var(--r-lg);
  box-shadow: var(--shadow-sm); padding: 8px 26px 26px; }

/* bouton "Fiche complète" dans la modale quick-view */
.ucp-open {
  margin-top: 14px; width: 100%; padding: 11px; border: 0; border-radius: var(--r-md);
  background: var(--primary); color: #fff; font: inherit; font-weight: 700; font-size: 13.5px; cursor: pointer;
}
.ucp-open:hover { background: var(--primary-dark); }

/* ressources / liens */
.rsrc-list { display: flex; flex-direction: column; gap: 6px; margin-bottom: 10px; }
.rsrc { display: flex; align-items: center; gap: 10px; }
.rsrc a { color: var(--primary); font-weight: 600; font-size: 13.5px; text-decoration: none; word-break: break-word; }
.rsrc a:hover { text-decoration: underline; }
.rsrc-kind { font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em;
  background: var(--egis-soft); color: var(--egis-ink); padding: 2px 8px; border-radius: 999px; }

/* contacts */
.contact-list { display: flex; flex-direction: column; gap: 6px; margin-bottom: 10px; }
.contact { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; font-size: 13.5px; }
.ct-name { font-weight: 700; color: var(--color-ink); }
.ct-role { color: var(--color-ink-soft); }
.ct-pil { font-size: 10.5px; font-weight: 700; background: rgba(171,192,34,.18); color: var(--accent-dark);
  padding: 2px 8px; border-radius: 999px; }
.ct-mail { color: var(--primary); text-decoration: none; font-size: 12.5px; }
.ct-mail:hover { text-decoration: underline; }

/* lignes d'ajout (liens + contacts) */
.addrow { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 4px; }
.addrow .ai { flex: 1 1 140px; min-width: 0; box-sizing: border-box; padding: 8px 11px;
  border: 1px solid var(--color-hair); border-radius: var(--r-sm); background: #fff; font: inherit; font-size: 13px; }
.addrow .ai:focus { outline: none; border-color: var(--primary); }
.addrow .addbtn { flex: 0 0 auto; padding: 8px 16px; border: 0; border-radius: var(--r-sm);
  background: var(--primary); color: #fff; font: inherit; font-weight: 700; font-size: 13px; cursor: pointer; }
.addrow .addbtn:hover { background: var(--primary-dark); }
.x-del { margin-left: auto; background: none; border: 0; color: var(--color-faint); font-size: 16px;
  line-height: 1; cursor: pointer; padding: 0 4px; }
.x-del:hover { color: var(--color-terra); }
.muted { color: var(--color-faint); font-size: 13px; font-style: italic; }

/* ── notes : tabs + rendu markdown ── */
.note-tabs { display: flex; gap: 6px; margin-bottom: 12px; }
.ntab { font: inherit; font-size: 12.5px; font-weight: 700; padding: 6px 13px; border-radius: 999px;
  border: 1px solid var(--color-hair); background: var(--card); color: var(--color-mute); cursor: pointer; }
.ntab:hover { background: var(--bg-alt); }
.ntab.active { background: var(--primary); color: #fff; border-color: var(--primary); }
.md-hint { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em;
  background: var(--bg-alt); color: var(--color-mute); padding: 2px 7px; border-radius: 999px; margin-left: 8px; }
.note-edit, .note-cancel { background: none; border: 1px solid var(--color-hair); color: var(--color-mute); }
.note-edit:hover, .note-cancel:hover { border-color: var(--primary); color: var(--primary); }

.md { font-size: 14px; line-height: 1.6; color: var(--color-ink); }
.md > :first-child { margin-top: 0; }
.md > :last-child { margin-bottom: 0; }
.md p { margin: 0 0 10px; }
.md h3 { font-size: 15px; font-weight: 800; margin: 16px 0 6px; letter-spacing: -0.01em; }
.md h4, .md h5 { font-size: 13px; font-weight: 800; margin: 14px 0 5px; color: var(--color-ink-soft); text-transform: none; letter-spacing: 0; }
.md ul, .md ol { margin: 0 0 10px; padding-left: 22px; }
.md li { margin: 2px 0; }
.md a { color: var(--primary); }
.md code { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 12.5px;
  background: var(--bg-alt); padding: 1px 5px; border-radius: 4px; }
.md pre { background: var(--bg-alt); border: 1px solid var(--color-hair); border-radius: var(--r-sm);
  padding: 10px 12px; overflow-x: auto; margin: 0 0 10px; }
.md pre code { background: none; padding: 0; }

/* ── scoring (grille de priorisation) ── */
.scoring { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 14px 22px; }
.scoring .note-actions { grid-column: 1 / -1; align-items: center; }
.sc-axis-h { font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: .04em;
  color: var(--primary); margin-bottom: 8px; display: flex; align-items: center; gap: 8px; }
.sc-comp { font-family: ui-monospace, "JetBrains Mono", monospace; font-weight: 800; color: var(--color-ink);
  background: var(--bg-alt); padding: 1px 8px; border-radius: 999px; font-size: 12px; }
.sc-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 4px 0;
  border-bottom: 1px solid var(--color-hair-soft); }
.sc-lbl { font-size: 13px; color: var(--color-ink-soft); }
.sc-in { width: 56px; box-sizing: border-box; padding: 5px 8px; border: 1px solid var(--color-hair);
  border-radius: var(--r-sm); font: inherit; font-size: 13px; text-align: center; }
.sc-in:focus { outline: none; border-color: var(--primary); }
.sc-prio { font-weight: 700; color: var(--primary); font-size: 13px; }
.sc-detail { margin-top: 16px; padding-top: 12px; border-top: 1px dashed var(--color-hair); }
.sc-tbl { width: 100%; border-collapse: collapse; font-size: 13px; margin-top: 6px; }
.sc-tbl th { text-align: right; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .03em;
  color: var(--color-mute); padding: 4px 10px; border-bottom: 1px solid var(--color-hair); }
.sc-tbl th:first-child, .sc-tbl td.sc-ev { text-align: left; }
.sc-tbl td { padding: 5px 10px; text-align: right; border-bottom: 1px solid var(--color-hair-soft);
  font-family: ui-monospace, "JetBrains Mono", monospace; }
.sc-tbl td.sc-ev { font-family: var(--font-sans); font-weight: 600; color: var(--color-ink); }
.sc-tbl tr.sc-avg td { font-weight: 800; color: var(--primary); border-top: 1px solid var(--color-hair); border-bottom: 0; }

/* ── matrice / quadrant ── */
.mx-head { margin: 22px 0 6px; }
.mx-head h2 { font-size: 20px; font-weight: 800; letter-spacing: -0.02em; }
.mx-sub { color: var(--color-mute); font-size: 12.5px; }
.mx-ctrl { display: flex; flex-wrap: wrap; gap: 14px; margin: 12px 0 16px; }
.mx-ctrl label { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .05em;
  color: var(--color-mute); display: flex; flex-direction: column; gap: 4px; }
.mx-ctrl select.sel { font-weight: 600; }
.mx-svg { width: 100%; height: auto; background: var(--card); border: 1px solid var(--color-hair);
  border-radius: var(--r-lg); box-shadow: var(--shadow-sm); margin-bottom: 80px; }
.mx-grid { stroke: var(--color-hair-soft); stroke-width: 1; }
.mx-mid { stroke: var(--color-hair-classic); stroke-width: 1.5; stroke-dasharray: 5 4; }
.mx-tick { fill: var(--color-faint); font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 11px; }
.mx-axis { fill: var(--primary); font-family: var(--font-sans); font-weight: 800; font-size: 13px;
  text-transform: uppercase; letter-spacing: .04em; }
.mx-pt { cursor: pointer; }
.mx-pt:hover circle { fill-opacity: 1; stroke: var(--primary); }
.mx-id { fill: var(--color-ink-soft); font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 9px; pointer-events: none; }
.mx-corner { font-family: var(--font-sans); font-weight: 800; font-size: 12px; letter-spacing: .04em; text-transform: uppercase; }
.mx-corner.good { fill: var(--niv3); opacity: .55; }
.mx-corner.bad { fill: var(--color-faint); opacity: .8; }

/* ── vue howto (config) + admin (membres) intégrées ── */
.cfg { display: flex; flex-direction: column; gap: 8px; margin-bottom: 8px; }
.cfg-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.cfg-row .k { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .05em;
  color: var(--color-mute); min-width: 150px; }
.cfg-row code { font-family: ui-monospace, "JetBrains Mono", monospace; font-size: 13px;
  background: var(--bg-alt); padding: 4px 9px; border-radius: var(--r-sm); color: var(--color-ink); }
.copy { font: inherit; font-size: 11px; font-weight: 700; padding: 4px 10px; border-radius: 999px;
  border: 1px solid var(--color-hair); background: var(--card); color: var(--primary); cursor: pointer; }
.copy:hover { background: var(--bg-alt); }
.adm-list { display: flex; flex-direction: column; gap: 2px; margin-bottom: 14px; }
.adm-row { display: flex; align-items: center; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--color-hair-soft); }
.adm-row .grow { flex: 1; }
.adm-email { color: var(--color-mute); font-size: 12.5px; margin-left: 6px; }

/* bouton "fiche →" sur la carte (accès direct fiche complète, sans passer par l'aperçu) */
.card-full { margin-left: auto; font: inherit; font-size: 11px; font-weight: 700; letter-spacing: .02em;
  padding: 3px 11px; border-radius: 999px; border: 1px solid var(--color-hair);
  background: var(--card); color: var(--primary); cursor: pointer; white-space: nowrap; }
.card-full:hover { background: var(--primary); color: #fff; border-color: var(--primary); }
