/*
Theme Name: AutoCerta MVP
Description: Tema MVP com Home, Como funciona, Planos, Sobre nós e páginas dos planos com formulários.
Version: 1.6.0
Text Domain: autocerta-mvp
*/

/* =========================================
   1) PALETA & VARIÁVEIS GERAIS
========================================= */
:root{
  --ac-blue:   #1F4B8E;   /* azul principal */
  --ac-blue2:  #4F8CCF;   /* azul secundário suave */
  --ac-blue3:  #163A6B;   /* azul profundo */
  --ac-gold:   #F7D774;   /* dourado suave */

  --ac-bg:     #F6F8FB;   /* fundo geral */
  --ac-white:  #FFFFFF;
  --ac-text:   #0F172A;
  --ac-muted:  #475569;
  --ac-border: #E5EAF0;

  --radius-lg: 18px;
  --radius-md: 12px;

  --shadow-sm: 0 6px 18px rgba(15,23,42,0.06);
  --shadow-md: 0 12px 30px rgba(15,23,42,0.08);
}

/* =========================================
   2) RESET & BASE
========================================= */
*{ box-sizing:border-box; }

html,body{
  margin:0;
  padding:0;
}

body{
  background:var(--ac-bg);
  color:var(--ac-text);
  font:400 16px/1.65 Inter,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
}

a{
  text-decoration:none;
  color:inherit;
}

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

/* container padrão */
.container,
.ac-container{
  width:min(1120px, 92%);
  margin:0 auto;
  padding:0 16px;
}

/* espaçamento padrão entre seções */
section,
.ac-section{
  padding:60px 0;
}

/* =========================================
   3) TIPOGRAFIA GLOBAL
========================================= */
h1,h2,h3,h4,h5,h6{
  font-weight:700;
  color:var(--ac-text);
  line-height:1.25;
  margin:0 0 .6em;
  text-align:left;
}
h1{font-size:2.25rem;}
h2{font-size:1.8rem;}
h3{font-size:1.35rem;}
h4{font-size:1.1rem;}

p, li, span{
  font-size:1.02rem;
  color:var(--ac-muted);
  line-height:1.65;
  text-align:justify;
}
p:last-child{margin-bottom:0;}
ul,ol{padding-left:1.2rem;margin:.2rem 0 1rem;}
ul li,ol li{margin-bottom:.35rem;}

/* =========================================
   4) HEADER + MENU DESKTOP / MOBILE
========================================= */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:var(--ac-white);
  border-bottom:1px solid var(--ac-border);
}

/* linha principal: logo + menu + botão mobile */
.site-header .nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0.9rem 0;
}

/* LOGO / BRAND */
.brand{
  display:flex;
  align-items:center;
  gap:.6rem;
  font-weight:800;
  color:var(--ac-blue);
}

/* bolinha azul caso não tenha logo */
.brand .dot{
  width:10px;
  height:10px;
  border-radius:50%;
  background:var(--ac-blue2);
}

/* LOGO (desktop & mobile) */
.custom-logo{
  max-height:80px;
  width:auto;
}

@media (min-width: 1024px){
  .custom-logo{
    max-height:110px;   /* aumenta aqui se quiser mais */
  }
}

/* MENU DESKTOP */
.site-nav{
  display:flex;
  align-items:center;
}

/* ul do menu (wp_nav_menu) */
.primary-menu{
  display:flex;
  align-items:center;
  gap:1.4rem;
  list-style:none;
  margin:0;
  padding:0;
}

/* links desktop */
.primary-menu > li > a{
  font-weight:600;
  font-size:1.01rem;           /* tamanho do texto do menu */
  color:var(--ac-muted);
  padding:6px 0;
  position:relative;
}

.primary-menu > li > a:hover{
  color:var(--ac-blue);
}

/* sublinhado suave no hover (desktop) */
@media (min-width: 769px){
  .primary-menu > li > a::after{
    content:"";
    position:absolute;
    left:0;
    bottom:-2px;
    width:0;
    height:2px;
    border-radius:999px;
    background:var(--ac-blue);
    transition:width .18s ease;
  }

  .primary-menu > li > a:hover::after{
    width:100%;
  }
}

/* BOTÃO HAMBÚRGUER MOBILE */
.nav-toggle{
  display:none;
  background:transparent;
  border:0;
  cursor:pointer;
  margin-left:auto;
  padding:0;
  width:28px;
  height:22px;
  position:relative;
}

/* as 3 barrinhas */
.nav-toggle-bar{
  position:absolute;
  left:0;
  width:100%;
  height:2px;
  border-radius:999px;
  background:#111827;
  transition:transform .2s ease, opacity .2s ease;
}

/* posições corretas no estado FECHADO */
.nav-toggle-bar:nth-of-type(1){
  top:0;
}
.nav-toggle-bar:nth-of-type(2){
  top:10px;
}
.nav-toggle-bar:nth-of-type(3){
  bottom:0;
}

/* estado ABERTO: vira X certinho */
.nav-toggle.is-open .nav-toggle-bar:nth-of-type(1){
  transform:translateY(10px) rotate(45deg);
}
.nav-toggle.is-open .nav-toggle-bar:nth-of-type(2){
  opacity:0;
}
.nav-toggle.is-open .nav-toggle-bar:nth-of-type(3){
  transform:translateY(-10px) rotate(-45deg);
}

/* OVERLAY ESCURO AO ABRIR O MENU */
.nav-overlay{
  position:fixed;
  inset:0;
  background:rgba(15,23,42,0.45);
  opacity:0;
  pointer-events:none;
  transition:opacity .2s ease;
  z-index:40;
}
.nav-overlay.is-visible{
  opacity:1;
  pointer-events:auto;
}

/* MENU MOBILE */
@media (max-width: 768px){
  .nav-toggle{
    display:inline-flex;
  }

  .site-nav{
    position:absolute;
    top:100%;
    right:0;
    left:0;
    background:#ffffff;
    display:none;
    padding:12px 18px 16px;
    border-bottom:1px solid var(--ac-border);
    box-shadow:0 10px 30px rgba(15,23,42,0.18);
    z-index:45;
  }

  .site-nav.is-open{
    display:block;
  }

  .primary-menu{
    flex-direction:column;
    align-items:flex-start;
    gap:4px;
  }

  .primary-menu > li{
    width:100%;
  }

  .primary-menu > li > a{
    display:block;
    width:100%;
    padding:8px 0;
    font-size:1.05rem;
    color:var(--ac-text);
  }

  .site-header{
    position:relative;
  }
}

/* =========================================
   5) BOTÕES GLOBAIS
========================================= */
.ac-btn,
.btn,
button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:11px 18px;
  border-radius:999px;
  font-size:.98rem;
  font-weight:700;
  border:0;
  cursor:pointer;
  transition:
    transform .15s ease,
    box-shadow .15s ease,
    background .2s ease,
    color .2s ease;
}

/* variações */
.ac-btn-light{
  background:#fff;
  color:var(--ac-blue);
  border:2px solid transparent;
  box-shadow:0 8px 16px rgba(15,23,42,0.08);
}
.ac-btn-light:hover{
  background:var(--ac-gold);
  border-color:var(--ac-gold);
  color:var(--ac-text);
  transform:translateY(-1px);
}

.ac-btn-dark{
  background:transparent;
  color:#fff;
  border:2px solid #fff;
}
.ac-btn-dark:hover{
  background:#fff;
  color:var(--ac-blue);
  transform:translateY(-1px);
}

.ac-btn-outline{
  background:transparent;
  color:var(--ac-blue);
  border:1.5px solid var(--ac-blue);
}
.ac-btn-outline:hover{
  background:var(--ac-blue);
  color:#fff;
  transform:translateY(-1px);
  box-shadow:0 10px 25px rgba(31,75,142,0.30);
}

/* =========================================
   6) HERO (HOME)
========================================= */
.ac-hero{
  background:linear-gradient(135deg,var(--ac-blue) 0%, var(--ac-blue3) 55%, var(--ac-blue2) 120%);
  color:#fff;
  padding:80px 0 70px;
}
.ac-hero-grid{
  display:grid;
  grid-template-columns:minmax(0,1.25fr) minmax(0,.85fr);
  gap:2rem;
  align-items:center;
}
.ac-hero-text h1{
  color:#fff;
  line-height:1.2;
  margin-bottom:14px;
}
.ac-hero-text h1 span{
  font-size:1.05em;
  font-weight:700;
  color:var(--ac-gold);
}
.ac-hero-sub{
  color:#EAF1FF;
  max-width:560px;
}
.ac-hero-list{
  list-style:none;
  padding:0;
  margin:0 0 1rem;
}
.ac-hero-list li{
  position:relative;
  padding-left:22px;
  margin-bottom:6px;
  color:#F3F7FF;
}
.ac-hero-list li::before{
  content:"✔";
  position:absolute;
  left:0;
  top:0;
  color:var(--ac-gold);
  font-size:.9rem;
}
.ac-hero-buttons{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:10px;
}
.ac-hero-box{ 
  background:rgba(255,255,255,0.10);
  border:1px solid rgba(255,255,255,0.18);
  border-radius:var(--radius-lg);
  padding:22px;
  box-shadow:0 18px 45px rgba(15,23,42,0.25);
}
.ac-hero-box h3{
  color:#fff;
  margin:0 0 6px;
}
.ac-hero-box p{
  color:#EAF1FF;
  margin:0;
}

/* =========================================
   7) BLOCO SONHO MINI
========================================= */
.sonho-mini-section{
  background:#EEF3FA;
  padding:60px 0;
}
.sonho-mini-card{
  width:100%;
  max-width:1120px;
  margin:0 auto;
  background:#fff;
  border:1px solid var(--ac-border);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-md);
  padding:32px;
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:36px;
  align-items:start;
}
.sonho-mini-badge{
  display:inline-block;
  font-size:.75rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  font-weight:700;
  color:var(--ac-blue);
  background:#E6F0FF;
  padding:4px 10px;
  border-radius:999px;
  margin-bottom:8px;
}
.sonho-mini-text h2{
  margin-top:0;
  color:var(--ac-text);
}
.sonho-mini-text p{
  color:var(--ac-muted);
}

/* Fluent Forms dentro do mini */
.sonho-mini-form .ff-el-group{
  margin-bottom:12px;
}
.sonho-mini-form input,
.sonho-mini-form select,
.sonho-mini-form textarea{
  border-radius:10px;
  border:1px solid #D9DEE7;
  padding:9px 11px;
  font-size:.98rem;
}
.sonho-mini-form .ff_submit_btn_wrapper,
.sonho-mini-form .ff_submit_btn_wrapper .ff-btn-submit{
  width:100%;
}
.sonho-mini-form .ff_submit_btn_wrapper .ff-btn-submit{
  background:var(--ac-blue) !important;
  color:#fff !important;
  border-radius:14px !important;
  padding:12px 0 !important;
  font-size:.95rem !important;
  font-weight:800 !important;
  text-transform:uppercase;
  box-shadow:0 6px 18px rgba(31,75,142,0.25);
  border:none !important;
  transition:.25s ease;
}
.sonho-mini-form .ff_submit_btn_wrapper .ff-btn-submit:hover{
  background:var(--ac-blue3) !important;
  transform:translateY(-2px);
  box-shadow:0 10px 26px rgba(31,75,142,0.35);
}

/* =========================================
   8) COMO FUNCIONA
========================================= */
.ac-como-funciona{
  background:#fff;
  padding:70px 0 60px;
}
.ac-section-title{
  text-align:center;
  font-size:1.9rem;
  margin-bottom:28px;
  color:var(--ac-text);
}

/* Tracinho sempre centralizado */
.ac-section-title .bar{
  display:block !important;
  margin:0 auto 10px auto !important;
  text-align:center !important;
}

.ac-steps-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px;
}
.ac-step{
  background:#fff;
  border:1px solid var(--ac-border);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  padding:18px 16px;
}
.ac-step-number{
  width:34px;
  height:34px;
  border-radius:999px;
  background:var(--ac-blue);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  margin-bottom:8px;
  font-size:.9rem;
}
.ac-step h3{
  margin:0 0 6px;
  color:var(--ac-blue);
}
.ac-step p{
  margin:0;
  color:var(--ac-muted);
}

/* =========================================
   9) PLANOS
========================================= */
.ac-planos{
  background:#F3F4F6;
  padding:70px 0 60px;
}
.ac-planos-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:20px;
}
.ac-plano{
  background:#fff;
  border:1px solid var(--ac-border);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  padding:22px 18px;
  position:relative;
  display:flex;
  flex-direction:column;
  height:100%;
}
.ac-plano-etiqueta{
  position:absolute;
  top:14px;
  right:16px;
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.07em;
  padding:3px 10px;
  border-radius:999px;
  background:#E5E7EB;
  color:#374151;
  font-weight:700;
}
.ac-plano-etiqueta-primario{
  background:#DBEAFE;
  color:var(--ac-blue);
}
.ac-plano-etiqueta-avancado{
  background:#FEE2E2;
  color:#B91C1C;
}

.ac-preco{
  margin:.4rem 0 .6rem;
  font-weight:800;
  color:var(--ac-blue);
  font-size:1.25rem;
}
.ac-preco-extra{
  font-size:.88rem;
  font-weight:500;
  color:var(--ac-muted);
}

.ac-plano ul{
  list-style:none;
  padding:0;
  margin:0 0 16px;
}
.ac-plano ul li{
  padding-left:18px;
  position:relative;
  margin-bottom:6px;
}
.ac-plano ul li::before{
  content:"•";
  position:absolute;
  left:4px;
  top:0;
  color:var(--ac-blue2);
}

.ac-plano-obs{
  font-size:.92rem;
  color:#64748B;
  margin:0 0 12px;
}

/* details do plano */
.ac-note{
  background:#fff;
  border:1px solid var(--ac-border);
  border-radius:14px;
  padding:.6rem;
  margin:8px 0 12px;
}
.ac-note summary{
  cursor:pointer;
  font-weight:800;
  color:var(--ac-blue);
  list-style:none;
}
.ac-note summary::-webkit-details-marker{display:none;}
.ac-note summary:before{
  content:"+ ";
  font-weight:900;
  color:var(--ac-blue);
}
.ac-note[open] summary:before{
  content:"– ";
}
.ac-observacao{
  font-size:.9rem;
  color:#6B7280;
  margin-top:6px;
}

.ac-plano .ac-btn{
  margin-top:auto;
  align-self:flex-start;
}

/* texto do Asaas */
.ac-info-asaas{
  margin-top:14px;
  font-size:.92rem;
  color:#64748B;
  text-align:center;
}

/* =========================================
   10) DEPOIMENTOS
========================================= */
.ac-depoimentos{
  background:#fff;
  padding:70px 0 60px;
}
.ac-depo-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.ac-depo{
  background:#F9FAFB;
  border:1px solid var(--ac-border);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-sm);
  padding:18px;
}
.ac-stars{
  color:#F59E0B;
  font-size:1.1rem;
  margin-bottom:8px;
}
.ac-depo p{
  margin:0 0 10px;
}
.ac-depo h4{
  margin:0;
  font-size:.98rem;
  font-weight:700;
  color:var(--ac-text);
}

/* =========================================
   11) AVISO IMPORTANTE / DISCLAIMER
========================================= */
.ac-aviso-importante{
  background:#F7FAFF;
  padding:40px 0 50px;
  border-top:1px dashed var(--ac-border);
}
.ac-aviso-importante strong{
  display:block;
  margin-bottom:10px;
  font-size:1.05rem;
  color:var(--ac-text);
  text-align:left;
}
.ac-disclaimer-list{
  margin:0;
  padding-left:18px;
}
.ac-disclaimer-list li{
  font-size:.96rem;
  color:#566173;
  margin-bottom:6px;
  text-align:justify;
}

/* =========================================
   12) FOOTER
========================================= */
.site-footer,
.ac-footer{
  border-top:2px solid var(--ac-blue2);
  background:#0B1727;
  color:#E5E7EB;
  padding:12px 0;
  font-size:.9rem;
  margin-top:10px;
}
.site-footer .container,
.ac-footer .ac-container{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  align-items:center;
  justify-content:center;
  text-align:center;
}

/* Link de política no rodapé */
.ac-footer-legal{
  width:100%;
  text-align:center;
  padding:12px 8px;
  font-size:0.95rem;
}
.ac-footer-legal a{
  color:#9CA3AF;
  text-decoration:none;
  transition:color .2s ease;
}
.ac-footer-legal a:hover{
  color:#1F4B8E;
  text-decoration:underline;
}

/* ===============================================
   13) HERO PÁGINA DE PLANOS
=================================================== */
.ac-planos-hero{
  background:linear-gradient(135deg, var(--ac-blue), var(--ac-blue3) 55%, var(--ac-blue2) 120%);
  color:#fff;
  padding:90px 0 80px;
  margin-bottom:0;
}
.ac-planos-hero .ac-container{
  display:flex;
  justify-content:center;
}
.ac-planos-hero .ac-hero-text{
  text-align:center;
  max-width:760px;
  margin:0 auto;
}
.ac-planos-hero .ac-hero-text h1{
  color:#fff;
  margin-bottom:16px;
  font-size:2.4rem;
  line-height:1.25;
}
.ac-planos-hero .ac-hero-sub{
  color:#EAF1FF;
  max-width:680px;
  margin:0 auto;
  font-size:1.05rem;
  line-height:1.7;
  text-align:center;
}

/* Badge igual ao da home */
.ac-hero-badge{
  display:inline-block;
  background:rgba(255,255,255,0.12);
  border:1px solid rgba(255,255,255,0.25);
  padding:6px 14px;
  border-radius:999px;
  font-size:0.78rem;
  text-transform:uppercase;
  letter-spacing:.08em;
  margin-bottom:18px;
  color:#fff;
}

/* ===============================================
   14) HERO PÁGINA SOBRE
=================================================== */
.ac-sobre-hero{
  padding:90px 0 70px !important;
  background:linear-gradient(135deg,var(--ac-blue) 0%, var(--ac-blue3) 55%, var(--ac-blue2) 120%) !important;
  color:#fff !important;
}
.ac-sobre-hero .ac-container{
  max-width:1120px !important;
  display:block !important;
}
.ac-sobre-hero h1,
.ac-sobre-hero p{
  max-width:100% !important;
  text-align:left !important;
  margin-left:0 !important;
}
.ac-sobre-hero p{
  max-width:100% !important;
  color:#EAF1FF !important;
}

/* ===============================================
   15) BOTÃO EXTRA (EX: CTA WHATSAPP)
=================================================== */
.ac-info-extra{
  margin-top:20px;
  text-align:center;
}
.ac-btn-extra{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:10px 18px;
  font-size:.92rem;
  background:#22c55e;
  color:#fff;
  border-radius:999px;
  text-decoration:none;
  font-weight:600;
  box-shadow:0 4px 15px rgba(34,197,94,0.35);
  transition:all .15s ease;
}
.ac-btn-extra:hover{
  background:#16a34a;
  box-shadow:0 6px 25px rgba(34,197,94,0.45);
  transform:translateY(-2px);
}

/* =========================================
   16) RESPONSIVO GLOBAL
========================================= */
@media (max-width: 992px){
  .ac-hero-grid{grid-template-columns:1fr;}
  .sonho-mini-card{grid-template-columns:1fr;gap:22px;}
  .ac-steps-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .ac-planos-grid{grid-template-columns:1fr;}
  .ac-depo-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}

@media (max-width: 640px){
  h1{font-size:1.95rem;}
  h2{font-size:1.6rem;}
  section,
  .ac-section{padding:50px 0;}
  .ac-steps-grid{grid-template-columns:1fr;}
  .ac-depo-grid{grid-template-columns:1fr;}
}

