/* =============================================================
   atlas-edn · Items 139·140·141 (Soins palliatifs pluridisciplinaires)
   Matière Douleur & Anesthésie (.mat-douleur — palette posée par 134-138,
   NON redéfinie ici)
   Variables CSS uniquement — pas de couleurs en dur.
   ============================================================= */

/* ---------- Mindmap : couleurs des familles (3 axes EDN) ---------- */
.fam-def .node-accent      { fill: var(--accent, var(--spe-douleur)); }       /* axe 139 — démarche */
.fam-thera .node-accent    { fill: var(--accent-strong, var(--spe-douleur)); } /* axe 139 — symptômes/ttt */
.fam-clin .node-accent     { fill: var(--accent-blue, var(--spe-cardio)); }   /* axe 139 — organisation */
.fam-fdr .node-accent      { fill: var(--accent-orange, var(--spe-orl)); }    /* axe 140 — cadre légal */
.fam-thera2 .node-accent   { fill: var(--spe-neuro); }                        /* axe 141 — sédation */
.fam-fdr2 .node-accent     { fill: var(--alert-red); }                        /* axe 141 — demande mort */

.node-sat.sat-danger .sat-bg {
  fill: var(--alert-red-soft);
  stroke: var(--alert-red);
  stroke-width: 1.5;
}
.node-sat.sat-danger .sat-title { fill: var(--alert-red); font-weight: 600; }

/* ---------- Vignette + Keypoints + Définitions ---------- */
.kp-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 14px;
  margin-top: 12px;
}
.kp-card {
  background: var(--bg-card);
  border: 1px solid var(--accent-border);
  border-left: 4px solid var(--accent, var(--spe-douleur));
  border-radius: var(--radius-md);
  padding: 14px 16px;
  position: relative;
}
.kp-card .kp-num {
  position: absolute;
  top: 10px; right: 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--ink-muted);
  letter-spacing: 0.08em;
}
.kp-card h3 {
  font-family: var(--font-serif);
  font-size: 15px;
  font-weight: 500;
  color: var(--accent-strong, var(--spe-douleur));
  margin: 0 0 6px;
  padding-right: 24px;
}
.kp-card p,
.kp-card ul {
  margin: 0;
  font-size: 13px;
  line-height: 1.5;
  color: var(--ink);
}
.kp-card ul { padding-left: 18px; }
.kp-card li { margin-bottom: 4px; }

.def-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 12px;
  margin-top: 12px;
}
.def-card-mini {
  background: var(--bg-card);
  border: 1px solid var(--accent-border);
  border-radius: var(--radius-md);
  padding: 12px 14px;
}
.def-card-mini h4 {
  font-family: var(--font-serif);
  font-size: 14px;
  font-weight: 500;
  color: var(--accent-strong, var(--spe-douleur));
  margin: 0 0 6px;
}
.def-card-mini p {
  margin: 0;
  font-size: 12.5px;
  line-height: 1.5;
}

/* ---------- Profil-cards génériques (réutilisé) ---------- */
.profil-card {
  background: var(--bg-card);
  border: 1px solid var(--accent-border);
  border-radius: var(--radius-md);
  padding: 16px 18px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.profil-card-title {
  font-family: var(--font-serif);
  font-size: 17px;
  font-weight: 500;
  color: var(--accent-strong, var(--spe-douleur));
  margin: 0 0 4px;
  padding-bottom: 8px;
  border-bottom: 1px dashed var(--accent-dash);
}
.profil-card .ludic-block { margin: 0; }
.profil-card .ludic-block b {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ink-muted);
  margin-bottom: 2px;
}
.profil-card .ludic-block p,
.profil-card .ludic-block ul {
  margin: 2px 0 0;
  font-size: 13px;
  line-height: 1.5;
}
.profil-card .ludic-block ul { padding-left: 18px; }
.profil-card .ludic-block li { margin-bottom: 3px; }

/* ---------- Vignette ---------- */
.vg-tag {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent-strong, var(--spe-douleur));
  background: var(--accent-soft, var(--bg-card));
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  margin-bottom: 8px;
}
.vignette {
  background: var(--accent-soft, var(--bg-card));
  border-left: 4px solid var(--accent, var(--spe-douleur));
  border-radius: var(--radius-md);
  padding: 14px 18px;
  margin: 12px 0 16px;
  font-size: 13.5px;
  line-height: 1.55;
}
.vignette p { margin: 0; }

/* ---------- Schémas SVG natifs (commun) ---------- */
.schema-fig {
  background: var(--bg-card);
  border: 1px solid var(--accent-border);
  border-radius: var(--radius-md);
  padding: 16px;
  margin: 16px 0;
  text-align: center;
}
.schema-svg {
  width: 100%;
  height: auto;
  max-width: 900px;
  display: block;
  margin: 0 auto;
  color: var(--ink);
}
.schema-fig figcaption {
  font-size: 12px;
  color: var(--ink-muted);
  font-style: italic;
  margin-top: 10px;
  line-height: 1.4;
}

/* ---------- Schéma 1 — Bio-psycho-social-spirituel (4 cercles) ---------- */
.bps-circle {
  fill-opacity: 0.22;
  stroke-width: 2;
}
.bps-bio  { fill: var(--accent, var(--spe-douleur));   stroke: var(--accent-strong, var(--spe-douleur)); }
.bps-psy  { fill: var(--accent-blue, var(--spe-cardio)); stroke: var(--accent-blue, var(--spe-cardio)); }
.bps-soc  { fill: var(--accent-green, var(--spe-pneumo)); stroke: var(--accent-green-strong, var(--spe-pneumo)); }
.bps-spir { fill: var(--accent-orange, var(--spe-orl)); stroke: var(--accent-orange, var(--spe-orl)); }
.schema-bps4 .bps-label { fill: var(--ink); }
.schema-bps4 .bps-center {
  fill: var(--bg-cream);
  stroke: var(--ink);
  stroke-width: 1.5;
}
.schema-bps4 .bps-center-t { fill: var(--ink); font-family: var(--font-serif); }

/* ---------- Schéma 2 — Frise des 5 phases ---------- */
.frp-seg rect {
  stroke: var(--accent-border);
  stroke-width: 1;
}
.frp-seg text { fill: var(--ink); }
.frp-curative rect  { fill: color-mix(in oklab, var(--accent-green, var(--spe-pneumo)) 18%, var(--bg-card)); }
.frp-active rect    { fill: color-mix(in oklab, var(--accent-blue, var(--spe-cardio)) 22%, var(--bg-card)); }
.frp-passive rect   { fill: color-mix(in oklab, var(--accent, var(--spe-douleur)) 22%, var(--bg-card)); }
.frp-terminale rect { fill: color-mix(in oklab, var(--accent-orange, var(--spe-orl)) 26%, var(--bg-card)); }
.frp-agonique rect  { fill: color-mix(in oklab, var(--alert-red) 22%, var(--bg-card)); }
.frp-axe { stroke: var(--ink-muted); stroke-width: 2; fill: none; }
.frp-arrow { fill: var(--ink-muted); }
.frp-bandeau {
  fill: var(--accent-soft, var(--bg-cream));
  stroke: var(--accent-strong, var(--spe-douleur));
  stroke-width: 1.5;
}
.frp-bandeau-t { fill: var(--accent-strong, var(--spe-douleur)); }

/* ---------- Schéma 3 — 3 trajectoires de Murray ---------- */
.schema-murray .mu-axe { stroke: var(--ink); stroke-width: 1.5; fill: none; }
.schema-murray text { fill: var(--ink); }
.mu-cancer { stroke: var(--alert-red); stroke-width: 3; fill: none; }
.mu-organe { stroke: var(--accent-orange, var(--spe-orl)); stroke-width: 2.5; fill: none; }
.mu-neuro  { stroke: var(--accent-green-strong, var(--spe-pneumo)); stroke-width: 2.5; fill: none; }
.mu-cancer-t { fill: var(--alert-red); }
.mu-organe-t { fill: var(--accent-orange, var(--spe-orl)); }
.mu-neuro-t  { fill: var(--accent-green-strong, var(--spe-pneumo)); }

/* ---------- Schéma 4 — Frise chronologique des lois ---------- */
.schema-frise-lois .fl-axe { stroke: var(--accent-dash); stroke-width: 2; fill: none; }
.schema-frise-lois text { fill: var(--ink); }
.fl-jalon circle {
  fill: var(--accent, var(--spe-douleur));
  stroke: var(--accent-strong, var(--spe-douleur));
  stroke-width: 2;
}
.fl-jalon-major circle {
  fill: var(--alert-red);
  stroke: var(--alert-red);
  stroke-width: 3;
}
.fl-arrow { fill: var(--accent-dash); }

/* ---------- Schéma 5 — Procédure collégiale 4 étapes ---------- */
.schema-proc-coll text { fill: var(--ink); }
.pc-prealable {
  fill: var(--accent-soft, var(--bg-card));
  stroke: var(--accent-strong, var(--spe-douleur));
  stroke-width: 1.5;
}
.pc-step {
  fill: var(--bg-card);
  stroke: var(--accent-border);
  stroke-width: 1.5;
}
.pc-step-final {
  fill: var(--accent-soft, var(--bg-cream));
  stroke: var(--accent-strong, var(--spe-douleur));
  stroke-width: 2;
}
.pc-num {
  font-family: var(--font-mono);
  fill: var(--accent-strong, var(--spe-douleur));
  letter-spacing: 0.08em;
}
.pc-link { stroke: var(--accent-strong, var(--spe-douleur)); stroke-width: 2; fill: none; }
.pc-arrow { fill: var(--accent-strong, var(--spe-douleur)); }
.pc-final {
  fill: var(--accent, var(--spe-douleur));
  stroke: var(--accent-strong, var(--spe-douleur));
  stroke-width: 2;
}
.pc-final-t { fill: var(--bg-card); font-weight: 600; }

/* ---------- Tableau natif ---------- */
.natif-table {
  width: 100%;
  border-collapse: collapse;
  margin: 6px 0 18px;
  background: var(--bg-card);
  border: 1px solid var(--accent-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  font-size: 13px;
}
.natif-table thead {
  background: color-mix(in oklab, var(--accent, var(--spe-douleur)) 12%, var(--bg-card));
}
.natif-table th {
  text-align: left;
  padding: 10px 12px;
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--accent-strong, var(--spe-douleur));
  border-bottom: 1px solid var(--accent-border);
}
.natif-table td {
  padding: 9px 12px;
  border-bottom: 1px solid var(--accent-border);
  vertical-align: top;
  line-height: 1.5;
}
.natif-table tr:last-child td { border-bottom: none; }
.natif-table tr:hover td {
  background: color-mix(in oklab, var(--accent-soft, var(--bg-cream)) 30%, var(--bg-card));
}

/* ---------- Bloc soft (cadres réglementaires, notes) ---------- */
.bg-soft {
  background: var(--accent-soft, var(--bg-card));
  border: 1px solid var(--accent-border);
  border-radius: var(--radius-md);
  padding: 12px 16px;
  margin: 14px 0;
}
.bg-soft h4 {
  font-family: var(--font-serif);
  font-size: 14px;
  font-weight: 500;
  margin: 0 0 6px;
  color: var(--accent-strong, var(--spe-douleur));
}
.bg-soft p {
  margin: 0;
  font-size: 13px;
  line-height: 1.55;
}
.bg-soft ul {
  margin: 4px 0 0;
  padding-left: 18px;
  font-size: 13px;
  line-height: 1.5;
}
.bg-soft li { margin-bottom: 3px; }

.regle-or {
  background: color-mix(in oklab, var(--accent, var(--spe-douleur)) 8%, var(--bg-card));
  border-left: 4px solid var(--accent-strong, var(--spe-douleur));
}
.regle-or h4 { color: var(--accent-strong, var(--spe-douleur)); }
.regle-or p { font-style: italic; }

.note-box {
  background: color-mix(in oklab, var(--accent, var(--spe-douleur)) 6%, var(--bg-card));
  border-left: 3px solid var(--accent-dash);
  border-radius: var(--radius-sm);
  padding: 10px 14px;
  margin: 8px 0 14px;
  font-size: 12.5px;
  line-height: 1.55;
  font-style: italic;
}

.surprise-card {
  border-left: 4px solid var(--accent-orange, var(--spe-orl));
  background: color-mix(in oklab, var(--accent-orange, var(--spe-orl)) 8%, var(--bg-card));
}

/* ---------- Alerte rouge ---------- */
.alerte-rouge {
  background: var(--alert-red-soft);
  border-left: 4px solid var(--danger, var(--alert-red));
  border-radius: var(--radius-md);
  padding: 14px 16px;
  margin: 14px 0;
}
.alerte-rouge h4 {
  font-family: var(--font-serif);
  font-size: 15px;
  font-weight: 500;
  margin: 0 0 6px;
  color: var(--danger, var(--alert-red));
}
.alerte-rouge p {
  margin: 0;
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--ink);
}

/* ---------- Onglet 05 — Indicateurs cards ---------- */
.indic-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
  margin-top: 12px;
}
.indic-card {
  background: var(--bg-card);
  border: 1px solid var(--accent-border);
  border-left: 3px solid var(--accent-blue, var(--spe-cardio));
  border-radius: var(--radius-md);
  padding: 14px 16px;
}
.indic-card h4 {
  font-family: var(--font-serif);
  font-size: 14px;
  font-weight: 500;
  color: var(--accent-strong, var(--spe-douleur));
  margin: 0 0 8px;
}
.indic-card ul { margin: 0; padding-left: 18px; font-size: 13px; line-height: 1.5; }
.indic-card li { margin-bottom: 3px; }

/* ---------- Onglet 06 — Symptômes par système ---------- */
.symp-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 14px;
  margin-top: 12px;
}
.symp-card {
  background: var(--bg-card);
  border: 1px solid var(--accent-border);
  border-top: 3px solid var(--accent, var(--spe-douleur));
  border-radius: var(--radius-md);
  padding: 14px 16px;
}
.symp-card h4 {
  font-family: var(--font-serif);
  font-size: 15px;
  font-weight: 500;
  color: var(--accent-strong, var(--spe-douleur));
  margin: 0 0 8px;
  padding-bottom: 6px;
  border-bottom: 1px dashed var(--accent-dash);
}
.symp-card ul { margin: 0; padding-left: 18px; font-size: 13px; line-height: 1.5; }
.symp-card li { margin-bottom: 5px; }

/* ---------- Onglet 07 — Traitements cards (Rang A ⭐⭐⭐) ---------- */
.ttt-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
  gap: 16px;
  margin-top: 12px;
}
.ttt-card {
  border-left: 4px solid var(--accent-strong, var(--spe-douleur));
}

/* Démarche occlusion 3 étapes */
.occl-wrap { display: flex; flex-direction: column; gap: 14px; margin-top: 12px; }
.occl-etape {
  background: var(--bg-card);
  border: 1px solid var(--accent-border);
  border-left: 4px solid var(--accent-orange, var(--spe-orl));
  border-radius: var(--radius-md);
  padding: 14px 16px;
}
.occl-etape h4 {
  font-family: var(--font-serif);
  font-size: 15px;
  font-weight: 500;
  color: var(--accent-strong, var(--spe-douleur));
  margin: 0 0 8px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.occl-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--accent-orange, var(--spe-orl));
  color: var(--bg-card);
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 700;
}
.occl-etape ul { margin: 0; padding-left: 18px; font-size: 13px; line-height: 1.5; }
.occl-etape li { margin-bottom: 4px; }

/* ---------- Onglet 09 — Piliers Claeys-Leonetti ---------- */
.piliers-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 14px;
  margin-top: 12px;
}
.pilier-card {
  background: var(--bg-card);
  border: 1px solid var(--accent-border);
  border-left: 4px solid var(--accent-orange, var(--spe-orl));
  border-radius: var(--radius-md);
  padding: 14px 16px;
  position: relative;
}
.pilier-card .pilier-num {
  position: absolute;
  top: 10px; right: 12px;
  font-family: var(--font-mono);
  font-size: 22px;
  font-weight: 700;
  color: color-mix(in oklab, var(--accent-orange, var(--spe-orl)) 60%, var(--bg-card));
}
.pilier-card h4 {
  font-family: var(--font-serif);
  font-size: 15px;
  font-weight: 500;
  color: var(--accent-strong, var(--spe-douleur));
  margin: 0 0 4px;
  padding-right: 32px;
}
.pilier-ref {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: 6px;
}
.pilier-card p {
  margin: 0;
  font-size: 13px;
  line-height: 1.5;
}

/* ---------- Onglet 10 — DA + PC cards ---------- */
.dapc-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
  gap: 16px;
  margin-top: 12px;
}
.dapc-card { border-left: 4px solid var(--accent-orange, var(--spe-orl)); }
.dapc-card .pilier-ref { padding-bottom: 6px; border-bottom: 1px dashed var(--accent-dash); margin-bottom: 8px; }

/* ---------- Onglet 11 — Mécanismes patient & soignants ---------- */
.meca-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 14px;
  margin-top: 12px;
}
.meca-card {
  padding: 14px 16px;
}
.meca-positif  { border-left: 4px solid var(--accent-green-strong, var(--spe-pneumo)); }
.meca-defensif { border-left: 4px solid var(--accent-orange, var(--spe-orl)); }
.meca-soignant { border-left: 4px solid var(--alert-red); }

/* Refus scenarios */
.refus-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 14px;
  margin-top: 12px;
}
.refus-card {
  background: var(--bg-card);
  border: 1px solid var(--accent-border);
  border-radius: var(--radius-md);
  padding: 14px 16px;
}
.refus-card.tone-safe    { border-left: 4px solid var(--accent-green-strong, var(--spe-pneumo)); }
.refus-card.tone-caution { border-left: 4px solid var(--accent-orange, var(--spe-orl)); }
.refus-card.tone-rang-a  { border-left: 4px solid var(--alert-red); }
.refus-card h4 {
  font-family: var(--font-serif);
  font-size: 14px;
  font-weight: 500;
  color: var(--accent-strong, var(--spe-douleur));
  margin: 0 0 8px;
}
.refus-card ul { margin: 0; padding-left: 18px; font-size: 13px; line-height: 1.5; }
.refus-card li { margin-bottom: 3px; }

/* ---------- Onglet 12 — Sédation : checklist + Midazolam ---------- */
.checklist-wrap {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 14px;
  margin-top: 12px;
}
.checklist-section {
  background: var(--bg-card);
  border: 1px solid var(--accent-border);
  border-left: 3px solid var(--spe-neuro);
  border-radius: var(--radius-md);
  padding: 14px 16px;
}
.checklist-section h4 {
  font-family: var(--font-serif);
  font-size: 14px;
  font-weight: 500;
  color: var(--accent-strong, var(--spe-douleur));
  margin: 0 0 8px;
}
.checklist-section ul { margin: 0; padding-left: 18px; font-size: 13px; line-height: 1.5; }
.checklist-section li { margin-bottom: 4px; }

.midazolam-card {
  border-left: 4px solid var(--spe-neuro);
}

/* ---------- Onglet 14 — Pathologies (4 cards flashcard rubricée) ---------- */
.patho-wrap {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
  gap: 16px;
  margin-top: 12px;
}
.patho-card { padding: 16px 18px; }
.patho-cancer { border-left: 4px solid var(--alert-red); }
.patho-hemato { border-left: 4px solid var(--accent-orange, var(--spe-orl)); }
.patho-organe { border-left: 4px solid var(--accent-blue, var(--spe-cardio)); }
.patho-neuro  { border-left: 4px solid var(--spe-neuro); }
