/* ============================================================
   CLIENTES POR PROPÓSITO — DESIGN SYSTEM
   CSS reutilizável para página de captura e página de vendas.
   Basta linkar este arquivo e usar as classes/variáveis abaixo.
   ============================================================ */

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

/* ---- Tokens ---- */
:root{
  /* Cores da marca */
  --azul:#2B5278;        /* primária   */
  --rosa:#C4929A;        /* secundária */
  --rosa-claro:#E8CDD1;  /* rosa legível sobre AZUL (AA: 5.46:1) */
  --rosa-escuro:#8E4A5C; /* rosa legível sobre fundo CLARO (AA: 5.1-6.4:1) */
  --off:#F7F4F1;         /* fundo      */
  --cinza:#2A2A2A;       /* texto      */
  --azul-claro:#7BA3C4;  /* acento     */

  /* Derivadas (uso interno) */
  --azul-escuro:#1f3e5c;
  --rosa-suave:#f1e2e4;
  --borda:#e3dcd5;
  --cinza-suave:#6b6660;
  --branco:#ffffff;
  --ok:#3f7d5a;

  /* Tipografia */
  --fonte-titulo:'Cormorant Garamond', Georgia, serif;
  --fonte-corpo:'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  /* Escala / ritmo */
  --container:1080px;
  --container-estreito:720px;
  --raio:14px;
  --raio-pill:999px;
  --sombra:0 8px 30px rgba(43,82,120,.10);
  --sombra-suave:0 2px 14px rgba(43,82,120,.07);
  --transicao:.18s ease;

  /* Espaçamentos verticais de seção */
  --secao-y:clamp(48px, 8vw, 104px);
}

/* ---- Reset enxuto ---- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--off);
  color:var(--cinza);
  font-family:var(--fonte-corpo);
  font-size:17px;
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--azul);text-decoration:none}

/* ---- Tipografia ---- */
h1,h2,h3,.titulo{
  font-family:var(--fonte-titulo);
  color:var(--azul);
  font-weight:600;
  line-height:1.12;
  margin:0 0 .5em;
  letter-spacing:.2px;
}
h1,.h1{font-size:2.8rem;font-size:clamp(2.2rem, 5.2vw, 3.6rem);font-weight:600}
h2,.h2{font-size:2.2rem;font-size:clamp(1.8rem, 4vw, 2.7rem)}
h3,.h3{font-size:1.5rem;font-size:clamp(1.3rem, 2.6vw, 1.7rem)}
.sobrescrito{           /* pequeno rótulo acima dos títulos */
  font-family:var(--fonte-corpo);
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--rosa-escuro);   /* rosa escuro: legível em qualquer fundo claro */
  margin:0 0 .8em;
}
.lead{font-size:1.2rem;font-size:clamp(1.05rem,2.2vw,1.3rem);color:var(--cinza);line-height:1.6}
p{margin:0 0 1.1em}
strong,b{font-weight:600}
em{font-style:italic}

/* ---- Logo oficial (arquivos PNG na pasta /marca) ----
   Use /marca/LOGO Clientes por Propósito.png            (sobre fundo claro)
   Use /marca/LOGO NEGATIVA Clientes por Propósito.png   (sobre fundo azul)
   Qualquer novo tamanho/formato deve ser derivado desses arquivos. */
.logo{display:block;width:auto;height:auto;max-width:340px}
.logo-sm{max-width:200px}
.logo-lg{max-width:460px}

/* ---- Layout ---- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:22px}
.container.estreito{max-width:var(--container-estreito)}
.secao{padding-block:var(--secao-y)}
.secao.azul{background:var(--azul);color:var(--off)}
/* Blindagem de contraste: TODO texto sobre fundo azul fica claro (off-white),
   mesmo componentes com cor escura própria. IMPORTANTE: links de botão (.btn)
   são EXCLUÍDOS — eles têm cores próprias e não podem herdar off-white. */
.secao.azul,
.secao.azul h1,.secao.azul h2,.secao.azul h3,
.secao.azul p,.secao.azul .lead,.secao.azul li,
.secao.azul .sobrescrito,.secao.azul a:not(.btn),
.secao.azul strong,.secao.azul em{color:var(--off)}
.secao.azul .sobrescrito{color:var(--rosa-claro)} /* rótulo em rosa claro: 5.46:1 sobre azul (AA) */
.secao.azul a:not(.btn){text-decoration:underline}
/* Botões usados sobre fundo azul: garantir texto visível */
.secao.azul .btn-secundario{color:var(--off);border-color:var(--off)}
.secao.azul .btn-secundario:hover{background:var(--off);color:var(--azul)}
/* EXCEÇÃO: um .card (superfície clara) dentro de seção azul volta ao texto escuro
   normal — senão o conteúdo do card herda off-white e some sobre o fundo branco. */
.secao.azul .card,
.secao.azul .card p,.secao.azul .card li,.secao.azul .card label,
.secao.azul .card strong,.secao.azul .card em,.secao.azul .card .lead{color:var(--cinza)}
.secao.azul .card h1,.secao.azul .card h2,.secao.azul .card h3{color:var(--azul)}
.secao.azul .card .sobrescrito{color:var(--rosa-escuro)}
.secao.azul .card a:not(.btn){color:var(--azul);text-decoration:underline}
.secao.creme{background:var(--branco)}
.secao.rosa{background:var(--rosa-suave)}
.centro{text-align:center}
.medido{max-width:62ch;margin-inline:auto}    /* largura de leitura confortável */

/* ---- Botões / CTA ---- */
.btn{
  display:inline-block;
  font-family:var(--fonte-corpo);
  font-weight:600;
  font-size:1.02rem;
  line-height:1.2;
  text-align:center;
  padding:16px 30px;
  border-radius:var(--raio-pill);
  border:2px solid transparent;
  cursor:pointer;
  transition:var(--transicao);
}
.btn-primario{background:var(--azul);color:#fff}
.btn-primario:hover{background:var(--azul-escuro);transform:translateY(-1px);box-shadow:var(--sombra)}
.btn-secundario{background:transparent;color:var(--azul);border-color:var(--azul)}
.btn-secundario:hover{background:var(--azul);color:#fff}
.btn-claro{background:var(--off);color:var(--azul)}   /* para usar sobre fundo azul */
.btn-claro:hover{background:#fff;transform:translateY(-1px)}
.btn-bloco{display:block;width:100%}
.btn-grande{font-size:1.12rem;padding:19px 38px}

/* ---- Cartões ---- */
.card{
  background:var(--branco);
  border:1px solid var(--borda);
  border-radius:var(--raio);
  padding:26px 28px;
  box-shadow:var(--sombra-suave);
}
.card.destaque{border-color:var(--azul-claro);box-shadow:var(--sombra)}

/* Grade simples e responsiva */
.grade{display:grid;gap:20px}
.grade-2{grid-template-columns:repeat(2,1fr)}
.grade-3{grid-template-columns:repeat(3,1fr)}
@media (max-width:760px){
  .grade-2,.grade-3{grid-template-columns:1fr}
}

/* ---- Listas com check (benefícios) ---- */
.lista-check{list-style:none;margin:0;padding:0}
.lista-check li{position:relative;padding-left:34px;margin-bottom:14px;line-height:1.5}
.lista-check li::before{
  content:"";position:absolute;left:0;top:2px;width:22px;height:22px;border-radius:50%;
  background:var(--azul);          /* círculo azul: tick branco lê em 8:1 */
}
.lista-check li::after{
  content:"";position:absolute;left:7px;top:7px;width:6px;height:11px;
  border:solid #fff;border-width:0 2.5px 2.5px 0;transform:rotate(45deg);
}
/* Sobre fundo azul: círculo off-white com tick azul (mantém contraste forte) */
.secao.azul .lista-check li::before{background:var(--off)}
.secao.azul .lista-check li::after{border-color:var(--azul)}

/* ---- Caixa de oferta / preço ---- */
.preco-antigo{color:var(--cinza-suave);text-decoration:line-through;font-size:1.1rem}
.preco-atual{font-family:var(--fonte-titulo);font-weight:600;color:var(--azul);font-size:3rem;font-size:clamp(2.6rem,6vw,3.6rem);line-height:1}
.secao.azul .preco-atual{color:var(--off)}
.parcelas{color:var(--cinza-suave);font-size:1rem;margin-top:6px}
.selo{
  display:inline-block;background:var(--rosa-suave);color:var(--azul);
  font-weight:600;font-size:.82rem;letter-spacing:.04em;
  padding:7px 16px;border-radius:var(--raio-pill);
}

/* ---- Formulário (página de captura) ---- */
.form-campo{margin-bottom:14px}
.form-campo label{display:block;font-size:.84rem;font-weight:600;color:var(--cinza-suave);margin-bottom:6px}
.form-campo input{
  width:100%;font-family:var(--fonte-corpo);font-size:1rem;color:var(--cinza);
  background:#fff;border:1px solid var(--borda);border-radius:10px;padding:14px 16px;
  transition:var(--transicao);
}
.form-campo input:focus{outline:none;border-color:var(--azul-claro);box-shadow:0 0 0 3px rgba(123,163,196,.25)}
.consentimento{display:flex;gap:10px;align-items:flex-start;font-size:.82rem;color:var(--cinza-suave);margin:8px 0 16px}
.consentimento input{margin-top:3px}

/* ---- Divisor / urgência textual ---- */
.divisor{height:1px;background:var(--borda);border:0;margin:0}
.aviso-urgencia{
  background:var(--rosa-suave);border:1px dashed var(--rosa);border-radius:var(--raio);
  padding:16px 20px;text-align:center;font-weight:500;color:var(--azul);
}

/* ---- FAQ (detalhes nativos) ---- */
.faq details{border-bottom:1px solid var(--borda);padding:6px 0}
.faq summary{cursor:pointer;list-style:none;font-weight:600;color:var(--azul);
  font-size:1.08rem;padding:14px 30px 14px 0;position:relative}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:4px;top:12px;font-size:1.5rem;color:var(--azul-claro);transition:var(--transicao)}
.faq details[open] summary::after{content:"–"}
.faq details p{padding:0 0 16px;color:var(--cinza);margin:0}

/* ---- Espaço reservado de prova social ---- */
.prova-placeholder{
  border:2px dashed var(--borda);border-radius:var(--raio);
  padding:40px 24px;text-align:center;color:var(--cinza-suave);font-style:italic;
}

/* ---- Utilitários ---- */
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:28px}.mt-4{margin-top:44px}
.mb-2{margin-bottom:16px}.mb-3{margin-bottom:28px}
.txt-rosa{color:var(--rosa)}.txt-azul{color:var(--azul)}
.fundo-off{background:var(--off)}
.sombra{box-shadow:var(--sombra)}

/* ---- Acessibilidade ---- */
:focus-visible{outline:3px solid var(--azul-claro);outline-offset:2px}
@media (prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto!important}}
