/*
Theme Name: Vexis
Theme URI: https://octavi.com.br
Author: Octavi
Author URI: https://octavi.com.br
Description: Tema do site da Vexis, app de telemedicina. Consulta médica e psicológica online, direto do celular e sem sala de espera.
Version: 1.4.0
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: vexis
Update URI: false
Tags: telemedicina, saúde, consulta médica, consulta psicológica, saúde digital, atendimento online, bem-estar
*/

:root{
  --roxo:#330066; --roxo-700:#45088a; --roxo-soft:#6b3fb0;
  --terra:#CC5533; --terra-int:#B5431F;
  --creme:#F5F3F0; --creme-2:#EFE7DA; --lav:#F3EEFA;
  --ink:#241032; --cinza:#5A575A; --linha:#ece6f3;
  --branco:#fff;
  --radius:18px; --radius-lg:26px;
  --shadow-sm:0 6px 22px rgba(51,0,102,.06);
  --shadow:0 16px 44px rgba(51,0,102,.10);
  --shadow-lg:0 28px 70px rgba(51,0,102,.16);
  --maxw:1180px;
  --pad-sec:clamp(64px,8vw,118px);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:clip}
body{overflow-x:clip}
body{margin:0;font-family:"Poppins",system-ui,sans-serif;color:var(--ink);background:var(--branco);
  font-size:17px;line-height:1.7;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:"Ubuntu",system-ui,sans-serif;color:var(--roxo);line-height:1.12;margin:0;font-weight:700;letter-spacing:-.5px}
p{margin:0}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ====== Acessibilidade ====== */
/* "Pular para o conteúdo": invisível até receber foco pelo teclado (Tab) */
.skip-link{position:fixed;left:12px;top:-100px;z-index:2000;background:var(--roxo);color:#fff;
  font-family:"Ubuntu",sans-serif;font-weight:600;padding:12px 20px;border-radius:0 0 14px 14px;
  box-shadow:var(--shadow);transition:top .18s ease}
.skip-link:focus{top:0}
/* Anel de foco visível para quem navega por teclado (não aparece no clique de mouse) */
:focus-visible{outline:3px solid var(--roxo);outline-offset:3px;border-radius:6px}
/* alvo do skip-link (<main>) não deve mostrar anel ao receber foco programático */
main:focus,main:focus-visible{outline:none}
/* Texto só para leitor de tela (invisível na tela) */
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0}
@media (prefers-reduced-motion:reduce){.skip-link{transition:none}}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:"Ubuntu",sans-serif;font-weight:600;font-size:.8rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--terra-int);margin:0 0 14px}
.eyebrow::before{content:"";width:22px;height:2px;border-radius:2px;background:var(--terra)}
.sec-title{font-size:clamp(1.9rem,3.4vw,2.7rem)}
.lead{color:var(--cinza);font-size:1.06rem;max-width:48ch}
.btn{display:inline-flex;align-items:center;gap:9px;font-family:"Poppins",sans-serif;font-weight:600;
  font-size:.98rem;padding:15px 30px;border-radius:999px;cursor:pointer;transition:.22s;border:2px solid transparent}
.btn-primary{background:var(--roxo);color:#fff}
.btn-primary:hover{background:var(--roxo-700);transform:translateY(-2px);box-shadow:0 12px 26px rgba(51,0,102,.28)}
.btn-ghost{background:transparent;color:var(--roxo);border-color:#d9cdeb}
.btn-ghost:hover{border-color:var(--roxo);background:#faf7fe}
.btn-light{background:#fff;color:var(--roxo)}
.btn-light:hover{transform:translateY(-2px);box-shadow:0 12px 26px rgba(0,0,0,.18)}
.icon{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* ===================== HEADER ===================== */
.topbar{background:var(--roxo);color:#efe7fb;font-size:.84rem}
.topbar .wrap{display:flex;gap:28px;justify-content:center;align-items:center;padding:9px 28px;flex-wrap:wrap}
.topbar span{display:inline-flex;align-items:center;gap:7px}
.topbar .icon{width:16px;height:16px;stroke-width:2.2;opacity:.85}
.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--linha)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;padding:10px 28px}
.logo{display:flex;align-items:center;gap:11px;font-family:"Ubuntu";font-weight:700;font-size:1.5rem;
  color:var(--roxo);letter-spacing:1px}
.logo svg{width:34px;height:34px}
.menu{display:flex;gap:30px;font-weight:500;font-size:.97rem;color:var(--ink)}
.menu a{position:relative;padding:4px 0;color:#2b2336}
.menu a::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:2px;background:var(--terra);transition:.22s}
.menu a:hover{color:var(--roxo)} .menu a:hover::after{width:100%}
.nav-right{display:flex;align-items:center;gap:18px}
.socials{display:flex;gap:10px}
.socials a{width:38px;height:38px;display:grid;place-items:center;border-radius:50%;background:var(--lav);color:var(--roxo);transition:.2s}
.socials a:hover{background:var(--roxo);color:#fff}

/* ===================== HERO ===================== */
.hero{background:radial-gradient(120% 130% at 85% 0%,#efe6fb 0%,#f8f3ee 55%,#fff 100%);position:relative;overflow:hidden}
.hero .wrap{padding:72px 28px 86px} /* grid removido — vazava p/ #vx2/#vx3 (heroes têm grid próprio escopado) */
.hero h1{font-size:clamp(2.5rem,4.7vw,3.7rem);line-height:1.05}
.hero p.sub{margin:22px 0 30px;font-size:1.16rem;color:#4a4257;max-width:30ch}
.hero p.sub b{color:var(--ink)}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-badges{display:flex;gap:26px;margin-top:38px;flex-wrap:wrap}
.hero-badge{display:flex;gap:11px;align-items:flex-start;max-width:215px}
.hero-badge .bi{flex:0 0 auto;width:42px;height:42px;border-radius:12px;background:var(--creme);display:grid;place-items:center;color:var(--roxo)}
.hero-badge b{display:block;font-family:"Ubuntu";font-size:.98rem;color:var(--ink);line-height:1.2;margin-bottom:2px}
.hero-badge small{color:var(--cinza);font-size:.85rem;line-height:1.35}

/* phone */
.hero-visual{position:relative;display:flex;justify-content:center}
.phone{width:288px;border-radius:42px;background:#15032e;padding:11px;box-shadow:var(--shadow-lg);position:relative}
.phone .screen{background:#f6f2fb;border-radius:32px;overflow:hidden;font-size:12px}
.ph-status{display:flex;justify-content:space-between;align-items:center;padding:11px 18px 4px;font-weight:600;color:#2b1c45;font-size:11px}
.ph-status .dots{display:flex;gap:3px}.ph-status .dots i{width:5px;height:5px;border-radius:50%;background:#bda9d6;display:block}
.ph-head{display:flex;justify-content:space-between;align-items:center;padding:6px 18px 12px}
.ph-logo{display:flex;align-items:center;gap:6px;font-family:"Ubuntu";font-weight:700;color:var(--roxo);font-size:13px;letter-spacing:.5px}
.ph-logo svg{width:16px;height:16px}
.ph-bell{width:26px;height:26px;border-radius:50%;background:#fff;display:grid;place-items:center;color:var(--roxo);box-shadow:0 3px 8px rgba(51,0,102,.08)}
.ph-body{padding:2px 16px 16px}
.ph-hi{font-family:"Ubuntu";font-weight:700;color:var(--ink);font-size:16px;margin-bottom:1px}
.ph-hi small{display:block;font-family:"Poppins";font-weight:400;color:#8a7da0;font-size:11px;margin-top:2px}
.ph-card{background:linear-gradient(135deg,var(--roxo),#5a1ea3);color:#fff;border-radius:18px;padding:15px 16px;margin-top:14px;box-shadow:0 12px 24px rgba(51,0,102,.28)}
.ph-tag{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.18);padding:3px 9px;border-radius:999px;font-size:9.5px;font-weight:600;margin-bottom:9px}
.ph-tag i{width:5px;height:5px;border-radius:50%;background:#7CFAC8;display:block}
.ph-card h4{color:#fff;font-size:15px;margin-bottom:5px}
.ph-card p{font-size:10.5px;color:#e4d6fb;line-height:1.45}
.ph-btn{margin-top:12px;background:#fff;color:var(--roxo);font-weight:600;font-size:11px;padding:9px;border-radius:11px;text-align:center}
.ph-doc{display:flex;align-items:center;gap:10px;background:#fff;border-radius:14px;padding:10px 12px;margin-top:12px;box-shadow:0 6px 16px rgba(51,0,102,.06)}
.ph-doc .av{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#caa9f0,#7c4fc0);flex:0 0 auto}
.ph-doc b{font-family:"Ubuntu";font-size:12px;color:var(--ink);display:block;line-height:1.2}
.ph-doc small{color:#8a7da0;font-size:10px}
.ph-doc .on{margin-left:auto;font-size:9px;color:#13b981;display:flex;align-items:center;gap:4px}
.ph-doc .on i{width:6px;height:6px;border-radius:50%;background:#13b981;display:block}
.ph-nav{display:flex;justify-content:space-around;padding:11px 0 12px;border-top:1px solid #eadff7;margin-top:14px;color:#b6a6cf}
.ph-nav svg{width:19px;height:19px}.ph-nav .act{color:var(--roxo)}
/* floating cards */
.float{position:absolute;background:#fff;border-radius:16px;box-shadow:var(--shadow);padding:13px 15px;z-index:3}
.float.f1{top:30px;right:-6px;display:flex;gap:10px;align-items:center;max-width:215px;background:var(--roxo);color:#fff}
.float.f1 .bi{width:34px;height:34px;border-radius:9px;background:rgba(255,255,255,.16);display:grid;place-items:center;flex:0 0 auto}
.float.f1 b{font-family:"Ubuntu";font-size:.82rem;display:block;line-height:1.15}
.float.f1 small{font-size:.72rem;color:#e0d2f7;line-height:1.3}
.float.f2{bottom:46px;left:-22px;display:flex;flex-direction:column;gap:8px;max-width:180px}
.float.f2 b{font-size:.8rem;font-family:"Ubuntu";color:var(--ink)}
.avstack{display:flex}
.avstack i{width:28px;height:28px;border-radius:50%;border:2px solid #fff;margin-left:-9px;display:block}
.avstack i:first-child{margin-left:0}
.avstack .more{background:var(--terra);color:#fff;font-size:.66rem;display:grid;place-items:center;font-weight:600}

/* ===================== STATS ===================== */
/* (.stats base removido — causava o "número espremido": fazia o .wrap virar
   grid de 4 colunas e jogava todo o conteúdo em 1/4 da largura. A home e as
   versões usam stats com escopo próprio #vx*. ) */

/* ===================== ABOUT ===================== */
.about{padding:var(--pad-sec) 0}
/* .about .wrap grid removido — vazava p/ as versões (usam .split escopado) */
.about-media{position:relative}
.about-media img{border-radius:var(--radius-lg);box-shadow:var(--shadow);width:100%;height:430px;object-fit:cover}
.about-stat{position:absolute;left:-18px;bottom:-22px;background:var(--ink);color:#fff;border-radius:18px;padding:20px 24px;box-shadow:var(--shadow);text-align:center}
.about-stat b{font-family:"Ubuntu";font-size:2.1rem;color:#c9a8f5;display:block;line-height:1}
.about-stat small{font-size:.8rem;color:#d8cce9}
.about h2{margin:6px 0 18px}
.about ul{list-style:none;padding:0;margin:22px 0 30px;display:flex;flex-direction:column;gap:13px}
.about li{display:flex;gap:12px;align-items:flex-start;color:#3f3850}
.about li .ck{flex:0 0 auto;width:25px;height:25px;border-radius:50%;background:var(--creme);color:var(--roxo);display:grid;place-items:center}
.about li .ck svg{width:15px;height:15px;stroke-width:2.6}

/* ===================== DIFERENCIAIS ===================== */
.jeito{padding:var(--pad-sec) 0;background:var(--lav)}
.jeito-head{display:grid;grid-template-columns:1.3fr 1fr;gap:40px;align-items:end;margin-bottom:50px}
.jeito-head .r{text-align:right;display:flex;flex-direction:column;align-items:flex-end}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{background:#fff;border-radius:22px;padding:32px 28px;box-shadow:var(--shadow-sm);transition:transform .22s ease,box-shadow .22s ease;border:1px solid rgba(51,0,102,.05)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card .ci{width:56px;height:56px;border-radius:16px;background:var(--creme-2);display:grid;place-items:center;color:var(--roxo);margin-bottom:20px;transition:background .22s ease}
.card:hover .ci{background:var(--lav)}
.card .ci svg{width:27px;height:27px;stroke-width:1.8}
.card h3{font-size:1.18rem;font-weight:600;color:var(--roxo);margin-bottom:9px}
.card p{color:var(--cinza);font-size:.96rem;line-height:1.6}

/* ===================== COMO FUNCIONA ===================== */
.howto{padding:var(--pad-sec) 0}
.howto .head{text-align:center;margin-bottom:54px}
.howto .head .lead{margin:14px auto 0}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;position:relative}
.step{background:#fff;border:1px solid rgba(51,0,102,.05);border-radius:22px;padding:34px 28px;position:relative;overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .22s ease,box-shadow .22s ease}
.step:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.step>*{position:relative;z-index:1}
/* número gigante de fundo (watermark roxo, transborda no canto inferior-direito) — igual à home */
.step .nb{position:absolute;z-index:0;top:auto;right:-14px;bottom:-44px;font-family:"Ubuntu";font-weight:700;font-size:15rem;line-height:.72;color:rgba(51,0,102,.07);-webkit-text-stroke:0;pointer-events:none;user-select:none}
.step h3{font-size:1.16rem;font-weight:600;color:var(--roxo);margin-bottom:10px;position:relative;max-width:82%}
.step p{color:var(--cinza);font-size:.95rem;position:relative}
.step .sk{width:54px;height:54px;border-radius:15px;background:linear-gradient(135deg,var(--roxo),var(--roxo-700));color:#fff;display:grid;place-items:center;margin-bottom:18px;position:relative;box-shadow:0 12px 24px -12px rgba(51,0,102,.6)}
.step .sk svg{width:26px;height:26px}
/* legado: estilo antigo dos passos (mantido p/ compat — markup atual usa .nb/.sk) */
.step .n{position:absolute;top:8px;right:14px;font-family:"Ubuntu";font-weight:700;font-size:4.4rem;color:#f0eaf8;line-height:1;z-index:0}
.step .dot{width:42px;height:42px;border-radius:12px;background:var(--roxo);color:#fff;display:grid;place-items:center;font-family:"Ubuntu";font-weight:700;margin-bottom:18px;position:relative}

/* ===================== POR QUE ===================== */
.why{padding:var(--pad-sec) 0;background:var(--creme)}
/* .why .wrap grid removido — vazava p/ as versões (usam layout escopado) */
.why-list{display:flex;flex-direction:column;gap:18px}
.why-item{display:flex;gap:18px;background:#fff;border-radius:var(--radius);padding:24px 26px;box-shadow:var(--shadow-sm);border:1px solid rgba(51,0,102,.05);transition:transform .22s ease,box-shadow .22s ease}
.why-item:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.why-item .wi{flex:0 0 auto;width:54px;height:54px;border-radius:14px;background:var(--creme-2);color:var(--roxo);display:grid;place-items:center;transition:background .22s ease,color .22s ease}
.why-item:hover .wi{background:var(--terra);color:#fff}
.why-item h3{font-size:1.1rem;margin-bottom:5px}
.why-item p{color:var(--cinza);font-size:.93rem}

/* ===================== CTA ===================== */
/* CTA flutua na EMENDA entre a última seção e o RODAPÉ (páginas internas) */
.cta{position:relative;height:0;padding:0;z-index:5}
.section:has(+ .cta){padding-bottom:calc(96px + 175px)}  /* seção acima: espaço p/ a metade superior do card */
.cta + .footer,
main:has(> .cta:last-child) + .footer{padding-top:calc(96px + 175px)} /* rodapé: espaço p/ a metade inferior do card (CTA dentro de <main>) */
.cta .band{position:absolute;left:50%;top:0;transform:translate(-50%,-50%);width:min(var(--maxw),calc(100% - 48px));margin:0;
  background:linear-gradient(135deg,rgba(51,0,102,.80),rgba(69,8,138,.70)),var(--cta-img,linear-gradient(135deg,var(--roxo),#5a1ea3));
  background-size:cover;background-position:center 35%;background-repeat:no-repeat;background-color:var(--roxo);
  border-radius:var(--radius-lg);padding:clamp(40px,6vw,72px);color:#fff;overflow:hidden;text-align:center;box-shadow:0 26px 60px -20px rgba(0,0,0,.45)}
.cta .band::before,.cta .band::after{content:"";position:absolute;border-radius:50%;background:rgba(255,255,255,.07)}
.cta .band::before{width:280px;height:280px;top:-120px;right:-60px}
.cta .band::after{width:200px;height:200px;bottom:-110px;left:-40px}
.cta h2{color:#fff;font-size:clamp(1.9rem,3.4vw,2.6rem);position:relative}
.cta p{color:#e7dafb;margin:16px auto 28px;max-width:46ch;position:relative}
.cta .btn{position:relative}

/* ===================== DEPOIMENTOS ===================== */
.depo{padding:var(--pad-sec) 0}
.depo .head{text-align:center;margin-bottom:50px}
.depo .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.tcard{background:#fff;border:1px solid var(--linha);border-radius:var(--radius);padding:30px 28px;box-shadow:var(--shadow-sm)}
.tcard .stars{display:flex;gap:3px;color:var(--terra);margin-bottom:14px}
.tcard .stars svg{width:18px;height:18px;fill:var(--terra);stroke:none}
.tcard .q{color:#3b3450;font-size:1.02rem;line-height:1.65;margin-bottom:20px}
.tcard .who{display:flex;align-items:center;gap:12px}
.tcard .who .av{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#caa9f0,#7c4fc0)}
.tcard .who b{font-family:"Ubuntu";font-size:.98rem;color:var(--ink);display:block}
.tcard .who small{color:var(--cinza);font-size:.84rem}

/* ===================== FOOTER ===================== */
.footer{background:var(--roxo);color:#d9cbf0;padding:70px 0 0}
.footer .cols{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1.2fr;gap:36px}
.footer .logo{color:#fff;margin-bottom:16px}
.footer .tag{font-family:"Ubuntu";color:#fff;font-size:1.02rem;margin-bottom:12px}
.footer .aviso{font-size:.8rem;color:#b7a6d6;line-height:1.55;max-width:34ch}
.footer h4{color:#fff;font-size:1rem;margin-bottom:18px;font-family:"Ubuntu"}
.footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:11px;font-size:.92rem}
.footer ul a:hover{color:#fff}
.footer .contact div{margin-bottom:14px}
.footer .contact small{display:block;color:#b7a6d6;font-size:.78rem}
.footer .contact b{font-weight:500;color:#efe7fb;font-size:.92rem}
.footer .fsoc{display:flex;gap:10px;margin-top:6px}
.footer .fsoc a{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.12);display:grid;place-items:center;color:#fff}
.footer .fsoc a:hover{background:#fff;color:var(--roxo)}
.footer .bottom{border-top:1px solid rgba(255,255,255,.14);margin-top:54px;padding:22px 0;
  display:flex;justify-content:space-between;gap:16px;font-size:.85rem;flex-wrap:wrap}
.footer .bottom a{color:#cdbce8;margin-left:22px}

@media(max-width:960px){
  .hero .wrap,.about .wrap,.why .wrap,.jeito-head{grid-template-columns:1fr}
  .jeito-head .r{text-align:left;align-items:flex-start}
  .stats .wrap{grid-template-columns:repeat(2,1fr);gap:30px}
  .cards,.steps,.depo .grid{grid-template-columns:1fr}
  .hero-visual{margin-top:30px}
  .footer .cols{grid-template-columns:1fr 1fr}
}

/* ============================================================
   COMPONENTES DAS PÁGINAS INTERNAS (Para Você, Agende, Faça Parte, FAQ, legais)
   ============================================================ */
/* Banner de página (hero interno) */
.page-hero{position:relative;overflow:hidden;background:linear-gradient(160deg,var(--lav) 0%,var(--creme) 60%,#fff 100%);padding:80px 0 70px;border-bottom:1px solid var(--linha)}
.page-hero::before{content:"";position:absolute;top:-150px;right:-130px;width:460px;height:460px;border-radius:50%;background:radial-gradient(circle,rgba(204,85,51,.11),transparent 68%);pointer-events:none}
.page-hero::after{content:"";position:absolute;bottom:-160px;left:-140px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(51,0,102,.08),transparent 70%);pointer-events:none}
.page-hero .wrap{position:relative}
.page-hero .eyebrow{margin-bottom:16px}
.page-hero h1{font-size:clamp(2.1rem,4.2vw,3.1rem)}
.page-hero .lead{margin-top:16px;max-width:56ch}
.crumb{display:flex;gap:10px;align-items:center;color:var(--cinza);font-size:.9rem;margin-top:18px;font-weight:500}
.crumb a:hover{color:var(--roxo)} .crumb svg{width:15px;height:15px;stroke:var(--cinza);fill:none;stroke-width:2}

/* Section genérica + cabeçalho centrado */
.section{padding:var(--pad-sec) 0}
.section--lav{background:var(--lav)} .section--creme{background:var(--creme)}
.head-center{text-align:center;max-width:680px;margin:0 auto 54px}
.head-center .eyebrow{text-align:center}
.head-center .lead{margin:14px auto 0}

/* Grid utilitário p/ cards */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}

/* Bloco de benefício (linha com ícone) — reusa .why-item */

/* Legais — card de leitura */
.legal{background:#F4F1F8;padding:64px 16px 96px}
.legal .card{max-width:840px;margin:0 auto;background:#fff;border-radius:20px;padding:clamp(28px,5vw,60px);box-shadow:var(--shadow)}
.legal .card .note{background:#F2EEF9;border-left:3px solid var(--roxo-soft);border-radius:10px;padding:14px 18px;margin:0 0 2.2em;font-size:.92rem;color:#615a6b;font-style:italic}
.legal .card h2{font-size:1.3rem;color:var(--roxo);margin:2.2em 0 .6em;padding-top:1.3em;border-top:1px solid var(--linha)}
.legal .card h2:first-of-type{border-top:0;padding-top:0;margin-top:.2em}
.legal .card p{margin:0 0 1.1em;color:#46404d;line-height:1.85}
.legal .card ul{margin:.2em 0 1.4em;padding-left:1.2em;list-style:none}
.legal .card li{position:relative;margin-bottom:.55em;padding-left:1.1em;color:#46404d}
.legal .card li::before{content:"";position:absolute;left:0;top:.72em;width:7px;height:7px;border-radius:50%;background:var(--roxo-soft)}

/* FAQ accordion (native <details>) */
.faq{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq details{background:#fff;border:1px solid var(--linha);border-radius:14px;padding:4px 22px;box-shadow:var(--shadow-sm);transition:.2s}
.faq details[open]{box-shadow:var(--shadow);border-color:#e0d4f3}
.faq summary{list-style:none;cursor:pointer;font-family:"Ubuntu";font-weight:500;color:var(--ink);
  padding:18px 0;display:flex;justify-content:space-between;align-items:center;gap:16px;font-size:1.04rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.5rem;color:var(--roxo);transition:.2s;font-family:"Poppins";line-height:1}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .ans{padding:0 0 20px;color:var(--cinza);line-height:1.7;font-size:.97rem}
.faq .group-title{font-family:"Ubuntu";color:var(--roxo);font-size:1.2rem;margin:32px 0 6px}
.faq .group-title:first-child{margin-top:0}

/* Formulário (Faça Parte / contato) — visual nativo */
.form{background:#fff;border:1px solid var(--linha);border-radius:var(--radius-lg);padding:clamp(28px,4vw,44px);box-shadow:var(--shadow)}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form label{display:block;font-size:.85rem;font-weight:600;color:var(--ink);margin:14px 0 6px}
.form input,.form select,.form textarea{width:100%;padding:13px 15px;border:1.5px solid #e3dcef;border-radius:12px;
  font-family:"Poppins";font-size:.95rem;color:var(--ink);background:#fbfaff;transition:.18s}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--roxo);background:#fff;box-shadow:0 0 0 3px rgba(51,0,102,.08)}
.form .full{grid-column:1/-1}
.form .btn{margin-top:22px;width:100%;justify-content:center}
.form small.hint{color:var(--cinza);font-size:.8rem}

/* faixa de passos numerados reusa .steps/.step */
@media(max-width:960px){ .grid-2,.grid-3,.split,.form .row{grid-template-columns:1fr} }

/* menu vindo do wp_nav_menu (<ul><li>) */
.menu{list-style:none;margin:0;padding:0}
.menu li{list-style:none}
.menu li a::after{content:"";position:absolute;left:0;bottom:-3px;width:0;height:2px;background:var(--terra);transition:.22s}
.menu li a{position:relative;padding:4px 0;color:#2b2336}
.menu li a:hover{color:var(--roxo)} .menu li a:hover::after{width:100%}

/* Logo oficial (img) */
.logo img{width:auto;display:block}
.nav .logo img{height:50px}
.footer .logo img{height:42px;filter:brightness(0) invert(1)} /* logo roxo -> branco no rodapé */
@media(max-width:640px){ .nav .logo img{height:42px} }

/* ============================================================
   ANIMAÇÕES / INTERATIVIDADE (progressive enhancement)
   ============================================================ */
/* scroll-reveal: só esconde quando há JS (.js) e o JS marcou .reveal */
html.js .reveal{opacity:0;transform:translateY(26px);
  transition:opacity .7s cubic-bezier(.2,.65,.2,1), transform .7s cubic-bezier(.2,.65,.2,1);will-change:opacity,transform}
html.js .reveal.is-in{opacity:1;transform:none}
/* header ganha sombra ao rolar */
.nav{transition:box-shadow .25s ease, background-color .25s ease}
.nav.is-scrolled{box-shadow:0 8px 28px rgba(51,0,102,.09)}
/* hover sutil nos botões (reforço) */
.btn{transition:transform .18s ease, box-shadow .18s ease, background-color .18s ease, border-color .18s ease}
@media (prefers-reduced-motion: reduce){
  html.js .reveal{opacity:1 !important;transform:none !important;transition:none}
  *{scroll-behavior:auto !important}
}

/* ============================================================
   CAMADA DE ANIMAÇÃO EXTRA (v1.1) — tudo respeita prefers-reduced-motion
   ============================================================ */
/* barra de progresso de leitura (topo) */
.vx-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:100;
  background:linear-gradient(90deg,var(--roxo),var(--terra));box-shadow:0 0 8px rgba(204,85,51,.45);
  transition:width .08s linear;pointer-events:none}

/* hero: entrada em cascata (reusa o mecanismo .reveal/.is-in, com delays por filho) */
#vxh .hero-copy>*{transition-delay:.06s}
#vxh .hero-copy>*:nth-child(2){transition-delay:.14s}
#vxh .hero-copy>*:nth-child(3){transition-delay:.22s}
#vxh .hero-copy>*:nth-child(4){transition-delay:.30s}
#vxh .hero-copy>*:nth-child(5){transition-delay:.38s}
#vxh .hero-copy>*:nth-child(6){transition-delay:.46s}
#vxh .pho-wrap{transition-delay:.24s}

/* zoom suave nas fotos editoriais ao passar o mouse */
#vxh .about-media img,#vxh .why-media img{transition:transform .6s cubic-bezier(.2,.6,.2,1)}
#vxh .about-media:hover img,#vxh .why-media:hover img{transform:scale(1.035)}

/* micro-interação nos ícones de card/step (home + páginas internas) */
.card .ci svg,.step .sk svg,#vxh .card .ci svg,#vxh .step .sk svg{transition:transform .25s ease}
.card:hover .ci svg,.step:hover .sk svg,#vxh .card:hover .ci svg,#vxh .step:hover .sk svg{transform:scale(1.1)}

/* selos editoriais (Sobre / Por que) flutuam como os cards do hero */
#vxh .about-media .badge{animation:vxfloat 5.5s ease-in-out infinite}
#vxh .why-media .badge{animation:vxfloat 6.5s ease-in-out -2.2s infinite}

@media (prefers-reduced-motion: reduce){
  .vx-progress{display:none}
  #vxh .float,#vxh .about-media .badge,#vxh .why-media .badge{animation:none}
  #vxh .hero-copy>*,#vxh .pho-wrap{transition-delay:0s !important}
  #vxh .about-media:hover img,#vxh .why-media:hover img{transform:none}
  .card:hover .ci svg,.step:hover .sk svg,#vxh .card:hover .ci svg,#vxh .step:hover .sk svg{transform:none}
  .nav-toggle .bar{transition:none}
}

/* ============================================================
   MOBILE / RESPONSIVO (v1.2) — nav hambúrguer, overflow guard, footer, toque
   ============================================================ */
/* envólucro do menu: no desktop é "transparente" (filhos fluem no flex do .nav .wrap) */
.nav-collapse{display:contents}
.nav .wrap,.nav-right,.menu{min-width:0}
/* botão hambúrguer (escondido no desktop) */
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;
  padding:10px;background:none;border:0;cursor:pointer;border-radius:10px}
.nav-toggle:hover{background:var(--lav)}
.nav-toggle .bar{display:block;width:100%;height:2px;background:var(--roxo);border-radius:2px;
  transition:transform .25s ease,opacity .2s ease}
.nav.is-open .nav-toggle .bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav.is-open .nav-toggle .bar:nth-child(2){opacity:0}
.nav.is-open .nav-toggle .bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:860px){
  .nav-toggle{display:flex}
  .nav-collapse{display:none}
  .nav.is-open .nav-collapse{display:flex;flex-direction:column;align-items:stretch;gap:0;
    position:absolute;top:100%;left:0;right:0;background:#fff;padding:6px 28px 18px;
    box-shadow:0 16px 32px rgba(51,0,102,.13);border-top:1px solid var(--linha)}
  .nav.is-open .menu{flex-direction:column;gap:0;width:100%}
  .nav.is-open .menu li{width:100%}
  .nav.is-open .menu li a{display:block;padding:15px 2px;border-bottom:1px solid var(--linha);white-space:nowrap}
  .nav.is-open .menu li a::after{display:none}
  .nav.is-open .nav-right{flex-direction:column;align-items:stretch;gap:14px;margin-top:14px;width:100%}
  .nav.is-open .socials{justify-content:center;gap:16px}
  .nav.is-open .socials a{width:44px;height:44px}
  .nav.is-open .nav-right .btn{width:100%;justify-content:center}
}

/* topbar: compacta no mobile (o e-mail já aparece no rodapé) */
@media(max-width:640px){
  .topbar .wrap{gap:14px;padding:8px 20px;font-size:.8rem}
  .topbar span:first-child{display:none}
}

/* footer 1 coluna + alvos de toque ≥44px + barra inferior empilhada + heroes textuais */
@media(max-width:560px){
  .footer .cols{grid-template-columns:1fr;gap:30px}
  .footer ul{gap:2px}
  .footer ul a{display:inline-block;padding:11px 0}
  .footer .fsoc a{width:44px;height:44px}
  .footer .contact small{font-size:.8rem}
  .footer .bottom{flex-direction:column;gap:8px;align-items:flex-start}
  .footer .bottom a{margin-left:0;margin-right:18px;display:inline-block;padding:8px 0}
  .page-hero{padding:52px 0 42px}
  .crumb{margin-top:14px}
}

/* FAQ: alinhar o marcador +/- ao topo em perguntas de 2 linhas */
.faq summary{align-items:flex-start}
.faq summary::after{margin-top:1px}

/* CTA das páginas internas: full-bleed quadrado no mobile (igual à home) */
@media(max-width:640px){
  /* no mobile o CTA volta a faixa full-bleed em fluxo (sem float) */
  .cta{position:static;height:auto;padding:0;z-index:auto}
  .cta .band{position:relative;transform:none;left:auto;top:auto;width:auto;border-radius:0;max-width:none;margin:0;padding:56px 24px;box-shadow:none}
  .section:has(+ .cta){padding-bottom:64px}
  .cta + .footer,
  main:has(> .cta:last-child) + .footer{padding-top:70px}
  .step .nb{font-size:11rem;bottom:-30px;right:-8px}
}
