/* ============================================================================
   A NOIVA DA VEZ — Estilos editoriais
   Paleta e tipografia conforme briefing §3.
   ========================================================================== */

:root {
  /* Paleta */
  --bordo: #6B1F2E;
  --bordo-escuro: #4A1320;
  --rose: #C9876B;
  --rose-claro: #E0A98F;
  --bege: #F5EBE0;
  --bege-claro: #FBF7F2;
  --creme: #FAF5EE;
  --branco: #FFFFFF;
  --grafite: #2C2C2C;
  --cinza: #595959;
  --cinza-claro: #8A8A8A;
  --dourado: #B89668;
  --dourado-claro: #D4B98E;
  --verde: #5C7A5C;
  --terra: #C25B3F;

  /* Tipografia */
  --font-display: 'Cormorant Garamond', 'Cormorant', Georgia, serif;
  --font-body: 'Manrope', system-ui, -apple-system, sans-serif;

  /* Tamanhos fluidos (clamp: min, preferred, max) */
  --fs-base: clamp(1.0625rem, 0.95rem + 0.5vw, 1.125rem); /* 17→18px */
  --fs-sm: clamp(0.875rem, 0.83rem + 0.2vw, 0.9375rem);
  --fs-xs: 0.8125rem;
  --fs-lg: clamp(1.125rem, 1rem + 0.6vw, 1.25rem);
  --fs-xl: clamp(1.375rem, 1.2rem + 0.8vw, 1.625rem);
  --fs-h3: clamp(1.625rem, 1.3rem + 1.5vw, 2.125rem);
  --fs-h2: clamp(2rem, 1.5rem + 2.5vw, 3rem);
  --fs-h1: clamp(2.5rem, 1.8rem + 3.5vw, 4.25rem);
  --fs-hero: clamp(2.75rem, 2rem + 4.5vw, 5.25rem);

  /* Ritmo */
  --container: 1200px;
  --container-narrow: 720px;
  --container-text: 680px;
  --pad-x: clamp(1.25rem, 1rem + 1.5vw, 2rem);
  --space-section: clamp(4rem, 3rem + 4vw, 6rem);

  /* Sombras */
  --shadow-soft: 0 6px 20px -10px rgba(45, 28, 30, 0.18);
  --shadow-card: 0 12px 40px -20px rgba(45, 28, 30, 0.25);

  /* Bordas */
  --radius: 8px;
  --radius-lg: 14px;
}

/* ----------------------------------------------------------------------------
   Reset suave
   -------------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-font-smoothing: antialiased; text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  line-height: 1.65;
  color: var(--grafite);
  background: var(--branco);
  font-weight: 400;
}
img, svg, video { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; transition: color .25s ease, opacity .25s ease; }
a:hover { color: var(--rose); }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
input, textarea, select, button { font: inherit; color: inherit; }
ul, ol { padding: 0; list-style: none; }

/* ----------------------------------------------------------------------------
   Tipografia
   -------------------------------------------------------------------------- */
h1, h2, h3, h4 {
  font-family: var(--font-display);
  line-height: 1.15;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--bordo);
  text-wrap: balance;
}
h1 { font-size: var(--fs-h1); }
h2 { font-size: var(--fs-h2); }
h3 { font-size: var(--fs-h3); }
h4 { font-size: var(--fs-xl); }
em, .italico { font-style: italic; color: var(--rose); font-weight: 500; }
.serif { font-family: var(--font-display); }

.eyebrow {
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--dourado);
  font-weight: 500;
}

/* Ornamento de losango ✦ — separador de marca */
.ornamento {
  display: flex; align-items: center; justify-content: center;
  gap: 1rem; color: var(--dourado);
  font-size: 1.1rem; margin: 1.5rem auto; max-width: 200px;
}
.ornamento::before, .ornamento::after {
  content: ''; flex: 1; height: 1px; background: currentColor; opacity: 0.4;
}

/* Linha fina dourada */
.divisor-dourado {
  border: 0; height: 1px; background: var(--dourado); opacity: 0.5; max-width: 100px; margin: 2rem auto;
}

/* ----------------------------------------------------------------------------
   Layout
   -------------------------------------------------------------------------- */
.container { max-width: var(--container); margin: 0 auto; padding: 0 var(--pad-x); }
.container.narrow { max-width: var(--container-narrow); }
.container.text { max-width: var(--container-text); }

.secao { padding: var(--space-section) 0; }
.secao.bege { background: var(--bege); }
.secao.bege-claro { background: var(--bege-claro); }
.secao.creme { background: var(--creme); }
.secao.bordo { background: var(--bordo); color: var(--bege-claro); }
.secao.bordo h1, .secao.bordo h2, .secao.bordo h3 { color: var(--bege-claro); }
.secao.bordo em { color: var(--rose-claro); }

.secao-header { text-align: center; margin-bottom: clamp(2.5rem, 4vw, 4rem); }
.secao-header h2 { margin-bottom: 1rem; }
.secao-header p { color: var(--cinza); max-width: 600px; margin: 0 auto; }

/* ----------------------------------------------------------------------------
   Botão
   -------------------------------------------------------------------------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.6rem;
  padding: 1.1rem 2.2rem;
  font-family: var(--font-body); font-weight: 600; font-size: 0.95rem;
  letter-spacing: 0.08em; text-transform: uppercase;
  background: var(--bordo); color: var(--bege-claro);
  border-radius: 2px;
  box-shadow: var(--shadow-soft);
  transition: transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease;
  min-height: 56px;
}
.btn:hover { background: var(--bordo-escuro); color: var(--bege-claro); transform: translateY(-2px); box-shadow: var(--shadow-card); }
.btn-grande { padding: 1.3rem 2.8rem; font-size: 1rem; min-height: 64px; }
.btn-secundario { background: transparent; color: var(--bordo); border: 1px solid var(--bordo); }
.btn-secundario:hover { background: var(--bordo); color: var(--bege-claro); }
.btn-bege { background: var(--bege-claro); color: var(--bordo); }
.btn-bege:hover { background: var(--branco); color: var(--bordo); }

/* ----------------------------------------------------------------------------
   Selo / badge
   -------------------------------------------------------------------------- */
.selo {
  display: inline-block;
  padding: 0.5rem 1.1rem;
  font-size: var(--fs-xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border-radius: 2px;
  font-weight: 600;
}
.selo-bordo { background: var(--bordo); color: var(--bege-claro); }
.selo-dourado { background: transparent; color: var(--dourado); border: 1px solid var(--dourado); }
.selo-creme { background: var(--bege-claro); color: var(--bordo); }

/* ----------------------------------------------------------------------------
   NAV TOP (surge ao rolar / hamburger no mobile)
   -------------------------------------------------------------------------- */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 60;
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: saturate(140%) blur(14px);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid rgba(184, 150, 104, 0.18);
  transform: translateY(-100%);
  opacity: 0;
  transition: transform .4s ease, opacity .35s ease;
  pointer-events: none;
}
.nav.visivel,
.nav[data-sempre-visivel="1"] {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}
.nav-inner {
  max-width: var(--container); margin: 0 auto;
  padding: 0.7rem var(--pad-x);
  display: flex; align-items: center; justify-content: space-between;
  gap: 1.5rem;
}
.nav-logo { display: flex; align-items: center; flex-shrink: 0; }
.nav-logo img { height: 36px; width: auto; }
.nav-links {
  display: flex; gap: clamp(1rem, 2.2vw, 2rem);
  align-items: center;
  font-size: var(--fs-sm);
  font-weight: 500;
  margin: 0; padding: 0;
}
.nav-links a {
  color: var(--grafite);
  position: relative;
  padding: 0.3rem 0;
  letter-spacing: 0.02em;
}
.nav-links a::after {
  content: '';
  position: absolute; left: 0; right: 0; bottom: -2px;
  height: 1px; background: var(--dourado);
  transform: scaleX(0); transform-origin: center;
  transition: transform .25s ease;
}
.nav-links a:hover { color: var(--bordo); }
.nav-links a:hover::after { transform: scaleX(1); }

.nav-cta {
  display: inline-flex; align-items: center; gap: 0.4rem;
  background: var(--bordo); color: var(--bege-claro);
  padding: 0.6rem 1.2rem;
  font-size: 0.8rem; font-weight: 600;
  letter-spacing: 0.08em; text-transform: uppercase;
  border-radius: 2px;
  transition: background .25s ease, transform .25s ease;
  flex-shrink: 0;
}
.nav-cta:hover { background: var(--bordo-escuro); color: var(--bege-claro); transform: translateY(-1px); }

.nav-hamburger {
  display: none;
  width: 44px; height: 44px;
  padding: 10px;
  background: transparent;
  flex-direction: column; justify-content: space-between;
  cursor: pointer;
}
.nav-hamburger span {
  display: block; height: 2px; background: var(--bordo);
  width: 100%; border-radius: 1px;
  transition: transform .3s ease, opacity .3s ease;
}
.nav.menu-aberto .nav-hamburger span:nth-child(1) { transform: translateY(10px) rotate(45deg); }
.nav.menu-aberto .nav-hamburger span:nth-child(2) { opacity: 0; }
.nav.menu-aberto .nav-hamburger span:nth-child(3) { transform: translateY(-10px) rotate(-45deg); }

/* Drawer mobile */
.nav-drawer { position: fixed; inset: 0; z-index: 70; display: none; }
.nav-drawer[hidden] { display: none !important; }
.nav.menu-aberto .nav-drawer { display: block; }
.nav-drawer-backdrop {
  position: absolute; inset: 0;
  background: rgba(20, 8, 12, 0.55);
  opacity: 0; animation: fadeIn .25s ease forwards;
}
.nav-drawer-painel {
  position: absolute; top: 0; right: 0; bottom: 0;
  width: min(360px, 88vw);
  background: var(--creme);
  padding: 5rem 2rem 2.5rem;
  overflow-y: auto;
  box-shadow: -20px 0 60px rgba(20, 8, 12, 0.3);
  transform: translateX(100%);
  animation: slideInRight .35s ease forwards;
}
.nav-drawer-fechar {
  position: absolute; top: 1rem; right: 1.2rem;
  width: 44px; height: 44px;
  font-size: 2rem; line-height: 1; font-weight: 300;
  color: var(--bordo);
  background: transparent;
}
.nav-drawer-links {
  display: flex; flex-direction: column;
  gap: 0.4rem;
  margin-bottom: 1.5rem;
}
.nav-drawer-links a {
  display: block;
  font-family: var(--font-display);
  font-size: 1.6rem; color: var(--bordo);
  padding: 0.8rem 0;
  border-bottom: 1px solid rgba(184, 150, 104, 0.2);
}
.nav-drawer-links a:hover { color: var(--rose); }
.nav-drawer-rodape {
  margin-top: 1.5rem; padding-top: 1.5rem;
  border-top: 1px solid rgba(184, 150, 104, 0.2);
  text-align: center;
  font-size: var(--fs-sm); color: var(--cinza);
}
.nav-drawer-rodape a { color: var(--bordo); text-decoration: underline; text-decoration-color: rgba(107,31,46,0.3); }
.nav-drawer-rodape span { margin: 0 0.5rem; color: var(--cinza-claro); }

@keyframes fadeIn { to { opacity: 1; } }
@keyframes slideInRight { to { transform: translateX(0); } }

/* Responsividade do nav */
@media (max-width: 900px) {
  .nav-links, .nav-cta { display: none; }
  .nav-hamburger { display: flex; }
  body.menu-aberto { overflow: hidden; }
}

/* ----------------------------------------------------------------------------
   HERO (Bloco 1)
   -------------------------------------------------------------------------- */
.hero {
  position: relative;
  min-height: 88vh;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  color: var(--bege-claro); text-align: center;
  padding: 6rem var(--pad-x) 4rem;
  overflow: hidden;
}
.hero-bg {
  position: absolute; inset: 0; z-index: 0;
  background-position: center; background-size: cover;
}
.hero-bg video {
  width: 100%; height: 100%; object-fit: cover;
}
.hero-overlay {
  position: absolute; inset: 0; z-index: 1;
  /* Vinheta radial focada no centro (onde o texto vive) + degradê vertical base */
  background:
    radial-gradient(ellipse 80% 70% at center 55%,
                    rgba(20, 8, 12, 0.65) 0%,
                    rgba(20, 8, 12, 0.50) 45%,
                    rgba(20, 8, 12, 0.35) 75%,
                    rgba(20, 8, 12, 0.20) 100%),
    linear-gradient(180deg,
                    rgba(20, 8, 12, 0.40) 0%,
                    rgba(20, 8, 12, 0.30) 40%,
                    rgba(20, 8, 12, 0.55) 100%);
}
.hero-conteudo {
  position: relative; z-index: 2; max-width: 900px;
  /* Sombra ampla e difusa que "escreve" um halo escuro no fundo,
     dando contraste sem precisar escurecer o vídeo inteiro */
  text-shadow: 0 2px 24px rgba(20, 8, 12, 0.55), 0 1px 2px rgba(0, 0, 0, 0.35);
}
.hero-logo { width: clamp(120px, 12vw, 160px); margin: 0 auto 2.5rem; opacity: 0.95; }
.hero-eyebrow { color: var(--dourado-claro); margin-bottom: 1.2rem; }
.hero h1 {
  font-size: var(--fs-hero);
  color: var(--bege-claro);
  font-weight: 400;
  margin-bottom: 1.5rem;
  text-wrap: balance;
}
.hero h1 em { color: var(--rose-claro); }
.hero-sub {
  font-size: var(--fs-lg);
  max-width: 680px; margin: 0 auto 2rem;
  color: rgba(251, 247, 242, 0.92);
  font-weight: 300;
}
.hero-cta-wrap { margin: 2rem 0 1.2rem; }
.hero-cta-micro {
  font-size: var(--fs-sm);
  color: rgba(251, 247, 242, 0.85);
  margin-top: 1rem;
}
.hero-contador {
  display: inline-block; margin-top: 2rem;
  padding: 0.7rem 1.4rem;
  background: rgba(0,0,0,0.25);
  border: 1px solid rgba(212, 185, 142, 0.5);
  border-radius: 2px;
  font-size: var(--fs-sm);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--dourado-claro);
}

/* ----------------------------------------------------------------------------
   Bloco 2 — Identificação
   -------------------------------------------------------------------------- */
.identificacao h2 { margin-bottom: 2.5rem; text-align: center; }
.identificacao-lista {
  max-width: 720px; margin: 0 auto;
  display: flex; flex-direction: column; gap: 1.2rem;
}
.identificacao-lista li {
  display: flex; gap: 1rem; align-items: flex-start;
  font-size: var(--fs-lg);
  color: var(--grafite); line-height: 1.5;
  padding-bottom: 1.2rem;
  border-bottom: 1px solid rgba(184, 150, 104, 0.2);
}
.identificacao-lista li::before {
  content: '✦'; color: var(--dourado);
  font-size: 1rem; line-height: 1.7; flex-shrink: 0;
}
.identificacao-lista li:last-child { border-bottom: none; }
.identificacao-fecho {
  text-align: center; margin-top: 3rem;
  font-family: var(--font-display);
  font-size: var(--fs-h3); color: var(--bordo);
  font-style: italic; font-weight: 500;
}

/* ----------------------------------------------------------------------------
   Bloco 3 — Apresentação Elis
   -------------------------------------------------------------------------- */
.apresentacao { display: grid; gap: clamp(2rem, 5vw, 4rem); align-items: center; }
@media (min-width: 900px) { .apresentacao { grid-template-columns: 1fr 1.2fr; } }
.apresentacao-foto {
  position: relative; aspect-ratio: 4 / 5;
  overflow: hidden; border-radius: var(--radius);
  box-shadow: var(--shadow-card);
}
.apresentacao-foto img { width: 100%; height: 100%; object-fit: cover; }
.apresentacao h2 { margin-bottom: 1.5rem; }
.apresentacao p { margin-bottom: 1.2rem; color: var(--cinza); }
.apresentacao .destaque {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-style: italic;
  color: var(--bordo);
  border-left: 2px solid var(--dourado);
  padding-left: 1.5rem;
  margin: 2rem 0;
  line-height: 1.45;
}
.apresentacao-numeros {
  display: flex; flex-wrap: wrap; gap: clamp(1rem, 3vw, 2.5rem);
  margin-top: 2rem; padding-top: 2rem;
  border-top: 1px solid rgba(184, 150, 104, 0.3);
  font-family: var(--font-display);
  color: var(--bordo);
  font-size: var(--fs-lg);
}
.apresentacao-numeros span { display: flex; align-items: center; gap: 0.5rem; }
.apresentacao-numeros strong { color: var(--dourado); font-weight: 600; font-size: 1.15em; }

/* ----------------------------------------------------------------------------
   Bloco 4 — Entregáveis (cards)
   -------------------------------------------------------------------------- */
.entregaveis-grid {
  display: grid; gap: 1.5rem;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}
.entregavel-card {
  background: var(--branco);
  padding: 2rem 1.8rem;
  border: 1px solid rgba(184, 150, 104, 0.2);
  border-radius: var(--radius);
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.entregavel-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-card); border-color: var(--dourado); }
.entregavel-card.destaque { border-color: var(--dourado); position: relative; }
.entregavel-card.destaque::before {
  content: 'EXCLUSIVO';
  position: absolute; top: -10px; right: 1.5rem;
  background: var(--dourado); color: var(--branco);
  font-size: 0.7rem; letter-spacing: 0.15em; padding: 0.3rem 0.7rem;
  font-weight: 600;
}
.entregavel-icone {
  width: 44px; height: 44px;
  display: flex; align-items: center; justify-content: center;
  color: var(--dourado); margin-bottom: 1.2rem;
  font-size: 1.6rem;
}
.entregavel-card h3 { font-size: var(--fs-xl); margin-bottom: 0.6rem; color: var(--bordo); }
.entregavel-card p { color: var(--cinza); font-size: var(--fs-sm); line-height: 1.55; }

/* ----------------------------------------------------------------------------
   Bloco 5 — Módulos (acordeão)
   -------------------------------------------------------------------------- */
.modulos { max-width: 880px; margin: 0 auto; }
.modulo {
  border-bottom: 1px solid rgba(184, 150, 104, 0.3);
}
.modulo[open] { background: rgba(251, 247, 242, 0.4); }
.modulo summary {
  list-style: none; cursor: pointer;
  padding: 1.6rem 0.5rem;
  display: grid; grid-template-columns: auto 1fr auto; gap: 1.5rem;
  align-items: baseline;
  transition: background .25s ease;
}
.modulo summary::-webkit-details-marker { display: none; }
.modulo summary:hover .modulo-titulo { color: var(--rose); }
.modulo-numero {
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  color: var(--dourado);
  font-weight: 400; line-height: 1;
}
.modulo-titulo {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  color: var(--bordo);
  font-weight: 500;
  transition: color .25s ease;
}
.modulo-subtitulo {
  display: block; font-family: var(--font-body); font-style: italic;
  color: var(--cinza); font-size: var(--fs-sm); font-weight: 400; margin-top: 0.3rem;
}
.modulo-chevron {
  width: 24px; height: 24px;
  color: var(--dourado);
  transition: transform .3s ease;
  align-self: center;
}
.modulo[open] .modulo-chevron { transform: rotate(180deg); }
.modulo-aulas {
  padding: 0 0.5rem 1.8rem 6rem;
  display: flex; flex-direction: column; gap: 0.8rem;
}
.modulo-aulas li {
  font-size: var(--fs-base); color: var(--grafite);
  padding-left: 1.2rem; position: relative;
}
.modulo-aulas li::before {
  content: ''; position: absolute; left: 0; top: 0.7rem;
  width: 6px; height: 6px; background: var(--rose); border-radius: 50%;
}

@media (max-width: 600px) {
  .modulo summary { grid-template-columns: auto 1fr auto; gap: 1rem; padding: 1.3rem 0.3rem; }
  .modulo-numero { font-size: var(--fs-h3); }
  .modulo-aulas { padding-left: 3rem; }
}

/* ----------------------------------------------------------------------------
   Captura de lead
   -------------------------------------------------------------------------- */
.captura {
  max-width: 640px; margin: 0 auto;
  background: var(--branco);
  padding: clamp(2rem, 5vw, 3.5rem);
  border: 1px solid rgba(184, 150, 104, 0.3);
  border-radius: var(--radius-lg);
  text-align: center;
  box-shadow: var(--shadow-soft);
}
.captura h2 { font-size: var(--fs-h3); margin-bottom: 1rem; }
.captura > p { color: var(--cinza); margin-bottom: 2rem; }
.captura-form { display: flex; flex-direction: column; gap: 1rem; text-align: left; }
.captura-form label { display: block; }
.captura-form .label-texto {
  font-size: var(--fs-sm); color: var(--cinza); font-weight: 500;
  margin-bottom: 0.4rem; display: block;
}
.captura-form input[type="text"],
.captura-form input[type="email"],
.captura-form input[type="tel"] {
  width: 100%;
  padding: 0.9rem 1rem;
  background: var(--bege-claro);
  border: 1px solid transparent;
  border-bottom: 1px solid rgba(184, 150, 104, 0.4);
  border-radius: 4px;
  font-size: var(--fs-base);
  transition: border-color .2s ease, background .2s ease;
}
.captura-form input:focus {
  outline: none;
  background: var(--branco);
  border-color: var(--dourado);
}
.captura-form .lgpd {
  display: flex; gap: 0.6rem; align-items: flex-start;
  font-size: var(--fs-sm); color: var(--cinza); line-height: 1.45;
}
.captura-form .lgpd input { margin-top: 0.25rem; flex-shrink: 0; }
.captura-form .lgpd a { color: var(--bordo); text-decoration: underline; text-decoration-color: rgba(107,31,46,0.3); }
.captura-msg { margin-top: 1rem; font-size: var(--fs-sm); }
.captura-msg.ok { color: var(--verde); }
.captura-msg.erro { color: var(--terra); }

/* ----------------------------------------------------------------------------
   Bloco 6 — A Elis Responde
   -------------------------------------------------------------------------- */
.elis-responde { text-align: center; }
.elis-responde .selo { margin-bottom: 1.5rem; background: rgba(212, 185, 142, 0.2); color: var(--dourado-claro); }
.elis-responde h2 { font-size: var(--fs-h2); margin-bottom: 2rem; color: var(--bege-claro); }
.elis-responde p {
  max-width: 720px; margin: 0 auto 1.2rem;
  color: rgba(251, 247, 242, 0.9);
  font-size: var(--fs-lg);
  line-height: 1.65;
}
.elis-responde .fecho {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-style: italic;
  color: var(--rose-claro);
  margin-top: 2rem;
}

/* ----------------------------------------------------------------------------
   Bloco 7 — Depoimentos
   -------------------------------------------------------------------------- */
/* Vídeo de depoimento em destaque (vertical, story-style) */
.depoimento-video {
  max-width: 360px;
  margin: 0 auto 3.5rem;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  background: var(--bordo);
  position: relative;
}
.depoimento-video video {
  width: 100%;
  aspect-ratio: 9 / 16;
  display: block;
  background: var(--bordo-escuro);
}
.depoimento-video figcaption {
  text-align: center;
  font-size: var(--fs-sm);
  color: var(--cinza-claro);
  font-style: italic;
  padding: 0.8rem 1rem;
  background: var(--branco);
}

.depoimentos-track { margin: 0 -1rem; }
.splide__list { padding-bottom: 1rem !important; }
.depoimento {
  background: var(--branco);
  padding: 2.5rem 2rem;
  border-radius: var(--radius);
  margin: 0 1rem;
  height: 100%;
  display: flex; flex-direction: column;
  box-shadow: var(--shadow-soft);
  border: 1px solid rgba(184, 150, 104, 0.15);
  min-height: 280px;
}
.depoimento-aspas {
  font-family: var(--font-display); font-size: 4rem; line-height: 0.5;
  color: var(--dourado); margin-bottom: 0.5rem;
}
.depoimento-texto {
  font-family: var(--font-display); font-style: italic;
  font-size: var(--fs-lg); color: var(--grafite); line-height: 1.5;
  flex-grow: 1; margin-bottom: 1.2rem;
}
.depoimento-autor {
  font-family: var(--font-body); font-size: var(--fs-sm);
  color: var(--dourado); font-weight: 600;
  letter-spacing: 0.05em;
}
.splide__arrow {
  background: var(--bordo) !important; color: var(--bege-claro) !important;
  width: 44px !important; height: 44px !important;
  opacity: 0.85 !important;
}
.splide__arrow svg { fill: currentColor !important; }
.splide__arrow:hover { background: var(--bordo-escuro) !important; opacity: 1 !important; }
.splide__pagination__page.is-active { background: var(--bordo) !important; }
.splide__pagination__page { background: var(--cinza-claro) !important; opacity: 0.5 !important; }

/* ----------------------------------------------------------------------------
   Depoimentos em formato story (Instagram/WhatsApp prints)
   -------------------------------------------------------------------------- */
.stories-secao {
  background: var(--bege-claro);
  position: relative;
}
.stories-secao h2 { margin-bottom: 0.6rem; }
.stories-secao .secao-header p { font-style: italic; }

.stories-track { margin: 0 -1rem; }
.stories-card {
  margin: 0 0.75rem;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  background: var(--branco);
  transition: transform .35s ease, box-shadow .35s ease;
  aspect-ratio: 9 / 16;
  height: 540px;
  max-height: 80vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.stories-card:hover { transform: translateY(-4px); }
.stories-card img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
}
@media (max-width: 768px) {
  .stories-card { height: 480px; }
}

/* ----------------------------------------------------------------------------
   Bloco 8 — Para quem é
   -------------------------------------------------------------------------- */
.para-quem { display: grid; gap: 2rem; }
@media (min-width: 800px) { .para-quem { grid-template-columns: 1fr 1fr; } }
.para-quem-coluna {
  padding: clamp(2rem, 4vw, 3rem);
  border-radius: var(--radius);
}
.para-quem-coluna.sim {
  background: rgba(92, 122, 92, 0.07);
  border: 1px solid rgba(92, 122, 92, 0.25);
}
.para-quem-coluna.nao {
  background: rgba(194, 91, 63, 0.06);
  border: 1px solid rgba(194, 91, 63, 0.25);
}
.para-quem h3 { font-size: var(--fs-xl); margin-bottom: 1.5rem; }
.para-quem-coluna.sim h3 { color: var(--verde); }
.para-quem-coluna.nao h3 { color: var(--terra); }
.para-quem ul { display: flex; flex-direction: column; gap: 1rem; }
.para-quem li {
  display: flex; gap: 0.8rem; align-items: flex-start;
  color: var(--grafite); line-height: 1.5;
}
.para-quem li::before {
  content: ''; width: 18px; height: 18px;
  flex-shrink: 0; margin-top: 0.25rem;
  background-position: center; background-repeat: no-repeat; background-size: contain;
}
.para-quem-coluna.sim li::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235C7A5C' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");
}
.para-quem-coluna.nao li::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23C25B3F' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'%3E%3C/line%3E%3Cline x1='6' y1='6' x2='18' y2='18'%3E%3C/line%3E%3C/svg%3E");
}

/* ----------------------------------------------------------------------------
   Bloco 9 — Preço + CTA
   -------------------------------------------------------------------------- */
.preco-card {
  max-width: 560px; margin: 0 auto;
  background: var(--branco);
  padding: clamp(2rem, 5vw, 3rem);
  border: 1px solid rgba(184, 150, 104, 0.4);
  border-radius: var(--radius-lg);
  text-align: center;
  box-shadow: var(--shadow-card);
  position: relative;
}
.preco-selo {
  display: inline-block; margin-bottom: 1.8rem;
}
.preco-de {
  font-family: var(--font-body);
  color: var(--cinza-claro);
  font-size: var(--fs-sm);
  text-decoration: line-through;
  margin-bottom: 0.4rem;
}
.preco-valor {
  font-family: var(--font-display);
  font-size: clamp(2.8rem, 2rem + 3.5vw, 4.5rem);
  color: var(--bordo);
  line-height: 1; font-weight: 500;
  margin: 0.3rem 0;
}
.preco-valor .moeda { font-size: 0.5em; vertical-align: 0.7em; margin-right: 0.2em; color: var(--rose); }
.preco-parcela {
  color: var(--cinza); font-size: var(--fs-base); margin-bottom: 1.8rem;
}
.preco-microcopy {
  font-size: var(--fs-sm); color: var(--cinza);
  font-style: italic; margin: 0 auto 1.8rem; max-width: 380px; line-height: 1.5;
}
.preco-garantia {
  display: inline-flex; align-items: center; gap: 0.6rem;
  padding: 0.7rem 1.2rem;
  background: rgba(92, 122, 92, 0.1);
  color: var(--verde);
  border-radius: 4px;
  font-size: var(--fs-sm); font-weight: 600;
  margin: 1.5rem auto;
}
.preco-cta-micro {
  margin-top: 1rem; font-size: var(--fs-sm); color: var(--cinza-claro);
}
.preco-cta-micro span { white-space: nowrap; margin: 0 0.4rem; }
.preco-orderbump {
  margin-top: 2rem; padding-top: 1.5rem;
  border-top: 1px dashed rgba(184, 150, 104, 0.4);
  font-size: var(--fs-sm); color: var(--cinza); line-height: 1.55;
  font-style: italic;
}

/* ----------------------------------------------------------------------------
   Bloco 10 — FAQ
   -------------------------------------------------------------------------- */
.faq { max-width: 780px; margin: 0 auto; }
.faq-item { border-bottom: 1px solid rgba(184, 150, 104, 0.3); }
.faq-item summary {
  list-style: none; cursor: pointer;
  padding: 1.4rem 0.5rem;
  display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem;
  font-family: var(--font-display);
  font-size: var(--fs-xl); color: var(--bordo);
  font-weight: 500;
  transition: color .25s ease;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary:hover { color: var(--rose); }
.faq-item .faq-icone {
  width: 22px; height: 22px;
  color: var(--dourado); flex-shrink: 0;
  transition: transform .3s ease; margin-top: 0.4rem;
}
.faq-item[open] .faq-icone { transform: rotate(45deg); }
.faq-item .faq-resposta {
  padding: 0 0.5rem 1.6rem;
  color: var(--cinza); line-height: 1.65;
}

/* ----------------------------------------------------------------------------
   Rodapé
   -------------------------------------------------------------------------- */
.rodape {
  background: var(--bordo-escuro);
  color: rgba(251, 247, 242, 0.85);
  padding: clamp(3rem, 6vw, 5rem) 0 2rem;
  font-size: var(--fs-sm);
}
.rodape h4 {
  color: var(--rose-claro);
  font-family: var(--font-display); font-size: 1.25rem;
  margin-bottom: 1rem; font-weight: 500;
}
.rodape-grid {
  display: grid; gap: 2.5rem;
  grid-template-columns: 1fr;
}
@media (min-width: 700px) { .rodape-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .rodape-grid { grid-template-columns: 1.5fr 1fr 1fr 1fr; } }
.rodape ul { display: flex; flex-direction: column; gap: 0.5rem; }
.rodape a:hover { color: var(--bege-claro); }
.rodape-marca p { font-style: italic; margin: 0.5rem 0; color: rgba(251, 247, 242, 0.65); }
.rodape-base {
  text-align: center; margin-top: 3rem; padding-top: 2rem;
  border-top: 1px solid rgba(184, 150, 104, 0.2);
  color: rgba(251, 247, 242, 0.5);
  font-size: var(--fs-xs);
}

/* ----------------------------------------------------------------------------
   CTA Sticky (mobile)
   -------------------------------------------------------------------------- */
.cta-sticky {
  position: fixed; bottom: 0; left: 0; right: 0;
  background: var(--bordo); color: var(--bege-claro);
  padding: 0.85rem var(--pad-x);
  display: none;
  align-items: center; justify-content: space-between;
  z-index: 50;
  box-shadow: 0 -8px 30px rgba(0,0,0,0.15);
  transform: translateY(100%);
  transition: transform .35s ease;
}
.cta-sticky.visivel { transform: translateY(0); }
.cta-sticky-preco { font-family: var(--font-display); font-size: 1.1rem; line-height: 1.1; }
.cta-sticky-preco small { display: block; font-size: 0.7rem; opacity: 0.75; letter-spacing: 0.1em; text-transform: uppercase; }
.cta-sticky .btn { padding: 0.7rem 1.2rem; min-height: 44px; font-size: 0.8rem; }
@media (max-width: 768px) { .cta-sticky { display: flex; } body { padding-bottom: 80px; } }

/* ----------------------------------------------------------------------------
   Páginas de checkout (/comprar, /checkout, /obrigado, /sucesso)
   -------------------------------------------------------------------------- */
body.pagina-checkout { background: var(--bege-claro); }

.checkout-header {
  background: var(--branco);
  border-bottom: 1px solid rgba(184, 150, 104, 0.2);
  padding: 1.2rem 0;
}
.checkout-header .container {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 1rem;
}
.checkout-logo { display: flex; align-items: center; }
.checkout-microcopy {
  font-size: var(--fs-sm);
  color: var(--cinza);
  font-style: italic;
  margin: 0;
}

.checkout {
  padding: clamp(2.5rem, 5vw, 4.5rem) 0 clamp(3rem, 6vw, 5rem);
}

/* Stepper */
.checkout-stepper {
  display: flex; justify-content: center; align-items: center;
  gap: 0.5rem; margin: 0 auto 2.5rem;
  padding: 0; list-style: none;
  flex-wrap: wrap;
  font-size: var(--fs-sm);
  color: var(--cinza-claro);
  font-weight: 500;
}
.checkout-stepper li {
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.4rem 0.8rem;
  border-radius: 999px;
}
.checkout-stepper li span {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px;
  border: 1px solid currentColor; border-radius: 50%;
  font-family: var(--font-display);
  font-size: 0.9rem;
}
.checkout-stepper li.ativo { color: var(--bordo); }
.checkout-stepper li.ativo span { background: var(--bordo); color: var(--bege-claro); border-color: var(--bordo); }
.checkout-stepper li.feito { color: var(--verde); }
.checkout-stepper li.feito span { background: var(--verde); color: var(--branco); border-color: var(--verde); }
.checkout-stepper li:not(:last-child)::after {
  content: ''; width: 24px; height: 1px; background: currentColor; opacity: 0.4;
  margin-left: 0.4rem;
}

.checkout-titulo {
  font-family: var(--font-display);
  font-size: var(--fs-h2);
  color: var(--bordo);
  text-align: center;
  margin-bottom: 0.5rem;
}
.checkout-lead {
  text-align: center; color: var(--cinza);
  margin-bottom: 2.5rem; max-width: 560px; margin-left: auto; margin-right: auto;
}

/* Grid form + resumo */
.checkout-grid { display: grid; gap: 2rem; }
@media (min-width: 850px) { .checkout-grid { grid-template-columns: 1.4fr 1fr; align-items: start; } }

.checkout-form {
  background: var(--branco);
  padding: clamp(1.6rem, 3vw, 2.4rem);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
}
.checkout-form fieldset { border: none; padding: 0; margin: 0; }
.checkout-form legend {
  font-family: var(--font-display);
  font-size: 1.4rem; color: var(--bordo);
  margin-bottom: 1.2rem;
}
.checkout-form label { display: block; margin-bottom: 1.1rem; }
.checkout-form .label-texto {
  font-size: var(--fs-sm); color: var(--cinza); font-weight: 500;
  margin-bottom: 0.35rem; display: block;
}
.checkout-form .label-ajuda {
  font-size: var(--fs-xs); color: var(--cinza-claro);
  margin-top: 0.2rem; display: block; font-style: italic;
}
.checkout-form input[type=text],
.checkout-form input[type=email],
.checkout-form input[type=tel] {
  width: 100%;
  padding: 0.8rem 1rem;
  background: var(--bege-claro);
  border: 1px solid transparent;
  border-bottom: 1px solid rgba(184, 150, 104, 0.4);
  border-radius: 4px;
  font-size: var(--fs-base);
  transition: border-color .2s ease, background .2s ease;
}
.checkout-form input:focus {
  outline: none; background: var(--branco); border-color: var(--dourado);
}
.checkout-form .lgpd {
  display: flex; gap: 0.6rem; align-items: flex-start;
  font-size: var(--fs-sm); color: var(--cinza); line-height: 1.5;
  margin-top: 1rem;
}
.checkout-form .lgpd input { margin-top: 0.25rem; flex-shrink: 0; }
.checkout-form .lgpd a { color: var(--bordo); text-decoration: underline; text-decoration-color: rgba(107,31,46,0.3); }
.checkout-btn { width: 100%; margin-top: 0.8rem; }
.checkout-msg { margin-top: 1rem; font-size: var(--fs-sm); }
.checkout-msg.erro { color: var(--terra); }
.checkout-msg.ok { color: var(--verde); }
.checkout-disclaimer {
  font-size: var(--fs-xs); color: var(--cinza-claro); margin-top: 1.2rem;
  text-align: center; line-height: 1.5;
}
.checkout-disclaimer code {
  background: var(--bege-claro); padding: 2px 6px; border-radius: 3px;
  font-family: monospace; font-size: 0.85em; color: var(--bordo);
}

/* Resumo do pedido (sidebar) */
.checkout-resumo {
  background: var(--branco);
  padding: clamp(1.6rem, 3vw, 2.4rem);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
  text-align: center;
  position: sticky; top: 90px;
}
.checkout-resumo h2 {
  font-family: var(--font-display);
  font-size: 1.3rem;
  margin-bottom: 1.2rem;
  color: var(--bordo);
}
.resumo-item { margin-bottom: 1.5rem; }
.resumo-item strong { display: block; font-family: var(--font-display); font-size: 1.5rem; color: var(--bordo); margin-bottom: 0.4rem; }
.resumo-item small { color: var(--cinza); display: block; font-size: var(--fs-sm); line-height: 1.45; }
.resumo-selo {
  display: inline-block;
  background: var(--bordo); color: var(--bege-claro);
  padding: 0.4rem 1rem;
  font-size: var(--fs-xs); letter-spacing: 0.12em; text-transform: uppercase;
  font-weight: 600;
  border-radius: 2px;
  margin-bottom: 1rem;
}
.resumo-de { font-size: var(--fs-sm); color: var(--cinza-claro); margin-bottom: 0.3rem; }
.resumo-de span { text-decoration: line-through; }
.resumo-valor {
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 2rem + 2vw, 3.5rem);
  color: var(--bordo); line-height: 1; font-weight: 500;
}
.resumo-valor .moeda { font-size: 0.45em; vertical-align: 0.6em; margin-right: 0.2em; color: var(--rose); }
.resumo-parcela { color: var(--cinza); font-size: var(--fs-sm); margin-bottom: 1.5rem; }
.resumo-bullets {
  list-style: none; padding: 1rem 0 0;
  border-top: 1px solid rgba(184, 150, 104, 0.2);
  font-size: var(--fs-sm); color: var(--cinza);
}
.resumo-bullets li { padding: 0.3rem 0; }
.resumo-bullets li::before { content: '✓ '; color: var(--verde); font-weight: 600; }

/* Estados da página de status (/obrigado) */
.checkout-status { text-align: center; }
.checkout-status h1 { margin-bottom: 1rem; }
.checkout-status.status-paga h1 { color: var(--verde); }
.checkout-status.status-aberta h1 { color: var(--bordo); }
.checkout-status.status-vencida h1, .checkout-status.status-cancelada h1 { color: var(--terra); }
.alert {
  border-radius: var(--radius);
  padding: 1rem 1.2rem;
  margin: 1.2rem auto;
  max-width: 480px;
  font-size: var(--fs-sm);
}
.alert-ok { background: rgba(92, 122, 92, 0.1); color: var(--verde); border: 1px solid rgba(92, 122, 92, 0.3); }
.alert-aguardando { background: rgba(184, 150, 104, 0.1); color: var(--dourado); border: 1px solid rgba(184, 150, 104, 0.3); }

/* Redirect com countdown */
.checkout-redirect { text-align: center; }
.checkout-redirect #countdown {
  font-family: var(--font-display); font-size: 3rem; color: var(--dourado);
  font-weight: 500;
}

/* Sucesso (welcome) */
.sucesso-conteudo { text-align: center; }
.sucesso-conteudo h1 em { color: var(--rose); }
.sucesso-card {
  background: var(--branco);
  padding: clamp(1.5rem, 3vw, 2.4rem);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
  text-align: left;
  margin: 2.5rem auto;
  max-width: 600px;
}
.sucesso-card h2 {
  font-size: 1.4rem; color: var(--bordo);
  text-align: center; margin-bottom: 1.5rem;
}
.sucesso-passos {
  list-style: none; padding: 0;
  counter-reset: passo;
}
.sucesso-passos li {
  padding: 1.2rem 0 1.2rem 3.5rem;
  border-bottom: 1px solid rgba(184, 150, 104, 0.2);
  position: relative;
  line-height: 1.55;
  counter-increment: passo;
}
.sucesso-passos li:last-child { border-bottom: none; }
.sucesso-passos li::before {
  content: counter(passo);
  position: absolute; left: 0; top: 1.2rem;
  width: 36px; height: 36px;
  background: var(--bordo); color: var(--bege-claro);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-size: 1.1rem;
}
.sucesso-fecho {
  font-family: var(--font-display); font-style: italic;
  color: var(--bordo); font-size: 1.3rem;
  margin: 2rem 0;
}

/* Erro */
.checkout-erro h1 { color: var(--terra); }
.checkout-erro ul {
  background: rgba(194, 91, 63, 0.06);
  border: 1px solid rgba(194, 91, 63, 0.25);
  padding: 1.2rem 2rem;
  border-radius: var(--radius);
  list-style-position: inside;
  margin: 1.5rem 0;
}

/* ----------------------------------------------------------------------------
   Área de membros
   -------------------------------------------------------------------------- */
.pagina-membros { background: var(--bege-claro); }
.membros { padding: clamp(2rem, 4vw, 4rem) 0 5rem; }

.membros-header { text-align: center; margin-bottom: clamp(2.5rem, 4vw, 4rem); }
.membros-header h1 {
  font-size: clamp(2rem, 1.5rem + 2vw, 3rem);
  margin: 0.5rem 0 1rem;
}
.membros-header h1 em { color: var(--rose); }
.membros-lead {
  max-width: 600px; margin: 0 auto 2rem;
  color: var(--cinza); font-size: var(--fs-lg);
}

.membros-contador {
  display: inline-block;
  padding: 1.2rem 2rem;
  background: var(--bordo); color: var(--bege-claro);
  border-radius: var(--radius);
  font-size: var(--fs-base);
  letter-spacing: 0.04em;
}
.membros-contador .contador-num {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(3rem, 2rem + 4vw, 5rem);
  font-weight: 500; line-height: 1;
  color: var(--dourado-claro);
  margin-bottom: 0.3rem;
}

.membros-recursos, .membros-modulos, .membros-elis-responde {
  margin-bottom: clamp(3rem, 5vw, 4rem);
}
.membros-recursos h2, .membros-modulos h2, .membros-elis-responde h2 {
  font-size: var(--fs-h3);
  text-align: center;
  margin-bottom: 2rem;
  color: var(--bordo);
}

/* Recursos extras (cards) */
.recursos-grid {
  display: grid; gap: 1.2rem;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}
.recurso-card {
  background: var(--branco);
  border: 1px solid rgba(184, 150, 104, 0.2);
  border-radius: var(--radius);
  padding: 1.8rem;
  text-align: center;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.recurso-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-card);
  border-color: var(--dourado);
}
.recurso-card.bloqueado { opacity: 0.6; }
.recurso-card.destaque { border-color: var(--dourado); }
.recurso-icone {
  display: block;
  font-size: 2rem; color: var(--dourado);
  margin-bottom: 0.8rem;
}
.recurso-card h3 {
  font-family: var(--font-display);
  font-size: 1.3rem; color: var(--bordo);
  margin-bottom: 0.5rem;
}
.recurso-card p {
  font-size: var(--fs-sm); color: var(--cinza);
  margin-bottom: 1.2rem; min-height: 2.4em;
}
.recurso-status {
  display: block; font-size: var(--fs-xs); color: var(--cinza-claro);
  font-style: italic; padding: 0.8rem;
  background: var(--bege-claro); border-radius: 4px;
}

/* Módulos do curso */
.membro-modulo {
  background: var(--branco);
  border: 1px solid rgba(184, 150, 104, 0.2);
  border-radius: var(--radius);
  margin-bottom: 0.8rem;
  overflow: hidden;
  transition: border-color .25s ease;
}
.membro-modulo.bloqueado { opacity: 0.65; background: var(--bege-claro); }
.membro-modulo.liberado:hover { border-color: var(--dourado); }
.membro-modulo summary {
  list-style: none; cursor: pointer;
  padding: 1.3rem 1.5rem;
  display: grid; grid-template-columns: auto 1fr auto; gap: 1.5rem;
  align-items: center;
}
.membro-modulo.bloqueado summary { cursor: default; }
.membro-modulo summary::-webkit-details-marker { display: none; }
.membro-modulo .modulo-numero {
  font-family: var(--font-display);
  font-size: 2rem; color: var(--dourado);
  font-weight: 500; line-height: 1;
}
.membro-modulo .modulo-info { display: flex; flex-direction: column; }
.membro-modulo .modulo-titulo {
  font-family: var(--font-display);
  font-size: 1.2rem; color: var(--bordo);
  font-weight: 500;
}
.membro-modulo .modulo-subtitulo {
  font-size: var(--fs-sm); color: var(--cinza);
  font-style: italic;
}
.membro-modulo .modulo-status {
  font-size: var(--fs-sm); color: var(--cinza-claro);
  white-space: nowrap;
}
.modulo-aulas-membro {
  padding: 0 1.5rem 1.5rem 5rem;
  list-style: none;
}
.modulo-aulas-membro .aula {
  padding: 0.8rem 0;
  border-bottom: 1px solid rgba(184, 150, 104, 0.15);
  display: grid;
  grid-template-columns: 70px 1fr auto auto;
  gap: 1rem; align-items: center;
  font-size: var(--fs-sm);
}
.modulo-aulas-membro .aula:last-child { border-bottom: none; }
.aula-numero { color: var(--cinza-claro); font-weight: 600; }
.aula-titulo { color: var(--grafite); }
.aula-duracao { color: var(--cinza-claro); font-size: var(--fs-xs); }
.aula-link {
  color: var(--bordo); font-weight: 600;
  text-decoration: none; padding: 0.3rem 0.8rem;
  border: 1px solid var(--bordo); border-radius: 2px;
  transition: background .25s ease, color .25s ease;
}
.aula-link:hover { background: var(--bordo); color: var(--bege-claro); }
.aula-em-breve {
  color: var(--cinza-claro); font-style: italic; font-size: var(--fs-xs);
}

.membros-elis-responde {
  background: var(--branco);
  padding: clamp(2rem, 4vw, 3rem);
  border-radius: var(--radius-lg);
  text-align: center;
}
.membros-elis-responde p {
  color: var(--cinza);
  max-width: 600px;
  margin: 0 auto 1rem;
}

.membros-rodape {
  text-align: center;
  padding-top: 2rem;
  border-top: 1px solid rgba(184, 150, 104, 0.2);
  color: var(--cinza);
  font-size: var(--fs-sm);
}
.membros-rodape a { color: var(--bordo); }
.codigo-acesso {
  margin-top: 0.6rem;
  font-size: var(--fs-xs);
  color: var(--cinza-claro);
}
.codigo-acesso code {
  font-family: monospace;
  background: var(--bege-claro);
  padding: 2px 6px;
  border-radius: 3px;
}

@media (max-width: 600px) {
  .membro-modulo summary { grid-template-columns: auto 1fr; gap: 1rem; }
  .membro-modulo .modulo-status { display: none; }
  .modulo-aulas-membro { padding-left: 1.5rem; }
  .modulo-aulas-membro .aula {
    grid-template-columns: 1fr;
    gap: 0.3rem;
  }
  .aula-numero, .aula-duracao { font-size: var(--fs-xs); }
}

/* ----------------------------------------------------------------------------
   Página /privacidade
   -------------------------------------------------------------------------- */
.pagina-privacidade { padding: 5rem 0 4rem; }
.pagina-privacidade h1 { text-align: center; margin-bottom: 0.5rem; }
.pagina-privacidade .meta-info {
  text-align: center; color: var(--cinza-claro);
  font-size: var(--fs-sm); margin-bottom: 3rem; font-style: italic;
}
.pagina-privacidade .conteudo h2 {
  font-size: var(--fs-xl); margin-top: 2.5rem; margin-bottom: 0.8rem; color: var(--bordo);
}
.pagina-privacidade .conteudo p { margin-bottom: 1rem; color: var(--grafite); }
.pagina-privacidade .conteudo ul {
  margin-bottom: 1.2rem; padding-left: 1.5rem; list-style: none;
}
.pagina-privacidade .conteudo li {
  position: relative; padding-left: 1.2rem; margin-bottom: 0.5rem;
}
.pagina-privacidade .conteudo li::before {
  content: '✦'; position: absolute; left: 0; color: var(--dourado); font-size: 0.7em;
}
.pagina-privacidade .conteudo strong { color: var(--bordo); font-weight: 600; }
.pagina-privacidade .voltar {
  display: inline-block; margin-top: 3rem;
  color: var(--bordo); text-decoration: underline;
}

/* ----------------------------------------------------------------------------
   Animação de entrada ao scroll
   -------------------------------------------------------------------------- */
.fade-in {
  opacity: 0; transform: translateY(20px);
  transition: opacity .8s ease-out, transform .8s ease-out;
}
.fade-in.visivel { opacity: 1; transform: translateY(0); }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
  .fade-in { opacity: 1; transform: none; }
}

/* ----------------------------------------------------------------------------
   Acessibilidade — foco visível
   -------------------------------------------------------------------------- */
:focus-visible {
  outline: 2px solid var(--dourado);
  outline-offset: 3px;
  border-radius: 2px;
}
