/* ===========================================================================
   LAURA & JOSÉ — ESTILOS
   ---------------------------------------------------------------------------
   Sumário:
     1. Variáveis (paleta, tipografia, espaçamentos)   ← edite as cores aqui
     2. Reset & base
     3. Utilitários (container, botões, animações)
     4. Cabeçalho & menu
     5. Hero
     6. Seções genéricas (cabeçalho, ornamentos, divisores)
     7. Nossa História
     8. O Grande Dia (cartões)
     9. Trajes (cartões + carrossel)
    10. Cronograma (timeline)
    11. Pais & Avós / Padrinhos (pessoas)
    12. Presentes
    13. Confirmação (formulário + aviso)
    14. Galeria
    15. Carrossel (componente reutilizável)
    16. Molduras de foto / placeholders
    17. Toast
    18. Rodapé
    19. Media queries (responsividade)
    20. Acessibilidade (prefers-reduced-motion)
   =========================================================================== */

/* ===========================================================================
   1. VARIÁVEIS  ·  PALETA PRINCIPAL (verde oliva + neutros + champagne)
   =========================================================================== */
:root {
  /* --- Verde oliva (cor central) --- */
  --oliva-900: #2c3022;   /* profundo — overlay do hero, textos sobre claro */
  --oliva-700: #434832;
  --oliva-600: #565b3e;   /* oliva principal (seções escuras) */
  --oliva-500: #6a6f4c;
  --oliva-300: #9da178;
  --oliva-200: #c9ccb4;
  --oliva-100: #e7e8d8;

  /* --- Neutros quentes (fundos) --- */
  --branco-quente: #fdfbf6;
  --off-white:     #faf7f0;
  --bege:          #f2ece0;
  --areia:         #e9e0cf;

  /* --- Champagne / dourado suave (detalhes) --- */
  --ouro:        #c2a36b;
  --ouro-claro:  #d8c39a;

  /* --- Texto --- */
  --texto:       #3a3a30;  /* corpo */
  --texto-suave: #6f6e60;  /* legendas, subtítulos */
  --texto-claro: #f3f1e6;  /* sobre fundo oliva */

  /* --- Tipografia --- */
  --fonte-nomes:   'Tangerine', cursive;             /* nomes dos noivos */
  --fonte-titulos: 'Cormorant Garamond', Georgia, serif;
  --fonte-texto:   'Montserrat', system-ui, sans-serif;

  /* --- Estrutura --- */
  --largura-max: 1180px;
  --raio:        18px;     /* cantos arredondados padrão */
  --raio-grande: 26px;
  --sombra-suave: 0 14px 40px rgba(58, 58, 48, 0.10);
  --sombra-cartao: 0 10px 30px rgba(58, 58, 48, 0.08);
  --transicao: 0.45s cubic-bezier(0.22, 0.61, 0.36, 1);

  /* Safe-area (celulares com notch) */
  --safe-top:    env(safe-area-inset-top, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --safe-left:   env(safe-area-inset-left, 0px);
  --safe-right:  env(safe-area-inset-right, 0px);
}

/* ===========================================================================
   2. RESET & BASE
   =========================================================================== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--fonte-texto);
  font-weight: 300;
  color: var(--texto);
  background-color: var(--off-white);
  line-height: 1.75;
  letter-spacing: 0.02em;
  overflow-x: hidden;
  /* textura orgânica leve no fundo */
  background-image:
    radial-gradient(circle at 12% 18%, rgba(194, 163, 107, 0.05), transparent 38%),
    radial-gradient(circle at 88% 82%, rgba(86, 91, 62, 0.05), transparent 40%);
}

img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
ul, ol { list-style: none; }

h1, h2, h3 { font-family: var(--fonte-titulos); font-weight: 500; line-height: 1.15; }

::selection { background: var(--oliva-200); color: var(--oliva-900); }

/* ===========================================================================
   3. UTILITÁRIOS
   =========================================================================== */
.container {
  width: 100%;
  max-width: var(--largura-max);
  margin-inline: auto;
  padding-inline: clamp(1.25rem, 5vw, 3rem);
  padding-left: max(clamp(1.25rem, 5vw, 3rem), var(--safe-left));
  padding-right: max(clamp(1.25rem, 5vw, 3rem), var(--safe-right));
}
.container--estreito { max-width: 760px; }

/* Link "pular para o conteúdo" (acessibilidade) */
.skip-link {
  position: absolute; left: -999px; top: 0; z-index: 1000;
  background: var(--oliva-600); color: #fff; padding: 0.75rem 1.25rem; border-radius: 0 0 12px 0;
}
.skip-link:focus { left: 0; }

/* --- Botões --- */
.botao {
  display: inline-flex; align-items: center; justify-content: center;
  min-height: 52px; padding: 0 1.85rem;
  font-family: var(--fonte-texto); font-size: 0.82rem; font-weight: 500;
  letter-spacing: 0.16em; text-transform: uppercase;
  border-radius: 999px;
  transition: transform var(--transicao), box-shadow var(--transicao),
              background-color var(--transicao), color var(--transicao);
  will-change: transform;
}
.botao:active { transform: translateY(1px) scale(0.99); }

.botao--ouro {
  background: linear-gradient(135deg, var(--ouro), var(--ouro-claro));
  color: var(--oliva-900);
  box-shadow: 0 10px 24px rgba(194, 163, 107, 0.35);
}
.botao--ouro:hover { transform: translateY(-3px); box-shadow: 0 16px 30px rgba(194, 163, 107, 0.45); }

.botao--contorno { background: transparent; color: #fff; border: 1.5px solid rgba(255,255,255,0.75); }
.botao--contorno:hover { background: rgba(255,255,255,0.12); transform: translateY(-3px); }

.botao--contorno-claro { background: transparent; color: var(--texto-claro); border: 1.5px solid rgba(243,241,230,0.6); }
.botao--contorno-claro:hover { background: rgba(243,241,230,0.12); transform: translateY(-3px); }

.botao--fantasma { background: transparent; color: #fff; border: 1.5px solid transparent; text-decoration: underline; text-underline-offset: 5px; }
.botao--fantasma:hover { color: var(--ouro-claro); }

.botao--fantasma-claro { background: transparent; color: var(--texto-claro); text-decoration: underline; text-underline-offset: 5px; }
.botao--fantasma-claro:hover { color: var(--ouro-claro); }

.botao--bloco { width: 100%; }

/* --- Animação de entrada (IntersectionObserver adiciona .is-visivel) --- */
.animar { opacity: 0; transform: translateY(28px); transition: opacity 0.9s ease, transform 0.9s cubic-bezier(0.22, 0.61, 0.36, 1); }
.animar.is-visivel { opacity: 1; transform: none; }
/* atrasos escalonados (data-animar-atraso="1..4") */
.animar[data-animar-atraso="1"] { transition-delay: 0.12s; }
.animar[data-animar-atraso="2"] { transition-delay: 0.24s; }
.animar[data-animar-atraso="3"] { transition-delay: 0.36s; }
.animar[data-animar-atraso="4"] { transition-delay: 0.48s; }

/* ===========================================================================
   4. CABEÇALHO & MENU
   =========================================================================== */
.cabecalho {
  position: fixed; inset: 0 0 auto 0; z-index: 100;
  padding-top: var(--safe-top);
  background: transparent;
  transition: background-color var(--transicao), box-shadow var(--transicao), padding var(--transicao);
}
.cabecalho__interno {
  display: flex; align-items: center; justify-content: space-between; gap: 2rem;
  padding-block: 1.5rem;
  transition: padding-block var(--transicao);
}
/* estado "rolado" (JS adiciona .is-rolado) */
.cabecalho.is-rolado { background: rgba(250, 247, 240, 0.92); backdrop-filter: blur(10px); box-shadow: 0 4px 24px rgba(58,58,48,0.07); }
.cabecalho.is-rolado .cabecalho__interno { padding-block: 0.9rem; }
.cabecalho.is-rolado .cabecalho__logo,
.cabecalho.is-rolado .menu__link { color: var(--oliva-700); }
.cabecalho.is-rolado .cabecalho__hamburguer span { background: var(--oliva-700); }

.cabecalho__logo { font-family: var(--fonte-nomes); font-size: 2.4rem; line-height: 1; color: #fff; text-shadow: 0 2px 12px rgba(0,0,0,0.3); white-space: nowrap; flex-shrink: 0; }

.cabecalho__nav { display: flex; }
.menu { display: flex; gap: clamp(0.75rem, 1.3vw, 1.4rem); }
.menu__link {
  position: relative; font-size: 0.74rem; font-weight: 500; letter-spacing: 0.12em;
  text-transform: uppercase; color: #fff; text-shadow: 0 1px 8px rgba(0,0,0,0.35);
  padding-block: 0.35rem; transition: color var(--transicao); white-space: nowrap;
}
.menu__link::after {
  content: ''; position: absolute; left: 0; bottom: 0; width: 0; height: 1.5px;
  background: var(--ouro); transition: width var(--transicao);
}
.menu__link:hover::after, .menu__link:focus-visible::after { width: 100%; }

/* Botão hamburguer (escondido no desktop) */
.cabecalho__hamburguer { display: none; flex-direction: column; gap: 5px; width: 42px; height: 42px; align-items: center; justify-content: center; z-index: 120; }
.cabecalho__hamburguer span { display: block; width: 26px; height: 2px; background: #fff; border-radius: 2px; transition: transform var(--transicao), opacity var(--transicao), background var(--transicao); }
/* estado aberto (JS) */
.cabecalho__hamburguer.is-aberto span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.cabecalho__hamburguer.is-aberto span:nth-child(2) { opacity: 0; }
.cabecalho__hamburguer.is-aberto span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Overlay escuro do menu mobile */
.overlay-menu { position: fixed; inset: 0; background: rgba(44, 48, 34, 0.5); backdrop-filter: blur(2px); z-index: 90; opacity: 0; transition: opacity var(--transicao); }
.overlay-menu.is-visivel { opacity: 1; }

/* ===========================================================================
   5. HERO
   =========================================================================== */
.hero {
  position: relative; min-height: 100svh;
  display: flex; align-items: center; justify-content: center; text-align: center;
  padding: 7rem 1.25rem 4rem; overflow: hidden;
}
.hero__video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: -2; }
/* overlay verde oliva escuro semitransparente + leve gradiente p/ legibilidade */
.hero__overlay {
  position: absolute; inset: 0; z-index: -1;
  background:
    linear-gradient(180deg, rgba(44,48,34,0.35) 0%, rgba(44,48,34,0.55) 60%, rgba(44,48,34,0.75) 100%),
    radial-gradient(circle at 50% 40%, rgba(86,91,62,0.25), rgba(44,48,34,0.6));
}
.hero__conteudo { color: #fff; max-width: 780px; }
.hero__intro { font-size: 0.85rem; letter-spacing: 0.32em; text-transform: uppercase; opacity: 0.92; margin-bottom: 1.2rem; }
.hero__nomes { font-family: var(--fonte-nomes); font-weight: 700; font-size: clamp(4.5rem, 16vw, 9.5rem); line-height: 0.95; text-shadow: 0 4px 30px rgba(0,0,0,0.3); }
.hero__data { font-family: var(--fonte-titulos); font-size: clamp(1.1rem, 3vw, 1.5rem); margin-top: 1rem; letter-spacing: 0.04em; }
.hero__local { font-size: 0.95rem; letter-spacing: 0.1em; opacity: 0.9; margin-top: 0.4rem; }
.hero__acoes { display: flex; flex-wrap: wrap; gap: 0.9rem; justify-content: center; margin-top: 2.6rem; }

/* indicador de rolagem */
.hero__rolar { position: absolute; left: 50%; bottom: calc(1.6rem + var(--safe-bottom)); transform: translateX(-50%); width: 26px; height: 44px; border: 1.5px solid rgba(255,255,255,0.6); border-radius: 14px; }
.hero__rolar-traco { position: absolute; left: 50%; top: 8px; width: 2px; height: 8px; background: #fff; border-radius: 2px; transform: translateX(-50%); animation: rolar 1.8s ease-in-out infinite; }
@keyframes rolar { 0% { opacity: 0; transform: translate(-50%, 0); } 40% { opacity: 1; } 100% { opacity: 0; transform: translate(-50%, 14px); } }

/* --- Contagem regressiva (dentro do hero) --- */
.contagem { display: flex; align-items: flex-start; justify-content: center; gap: clamp(0.6rem, 2.5vw, 1.6rem); margin-top: 1.9rem; }
.contagem__bloco { display: flex; flex-direction: column; align-items: center; min-width: 56px; }
.contagem__num { font-family: var(--fonte-titulos); font-weight: 600; font-size: clamp(1.9rem, 5vw, 2.8rem); line-height: 1; color: #fff; text-shadow: 0 2px 14px rgba(0,0,0,0.3); font-variant-numeric: tabular-nums; }
.contagem__rotulo { font-size: 0.64rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ouro-claro); margin-top: 0.5rem; }
.contagem__sep { width: 1px; height: 38px; margin-top: 2px; background: linear-gradient(transparent, rgba(255,255,255,0.4), transparent); }
.contagem--encerrada { font-family: var(--fonte-titulos); font-style: italic; font-size: 1.4rem; color: #fff; }

/* ===========================================================================
   5b. TELA DE ABERTURA (ENVELOPE CINEMATOGRÁFICO)
   Cena atmosférica + envelope 3D + lacre de cera + revelação do site.
   =========================================================================== */
.abertura {
  position: fixed; inset: 0; z-index: 1000; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  padding: 1.5rem; padding-top: max(1.5rem, var(--safe-top)); padding-bottom: max(1.5rem, var(--safe-bottom));
  background:
    radial-gradient(120% 90% at 50% 36%, rgba(132,134,92,0.40), rgba(58,62,40,0.55) 38%, rgba(24,27,17,0.99) 100%),
    linear-gradient(160deg, #3c4030, #1c1f12);
  transition: opacity 1s ease, visibility 1s;
}
.abertura.is-saindo { opacity: 0; visibility: hidden; pointer-events: none; }

.abertura__particulas { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
.abertura__luz { position: absolute; left: 50%; top: 38%; width: 160vmax; height: 160vmax; z-index: 0; pointer-events: none;
  transform: translate(-50%, -50%); opacity: 0.5; mix-blend-mode: screen;
  background: conic-gradient(from 0deg,
    transparent 0deg, rgba(216,195,154,0.10) 6deg, transparent 14deg,
    transparent 40deg, rgba(216,195,154,0.07) 48deg, transparent 58deg,
    transparent 90deg, rgba(216,195,154,0.10) 98deg, transparent 108deg,
    transparent 150deg, rgba(216,195,154,0.06) 158deg, transparent 168deg,
    transparent 210deg, rgba(216,195,154,0.09) 218deg, transparent 228deg,
    transparent 280deg, rgba(216,195,154,0.07) 288deg, transparent 298deg,
    transparent 340deg, rgba(216,195,154,0.08) 348deg, transparent 360deg);
  animation: giraLuz 90s linear infinite; }
@keyframes giraLuz { to { transform: translate(-50%, -50%) rotate(360deg); } }

.abertura__brilho-final { position: absolute; inset: 0; z-index: 8; pointer-events: none; opacity: 0;
  background: radial-gradient(circle at 50% 46%, rgba(255,248,232,0.9), rgba(216,195,154,0.35) 40%, transparent 70%);
  transition: opacity 0.5s ease; }
.abertura.is-saindo .abertura__brilho-final { opacity: 1; transition: opacity 0.45s ease; }

.abertura__cena { position: relative; z-index: 1; text-align: center; perspective: 1300px;
  transition: transform 1s cubic-bezier(0.55,0,0.2,1), opacity 0.9s ease; }
.abertura.is-saindo .abertura__cena { transform: scale(1.9); opacity: 0; }

.envelope { position: relative; width: clamp(290px, 84vw, 392px); aspect-ratio: 3 / 2; margin-inline: auto;
  transform-style: preserve-3d;
  animation: envelopeEntra 1.1s cubic-bezier(0.22,0.61,0.36,1) both, flutua 6s ease-in-out 1.1s infinite; }
@keyframes envelopeEntra { from { opacity: 0; transform: translateY(40px) scale(0.92) rotateX(8deg); } to { opacity: 1; transform: none; } }
@keyframes flutua { 0%,100% { transform: translateY(0) rotateZ(-0.5deg); } 50% { transform: translateY(-12px) rotateZ(0.5deg); } }
.abertura.is-abrindo .envelope { animation: envelopeEntra 1.1s both; }

.envelope__sombra { position: absolute; left: 50%; bottom: -10%; width: 78%; height: 16%; z-index: -1;
  transform: translateX(-50%); border-radius: 50%; filter: blur(16px);
  background: radial-gradient(ellipse, rgba(0,0,0,0.5), transparent 70%);
  animation: sombraFlutua 6s ease-in-out 1.1s infinite; }
@keyframes sombraFlutua { 0%,100% { opacity: 0.55; transform: translateX(-50%) scale(1); } 50% { opacity: 0.38; transform: translateX(-50%) scale(0.9); } }

.envelope__corpo { position: absolute; inset: 0; border-radius: 12px; transform-style: preserve-3d;
  background: linear-gradient(155deg, #6f7450, #4d5236);
  box-shadow: 0 44px 90px -24px rgba(0,0,0,0.7), 0 10px 26px rgba(0,0,0,0.4); }
.envelope__corpo::before { content: ''; position: absolute; inset: 0; border-radius: inherit; z-index: 5;
  pointer-events: none; opacity: 0.07; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }

.envelope__forro { position: absolute; inset: 0; z-index: 1; border-radius: 12px;
  background-color: #f1e6cf;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='64' height='64' viewBox='0 0 64 64'%3E%3Crect width='64' height='64' fill='%23f1e6cf'/%3E%3Cg fill='none' stroke='%23c2a36b' stroke-width='1' stroke-linecap='round' opacity='0.5'%3E%3Cpath d='M16 4 V20 M16 8 q-5 -2 -7 -6 M16 8 q5 -2 7 -6 M16 13 q-4 -1 -6 -4 M16 13 q4 -1 6 -4'/%3E%3Cpath d='M48 36 V52 M48 40 q-5 -2 -7 -6 M48 40 q5 -2 7 -6 M48 45 q-4 -1 -6 -4 M48 45 q4 -1 6 -4'/%3E%3C/g%3E%3C/svg%3E"); }

.envelope__carta { position: absolute; left: 50%; top: 6%; width: 84%; height: 90%;
  transform: translateX(-50%); z-index: 2;
  display: flex; flex-direction: column; align-items: center; justify-content: flex-start; gap: 0.4rem;
  padding: 1.4rem 1rem 1rem;
  background: linear-gradient(180deg, #fdfbf6, #f6f0e4);
  border-radius: 7px;
  box-shadow: 0 8px 20px rgba(0,0,0,0.22), inset 0 0 0 1px rgba(194,163,107,0.4), inset 0 0 0 6px #fdfbf6, inset 0 0 0 7px rgba(194,163,107,0.2);
  transition: transform 1.1s cubic-bezier(0.18,0.7,0.25,1), box-shadow 1.1s ease; }
.carta__topo { font-size: 0.56rem; letter-spacing: 0.26em; text-transform: uppercase; color: var(--texto-suave); }
.carta__nomes { font-family: var(--fonte-nomes); font-size: clamp(2.4rem, 9vw, 3.2rem); line-height: 1; color: var(--oliva-700); }
.carta__sub { font-family: var(--fonte-titulos); font-style: italic; font-size: 0.8rem; color: var(--texto-suave); margin-top: -0.2rem; }
.carta__data { font-family: var(--fonte-titulos); letter-spacing: 0.2em; color: var(--ouro); font-size: 0.92rem; margin-top: 0.1rem; }
.carta__sprig { width: 30px; height: 30px; margin-top: 0.4rem; background: no-repeat center / contain
  url("assets/brasao.png"); }

.envelope__frente { position: absolute; inset: 0; z-index: 3; border-radius: 12px;
  background: linear-gradient(155deg, #5e6342, #4a4f34);
  clip-path: polygon(0 0, 0 100%, 100% 100%, 100% 0, 50% 52%);
  box-shadow: inset 0 -12px 28px rgba(0,0,0,0.14); }
.envelope__frente::after { content: ''; position: absolute; inset: 0;
  background:
    linear-gradient(to top right, transparent calc(50% - 0.6px), rgba(0,0,0,0.12) 50%, transparent calc(50% + 0.6px)),
    linear-gradient(to top left, transparent calc(50% - 0.6px), rgba(0,0,0,0.12) 50%, transparent calc(50% + 0.6px));
  clip-path: polygon(0 100%, 50% 52%, 100% 100%); }

.envelope__aba { position: absolute; top: 0; left: 0; width: 100%; height: 52%; z-index: 4;
  transform-style: preserve-3d; transform-origin: top center; transform: rotateX(0deg);
  transition: transform 1s cubic-bezier(0.6,0,0.25,1); }
.envelope__aba-fora, .envelope__aba-dentro { position: absolute; inset: 0; backface-visibility: hidden;
  clip-path: polygon(0 0, 100% 0, 50% 100%); }
.envelope__aba-fora { background: linear-gradient(155deg, #6a6f4c, #565b3e); box-shadow: inset 0 -3px 8px rgba(0,0,0,0.14); }
.envelope__aba-dentro { transform: rotateX(180deg);
  background-color: #f1e6cf;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='64' height='64' viewBox='0 0 64 64'%3E%3Crect width='64' height='64' fill='%23f1e6cf'/%3E%3Cg fill='none' stroke='%23c2a36b' stroke-width='1' stroke-linecap='round' opacity='0.5'%3E%3Cpath d='M16 4 V20 M16 8 q-5 -2 -7 -6 M16 8 q5 -2 7 -6'/%3E%3Cpath d='M48 36 V52 M48 40 q-5 -2 -7 -6 M48 40 q5 -2 7 -6'/%3E%3C/g%3E%3C/svg%3E"); }

.lacre { position: absolute; left: 50%; top: 52%; transform: translate(-50%, -50%); z-index: 6;
  width: 92px; height: 92px; border: none; background: none; cursor: pointer;
  transition: transform 0.55s cubic-bezier(0.5,-0.4,0.3,1.4), opacity 0.55s ease;
  animation: lacrePulsa 2.6s ease-in-out infinite; }
.lacre__cera { position: absolute; inset: 0; border-radius: 50%; overflow: hidden; z-index: 1;
  background: radial-gradient(circle at 36% 28%, #e6cf9e, #c8a96a 50%, #9c7d3e 100%);
  box-shadow: 0 10px 24px rgba(0,0,0,0.45), inset 0 3px 6px rgba(255,255,255,0.55), inset 0 -6px 12px rgba(0,0,0,0.35); }
.lacre__cera::before { content: ''; position: absolute; inset: 7px; border-radius: 50%;
  box-shadow: inset 0 0 0 1.5px rgba(74,60,30,0.3), inset 0 2px 4px rgba(255,255,255,0.35); }
.lacre__gloss { position: absolute; top: -30%; left: -60%; width: 60%; height: 160%; z-index: 2; pointer-events: none;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.55), transparent); transform: rotate(22deg);
  animation: gloss 4.5s ease-in-out infinite; }
@keyframes gloss { 0%, 18% { left: -60%; } 38%, 100% { left: 140%; } }
.lacre__brasao { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); z-index: 3;
  width: 62%; height: 62%; object-fit: contain; filter: drop-shadow(0 1px 1px rgba(74,60,30,0.5)); }
.lacre__texto { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); z-index: 3; display: none;
  font-family: var(--fonte-titulos); font-weight: 600; font-size: 1.6rem; color: #4a3c1e; }
.lacre.sem-brasao .lacre__brasao { display: none; }
.lacre.sem-brasao .lacre__texto { display: block; }
.lacre::after { content: ''; position: absolute; inset: -10px; border-radius: 50%; z-index: 0;
  background: radial-gradient(circle, rgba(216,195,154,0.45), transparent 70%);
  animation: halo 2.6s ease-in-out infinite; }
@keyframes halo { 0%,100% { opacity: 0.35; transform: scale(0.9); } 50% { opacity: 0.8; transform: scale(1.15); } }
.lacre::before { content: ''; position: absolute; inset: 0; border-radius: 50%; z-index: 4; opacity: 0;
  border: 2px solid rgba(232,214,170,0.9); pointer-events: none; }
@keyframes lacrePulsa { 0%,100% { transform: translate(-50%,-50%) scale(1); } 50% { transform: translate(-50%,-50%) scale(1.05); } }
.lacre:hover { transform: translate(-50%,-50%) scale(1.08); }
.lacre:active { transform: translate(-50%,-50%) scale(0.94); }

.abertura__hint { margin-top: 2.4rem; font-size: 0.7rem; letter-spacing: 0.3em; text-transform: uppercase;
  color: rgba(243,241,230,0.65); animation: hintPulsa 2.6s ease-in-out infinite; transition: opacity 0.5s ease; }
@keyframes hintPulsa { 0%,100% { opacity: 0.45; } 50% { opacity: 0.9; } }

/* ----- SEQUÊNCIA DE ABERTURA ----- */
.abertura.is-abrindo .lacre { opacity: 0; transform: translate(-50%, -160%) scale(0.55) rotate(-14deg); animation: none; pointer-events: none; }
.abertura.is-abrindo .lacre::before { animation: ondaChoque 0.7s ease-out forwards; }
@keyframes ondaChoque { 0% { opacity: 0.9; transform: scale(1); } 100% { opacity: 0; transform: scale(3); } }
.abertura.is-abrindo .abertura__hint { opacity: 0; }
/* 2) abrir a aba */
.abertura.is-aberto .envelope__aba { transform: rotateX(165deg); }
/* 3) carta flutua para fora (à frente da aba via translateZ) */
.abertura.is-aberto .envelope__carta { transform: translate(-50%, -66%) translateZ(55px); z-index: 7;
  box-shadow: 0 30px 50px rgba(0,0,0,0.4), inset 0 0 0 1px rgba(194,163,107,0.4), inset 0 0 0 6px #fdfbf6, inset 0 0 0 7px rgba(194,163,107,0.2); }

/* trava o scroll enquanto a abertura está ativa */
body.abertura-ativa { overflow: hidden; }

/* ----- ENTRADA COREOGRAFADA DO HERO ----- */
.hero-item { opacity: 1; }
body.aguardando-abertura .hero-item { opacity: 0; transform: translateY(30px); filter: blur(8px); }
body.site-revelado .hero-item { opacity: 1; transform: none; filter: blur(0);
  transition: opacity 1s ease, transform 1.15s cubic-bezier(0.22,0.61,0.36,1), filter 1s ease; }
body.site-revelado .hero-item:nth-child(1) { transition-delay: 0.10s; }
body.site-revelado .hero-item:nth-child(2) { transition-delay: 0.26s; }
body.site-revelado .hero-item:nth-child(3) { transition-delay: 0.42s; }
body.site-revelado .hero-item:nth-child(4) { transition-delay: 0.56s; }
body.site-revelado .hero-item:nth-child(5) { transition-delay: 0.70s; }
body.site-revelado .hero-item:nth-child(6) { transition-delay: 0.84s; }


/* ===========================================================================
   6. SEÇÕES GENÉRICAS
   =========================================================================== */
.secao { padding-block: clamp(4.5rem, 10vw, 8rem); position: relative; }
.secao--oliva { background: linear-gradient(160deg, var(--oliva-600), var(--oliva-700)); color: var(--texto-claro); }
.secao--oliva .secao__subtitulo { color: rgba(243,241,230,0.82); }
.secao--areia { background: linear-gradient(180deg, var(--bege), var(--areia)); }

.secao__cabecalho { text-align: center; max-width: 680px; margin-inline: auto; margin-bottom: clamp(2.5rem, 6vw, 4rem); }
.secao__titulo { font-size: clamp(2.2rem, 6vw, 3.4rem); color: var(--oliva-700); }
.secao--oliva .secao__titulo { color: #fff; }
.secao__subtitulo { font-family: var(--fonte-titulos); font-style: italic; font-size: clamp(1.05rem, 2.6vw, 1.4rem); color: var(--texto-suave); margin-top: 0.75rem; }

/* ornamento: pequeno galho/folha estilizado */
.secao__ornamento { display: inline-block; width: 46px; height: 46px; margin-bottom: 1rem;
  background: no-repeat center / contain url("assets/brasao.png"); }
.secao__ornamento--claro { filter: brightness(0) invert(1) sepia(1) saturate(2) hue-rotate(5deg) brightness(1.4); }

/* ===========================================================================
   7. NOSSA HISTÓRIA
   =========================================================================== */
.historia__grade { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(2rem, 5vw, 4rem); align-items: center; }
.historia__texto p { margin-bottom: 1.1rem; color: var(--texto); }
.historia__texto p:last-child { margin-bottom: 0; }
.historia__texto strong { color: var(--oliva-600); font-weight: 600; }

/* ===========================================================================
   8. O GRANDE DIA (cartões)
   =========================================================================== */
.cartoes { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
.cartao {
  background: rgba(253, 251, 246, 0.08); border: 1px solid rgba(243,241,230,0.2);
  border-radius: var(--raio); padding: 2rem 1.5rem; text-align: center;
  backdrop-filter: blur(4px);
  transition: transform var(--transicao), box-shadow var(--transicao), background var(--transicao);
}
.cartao:hover { transform: translateY(-6px); background: rgba(253,251,246,0.14); }
.cartao__titulo { font-size: 1.4rem; color: var(--ouro-claro); margin-bottom: 0.7rem; }
.cartao__texto { font-size: 0.95rem; color: rgba(243,241,230,0.9); }
.grande-dia__acoes { display: flex; flex-wrap: wrap; gap: 0.9rem; justify-content: center; margin-top: 2.8rem; }

/* ===========================================================================
   9. TRAJES
   =========================================================================== */
.trajes__grade { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.5rem, 4vw, 2.5rem); }
.cartao-traje { background: var(--branco-quente); border: 1px solid rgba(194,163,107,0.18); border-radius: var(--raio-grande); overflow: hidden; box-shadow: var(--sombra-cartao); transition: transform var(--transicao), box-shadow var(--transicao); }
.cartao-traje:hover { transform: translateY(-6px); box-shadow: var(--sombra-suave); }
.cartao-traje__texto { padding: 1.75rem 1.85rem 2rem; }
.cartao-traje__titulo { font-size: 1.6rem; color: var(--oliva-700); margin-bottom: 0.6rem; }
.cartao-traje__texto p { color: var(--texto-suave); font-size: 0.95rem; }
.trajes__nota { text-align: center; margin-top: 2.5rem; font-family: var(--fonte-titulos); font-style: italic; font-size: 1.15rem; color: var(--texto-suave); }
.trajes__nota strong { color: var(--oliva-600); font-style: normal; }

/* ===========================================================================
   10. CRONOGRAMA (timeline)
   =========================================================================== */
.timeline { position: relative; max-width: 760px; margin-inline: auto; padding-left: 0; }
.timeline::before { content: ''; position: absolute; left: 120px; top: 8px; bottom: 8px; width: 2px; background: linear-gradient(var(--ouro), var(--oliva-300)); }
.timeline__item { position: relative; display: grid; grid-template-columns: 104px 1fr; gap: 2rem; padding-bottom: 2.5rem; }
.timeline__item:last-child { padding-bottom: 0; }
.timeline__hora { font-family: var(--fonte-titulos); font-size: 1.25rem; font-weight: 600; color: var(--oliva-700); text-align: right; padding-top: 0.1rem; }
.timeline__conteudo { position: relative; }
/* ponto na linha */
.timeline__conteudo::before { content: ''; position: absolute; left: -36px; top: 8px; width: 14px; height: 14px; border-radius: 50%; background: var(--branco-quente); border: 3px solid var(--ouro); box-shadow: 0 0 0 5px rgba(194,163,107,0.12); }
.timeline__titulo { font-size: 1.3rem; color: var(--oliva-700); margin-bottom: 0.35rem; }
.timeline__conteudo p { color: var(--texto-suave); font-size: 0.95rem; }

/* ===========================================================================
   11. PAIS & AVÓS / PADRINHOS (pessoas)
   =========================================================================== */
.familia__grupo { text-align: center; font-size: 1.5rem; color: var(--oliva-600); margin: 2.5rem 0 1.75rem; }
.familia__grupo--claro { color: var(--ouro-claro); }
.familia__grupo:first-of-type { margin-top: 0; }

.pessoas { display: flex; flex-wrap: wrap; justify-content: center; gap: clamp(1.25rem, 3vw, 2rem); }
.pessoas .pessoa { flex: 0 1 190px; max-width: 210px; }
.pessoa { text-align: center; }
.pessoa__foto { position: relative; display: block; aspect-ratio: 3 / 4; border-radius: var(--raio); overflow: hidden; box-shadow: var(--sombra-cartao); transition: transform var(--transicao), box-shadow var(--transicao); }
.pessoa:hover .pessoa__foto { transform: translateY(-5px); box-shadow: var(--sombra-suave); }
.pessoa__nome { display: block; margin-top: 0.9rem; font-family: var(--fonte-titulos); font-size: 1.1rem; font-weight: 600; color: var(--oliva-700); line-height: 1.3; }
.pessoas--claro .pessoa__nome { color: #fff; }
.pessoa__papel { display: block; font-family: var(--fonte-texto); font-size: 0.72rem; font-weight: 400; letter-spacing: 0.14em; text-transform: uppercase; color: var(--texto-suave); margin-top: 0.25rem; }
.pessoas--claro .pessoa__papel { color: rgba(243,241,230,0.7); }

.familia__fecho { text-align: center; max-width: 640px; margin: 3rem auto 0; font-family: var(--fonte-titulos); font-style: italic; font-size: 1.2rem; color: var(--texto-suave); }
.familia__fecho--claro { color: rgba(243,241,230,0.85); }

/* ===========================================================================
   12. PRESENTES
   =========================================================================== */
.presentes { text-align: center; }
.presentes__texto { max-width: 620px; margin-inline: auto; }
.presentes__texto p { margin-bottom: 1.1rem; color: var(--texto-suave); }
.presentes__acao { margin-top: 2.2rem; }

/* ===========================================================================
   13. CONFIRMAÇÃO (formulário + aviso)
   =========================================================================== */
.formulario { background: var(--branco-quente); border: 1px solid rgba(194,163,107,0.2); border-radius: var(--raio-grande); padding: clamp(1.75rem, 4vw, 2.75rem); box-shadow: var(--sombra-cartao); }
.campo { margin-bottom: 1.5rem; }
.campo__rotulo { display: block; font-size: 0.78rem; font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase; color: var(--oliva-600); margin-bottom: 0.55rem; }
.campo__opcional { text-transform: none; letter-spacing: 0; color: var(--texto-suave); font-weight: 300; }
.campo__entrada { width: 100%; font-family: var(--fonte-texto); font-size: 1rem; color: var(--texto); background: var(--off-white); border: 1.5px solid rgba(111,110,96,0.22); border-radius: 12px; padding: 0.85rem 1rem; transition: border-color var(--transicao), box-shadow var(--transicao); }
.campo__entrada:focus { outline: none; border-color: var(--ouro); box-shadow: 0 0 0 3px rgba(194,163,107,0.18); }
textarea.campo__entrada { resize: vertical; min-height: 90px; }

/* card de aviso importante */
.aviso { position: relative; margin-top: 2.5rem; background: rgba(253,251,246,0.7); border: 1px solid rgba(194,163,107,0.3); border-left: 4px solid var(--ouro); border-radius: var(--raio); padding: 2.25rem 1.85rem 1.85rem; }
.aviso__selo { position: absolute; top: -0.85rem; left: 1.6rem; background: linear-gradient(135deg, var(--ouro), var(--ouro-claro)); color: var(--oliva-900); font-size: 0.68rem; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; padding: 0.4rem 1rem; border-radius: 999px; }
.aviso p { font-size: 0.9rem; color: var(--texto-suave); margin-bottom: 0.9rem; }
.aviso p:last-child { margin-bottom: 0; }
.aviso strong { color: var(--oliva-600); }

/* ===========================================================================
   14. GALERIA
   =========================================================================== */
.carrossel--galeria { max-width: 920px; margin-inline: auto; }
.carrossel--galeria .carrossel__slide { aspect-ratio: 16 / 10; }

/* ===========================================================================
   15. CARROSSEL (componente reutilizável)
   =========================================================================== */
.carrossel { position: relative; }
.carrossel__janela { overflow: hidden; border-radius: var(--raio-grande); }
.carrossel__trilho { display: flex; transition: transform 0.6s cubic-bezier(0.22, 0.61, 0.36, 1); touch-action: pan-y; }
.carrossel__slide { position: relative; flex: 0 0 100%; aspect-ratio: 3 / 4; }
.carrossel--galeria .carrossel__slide { flex: 0 0 100%; }

.carrossel__seta {
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 46px; height: 46px; border-radius: 50%;
  background: rgba(253,251,246,0.9); color: var(--oliva-700);
  font-size: 1.6rem; line-height: 1; display: flex; align-items: center; justify-content: center;
  box-shadow: var(--sombra-cartao); transition: transform var(--transicao), background var(--transicao); z-index: 3;
}
.carrossel__seta:hover { background: #fff; transform: translateY(-50%) scale(1.08); }
.carrossel__seta--ant { left: 0.8rem; }
.carrossel__seta--prox { right: 0.8rem; }

.carrossel__dots { display: flex; gap: 0.5rem; justify-content: center; margin-top: 1.1rem; }
.carrossel__dot { width: 9px; height: 9px; border-radius: 50%; background: rgba(111,110,96,0.3); transition: background var(--transicao), transform var(--transicao); }
.carrossel__dot.is-ativo { background: var(--ouro); transform: scale(1.35); }

/* ===========================================================================
   16. MOLDURAS DE FOTO / PLACEHOLDERS
   (a imagem aparece quando carrega; sem imagem, mostra placeholder elegante)
   =========================================================================== */
.moldura { position: relative; border-radius: var(--raio-grande); overflow: hidden; box-shadow: var(--sombra-cartao); }
.moldura--retrato { aspect-ratio: 4 / 5; }
.moldura__img { position: absolute; inset: 0; z-index: 2; width: 100%; height: 100%; object-fit: cover; opacity: 0; transition: opacity 0.8s ease; }
.moldura__img.is-carregada { opacity: 1; }
/* placeholder: fundo orgânico + rótulo */
.moldura__placeholder, .pessoa__foto .moldura__placeholder, .carrossel__slide .moldura__placeholder {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--oliva-100), var(--bege));
  color: var(--oliva-500); font-size: 0.8rem; letter-spacing: 0.18em; text-transform: uppercase;
}
.moldura__placeholder::before {
  content: ''; position: absolute; inset: 0; opacity: 0.35;
  background: no-repeat center / 60px
    url("assets/brasao.png");
  transform: translateY(-18px);
}

/* ===========================================================================
   17. TOAST
   =========================================================================== */
.toast {
  position: fixed; left: 50%; bottom: calc(1.5rem + var(--safe-bottom)); transform: translate(-50%, 120%);
  max-width: min(90vw, 420px); z-index: 200;
  background: var(--oliva-700); color: var(--texto-claro);
  padding: 1rem 1.4rem; border-radius: 14px; box-shadow: 0 12px 34px rgba(44,48,34,0.35);
  font-size: 0.9rem; text-align: center; line-height: 1.5;
  opacity: 0; transition: transform 0.5s cubic-bezier(0.22,0.61,0.36,1), opacity 0.5s ease;
}
.toast.is-visivel { transform: translate(-50%, 0); opacity: 1; }
.toast__borda { border-left: 4px solid var(--ouro); }

/* ===========================================================================
   18. RODAPÉ
   =========================================================================== */
.rodape { background: linear-gradient(160deg, var(--oliva-700), var(--oliva-900)); color: var(--texto-claro); text-align: center; padding: clamp(3.5rem, 8vw, 5.5rem) 1.25rem calc(clamp(2.5rem,6vw,3.5rem) + var(--safe-bottom)); }
.rodape__nomes { font-family: var(--fonte-nomes); font-size: clamp(3.5rem, 10vw, 5.5rem); line-height: 1; }
.rodape__texto { max-width: 540px; margin: 1.2rem auto 0; color: rgba(243,241,230,0.85); font-size: 0.95rem; }
.rodape__mensagem { max-width: 540px; margin: 1rem auto 0; font-family: var(--fonte-titulos); font-style: italic; font-size: 1.1rem; color: rgba(243,241,230,0.92); }
.rodape__ornamento { display: inline-block; width: 52px; height: 52px; margin: 1.8rem 0 1rem; background: no-repeat center / contain
  url("assets/brasao-branco.png"); }
.rodape__assinatura { font-size: 0.75rem; letter-spacing: 0.18em; text-transform: uppercase; color: rgba(243,241,230,0.6); }

/* ===========================================================================
   19. MEDIA QUERIES (responsividade)
   =========================================================================== */

/* --- Tablet e abaixo: menu vira hamburguer --- */
@media (max-width: 980px) {
  .cabecalho__hamburguer { display: flex; }

  .cabecalho__nav {
    position: fixed; inset: 0 0 0 auto; width: min(82vw, 340px);
    flex-direction: column; justify-content: center;
    background: linear-gradient(160deg, var(--oliva-600), var(--oliva-900));
    padding: 4rem 2rem calc(2rem + var(--safe-bottom)); padding-top: calc(4rem + var(--safe-top));
    transform: translateX(100%); transition: transform var(--transicao); z-index: 110;
  }
  .cabecalho__nav.is-aberto { transform: translateX(0); }
  .menu { flex-direction: column; gap: 0; }
  .menu__link { display: block; color: var(--texto-claro); text-shadow: none; font-size: 0.95rem; padding-block: 1rem; border-bottom: 1px solid rgba(243,241,230,0.12); }
  .menu__link::after { display: none; }

  .cartoes { grid-template-columns: repeat(2, 1fr); }
  .pessoas { grid-template-columns: repeat(3, 1fr); }
}

/* --- Mobile --- */
@media (max-width: 680px) {
  .historia__grade { grid-template-columns: 1fr; }
  .moldura--retrato { aspect-ratio: 4 / 5; max-width: 420px; margin-inline: auto; }

  .cartoes { grid-template-columns: 1fr; }
  .trajes__grade { grid-template-columns: 1fr; }

  .pessoas { grid-template-columns: repeat(2, 1fr); }

  /* timeline empilhada e mais compacta */
  .timeline::before { left: 7px; }
  .timeline__item { grid-template-columns: 1fr; gap: 0.35rem; padding-left: 2.25rem; padding-bottom: 2rem; }
  .timeline__hora { text-align: left; font-size: 1.15rem; }
  .timeline__conteudo::before { left: -2.25rem; top: 0.55rem; }

  .hero__acoes .botao,
  .grande-dia__acoes .botao { width: 100%; }
  .hero__acoes, .grande-dia__acoes { flex-direction: column; align-items: stretch; }

  .carrossel__seta { width: 40px; height: 40px; font-size: 1.4rem; }
}

/* --- Telas muito pequenas --- */
@media (max-width: 380px) {
  .pessoas { grid-template-columns: 1fr 1fr; gap: 1rem; }
  .cabecalho__logo { font-size: 2rem; }
  .contagem { gap: 0.4rem; }
  .contagem__bloco { min-width: 46px; }
  .contagem__sep { height: 30px; }
}

/* --- Telas grandes: limita largura da galeria --- */
@media (min-width: 1400px) {
  .carrossel--galeria { max-width: 1000px; }
}

/* ===========================================================================
   20. ACESSIBILIDADE — redução de movimento
   =========================================================================== */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; transition-duration: 0.001ms !important; }
  .animar { opacity: 1; transform: none; }
  .carrossel__trilho { transition: none; }
  /* Abertura: sem flutuar/pulsar/raios; abrir só revela o site */
  .envelope { animation: none; }
  .envelope__sombra, .lacre, .lacre__gloss, .lacre::after, .abertura__luz, .abertura__hint { animation: none; }
  .abertura.is-aberto .envelope__aba { transform: rotateX(165deg); }
  .abertura { transition: opacity 0.2s ease; }
  .abertura.is-saindo .abertura__cena { transform: none; }
  body.aguardando-abertura .hero-item { opacity: 1; transform: none; filter: none; }
}

/* Foco visível consistente (acessibilidade por teclado) */
:focus-visible { outline: 2px solid var(--ouro); outline-offset: 3px; border-radius: 4px; }

/* ===========================================================================
   12b. LISTA DE PRESENTES — cotas temáticas + modal
   =========================================================================== */
.cotas { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(1rem, 2.5vw, 1.75rem); text-align: left; }
.cota { background: var(--branco-quente); border: 1px solid rgba(194,163,107,0.18); border-radius: var(--raio); overflow: hidden;
  box-shadow: var(--sombra-cartao); display: flex; flex-direction: column;
  transition: transform var(--transicao), box-shadow var(--transicao); }
.cota:hover { transform: translateY(-6px); box-shadow: var(--sombra-suave); }
.cota__foto { aspect-ratio: 4 / 3; border-radius: 0; box-shadow: none; }
.cota__corpo { padding: 1.1rem 1.1rem 1.25rem; display: flex; flex-direction: column; gap: 0.45rem; flex: 1; }
.cota__nome { font-size: 1.12rem; color: var(--oliva-700); line-height: 1.2; }
.cota__valor { font-family: var(--fonte-titulos); font-weight: 600; font-size: 1.5rem; color: var(--ouro); }
.cota__botoes { display: flex; gap: 0.55rem; margin-top: auto; padding-top: 0.5rem; }
.cota__botoes .botao { flex: 1; }

/* Botão menor + variante contorno oliva (para fundo claro) */
.botao--peq { min-height: 42px; padding: 0 0.9rem; font-size: 0.72rem; letter-spacing: 0.1em; }
.botao--contorno-oliva { background: transparent; color: var(--oliva-700); border: 1.5px solid rgba(86,91,62,0.5); }
.botao--contorno-oliva:hover { background: rgba(86,91,62,0.08); transform: translateY(-3px); }

/* Modal de presente */
.modal-presente { position: fixed; inset: 0; z-index: 300; display: flex; align-items: center; justify-content: center; padding: 1.25rem; }
.modal-presente[hidden] { display: none; }
.modal-presente__fundo { position: absolute; inset: 0; background: rgba(44,48,34,0.55); backdrop-filter: blur(4px);
  opacity: 0; transition: opacity 0.3s ease; }
.modal-presente.is-aberto .modal-presente__fundo { opacity: 1; }
.modal-presente__caixa { position: relative; z-index: 1; width: 100%; max-width: 440px; max-height: 90vh; overflow-y: auto;
  background: var(--off-white); border-radius: var(--raio-grande); padding: 2.25rem 1.75rem 2rem; text-align: center;
  box-shadow: 0 30px 70px rgba(0,0,0,0.35);
  transform: translateY(20px) scale(0.97); opacity: 0;
  transition: transform 0.35s cubic-bezier(0.22,0.61,0.36,1), opacity 0.35s ease; }
.modal-presente.is-aberto .modal-presente__caixa { transform: none; opacity: 1; }
.modal-presente__x { position: absolute; top: 0.6rem; right: 0.9rem; width: 40px; height: 40px; font-size: 1.7rem; line-height: 1;
  color: var(--texto-suave); transition: color var(--transicao); }
.modal-presente__x:hover { color: var(--oliva-700); }
.modal-presente .secao__ornamento { margin-bottom: 0.4rem; }
.modal-presente__rotulo { font-size: 0.68rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--texto-suave); }
.modal-presente__titulo { font-size: 1.55rem; color: var(--oliva-700); margin-top: 0.15rem; }
.modal-presente__valor { font-family: var(--fonte-titulos); font-weight: 600; font-size: 2rem; color: var(--ouro); margin-top: 0.15rem; }
.modal-presente__pagar { display: flex; flex-direction: column; gap: 0.7rem; margin-top: 1.5rem; }
.modal-presente__nota { font-size: 0.74rem; color: var(--texto-suave); margin-top: 0.1rem; }
.modal-presente__nota em { color: var(--ouro); font-style: normal; }
.modal-presente__divisor { display: flex; align-items: center; gap: 0.8rem; margin: 1.6rem 0 1.1rem;
  color: var(--texto-suave); font-size: 0.68rem; letter-spacing: 0.16em; text-transform: uppercase; }
.modal-presente__divisor::before, .modal-presente__divisor::after { content: ''; flex: 1; height: 1px; background: rgba(111,110,96,0.25); }
.modal-presente__form { text-align: left; }
.modal-presente__form-titulo { text-align: center; font-family: var(--fonte-titulos); font-style: italic; font-size: 1.15rem; color: var(--oliva-700); margin-bottom: 1rem; }

body.modal-ativo { overflow: hidden; }

/* Responsivo das cotas */
@media (max-width: 980px) { .cotas { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 680px) { .cotas { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 400px) { .cotas { grid-template-columns: 1fr; } }
