/* ============================================================
   Viasoft Pay — site-v2 · Design System
   Base: conselho-design.md §2 · identidade canônica
   Magenta é tinta de destaque, nunca papel de parede.
   ============================================================ */

:root{
  /* PALETA — canônica */
  --magenta:#FF0646;        --magenta-esc:#E00440;   --magenta-rosa:#F56388;   --magenta-vinho:#481323;
  --amarelo:#FFC000;        --amarelo-ambar:#F7B427;
  --navy:#0F2D52;           --navy-900:#091C33;
  --cinza:#E7E7E7;          --cinza-borda:#D8D8D8;
  --cinza-texto:#5A5A5A;    --branco:#FFFFFF;         --off-white:#FAFAFA;
  --tinta:#0E1726;

  /* GRADIENTES — só em superfície de marca contida */
  --grad-magenta:linear-gradient(135deg,#FF0646 0%,#481323 100%);
  --grad-magenta-radial:radial-gradient(120% 120% at 75% 28%,#F56388 0%,#FF0646 45%,#481323 100%);
  --grad-amarelo:linear-gradient(135deg,#FFC000 0%,#F7B427 100%);
  --grad-navy:linear-gradient(150deg,#0F2D52 0%,#091C33 100%);
  --grad-navy-radial:radial-gradient(120% 120% at 75% 28%,#2E558A 0%,#0F2D52 45%,#050E1C 100%);

  /* TIPOGRAFIA */
  --font:'Aptos','Plus Jakarta Sans','Inter',system-ui,-apple-system,'Segoe UI',sans-serif;
  --fw-regular:400; --fw-medium:500; --fw-bold:700; --fw-black:800;

  /* ESCALA fluida */
  --fs-display:clamp(2.4rem,3.2vw + 1rem,3.7rem);
  --fs-h1:clamp(2rem,3vw + 1rem,3.1rem);
  --fs-h2:clamp(1.55rem,2vw + .75rem,2.35rem);
  --fs-h3:1.3rem;  --fs-h4:1.0625rem;
  --fs-body:1.0625rem;  --fs-small:.9375rem;  --fs-micro:.78rem;
  --lh-tight:1.08; --lh-head:1.18; --lh-body:1.62;

  /* ESPAÇO */
  --s1:.25rem; --s2:.5rem; --s3:.75rem; --s4:1rem; --s5:1.5rem;
  --s6:2rem;   --s7:3rem;  --s8:4.5rem; --s9:6.5rem; --s10:9rem;
  --container:1180px; --container-wide:1320px;
  --pad:clamp(1.15rem,4vw,2.25rem);

  /* RADIUS — squircle canônico */
  --r-sm:10px;   --r-card:24px;  --r-card-lg:32px;  --r-pill:999px;

  /* SOMBRA */
  --sh-sm:0 1px 3px rgba(14,23,38,.06),0 2px 8px rgba(14,23,38,.05);
  --sh-md:0 6px 20px rgba(14,23,38,.08),0 2px 6px rgba(14,23,38,.05);
  --sh-lg:0 20px 50px rgba(14,23,38,.12);
  --sh-card:0 22px 45px rgba(255,6,70,.16);
  --sh-focus:0 0 0 3px rgba(255,6,70,.35);

  --ease:.18s cubic-bezier(.4,0,.2,1);
}

/* ---- Plus Jakarta Sans self-hosted (variável 400–800), sem render-blocking de 3rd-party ---- */
@font-face{
  font-family:'Plus Jakarta Sans';font-style:normal;font-weight:400 800;font-display:swap;
  src:url('../assets/fonts/pjs-latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF;
}
@font-face{
  font-family:'Plus Jakarta Sans';font-style:normal;font-weight:400 800;font-display:swap;
  src:url('../assets/fonts/pjs-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
/* âncoras pousam abaixo do header sticky (senão ele cobre o alvo) */
[id]{scroll-margin-top:112px}
body{
  font-family:var(--font);font-size:var(--fs-body);line-height:var(--lh-body);
  color:var(--tinta);background:var(--branco);font-weight:var(--fw-regular);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  /* sem ligaduras: na PJS o "fi"/"ti" funde (o f come o ponto do i, ex. "fidelidade") */
  font-variant-ligatures:no-common-ligatures;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
:focus-visible{outline:none;box-shadow:var(--sh-focus);border-radius:6px}
/* Skip-link: invisível até receber foco por teclado */
.skip-link{position:fixed;left:var(--s4);top:var(--s4);z-index:100;
  background:var(--magenta);color:#fff;padding:var(--s2) var(--s4);border-radius:var(--r-sm);
  font-weight:var(--fw-bold);transform:translateY(-150%);transition:transform var(--ease)}
.skip-link:focus{transform:translateY(0)}
body.no-scroll{overflow:hidden}

/* ---- Layout ---- */
.container{max-width:var(--container);margin-inline:auto;padding-inline:var(--pad)}
.container-wide{max-width:var(--container-wide);margin-inline:auto;padding-inline:var(--pad)}
.section{padding-block:var(--s8)}
.section-sm{padding-block:var(--s7)}
.section + .section,.section + .section-sm,.section-sm + .section,.section-sm + .section-sm{padding-top:var(--s6)}
/* o wrapper .dx-fusao não pode quebrar o ritmo de adjacência das seções */
.dx-fusao > .section:first-child,.dx-fusao + .section{padding-top:var(--s6)}
.section-light{background:var(--off-white)}
.section-navy{background:var(--grad-navy-radial);color:#fff}
.center{text-align:center}
.mw-720{max-width:720px}
.mw-840{max-width:840px}
.mx-auto{margin-inline:auto}
.mb-2{margin-bottom:var(--s2)}.mb-4{margin-bottom:var(--s4)}.mb-5{margin-bottom:var(--s5)}
.mb-6{margin-bottom:var(--s6)}.mb-7{margin-bottom:var(--s7)}.mt-4{margin-top:var(--s4)}
.mt-5{margin-top:var(--s5)}.mt-6{margin-top:var(--s6)}.mt-7{margin-top:var(--s7)}
.grid{display:grid;gap:var(--s5)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.g2{grid-template-columns:repeat(2,1fr)}

/* ---- Tipografia ---- */
h1,h2,h3,h4{line-height:var(--lh-head);color:var(--navy);font-weight:var(--fw-bold)}
.display{font-size:var(--fs-display);font-weight:var(--fw-black);line-height:var(--lh-tight);letter-spacing:-.025em}
h1,.h1{font-size:var(--fs-h1);font-weight:var(--fw-black);letter-spacing:-.02em}
h2,.h2{font-size:var(--fs-h2);font-weight:var(--fw-bold)}
h3{font-size:var(--fs-h3)}
.section-navy h1,.section-navy h2,.section-navy h3,
.on-brand h1,.on-brand h2,.on-brand h3,.on-brand h4,
.faixa-mig h1,.faixa-mig h2,.bif h1,.bif h2,.bif h3,
.calc h1,.calc h2,.calc h3,.prova-real h1,.prova-real h2,.prova-real h3{color:#fff}
.lead{font-size:1.18rem;line-height:1.55;color:var(--cinza-texto);max-width:60ch}
.section-navy .lead{color:rgba(255,255,255,.85)}
p{max-width:68ch}
.mw-720 p + p,.mw-840 p + p{margin-top:var(--s5)}
/* Respiro em artigos de conteúdo */
article > h2,article > h3{margin-top:var(--s7)}
article > p,article > ul,article > ol,article > blockquote{margin-top:var(--s4)}
article > :first-child{margin-top:0}
/* Prose direta dentro do container (sem wrapper mw-*): mantém measure confortável */
.section > .container > h2,.section > .container > h3,.section > .container > h4{max-width:56rem}
.section > .container > p,.section > .container > ul.taglist,.section > .container > ul.sem-list,.section > .container > .rubrica{max-width:72ch}
/* Em container centralizado, a caixa de medida confortável precisa de margin auto
   pra ficar de fato no centro (senão alinha à esquerda e só o texto interno centraliza) */
.center.container > h2,.center.container > h3,.center.container > h4,
.center.container > p,.center.container > .rubrica{margin-inline:auto}
.eyebrow + h1,.eyebrow + h2,.eyebrow + h3{margin-top:var(--s4)}
.eyebrow{display:inline-block;font-size:var(--fs-small);font-weight:var(--fw-bold);
  text-transform:uppercase;letter-spacing:.1em;color:var(--magenta);margin-bottom:var(--s3)}
.section-navy .eyebrow,.on-brand .eyebrow,.calc .eyebrow{color:var(--amarelo)}
.rubrica{display:flex;gap:6px;align-items:center;margin:var(--s3) 0 var(--s5)}
.rubrica i{display:block;height:4px;border-radius:2px;background:var(--magenta)}
.rubrica i:nth-child(1){width:48px}.rubrica i:nth-child(2){width:12px}.rubrica i:nth-child(3){width:8px}
.center .rubrica{justify-content:center}
.small{font-size:var(--fs-small)}
.micro{font-size:var(--fs-micro);color:var(--cinza-texto)}
.txt-cinza{color:var(--cinza-texto)}
.txt-magenta{color:var(--magenta);font-weight:var(--fw-bold)}
/* Componente padrão "Base legal" — claim ancorado em lei, não em promessa da Viasoft Pay (pedido Jurídico mai/2026) */
.base-legal{display:flex;gap:.5rem;align-items:flex-start;font-size:var(--fs-micro);
  color:var(--cinza-texto);line-height:1.5;border-top:1px solid var(--cinza-borda);
  margin-top:var(--s4);padding-top:var(--s3)}
.base-legal::before{content:"§";flex:none;font-weight:800;color:var(--navy);
  font-size:.95rem;line-height:1.45}
.base-legal b,.base-legal strong{color:var(--navy);font-weight:600}
.base-legal a{color:var(--navy);text-decoration:underline;text-underline-offset:2px}
.base-legal--selo,.section > .container > p.base-legal--selo{border:1px solid var(--cinza-borda);border-radius:var(--r-sm);
  padding:var(--s3) var(--s4);background:var(--off-white);max-width:none}
/* base-legal sobre fundo escuro (on-brand / section-navy) */
.on-brand .base-legal,.section-navy .base-legal{color:rgba(255,255,255,.72);
  border-top-color:rgba(255,255,255,.22)}
.on-brand .base-legal::before,.section-navy .base-legal::before{color:var(--amarelo)}
.on-brand .base-legal b,.on-brand .base-legal strong,
.section-navy .base-legal b,.section-navy .base-legal strong{color:#fff}
.on-brand .base-legal a,.section-navy .base-legal a{color:var(--amarelo)}
/* respiro entre a linha de base legal e o CTA logo abaixo */
.base-legal + .btn,.base-legal + .cta-row{margin-top:var(--s6)}
@media (max-width:560px){.base-legal{font-size:.72rem}}
strong{font-weight:var(--fw-bold)}

/* ---- Botões ---- */
.btn{display:inline-flex;align-items:center;gap:.5rem;justify-content:center;
  padding:15px 30px;border-radius:var(--r-pill);font-weight:var(--fw-bold);
  font-size:var(--fs-body);line-height:1;transition:transform var(--ease),background var(--ease),box-shadow var(--ease),gap var(--ease)}
.btn:active{transform:scale(.985)}
.btn-primary{background:var(--magenta);color:#fff}
.btn-primary:hover{background:var(--magenta-esc);transform:translateY(-2px);box-shadow:0 10px 24px rgba(255,6,70,.32)}
.btn-secondary{background:var(--navy);color:#fff}
.btn-secondary:hover{background:var(--navy-900);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--magenta);box-shadow:inset 0 0 0 2px var(--magenta)}
.btn-outline:hover{background:var(--magenta);color:#fff}
.btn-on-brand{background:transparent;color:#fff;box-shadow:inset 0 0 0 2px rgba(255,255,255,.8)}
.btn-on-brand:hover{background:#fff;color:var(--magenta)}
.btn-amarelo{background:var(--amarelo);color:var(--navy)}
.btn-amarelo:hover{background:var(--amarelo-ambar);transform:translateY(-2px)}
.btn-ghost{color:var(--magenta);padding:8px 0}
.btn-ghost:hover{color:var(--magenta-esc);gap:.85rem}
.btn-lg{padding:18px 38px;font-size:1.0625rem}
.btn[disabled]{opacity:.45;pointer-events:none}
.cta-row{display:flex;gap:var(--s4);flex-wrap:wrap}
.cta-row.center{justify-content:center}
.cta-sub{font-size:var(--fs-small);color:var(--cinza-texto);margin-top:var(--s4)}
.section-navy .cta-sub{color:rgba(255,255,255,.7)}

/* ---- Aros concêntricos (assinatura silenciosa, de canto) ---- */
.aros{position:absolute;pointer-events:none;width:520px;height:520px;border-radius:50%;
  border:1.5px solid currentColor;opacity:.12}
.aros::before,.aros::after{content:"";position:absolute;border-radius:50%;border:1.5px solid currentColor}
.aros::before{inset:60px}.aros::after{inset:130px}
.aros-tr{top:-180px;right:-180px;color:var(--magenta);opacity:.15}
.aros-br{bottom:-200px;right:-160px;color:#fff;opacity:.10}
.aros-bl{bottom:-200px;left:-180px;color:var(--magenta);opacity:.09}

/* ============== HEADER (2 linhas) ============== */
.header{position:sticky;top:0;z-index:60;background:#fff}
.header-util{background:var(--off-white);border-bottom:1px solid var(--cinza);
  font-size:var(--fs-small);transition:max-height var(--ease),padding var(--ease);overflow:hidden;max-height:48px}
.header.scrolled .header-util{max-height:0;padding-block:0;border-bottom:0}
.header-util .container{display:flex;justify-content:space-between;align-items:center;min-height:40px;gap:var(--s4)}
.util-left{display:flex;gap:var(--s5);align-items:center;flex-wrap:wrap}
.util-left .strong{font-weight:var(--fw-bold);color:var(--tinta)}
.util-left a{color:var(--cinza-texto);transition:color var(--ease)}
.util-left a:hover{color:var(--magenta)}
.util-right{color:var(--cinza-texto);white-space:nowrap}
.util-right b{color:var(--magenta)}
.util-right a{color:var(--magenta);font-weight:var(--fw-bold);display:inline-flex;align-items:center;gap:6px}
.util-right a svg{width:14px;height:14px;fill:currentColor;flex:none}
.util-right a:hover{text-decoration:underline}
.header-nav{border-bottom:1px solid var(--cinza)}
.header.scrolled .header-nav{box-shadow:var(--sh-sm)}
.header-nav .container{display:flex;align-items:center;gap:var(--s6);min-height:80px}
/* LOGO — regra de marca: só magenta (#FF0646) sobre fundo claro OU branca
   sobre fundo escuro. Nunca outra cor, nunca distorcer (width:auto sempre).
   IMPRESSÃO (folder A4 etc.): largura mínima 1,5 cm pra preservar leitura —
   regra de arte-final, não do site. Equivalente web: nunca abaixo de ~110px
   de largura / ~30px de altura. Produção: exportar SVG do .ai oficial
   (header magenta; footer/escuro: SVG branco de verdade no lugar do filtro). */
.header-nav .logo{flex:none}
.header-nav .logo img{height:50px;width:auto;aspect-ratio:312.45/329.45;min-height:44px;max-width:none;display:block}
.nav-links{display:flex;gap:var(--s6);margin-left:var(--s4)}
.nav-links a{font-weight:var(--fw-medium);position:relative;padding:6px 0;color:var(--tinta)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--magenta);transition:width var(--ease)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{margin-left:auto;display:flex;gap:var(--s4);align-items:center}
.nav-sec{font-weight:var(--fw-medium);color:var(--cinza-texto)}
.nav-sec:hover{color:var(--magenta)}
.burger{display:none;margin-left:auto;width:44px;height:44px;align-items:center;justify-content:center}
.burger span,.burger span::before,.burger span::after{content:"";display:block;width:24px;height:2px;background:var(--navy);position:relative;transition:var(--ease)}
.burger span::before{position:absolute;top:-7px}.burger span::after{position:absolute;top:7px}
.drawer{position:fixed;inset:0 0 0 auto;width:min(86vw,360px);background:#fff;z-index:90;
  transform:translateX(100%);transition:transform .25s ease;padding:var(--s6) var(--s5);
  box-shadow:var(--sh-lg);overflow-y:auto;display:flex;flex-direction:column;gap:var(--s4)}
.drawer.open{transform:translateX(0)}
.drawer a{padding:12px 4px;font-size:1.15rem;font-weight:var(--fw-medium);border-bottom:1px solid var(--cinza)}
.drawer .drawer-util{font-size:var(--fs-small);color:var(--cinza-texto);margin-top:var(--s4)}
/* links do "Já é cliente?" no drawer: tocáveis de verdade (antes era texto morto) */
.drawer .drawer-util a{display:inline-flex;align-items:center;min-height:44px;
  padding:0 var(--s1);border-bottom:none;font-size:var(--fs-small);font-weight:var(--fw-bold);
  color:var(--magenta);text-decoration:underline;text-underline-offset:3px}
.drawer .drawer-util__label{display:block;margin-bottom:2px;font-weight:var(--fw-bold);color:var(--navy)}
.drawer-close{align-self:flex-end;font-size:1.6rem;color:var(--cinza-texto);width:40px;height:40px}
.scrim{position:fixed;inset:0;background:rgba(14,23,38,.45);z-index:85;opacity:0;pointer-events:none;transition:opacity var(--ease)}
.scrim.open{opacity:1;pointer-events:auto}

/* ============== HERO ============== */
.hero{position:relative;overflow:hidden;background:var(--off-white)}
.hero .container{display:grid;grid-template-columns:1.05fr .95fr;gap:var(--s7);
  align-items:center;padding-block:var(--s8)}
.hero-copy{position:relative;z-index:2}
.hero-copy .display{color:var(--navy);margin-bottom:var(--s5)}
.hero-copy .lead{margin-bottom:var(--s6)}
.hero-art{position:relative;display:flex;justify-content:center;align-items:center;min-height:340px}
.hero-art .brand-pane{position:absolute;inset:8% 4%;background:var(--grad-magenta-radial);
  border-radius:var(--r-card-lg);box-shadow:var(--sh-lg)}
/* <picture> usado pra poupar o webp no mobile não pode virar flex item: some do layout */
.hero-art picture{display:contents}
.hero-art img.cartao{position:relative;z-index:3;max-width:78%;aspect-ratio:1501/936;transform:rotate(-11deg);
  filter:drop-shadow(0 28px 40px rgba(255,6,70,.30))}
.hero-art img.mascote{position:relative;z-index:3;max-width:60%;filter:drop-shadow(0 16px 26px rgba(14,23,38,.18))}
.hero-art:has(img.mascote) .brand-pane{display:none}
.hero-mini-link{font-size:var(--fs-small);color:var(--cinza-texto);margin-top:var(--s5)}
.hero-mini-link a{color:var(--magenta);font-weight:var(--fw-medium);border-bottom:1px solid currentColor}
.hero--solo .container{grid-template-columns:1.1fr .9fr}
.hero--short .container{padding-top:var(--s8);padding-bottom:var(--s5);grid-template-columns:1fr}
.hero--short .hero-art{display:none}
.hero--short + .section,.hero--short + .section-sm{padding-top:var(--s7)}
.hero--art .hero-art{display:flex;min-height:auto;margin-top:var(--s5)}
.hero--art .brand-pane{display:none}
.hero--art .hero-art img.mascote{max-width:190px}

/* ============== FAIXA MIGRAÇÃO ============== */
.faixa-mig{background:var(--grad-magenta);color:#fff;position:relative;overflow:hidden}
.faixa-mig::after{content:"";position:absolute;width:380px;height:380px;border-radius:50%;border:1.5px solid rgba(255,255,255,.13);right:-150px;bottom:-170px;pointer-events:none}

.faixa-mig .container{display:flex;align-items:center;gap:var(--s6);padding-block:var(--s6);flex-wrap:wrap}
.faixa-mig .fm-txt{flex:1;min-width:260px}
.faixa-mig h2{color:#fff;font-size:1.5rem;margin-bottom:var(--s2)}
.faixa-mig p{color:rgba(255,255,255,.9);margin:0}
.faixa-mig .via{height:112px;width:auto;aspect-ratio:1;align-self:flex-end}

/* ============== CARDS ============== */
.card{display:flex;flex-direction:column;background:#fff;border-radius:var(--r-card);box-shadow:var(--sh-sm);padding:var(--s6);transition:transform var(--ease),box-shadow var(--ease)}
.card h3{margin-bottom:var(--s4)}
.card > .btn:last-child{margin-top:auto}
.card:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}

/* número */
.num-card{background:#fff;border-radius:var(--r-card);box-shadow:var(--sh-sm);
  padding:var(--s6) var(--s5);text-align:center;border-top:4px solid var(--amarelo);
  display:flex;flex-direction:column}
.num-card .num{font-size:clamp(2.1rem,3vw + 1rem,3rem);font-weight:var(--fw-black);
  color:var(--navy);letter-spacing:-.03em;line-height:1.1;
  min-height:2.2em;display:flex;align-items:center;justify-content:center}
.num-card .num span{font-size:.45em;color:var(--cinza-texto);font-weight:var(--fw-bold)}
.num-card .lbl{font-size:var(--fs-small);color:var(--cinza-texto);margin-top:var(--s3)}
.num-card--destaque{background:var(--grad-magenta-radial);border-top-color:var(--amarelo);color:#fff}
.num-card--destaque .num{color:#fff}
.num-card--destaque .num span{color:var(--amarelo)}
.num-card--destaque .lbl{color:rgba(255,255,255,.9)}

/* compromisso */
.comp-card{background:#fff;border-radius:var(--r-card);box-shadow:var(--sh-sm);
  padding:var(--s6);border-top:4px solid var(--magenta)}
.comp-card .ico{width:44px;height:44px;border-radius:50%;background:rgba(255,6,70,.10);
  color:var(--magenta);display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin-bottom:var(--s4)}
.comp-card .subj{font-size:var(--fs-small);font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:.08em;color:var(--magenta);margin-bottom:4px}
.comp-card .num{font-size:2rem;font-weight:var(--fw-black);color:var(--navy);line-height:1.05;margin-bottom:var(--s3)}
.comp-card .num span{font-size:.5em;color:var(--cinza-texto)}
.comp-card .lbl{font-weight:var(--fw-bold);color:var(--navy);margin:var(--s2) 0}
.comp-card .desc{font-size:var(--fs-small);color:var(--cinza-texto)}

/* produto */
.prod-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s5)}
.prod-card{background:#fff;border-radius:var(--r-card);box-shadow:var(--sh-sm);
  padding:var(--s6);display:flex;flex-direction:column;gap:var(--s3);transition:transform var(--ease),box-shadow var(--ease)}
.prod-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
.prod-card .pimg{height:118px;display:flex;align-items:center;justify-content:center}
.prod-card .pimg img{max-height:118px;width:auto;aspect-ratio:1501/936;transform:rotate(-7deg);filter:drop-shadow(0 14px 22px rgba(255,6,70,.18));transition:transform var(--ease)}
.prod-card:hover .pimg img{transform:rotate(-3deg) scale(1.04)}
.prod-card h3{font-size:1.15rem}
.prod-card p{font-size:var(--fs-small);color:var(--cinza-texto);flex:1}
.prod-card .arrow{color:var(--magenta);font-weight:var(--fw-bold);font-size:var(--fs-small)}
.prod-card.destaque{grid-column:span 2;background:var(--grad-magenta-radial);color:#fff;
  flex-direction:row;align-items:center;gap:var(--s5)}
.prod-card.destaque h3,.prod-card.destaque p{color:#fff}
.prod-card.destaque .arrow{color:var(--amarelo)}
.prod-card.destaque .pimg img{max-height:160px}
.prod-card.cta-multipay{background:var(--grad-navy-radial);color:#fff}
.prod-card.cta-multipay h3,.prod-card.cta-multipay p{color:#fff}
.prod-card.cta-multipay .arrow{color:var(--amarelo)}
.prod-card.cta-multipay .pimg img{filter:drop-shadow(0 14px 22px rgba(0,0,0,.45))}
.selo{display:inline-block;background:var(--amarelo);color:var(--navy);font-size:var(--fs-micro);
  font-weight:var(--fw-bold);text-transform:uppercase;letter-spacing:.06em;padding:5px 12px;border-radius:var(--r-pill)}

/* caso */
.caso-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s5)}
.caso-card{background:#fff;border-radius:var(--r-card);box-shadow:var(--sh-sm);
  padding:var(--s6);border-left:4px solid var(--magenta)}
.caso-card .tag{display:inline-block;background:var(--cinza);color:var(--cinza-texto);
  font-size:var(--fs-micro);text-transform:uppercase;letter-spacing:.05em;padding:4px 10px;border-radius:var(--r-pill);margin-bottom:var(--s4)}
.caso-card .num{font-size:1.55rem;font-weight:var(--fw-black);color:var(--navy);line-height:1.15;margin-bottom:var(--s3)}
.caso-card p{font-size:var(--fs-small);color:var(--cinza-texto)}
.quote{background:#fff;border-left:4px solid var(--magenta);border-radius:var(--r-card);
  padding:var(--s7);box-shadow:var(--sh-sm);max-width:840px;margin:var(--s7) auto 0}
.quote .q{font-size:1.3rem;line-height:1.5;color:var(--tinta)}
.quote .a{margin-top:var(--s4);font-size:var(--fs-small);color:var(--cinza-texto)}
.quote .a strong{color:var(--navy)}

/* tabela comparativa */
.cmp{width:100%;border-collapse:collapse;border-radius:var(--r-card);overflow:hidden;box-shadow:var(--sh-sm);background:#fff}
.cmp th,.cmp td{padding:16px 18px;text-align:left;font-size:var(--fs-small);border-bottom:1px solid var(--cinza)}
.cmp thead th{font-size:var(--fs-small);font-weight:var(--fw-bold)}
.cmp .c-crit{background:var(--off-white);font-weight:var(--fw-bold);color:var(--cinza-texto);width:34%}
.cmp .c-mkt{background:var(--cinza);color:var(--cinza-texto)}
.cmp thead .c-vp{background:var(--magenta);color:#fff}
.cmp tbody .c-vp{background:rgba(255,6,70,.05);font-weight:var(--fw-medium);color:var(--tinta)}
.cmp-foot{font-size:var(--fs-micro);color:var(--cinza-texto);margin-top:var(--s3)}

/* timeline */
.timeline{display:grid;grid-auto-flow:column;grid-auto-columns:1fr;gap:var(--s4);position:relative;margin-top:var(--s6)}
.timeline::before{content:"";position:absolute;top:23px;left:8%;right:8%;height:2px;background:var(--cinza)}
.tl-step{text-align:center;position:relative;z-index:1}
.tl-step .dot{width:48px;height:48px;border-radius:50%;background:var(--magenta);color:#fff;
  font-weight:var(--fw-bold);display:flex;align-items:center;justify-content:center;margin:0 auto var(--s3);
  box-shadow:0 0 0 4px #fff,var(--sh-sm)}
.tl-step:last-child .dot{background:var(--amarelo);color:var(--navy)}
.tl-step h3{font-size:var(--fs-h4);margin-bottom:4px;min-height:2.4em;display:flex;align-items:center;justify-content:center}
.tl-step p{font-size:var(--fs-small);color:var(--cinza-texto);margin-inline:auto;max-width:24ch;min-height:4.2em}
/* Subtítulo de card (mesmo tamanho do h4, mas semanticamente h3 sob o h2 da seção) */
.card-sub{font-size:var(--fs-h4);margin:0 0 1.1rem}

/* lista "não cobramos" */
.sem-list{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s3) var(--s6);margin:var(--s5) 0}
.sem-list--3{grid-template-columns:repeat(3,1fr)}
.sem-list li{display:flex;gap:var(--s3);align-items:center;font-weight:var(--fw-medium)}
.sem-list .x{width:28px;height:28px;border-radius:50%;background:rgba(255,6,70,.10);color:var(--magenta);
  display:flex;align-items:center;justify-content:center;flex:none;font-weight:var(--fw-bold)}
/* Lista de categorias em chips (ex.: "Onde aceita") — substitui a lista de pontinhos */
.taglist{display:flex;flex-wrap:wrap;gap:var(--s2) var(--s3);margin:var(--s5) 0;padding:0;list-style:none}
.taglist li{display:inline-flex;align-items:center;background:var(--off-white);
  border:1px solid var(--cinza-borda);color:var(--navy);font-size:var(--fs-small);
  font-weight:var(--fw-medium);padding:.4rem .9rem;border-radius:var(--r-pill)}
/* Lista numerada (ex.: "os cinco pilares") — conjunto ordenado, escaneável */
.pilares{display:grid;gap:var(--s3);margin-top:var(--s5);counter-reset:pilar;padding:0;list-style:none}
.pilares li{display:grid;grid-template-columns:auto 1fr;gap:var(--s4);align-items:start;
  background:#fff;border:1px solid var(--cinza-borda);border-radius:var(--r-card);padding:var(--s4) var(--s5)}
.pilares li::before{counter-increment:pilar;content:counter(pilar);width:34px;height:34px;
  border-radius:50%;background:var(--magenta);color:#fff;font-weight:var(--fw-bold);font-size:.95rem;
  display:flex;align-items:center;justify-content:center;flex:none}
.pilares h3{font-size:1.05rem;margin:0 0 .2rem;color:var(--navy)}
.pilares p{font-size:var(--fs-small);color:var(--cinza-texto);margin:0}
.so-mdr{background:var(--grad-magenta);color:#fff;border-radius:var(--r-card);padding:var(--s5) var(--s6);
  font-size:1.2rem;font-weight:var(--fw-bold);text-align:center;margin-top:var(--s4)}

/* banda mdr */
.banda{margin:var(--s6) 0}
.banda-bar{height:46px;border-radius:var(--r-pill);background:var(--grad-amarelo);
  position:relative;display:flex;align-items:center;justify-content:space-between;padding:0 22px;
  color:var(--navy);font-weight:var(--fw-bold);font-size:var(--fs-small)}
.banda-tags{display:flex;justify-content:space-between;margin-top:var(--s3);font-size:var(--fs-micro);color:var(--cinza-texto)}
.box-num{background:var(--off-white);border-radius:var(--r-card);padding:var(--s6);border:1px solid var(--cinza)}
.box-num h3{margin-bottom:var(--s3)}

/* FAQ accordion */
.faq details{background:#fff;border-radius:var(--r-card);box-shadow:var(--sh-sm);margin-bottom:var(--s3);overflow:hidden}
.faq summary{list-style:none;padding:18px var(--s5);font-weight:var(--fw-bold);color:var(--navy);
  display:flex;justify-content:space-between;align-items:center;gap:var(--s4);cursor:pointer}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";width:30px;height:30px;border-radius:50%;background:rgba(255,6,70,.08);
  color:var(--magenta);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex:none;transition:var(--ease)}
.faq details[open] summary{background:var(--off-white)}
.faq details[open] summary::after{content:"–";transform:rotate(180deg)}
.faq .ans{padding:0 var(--s5) 20px;color:var(--cinza-texto);font-size:var(--fs-small)}

/* formulário */
.form-card{background:#fff;border-radius:var(--r-card);box-shadow:var(--sh-md);padding:var(--s7)}
.field{margin-bottom:var(--s4)}
.field label{display:block;font-size:var(--fs-small);font-weight:var(--fw-bold);color:var(--cinza-texto);margin-bottom:6px}
.field input,.field select{width:100%;padding:14px 16px;border:1px solid var(--cinza-borda);
  border-radius:var(--r-sm);font-family:inherit;font-size:var(--fs-body);background:#fff;transition:var(--ease)}
.field input:focus,.field select:focus{outline:none;border-color:var(--magenta);box-shadow:var(--sh-focus)}
.toggle{display:flex;gap:var(--s2);background:var(--off-white);padding:5px;border-radius:var(--r-pill);margin-bottom:var(--s4)}
.toggle button{flex:1;padding:10px;border-radius:var(--r-pill);font-weight:var(--fw-bold);font-size:var(--fs-small);color:var(--cinza-texto)}
.toggle button.on{background:var(--magenta);color:#fff}
.form-msg{padding:var(--s5);border-radius:var(--r-card);background:rgba(255,6,70,.06);
  border-left:4px solid var(--magenta);font-weight:var(--fw-medium);color:var(--navy)}
.form-foot{font-size:var(--fs-micro);color:var(--cinza-texto);margin-top:var(--s4)}
.hidden{display:none}
/* honeypot anti-spam: invisível pra humano, submetível por bot */
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
/* caixa de erro de envio do formulário */
.form-erro{background:rgba(255,6,70,.06);border-left:4px solid var(--magenta);color:var(--navy);
  padding:var(--s4);border-radius:var(--r-sm);font-weight:var(--fw-medium);margin-bottom:var(--s4)}
.cf-turnstile{margin-bottom:var(--s4)}

/* roteamento (sou-usuario) */
.rot-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s5)}
.rot-card{background:#fff;border-radius:var(--r-card);box-shadow:var(--sh-sm);padding:var(--s6);
  display:flex;flex-direction:column;gap:var(--s3)}
.rot-card .ico{width:46px;height:46px;border-radius:50%;background:var(--magenta);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:1.3rem}
.rot-card h2{font-size:1.15rem}
.rot-card p{font-size:var(--fs-small);color:var(--cinza-texto);flex:1}

/* bloco "Já é cliente" / portais */
.portais{background:var(--cinza);border-radius:var(--r-card-lg);padding:var(--s7)}
.portais .grid{grid-template-columns:repeat(4,1fr)}
.portal-tile{background:#fff;border-radius:var(--r-card);padding:var(--s5);text-align:center;transition:var(--ease)}
.portal-tile:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}
.portal-tile .ico{width:40px;height:40px;border-radius:50%;background:rgba(255,6,70,.10);color:var(--magenta);
  display:flex;align-items:center;justify-content:center;margin:0 auto var(--s3)}
.portal-tile b{display:block;color:var(--navy)}
.portal-tile span{font-size:var(--fs-micro);color:var(--cinza-texto)}

/* bifurcação */
.bifurc{display:grid;grid-template-columns:1fr 1fr;gap:var(--s5)}
.bif{border-radius:var(--r-card-lg);padding:var(--s8) var(--s7);color:#fff}
.bif.emp{background:var(--grad-magenta)}
.bif.est{background:var(--grad-navy-radial)}
.bif h3{color:#fff;font-size:1.6rem;margin-bottom:var(--s3)}
.bif p{color:rgba(255,255,255,.85);margin-bottom:var(--s5)}
.bloco-parc{background:var(--off-white);border-radius:var(--r-card);padding:var(--s6);
  display:flex;align-items:center;justify-content:space-between;gap:var(--s5);margin-top:var(--s5);flex-wrap:wrap}

/* logos */
.logos{display:flex;flex-wrap:wrap;gap:var(--s5);justify-content:center;align-items:center}
.logo-tile{background:var(--off-white);border-radius:var(--r-sm);padding:18px 26px;color:var(--cinza-texto);
  font-weight:var(--fw-bold);min-width:130px;text-align:center}
/* mural de logos — célula fixa 240x120, tratamento monocromático pra paridade visual */
.logo-wall{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--s4);align-items:stretch}
.logo-wall .cell{background:var(--off-white);border-radius:var(--r-card);min-height:108px;
  display:flex;align-items:center;justify-content:center;padding:18px 22px;transition:var(--ease)}
.logo-wall .cell:hover{box-shadow:var(--sh-sm);transform:translateY(-2px)}
.logo-wall .cell img{max-height:56px;max-width:170px;width:auto;object-fit:contain;
  filter:grayscale(1);opacity:.62;transition:var(--ease)}
.logo-wall .cell:hover img{filter:grayscale(0);opacity:1}
.logo-wall .cell .ph{color:var(--cinza-texto);font-weight:var(--fw-bold);font-size:.95rem;
  letter-spacing:.01em;text-align:center;opacity:.7}
/* variante "compatível com" — leve, pra marcas de terceiros (não é wall of fame).
   Cor original em repouso (o lojista reconhece a maquininha de imediato), sem caixa
   nem borda, logos menores/sutis. Flex+wrap centraliza inclusive a última linha. */
.logo-wall--compat{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--s4)}
.logo-wall--compat .cell{flex:0 0 auto;width:124px;min-height:auto;background:transparent;border:none;border-radius:0;padding:6px 10px}
.logo-wall--compat .cell:hover{box-shadow:none;transform:none}
.logo-wall--compat .cell img{filter:none;opacity:1;max-height:29px;max-width:100px}
.logo-wall--compat .cell:hover img{filter:none;opacity:1}
.logo-wall--compat .cell .ph{font-weight:var(--fw-medium);font-size:.82rem;opacity:.85}
@media(max-width:980px){.logo-wall{grid-template-columns:repeat(3,1fr)}}
@media(max-width:620px){.logo-wall{grid-template-columns:repeat(2,1fr)}.logo-wall .cell{min-height:84px;min-width:0}.logo-wall .cell img{max-width:100%}}

/* perfil parceiro */
.perfil-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s5)}
.perfil-grid--3{grid-template-columns:repeat(3,1fr)}
.perfil{background:var(--grad-navy-radial);color:#fff;border-radius:var(--r-card);box-shadow:var(--sh-sm);padding:var(--s7) var(--s6);text-align:center;transition:transform var(--ease),box-shadow var(--ease)}
.perfil:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
.perfil h3{color:#fff;margin:var(--s4) 0 var(--s4);font-size:1.2rem}
.perfil p{color:rgba(255,255,255,.85);margin:0;font-size:var(--fs-small);line-height:1.55}
.perfil .ico{width:56px;height:56px;border-radius:50%;background:var(--amarelo);color:var(--navy);font-size:1.5rem;
  display:flex;align-items:center;justify-content:center;margin:0 auto var(--s4);font-size:1.3rem}
.prova-real{background:var(--grad-navy-radial);color:#fff;border-radius:var(--r-card-lg);padding:var(--s7);text-align:center}
.prova-real p{color:rgba(255,255,255,.92);font-size:1.15rem;margin-inline:auto;max-width:60ch}

/* calculadora estática */
.calc{background:var(--grad-navy-radial);color:#fff;border-radius:var(--r-card-lg);padding:var(--s8);text-align:center}
.calc .out{font-size:clamp(2.4rem,5vw,3.6rem);font-weight:var(--fw-black);color:var(--amarelo);margin:var(--s4) 0}
.calc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s4);max-width:680px;margin:var(--s5) auto}
.calc .field label{color:rgba(255,255,255,.8)}
.calc .field input,.calc .field select{background:rgba(255,255,255,.95)}

/* mapa escritórios */
.mapa{display:grid;grid-template-columns:1.4fr 1fr;gap:var(--s7);align-items:center}
.mapa ul li{padding:10px 0;border-bottom:1px solid var(--cinza);display:flex;justify-content:space-between}
.mapa .sede{color:var(--magenta);font-weight:var(--fw-bold)}
.mapa-svg{background:var(--off-white);border-radius:var(--r-card);padding:var(--s6);min-height:300px;
  display:flex;align-items:center;justify-content:center}

/* split genérico */
.split{display:grid;grid-template-columns:1fr 1fr;gap:var(--s7);align-items:center}
.split.on-brand{background:var(--grad-navy-radial);color:#fff;border-radius:var(--r-card-lg);padding:var(--s8)}
.split .pts{display:flex;flex-direction:column;gap:var(--s4);margin:var(--s5) 0}
.split .pt{display:flex;gap:var(--s4);align-items:flex-start}
.split .pt .ck{width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.14);color:var(--amarelo);
  display:flex;align-items:center;justify-content:center;flex:none;font-weight:var(--fw-bold)}
.split .art{display:flex;justify-content:center}
.split .art img{max-width:80%;transform:rotate(-8deg);filter:drop-shadow(0 22px 36px rgba(0,0,0,.30))}

/* listas de conteúdo */
.list-card{display:grid;gap:var(--s5);grid-template-columns:repeat(2,1fr)}
.list-card a.li{background:#fff;border-radius:var(--r-card);box-shadow:var(--sh-sm);padding:var(--s6);transition:var(--ease);display:block}
.list-card a.li:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
.list-card .li h2,.list-card .li h3{font-size:1.15rem;margin-bottom:var(--s2)}
.list-card .li p{font-size:var(--fs-small);color:var(--cinza-texto)}
.prose{max-width:760px;margin-inline:auto}
.prose h2{margin:var(--s7) 0 var(--s3)}
.prose p,.prose li{margin-bottom:var(--s4);color:var(--tinta)}
.prose ul{list-style:disc;padding-left:1.4rem}

/* Citação do fundador (página sobre) */
.cite-fundador{margin:var(--s7) 0 0;padding:var(--s4) 0 var(--s4) var(--s5);
  border-left:3px solid var(--magenta);max-width:760px}
.cite-fundador p{font-size:1.2rem;line-height:1.45;color:var(--navy);
  font-weight:var(--fw-medium);margin:0 0 var(--s3);font-style:italic}
.cite-fundador footer{font-size:var(--fs-small);color:var(--cinza-texto)}
.cite-fundador footer strong{color:var(--magenta);font-weight:var(--fw-bold)}

/* Cards de valores (página sobre) */
.valores-list{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--s4)}
.valor-card{display:flex;flex-direction:column;gap:var(--s3);
  background:var(--grad-navy-radial);color:#fff;border-radius:var(--r-card);
  padding:var(--s5);box-shadow:var(--sh-sm);
  transition:transform var(--ease),box-shadow var(--ease)}
.valor-card:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
.valor-num{font-size:2rem;font-weight:var(--fw-black);color:var(--amarelo);line-height:1;letter-spacing:-.02em}
.valor-body h3{color:#fff;margin:0 0 var(--s2);font-size:1.05rem;font-weight:var(--fw-bold);line-height:1.25}
.valor-body p{color:rgba(255,255,255,.85);margin:0;font-size:var(--fs-small);line-height:1.5}
@media (max-width:1024px){.valores-list{grid-template-columns:repeat(3,1fr)}}
@media (max-width:640px){.valores-list{grid-template-columns:1fr}}

/* ============== FOOTER ============== */
.footer{background:var(--grad-navy);color:#fff;position:relative;overflow:hidden;padding-block:var(--s8) var(--s6)}
.footer .cols{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;gap:var(--s6)}
.footer .f-logo{height:54px;min-height:46px;width:auto;aspect-ratio:312.45/329.45;margin-bottom:var(--s4)}
.footer p{color:rgba(255,255,255,.75);font-size:var(--fs-small)}
.footer .footer-hours{margin-top:var(--s4)}
.footer h4{color:var(--amarelo);font-size:var(--fs-small);text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--s4)}
.footer ul li{margin-bottom:10px}
.footer ul a{color:rgba(255,255,255,.8);font-size:var(--fs-small);transition:var(--ease)}
.footer ul a:hover{color:var(--amarelo)}
.footer .base{border-top:1px solid rgba(255,255,255,.14);margin-top:var(--s7);padding-top:var(--s5);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:var(--s4);font-size:var(--fs-micro);color:rgba(255,255,255,.6)}
.footer .base a{color:rgba(255,255,255,.6)}
.footer .base a:hover{color:#fff}
/* Título de coluna é um botão (vira accordion no mobile); no desktop, indistinguível do h4 */
.footer .ft-tg{display:flex;width:100%;align-items:center;justify-content:space-between;gap:var(--s3);
  background:none;border:0;padding:0;font:inherit;color:inherit;text-align:left;cursor:default}
@media (max-width:620px){
  .footer .ft-tg{cursor:pointer;min-height:44px}
  .footer .ft-tg::after{content:"▾";font-size:1rem;opacity:.7}
  .footer .ft-off .ft-tg::after{content:"▸"}
  .footer .ft-off ul{display:none}
  .footer h4{margin-bottom:var(--s2)}
}

/* ============== RESPONSIVO ==============
   Breakpoints canônicos (mobile-first por max-width):
     1024px — tablet largo: grids de 5→3 colunas (ex. .valores-list)
      980px — tablet: nav vira burger; grids de 4→2 e 3→1; hero empilha
      640px — phone largo: grids finos colapsam (ex. .valores-list→1)
      620px — phone: tudo em 1 coluna; tabela .cmp vira cards; timeline empilha
      560px — phone estreito: ajustes finos de tipografia (ex. .base-legal)
   Regras responsivas específicas de um componente ficam ao lado dele
   (ex. .logo-wall em 980/620 acima); as regras globais ficam neste bloco. */
@media (max-width:980px){
  .hero .container,.hero--solo .container{grid-template-columns:1fr;padding-block:var(--s8)}
  .hero--short .container{padding-top:var(--s7);padding-bottom:var(--s5)}
  .hero-art{order:-1;min-height:240px}
  .g4,.prod-grid,.perfil-grid,.portais .grid{grid-template-columns:repeat(2,1fr)}
  .g3,.caso-grid,.rot-grid,.list-card{grid-template-columns:1fr}
  .split,.mapa,.bifurc{grid-template-columns:1fr}
  .prod-card.destaque{grid-column:span 2;flex-direction:column}
  .nav-links,.nav-cta,.util-left a{display:none}
  .burger{display:flex}
  .footer .cols{grid-template-columns:1fr 1fr}
}
@media (max-width:620px){
  .g4,.prod-grid,.g2,.perfil-grid,.portais .grid,.footer .cols{grid-template-columns:1fr}
  .timeline{grid-auto-flow:row;grid-auto-columns:auto}
  .timeline::before{display:none}
  .sem-list{grid-template-columns:1fr}
  .cmp thead{display:none}
  .cmp,.cmp tbody,.cmp tr,.cmp td{display:block;width:100%}
  .cmp tr{margin-bottom:var(--s4);border-radius:var(--r-card);overflow:hidden;box-shadow:var(--sh-sm)}
  .cmp td{border:none;border-bottom:1px solid var(--cinza)}
  .cmp td.c-mkt::before{content:"Mercado nacional: ";font-weight:var(--fw-bold)}
  .cmp td.c-vp::before{content:"Viasoft Pay: ";font-weight:var(--fw-bold);color:var(--magenta)}
  /* critério vira título do card full-width (corrige o 34% herdado da tabela desktop) */
  .cmp td.c-crit{width:100%;background:var(--off-white);color:var(--navy);font-size:var(--fs-body);font-weight:var(--fw-bold)}
  .faixa-mig .via{height:68px}
  .display{font-size:2.4rem}
  .calc{padding:var(--s7) var(--s5)}
  .calc-grid{grid-template-columns:1fr}
}

/* ============================================================
   MOBILE UX — redesign mobile-first (arquétipo)
   Tudo aqui é mobile-only: vive dentro de @media, não toca o desktop.
   Componentes reutilizáveis nas 36 páginas:
     .sticky-cta            barra de ação fixa (conversão sempre à mão)
     .rail-m / .rail-sm-m   trilho horizontal com swipe (mata a "linguiça")
     .g-2-m / .g-2c-m       2 colunas compactas (stats/compromissos)
   Régua: docs/plano-mobile-ux-criterios.md
   ============================================================ */

/* — Densidade: seções e hero mais curtos no celular — */
@media (max-width:620px){
  .section{padding-block:var(--s7)}
  .section + .section,.section + .section-sm,.section-sm + .section,.section-sm + .section-sm{padding-top:var(--s6)}
  .mb-7{margin-bottom:var(--s5)}
  /* Hero: card menor e CTA acima da dobra; botões full-width pra toque */
  .hero .container,.hero--solo .container{padding-block:var(--s6) var(--s7);gap:var(--s5)}
  .hero-art{min-height:auto;order:-1}
  .hero-art .brand-pane{inset:10% 12%}
  .hero-art img.cartao{max-width:60%}
  .hero-copy .display{margin-bottom:var(--s4)}
  .hero-copy .lead{margin-bottom:var(--s5)}
  .hero .cta-row{gap:var(--s3)}
  .hero .cta-row .btn{width:100%}
  /* Painéis de padding pesado (s8/s7): enxugar no celular — densidade + evita
     overflow em 320px, onde o padding lateral fixo estourava o container */
  .bif{padding:var(--s6) var(--s5)}
  .bifurc{gap:var(--s4)}
  /* Faixa de migração: esconder o mascote no mobile (economiza dobra nobre) */
  .faixa-mig .via{display:none}
  /* Multipay: card do produto primeiro (âncora visual), lista mais compacta */
  .split.on-brand{padding:var(--s5)}
  .split.on-brand .art{order:-1;margin-bottom:var(--s3)}
  .split.on-brand .art img{max-width:58%;transform:rotate(-6deg)}
  .split .pts{gap:var(--s3);margin:var(--s4) 0}
  .split .pt{gap:var(--s3)}
  .split .pt > div:last-child{line-height:1.5}
  /* sem o check no mobile (SÓ no Multipay/on-brand): respiro + hierarquia do título
     já fazem a "lista"; libera a largura horizontal toda pro texto */
  .split.on-brand .pt .ck{display:none}
  .split.on-brand .pts{gap:var(--s4)}
}

/* — Números: 2 colunas compactas (troca a coluna única longa) — */
@media (max-width:620px){
  .g-2-m{grid-template-columns:1fr 1fr;gap:var(--s3)}
  .g-2-m .num-card{padding:var(--s5) var(--s3)}
  .g-2-m .num-card .num{min-height:1.5em;font-size:1.85rem}
}
/* — Compromissos: linha compacta (ícone à esquerda) em vez de boxes altos — */
@media (max-width:620px){
  .g-2c-m{grid-template-columns:1fr;gap:var(--s3)}
  .g-2c-m .comp-card{
    display:grid;grid-template-columns:auto 1fr;
    grid-template-areas:"ico subj" "ico num" "ico desc";
    column-gap:var(--s4);row-gap:0;align-items:center;
    padding:var(--s4) var(--s5);
    border-top:none;border-left:4px solid var(--magenta);
  }
  .g-2c-m .comp-card .ico{grid-area:ico;align-self:center;margin:0;width:42px;height:42px}
  .g-2c-m .comp-card .subj{grid-area:subj;margin:0}
  .g-2c-m .comp-card .num{grid-area:num;font-size:1.4rem;margin:0;line-height:1.15}
  .g-2c-m .comp-card .desc{grid-area:desc;margin-top:3px}
}
/* — Cards de princípio/valor (ícone + título + texto): linha compacta genérica.
     Funciona com qualquer estrutura interna (usa posicionamento por coluna, não áreas fixas). — */
@media (max-width:620px){
  .comp-row-m{grid-template-columns:1fr;gap:var(--s3)}
  .comp-row-m .comp-card{
    display:grid;grid-template-columns:auto 1fr;column-gap:var(--s4);align-items:center;
    padding:var(--s4) var(--s5);border-top:none;border-left:4px solid var(--magenta)
  }
  .comp-row-m .comp-card .ico{grid-column:1;grid-row:1 / -1;align-self:center;margin:0;width:42px;height:42px}
  .comp-row-m .comp-card > :not(.ico){grid-column:2;margin:0}
  .comp-row-m .comp-card .desc{margin-top:3px}
  /* Form-card: padding mais enxuto no celular */
  .form-card{padding:var(--s5)}
}

/* — Trilho horizontal (swipe): listas longas deixam de empilhar — */
@media (max-width:620px){
  .rail-m{
    display:grid;
    grid-auto-flow:column;
    grid-auto-columns:80%;
    grid-template-columns:none !important;
    gap:var(--s4);
    overflow-x:auto;
    overflow-y:visible;
    scroll-snap-type:x mandatory;
    scroll-padding-inline:var(--pad);
    margin-inline:calc(var(--pad) * -1);
    padding:var(--s1) var(--pad) var(--s4);
    scrollbar-width:none;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior-x:contain;
  }
  .rail-m::-webkit-scrollbar{display:none}
  .rail-m > *{scroll-snap-align:start;margin:0}
  /* trilho de itens pequenos (logos): mostra mais por tela */
  .rail-sm-m{grid-auto-columns:42%}
  .rail-sm-m .cell{min-height:92px}
  /* dica de "tem mais ao lado" */
  .rail-hint{display:block;font-size:var(--fs-micro);color:var(--cinza-texto);
    text-align:center;margin-top:var(--s2)}
  .rail-hint::after{content:" →"}
}
@media (min-width:621px){.rail-hint{display:none}}

/* — Barra de CTA fixa (mobile): conversão sempre acessível (G1) — */
.sticky-cta{display:none}
@media (max-width:980px){
  .sticky-cta{
    display:flex;gap:var(--s3);align-items:stretch;
    position:fixed;left:0;right:0;bottom:0;z-index:70;
    padding:var(--s3) var(--pad);
    padding-bottom:calc(var(--s3) + env(safe-area-inset-bottom));
    background:rgba(255,255,255,.92);
    -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
    border-top:1px solid var(--cinza);
    box-shadow:0 -6px 22px rgba(14,23,38,.10);
  }
  .sticky-cta .btn{flex:1;padding:14px 18px;font-size:1rem}
  .sticky-cta__icon{
    flex:none;width:54px;border-radius:var(--r-pill);
    background:var(--navy);color:#fff;
    display:flex;align-items:center;justify-content:center;
    transition:background var(--ease)}
  .sticky-cta__icon:hover{background:var(--navy-900)}
  .sticky-cta__icon svg{width:26px;height:26px;fill:currentColor}
  /* não deixar a barra cobrir o fim da página */
  body{padding-bottom:calc(76px + env(safe-area-inset-bottom))}
}

/* ============================================================
   MOBILE CRO — arquétipo Empresas (opt-in por página: <body class="m-cro">)
   Eleva o mobile de "compacto" pra "que converte": pitch na 1ª dobra,
   um CTA sólido por momento, comparativo em cards "versus".
   Tudo mobile-only; o desktop não enxerga nada daqui.
   ============================================================ */
@media (max-width:620px){
  /* 1ª dobra = pitch: a arte sai, copy + CTA + prova assumem a dobra */
  .m-cro .hero-art{display:none}
  .m-cro .hero .lead{font-size:1.05rem}
  /* um botão sólido por dobra: o secundário do hero vira link discreto */
  .m-cro .hero .cta-row .btn-secondary{background:none;color:var(--navy);
    width:auto;margin-inline:auto;padding:10px var(--s4);min-height:44px;font-weight:var(--fw-bold);
    text-align:center;line-height:1.5;text-decoration:underline;
    text-underline-offset:3px;text-decoration-thickness:1px}
  .m-cro .hero .cta-row .btn-secondary:hover{background:none;transform:none}
}
/* chips de prova da 1ª dobra (só existem no mobile) */
.proof-m{display:none}
@media (max-width:620px){
  .proof-m{display:grid;grid-template-columns:1fr 1fr;gap:var(--s2);margin-top:var(--s5);padding:0;list-style:none}
  .proof-m li{display:flex;align-items:center;gap:var(--s2);background:var(--off-white);
    border:1px solid var(--cinza);border-radius:var(--r-sm);padding:var(--s2) var(--s3);
    font-size:var(--fs-small);font-weight:var(--fw-bold);color:var(--navy)}
  .proof-m li::before{content:"✓";color:var(--magenta);font-weight:var(--fw-black);flex:none}
}
@media (max-width:620px){
  /* CTAs concorrentes de meio de página viram links: sobra UMA ação primária */
  .m-cro .cta-row .btn-outline,.m-cro .center > .btn-outline{background:none;box-shadow:none;
    color:var(--magenta);padding:10px 0;min-height:44px;font-weight:var(--fw-bold);
    line-height:1.5;text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
  .m-cro .cta-row .btn-outline:hover,.m-cro .center > .btn-outline:hover{background:none;color:var(--magenta-esc)}
  /* Em superfície magenta, secundário continua botão (link sublinhado branco
     reprovaria contraste AA e perderia affordance) */
  /* CTA de navegação em superfície de marca: outline branco (sólido fica
     reservado pra ação de conversão — semântica de cor consistente) */
  .m-cro .split.on-brand .btn-amarelo{background:none;color:#fff;
    box-shadow:inset 0 0 0 2px rgba(255,255,255,.8)}
  /* link ghost flui como texto (a seta não quebra sozinha) */
  .m-cro .cta-row .btn-ghost{display:inline;padding:10px 0}

  /* Migração: passos viram linhas numeradas densas (dot à esquerda) */
  .m-cro .timeline{gap:var(--s3);margin-top:var(--s5)}
  .m-cro .tl-step{display:grid;grid-template-columns:auto 1fr;column-gap:var(--s4);row-gap:2px;
    text-align:left;background:#fff;border:1px solid var(--cinza);border-radius:var(--r-card);
    padding:var(--s4) var(--s5)}
  .m-cro .tl-step .dot{grid-row:1 / span 2;width:34px;height:34px;font-size:.95rem;margin:0;align-self:center}
  .m-cro .tl-step h3{min-height:0;justify-content:flex-start;margin:0}
  .m-cro .tl-step p{min-height:0;max-width:none;margin:0}

  /* PAT: os 3 regimes viram linhas (regime à esquerda, caminho à direita) */
  .num-rows-m{grid-template-columns:1fr;gap:var(--s3)}
  .num-rows-m .num-card{flex-direction:row;align-items:center;gap:var(--s4);
    padding:var(--s4) var(--s5);text-align:left}
  .num-rows-m .num-card .num{font-size:1.05rem;flex:none;width:6.2em;line-height:1.25}
  .num-rows-m .num-card .lbl{margin-top:0}

  /* Calculadora mais densa */
  .m-cro .calc{padding:var(--s6) var(--s4)}
  .m-cro .calc-grid{gap:var(--s3)}

  /* Comparativo: cards "versus" (mercado ✕ / Viasoft ✓) EMPILHADOS — swipe
     esconderia os argumentos anti-incumbente e, sem analytics, não dá pra
     validar; entra colapsado nos 2 critérios decisivos + "ver os outros" */
  .m-cro .cmp{box-shadow:none;background:none;border-radius:0}
  .m-cro .cmp tbody{display:grid;gap:var(--s4)}
  .m-cro .cmp.cmp-colapso-m tr:nth-child(n+3){display:none}
  .m-cro .cmp tr{display:flex;flex-direction:column;width:auto;margin:0;
    border-radius:var(--r-card);overflow:hidden;box-shadow:var(--sh-sm);background:#fff}
  .m-cro .cmp td{border:none;width:auto}
  .m-cro .cmp td.c-crit{padding-bottom:var(--s2)}
  .m-cro .cmp td.c-mkt{background:#fff;flex:1}
  .m-cro .cmp td.c-mkt::before{content:"✕ Mercado";display:block;font-size:var(--fs-micro);
    font-weight:var(--fw-bold);letter-spacing:.06em;text-transform:uppercase;margin-bottom:2px}
  .m-cro .cmp td.c-vp{border-top:1px solid var(--cinza);font-weight:var(--fw-bold);color:var(--navy)}
  .m-cro .cmp td.c-vp::before{content:"✓ Viasoft Pay";display:block;font-size:var(--fs-micro);
    font-weight:var(--fw-bold);letter-spacing:.06em;text-transform:uppercase;color:var(--magenta);margin-bottom:2px}

  /* FAQ: summaries mais densos (mantém alvo de toque ≥44px) */
  .m-cro .faq summary{padding:14px var(--s5)}

  /* Variante m-keep-art (detalhe de produto): o cartão É o produto —
     fica compacto DEPOIS do pitch, em vez de sumir */
  .m-cro.m-keep-art .hero-art{display:flex;order:2;min-height:auto;margin-top:var(--s2)}
  .m-cro.m-keep-art .hero-art img.cartao{max-width:56%}
  .m-cro.m-keep-art .hero-art .brand-pane{inset:12% 14%}
}
/* Variante m-user (páginas de quem já tem cartão): a ação primária do sticky
   JÁ É o WhatsApp — o ícone duplicado sai e o botão ocupa a barra inteira */
@media (max-width:980px){
  .m-user .sticky-cta__icon{display:none}
}
/* Accordion de documento legal (m-legal): o JS agrupa h2 + conteúdo;
   colapsa só no mobile. Sem JS, o documento fica corrido como sempre. */
.leg-tg{display:flex;width:100%;align-items:center;justify-content:space-between;gap:var(--s3);
  background:none;border:0;padding:0;font:inherit;color:inherit;text-align:left;cursor:default}
/* o wrapper .leg-body replica o ritmo de article > * (os filhos saem do seletor direto) */
.leg-body > p,.leg-body > ul,.leg-body > ol,.leg-body > blockquote{margin-top:var(--s4)}
@media (max-width:620px){
  .m-legal .leg-tg{cursor:pointer;min-height:44px}
  .m-legal .leg-tg::after{content:"▸";color:var(--magenta);font-size:1rem}
  .m-legal .leg-tg[aria-expanded="true"]::after{content:"▾"}
  .m-legal .leg-body{display:none}
  .m-legal .leg-body.leg-open{display:block}
}
/* botão que expande o comparativo colapsado (só existe no mobile) */
.cmp-more-m{display:none}
@media (max-width:620px){
  .m-cro .cmp-more-m{display:block;width:100%;min-height:44px;margin-top:var(--s4);
    padding:10px;font-size:var(--fs-body);font-weight:var(--fw-bold);color:var(--magenta);
    text-decoration:underline;text-underline-offset:4px}
  .m-cro .cmp-more-m::after{content:" ▾"}
}
/* Sticky CTA inteligente: entra quando o CTA do hero sai da dobra; some sobre o form */
@media (max-width:980px){
  .m-cro .sticky-cta{transition:transform .25s ease}
  .m-cro .sticky-cta.sticky-cta--off{transform:translateY(130%);pointer-events:none}
}

/* ============================================================
   DX — desktop v5 (opt-in por página: <body class="dx">)
   Credibilidade + conversão no desktop: ritmo entre seções,
   prova com peso, motion sutil. Tudo ≥981px; o mobile aprovado
   não enxerga nada daqui. Sem JS a página fica estática.
   ============================================================ */
/* micro-prova do hero só existe no desktop dx (no mobile a banda vem logo abaixo) */
.hero-prova{display:none}
@media (min-width:981px){
  /* Hero: UMA ação sólida; o secundário vira outline (hierarquia clara) */
  .dx .hero .cta-row .btn-secondary{background:transparent;color:var(--navy);
    box-shadow:inset 0 0 0 2px var(--navy)}
  .dx .hero .cta-row .btn-secondary:hover{background:var(--navy);color:#fff;transform:translateY(-2px)}

  /* Prova: banda navy full-bleed; números nus, sem cartão (peso de verdade) */
  .dx .dx-prova{background:var(--grad-navy-radial)}
  .dx .dx-prova h2{color:#fff}
  .dx .dx-prova .eyebrow{color:var(--amarelo)}
  .dx .dx-prova .rubrica i{background:var(--amarelo)}
  /* texto de apoio dentro da banda: branco suave (txt-cinza seria ilegível no navy) */
  .dx .dx-prova p,.dx .dx-prova .txt-cinza,.dx .dx-prova .lead{color:rgba(255,255,255,.85)}
  .dx .dx-prova .num-card{background:none;box-shadow:none;border:0;padding:var(--s5) var(--s4);
    border-left:1px solid rgba(255,255,255,.14);border-radius:0}
  .dx .dx-prova .num-card:nth-child(3n+1){border-left:0}
  .dx .dx-prova .num-card .num{color:#fff}
  .dx .dx-prova .num-card .num span{color:var(--amarelo)}
  .dx .dx-prova .num-card .lbl{color:rgba(255,255,255,.78)}
  /* dois níveis de prova: 3 argumentos heróis em cima, 3 de sustentação embaixo */
  .dx .dx-prova .num-card:nth-child(-n+3) .num{font-size:3.4rem}
  .dx .dx-prova .num-card:nth-child(n+4){padding-top:var(--s3);padding-bottom:var(--s3)}
  .dx .dx-prova .num-card:nth-child(n+4) .num{font-size:1.6rem}
  .dx .dx-prova .num-card:nth-child(n+4) .lbl{color:rgba(255,255,255,.6);margin-top:2px}

  /* micro-prova do hero (copy aprovada 11/06; só desktop, o mobile tem a banda logo abaixo) */
  .dx .hero-prova{display:block;margin-top:var(--s4);font-size:var(--fs-small);color:var(--cinza-texto)}
  .dx .hero-prova strong{color:var(--navy)}

  /* Fusão de seções navy adjacentes (sobre: porte + presença): a regra da marca
     pede degradê em superfície navy/magenta — então o wrapper pinta UM radial
     abraçando o bloco inteiro e as seções ficam transparentes (sem costura) */
  .dx .dx-fusao{background:var(--grad-navy-radial)}
  .dx .dx-fusao-ini{background:none;padding-bottom:var(--s6)}
  .dx .dx-fusao-fim{background:none;padding-top:0}

  /* Cards respondem ao cursor (profundidade é resposta, não decoração) */
  .dx .comp-card,.dx .prod-card,.dx .caso-card{transition:transform var(--ease),box-shadow var(--ease)}
  .dx .comp-card:hover,.dx .prod-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md)}
  .dx .caso-card:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
  .dx .comp-card .ico{width:54px;height:54px}

  /* A única voz humana da página merece corpo */
  .dx .quote .q{font-size:1.55rem;line-height:1.45}
}
@media (min-width:981px) and (prefers-reduced-motion:no-preference){
  /* Entrada do hero — CSS puro (roda sem JS; morre no reduced-motion) */
  @keyframes dxIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
  .dx .hero-copy > *{animation:dxIn .5s cubic-bezier(.22,.61,.36,1) both}
  .dx .hero-copy > :nth-child(2){animation-delay:.07s}
  .dx .hero-copy > :nth-child(3){animation-delay:.14s}
  .dx .hero-copy > :nth-child(4){animation-delay:.21s}
  .dx .hero-copy > :nth-child(5){animation-delay:.28s}
  .dx .hero-art{animation:dxIn .6s cubic-bezier(.22,.61,.36,1) .1s both}

  /* Reveal ao rolar — classes aplicadas POR JS (sem JS, nada se esconde).
     Vocabulário de 3 papéis, mesma família de easing:
       .dx-rv      anúncio (títulos/blocos de texto): sobe 14px, rápido
       .dx-rv-kids conteúdo (grades de cards): sobe 10px em cascata curta
       .dx-rv-band superfície grande (split/calc/cmp/quote/bifurc): SÓ surge,
                   sem transladar — superfície que se move parece instável */
  .dx .dx-rv{opacity:0;transform:translateY(14px);
    transition:opacity .45s cubic-bezier(.22,.61,.36,1),transform .45s cubic-bezier(.22,.61,.36,1)}
  .dx .dx-rv.rv-in{opacity:1;transform:none}
  .dx .dx-rv-band{opacity:0;transition:opacity .65s cubic-bezier(.22,.61,.36,1)}
  .dx .dx-rv-band.rv-in{opacity:1}
  .dx .dx-rv-kids > *{opacity:0;transform:translateY(10px);
    transition:opacity .4s cubic-bezier(.22,.61,.36,1),transform .4s cubic-bezier(.22,.61,.36,1)}
  .dx .dx-rv-kids.rv-in > *{opacity:1;transform:none}
  .dx .dx-rv-kids.rv-in > :nth-child(2){transition-delay:.05s}
  .dx .dx-rv-kids.rv-in > :nth-child(3){transition-delay:.10s}
  .dx .dx-rv-kids.rv-in > :nth-child(4){transition-delay:.15s}
  .dx .dx-rv-kids.rv-in > :nth-child(5){transition-delay:.20s}
  .dx .dx-rv-kids.rv-in > :nth-child(6){transition-delay:.25s}
  .dx .dx-rv-kids.rv-in > :nth-child(7){transition-delay:.30s}
  .dx .dx-rv-kids.rv-in > :nth-child(8){transition-delay:.35s}
}

@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto}}
