/* ════════════════════════════════════════════════════
   O FANTÁSTICO LABORATÓRIO — PITCH DECK v2
   Co-produção & Distribuição
════════════════════════════════════════════════════ */

/* ── INTRO VIDEO SLIDE ────────────────────────────── */
.slide-intro { padding: 0; overflow: hidden; }

/* iframe full-cover (16:9 fill) */
.yt-frame-wrap {
  position: absolute;
  inset: 0;
  z-index: 1;
  overflow: hidden;
  pointer-events: none;
  background: #000;
}
.yt-frame-wrap iframe {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 177.78vh;   /* 16/9 × 100vh */
  height: 56.25vw;   /* 9/16 × 100vw */
  min-width: 100%; min-height: 100%;
  border: none;
  pointer-events: none;
}

/* VHS scanlines */
.vhs-overlay {
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
}
.vhs-overlay::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    to bottom,
    transparent 0px, transparent 2px,
    rgba(0,0,0,.18) 2px, rgba(0,0,0,.18) 4px
  );
}
.vhs-overlay::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    transparent 0%, rgba(255,20,20,.04) 22%,
    transparent 44%, rgba(0,244,255,.03) 66%,
    transparent 88%
  );
  animation: vhs-flicker .12s infinite;
}
@keyframes vhs-flicker {
  0%,100% { opacity:1; }
  50%     { opacity:.88; }
}

/* VHS glitch bar */
.vhs-glitch-line {
  position: absolute;
  left: 0; right: 0;
  height: 2px;
  background: rgba(57,255,20,.55);
  opacity: 0;
  z-index: 4;
  pointer-events: none;
  animation: vhs-bar 5s linear infinite;
}
@keyframes vhs-bar {
  0%   { top: -2px; opacity: 0; }
  1%   { opacity: .8; }
  12%  { top: 102%; opacity: 0; }
  100% { top: 102%; opacity: 0; }
}

/* ── SLIDE 0: INTRO LOGO ──────────────────────── */
.s00-inner {
  position: absolute;
  inset: 0;
  z-index: 5;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1.2rem;
  pointer-events: none;
}

/* Animações auto-iniciadas via @keyframes — sem dependência de JS.
   fill-mode:both aplica o estado "from" (opacity:0) antes do delay,
   mantém o estado "to" depois. Funciona em qualquer servidor. */
.s00-logo {
  height: clamp(60px, 12vw, 120px);
  width: auto;
  animation: s00-logo-in .9s .5s cubic-bezier(.22,.68,0,1.2) both,
             s00-pulse   2.6s 1.5s ease-in-out infinite;
}
.s00-tag {
  font-family: var(--serif);
  font-size: clamp(.75rem, 1.3vw, .95rem);
  font-style: italic;
  letter-spacing: .04em;
  color: rgba(0,244,255,.7);
  text-align: center;
  max-width: 520px;
  animation: s00-up  .7s .8s  ease both;
}
.s00-cred {
  font-family: var(--mono);
  font-size: .56rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: rgba(0,244,255,.45);
  animation: s00-dim .7s .95s ease both;
}
.s00-co {
  height: 52px;
  width: auto;
  margin-top: .5rem;
  filter: brightness(1.1);
  animation: s00-up  .7s 1.1s ease both;
}

@keyframes s00-logo-in {
  from { opacity: 0; transform: scale(1.08); filter: drop-shadow(0 0 70px rgba(57,255,20,.85)); }
  to   { opacity: 1; transform: scale(1);    filter: drop-shadow(0 0 44px rgba(57,255,20,.5)); }
}
@keyframes s00-up {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: none; }
}
@keyframes s00-dim {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: .65; transform: none; }
}
@keyframes s00-pulse {
  0%,100% { filter: drop-shadow(0 0 44px rgba(57,255,20,.5)); }
  50%     { filter: drop-shadow(0 0 18px rgba(57,255,20,.2)); }
}

/* Custom controls — acima do bloqueador (z-index 6) */
.yt-custom-controls {
  position: absolute;
  bottom: clamp(1.5rem, 4vh, 3rem);
  left: 50%;
  transform: translateX(-50%);
  z-index: 20 !important;
  z-index: 10;
  display: flex;
  gap: .75rem;
  align-items: center;
}
.yt-btn {
  width: 46px; height: 46px;
  border-radius: 50%;
  border: 1px solid rgba(57,255,20,.35);
  background: rgba(3,4,8,.75);
  color: var(--text);
  font-size: 1rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: border-color .2s, box-shadow .2s;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.yt-btn:hover {
  border-color: var(--green);
  box-shadow: 0 0 16px rgba(57,255,20,.35);
}
.yt-btn svg { width: 18px; height: 18px; fill: currentColor; }

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:      #030408;
  --bg2:     #060b12;
  --panel:   rgba(6,10,18,.90);
  --text:    #f7fbff;
  --muted:   rgba(247,251,255,.58);
  --dim:     rgba(247,251,255,.26);
  --green:   #39ff14;
  --cyan:    #00f4ff;
  --mag:     #ff2abf;
  --yel:     #fff200;
  --border:  rgba(0,244,255,.15);
  --bgreen:  rgba(57,255,20,.22);
  --bmag:    rgba(255,42,191,.22);
  --glow-g:  0 0 14px rgba(57,255,20,.45),  0 0 30px rgba(57,255,20,.18);
  --glow-c:  0 0 14px rgba(0,244,255,.45),  0 0 30px rgba(0,244,255,.18);
  --glow-m:  0 0 14px rgba(255,42,191,.45), 0 0 30px rgba(255,42,191,.18);
  --serif:   Georgia, "Times New Roman", serif;
  --sans:    Inter, ui-sans-serif, system-ui, -apple-system, sans-serif;
  --mono:    "SF Mono", "Fira Code", ui-monospace, monospace;
  --bar:     52px;
}

html, body {
  height: 100%;
  overflow: hidden;
  background: var(--bg);
  color: var(--text);
  font-family: var(--sans);
  line-height: 1.55;
}

/* film grain */
body::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 999;
  pointer-events: none;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='.07'/%3E%3C/svg%3E");
  opacity: 1;
  mix-blend-mode: overlay;
}

/* ── TOPBAR ────────────────────────────────── */
.topbar {
  position: fixed;
  inset: 0 0 auto 0;
  height: var(--bar);
  z-index: 500;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 1.5rem;
  background: rgba(3,4,8,.96);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
  gap: 1rem;
}

.topbar-brand {
  display: flex;
  align-items: center;
  gap: .6rem;
  text-decoration: none;
  flex-shrink: 0;
}
.topbar-brand img { height: 26px; width: auto; filter: brightness(1.1); }
.topbar-brand span {
  font-size: .66rem;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
  white-space: nowrap;
}

.topbar-center {
  font-size: .62rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--dim);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: color .3s;
}
.topbar-center.flash { color: var(--cyan); }

.topbar-right { display: flex; align-items: center; gap: 1rem; flex-shrink: 0; }

/* Seletor de idioma */
.lang-switch {
  display: flex;
  align-items: center;
  gap: .3rem;
  font-family: var(--mono);
  font-size: .55rem;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.lang-switch a {
  color: var(--dim);
  text-decoration: none;
  padding: 2px 5px;
  border-radius: 2px;
  transition: color .2s, background .2s;
}
.lang-switch a:hover { color: var(--cyan); }
.lang-switch .lang-active {
  color: var(--green);
  font-weight: 700;
  pointer-events: none;
}
.lang-switch .lang-sep { color: rgba(255,255,255,.15); }

.topbar-counter {
  font-family: var(--mono);
  font-size: .68rem;
  letter-spacing: .06em;
  color: var(--cyan);
  opacity: .75;
}

.btn-pdf {
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--green);
  border: 1px solid rgba(57,255,20,.4);
  border-radius: 3px;
  padding: 4px 10px;
  background: transparent;
  cursor: pointer;
  transition: background .2s, color .2s, box-shadow .2s;
  white-space: nowrap;
}
.btn-pdf:hover { background: var(--green); color: var(--bg); box-shadow: var(--glow-g); }

/* ── DECK CONTAINER ────────────────────────── */
.deck {
  margin-top: var(--bar);
  height: calc(100vh - var(--bar));
  overflow-y: scroll;
  scroll-snap-type: y mandatory;
  scroll-behavior: smooth;
}
.deck::-webkit-scrollbar { display: none; }
.deck { scrollbar-width: none; }

/* ── SLIDE BASE ────────────────────────────── */
.slide {
  height: calc(100vh - var(--bar));
  min-height: 540px;
  scroll-snap-align: start;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  padding: 2.5rem clamp(1.5rem, 6vw, 5rem);
}

.slide-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  z-index: 0;
  transform: scale(1.04);
  transition: transform 8s ease-out;
}
.slide.is-active .slide-bg { transform: scale(1); }

.slide-scrim { position: absolute; inset: 0; z-index: 1; }

/* scan lines */
.slide::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  background: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 2px,
    rgba(0,0,0,.07) 2px,
    rgba(0,0,0,.07) 4px
  );
}

/* horizontal CRT sweep */
.slide::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  height: 80px;
  z-index: 4;
  pointer-events: none;
  background: linear-gradient(transparent, rgba(0,244,255,.025), transparent);
  top: -80px;
  animation: crt-sweep 7s linear infinite;
}
@keyframes crt-sweep {
  0%   { top: -80px; }
  100% { top: 100%; }
}

.slide-content {
  position: relative;
  z-index: 5;
  width: 100%;
  max-width: 1100px;
}

/* VHS corner decorations */
.slide-corner {
  position: absolute;
  z-index: 6;
  font-family: var(--mono);
  font-size: .56rem;
  letter-spacing: .14em;
  color: var(--dim);
  text-transform: uppercase;
  pointer-events: none;
}
.slide-corner--tl { top: 1rem; left: 1.5rem; }
.slide-corner--tr { top: 1rem; right: 1.5rem; text-align: right; }
.slide-corner--bl { bottom: 1rem; left: 1.5rem; }
.slide-corner--br { bottom: 1rem; right: 1.5rem; text-align: right; }

/* ── ENTRANCE ANIMATIONS ───────────────────── */
[data-anim] {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity .65s cubic-bezier(.22,.68,0,1.2),
              transform .65s cubic-bezier(.22,.68,0,1.2);
}
.slide.is-active [data-anim] { opacity: 1; transform: none; }

[data-anim="left"]  { transform: translateX(-22px); }
[data-anim="right"] { transform: translateX(22px); }
[data-anim="scale"] { transform: scale(.93); }
[data-anim="fade"]  { transform: none; }

.slide.is-active [data-anim="left"],
.slide.is-active [data-anim="right"],
.slide.is-active [data-anim="scale"],
.slide.is-active [data-anim="fade"] { transform: none; }

[data-d="1"]  { transition-delay: .10s; }
[data-d="2"]  { transition-delay: .20s; }
[data-d="3"]  { transition-delay: .30s; }
[data-d="4"]  { transition-delay: .40s; }
[data-d="5"]  { transition-delay: .50s; }
[data-d="6"]  { transition-delay: .62s; }
[data-d="7"]  { transition-delay: .74s; }
[data-d="8"]  { transition-delay: .86s; }

/* ── NAV DOTS ──────────────────────────────── */
.deck-nav {
  position: fixed;
  right: .9rem;
  top: calc(50% + var(--bar)/2);
  transform: translateY(-50%);
  z-index: 400;
  display: flex;
  flex-direction: column;
  gap: .4rem;
}

.deck-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  border: 1px solid rgba(0,244,255,.3);
  background: transparent;
  cursor: pointer;
  padding: 0;
  transition: all .25s;
  position: relative;
}
.deck-dot::after {
  content: attr(data-label);
  position: absolute;
  right: calc(100% + 9px);
  top: 50%;
  transform: translateY(-50%);
  white-space: nowrap;
  font-size: .56rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--cyan);
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s;
  font-family: var(--mono);
}
.deck-dot:hover::after { opacity: 1; }
.deck-dot.is-active::after { opacity: 1; color: var(--green); }
.deck-dot.is-active {
  background: var(--green);
  border-color: var(--green);
  box-shadow: var(--glow-g);
  animation: dot-pulse 2s infinite;
}
@keyframes dot-pulse {
  0%,100% { box-shadow: 0 0 6px rgba(57,255,20,.5); }
  50%      { box-shadow: 0 0 14px rgba(57,255,20,.8), 0 0 28px rgba(57,255,20,.3); }
}
.deck-dot:hover:not(.is-active) {
  border-color: var(--cyan);
  background: rgba(0,244,255,.2);
}

/* ── ARROWS ────────────────────────────────── */
.deck-arrows {
  position: fixed;
  bottom: 1.25rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 400;
  display: flex;
  gap: .6rem;
}
.deck-arrow {
  width: 33px;
  height: 33px;
  border: 1px solid var(--border);
  border-radius: 50%;
  background: rgba(3,4,8,.85);
  color: var(--cyan);
  font-size: .85rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .2s;
  line-height: 1;
}
.deck-arrow:hover { border-color: var(--cyan); box-shadow: var(--glow-c); }
.deck-arrow:disabled { opacity: .2; cursor: default; pointer-events: none; }

.back-link {
  position: fixed;
  bottom: 1.4rem;
  left: 1.5rem;
  z-index: 400;
  font-size: .58rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--dim);
  text-decoration: none;
  transition: color .2s;
  font-family: var(--mono);
}
.back-link:hover { color: var(--cyan); }

/* ── TYPOGRAPHY ────────────────────────────── */
.eyebrow {
  display: block;
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--cyan);
  margin-bottom: .65rem;
}
.eyebrow-g { color: var(--green); }
.eyebrow-m { color: var(--mag); }
.eyebrow-y { color: var(--yel); }

.slide-h1 {
  font-family: var(--serif);
  font-size: clamp(2.4rem, 5.5vw, 4.8rem);
  font-weight: 700;
  line-height: 1.0;
  letter-spacing: -.025em;
}

.slide-h2 {
  font-family: var(--serif);
  font-size: clamp(1.55rem, 3.2vw, 2.7rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -.02em;
  margin-bottom: .85rem;
}

.body {
  font-size: clamp(.84rem, 1.35vw, 1rem);
  color: var(--muted);
  line-height: 1.75;
}
.body + .body { margin-top: .7rem; }
.body strong { color: var(--text); font-weight: 600; }

.quote-block {
  font-family: var(--serif);
  font-size: clamp(1.05rem, 2.1vw, 1.5rem);
  font-style: italic;
  line-height: 1.45;
  color: var(--text);
  border-left: 3px solid var(--cyan);
  padding-left: 1.25rem;
  margin: 1.25rem 0;
  text-shadow: 0 0 40px rgba(0,244,255,.12);
}

.tags { display: flex; flex-wrap: wrap; gap: .35rem; margin-top: 1rem; }
.tag {
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 2px;
  border: 1px solid var(--border);
  color: var(--muted);
}
.tag-g { border-color: var(--bgreen); color: var(--green); background: rgba(57,255,20,.06); }
.tag-c { border-color: var(--border); color: var(--cyan);  background: rgba(0,244,255,.06); }
.tag-m { border-color: var(--bmag);   color: var(--mag);   background: rgba(255,42,191,.06); }

/* ── COVER ─────────────────────────────────── */
.slide-cover {
  align-items: center;
  justify-content: flex-start;
  padding-left: clamp(2rem, 9vw, 7rem);
}

.cover-logo {
  height: clamp(38px, 6vw, 64px);
  width: auto;
  margin-bottom: 1.25rem;
  display: block;
  filter: drop-shadow(0 0 18px rgba(57,255,20,.3));
}

.cover-rule {
  width: 60px;
  height: 2px;
  background: linear-gradient(90deg, var(--green), transparent);
  margin: 1rem 0;
  border: none;
}

.cover-tagline {
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(.95rem, 1.7vw, 1.3rem);
  color: rgba(247,251,255,.68);
  margin: .5rem 0 1rem;
}

.cover-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .35rem 1.2rem;
  font-size: .66rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: .5rem;
}
.cover-meta strong { color: var(--text); font-weight: 600; }

.cover-badges {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  margin-top: 1.5rem;
}
.cover-badge {
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 2px;
  background: rgba(57,255,20,.08);
  border: 1px solid rgba(57,255,20,.35);
  color: var(--green);
  transition: box-shadow .3s;
}
.cover-badge:hover { box-shadow: var(--glow-g); }

.cover-vert {
  position: absolute;
  right: clamp(1.5rem, 4vw, 4rem);
  top: 50%;
  transform: translateY(-50%);
  writing-mode: vertical-lr;
  font-family: var(--mono);
  font-size: .56rem;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: rgba(0,244,255,.28);
  z-index: 5;
}

/* ── GRIDS ─────────────────────────────────── */
.col2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 4vw, 4rem);
  align-items: start;
}
.col2-45 {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: clamp(2rem, 4vw, 4rem);
  align-items: center;
}
@media (max-width: 780px) {
  .col2, .col2-45 { grid-template-columns: 1fr; gap: 1.5rem; }
}

/* ── TRIPTYCH ───────────────────────────────── */
.triptych {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr;
  gap: .5rem;
  margin-top: 1.25rem;
}
.triptych img {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
  border-radius: 2px;
  border: 1px solid var(--border);
  display: block;
  transition: border-color .3s, box-shadow .3s;
}
.triptych img:first-child { aspect-ratio: 4/3; }
.triptych img:hover { border-color: var(--cyan); box-shadow: var(--glow-c); }

/* ── CHARACTERS ─────────────────────────────── */
.char-row {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: .7rem;
  margin-top: 1.1rem;
}
@media (max-width: 860px) { .char-row { grid-template-columns: repeat(3, 1fr); } }

.char-card { text-align: center; }
.char-card img {
  width: 100%;
  aspect-ratio: 9/13;
  object-fit: cover;
  border-radius: 3px;
  border: 1px solid var(--border);
  display: block;
  margin-bottom: .45rem;
  filter: grayscale(35%) contrast(1.1);
  transition: filter .35s, border-color .35s, box-shadow .35s;
}
.char-card:hover img {
  filter: none;
  border-color: var(--cyan);
  box-shadow: var(--glow-c);
}
.char-name {
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  display: block;
  color: var(--text);
}
.char-role {
  font-size: .56rem;
  color: var(--muted);
  display: block;
  margin-top: 2px;
}

/* ── BYTE SLIDE ─────────────────────────────── */
.byte-img-frame {
  position: relative;
  border: 2px solid var(--green);
  border-radius: 4px;
  overflow: hidden;
  animation: byte-border 4s linear infinite;
}
@keyframes byte-border {
  0%,100% { border-color: var(--green); box-shadow: var(--glow-g); }
  33%      { border-color: var(--cyan);  box-shadow: var(--glow-c); }
  66%      { border-color: var(--mag);   box-shadow: var(--glow-m); }
}
.byte-img-frame img { width: 100%; display: block; }

/* Radar */
.byte-radar {
  position: absolute;
  bottom: 12px;
  right: 12px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid rgba(0,244,255,.5);
  overflow: hidden;
}
.byte-radar::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: conic-gradient(
    rgba(0,244,255,.35) 0deg 60deg,
    transparent 60deg 360deg
  );
  animation: radar-spin 3s linear infinite;
}
.byte-radar::after {
  content: "";
  position: absolute;
  inset: 4px;
  border-radius: 50%;
  border: 1px solid rgba(0,244,255,.25);
}
@keyframes radar-spin { to { transform: rotate(360deg); } }

/* LED ticker */
.byte-led-strip {
  overflow: hidden;
  white-space: nowrap;
  font-family: var(--mono);
  font-size: .6rem;
  letter-spacing: .08em;
  color: var(--green);
  padding: 4px 0;
  margin-top: 1rem;
  border-top: 1px solid var(--bgreen);
  border-bottom: 1px solid var(--bgreen);
  background: rgba(57,255,20,.04);
}
.byte-led-strip span {
  display: inline-block;
  animation: led-scroll 16s linear infinite;
}
@keyframes led-scroll {
  0%   { transform: translateX(100%); }
  100% { transform: translateX(-100%); }
}

.byte-stat-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .6rem;
  margin-top: 1.1rem;
}
.byte-stat {
  padding: .75rem .9rem;
  border: 1px solid var(--bgreen);
  border-radius: 3px;
  background: rgba(57,255,20,.04);
  transition: box-shadow .3s;
}
.byte-stat:hover { box-shadow: var(--glow-g); }
.byte-stat span {
  font-size: .57rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--green);
  display: block;
  margin-bottom: 3px;
}
.byte-stat strong {
  font-size: .8rem;
  font-weight: 700;
  color: var(--text);
  display: block;
  line-height: 1.3;
}

.ip-mini-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .73rem;
  margin-top: 1.1rem;
}
.ip-mini-table th {
  font-size: .56rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--cyan);
  text-align: left;
  padding: 5px 8px;
  border-bottom: 1px solid var(--border);
}
.ip-mini-table td {
  padding: 6px 8px;
  border-bottom: 1px solid rgba(0,244,255,.06);
  color: var(--muted);
}
.ip-mini-table td:first-child { color: var(--text); }
.ip-mini-table tr.byte-row td { color: var(--green); font-weight: 600; }

/* ── TEAM CARDS ─────────────────────────────── */
.team-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-top: 1.1rem;
}
@media (max-width: 640px) { .team-cards { grid-template-columns: 1fr; } }

.team-card {
  padding: 1.25rem 1.4rem;
  border: 1px solid var(--border);
  border-radius: 3px;
  background: var(--panel);
  backdrop-filter: blur(12px);
  transition: border-color .3s, box-shadow .3s;
}
.team-card:hover { border-color: var(--cyan); box-shadow: var(--glow-c); }
.team-card-role {
  font-size: .57rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--cyan);
  display: block;
  margin-bottom: .35rem;
}
.team-card-name {
  font-family: var(--serif);
  font-size: 1.2rem;
  font-weight: 700;
  margin-bottom: .55rem;
}
.team-card-bio {
  font-size: .76rem;
  color: var(--muted);
  line-height: 1.6;
}
.team-card-bio strong { color: var(--text); font-weight: 600; }

.producers-strip { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 1.4rem; }
.prod-badge {
  font-size: .6rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 4px 10px;
  border: 1px solid var(--border);
  border-radius: 2px;
  color: var(--muted);
  transition: border-color .2s, color .2s;
}
.prod-badge:hover { border-color: var(--cyan); color: var(--cyan); }

/* info 3-col strip */
.info-strip {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .75rem;
  margin-top: 1.25rem;
}
.info-strip-item {
  padding: .9rem 1rem;
  border: 1px solid var(--border);
  border-radius: 3px;
  transition: border-color .3s, box-shadow .3s;
  background: rgba(255,255,255,.015);
}
.info-strip-item:hover { border-color: var(--green); box-shadow: var(--glow-g); }

/* ── SINOPSE COLUMN DIVIDER ────────────────── */
.sinopse-right {
  padding-left: clamp(1.5rem, 3vw, 2.5rem);
  border-left: 1px solid var(--border);
}

/* ── TEAM CARD VARIANTS ─────────────────────── */
.team-card-dir { border-left: 2px solid var(--cyan); }
.team-card-rot { border-left: 2px solid var(--mag); }

/* ── WIN-STEP PHASE COLORS ──────────────────── */
.win-step-fest  { border-color: rgba(255,242,0,.25);    background: rgba(255,242,0,.03); }
.win-step-cine  { border-color: rgba(57,255,20,.3);     background: rgba(57,255,20,.04); }
.win-step-strea { border-color: rgba(0,244,255,.3);     background: rgba(0,244,255,.04); }
.win-step-tv    { border-color: rgba(255,42,191,.25);   background: rgba(255,42,191,.03); }
.win-step-lic   { border-color: rgba(57,255,20,.2);     background: rgba(57,255,20,.025); }
.win-step-seq   { border-color: rgba(0,244,255,.2);     background: rgba(0,244,255,.025); }

/* All win-step right-border fix when colored */
.win-step-fest,.win-step-cine,.win-step-strea,
.win-step-tv,.win-step-lic,.win-step-seq { border-right: none; }
.win-step-seq { border-right: 1px solid rgba(0,244,255,.2); }

/* ── BUDGET ─────────────────────────────────── */
.budget-hero { display: flex; align-items: flex-end; gap: 1rem; margin-bottom: 1.4rem; }
.budget-total-num {
  font-family: var(--serif);
  font-size: clamp(2rem, 4.5vw, 3.4rem);
  font-weight: 700;
  color: var(--green);
  line-height: 1;
  text-shadow: var(--glow-g);
}
.budget-total-label {
  font-size: .62rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
  padding-bottom: .35rem;
}

/* funded bar */
.budget-bar-wrap {
  margin-bottom: 1.5rem;
}
.budget-bar-label {
  display: flex;
  justify-content: space-between;
  font-size: .6rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: .4rem;
}
.budget-bar-label span:last-child { color: var(--green); }
.budget-bar-track {
  height: 9px;
  background: rgba(255,255,255,.06);
  border-radius: 4px;
  overflow: hidden;
}
.budget-bar-fill {
  height: 100%;
  border-radius: 4px;
  background: linear-gradient(90deg, var(--green), var(--cyan));
  width: 0%;
  transition: width 1.4s cubic-bezier(.4,0,.2,1);
  box-shadow: 0 0 12px rgba(57,255,20,.7), 0 0 24px rgba(57,255,20,.25);
}

.budget-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .75rem;
}
@media (max-width: 720px) { .budget-grid { grid-template-columns: 1fr 1fr; } }

.budget-card {
  padding: 1rem 1.1rem;
  border-radius: 0 3px 3px 0;
  border-left: 2px solid;
  border-top: 1px solid;
  border-right: 1px solid;
  border-bottom: 1px solid;
  transition: box-shadow .3s;
}
.budget-card.funded {
  border-left-color: var(--green);
  border-top-color: rgba(57,255,20,.12);
  border-right-color: rgba(57,255,20,.12);
  border-bottom-color: rgba(57,255,20,.12);
  background: rgba(57,255,20,.04);
}
.budget-card.funded:hover { box-shadow: var(--glow-g); }
.budget-card.pending {
  border-left-color: var(--mag);
  border-top-color: rgba(255,42,191,.12);
  border-right-color: rgba(255,42,191,.12);
  border-bottom-color: rgba(255,42,191,.12);
  background: rgba(255,42,191,.04);
}
.budget-card.pending:hover { box-shadow: var(--glow-m); }
.budget-card.info {
  border-left-color: var(--cyan);
  border-top-color: rgba(0,244,255,.12);
  border-right-color: rgba(0,244,255,.12);
  border-bottom-color: rgba(0,244,255,.12);
  background: rgba(0,244,255,.04);
}
.budget-card.info:hover { box-shadow: var(--glow-c); }
.budget-card span {
  font-size: .57rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted);
  display: block;
  margin-bottom: 3px;
}
.budget-card strong {
  font-family: var(--serif);
  font-size: 1.25rem;
  font-weight: 700;
  display: block;
  margin-bottom: 3px;
}
.budget-card p { font-size: .67rem; color: var(--muted); line-height: 1.5; margin-top: .4rem; }

/* timeline */
.timeline { display: flex; flex-direction: column; gap: .55rem; margin-top: .6rem; }
.tl-row {
  padding: .72rem 1rem;
  border: 1px solid var(--border);
  border-radius: 3px;
  display: flex;
  gap: 1rem;
  align-items: center;
  background: rgba(255,255,255,.015);
  transition: border-color .25s;
}
.tl-row:hover { border-color: rgba(0,244,255,.35); }
.tl-row.highlight {
  border-color: rgba(57,255,20,.35);
  background: rgba(57,255,20,.04);
}
.tl-row span {
  font-size: .58rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted);
  min-width: 90px;
  flex-shrink: 0;
}
.tl-row.highlight span { color: var(--green); }
.tl-row strong { font-size: .8rem; color: var(--text); }
.tl-row.highlight strong { color: var(--green); }

/* ── MARKET ─────────────────────────────────── */
.market-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin-bottom: 1.4rem;
}
.mstat {
  text-align: center;
  padding: 1rem;
  border: 1px solid var(--border);
  border-radius: 3px;
  background: var(--panel);
  backdrop-filter: blur(8px);
  transition: border-color .3s, box-shadow .3s;
}
.mstat:hover { border-color: var(--cyan); box-shadow: var(--glow-c); }
.mstat .num {
  font-family: var(--serif);
  font-size: clamp(1.3rem, 2.5vw, 1.9rem);
  font-weight: 700;
  color: var(--cyan);
  display: block;
  line-height: 1;
  margin-bottom: .3rem;
}
.mstat .lbl {
  font-size: .58rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted);
  display: block;
}

/* reach bars */
.reach-row {
  display: grid;
  grid-template-columns: 90px 1fr 52px;
  align-items: center;
  gap: .6rem;
  margin: .4rem 0;
}
.reach-row-label { font-size: .68rem; color: var(--muted); }
.reach-bar-track { height: 4px; background: rgba(255,255,255,.08); border-radius: 2px; overflow: hidden; }
.reach-bar-fill {
  height: 100%;
  background: var(--cyan);
  border-radius: 2px;
  width: 0%;
  transition: width 1s ease-out;
  box-shadow: 0 0 6px rgba(0,244,255,.6);
}
.reach-row-val { font-size: .66rem; color: var(--cyan); text-align: right; font-family: var(--mono); }

.comp-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .73rem;
  margin-top: .75rem;
}
.comp-table th {
  font-size: .57rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--cyan);
  text-align: left;
  padding: 5px 8px;
  border-bottom: 1px solid var(--border);
}
.comp-table td {
  padding: 6px 8px;
  border-bottom: 1px solid rgba(0,244,255,.06);
  color: var(--muted);
}
.comp-table td:first-child { color: var(--text); }
.comp-table tr.highlight td { color: var(--green); font-weight: 600; }

/* ── WINDOWS ────────────────────────────────── */
.windows-flow {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  margin-top: 1.4rem;
}
@media (max-width: 860px) { .windows-flow { grid-template-columns: repeat(3, 1fr); } }

.win-step {
  padding: 1rem .9rem;
  border: 1px solid var(--border);
  border-right: none;
  position: relative;
  background: var(--panel);
  transition: border-color .25s, background .25s;
}
.win-step:hover { background: rgba(0,244,255,.04); border-color: rgba(0,244,255,.3); }
.win-step:last-child { border-right: 1px solid var(--border); }
.win-step::after {
  content: "›";
  position: absolute;
  right: -9px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1rem;
  color: var(--cyan);
  z-index: 2;
  background: var(--bg);
  line-height: 1;
  padding: 2px 1px;
}
.win-step:last-child::after { display: none; }
.win-step span {
  font-size: .55rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted);
  display: block;
  margin-bottom: 3px;
}
.win-step strong {
  font-size: .78rem;
  font-weight: 700;
  color: var(--text);
  display: block;
  margin-bottom: 2px;
  line-height: 1.3;
}
.win-step em {
  font-size: .6rem;
  font-style: normal;
  color: var(--dim);
  display: block;
}

.festivals-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .5rem;
  margin-top: 1.2rem;
}
.fest-item {
  padding: .6rem .75rem;
  border: 1px solid var(--border);
  border-radius: 2px;
  background: rgba(0,244,255,.03);
  transition: border-color .25s, box-shadow .25s;
}
.fest-item:hover { border-color: var(--cyan); box-shadow: var(--glow-c); }
.fest-item span { font-size: .55rem; letter-spacing: .1em; text-transform: uppercase; color: var(--cyan); display: block; }
.fest-item strong { font-size: .75rem; color: var(--text); font-weight: 600; }

/* ── CO-PROD ────────────────────────────────── */
.coprod-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  margin-top: 1.4rem;
}
@media (max-width: 640px) { .coprod-cols { grid-template-columns: 1fr; } }

.coprod-col-head {
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  padding-bottom: .6rem;
  border-bottom: 1px solid;
  margin-bottom: .9rem;
  display: flex;
  align-items: center;
  gap: .4rem;
}
.col-offer .coprod-col-head { color: var(--green); border-color: rgba(57,255,20,.4); }
.col-seek  .coprod-col-head { color: var(--mag);   border-color: rgba(255,42,191,.4); }

.coprod-list { list-style: none; display: flex; flex-direction: column; gap: .5rem; }
.coprod-list li {
  font-size: .8rem;
  color: var(--muted);
  padding-left: 1.1rem;
  position: relative;
  line-height: 1.5;
  transition: color .2s;
}
.coprod-list li:hover { color: var(--text); }
.coprod-list li::before { content: "›"; position: absolute; left: 0; }
.col-offer .coprod-list li::before { color: var(--green); }
.col-seek  .coprod-list li::before { color: var(--mag); }
.coprod-list li strong { color: var(--text); font-weight: 600; }

/* ── CONTACT ────────────────────────────────── */
.contact-center {
  max-width: 600px;
  margin: 0 auto;
  text-align: center;
}
.contact-info {
  display: flex;
  flex-direction: column;
  gap: .55rem;
  margin: 1.5rem auto;
  align-items: center;
}
.contact-row {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .84rem;
  color: var(--muted);
}
.contact-row strong { color: var(--text); }
.contact-row a { color: var(--cyan); text-decoration: none; transition: color .2s; }
.contact-row a:hover { color: var(--green); }

.btn-cta-main {
  display: inline-block;
  padding: .9rem 2.5rem;
  background: var(--green);
  color: var(--bg);
  font-weight: 700;
  font-size: .8rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: 3px;
  transition: opacity .2s, transform .2s, box-shadow .2s;
  margin-top: .5rem;
  animation: cta-pulse 2.5s infinite;
}
@keyframes cta-pulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(57,255,20,.0); }
  50%      { box-shadow: 0 0 0 8px rgba(57,255,20,.12), 0 0 20px rgba(57,255,20,.2); }
}
.btn-cta-main:hover { opacity: .88; transform: translateY(-2px); box-shadow: var(--glow-g); }

.btn-cta-sec {
  display: inline-block;
  padding: .75rem 1.5rem;
  border: 1px solid var(--border);
  color: var(--muted);
  font-size: .74rem;
  text-decoration: none;
  border-radius: 3px;
  margin-top: .5rem;
  margin-left: .75rem;
  transition: border-color .2s, color .2s;
}
.btn-cta-sec:hover { border-color: var(--cyan); color: var(--cyan); }

/* ── NEON HR ────────────────────────────────── */
.neon-rule {
  border: none;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--cyan), transparent);
  margin: 1.25rem 0;
  opacity: .4;
}

/* ── WORLD MOSAIC (slide Universo) ─────────────── */
.world-layout {
  display: grid;
  grid-template-columns: 1fr 1.45fr;
  gap: clamp(1.5rem,3vw,3rem);
  align-items: start;
  margin-top: .4rem;
}
@media (max-width: 820px) { .world-layout { grid-template-columns: 1fr; } }

.world-mosaic {
  display: grid;
  grid-template-columns: 1.7fr 1fr;
  grid-template-rows: repeat(3, 1fr);
  gap: .42rem;
  height: clamp(230px, 52vh, 430px);
}
.world-mosaic img {
  width: 100%; height: 100%;
  object-fit: cover;
  border-radius: 2px;
  border: 1px solid var(--border);
  display: block;
  transition: border-color .3s, box-shadow .3s;
}
.world-mosaic img:hover { border-color: var(--cyan); box-shadow: var(--glow-c); }
.wm-hero { grid-row: 1 / 4; }

/* ══════════════════════════════════════════
   BYTE SLIDE — Reconstrução total
══════════════════════════════════════════ */

/* filmstrip reserva 96px na base */
.slide-byte {
  padding-bottom: 96px;
}

/* col2 padrão dentro do slide */
.byte-slide-flex {
  width: 100%;
}

.byte-copy-panel {
  max-width: 540px;
  width: 100%;
}

/* Watermark gigante */
.byte-watermark {
  position: absolute;
  right: -1vw;
  top: 50%;
  transform: translateY(-50%);
  font-family: var(--serif);
  font-size: clamp(7rem, 18vw, 15rem);
  font-weight: 700;
  color: rgba(57,255,20,.05);
  letter-spacing: -.05em;
  pointer-events: none;
  z-index: 3;
  line-height: 1;
  user-select: none;
}

/* Headline específica do Byte */
.byte-headline {
  font-size: clamp(1.75rem, 3.4vw, 2.85rem);
  line-height: 1.08;
  margin-bottom: .75rem;
}

/* Separador luminoso */
.byte-hr {
  width: 56px;
  height: 2px;
  background: linear-gradient(90deg, var(--green), transparent);
  border: none;
  margin: .9rem 0;
}

/* KPI row: 2x2 grid */
.byte-kpi-row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: .55rem;
  margin: 1.1rem 0;
}

.byte-kpi {
  padding: .85rem .7rem;
  border: 1px solid rgba(57,255,20,.28);
  border-radius: 3px;
  background: rgba(57,255,20,.05);
  text-align: center;
  transition: box-shadow .3s, border-color .3s;
}
.byte-kpi:hover {
  border-color: var(--green);
  box-shadow: var(--glow-g);
}
.byte-kpi-num {
  display: block;
  font-family: var(--serif);
  font-size: clamp(1.1rem, 2.2vw, 1.6rem);
  font-weight: 700;
  color: var(--green);
  line-height: 1;
  margin-bottom: .3rem;
  text-shadow: 0 0 20px rgba(57,255,20,.4);
}
.byte-kpi-lbl {
  display: block;
  font-size: .56rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--muted);
  line-height: 1.35;
}

/* Filmstrip: filho direto do <section>, fora do slide-content */
.byte-strip {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 7;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
}
.byte-strip img {
  width: 100%;
  height: 134px;
  object-fit: contain;
  object-position: center bottom;
  display: block;
  background: rgba(3,4,8,.88);
  filter: grayscale(35%) brightness(.85);
  border-top: 1px solid rgba(57,255,20,.3);
  border-right: 1px solid rgba(57,255,20,.08);
  transition: filter .35s, border-color .35s, transform .35s;
  cursor: pointer;
}
.byte-strip img:hover {
  filter: grayscale(0%) brightness(1.1);
  border-color: rgba(57,255,20,.8);
  transform: scaleY(1.04);
  transform-origin: bottom;
}
.byte-strip img:last-child { border-right: none; }

/* LED strip: oculto no pitch deck de investidor */
.byte-led-strip { display: none; }

/* Licensing thumbnails row (Slide 07) */
.byte-licensing-row {
  display: flex;
  gap: .75rem;
  align-items: center;
  margin-top: .85rem;
  padding-top: .75rem;
  border-top: 1px solid rgba(57,255,20,.15);
}
.byte-licensing-row img {
  height: 56px;
  width: auto;
  object-fit: contain;
  border-radius: 3px;
  opacity: .82;
  filter: brightness(.9);
  transition: opacity .3s;
}
.byte-licensing-row img:hover { opacity: 1; filter: brightness(1.05); }

/* Char arc: subtexto emocional abaixo do role em char-card */
.char-arc {
  display: block;
  font-size: .5rem;
  font-style: italic;
  color: var(--dim);
  margin-top: .18rem;
  line-height: 1.3;
}

/* Avatar strip (Slide 05 interlude) */
.avatar-strip {
  display: flex;
  gap: .45rem;
  justify-content: flex-start;
  align-items: center;
  margin-top: .85rem;
}
.avatar-strip img {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  object-fit: cover;
  border: 1px solid rgba(57,255,20,.3);
  filter: grayscale(30%);
  transition: filter .3s;
}
.avatar-strip img:hover { filter: grayscale(0%); }

/* ── INTERLUDE SLIDES ──────────────────────────── */
.slide-interlude {
  align-items: flex-end;
  justify-content: flex-start;
  padding: 2.5rem clamp(2rem, 6vw, 6rem) clamp(3rem, 7vh, 5.5rem);
}

.interlude-inner {
  position: relative;
  z-index: 5;
  text-align: left;
  max-width: 460px;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
  background: rgba(3,4,8,.42);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border: none;
  border-left: 2px solid var(--cyan);
  border-radius: 0 2px 2px 0;
  padding: 1rem 1.4rem 1.1rem 1.25rem;
}

/* Eyebrow: monospace pequeno, bem espaçado */
.interlude-eyebrow {
  display: block;
  font-family: var(--mono);
  font-size: .56rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--cyan);
  opacity: 1;
  margin: 0;
  line-height: 1;
}

/* Regra decorativa entre eyebrow e quote */
.interlude-rule {
  display: block;
  width: 28px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--cyan), transparent);
  border: none;
  margin: 1.1rem auto 1.3rem;
  opacity: .70;
  flex-shrink: 0;
}

/* Quote: impactante mas compacta */
.interlude-quote {
  font-family: var(--serif);
  font-size: clamp(1.05rem, 2vw, 1.65rem);
  font-style: italic;
  line-height: 1.52;
  color: #fff;
  text-align: center;
  margin: 0;
  text-shadow: 0 1px 12px rgba(0,0,0,.45);
}

.interlude-quote strong {
  font-style: normal;
  color: var(--cyan);
  font-weight: 400;
}

/* Variante: destaque verde para interlúdio 2 */
.interlude-accent-g .interlude-inner  { border-left-color: var(--green); }
.interlude-accent-g .interlude-eyebrow { color: var(--green); }
.interlude-accent-g .interlude-rule   { background: linear-gradient(90deg, var(--green), transparent); }
.interlude-accent-g .interlude-quote strong { color: var(--green); }

/* Variante: magenta para interlúdio climático */
.interlude-accent-m .interlude-inner  { border-left-color: var(--mag); }
.interlude-accent-m .interlude-eyebrow { color: var(--mag); opacity: .9; }
.interlude-accent-m .interlude-rule   { background: linear-gradient(90deg, var(--mag), transparent); opacity: .6; }
.interlude-accent-m .interlude-quote strong { color: var(--mag); }

/* compact char cards for Personagens */
.char-card img { aspect-ratio: 3/4; }

/* ── PRINT ──────────────────────────────────── */
@media print {
  .topbar, .deck-nav, .deck-arrows, .back-link { display: none !important; }
  html, body { overflow: visible; height: auto; }
  .deck { height: auto; overflow: visible; scroll-snap-type: none; margin-top: 0; }
  .slide { height: auto; min-height: 100vh; page-break-after: always; scroll-snap-type: none; scroll-snap-align: none; }
  [data-anim] { opacity: 1 !important; transform: none !important; }
  * { print-color-adjust: exact; -webkit-print-color-adjust: exact; }
}
