/* ═══════════════════════════════════════════════════════════════════
 * fiche.css — refonte de la fiche UC (page #/uc/ID).
 * Pose une vraie hiérarchie sur les 12 sections empilées : header fort +
 * décision en avant + 2 colonnes (récit / contexte). Réutilise les tokens
 * et le langage Egis (Inter, teal #00617E, lime, niveaux, chips, timeline).
 * Variables locales pour brancher les Tweaks (densité, layout, header).
 * ═══════════════════════════════════════════════════════════════════ */

.fpage {
  --gap: 22px;
  --card-pad: 22px;
  --rail-w: 348px;
  --maxw: 1220px;
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 22px clamp(16px, 4vw, 40px) 100px;
}
.fpage.dense { --gap: 14px; --card-pad: 16px; }

/* ── fil + retour ── */
.fcrumb {
  display: flex; align-items: center; gap: 10px;
  font-size: 13px; color: var(--color-mute); margin-bottom: 14px;
}
.fcrumb .fback {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--card); border: 1px solid var(--color-hair); border-radius: 999px;
  padding: 6px 14px; font-weight: 600; color: var(--color-ink-soft); cursor: pointer;
  transition: all var(--t-fast, .18s) ease;
}
.fcrumb .fback:hover { border-color: var(--primary); color: var(--primary); }
.fcrumb .sep { opacity: .5; }
.fcrumb .here { color: var(--color-ink); font-weight: 600; }

/* ════════ HERO / EN-TÊTE ════════ */
.fhero {
  position: relative; overflow: hidden;
  background: var(--card); border: 1px solid var(--color-hair);
  border-radius: var(--r-lg); box-shadow: var(--shadow-sm);
  padding: 22px 26px 0;
  margin-bottom: var(--gap);
}
/* bandeau teal optionnel (Tweak header=band) */
.fpage.head-band .fhero {
  background: #013a4b;
  background-image: linear-gradient(135deg, var(--primary-darker), var(--primary-dark) 55%, #0a6378);
  border-color: transparent; color: #fff;
}
.fpage.head-band .fhero .fh-fam,
.fpage.head-band .fhero .fh-meta { color: rgba(255,255,255,.72); }
.fpage.head-band .fhero h1 { color: #fff; }
.fpage.head-band .fhero .uc-id { background: rgba(255,255,255,.16); color: #fff; }
.fpage.head-band .fnav { background: rgba(255,255,255,.08); border-top-color: rgba(255,255,255,.16); }
.fpage.head-band .fnav a { color: rgba(255,255,255,.74); }
.fpage.head-band .fnav a:hover, .fpage.head-band .fnav a.on { color: #fff; }
.fpage.head-band .fnav a.on::after { background: var(--accent); }

.fh-row1 { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.fh-row1 .uc-id {
  font-family: var(--font-mono); font-weight: 700; font-size: 12px; letter-spacing: .04em;
  background: var(--bg); color: var(--color-ink-soft); padding: 3px 9px; border-radius: 6px;
}
.fh-fam {
  font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
  color: var(--color-mute);
}
.fh-spacer { flex: 1; }
.fh-meta { font-size: 12px; color: var(--color-mute); display: inline-flex; gap: 12px; align-items: center; }
.fh-code {
  display: inline-flex; align-items: center; gap: 5px; white-space: nowrap; font-family: var(--font-mono);
  font-size: 11px; font-weight: 600; color: var(--primary);
  border: 1px solid var(--egis-soft); background: color-mix(in srgb, var(--egis-soft) 30%, transparent);
  padding: 4px 10px; border-radius: 999px;
}
.fpage.head-band .fh-code { color: #fff; border-color: rgba(255,255,255,.3); background: rgba(255,255,255,.1); }

.fhero h1 {
  font-size: clamp(22px, 2.6vw, 30px); font-weight: 800; letter-spacing: -0.02em;
  line-height: 1.15; margin: 14px 0 0; color: var(--color-ink); max-width: 30ch;
}

/* strip décision : verdict + priorité + statut, le 1er coup d'œil */
.fh-strip {
  display: flex; align-items: stretch; gap: 14px; flex-wrap: wrap;
  margin: 18px 0 20px;
}
.verdict {
  display: inline-flex; align-items: center; gap: 9px;
  padding: 9px 16px 9px 13px; border-radius: 12px; font-weight: 800; font-size: 15px;
  letter-spacing: -0.01em; border: 1px solid transparent; white-space: nowrap;
}
.verdict .va { font-family: var(--font-mono); font-weight: 700; opacity: .8; font-size: 13px; }
.verdict.act-lancer     { background: var(--color-olive-soft);  color: var(--color-olive-ink);  border-color: color-mix(in srgb, var(--color-olive) 40%, transparent); }
.verdict.act-approfondir { background: var(--color-cobalt-soft); color: var(--color-cobalt-ink); border-color: color-mix(in srgb, var(--color-cobalt) 35%, transparent); }
.verdict.act-regrouper  { background: var(--color-saffron-soft); color: var(--color-saffron-ink); border-color: color-mix(in srgb, var(--color-saffron) 45%, transparent); }
.verdict.act-outiller   { background: var(--egis-soft); color: var(--egis-ink); border-color: color-mix(in srgb, var(--primary) 30%, transparent); }
.verdict.act-ecarter    { background: var(--color-terra-soft); color: var(--color-terra-ink); border-color: color-mix(in srgb, var(--color-terra) 35%, transparent); }

.prio-pill {
  display: inline-flex; flex-direction: column; justify-content: center;
  padding: 7px 16px; border-radius: 12px; border: 1px solid var(--color-hair); background: var(--bg-alt);
}
.prio-pill .pl { font-size: 9.5px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: var(--color-mute); }
.prio-pill .pv { font-size: 18px; font-weight: 800; color: var(--color-ink); letter-spacing: -0.02em; }
.prio-pill .pv small { font-size: 11px; font-weight: 700; color: var(--color-faint); }
.fpage.head-band .prio-pill { background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.2); }
.fpage.head-band .prio-pill .pl { color: rgba(255,255,255,.7); }
.fpage.head-band .prio-pill .pv { color: #fff; }
.fpage.head-band .prio-pill .pv small { color: rgba(255,255,255,.6); }

.fh-badges { display: inline-flex; align-items: center; gap: 8px; flex-wrap: wrap; }

/* nav d'ancres / onglets, collée en bas du hero */
.fnav {
  display: flex; gap: 2px; flex-wrap: wrap;
  margin: 0 -26px; padding: 0 18px;
  border-top: 1px solid var(--color-hair); background: var(--bg-alt);
  border-radius: 0 0 var(--r-lg) var(--r-lg);
}
.fnav a {
  position: relative; padding: 12px 14px; font-size: 13px; font-weight: 700;
  color: var(--color-mute); cursor: pointer; user-select: none; white-space: nowrap;
}
.fnav a:hover { color: var(--color-ink); }
.fnav a.on { color: var(--primary); }
.fnav a.on::after {
  content: ""; position: absolute; left: 12px; right: 12px; bottom: -1px; height: 2.5px;
  background: var(--primary); border-radius: 2px;
}
.fnav .cnt { font-family: var(--font-mono); font-weight: 600; font-size: 10px; opacity: .65; margin-left: 5px; }

/* ════════ CORPS : 2 colonnes ════════ */
.fbody {
  display: grid; grid-template-columns: minmax(0, 1fr) var(--rail-w);
  gap: var(--gap); align-items: start;
}
.fmain, .frail { display: flex; flex-direction: column; gap: var(--gap); min-width: 0; }

/* layout single : tout en colonne */
.fpage.mode-single .fbody { display: block; }
.fpage.mode-single .fmain { margin-bottom: var(--gap); }
.fpage.mode-single .fmain, .fpage.mode-single .frail { display: flex; }

/* layout onglets : flux unique filtré par groupe */
.fnav.as-anchors { }                 /* mode 2-col : ancres */
.fpage.mode-tabs .fbody { display: block; max-width: 860px; }
.fpage.mode-tabs .fmain, .fpage.mode-tabs .frail { display: contents; }
.fpage.mode-tabs .fcard { margin-bottom: var(--gap); }
.fpage.mode-tabs .fcard[data-group] { display: none; }
.fpage.mode-tabs .fcard.tab-on { display: block; }

/* ════════ CARTE GÉNÉRIQUE ════════ */
.fcard {
  background: var(--card); border: 1px solid var(--color-hair);
  border-radius: var(--r-lg); box-shadow: var(--shadow-sm);
  padding: var(--card-pad);
}
.fcard.flush { padding: 0; overflow: hidden; }

.fsec-h { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.fsec-n {
  font-family: var(--font-mono); font-size: 10px; font-weight: 700; letter-spacing: .08em; white-space: nowrap;
  color: var(--primary); border: 1px solid var(--egis-soft); border-radius: 6px;
  padding: 2px 7px; background: color-mix(in srgb, var(--egis-soft) 25%, transparent);
}
.fsec-t { font-size: 14px; font-weight: 800; letter-spacing: -0.01em; color: var(--color-ink); text-transform: none; }
.fsec-hint { margin-left: auto; font-size: 11.5px; color: var(--color-faint); font-weight: 600; }
.fsec-act {
  margin-left: auto; font-size: 12px; font-weight: 700; color: var(--color-mute);
  background: none; border: 1px solid var(--color-hair); border-radius: 999px; padding: 4px 12px; cursor: pointer;
}
.fsec-act:hover { border-color: var(--primary); color: var(--primary); }

/* ════════ LE BESOIN — 3 temps ════════ */
.besoin { display: flex; flex-direction: column; gap: 0; }
.beat { padding: 14px 0; border-top: 1px dashed var(--color-hair); }
.beat:first-child { border-top: 0; padding-top: 2px; }
.beat .blab {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: 10.5px; font-weight: 800; letter-spacing: .07em; text-transform: uppercase;
  margin-bottom: 7px;
}
.beat .blab .bd { width: 8px; height: 8px; border-radius: 999px; }
.beat .btext { font-size: 14.5px; line-height: 1.6; color: var(--color-ink); }
.beat.b-pain   .blab { color: var(--color-terra-ink); }   .beat.b-pain .bd   { background: var(--color-terra); }
.beat.b-sol    .blab { color: var(--primary); }            .beat.b-sol .bd    { background: var(--primary); }
.beat.b-benef  .blab { color: var(--color-olive-ink); }    .beat.b-benef .bd  { background: var(--color-olive); }
/* la réponse IA est le cœur : encadré teint */
.beat.b-sol {
  background: color-mix(in srgb, var(--egis-soft) 18%, transparent);
  border-radius: var(--r-md); border: 1px solid color-mix(in srgb, var(--primary) 16%, transparent);
  border-top: 1px solid color-mix(in srgb, var(--primary) 16%, transparent);
  padding: 14px 16px; margin: 12px 0;
}
.beat.b-sol .btext { font-weight: 500; }
.beat.b-benef {
  display: flex; gap: 12px; align-items: baseline;
}

/* ════════ DÉCISION ════════ */
.decision .dec-top { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; margin-bottom: 12px; }
.decision .just { font-size: 14px; line-height: 1.6; color: var(--color-ink-soft); margin: 0 0 14px; }
.dec-meta { display: flex; gap: 8px; flex-wrap: wrap; }
.metachip {
  display: inline-flex; flex-direction: column; gap: 1px;
  border: 1px solid var(--color-hair); border-radius: var(--r-sm); padding: 6px 12px; background: var(--bg-alt);
}
.metachip .mk { font-size: 9px; font-weight: 800; letter-spacing: .07em; text-transform: uppercase; color: var(--color-mute); }
.metachip .mv { font-size: 13px; font-weight: 700; color: var(--color-ink); }
.metachip.p1 .mv { color: var(--color-terra-ink); }
.metachip.yes .mv { color: var(--color-olive-ink); }

/* ════════ IMPLÉMENTATION ════════ */
.impl-badges { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 12px; }
.impl-forme {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; font-weight: 700;
  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: .1em; text-transform: uppercase; font-weight: 700;
  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, .impl-demo {
  font-family: var(--font-mono); font-size: 11px; font-weight: 600; color: var(--primary);
  border: 1px solid var(--egis-soft); border-radius: 999px; padding: 4px 11px;
}
/* le 1er lien (démo ou code) cale le groupe de liens à droite */
.impl-badges > a:first-of-type { margin-left: auto; }
.impl-repo:hover, .impl-demo:hover { background: var(--egis-soft); }

/* ════════ SCORING / PRIORISATION ════════ */
.gate {
  display: flex; align-items: center; gap: 12px; padding: 12px 14px; margin-bottom: 16px;
  border-radius: var(--r-md); border: 1px solid var(--color-hair); background: var(--bg-alt);
}
.gate .gt { font-size: 13px; font-weight: 800; color: var(--color-ink); }
.gate .gsub { font-size: 11.5px; color: var(--color-mute); }
.gate .gscore { margin-left: auto; }
.dots { display: inline-flex; gap: 4px; }
.dots .dt { width: 11px; height: 11px; border-radius: 999px; background: var(--color-paper-3); }
.dots .dt.on { background: var(--primary); }

.axis { padding: 13px 0; border-top: 1px solid var(--color-hair); }
.axis:first-of-type { border-top: 0; }
.axis-head { display: flex; align-items: baseline; gap: 10px; margin-bottom: 9px; }
.axis-name { font-size: 13px; font-weight: 800; color: var(--color-ink); }
.axis-comp { margin-left: auto; font-size: 15px; font-weight: 800; color: var(--primary); letter-spacing: -0.02em; }
.axis-comp small { font-size: 10px; color: var(--color-faint); font-weight: 700; }
.bar { height: 7px; border-radius: 999px; background: var(--color-paper-3); overflow: hidden; margin-bottom: 10px; }
.bar > i { display: block; height: 100%; border-radius: 999px; background: linear-gradient(90deg, var(--primary), var(--egis-bright)); }
.crit-row { display: flex; flex-wrap: wrap; gap: 6px; }
.crit {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: 11.5px; border: 1px solid var(--color-hair); border-radius: 999px; padding: 3px 6px 3px 10px; background: var(--card);
}
.crit .ck { color: var(--color-ink-soft); font-weight: 600; }
.crit .cv {
  font-family: var(--font-mono); font-weight: 700; font-size: 11px; color: #fff; background: var(--primary);
  border-radius: 999px; min-width: 18px; height: 18px; display: inline-flex; align-items: center; justify-content: center; padding: 0 5px;
}
.crit .cv.lo { background: var(--color-faint); }

.team { margin-top: 14px; border-top: 1px solid var(--color-hair); padding-top: 12px; }
.team-h { font-size: 11px; font-weight: 800; letter-spacing: .05em; text-transform: uppercase; color: var(--color-mute); margin-bottom: 8px; }
.team table { width: 100%; border-collapse: collapse; font-size: 12.5px; }
.team th { text-align: right; font-weight: 700; color: var(--color-mute); font-size: 10.5px; text-transform: uppercase; letter-spacing: .03em; padding: 4px 6px; }
.team th:first-child { text-align: left; }
.team td { text-align: right; padding: 5px 6px; border-top: 1px solid var(--color-hair-soft); color: var(--color-ink); font-variant-numeric: tabular-nums; }
.team td:first-child { text-align: left; font-weight: 600; color: var(--color-ink-soft); }
.team tr.avg td { font-weight: 800; color: var(--color-ink); border-top: 1.5px solid var(--color-hair-classic); }

/* ════════ NOTES ════════ */
.note-tabs { display: flex; gap: 6px; margin-bottom: 14px; }
.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.on { background: var(--primary); color: #fff; border-color: var(--primary); }
.note-pane[hidden] { display: none; }
.note-foot { display: flex; gap: 8px; margin-top: 12px; }
.btn-pri { background: var(--primary); color: #fff; border: 0; border-radius: var(--r-sm); font: inherit; font-weight: 700; font-size: 12.5px; padding: 7px 15px; cursor: pointer; }
.btn-pri:hover { background: var(--primary-dark); }
.btn-ghost2 { background: none; border: 1px solid var(--color-hair); color: var(--color-mute); border-radius: var(--r-sm); font: inherit; font-weight: 700; font-size: 12.5px; padding: 7px 15px; cursor: pointer; }
.btn-ghost2:hover { border-color: var(--primary); color: var(--primary); }
.note-other { border-left: 3px solid var(--accent); background: rgba(171,192,34,.07); border-radius: var(--r-sm); padding: 11px 13px; margin-top: 10px; }
.note-meta { font-size: 11px; color: var(--color-mute); margin-bottom: 4px; font-weight: 700; }
.note-empty { color: var(--color-faint); font-style: italic; font-size: 13px; }

/* markdown (scopé .fpage : ne pas écraser le .md de la vue howto) */
.fpage .md { font-size: 13.5px; line-height: 1.6; color: var(--color-ink); }
.fpage .md > :first-child { margin-top: 0; } .fpage .md > :last-child { margin-bottom: 0; }
.fpage .md p { margin: 0 0 9px; } .fpage .md ul { margin: 0 0 9px; padding-left: 18px; } .fpage .md li { margin: 2px 0; }
.fpage .md h3, .fpage .md h4, .fpage .md h5 { font-size: 14px; font-weight: 800; margin: 14px 0 6px; letter-spacing: -0.01em; }
.fpage .md code { font-family: var(--font-mono); font-size: .86em; background: var(--bg); border: 1px solid var(--color-hair); padding: 1px 5px; border-radius: 5px; }
.fpage .md pre { background: var(--bg); border: 1px solid var(--color-hair); border-radius: var(--r-sm); padding: 10px 12px; overflow-x: auto; margin: 0 0 9px; }
.fpage .md pre code { background: none; border: 0; padding: 0; }
.fpage .md strong { font-weight: 700; color: var(--color-ink); }
.fpage .md a { color: var(--primary); text-decoration: underline; }

/* ════════ HISTORIQUE ════════ */
.histo .tl { margin-top: 4px; }
.tl-ev { position: relative; padding: 0 0 16px 20px; border-left: 1px solid var(--color-hair); }
.tl-ev:last-child { border-left-color: transparent; padding-bottom: 0; }
.tl-ev::before { content: ""; position: absolute; left: -5px; top: 3px; width: 9px; height: 9px; border-radius: 999px; background: var(--card); border: 2px solid var(--primary); }
.tl-ev.import::before { border-color: var(--color-faint); }
.tl-top { display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; }
.tl-op { font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .05em; padding: 1px 7px; border-radius: 999px; background: var(--bg); color: var(--color-mute); }
.tl-op.update { background: var(--color-cobalt-soft); color: var(--color-cobalt-ink); }
.tl-op.note   { background: rgba(171,192,34,.18); color: var(--accent-dark); }
.tl-op.import { background: var(--color-paper-3); color: var(--color-mute); }
.tl-when { font-family: var(--font-mono); font-size: 11px; color: var(--color-faint); }
.tl-actor { font-size: 12px; color: var(--color-mute); font-weight: 600; }
.tl-note { font-style: italic; font-size: 12.5px; color: var(--color-mute); margin-top: 3px; }
.tl-diff { font-family: var(--font-mono); font-size: 11.5px; margin-top: 6px; background: var(--bg-alt); border: 1px solid var(--color-hair); border-radius: var(--r-sm); padding: 7px 10px; display: inline-block; }
.tl-diff .f { color: var(--color-ink-soft); } .tl-diff .o { color: var(--color-terra); text-decoration: line-through; } .tl-diff .n { color: var(--color-olive-ink); }

/* ════════ RAIL : cartes contexte ════════ */
.kv { display: flex; flex-direction: column; gap: 0; }
.kv .kvr { display: flex; gap: 12px; align-items: baseline; justify-content: space-between; padding: 8px 0; border-top: 1px solid var(--color-hair-soft); }
.kv .kvr:first-child { border-top: 0; padding-top: 0; }
.kv .kk { font-size: 11px; font-weight: 700; letter-spacing: .03em; text-transform: uppercase; color: var(--color-mute); white-space: nowrap; }
.kv .kvv { font-size: 13px; font-weight: 600; color: var(--color-ink); text-align: right; }

.chiprow { display: flex; flex-wrap: wrap; gap: 6px; }
.pilote-chip {
  font-size: 12px; font-weight: 600; color: var(--color-ink-soft);
  border: 1px solid var(--color-hair); border-radius: 999px; padding: 3px 11px; background: var(--bg-alt);
}

.contact { display: flex; align-items: baseline; gap: 8px; flex-wrap: wrap; padding: 9px 0; border-top: 1px solid var(--color-hair-soft); font-size: 13px; }
.contact:first-child { border-top: 0; padding-top: 0; }
.ct-name { font-weight: 700; color: var(--color-ink); }
.ct-role { color: var(--color-ink-soft); font-size: 12px; }
.ct-pil { font-size: 10px; font-weight: 700; background: rgba(171,192,34,.18); color: var(--accent-dark); padding: 2px 8px; border-radius: 999px; }
.ct-mail { color: var(--primary); font-size: 11.5px; margin-left: auto; }

.rsrc { display: flex; align-items: center; gap: 9px; padding: 8px 0; border-top: 1px solid var(--color-hair-soft); }
.rsrc:first-child { border-top: 0; padding-top: 0; }
.rsrc a { color: var(--primary); font-weight: 600; font-size: 12.5px; word-break: break-word; }
.rsrc a:hover { text-decoration: underline; }
.rsrc-kind { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; background: var(--egis-soft); color: var(--egis-ink); padding: 2px 8px; border-radius: 999px; margin-left: auto; white-space: nowrap; }

/* DDPO — gouvernance, violet */
.fcard.ddpo-card { border-left: 4px solid var(--ddpo); }
.ddpo-card .fsec-n { color: var(--ddpo-ink); border-color: var(--ddpo-soft); background: color-mix(in srgb, var(--ddpo-soft) 35%, transparent); }
.ddpo-card .kvv.ok { color: var(--color-olive-ink); }

/* badges header réutilisés (niv/chip/qw/rex) — assure le look même hors viewer.css */
.fh-badges .niv { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; font-weight: 700; color: #fff; padding: 3px 10px; border-radius: 999px; }
.fh-badges .niv .nd { width: 6px; height: 6px; border-radius: 999px; background: rgba(255,255,255,.85); }
.fh-badges .niv.N0 { background: var(--niv0); } .fh-badges .niv.N1 { background: var(--niv1); } .fh-badges .niv.N2 { background: var(--niv2); } .fh-badges .niv.N3 { background: var(--niv3); }
.fh-badges .chip { font-size: 12px; font-weight: 600; border-radius: 999px; border: 1px solid var(--color-hair); background: var(--card); color: var(--color-ink-soft); padding: 3px 11px; }
.fpage.head-band .fh-badges .chip { background: rgba(255,255,255,.12); border-color: rgba(255,255,255,.22); color: #fff; }
.fpage .qw { display: inline-flex; align-items: center; gap: 4px; font-size: 12px; font-weight: 700; color: var(--color-saffron-ink); }
.fpage .qw .star { color: var(--niv3); }
.fpage .rex { display: inline-flex; align-items: center; gap: 5px; font-size: 12px; font-weight: 700; color: var(--niv2); }
.fpage .rex .rd { width: 7px; height: 7px; border-radius: 999px; background: var(--niv2); }
.fpage.head-band .qw, .fpage.head-band .rex { color: #fff; }

/* ════════ ÉDITION (ajouts live, hors prototype read-only) ════════ */
/* éditeur de scoring, replié par défaut sous le visuel */
.sc-edit { margin-top: 14px; border-top: 1px solid var(--color-hair); padding-top: 14px; }
.sc-edit .sc-axis { margin-bottom: 10px; }
.sc-edit .sc-axis-h { font-size: 11px; font-weight: 800; letter-spacing: .04em; text-transform: uppercase; color: var(--color-mute); margin-bottom: 6px; display: flex; align-items: baseline; gap: 8px; }
.sc-edit .sc-comp { margin-left: auto; font-family: var(--font-mono); font-weight: 700; color: var(--primary); }
.sc-edit .sc-row { display: flex; align-items: center; gap: 10px; padding: 5px 0; }
.sc-edit .sc-lbl { flex: 1; font-size: 12.5px; color: var(--color-ink-soft); }
.sc-edit .sc-in { width: 56px; font: inherit; font-family: var(--font-mono); text-align: center; border: 1px solid var(--color-hair); border-radius: var(--r-sm); padding: 5px 6px; background: var(--card); color: var(--color-ink); }
.sc-edit .sc-in:focus { outline: none; border-color: var(--primary); }
.sc-edit-actions { display: flex; align-items: center; gap: 10px; margin-top: 12px; }
.sc-prio { font-size: 12px; font-weight: 700; color: var(--color-mute); }

/* boutons d'édition génériques dans les cartes */
.fcard .note-save, .fcard .addbtn { background: var(--primary); color: #fff; border: 0; border-radius: var(--r-sm); font: inherit; font-weight: 700; font-size: 12.5px; padding: 7px 15px; cursor: pointer; }
.fcard .note-save:hover, .fcard .addbtn:hover { background: var(--primary-dark); }
.fcard .note-cancel { background: none; border: 1px solid var(--color-hair); color: var(--color-mute); border-radius: var(--r-sm); font: inherit; font-weight: 700; font-size: 12.5px; padding: 7px 15px; cursor: pointer; }
.fcard .note-input { width: 100%; box-sizing: border-box; font: inherit; font-size: 13.5px; line-height: 1.55; border: 1px solid var(--color-hair); border-radius: var(--r-md); padding: 11px 13px; resize: vertical; color: var(--color-ink); background: var(--card); }
.fcard .note-input:focus { outline: none; border-color: var(--primary); }
.fcard .md-hint { font-family: var(--font-mono); font-size: 10px; font-weight: 600; color: var(--color-faint); margin-left: 6px; }

/* boutons supprimer (× discret) sur items éditables du rail */
.x-del { margin-left: auto; background: none; border: 0; color: var(--color-faint); font-size: 16px; line-height: 1; cursor: pointer; padding: 0 2px; }
.x-del:hover { color: var(--color-terra-ink); }
.rsrc .x-del, .contact .x-del { margin-left: 4px; }

/* formulaire d'ajout compact, empilé dans le rail étroit */
.frail .addrow { display: flex; flex-direction: column; gap: 7px; margin-top: 12px; padding-top: 12px; border-top: 1px dashed var(--color-hair); }
.fmain .addrow { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }
.addrow .ai { font: inherit; font-size: 12.5px; border: 1px solid var(--color-hair); border-radius: var(--r-sm); padding: 7px 10px; background: var(--card); color: var(--color-ink); min-width: 0; }
.frail .addrow .ai { width: 100%; box-sizing: border-box; }
.fmain .addrow .ai { flex: 1; }
.addrow .ai:focus { outline: none; border-color: var(--primary); }
.add-toggle { background: none; border: 1px dashed var(--color-hair); border-radius: var(--r-sm); color: var(--color-mute); font: inherit; font-weight: 700; font-size: 12px; padding: 6px 12px; cursor: pointer; margin-top: 10px; width: 100%; }
.add-toggle:hover { border-color: var(--primary); color: var(--primary); }

@media (max-width: 920px) {
  .fbody { grid-template-columns: 1fr; }
  .fnav { overflow-x: auto; }
}
