/* ================== TOKENS ================== */
:root{
  --secondary:#172A3A;

  --ink:#1f2226;
  --muted:#5f6672;

  --bg-1:#F5F5F5;
  --bg-2:#E5E1D8;

  --card:#ffffff;
  --card-border:#eee;

  --shadow-1:0 10px 24px rgba(10,12,28,.12);
  --shadow-2:0 22px 48px rgba(10,12,28,.22);
}

/* ================== BASE ================== */
*{box-sizing:border-box}
html,body{height:100%}
html.no-js .js-only{display:none}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--ink);
  background:
    radial-gradient(1200px 520px at 50% -160px, var(--bg-2), transparent 70%),
    linear-gradient(180deg, var(--bg-1), #ffffff 30%, var(--bg-1) 100%);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
.container{width:min(1100px,92%);margin:0 auto}
.section{padding:32px 0}
.muted{color:var(--muted)}

/* ================== HEADER / NAV ================== */
.site-header{
  position:sticky; top:0; z-index:950; /* entre backdrop e painel */
  background:#ffffffE6;
  backdrop-filter:saturate(1.2) blur(6px);
  border-bottom:1px solid #ececec;
  box-shadow:0 6px 22px rgba(0,0,0,.03);
}
.header__wrap{
  height:72px;
  display:flex; align-items:center; justify-content:space-between;
}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.brand__badge{
  display:grid;place-items:center;
  width:34px;height:34px;border-radius:10px;
  background:linear-gradient(180deg,var(--brand-2),var(--brand));
  color:#fff;font-weight:800;
}
.brand__text{font-weight:700;color:#1f2226}

.nav{display:flex;align-items:center;gap:16px;position:relative}
.nav__toggle{display:none;border:0;background:#fff;font-size:22px;width:40px;height:40px;border-radius:12px;box-shadow:0 8px 18px rgba(10,12,28,.08)}
.nav__list{display:flex;gap:16px;list-style:none;margin:0;padding:0;align-items:center}
.nav-link{
  padding:8px 12px;border-radius:10px;text-decoration:none;
  color:#2d2f33;font-weight:500;transition:background .18s,color .18s
}
.nav-link:hover{background:var(--bg-2);color:#14191e}
.nav-link.is-active{
  color:#fff;
  background:linear-gradient(180deg,var(--brand-2),var(--brand));
  box-shadow:0 10px 24px rgba(68,13,15,.28);
}

/* Botões do header */
.btn{
  display:inline-flex;align-items:center;gap:8px;border-radius:12px;
  padding:10px 14px;text-decoration:none;font-weight:700;
  transition:transform .18s,box-shadow .18s
}
.btn--primary{
  background:linear-gradient(180deg,var(--brand-2),var(--brand));color:#fff;
  box-shadow:0 10px 24px rgba(68,13,15,.28)
}

/* ================== HERO ================== */
.hero-areas{
  text-align:center;
  padding:64px 0 26px;
}
.hero-title{
  margin:0 0 8px;
  color:var(--brand);
  font-weight:800; letter-spacing:-.02em;
  font-size:clamp(34px,6vw,60px);
}
.hero-lead{color:#5d646e;font-weight:500;margin:0}

/* ================== CARDS ================== */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.service-card{
  background:var(--card);
  border:1px solid var(--card-border);
  border-radius:20px;
  box-shadow:var(--shadow-1);
  padding:24px 24px 22px;
}
.svc-head{display:flex;gap:16px;align-items:flex-start;margin-bottom:10px}
.svc-icon{
  display:grid;place-items:center;flex:0 0 56px;width:56px;height:56px;border-radius:16px;
  background:#f0e9e4;color:var(--brand);font-size:28px;
  box-shadow:inset 0 0 0 1px rgba(68,13,15,.10);
}
.svc-title{margin:0;color:#1f2733;font-size:22px;font-weight:800}
.svc-desc{margin:6px 0 0;color:#5f6672}
.svc-body h4{margin:12px 0 8px;font-size:14px;color:#2d2d2d;font-weight:700}
.svc-list{margin:0;padding:0 0 0 18px;color:#4e5661;display:grid;gap:9px}
.svc-list li::marker{color:var(--brand)}

/* ================== CTA ================== */
.cta{
  margin-top:26px;
  color:#fff; text-align:center;
  padding:58px 0;
  background:
    radial-gradient(1000px 260px at 50% 0, rgba(255,255,255,.14), transparent),
    linear-gradient(180deg, var(--brand-2), var(--brand));
}
.cta-title{
  margin:0 0 8px; font-weight:800; letter-spacing:-.02em;
  font-size:clamp(28px,5vw,48px);
}
.cta-lead{margin:0;opacity:.98}

.site-footer{
  background:var(--secondary);
  color:#fff;
  padding:36px 0 44px;
}
.footer__grid{
  display:grid;
  grid-template-columns:1.4fr .9fr 1.3fr .8fr;
  gap:28px;
  align-items:flex-start;
}
.brand--invert{display:flex;align-items:center;gap:10px;text-decoration:none}
.brand--invert .brand-badge{
  display:inline-grid;place-items:center;
  width:34px;height:34px;border-radius:10px;
  background:linear-gradient(180deg,#ffffff,var(--bg-2));
  color:var(--brand);
  font-weight:800;
}
.brand--invert .brand-name{color:#fff;font-weight:700}
.muted{opacity:.92}

.footer__title{margin:0 0 10px;font-size:15px;letter-spacing:.3px}
.footer__list{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.footer__list li{display:flex;gap:8px;align-items:flex-start;line-height:1.5}
.footer__list a{color:#fff;opacity:.9;text-decoration:none;transition:opacity .18s ease}
.footer__list a:hover{opacity:1;text-decoration:underline}
.footer__copy{
  border-top:1px solid rgba(255,255,255,.12);
  margin-top:24px;padding-top:18px;
  text-align:center;font-size:14px;opacity:.92;
}

@media (max-width:1024px){
  .footer__grid{grid-template-columns:repeat(2,1fr);gap:22px}
}
@media (max-width:720px){
  .footer__grid{grid-template-columns:1fr;gap:18px}
}


/* ================== REVEAL ================== */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .6s ease, transform .6s ease}
.reveal.is-visible{opacity:1;transform:none}

/* ================== RESPONSIVO ================== */
@media (max-width:1024px){
  .grid-2{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:repeat(2,1fr)}
}

/* ===== Header (mobile) — fix do painel ancorado à direita ===== */
@media (max-width: 780px){
  .nav { position: relative; }

  .nav__toggle{
    display: inline-grid;
    place-items: center;
    width: 40px;
    height: 40px;
    border: 0;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 8px 18px rgba(10,12,28,.08);
    transition: transform .18s ease, box-shadow .18s ease;
  }
  .nav__toggle:hover{ transform: translateY(-1px); }

  /* painel ancorado à direita, com animação sem translateX(-50%) */
  .nav__list{
    position: absolute;
    top: 64px;
    right: 0;
    display: none;
    flex-direction: column;
    gap: 10px;
    padding: 12px;
    width: min(92vw, 320px);
    background: rgba(255,255,255,.92);
    backdrop-filter: blur(8px) saturate(1.2);
    border: 1px solid rgba(0,0,0,.06);
    border-radius: 14px;
    box-shadow: 0 22px 48px rgba(10,12,28,.22);
    transform-origin: top right;
    animation: menu-pop-right .22s ease-out;
  }
  .nav.is-open .nav__list{ display: flex; }

  .nav__list .nav-link{
    display: block;
    padding: 10px 12px;
    border-radius: 10px;
    background: transparent;
  }
  .nav__list .nav-link:hover{ background: var(--bg-2); }

  /* esconder CTA no mobile */
  .btn.btn--primary{ display: none; }
}

/* ========= Animação exclusiva para o painel à direita ========= */
@keyframes menu-pop-right{
  from { opacity: 0; transform: scale(.98) translateY(-6px); }
  to   { opacity: 1; transform: none; }
}


/* sombra discreta quando o menu abre em mobile */
.site-header.has-shadow{ box-shadow: 0 10px 24px rgba(10,12,28,.06); }

/* mantém o destaque do ativo no painel mobile */
@media (max-width: 780px){
  .nav__list .nav-link.is-active{
    background: linear-gradient(180deg, var(--brand-2), var(--brand));
    color: #fff;
  }
}

/* ================== ANIMAÇÕES ================== */
@keyframes menu-pop{
  from{opacity:0; transform:translate(-50%,-6px) scale(.98)}
  to{opacity:1; transform:translate(-50%,0) scale(1)}
}
@keyframes fadeIn{
  from{opacity:0}
  to{opacity:1}
}


/* === Padronização da NAV e LOGO com o resto do site === */

/* mesma altura do header das outras páginas */
.header__wrap{ height:80px; }

/* logo (header) */
.brand__logo{
  display:flex; align-items:center; height:50px;
}
.brand__logo img{
  height:100%; width:auto; max-height:50px; object-fit:contain;
}

/* logo (footer invertida) */
.brand--invert .brand__logo{ height:45px; }
.brand--invert .brand__logo img{ max-height:45px; }

/* opcional: remover estilos antigos da badge se não for mais usada aqui */
.brand__badge, .brand-badge{ display:none; }
.brand__text, .brand-name{ display:none; }

/* ===== Aumentar só a logo da NAV (não mexe no footer) ===== */
:root{
  --nav-logo: 84px;    /* ajuste o tamanho que quiser */
  --header-h: 88px;    /* altura da barra para acomodar a logo maior */
}

.site-header .brand__logo{
  height: var(--nav-logo);
}
.site-header .brand__logo img{
  max-height: var(--nav-logo);
}

/* mantém a barra alinhada e o menu mobile no lugar */
.site-header .header__wrap{
  height: var(--header-h);
}
@media (max-width: 780px){
  .nav__list{ top: var(--header-h); }
}

/* Botão flutuante do WhatsApp (global) */
.whatsapp-fab{
  position: fixed;
  right: 18px;
  bottom: calc(18px + env(safe-area-inset-bottom, 0px)); /* respeita safe area no iOS */
  width: 56px; height: 56px;
  border-radius: 50%;
  display: grid; place-items: center;
  background: #25D366; color: #fff;
  text-decoration: none;
  font-size: 28px; line-height: 1;
  box-shadow: 0 12px 28px rgba(0,0,0,.22);
  z-index: 9999;
  transition: transform .18s ease, box-shadow .18s ease, opacity .18s ease;
}
.whatsapp-fab:hover{ transform: translateY(-2px); box-shadow: 0 16px 36px rgba(0,0,0,.28); }
.whatsapp-fab:active{ transform: translateY(0); }

/* Se tiver outro botão flutuante (ex.: ajuda '?'), suba um pouco este aqui:  */
@media (min-width: 0){
  /* descomente se precisar empilhar acima de outro FAB
  .whatsapp-fab{ bottom: 86px; }
  */
}

/* Tamanhos em mobile */
@media (max-width: 780px){
  .whatsapp-fab{ right: 14px; width: 54px; height: 54px; font-size: 26px; }
}

/* ==== TROCA DO VERMELHO PARA AZUL (OVERRIDE GLOBAL) ==== */
:root{
  /* Novo tema azul (usa o mesmo “tom” do --secondary) */
  --brand:   #172A3A;   /* principal */
  --brand-2: #1e4a66;   /* variação p/ gradiente */
  --brand-3: #256086;   /* variação p/ destaque */

  /* Gradiente da CTA em azul */
  --grad-cta: linear-gradient(180deg, var(--brand-2) 0%, var(--brand) 55%, #0f1f2b 100%);
}

/* Botões e estados que tinham RGBA fixo em vermelho */
.btn--primary{
  /* sombra azulada */
  box-shadow: 0 10px 24px rgba(23,42,58,.28);
}
.btn--ghost{
  color: var(--brand);
  /* borda azulada com alpha (antes usava o vermelho) */
  border: 1px solid rgba(23,42,58,.28);
}

/* Ativo no menu mobile já usa var(--brand), então nada a fazer. */

/* Hovers que usavam a borda “vermelha” translúcida */
.card-feature:hover{
  border-color: rgba(23,42,58,.22);
  box-shadow: 0 18px 44px rgba(23,42,58,.15);
}
.process-item:hover{
  border-color: rgba(23,42,58,.22);
  box-shadow: 0 16px 36px rgba(23,42,58,.12);
}

/* Ícones dos cards: fundo mais neutro azulado + ícone na cor da brand */
.card-feature__icon{
  background: #e6edf5; /* antes: #f0e9e4 */
  color: var(--brand);
}

/* Ações/links já pegam var(--brand); mantemos para garantir consistência */
.pi__action{ color: var(--brand); }

/* No menu mobile (ativo), manter o gradiente em azul */
@media (max-width: 780px){
  .nav__list .nav-link.is-active{
    background: linear-gradient(180deg, var(--brand-2), var(--brand));
    color:#fff;
  }
}

.foot {
  margin-top: 20px;
  text-align: center;
  color: var(--muted);
}

.developer-credit {
  text-align: center;
  margin-top: 10px;
}

.developer-credit small {
  color: #ffffff;
  font-size: 0.85rem;
  opacity: 0.9;
}

.developer-credit a {
  color: var(--accent);
  font-weight: 700;
  text-decoration: none;
}

.developer-credit a:hover {
  text-decoration: underline;
  color: var(--accent-2);
}
