/* ==========================================================================
   Item 246 · Gynécomastie (Endocrinologie)
   8ème item endocrino · palette --spe-endocrino dominante (ocre #c27a2c)
   Variables CSS uniquement — pas de couleurs en dur.
   Pattern adapté de items/242 + 245 + 241 (matière endocrinologie).
   ========================================================================== */

: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 (endocrino dominante) */
  --fam-physio:   var(--spe-endocrino);
  --fam-triade:   var(--accent-orange);
  --fam-dx:       #2f5e7a;
  --fam-warn:     #8a5a12;
  --fam-endo:     var(--spe-endocrino);
  --fam-phys:     #4e6a2f;
}

/* ---------- Mindmap : couleurs des familles ---------- */
.fam-physio .node-accent { fill: var(--fam-physio); }
.fam-triade .node-accent { fill: var(--fam-triade); }
.fam-dx     .node-accent { fill: var(--fam-dx); }
.fam-warn   .node-accent { fill: var(--fam-warn); }
.fam-endo   .node-accent { fill: var(--fam-endo); }
.fam-phys   .node-accent { fill: var(--fam-phys); }

.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
   héritent de .kp-grid / .def-grid / .vignette / .vg-tag de items/138/143
   (composants partagés via assets/components.css ou injecté inline)
   Si non disponible, on les redéfinit ici en variables endo. ---------- */
.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-endocrino);
  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-endocrino);
  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-endocrino);
  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-endocrino);
  background: var(--accent-orange-soft);
  padding: 4px 10px;
  border-radius: var(--radius-sm);
  margin-bottom: 8px;
}
.vignette {
  background: var(--accent-orange-soft);
  border-left: 4px solid var(--spe-endocrino);
  border-radius: var(--radius-md);
  padding: 14px 18px;
  margin: 12px 0 16px;
  font-size: 13.5px;
  line-height: 1.55;
}
.vignette p { margin: 0; }

/* ---------- Profil-cards génériques ---------- */
.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: 16px;
  font-weight: 500;
  color: var(--spe-endocrino);
  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-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-endocrino) 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(--spe-endocrino);
  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-orange-soft) 30%, var(--bg-card));
}

/* ---------- Tableau pivot triade clinique (PIVOT PÉDAGOGIQUE) ---------- */
.triade-table th.col-adipo {
  background: color-mix(in oklab, var(--accent-green) 14%, var(--bg-card));
  color: var(--accent-green-strong);
}
.triade-table th.col-gyneco {
  background: color-mix(in oklab, var(--spe-endocrino) 18%, var(--bg-card));
  color: var(--spe-endocrino);
}
.triade-table th.col-cancer {
  background: color-mix(in oklab, var(--alert-red) 16%, var(--bg-card));
  color: var(--alert-red);
}
.triade-table td.cell-adipo {
  background: color-mix(in oklab, var(--accent-green-soft) 50%, var(--bg-card));
}
.triade-table td.cell-gyneco {
  background: color-mix(in oklab, var(--accent-orange-soft) 60%, var(--bg-card));
}
.triade-table td.cell-cancer {
  background: color-mix(in oklab, var(--alert-red-soft) 70%, var(--bg-card));
  color: var(--ink);
}
.technique-bloc {
  background: var(--accent-orange-soft);
  border-left: 4px solid var(--spe-endocrino);
}

/* ---------- Bloc soft (cadres réglementaires, notes) ---------- */
.bg-soft {
  background: var(--accent-orange-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-endocrino);
}
.bg-soft p {
  margin: 0;
  font-size: 13px;
  line-height: 1.55;
}
.bg-soft p.ccl,
.bg-soft p.note-physio,
.bg-soft p.note-bilan {
  margin-top: 8px;
  font-style: italic;
  color: var(--ink-soft);
}
.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-endocrino) 8%, var(--bg-card));
  border-left: 4px solid var(--spe-endocrino);
}

/* ---------- Schéma 1 — Balance T libre / E2 libre ---------- */
.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;
}
.bal-titre-t   { fill: var(--spe-endocrino); }
.bal-pivot     { stroke: var(--spe-endocrino); stroke-width: 3; }
.bal-base      { fill: var(--spe-endocrino); }
.bal-fleau     { stroke: var(--spe-endocrino); stroke-width: 4; stroke-linecap: round; }
.bal-suspente  { stroke: var(--accent-dash); stroke-width: 1.5; stroke-dasharray: 2 2; }
.bal-plat-t {
  fill: color-mix(in oklab, var(--spe-endocrino) 30%, var(--bg-card));
  stroke: var(--spe-endocrino);
  stroke-width: 1.5;
}
.bal-plat-e {
  fill: color-mix(in oklab, var(--accent-yellow) 30%, var(--bg-card));
  stroke: var(--accent-yellow);
  stroke-width: 1.5;
}
.bal-plat-t-text { fill: var(--ink); }
.bal-plat-e-text { fill: var(--ink); }
.bal-jeton-t {
  fill: var(--spe-endocrino);
  stroke: var(--accent-strong, var(--spe-endocrino));
  stroke-width: 1;
}
.bal-jeton-e {
  fill: var(--accent-yellow);
  stroke: var(--accent-yellow);
  stroke-width: 1;
}
.bal-meca-t { fill: var(--ink-soft); font-style: italic; }

/* ---------- Schéma 2 — 3 mécanismes physiopath ---------- */
.meca-col rect {
  fill: var(--bg-cream);
  stroke-width: 1.5;
}
.meca-col text { fill: var(--ink); }
.meca-est rect  { stroke: var(--accent-blue); fill: color-mix(in oklab, var(--accent-blue-soft) 50%, var(--bg-cream)); }
.meca-test rect { stroke: var(--alert-red); fill: color-mix(in oklab, var(--alert-red-soft) 40%, var(--bg-cream)); }
.meca-tebg rect { stroke: var(--spe-endocrino); fill: color-mix(in oklab, var(--accent-orange-soft) 60%, var(--bg-cream)); }
.meca-sep {
  stroke: var(--accent-dash);
  stroke-width: 1;
  stroke-dasharray: 2 2;
}
.meca-ccl {
  fill: color-mix(in oklab, var(--spe-endocrino) 12%, var(--bg-card));
  stroke: var(--spe-endocrino);
  stroke-width: 2;
}
.meca-ccl-t { fill: var(--spe-endocrino); }

/* ---------- Schéma 4 — Flowchart traitement ---------- */
.flow-root {
  fill: color-mix(in oklab, var(--spe-endocrino) 14%, var(--bg-card));
  stroke: var(--spe-endocrino);
  stroke-width: 2;
}
.flow-root-t { fill: var(--spe-endocrino); }
.flow-question {
  fill: var(--bg-cream);
  stroke: var(--accent-orange);
  stroke-width: 1.5;
}
.flow-question text { fill: var(--ink); }
.flow-leaf rect, .flow-leaf {
  stroke-width: 1.5;
}
.flow-leaf-ok {
  fill: color-mix(in oklab, var(--accent-green-soft) 70%, var(--bg-card));
  stroke: var(--accent-green-strong);
}
.flow-leaf-warn {
  fill: color-mix(in oklab, var(--accent-yellow-soft) 70%, var(--bg-card));
  stroke: var(--accent-yellow);
}
.flow-leaf-danger {
  fill: var(--alert-red-soft);
  stroke: var(--alert-red);
}
.schema-flow text { fill: var(--ink); }
.flow-link {
  stroke: var(--ink-soft);
  stroke-width: 1.8;
  fill: none;
}
.flow-arrow { fill: var(--ink-soft); }
.flow-edge-yes { fill: var(--accent-green-strong); }
.flow-edge-no  { fill: var(--alert-red); }
.flow-encart {
  fill: var(--alert-red-soft);
  stroke: var(--alert-red);
  stroke-width: 1.5;
}
.flow-encart-t { fill: var(--alert-red); }

/* ---------- Onglet 07 : Causes générales (3 cards) ---------- */
.general-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 14px;
  margin-top: 12px;
}
.general-card {
  border-left: 4px solid var(--fam-warn);
}
.general-card .profil-card-title {
  color: var(--fam-warn);
  font-size: 15px;
}

/* ---------- Onglet 09 : Klinefelter détaillé ---------- */
.klinefelter-card {
  border-left: 4px solid var(--spe-endocrino);
  background: color-mix(in oklab, var(--accent-orange-soft) 30%, var(--bg-card));
}
.klinefelter-card .profil-card-title {
  font-size: 17px;
  color: var(--spe-endocrino);
}

/* ---------- Onglet 10 : Hypogonadisme + tumeurs (3 cards) ---------- */
.hypogo-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 14px;
  margin-top: 12px;
}
.hypogo-card:nth-child(1) {
  border-left: 4px solid var(--fam-warn);
}
.hypogo-card:nth-child(2) {
  border-left: 4px solid var(--accent-yellow);
}
.hypogo-card:nth-child(3) {
  border-left: 4px solid var(--alert-red);
  background: color-mix(in oklab, var(--alert-red-soft) 18%, var(--bg-card));
}
.hypogo-card:nth-child(1) .profil-card-title { color: var(--fam-warn); }
.hypogo-card:nth-child(2) .profil-card-title { color: var(--accent-yellow); }
.hypogo-card:nth-child(3) .profil-card-title { color: var(--alert-red); }

/* ---------- Onglet 13 : Traitement (DHT + chirurgie en 2 cols) ---------- */
.trt-2-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-top: 12px;
}
.trt-card {
  border-left: 4px solid var(--spe-endocrino);
}
.trt-card .profil-card-title {
  color: var(--spe-endocrino);
  font-size: 14.5px;
}

/* ---------- 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) {
  .general-grid,
  .hypogo-grid,
  .trt-2-cols {
    grid-template-columns: 1fr;
  }
  .triade-table {
    font-size: 12px;
  }
  .triade-table th, .triade-table td {
    padding: 7px 8px;
  }
}
