:root{
  --brand-bg:#013f6a;          /* fundo topo/nav (um tom abaixo do #01508a p/ contraste) */
  --brand:#01508a;             /* azul principal */
  --brand-2:#01508a;           /* secundária (mantém monocromia) */
  --brand-acc:#c19d3f;         /* dourado/acento */
  --text:#454545;              /* texto padrão */
  --muted:#6a6a6a;             /* texto secundário */
  --soft:#f6f8fb;              /* cinza muito claro para faixas */
  --white:#fff;
  --ok:#25D366;                /* WhatsApp */
  --danger:#d33b3b;
  --radius:14px;
  --shadow:0 10px 30px rgba(1,80,138,.12);
  --cf-blue: #01508a;
  --cf-gold: #c19d3f;
  --cf-text: #444444;
  --cf-soft: #f8f6ef;
}

/* Base */
body{font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:#fff}
h1,h2,h3,h4{font-family:"Noto Serif", Georgia, serif;color:#1f1f1f}

/* TEXT ALIGN */
.text-align-center{text-align:center !important}
.text-align-left{text-align:left !important}
.text-align-right{text-align:right !important}
.text-align-justify{text-align:justify !important}

@media only screen and (max-width: 600px) {
 .text-align-center{text-align:center !important}
 .text-align-left{text-align:center !important}
 .text-align-right{text-align:center !important}
 .text-align-justify{text-align:center !important}
}


.py-5{padding-top:6rem!important;padding-bottom:6rem!important}

.form-label{
	font-weight:800 !important
}

.text-content-all{
	color: var(--text) !important;
	font-size:1rem !important
}

.text-secondary{
	color: var(--bs-accordion-color) !important
}

/* Topbar / Navbar */
.topbar{background:var(--brand-bg);color:var(--white);font-size:.9rem}
.navbar{
  background:linear-gradient(0deg, rgba(255,255,255,.9), rgba(255,255,255,.98));
  backdrop-filter:saturate(150%) blur(8px);
  border-bottom:1px solid rgba(1,80,138,.08);
}
.navbar .nav-link{color:#273037;font-weight:600; margin:0 16px}
.navbar .nav-link:hover{color:var(--brand)}

/* Botões */
.btn-brand{
  background:var(--brand);
  color:#fff;border:none;border-radius:10px;padding:.9rem 1.2rem;
  box-shadow:0 8px 20px rgba(1,80,138,.22);
}
.btn-brand:hover{background:var(--brand-acc); color:#fff;}
.btn-outline-brand{
  border:2px solid var(--brand);
  color:var(--brand);border-radius:10px;padding:.8rem .9rem
}
.btn-outline-brand:hover{background:var(--brand);color:#fff}

.btn-whatsapp{
  border:2px solid #22b759; background:#22b759;
  color:#fff;border-radius:10px;padding:.8rem .9rem; box-shadow:0 10px 24px rgba(37,211,102,.45)
}
.btn-whatsapp:hover{background:#1d8f47; color:#fff}

.btn-outline-whatsapp{
  border:2px solid #22b759;
  color:#22b759;border-radius:10px;padding:.8rem .9rem
}
.btn-outline-whatsapp:hover{background:var(--brand-acc);color:#fff}

/* WhatsApp flutuante */
.floating-wpp{position:fixed;right:18px;bottom:18px;z-index:999}
.floating-wpp .btn{
  background:#22b759;color:#fff;border:none;border-radius:999px; font-weight:800; font-size:2.1rem;
  padding:0.2rem 1rem;box-shadow:0 10px 24px rgba(37,211,102,.45)
}
.floating-wpp .btn:hover{background:#1d8f47; color:#fff}

#titulo-form{
	text-align:center;
	padding:5px 25px;
	background: var(--brand-acc);
	color:#fff !important;
	border-radius:15px;
	margin-bottom:10px
}

/* Hero (com duotone azul + acento dourado) */
.hero{
  background:
    radial-gradient(1200px 500px at 80% -10%, rgba(1,80,138,.14), transparent 60%),
    radial-gradient(1000px 400px at -10% 10%, rgba(193,157,63,.12), transparent 60%),
    linear-gradient(180deg, #f7fbff 0%, #ffffff 100%);
  padding: 120px 0 64px; /* ↑ mais alto que antes */
}
.hero .card{border:none;border-radius:var(--radius);box-shadow:var(--shadow); background:#ffffff90}
.hero-badge{
  display:inline-flex;gap:.5rem;align-items:center;
  background:var(--brand-acc);border:1px solid #d6e6f4;color:#fff;
  border-radius:999px;padding:.4rem .8rem;font-weight:700;font-size:.85rem
}

/* ---------- Métricas em boxes ---------- */
.metrics-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

.metric-box {
  flex: 1 1 150px;
  min-width: 160px;
  text-align: center;
  background: #fff;
  border: 1px solid rgba(1,80,138,.12);
  border-radius: 12px;
  padding: 1.2rem .8rem;
  box-shadow: 0 8px 16px rgba(1,80,138,.08);
  transition: transform .25s ease, box-shadow .25s ease;
}

.metric-box i {
  font-size: 1.8rem;
  color: var(--brand-acc);
}

.metric-box .kpi {
  font-weight: 700;
  color: var(--brand);
  margin-top: .4rem;
}

.metric-box small {
  color: #666;
  font-size: .875rem;
}

.metric-box:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 24px rgba(1,80,138,.15);
}

/* Melhor espaçamento em telas menores */
@media (max-width: 576px){
  .metric-box { flex: 1 1 100%; }
}


/* Cards / Features */
.feature-card{
  border:1px solid #e6ecf2;border-radius:16px;padding:26px;
  transition:transform .2s, box-shadow .2s;background:#fff
}
.feature-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.feature-icon {
  width: 58px;
  height: 58px;
  border-radius: 12px;
  background: #e8f1f8;
  display: grid;
  place-items: center;
  color: var(--brand-acc);
  font-size: 2rem;
}

/* centraliza no mobile */
@media (max-width: 575.98px) {
  .feature-icon {
    margin: 0 auto 10px;        /* centro + espacinho embaixo */
  }
  .feature-card h3,
  .feature-card p {
    text-align: center;          /* opcional: centralizar textos do card */
  }
}
.feature-icon h6{
	font-weight:800 !important
}

/* Etapas */
.step{display:flex;gap:14px}
.step .num{
  width:36px;height:36px;border-radius:9px;background:#e8f1f8;
  color:var(--brand-acc);display:grid;place-items:center;font-weight:800
}

/* Formulário */
.lead-card{border:none;border-radius:16px;box-shadow:var(--shadow)}
.form-check a{color:var(--brand);text-decoration:underline dotted}

/* Faixas suaves */
#vantagens{background:var(--soft)}

/* Rodapé */
footer{background:#0e2532;color:#cfe0ea}
footer a{color:#cfe0ea;text-decoration:none}
footer a:hover{text-decoration:underline}

/* Acessibilidade */
.sr-only{position:absolute;left:-10000px;top:auto;width:1px;height:1px;overflow:hidden}


/* Seções principais normalmente usam py-5; banners/logos podem usar py-4 */
section{scroll-margin-top:90px} /* suaviza âncora com navbar sticky */

/* Dourado em detalhes/links importantes */
a.link-accent{color:var(--brand-acc)}
.badge-accent{
  background:rgba(193,157,63,.14);border:1px solid rgba(193,157,63,.25);
  color:#715b1e;border-radius:999px;padding:.3rem .6rem;font-weight:700
}

.cf-section{ background: #fff; }
  .cf-title{
    color: var(--cf-blue);
    font-weight: 800;
    letter-spacing: .2px;
  }
  .cf-subtitle{
    color: var(--cf-text);
    max-width: 760px;
    margin-left: auto; margin-right: auto;
  }

  /* Layout das etapas */
  .cf-steps{
    display: grid;
    grid-template-columns: 1fr 40px 1fr 40px 1fr 40px 1fr 40px 1fr;
    align-items: start;
    gap: 18px;
  }
  /* mobile: empilha e esconde setas */
  @media (max-width: 991.98px){
    .cf-steps{
      grid-template-columns: 1fr;
      gap: 26px;
    }
  }

  .cf-step{
    text-align: center;
    color: var(--cf-text);
  }
  .cf-icon{
    width: 120px; height: 120px;
    border-radius: 50%;
    margin: 0 auto 12px;
    display: grid; place-items: center;
    background: var(--cf-gold);
    color: #fff;
    font-size: 55px;
    position: relative;
    box-shadow: 0 6px 18px rgba(193,157,63,.25);
  }
  .cf-badge{
    position: absolute;
    right: -2px; top: -2px;
    background: var(--cf-blue);
    color:#fff;
    font-size: .85rem;
    font-weight: 700;
    padding: 4px 8px;
    border-radius: 999px;
    box-shadow: 0 2px 8px rgba(1,80,138,.25);
  }
  .cf-step-title{
    margin: 20px 0 6px;
    font-weight: 800;
    font-size: 1.3rem;
  }
  .cf-step-text{ margin:0; line-height:1.55; }

  .cf-arrow{
    align-items: center; justify-content: center;
    color: var(--cf-gold);
    font-size: 28px;
    opacity: .95;
  }