/* =====================================================================
   SO Consultoria — Sistema de Design
   Identidade: azul cobalto institucional + acento dourado (selo de
   conformidade). Display serifado Fraunces + corpo Inter.
   ===================================================================== */

:root{
  /* Cores */
  --ink:#0A2540;            /* texto forte / títulos escuros */
  --navy:#0E3D8C;           /* azul profundo */
  --brand:#1B50B3;          /* cobalto da marca */
  --brand-700:#16448F;
  --brand-50:#EAF1FB;
  --gold:#C8A24A;           /* selo / acento */
  --gold-soft:#F3E9CF;
  --paper:#F5F7FB;          /* fundo de seção clara */
  --paper-2:#EEF2F8;
  --white:#ffffff;
  --line:#E2E8F2;
  --line-strong:#CDD8E8;
  --text:#27384E;           /* corpo */
  --muted:#5E6E84;          /* secundário */
  --muted-2:#8494A8;

  /* Tipografia */
  --serif:"Fraunces", Georgia, "Times New Roman", serif;
  --sans:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;

  /* Forma */
  --r-sm:10px; --r:16px; --r-lg:24px; --r-pill:999px;
  --shadow-sm:0 2px 8px rgba(10,37,64,.06);
  --shadow:0 14px 40px rgba(10,37,64,.10);
  --shadow-lg:0 30px 70px rgba(10,37,64,.16);
  --container:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; font-family:var(--sans); color:var(--text);
  background:var(--white); line-height:1.65; font-size:17px;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{max-width:100%; display:block}
a{color:var(--brand); text-decoration:none}
a:hover{color:var(--brand-700)}
h1,h2,h3,h4{font-family:var(--serif); color:var(--ink); line-height:1.12; font-weight:600; margin:0}
p{margin:0 0 1rem}
.container{width:100%; max-width:var(--container); margin-inline:auto; padding-inline:22px}

/* ---------- Utilitários ---------- */
.eyebrow{
  display:inline-flex; align-items:center; gap:.5rem;
  font-size:.74rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
  color:var(--brand); background:var(--brand-50);
  padding:.4rem .8rem; border-radius:var(--r-pill);
}
.eyebrow::before{content:""; width:14px; height:14px; border-radius:50%;
  background:radial-gradient(circle at 50% 50%, var(--gold) 0 38%, transparent 42%);
  box-shadow:0 0 0 2px var(--gold-soft) inset; flex:0 0 auto}
.lead{font-size:1.12rem; color:var(--muted)}
.section-head{max-width:760px; margin-bottom:2.4rem}
.section-head h2{font-size:clamp(1.7rem,3.4vw,2.5rem); margin:.7rem 0 .6rem; letter-spacing:-.01em}
.section-head p{font-size:1.08rem; color:var(--muted); margin:0}
.center{text-align:center} .center.section-head{margin-inline:auto}
section{padding:clamp(3.4rem,7vw,6rem) 0}
.bg-paper{background:var(--paper)}
.bg-ink{background:
   radial-gradient(1100px 600px at 12% -10%, rgba(27,80,179,.55), transparent 60%),
   radial-gradient(900px 500px at 110% 10%, rgba(200,162,74,.20), transparent 55%),
   var(--ink); color:#D6E1F2}
.bg-ink h2,.bg-ink h3{color:#fff}

/* ---------- Botões ---------- */
.btn{display:inline-flex; align-items:center; gap:.55rem; font-weight:600;
  font-size:1rem; padding:.85rem 1.4rem; border-radius:var(--r-pill);
  border:1px solid transparent; cursor:pointer; transition:.2s var(--ease);
  text-decoration:none; line-height:1}
.btn svg{width:18px; height:18px}
.btn-primary{background:var(--brand); color:#fff; box-shadow:0 8px 20px rgba(27,80,179,.28)}
.btn-primary:hover{background:var(--brand-700); color:#fff; transform:translateY(-2px); box-shadow:0 12px 26px rgba(27,80,179,.34)}
.btn-gold{background:var(--gold); color:#3a2c08; box-shadow:0 8px 20px rgba(200,162,74,.30)}
.btn-gold:hover{filter:brightness(1.05); color:#3a2c08; transform:translateY(-2px)}
.btn-ghost{background:#fff; color:var(--ink); border-color:var(--line-strong)}
.btn-ghost:hover{border-color:var(--brand); color:var(--brand); transform:translateY(-2px)}
.btn-wa{background:#1FA855; color:#fff}
.btn-wa:hover{background:#178a45; color:#fff; transform:translateY(-2px)}

/* ---------- Header / Navegação ---------- */
.topbar{background:var(--ink); color:#AFC1DA; font-size:.82rem}
.topbar .container{display:flex; gap:1.2rem; justify-content:space-between; align-items:center; min-height:38px; flex-wrap:wrap}
.topbar a{color:#D6E1F2}
.topbar a:hover{color:#fff}
.topbar .ti{display:inline-flex; align-items:center; gap:.4rem}
.topbar svg{width:14px;height:14px;opacity:.85}

header.site{position:sticky; top:0; z-index:60; background:rgba(255,255,255,.86);
  backdrop-filter:saturate(180%) blur(10px); border-bottom:1px solid var(--line)}
.nav{display:flex; align-items:center; justify-content:space-between; height:86px; gap:1rem}
.brand{display:flex; align-items:center}
.brand img{height:58px; width:auto}
.menu{display:flex; align-items:center; gap:.3rem}
.menu>a, .has-sub>button{
  font-family:var(--sans); font-weight:600; font-size:.96rem; color:var(--ink);
  background:none; border:0; cursor:pointer; padding:.6rem .8rem; border-radius:var(--r-sm);
  display:inline-flex; align-items:center; gap:.35rem; transition:.18s}
.menu>a:hover, .has-sub>button:hover{background:var(--brand-50); color:var(--brand)}
.menu>a.active{color:var(--brand)}
.menu>a.active::after{content:""; display:block}
.has-sub{position:relative}
.has-sub>button svg{width:14px;height:14px; transition:.2s}
.has-sub:hover>button svg, .has-sub.open>button svg{transform:rotate(180deg)}
.submenu{position:absolute; top:calc(100% + 8px); left:0; min-width:248px;
  background:#fff; border:1px solid var(--line); border-radius:var(--r);
  box-shadow:var(--shadow); padding:.5rem; opacity:0; visibility:hidden;
  transform:translateY(8px); transition:.2s var(--ease)}
.has-sub:hover .submenu, .has-sub.open .submenu{opacity:1; visibility:visible; transform:translateY(0)}
.submenu a{display:flex; flex-direction:column; gap:.1rem; padding:.6rem .7rem; border-radius:var(--r-sm); color:var(--ink)}
.submenu a span{font-size:.78rem; color:var(--muted-2); font-weight:500}
.submenu a:hover{background:var(--brand-50); color:var(--brand)}
.nav-cta{display:flex; align-items:center; gap:.5rem}
.burger{display:none; background:none; border:1px solid var(--line-strong); border-radius:var(--r-sm);
  width:46px; height:46px; cursor:pointer; align-items:center; justify-content:center; color:var(--ink)}
.burger svg{width:24px;height:24px}

/* ---------- Hero ---------- */
.hero{position:relative; overflow:hidden; background:
   radial-gradient(1200px 700px at 8% -20%, rgba(27,80,179,.10), transparent 55%),
   radial-gradient(900px 600px at 105% 0%, rgba(200,162,74,.10), transparent 55%),
   linear-gradient(180deg,#fff, var(--paper))}
.hero .container{display:grid; grid-template-columns:1.05fr .95fr; gap:3rem; align-items:center;
  padding-block:clamp(3rem,6vw,5.4rem)}
.hero h1{font-size:clamp(2.2rem,4.6vw,3.5rem); letter-spacing:-.02em; margin:.9rem 0 1rem}
.hero h1 .u{color:var(--brand); position:relative; white-space:nowrap}
.hero h1 .u::after{content:""; position:absolute; left:0; right:0; bottom:.06em; height:.16em;
  background:var(--gold-soft); z-index:-1; border-radius:4px}
.hero p.lead{font-size:1.18rem; color:var(--muted); max-width:36ch; margin-bottom:1.6rem}
.hero-actions{display:flex; gap:.8rem; flex-wrap:wrap; margin-bottom:1.7rem}
.hero-badges{display:flex; gap:.5rem; flex-wrap:wrap}
.chip{display:inline-flex; align-items:center; gap:.4rem; font-size:.82rem; font-weight:600;
  color:var(--ink); background:#fff; border:1px solid var(--line); padding:.4rem .75rem;
  border-radius:var(--r-pill); box-shadow:var(--shadow-sm)}
.chip svg{width:15px; height:15px; color:var(--brand)}

/* Cartão "selo" do hero */
.hero-visual{position:relative; display:flex; justify-content:center}
.seal-card{position:relative; width:100%; max-width:430px; background:#fff;
  border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--shadow-lg);
  padding:1.8rem 1.8rem 1.6rem}
.seal-card .seal-top{display:flex; align-items:center; justify-content:space-between; margin-bottom:1.1rem}
.seal-card .years{font-family:var(--serif); font-weight:600; line-height:1}
.seal-card .years b{display:block; font-size:3.2rem; color:var(--brand); letter-spacing:-.03em}
.seal-card .years span{font-size:.95rem; color:var(--muted)}
.stamp{width:78px;height:78px; flex:0 0 auto; color:var(--gold); animation:spin 22s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.seal-list{list-style:none; margin:0; padding:.4rem 0 0; display:grid; gap:.7rem}
.seal-list li{display:flex; gap:.7rem; align-items:flex-start; font-size:.96rem; color:var(--text)}
.seal-list li svg{width:22px;height:22px;flex:0 0 auto; color:var(--brand); margin-top:1px}
.seal-card .foot{margin-top:1.2rem; padding-top:1rem; border-top:1px dashed var(--line-strong);
  font-size:.82rem; color:var(--muted); display:flex; align-items:center; gap:.5rem}

/* ---------- Faixa de estatísticas ---------- */
.stats{display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line);
  border:1px solid var(--line); border-radius:var(--r); overflow:hidden}
.stats .stat{background:#fff; padding:1.5rem 1.2rem; text-align:center}
.stats .stat b{display:block; font-family:var(--serif); font-size:2.1rem; color:var(--brand); line-height:1}
.stats .stat span{display:block; margin-top:.35rem; font-size:.86rem; color:var(--muted); font-weight:500}

/* ---------- Grid de serviços / cards ---------- */
.grid{display:grid; gap:1.4rem}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:1.6rem;
  box-shadow:var(--shadow-sm); transition:.22s var(--ease); position:relative}
.card:hover{transform:translateY(-4px); box-shadow:var(--shadow); border-color:var(--line-strong)}
.card .ico{width:52px;height:52px; border-radius:14px; display:grid; place-items:center;
  background:linear-gradient(140deg,var(--brand),var(--navy)); color:#fff; margin-bottom:1rem}
.card .ico svg{width:26px;height:26px}
.card.gold .ico{background:linear-gradient(140deg,var(--gold),#a87f2c); color:#2f2406}
.card h3{font-size:1.22rem; margin-bottom:.4rem}
.card p{margin:0; color:var(--muted); font-size:.98rem}
.card .more{display:inline-flex; align-items:center; gap:.35rem; margin-top:1rem;
  font-weight:600; font-size:.92rem; color:var(--brand)}
.card .more svg{width:16px;height:16px; transition:.2s}
.card:hover .more svg{transform:translateX(4px)}

/* numeração de processo */
.steps{counter-reset:step; display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem}
.step{position:relative; background:#fff; border:1px solid var(--line); border-radius:var(--r);
  padding:1.5rem 1.3rem 1.3rem; box-shadow:var(--shadow-sm)}
.step::before{counter-increment:step; content:counter(step,decimal-leading-zero);
  font-family:var(--serif); font-weight:600; font-size:1.4rem; color:var(--gold);
  display:inline-block; margin-bottom:.5rem}
.step h3{font-size:1.08rem; margin-bottom:.35rem}
.step p{margin:0; font-size:.92rem; color:var(--muted)}

/* ---------- Bloco com imagem (media) ---------- */
.media{display:grid; grid-template-columns:1fr 1fr; gap:2.6rem; align-items:center}
.media.rev{direction:rtl} .media.rev>*{direction:ltr}
.media-fig{border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow); position:relative; aspect-ratio:3/2}
.media-fig img{width:100%; height:100%; object-fit:cover}
.media-fig .tag{position:absolute; left:14px; bottom:14px; background:rgba(10,37,64,.78);
  color:#fff; font-size:.8rem; font-weight:600; padding:.4rem .7rem; border-radius:var(--r-pill); backdrop-filter:blur(4px)}
.media h2{font-size:clamp(1.5rem,3vw,2.1rem); margin-bottom:.7rem}
.tick{list-style:none; padding:0; margin:1rem 0 0; display:grid; gap:.6rem}
.tick li{display:flex; gap:.6rem; align-items:flex-start; color:var(--text)}
.tick li svg{width:21px;height:21px;flex:0 0 auto;color:var(--brand);margin-top:2px}

/* ---------- Atuação nacional (Brasil) ---------- */
.brasil-wrap{display:grid; grid-template-columns:1fr 1fr; gap:2.5rem; align-items:center}
.brasil-art{display:flex; justify-content:center; position:relative}
.brasil-art .map{width:min(360px,80%); color:var(--brand); filter:drop-shadow(0 18px 30px rgba(27,80,179,.25))}
.brasil-art .pin{position:absolute; width:14px;height:14px;border-radius:50%;
  background:var(--gold); box-shadow:0 0 0 6px rgba(200,162,74,.25)}
.brasil-art .pin::after{content:""; position:absolute; inset:0; border-radius:50%;
  background:var(--gold); animation:pulse 2.6s var(--ease) infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.7}70%{transform:scale(3);opacity:0}100%{opacity:0}}

/* ---------- Legislação ---------- */
.leg-tools{display:flex; gap:.8rem; flex-wrap:wrap; align-items:center; margin-bottom:1.6rem}
.search{flex:1; min-width:240px; position:relative}
.search input{width:100%; padding:.85rem 1rem .85rem 2.7rem; border:1px solid var(--line-strong);
  border-radius:var(--r-pill); font-size:1rem; font-family:var(--sans); background:#fff; color:var(--ink)}
.search input:focus{outline:none; border-color:var(--brand); box-shadow:0 0 0 4px var(--brand-50)}
.search svg{position:absolute; left:1rem; top:50%; transform:translateY(-50%); width:18px;height:18px;color:var(--muted)}
.filters{display:flex; gap:.4rem; flex-wrap:wrap}
.fbtn{font-family:var(--sans); font-weight:600; font-size:.85rem; padding:.55rem .9rem;
  border:1px solid var(--line-strong); background:#fff; color:var(--muted); border-radius:var(--r-pill); cursor:pointer; transition:.18s}
.fbtn:hover{border-color:var(--brand); color:var(--brand)}
.fbtn.active{background:var(--brand); border-color:var(--brand); color:#fff}
.leg-list{display:grid; gap:.7rem}
.leg-item{display:flex; gap:1rem; align-items:center; background:#fff; border:1px solid var(--line);
  border-radius:var(--r); padding:1rem 1.2rem; box-shadow:var(--shadow-sm); transition:.18s var(--ease)}
.leg-item:hover{border-color:var(--brand); transform:translateX(3px); box-shadow:var(--shadow)}
.leg-badge{flex:0 0 auto; font-size:.68rem; font-weight:700; letter-spacing:.06em; padding:.3rem .55rem;
  border-radius:6px; text-transform:uppercase}
.b-ANVISA{background:#E7F0FC; color:#15448E}
.b-INMETRO{background:#FBEFD9; color:#8A6418}
.b-MTP{background:#E9F6EC; color:#1d6e36}
.b-GUIA{background:#EEEAFB; color:#5840a8}
.b-LEI{background:#F0EEEA; color:#5b5345}
.leg-main{flex:1; min-width:0}
.leg-main b{display:block; font-size:1rem; color:var(--ink); font-weight:700}
.leg-main span{display:block; font-size:.9rem; color:var(--muted); margin-top:.15rem}
.leg-item .dl{flex:0 0 auto; width:42px;height:42px;border-radius:12px; display:grid;place-items:center;
  background:var(--brand-50); color:var(--brand); transition:.18s}
.leg-item:hover .dl{background:var(--brand); color:#fff}
.leg-item .dl svg{width:20px;height:20px}
.leg-empty{display:none; text-align:center; color:var(--muted); padding:2rem}

/* ---------- Tabelas (Taxas) ---------- */
.table-card{background:#fff; border:1px solid var(--line); border-radius:var(--r);
  box-shadow:var(--shadow-sm); overflow:hidden; margin-bottom:1.8rem}
.table-card>h3{padding:1.1rem 1.3rem; margin:0; font-size:1.18rem; color:#fff;
  background:linear-gradient(120deg,var(--navy),var(--brand)); display:flex; align-items:center; gap:.6rem}
.table-card>h3 svg{width:22px;height:22px; color:var(--gold)}
.table-scroll{overflow-x:auto}
table.taxas{width:100%; border-collapse:collapse; font-size:.92rem; min-width:760px}
table.taxas th, table.taxas td{padding:.8rem 1rem; text-align:right; border-bottom:1px solid var(--line)}
table.taxas th:first-child, table.taxas td:first-child{text-align:left}
table.taxas thead th{background:var(--paper); color:var(--ink); font-weight:700; font-size:.78rem;
  letter-spacing:.03em; text-transform:uppercase; position:sticky; top:0}
table.taxas tbody tr:hover{background:var(--brand-50)}
table.taxas td:first-child{color:var(--ink); font-weight:600}
table.taxas .isento{color:#1d6e36; font-weight:700}
table.taxas td.val{font-variant-numeric:tabular-nums; color:var(--text)}

/* ---------- Accordion (não-correlatos) ---------- */
.acc{display:grid; gap:.7rem}
.acc-item{background:#fff; border:1px solid var(--line); border-radius:var(--r); overflow:hidden; box-shadow:var(--shadow-sm)}
.acc-head{width:100%; text-align:left; background:none; border:0; cursor:pointer;
  padding:1.1rem 1.3rem; display:flex; align-items:center; gap:.9rem; font-family:var(--sans)}
.acc-head:hover{background:var(--paper)}
.acc-head .n{flex:0 0 auto; width:34px;height:34px;border-radius:9px; display:grid;place-items:center;
  background:var(--brand-50); color:var(--brand); font-weight:700; font-size:.9rem}
.acc-head b{flex:1; color:var(--ink); font-size:1.02rem; font-weight:700}
.acc-head .ct{font-size:.78rem; color:var(--muted); background:var(--paper-2); padding:.2rem .55rem; border-radius:var(--r-pill)}
.acc-head .chev{width:20px;height:20px; color:var(--muted); transition:.25s}
.acc-item.open .chev{transform:rotate(180deg)}
.acc-body{max-height:0; overflow:hidden; transition:max-height .35s var(--ease)}
.acc-body .inner{padding:0 1.3rem 1.2rem 1.3rem}
.acc-body ul{columns:2; column-gap:2rem; margin:0; padding-left:1.1rem; color:var(--muted); font-size:.92rem}
.acc-body li{margin:.2rem 0; break-inside:avoid}

/* ---------- Formulário de contato ---------- */
.contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:2.4rem; align-items:start}
.form-card{background:#fff; border:1px solid var(--line); border-radius:var(--r-lg);
  box-shadow:var(--shadow); padding:1.9rem}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:1rem}
.field{margin-bottom:1rem}
.field label{display:block; font-size:.82rem; font-weight:700; color:var(--ink); margin-bottom:.35rem; letter-spacing:.01em}
.field label .req{color:var(--brand)}
.field input, .field select, .field textarea{width:100%; padding:.8rem .95rem; border:1px solid var(--line-strong);
  border-radius:var(--r-sm); font-size:1rem; font-family:var(--sans); color:var(--ink); background:#fff; transition:.16s}
.field input:focus, .field select:focus, .field textarea:focus{outline:none; border-color:var(--brand); box-shadow:0 0 0 4px var(--brand-50)}
.field textarea{resize:vertical; min-height:120px}
.checks{display:grid; gap:.5rem; grid-template-columns:1fr 1fr}
.check{display:flex; align-items:flex-start; gap:.55rem; font-size:.9rem; color:var(--text); cursor:pointer;
  padding:.6rem .7rem; border:1px solid var(--line); border-radius:var(--r-sm); transition:.16s; background:#fff}
.check:hover{border-color:var(--brand); background:var(--brand-50)}
.check input{width:18px;height:18px; margin-top:1px; accent-color:var(--brand); flex:0 0 auto}
.hp{position:absolute; left:-9999px; opacity:0; height:0; width:0}
.form-note{font-size:.82rem; color:var(--muted); margin-top:.4rem}

.alert{padding:1rem 1.2rem; border-radius:var(--r); margin-bottom:1.2rem; font-size:.96rem; display:flex; gap:.7rem; align-items:flex-start}
.alert svg{width:22px;height:22px;flex:0 0 auto;margin-top:1px}
.alert-ok{background:#E9F6EC; color:#16572c; border:1px solid #BBE3C5}
.alert-err{background:#FCEDEC; color:#8a2820; border:1px solid #F2C5C0}

/* aside de contato */
.contact-aside .info{display:grid; gap:1rem}
.info-item{display:flex; gap:.9rem; align-items:flex-start; background:#fff; border:1px solid var(--line);
  border-radius:var(--r); padding:1.1rem 1.2rem; box-shadow:var(--shadow-sm)}
.info-item .ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;flex:0 0 auto;
  background:var(--brand-50); color:var(--brand)}
.info-item .ic svg{width:22px;height:22px}
.info-item b{display:block; color:var(--ink); font-size:.95rem}
.info-item span, .info-item a{display:block; color:var(--muted); font-size:.95rem}

/* ---------- CTA faixa ---------- */
.cta-band{border-radius:var(--r-lg); padding:clamp(2rem,5vw,3.4rem); text-align:center; position:relative; overflow:hidden}
.cta-band h2{font-size:clamp(1.6rem,3.4vw,2.4rem); margin-bottom:.6rem}
.cta-band p{max-width:60ch; margin:0 auto 1.6rem; color:#C7D6EC}
.cta-actions{display:flex; gap:.8rem; justify-content:center; flex-wrap:wrap}

/* ---------- Rodapé ---------- */
footer.site{background:var(--ink); color:#A9BCD6; padding:3.4rem 0 1.6rem; font-size:.95rem}
.foot-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1.1fr; gap:2rem}
footer.site img.flogo{height:62px; margin-bottom:1rem}
footer.site h4{color:#fff; font-family:var(--sans); font-size:.82rem; letter-spacing:.12em; text-transform:uppercase; margin:0 0 1rem; font-weight:700}
footer.site ul{list-style:none; margin:0; padding:0; display:grid; gap:.55rem}
footer.site a{color:#A9BCD6}
footer.site a:hover{color:#fff}
.foot-contact li{display:flex; gap:.55rem; align-items:flex-start}
.foot-contact svg{width:17px;height:17px;flex:0 0 auto;margin-top:3px;color:var(--gold)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12); margin-top:2.4rem; padding-top:1.4rem;
  display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; color:#7E91AC; font-size:.85rem}

/* ---------- WhatsApp flutuante ---------- */
.wa-float{position:fixed; right:20px; bottom:20px; z-index:70; width:58px;height:58px;border-radius:50%;
  background:#1FA855; color:#fff; display:grid; place-items:center; box-shadow:0 12px 30px rgba(31,168,85,.4);
  transition:.2s var(--ease)}
.wa-float:hover{transform:scale(1.08); color:#fff}
.wa-float svg{width:30px;height:30px}

/* ---------- Page hero (interno) ---------- */
.page-hero{background:
   radial-gradient(900px 500px at 100% -30%, rgba(200,162,74,.14), transparent 55%),
   radial-gradient(900px 500px at 0% 120%, rgba(27,80,179,.10), transparent 55%),
   linear-gradient(180deg,var(--paper),#fff); border-bottom:1px solid var(--line)}
.page-hero .container{padding-block:clamp(2.6rem,5vw,4rem)}
.page-hero h1{font-size:clamp(1.9rem,4vw,2.9rem); letter-spacing:-.01em; margin:.7rem 0 .6rem}
.page-hero p{font-size:1.1rem; color:var(--muted); max-width:60ch; margin:0}
.crumb{font-size:.84rem; color:var(--muted-2)}
.crumb a{color:var(--muted)}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0; transform:translateY(22px); transition:.7s var(--ease)}
.reveal.in{opacity:1; transform:none}

/* ===================================================================
   RESPONSIVO
   =================================================================== */
@media (max-width:980px){
  .hero .container{grid-template-columns:1fr; gap:2.4rem}
  .hero-visual{order:-1; max-width:420px; margin-inline:auto}
  .grid-3{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr}
  .media, .media.rev{grid-template-columns:1fr; direction:ltr; gap:1.6rem}
  .media.rev .media-fig{order:-1}
  .brasil-wrap{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:860px){
  .menu, .nav-cta .btn-ghost{display:none}
  .burger{display:inline-flex}
  .menu.open{display:flex; position:absolute; top:86px; right:16px; left:16px;
    flex-direction:column; align-items:stretch; background:#fff; border:1px solid var(--line);
    border-radius:var(--r); box-shadow:var(--shadow-lg); padding:.6rem; gap:.1rem}
  .menu.open>a, .menu.open .has-sub>button{width:100%; justify-content:space-between; padding:.85rem .9rem}
  .menu.open .submenu{position:static; opacity:1; visibility:visible; transform:none; box-shadow:none;
    border:0; border-left:2px solid var(--brand-50); margin:.1rem 0 .3rem .8rem; padding:.2rem; min-width:auto}
  .menu.open .has-sub:not(.open) .submenu{display:none}
}
@media (max-width:620px){
  body{font-size:16px}
  .stats{grid-template-columns:1fr 1fr}
  .grid-3, .grid-2{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .form-row, .checks{grid-template-columns:1fr}
  .acc-body ul{columns:1}
  .foot-grid{grid-template-columns:1fr}
  .topbar .container{justify-content:center}
  .topbar .hide-sm{display:none}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none !important; transition:none !important; scroll-behavior:auto}
  .reveal{opacity:1; transform:none}
}
