/* ===== Dossier — sistema de diseño editorial ===== */
@font-face{font-family:"Bodoni Moda";src:url("../assets/fonts/BodoniModa-400.woff2") format("woff2");font-weight:400;font-display:swap}
@font-face{font-family:"Bodoni Moda";src:url("../assets/fonts/BodoniModa-600.woff2") format("woff2");font-weight:600;font-display:swap}
@font-face{font-family:"Bodoni Moda";src:url("../assets/fonts/BodoniModa-800.woff2") format("woff2");font-weight:800;font-display:swap}
@font-face{font-family:"Newsreader";src:url("../assets/fonts/Newsreader-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Newsreader";src:url("../assets/fonts/Newsreader-Italic.woff2") format("woff2");font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:"IBM Plex Mono";src:url("../assets/fonts/IBMPlexMono-400.woff2") format("woff2");font-weight:400;font-display:swap}

:root{
  --paper:#f1ede2; --ink:#171310; --ink-soft:#5a534a; --red:#d2402b;
  --display:"Bodoni Moda",Georgia,serif;
  --serif:"Newsreader",Georgia,serif;
  --mono:"IBM Plex Mono",ui-monospace,monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%;background:#0b0a08;overflow:hidden}
body{display:grid;place-items:center}
#fit{width:100vw;height:100vh;display:grid;place-items:center}
#stage{width:1280px;height:720px;position:relative;background:var(--paper);color:var(--ink);overflow:hidden;flex:none}

.grain{position:absolute;inset:0;pointer-events:none;opacity:.5;mix-blend-mode:multiply;z-index:5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='0.35'/%3E%3C/svg%3E")}

/* Una escena = una grilla: texto izquierda · medio derecha */
.slide{position:absolute;inset:0;display:none}
.slide.is-active{display:block}
.grid{position:absolute;inset:0;display:grid;grid-template-columns:1fr 560px;gap:60px;
  align-items:center;padding:96px 84px 84px;z-index:1}
.grid.solo{grid-template-columns:1fr}
.grid.solo .col-text{max-width:1000px}

.topline{position:absolute;left:84px;right:84px;top:40px;display:flex;justify-content:space-between;
  align-items:baseline;font-family:var(--mono);font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-soft);z-index:3}
.topline .r{color:var(--red)}
.topline::after{content:"";position:absolute;left:0;right:0;top:28px;height:1px;background:currentColor;opacity:.26}
.folio{position:absolute;right:84px;bottom:38px;font-family:var(--mono);font-size:12px;letter-spacing:.18em;color:var(--ink-soft);z-index:3}
.baseline{position:absolute;left:84px;bottom:38px;font-family:var(--mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);z-index:3}

.col-text{min-width:0;display:flex;flex-direction:column}
.kicker{font-family:var(--mono);font-size:13px;letter-spacing:.3em;text-transform:uppercase;color:var(--red)}
h1{font-family:var(--display);font-weight:600;font-size:44px;line-height:1.05;letter-spacing:-.012em;margin-top:14px}
h1.big{font-size:58px;font-weight:800}
.quote{font-family:var(--serif);font-style:italic;font-size:25px;line-height:1.36;margin-top:22px}
.quote .tr{display:block;font-size:15px;font-style:italic;color:var(--ink-soft);margin-top:6px}
.mark{position:relative;white-space:nowrap}
.mark::after{content:"";position:absolute;left:-.05em;right:-.05em;bottom:.05em;height:.4em;background:var(--red);opacity:.22;z-index:-1;transform:skewX(-9deg)}
.cite{font-family:var(--mono);font-size:12px;letter-spacing:.03em;color:var(--ink-soft);margin-top:14px}
.col-text ul{list-style:none;display:grid;gap:10px;margin-top:22px}
.col-text li{font-family:var(--serif);font-size:19px;line-height:1.32;padding-left:26px;position:relative;color:var(--ink)}
.col-text li::before{content:"\2014";position:absolute;left:0;color:var(--red);font-family:var(--mono)}
.redrule{width:88px;height:3px;background:var(--red);margin:20px 0 4px}

/* Columna de medios — siempre a la derecha, redondeada */
.col-media{display:flex;flex-direction:column;justify-content:center;gap:12px}
.frame{position:relative;width:100%;border-radius:16px;overflow:hidden;background:#000;
  box-shadow:0 16px 44px rgba(0,0,0,.32)}
.frame.v{width:100%;aspect-ratio:16/9}
.frame.v iframe,.frame.v img{position:absolute;inset:0;width:100%;height:100%;border:0;object-fit:cover}
.frame.portrait{height:540px;width:auto;aspect-ratio:9/16;margin:0 auto}
.frame.portrait iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.frame.pic{height:472px;width:auto;aspect-ratio:4/5;margin:0 auto}
.frame.pic img{position:absolute;inset:0;width:100%;height:100%;border:0;object-fit:cover;filter:grayscale(.12) contrast(1.04)}
.frame.photo{width:100%;aspect-ratio:3/2}
.frame.photo img{position:absolute;inset:0;width:100%;height:100%;border:0;object-fit:cover;filter:grayscale(.1) contrast(1.04)}
.frame::after{content:"";position:absolute;inset:0;border-radius:16px;border:1px solid rgba(0,0,0,.18);pointer-events:none}
.credit{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--ink-soft);text-align:right}
.col-media .vcap{font-family:var(--serif);font-style:italic;font-size:17px;color:var(--ink-soft);text-align:right}

/* Comparativa: dos retratos apilados a la derecha */
.col-media.duo{gap:16px}
.duo .pair{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.duo .pair figure{margin:0;text-align:center}
.duo .pair img{width:100%;aspect-ratio:3/4;object-fit:cover;border-radius:14px;filter:grayscale(.15) contrast(1.05);display:block}
.duo .pair figcaption{font-family:var(--serif);font-style:italic;font-size:15px;margin-top:8px}
.duo .pair .who{font-family:var(--mono);font-style:normal;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-top:3px}

/* Chart editorial (escena 04, solo) */
.chart{margin-top:26px;display:grid;width:100%}
.crow{display:grid;grid-template-columns:320px 1fr 80px;align-items:center;gap:28px;padding:11px 0;border-top:1px solid rgba(23,19,16,.2)}
.crow:last-child{border-bottom:1px solid rgba(23,19,16,.2)}
.clab{font-family:var(--mono);font-size:14px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-soft)}
.ctrack{height:7px;background:rgba(23,19,16,.13);position:relative;overflow:hidden;min-width:0;border-radius:4px}
.cbar{height:100%;background:var(--ink);transform:scaleX(1);transform-origin:left center;border-radius:4px}
.cfig{font-family:var(--display);font-weight:600;font-size:30px;text-align:right}
.crow.key{border-color:var(--red)}
.crow.key .clab,.crow.key .cfig{color:var(--red)}
.crow.key .cbar{background:var(--red)}
/* Gráfico compacto para la columna derecha (escena 04) */
.chart.compact{margin-top:0}
.chart.compact .crow{grid-template-columns:128px 1fr 40px;gap:14px;padding:10px 0}
.chart.compact .clab{font-size:10.5px;letter-spacing:.02em;line-height:1.25}
.chart.compact .cfig{font-size:22px}

/* ===== Detonante (tinta invertida) ===== */
html.dark #stage{background:var(--ink)}
.slide.dark{background:var(--ink);color:var(--paper)}
.slide.dark .topline,.slide.dark .folio,.slide.dark .baseline{color:rgba(241,237,226,.55)}
.slide.dark .topline .r,.slide.dark .kicker{color:var(--red)}
.slide.dark h1{color:var(--paper)}
.slide.dark .quote{color:var(--paper)}
.slide.dark .quote .tr{color:rgba(241,237,226,.6)}
.slide.dark .cite{color:rgba(241,237,226,.55)}
.slide.dark li{color:rgba(241,237,226,.92)}
.slide.dark .credit,.slide.dark .col-media .vcap{color:rgba(241,237,226,.55)}
.slide.dark .duo .pair figcaption{color:var(--paper)}
.slide.dark .frame::after{border-color:rgba(241,237,226,.16)}

/* Fallback de embed */
.embed-fallback{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:14px;background:#181410;color:rgba(241,237,226,.8);text-align:center;padding:26px}
.embed-fallback img{max-width:72%;max-height:55%;object-fit:cover;border-radius:8px}
.embed-fallback a{color:var(--red);font-family:var(--mono);font-size:13px;letter-spacing:.06em}

/* Navegación */
#prog{position:absolute;left:0;top:0;height:3px;background:var(--red);width:0;z-index:8;transition:width .45s ease}
#hint{position:absolute;left:50%;bottom:13px;transform:translateX(-50%);font-family:var(--mono);font-size:11px;
  letter-spacing:.2em;color:var(--ink-soft);opacity:.5;text-transform:uppercase;z-index:8}
html.dark #hint{color:rgba(241,237,226,.4)}

/* Animaciones: solo mejora; por defecto todo visible */
.js-anim .anim{opacity:0;transform:translateY(16px)}
.js-anim .slide.is-active .anim{animation:rise .8s cubic-bezier(.16,.8,.26,1) forwards}
.js-anim .slide.is-active .d1{animation-delay:.04s}.js-anim .slide.is-active .d2{animation-delay:.14s}
.js-anim .slide.is-active .d3{animation-delay:.26s}.js-anim .slide.is-active .d4{animation-delay:.38s}
.js-anim .slide.is-active .d5{animation-delay:.5s}
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.js-anim .cbar{transform:scaleX(0)}
.js-anim .slide.is-active .cbar{animation:grow 1s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes grow{from{transform:scaleX(0)}to{transform:scaleX(1)}}
@media (prefers-reduced-motion:reduce){#prog{transition:none}}

/* Plan B PDF (Ctrl+P) */
@media print{
  @page{size:1280px 720px;margin:0}
  html,body{height:auto;overflow:visible;background:#fff;display:block}
  #fit{display:block;width:1280px;height:auto}
  #stage{transform:none!important;width:1280px;height:auto;overflow:visible}
  #prog,#hint{display:none}
  .slide{position:relative!important;inset:auto!important;display:block!important;width:1280px;height:720px;break-after:page}
  .slide:last-of-type{break-after:auto}
  .anim{opacity:1!important;transform:none!important}
  .cbar{transform:scaleX(1)!important}
  *{-webkit-print-color-adjust:exact;print-color-adjust:exact}
}
