/* ==========================================================================
   Item 92 · Déficit sensitif et/ou moteur des membres — styles spécifiques
   Item de DÉMARCHE syndromique et topographique (zoom anatomique fin du 91).
   Charge après styles.css + components.css. Reprend les composants
   structurels du 91 et ajoute :
   - tableau géant 4 syndromes moteurs avec cellules discriminantes mises en couleur
   - schéma anatomique custom des 3 voies en parallèle (SVG)
   - coupe médullaire avec overlays toggleables (5 syndromes)
   - profils anatomiques SNC en cartes
   - arbre décisionnel paraclinique simplifié (template 340)
   ========================================================================== */

:root {
  --paper:    #faf6ec;
  --paper-2:  #fffcf5;
  --rule:     #d7ccb4;
  --rule-2:   var(--accent-dash);
  --bg-2:     #ece5d6;
  --bg-3:     #e4dcc8;
  --ink-2:    #524a3e;
  --ink-3:    #8a8270;
  --ink-4:    #b2a98f;
  --danger:   #a52a1a;
  --warn:     #8a5a12;
  --ok:       #4e6a2f;
  --info:     #2f5e6b;

  /* Familles thématiques pour ce cours */
  --fam-def:    var(--spe-neuro);     /* aubergine principal · syndromes moteurs */
  --fam-dx:     var(--spe-cardio);    /* bleu canard · démarche/diagnostic */
  --fam-sens:   var(--spe-cardio);    /* bleu · voies sensitives */
  --fam-warn:   var(--accent-orange); /* orange · spinothalamique, JNM */
  --fam-danger: var(--danger);
  --fam-topo:   #b35a8a;              /* rose éteint · topographies */
  --fam-th:     var(--ok);            /* vert · paraclinique */
  --fam-info:   var(--info);
  --fam-ok:     var(--ok);

  /* Cellules discriminantes (tableau géant) */
  --cell-danger-bg: #f3dccf;
  --cell-warn-bg:   #f5e6ce;
  --cell-info-bg:   #d8e3e7;
}

.content { max-width: 1400px; }

@keyframes deficit-fadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: none; }
}
.content-panel.active { animation: deficit-fadeIn .35s ease-out; }

.mono   { font-family: var(--font-mono); }
.serif  { font-family: var(--font-serif); }
.muted  { color: var(--ink-3); }
.danger { color: var(--danger); }
.warn   { color: var(--warn); }

/* =========================================================
   Familles utilitaires
   ========================================================= */
.fam-def     { --fam: var(--fam-def);     --fam-bg: #ead8e4; }
.fam-dx      { --fam: var(--fam-dx);      --fam-bg: #cfdde0; }
.fam-sens    { --fam: var(--fam-sens);    --fam-bg: #cfdde0; }
.fam-warn    { --fam: var(--fam-warn);    --fam-bg: #f4e0cf; }
.fam-danger  { --fam: var(--fam-danger);  --fam-bg: #f3dccf; }
.fam-topo    { --fam: var(--fam-topo);    --fam-bg: #ead8e0; }
.fam-th      { --fam: var(--fam-th);      --fam-bg: #dde2c8; }
.fam-info    { --fam: var(--fam-info);    --fam-bg: #cfdde0; }
.fam-ok      { --fam: var(--fam-ok);      --fam-bg: #dde2c8; }

/* =========================================================
   Section titles (repris du 91)
   ========================================================= */
.sec-title       { display: flex; align-items: baseline; gap: 16px; margin: 36px 0 18px; flex-wrap: wrap; }
.sec-num         { font-family: var(--font-mono); font-size: 11px; letter-spacing: .18em; color: var(--ink-3); text-transform: uppercase; }
.sec-title h2    { font-family: var(--font-serif); font-weight: 500; font-size: 30px; letter-spacing: -.01em; margin: 0; line-height: 1; }
.sec-title .rule { flex: 1; height: 1px; background: var(--rule); margin-bottom: 8px; min-width: 40px; }
.sec-title .hint { font-family: var(--font-mono); font-size: 11px; color: var(--ink-3); letter-spacing: .06em; }

.rang-tag {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase;
  padding: 3px 8px; border-radius: 2px;
  border: 1px solid var(--rule-2); color: var(--ink-2); background: var(--paper);
}
.rang-tag.rang-a { color: var(--ok);    border-color: color-mix(in oklab, var(--ok) 40%, var(--rule-2)); }
.rang-tag.rang-b { color: var(--ink-3); border-color: var(--rule-2); }

/* =========================================================
   Vignette + keypoints + définitions (repris 91)
   ========================================================= */
.vignette {
  background: var(--paper); border: 1px solid var(--rule);
  border-left: 4px solid var(--fam-def);
  border-radius: 4px; padding: 20px 24px; margin: 14px 0;
}
.vignette .vg-tag {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--ink-3); margin-bottom: 10px;
}
.vignette p { margin: 0 0 12px; font-style: italic; color: var(--ink-2); line-height: 1.65; font-size: 14.5px; }
.vignette .vg-questions {
  margin: 12px 0 0; padding: 12px 16px;
  background: var(--paper-2); border-left: 3px solid var(--fam-dx); border-radius: 3px;
}
.vignette .vg-questions ul { margin: 0; padding-left: 18px; font-size: 13px; color: var(--ink-2); line-height: 1.6; }
.vignette .vg-questions ul li { margin: 4px 0; }
.vignette .vg-questions ul li b { color: var(--ink); }
.vignette .vg-decode {
  margin-top: 12px; padding: 12px 16px;
  background: color-mix(in oklab, var(--fam-def) 6%, var(--paper-2));
  border-left: 3px solid var(--fam-def); border-radius: 3px;
  font-size: 13px; color: var(--ink-2); line-height: 1.6;
}
.vignette .vg-decode b { color: var(--ink); }

.keypoints { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin: 14px 0; }
.kp-card {
  background: var(--paper); border: 1px solid var(--rule);
  border-top: 3px solid var(--fam-def);
  border-radius: 3px; padding: 14px 16px;
}
.kp-card .kp-n {
  display: inline-block; font-family: var(--font-mono); font-size: 11px;
  font-weight: 600; color: var(--fam-def); margin-bottom: 4px; letter-spacing: .08em;
}
.kp-card h4 { font-family: var(--font-serif); font-weight: 500; font-size: 16px; margin: 0 0 8px; line-height: 1.25; }
.kp-card p  { margin: 0; font-size: 13px; color: var(--ink-2); line-height: 1.55; }
.kp-card p b { color: var(--ink); }
.kp-card p a { color: var(--fam-dx); text-decoration: underline; }

.def-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; margin: 14px 0; }
.def-card {
  background: var(--paper); border: 1px solid var(--rule);
  border-left: 3px solid var(--fam-def);
  border-radius: 3px; padding: 14px 16px;
}
.def-card h4 { font-family: var(--font-serif); font-weight: 500; font-size: 16px; margin: 0 0 6px; color: var(--fam-def); }
.def-card p  { margin: 0; font-size: 13px; color: var(--ink-2); line-height: 1.55; }
.def-card p b { color: var(--ink); }

/* =========================================================
   Encadrés d'alerte clinique
   ========================================================= */
.alert-clinical {
  background: #f3dccf; border: 1px solid var(--danger);
  border-radius: 4px; padding: 16px 20px;
  display: grid; grid-template-columns: 44px 1fr; gap: 16px; align-items: start;
  margin: 18px 0;
}
.alert-clinical .alert-icon {
  font-family: var(--font-serif); font-size: 32px; line-height: 1;
  color: var(--danger); font-style: italic; font-weight: 500;
}
.alert-clinical h4 {
  font-family: var(--font-serif); font-weight: 500; font-size: 18px;
  letter-spacing: -.005em; color: var(--danger); margin: 0 0 8px;
}
.alert-clinical p  { margin: 4px 0; font-size: 13px; color: var(--ink-2); line-height: 1.55; }
.alert-clinical p b { color: var(--ink); }
.alert-clinical ul { margin: 4px 0 0; padding-left: 18px; font-size: 13px; color: var(--ink-2); line-height: 1.55; }
.alert-clinical ul li { margin: 4px 0; }
.alert-clinical ul li b { color: var(--ink); font-weight: 600; }
.alert-clinical a { color: var(--danger); text-decoration: underline; }

/* Encart pédagogique générique */
.encart-mnemo {
  background: var(--paper-2); border: 1px solid var(--accent-dash);
  border-left: 3px solid var(--fam-dx); border-radius: 3px;
  padding: 14px 16px; margin: 16px 0;
}
.encart-mnemo h4 {
  font-family: var(--font-serif); font-weight: 500; font-size: 15.5px;
  margin: 0 0 8px; color: var(--fam-dx);
}
.encart-mnemo ol,
.encart-mnemo ul { margin: 4px 0 0; padding-left: 22px; font-size: 13px; color: var(--ink-2); line-height: 1.6; }
.encart-mnemo ol li,
.encart-mnemo ul li { margin: 4px 0; }
.encart-mnemo ol li b,
.encart-mnemo ul li b { color: var(--ink); }
.encart-mnemo p { margin: 4px 0; font-size: 13px; color: var(--ink-2); line-height: 1.6; }
.encart-mnemo p b { color: var(--ink); }

.note-renvoi {
  background: var(--bg-2); border-left: 3px solid var(--ink-3);
  border-radius: 3px; padding: 12px 14px; margin: 14px 0;
  font-size: 12.5px; color: var(--ink-2); line-height: 1.55; font-style: italic;
}
.note-renvoi b { color: var(--ink); font-style: normal; }
.note-renvoi a { color: var(--fam-dx); text-decoration: underline; font-style: normal; }

/* =========================================================
   TABLEAU GÉANT 4 SYNDROMES MOTEURS (onglet 04)
   ========================================================= */
.giant-table-wrap {
  background: var(--paper); border: 1px solid var(--rule);
  border-radius: 4px; padding: 18px; margin: 16px 0;
  overflow-x: auto;
}
.giant-table {
  width: 100%; border-collapse: separate; border-spacing: 0;
  font-size: 13px; line-height: 1.5;
}
.giant-table thead th {
  background: var(--paper-2);
  font-family: var(--font-serif); font-weight: 500;
  font-size: 15px; letter-spacing: -.005em;
  color: var(--ink); padding: 12px 10px;
  border-bottom: 2px solid var(--rule);
  text-align: left; vertical-align: top;
  position: sticky; top: 0; z-index: 2;
}
.giant-table thead th:first-child { width: 16%; }
.giant-table thead th .gth-sub {
  display: block; font-family: var(--font-mono); font-size: 10px;
  letter-spacing: .08em; color: var(--ink-3); text-transform: uppercase;
  margin-top: 3px; font-weight: 400;
}
.giant-table tbody th {
  background: var(--bg-2); font-weight: 500; text-align: left;
  padding: 10px 10px; border-bottom: 1px solid var(--rule);
  color: var(--ink); font-size: 13px;
}
.giant-table tbody td {
  padding: 10px 10px; border-bottom: 1px solid var(--rule);
  vertical-align: top; color: var(--ink-2);
}
.giant-table tbody td b { color: var(--ink); }

/* Cellules discriminantes — niveaux 1 (info), 2 (warn), 3 (danger) */
.giant-table td.hi-1 { background: var(--cell-info-bg); }
.giant-table td.hi-2 { background: var(--cell-warn-bg); }
.giant-table td.hi-3 { background: var(--cell-danger-bg); color: var(--ink); font-weight: 500; }

.giant-table tbody tr:hover td { background: color-mix(in oklab, var(--fam-def) 4%, var(--paper-2)); }
.giant-table tbody tr:hover td.hi-1,
.giant-table tbody tr:hover td.hi-2,
.giant-table tbody tr:hover td.hi-3 { filter: brightness(.97); }

.giant-table-legend {
  margin-top: 10px; font-family: var(--font-mono); font-size: 11px;
  color: var(--ink-3); letter-spacing: .04em;
  display: flex; gap: 18px; flex-wrap: wrap;
}
.giant-table-legend .lg-chip {
  display: inline-flex; align-items: center; gap: 6px;
}
.giant-table-legend .lg-chip::before {
  content: ''; width: 10px; height: 10px; border-radius: 2px; border: 1px solid var(--rule);
}
.giant-table-legend .lg-info::before    { background: var(--cell-info-bg); }
.giant-table-legend .lg-warn::before    { background: var(--cell-warn-bg); }
.giant-table-legend .lg-danger::before  { background: var(--cell-danger-bg); }

/* Cartes 1er motoneurone / 2nd motoneurone / JNM / muscle (dessous tableau) */
.mn-cards {
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 14px; margin: 18px 0;
}
.mn-card {
  background: var(--paper); border: 1px solid var(--rule);
  border-left: 3px solid var(--fam, var(--fam-def));
  border-radius: 3px; padding: 14px 16px;
}
.mn-card h4 {
  font-family: var(--font-serif); font-weight: 500; font-size: 17px;
  color: var(--fam, var(--fam-def)); margin: 0 0 4px;
}
.mn-card .mn-sub {
  display: block; font-family: var(--font-mono); font-size: 10px;
  letter-spacing: .12em; text-transform: uppercase;
  color: var(--ink-3); margin-bottom: 8px;
}
.mn-card ul { margin: 4px 0 0; padding-left: 18px; font-size: 13px; color: var(--ink-2); line-height: 1.55; }
.mn-card li { margin: 5px 0; }
.mn-card li b { color: var(--ink); }
.mn-card a { color: var(--fam-dx); text-decoration: underline; }

/* =========================================================
   Démarche sensitive (onglet 05) — voies + tableaux SNC/SNP
   ========================================================= */
.voies-grid {
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 14px; margin: 14px 0;
}
.voie-card {
  background: var(--paper); border: 1px solid var(--rule);
  border-top: 3px solid var(--fam, var(--fam-sens));
  border-radius: 3px; padding: 14px 16px;
}
.voie-card h4 { font-family: var(--font-serif); font-weight: 500; font-size: 17px; color: var(--fam, var(--fam-sens)); margin: 0 0 4px; }
.voie-card .voie-sub { display: block; font-family: var(--font-mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 8px; }
.voie-card ul { margin: 4px 0 0; padding-left: 18px; font-size: 13px; color: var(--ink-2); line-height: 1.55; }
.voie-card li { margin: 5px 0; }
.voie-card li b { color: var(--ink); }

/* Tableau matrix générique (utilisé pour SNP/SNC sensitif, etc.) */
.matrix {
  width: 100%; border-collapse: separate; border-spacing: 0;
  font-size: 13px; margin: 14px 0;
  background: var(--paper); border: 1px solid var(--rule);
  border-radius: 4px; overflow: hidden;
}
.matrix thead th {
  background: var(--bg-2); font-family: var(--font-serif); font-weight: 500;
  font-size: 14.5px; padding: 11px 12px; text-align: left;
  color: var(--ink); border-bottom: 1px solid var(--rule);
}
.matrix tbody th {
  background: var(--paper-2); font-weight: 500; padding: 10px 12px;
  text-align: left; color: var(--ink); font-size: 13px;
  border-bottom: 1px solid var(--rule); width: 22%; vertical-align: top;
}
.matrix tbody td {
  padding: 10px 12px; border-bottom: 1px solid var(--rule);
  color: var(--ink-2); vertical-align: top;
}
.matrix tbody td b { color: var(--ink); }
.matrix tbody td a { color: var(--fam-dx); text-decoration: underline; }
.matrix tbody td ul { margin: 4px 0 0; padding-left: 18px; }
.matrix tbody td ul li { margin: 4px 0; }
.matrix tbody tr:last-child th,
.matrix tbody tr:last-child td { border-bottom: none; }

/* =========================================================
   Anatomie des voies (onglet 06) — schéma SVG + texte
   ========================================================= */
.anat-wrap {
  background: var(--paper); border: 1px solid var(--rule);
  border-radius: 4px; padding: 18px; margin: 14px 0;
  display: grid; grid-template-columns: 1fr 1fr; gap: 22px;
  align-items: start;
}
@media (max-width: 1100px) { .anat-wrap { grid-template-columns: 1fr; } }
.anat-svg {
  width: 100%; max-width: 600px;
  background: var(--paper-2); border: 1px solid var(--rule); border-radius: 4px;
  padding: 8px;
}
.anat-svg .anat-bg-spine { fill: var(--bg-3); stroke: var(--ink-3); stroke-width: 1; }
.anat-svg .anat-region { fill: var(--paper-2); stroke: var(--ink-3); stroke-width: 1; }
.anat-svg .anat-label { font-family: var(--font-mono); font-size: 9px; fill: var(--ink-3); letter-spacing: .04em; }
.anat-svg .anat-region-label { font-family: var(--font-serif); font-size: 12px; fill: var(--ink); font-weight: 500; }
.anat-svg .voie-pyr { stroke: var(--spe-neuro); stroke-width: 3; fill: none; }
.anat-svg .voie-lem { stroke: var(--spe-cardio); stroke-width: 3; fill: none; }
.anat-svg .voie-sth { stroke: var(--accent-orange); stroke-width: 3; fill: none; }
.anat-svg .voie-pyr.dashed,
.anat-svg .voie-lem.dashed,
.anat-svg .voie-sth.dashed { stroke-dasharray: 4 3; }
.anat-svg .decuss-star { font-size: 18px; }
.anat-svg .voie-hidden { display: none; }
.anat-svg circle.endpoint { fill: var(--paper); stroke: var(--ink); stroke-width: 1; }

.anat-legend {
  display: flex; gap: 14px; flex-wrap: wrap; margin: 12px 0 0;
  padding: 10px; background: var(--paper-2); border-radius: 4px;
}
.anat-legend button {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--paper); border: 1px solid var(--rule);
  border-radius: 16px; padding: 4px 12px;
  font-family: var(--font-sans); font-size: 12px; color: var(--ink-2);
  cursor: pointer; transition: all .2s;
}
.anat-legend button:hover { background: var(--bg-2); }
.anat-legend button[aria-pressed="true"] { background: color-mix(in oklab, var(--lg-c, var(--ink)) 12%, var(--paper)); border-color: var(--lg-c, var(--ink)); }
.anat-legend button .lg-dot {
  display: inline-block; width: 12px; height: 4px; border-radius: 2px;
  background: var(--lg-c, var(--ink));
}
.anat-legend button[aria-pressed="false"] { opacity: .45; }

.anat-text { font-size: 13px; color: var(--ink-2); line-height: 1.6; }
.anat-text h4 { font-family: var(--font-serif); font-weight: 500; font-size: 16px; margin: 0 0 6px; color: var(--fam-def); }
.anat-text .voie-block { padding: 10px 12px; margin: 10px 0; background: var(--paper-2); border-left: 3px solid var(--fam, var(--fam-def)); border-radius: 3px; }
.anat-text .voie-block ul { margin: 4px 0 0; padding-left: 18px; }
.anat-text .voie-block li { margin: 4px 0; }
.anat-text .voie-block li b { color: var(--ink); }
.anat-text .face-note {
  margin-top: 12px; padding: 10px 12px;
  background: var(--bg-2); border-radius: 3px;
}
.anat-text .face-note h5 { font-family: var(--font-serif); font-weight: 500; font-size: 14px; margin: 0 0 4px; }

/* =========================================================
   Profils anatomiques SNC en cartes (onglet 07)
   ========================================================= */
.profils-grid {
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 14px; margin: 14px 0;
}
.profil-card {
  background: var(--paper); border: 1px solid var(--rule);
  border-top: 3px solid var(--fam, var(--fam-def));
  border-radius: 3px; padding: 14px 16px;
}
.profil-card h4 {
  font-family: var(--font-serif); font-weight: 500; font-size: 17px;
  color: var(--fam, var(--fam-def)); margin: 0 0 8px;
}
.profil-card .profil-line {
  font-size: 13px; color: var(--ink-2); line-height: 1.55;
  margin: 6px 0; display: grid; grid-template-columns: 90px 1fr; gap: 10px;
}
.profil-card .profil-line b { color: var(--ink); }
.profil-card .profil-line .label {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .08em;
  text-transform: uppercase; color: var(--ink-3); padding-top: 1px;
}
.profil-card .profil-line a { color: var(--fam-dx); text-decoration: underline; }

/* =========================================================
   Hémiplégie (onglet 08) — cartes par mode
   ========================================================= */
.modes-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 14px; margin: 14px 0;
}
.mode-card {
  background: var(--paper); border: 1px solid var(--rule);
  border-top: 3px solid var(--fam, var(--fam-def));
  border-radius: 3px; padding: 14px 16px;
}
.mode-card h5 { font-family: var(--font-serif); font-weight: 500; font-size: 16px; color: var(--fam, var(--fam-def)); margin: 0 0 4px; }
.mode-card .mode-sub { display: block; font-family: var(--font-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 8px; }
.mode-card ul { margin: 4px 0 0; padding-left: 18px; font-size: 12.5px; color: var(--ink-2); line-height: 1.55; }
.mode-card li { margin: 4px 0; }
.mode-card li b { color: var(--ink); }
.mode-card a { color: var(--fam-dx); text-decoration: underline; }

/* =========================================================
   Syndromes médullaires (onglet 10) — cartes + coupe SVG
   ========================================================= */
.medul-wrap {
  display: grid; grid-template-columns: 320px 1fr; gap: 22px;
  align-items: start; margin: 14px 0;
}
@media (max-width: 1100px) { .medul-wrap { grid-template-columns: 1fr; } }

.medul-svg {
  background: var(--paper-2); border: 1px solid var(--rule); border-radius: 4px;
  padding: 12px; position: sticky; top: 80px;
}
.medul-svg svg { width: 100%; height: auto; }
.medul-svg .axis { fill: var(--ink); stroke: var(--ink-3); stroke-width: 1; }
.medul-svg .struct-fill   { fill: var(--paper-2); stroke: var(--ink-3); stroke-width: 1; }
.medul-svg .gris            { fill: #b8a89a; stroke: var(--ink-3); stroke-width: 1; }
.medul-svg .commissure-grise{ fill: var(--accent-orange); opacity: .35; stroke: var(--accent-orange); stroke-width: 1.2; }
.medul-svg .cordon-post { fill: color-mix(in oklab, var(--spe-cardio) 18%, var(--paper-2)); stroke: var(--spe-cardio); stroke-width: 1.2; }
.medul-svg .cordon-lat  { fill: color-mix(in oklab, var(--accent-orange) 18%, var(--paper-2)); stroke: var(--accent-orange); stroke-width: 1.2; }
.medul-svg .cordon-vent { fill: color-mix(in oklab, var(--spe-neuro) 12%, var(--paper-2)); stroke: var(--spe-neuro); stroke-width: 1.2; }

.medul-svg .overlay { display: none; }
.medul-svg .overlay.active { display: block; }
.medul-svg .ov-shade { fill: var(--danger); opacity: .25; }
.medul-svg .ov-shade-warn { fill: var(--accent-orange); opacity: .3; }
.medul-svg .ov-shade-info { fill: var(--spe-cardio); opacity: .3; }
.medul-svg .ov-shade-mid  { fill: var(--accent-orange); opacity: .45; }

.medul-svg text { font-family: var(--font-mono); font-size: 9px; fill: var(--ink-3); letter-spacing: .04em; }
.medul-svg text.tlabel { font-family: var(--font-serif); font-size: 11px; fill: var(--ink); font-style: italic; }

.medul-controls {
  margin-top: 10px; display: flex; flex-direction: column; gap: 6px;
}
.medul-controls button {
  background: var(--paper); border: 1px solid var(--rule); border-radius: 3px;
  padding: 6px 10px; font-family: var(--font-sans); font-size: 12px;
  text-align: left; color: var(--ink-2); cursor: pointer;
}
.medul-controls button[aria-pressed="true"] {
  background: color-mix(in oklab, var(--fam-def) 12%, var(--paper));
  border-color: var(--fam-def); color: var(--ink);
}

.medul-cards { display: grid; gap: 14px; }
.medul-card {
  background: var(--paper); border: 1px solid var(--rule);
  border-left: 3px solid var(--fam, var(--fam-def));
  border-radius: 3px; padding: 14px 16px;
}
.medul-card h4 { font-family: var(--font-serif); font-weight: 500; font-size: 17px; color: var(--fam, var(--fam-def)); margin: 0 0 6px; }
.medul-card .medul-atteinte { font-size: 12.5px; color: var(--ink-3); font-style: italic; margin: 0 0 8px; }
.medul-card ul { margin: 4px 0 0; padding-left: 18px; font-size: 13px; color: var(--ink-2); line-height: 1.55; }
.medul-card li { margin: 5px 0; }
.medul-card li b { color: var(--ink); }
.medul-card .medul-etios {
  margin-top: 10px; padding: 8px 12px;
  background: var(--bg-2); border-radius: 3px; font-size: 12.5px;
}
.medul-card .medul-etios b { color: var(--ink); }

/* =========================================================
   Queue de cheval (onglet 11)
   ========================================================= */
.queue-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 14px; margin: 14px 0;
}
.queue-card {
  background: var(--paper); border: 1px solid var(--rule);
  border-top: 3px solid var(--danger);
  border-radius: 3px; padding: 14px 16px;
}
.queue-card h4 { font-family: var(--font-serif); font-weight: 500; font-size: 16px; color: var(--danger); margin: 0 0 8px; }
.queue-card ul { margin: 4px 0 0; padding-left: 18px; font-size: 13px; color: var(--ink-2); line-height: 1.55; }
.queue-card li { margin: 5px 0; }
.queue-card li b { color: var(--ink); }

/* =========================================================
   Algorithme paraclinique (onglet 12)
   ========================================================= */
.algo-table { width: 100%; border-collapse: separate; border-spacing: 0; font-size: 13px; margin: 14px 0; background: var(--paper); border: 1px solid var(--rule); border-radius: 4px; overflow: hidden; }
.algo-table thead th { background: var(--bg-2); font-family: var(--font-serif); font-weight: 500; font-size: 14.5px; padding: 11px 12px; text-align: left; color: var(--ink); border-bottom: 1px solid var(--rule); }
.algo-table tbody td { padding: 10px 12px; border-bottom: 1px solid var(--rule); color: var(--ink-2); vertical-align: top; }
.algo-table tbody td b { color: var(--ink); }
.algo-table tbody tr:last-child td { border-bottom: none; }
.algo-table .pres { width: 28%; }
.algo-table .exam { width: 32%; font-weight: 500; }
.algo-table .exam-1 { background: color-mix(in oklab, var(--ok) 10%, var(--paper)); }
.algo-table .urg-bullet { display: inline-block; width: 10px; height: 10px; border-radius: 50%; margin-right: 6px; vertical-align: middle; }
.algo-table .urg-danger { background: var(--danger); }
.algo-table .urg-warn   { background: var(--accent-orange); }
.algo-table .urg-info   { background: var(--info); }
.algo-table .urg-ok     { background: var(--ok); }

.role-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 12px; margin: 14px 0;
}
.role-card {
  background: var(--paper-2); border: 1px solid var(--rule);
  border-left: 3px solid var(--fam-dx);
  border-radius: 3px; padding: 12px 14px;
}
.role-card h5 { font-family: var(--font-serif); font-weight: 500; font-size: 15px; color: var(--fam-dx); margin: 0 0 6px; }
.role-card ul { margin: 4px 0 0; padding-left: 18px; font-size: 12.5px; color: var(--ink-2); line-height: 1.5; }
.role-card li { margin: 4px 0; }
.role-card li b { color: var(--ink); }

/* Arbre décisionnel SVG (template 340) */
.diagtree-svg {
  background: var(--paper); border: 1px solid var(--rule);
  border-radius: 4px; padding: 12px; margin: 14px 0; overflow-x: auto;
}
.diagtree-svg svg { display: block; margin: auto; max-width: 100%; height: auto; }
.diagtree-svg .dt-svg-entry rect { fill: var(--bg-2); stroke: var(--ink-3); stroke-width: 1; }
.diagtree-svg .dt-svg-action .dt-bg { fill: var(--paper-2); stroke: var(--rule); stroke-width: 1; }
.diagtree-svg .dt-svg-action.acc-dx     .dt-accent { fill: var(--fam-dx); }
.diagtree-svg .dt-svg-action.acc-warn   .dt-accent { fill: var(--accent-orange); }
.diagtree-svg .dt-svg-action.acc-danger .dt-accent { fill: var(--danger); }
.diagtree-svg .dt-svg-action.acc-ok     .dt-accent { fill: var(--ok); }
.diagtree-svg .dt-svg-action.acc-grey   .dt-accent { fill: var(--ink-3); }
.diagtree-svg .dt-svg-arrow path { fill: none; stroke-width: 1.5; }
.diagtree-svg .arr-grey   path { stroke: var(--ink-3); }
.diagtree-svg .arr-ok     path { stroke: var(--ok); }
.diagtree-svg .arr-warn   path { stroke: var(--accent-orange); }
.diagtree-svg .arr-danger path { stroke: var(--danger); }
.diagtree-svg .mh-grey   { fill: var(--ink-3); }
.diagtree-svg .mh-ok     { fill: var(--ok); }
.diagtree-svg .mh-warn   { fill: var(--accent-orange); }
.diagtree-svg .mh-danger { fill: var(--danger); }
.diagtree-svg .dt-lbl-bg { fill: var(--paper); stroke: var(--rule); stroke-width: 1; }
.diagtree-svg .dt-lbl    { font-family: var(--font-mono); font-size: 10px; fill: var(--ink-2); letter-spacing: .06em; }
.diagtree-svg .dt-fo {
  font-family: var(--font-sans); font-size: 12px; color: var(--ink-2);
  line-height: 1.45;
}
.diagtree-svg .dt-fo-htitle {
  font-family: var(--font-serif); font-weight: 500; font-size: 14px;
  color: var(--ink); margin-bottom: 4px;
}
.diagtree-svg .dt-fo-tag {
  font-family: var(--font-mono); font-size: 9px; letter-spacing: .12em;
  text-transform: uppercase; color: var(--ink-3); margin-bottom: 2px;
}
.diagtree-svg .dt-fo ul { margin: 4px 0 0; padding-left: 16px; font-size: 11.5px; }
.diagtree-svg .dt-fo li { margin: 2px 0; }
.diagtree-svg .dt-fo li b { color: var(--ink); }

/* =========================================================
   Étiologies par mode (onglet 13)
   ========================================================= */
.mode-table { width: 100%; }

/* =========================================================
   DD non neuro (onglet 14)
   ========================================================= */
.dd-list {
  display: grid; gap: 12px; margin: 14px 0;
}
.dd-row {
  background: var(--paper); border: 1px solid var(--rule);
  border-left: 3px solid var(--warn);
  border-radius: 3px; padding: 14px 16px;
}
.dd-row h4 { font-family: var(--font-serif); font-weight: 500; font-size: 16px; color: var(--warn); margin: 0 0 8px; }
.dd-row ul { margin: 4px 0 0; padding-left: 18px; font-size: 13px; color: var(--ink-2); line-height: 1.55; }
.dd-row li { margin: 5px 0; }
.dd-row li b { color: var(--ink); }

/* =========================================================
   Complications + sujet âgé (onglet 15)
   ========================================================= */
.compli-table {
  width: 100%; border-collapse: separate; border-spacing: 0;
  font-size: 13px; margin: 14px 0;
  background: var(--paper); border: 1px solid var(--rule);
  border-radius: 4px; overflow: hidden;
}
.compli-table thead th {
  background: var(--bg-2); font-family: var(--font-serif); font-weight: 500;
  font-size: 14.5px; padding: 11px 12px; text-align: left;
  color: var(--ink); border-bottom: 1px solid var(--rule);
}
.compli-table tbody th {
  background: var(--paper-2); font-weight: 500; padding: 10px 12px;
  text-align: left; color: var(--ink); font-size: 13px;
  border-bottom: 1px solid var(--rule); width: 30%; vertical-align: top;
}
.compli-table tbody td {
  padding: 10px 12px; border-bottom: 1px solid var(--rule);
  color: var(--ink-2); vertical-align: top;
}
.compli-table tbody td b { color: var(--ink); }
.compli-table tbody tr:last-child th,
.compli-table tbody tr:last-child td { border-bottom: none; }

.sa-card {
  background: var(--paper); border: 1px solid var(--warn);
  border-left: 4px solid var(--warn);
  border-radius: 4px; padding: 16px 20px; margin: 16px 0;
}
.sa-card h4 { font-family: var(--font-serif); font-weight: 500; font-size: 18px; color: var(--warn); margin: 0 0 4px; }
.sa-card .sa-sub { font-size: 13px; color: var(--ink-3); font-style: italic; margin: 0 0 10px; }
.sa-card ul { margin: 4px 0 0; padding-left: 18px; font-size: 13px; color: var(--ink-2); line-height: 1.55; }
.sa-card li { margin: 5px 0; }
.sa-card li b { color: var(--ink); }
.sa-card .sa-pec {
  margin-top: 12px; padding: 10px 12px;
  background: var(--paper-2); border-radius: 3px; font-size: 13px; color: var(--ink-2);
}
.sa-card .sa-pec b { color: var(--ink); }

.aside-resume {
  margin: 14px 0; padding: 12px 16px;
  background: color-mix(in oklab, var(--ok) 8%, var(--paper));
  border-left: 3px solid var(--ok); border-radius: 3px;
  font-size: 13.5px; color: var(--ink); font-style: italic;
}
.aside-resume::before { content: '✓ '; color: var(--ok); font-style: normal; font-weight: 600; }

/* =========================================================
   Mindmap (commun avec 91/194)
   ========================================================= */
.mmwrap {
  position: relative; width: 100%; height: 740px;
  background: var(--paper); border: 1px solid var(--rule); border-radius: 4px;
  overflow: hidden;
}
.mmwrap svg.canvas { width: 100%; height: 100%; cursor: grab; user-select: none; }
.mmwrap svg.canvas:active { cursor: grabbing; }
.zctl {
  position: absolute; top: 12px; right: 12px;
  display: flex; gap: 6px; z-index: 5;
}
.zctl button {
  width: 32px; height: 32px; border-radius: 4px;
  background: var(--paper); border: 1px solid var(--rule);
  font-family: var(--font-mono); font-size: 16px; color: var(--ink-2);
}
.zctl button:hover { background: var(--bg-2); }
.zhint {
  position: absolute; bottom: 10px; left: 12px; z-index: 5;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: .06em;
  color: var(--ink-3);
}

.mmwrap .ring { fill: none; stroke: var(--rule); stroke-dasharray: 3 3; stroke-width: 1; }
.mmwrap .link.main { fill: none; stroke: var(--rule); stroke-width: 1.5; }
.mmwrap .link.sat  { fill: none; stroke: var(--rule); stroke-width: 1; stroke-dasharray: 2 3; }

.mmwrap .root-circle { fill: var(--bg-dark); stroke: var(--rule); stroke-width: 1; }
.mmwrap .root-text   { fill: #faf6ec; font-family: var(--font-serif); }

.mmwrap .node-card { cursor: pointer; }
.mmwrap .node-card .node-bg { fill: var(--paper); stroke: var(--rule); stroke-width: 1; }
.mmwrap .node-card .node-accent { fill: var(--fam, var(--fam-def)); }
.mmwrap .node-card.fam-def    .node-accent { fill: var(--fam-def); }
.mmwrap .node-card.fam-dx     .node-accent { fill: var(--fam-dx); }
.mmwrap .node-card.fam-sens   .node-accent { fill: var(--fam-sens); }
.mmwrap .node-card.fam-warn   .node-accent { fill: var(--fam-warn); }
.mmwrap .node-card.fam-th     .node-accent { fill: var(--fam-th); }
.mmwrap .node-card.fam-topo   .node-accent { fill: var(--fam-topo); }
.mmwrap .node-chip { fill: var(--bg-2); }
.mmwrap .node-chip-t { font-family: var(--font-mono); font-size: 9px; fill: var(--ink-3); letter-spacing: .08em; }
.mmwrap .node-title { font-family: var(--font-serif); font-size: 16px; font-weight: 500; fill: var(--ink); }
.mmwrap .node-sub   { font-family: var(--font-sans); font-size: 11px; fill: var(--ink-2); }
.mmwrap .node-card:hover .node-bg { fill: var(--paper-2); stroke: var(--ink-3); }

.mmwrap .node-sat { cursor: pointer; }
.mmwrap .node-sat .sat-bg { fill: var(--paper-2); stroke: var(--accent-dash); stroke-width: 1; }
.mmwrap .node-sat:hover .sat-bg { fill: var(--bg-2); stroke: var(--ink-3); }
.mmwrap .node-sat .sat-title { font-family: var(--font-serif); font-size: 13px; font-weight: 500; fill: var(--ink); }
.mmwrap .node-sat .sat-sub   { font-family: var(--font-sans); font-size: 10px; fill: var(--ink-3); }

/* =========================================================
   Tabs + content (commun)
   ========================================================= */
.tabs-wrapper { background: var(--paper); border-bottom: 1px solid var(--rule); position: sticky; top: 48px; z-index: 4; }
.tabs { display: flex; gap: 0; max-width: 1400px; margin: auto; overflow-x: auto; padding: 0 16px; }
.tab {
  background: transparent; border: none; padding: 14px 14px;
  font-family: var(--font-sans); font-size: 13px; color: var(--ink-3);
  border-bottom: 2px solid transparent; white-space: nowrap;
  display: inline-flex; gap: 8px; align-items: center;
}
.tab .tab-num { font-family: var(--font-mono); font-size: 11px; letter-spacing: .08em; color: var(--ink-4); }
.tab.active { color: var(--ink); border-bottom-color: var(--fam-def); }
.tab.active .tab-num { color: var(--fam-def); }
.tab:hover { color: var(--ink-2); }

.content { padding: 22px 24px 60px; max-width: 1400px; margin: auto; }
.content-panel { display: none; }
.content-panel.active { display: block; }
