/* =========================================================
   Simulados ANAC - CSS v5.3 (refinado, sem dark mode)
   - Botões "Cadastrar e Pagar" maiores e centralizados
   - Fonte dedicada só nos botões (mais presença)
   - Hero com mais respiro e texto mais claro
   - Plano 90 dias mega-destaque
   - Badges 2x2 no mobile
   - Menu hamburger (CSS-ready)
   ========================================================= */

/* ========== Tokens ========== */
:root{
  /* Cores principais */
  --azul:#0b3f93;
  --azul-esc:#062a62;
  --amarelo:#ffd23c;

  /* Compat antigo */
  --primary-color:#0056b3;
  --secondary-color:#007bff;
  --accent-color:#ffcc00;
  --background-color:#f8f9fa;

  /* Texto / superfícies */
  --txt:#101828;
  --txt-alt:#475569;
  --muted:#5b667a;
  --bg:#ffffff;
  --bg-soft:#f7f9ff;
  --borda:#e7eef7;

  /* Layout / efeitos */
  --container:1100px;
  --container-wide:1280px;
  --radius:12px;
  --radius-lg:16px;
  --shadow:0 10px 28px rgba(16,24,40,.08);
  --shadow-soft:0 6px 18px rgba(16,24,40,.06);

  /* Tipografia fluida */
  --fs-base:clamp(15px, .35vw + 14px, 17px);
  --fs-h1:clamp(32px, 2.2vw + 24px, 44px);
  --fs-h2:clamp(22px, 1.2vw + 18px, 30px);
  --fs-h3:clamp(18px, .9vw + 16px, 22px);

  /* Botões */
  --btn-font:"Montserrat", "Poppins", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --btn-radius:14px;
  --btn-minh:54px;            /* altura mínima maior */
  --btn-fs:clamp(16px, .6vw + 15px, 19px);
  --btn-ls:.2px;              /* letter-spacing leve */
  --btn-shadow:0 10px 20px rgba(0,0,0,.14);

  /* Espaçamentos */
  --sp-1:8px; --sp-2:12px; --sp-3:16px; --sp-4:20px; --sp-5:24px;
  --sp-6:28px; --sp-7:32px; --sp-8:40px; --sp-9:52px; --sp-10:64px;

  /* Safe-area iOS */
  --safe-b:env(safe-area-inset-bottom, 0px);
}

/* ========== Base ========== */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Helvetica, Arial, ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  font-size:var(--fs-base);
  color:var(--txt);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:var(--container);margin:0 auto;padding:0 var(--sp-3)}
.container--wide{max-width:var(--container-wide)}
section{padding:var(--sp-8) 0}
h1,h2,h3{margin:0 0 var(--sp-3);line-height:1.15}
h1{font-size:var(--fs-h1)}
h2{font-size:var(--fs-h2)}
h3{font-size:var(--fs-h3)}
p{margin:0 0 var(--sp-3);color:var(--muted)}
.micro{font-size:.92rem;color:var(--txt-alt)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* Acessibilidade */
:focus-visible{outline:3px solid #94c5ff;outline-offset:2px;border-radius:8px}
@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
}

/* ========== Grades ========== */
.grid{display:grid;gap:var(--sp-3)}
.grid--2,.grid--3,.grid--4,.grid--5{grid-template-columns:repeat(1,minmax(0,1fr))}
@media (min-width:560px){.grid--2{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (min-width:720px){.grid--3{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (min-width:960px){.grid--4{grid-template-columns:repeat(4,minmax(0,1fr))}}
@media (min-width:1280px){.grid--5{grid-template-columns:repeat(5,minmax(0,1fr))}}
.grid--auto{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}

/* ========== Cartões / superfícies ========== */
.card{
  background:#fff;border:1px solid var(--borda);border-radius:var(--radius);
  padding:var(--sp-3); box-shadow:var(--shadow-soft);
  transition:transform .18s ease, box-shadow .18s ease
}
.card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.soft{background:var(--bg-soft)}

/* ========== Navbar + Hamburger ========== */
.nav{
  position:sticky; top:0; z-index:1000; background:#fff;
  border-bottom:1px solid var(--borda); backdrop-filter:saturate(180%) blur(8px)
}
.nav__wrap{display:flex;align-items:center;justify-content:space-between;height:60px}
.nav__links{display:flex;gap:var(--sp-3);align-items:center;flex-wrap:wrap}
.nav__links a{padding:6px 8px;border-radius:8px}
.nav__links a:hover{background:#f1f5ff}

/* Toggle (checkbox + label) */
#menu-toggle{display:none}
.nav__toggle{
  display:none; width:42px;height:42px;border-radius:10px;border:1px solid var(--borda);
  align-items:center;justify-content:center;cursor:pointer
}
.nav__toggle span{display:block;width:20px;height:2px;background:#1e293b;position:relative}
.nav__toggle span::before,.nav__toggle span::after{
  content:"";position:absolute;left:0;width:20px;height:2px;background:#1e293b
}
.nav__toggle span::before{top:-6px}.nav__toggle span::after{top:6px}

/* Mobile: abre/fecha menu */
@media (max-width:920px){
  .nav__toggle{display:flex}
  .nav__links{
    position:absolute; left:0; right:0; top:60px;
    background:#fff; border-bottom:1px solid var(--borda);
    display:grid; gap:8px; padding:12px; transform-origin:top;
    transform:scaleY(0); opacity:0; pointer-events:none; transition:.18s ease;
  }
  #menu-toggle:checked ~ .nav__links{
    transform:scaleY(1); opacity:1; pointer-events:auto;
  }
}

/* Ações rápidas nav */
.btn--wpp{background:#187039;color:#fff;padding:8px 12px;border-radius:10px;font-weight:800;box-shadow:0 2px 8px rgba(37,211,102,.25)}
.btn--login{background:transparent;border:2px solid var(--azul);color:var(--azul);padding:6px 12px;border-radius:10px;font-weight:800}

/* ========== Botões (maiores e com fonte própria) ========== */
.btn{
  appearance:none;border:none;border-radius:var(--btn-radius);
  padding:16px 22px; min-height:var(--btn-minh);
  font-family:var(--btn-font);
  font-size:var(--btn-fs); font-weight:900; letter-spacing:var(--btn-ls);
  cursor:pointer; line-height:1; text-align:center;
  transition:transform .06s ease, filter .2s ease, box-shadow .2s ease
}
.btn:active{transform:translateY(1px)}
.btn--prim{
  background:var(--amarelo);color:#0e1420;box-shadow:var(--btn-shadow)
}
.btn--prim:hover{filter:brightness(.96)}
.btn--ghost{background:transparent;color:#fff;border:2px solid #fff}
.btn--ghost:hover{background:rgba(255,255,255,.14)}

/* ========== HERO (mais respiro e texto mais claro) ========== */
.hero{
  position:relative;
  background:linear-gradient(180deg,var(--azul) 0%, var(--azul-esc) 100%);
  color:#fff; text-align:center; padding:var(--sp-10) 0 var(--sp-9);
}
.hero .kicker{
  display:inline-block;background:rgba(255,255,255,.16);padding:8px 14px;
  border-radius:999px;font-weight:900;letter-spacing:.02em
}
.hero h1{
  margin:22px 0 16px;
  letter-spacing:.1px;
}
.hero p{
  margin:18px auto 0;max-width:760px;
  color:rgba(255,255,255,.98);   /* MAIS CLARO */
  line-height:1.8;               /* MAIS RESPIRO ENTRE LINHAS */
}
.hero .cta{
  display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:28px
}

/* Badges (desktop e mobile) */
.badges{
  display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin:24px 0 8px
}
.badge{
  background:#fff;color:#0e1a2a;border:1px solid rgba(0,0,0,.06);
  border-radius:999px;padding:10px 12px;font-weight:800;box-shadow:0 2px 6px rgba(0,0,0,.06)
}
/* Mobile: 2x2 certinho */
@media (max-width:540px){
  .badges{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;max-width:520px;margin-left:auto;margin-right:auto}
  .badge{justify-self:stretch;text-align:center}
}

/* ========== Depoimento ========== */
.depo{display:grid;gap:var(--sp-3)}
@media(min-width:880px){.depo{grid-template-columns:auto}}

/* ========== Tabela comparativa ========== */
.table-wrap{overflow:auto}
table{border-collapse:collapse;width:100%;min-width:720px;background:#fff;border-radius:var(--radius);overflow:hidden}
th,td{border:1px solid var(--borda);padding:12px;text-align:left}
th{background:#f2f6ff}
tbody tr:nth-child(even){background:#fcfdff}

/* ========== Planos (DESTAQUE no 90 dias + botões centrados) ========== */
.plan{
  position:relative;
  border:2px solid var(--borda);border-radius:var(--radius-lg);padding:var(--sp-4);background:#fff;
  box-shadow:var(--shadow-soft); transition:transform .18s ease, box-shadow .18s ease;
  text-align:center;
}
.plan:hover{transform:translateY(-2px); box-shadow:var(--shadow)}
.plan h3{margin-bottom:12px}
.plan__price{font-size:clamp(24px, 1.4vw + 20px, 32px);font-weight:900}
.plan__old{opacity:.55;text-decoration:line-through;font-weight:700;margin-right:6px}
.plan__tag{
  display:inline-block;background:#e7f6e7;border:1px solid #bfe3bf;color:#0b6b0b;
  border-radius:10px;padding:6px 10px;font-weight:800
}
.plan ul{
  margin:14px auto 0; padding-left:0; list-style:none; max-width:300px; text-align:left; color:var(--txt-alt)
}
.plan li{margin:7px 0}

/* Botão "Cadastrar e Pagar" CENTRALIZADO (desktop e mobile) */
.plan .btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  margin:18px auto 8px; min-width:240px; width:auto; padding:16px 22px;
  font-size:var(--btn-fs); font-family:var(--btn-font); font-weight:900;
}
@media (max-width:480px){
  .plan .btn{min-width:unset; width:100%} /* no celular ocupa toda a largura (melhor toque) */
}

/* Destaque visual do PRIMEIRO card (90 dias) — robusto */
.grid.grid--3 .plan:first-child,
.grid .plan:first-child{
  border-color:#ffd23c;
  box-shadow:0 18px 36px rgba(255,210,60,.28), var(--shadow-soft);
  transform:translateY(-3px);
}
.grid.grid--3 .plan:first-child .plan__price{font-size:clamp(26px, 1.8vw + 22px, 36px)}
.grid.grid--3 .plan:first-child .plan__tag{background:#fff2bf;border-color:#ffe58a;color:#573b00}
.grid.grid--3 .plan:first-child .btn{
  background:linear-gradient(180deg,#ffe070,#ffd23c);
  box-shadow:0 12px 22px rgba(255,210,60,.38);
}

/* Ribbon “Mais escolhido” no 90 dias */
.grid .plan:first-child::before{
  content:"MAIS ESCOLHIDO";
  position:absolute; top:-12px; right:-12px;
  background:#0b3f93; color:#fff; font-weight:900; font-size:.8rem;
  padding:7px 11px; border-radius:999px; box-shadow:0 6px 14px rgba(11,63,147,.22);
}

/* ========== Rodapé ========== */
footer{border-top:1px solid var(--borda);background:#fafcff;padding:22px 0;font-size:.95rem;text-align:center;color:#4b5563}

/* ========== Compat CSS antigo (mantido) ========== */
header.page-header{
  background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));
  text-align:center;padding:60px 20px;border-bottom-left-radius:20px;border-bottom-right-radius:20px;color:#fff
}
header.page-header h1{font-size:3rem;font-weight:700;margin:0 0 10px}
header.page-header p{font-size:1.25rem;color:#e0e0e0;margin:10px 0 0}

.beneficios{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:25px;padding:40px 20px;max-width:var(--container);margin:0 auto
}
.beneficio-item{
  background:#fff;padding:25px;border-radius:12px;box-shadow:0 4px 10px rgba(0,0,0,.06);
  transition:transform .2s ease, box-shadow .2s ease
}
.beneficio-item:hover{transform:translateY(-5px);box-shadow:0 8px 20px rgba(0,0,0,.12)}
.beneficio-item span{font-size:1.5rem}

.planos{text-align:center;padding:60px 20px;background:transparent}
.planos h2{font-size:2rem;font-weight:700;color:var(--primary-color);margin-bottom:30px}
.planos-container{display:flex;flex-wrap:wrap;justify-content:center;gap:25px;max-width:1000px;margin:0 auto}
.plano{
  background-color:var(--background-color);padding:30px;border-radius:12px;width:320px;text-align:left;
  border:3px solid transparent;transition:transform .3s ease, border-color .3s ease, box-shadow .3s ease
}
.plano:hover{border-color:var(--primary-color);transform:scale(1.03);box-shadow:0 6px 18px rgba(0,0,0,.12)}
.plano h3{font-size:1.5rem;font-weight:700;margin-bottom:12px}
.plano p{font-size:1rem;color:#555;margin-bottom:10px}
.plano-destaque{border:3px solid var(--accent-color);background:#fff8e1;box-shadow:0 4px 12px rgba(255,204,0,.25)}
.plano-destaque .selo{background:#e10600;color:#fff;font-size:.875rem;font-weight:800;padding:6px 12px;border-radius:20px;display:inline-block}
.botao-assinar{
  background:var(--accent-color);padding:12px 14px;border-radius:10px;color:#000;
  font-weight:900;text-align:center;display:block;width:100%;margin-top:15px;transition:filter .2s
}
.botao-assinar:hover,.botao-assinar:focus{filter:brightness(.94);outline:2px solid var(--secondary-color)}

/* ========== Ajustes responsivos finos ========== */
@media (max-width:920px){
  .nav__wrap{height:56px}
  .nav__links a{padding:10px 8px}
}
@media (max-width:768px){
  .hero{padding:var(--sp-9) 0 var(--sp-7)}
  header.page-header{padding:40px 15px}
  header.page-header h1{font-size:2.3rem}
  .planos h2{font-size:1.75rem}
  .plano{width:92%}
}
@media (max-width:360px){
  .btn{padding:13px 16px}
  .badge{padding:8px 10px}
}
.social-link {
  display: inline-block;
  margin: 0 10px;
  transition: transform 0.2s ease, opacity 0.2s ease;
}
.social-link:hover {
  transform: scale(1.15);
  opacity: 0.8;
}
.social svg {
  vertical-align: middle;
}
/* Container centralizado e fluido */
  .video-section {
    text-align: center;
    padding: 24px 16px;
  }
  .video-section h2 { margin-bottom: 4px; }
  .video-section p  { margin: 0 0 16px; }

  /* Wrapper responsivo com aspect-ratio moderno + fallback */
  .video-wrapper {
    --max-w: 1100px;         /* ajuste se quiser limitar a largura no desktop */
    width: 100%;
    max-width: var(--max-w);
    margin: 0 auto;
    position: relative;
    border-radius: 12px;     /* "auto" não é válido; use um valor */
    overflow: hidden;
    box-shadow: 0 8px 28px rgba(0,0,0,.12);
    background: #000;
    /* Modern browsers */
    aspect-ratio: 16 / 9;
  }
  /* Fallback para navegadores antigos (mantém 16:9) */
  .video-wrapper::before {
    content: "";
    display: block;
    padding-bottom: 56.25%;  /* 9/16 = 0.5625 */
  }
  .video-wrapper > iframe {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    border: 0;
  }

  /* Ajustes mobile */
  @media (max-width: 480px) {
    .video-section { padding: 20px 12px; }
    .video-wrapper { box-shadow: 0 6px 18px rgba(0,0,0,.14); }
  }

  /* Classe opcional para Shorts/vertical (9:16) */
  .video-vertical { aspect-ratio: 9 / 16; }
  .video-vertical::before { padding-bottom: 177.78%; } /* fallback */