/* ───────────────────────────────────────────────────────────
 * viewer.css — habillage du panorama. Langage Otomata
 * (cream chaud, hairlines, Familjen Grotesk, squiggle) + UN
 * accent emprunté à Egis : le teal/petrol, posé avec parcimonie
 * (héros d'avancement, lockup de marque). Le reste du sens
 * (niveaux, statuts) reste porté par les accents Otomata.
 * ─────────────────────────────────────────────────────────── */

:root {
  --egis:      #0c7268;   /* teal / petrol emprunté à la marque Egis */
  --egis-ink:  #06352f;
  --egis-soft: #cfe6e1;

  --pad-x: clamp(20px, 5vw, 56px);
  --maxw: 1320px;

  /* densité (piloté par tweaks) */
  --row-py: 13px;
  --card-pad: 22px;
  --grid-min: 320px;
}
[data-density="compact"] {
  --row-py: 8px;
  --card-pad: 16px;
  --grid-min: 280px;
}

/* la texture quadrillage est déjà sur body via tokens.css */
[data-grid="off"] body { background-image: none; }

body { overflow-x: hidden; }
.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--pad-x); }

/* ───────────────────────────── TOP BAR */
.topbar {
  position: sticky; top: 0; z-index: 40;
  background: color-mix(in srgb, var(--color-bg) 86%, transparent);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--color-hair);
}
.topbar .wrap {
  display: flex; align-items: center; justify-content: space-between;
  gap: 18px; padding-top: 14px; padding-bottom: 14px;
}
.lockup { display: flex; align-items: center; gap: 12px; }
.lockup .mark {
  font-family: var(--font-display); font-weight: 700; font-size: 25px;
  letter-spacing: -0.04em; color: var(--egis); line-height: 1;
}
.lockup .cross { color: var(--color-faint); font-size: 16px; font-style: italic; }
.lockup .oto {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--font-display); font-weight: 700; font-size: 18px;
  letter-spacing: -0.03em; color: var(--color-ink);
}
.lockup .tag {
  margin-left: 6px; padding-left: 14px; border-left: 1px solid var(--color-hair);
  display: flex; flex-direction: column; gap: 1px;
}
.lockup .tag b { font-family: var(--font-sans); font-weight: 600; font-size: 13px; letter-spacing: -0.01em; }
.lockup .tag span {
  font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--color-mute);
}
.live-pill {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--color-mute);
  border: 1px solid var(--color-hair); border-radius: 999px; padding: 7px 13px;
}
.live-dot { width: 7px; height: 7px; border-radius: 999px; background: var(--color-olive);
  box-shadow: 0 0 0 0 color-mix(in srgb, var(--color-olive) 60%, transparent); animation: pulse 2.4s infinite; }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--color-olive) 55%, transparent); }
  70% { box-shadow: 0 0 0 6px transparent; } 100% { box-shadow: 0 0 0 0 transparent; } }
.actor-pill {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em;
  color: var(--color-ink-soft); border: 1px solid var(--color-hair);
  border-radius: 999px; padding: 6px 8px 6px 6px;
}
.actor-pill .av {
  width: 18px; height: 18px; border-radius: 999px; background: var(--color-ink);
  color: var(--color-bg); display: inline-flex; align-items: center; justify-content: center;
  font-size: 9px; font-weight: 700;
}

/* ───────────────────────────── HERO */
.hero { padding: clamp(30px, 5vw, 54px) 0 0; }
.hero-top { display: grid; grid-template-columns: 3fr 9fr; gap: clamp(20px, 4vw, 56px); align-items: end; }
.hero-kick .eyebrow { display: block; margin-bottom: 12px; }
.hero-kick p { font-style: italic; font-size: 15px; color: var(--color-mute); margin: 0; line-height: 1.5; }
.hero h1 {
  font-size: clamp(2.1rem, 5vw, 3.7rem); letter-spacing: -0.038em; line-height: 0.98; margin: 0;
}
.sq-host { position: relative; display: inline-block; white-space: nowrap; padding-bottom: 6px; }
.sq-host .squiggle-svg { position: absolute; left: 0; bottom: -3px; width: 100%; }

/* KPI strip */
.kpis {
  margin-top: clamp(26px, 4vw, 42px);
  border-top: 1px solid var(--color-hair);
  border-bottom: 1px solid var(--color-hair);
  display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr 1.1fr;
}
.kpi { padding: 22px 26px; border-left: 1px solid var(--color-hair); }
.kpi:first-child { border-left: 0; padding-left: 0; }
.kpi .klabel {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--color-mute); margin-bottom: 10px;
}
.kpi .kval { font-family: var(--font-display); font-weight: 700; letter-spacing: -0.03em;
  font-size: 38px; line-height: 1; color: var(--color-ink); }
.kpi .kval small { font-size: 17px; color: var(--color-mute); font-weight: 600; }
.kpi .ksub { font-size: 12.5px; color: var(--color-mute); margin-top: 7px; font-style: italic; }

/* avancement meter (idée forte — porte l'accent Egis) */
.meter { margin-top: 14px; }
.meter .track { height: 8px; background: var(--color-paper-3); border-radius: 999px; overflow: hidden; position: relative; }
.meter .fill { height: 100%; background: var(--egis); border-radius: 999px; transition: width 1s var(--ease-out); }
.meter .ticks { display: flex; justify-content: space-between; margin-top: 7px;
  font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.12em; color: var(--color-faint); }
.kpi.verrous .kval { color: var(--color-terra); }

/* niveau distribution : barre proportionnelle + légende cliquable */
.nivbar-wrap { padding: 20px 0 4px; }
.nivbar-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 9px; }
.nivbar-head .eyebrow { color: var(--color-mute); }
.nivbar-head .hint { font-size: 12px; color: var(--color-faint); font-style: italic; white-space: nowrap; }
.nivbar { display: flex; height: 12px; border-radius: 999px; overflow: hidden; background: var(--color-paper-3); gap: 2px; }
.nivseg-bar { transition: opacity var(--t-fast); cursor: pointer; min-width: 4px; }
.nivseg-bar:hover { opacity: 0.82; }
.nivlegend { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 12px; }
.nivseg { display: inline-flex; align-items: center; gap: 8px; cursor: pointer;
  font-family: var(--font-sans); font-size: 13px; color: var(--color-ink-soft);
  border: 1px solid var(--color-hair); border-radius: 999px; padding: 6px 13px; transition: background var(--t-fast); white-space: nowrap; }
.nivseg:hover { background: var(--color-paper-2); }
.nivseg.active { background: var(--color-ink); color: var(--color-bg); border-color: var(--color-ink); }
.nivseg .nd { width: 9px; height: 9px; border-radius: 999px; }
.nivseg .nn { font-family: var(--font-mono); font-size: 11px; opacity: 0.7; }

/* ───────────────────────────── TABS */
.tabs { display: flex; gap: 4px; margin-top: 30px; border-bottom: 1px solid var(--color-hair); }
.tab {
  background: none; border: 0; padding: 13px 4px; margin-right: 22px;
  font-family: var(--font-sans); font-size: 16px; font-weight: 600; letter-spacing: -0.01em;
  color: var(--color-mute); cursor: pointer; position: relative; text-transform: lowercase;
}
.tab:hover { color: var(--color-ink); }
.tab.active { color: var(--color-ink); }
.tab.active::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 2px; background: var(--egis);
}
.tab .cnt { font-family: var(--font-mono); font-size: 11px; color: var(--color-faint); margin-left: 6px; }

/* ───────────────────────────── TOOLBAR */
.toolbar { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; padding: 22px 0 18px; }
.search { flex: 1; min-width: 240px; position: relative; }
.search input {
  width: 100%; background: var(--color-surface); border: 1px solid var(--color-hair); border-radius: 999px;
  padding: 11px 16px 11px 38px; font-family: var(--font-sans); font-size: 14px; color: var(--color-ink);
}
.search input::placeholder { color: var(--color-faint); }
.search .ic { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); color: var(--color-faint); }
select.sel, button.btn-tool {
  background: var(--color-surface); border: 1px solid var(--color-hair); border-radius: 999px;
  padding: 10px 14px; font-family: var(--font-sans); font-size: 13.5px; color: var(--color-ink-soft); cursor: pointer;
}
select.sel:hover, button.btn-tool:hover { background: var(--color-paper-2); }
.viewtoggle { display: inline-flex; border: 1px solid var(--color-hair); border-radius: 999px; overflow: hidden; background: var(--color-surface); }
.viewtoggle button { background: none; border: 0; padding: 9px 14px; font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-mute); cursor: pointer; }
.viewtoggle button.active { background: var(--color-ink); color: var(--color-bg); }
.reset { background: none; border: 0; color: var(--color-mute); font-style: italic; font-size: 13px; cursor: pointer; padding: 8px; }
.reset:hover { color: var(--color-terra); }
.result-count { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-faint); margin-left: auto; }

/* active filter chips */
.activechips { display: flex; gap: 8px; flex-wrap: wrap; padding-bottom: 10px; }
.activechips:empty { display: none; }
.fchip { display: inline-flex; align-items: center; gap: 7px; font-size: 12px; color: var(--color-ink-soft);
  background: var(--color-paper-2); border: 1px solid var(--color-hair); border-radius: 999px; padding: 4px 6px 4px 11px; }
.fchip button { background: none; border: 0; color: var(--color-mute); cursor: pointer; font-size: 14px; line-height: 1; }
.fchip button:hover { color: var(--color-terra); }

/* ───────────────────────────── CARD GRID */
.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(var(--grid-min), 1fr)); gap: 14px; padding-bottom: 80px; }
.card {
  background: var(--color-surface); border: 1px solid var(--color-hair); border-radius: 16px;
  padding: var(--card-pad); cursor: pointer; transition: transform .2s var(--ease-out), border-color var(--t-fast);
  display: flex; flex-direction: column; gap: 12px; position: relative;
}
.card:hover { transform: translateY(-2px); border-color: var(--color-hair-classic); }
.card .ctop { display: flex; align-items: center; gap: 9px; }
.uc-id { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.06em; color: var(--color-mute); }
.niv {
  display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.08em; padding: 3px 9px 3px 8px; border-radius: 999px; border: 1px solid var(--color-hair);
  text-transform: uppercase;
}
.niv .nd { width: 7px; height: 7px; border-radius: 999px; }
.niv.N0 { color: var(--color-mute); }   .niv.N0 .nd { background: var(--color-faint); }
.niv.N1 { color: var(--color-cobalt-ink); } .niv.N1 .nd { background: var(--color-cobalt); }
.niv.N2 { color: var(--color-saffron-ink); } .niv.N2 .nd { background: var(--color-saffron); }
.niv.N3 { color: var(--color-olive-ink); }  .niv.N3 .nd { background: var(--color-olive); }
.card .ctop .spacer { flex: 1; }
.qw { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--color-saffron-ink); display: inline-flex; align-items: center; gap: 5px; white-space: nowrap; }
.qw .star { color: var(--color-saffron); font-size: 12px; }
.rex { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.08em; color: var(--color-cobalt);
  display: inline-flex; align-items: center; gap: 4px; white-space: nowrap; }
.rex .rd { width: 6px; height: 6px; border-radius: 999px; background: var(--color-cobalt); }
.card h3 { font-family: var(--font-sans); font-weight: 700; font-size: 17px; letter-spacing: -0.018em;
  line-height: 1.22; color: var(--color-ink); margin: 0; text-transform: none; text-wrap: balance; }
.card .fam { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-mute); }
.card .pp { font-size: 13.5px; color: var(--color-ink-soft); line-height: 1.5; margin: 0;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.card .cfoot { margin-top: auto; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; padding-top: 4px; }
.chip { font-family: var(--font-sans); font-size: 11.5px; color: var(--color-ink-soft);
  border: 1px solid var(--color-hair); border-radius: 999px; padding: 3px 10px; }
.chip.statut { color: var(--color-ink); }
.chip.act { color: var(--egis-ink); border-color: var(--egis-soft); background: color-mix(in srgb, var(--egis-soft) 35%, transparent); }
.card .pilrow { display: flex; gap: 5px; flex-wrap: wrap; }
.pilchip { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.04em; color: var(--color-mute);
  border: 1px solid var(--color-hair); border-radius: 5px; padding: 2px 6px; }

/* ───────────────────────────── TABLE */
.tablewrap { padding-bottom: 80px; overflow-x: auto; }
table.dense { width: 100%; border-collapse: collapse; font-size: 13px; min-width: 880px; }
table.dense thead th {
  position: sticky; top: 64px; background: var(--color-bg); text-align: left;
  font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--color-mute); font-weight: 600; padding: 11px 12px; border-bottom: 1px solid var(--color-hair);
  cursor: pointer; white-space: nowrap; user-select: none;
}
table.dense thead th:hover { color: var(--color-ink); }
table.dense thead th .arr { color: var(--egis); margin-left: 3px; }
table.dense tbody td { padding: var(--row-py) 12px; border-bottom: 1px solid var(--color-hair-soft); vertical-align: middle; }
table.dense tbody tr { cursor: pointer; transition: background var(--t-fast); }
table.dense tbody tr:hover { background: var(--color-paper-2); }
table.dense td.t-id { font-family: var(--font-mono); font-size: 11px; color: var(--color-mute); white-space: nowrap; }
table.dense td.t-titre { font-weight: 600; color: var(--color-ink); letter-spacing: -0.01em; max-width: 360px; }
table.dense td.t-fam { color: var(--color-mute); font-size: 12px; }
.tn { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-mono); font-size: 10px; }
.tn .nd { width: 7px; height: 7px; border-radius: 999px; }
.tdot { display: inline-block; width: 7px; height: 7px; border-radius: 999px; margin-right: 6px; vertical-align: middle; }

/* ───────────────────────────── PILOTES */
.pgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(360px, 1fr)); gap: 14px; padding-bottom: 80px; }
.pcard { background: var(--color-surface); border: 1px solid var(--color-hair); border-radius: 16px; padding: 24px;
  display: flex; flex-direction: column; gap: 14px; transition: transform .2s var(--ease-out); }
.pcard:hover { transform: translateY(-2px); }
.pcard .phead { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; }
.pcard .pname { font-family: var(--font-display); font-weight: 700; font-size: 24px; letter-spacing: -0.03em; color: var(--color-ink); }
.pcard .ppays { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-mute); }
.pcard .pdesc { font-size: 14px; color: var(--color-ink-soft); line-height: 1.5; margin: 0; }
.pcard .pmeta { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 18px; padding-top: 6px; border-top: 1px solid var(--color-hair); }
.pcard .pmeta .k { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--color-faint); }
.pcard .pmeta .v { font-size: 13px; color: var(--color-ink); margin-top: 2px; }
.verrou-box { display: flex; gap: 10px; align-items: flex-start; background: color-mix(in srgb, var(--color-terra-soft) 30%, transparent);
  border: 1px solid var(--color-terra-soft); border-radius: 10px; padding: 11px 13px; }
.verrou-box .vd { width: 9px; height: 9px; border-radius: 999px; background: var(--color-terra); margin-top: 4px; flex-shrink: 0; }
.verrou-box .vt { font-size: 13px; color: var(--color-terra-ink); line-height: 1.4; }
.verrou-box .vt b { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.14em; text-transform: uppercase; display: block; margin-bottom: 2px; color: var(--color-terra); }
.pstat { display: inline-flex; align-items: center; gap: 7px; font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.1em; text-transform: uppercase; color: var(--color-ink-soft); }

/* ───────────────────────────── CLUSTERS */
.cgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(330px, 1fr)); gap: 14px; padding-bottom: 80px; }
.ccard { background: var(--color-surface); border: 1px solid var(--color-hair); border-radius: 16px; padding: 22px;
  display: flex; flex-direction: column; gap: 12px; transition: transform .2s var(--ease-out); }
.ccard:hover { transform: translateY(-2px); }
.ccard .cid { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; color: var(--color-mute); }
.ccard h3 { font-family: var(--font-sans); font-weight: 700; font-size: 19px; letter-spacing: -0.02em; color: var(--color-ink); margin: 0; text-transform: none; }
.ccard .cpain { font-size: 13.5px; color: var(--color-ink-soft); line-height: 1.5; font-style: italic; margin: 0; }
.ccard .cfoot { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding-top: 10px; border-top: 1px solid var(--color-hair); margin-top: auto; }
.ccard .cnb { font-family: var(--font-display); font-weight: 700; font-size: 26px; letter-spacing: -0.03em; color: var(--egis); }
.ccard .cnb small { font-size: 12px; color: var(--color-mute); font-weight: 600; font-family: var(--font-sans); }
/* gradation rail (idée forte cluster) */
.grad { display: flex; gap: 4px; align-items: center; }
.grad .step { width: 22px; height: 5px; border-radius: 999px; background: var(--color-paper-3); }
.grad .step.on0 { background: var(--color-faint); }
.grad .step.on1 { background: var(--color-cobalt); }
.grad .step.on2 { background: var(--color-saffron); }
.grad .step.on3 { background: var(--color-olive); }

/* ───────────────────────────── CHANGELOG */
.changelog { max-width: 860px; padding-bottom: 80px; }
.cl-day { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--color-mute); margin: 26px 0 12px; padding-bottom: 6px; border-bottom: 1px solid var(--color-hair); }
.cl-row { display: grid; grid-template-columns: 86px 1fr; gap: 16px; padding: 11px 0; border-bottom: 1px solid var(--color-hair-soft); cursor: pointer; }
.cl-row:hover { background: var(--color-paper-2); }
.cl-time { font-family: var(--font-mono); font-size: 11px; color: var(--color-faint); padding-top: 2px; }
.cl-main .cl-line { font-size: 14px; color: var(--color-ink); }
.cl-main .cl-line .op { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase;
  padding: 1px 7px; border-radius: 999px; margin-right: 8px; }
.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); }
.cl-main .cl-line a { color: var(--color-ink); font-weight: 600; }
.cl-main .cl-diff { font-family: var(--font-mono); font-size: 11.5px; margin-top: 5px; color: var(--color-mute); }
.cl-main .cl-diff .o { color: var(--color-terra); text-decoration: line-through; }
.cl-main .cl-diff .n { color: var(--color-olive-ink); }
.cl-main .cl-note { font-style: italic; font-size: 12.5px; color: var(--color-mute); margin-top: 4px; }
.cl-actor { font-family: var(--font-mono); font-size: 10px; color: var(--color-mute); }

/* ───────────────────────────── DRAWER */
.overlay { position: fixed; inset: 0; background: rgba(20,14,4,.34); backdrop-filter: blur(3px);
  opacity: 0; pointer-events: none; transition: opacity .2s; z-index: 60; }
.overlay.open { opacity: 1; pointer-events: auto; }
.drawer { position: fixed; top: 0; right: 0; height: 100%; width: min(640px, 94vw); z-index: 61;
  background: var(--color-surface); border-left: 1px solid var(--color-hair);
  transform: translateX(100%); transition: transform .26s var(--ease-out); overflow-y: auto;
  box-shadow: -16px 0 40px -20px rgba(20,14,4,.3); }
.drawer.open { transform: translateX(0); }
.dr-head { position: sticky; top: 0; background: color-mix(in srgb, var(--color-surface) 92%, transparent);
  backdrop-filter: blur(6px); border-bottom: 1px solid var(--color-hair); padding: 22px 30px 18px; }
.dr-head .drtop { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.dr-close { margin-left: auto; background: none; border: 1px solid var(--color-hair); border-radius: 999px;
  width: 32px; height: 32px; color: var(--color-mute); cursor: pointer; font-size: 18px; line-height: 1; }
.dr-close:hover { background: var(--color-paper-2); color: var(--color-ink); }
.dr-head h2 { font-family: var(--font-sans); font-weight: 700; font-size: 23px; letter-spacing: -0.025em;
  line-height: 1.15; color: var(--color-ink); margin: 0; text-transform: none; text-wrap: balance; }
.dr-head .drfam { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--color-mute); margin-top: 8px; }
.dr-body { padding: 24px 30px 60px; }
.dr-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px 24px; }
.dr-section-h { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--egis); margin: 26px 0 4px; padding-bottom: 8px; border-bottom: 1px solid var(--color-hair); }
.field .k { font-family: var(--font-mono); font-size: 9.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--color-faint); }
.field .v { font-size: 14px; color: var(--color-ink); margin-top: 4px; line-height: 1.5; white-space: pre-wrap; }
.field.full { grid-column: 1 / -1; }
.field .v.lead { font-size: 15px; color: var(--color-ink-soft); }
.kvpills { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 5px; }

/* timeline historique */
.tl { margin-top: 12px; }
.tl-ev { position: relative; padding: 0 0 18px 22px; border-left: 1px solid var(--color-hair); }
.tl-ev:last-child { border-left-color: transparent; }
.tl-ev::before { content: ""; position: absolute; left: -5px; top: 3px; width: 9px; height: 9px; border-radius: 999px;
  background: var(--color-surface); border: 2px solid var(--egis); }
.tl-ev.import::before { border-color: var(--color-faint); }
.tl-ev .tl-top { display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; }
.tl-ev .tl-op { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase;
  padding: 1px 7px; border-radius: 999px; }
.tl-ev .tl-when { font-family: var(--font-mono); font-size: 11px; color: var(--color-faint); }
.tl-ev .tl-actor { font-size: 12px; color: var(--color-mute); }
.tl-ev .tl-note { font-style: italic; font-size: 12.5px; color: var(--color-mute); margin-top: 4px; }
.tl-ev .tl-diff { font-family: var(--font-mono); font-size: 11.5px; margin-top: 6px; background: var(--color-paper-2);
  border: 1px solid var(--color-hair); border-radius: 8px; padding: 8px 10px; }
.tl-ev .tl-diff .f { color: var(--color-ink-soft); }
.tl-ev .tl-diff .o { color: var(--color-terra); text-decoration: line-through; }
.tl-ev .tl-diff .n { color: var(--color-olive-ink); }

.empty { text-align: center; color: var(--color-mute); font-style: italic; padding: 70px 20px; font-size: 15px; }

/* entrance — anime UNIQUEMENT le transform, jamais l'opacité : si la
   timeline de l'iframe est figée à t=0 (non peinte / print), le contenu
   reste pleinement visible (juste légèrement décalé, imperceptible). */
.rise { animation: rise .5s var(--ease-out); }
@keyframes rise { from { transform: translateY(7px); } to { transform: translateY(0); } }
@media (prefers-reduced-motion: reduce) { .rise { animation: none; } }

/* responsive */
@media (max-width: 880px) {
  .hero-top { grid-template-columns: 1fr; align-items: start; }
  .kpis { grid-template-columns: 1fr 1fr; }
  .kpi { border-left: 0; border-top: 1px solid var(--color-hair); padding-left: 0; }
  .kpi:first-child, .kpi:nth-child(2) { border-top: 0; }
  .lockup .tag { display: none; }
  /* drawer : une seule colonne (94vw devient trop étroit pour 2) */
  .dr-grid { grid-template-columns: 1fr; }
  /* onglets scrollables horizontalement plutôt que de déborder */
  .tabs { overflow-x: auto; flex-wrap: nowrap; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
  .tabs::-webkit-scrollbar { display: none; }
  .tab { white-space: nowrap; }
}

/* téléphone */
@media (max-width: 560px) {
  /* la barre petrol passe en deux lignes au lieu de se faire couper */
  .topbar .wrap { flex-wrap: wrap; gap: 10px 12px; }
  .live-pill { display: none; }                 /* décoratif — on libère la place */
  .actor-pill { max-width: 60vw; overflow: hidden; }
  .actor-pill #actor-name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

  /* KPI : 2 colonnes resserrées */
  .kpi { padding: 16px 14px 16px 0; }
  .kpi .kval { font-size: 30px; }

  /* toolbar : recherche pleine largeur, contrôles qui se répartissent */
  .search { flex-basis: 100%; min-width: 0; }
  select.sel, button.btn-tool { flex: 1 1 auto; }
  .viewtoggle { flex-basis: 100%; }
  .viewtoggle button { flex: 1; }
  .result-count { flex-basis: 100%; margin-left: 0; }

  /* drawer : marges réduites */
  .dr-head { padding: 18px 18px 14px; }
  .dr-body { padding: 18px 18px 50px; }
}

/* ── section Implémentation (comment le travail de l'UC est fait) ── */
.impl-card { border: 1px solid var(--color-hair); border-radius: 12px;
  background: color-mix(in srgb, var(--egis-soft) 16%, var(--color-surface));
  padding: 16px 18px; margin-top: 6px; }
.impl-badges { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.impl-forme { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--egis-ink); border: 1px solid var(--egis-soft);
  background: color-mix(in srgb, var(--egis-soft) 45%, transparent);
  border-radius: 999px; padding: 4px 11px; }
.impl-statut { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em;
  text-transform: uppercase; border-radius: 999px; padding: 4px 11px;
  border: 1px solid var(--color-hair); color: var(--color-mute); }
.impl-statut.st-poc    { color: var(--color-saffron-ink); border-color: var(--color-saffron);
  background: color-mix(in srgb, var(--color-saffron-soft) 50%, transparent); }
.impl-statut.st-pilote { color: var(--color-cobalt-ink); border-color: var(--color-cobalt);
  background: color-mix(in srgb, var(--color-cobalt-soft) 50%, transparent); }
.impl-statut.st-deploye{ color: var(--color-olive-ink); border-color: var(--color-olive);
  background: color-mix(in srgb, var(--color-olive-soft) 60%, transparent); }
.impl-repo { margin-left: auto; font-family: var(--font-mono); font-size: 11px;
  color: var(--egis); text-decoration: none; }
.impl-repo:hover { text-decoration: underline; }
.impl-md { margin-top: 12px; font-size: 14px; color: var(--color-ink); line-height: 1.55; }
.impl-md h3 { font-size: 13px; margin: 16px 0 4px; color: var(--color-ink); }
.impl-md h4, .impl-md h5 { font-size: 12px; margin: 12px 0 3px; color: var(--color-ink-soft); }
.impl-md p { margin: 6px 0; }
.impl-md ul, .impl-md ol { margin: 6px 0 6px 20px; }
.impl-md code { font-family: var(--font-mono); font-size: 12px;
  background: var(--color-paper-2); padding: 1px 5px; border-radius: 4px; }
.impl-md pre { background: var(--color-paper-2); padding: 12px; border-radius: 8px; overflow-x: auto; }
.impl-md pre code { background: none; padding: 0; }
.impl-md a { color: var(--egis); }
