/**
 * bfcr-dictamen.css — estilos del CPT `dictamen` (Dictamenes Juridicos del Lic. Arroyo).
 *
 * Generado automaticamente desde el prototipo HTML del Dictamen 0001.
 * Fuente: AUDIOS/OIJ-PODCAST/dictamen-0001-liberia/dictamen-juridico-0001.html
 * Script de extraccion: tmp/extract_dictamen_css.py
 *
 * Namespace: el CSS se enqueua solo en single-dictamen + archive-dictamen.
 * Selectores globales (body, *, a) se renombran a .dictamen-shell para defender
 * el header/footer del theme Avante.
 */

:root {
  --ink-deepest: #0c0b0a;
  --ink-deep:    #15130f;
  --ink-mid:     #1f1c17;
  --ink-soft:    #2a2620;
  --paper:       #f0e7cf;
  --paper-aged:  #e7ddc1;
  --paper-shadow:#c8bd9d;
  --ink-text:    #1a1814;
  --ink-light:   #4a4339;
  --gold:        #b08a3e;
  --gold-deep:   #8a6a28;
  --gold-soft:   #f3e7bf;
  --oxblood:     #7a1c18;
  --oxblood-deep:#5a0f0c;
  --bone:        #e8dfc7;
  --warm-white:  #ece4cf;
  --rule:        rgba(26,24,20,.18);
  --stamp-red:   #962820;
  --green-bcr:   #0e3d2e;
}

.dictamen-shell, .dictamen-shell *, .dictamen-shell *::before, .dictamen-shell *::after { box-sizing: border-box; }
.dictamen-shell .reset, .dictamen-shell .reset * { margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

.dictamen-shell {
  background: var(--ink-deepest);
  color: var(--warm-white);
  font-family: "Source Serif 4", Georgia, serif;
  font-size: 18px;
  line-height: 1.7;
  font-feature-settings: "liga", "kern", "onum";
  /* overflow-x:hidden rompe position:sticky de los descendientes (chapter-nav).
     Lo sustituimos por overflow-clip que solo evita el scroll horizontal sin
     crear contexto de scroll. */
  overflow-x: clip;
  position: relative;
}

.dictamen-shell::before {
  content: "";
  position: fixed; inset: 0;
  pointer-events: none;
  z-index: 1000;
  opacity: .35;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.92' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.45 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}
.dictamen-shell::after {
  content: "";
  position: fixed; inset: 0;
  pointer-events: none;
  z-index: 1;
  background: radial-gradient(ellipse at center, transparent 55%, rgba(0,0,0,.55) 100%);
}

.dictamen-shell a { color: var(--gold); text-decoration: none; border-bottom: 1px solid rgba(176,138,62,.35); transition: all .2s; }
.dictamen-shell a:hover { color: var(--paper); border-bottom-color: var(--paper); }

.nav-bar {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(12,11,10,.92);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(176,138,62,.18);
}
.nav-inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: .85rem clamp(1rem, 3vw, 3rem);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.nav-brand {
  display: flex;
  align-items: center;
  gap: .7rem;
  font-family: "JetBrains Mono", monospace;
  font-size: .68rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(236,228,207,.7);
}
.nav-brand-mark {
  width: 26px; height: 26px;
  border: 1.5px solid var(--gold);
  display: grid; place-items: center;
  font-family: "Fraunces", serif;
  font-size: .9rem; font-weight: 600; font-style: italic;
  color: var(--gold);
  font-variation-settings: "SOFT" 80;
}
.nav-brand-name strong { color: var(--warm-white); font-weight: 600; }
.nav-brand-name .pipe { color: rgba(176,138,62,.4); margin: 0 .5rem; }
.nav-brand-name .accent { color: var(--gold); }

.nav-links {
  display: none;
  gap: 1.5rem;
  font-family: "JetBrains Mono", monospace;
  font-size: .68rem;
  letter-spacing: .12em;
  text-transform: uppercase;
}
@media (min-width: 900px) { .nav-links { display: flex; } }
.nav-links a {
  color: rgba(236,228,207,.55);
  border: none;
  letter-spacing: .12em;
  transition: color .2s;
}
.nav-links a:hover { color: var(--gold); }

.cover {
  min-height: 88vh;
  position: relative;
  padding: 4rem clamp(1.5rem, 5vw, 5rem) 3rem;
  display: grid;
  grid-template-rows: auto 1fr auto;
  background:
    linear-gradient(180deg, transparent 0%, rgba(122,28,24,.04) 100%),
    radial-gradient(circle at 30% 10%, rgba(176,138,62,.08), transparent 50%),
    var(--ink-deepest);
  border-bottom: 1px solid rgba(176,138,62,.15);
  z-index: 2;
}

.cover-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 2rem;
  font-family: "JetBrains Mono", monospace;
  font-size: .72rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(236,228,207,.5);
}
.cover-top .left, .cover-top .right { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.cover-top span { display: inline-flex; align-items: center; gap: .5rem; }
.cover-top .pip::before {
  content: ""; width: 6px; height: 6px;
  background: var(--oxblood);
  display: inline-block;
}

.cover-center {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  align-content: center;
  padding: 4rem 0 2.5rem;
  position: relative;
}

.episode-mark {
  font-family: "JetBrains Mono", monospace;
  font-size: .7rem;
  letter-spacing: .32em;
  color: var(--gold);
  text-transform: uppercase;
  margin-bottom: 1.5rem;
  display: flex;
  align-items: center;
  gap: 1rem;
}
.episode-mark::before {
  content: ""; flex: 0 0 50px; height: 1px;
  background: linear-gradient(90deg, var(--gold), transparent);
}

.cover h1 {
  font-family: "Fraunces", serif;
  font-weight: 350;
  font-size: clamp(2.4rem, 6.5vw, 5.4rem);
  line-height: 1.02;
  letter-spacing: -.025em;
  font-variation-settings: "SOFT" 30, "opsz" 144;
  color: var(--warm-white);
  max-width: 22ch;
  margin-bottom: 1.5rem;
}
.cover h1 em {
  font-style: italic;
  color: var(--gold);
  font-variation-settings: "SOFT" 100, "opsz" 144;
  font-weight: 300;
}

.cover-deck {
  font-family: "Source Serif 4", serif;
  font-weight: 300;
  font-size: clamp(1.05rem, 1.6vw, 1.25rem);
  line-height: 1.55;
  color: rgba(236,228,207,.75);
  max-width: 60ch;
  margin-top: 1.5rem;
  font-style: italic;
}

.cover-meta {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 1.5rem 2rem;
  margin-top: 3rem;
  padding-top: 2rem;
  border-top: 1px solid rgba(176,138,62,.2);
  font-family: "JetBrains Mono", monospace;
  font-size: .78rem;
}
.cover-meta dt {
  font-size: .62rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(236,228,207,.45);
  margin-bottom: .4rem;
}
.cover-meta dd { color: var(--warm-white); font-weight: 500; }

.stamp {
  position: absolute;
  font-family: "JetBrains Mono", monospace;
  font-weight: 700;
  letter-spacing: .15em;
  text-transform: uppercase;
  border: 3px double var(--stamp-red);
  color: var(--stamp-red);
  padding: .7rem 1.4rem;
  font-size: .9rem;
  opacity: .78;
  pointer-events: none;
  background: rgba(150,40,32,.04);
  text-shadow: 1px 0 0 rgba(150,40,32,.2);
}
.stamp-cover {
  top: 14vh;
  right: clamp(1rem, 5vw, 5rem);
  transform: rotate(8deg);
  z-index: 3;
}
.stamp-cover::before {
  content: "✻";
  position: absolute;
  top: 50%; left: -1.3rem;
  transform: translateY(-50%);
  font-size: .8rem;
}

.cover-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  margin-top: 2.5rem;
  padding-top: 2rem;
  border-top: 1px solid rgba(176,138,62,.18);
  background: rgba(176,138,62,.08);
}
.cover-stat {
  background: var(--ink-deepest);
  padding: 1.2rem 1.4rem;
  text-align: center;
}
.cover-stat .num {
  font-family: "Fraunces", serif;
  font-style: italic;
  font-size: clamp(2.2rem, 4vw, 3rem);
  color: var(--gold);
  font-weight: 400;
  line-height: 1;
  margin-bottom: .3rem;
  font-variation-settings: "SOFT" 100, "opsz" 144;
}
.cover-stat .label {
  font-family: "JetBrains Mono", monospace;
  font-size: .62rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(236,228,207,.6);
}
@media (max-width: 700px) {
  .cover-stats { grid-template-columns: repeat(2, 1fr); }
}

.dossier {
  position: relative;
  z-index: 2;
  padding: 5rem clamp(1rem, 3vw, 3rem) 3rem;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  max-width: 1500px;
  margin: 0 auto;
}
@media (min-width: 1100px) {
  .dossier { grid-template-columns: 220px minmax(0, 1fr); gap: 3rem; }
}

.chapter-nav {
  display: none;
  align-self: start;
  position: sticky;
  /* Margen superior considera el header sticky de Avante (~70px) + breathing */
  top: 100px;
  /* Max-height calculado para que el bottom de la TOC quede SIEMPRE arriba del
     audio dock (fixed bottom-left, width 320px, ~120px de alto colapsado, ~280px
     expandido). 100px top + 240px reservados al bottom = 340px buffer total. */
  max-height: calc(100vh - 340px);
  overflow-y: auto;
  /* Scrollbar discreto */
  scrollbar-width: thin;
  scrollbar-color: rgba(176,138,62,.3) transparent;
  font-family: "JetBrains Mono", monospace;
  font-size: .72rem;
  padding-right: .5rem;
}
.chapter-nav::-webkit-scrollbar { width: 4px; }
.chapter-nav::-webkit-scrollbar-thumb { background: rgba(176,138,62,.3); border-radius: 4px; }
.chapter-nav::-webkit-scrollbar-track { background: transparent; }
@media (min-width: 1100px) { .chapter-nav { display: block; } }
/* Si el audio dock NO esta presente (dictamen sin audio), recuperamos espacio
   bajando solo el header + breathing en el bottom. */
.dictamen-shell:not(:has(.audio-dock)) .chapter-nav {
  max-height: calc(100vh - 140px);
}
.chapter-nav-title {
  font-size: .62rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: rgba(236,228,207,.4);
  margin-bottom: 1.5rem;
  padding-bottom: .75rem;
  border-bottom: 1px solid rgba(176,138,62,.2);
}
.chapter-nav ol {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: .65rem;
}
.chapter-nav a {
  color: rgba(236,228,207,.55);
  border: none;
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: .7rem;
  align-items: baseline;
  letter-spacing: .05em;
  line-height: 1.35;
  padding: .15rem 0;
  transition: color .2s;
}
.chapter-nav a:hover { color: var(--gold); }
.chapter-nav a span:first-child {
  color: var(--gold);
  font-weight: 700;
  font-size: .65rem;
}

.document {
  background: var(--paper);
  color: var(--ink-text);
  padding: clamp(2rem, 5vw, 5rem) clamp(1.5rem, 5vw, 5rem);
  position: relative;
  box-shadow:
    0 0 0 1px rgba(0,0,0,.05),
    0 30px 60px -20px rgba(0,0,0,.5),
    0 50px 120px -30px rgba(122,28,24,.15);
  background-image:
    radial-gradient(ellipse at top left, rgba(176,138,62,.05), transparent 60%),
    radial-gradient(ellipse at bottom right, rgba(122,28,24,.04), transparent 60%);
}
.document::before {
  content: "";
  position: absolute;
  left: -1px; top: 0; bottom: 0;
  width: 4px;
  background: linear-gradient(180deg,
    var(--paper-shadow) 0%, var(--paper-aged) 25%,
    var(--paper-shadow) 50%, var(--paper-aged) 75%,
    var(--paper-shadow) 100%);
  opacity: .4;
}

.doc-header {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 2rem;
  padding-bottom: 2rem;
  margin-bottom: 3rem;
  border-bottom: 1px solid var(--rule);
  align-items: end;
}
@media (max-width: 700px) {
  .doc-header { grid-template-columns: 1fr; gap: 1rem; }
}
.doc-header-num {
  font-family: "Fraunces", serif;
  font-style: italic;
  font-weight: 200;
  font-size: clamp(3rem, 8vw, 5.5rem);
  line-height: .85;
  color: var(--oxblood);
  font-variation-settings: "SOFT" 100, "opsz" 144;
}
.doc-header-info {
  font-family: "JetBrains Mono", monospace;
  font-size: .72rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink-light);
  line-height: 1.9;
}
.doc-header-info strong { color: var(--ink-text); font-weight: 700; }

.chapter {
  margin-top: 4rem;
  scroll-margin-top: 5rem;
}
.chapter:first-of-type { margin-top: 0; }

.chapter-head {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1.5rem;
  align-items: baseline;
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1.5px solid var(--ink-text);
  position: relative;
}
.chapter-num {
  font-family: "JetBrains Mono", monospace;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .2em;
  color: var(--oxblood);
  text-transform: uppercase;
  white-space: nowrap;
}
.chapter-head h2 {
  font-family: "Fraunces", serif;
  font-weight: 400;
  font-size: clamp(1.6rem, 3.4vw, 2.3rem);
  line-height: 1.1;
  letter-spacing: -.015em;
  color: var(--ink-text);
  font-variation-settings: "SOFT" 50, "opsz" 144;
}

.chapter > p:first-of-type::first-letter,
.drop-cap::first-letter {
  font-family: "Fraunces", serif;
  font-weight: 300;
  font-style: italic;
  font-size: 4.6rem;
  line-height: .85;
  float: left;
  margin: .15em .12em -.05em 0;
  color: var(--oxblood);
  font-variation-settings: "SOFT" 100, "opsz" 144;
}

.document h3 {
  font-family: "Fraunces", serif;
  font-weight: 500;
  font-size: 1.35rem;
  margin: 2.5rem 0 .9rem;
  color: var(--ink-text);
  letter-spacing: -.01em;
  font-variation-settings: "SOFT" 30, "opsz" 60;
  display: flex;
  align-items: baseline;
  gap: .8rem;
}
.document h3::before {
  content: "§";
  color: var(--oxblood);
  font-style: italic;
  font-weight: 300;
  font-size: 1.1em;
  font-variation-settings: "SOFT" 100;
}

.document p {
  margin-bottom: 1.2rem;
  font-size: 1.05rem;
  line-height: 1.75;
  color: var(--ink-text);
  text-align: justify;
  hyphens: auto;
}
.document strong { color: var(--ink-text); font-weight: 600; }
.document em { font-style: italic; }

.legal-cite {
  display: inline-block;
  font-family: "JetBrains Mono", monospace;
  font-size: .78em;
  font-weight: 600;
  letter-spacing: .02em;
  background: rgba(122,28,24,.08);
  color: var(--oxblood-deep);
  padding: .1em .5em;
  border-left: 2px solid var(--oxblood);
  white-space: nowrap;
}

blockquote.testimonio {
  margin: 2.5rem 0;
  padding: 1.5rem 1.8rem 1.5rem 2.2rem;
  background: rgba(176,138,62,.07);
  border-left: 3px solid var(--gold-deep);
  position: relative;
  border-radius: 0 4px 4px 0;
}
blockquote.testimonio::before {
  content: "TESTIMONIO";
  position: absolute;
  top: -.55rem;
  left: 1.5rem;
  background: var(--paper);
  padding: 0 .6rem;
  font-family: "JetBrains Mono", monospace;
  font-size: .58rem;
  letter-spacing: .2em;
  color: var(--gold-deep);
  font-weight: 700;
}
blockquote.testimonio p {
  font-family: "Fraunces", serif;
  font-style: italic;
  font-size: 1.15rem;
  line-height: 1.55;
  color: var(--ink-soft);
  margin-bottom: .8rem;
  font-variation-settings: "SOFT" 80;
  text-align: left;
}
blockquote.testimonio cite {
  display: block;
  font-style: normal;
  font-family: "JetBrains Mono", monospace;
  font-size: .68rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--ink-light);
  font-weight: 600;
}
blockquote.testimonio cite .ts {
  color: var(--oxblood);
  font-family: "Fraunces", serif;
  font-style: italic;
  text-transform: none;
  letter-spacing: 0;
  font-size: .9rem;
  font-weight: 500;
  margin-left: .5rem;
}

.pullquote {
  margin: 3rem 0;
  padding: 1rem 0 1rem 2.5rem;
  border-left: 3px solid var(--oxblood);
  font-family: "Fraunces", serif;
  font-size: clamp(1.3rem, 2.5vw, 1.7rem);
  font-style: italic;
  font-weight: 300;
  line-height: 1.35;
  color: var(--ink-text);
  font-variation-settings: "SOFT" 80, "opsz" 144;
}
.pullquote::before { content: "\""; color: var(--oxblood); font-size: 1.5em; line-height: 0; vertical-align: -.4em; margin-right: .05em; }
.pullquote::after { content: "\""; color: var(--oxblood); font-size: 1.5em; line-height: 0; vertical-align: -.65em; margin-left: .05em; }

.pull-large {
  font-family: "Fraunces", serif;
  font-style: italic;
  font-size: clamp(1.4rem, 3vw, 2rem);
  line-height: 1.3;
  color: var(--ink-text);
  text-align: center;
  margin: 3.5rem 0;
  padding: 0 2rem;
  position: relative;
  font-weight: 400;
  font-variation-settings: "SOFT" 80;
}
.pull-large::before, .pull-large::after {
  content: "";
  width: 50px; height: 1px;
  background: var(--oxblood);
  display: block;
  margin: 1.5rem auto;
}

.marginalia {
  float: right;
  width: 220px;
  margin: .5rem -1.5rem 1rem 1.5rem;
  padding: 1rem 1.2rem;
  background: rgba(176,138,62,.07);
  border-left: 2px solid var(--gold);
  font-family: "Fraunces", serif;
  font-size: .92rem;
  line-height: 1.5;
  color: var(--ink-light);
  font-style: italic;
  font-variation-settings: "SOFT" 60;
}
@media (max-width: 880px) {
  .marginalia { float: none; width: auto; margin: 1.2rem 0; }
}

.editorial-note {
  margin: 2.5rem 0;
  padding: 1.5rem 1.8rem 1.5rem 2.2rem;
  background: rgba(122,28,24,.05);
  border-left: 3px solid var(--oxblood);
  position: relative;
  border-radius: 0 3px 3px 0;
}
.editorial-note::before {
  content: "NOTA EDITORIAL";
  position: absolute;
  top: -.55rem;
  left: 1.5rem;
  background: var(--paper);
  padding: 0 .6rem;
  font-family: "JetBrains Mono", monospace;
  font-size: .58rem;
  letter-spacing: .2em;
  color: var(--oxblood);
  font-weight: 700;
}
.editorial-note p {
  font-style: italic;
  font-size: .95rem;
  color: var(--ink-light);
  margin-bottom: 0;
  text-align: left;
}

.document ul, .document ol {
  margin: 1.2rem 0 1.8rem 0;
  padding-left: 0;
  list-style: none;
}
.document ul li, .document ol li {
  position: relative;
  padding-left: 2.2rem;
  margin-bottom: .85rem;
  line-height: 1.7;
  text-align: justify;
}
.document ul li::before {
  content: "◆";
  position: absolute;
  left: .4rem; top: 0;
  color: var(--oxblood);
  font-size: .7rem;
  line-height: 1.7;
}
.document ol { counter-reset: item; }
.document ol li::before {
  counter-increment: item;
  content: counter(item, decimal-leading-zero);
  position: absolute;
  left: 0; top: .05rem;
  font-family: "JetBrains Mono", monospace;
  font-size: .72rem;
  font-weight: 700;
  color: var(--oxblood);
  letter-spacing: .05em;
}

.factbox {
  background: rgba(255,255,255,.5);
  border: 1px solid var(--rule);
  padding: 1.4rem 1.6rem;
  margin: 1.8rem 0;
  border-radius: 4px;
  position: relative;
}
.factbox-label {
  position: absolute;
  top: -.55rem;
  left: 1.2rem;
  background: var(--paper);
  padding: 0 .6rem;
  font-family: "JetBrains Mono", monospace;
  font-size: .58rem;
  letter-spacing: .2em;
  color: var(--gold-deep);
  font-weight: 700;
}
.factbox dl {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: .55rem 1.2rem;
  margin: 0;
  font-size: .95rem;
}
@media (max-width: 700px) {
  .factbox dl { grid-template-columns: 1fr; gap: .15rem 0; }
  .factbox dt { margin-top: .6rem; }
}
.factbox dt {
  font-family: "JetBrains Mono", monospace;
  font-size: .68rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--oxblood-deep);
  font-weight: 700;
  padding-top: .15rem;
}
.factbox dd { margin: 0; color: var(--ink-text); }

.timeline {
  margin: 2.5rem 0;
  border-left: 2px solid var(--gold);
  padding: .5rem 0;
}
.timeline-item {
  position: relative;
  padding: 1rem 0 1.3rem 2.5rem;
  margin-left: -2px;
}
.timeline-item::before {
  content: "";
  position: absolute;
  left: -8px; top: 1.3rem;
  width: 14px; height: 14px;
  background: var(--paper);
  border: 2px solid var(--gold);
  border-radius: 50%;
}
.timeline-item.highlight::before { background: var(--gold); }
.timeline-item.fatal::before { background: var(--oxblood); border-color: var(--oxblood-deep); }

.timeline-item time {
  font-family: "JetBrains Mono", monospace;
  font-size: .68rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--oxblood);
  font-weight: 700;
  display: block;
  margin-bottom: .3rem;
}
.timeline-item h5 {
  font-family: "Fraunces", serif;
  color: var(--ink-text);
  margin: 0 0 .3rem;
  font-size: 1.1rem;
  font-weight: 500;
  letter-spacing: -.005em;
}
.timeline-item p {
  margin: 0;
  font-size: .97rem;
  color: var(--ink-light);
  line-height: 1.55;
  text-align: left;
}

.lens-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1rem;
  margin: 2rem 0;
}
.lens {
  background: rgba(255,255,255,.4);
  border: 1px solid var(--rule);
  border-top: 2px solid var(--oxblood);
  padding: 1.3rem 1.4rem 1.4rem;
  position: relative;
}
.lens-num {
  display: inline-flex;
  width: 28px; height: 28px;
  align-items: center;
  justify-content: center;
  background: var(--ink-text);
  color: var(--gold);
  font-family: "JetBrains Mono", monospace;
  font-weight: 700;
  font-size: .78rem;
  margin-bottom: .9rem;
  border-radius: 2px;
}
.lens h4 {
  font-family: "Fraunces", serif;
  font-size: 1.1rem;
  font-weight: 500;
  margin: 0 0 .5rem;
  color: var(--ink-text);
  letter-spacing: -.01em;
}
.lens p {
  font-size: .9rem;
  color: var(--ink-light);
  line-height: 1.55;
  margin: 0;
  text-align: left;
}

.penal-grid {
  display: grid;
  gap: 1rem;
  margin: 2rem 0;
}
.penal-card {
  background: rgba(255,255,255,.5);
  border: 1px solid var(--rule);
  border-left: 4px solid var(--oxblood);
  padding: 1.3rem 1.5rem;
  border-radius: 0 3px 3px 0;
}
.penal-card .lawref-tag {
  display: inline-block;
  font-family: "JetBrains Mono", monospace;
  font-size: .65rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--oxblood-deep);
  font-weight: 700;
  margin-bottom: .35rem;
  background: rgba(122,28,24,.08);
  padding: .15em .55em;
  border-left: 2px solid var(--oxblood);
}
.penal-card h4 {
  font-family: "Fraunces", serif;
  color: var(--ink-text);
  margin: .3rem 0 .5rem;
  font-size: 1.18rem;
  font-weight: 500;
  letter-spacing: -.005em;
}
.penal-card p {
  font-size: .95rem;
  margin: 0 0 .55rem;
  color: var(--ink-light);
  line-height: 1.6;
}
.imputado-tag {
  display: inline-block;
  font-size: .72rem;
  background: rgba(176,138,62,.12);
  color: var(--gold-deep);
  border-left: 2px solid var(--gold-deep);
  padding: .15em .55em;
  font-family: "JetBrains Mono", monospace;
  letter-spacing: .05em;
  font-weight: 600;
}

.penalty-table {
  width: 100%;
  margin: 2rem 0;
  border-collapse: collapse;
  font-family: "Source Serif 4", serif;
  font-size: .95rem;
}
.penalty-table caption {
  caption-side: top;
  text-align: left;
  font-family: "JetBrains Mono", monospace;
  font-size: .65rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink-light);
  margin-bottom: .75rem;
  padding-bottom: .5rem;
  border-bottom: 1px solid var(--rule);
}
.penalty-table th {
  font-family: "JetBrains Mono", monospace;
  font-size: .68rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-weight: 700;
  text-align: left;
  padding: .7rem .9rem;
  background: rgba(26,24,20,.06);
  color: var(--ink-text);
  border-bottom: 1.5px solid var(--ink-text);
}
.penalty-table td {
  padding: .85rem .9rem;
  border-bottom: 1px solid var(--rule);
  vertical-align: top;
  line-height: 1.5;
}
.penalty-table tr:last-child td {
  border-bottom: 1.5px solid var(--ink-text);
  background: rgba(122,28,24,.04);
}
.penalty-table .num {
  font-family: "JetBrains Mono", monospace;
  font-size: .85rem;
  color: var(--oxblood-deep);
  font-weight: 600;
  white-space: nowrap;
}

.matrix-table {
  width: 100%;
  margin: 2rem 0;
  border-collapse: collapse;
  font-size: .92rem;
}
.matrix-table caption {
  caption-side: top;
  text-align: left;
  font-family: "JetBrains Mono", monospace;
  font-size: .65rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink-light);
  margin-bottom: .75rem;
  padding-bottom: .5rem;
  border-bottom: 1px solid var(--rule);
}
.matrix-table th {
  font-family: "JetBrains Mono", monospace;
  font-size: .65rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  font-weight: 700;
  text-align: left;
  padding: .7rem .8rem;
  background: var(--ink-text);
  color: var(--gold);
  vertical-align: top;
  white-space: nowrap;
}
.matrix-table td {
  padding: .85rem .9rem;
  border-bottom: 1px solid var(--rule);
  vertical-align: top;
  line-height: 1.5;
  font-size: .93rem;
}
.matrix-table tr:last-child td { border-bottom: 1.5px solid var(--ink-text); }
.matrix-table td:first-child {
  font-family: "Fraunces", serif;
  font-weight: 600;
  font-size: 1rem;
  color: var(--oxblood-deep);
  white-space: nowrap;
}

.actors {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1rem;
  margin: 1.5rem 0 2rem;
}
.actor {
  background: rgba(255,255,255,.5);
  border: 1px solid var(--rule);
  border-top: 3px solid var(--ink-text);
  padding: 1.1rem 1.3rem;
  border-radius: 0 0 3px 3px;
}
.actor.victim { border-top-color: var(--oxblood); }
.actor.perp { border-top-color: var(--ink-text); }
.actor.officer { border-top-color: var(--gold-deep); }
.actor.survivor { border-top-color: var(--gold); }
.actor h4 {
  font-family: "Fraunces", serif;
  color: var(--ink-text);
  margin: 0 0 .25rem;
  font-size: 1.05rem;
  font-weight: 500;
}
.actor .role {
  font-family: "JetBrains Mono", monospace;
  font-size: .6rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--oxblood);
  font-weight: 700;
  margin-bottom: .55rem;
}
.actor.officer .role { color: var(--gold-deep); }
.actor.survivor .role { color: var(--gold-deep); }
.actor p {
  font-size: .88rem;
  margin: 0;
  color: var(--ink-light);
  line-height: 1.55;
  text-align: left;
}

.contrast {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  margin: 2rem 0;
  border: 1px solid var(--rule);
}
@media (max-width: 700px) { .contrast { grid-template-columns: 1fr; } }
.contrast-col {
  padding: 1.6rem 1.7rem;
}
.contrast-col.left {
  background: rgba(26,24,20,.04);
  border-right: 1px solid var(--rule);
}
.contrast-col.right {
  background: rgba(176,138,62,.07);
}
.contrast-label {
  font-family: "JetBrains Mono", monospace;
  font-size: .62rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink-light);
  margin-bottom: .4rem;
}
.contrast-col.right .contrast-label { color: var(--gold-deep); }
.contrast-col h4 {
  font-family: "Fraunces", serif;
  font-size: 1.3rem;
  margin: 0 0 1rem;
  color: var(--ink-text);
  font-weight: 500;
}
.contrast-col ul { margin: 0; }
.contrast-col li {
  font-size: .9rem;
  color: var(--ink-light);
  margin-bottom: .55rem;
  padding-left: 1.2rem;
}
.contrast-col li::before {
  content: "—";
  position: absolute;
  left: .3rem;
  color: var(--oxblood);
}

.ornament {
  text-align: center;
  margin: 3.5rem 0;
  font-family: "Fraunces", serif;
  color: var(--oxblood);
  font-size: 1.3rem;
  letter-spacing: 1.5em;
  padding-left: 1.5em;
  font-style: italic;
  font-variation-settings: "SOFT" 100;
}

.signature {
  margin-top: 4.5rem;
  padding-top: 2.5rem;
  border-top: 1px solid var(--rule);
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}
@media (min-width: 700px) {
  .signature { grid-template-columns: 1fr auto; align-items: end; }
}
.signature-author {
  font-family: "Fraunces", serif;
  font-size: 1.1rem;
  font-style: italic;
  font-weight: 400;
  color: var(--ink-text);
  font-variation-settings: "SOFT" 80;
  letter-spacing: -.005em;
  line-height: 1.4;
}
.signature-author .place {
  display: block;
  font-style: normal;
  font-family: "JetBrains Mono", monospace;
  font-size: .65rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--ink-light);
  margin-bottom: .9rem;
  font-weight: 400;
}
.signature-author .name {
  display: block;
  font-style: normal;
  font-family: "Fraunces", serif;
  font-weight: 600;
  font-size: 1.4rem;
  letter-spacing: -.01em;
  margin-bottom: .3rem;
}
.signature-author small {
  display: block;
  font-style: normal;
  font-family: "JetBrains Mono", monospace;
  font-size: .65rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink-light);
  margin-top: .55rem;
  font-weight: 400;
}
.signature-seal {
  align-self: end;
  width: 110px;
  height: 110px;
  border: 2px solid var(--oxblood);
  border-radius: 50%;
  display: grid;
  place-items: center;
  text-align: center;
  font-family: "JetBrains Mono", monospace;
  font-size: .55rem;
  letter-spacing: .18em;
  color: var(--oxblood);
  position: relative;
  transform: rotate(-6deg);
  opacity: .8;
  line-height: 1.4;
  padding: .5rem;
}
.signature-seal::before {
  content: "";
  position: absolute;
  inset: 6px;
  border: 1px solid var(--oxblood);
  border-radius: 50%;
}
.signature-seal strong {
  display: block;
  font-family: "Fraunces", serif;
  font-style: italic;
  font-size: 1rem;
  letter-spacing: .04em;
  font-weight: 500;
  margin-bottom: .3rem;
  color: var(--oxblood);
}

.faq { margin: 2rem 0; }
.faq details {
  background: rgba(255,255,255,.4);
  border: 1px solid var(--rule);
  padding: 1rem 1.4rem;
  margin-bottom: .7rem;
  border-radius: 3px;
}
.faq details[open] { background: rgba(176,138,62,.08); border-color: var(--gold-deep); }
.faq summary {
  cursor: pointer;
  font-family: "Fraunces", serif;
  color: var(--ink-text);
  font-weight: 500;
  font-size: 1.05rem;
  list-style: none;
  position: relative;
  padding-right: 2rem;
  letter-spacing: -.005em;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
  content: "+";
  position: absolute;
  right: 0;
  top: 0;
  font-family: "JetBrains Mono", monospace;
  font-weight: 300;
  font-size: 1.4rem;
  color: var(--oxblood);
  transition: transform .25s;
}
.faq details[open] summary::after { transform: rotate(45deg); }
.faq details p {
  margin-top: .8rem;
  font-size: .95rem;
  color: var(--ink-light);
  line-height: 1.65;
  text-align: left;
}

.next-files {
  margin-top: 4rem;
  padding-top: 2.5rem;
  border-top: 1px solid var(--rule);
}
.next-files-label {
  font-family: "JetBrains Mono", monospace;
  font-size: .62rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gold-deep);
  margin-bottom: 1rem;
}
.next-files h3 {
  font-family: "Fraunces", serif;
  font-size: 1.6rem;
  font-weight: 400;
  color: var(--ink-text);
  margin: 0 0 1.2rem;
  letter-spacing: -.01em;
}
.next-files h3::before { display: none; }
.next-files-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem;
}
.next-file {
  background: rgba(255,255,255,.3);
  border: 1px dashed var(--rule);
  padding: 1rem 1.2rem;
  border-radius: 3px;
}
.next-file .num {
  font-family: "JetBrains Mono", monospace;
  font-size: .65rem;
  letter-spacing: .15em;
  color: var(--oxblood);
  font-weight: 700;
  margin-bottom: .35rem;
}
.next-file h5 {
  font-family: "Fraunces", serif;
  font-size: .98rem;
  color: var(--ink-text);
  margin: 0 0 .25rem;
  font-weight: 500;
}
.next-file p {
  font-size: .82rem;
  color: var(--ink-light);
  margin: 0;
  line-height: 1.5;
  text-align: left;
}

/* HIGHLIGHT BOX — for the dramatic 216 / 50 contrast */
.highlight-num {
  display: grid;
  grid-template-columns: 1fr 1fr;
  margin: 2rem 0;
  background: rgba(122,28,24,.06);
  border: 1px solid rgba(122,28,24,.2);
  border-radius: 4px;
  overflow: hidden;
}
@media (max-width: 600px) { .highlight-num { grid-template-columns: 1fr; } }
.highlight-num-cell {
  padding: 1.6rem 1.8rem;
  text-align: center;
  border-right: 1px solid rgba(122,28,24,.2);
}
.highlight-num-cell:last-child { border-right: none; }
@media (max-width: 600px) {
  .highlight-num-cell { border-right: none; border-bottom: 1px solid rgba(122,28,24,.2); }
  .highlight-num-cell:last-child { border-bottom: none; }
}
.highlight-num-cell .label {
  font-family: "JetBrains Mono", monospace;
  font-size: .65rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--oxblood);
  font-weight: 700;
  margin-bottom: .5rem;
}
.highlight-num-cell .big {
  font-family: "Fraunces", serif;
  font-style: italic;
  font-size: clamp(2.5rem, 6vw, 4rem);
  color: var(--oxblood-deep);
  font-weight: 400;
  line-height: 1;
  margin-bottom: .3rem;
  font-variation-settings: "SOFT" 100, "opsz" 144;
}
.highlight-num-cell .units {
  font-family: "JetBrains Mono", monospace;
  font-size: .65rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ink-light);
}
.highlight-num-cell.future .label, .highlight-num-cell.future .big { color: var(--gold-deep); }

.appendix {
  position: relative;
  z-index: 2;
  max-width: 1500px;
  margin: 0 auto 3rem;
  padding: 0 clamp(1rem, 3vw, 3rem);
}
.appendix-toggle {
  width: 100%;
  background: transparent;
  color: var(--gold);
  border: 1px solid rgba(176,138,62,.3);
  padding: 1.4rem 1.8rem;
  font-family: "JetBrains Mono", monospace;
  font-size: .78rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  transition: all .25s;
  list-style: none;
}
.appendix-toggle::-webkit-details-marker { display: none; }
.appendix-toggle:hover {
  background: rgba(176,138,62,.06);
  border-color: var(--gold);
}
.appendix-toggle::after {
  content: "+";
  font-size: 1.5rem;
  font-weight: 300;
  transition: transform .3s;
}
details[open] .appendix-toggle::after { transform: rotate(45deg); }

.appendix-content {
  padding: 2.5rem clamp(1.5rem, 4vw, 3rem);
  background: var(--ink-deep);
  border: 1px solid rgba(176,138,62,.15);
  border-top: none;
  font-size: .95rem;
  color: rgba(236,228,207,.85);
}
.appendix-content h3 {
  font-family: "Fraunces", serif;
  font-size: 1.25rem;
  font-weight: 500;
  color: var(--gold);
  margin: 2rem 0 .8rem;
  letter-spacing: -.005em;
}
.appendix-content h3:first-child { margin-top: 0; }
.appendix-content p { margin-bottom: .9rem; line-height: 1.65; }
.appendix-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 1rem 0 1.5rem;
  font-size: .85rem;
}
.appendix-content th, .appendix-content td {
  text-align: left;
  padding: .55rem .7rem;
  border-bottom: 1px solid rgba(176,138,62,.12);
  vertical-align: top;
}
.appendix-content th {
  font-family: "JetBrains Mono", monospace;
  font-size: .68rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 700;
  background: rgba(26,19,15,.5);
  white-space: nowrap;
}
.appendix-content td:first-child {
  font-family: "JetBrains Mono", monospace;
  font-size: .78rem;
  color: var(--gold);
  white-space: nowrap;
  padding-right: 1.5rem;
}
.appendix-content ul {
  margin: .5rem 0 1rem 0;
  padding-left: 1.2rem;
  list-style: none;
}
.appendix-content ul li {
  position: relative;
  padding-left: 1rem;
  margin-bottom: .5rem;
}
.appendix-content ul li::before {
  content: "›";
  position: absolute;
  left: 0;
  color: var(--gold);
  font-weight: 700;
}
.appendix-content code {
  font-family: "JetBrains Mono", monospace;
  font-size: .85em;
  background: rgba(176,138,62,.08);
  padding: .1em .4em;
  border-radius: 2px;
  color: var(--paper);
}

.dossier-footer {
  position: relative;
  z-index: 2;
  padding: 3rem clamp(1.5rem, 5vw, 5rem);
  text-align: center;
  border-top: 1px solid rgba(176,138,62,.15);
  font-family: "JetBrains Mono", monospace;
  font-size: .68rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(236,228,207,.4);
  line-height: 1.8;
}
.dossier-footer a { color: var(--gold); border: none; }
.dossier-footer a:hover { color: var(--paper); }

@media print {
  .dictamen-shell { background: white; color: black; }
  .dictamen-shell::before, .dictamen-shell::after { display: none; }
  .nav-bar { display: none; }
  .cover { background: white; color: black; min-height: auto; padding: 2rem; }
  .cover h1, .cover-deck { color: black; }
  .cover-stat { background: white; }
  .cover-stat .num, .cover-stat .label { color: black; }
  .chapter-nav, .appendix, .dossier-footer { display: none; }
  .document { box-shadow: none; padding: 0; background: white; }
  .stamp { display: none; }
  section, .chapter { break-inside: avoid; }
}

@media (prefers-reduced-motion: no-preference) {
  .cover h1, .cover-deck, .episode-mark, .cover-meta, .cover-stats {
    opacity: 0;
    transform: translateY(15px);
    animation: reveal 1.1s cubic-bezier(.2,.8,.2,1) forwards;
  }
  .episode-mark { animation-delay: .1s; }
  .cover h1 { animation-delay: .25s; }
  .cover-deck { animation-delay: .5s; }
  .cover-meta { animation-delay: .75s; }
  .cover-stats { animation-delay: .9s; }
  .stamp-cover {
    opacity: 0;
    animation: stampDrop .4s cubic-bezier(.2,1.5,.4,1) 1.2s forwards;
  }
}
@keyframes reveal {
  to { opacity: 1; transform: translateY(0); }
}
@keyframes stampDrop {
  from { opacity: 0; transform: rotate(8deg) scale(1.6); }
  to { opacity: .78; transform: rotate(8deg) scale(1); }
}

::selection { background: var(--oxblood); color: var(--paper); }
.document ::selection { background: var(--ink-text); color: var(--paper); }

/* ============================================
   CÁPSULA DOCTRINAL — hero del audio dentro del documento
   Sección ceremonial al inicio del dictamen donde la voz del
   Lic. Arroyo es protagonista. Altar editorial.
   ============================================ */
.audio-capsule {
  margin: 0 0 4rem;
  padding: 2.6rem clamp(1.4rem, 4vw, 3rem);
  background: linear-gradient(180deg, rgba(255,255,255,.55) 0%, rgba(248,242,225,.4) 100%);
  border: 2px double var(--oxblood);
  border-radius: 4px;
  position: relative;
  text-align: center;
}
.audio-capsule::before,
.audio-capsule::after {
  content: "";
  position: absolute;
  left: 50%;
  width: 50px;
  height: 1px;
  background: var(--gold);
  transform: translateX(-50%);
}
.audio-capsule::before { top: -1px; background: linear-gradient(90deg, transparent, var(--gold), transparent); width: 80px; }
.audio-capsule::after  { bottom: -1px; background: linear-gradient(90deg, transparent, var(--gold), transparent); width: 80px; }

.audio-capsule-eyebrow {
  font-family: "JetBrains Mono", monospace;
  font-size: .68rem;
  letter-spacing: .35em;
  text-transform: uppercase;
  color: var(--oxblood);
  font-weight: 700;
  margin: 0 0 .9rem;
  display: inline-flex;
  align-items: center;
  gap: 1rem;
}
.audio-capsule-eyebrow::before,
.audio-capsule-eyebrow::after {
  content: "";
  width: 28px;
  height: 1px;
  background: var(--oxblood);
  opacity: .55;
}

.audio-capsule-title {
  font-family: "Fraunces", serif;
  font-style: italic;
  font-weight: 400;
  font-variation-settings: "SOFT" 80, "opsz" 144;
  font-size: clamp(1.6rem, 3.5vw, 2.4rem);
  line-height: 1.15;
  color: var(--ink-text);
  margin: 0 0 .9rem;
  letter-spacing: -.005em;
}
.audio-capsule-title strong {
  font-style: normal;
  font-weight: 600;
  color: var(--oxblood-deep);
}

.audio-capsule-deck {
  font-family: "Source Serif 4", serif;
  font-size: 1.05rem;
  line-height: 1.6;
  color: var(--ink-light);
  max-width: 56ch;
  margin: 0 auto 2.2rem;
  text-align: center;
  font-style: italic;
}

.audio-capsule-stage {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.2rem;
  margin: 0 auto 1.8rem;
  max-width: 580px;
}

.audio-capsule-play {
  width: 76px; height: 76px;
  border-radius: 50%;
  border: 2px solid var(--oxblood);
  background: var(--oxblood);
  color: var(--paper);
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: transform .15s ease, box-shadow .2s ease, background .2s ease;
  padding: 0;
  box-shadow: 0 6px 20px -4px rgba(122,28,24,.35),
              inset 0 0 0 4px var(--paper),
              inset 0 0 0 5px var(--oxblood);
}
.audio-capsule-play:hover {
  transform: scale(1.04);
  box-shadow: 0 10px 26px -4px rgba(122,28,24,.5),
              inset 0 0 0 4px var(--paper),
              inset 0 0 0 5px var(--oxblood);
}
.audio-capsule-play:active { transform: scale(.97); }
.audio-capsule-play svg { width: 26px; height: 26px; fill: currentColor; }
.audio-capsule-play svg.icon-pause { display: none; }
.audio-capsule[data-playing="true"] .audio-capsule-play .icon-play { display: none; }
.audio-capsule[data-playing="true"] .audio-capsule-play .icon-pause { display: block; }

.audio-capsule-track {
  width: 100%;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: .9rem;
  align-items: center;
  font-family: "JetBrains Mono", monospace;
  font-size: .75rem;
  color: var(--ink-light);
  letter-spacing: .04em;
}
.audio-capsule-progress {
  height: 4px;
  background: rgba(26,24,20,.15);
  border-radius: 2px;
  position: relative;
  cursor: pointer;
  overflow: hidden;
}
.audio-capsule-progress::before {
  content: "";
  position: absolute;
  inset: -10px 0;
}
.audio-capsule-bar {
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 0%;
  background: linear-gradient(90deg, var(--oxblood) 0%, var(--gold) 100%);
  border-radius: 2px;
  transition: width .15s linear;
}

.audio-capsule-actions {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem 1.5rem;
  margin-top: 1.6rem;
  padding-top: 1.6rem;
  border-top: 1px solid var(--rule);
}
.audio-capsule-action {
  font-family: "JetBrains Mono", monospace;
  font-size: .68rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--oxblood-deep);
  text-decoration: none;
  border: 1px solid var(--oxblood);
  padding: .65rem 1.1rem;
  border-radius: 3px;
  transition: background .2s ease, color .2s ease;
  cursor: pointer;
  background: transparent;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  gap: .55rem;
}
.audio-capsule-action svg { width: 14px; height: 14px; fill: none; stroke: currentColor; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.audio-capsule-action:hover {
  background: var(--oxblood);
  color: var(--paper);
}

.audio-capsule-transcript {
  margin-top: 1.5rem;
  text-align: left;
  border-top: 1px solid var(--rule);
  padding-top: 1.4rem;
}
.audio-capsule[data-show-transcript="false"] .audio-capsule-transcript { display: none; }
.audio-capsule-transcript-label {
  font-family: "JetBrains Mono", monospace;
  font-size: .58rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--gold-deep);
  font-weight: 700;
  margin-bottom: .8rem;
  text-align: center;
}
.audio-capsule-transcript p {
  font-family: "Source Serif 4", serif;
  font-size: 1rem;
  line-height: 1.65;
  color: var(--ink-soft);
  margin: 0 0 .9rem;
  text-align: justify;
  hyphens: auto;
}
.audio-capsule-transcript p strong {
  color: var(--oxblood-deep);
  font-weight: 600;
}
.audio-capsule-transcript p:last-child { margin-bottom: 0; }

/* ============================================
   COVER HERO IMAGE — banner editorial arriba del cover
   ============================================ */
.cover-hero-image {
  position: relative;
  width: 100%;
  margin: 0 0 1.5rem;
  background: var(--ink-deepest);
  overflow: hidden;
  border-bottom: 1px solid rgba(176,138,62,.25);
  box-shadow:
    inset 0 -60px 80px -40px rgba(12,11,10,.85),
    0 4px 20px rgba(0,0,0,.4);
}
.cover-hero-image::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 2;
  background:
    linear-gradient(180deg, rgba(12,11,10,0) 60%, rgba(12,11,10,.55) 100%),
    radial-gradient(ellipse at center, transparent 50%, rgba(0,0,0,.35) 100%);
}
.cover-hero-image::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 3px;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(176,138,62,.6) 20%,
    var(--gold) 50%,
    rgba(176,138,62,.6) 80%,
    transparent 100%);
  z-index: 3;
}
.cover-hero-image img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  object-fit: contain;
  object-position: center;
  background: var(--ink-deepest);
  filter: saturate(.95) contrast(1.02);
}

@media (max-width: 700px) {
  .cover-hero-image { margin-bottom: 1rem; }
}

@media print {
  .cover-hero-image { page-break-inside: avoid; }
  .cover-hero-image::before, .cover-hero-image::after { display: none; }
}

/* Ajuste cover: cuando hay hero image, el padding-top se reduce para que la
   imagen sea el primer elemento visual del documento. */
.cover.has-hero { padding-top: 0; }
.cover.has-hero .cover-top { padding-top: 1.5rem; }

/* ============================================
   AUDIO DOCK — sticky audio player + transcript
   ============================================ */
.audio-dock {
  position: fixed;
  /* Desktop: bottom-LEFT para no colisionar con el FAB de WhatsApp (bottom-right). */
  bottom: 1.25rem;
  left: 1.25rem;
  right: auto;
  z-index: 90;
  width: 320px;
  max-width: calc(100vw - 2.5rem);
  background: var(--paper);
  color: var(--ink-text);
  border: 1px solid rgba(122,28,24,.25);
  border-radius: 6px;
  box-shadow:
    0 0 0 1px rgba(0,0,0,.05),
    0 18px 40px -12px rgba(0,0,0,.45),
    0 6px 18px -6px rgba(122,28,24,.18);
  overflow: hidden;
  transition: width .3s cubic-bezier(.2,.8,.2,1), transform .3s ease;
  font-family: "Source Serif 4", Georgia, serif;
}
.audio-dock[data-expanded="true"] { width: 380px; }
@media (max-width: 900px) {
  /* Tablet/mobile: full-width al pie, pero LEVANTADO ~78px para no quedar tapado
     por el FAB de WhatsApp (que vive en bottom-right con ~62px de diametro + margen). */
  .audio-dock {
    bottom: 78px;
    left: 0;
    right: 0;
    width: auto;
    max-width: none;
    border-radius: 6px 6px 0 0;
    border-bottom: none;
  }
  .audio-dock[data-expanded="true"] { width: auto; }
}

.audio-dock::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: .25;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.92' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.4 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

.audio-dock-header {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center;
  gap: .7rem;
  padding: .85rem 1rem;
  position: relative;
}

.audio-dock-play {
  width: 38px; height: 38px;
  border-radius: 50%;
  border: 1.5px solid var(--oxblood);
  background: var(--oxblood);
  color: var(--paper);
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease, background .2s ease;
  padding: 0;
  flex-shrink: 0;
}
.audio-dock-play:hover {
  transform: scale(1.05);
  box-shadow: 0 4px 14px rgba(122,28,24,.4);
}
.audio-dock-play:active { transform: scale(.95); }
.audio-dock-play svg { width: 14px; height: 14px; fill: currentColor; }
.audio-dock-play .icon-pause { display: none; }
.audio-dock[data-playing="true"] .audio-dock-play .icon-play { display: none; }
.audio-dock[data-playing="true"] .audio-dock-play .icon-pause { display: block; }

.audio-dock-meta {
  min-width: 0;
  line-height: 1.2;
}
.audio-dock-label {
  font-family: "JetBrains Mono", monospace;
  font-size: .58rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--oxblood);
  font-weight: 700;
  margin-bottom: 2px;
}
.audio-dock-title {
  font-family: "Fraunces", serif;
  font-size: .95rem;
  color: var(--ink-text);
  font-weight: 500;
  letter-spacing: -.005em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.audio-dock-timer {
  font-family: "JetBrains Mono", monospace;
  font-size: .68rem;
  color: var(--ink-light);
  margin-top: 2px;
  letter-spacing: .04em;
}

.audio-dock-iconbtn {
  width: 30px; height: 30px;
  background: transparent;
  border: none;
  color: var(--ink-light);
  display: grid;
  place-items: center;
  cursor: pointer;
  border-radius: 4px;
  transition: background .15s ease, color .15s ease;
  padding: 0;
}
.audio-dock-iconbtn:hover {
  background: rgba(122,28,24,.08);
  color: var(--oxblood);
}
.audio-dock-iconbtn svg { width: 16px; height: 16px; fill: none; stroke: currentColor; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.audio-dock-iconbtn[data-state="active"] { color: var(--oxblood); }

.audio-dock[data-expanded="true"] .audio-dock-toggle .icon-chevron {
  transform: rotate(180deg);
}
.audio-dock-toggle .icon-chevron { transition: transform .25s ease; }

.audio-dock-progress {
  position: relative;
  height: 4px;
  background: rgba(26,24,20,.12);
  cursor: pointer;
}
.audio-dock-progress::before {
  content: "";
  position: absolute;
  inset: -8px 0;
}
.audio-dock-progress-bar {
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 0%;
  background: linear-gradient(90deg, var(--oxblood) 0%, var(--gold) 100%);
  transition: width .15s linear;
}
.audio-dock-progress-bar::after {
  content: "";
  position: absolute;
  right: -5px; top: 50%;
  transform: translateY(-50%);
  width: 10px; height: 10px;
  background: var(--oxblood);
  border-radius: 50%;
  border: 2px solid var(--paper);
  opacity: 0;
  transition: opacity .2s ease;
}
.audio-dock[data-playing="true"] .audio-dock-progress-bar::after,
.audio-dock-progress:hover .audio-dock-progress-bar::after { opacity: 1; }

.audio-dock-transcript {
  display: none;
  border-top: 1px solid rgba(26,24,20,.1);
  background: rgba(255,255,255,.4);
}
.audio-dock[data-expanded="true"] .audio-dock-transcript { display: block; }

.audio-dock-transcript-inner {
  max-height: 280px;
  overflow-y: auto;
  padding: 1rem 1.1rem 1.1rem;
  font-family: "Source Serif 4", Georgia, serif;
  font-size: .92rem;
  line-height: 1.55;
  color: var(--ink-soft);
}
.audio-dock-transcript-inner::-webkit-scrollbar { width: 6px; }
.audio-dock-transcript-inner::-webkit-scrollbar-track { background: transparent; }
.audio-dock-transcript-inner::-webkit-scrollbar-thumb {
  background: rgba(122,28,24,.25);
  border-radius: 3px;
}
.audio-dock-transcript-inner p {
  margin: 0 0 .7rem;
  text-align: left;
  text-indent: 0;
}
.audio-dock-transcript-inner p:last-child { margin-bottom: 0; }
.audio-dock-transcript-inner p strong {
  color: var(--oxblood-deep);
  font-weight: 600;
}
.audio-dock-transcript-label {
  display: block;
  font-family: "JetBrains Mono", monospace;
  font-size: .58rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--oxblood);
  font-weight: 700;
  margin-bottom: .55rem;
  padding-bottom: .45rem;
  border-bottom: 1px solid rgba(122,28,24,.15);
}

.audio-dock audio { display: none; }

@media print { .audio-dock { display: none; } }

/* ============================================================
 * ARCHIVE — /dictamenes
 * Grilla de cards con paleta dossier (oxblood + gold + paper).
 * ============================================================ */

.dictamen-shell.dictamen-archive {
  background: var(--ink-deepest);
  color: var(--warm-white);
  min-height: 100vh;
  padding: 0 0 6rem;
  position: relative;
  z-index: 2;
}

.dictamen-archive-hero {
  padding: 5rem clamp(1.5rem, 5vw, 5rem) 3rem;
  background:
    radial-gradient(circle at 20% 10%, rgba(176,138,62,.10), transparent 50%),
    radial-gradient(circle at 80% 90%, rgba(122,28,24,.12), transparent 60%),
    var(--ink-deepest);
  border-bottom: 1px solid rgba(176,138,62,.18);
  margin-bottom: 4rem;
}

.dictamen-archive-hero-inner {
  max-width: 1100px;
  margin: 0 auto;
}

.dictamen-archive-eyebrow {
  font-family: "JetBrains Mono", monospace;
  font-size: .72rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 1.5rem;
}

.dictamen-archive-title {
  font-family: "Fraunces", serif;
  font-weight: 300;
  font-size: clamp(2.6rem, 7vw, 5rem);
  line-height: 1;
  letter-spacing: -0.025em;
  color: var(--warm-white);
  margin-bottom: 1.5rem;
  font-variation-settings: "SOFT" 50;
}
.dictamen-archive-title em {
  font-style: italic;
  color: var(--gold);
  font-variation-settings: "SOFT" 100;
}

.dictamen-archive-deck {
  font-family: "Source Serif 4", Georgia, serif;
  font-size: 1.15rem;
  line-height: 1.6;
  color: rgba(236,228,207,.78);
  font-style: italic;
  max-width: 720px;
}

.dictamen-archive-grid {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 clamp(1.5rem, 4vw, 4rem);
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
}
@media (min-width: 720px) {
  .dictamen-archive-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1080px) {
  .dictamen-archive-grid { grid-template-columns: repeat(3, 1fr); }
  .dictamen-card--featured { grid-column: span 3; }
}

.dictamen-card {
  background: rgba(15,13,11,.6);
  border: 1px solid rgba(176,138,62,.18);
  position: relative;
  transition: transform .25s, border-color .25s, background .25s;
}
.dictamen-card:hover {
  border-color: rgba(176,138,62,.5);
  background: rgba(20,17,14,.85);
  transform: translateY(-3px);
}
.dictamen-card__link {
  display: block;
  color: inherit;
  border-bottom: none;
}
.dictamen-card__image {
  position: relative;
  aspect-ratio: 16/9;
  overflow: hidden;
  background: var(--ink-deepest);
}
.dictamen-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.dictamen-card__badge {
  position: absolute;
  top: 14px;
  left: 14px;
  background: var(--oxblood);
  color: var(--warm-white);
  padding: 6px 14px;
  font-family: "JetBrains Mono", monospace;
  font-size: .68rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-weight: 700;
  box-shadow: 0 2px 8px rgba(0,0,0,.35);
}
.dictamen-card__body {
  padding: 1.6rem 1.4rem 1.4rem;
}
.dictamen-card__rama {
  font-family: "JetBrains Mono", monospace;
  font-size: .65rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: .8rem;
}
.dictamen-card__title {
  font-family: "Fraunces", serif;
  font-weight: 400;
  font-size: 1.5rem;
  line-height: 1.2;
  margin-bottom: .8rem;
  color: var(--warm-white);
  font-variation-settings: "SOFT" 70;
}
.dictamen-card--featured .dictamen-card__title {
  font-size: 2.2rem;
  font-weight: 300;
}
.dictamen-card__excerpt {
  font-family: "Source Serif 4", Georgia, serif;
  font-size: .98rem;
  line-height: 1.55;
  color: rgba(236,228,207,.7);
  margin-bottom: 1.2rem;
}
.dictamen-card--featured .dictamen-card__excerpt {
  font-size: 1.08rem;
}
.dictamen-card__meta {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-wrap: wrap;
  font-family: "JetBrains Mono", monospace;
  font-size: .7rem;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.dictamen-card__date,
.dictamen-card__audio {
  color: rgba(236,228,207,.6);
  display: inline-flex;
  align-items: center;
  gap: .4rem;
}
.dictamen-card__cta {
  margin-left: auto;
  color: var(--gold);
}

.dictamen-archive-empty {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
  font-family: "Fraunces", serif;
  font-style: italic;
  font-size: 1.4rem;
  color: rgba(236,228,207,.55);
  padding: 4rem 0;
}

.dictamen-archive-pagination {
  max-width: 1280px;
  margin: 4rem auto 0;
  padding: 0 clamp(1.5rem, 4vw, 4rem);
  display: flex;
  justify-content: center;
  font-family: "JetBrains Mono", monospace;
}


/* ============================================================
 * Shortcodes nuevos — clases que el prototipo NO tenia.
 * Las clases que SI tiene el prototipo (.lens, .penal-card,
 * .testimonio, .editorial-note, .pullquote, .timeline,
 * .highlight-num, .factbox, .actors, .matrix-table) NO se
 * re-definen aqui — usan el styling original del prototipo
 * que asume contexto `.document` (paper bg + dark text).
 * ============================================================ */

/* Cuestiones / Conclusiones lists (shortcodes [bfcr_dictamen_cuestiones|conclusiones]) */
.document .cuestiones-list,
.document .conclusiones-list {
  list-style: none;
  padding-left: 0;
  margin: 2rem 0;
  counter-reset: c-list;
}
.document .cuestiones-list li,
.document .conclusiones-list li {
  position: relative;
  margin-bottom: 1.4rem;
  padding-left: 1.6rem;
  border-left: 2px solid var(--oxblood);
  font-family: "Source Serif 4", Georgia, serif;
  line-height: 1.7;
  color: var(--ink-text);
}
.document .cuestiones-list li strong,
.document .conclusiones-list li strong {
  color: var(--oxblood);
  font-family: "Fraunces", serif;
  font-style: italic;
  font-weight: 600;
  font-variation-settings: "SOFT" 90;
}

/* Signature seal del shortcode [bfcr_dictamen_signature] */
.document .signature-block {
  margin: 3.5rem auto 2rem;
  text-align: center;
  max-width: 540px;
  padding: 1rem;
  border-top: 1px solid rgba(122,28,24,.25);
  padding-top: 2.5rem;
}
.document .signature-place {
  font-family: "JetBrains Mono", monospace;
  font-size: .72rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gold-deep);
  margin-bottom: 1.2rem;
}
.document .signature-name {
  font-family: "Fraunces", serif;
  font-size: 1.4rem;
  font-weight: 500;
  color: var(--ink-text);
  margin-bottom: .3rem;
  font-variation-settings: "SOFT" 60;
}
.document .signature-title {
  font-family: "Source Serif 4", serif;
  font-style: italic;
  color: var(--ink-light);
  margin-bottom: .3rem;
}
.document .signature-url {
  font-family: "JetBrains Mono", monospace;
  font-size: .72rem;
  letter-spacing: .12em;
  margin-bottom: 1.5rem;
  color: var(--gold-deep);
}
.document .signature-seal {
  width: 130px;
  height: 130px;
  margin: 0 auto;
  border-radius: 50%;
  border: 2px solid var(--oxblood);
  outline: 1px solid var(--oxblood);
  outline-offset: 6px;
  display: grid;
  place-items: center;
  transform: rotate(-8deg);
  background: rgba(122,28,24,.04);
}
.document .signature-seal-inner {
  text-align: center;
  font-family: "JetBrains Mono", monospace;
  font-size: .6rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--oxblood);
  line-height: 1.4;
  padding: 4px;
}
.document .signature-seal-inner strong {
  display: block;
  font-family: "Fraunces", serif;
  font-style: italic;
  font-weight: 600;
  font-size: 1.4rem;
  letter-spacing: .04em;
  color: var(--oxblood);
  margin-bottom: 4px;
  font-variation-settings: "SOFT" 80;
}
.document .signature-seal-inner span {
  display: block;
  font-size: .56rem;
}

/* penal-card-title + penal-card-tags wrappers del shortcode */
.document .penal-card-title {
  font-family: "Fraunces", serif;
  font-weight: 500;
  font-size: 1.3rem;
  color: var(--ink-text);
  margin-bottom: .8rem;
  font-variation-settings: "SOFT" 80;
}
.document .penal-card-tags {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
  margin-bottom: 1rem;
}

/* Print: ocultar dock + chapter nav */
@media print {
  .dictamen-shell .audio-dock,
  .dictamen-shell .chapter-nav,
  .dictamen-shell::before,
  .dictamen-shell::after { display: none !important; }
  .dictamen-shell { background: white !important; color: black !important; }
  .dictamen-shell .audio-capsule { page-break-inside: avoid; }
}

/* ============================================================
 * Integracion con el footer del theme (Avante/Elementor).
 * El footer empieza con un Elementor shape divider (tilt blanco)
 * que en una pagina dictamen luce mal contra el fondo oscuro.
 * Lo coloreamos igual al fondo --ink-deepest para que la transicion
 * sea seamless: el dossier oscuro "baja" hacia el footer sin corte.
 * ============================================================ */
.single-dictamen .elementor-shape-top .elementor-shape-fill,
.post-type-archive-dictamen .elementor-shape-top .elementor-shape-fill {
  fill: var(--ink-deepest);
}
/* Padding inferior del dossier para evitar gaps en blanco entre el
   .document (paper) y el inicio del footer. */
.single-dictamen .dictamen-shell .dossier,
.post-type-archive-dictamen .dictamen-shell {
  padding-bottom: 0;
}
/* Eliminar margen negro entre dictamen-shell y footer-wrapper si lo hubiera */
.single-dictamen #footer-wrapper,
.post-type-archive-dictamen #footer-wrapper {
  margin-top: 0;
}

/* ============================================================
 * Lentes interactivos — <details> + <summary> con CSS
 * smooth transition. Click expande el card y revela respuesta.
 * Multi-open: el usuario puede expandir varios a la vez.
 * ============================================================ */

.document .lens-grid-interactive {
  /* mantiene el grid 3x2 del prototipo */
}

.document details.lens-interactive {
  cursor: pointer;
  transition: background .25s, border-color .25s, box-shadow .25s;
  position: relative;
}
.document details.lens-interactive[open] {
  border-color: var(--oxblood);
  box-shadow:
    0 0 0 1px rgba(122,28,24,.15),
    0 12px 28px -10px rgba(0,0,0,.18);
  background: linear-gradient(180deg, rgba(243,231,191,.4), transparent 60%);
}

.document details.lens-interactive summary {
  list-style: none;
  outline: none;
  position: relative;
  padding-right: 2.5rem;  /* espacio para el toggle "+" */
}
.document details.lens-interactive summary::-webkit-details-marker { display: none; }
.document details.lens-interactive summary::marker { content: ""; }

.document details.lens-interactive summary:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 4px;
}

.document .lens-question {
  color: var(--ink-soft);
  margin-bottom: 0;
}

/* Toggle "+/-" como pseudo-element del summary — evita que wpautop rompa el HTML */
.document details.lens-interactive summary::after {
  content: "+";
  position: absolute;
  top: 1rem;
  right: 1rem;
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(122,28,24,.4);
  border-radius: 50%;
  font-family: "JetBrains Mono", monospace;
  font-size: 1.1rem;
  font-weight: 500;
  color: var(--oxblood);
  background: var(--paper);
  transition: background .25s, color .25s, border-color .25s;
  user-select: none;
  line-height: 1;
}
.document details.lens-interactive[open] summary::after {
  content: "−";
  background: var(--oxblood);
  color: var(--paper);
  border-color: var(--oxblood);
}

.document .lens-answer {
  margin-top: 1.2rem;
  padding-top: 1.2rem;
  border-top: 1px solid rgba(122,28,24,.15);
  font-family: "Source Serif 4", Georgia, serif;
  color: var(--ink-text);
  line-height: 1.7;
  animation: lens-reveal .35s cubic-bezier(.2,.8,.2,1);
}
.document .lens-answer p {
  margin-bottom: .8rem;
  color: var(--ink-text);
}
.document .lens-answer strong {
  color: var(--oxblood);
}

.document .lens-anchor {
  margin-top: .6rem;
  font-family: "JetBrains Mono", monospace;
  font-size: .72rem;
  letter-spacing: .08em;
}
.document .lens-anchor a {
  color: var(--gold-deep);
  text-transform: uppercase;
  font-weight: 600;
  border-bottom: 1px solid var(--gold-deep);
}
.document .lens-anchor a:hover {
  color: var(--oxblood);
  border-bottom-color: var(--oxblood);
}

@keyframes lens-reveal {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Hint sutil al primer hover para que el usuario sepa que es clickable */
.document details.lens-interactive:not([open]):hover {
  transform: translateY(-1px);
  border-color: rgba(122,28,24,.4);
}

/* Views badge en archive cards */
.dictamen-card__views {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  color: rgba(236, 228, 207, 0.6);
  font-family: "JetBrains Mono", monospace;
  font-size: .7rem;
  letter-spacing: .08em;
}
.dictamen-card__views svg {
  opacity: .8;
}

/* ============================================================
 * Fix sticky: Avante define `#perspective { overflow-x: hidden }`
 * que crea un scrolling container y rompe `position: sticky` de
 * todos los descendientes (incluyendo el chapter-nav del dictamen).
 * Override SOLO en single-dictamen + archive a `overflow-x: clip`
 * que evita scroll horizontal sin crear scroll container.
 * ============================================================ */
.single-dictamen #perspective,
.post-type-archive-dictamen #perspective {
  overflow-x: clip;
}
