/* ============================================================
   ORAÇÕES SAGRADAS — style.css
   Variáveis CSS, Reset e Estilos Globais
   ============================================================ */

/* --- Google Fonts Import --- */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,600&family=Lato:wght@300;400;700&display=swap');

/* --- CSS Variables --- */
:root {
  /* Cores Principais */
  --azul-escuro:    #0f1d5c;
  --azul-medio:     #1a2a6c;
  --azul-claro:     #253580;
  --dourado:        #c9a84c;
  --dourado-claro:  #e2c46e;
  --dourado-escuro: #a8872a;
  --branco:         #ffffff;
  --creme:          #fdf8ee;
  --preto:          #0d0d0d;
  --cinza-escuro:   #1a1a1a;
  --cinza-medio:    #555555;
  --cinza-claro:    #f5f5f5;
  --verde-garantia: #1a5c2a;

  /* Fontes */
  --fonte-titulo:   'Cormorant Garamond', Georgia, serif;
  --fonte-corpo:    'Lato', 'Helvetica Neue', sans-serif;

  /* Espaçamentos */
  --secao-padding:  80px 0;
  --container-max:  1140px;
  --radius-card:    12px;
  --radius-btn:     8px;

  /* Sombras */
  --sombra-card:    0 4px 24px rgba(0,0,0,0.15);
  --sombra-dourada: 0 4px 20px rgba(201,168,76,0.35);
  --sombra-azul:    0 4px 20px rgba(26,42,108,0.35);

  /* Transições */
  --transicao:      all 0.3s ease;
}

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

html {
  scroll-behavior: smooth;
  font-size: 16px;
}

body {
  font-family: var(--fonte-corpo);
  color: var(--cinza-escuro);
  background-color: var(--branco);
  line-height: 1.6;
  overflow-x: hidden;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  text-decoration: none;
  color: inherit;
  transition: var(--transicao);
}

ul, ol {
  list-style: none;
}

button {
  cursor: pointer;
  border: none;
  background: none;
  font-family: var(--fonte-corpo);
}

/* --- Container Global --- */
.container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 24px;
}

/* --- Tipografia Global --- */
h1, h2, h3, h4, h5 {
  font-family: var(--fonte-titulo);
  line-height: 1.25;
  font-weight: 600;
}

h1 { font-size: clamp(2rem, 5vw, 3.5rem); }
h2 { font-size: clamp(1.6rem, 3.5vw, 2.5rem); }
h3 { font-size: clamp(1.2rem, 2.5vw, 1.6rem); }
h4 { font-size: 1.15rem; }

p {
  font-size: 1rem;
  line-height: 1.75;
  color: var(--cinza-medio);
}

/* --- Botões Globais --- */
.btn-primario {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  background: linear-gradient(135deg, var(--dourado), var(--dourado-escuro));
  color: var(--preto);
  font-family: var(--fonte-corpo);
  font-weight: 700;
  font-size: 1.05rem;
  padding: 16px 40px;
  border-radius: var(--radius-btn);
  border: none;
  box-shadow: var(--sombra-dourada);
  transition: var(--transicao);
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.btn-primario:hover {
  background: linear-gradient(135deg, var(--dourado-claro), var(--dourado));
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(201,168,76,0.5);
}

.btn-primario.btn-grande {
  font-size: 1.2rem;
  padding: 20px 56px;
}

.btn-secundario {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: transparent;
  color: var(--dourado);
  font-weight: 600;
  font-size: 0.95rem;
  padding: 12px 28px;
  border-radius: var(--radius-btn);
  border: 2px solid var(--dourado);
  transition: var(--transicao);
  cursor: pointer;
}

.btn-secundario:hover {
  background: var(--dourado);
  color: var(--preto);
}

/* --- Destaque Dourado --- */
.texto-dourado {
  color: var(--dourado);
}

.texto-branco {
  color: var(--branco);
}

/* --- Separador Ornamental --- */
.separador {
  display: flex;
  align-items: center;
  gap: 12px;
  justify-content: center;
  margin: 16px 0;
}

.separador::before,
.separador::after {
  content: '';
  height: 1px;
  width: 60px;
  background: linear-gradient(to right, transparent, var(--dourado));
}

.separador::after {
  background: linear-gradient(to left, transparent, var(--dourado));
}

.separador span {
  color: var(--dourado);
  font-size: 1.2rem;
}

/* --- Badge --- */
.badge {
  display: inline-block;
  background: var(--dourado);
  color: var(--preto);
  font-size: 0.75rem;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: 20px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.badge-azul {
  background: var(--azul-medio);
  color: var(--branco);
}

/* --- Scroll Reveal Helper --- */
[data-sr] {
  visibility: hidden;
}
/* ============================================================
   ORAÇÕES SAGRADAS — sections.css
   Estilos específicos de cada seção
   ============================================================ */

/* ============================================================
   HEADER / NAVBAR
   ============================================================ */
.header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  padding: 14px 0;
  transition: all 0.4s ease;
}

.header.sticky {
  background: rgba(15, 29, 92, 0.97);
  backdrop-filter: blur(12px);
  padding: 10px 0;
  box-shadow: 0 2px 20px rgba(0,0,0,0.3);
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
}

.header-nav {
  display: flex;
  align-items: center;
  gap: 32px;
}

.header-nav a {
  color: rgba(255,255,255,0.85);
  font-size: 0.9rem;
  font-weight: 400;
  transition: var(--transicao);
}

.header-nav a:hover {
  color: var(--dourado);
}

.header-cta {
  display: flex;
  align-items: center;
  gap: 12px;
}

.btn-acesso {
  background: transparent;
  color: var(--dourado);
  border: 1px solid var(--dourado);
  padding: 8px 18px;
  border-radius: 6px;
  font-size: 0.85rem;
  font-weight: 600;
  transition: var(--transicao);
}

/* Link "Já comprei" no nav desktop */
.nav-link-acesso {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--dourado) !important;
  font-weight: 600 !important;
  border: 1px solid rgba(201,168,76,0.4);
  padding: 6px 14px;
  border-radius: 20px;
  font-size: 0.88rem !important;
  transition: var(--transicao);
}

.nav-link-acesso:hover {
  background: rgba(201,168,76,0.1);
  border-color: var(--dourado);
}

/* ---- Dois botões iguais no header ---- */
.header-cta {
  display: flex;
  align-items: center;
  gap: 10px;
}

.header-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: var(--fonte-corpo);
  font-weight: 700;
  font-size: 0.88rem;
  padding: 0 18px;
  height: 44px;
  border-radius: 8px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  transition: var(--transicao);
  white-space: nowrap;
  cursor: pointer;
  min-width: 140px;
}

.header-btn-secundario {
  background: transparent;
  color: var(--dourado);
  border: 2px solid var(--dourado);
}

.header-btn-secundario:hover {
  background: rgba(201,168,76,0.1);
}

.header-btn-primario {
  background: linear-gradient(135deg, var(--dourado), var(--dourado-escuro));
  color: var(--preto);
  border: 2px solid transparent;
  box-shadow: 0 4px 14px rgba(201,168,76,0.35);
}

.header-btn-primario:hover {
  background: linear-gradient(135deg, var(--dourado-claro), var(--dourado));
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(201,168,76,0.5);
}

.btn-acesso:hover {
  background: var(--dourado);
  color: var(--preto);
}

/* ============================================================
   HERO
   ============================================================ */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  background: linear-gradient(135deg, var(--preto) 0%, var(--azul-escuro) 40%, var(--azul-medio) 100%);
  overflow: hidden;
  padding-top: 80px;
}

.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 20% 50%, rgba(201,168,76,0.08) 0%, transparent 60%),
    radial-gradient(ellipse at 80% 20%, rgba(201,168,76,0.06) 0%, transparent 50%);
  pointer-events: none;
}

.hero-bg-cross {
  position: absolute;
  right: -60px;
  top: 50%;
  transform: translateY(-50%);
  width: 500px;
  height: 500px;
  opacity: 0.04;
}

.hero-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
  position: relative;
  z-index: 2;
}

.hero-badge {
  margin-bottom: 20px;
}

.hero-titulo {
  font-size: clamp(2.2rem, 4.5vw, 3.6rem);
  color: var(--branco);
  line-height: 1.15;
  margin-bottom: 20px;
  font-weight: 700;
}

.hero-titulo .linha-dourada {
  color: var(--dourado);
  display: block;
}

.hero-subtitulo {
  font-size: 1.15rem;
  color: rgba(255,255,255,0.78);
  margin-bottom: 36px;
  max-width: 520px;
  line-height: 1.8;
}

.hero-stats {
  display: flex;
  gap: 32px;
  margin-bottom: 36px;
}

.hero-stat {
  text-align: center;
}

.hero-stat-num {
  display: block;
  font-family: var(--fonte-titulo);
  font-size: 2rem;
  color: var(--dourado);
  font-weight: 700;
  line-height: 1;
}

.hero-stat-desc {
  display: block;
  font-size: 0.78rem;
  color: rgba(255,255,255,0.6);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-top: 4px;
}

.hero-btns {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
}

.hero-link-acesso {
  color: rgba(255,255,255,0.6);
  font-size: 0.88rem;
  text-decoration: underline;
  transition: var(--transicao);
}

.hero-link-acesso:hover {
  color: var(--dourado);
}

.hero-imagem {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}

.hero-mockup {
  max-width: 380px;
  filter: drop-shadow(0 20px 60px rgba(201,168,76,0.25));
  animation: float 4s ease-in-out infinite;
}

@keyframes float {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-16px); }
}

.hero-anel {
  position: absolute;
  width: 440px;
  height: 440px;
  border: 1px solid rgba(201,168,76,0.2);
  border-radius: 50%;
  animation: pulsar 3s ease-in-out infinite;
}

.hero-anel:nth-child(2) {
  width: 520px;
  height: 520px;
  animation-delay: 0.5s;
  border-color: rgba(201,168,76,0.1);
}

@keyframes pulsar {
  0%, 100% { transform: scale(1); opacity: 1; }
  50%       { transform: scale(1.03); opacity: 0.7; }
}

/* ============================================================
   SEÇÃO PADRE JORGE
   ============================================================ */
.padre-jorge {
  padding: 80px 0;
  background: var(--creme);
  position: relative;
  overflow: hidden;
}

.padre-jorge::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, transparent, var(--dourado), transparent);
}

.padre-jorge-inner {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 56px;
  align-items: center;
}

.padre-foto-wrapper {
  position: relative;
  flex-shrink: 0;
}

.padre-foto {
  width: 220px;
  height: 220px;
  border-radius: 50%;
  object-fit: cover;
  border: 4px solid var(--dourado);
  box-shadow: 0 0 0 8px rgba(201,168,76,0.15);
}

.padre-foto-badge {
  position: absolute;
  bottom: 8px;
  right: -8px;
  background: var(--dourado);
  color: var(--preto);
  font-size: 0.72rem;
  font-weight: 700;
  padding: 6px 14px;
  border-radius: 20px;
  white-space: nowrap;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  box-shadow: 0 2px 10px rgba(0,0,0,0.2);
}

.padre-info-subtitulo {
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--dourado);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin-bottom: 8px;
}

.padre-info h2 {
  color: var(--azul-escuro);
  margin-bottom: 16px;
}

.padre-info p {
  font-size: 1.05rem;
  line-height: 1.8;
  color: var(--cinza-medio);
  max-width: 620px;
}

.padre-info-aspas {
  font-family: var(--fonte-titulo);
  font-size: 1.3rem;
  font-style: italic;
  color: var(--azul-escuro);
  border-left: 3px solid var(--dourado);
  padding-left: 20px;
  margin-top: 24px;
  line-height: 1.7;
}

/* ============================================================
   SEÇÃO PILARES
   ============================================================ */
.pilares {
  padding: 90px 0;
  background: linear-gradient(160deg, var(--azul-escuro) 0%, var(--azul-medio) 100%);
  position: relative;
  overflow: hidden;
}

.pilares::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at center, rgba(201,168,76,0.06) 0%, transparent 70%);
  pointer-events: none;
}

.secao-cabecalho {
  text-align: center;
  margin-bottom: 56px;
}

.secao-cabecalho .pre-titulo {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--dourado);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  margin-bottom: 10px;
}

.secao-cabecalho h2 {
  color: var(--branco);
  margin-bottom: 16px;
}

.secao-cabecalho p {
  max-width: 580px;
  margin: 0 auto;
  color: rgba(255,255,255,0.65);
  font-size: 1.05rem;
}

.pilares-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}

.pilar-card {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(201,168,76,0.25);
  border-radius: var(--radius-card);
  padding: 36px 24px;
  text-align: center;
  transition: var(--transicao);
  position: relative;
  overflow: hidden;
}

.pilar-card::before {
  content: '';
  position: absolute;
  bottom: 0; left: 0;
  width: 100%;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--dourado), transparent);
  transform: scaleX(0);
  transition: transform 0.4s ease;
}

.pilar-card:hover {
  background: rgba(255,255,255,0.09);
  border-color: rgba(201,168,76,0.5);
  transform: translateY(-6px);
  box-shadow: 0 12px 32px rgba(0,0,0,0.3), 0 0 20px rgba(201,168,76,0.1);
}

.pilar-card:hover::before {
  transform: scaleX(1);
}

.pilar-icone {
  width: 64px;
  height: 64px;
  margin: 0 auto 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(201,168,76,0.12);
  border-radius: 50%;
  border: 1px solid rgba(201,168,76,0.3);
}

.pilar-icone svg {
  width: 32px;
  height: 32px;
  fill: var(--dourado);
}

.pilar-card h3 {
  color: var(--dourado);
  font-size: 1.3rem;
  margin-bottom: 10px;
}

.pilar-card p {
  color: rgba(255,255,255,0.65);
  font-size: 0.92rem;
  line-height: 1.7;
}

/* ============================================================
   SEÇÃO CATÁLOGO
   ============================================================ */
.catalogo {
  padding: 90px 0;
  background: var(--branco);
}

.catalogo .secao-cabecalho h2 {
  color: var(--azul-escuro);
}

.catalogo .secao-cabecalho p {
  color: var(--cinza-medio);
}

.catalogo-grupo {
  margin-bottom: 56px;
}

.catalogo-grupo:last-child {
  margin-bottom: 0;
}

.catalogo-grupo-titulo {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 28px;
}

.catalogo-grupo-titulo .icone-grupo {
  width: 44px;
  height: 44px;
  background: var(--azul-medio);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.catalogo-grupo-titulo .icone-grupo svg {
  width: 22px;
  height: 22px;
  fill: var(--dourado);
}

.catalogo-grupo-titulo h3 {
  color: var(--azul-escuro);
  font-size: 1.35rem;
}

.catalogo-grupo-titulo .qtd {
  margin-left: auto;
  font-size: 0.82rem;
  color: var(--cinza-medio);
  background: var(--cinza-claro);
  padding: 4px 12px;
  border-radius: 20px;
}

.catalogo-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.catalogo-card {
  border: 1px solid #e8e8e8;
  border-radius: var(--radius-card);
  padding: 24px 20px;
  display: flex;
  align-items: flex-start;
  gap: 16px;
  transition: var(--transicao);
  background: var(--branco);
}

.catalogo-card:hover {
  border-color: var(--dourado);
  box-shadow: 0 4px 20px rgba(201,168,76,0.12);
  transform: translateY(-2px);
}

.catalogo-card-icone {
  width: 48px;
  height: 48px;
  background: linear-gradient(135deg, var(--azul-escuro), var(--azul-medio));
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.catalogo-card-icone svg {
  width: 22px;
  height: 22px;
  fill: var(--dourado);
}

.catalogo-card-num {
  font-family: var(--fonte-titulo);
  font-size: 0.8rem;
  color: var(--dourado);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  display: block;
  margin-bottom: 4px;
}

.catalogo-card h4 {
  color: var(--azul-escuro);
  font-size: 0.95rem;
  margin-bottom: 4px;
  line-height: 1.35;
}

.catalogo-card p {
  font-size: 0.82rem;
  color: var(--cinza-medio);
  line-height: 1.5;
}

/* Card especial Ritual */
.catalogo-ritual {
  grid-column: 1 / -1;
  border: 2px solid var(--dourado);
  background: linear-gradient(135deg, #fdf8ee, #fff);
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 24px;
  padding: 28px;
}

.ritual-badge-destaque {
  display: inline-block;
  background: var(--dourado);
  color: var(--preto);
  font-size: 0.7rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 8px;
}

.ritual-icone {
  width: 72px;
  height: 72px;
  background: linear-gradient(135deg, var(--azul-escuro), var(--azul-medio));
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.ritual-icone svg {
  width: 36px;
  height: 36px;
  fill: var(--dourado);
}

.ritual-subitens {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.ritual-subitem {
  background: var(--azul-escuro);
  color: var(--dourado);
  font-size: 0.75rem;
  padding: 4px 12px;
  border-radius: 20px;
}

/* ============================================================
   COMO FUNCIONA
   ============================================================ */
.como-funciona {
  padding: 90px 0;
  background: linear-gradient(160deg, var(--azul-escuro), #0d1650);
  position: relative;
  overflow: hidden;
}

.como-funciona .secao-cabecalho h2 {
  color: var(--branco);
}

.como-funciona .secao-cabecalho p {
  color: rgba(255,255,255,0.65);
}

.passos-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  position: relative;
  margin-top: 20px;
}

.passo {
  text-align: center;
  padding: 40px 32px;
  position: relative;
}

.passo::after {
  content: '→';
  position: absolute;
  right: -12px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 2rem;
  color: var(--dourado);
  opacity: 0.5;
}

.passo:last-child::after {
  display: none;
}

.passo-num {
  width: 64px;
  height: 64px;
  background: rgba(201,168,76,0.1);
  border: 2px solid var(--dourado);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
  font-family: var(--fonte-titulo);
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--dourado);
}

.passo-icone {
  width: 56px;
  height: 56px;
  margin: 0 auto 16px;
}

.passo-icone svg {
  width: 56px;
  height: 56px;
  fill: none;
  stroke: var(--dourado);
  stroke-width: 1.5;
}

.passo h3 {
  color: var(--branco);
  font-size: 1.2rem;
  margin-bottom: 10px;
}

.passo p {
  color: rgba(255,255,255,0.65);
  font-size: 0.92rem;
}

.passo-detalhe {
  margin-top: 10px;
  font-size: 0.82rem;
  color: var(--dourado);
  font-style: italic;
}

/* ============================================================
   DEPOIMENTOS
   ============================================================ */
.depoimentos {
  padding: 90px 0;
  background: var(--creme);
  position: relative;
  overflow: hidden;
}

.depoimentos::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, transparent, var(--dourado), transparent);
}

.depoimentos .secao-cabecalho h2 {
  color: var(--azul-escuro);
}

.depoimentos .secao-cabecalho p {
  color: var(--cinza-medio);
}

.depoimentos-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

.depoimento-card {
  background: var(--branco);
  border: 1px solid rgba(201,168,76,0.2);
  border-radius: var(--radius-card);
  padding: 32px 28px;
  position: relative;
  transition: var(--transicao);
}

.depoimento-card:hover {
  border-color: var(--dourado);
  box-shadow: var(--sombra-dourada);
  transform: translateY(-4px);
}

.depoimento-aspas {
  font-family: Georgia, serif;
  font-size: 4rem;
  line-height: 0.5;
  color: var(--dourado);
  opacity: 0.4;
  margin-bottom: 14px;
  display: block;
}

.depoimento-texto {
  font-style: italic;
  color: var(--cinza-escuro);
  font-size: 0.97rem;
  line-height: 1.8;
  margin-bottom: 24px;
}

.depoimento-autor {
  display: flex;
  align-items: center;
  gap: 14px;
}

.depoimento-foto {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid var(--dourado);
  flex-shrink: 0;
  background: var(--azul-escuro);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--fonte-titulo);
  color: var(--dourado);
  font-size: 1.3rem;
  font-weight: 600;
}

.depoimento-nome {
  display: block;
  font-weight: 700;
  color: var(--azul-escuro);
  font-size: 0.95rem;
}

.depoimento-local {
  display: block;
  font-size: 0.82rem;
  color: var(--cinza-medio);
}

.depoimento-estrelas {
  color: var(--dourado);
  font-size: 0.9rem;
  margin-bottom: 8px;
}

.depoimento-tema {
  display: inline-block;
  background: rgba(26,42,108,0.08);
  color: var(--azul-medio);
  font-size: 0.72rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 12px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 12px;
}

/* ============================================================
   PRICING / CONTRIBUIÇÃO
   ============================================================ */
.pricing {
  padding: 90px 0;
  background: linear-gradient(160deg, var(--preto) 0%, var(--azul-escuro) 100%);
  position: relative;
  overflow: hidden;
}

.pricing::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at center bottom, rgba(201,168,76,0.07) 0%, transparent 60%);
  pointer-events: none;
}

.pricing .secao-cabecalho h2 {
  color: var(--branco);
}

.pricing .secao-cabecalho p {
  color: rgba(255,255,255,0.65);
}

.pricing-card {
  max-width: 680px;
  margin: 0 auto;
  background: rgba(255,255,255,0.04);
  border: 2px solid var(--dourado);
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(0,0,0,0.5), 0 0 40px rgba(201,168,76,0.1);
}

.pricing-header {
  background: linear-gradient(135deg, var(--dourado-escuro), var(--dourado));
  padding: 28px 40px;
  text-align: center;
}

.pricing-header h3 {
  font-family: var(--fonte-titulo);
  font-size: 1.6rem;
  color: var(--preto);
  font-weight: 700;
}

.pricing-header p {
  color: rgba(0,0,0,0.65);
  font-size: 0.9rem;
  margin-top: 6px;
}

.pricing-body {
  padding: 36px 40px;
}

.pricing-lista {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 32px;
}

.pricing-item {
  display: flex;
  align-items: center;
  gap: 10px;
  color: rgba(255,255,255,0.85);
  font-size: 0.92rem;
}

.pricing-item i {
  color: var(--dourado);
  font-size: 0.85rem;
  flex-shrink: 0;
}

.pricing-divider {
  height: 1px;
  background: rgba(201,168,76,0.2);
  margin: 24px 0;
}

.pricing-valor {
  text-align: center;
  margin-bottom: 28px;
}

.pricing-parcelado {
  display: block;
  font-size: 2.8rem;
  font-family: var(--fonte-titulo);
  color: var(--dourado);
  font-weight: 700;
  line-height: 1;
}

.pricing-parcelado-desc {
  display: block;
  font-size: 0.85rem;
  color: rgba(255,255,255,0.55);
  margin-top: 4px;
}

.pricing-ou {
  display: flex;
  align-items: center;
  gap: 12px;
  color: rgba(255,255,255,0.35);
  font-size: 0.85rem;
  margin: 14px 0;
  justify-content: center;
}

.pricing-ou::before,
.pricing-ou::after {
  content: '';
  height: 1px;
  width: 80px;
  background: rgba(255,255,255,0.15);
}

.pricing-unico {
  display: block;
  font-size: 1.5rem;
  font-family: var(--fonte-titulo);
  color: rgba(255,255,255,0.7);
  text-align: center;
}

.pricing-unico strong {
  color: var(--branco);
}

.pricing-cta {
  width: 100%;
  font-size: 1.15rem;
  padding: 20px;
  margin-bottom: 20px;
}

.pricing-seguranca {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  flex-wrap: wrap;
}

.pricing-seguranca-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.8rem;
  color: rgba(255,255,255,0.5);
}

.pricing-seguranca-item i {
  color: var(--dourado);
}

.pricing-bonus {
  background: rgba(201,168,76,0.07);
  border: 1px solid rgba(201,168,76,0.2);
  border-radius: 10px;
  padding: 20px;
  margin: 28px 0;
}

.pricing-bonus h4 {
  color: var(--dourado);
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 12px;
}

.pricing-bonus-item {
  display: flex;
  align-items: center;
  gap: 10px;
  color: rgba(255,255,255,0.75);
  font-size: 0.88rem;
  padding: 6px 0;
}

.pricing-bonus-item i {
  color: var(--dourado);
}

/* ============================================================
   GARANTIA
   ============================================================ */
.garantia {
  padding: 70px 0;
  background: var(--creme);
}

.garantia-box {
  max-width: 780px;
  margin: 0 auto;
  background: var(--branco);
  border: 2px solid var(--verde-garantia);
  border-radius: 16px;
  padding: 44px 48px;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 36px;
  align-items: center;
  box-shadow: 0 4px 24px rgba(26,92,42,0.1);
}

.garantia-icone {
  width: 100px;
  height: 100px;
  background: var(--verde-garantia);
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  text-align: center;
}

.garantia-icone .dias {
  font-family: var(--fonte-titulo);
  font-size: 2.2rem;
  font-weight: 700;
  color: var(--branco);
  line-height: 1;
}

.garantia-icone .dias-label {
  font-size: 0.65rem;
  color: rgba(255,255,255,0.75);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.garantia-pre {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--verde-garantia);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin-bottom: 8px;
}

.garantia-info h3 {
  color: var(--cinza-escuro);
  font-size: 1.4rem;
  margin-bottom: 12px;
}

.garantia-info p {
  color: var(--cinza-medio);
  font-size: 0.97rem;
  line-height: 1.75;
}

/* ============================================================
   FAQ
   ============================================================ */
.faq {
  padding: 80px 0;
  background: var(--branco);
}

.faq .secao-cabecalho h2 {
  color: var(--azul-escuro);
}

.faq .secao-cabecalho p {
  color: var(--cinza-medio);
}

.faq-lista {
  max-width: 780px;
  margin: 0 auto;
}

.faq-item {
  border: 1px solid #e0e0e0;
  border-radius: 10px;
  margin-bottom: 12px;
  overflow: hidden;
  transition: var(--transicao);
}

.faq-item.ativo {
  border-color: var(--dourado);
  box-shadow: 0 2px 12px rgba(201,168,76,0.12);
}

.faq-pergunta {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  background: var(--branco);
  color: var(--azul-escuro);
  font-family: var(--fonte-titulo);
  font-size: 1.1rem;
  font-weight: 600;
  text-align: left;
  cursor: pointer;
  gap: 16px;
  transition: var(--transicao);
}

.faq-item.ativo .faq-pergunta {
  background: linear-gradient(90deg, #fdf8ee, var(--branco));
  color: var(--dourado-escuro);
}

.faq-icone {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1.5px solid var(--dourado);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 1.1rem;
  color: var(--dourado);
  transition: transform 0.3s ease;
}

.faq-item.ativo .faq-icone {
  transform: rotate(45deg);
  background: var(--dourado);
  color: var(--preto);
}

.faq-resposta {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease, padding 0.3s ease;
  padding: 0 24px;
}

.faq-item.ativo .faq-resposta {
  max-height: 300px;
  padding: 0 24px 20px;
}

.faq-resposta p {
  font-size: 0.97rem;
  color: var(--cinza-medio);
  line-height: 1.8;
}

/* ============================================================
   CTA FINAL
   ============================================================ */
.cta-final {
  padding: 100px 0;
  background: linear-gradient(160deg, var(--azul-escuro) 0%, var(--preto) 100%);
  text-align: center;
  position: relative;
  overflow: hidden;
}

.cta-final::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at center, rgba(201,168,76,0.08) 0%, transparent 65%);
  pointer-events: none;
}

.cta-final-inner {
  position: relative;
  z-index: 2;
}

.cta-final h2 {
  color: var(--branco);
  font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  margin-bottom: 16px;
  max-width: 680px;
  margin-left: auto;
  margin-right: auto;
}

.cta-final h2 span {
  color: var(--dourado);
}

.cta-final p {
  color: rgba(255,255,255,0.65);
  font-size: 1.1rem;
  margin-bottom: 36px;
  max-width: 520px;
  margin-left: auto;
  margin-right: auto;
}

.cta-final-btns {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 28px;
}

.cta-garantia-nota {
  color: rgba(255,255,255,0.45);
  font-size: 0.85rem;
}

.cta-garantia-nota i {
  color: var(--dourado);
  margin-right: 4px;
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer {
  background: var(--preto);
  padding: 48px 0 24px;
  border-top: 1px solid rgba(201,168,76,0.12);
}

.footer-inner {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr;
  gap: 40px;
  margin-bottom: 36px;
}

.footer-brand .logo-texto {
  font-family: var(--fonte-titulo);
  font-size: 1.5rem;
  color: var(--branco);
  font-weight: 600;
  margin-bottom: 12px;
}

.footer-brand .logo-texto span {
  color: var(--dourado);
}

.footer-brand p {
  color: rgba(255,255,255,0.45);
  font-size: 0.88rem;
  line-height: 1.75;
  max-width: 280px;
}

.footer-col h4 {
  color: var(--dourado);
  font-family: var(--fonte-corpo);
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin-bottom: 16px;
  font-weight: 700;
}

.footer-col ul li {
  margin-bottom: 10px;
}

.footer-col ul li a {
  color: rgba(255,255,255,0.5);
  font-size: 0.9rem;
  transition: var(--transicao);
}

.footer-col ul li a:hover {
  color: var(--dourado);
}

.footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.06);
  padding-top: 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
}

.footer-bottom p {
  color: rgba(255,255,255,0.3);
  font-size: 0.82rem;
}

.footer-bottom a {
  color: rgba(255,255,255,0.4);
  font-size: 0.82rem;
  transition: var(--transicao);
}

.footer-bottom a:hover {
  color: var(--dourado);
}

/* ============================================================
   FAIXA DE CONFIANÇA
   ============================================================ */
.faixa-confianca {
  background: var(--azul-escuro);
  padding: 28px 0;
  border-top: 1px solid rgba(201,168,76,0.15);
  border-bottom: 1px solid rgba(201,168,76,0.15);
}

.faixa-itens {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 48px;
  flex-wrap: wrap;
}

.faixa-item {
  display: flex;
  align-items: center;
  gap: 10px;
  color: rgba(255,255,255,0.7);
  font-size: 0.88rem;
}

.faixa-item i {
  color: var(--dourado);
  font-size: 1.1rem;
}

/* ============================================================
   SEÇÃO — JÁ COMPROU? ACESSE O APP
   ============================================================ */
.acesso-app {
  padding: 80px 0;
  background: linear-gradient(160deg, #0a1240 0%, var(--azul-escuro) 100%);
  position: relative;
  overflow: hidden;
  border-top: 3px solid var(--dourado);
  border-bottom: 3px solid var(--dourado);
}

.acesso-app::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at center top, rgba(201,168,76,0.08) 0%, transparent 60%);
  pointer-events: none;
}

/* Topo / Cabeçalho */
.acesso-app-topo {
  text-align: center;
  margin-bottom: 52px;
}

.acesso-app-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(201,168,76,0.15);
  border: 1px solid var(--dourado);
  color: var(--dourado);
  font-size: 0.88rem;
  font-weight: 700;
  padding: 8px 20px;
  border-radius: 40px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 20px;
}

.acesso-app-badge i {
  font-size: 1rem;
}

.acesso-app-titulo {
  font-size: clamp(2rem, 4vw, 2.8rem);
  color: var(--branco);
  margin-bottom: 16px;
}

.acesso-app-desc {
  max-width: 560px;
  margin: 0 auto;
  color: rgba(255,255,255,0.7);
  font-size: 1.1rem;
  line-height: 1.8;
}

/* Passos */
.acesso-passos {
  max-width: 680px;
  margin: 0 auto 48px;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.acesso-passo {
  display: flex;
  align-items: flex-start;
  gap: 24px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(201,168,76,0.2);
  border-radius: 16px;
  padding: 28px 32px;
  transition: var(--transicao);
}

.acesso-passo:hover {
  background: rgba(255,255,255,0.08);
  border-color: rgba(201,168,76,0.45);
}

.acesso-passo-num {
  width: 52px;
  height: 52px;
  background: linear-gradient(135deg, var(--dourado-escuro), var(--dourado));
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--fonte-titulo);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--preto);
  flex-shrink: 0;
}

.acesso-passo-info h3 {
  color: var(--branco);
  font-size: 1.25rem;
  margin-bottom: 8px;
}

.acesso-passo-info p {
  color: rgba(255,255,255,0.7);
  font-size: 1rem;
  line-height: 1.75;
}

.acesso-passo-info strong {
  color: var(--dourado);
}

/* Box do endereço do app */
.acesso-url {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: rgba(201,168,76,0.1);
  border: 1.5px dashed var(--dourado);
  border-radius: 10px;
  padding: 10px 18px;
  margin-top: 10px;
  font-family: 'Courier New', monospace;
  font-size: 1rem;
  font-weight: 700;
  color: var(--dourado);
  letter-spacing: 0.03em;
  word-break: break-all;
}

.acesso-url i {
  font-size: 1rem;
  flex-shrink: 0;
}

/* Seta entre passos */
.acesso-seta {
  text-align: center;
  color: var(--dourado);
  opacity: 0.5;
  font-size: 1.3rem;
  padding: 8px 0;
  line-height: 1;
}

/* Botão de Acesso Principal */
.acesso-cta-wrapper {
  text-align: center;
  margin-bottom: 44px;
}

.acesso-btn-principal {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  background: linear-gradient(135deg, var(--dourado), var(--dourado-escuro));
  color: var(--preto);
  font-family: var(--fonte-corpo);
  font-weight: 700;
  font-size: 1.25rem;
  padding: 22px 56px;
  border-radius: 14px;
  box-shadow: 0 8px 32px rgba(201,168,76,0.45);
  transition: var(--transicao);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  cursor: pointer;
  margin-bottom: 16px;
}

.acesso-btn-principal i {
  font-size: 1.4rem;
}

.acesso-btn-principal:hover {
  background: linear-gradient(135deg, var(--dourado-claro), var(--dourado));
  transform: translateY(-3px);
  box-shadow: 0 12px 40px rgba(201,168,76,0.6);
}

.acesso-dica {
  color: rgba(255,255,255,0.5);
  font-size: 0.9rem;
  margin-top: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.acesso-dica i {
  color: var(--dourado);
}

/* Box de Suporte */
.acesso-suporte {
  max-width: 680px;
  margin: 0 auto;
  display: flex;
  align-items: flex-start;
  gap: 20px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 14px;
  padding: 28px 32px;
}

.acesso-suporte-icone {
  width: 52px;
  height: 52px;
  background: rgba(201,168,76,0.1);
  border: 1px solid rgba(201,168,76,0.3);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 1.3rem;
  color: var(--dourado);
}

.acesso-suporte-titulo {
  font-weight: 700;
  color: var(--branco);
  font-size: 1.05rem;
  margin-bottom: 6px;
  line-height: 1.4;
}

.acesso-suporte-texto {
  color: rgba(255,255,255,0.6);
  font-size: 0.95rem;
  line-height: 1.7;
  margin-bottom: 12px;
}

.acesso-suporte-email {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--dourado);
  font-weight: 700;
  font-size: 0.97rem;
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: var(--transicao);
}

.acesso-suporte-email:hover {
  color: var(--dourado-claro);
}

/* ---- Responsive da seção de acesso ---- */
@media (max-width: 768px) {
  .acesso-app {
    padding: 60px 0;
  }

  .acesso-app-topo {
    margin-bottom: 36px;
  }

  .acesso-app-titulo {
    font-size: 2rem;
  }

  .acesso-app-desc {
    font-size: 1.05rem;
  }

  .acesso-passo {
    flex-direction: row;
    gap: 16px;
    padding: 22px 20px;
  }

  .acesso-passo-num {
    width: 46px;
    height: 46px;
    font-size: 1.3rem;
  }

  .acesso-passo-info h3 {
    font-size: 1.1rem;
    margin-bottom: 6px;
  }

  .acesso-passo-info p {
    font-size: 0.97rem;
  }

  .acesso-url {
    font-size: 0.92rem;
    padding: 10px 14px;
    width: 100%;
    justify-content: center;
  }

  /* Botão de acesso — máximo impacto no mobile */
  .acesso-btn-principal {
    width: 100%;
    font-size: 1.2rem;
    padding: 24px 20px;
    min-height: 72px;
    border-radius: 14px;
    gap: 12px;
    letter-spacing: 0.02em;
    /* Sombra pulsante para chamar atenção */
    animation: pulsar-botao 2.5s ease-in-out infinite;
  }

  .acesso-btn-principal i {
    font-size: 1.5rem;
  }

  @keyframes pulsar-botao {
    0%, 100% { box-shadow: 0 8px 32px rgba(201,168,76,0.45); }
    50%       { box-shadow: 0 8px 48px rgba(201,168,76,0.75); }
  }

  .acesso-dica {
    font-size: 0.9rem;
    text-align: center;
    padding: 0 8px;
  }

  .acesso-suporte {
    flex-direction: column;
    padding: 24px 20px;
    gap: 16px;
    align-items: center;
    text-align: center;
  }

  .acesso-suporte-titulo {
    font-size: 1.1rem;
  }

  .acesso-suporte-texto {
    font-size: 1rem;
  }

  .acesso-suporte-email {
    font-size: 1rem;
    justify-content: center;
  }
}
/* ============================================================
   ORAÇÕES SAGRADAS — responsive.css
   Design Mobile otimizado para público 55+ anos
   Foco: fontes grandes, botões amplos, espaçamento generoso
   ============================================================ */

/* ---- Tablet (máx 1024px) ---- */
@media (max-width: 1024px) {
  .pilares-grid {
    grid-template-columns: repeat(2, 1fr);
  }

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

  .hero-imagem .hero-anel,
  .hero-imagem .hero-anel:nth-child(2) {
    width: 320px;
    height: 320px;
  }

  .header-nav {
    display: none;
  }

  .footer-inner {
    grid-template-columns: 1fr 1fr;
  }

  .footer-brand {
    grid-column: 1 / -1;
  }
}

/* ============================================================
   MOBILE — máx 768px
   Otimizado para leitura e toque fácil (público 55+)
   ============================================================ */
@media (max-width: 768px) {

  /* --- Variáveis Mobile --- */
  :root {
    --secao-padding: 64px 0;
    /* Fontes base maiores para leitura fácil */
    --fonte-corpo-mobile: 18px;
  }

  /* --- Reset de fonte base --- */
  body {
    font-size: 18px; /* +2px base — leitura mais fácil */
    line-height: 1.8;
  }

  p {
    font-size: 1rem; /* 18px */
    line-height: 1.85;
  }

  /* ============================================================
     HEADER MOBILE
     Simplificado: logo + apenas botão principal
     ============================================================ */
  .header {
    padding: 12px 0;
    background: rgba(15, 29, 92, 0.98);
    backdrop-filter: blur(10px);
  }

  .header-inner {
    gap: 10px;
  }

  .header-nav {
    display: none;
  }

  /* Dois botões do header — iguais e bem visíveis no mobile */
  .header-cta {
    gap: 8px;
    flex: 1;
    justify-content: flex-end;
  }

  .header-btn {
    flex: 1;
    font-size: 0.78rem;
    height: 48px;
    padding: 0 10px;
    min-width: 0;
    border-radius: 8px;
    gap: 6px;
    letter-spacing: 0.02em;
  }

  .header-btn i {
    font-size: 0.9rem;
  }

  /* ============================================================
     HERO MOBILE
     ============================================================ */
  .hero {
    min-height: auto;
    padding: 88px 0 60px;
  }

  .hero-inner {
    grid-template-columns: 1fr;
    gap: 32px;
    text-align: center;
  }

  /* Imagem primeiro (impacto visual imediato) */
  .hero-imagem {
    order: -1;
  }

  .hero-mockup {
    max-width: 240px;
    margin: 0 auto;
  }

  .hero-anel,
  .hero-anel:nth-child(2) {
    display: none;
  }

  /* Badge */
  .hero-badge .badge {
    font-size: 0.85rem;
    padding: 6px 16px;
  }

  /* Título hero — fonte grande e legível */
  .hero-titulo {
    font-size: 2.1rem;
    line-height: 1.2;
    margin-bottom: 18px;
  }

  /* Subtítulo — tamanho confortável */
  .hero-subtitulo {
    font-size: 1.05rem;
    line-height: 1.85;
    margin-bottom: 28px;
  }

  /* Stats — números grandes */
  .hero-stats {
    justify-content: center;
    gap: 24px;
    margin-bottom: 32px;
  }

  .hero-stat-num {
    font-size: 2.2rem !important;
  }

  .hero-stat-desc {
    font-size: 0.85rem !important;
  }

  /* Botões Hero — largura total, altura generosa */
  .hero-btns {
    flex-direction: column;
    align-items: stretch;
    gap: 16px;
    width: 100%;
  }

  .hero-btns .btn-primario {
    width: 100%;
    font-size: 1.15rem;
    padding: 22px 24px;
    min-height: 64px;
    border-radius: 12px;
    letter-spacing: 0.03em;
  }

  .hero-link-acesso {
    font-size: 1rem;
    padding: 16px;
    display: block;
    text-align: center;
  }

  /* ============================================================
     FAIXA DE CONFIANÇA
     ============================================================ */
  .faixa-confianca {
    padding: 24px 0;
  }

  .faixa-itens {
    gap: 18px;
    flex-direction: column;
    align-items: flex-start;
    padding: 0 20px;
  }

  .faixa-item {
    font-size: 1rem;
    gap: 12px;
  }

  .faixa-item i {
    font-size: 1.25rem;
    width: 24px;
    text-align: center;
  }

  /* ============================================================
     PADRE JORGE
     ============================================================ */
  .padre-jorge {
    padding: 60px 0;
  }

  .padre-jorge-inner {
    grid-template-columns: 1fr;
    text-align: center;
    gap: 28px;
  }

  .padre-foto-wrapper {
    margin: 0 auto;
  }

  .padre-foto {
    width: 180px;
    height: 180px;
  }

  .padre-info-subtitulo {
    font-size: 0.9rem;
  }

  .padre-info h2 {
    font-size: 1.9rem;
    margin-bottom: 16px;
  }

  .padre-info p {
    font-size: 1.05rem;
    line-height: 1.85;
  }

  .padre-info-aspas {
    text-align: left;
    font-size: 1.1rem;
    line-height: 1.75;
    padding-left: 16px;
    margin-top: 20px;
  }

  /* ============================================================
     PILARES
     ============================================================ */
  .pilares {
    padding: 64px 0;
  }

  /* 1 coluna no mobile — mais fácil de ler */
  .pilares-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .pilar-card {
    padding: 28px 24px;
    display: flex;
    align-items: flex-start;
    gap: 18px;
    text-align: left;
  }

  .pilar-icone {
    margin: 0;
    flex-shrink: 0;
    width: 56px;
    height: 56px;
  }

  .pilar-icone svg {
    width: 28px;
    height: 28px;
  }

  .pilar-card h3 {
    font-size: 1.25rem;
    margin-bottom: 6px;
  }

  .pilar-card p {
    font-size: 0.97rem;
    line-height: 1.75;
    color: rgba(255,255,255,0.7);
  }

  /* Cabeçalhos de seção */
  .secao-cabecalho {
    margin-bottom: 40px;
  }

  .secao-cabecalho .pre-titulo {
    font-size: 0.9rem;
  }

  .secao-cabecalho h2 {
    font-size: 1.85rem;
    margin-bottom: 14px;
  }

  .secao-cabecalho p {
    font-size: 1.05rem;
  }

  /* ============================================================
     CATÁLOGO
     ============================================================ */
  .catalogo {
    padding: 64px 0;
  }

  .catalogo-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .catalogo-ritual {
    grid-template-columns: 1fr;
  }

  .catalogo-grupo-titulo h3 {
    font-size: 1.25rem;
  }

  .catalogo-card {
    padding: 20px 18px;
    gap: 14px;
  }

  .catalogo-card h4 {
    font-size: 1rem;
    line-height: 1.4;
  }

  .catalogo-card p {
    font-size: 0.9rem;
  }

  .catalogo-card-num {
    font-size: 0.78rem;
  }

  /* ============================================================
     COMO FUNCIONA
     ============================================================ */
  .como-funciona {
    padding: 64px 0;
  }

  .passos-grid {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .passo::after {
    display: none;
  }

  .passo {
    padding: 32px 24px;
    border-bottom: 1px solid rgba(201,168,76,0.15);
  }

  .passo:last-child {
    border-bottom: none;
  }

  .passo-num {
    width: 56px;
    height: 56px;
    font-size: 1.5rem;
  }

  .passo h3 {
    font-size: 1.3rem;
    margin-bottom: 10px;
  }

  .passo p {
    font-size: 1rem;
    line-height: 1.8;
    color: rgba(255,255,255,0.7);
  }

  .passo-detalhe {
    font-size: 0.95rem;
    margin-top: 10px;
  }

  /* ============================================================
     DEPOIMENTOS
     ============================================================ */
  .depoimentos {
    padding: 64px 0;
  }

  .depoimentos-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .depoimento-card {
    padding: 28px 24px;
  }

  .depoimento-texto {
    font-size: 1.02rem;
    line-height: 1.85;
  }

  .depoimento-nome {
    font-size: 1rem;
  }

  .depoimento-local {
    font-size: 0.9rem;
  }

  .depoimento-estrelas {
    font-size: 1rem;
  }

  /* ============================================================
     PRICING / CONTRIBUIÇÃO
     Área mais crítica — máxima clareza
     ============================================================ */
  .pricing {
    padding: 64px 0;
  }

  .pricing-card {
    border-radius: 16px;
    margin: 0 4px;
  }

  .pricing-header {
    padding: 28px 24px;
  }

  .pricing-header h3 {
    font-size: 1.35rem;
    line-height: 1.35;
  }

  .pricing-header p {
    font-size: 0.97rem;
    margin-top: 8px;
  }

  .pricing-body {
    padding: 28px 24px;
  }

  /* Lista de benefícios: 1 coluna */
  .pricing-lista {
    grid-template-columns: 1fr;
    gap: 14px;
    margin-bottom: 28px;
  }

  .pricing-item {
    font-size: 1rem;
    gap: 12px;
  }

  .pricing-item i {
    font-size: 1rem;
  }

  /* Preço grande e legível */
  .pricing-parcelado {
    font-size: 3.2rem;
  }

  .pricing-parcelado-desc {
    font-size: 0.97rem;
    margin-top: 6px;
  }

  /* Botão de compra — o mais importante */
  .pricing-cta {
    width: 100%;
    font-size: 1.2rem;
    padding: 22px 24px;
    min-height: 68px;
    border-radius: 12px;
    margin-bottom: 20px;
    letter-spacing: 0.02em;
  }

  .pricing-seguranca {
    gap: 14px;
    flex-wrap: wrap;
    justify-content: center;
  }

  .pricing-seguranca-item {
    font-size: 0.9rem;
  }

  .pricing-bonus h4 {
    font-size: 0.88rem;
  }

  .pricing-bonus-item {
    font-size: 0.95rem;
    gap: 12px;
  }

  /* ============================================================
     GARANTIA
     ============================================================ */
  .garantia {
    padding: 56px 0;
  }

  .garantia-box {
    grid-template-columns: 1fr;
    text-align: center;
    padding: 36px 24px;
    gap: 24px;
  }

  .garantia-icone {
    margin: 0 auto;
    width: 110px;
    height: 110px;
  }

  .garantia-icone .dias {
    font-size: 2.4rem;
  }

  .garantia-icone .dias-label {
    font-size: 0.7rem;
  }

  .garantia-info h3 {
    font-size: 1.5rem;
    margin-bottom: 14px;
  }

  .garantia-info p {
    font-size: 1.02rem;
    line-height: 1.85;
  }

  /* ============================================================
     FAQ
     Perguntas e respostas fáceis de ler e tocar
     ============================================================ */
  .faq {
    padding: 64px 0;
  }

  .faq-item {
    margin-bottom: 14px;
    border-radius: 12px;
  }

  /* Área de toque ampla — mínimo 60px */
  .faq-pergunta {
    font-size: 1.05rem;
    padding: 20px 20px;
    min-height: 60px;
    line-height: 1.45;
    gap: 14px;
  }

  .faq-icone {
    width: 32px;
    height: 32px;
    font-size: 1.2rem;
    flex-shrink: 0;
  }

  .faq-resposta {
    padding: 0 20px;
  }

  .faq-item.ativo .faq-resposta {
    padding: 0 20px 20px;
  }

  .faq-resposta p {
    font-size: 1rem;
    line-height: 1.85;
  }

  /* ============================================================
     CTA FINAL
     ============================================================ */
  .cta-final {
    padding: 72px 0;
  }

  .cta-final h2 {
    font-size: 1.85rem;
    line-height: 1.3;
    margin-bottom: 18px;
  }

  .cta-final p {
    font-size: 1.05rem;
    margin-bottom: 32px;
    line-height: 1.85;
  }

  .cta-final-btns {
    flex-direction: column;
    align-items: stretch;
    gap: 14px;
  }

  .cta-final-btns .btn-primario {
    width: 100%;
    font-size: 1.2rem;
    padding: 22px 24px;
    min-height: 68px;
    border-radius: 12px;
  }

  .cta-final-btns .btn-secundario {
    width: 100%;
    font-size: 1.05rem;
    padding: 18px 24px;
    min-height: 58px;
    border-radius: 12px;
  }

  .cta-garantia-nota {
    font-size: 0.95rem;
    line-height: 1.7;
    margin-top: 4px;
  }

  /* ============================================================
     FOOTER
     ============================================================ */
  .footer {
    padding: 44px 0 24px;
  }

  .footer-inner {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .footer-brand .logo-texto {
    font-size: 1.4rem;
  }

  .footer-brand p {
    font-size: 0.95rem;
    line-height: 1.8;
  }

  .footer-col h4 {
    font-size: 0.88rem;
    margin-bottom: 14px;
  }

  .footer-col ul li {
    margin-bottom: 12px;
  }

  .footer-col ul li a {
    font-size: 1rem;
    /* Área de toque maior */
    display: block;
    padding: 2px 0;
  }

  .footer-bottom {
    flex-direction: column;
    text-align: center;
    gap: 10px;
  }

  .footer-bottom p,
  .footer-bottom a {
    font-size: 0.88rem;
  }

  /* ============================================================
     BOTÕES GLOBAIS — padrão mobile
     ============================================================ */
  .btn-primario,
  .btn-primario.btn-grande {
    width: 100%;
    font-size: 1.1rem;
    padding: 20px 24px;
    min-height: 64px;
    border-radius: 12px;
    letter-spacing: 0.02em;
  }

  .btn-secundario {
    width: 100%;
    font-size: 1rem;
    padding: 16px 24px;
    min-height: 56px;
    border-radius: 12px;
  }
}

/* ============================================================
   MOBILE PEQUENO — máx 400px
   ============================================================ */
@media (max-width: 400px) {
  .container {
    padding: 0 16px;
  }

  .pilares-grid {
    grid-template-columns: 1fr;
  }

  .hero-stats {
    gap: 16px;
  }

  .hero-stat-num {
    font-size: 1.9rem !important;
  }

  .pricing-card {
    border-radius: 12px;
    margin: 0;
  }

  .hero-titulo {
    font-size: 1.85rem;
  }
}

/* ============================================================
   DESKTOP GRANDE — mín 1280px
   ============================================================ */
@media (min-width: 1280px) {
  .container {
    padding: 0 32px;
  }

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