/*
Theme Name:  Brasil Fiança
Theme URI:   https://brasilfianca.com.br
Description: Portal institucional de garantias bancárias e fidejussórias — padrão GOV.br.
Version:     2.0.0
Author:      Brasil Fiança
Author URI:  https://brasilfianca.com.br
Text Domain: brasil-fianca
Tags:        institutional, portal, accessibility, responsive
*/

/* ═══════════════════════════════
   DESIGN TOKENS
═══════════════════════════════ */
:root{
  --green:#2e8b1e; --green-d:#1f6213; --green-m:#3aaa24; --green-l:#eaf5e6;
  --yellow:#f5c400; --yellow-l:#fdf6cc;
  --coal:#4a4a4a; --coal-d:#2e2e2e;
  --white:#fff; --off:#f8f9fa; --border:#dde1e7;
  --g4:#9aa3b0; --g6:#5a6474; --tx:#1e2530; --txm:#5a6474;
  --maxw:1200px; --hh:64px; --hh-sub:44px;
  --r:4px; --rm:8px; --rl:14px;
  --s1:0 1px 4px rgba(0,0,0,.06);
  --s2:0 4px 16px rgba(0,0,0,.09);
  --s3:0 8px 32px rgba(0,0,0,.12);
  --font:'Barlow',system-ui,sans-serif;
  --font-c:'Barlow Condensed',system-ui,sans-serif;

  --govbar-h: 42px;     /* Altura da GOV bar */
  --header-h: 70px;     /* Altura do header principal */

}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font);color:var(--tx);background:var(--white);line-height:1.65;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
img{display:block;max-width:100%}
button{cursor:pointer;font-family:inherit;border:none;background:none}
:focus-visible{outline:3px solid var(--yellow);outline-offset:2px;border-radius:2px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ── CONTAINER ── */
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 30px}


/* ═══════════════════════════════
   GOV BAR
═══════════════════════════════ */
.gov-bar {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  min-height: var(--govbar-h);
  background: var(--coal-d);
  color: rgba(255,255,255,.85);
  font-size: 12px;
  border-bottom: 1px solid rgba(255,255,255,.05);
  z-index: 10000;
  display: flex;
  align-items: center;
  
}

.gov-bar .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap; /* Permite quebra controlada */
}

.gov-bar__left {
  display: flex;
  align-items: center;
  gap: 8px;
}

.gov-bar__badge {
  background: var(--yellow);
  color: var(--coal-d);
  font-weight: 700;
  font-size: 9px;
  padding: 2px 7px;
  border-radius: 2px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.gov-bar__title {
  opacity: 0.9;
}

.gov-bar__links {
  display: flex;
  align-items: center;
  gap: 24px;
}

.gov-bar__links a {
  color: rgba(255, 255, 255, 0.7);
  text-decoration: none;
  transition: opacity 0.15s ease, color 0.15s ease;
}

.gov-bar__links a:hover {
  opacity: 1;
  color: #ffffff;
}


/* Compensação do conteúdo */
body {
  margin: 0;
  padding-top: calc(var(--govbar-h) + var(--header-h));
}

/* Garante que o hero encoste exatamente no header */
.hero {
  margin-top: 0px;
}

/* ====================== MOBILE ====================== */
@media (max-width: 992px) {
    .header {
        height: 80px;
        padding: 0 5%;
    }
    
    .header__nav {
        position: fixed;
        top: 50px;
        left: -100%;
        width: 100%;
        height: calc(100vh - 80px);
        background: #111;
        flex-direction: column;
        align-items: flex-start;
        padding: 40px 8%;
        gap: 24px;
        transition: left 0.4s ease;
        z-index: 999;
        box-shadow: 0 10px 20px rgba(0,0,0,0.3);
    }
    
    .header__nav.active {
        left: 0;
    }
    
    /* Hamburger Button */
    .hamburger {
        display: block;
        cursor: pointer;
        z-index: 1001;
    }
}


/* ════════════════════════════════
   HEADER PRINCIPAL
════════════════════════════════ */
.site-header {
  display: flex;     /* Alinhamento000oooo00 */
  position: fixed;
  top: var(--govbar-h);
  left: 0;
  width: 100%;
  align-items: center;           /* Alinhamento vertical */
  height: 40px;         /* Altura fixa recomendada */
  min-height: var(--header-h);
  background: var(--white);
  border-bottom: 3px solid var(--green);
  box-shadow: var(--sh-sm);
  z-index: 9999;
}



.site-header .container {
  display: flex;
  align-items: center;
  justify-content: flex;
  gap: 5px;
}

.header-user {
  display: flex;
  align-items: center;
  margin-left: 30px;
}

.header-user__link {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 600;
  color: var(--coal);
  transition: color 0.15s ease;
}

.header-user__link:hover {
  color: var(--green);
}

.header-user__icon {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: auto;
}
/* Ajuste fino caso tenha sidebar ou overlay */
.overlay {
    display: none;
}

.header__nav.active ~ .overlay {
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.6);
    z-index: 998;
}

.header__nav.active {
        left: 0;
    }




/* ── LOGO ───────────────────────────── */
.site-logo {
  display: auto;
  align-items: flex;     /* Garante centralização do conteúdo interno */
  flex-shrink: 0;
}

.site-logo img {
  height: 50px;            /* Ajuste conforme necessário */
  width: auto;
  display: auto;          /* Remove espaços extras abaixo da imagem */
}


@media (max-width: 500px) {
  .site-logo img {
    height: 40px;
  }
}


/* ── NAV PRINCIPAL ── */
.primary-nav {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: 2px;
    height: 100%;
}

.primary-nav > li {
    position: relative;
    height: 100%;
    display: flex;
    align-items: center;
}

.primary-nav > li > a {
    font-family: var(--font);              /* Garante o uso da fonte correta */
    font-size: 14px;                       /* Aumenta levemente para melhor legibilidade */
    font-weight: 500;
    letter-spacing: 0.2px;                 /* Melhora a definição da letra "i" */
    color: var(--coal);
    padding: 0 12px;
    height: 100%;
    display: flex;
    align-items: center;
    gap: 5px;
    text-decoration: none;
    transition: color .15s ease, background .15s ease;
    border-bottom: 3px solid transparent;
    margin-bottom: -3px;

    /* Melhor renderização tipográfica */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

.primary-nav > li > a:hover,
.primary-nav > li > a.active {
    color: var(--green);
    border-bottom-color: var(--green);
}

.primary-nav > li > a .caret {
    width: 10px;
    height: 10px;
    stroke: currentColor;
    fill: none;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
    transition: transform .2s ease;
}

.primary-nav > li.open > a .caret {
    transform: rotate(180deg);
}

/* ── DROPDOWN ── */
.dropdown{position:absolute;top:100%;left:0;min-width:260px;background:var(--white);border:1px solid var(--border);border-top:3px solid var(--green);border-radius:0 0 var(--rm) var(--rm);box-shadow:var(--s2);opacity:0;pointer-events:none;transform:translateY(-6px);transition:opacity .18s,transform .18s;z-index:300}
.primary-nav>li.open .dropdown{opacity:1;pointer-events:auto;transform:translateY(0)}
.dropdown__section{padding:8px 0;border-bottom:1px solid var(--border)}
.dropdown__section:last-child{border-bottom:none}
.dropdown__label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--g6);padding:6px 16px 4px}
.dropdown a{display:flex;align-items:center;gap:8px;padding:8px 16px;font-size:13px;color:var(--tx);transition:background .12s,color .12s}
.dropdown a:hover{background:var(--green-l);color:var(--green-d)}
.dropdown a svg{width:14px;height:14px;stroke:var(--green);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}

-------NOVO
.dropdown {
    position: flex;
    top: 100%;
    left: 0;
    min-width: 260px;
    background: var(--white);
    border: 1px solid var(--border);
    border-top: 3px solid var(--green);
    border-radius: 0 0 var(--rm) var(--rm);
    box-shadow: var(--s2);
    opacity: 0;
    visibility: hidden; /* Adicionado */
    pointer-events: none;
    transform: translateY(-6px);
    transition: opacity .18s ease, transform .18s ease, visibility .18s;
    z-index: 1100; /* Garantir sobreposição */
}

.primary-nav > li.open > .dropdown,
.primary-nav > li.has-dropdown:hover > .dropdown {
    opacity: 1;
    visibility: visible; /* Adicionado */
    pointer-events: auto;
    transform: translateY(0);
}

/* Exibe o dropdown ao passar o mouse (desktop) */
.primary-nav > li.has-dropdown:hover > .dropdown {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

/* Rotaciona o ícone caret no hover */
.primary-nav > li.has-dropdown:hover > a .caret {
    transform: rotate(180deg);
}
---------------------Login aqui
/* ─────────────────────────────
   ACESSO DO USUÁRIO (LOGIN/PERFIL)
───────────────────────────── */
.header-user {
    display: auto;
    align-items: center;
    margin-left: 4px;
	 height: 100%;
}

.header-user__link {
    display: auto;
    align-items: center;
    gap: 6px;
    font-family: var(--font);
    font-size: 14px;
    font-weight: 500;
    color: var(--text-main);
    text-decoration: none;
    padding: 6px 4px;
    transition: color .2s ease;
}

main,
.site-main,
.content-area,
.entry-content,
section:first-child {
  margin-top: 0;
  padding-top: 0;
}

/* Ícone herdando a cor do texto */
.header-user__icon {
    width: 18px;
    height: 18px;
    stroke: currentColor;
    fill: none;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
    transition: transform .2s ease, color .2s ease;
}

/* Efeito hover discreto */
.header-user__link:hover {
    color: var(--green);
}

.header-user__link:hover .header-user__icon {
    transform: scale(1.05);
}

/* Nome do usuário */
.header-user__name {
    font-weight: 600;
    white-space: nowrap;
}

/* ── BOTÃO CTA DO HEADER ───────────── */
.btn-header-cta {
  margin-left: 40px;
  background: var(--green);
  color: #fff !important;
  font-size: 12px;
  font-weight: 800;
  padding: 20 20px;
  border-radius: 5px;
  transition: background 0.2s ease, transform 0.1s ease;
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 20px;
  text-decoration: none;
}
.btn-header-cta:hover {
  background: var(--green-d);
  color: #fff !important;
}

.btn-header-cta:hover {
  background: var(--green-d);
  transform: translateY(-1px);
}

@media (max-width: 768px) {
  .btn-header-cta {
    font-size: 11px;
    padding: 1 12px;
  }
}

/* ── HAMBURGER ── */
.hamburger{display:none;flex-direction:column;gap:5px;padding:4px;margin-left:auto}
.hamburger span{display:block;width:24px;height:2px;background:var(--coal);border-radius:2px;transition:all .22s}
.hamburger[aria-expanded="true"] span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
.hamburger[aria-expanded="true"] span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ════════════════════════════════
   BREADCRUMB
════════════════════════════════ */
.breadcrumb{background:var(--off);border-bottom:1px solid var(--border);padding:6px 0;font-size:12px;color:var(--g6)}
.breadcrumb .container{display:auto;align-items:center;gap:-1px;flex-wrap:wrap}
.breadcrumb a{color:var(--green);transition:color .12s}
.breadcrumb a:hover{color:var(--green-d)}
.breadcrumb__sep{opacity:.5}

/* ════════════════════════════════
   PAGE HERO (usado nas internas)
════════════════════════════════ */
.page-hero{background:var(--coal-d);color:white;padding:44px 0 48px;position:relative;overflow:hidden}
.page-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--green),var(--yellow),var(--green))}
.page-hero .container{position:relative}
.page-hero__label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--yellow);margin-bottom:8px;display:flex;align-items:center;gap:7px}
.page-hero__label::before{content:'';width:14px;height:2px;background:var(--yellow)}
.page-hero h1{font-family:var(--font-c);font-size:clamp(24px,3.5vw,42px);font-weight:800;text-transform:uppercase;letter-spacing:.01em;line-height:1.1;margin-bottom:12px}
.page-hero p{font-size:15px;color:rgba(255,255,255,.7);max-width:600px;line-height:1.7}

/* ════════════════════════════════
   HOME HERO
════════════════════════════════ */
.home-hero{background:var(--coal-d);color:white;padding:64px 0 72px;position:relative;overflow:hidden}
.home-hero::before{content:'';position:absolute;inset:0;background:linear-gradient(160deg,rgba(46,139,30,.14) 0%,transparent 55%),repeating-linear-gradient(45deg,rgba(255,255,255,.013) 0,rgba(255,255,255,.013) 1px,transparent 1px,transparent 32px)}
.home-hero::after{content:'';position:absolute;bottom:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--green) 0%,var(--yellow) 50%,var(--green) 100%)}
.home-hero .container{position:relative;display:grid;grid-template-columns:1fr 360px;gap:48px;align-items:center}
.home-hero__badge{display:inline-flex;align-items:center;gap:6px;background:rgba(245,196,0,.13);border:1px solid rgba(245,196,0,.28);padding:4px 12px;border-radius:20px;font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--yellow);margin-bottom:16px}
.home-hero__badge::before{content:'';width:5px;height:5px;background:var(--yellow);border-radius:50%;flex-shrink:0}
.home-hero h1{font-family:var(--font-c);font-size:clamp(28px,4.2vw,52px);font-weight:800;line-height:1.05;text-transform:uppercase;letter-spacing:.01em;margin-bottom:14px}
.home-hero h1 em{font-style:normal;color:var(--green-m)}
.home-hero__sub{font-size:15px;line-height:1.7;color:rgba(255,255,255,.68);max-width:520px;margin-bottom:28px}
.home-hero__actions{display:flex;gap:10px;flex-wrap:wrap}
.btn-primary{background:var(--green);color:white;font-family:var(--font-c);font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.04em;padding:12px 24px;border-radius:var(--r);transition:background .15s,transform .12s;display:inline-flex;align-items:center;gap:7px}
.btn-primary:hover{background:var(--green-m);transform:translateY(-1px)}
.btn-secondary{background:transparent;color:rgba(255,255,255,.85);font-family:var(--font-c);font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.04em;padding:12px 24px;border-radius:var(--r);border:1px solid rgba(255,255,255,.28);transition:border-color .15s,color .15s;display:inline-block}
.btn-secondary:hover{border-color:rgba(255,255,255,.7);color:white}
.btn-outline{background:transparent;color:var(--green);font-family:var(--font-c);font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.04em;padding:10px 20px;border-radius:var(--r);border:2px solid var(--green);transition:background .15s,color .15s;display:inline-block}
.btn-outline:hover{background:var(--green);color:white}

/* CTA card no hero */
.hero-cta-card{background:white;border-radius:var(--rl);padding:28px;box-shadow:var(--s3);color:var(--tx);border-top:4px solid var(--green)}
.hero-cta-card__title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--green);margin-bottom:3px}
.hero-cta-card__sub{font-size:12px;color:var(--g6);margin-bottom:16px}

/* ════════════════════════════════
   FORMULÁRIOS GENÉRICOS
════════════════════════════════ */
.field{margin-bottom:14px}
.field label{display:block;font-size:11px;font-weight:700;color:var(--g6);margin-bottom:4px;text-transform:uppercase;letter-spacing:.04em}
.field input,.field select,.field textarea{width:100%;padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--r);font-family:var(--font);font-size:13px;color:var(--tx);background:var(--off);outline:none;transition:border-color .15s,background .15s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--green);background:white}
.field textarea{min-height:100px;resize:vertical}
.field--error input,.field--error select,.field--error textarea{border-color:#dc3545}
.field__msg{font-size:11.5px;margin-top:4px;color:#dc3545}
.field--valid .field__msg{color:var(--green)}
.btn-form{width:100%;background:var(--green);color:white;font-family:var(--font-c);font-weight:800;font-size:14px;text-transform:uppercase;letter-spacing:.05em;padding:13px;border-radius:var(--r);transition:background .15s;display:flex;align-items:center;justify-content:center;gap:8px}
.btn-form:hover{background:var(--green-d)}
.form-note{font-size:11px;color:var(--g4);text-align:center;margin-top:10px}

/* ════════════════════════════════
   SECTIONS
════════════════════════════════ */
.section{padding:64px 0}
.section--alt{background:var(--off)}
.section--dark{background:var(--coal-d);color:white}
.section--yellow{background:var(--yellow)}
.section-head{margin-bottom:36px}
.section-head--center{text-align:center}
.section-head--center .section-desc{margin:0 auto}
.section-label{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--green);margin-bottom:8px;display:flex;align-items:center;gap:7px}
.section-label--center{justify-content:center}
.section-label--yellow{color:var(--yellow)}
.section-label::before,.section-label--center::before{content:'';width:14px;height:2px;background:currentColor;flex-shrink:0}
.section-title{font-family:var(--font-c);font-size:clamp(22px,3vw,34px);font-weight:800;color:var(--coal-d);line-height:1.1;text-transform:uppercase;letter-spacing:.01em;margin-bottom:10px}
.section-title--white{color:white}
.section-desc{font-size:15px;color:var(--txm);max-width:580px;line-height:1.7}
.section-desc--light{color:rgba(255,255,255,.68)}

/* ── MENU PRINCIPAL ─────────────────────────── */
.primary-nav {
  margin-left: center;
  display: center;
  align-items: center;     /* Centraliza os itens do menu verticalmente */
  gap: 1px;
  height: 100%;
}

.primary-nav > li {
  display: center;
  align-items: center;     /* Centraliza cada item do menu */
  height: 100%;
}



/* ════════════════════════════════
   SOLUTION CARDS (home + páginas)
════════════════════════════════ */
.solutions-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:36px}
.solution-card{background:white;border:1px solid var(--border);border-radius:var(--rm);padding:32px 28px;display:flex;flex-direction:column;gap:12px;position:relative;overflow:hidden;transition:box-shadow .18s,transform .18s}
.solution-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:var(--green);transition:height .18s}
.solution-card--yellow::before{background:var(--yellow)}
.solution-card:hover{box-shadow:var(--s2);transform:translateY(-2px)}
.solution-card__badge{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--green);margin-bottom:4px}
.solution-card--yellow .solution-card__badge{color:#7a5f00}
.solution-card__title{font-family:var(--font-c);font-size:20px;font-weight:800;text-transform:uppercase;color:var(--coal-d)}
.solution-card__desc{font-size:14px;color:var(--txm);line-height:1.65;flex:1}
.solution-card__link{font-family:var(--font-c);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--green);display:inline-flex;align-items:center;gap:5px;transition:gap .15s;margin-top:4px}
.solution-card:hover .solution-card__link{gap:9px}

/* ── SUBMENU DE MODALIDADES ── */
.modalities-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:28px}
.modality-card{background:white;border:1px solid var(--border);border-radius:var(--r);padding:18px 16px;transition:box-shadow .15s,border-color .15s;display:flex;flex-direction:column;gap:8px}
.modality-card:hover{box-shadow:var(--s1);border-color:#b5d9ab}
.modality-card__num{font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--green)}
.modality-card__title{font-family:var(--font-c);font-size:14px;font-weight:800;text-transform:uppercase;color:var(--coal-d);line-height:1.2}
.modality-card__desc{font-size:12.5px;color:var(--txm);line-height:1.55;flex:1}
.modality-card__link{font-size:12px;font-weight:600;color:var(--green);display:inline-flex;align-items:center;gap:4px;transition:gap .12s;font-family:var(--font-c);text-transform:uppercase;letter-spacing:.03em}
.modality-card:hover .modality-card__link{gap:7px}

/* ════════════════════════════════
   COMO FUNCIONA — ETAPAS
════════════════════════════════ */
.process-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:0;margin-top:44px;position:relative}
.process-steps::before{content:'';position:absolute;top:28px;left:10%;right:10%;height:2px;background:repeating-linear-gradient(90deg,var(--green) 0,var(--green) 8px,transparent 8px,transparent 18px);z-index:0}
.step{display:flex;flex-direction:column;align-items:center;text-align:center;padding:0 8px;z-index:1;position:relative}
.step__num{width:56px;height:56px;background:white;border:2.5px solid var(--green);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-c);font-size:22px;font-weight:800;color:var(--green);margin-bottom:14px;flex-shrink:0;transition:background .18s,color .18s}
.step:hover .step__num{background:var(--green);color:white}
.step__title{font-family:var(--font-c);font-size:13px;font-weight:800;color:var(--coal-d);margin-bottom:6px;text-transform:uppercase;letter-spacing:.02em;line-height:1.2}
.step__desc{font-size:12px;color:var(--txm);line-height:1.55}

/* ════════════════════════════════
   PARCEIROS
════════════════════════════════ */
.partners-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;margin-top:32px}
.partner-card{background:white;border:1px solid var(--border);border-radius:var(--r);padding:20px;display:flex;align-items:center;justify-content:center;transition:box-shadow .15s,border-color .15s;min-height:80px}
.partner-card:hover{box-shadow:var(--s1);border-color:#b5d9ab}
.partner-card img{max-height:80px;width:auto;object-fit:contain;filter:grayscale(1);opacity:.65;transition:filter .2s,opacity .2s}
.partner-card:hover img{filter:grayscale(0);opacity:1}
.partner-card__name{font-family:var(--font-c);font-size:13px;font-weight:700;color:var(--g6);text-align:center}

/* ════════════════════════════════
   DIFERENCIAIS / CREDENCIAIS
════════════════════════════════ */
.credentials-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:32px}
.credential-card{text-align:center;padding:28px 20px}
.credential-card__icon{width:52px;height:52px;background:var(--green-l);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.credential-card__icon svg{width:24px;height:24px;stroke:var(--green);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.credential-card__value{font-family:var(--font-c);font-size:28px;font-weight:800;color:var(--green-d);line-height:1}
.credential-card__label{font-size:13px;color:var(--txm);margin-top:5px;line-height:1.4}

/* ════════════════════════════════
   FAQ ACCORDION
════════════════════════════════ */
.faq-list{display:flex;flex-direction:column;gap:7px}
.faq-item{border:1px solid var(--border);border-radius:var(--rm);overflow:hidden}
.faq-question{width:100%;padding:16px 20px;text-align:left;font-size:14.5px;font-weight:600;color:var(--coal-d);display:flex;align-items:center;justify-content:space-between;gap:14px;transition:background .15s}
.faq-question:hover{background:var(--off)}
.faq-question[aria-expanded="true"]{background:var(--green-l);color:var(--green-d)}
.faq-question[aria-expanded="true"] .faq-chev{transform:rotate(180deg)}
.faq-chev{width:16px;height:16px;flex-shrink:0;transition:transform .22s;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.faq-answer{display:none;padding:0 20px 16px;font-size:14px;color:var(--txm);line-height:1.75;border-top:1px solid var(--border);background:var(--off)}
.faq-answer.open{display:block}

/* ════════════════════════════════
   COTAÇÃO — FORMULÁRIO COMPLETO
════════════════════════════════ */
.cotacao-wrapper{max-width:840px;margin:0 auto}
.tipo-selector{display:flex;gap:12px;margin-bottom:32px}
.tipo-btn{flex:1;padding:20px 16px;border:2px solid var(--border);border-radius:var(--rm);text-align:center;transition:border-color .15s,background .15s;cursor:pointer}
.tipo-btn:hover{border-color:var(--green);background:var(--green-l)}
.tipo-btn.active{border-color:var(--green);background:var(--green-l)}
.tipo-btn__icon{width:40px;height:40px;background:var(--green-l);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 10px}
.tipo-btn.active .tipo-btn__icon{background:var(--green)}
.tipo-btn__icon svg{width:20px;height:20px;stroke:var(--green);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.tipo-btn.active .tipo-btn__icon svg{stroke:white}
.tipo-btn__label{font-family:var(--font-c);font-size:16px;font-weight:800;text-transform:uppercase;color:var(--coal-d)}
.tipo-btn__desc{font-size:12px;color:var(--txm);margin-top:4px}

.form-section{background:white;border:1px solid var(--border);border-radius:var(--rm);padding:28px;margin-bottom:20px}
.form-section__title{font-family:var(--font-c);font-size:16px;font-weight:800;text-transform:uppercase;color:var(--coal-d);margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid var(--green-l);display:flex;align-items:center;gap:8px}
.form-section__title svg{width:18px;height:18px;stroke:var(--green);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.form-row{display:grid;gap:14px}
.form-row--2{grid-template-columns:1fr 1fr}
.form-row--3{grid-template-columns:1fr 1fr 1fr}
.pf-fields,.pj-fields{display:none}
.pf-fields.active,.pj-fields.active{display:block}

.upload-zone{border:2px dashed var(--border);border-radius:var(--r);padding:28px;text-align:center;transition:border-color .15s,background .15s;cursor:pointer}
.upload-zone:hover,.upload-zone.drag-over{border-color:var(--green);background:var(--green-l)}
.upload-zone__icon{width:44px;height:44px;margin:0 auto 10px;stroke:var(--g4);fill:none;stroke-width:1.5}
.upload-zone p{font-size:13px;color:var(--g6)}
.upload-zone span{color:var(--green);font-weight:600}
.upload-list{margin-top:12px;display:flex;flex-direction:column;gap:6px}
.upload-item{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--g6);background:var(--off);padding:6px 10px;border-radius:var(--r);border:1px solid var(--border)}
.upload-item svg{width:14px;height:14px;stroke:var(--green);fill:none;flex-shrink:0}
.upload-item__remove{margin-left:auto;cursor:pointer;opacity:.6;transition:opacity .12s}
.upload-item__remove:hover{opacity:1}

.lgpd-check{display:flex;align-items:flex-start;gap:10px;padding:16px;background:var(--off);border-radius:var(--r);border:1px solid var(--border)}
.lgpd-check input[type="checkbox"]{width:18px;height:18px;accent-color:var(--green);flex-shrink:0;margin-top:2px}
.lgpd-check label{font-size:13px;color:var(--txm);line-height:1.5}
.lgpd-check a{color:var(--green)}

/* ════════════════════════════════
   INSTITUCIONAL
════════════════════════════════ */
.mvv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:32px}
.mvv-card{background:white;border:1px solid var(--border);border-radius:var(--rm);padding:28px;position:relative;overflow:hidden}
.mvv-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.mvv-card:nth-child(1)::before{background:var(--green)}
.mvv-card:nth-child(2)::before{background:var(--yellow)}
.mvv-card:nth-child(3)::before{background:var(--coal)}
.mvv-card__label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--g4);margin-bottom:8px}
.mvv-card__title{font-family:var(--font-c);font-size:22px;font-weight:800;text-transform:uppercase;color:var(--coal-d);margin-bottom:12px}
.mvv-card p{font-size:14px;color:var(--txm);line-height:1.7}

/* ════════════════════════════════
   CONTATO
════════════════════════════════ */
.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:20px}
.contact-item{display:flex;align-items:flex-start;gap:14px}
.contact-item__icon{width:44px;height:44px;background:var(--green-l);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-item__icon svg{width:20px;height:20px;stroke:var(--green);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.contact-item h4{font-size:13px;font-weight:700;color:var(--coal-d);margin-bottom:3px}
.contact-item p,.contact-item a{font-size:14px;color:var(--txm)}
.contact-item a:hover{color:var(--green)}

/* ════════════════════════════════
   FOOTER
════════════════════════════════ */
.footer-topbar{background:var(--green-d);padding:10px 0}
.footer-topbar .container{display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-size:11px;color:rgba(255,255,255,.75)}
.footer-topbar strong{color:var(--yellow)}
.site-footer{background:var(--coal-d);color:rgba(255,255,255,.65);padding:52px 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand img { height: 60; width: auto; margin-bottom: 20px; filter: none; opacity: 1; }
.footer-brand p{font-size:13px;line-height:1.7;max-width:240px;margin-bottom:16px}
.footer-social{display:flex;gap:7px}
.social-btn{width:32px;height:32px;background:rgba(255,255,255,.08);border-radius:var(--r);display:flex;align-items:center;justify-content:center;transition:background .15s}
.social-btn:hover{background:var(--green)}
.social-btn svg{width:15px;height:15px;stroke:white;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.footer-col h4{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.38);margin-bottom:14px}
.footer-col ul{display:flex;flex-direction:column;gap:8px}
.footer-col ul li a{font-size:13px;color:rgba(255,255,255,.58);transition:color .12s}
.footer-col ul li a:hover{color:white}
.footer-bottom{padding:16px 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:11px}
.footer-links{display:flex;gap:14px}
.footer-links a{color:rgba(255,255,255,.35);transition:color .12s}
.footer-links a:hover{color:rgba(255,255,255,.75)}
.footer-copy{color:rgba(255,255,255,.32)}



/* ════════════════════════════════
   BACK TO TOP
════════════════════════════════ */
.back-to-top{position:fixed;bottom:24px;right:24px;width:40px;height:40px;background:var(--green);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--s2);opacity:0;pointer-events:none;transition:opacity .22s,transform .22s;transform:translateY(8px);z-index:999}
.back-to-top.visible{opacity:1;pointer-events:auto;transform:translateY(0)}
.back-to-top svg{width:16px;height:16px;stroke:white;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}

/* ════════════════════════════════
   REVEAL ANIMATION
════════════════════════════════ */
.reveal {
  opacity: 0;
  transition: opacity .4s ease;
}

.reveal.visible {
  opacity: 1;
}
/* ════════════════════════════════
   RESPONSIVO
════════════════════════════════ */
@media(max-width:1024px){
  .home-hero .container{grid-template-columns:1fr}
  .hero-cta-card{max-width:420px}
  .solutions-grid{grid-template-columns:1fr}
  .credentials-grid{grid-template-columns:repeat(2,1fr)}
  .modalities-grid{grid-template-columns:repeat(2,1fr)}
  .process-steps{grid-template-columns:repeat(3,1fr);gap:20px}
  .process-steps::before{display:none}
  .contact-layout{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .gov-bar__links,.primary-nav{display:none}
  .hamburger{display:flex}
  .primary-nav.open{
    display:flex;flex-direction:column;position:fixed;
    inset:var(--hh) 0 0 0;background:white;padding:20px;gap:2px;
    box-shadow:var(--s3);overflow-y:auto;z-index:199;
  }
  .primary-nav.open>li{height:auto}
  .primary-nav.open>li>a{height:auto;padding:12px 14px;border-bottom:none;border-radius:var(--r);font-size:15px}
  .primary-nav.open .dropdown{position:static;opacity:1;pointer-events:auto;transform:none;box-shadow:none;border:none;border-radius:0;padding-left:16px;border-top:1px solid var(--border)}
  .primary-nav.open .btn-header-cta{margin:10px 0 0;text-align:center;padding:13px;display:block}
  .solutions-grid,.modalities-grid,.mvv-grid,.credentials-grid,.form-row--2,.form-row--3,.footer-grid{grid-template-columns:1fr}
  .process-steps{grid-template-columns:1fr}
  .tipo-selector{flex-direction:column}
  .section{padding:44px 0}
  .home-hero{padding:44px 0 52px}
}

