/* ==========================================================================
   Item 230 · Douleur thoracique aiguë (Cardiologie)
   Palette --spe-cardio dominante (bleu canard #2f5e6b) + 4 couleurs PIED
   sémantiques (P=cardio, I=danger, E=info, D=fdr/orange).
   Variables CSS uniquement — pas de couleurs en dur dans les règles.
   ========================================================================== */

:root {
  --paper:    var(--bg-card);
  --paper-2:  #fffcf5;
  --rule:     #d7ccb4;
  --rule-2:   var(--accent-dash);
  --bg-2:     #ece5d6;
  --bg-3:     #e4dcc8;
  --ink-soft: #8a8270;

  /* Familles thématiques — palette PIED */
  --fam-detresse:  var(--alert-red);
  --fam-semio:     var(--accent-blue);
  --fam-pied:      var(--spe-cardio);
  --fam-dx:        var(--accent-blue);
  --fam-fdr:       var(--accent-orange);
  --fam-clin:      var(--accent-green);

  /* PIED couleurs sémantiques */
  --pied-p: var(--spe-cardio);
  --pied-i: var(--alert-red);
  --pied-e: var(--accent-blue);
  --pied-d: var(--accent-orange);
}

/* ---------- Mindmap : couleurs des familles ---------- */
.fam-detresse .node-accent { fill: var(--fam-detresse); }
.fam-semio .node-accent    { fill: var(--fam-semio); }
.fam-pied .node-accent     { fill: var(--fam-pied); }
.fam-dx .node-accent       { fill: var(--fam-dx); }
.fam-fdr .node-accent      { fill: var(--fam-fdr); }
.fam-clin .node-accent     { fill: var(--fam-clin); }

.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(--spe-cardio);
  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-soft);
  letter-spacing: 0.08em;
}
.kp-card h3 {
  font-family: var(--font-serif);
  font-size: 15px;
  font-weight: 500;
  color: var(--spe-cardio);
  margin: 0 0 6px;
  padding-right: 24px;
}
.kp-card p { margin: 0; font-size: 13px; line-height: 1.5; color: var(--ink); }

.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(--spe-cardio);
  margin: 0 0 6px;
}
.def-card-mini p { margin: 0; font-size: 12.5px; line-height: 1.5; }

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

/* ---------- Bloc mnémonique PIED (4 carrés) ---------- */
.pied-bloc {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin: 12px 0 16px;
}
.pied-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border-radius: var(--radius-md);
  color: var(--bg-card);
}
.pied-card.pied-p { background: var(--pied-p); }
.pied-card.pied-i { background: var(--pied-i); }
.pied-card.pied-e { background: var(--pied-e); }
.pied-card.pied-d { background: var(--pied-d); }
.pied-letter {
  font-family: var(--font-serif);
  font-size: 36px;
  font-weight: 700;
  line-height: 1;
}
.pied-content { display: flex; flex-direction: column; gap: 2px; }
.pied-titre { font-family: var(--font-serif); font-size: 14px; font-weight: 600; }
.pied-sub { font-size: 11px; opacity: 0.92; }

/* ---------- Profil-cards génériques ---------- */
.profil-card {
  background: var(--bg-card);
  border: 1px solid var(--accent-border);
  border-radius: var(--radius-md);
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.profil-card-title {
  font-family: var(--font-serif);
  font-size: 15px;
  font-weight: 500;
  color: var(--spe-cardio);
  margin: 0 0 4px;
  padding-bottom: 6px;
  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-soft);
  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; }

/* ---------- Tableau natif (commun) ---------- */
.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(--spe-cardio) 14%, 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(--spe-cardio);
  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-blue-soft) 30%, var(--bg-card));
}

/* ---------- Tableau pivot PIED — couleurs colonnes ---------- */
.pied-table th .hcol-p,
.pied-table th .hcol-i,
.pied-table th .hcol-e,
.pied-table th .hcol-d {
  display: inline-block;
  font-family: var(--font-serif);
  font-size: 14px;
  font-weight: 700;
  color: var(--bg-card);
  padding: 0 6px;
  border-radius: 3px;
  margin-right: 4px;
}
.pied-table th .hcol-p { background: var(--pied-p); }
.pied-table th .hcol-i { background: var(--pied-i); }
.pied-table th .hcol-e { background: var(--pied-e); }
.pied-table th .hcol-d { background: var(--pied-d); }

.pied-table td.cell-p { background: color-mix(in oklab, var(--pied-p) 6%, var(--bg-card)); }
.pied-table td.cell-i { background: color-mix(in oklab, var(--pied-i) 6%, var(--bg-card)); }
.pied-table td.cell-e { background: color-mix(in oklab, var(--pied-e) 6%, var(--bg-card)); }
.pied-table td.cell-d { background: color-mix(in oklab, var(--pied-d) 8%, var(--bg-card)); }

.cell-discrim {
  background: color-mix(in oklab, var(--alert-red) 18%, var(--bg-card));
  padding: 2px 4px;
  border-radius: 3px;
}

/* ---------- 4 cards-profil PIED ---------- */
.pied-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 14px;
  margin-top: 12px;
}
.pied-letter-mini {
  display: inline-block;
  width: 26px; height: 26px;
  text-align: center;
  line-height: 26px;
  font-weight: 700;
  font-family: var(--font-serif);
  border-radius: 4px;
  color: var(--bg-card);
  margin-right: 6px;
}
.pied-profil-p { border-left: 4px solid var(--pied-p); }
.pied-profil-i { border-left: 4px solid var(--pied-i); }
.pied-profil-e { border-left: 4px solid var(--pied-e); }
.pied-profil-d { border-left: 4px solid var(--pied-d); }
.pied-profil-p .profil-card-title { color: var(--pied-p); }
.pied-profil-i .profil-card-title { color: var(--pied-i); }
.pied-profil-e .profil-card-title { color: var(--pied-e); }
.pied-profil-d .profil-card-title { color: var(--pied-d); }
.pied-profil-p .pied-letter-mini { background: var(--pied-p); }
.pied-profil-i .pied-letter-mini { background: var(--pied-i); }
.pied-profil-e .pied-letter-mini { background: var(--pied-e); }
.pied-profil-d .pied-letter-mini { background: var(--pied-d); }

.renvoi-link a {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--spe-cardio);
  text-decoration: none;
}
.renvoi-link a:hover { text-decoration: underline; }
.renvoi-info { font-size: 12px; color: var(--ink-soft); }

/* ---------- Détresse vitale (3 cards) ---------- */
.detresse-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 14px;
  margin-top: 12px;
}
.detresse-card {
  border-left: 4px solid var(--alert-red);
  background: color-mix(in oklab, var(--alert-red-soft) 25%, var(--bg-card));
}
.detresse-card .profil-card-title { color: var(--alert-red); }

/* ---------- Bloc soft (cadres réglementaires, notes) ---------- */
.bg-soft {
  background: var(--accent-blue-soft);
  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(--spe-cardio);
}
.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(--spe-cardio) 8%, var(--bg-card));
  border-left: 4px solid var(--spe-cardio);
}

/* ---------- Schéma 1 — Coupe transversale thorax ---------- */
.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: 760px;
  display: block;
  margin: 0 auto;
  color: var(--ink);
}
.schema-fig figcaption {
  font-size: 12px;
  color: var(--ink-soft);
  font-style: italic;
  margin-top: 10px;
  line-height: 1.4;
}

.thorax-paroi {
  fill: color-mix(in oklab, var(--accent-orange) 6%, var(--bg-cream));
  stroke: var(--accent-orange);
  stroke-width: 2;
}
.thorax-plevre {
  fill: color-mix(in oklab, var(--spe-cardio) 6%, var(--bg-cream));
  stroke: var(--spe-cardio);
  stroke-width: 1.5;
  stroke-dasharray: 4 3;
}
.thorax-parenchyme {
  fill: color-mix(in oklab, var(--ink-soft) 14%, var(--bg-cream));
  stroke: var(--ink-soft);
  stroke-width: 1.2;
  fill-opacity: 0.55;
}
.thorax-coeur {
  fill: var(--spe-cardio);
  stroke: var(--spe-cardio);
  stroke-width: 1.5;
}
.thorax-coeur-t { fill: var(--bg-card); }
.thorax-oeso {
  fill: color-mix(in oklab, var(--accent-yellow) 30%, var(--bg-cream));
  stroke: var(--accent-yellow);
  stroke-width: 1.5;
}
.thorax-oeso-t { fill: var(--ink); }
.thorax-aorte {
  fill: color-mix(in oklab, var(--alert-red) 22%, var(--bg-cream));
  stroke: var(--alert-red);
  stroke-width: 2;
}
.thorax-aorte-t { fill: var(--alert-red); }
.thorax-label { fill: var(--ink); }
.thorax-pleura-t { fill: var(--spe-cardio); font-weight: 600; }
.thorax-not-innerv { fill: var(--ink-soft); }
.thorax-legende rect.leg-paroi      { fill: color-mix(in oklab, var(--accent-orange) 30%, var(--bg-cream)); stroke: var(--accent-orange); stroke-width: 1; }
.thorax-legende rect.leg-plevre     { fill: color-mix(in oklab, var(--spe-cardio) 25%, var(--bg-cream)); stroke: var(--spe-cardio); stroke-width: 1; }
.thorax-legende rect.leg-viscerale  { fill: color-mix(in oklab, var(--accent-yellow) 50%, var(--bg-cream)); stroke: var(--accent-yellow); stroke-width: 1; }
.thorax-legende rect.leg-parenchyme { fill: color-mix(in oklab, var(--ink-soft) 35%, var(--bg-cream)); stroke: var(--ink-soft); stroke-width: 1; }
.thorax-legende text { fill: var(--ink); }

/* ---------- Dissection aortique — 4 cartes sémio + score ---------- */
.dissection-semio-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 14px;
  margin: 12px 0;
}
.dissection-card {
  border-left: 4px solid var(--accent-orange);
}
.dissection-card .profil-card-title {
  color: var(--accent-orange);
  font-size: 14.5px;
}

.score-da-card {
  background: var(--bg-card);
  border: 1px solid var(--accent-border);
  border-radius: var(--radius-md);
  padding: 14px 16px;
  margin: 14px 0;
}
.score-da-card > h4 {
  font-family: var(--font-serif);
  font-size: 15px;
  font-weight: 600;
  color: var(--accent-orange);
  margin: 0 0 8px;
}
.score-da-seuils {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin: 12px 0;
}
.score-seuil {
  padding: 12px 14px;
  border-radius: var(--radius-md);
  text-align: center;
  font-size: 12.5px;
  line-height: 1.4;
}
.score-seuil b {
  display: block;
  font-family: var(--font-serif);
  font-size: 22px;
  margin-bottom: 4px;
}
.score-faible {
  background: color-mix(in oklab, var(--accent-green) 14%, var(--bg-card));
  color: var(--accent-green-strong);
  border-left: 4px solid var(--accent-green-strong);
}
.score-forte {
  background: var(--alert-red-soft);
  color: var(--alert-red);
  border-left: 4px solid var(--alert-red);
}

/* ---------- Dissection — images médicales ---------- */
.dissection-images-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin: 14px 0;
}
.med-image {
  background: var(--bg-card);
  border: 1px solid var(--accent-border);
  border-radius: var(--radius-md);
  padding: 12px;
  margin: 0;
  text-align: center;
}
.med-image img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-sm);
  display: block;
  margin: 0 auto;
}
.med-image figcaption {
  font-size: 12px;
  color: var(--ink-soft);
  font-style: italic;
  margin-top: 8px;
  line-height: 1.4;
}
.med-image-wide { grid-column: 1 / -1; }

/* ---------- Dissection — classifications + PEC ---------- */
.classif-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin: 12px 0;
}
.pec-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin: 14px 0;
}
.pec-card-stanford-a {
  border-left: 4px solid var(--alert-red);
  background: color-mix(in oklab, var(--alert-red-soft) 22%, var(--bg-card));
}
.pec-card-stanford-a .profil-card-title { color: var(--alert-red); }
.pec-card-stanford-b {
  border-left: 4px solid var(--accent-orange);
  background: color-mix(in oklab, var(--accent-orange-soft) 22%, var(--bg-card));
}
.pec-card-stanford-b .profil-card-title { color: var(--accent-orange); }

/* ---------- Renvois SCA / EP / Péricardite ---------- */
.renvois-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 14px;
  margin-top: 12px;
}
.renvoi-card {
  border-left: 4px solid var(--accent-blue);
}
.renvoi-card .profil-card-title { color: var(--accent-blue); }

/* ---------- Étiologies non-PIED (4 sections) ---------- */
.etio-section {
  background: var(--bg-card);
  border: 1px solid var(--accent-border);
  border-radius: var(--radius-md);
  padding: 14px 16px;
  margin: 14px 0;
}
.etio-section-title {
  font-family: var(--font-serif);
  font-size: 16px;
  font-weight: 500;
  color: var(--spe-cardio);
  margin: 0 0 10px;
  padding-bottom: 6px;
  border-bottom: 1px dashed var(--accent-dash);
}
.etio-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 10px;
}
.etio-card {
  border-left: 4px solid var(--spe-cardio);
  padding: 12px 14px;
  gap: 6px;
}
.etio-card .profil-card-title {
  font-size: 13.5px;
  padding-bottom: 4px;
}
.etio-card-danger {
  border-left-color: var(--alert-red);
  background: color-mix(in oklab, var(--alert-red-soft) 18%, var(--bg-card));
}
.etio-card-danger .profil-card-title { color: var(--alert-red); }

.sec-respi  .etio-card { border-left-color: var(--accent-blue); }
.sec-respi  .etio-card .profil-card-title { color: var(--accent-blue); }
.sec-oeso   .etio-card { border-left-color: var(--accent-yellow); }
.sec-oeso   .etio-card .profil-card-title { color: var(--accent-yellow); }
.sec-oeso   .etio-card.etio-card-danger { border-left-color: var(--alert-red); }
.sec-oeso   .etio-card.etio-card-danger .profil-card-title { color: var(--alert-red); }
.sec-ms     .etio-card { border-left-color: var(--accent-orange); }
.sec-ms     .etio-card .profil-card-title { color: var(--accent-orange); }
.sec-neuro  .etio-card { border-left-color: var(--accent-green-strong); }
.sec-neuro  .etio-card .profil-card-title { color: var(--accent-green-strong); }

/* ---------- Étiologies extra-thoraciques + Cocaïne ---------- */
.extra-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 14px;
  margin-top: 12px;
}
.extra-card {
  border-left: 4px solid var(--spe-cardio);
}
.extra-card .profil-card-title { color: var(--spe-cardio); font-size: 14.5px; }

/* ---------- Angor fonctionnel (Rang B) ---------- */
.angor-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 12px;
  margin-top: 12px;
}
.angor-card {
  border-left: 4px solid var(--accent-blue);
}
.angor-card .profil-card-title { color: var(--accent-blue); font-size: 14px; }

/* ---------- Alertes rouges (commun) ---------- */
.alerte-rouge {
  background: var(--alert-red-soft);
  border-left: 4px solid 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(--alert-red);
}
.alerte-rouge p {
  margin: 0;
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--ink);
}

/* ---------- Responsive ---------- */
@media (max-width: 720px) {
  .pied-bloc { grid-template-columns: repeat(2, 1fr); }
  .pied-cards-grid,
  .detresse-grid,
  .dissection-semio-grid,
  .renvois-grid,
  .extra-grid,
  .angor-grid,
  .etio-cards-grid,
  .pec-grid,
  .classif-grid,
  .dissection-images-grid,
  .score-da-seuils {
    grid-template-columns: 1fr;
  }
  .pied-table { font-size: 12px; }
  .pied-table th, .pied-table td { padding: 7px 8px; }
}
