/* =====================================================================
   NOSSA HISTÓRIA DE AMOR - folha de estilos
   (v3: ritmo sanduíche - vertical ↓ · horizontal → · clímax ↓ · horizontal →)
   Paleta: creme #FAF3E9 · vinho #7D3C4A · acentos pastéis por momento
   Tipografia: Fraunces (títulos) + Manrope (datas/UI)
   ===================================================================== */

/* ------------------------------ Tokens ------------------------------ */
:root {
  --creme: #FAF3E9;
  --vinho: #7D3C4A;
  --tinta: #6B5A55;            /* texto corrido */
  --papel: #FFFDF8;            /* moldura polaroid */

  --rose: #E8B4B8;
  --terracota: #D98E73;
  --salvia: #A8BCA1;
  --ceu: #A9C5D8;
  --lilas: #C9B6D9;
  --dourado: #D9B36C;

  --fonte-titulo: "Fraunces", Georgia, "Times New Roman", serif;
  --fonte-corpo: "Manrope", -apple-system, "Segoe UI", sans-serif;

  --divisoria-h: 96px;
}

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

html { scroll-behavior: auto; }
html, body { overflow-x: clip; }

body {
  background: var(--creme);
  color: var(--tinta);
  font-family: var(--fonte-corpo);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -webkit-tap-highlight-color: transparent;
}

img, video, svg { display: block; max-width: 100%; }

button {
  font: inherit;
  color: inherit;
  background: none;
  border: none;
  cursor: pointer;
}

::selection { background: var(--rose); color: var(--vinho); }

:focus-visible { outline: 2px solid var(--vinho); outline-offset: 3px; border-radius: 4px; }

.visually-hidden {
  position: absolute;
  width: 1px; height: 1px;
  margin: -1px; padding: 0;
  overflow: hidden;
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
}

.aviso-noscript {
  padding: 32px 24px;
  text-align: center;
  font-family: var(--fonte-titulo);
  color: var(--vinho);
}

/* grão de filme - estático, sobre tudo menos o botão de áudio */
.grao {
  position: fixed;
  inset: 0;
  z-index: 40;
  pointer-events: none;
  opacity: 0.05;
}

/* Decoração ambiente (sparkles ✦ e corações de linha) */
.sparkle, .deco-coracao {
  position: absolute;
  pointer-events: none;
  z-index: 1;
}
.sparkle svg path { fill: currentColor; }
.deco-coracao svg path { stroke: currentColor; fill: none; }

/* divisória curva ("sorriso") - topo de cada seção, na cor da própria seção */
.divisoria {
  position: absolute;
  left: 0;
  top: calc(-1 * var(--divisoria-h) + 1px);
  width: 100%;
  height: var(--divisoria-h);
  pointer-events: none;
  z-index: 1;
  color: var(--bg);
}
.divisoria svg { width: 100%; height: 100%; }

/* a divisória que mora no rodapé do hero */
.divisoria--hero { top: auto; bottom: -1px; z-index: 3; }

/* numeral fantasma atrás de cada momento */
.numeral {
  position: absolute;
  top: 50%;
  translate: 0 -54%;
  z-index: 0;
  font-family: var(--fonte-titulo);
  font-weight: 600;
  font-style: italic;
  font-size: clamp(11rem, 24vw, 22rem);
  line-height: 1;
  color: color-mix(in srgb, var(--vinho) 6%, transparent);
  pointer-events: none;
  user-select: none;
}

/* wash radial de cor por momento */
.painel__wash {
  position: absolute;
  inset: -10% -10% 0 -10%;
  z-index: 0;
  pointer-events: none;
  background: radial-gradient(ellipse 60% 55% at var(--wx, 70%) var(--wy, 30%),
    color-mix(in srgb, var(--accent) 18%, transparent) 0%, transparent 62%);
}

/* ------------------------------- Hero ------------------------------- */
.hero {
  position: relative;
  min-height: 100vh;
  min-height: 100svh;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 32px 24px calc(var(--divisoria-h) + 24px);
  background: var(--creme);
}

.hero__inner { position: relative; z-index: 2; max-width: 980px; }

.hero__sparkles { position: absolute; inset: 0; pointer-events: none; z-index: 1; }

.hero__saudacao {
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.38em;
  text-indent: 0.38em;
  font-size: clamp(0.78rem, 1.6vw, 0.95rem);
  color: var(--vinho);
}

.hero__titulo {
  font-family: var(--fonte-titulo);
  font-weight: 600;
  font-size: clamp(2.8rem, 9.5vw, 7rem);
  line-height: 1.03;
  color: var(--vinho);
  margin: 0.38em 0 0.4em;
}

.hero__titulo .letra-acento { color: var(--terracota); }

.hero__subtitulo {
  font-family: var(--fonte-titulo);
  font-style: italic;
  font-size: clamp(1.05rem, 2.4vw, 1.5rem);
  color: var(--tinta);
}

.hero__stat {
  margin-top: 1.1rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  text-indent: 0.3em;
  font-size: 0.72rem;
  color: color-mix(in srgb, var(--vinho) 60%, transparent);
}

.hero__botao {
  display: inline-grid;
  justify-items: center;
  gap: 14px;
  margin-top: clamp(2rem, 4.6vh, 3.2rem);
  color: var(--vinho);
}

.hero__botao > span {
  position: relative;
  display: inline-block;
  padding: 14px 38px;
  border: 1.5px solid var(--vinho);
  border-radius: 999px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-size: 0.88rem;
  background: rgba(255, 253, 248, 0.5);
}

/* brilho do pulso: pseudo-elemento pré-cozido, só a opacidade (via --glow) anima */
.hero__botao > span::after {
  content: "";
  position: absolute;
  inset: -4px;
  border-radius: inherit;
  box-shadow: 0 0 36px 10px rgba(232, 180, 184, 0.65);
  opacity: var(--glow, 0);
  z-index: -1;
}

.hero__seta-baixo { width: 18px; height: 18px; opacity: 0.7; }

/* mini-polaroids flutuantes do hero (aparecem quando as fotos existem) */
.hero__mini {
  position: absolute;
  z-index: 1;
  background: var(--papel);
  padding: 6px 6px 22px;
  border-radius: 4px;
  rotate: var(--mr, -6deg);
  box-shadow: 0 14px 30px -14px rgba(125, 60, 74, 0.4);
  opacity: 0;
  pointer-events: none;
}
.hero__mini img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  border-radius: 2px;
}
@media (max-width: 767px) { .hero__mini { display: none; } }

/* estados iniciais (apenas com JS ligado; a timeline do hero revela) */
.js .hero__saudacao,
.js .hero__subtitulo,
.js .hero__stat,
.js .hero__botao { opacity: 0; }
.js .hero__titulo { visibility: hidden; }

/* -------------------- Seções verticais de momento ------------------- */
.momento--vertical {
  position: relative;
  --bg: color-mix(in srgb, var(--accent) 12%, var(--creme));
  background: var(--bg);
  min-height: 90svh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: calc(var(--divisoria-h) + 32px) 24px 130px;
  overflow: clip;
}

/* numeral na borda do lado da mídia */
.momento--vertical .numeral { right: clamp(8px, 3vw, 48px); }
.momento--vertical.momento--invertido .numeral { left: clamp(8px, 3vw, 48px); right: auto; }

.momento__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1240px;
  display: grid;
  grid-template-columns: 0.8fr 1.2fr;
  gap: clamp(32px, 4vw, 80px);
  align-items: center;
}

.momento--invertido .momento__texto { order: 2; }
.momento--invertido .momento__galeria { order: 1; }

/* Galeria sempre na coluna larga (1.2fr), mesmo nos momentos invertidos -
   o `order` acima joga a galeria pra 1ª célula, então invertemos a proporção. */
@media (min-width: 768px) {
  .momento--invertido .momento__inner { grid-template-columns: 1.2fr 0.8fr; }
}

.momento__data {
  display: inline-block;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.24em;
  font-size: 0.72rem;
  color: var(--vinho);
  background: color-mix(in srgb, var(--accent) 42%, white);
  padding: 9px 16px;
  border-radius: 999px;
  rotate: -2deg;
}

.momento__titulo {
  font-family: var(--fonte-titulo);
  font-weight: 600;
  font-size: clamp(2.1rem, 4.8vw, 4.1rem);
  line-height: 1.06;
  color: var(--vinho);
  margin: 0.55em 0 0.45em;
}

.momento__frase {
  font-family: var(--fonte-titulo);
  font-style: italic;
  font-size: clamp(1.05rem, 2vw, 1.32rem);
  line-height: 1.55;
  max-width: 44ch;
}

/* --------------------- Palco horizontal (capítulos) ------------------ */
.palco {
  position: relative;
  height: 100svh;
  overflow: clip;
  background: var(--creme);
}

/* o "sorriso" do próprio palco fica fora da área clipada */
.palco > .divisoria { z-index: 4; }

/* cobre a faixa abaixo do palco pinado quando a barra do iOS recolhe */
.palco::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  height: 140px;
  background: inherit;
}

.palco__trilho {
  display: flex;
  height: 100%;
  will-change: transform;
}

.painel {
  position: relative;
  flex: 0 0 100vw;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px clamp(20px, 5vw, 84px) calc(58px + env(safe-area-inset-bottom));
  overflow: clip;
}

.painel:nth-child(odd) .numeral { left: clamp(8px, 3vw, 48px); }
.painel:nth-child(even) .numeral { right: clamp(8px, 3vw, 48px); }

/* ----------------- Colagem de polaroids (todas visíveis) ------------- */
/* Regra do projeto: TODA mídia de um momento fica exposta de uma vez -
   nada escondido atrás de setas/carrossel. */
.colagem {
  position: relative;
  width: min(800px, 100%);
}
.colagem--1 { width: min(540px, 96%); aspect-ratio: 4 / 5.4; }
.colagem--2 { aspect-ratio: 1 / 0.82; }   /* par lado a lado: baixo e largo */
.colagem--3 { aspect-ratio: 1 / 1.1; }
.colagem--4 { aspect-ratio: 1 / 1.12; }
.colagem--5 { width: min(820px, 100%); aspect-ratio: 1 / 1.0; }
.colagem--6 { width: min(900px, 100%); aspect-ratio: 1 / 1.76; } /* 2 col x 3 linhas, fotos grandes (formatura vertical) */

/* Nos palcos (pinados a 100svh) o tamanho é limitado pela ALTURA da tela, para
   a colagem nunca estourar o painel - cada svh é calibrado pelo aspecto da colagem. */
.painel .colagem--1 { width: min(540px, 100%, 62svh); }
.painel .colagem--3 { width: min(820px, 100%, 76svh); }
.painel .colagem--4 { width: min(820px, 100%, 75svh); }
.painel .colagem--5 { width: min(820px, 100%, 84svh); }
.painel .colagem--6 { width: min(880px, 100%, 86svh); }

.polaroid {
  position: absolute;
  translate: -50% -50%;
  rotate: var(--r, -2deg);
  background: var(--papel);
  padding: 3.4% 3.4% 0;
  border-radius: 6px;
  box-shadow:
    0 18px 40px -18px rgba(125, 60, 74, 0.38),
    0 4px 12px rgba(125, 60, 74, 0.10);
  transition: scale 0.35s ease, rotate 0.35s ease;
}

/* sombra de hover pré-cozida (crossfade por opacidade) */
.polaroid::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  box-shadow: 0 30px 56px -20px rgba(125, 60, 74, 0.5);
  opacity: 0;
  transition: opacity 0.35s ease;
  pointer-events: none;
  z-index: -1;
}

@media (hover: hover) and (pointer: fine) {
  .polaroid:hover {
    scale: 1.05;
    rotate: calc(var(--r, -2deg) * 0.35);
    z-index: 30 !important;
  }
  .polaroid:hover::after { opacity: 1; }
}

/* "fita adesiva" na primeira polaroid */
.polaroid__fita {
  position: absolute;
  top: -11px;
  left: 50%;
  translate: -50% 0;
  rotate: -4deg;
  width: 64px;
  height: 22px;
  background: color-mix(in srgb, var(--accent) 50%, white);
  opacity: 0.85;
  border-radius: 2px;
  box-shadow: 0 2px 6px rgba(125, 60, 74, 0.15);
  z-index: 4;
}

.polaroid__midia {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  border-radius: 2px;
  background: color-mix(in srgb, var(--accent) 14%, var(--creme));
  user-select: none;
  -webkit-user-drag: none;
}

.polaroid--placeholder .polaroid__midia { object-fit: contain; }

.polaroid__legenda {
  min-height: clamp(18px, 9%, 30px);
  padding: 4px 2px 7px;
  display: grid;
  place-items: center;
  font-family: var(--fonte-titulo);
  font-style: italic;
  font-size: clamp(0.7rem, 1.4vw, 0.92rem);
  color: #8A7368;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

/* ----------------- Momento 9 - clímax vertical 💍 ------------------- */
.secao-climax {
  position: relative;
  --bg: var(--vinho);
  background: var(--vinho);
  color: var(--creme);
  overflow: clip;
}

.secao-climax .numeral {
  color: color-mix(in srgb, var(--creme) 7%, transparent);
  left: clamp(8px, 3vw, 48px);
}

.secao-climax .momento__conteudo {
  position: relative;
  z-index: 2;
  min-height: 100vh;
  min-height: 100svh;
  text-align: center;
}

/* duas "cenas" empilhadas: o título sai, a polaroid entra */
.climax__camada {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.secao-climax .momento__data {
  background: rgba(217, 179, 108, 0.22);
  color: #F0DDB4;
}

.secao-climax .momento__titulo {
  color: var(--creme);
  max-width: 16ch;
  margin: 0.7em auto 0.55em;
  font-size: clamp(2.1rem, 5.2vw, 4rem);
}

.secao-climax .momento__frase {
  color: rgba(250, 243, 233, 0.88);
  max-width: 52ch;
  margin: 1.4rem auto 0;
  font-size: clamp(1rem, 1.8vw, 1.2rem);
}

.secao-climax .colagem--1 { width: min(400px, 74vw, 46svh); aspect-ratio: 4 / 5.2; }
.secao-climax .polaroid__midia { background: rgba(250, 243, 233, 0.12); }

.climax__final {
  position: relative;
  margin-top: 1.6rem;
  display: grid;
  justify-items: center;
  gap: 8px;
}

.climax__coracao { width: 44px; height: 39px; color: #E9C98F; }
.climax__coracao path { fill: none; stroke: currentColor; stroke-width: 2.4; stroke-linecap: round; }

.climax__anel-wrap { position: relative; display: grid; place-items: center; }
.climax__anel { width: 62px; height: 74px; color: var(--dourado); }
.climax__anel path, .climax__anel circle { fill: none; stroke: currentColor; stroke-width: 2.6; stroke-linecap: round; }
.climax__anel .anel-brilho { fill: currentColor; stroke: none; }

.climax__glow {
  position: absolute;
  inset: -80px;
  background: radial-gradient(circle, rgba(217, 179, 108, 0.45) 0%, rgba(217, 179, 108, 0) 65%);
  opacity: 0;
  pointer-events: none;
}

/* ----------------------------- HUD do palco -------------------------- */
.palco__hud {
  position: absolute;
  inset: 0;
  z-index: 10;
  pointer-events: none;
}
.palco__hud button { pointer-events: auto; }

.palco__contador {
  position: absolute;
  left: 28px;
  bottom: 22px;
  font-family: var(--fonte-titulo);
  font-style: italic;
  font-variant-numeric: tabular-nums;
  font-size: 1.05rem;
  color: var(--vinho);
}

.palco__seta {
  position: absolute;
  top: 50%;
  translate: 0 -50%;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1.5px solid var(--vinho);
  background: rgba(255, 253, 248, 0.75);
  color: var(--vinho);
  display: grid;
  place-items: center;
  transition: background-color 0.35s ease, border-color 0.35s ease, color 0.35s ease, opacity 0.35s ease;
}
.palco__seta svg { width: 17px; height: 17px; }
.palco__seta--ant { left: 18px; }
.palco__seta--prox { right: 18px; }
.palco__seta[disabled] { opacity: 0.3; pointer-events: none; }

@media (hover: hover) and (pointer: fine) {
  .palco__seta--ant:hover { translate: -3px -50%; background: var(--creme); }
  .palco__seta--prox:hover { translate: 3px -50%; background: var(--creme); }
}

.palco__fio {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 2px;
  background: color-mix(in srgb, var(--vinho) 15%, transparent);
}

.palco__fio-fill {
  position: absolute;
  inset: 0;
  background: color-mix(in srgb, var(--vinho) 55%, transparent);
  transform-origin: left center;
  transform: scaleX(0);
}

.palco__no {
  position: absolute;
  bottom: -3.5px;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--cor-no, var(--rose));
  border: 1.5px solid var(--vinho);
  translate: -50% 0;
  pointer-events: none;
}
@media (pointer: fine) {
  .palco__no { pointer-events: auto; cursor: pointer; }
}

.palco__marcador {
  position: absolute;
  bottom: -7px;
  left: 0;
  width: 16px;
  height: 15px;
  color: var(--vinho);
  translate: -50% 0;
}
.palco__marcador svg path { fill: var(--creme); stroke: currentColor; stroke-width: 2; }

/* ------------------------------ Finale ------------------------------ */
.finale {
  position: relative;
  --bg: color-mix(in srgb, var(--rose) 22%, var(--creme));
  background: var(--bg);
  min-height: 100svh;
  display: grid;
  place-items: center;
  text-align: center;
  padding: calc(var(--divisoria-h) + 40px) 24px 110px;
}

.finale__inner { position: relative; z-index: 2; max-width: 920px; }

.finale__fio {
  display: grid;
  justify-items: center;
  margin-bottom: 14px;
  color: var(--vinho);
}
.finale__fio-svg { width: 40px; height: 96px; }

.finale__titulo {
  font-family: var(--fonte-titulo);
  font-style: italic;
  font-weight: 600;
  font-size: clamp(2.6rem, 7.5vw, 5.2rem);
  line-height: 1.08;
  color: var(--vinho);
  rotate: -2deg;
}

.finale__mensagem {
  font-family: var(--fonte-titulo);
  font-style: italic;
  font-size: clamp(1.1rem, 2.2vw, 1.45rem);
  line-height: 1.6;
  max-width: 56ch;
  margin: 1.6em auto 2em;
}

.finale__assinatura {
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  text-indent: 0.3em;
  font-size: 0.85rem;
  color: var(--vinho);
}

.finale__dica {
  margin-top: 3.2rem;
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  opacity: 0.55;
}

.finale__coracoes {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 3;
}
.finale__coracoes svg {
  position: absolute;
  width: 26px;
  height: 24px;
  opacity: 0;
}
.finale__coracoes svg path {
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
}

/* -------------------------- Botão de áudio -------------------------- */
.botao-audio[hidden] { display: none; }

.botao-audio {
  position: fixed;
  right: calc(16px + env(safe-area-inset-right));
  bottom: calc(16px + env(safe-area-inset-bottom));
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: rgba(255, 253, 248, 0.9);
  border: 1.5px solid var(--vinho);
  box-shadow: 0 4px 14px rgba(125, 60, 74, 0.18);
  display: grid;
  place-items: center;
  z-index: 50;
}

.botao-audio__barras {
  display: flex;
  gap: 3px;
  align-items: flex-end;
  height: 16px;
}
.botao-audio__barras i {
  width: 3px;
  height: 100%;
  border-radius: 2px;
  background: var(--vinho);
  transform: scaleY(0.3);
  transform-origin: bottom;
}

.botao-audio.tocando .botao-audio__barras i {
  animation: equalizer 0.9s ease-in-out infinite alternate;
}
.botao-audio.tocando .botao-audio__barras i:nth-child(2) { animation-delay: 0.15s; }
.botao-audio.tocando .botao-audio__barras i:nth-child(3) { animation-delay: 0.3s; }

@keyframes equalizer {
  from { transform: scaleY(0.25); }
  to   { transform: scaleY(1); }
}

.botao-audio__risco {
  position: absolute;
  width: 26px;
  height: 1.5px;
  background: var(--vinho);
  rotate: -45deg;
  opacity: 0;
  transition: opacity 0.2s ease;
}
.botao-audio:not(.tocando) .botao-audio__risco { opacity: 1; }

/* -------------------------- Capa · portão de entrada (só o Play) -------------------------- */
.capa { display: none; }

.js .capa {
  display: grid;
  place-items: center;
  position: fixed;
  inset: 0;
  z-index: 2000;
  padding: 24px;
  text-align: center;
  background: radial-gradient(120% 90% at 50% 20%, #FFFDF8 0%, var(--creme) 55%, #F3E7D6 100%);
  animation: capa-entra 0.7s ease both;
  touch-action: none;
  overscroll-behavior: none;
}

/* trava o scroll do fundo enquanto a capa está aberta */
html.capa-aberta, html.capa-aberta body { overflow: hidden; }

/* saída da capa: revela o hero por baixo */
.capa--saiu {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.6s ease, visibility 0s linear 0.6s;
}

.capa__inner {
  display: grid;
  justify-items: center;
  gap: clamp(18px, 3.5vh, 28px);
  max-width: 30rem;
}

.capa__play {
  position: relative;
  width: clamp(104px, 26vw, 132px);
  height: clamp(104px, 26vw, 132px);
  border-radius: 50%;
  display: grid;
  place-items: center;
  color: var(--creme);
  background: var(--vinho);
  border: none;
  box-shadow: 0 18px 42px -12px rgba(125, 60, 74, 0.55);
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.capa__play:hover { transform: scale(1.04); box-shadow: 0 22px 48px -12px rgba(125, 60, 74, 0.6); }
.capa__play:active { transform: scale(0.97); }

.capa__play-icone {
  width: 42%;
  height: 42%;
  margin-left: 7%;   /* compensa o peso visual do triângulo */
}

/* anel que pulsa convidando o toque */
.capa__play-anel {
  position: absolute;
  inset: -9px;
  border-radius: 50%;
  border: 2px solid var(--rose);
  opacity: 0;
  animation: capa-pulso 2.4s ease-out infinite;
}

.capa__cta {
  font-family: var(--fonte-titulo);
  font-weight: 600;
  font-size: clamp(1.5rem, 5.6vw, 2rem);
  color: var(--vinho);
  line-height: 1.15;
}
.capa__dica {
  font-family: var(--fonte-corpo);
  font-size: 0.95rem;
  color: var(--tinta);
  opacity: 0.82;
}

@keyframes capa-entra { from { opacity: 0; } to { opacity: 1; } }
@keyframes capa-pulso {
  0%   { opacity: 0.5; transform: scale(1); }
  70%  { opacity: 0;   transform: scale(1.32); }
  100% { opacity: 0;   transform: scale(1.32); }
}

/* rede de segurança: se o GSAP não carregar, o Play ainda revela o hero */
html.comecou .hero__saudacao,
html.comecou .hero__subtitulo,
html.comecou .hero__stat,
html.comecou .hero__botao { opacity: 1; }
html.comecou .hero__titulo { visibility: visible; }

@media (prefers-reduced-motion: reduce) {
  .js .capa { animation: none; }
  .capa__play-anel { animation: none; }
}

/* ---------------------- Ajustes por momento ------------------------ */
/* Nossas ligações (M13): Gabi aparece no alto do quadro → enquadra o topo */
#momento-13 .polaroid__midia { object-position: top; }

/* Formatura M7: agora é SEÇÃO VERTICAL (rola pra baixo), em coluna única com a
   galeria em largura cheia - as 6 fotos ficam grandes, sem o limite de altura
   do palco. */
@media (min-width: 768px) {
  #momento-07 .momento__inner { grid-template-columns: 1fr; justify-items: center; text-align: center; }
}

/* ------------------------------ Mobile ------------------------------ */
@media (max-width: 767px) {
  :root { --divisoria-h: 48px; }

  .momento--vertical {
    min-height: 0;
    padding: calc(var(--divisoria-h) + 36px) 20px 96px;
  }

  .momento__inner {
    grid-template-columns: 1fr;
    gap: 18px;
    justify-items: center;
    text-align: center;
  }

  .momento--invertido .momento__texto,
  .momento--invertido .momento__galeria { order: initial; }

  .momento__data { font-size: 0.68rem; padding: 7px 13px; }

  .momento__titulo {
    font-size: clamp(1.5rem, 6.4vw, 1.9rem);
    margin: 0.45em 0 0.35em;
  }

  .momento__frase {
    font-size: 0.95rem;
    line-height: 1.45;
    max-width: 34ch;
  }

  .momento--vertical .colagem { width: min(94vw, 480px); }
  .momento--vertical .colagem--1 { width: min(84vw, 420px); }

  /* dentro do palco pinado, o orçamento é mais apertado */
  .painel {
    padding: 14px 18px calc(96px + env(safe-area-inset-bottom));
  }
  .painel .momento__inner { gap: 14px; }
  .painel .colagem { width: min(94vw, 460px); }
  .painel .colagem--1 { width: min(78vw, 380px, 37svh); }
  .painel .colagem--3 { width: min(94vw, 460px, 45svh); }
  .painel .colagem--4 { width: min(94vw, 460px, 44svh); }
  .painel .colagem--5 { width: min(94vw, 460px, 50svh); }
  .painel .colagem--6 { width: min(94vw, 460px, 47svh); }
  .painel .momento__titulo { font-size: clamp(1.4rem, 6vw, 1.8rem); }

  .numeral { font-size: clamp(8rem, 38vw, 12rem); }

  /* HUD vira um cluster central no rodapé: ‹ 05/12 › */
  .palco__seta {
    top: auto;
    translate: 0 0;
    bottom: calc(14px + env(safe-area-inset-bottom));
    width: 40px;
    height: 40px;
  }
  .palco__seta--ant { left: calc(50% - 86px); right: auto; }
  .palco__seta--prox { right: calc(50% - 86px); left: auto; }

  .palco__contador {
    left: 50%;
    translate: -50% 0;
    bottom: calc(22px + env(safe-area-inset-bottom));
    font-size: 0.95rem;
  }
}

/* ------------------------ Reduced motion (CSS) ---------------------- */
@media (prefers-reduced-motion: reduce) {
  .sparkle, .deco-coracao { opacity: 0.6 !important; }
  .hero__botao > span::after { opacity: 0 !important; }
  .botao-audio.tocando .botao-audio__barras i {
    animation: none;
    transform: scaleY(0.7);
  }
  .galeria__moldura::after { transition: none; }
}

/* Modo reduzido / sem JS: palcos viram seções verticais empilhadas */
html.reduz .palco,
html:not(.js) .palco {
  height: auto;
  overflow: visible;
}
html.reduz .palco::after,
html:not(.js) .palco::after { content: none; }

html.reduz .palco__trilho,
html:not(.js) .palco__trilho {
  display: block;
  transform: none !important;
  will-change: auto;
}

html.reduz .painel,
html:not(.js) .painel {
  width: auto;
  height: auto;
  min-height: 0;
  padding: 72px 24px;
  background: color-mix(in srgb, var(--accent) 12%, var(--creme));
}

html.reduz .palco__hud,
html:not(.js) .palco__hud { display: none; }

html.reduz .secao-climax .momento__conteudo,
html:not(.js) .secao-climax .momento__conteudo {
  min-height: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 72px 0 80px;
}

html.reduz .climax__camada,
html:not(.js) .climax__camada {
  position: static;
  inset: auto;
  padding: 16px 24px;
}

html.reduz .numeral,
html:not(.js) .numeral { display: none; }
