/* ==========================================================================
   PLANEJAR PARA LUCRAR — Turma 4
   style.css — Tokens, base e componentes (mobile-first)
   Edite cores/fontes aqui em :root. O conteúdo de texto vem dos arquivos
   .json em assets/data/ — não precisa editar este arquivo para trocar copy.
   ========================================================================== */

/* ---------- TOKENS ---------- */
:root {
  /* Cores obrigatórias da identidade visual */
  --azul-petroleo: #17394A;
  --azul-petroleo-2: #1F4456;
  --azul-escuro: #0E2332;
  --terracota: #D9783D;
  --terracota-hover: #C2682F;
  --bege-claro: #F8EEE4;
  --branco: #FFFFFF;
  --cinza-azulado: #60727C;

  /* Tons derivados (uso interno, não alteram a paleta acima) */
  --linha-clara: rgba(248, 238, 228, 0.14);
  --linha-escura: rgba(23, 57, 74, 0.12);
  --sombra: rgba(14, 35, 50, 0.28);

  /* Tipografia */
  --fonte-titulo: 'Montserrat', 'Gotham', Arial, sans-serif;
  --fonte-corpo: 'Lato', 'Open Sans', Arial, sans-serif;

  /* Escala de espaçamento */
  --space-xs: 0.5rem;
  --space-sm: 1rem;
  --space-md: 1.75rem;
  --space-lg: 3rem;
  --space-xl: 5rem;
  --space-2xl: 7rem;

  /* Layout */
  --largura-maxima: 1180px;
  --raio: 6px;
  --raio-pill: 999px;

  --transicao: 220ms ease;
}

/* ---------- RESET ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body, h1, h2, h3, h4, p, ul, ol, figure, blockquote { margin: 0; }
ul { padding: 0; list-style: none; }
img { max-width: 100%; display: block; }
button { font-family: inherit; cursor: pointer; }
a { color: inherit; text-decoration: none; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}

/* ---------- BASE ---------- */
body {
  font-family: var(--fonte-corpo);
  background: var(--azul-escuro);
  color: var(--branco);
  line-height: 1.6;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4 {
  font-family: var(--fonte-titulo);
  font-weight: 700;
  line-height: 1.18;
  letter-spacing: -0.01em;
}

.container {
  width: 100%;
  max-width: var(--largura-maxima);
  margin: 0 auto;
  padding: 0 var(--space-md);
}

.secao {
  padding: var(--space-2xl) 0;
  position: relative;
}

.secao,
.hero {
  scroll-margin-top: 5.5rem;
}

/* Fundos de seção — alternância proposital para alto contraste */
.secao--escura      { background: var(--azul-escuro); color: var(--branco); }
.secao--petroleo     { background: var(--azul-petroleo); color: var(--branco); }
.secao--bege         { background: var(--bege-claro); color: var(--azul-escuro); }

.secao--bege .eyebrow { color: var(--terracota); }
.secao--bege .cinza   { color: var(--cinza-azulado); }
.secao--escura .cinza,
.secao--petroleo .cinza { color: #AFC2CB; }

.eyebrow {
  font-family: var(--fonte-titulo);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--terracota);
  display: inline-block;
  margin-bottom: var(--space-sm);
}

.titulo-secao {
  font-size: clamp(1.7rem, 4.4vw, 2.5rem);
  max-width: 38ch;
  margin-bottom: var(--space-md);
}

.texto-lead {
  font-size: 1.1rem;
  max-width: 56ch;
  color: var(--cinza-azulado);
}
.secao--escura .texto-lead,
.secao--petroleo .texto-lead { color: #C9D6DA; }

/* ---------- BOTÕES / CTAs ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  font-family: var(--fonte-titulo);
  font-weight: 700;
  font-size: 0.95rem;
  letter-spacing: 0.01em;
  padding: 1rem 1.85rem;
  border-radius: var(--raio-pill);
  border: 2px solid transparent;
  transition: transform var(--transicao), box-shadow var(--transicao), background var(--transicao);
  white-space: normal;
  text-align: center;
}
.btn:focus-visible {
  outline: 3px solid var(--bege-claro);
  outline-offset: 3px;
}

.btn--primario {
  background: var(--terracota);
  color: var(--branco);
  box-shadow: 0 10px 26px -8px rgba(217, 120, 61, 0.55);
}
.btn--primario:hover { background: var(--terracota-hover); transform: translateY(-2px); }

.btn--secundario {
  background: transparent;
  border-color: rgba(248, 238, 228, 0.4);
  color: var(--branco);
}
.btn--secundario:hover { border-color: var(--branco); background: rgba(248, 238, 228, 0.08); }

.secao--bege .btn--secundario {
  border-color: var(--azul-petroleo);
  color: var(--azul-petroleo);
}
.secao--bege .btn--secundario:hover { background: rgba(23, 57, 74, 0.06); }

.btn--whatsapp {
  background: var(--azul-petroleo);
  color: var(--branco);
  border-color: var(--azul-petroleo);
}
.btn--whatsapp:hover { background: var(--azul-petroleo-2); }

.btn--grande { padding: 1.15rem 2.2rem; font-size: 1.02rem; }
.btn--bloco { width: 100%; }

.grupo-cta {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  margin-top: var(--space-lg);
}
.grupo-cta--linha { flex-direction: column; }

.nota-cta {
  font-size: 0.82rem;
  color: var(--cinza-azulado);
  margin-top: var(--space-xs);
  letter-spacing: 0.02em;
  max-width: max-content;
  text-align: center;
}
.secao--escura .nota-cta,
.secao--petroleo .nota-cta { color: #9FB3BB; }
.grupo-cta + .nota-cta {
  margin-left: auto;
  margin-right: auto;
}

/* ---------- ESCASSEZ / TARJA ---------- */
.tarja {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--fonte-titulo);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--terracota);
  border: 1px solid rgba(217, 120, 61, 0.5);
  border-radius: var(--raio-pill);
  padding: 0.45rem 1rem;
  margin-bottom: var(--space-md);
}

.box-escassez {
  border-left: 3px solid var(--terracota);
  background: rgba(217, 120, 61, 0.08);
  padding: var(--space-sm) var(--space-md);
  font-family: var(--fonte-titulo);
  font-weight: 700;
  font-size: 0.92rem;
  border-radius: 0 var(--raio) var(--raio) 0;
  margin: var(--space-lg) 0;
}

/* ==========================================================================
   HEADER
   ========================================================================== */
.header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  background: rgba(14, 35, 50, 0.0);
  backdrop-filter: blur(0px);
  transition: background var(--transicao), box-shadow var(--transicao), backdrop-filter var(--transicao);
  padding: 1.1rem 0;
}
.header.header--rolado {
  background: rgba(14, 35, 50, 0.92);
  backdrop-filter: blur(10px);
  box-shadow: 0 8px 24px -12px rgba(0,0,0,0.4);
  padding: 0.7rem 0;
}
.header__interno {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-md);
}
.header__logo {
  font-family: var(--fonte-titulo);
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: 0.08em;
}
.header__nav {
  position: absolute;
  top: calc(100% + 0.35rem);
  right: var(--space-md);
  display: none;
  min-width: min(260px, calc(100vw - (var(--space-md) * 2)));
  padding: 0.5rem;
  border: 1px solid rgba(248, 238, 228, 0.14);
  border-radius: var(--raio);
  background: rgba(14, 35, 50, 0.98);
  box-shadow: 0 18px 32px -18px rgba(0,0,0,0.62);
}
.header__nav.header__nav--aberta {
  display: grid;
  gap: 0.15rem;
}
.header__nav a {
  display: block;
  padding: 0.78rem 0.9rem;
  border-radius: var(--raio);
  color: #D8E2E5;
  font-family: var(--fonte-titulo);
  font-size: 0.9rem;
  font-weight: 700;
}
.header__nav a:hover,
.header__nav a:focus-visible {
  background: rgba(248, 238, 228, 0.08);
  color: var(--branco);
}
.header__menu-toggle {
  width: 44px;
  height: 44px;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 5px;
  border: 1px solid rgba(248, 238, 228, 0.18);
  border-radius: var(--raio);
  background: rgba(248, 238, 228, 0.04);
  color: var(--branco);
}
.header__menu-toggle span {
  width: 20px;
  height: 2px;
  border-radius: 2px;
  background: currentColor;
  transition: transform var(--transicao), opacity var(--transicao);
}
.header__menu-toggle[aria-expanded="true"] span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.header__menu-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.header__menu-toggle[aria-expanded="true"] span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}
.header__cta { display: none; }

/* ==========================================================================
   HERO
   ========================================================================== */
.hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  padding-top: 7rem;
  padding-bottom: var(--space-2xl);
  background:
    radial-gradient(ellipse 80% 60% at 85% 0%, rgba(23, 57, 74, 0.55), transparent 60%),
    var(--azul-escuro);
  position: relative;
  overflow: hidden;
}
.hero::after {
  content: "";
  position: absolute;
  right: -10%;
  bottom: -20%;
  width: 60%;
  height: 70%;
  background: radial-gradient(circle, rgba(217, 120, 61, 0.10), transparent 70%);
  pointer-events: none;
}
.hero__meta {
  font-size: 0.85rem;
  color: #AFC2CB;
  margin-bottom: var(--space-sm);
  letter-spacing: 0.03em;
}
.hero__headline {
  font-size: clamp(2.4rem, 8vw, 4.2rem);
  margin-bottom: var(--space-sm);
}
.hero__sub {
  font-size: clamp(1.05rem, 2.4vw, 1.3rem);
  color: #D8E2E5;
  max-width: 42ch;
  margin-bottom: var(--space-lg);
}

/* ==========================================================================
   DORES (identificação)
   ========================================================================== */
.lista-dores {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  margin: var(--space-md) 0 0;
}
.dores__destaque {
  margin-top: var(--space-lg);
}
.dores__destaque .titulo-secao {
  color: var(--branco);
  margin-bottom: 0;
}
.dores__destaque .grupo-cta {
  align-items: flex-start;
  flex-direction: column;
}
.item-dor {
  display: flex;
  gap: var(--space-sm);
  align-items: flex-start;
  padding-bottom: var(--space-md);
  border-bottom: 1px solid var(--linha-clara);
}
.item-dor:last-child { border-bottom: none; padding-bottom: 0; }
.item-dor__marca {
  flex: none;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1.5px solid rgba(217, 120, 61, 0.6);
  color: var(--terracota);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  font-weight: 700;
  margin-top: 0.1rem;
}
.item-dor__texto { font-size: 1.02rem; }

/* ==========================================================================
   PROBLEMA REAL (citação)
   ========================================================================== */
.bloco-citacao {
  max-width: 52ch;
  margin: 0 auto;
  text-align: justify;
  text-align-last: left;
}
.bloco-citacao__texto {
  font-family: var(--fonte-titulo);
  font-size: clamp(1.3rem, 3.6vw, 1.9rem);
  line-height: 1.4;
  color: var(--azul-petroleo);
}
.bloco-citacao__fecho {
  margin-top: var(--space-md);
  font-family: var(--fonte-titulo);
  font-weight: 700;
  font-size: 1.05rem;
  color: var(--terracota);
}

/* ==========================================================================
   AUTORIDADE
   ========================================================================== */
.grid-autoridade {
  display: grid;
  gap: var(--space-xl);
}
.stats-autoridade {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-sm);
  margin: var(--space-lg) 0;
  border-top: 1px solid var(--linha-clara);
  border-bottom: 1px solid var(--linha-clara);
  padding: var(--space-md) 0;
}
.stat-item { text-align: left; }
.stat-item__numero {
  font-family: var(--fonte-titulo);
  font-size: clamp(1.8rem, 5vw, 2.6rem);
  color: var(--terracota);
  display: block;
}
.stat-item__label {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #AFC2CB;
}
.autoridade__paragrafo { margin-bottom: var(--space-sm); color: #D8E2E5; max-width: 56ch; }
.autoridade__destaque {
  font-family: var(--fonte-titulo);
  font-weight: 700;
  font-size: 1.1rem;
  margin: var(--space-lg) 0;
  border-left: 3px solid var(--terracota);
  padding-left: var(--space-sm);
  max-width: 48ch;
}

/* ==========================================================================
   MÉTODO — linha do tempo (elemento de assinatura)
   ========================================================================== */
.metodo__intro { margin-bottom: var(--space-xl); }

.timeline {
  position: relative;
}
.timeline::before {
  content: "";
  position: absolute;
  left: 27px;
  top: 12px;
  bottom: 12px;
  width: 2px;
  background: linear-gradient(to bottom, var(--terracota), rgba(23, 57, 74, 0.25));
}
.etapa {
  position: relative;
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: var(--space-md);
  padding-bottom: var(--space-xl);
}
.etapa:last-child { padding-bottom: 0; }
.etapa__numero {
  position: relative;
  z-index: 1;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--azul-escuro);
  border: 2px solid var(--terracota);
  color: var(--terracota);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--fonte-titulo);
  font-weight: 700;
  font-size: 1.05rem;
  flex: none;
}
.etapa__corpo {
  background: var(--branco);
  border-radius: var(--raio);
  padding: var(--space-md);
  box-shadow: 0 18px 40px -22px var(--sombra);
}
.etapa__nome {
  color: var(--azul-escuro);
  font-size: 1.25rem;
  margin-bottom: 0.35rem;
}
.etapa__frase {
  color: var(--terracota);
  font-weight: 700;
  font-family: var(--fonte-titulo);
  font-size: 0.95rem;
  margin-bottom: var(--space-sm);
}
.etapa__pontos {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  margin-bottom: var(--space-sm);
}
.etapa__ponto {
  display: flex;
  gap: 0.6rem;
  font-size: 0.95rem;
  color: var(--azul-petroleo);
}
.etapa__ponto::before {
  content: "→";
  color: var(--terracota);
  flex: none;
  font-weight: 700;
}
.etapa__entrega {
  margin-top: var(--space-sm);
  padding-top: var(--space-sm);
  border-top: 1px dashed rgba(23, 57, 74, 0.18);
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--azul-escuro);
}
.etapa__entrega span {
  color: var(--cinza-azulado);
  font-weight: 400;
  text-transform: uppercase;
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  display: block;
  margin-bottom: 0.2rem;
}

/* ==========================================================================
   TRANSFORMAÇÃO (antes / depois)
   ========================================================================== */
.transformacao-grid {
  display: grid;
  gap: var(--space-md);
  margin-top: var(--space-lg);
}
.coluna-transf {
  border-radius: var(--raio);
  padding: var(--space-md);
}
.coluna-transf--antes {
  background: rgba(96, 114, 124, 0.12);
  border: 1px solid rgba(96, 114, 124, 0.3);
}
.coluna-transf--depois {
  background: rgba(217, 120, 61, 0.1);
  border: 1px solid rgba(217, 120, 61, 0.45);
}
.coluna-transf__label {
  font-family: var(--fonte-titulo);
  text-transform: uppercase;
  font-size: 0.75rem;
  letter-spacing: 0.1em;
  margin-bottom: var(--space-sm);
  display: block;
}
.coluna-transf--antes .coluna-transf__label { color: var(--cinza-azulado); }
.coluna-transf--depois .coluna-transf__label { color: var(--terracota); }
.coluna-transf li {
  padding: 0.5rem 0;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  font-size: 0.98rem;
}
.coluna-transf li:last-child { border-bottom: none; }

/* ==========================================================================
   PARA QUEM É
   ========================================================================== */
.lista-paraquem {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  margin: var(--space-lg) 0;
}
.item-paraquem {
  display: flex;
  gap: var(--space-sm);
  align-items: flex-start;
}
.item-paraquem__marca {
  flex: none;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--terracota);
  color: var(--branco);
  font-size: 0.75rem;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 0.15rem;
}
.rodape-secao {
  font-family: var(--fonte-titulo);
  font-weight: 700;
  color: var(--terracota);
}

.grupos-paraquem {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
  margin: var(--space-lg) 0;
}
.grupo-paraquem {
  background: rgba(248, 238, 228, 0.06);
  border-left: 3px solid var(--terracota);
  border-radius: 0 var(--raio) var(--raio) 0;
  padding: var(--space-md);
}
.grupo-paraquem__titulo {
  font-family: var(--fonte-titulo);
  font-weight: 700;
  font-size: 1.05rem;
  margin-bottom: 0.4rem;
}
.grupo-paraquem__texto {
  color: #C9D6DA;
  font-size: 0.97rem;
}

/* ==========================================================================
   PROVAS SOCIAIS
   ========================================================================== */
.grid-depoimentos {
  display: grid;
  gap: var(--space-md);
  margin: var(--space-lg) 0;
}
.depoimento {
  background: var(--branco);
  border-radius: var(--raio);
  padding: var(--space-md);
  box-shadow: 0 16px 36px -20px rgba(23, 57, 74, 0.2);
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-sm);
  align-items: start;
}
.depoimento__aspas {
  font-family: var(--fonte-titulo);
  font-size: 2rem;
  color: var(--terracota);
  line-height: 1;
  grid-column: 1;
  grid-row: 2;
  margin-top: 0.25rem;
}
.depoimento__texto {
  color: var(--azul-escuro);
  font-size: 0.98rem;
  grid-column: 1;
  grid-row: 3;
}
.depoimento__autor {
  font-family: var(--fonte-titulo);
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--azul-petroleo);
  grid-column: 1;
  grid-row: 1;
}
.depoimento__cargo {
  display: block;
  font-family: var(--fonte-corpo);
  font-weight: 400;
  color: var(--cinza-azulado);
  font-size: 0.84rem;
}
/* ==========================================================================
   AVALIAÇÕES DO GOOGLE
   ========================================================================== */
.avaliacoes-google {
  overflow: hidden;
}
.avaliacoes-google__topo {
  display: grid;
  gap: var(--space-md);
  align-items: start;
}
.avaliacoes-google__topo .texto-lead {
  color: var(--cinza-azulado);
  margin-top: var(--space-sm);
}
.avaliacoes-google__resumo {
  background: var(--branco);
  border: 1px solid var(--linha-escura);
  border-radius: var(--raio);
  padding: var(--space-md);
  box-shadow: 0 18px 38px -26px rgba(23, 57, 74, 0.42);
}
.avaliacoes-google__empresa {
  display: block;
  color: var(--azul-petroleo);
  font-family: var(--fonte-titulo);
  font-weight: 700;
  margin-bottom: 0.35rem;
}
.avaliacoes-google__nota {
  color: var(--azul-escuro);
  font-family: var(--fonte-titulo);
  font-size: 2rem;
  font-weight: 700;
  margin-right: 0.45rem;
  vertical-align: middle;
}
.avaliacoes-google__estrelas {
  color: #F4B400;
  letter-spacing: 0;
  vertical-align: middle;
  white-space: nowrap;
}
.avaliacoes-google__total {
  display: block;
  color: var(--cinza-azulado);
  font-size: 0.9rem;
  margin: 0.25rem 0 0.75rem;
}
.avaliacoes-google__link {
  display: inline-flex;
  color: var(--terracota);
  font-family: var(--fonte-titulo);
  font-weight: 700;
}
.avaliacoes-google__link:hover,
.avaliacoes-google__link:focus-visible {
  text-decoration: underline;
}
.avaliacoes-google__carrossel {
  position: relative;
  margin-top: var(--space-lg);
}
.avaliacoes-google__viewport {
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  padding: 0.35rem 0 var(--space-md);
}
.avaliacoes-google__viewport::-webkit-scrollbar {
  display: none;
}
.avaliacoes-google__trilho {
  display: flex;
  gap: 1.1rem;
}
.google-review {
  flex: 0 0 min(86vw, 340px);
  scroll-snap-align: center;
  background: var(--branco);
  border: 1px solid rgba(23, 57, 74, 0.12);
  border-radius: 8px;
  box-shadow: 0 14px 34px -24px rgba(23, 57, 74, 0.45);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.google-review--destaque {
  border-color: var(--terracota);
  box-shadow: 0 20px 50px -22px rgba(217, 120, 61, 0.58);
}
.google-review__imagem {
  background: #F6F8F9;
  display: flex;
  border-bottom: 1px solid var(--linha-escura);
}
.google-review__imagem img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
}
.google-review__conteudo {
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
  padding: var(--space-md);
  min-height: 100%;
  flex: 1;
}
.google-review__cabecalho {
  display: grid;
  grid-template-columns: 42px 1fr;
  gap: 0.75rem;
  align-items: center;
}
.google-review__avatar {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: #1A73E8;
  color: var(--branco);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: Arial, sans-serif;
  font-weight: 700;
}
.google-review__identidade {
  min-width: 0;
}
.google-review__nome {
  color: var(--azul-petroleo);
  font-family: Arial, sans-serif;
  font-size: 0.96rem;
  font-weight: 700;
  margin: 0 0 0.12rem;
}
.google-review__empresa {
  color: var(--cinza-azulado);
  font-size: 0.8rem;
  min-height: 1em;
}
.google-review__meta {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  flex-wrap: wrap;
}
.google-review__estrelas {
  color: #F4B400;
  letter-spacing: 0;
  line-height: 1;
  white-space: nowrap;
}
.google-review__data {
  color: var(--cinza-azulado);
  font-size: 0.78rem;
}
.google-review__texto {
  color: var(--azul-escuro);
  font-size: 0.92rem;
  line-height: 1.55;
}
.google-review__origem {
  margin-top: auto;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--cinza-azulado);
  font-size: 0.8rem;
  font-weight: 700;
}
.google-review__origem:hover,
.google-review__origem:focus-visible {
  color: var(--terracota);
}
.google-review__g {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--branco);
  color: #4285F4;
  font-family: Arial, sans-serif;
  font-weight: 700;
  box-shadow: 0 6px 16px -12px rgba(23, 57, 74, 0.5);
}
.avaliacoes-google__nav {
  position: absolute;
  top: 42%;
  z-index: 2;
  width: 42px;
  height: 42px;
  border: 1px solid rgba(217, 120, 61, 0.32);
  border-radius: 50%;
  background: var(--branco);
  color: var(--terracota);
  font-size: 1.75rem;
  line-height: 1;
  box-shadow: 0 14px 30px -22px rgba(23, 57, 74, 0.6);
}
.avaliacoes-google__nav--anterior {
  left: -0.3rem;
}
.avaliacoes-google__nav--proxima {
  right: -0.3rem;
}
.avaliacoes-google__nav:hover,
.avaliacoes-google__nav:focus-visible {
  background: var(--terracota);
  color: var(--branco);
}

/* ==========================================================================
   INVESTIMENTO
   ========================================================================== */
.grid-investimento {
  display: grid;
  gap: var(--space-md);
  margin: var(--space-lg) 0;
}
.cartao-preco {
  border-radius: var(--raio);
  padding: var(--space-lg) var(--space-md);
  border: 1px solid var(--linha-clara);
  background: rgba(255,255,255,0.03);
}
.cartao-preco--destaque {
  border: 2px solid var(--terracota);
  background: rgba(217, 120, 61, 0.08);
  position: relative;
}
.cartao-preco__label {
  font-family: var(--fonte-titulo);
  text-transform: uppercase;
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  color: var(--cinza-azulado);
}
.cartao-preco--destaque .cartao-preco__label { color: var(--terracota); }
.cartao-preco__valor {
  font-family: var(--fonte-titulo);
  font-size: clamp(1.8rem, 5vw, 2.4rem);
  margin: 0.4rem 0;
}
.cartao-preco__nota { color: #AFC2CB; font-size: 0.9rem; }

.comparativo-investimento {
  max-width: 56ch;
  color: #D8E2E5;
  margin-bottom: var(--space-lg);
}
.investimento__rodape {
  max-width: 52ch;
  margin: calc(var(--space-md) * -0.35) auto var(--space-lg);
  color: #D8E2E5;
  font-family: var(--fonte-titulo);
  font-weight: 700;
}

/* ==========================================================================
   FAQ
   ========================================================================== */
.lista-faq { margin-top: var(--space-lg); }
.faq-item {
  border-bottom: 1px solid rgba(23, 57, 74, 0.15);
}
.faq-item__pergunta {
  width: 100%;
  background: none;
  border: none;
  text-align: left;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-md) 0;
  font-family: var(--fonte-titulo);
  font-weight: 700;
  font-size: 1.02rem;
  color: var(--azul-escuro);
}
.faq-item__icone {
  flex: none;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1.5px solid var(--terracota);
  color: var(--terracota);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  transition: transform var(--transicao);
}
.faq-item[aria-expanded="true"] .faq-item__icone { transform: rotate(45deg); }
.faq-item__resposta {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--transicao);
  color: var(--cinza-azulado);
  font-size: 0.97rem;
}
.faq-item__resposta-interno { padding-bottom: var(--space-md); max-width: 60ch; }

/* ==========================================================================
   CTA FINAL
   ========================================================================== */
.cta-final {
  text-align: center;
  background:
    radial-gradient(ellipse 70% 70% at 50% 0%, rgba(217, 120, 61, 0.12), transparent 65%),
    var(--azul-escuro);
}
.cta-final__titulo {
  font-size: clamp(2rem, 6vw, 3rem);
  max-width: 32ch;
  margin: 0 auto var(--space-sm);
}
.cta-final__sub {
  font-size: 1.15rem;
  color: #D8E2E5;
  max-width: 36ch;
  margin: 0 auto var(--space-lg);
}
.cta-final .grupo-cta { align-items: center; }
.cta-final .tarja { margin-bottom: var(--space-lg); }

/* ==========================================================================
   FOOTER
   ========================================================================== */
.footer {
  background: #081621;
  padding: var(--space-xl) 0 calc(var(--space-xl) + 70px);
  color: #9FB3BB;
}
.footer__topo {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
  border-bottom: 1px solid rgba(255,255,255,0.08);
  padding-bottom: var(--space-lg);
  margin-bottom: var(--space-lg);
}
.footer__marca {
  font-family: var(--fonte-titulo);
  font-weight: 700;
  color: var(--branco);
  font-size: 1.05rem;
  margin-bottom: var(--space-xs);
}
.footer__ctas {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}
.footer__base {
  font-size: 0.82rem;
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}
.footer__base a:hover { color: var(--branco); }

/* ==========================================================================
   BARRA FIXA MOBILE + WHATSAPP FLUTUANTE
   ========================================================================== */
.barra-fixa-mobile {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 90;
  background: var(--azul-escuro);
  border-top: 1px solid rgba(255,255,255,0.08);
  padding: 0.7rem var(--space-md);
  display: flex;
  gap: 0.6rem;
  box-shadow: 0 -10px 24px -10px rgba(0,0,0,0.4);
}
.barra-fixa-mobile .btn { flex: 1; padding: 0.85rem 1rem; font-size: 0.85rem; }

.whatsapp-flutuante {
  position: fixed;
  right: var(--space-md);
  bottom: calc(70px + var(--space-md));
  z-index: 95;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--azul-petroleo);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 10px 26px -10px rgba(0,0,0,0.5);
  transition: transform var(--transicao);
}
.whatsapp-flutuante:hover { transform: scale(1.08); }
.whatsapp-flutuante svg { width: 26px; height: 26px; }

/* ==========================================================================
   CONTADOR (urgência com dígitos "girando")
   ========================================================================== */
.bloco-contador {
  margin: var(--space-lg) 0;
}
.contador__frase {
  font-size: 0.95rem;
  color: #C9D6DA;
  margin-bottom: var(--space-sm);
}
.contador__frase strong { color: var(--branco); }
.contador {
  display: flex;
  gap: 0.6rem;
  flex-wrap: wrap;
}
.contador__unidade {
  background: rgba(248, 238, 228, 0.06);
  border: 1px solid rgba(248, 238, 228, 0.16);
  border-radius: var(--raio);
  padding: 0.6rem 0.4rem;
  width: 68px;
  text-align: center;
  perspective: 240px;
}
.contador__numero {
  display: block;
  font-family: var(--fonte-titulo);
  font-weight: 800;
  font-size: 1.7rem;
  color: var(--terracota);
  transform-style: preserve-3d;
}
.contador__numero.girando {
  animation: girar-digito 480ms ease;
}
@keyframes girar-digito {
  0%   { transform: rotateX(0deg); opacity: 1; }
  45%  { transform: rotateX(90deg); opacity: 0.25; }
  55%  { transform: rotateX(-90deg); opacity: 0.25; }
  100% { transform: rotateX(0deg); opacity: 1; }
}
.contador__label {
  display: block;
  font-size: 0.62rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #9FB3BB;
  margin-top: 0.2rem;
}
.contador__frase-fecho {
  font-size: 0.95rem;
  color: #C9D6DA;
  margin-top: var(--space-sm);
}

/* Versão clara do contador (usado em fundos bege/petróleo, se necessário) */
.secao--bege .contador__frase,
.secao--bege .contador__frase-fecho { color: var(--cinza-azulado); }
.secao--bege .contador__unidade { background: rgba(23,57,74,0.05); border-color: rgba(23,57,74,0.14); }
.secao--bege .contador__label { color: var(--cinza-azulado); }

/* ==========================================================================
   AUTORIDADE — foto + redes sociais
   ========================================================================== */
.autoridade__foto-coluna {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}
.autoridade__foto {
  width: 100%;
  aspect-ratio: 3 / 4;
  border-radius: var(--raio);
  overflow: hidden;
  background: linear-gradient(160deg, var(--azul-petroleo), var(--azul-petroleo-2));
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  min-height: 360px;
}
.autoridade__foto img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.autoridade__foto-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.6rem;
  color: rgba(248, 238, 228, 0.55);
  font-size: 0.8rem;
  text-align: center;
  padding: var(--space-md);
}
.autoridade__foto-placeholder svg { width: 44px; height: 44px; opacity: 0.7; }

.redes-sociais {
  display: flex;
  gap: 0.6rem;
}
.rede-social {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  padding: 0.7rem 0.5rem;
  border-radius: var(--raio-pill);
  border: 1px solid rgba(248, 238, 228, 0.25);
  font-family: var(--fonte-titulo);
  font-weight: 700;
  font-size: 0.82rem;
  color: var(--branco);
  transition: background var(--transicao), border-color var(--transicao);
}
.rede-social:hover { background: rgba(248, 238, 228, 0.08); border-color: var(--branco); }
.rede-social svg { width: 16px; height: 16px; flex: none; }

/* ==========================================================================
   GARANTIA
   ========================================================================== */
.garantia__grid {
  display: grid;
  gap: var(--space-lg);
  align-items: center;
}
.selo-garantia {
  width: 168px;
  height: 168px;
  border-radius: 50%;
  border: 3px solid var(--terracota);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  background: rgba(217, 120, 61, 0.06);
  text-align: center;
  flex: none;
}
.selo-garantia__numero {
  font-family: var(--fonte-titulo);
  font-weight: 800;
  font-size: 3rem;
  color: var(--terracota);
  line-height: 1;
}
.selo-garantia__label {
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  max-width: 110px;
  color: var(--azul-petroleo);
  margin-top: 0.2rem;
}
.garantia__lista {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  margin: var(--space-md) 0 var(--space-lg);
}
.garantia__item {
  display: flex;
  gap: 0.6rem;
  align-items: flex-start;
  font-size: 0.95rem;
  color: var(--azul-petroleo);
}
.garantia__item::before {
  content: "✓";
  color: var(--terracota);
  font-weight: 700;
  flex: none;
}

/* ==========================================================================
   AVATAR DE DEPOIMENTO (foto ou iniciais)
   ========================================================================== */
.depoimento__cabeca {
  display: grid;
  gap: 0.7rem;
  justify-items: stretch;
  text-align: left;
}
.depoimento__avatar {
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 3;
  border-radius: var(--raio);
  flex: none;
  overflow: hidden;
  background: var(--azul-petroleo);
  border: 3px solid var(--branco);
  box-shadow: 0 14px 26px -18px rgba(23, 57, 74, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--branco);
  font-family: var(--fonte-titulo);
  font-weight: 700;
  font-size: 1.5rem;
}
.depoimento__avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (max-width: 420px) {
  .depoimento {
    grid-template-columns: 1fr;
    gap: var(--space-sm);
  }
  .depoimento__avatar {
    width: 100%;
    height: auto;
  }
}

/* ==========================================================================
   REVEAL (animações leves controladas por animations.js)
   ========================================================================== */
.revelar {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 700ms ease, transform 700ms ease;
}
.revelar.revelar--ativo {
  opacity: 1;
  transform: translateY(0);
}

/* Skip link de acessibilidade */
.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  background: var(--terracota);
  color: var(--branco);
  padding: 0.6rem 1rem;
  z-index: 200;
}
.skip-link:focus { left: var(--space-sm); top: var(--space-sm); }
