@font-face{font-family:"Inter";font-style:normal;font-weight:400 700;font-display:swap;src:url("assets/fonts/inter.woff2") format("woff2")}
@font-face{font-family:"Manrope";font-style:normal;font-weight:500 800;font-display:swap;src:url("assets/fonts/manrope.woff2") format("woff2")}
@font-face{font-family:"Dancing Script";font-style:normal;font-weight:600 700;font-display:swap;src:url("assets/fonts/dancingscript.woff2") format("woff2")}
:root{
  --bg:#ffffff; --bg-alt:#F5F5F7; --bg-tint:#F0F4FE;
  --ink:#1D1D1F; --ink-soft:#3C3F45; --muted:#6E7178; --muted-2:#9AA0A6;
  --line:rgba(0,0,0,.09); --line-soft:rgba(0,0,0,.06);
  --brand:#0453BE; --blue:#0064E0; --blue-2:#0052BD; --blue-tint:#E7F0FE;
  --grad:linear-gradient(118deg,#0064E0 0%,#2E93F7 55%,#46A6FF 100%);
  --grad-deep:linear-gradient(118deg,#0064E0 0%,#0B5AD0 100%);
  --grad-soft:linear-gradient(118deg,rgba(0,100,224,.12),rgba(61,155,255,.12));
  --radius:18px; --radius-lg:28px; --radius-sm:12px;
  --maxw:1160px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --shadow-sm:0 2px 10px -4px rgba(20,30,55,.12);
  --shadow:0 18px 50px -18px rgba(20,30,55,.22), 0 6px 18px -10px rgba(20,30,55,.12);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  background:var(--bg); color:var(--ink);
  font-family:"Inter",system-ui,-apple-system,sans-serif;
  font-size:17px; line-height:1.6; font-weight:400;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
  letter-spacing:-.011em;
}
.wrap{max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(20px,5vw,40px)}
h1,h2,h3,h4{font-family:"Manrope","Inter",sans-serif; font-weight:800; line-height:1.06; letter-spacing:-.03em; color:var(--ink)}
a{color:inherit; text-decoration:none}
img{display:block; max-width:100%; height:auto}
.grad-text{background:var(--grad); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent}
.blue{color:var(--blue)}

a:focus-visible,button:focus-visible{outline:2.5px solid var(--blue); outline-offset:3px; border-radius:6px}
.skip{position:absolute; left:-999px; top:0; background:var(--blue); color:#fff; padding:10px 16px; border-radius:0 0 8px 0; font-weight:700; z-index:200}
.skip:focus{left:0}

.eyebrow{font-family:"Inter",sans-serif; font-size:14px; font-weight:600; letter-spacing:0; color:var(--blue); text-transform:none}

/* buttons */
.btn{display:inline-flex; align-items:center; gap:9px; font-family:"Inter",sans-serif; font-weight:600; font-size:16px; padding:13px 26px; border-radius:999px; border:1px solid transparent; cursor:pointer; transition:transform .2s var(--ease),background .2s var(--ease),box-shadow .2s var(--ease),color .2s; min-height:48px; white-space:nowrap}
.btn-primary{background:var(--blue); color:#fff; box-shadow:0 8px 22px -8px rgba(0,100,224,.5)}
.btn-primary:hover{background:var(--blue-2); transform:translateY(-2px); box-shadow:0 14px 30px -10px rgba(0,100,224,.55)}
.btn-primary:active{transform:translateY(0)}
.btn-white{background:#fff; color:var(--blue); border:1px solid var(--line); box-shadow:0 8px 22px -10px rgba(20,30,55,.18)}
.btn-white:hover{background:#fff; transform:translateY(-2px); box-shadow:0 14px 30px -12px rgba(20,30,55,.22)}
.btn-white:active{transform:translateY(0)}
.btn-ghost{background:transparent; color:var(--ink); border-color:var(--line)}
.btn-ghost:hover{border-color:var(--blue); color:var(--blue); transform:translateY(-2px)}
.btn svg{width:19px; height:19px; flex:none}
.txtlink{display:inline-flex; align-items:center; gap:7px; color:var(--blue); font-weight:600; transition:gap .2s var(--ease)}
.txtlink:hover{gap:11px}
.txtlink svg{width:18px;height:18px}

/* header */
header.site{position:sticky; top:0; z-index:100; backdrop-filter:saturate(180%) blur(18px); background:rgba(255,255,255,.78); border-bottom:1px solid var(--line-soft)}
.nav{display:flex; align-items:center; justify-content:space-between; height:64px}
.brand{display:flex; align-items:center; gap:10px; font-family:"Manrope",sans-serif; font-weight:800; letter-spacing:-.02em; font-size:18px; color:var(--ink)}
.brand .mark{width:30px; height:30px; border-radius:9px; background:linear-gradient(135deg,#0453BE 0%,#1E6FE6 100%); display:grid; place-items:center; overflow:hidden; box-shadow:0 4px 12px -4px rgba(4,83,190,.5)}
.brand .mark img{width:70%; height:70%; object-fit:contain; display:block}
.brand-txt{display:flex; flex-direction:column; line-height:1.04}
.brand-name{font-family:"Manrope",sans-serif; font-weight:800; font-size:18px; letter-spacing:-.02em}
.brand-tag{font-family:"Inter",sans-serif; font-weight:600; font-size:10px; letter-spacing:.13em; text-transform:uppercase; color:var(--muted); margin-top:3px}
.nav-links{display:flex; align-items:center; gap:30px}
.nav-links a.lnk{font-size:15px; color:var(--ink-soft); font-weight:500; transition:color .15s}
.nav-links a.lnk:hover{color:var(--blue)}
.nav .btn{padding:9px 18px; font-size:14.5px; min-height:40px}
.nav-toggle{display:none; background:none; border:1px solid var(--line); border-radius:10px; width:44px; height:44px; color:var(--ink); cursor:pointer; align-items:center; justify-content:center}
.nav-toggle svg{width:22px;height:22px}
@media(max-width:860px){
  .nav-links{position:fixed; inset:64px 0 auto 0; flex-direction:column; gap:0; background:rgba(255,255,255,.97); backdrop-filter:blur(18px); border-bottom:1px solid var(--line); padding:6px 0; transform:translateY(-130%); transition:transform .3s var(--ease); align-items:stretch}
  .nav-links.open{transform:translateY(0)}
  .nav-links a.lnk{padding:15px clamp(20px,5vw,40px); border-bottom:1px solid var(--line-soft)}
  .nav-links .btn{margin:14px clamp(20px,5vw,40px); justify-content:center}
  .nav-toggle{display:inline-flex}
}

header.site.at-top{background:linear-gradient(180deg,rgba(9,11,22,.52) 0%,rgba(9,11,22,0) 100%); border-bottom-color:transparent; backdrop-filter:none}
header.site.at-top .brand{color:#fff}
header.site.at-top .brand-tag{color:rgba(255,255,255,.72)}
header.site.at-top .nav-toggle{color:#fff; border-color:rgba(255,255,255,.42)}
@media(min-width:861px){
  header.site.at-top .nav-links a.lnk{color:rgba(255,255,255,.92)}
  header.site.at-top .nav-links a.lnk:hover{color:#fff}
}

/* hero — full-bleed dark with rocket bg */
.hero{position:relative; overflow:hidden; min-height:clamp(440px,68vh,600px); display:flex; align-items:center; text-align:center; padding:clamp(72px,9vh,108px) 0 clamp(48px,6vh,72px)}
.hero-bg{position:absolute; inset:0; z-index:0}
.hero-bg img{width:100%; height:100%; object-fit:cover; object-position:center 36%}
.hero-bg::after{content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(9,11,22,.60) 0%,rgba(9,11,22,.46) 42%,rgba(9,11,22,.82) 100%)}
.hero .wrap{position:relative; z-index:1; width:100%}
.hero .eyebrow{display:inline-block; padding:7px 15px; background:rgba(255,255,255,.15); color:#fff; border-radius:999px; font-weight:600; backdrop-filter:blur(4px)}
.hero h1{font-size:clamp(2.7rem,7.2vw,5.2rem); max-width:16ch; margin:22px auto 0; letter-spacing:-.038em; color:#fff; text-shadow:0 2px 34px rgba(0,0,0,.4)}
.hero .grad-text{background:linear-gradient(118deg,#3D9BFF 0%,#AED6FF 50%,#ffffff 100%); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent}
.hero .stat .n.grad-text{background:linear-gradient(118deg,#7FBEFF,#ffffff); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent}
.hero .lead{font-size:clamp(1.05rem,2.2vw,1.3rem); color:rgba(255,255,255,.87); max-width:48ch; margin:18px auto 0; line-height:1.5; font-weight:400; letter-spacing:-.012em; text-shadow:0 1px 18px rgba(0,0,0,.34)}
.hero .cta-row{display:flex; flex-wrap:wrap; gap:14px; justify-content:center; margin-top:26px}
.hero .btn-ghost{color:#fff; border-color:rgba(255,255,255,.45)}
.hero .btn-ghost:hover{color:#fff; border-color:#fff; background:rgba(255,255,255,.1); transform:translateY(-2px)}
.stats{display:flex; flex-wrap:wrap; justify-content:center; gap:clamp(22px,5vw,56px); margin-top:clamp(30px,4vw,42px)}
.stat .n{font-family:"Manrope",sans-serif; font-size:clamp(1.5rem,3.2vw,2.1rem); font-weight:800; line-height:1; letter-spacing:-.03em}
.stat .l{font-size:13.5px; color:rgba(255,255,255,.8); margin-top:8px; font-weight:500}

/* sections */
section{padding:clamp(42px,5.5vw,72px) 0}
.sec-head{max-width:62ch}
.sec-head.center{margin-inline:auto; text-align:center}
.sec-head h2{font-size:clamp(2rem,4.6vw,3rem); margin:14px 0 0; letter-spacing:-.034em}
.sec-head p{color:var(--muted); margin:13px 0 0; font-size:1.06rem; font-weight:400}
.sec-head.center p{margin-inline:auto}

/* cases */
.projects-sec{background:var(--bg-alt)}
#projetos{padding-top:clamp(42px,5.5vw,70px)}
.case{padding:clamp(26px,3.4vw,44px) 0}
.case + .case{border-top:1px solid var(--line-soft)}
.case-visual{position:relative; max-width:940px; margin:0 auto clamp(26px,3.4vw,42px)}
.browser{position:relative; border-radius:14px; overflow:hidden; background:#fff; border:1px solid var(--line); box-shadow:0 34px 72px -30px rgba(20,30,55,.5), 0 10px 28px -14px rgba(20,30,55,.28)}
.browser-shot{display:block; width:100%; height:auto}
.case-mock{position:relative; margin-right:clamp(0px,2vw,26px)}
.case-phone-ov{position:absolute; z-index:3; right:-3%; bottom:-7%; width:19%; min-width:92px; aspect-ratio:9/19.5; border:6px solid #141418; border-radius:24px; overflow:hidden; background:#0b0b0d; box-shadow:0 26px 48px -16px rgba(20,30,55,.5)}
.case-phone-ov img{width:100%; height:100%; object-fit:cover; object-position:top center; display:block}
@media(max-width:680px){.case-phone-ov{width:24%; right:-2%; bottom:-5%; border-width:5px; border-radius:18px}}
.laptop{position:relative; width:84%; margin:0 auto; filter:drop-shadow(0 28px 46px rgba(20,30,55,.22))}
.laptop .screen{position:relative; border:10px solid #1d1d1f; border-bottom:0; border-radius:16px 16px 0 0; background:#0b0b0d; aspect-ratio:16/10; overflow:hidden}
.laptop .screen img{width:100%; height:100%; object-fit:cover; object-position:top center; display:block}
.laptop .deck{height:15px; width:118%; margin-left:-9%; background:linear-gradient(#d2d6dd,#a8aeb9); border-radius:2px 2px 12px 12px; position:relative; box-shadow:inset 0 1px 0 rgba(255,255,255,.7)}
.laptop .deck::after{content:""; position:absolute; top:0; left:50%; transform:translateX(-50%); width:15%; height:6px; background:#9298a4; border-radius:0 0 7px 7px}
.phone{position:absolute; right:0; bottom:0; width:19%; min-width:84px; border:6px solid #1d1d1f; border-radius:22px; background:#0b0b0d; aspect-ratio:9/19.5; overflow:hidden; box-shadow:0 20px 38px -14px rgba(20,30,55,.5)}
.phone img{width:100%; height:100%; object-fit:cover; object-position:top center; display:block}
.case-body{display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(24px,4vw,50px); align-items:start}
.case-kicker{font-size:12.5px; font-weight:700; letter-spacing:.15em; text-transform:uppercase; color:var(--blue)}
.case h3{font-size:clamp(1.8rem,3.7vw,2.5rem); margin:10px 0 0; letter-spacing:-.03em}
.case-desc{color:var(--muted); margin:11px 0 0; font-size:1rem; line-height:1.5}
.case-desc strong{color:var(--ink-soft); font-weight:600}
.case .txtlink{margin-top:15px; font-size:15px}
.case-stats{display:flex; flex-direction:column; gap:0; margin-top:3px}
.cstat{padding:12px 0; border-top:1px solid var(--line-soft)}
.cstat:first-child{border-top:0; padding-top:0}
.cstat:last-child{padding-bottom:0}
.cstat .cn{font-family:"Manrope",sans-serif; font-size:clamp(1.5rem,3vw,1.95rem); font-weight:800; line-height:1.05; letter-spacing:-.035em; background:var(--grad); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; display:inline-block}
.cstat .cl{color:var(--muted); font-size:.9rem; margin-top:4px; font-weight:500}
@media(max-width:820px){
  .case-body{grid-template-columns:1fr; gap:22px}
}

/* process */
.steps{display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:34px}
.step{background:var(--bg-alt); padding:24px 22px; border-radius:var(--radius-lg); transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.step:hover{transform:translateY(-4px); box-shadow:var(--shadow)}
.step .sn{font-family:"Manrope",sans-serif; font-size:2rem; font-weight:800; letter-spacing:-.04em}
.step .sn span{background:var(--grad); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent}
.step h4{font-size:1.14rem; font-weight:700; margin:14px 0 0; letter-spacing:-.02em}
.step p{color:var(--muted); font-size:.96rem; margin:9px 0 0; line-height:1.55; font-weight:400}
@media(max-width:860px){.steps{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.steps{grid-template-columns:1fr}}

/* why */
.why-sec{background:var(--bg-alt)}
.why-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:34px}
.why{padding:26px 26px; background:var(--bg); border:1px solid var(--line-soft); border-radius:var(--radius-lg); transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.why:hover{transform:translateY(-5px); box-shadow:var(--shadow)}
.why .ic{width:50px; height:50px; border-radius:14px; background:var(--grad-deep); display:grid; place-items:center; color:#fff; box-shadow:0 8px 20px -8px rgba(0,100,224,.45)}
.why .ic svg{width:24px;height:24px}
.why h3{font-size:1.16rem; font-weight:700; margin:18px 0 0; letter-spacing:-.02em}
.why p{color:var(--muted); font-size:.98rem; margin:10px 0 0; line-height:1.55; font-weight:400}
@media(max-width:860px){.why-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.why-grid{grid-template-columns:1fr}}

/* mobile carousels (Processo / Por que) */
@media(max-width:640px){
  .steps, .why-grid, .certs{
    display:flex; grid-template-columns:none; gap:13px;
    overflow-x:auto; scroll-snap-type:x mandatory;
    margin-inline:calc(-1 * clamp(20px,5vw,40px));
    padding:4px clamp(20px,5vw,40px) 2px;
    scroll-padding-inline:clamp(20px,5vw,40px);
    scrollbar-width:none; -webkit-overflow-scrolling:touch;
  }
  .steps::-webkit-scrollbar, .why-grid::-webkit-scrollbar, .certs::-webkit-scrollbar{display:none}
  .step, .why, .cert{flex:0 0 79%; scroll-snap-align:start}
  .certs .cert{flex-basis:86%}
  .why-grid .why{opacity:1; transform:none}
  .why:hover{transform:none; box-shadow:none}
}
.cdots{display:none}
@media(max-width:640px){
  .cdots{display:flex; gap:7px; justify-content:center; margin-top:18px}
  .cdots b{width:7px; height:7px; border-radius:50%; background:var(--line); transition:width .25s var(--ease),background .25s; cursor:pointer}
  .cdots b.on{background:var(--blue); width:22px; border-radius:4px}
}

/* final CTA — full-bleed Meta gradient */
.final{padding:0}
.final .panel{position:relative; background:linear-gradient(180deg,rgba(9,11,22,.55) 0%,rgba(9,11,22,.42) 45%,rgba(9,11,22,.70) 100%),url('assets/img/img02-053fba92.jpg') center 28% / cover no-repeat,var(--grad-deep); border-radius:clamp(24px,4vw,40px); margin:clamp(28px,4.5vw,56px) 0; padding:clamp(40px,5.5vw,68px) clamp(24px,5vw,48px); text-align:center; overflow:hidden; color:#fff}
.final .panel::after{content:""; position:absolute; inset:0; background:radial-gradient(circle at 80% 10%,rgba(255,255,255,.18),transparent 40%); pointer-events:none}
.final .panel > *{position:relative}
.final .eyebrow{color:rgba(255,255,255,.85)}
.final h2{color:#fff; font-size:clamp(2.2rem,5.2vw,3.6rem); max-width:18ch; margin:14px auto 0; letter-spacing:-.034em}
.final p{color:rgba(255,255,255,.9); max-width:50ch; margin:14px auto 0; font-size:1.08rem; font-weight:400}
.final .btn{margin-top:24px}
.final .micro{margin-top:18px; font-size:13.5px; color:rgba(255,255,255,.8)}

/* footer */
footer.site{border-top:1px solid var(--line-soft); padding:36px 0 30px; background:var(--bg)}
.foot{display:flex; flex-wrap:wrap; justify-content:space-between; gap:28px; align-items:flex-start}
.foot .brand{margin-bottom:14px}
.foot p{color:var(--muted); font-size:.95rem; max-width:40ch; font-weight:400}
.foot .contact{font-size:.96rem; line-height:1.95}
.foot .contact a{color:var(--ink-soft); transition:color .15s; font-weight:500}
.foot .contact a:hover{color:var(--blue)}
.foot .wa{font-weight:700; color:var(--ink)}
.copyright{margin-top:26px; padding-top:20px; border-top:1px solid var(--line-soft); font-size:13px; color:var(--muted); display:flex; flex-wrap:wrap; gap:10px; justify-content:space-between}
.founder{display:flex; flex-wrap:wrap; justify-content:space-between; gap:28px 48px; align-items:flex-end; padding-bottom:30px; margin-bottom:30px; border-bottom:1px solid var(--line-soft)}
.founder .eyebrow{display:block}
.sig{font-family:"Dancing Script","Snell Roundhand","Segoe Script","Brush Script MT",cursive; font-size:clamp(2.1rem,4.4vw,2.65rem); font-weight:700; color:var(--ink); line-height:1.05; margin:9px 0 7px; letter-spacing:.01em}
.founder-role{color:var(--muted); font-size:.95rem; margin:0; font-weight:500}
.creds-label{font-size:11px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--muted)}
.creds-list{display:flex; flex-direction:column; gap:10px; margin-top:13px}
.cred{display:flex; align-items:center; gap:10px; font-size:.97rem; font-weight:600; color:var(--ink-soft)}
.cred .chk{width:20px; height:20px; border-radius:6px; background:var(--blue-tint); color:var(--blue); display:grid; place-items:center; flex:none}
.cred .chk svg{width:12px; height:12px}
@media(max-width:620px){.founder{align-items:flex-start; gap:22px}}

/* reach / international presence */
.reach{padding:clamp(40px,5.5vw,66px) 0; text-align:center; background:var(--bg); border-top:1px solid var(--line-soft)}
.reach h2{font-size:clamp(1.7rem,4vw,2.5rem); margin:14px auto 0; max-width:20ch; letter-spacing:-.032em}
.reach .lead{color:var(--muted); max-width:52ch; margin:13px auto 0; font-size:1.02rem; line-height:1.55}
.flags{display:flex; flex-wrap:wrap; justify-content:center; gap:clamp(14px,2.2vw,24px) clamp(16px,3vw,30px); margin-top:clamp(26px,3.5vw,40px); padding:2px 6px 4px}
.flags::-webkit-scrollbar{display:none}
.flag-item{flex:0 0 auto; display:flex; flex-direction:column; align-items:center; gap:9px; transition:transform .25s var(--ease)}
.flag-item:hover{transform:translateY(-4px)}
.flag-item img{width:38px; height:28.5px; object-fit:cover; border-radius:6px; border:1px solid var(--line); box-shadow:0 5px 14px -8px rgba(20,30,55,.32)}
.flag-item span{font-size:12.5px; font-weight:600; color:var(--ink-soft); letter-spacing:-.01em; white-space:nowrap}
@media(max-width:520px){.flag-item img{width:30px;height:22.5px}.flags{gap:12px 16px}.flag-item span{font-size:10.5px}}

/* reveal */
.js .reveal{opacity:0; transform:translateY(20px)}
.reveal.in{opacity:1; transform:none; transition:opacity .7s var(--ease),transform .7s var(--ease)}
@media (prefers-reduced-motion:reduce){.js .reveal{opacity:1!important; transform:none!important}}

/* certificações */
.certs{display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:clamp(30px,4vw,44px)}
.cert{padding:0; margin:0; font:inherit; color:inherit; text-align:inherit; border:1px solid var(--line-soft); border-radius:14px; overflow:hidden; background:#fff; cursor:zoom-in; display:block; position:relative; box-shadow:0 18px 42px -24px rgba(20,30,55,.32); transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.cert:hover{transform:translateY(-5px); box-shadow:0 30px 62px -26px rgba(20,30,55,.42)}
.cert img{display:block; width:100%; height:auto}
.cert::after{content:"\2922"; position:absolute; top:10px; right:10px; width:30px; height:30px; border-radius:9px; background:rgba(13,17,23,.62); color:#fff; display:grid; place-items:center; font-size:16px; opacity:0; transition:opacity .25s}
.cert:hover::after, .cert:focus-visible::after{opacity:1}
.cert:focus-visible{outline:2px solid var(--blue); outline-offset:3px}
.lb{position:fixed; inset:0; background:rgba(12,16,24,.86); display:none; place-items:center; z-index:300; padding:20px; cursor:zoom-out}
.lb.open{display:grid}
body.lb-open header.site{visibility:hidden}
.lb img{max-width:min(1120px,95vw); max-height:92vh; height:auto; border-radius:12px; box-shadow:0 40px 90px -30px rgba(0,0,0,.6)}
.lb-x{position:absolute; top:16px; right:20px; width:42px; height:42px; border-radius:50%; background:rgba(255,255,255,.16); color:#fff; border:0; font-size:19px; line-height:1; cursor:pointer; display:grid; place-items:center}
.lb-x:hover{background:rgba(255,255,255,.28)}
.faq-sec .faq{max-width:820px;margin:0 auto}
.faq-item{border-top:1px solid var(--line)}
.faq-item:last-child{border-bottom:1px solid var(--line)}
.faq-item summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:20px;padding:22px 4px;font-family:"Manrope","Inter",sans-serif;font-weight:700;font-size:18px;color:var(--ink)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:26px;font-weight:500;line-height:1;color:var(--blue);flex:none;transition:transform .25s var(--ease)}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item summary:focus-visible{outline:2.5px solid var(--blue);outline-offset:3px;border-radius:6px}
.faq-item .faq-a{padding:0 4px 24px;color:var(--muted);max-width:72ch;line-height:1.65}
.faq-item .faq-a a{color:var(--blue);font-weight:600}
@media (max-width:560px){.faq-item summary{font-size:16px}}

/* ---- subpáginas de serviço ---- */
.subhero{padding:118px 0 60px;background:linear-gradient(180deg,var(--bg-tint),var(--bg));border-bottom:1px solid var(--line-soft);text-align:center}
.subhero .breadcrumb{font-size:13px;color:var(--muted);margin-bottom:16px}
.subhero .breadcrumb a{color:var(--blue);font-weight:600}
.subhero h1{font-size:clamp(33px,6vw,58px);line-height:1.05;margin:6px auto 0;max-width:16ch}
.subhero .lead{font-size:clamp(16.5px,2.3vw,20px);color:var(--muted);max-width:58ch;margin:20px auto 30px;line-height:1.6}
.subhero .cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.svc{padding:74px 0}
.svc + .svc{padding-top:0}

/* ---- rodapé: segmentos ---- */
.foot-seg{margin-top:30px;padding-top:24px;border-top:1px solid var(--line-soft)}
.foot-seg .creds-label{display:block;margin-bottom:12px}
.seg-links{display:flex;flex-wrap:wrap;gap:10px 22px}
.seg-links a{font-size:14px;color:var(--muted);transition:color .2s var(--ease)}
.seg-links a:hover{color:var(--blue)}

/* ---- hero dividido com imagem do segmento ---- */
.subhero-split{text-align:left}
.subhero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:52px;align-items:center}
.subhero-split .breadcrumb{margin-bottom:14px}
.subhero-split h1{max-width:none;margin:6px 0 0}
.subhero-split .lead{max-width:54ch;margin:20px 0 28px}
.subhero-split .cta-row{justify-content:flex-start}
.subhero-media img{display:block;width:100%;height:auto;aspect-ratio:1/1;object-fit:cover;border-radius:22px;box-shadow:0 30px 70px -28px rgba(20,30,55,.32);background:linear-gradient(135deg,#eaf1ff,#cdddff)}
@media (max-width:860px){
  .subhero-grid{grid-template-columns:1fr;gap:28px;text-align:center}
  .subhero-split h1{margin-left:auto;margin-right:auto}
  .subhero-split .lead{margin:18px auto 26px}
  .subhero-split .cta-row{justify-content:center}
  .subhero-media{max-width:360px;margin:0 auto}
}

/* ---- faixa de prova social (sub-páginas) ---- */
.trust{padding:8px 0 4px}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);padding:26px 0}
.trust-item{display:flex;flex-direction:column;gap:4px}
.trust-item strong{font-family:"Manrope",sans-serif;font-size:1rem;letter-spacing:-.02em;color:var(--ink)}
.trust-item span{font-size:.9rem;line-height:1.4;color:var(--muted)}
@media (max-width:760px){.trust-grid{grid-template-columns:repeat(2,1fr);gap:20px 16px}}

/* ---- hero das sub-páginas (imagem ao fundo, padrão da home) ---- */
.hero-sub h1{max-width:22ch}
.hero-sub .breadcrumb{color:rgba(255,255,255,.82); font-size:.92rem; margin:0 0 4px; text-shadow:0 1px 14px rgba(0,0,0,.4)}
.hero-sub .breadcrumb a{color:#fff; font-weight:600}
