/* =============================================================
   BAM Assessoria — Folha de estilo principal
   Design original preservado. Organizado por seções.
   ============================================================= */
:root{
  --green:#00FFAE;--green2:#56FFC1;--green3:#57F5C3;--dgreen:#21614D;
  --ink:#383838;--gray:#8a8a8a;--black:#050505;--black2:#0c0e0d;--panel:#0a0d0c;--white:#fff;
  --line:rgba(255,255,255,.12);
  --mono:'Space Mono',monospace;--disp:'Oswald',sans-serif;--body:'Inter','Trebuchet MS',sans-serif;
  --gut:clamp(18px,4vw,56px);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
html,body{overflow-x:clip}
body{background:#000;color:var(--white);font-family:var(--body);font-size:17px;line-height:1.55;-webkit-font-smoothing:antialiased}
::selection{background:var(--green);color:#000}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:1320px;margin:0 auto;padding:0 var(--gut);width:100%}
@media(min-width:1600px){.wrap{max-width:1480px}}
.mono{font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em}
.tlabel{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--green);display:inline-flex;align-items:center;gap:8px}
.tlabel::before{content:"";width:7px;height:7px;background:var(--green);display:inline-block;clip-path:polygon(0 0,100% 50%,0 100%)}
.idx{font-family:var(--mono);font-size:12px;color:var(--gray);letter-spacing:.2em;text-transform:uppercase}

/* cursor */

/* progress bar */
.progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--green);z-index:960;transition:width .1s linear}

/* preloader */
#loader{position:fixed;inset:0;background:#000;z-index:10000;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:0;transition:opacity .6s,visibility .6s,background .9s}
#loader.done{opacity:0;visibility:hidden}
#loader.rise{background:rgba(0,0,0,0)}
.intro-logo{height:clamp(44px,7vw,74px);width:auto;opacity:0;animation:introFade .9s ease forwards;transition:transform .85s cubic-bezier(.6,0,.2,1)}
#loader.rise .intro-logo{transform:translateY(-40vh) scale(.32)}
.intro-arrow{margin-top:36px;opacity:0;animation:introFade .8s ease .5s forwards;transition:opacity .3s}
.intro-arrow i{display:block;width:13px;height:13px;border-right:2px solid var(--green);border-bottom:2px solid var(--green);transform:rotate(45deg);animation:introArrow 1.5s ease-in-out infinite;box-shadow:2px 2px 10px rgba(0,255,174,.4)}
#loader.rise .intro-arrow{opacity:0}
@keyframes introFade{to{opacity:1}}
@keyframes introArrow{0%,100%{transform:rotate(45deg) translate(-2px,-2px)}50%{transform:rotate(45deg) translate(3px,3px)}}

/* intro (home): topbar e whats escondidos até a logo "chegar"; aí se constroem */
body.intro-on .topbar{opacity:0}
body.intro-on .wa-float{opacity:0;transform:perspective(420px) rotateX(90deg) scale(.5);pointer-events:none}
body.intro-on.intro-reveal .topbar{opacity:1;transition:opacity .7s ease}
body.intro-on.intro-wa .wa-float{opacity:1;transform:perspective(420px) rotateX(0deg) scale(1);pointer-events:auto;transition:opacity .4s .1s,transform .75s cubic-bezier(.34,1.56,.64,1)}
/* cursor de digitação */
.tw-cursor{display:inline-block;width:1.5px;height:.8em;background:currentColor;margin-left:1px;vertical-align:middle;animation:twBlink .65s step-end infinite}
@keyframes twBlink{0%,100%{opacity:1}50%{opacity:0}}

/* top bar */
.topbar{position:fixed;top:0;left:0;width:100%;z-index:920;display:flex;align-items:center;justify-content:space-between;
  padding:26px var(--gut);transition:background .4s,padding .4s,border-color .4s;border-bottom:1px solid transparent}
.topbar.scrolled{background:rgba(5,5,5,.72);backdrop-filter:blur(14px);padding-top:18px;padding-bottom:18px;border-bottom-color:var(--line)}
.brand-logo{height:30px;width:auto;display:block}
.topbar-right{display:flex;align-items:center;gap:22px}
.store-link{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:#cfcfcf;transition:color .25s}
.store-link:hover{color:var(--green)}
.menu-btn{display:flex;align-items:center;gap:12px;background:none;border:0;cursor:pointer;font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:#fff}
.menu-btn .bars{display:flex;flex-direction:column;gap:4px}
.menu-btn .bars span{width:24px;height:2px;background:var(--green);transition:transform .32s,opacity .32s}
body.intro-on .menu-btn .bars span{width:0}
@keyframes barDraw{from{width:0}to{width:24px}}
body.intro-reveal .menu-btn .bars span:nth-child(1){animation:barDraw .38s .0s ease forwards}
body.intro-reveal .menu-btn .bars span:nth-child(2){animation:barDraw .38s .13s ease forwards}
.menu-btn[aria-expanded="true"] .bars span:nth-child(1){transform:translateY(3px) rotate(45deg)}
.menu-btn[aria-expanded="true"] .bars span:nth-child(2){transform:translateY(-3px) rotate(-45deg)}

/* fullscreen menu */
.menu{position:fixed;inset:0;z-index:950;background:#000;clip-path:circle(0% at calc(100% - 56px) 36px);transition:clip-path .7s cubic-bezier(.7,0,.2,1);display:flex;flex-direction:column;justify-content:center;pointer-events:none}
.menu.open{clip-path:circle(150% at calc(100% - 56px) 36px);pointer-events:auto}
.menu-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:center;max-width:1320px;margin:0 auto;width:100%;padding:0 var(--gut)}
.menu-links{display:flex;flex-direction:column}
.menu-links a{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:clamp(36px,7vw,84px);line-height:1.12;color:#fff;opacity:.5;transition:opacity .3s,transform .3s,color .3s;width:max-content;position:relative}
.menu-links a:hover{opacity:1;color:var(--green);transform:translateX(14px)}
.menu-links a span{font-family:var(--mono);font-size:12px;color:var(--green);vertical-align:super;margin-left:8px;opacity:0;transition:opacity .3s}
.menu-links a:hover span{opacity:1}
.menu-side{border-left:1px solid var(--line);padding-left:36px}
.menu-side h4{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--gray);text-transform:uppercase;margin-bottom:14px}
.menu-side a,.menu-side p{display:block;color:#cfcfcf;font-size:15px;margin-bottom:10px;transition:color .25s}
.menu-side a:hover{color:var(--green)}
.menu-tag{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--green);margin-bottom:30px}
.menu-socials{display:flex;gap:18px;margin-top:18px}
.menu-socials a{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.1em}

/* ===== SCENE (sticky stacking "pages") ===== */
.scene{position:sticky;top:0;min-height:100vh;min-height:100svh;display:flex;align-items:center;
  background:var(--black);border-top:1px solid var(--line);box-shadow:0 -50px 90px rgba(0,0,0,.75);
  border-radius:26px 26px 0 0;overflow:hidden;z-index:1}
.scene-edge{position:absolute;top:0;left:0;width:100%;height:1px;background:linear-gradient(90deg,transparent,var(--green),transparent);opacity:.6;z-index:1}
.scene .wrap{position:relative;z-index:2}
.flow{position:relative;background:var(--black);border-top:1px solid var(--line);box-shadow:0 -50px 90px rgba(0,0,0,.75);border-radius:26px 26px 0 0;padding:clamp(80px,11vw,150px) 0;z-index:1}

/* reveals */
.r{opacity:0;transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1),clip-path 1s cubic-bezier(.7,0,.2,1)}
.r.up{transform:translateY(42px)}
.r.left{transform:translateX(-56px)}
.r.right{transform:translateX(56px)}
.r.scale{transform:scale(.9)}
.r.clip{clip-path:inset(0 0 100% 0)}
.r.in{opacity:1;transform:none;clip-path:inset(0 0 0 0)}
.r.d1{transition-delay:.08s}.r.d2{transition-delay:.18s}.r.d3{transition-delay:.28s}.r.d4{transition-delay:.38s}.r.d5{transition-delay:.48s}.r.d6{transition-delay:.58s}

/* section header */
.shead{display:block;margin-bottom:clamp(36px,5vw,60px)}
.shead .idx{display:inline-flex;align-items:center;gap:11px;margin-bottom:clamp(16px,1.7vw,24px)}
.shead .idx::before{content:"";width:24px;height:1px;background:var(--green);flex:0 0 auto}
.shead h2{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:clamp(28px,5.2vw,82px);line-height:1.06;letter-spacing:-.014em;padding-top:.04em;padding-bottom:.06em}
.shead h2 .g{color:var(--green)}
.shead .sub{color:#bdbdbd;font-size:clamp(16px,1.8vw,19px);max-width:640px;margin-top:18px;line-height:1.55}

/* hero estático */
.hero{display:flex;align-items:flex-start;min-height:100vh;min-height:100svh;position:relative;overflow:hidden;background:var(--black);padding-bottom:clamp(48px,7vh,72px);padding-top:clamp(110px,16vh,148px)}
.hero .hero-grid{position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:72px 72px;mask-image:radial-gradient(ellipse 90% 80% at 50% 55%,#000 25%,transparent 80%);opacity:.45;z-index:0}
.hero .hero-glow{position:absolute;width:80vw;height:80vw;max-width:900px;max-height:900px;border-radius:50%;background:radial-gradient(circle,rgba(0,255,174,.14),transparent 62%);top:-18%;right:-12%;z-index:0;filter:blur(10px)}
.hero .wrap{position:relative;z-index:1}
.hero-eyebrow{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;margin-bottom:24px}
.hero h1{font-family:var(--disp);font-weight:700;text-transform:uppercase;overflow-wrap:break-word;font-size:clamp(34px,7.6vw,108px);line-height:1.02;letter-spacing:-.012em;padding-top:.08em;padding-bottom:.12em}
.hero h1 .g{color:var(--green)}
/* Palavras do slogan: cada uma "voa" da placa até o lugar (posição/opacidade via JS no scroll) */
.hero h1 .hw{display:inline-block;opacity:0;will-change:transform,opacity;transform-origin:50% 50%}
.hero h1 .hw.show{opacity:1;transform:none}
.hero-chevsvg{height:clamp(38px,6.5vw,96px);width:auto;margin-left:.12em;vertical-align:baseline}
/* puxa o slogan para a esquerda, deixando a estrada/placa respirarem à direita */
@media(min-width:1100px){.hero h1,.hero-eyebrow{max-width:64%}}

/* Placa (outdoor) na estrada — origem das palavras do slogan (visual da placa "MAIS") */
.road-sign{position:absolute;top:0;left:0;z-index:2;display:flex;flex-direction:column;align-items:center;opacity:0;pointer-events:none;transform:translate(-50%,-50%) scale(0.1);will-change:left,top,transform,opacity}
.road-sign-box{border:2.5px solid var(--green);border-radius:12px;padding:24px 46px;background:rgba(4,6,5,.72);box-shadow:0 0 36px rgba(0,255,174,.38),0 0 90px rgba(0,255,174,.14),inset 0 0 26px rgba(0,255,174,.1)}
.road-sign-word{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:clamp(28px,3vw,52px);letter-spacing:.02em;color:rgba(228,238,233,.55);text-shadow:0 0 18px rgba(0,255,174,.35);white-space:nowrap}
.road-sign-pole{width:2px;height:74px;background:linear-gradient(var(--green),rgba(0,255,174,0));box-shadow:0 0 12px rgba(0,255,174,.5)}
@media(max-width:1024px){.road-sign{display:none}}

/* hero: agrupa sub + CTA à esquerda, tirando o "Próximo passo" do centro/estrada */
.hero-bottom-left{display:flex;align-items:flex-end;gap:clamp(20px,3vw,40px);flex-wrap:wrap}
.hero-bottom{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:24px;margin-top:40px}
.hero-sub{max-width:440px;color:#d7d7d7;font-size:clamp(15px,1.6vw,19px)}
.hero-sub .g{color:var(--green)}
.next-step{display:inline-flex;flex-direction:column;gap:6px;border:1px solid var(--line);border-radius:7px;padding:16px 22px;transition:border-color .3s,background .3s}
.next-step:hover{border-color:var(--green);background:rgba(0,255,174,.05)}
.next-step .lab{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.16em;color:var(--gray)}
.next-step .val{font-family:var(--disp);font-weight:600;font-size:22px;text-transform:uppercase;display:flex;align-items:center;gap:10px}
.next-step .val .g{color:var(--green)}
.scroll-ind{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gray);display:flex;align-items:center;gap:10px}
.scroll-ind i{width:1px;height:34px;background:linear-gradient(var(--green),transparent);display:block;animation:scrolldown 1.8s infinite}
@keyframes scrolldown{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* =============================================================
   A ESTRADA — fundo cinematográfico em scroll (Fase 1: placeholders)
   ============================================================= */
.road-stage{position:fixed;inset:0;z-index:0;pointer-events:none;background:var(--black)}
.road-stage .road-poster,.road-stage #roadCanvas{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.road-stage #roadCanvas{z-index:1}
.road-scrim{position:absolute;inset:0;z-index:2;background:
  radial-gradient(125% 85% at 50% 16%,transparent 42%,rgba(5,5,5,.5) 100%),
  linear-gradient(180deg,rgba(5,5,5,.42) 0%,rgba(5,5,5,.1) 30%,rgba(5,5,5,.2) 58%,rgba(5,5,5,.74) 100%)}
/* abertura: a seção alta define o comprimento do scrub; o miolo fica pinado */
.road-journey{position:relative;z-index:1}
.road-pin{display:flex;align-items:flex-start;min-height:100vh;min-height:100svh}
body.journey-on .road-journey{height:420vh}
body.journey-on .road-pin{position:sticky;top:0;height:100vh;height:100svh;min-height:0;overflow:hidden}
/* conteúdo sempre acima da estrada; seções após a abertura ficam opacas */
body.journey-on #main>section:not(.road-journey),body.journey-on #main>div:not(.road-stage){position:relative;z-index:1}
body.journey-on .scene,body.journey-on .cases{background:var(--black)}
/* fallback: mobile/coarse/redução de movimento → site normal, sem estrada */
@media (max-width:1024px),(pointer:coarse){.road-stage{display:none}}
@media (prefers-reduced-motion:reduce){.road-stage{display:none}}
/* road-pin typography — mirrors .hero h1 rules without requiring .hero parent */
.road-pin .wrap{position:relative;z-index:2;padding-top:clamp(110px,16vh,148px);margin-left:0;margin-right:auto}
.road-pin h1{font-family:var(--disp);font-weight:700;text-transform:uppercase;overflow-wrap:break-word;font-size:clamp(34px,7.6vw,108px);line-height:1.02;letter-spacing:-.012em;padding-top:.08em;padding-bottom:.12em}
.road-pin h1 .g{color:var(--green)}
.road-pin h1 .hw{display:inline-block;opacity:0;will-change:transform,opacity;transform-origin:50% 50%}
.road-pin h1 .hw.show{opacity:1;transform:none}
@media(min-width:1025px){.road-pin h1{max-width:64%}}

/* marquee */
.marquee{display:flex;overflow:hidden;white-space:nowrap;padding:16px 0;background:var(--green);color:#000;position:relative;z-index:1}
.marquee-t{display:inline-flex;align-items:center;gap:28px;font-family:var(--disp);font-weight:700;font-size:24px;text-transform:uppercase;padding-right:28px;animation:marq 30s linear infinite}
.marquee-t .dot{opacity:.55}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* manifesto */
.manifesto{font-family:var(--disp);font-weight:600;text-transform:uppercase;font-size:clamp(23px,4.5vw,72px);line-height:1.14;letter-spacing:-.006em;max-width:1180px;padding-top:.06em}
.manifesto span{display:block}
.manifesto .g{color:var(--green);display:inline}
.manifesto .muted{color:#8a8a8a;display:inline}
.man-foot{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px;margin-top:54px}
.man-foot img{height:42px;width:auto;opacity:.9}
.man-foot p{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--gray)}

/* horizontal cases */
/* Cases — grid de cards com logo do cliente (sem scroll horizontal) */
.cases{position:relative;background:var(--black);border-top:1px solid var(--line);box-shadow:0 -50px 90px rgba(0,0,0,.75);border-radius:26px 26px 0 0;z-index:1;padding:clamp(56px,8vw,110px) 0}
.case-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.case-card{position:relative;height:clamp(330px,33vw,400px);perspective:1300px;border:0;background:transparent;padding:0;outline:none;cursor:pointer}
.case-flip{position:relative;width:100%;height:100%;transition:transform .7s cubic-bezier(.45,.05,.2,1);transform-style:preserve-3d}
.case-card:hover .case-flip,.case-card:focus-within .case-flip{transform:rotateY(180deg)}
.case-face{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border:1px solid var(--line);border-radius:14px;background:var(--panel);overflow:hidden;display:flex;flex-direction:column;padding:clamp(24px,2.4vw,32px);transition:border-color .4s,box-shadow .4s}
.case-card:hover .case-face,.case-card:focus-within .case-face{border-color:var(--green);box-shadow:0 0 30px rgba(0,255,174,.12)}
.case-front{align-items:center;justify-content:center;gap:16px;text-align:center}
.case-front-top{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}
.case-avatar{width:54px;height:54px;border-radius:50%;object-fit:cover;border:2px solid var(--green);box-shadow:0 0 14px rgba(0,255,174,.32);flex:0 0 auto}
.case-front .case-logo{height:clamp(44px,4.6vw,60px);max-width:62%;margin-top:0}
.case-front .case-client{margin-top:0}
.case-hint{position:absolute;left:0;right:0;bottom:22px;font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--green);opacity:.85}
.case-back{transform:rotateY(180deg)}
.case-back>*{position:relative;z-index:1}
.case-back .cgrid{position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:46px 46px;opacity:.35;z-index:0}
.case-top{display:flex;justify-content:space-between;align-items:center;gap:14px;min-height:30px}
.case-logo{height:30px;width:auto;max-width:55%;object-fit:contain;opacity:.9}
.case-year{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--gray)}
.case-client{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--gray);margin-top:18px}
.case-metric{font-family:var(--disp);font-weight:700;font-size:clamp(44px,5.2vw,72px);line-height:1;text-transform:uppercase;margin-top:4px;padding-bottom:.04em}
.case-metric .g{color:var(--green)}
.case-card h3{font-family:var(--disp);font-weight:600;font-size:clamp(20px,2.2vw,26px);text-transform:uppercase;margin-top:8px}
.case-card p{color:#bdbdbd;font-size:14.5px;line-height:1.55;margin-top:10px}
.case-quotes{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-top:18px}
.case-quote{border:1px solid var(--line);border-radius:14px;padding:clamp(24px,2.4vw,32px);background:#0a0d0c;display:flex;flex-direction:column}
.quote-photo{width:52px;height:52px;border-radius:50%;object-fit:cover;border:2px solid var(--green);box-shadow:0 0 12px rgba(0,255,174,.3);margin-bottom:18px}
.case-quote blockquote{font-family:var(--body);font-weight:400;font-size:clamp(15px,1.15vw,17px);line-height:1.5;color:#e7e7e7;flex:1 1 auto}
.case-quote blockquote .g{color:var(--green);font-weight:600}
.case-quote .quote-result{font-family:var(--mono);font-size:12px;letter-spacing:.03em;color:#cfcfcf;margin-top:18px;padding-top:14px;border-top:1px solid var(--line)}
.case-quote .quote-result .g{color:var(--green);font-weight:700}
.case-quote figcaption{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--gray);margin-top:14px}
.case-next{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;margin-top:34px;border-top:1px solid var(--line);padding-top:34px}
.case-next h3{font-family:var(--disp);font-weight:700;font-size:clamp(28px,3.4vw,48px);text-transform:uppercase;margin-top:8px}
.case-next h3 .g{color:var(--green)}
.case-next p{color:#bdbdbd;margin-top:6px}
@media(max-width:1024px){.case-grid{grid-template-columns:repeat(2,1fr)}.case-quotes{grid-template-columns:1fr}}
@media(max-width:600px){.case-grid{grid-template-columns:1fr}}
/* sem hover (touch): não vira — mostra direto o card com a info */
@media(hover:none){.case-card{height:auto;cursor:auto}.case-flip{transform:none!important}.case-front{display:none}.case-face.case-back{position:relative;transform:none;backface-visibility:visible;-webkit-backface-visibility:visible}}
@keyframes nudge{0%,100%{transform:translateX(0)}50%{transform:translateX(6px)}}

/* category panels */
.panels{display:grid;grid-template-columns:1fr 1fr;gap:0;width:100%}
.cat{position:relative;min-height:min(66vh,560px);border:1px solid var(--line);border-radius:0;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;padding:clamp(28px,3vw,44px);transition:background .5s,color .5s}
.panels>.cat:first-child{border-radius:14px 0 0 14px;border-right:none}
.panels>.cat:last-child{border-radius:0 14px 14px 0}
.cat .cgrid{position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:56px 56px;opacity:.4;transition:opacity .5s}
.cat>*{position:relative;z-index:1}
.cat:hover{background:var(--green);color:#000}.cat:hover .cgrid{opacity:0}
.cat .ctag{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.16em;color:var(--green);transition:color .5s}
.cat:hover .ctag{color:#000}
.cat h2{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:clamp(30px,4.4vw,72px);line-height:1.04;padding-top:.08em;padding-bottom:.04em}
.cat .clist{display:flex;flex-wrap:wrap;gap:8px 16px;margin-top:18px}
.cat .clist span{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.06em;opacity:.8}
.cat .cgo{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:13px;text-transform:uppercase;letter-spacing:.1em;margin-top:24px}
.cat .cgo .ar{transition:transform .3s}.cat:hover .cgo .ar{transform:translateX(6px)}

/* services hover-swap */
.caps{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.cap{position:relative;border:1px solid var(--line);border-radius:9px;overflow:hidden;min-height:270px;padding:28px;display:flex;flex-direction:column;justify-content:space-between;transition:background .45s,color .45s,transform .45s}
.cap:hover{background:var(--green);color:#000;transform:translateY(-6px)}
.cap .cnum{font-family:var(--mono);font-size:12px;letter-spacing:.14em;color:var(--green);transition:color .45s}
.cap:hover .cnum{color:#000}
.cap h3{font-family:var(--disp);font-weight:600;font-size:clamp(24px,2.6vw,32px);text-transform:uppercase;line-height:1.08}
.cap .out{font-size:14.5px;line-height:1.5;opacity:0;max-height:0;transform:translateY(10px);transition:opacity .4s,transform .4s,max-height .4s}
.cap:hover .out{opacity:1;max-height:130px;transform:none}
.cap .cdef{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--gray);transition:opacity .35s}
.cap:hover .cdef{opacity:0}

/* feature/app */
.feature{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--line);background:radial-gradient(circle at 80% 20%,rgba(0,255,174,.16),transparent 55%),var(--panel);padding:clamp(34px,5vw,76px);width:100%}
.feature .tlabel{margin-bottom:20px}
.feature h2{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:clamp(36px,6vw,92px);line-height:1.08;max-width:14ch;padding-top:.16em;padding-bottom:.05em}
.feature h2 .g{color:var(--green)}
.feature p{margin-top:22px;color:#cfcfcf;max-width:560px;font-size:17px}
.feature .chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:26px}
.feature .chips span{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;border:1px solid var(--line);padding:9px 13px;border-radius:4px;color:#cfcfcf}
.feature .fcta{margin-top:32px}
.scene-wm{position:absolute;left:0;right:0;bottom:-1%;text-align:center;font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:clamp(70px,17vw,250px);line-height:.8;color:rgba(255,255,255,.035);letter-spacing:-.02em;z-index:0;pointer-events:none;white-space:nowrap;overflow:hidden}

/* buttons */
.btn{font-family:var(--mono);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;background:var(--green);color:#000;padding:17px 26px;border-radius:4px;display:inline-flex;align-items:center;gap:12px;position:relative;overflow:hidden;transition:transform .25s;border:1px solid var(--green)}
.btn span{position:relative;z-index:1;transition:color .3s}
.btn::before{content:"";position:absolute;inset:0;background:#000;transform:translateY(101%);transition:transform .35s cubic-bezier(.7,0,.3,1);z-index:0}
.btn:hover::before{transform:translateY(0)}.btn:hover span{color:var(--green)}.btn:hover{transform:translateY(-2px)}
.btn.ghost{background:transparent;color:#fff;border:1px solid var(--line)}.btn.ghost::before{background:var(--green)}.btn.ghost:hover span{color:#000}
.btn .ar{transition:transform .3s}.btn:hover .ar{transform:translateX(4px)}

/* clients wall */
.flow.clients{padding:clamp(44px,6vw,76px) 0}
.wall-row{display:flex;overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.wall-move{display:flex;align-items:center;gap:60px;padding-right:60px}
.wall-move.a{animation:marq 40s linear infinite}
.wall-move.b{animation:marq 52s linear infinite reverse}
.wall-move img{height:60px;width:auto;filter:grayscale(1) brightness(0) invert(1);opacity:.65;transition:opacity .3s,filter .3s}
.wall-move img:hover{opacity:1;filter:none}

/* team */
.team-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.member{position:relative;border:1px solid var(--line);border-radius:7px;overflow:hidden;aspect-ratio:3/4;background:var(--panel);transition:transform .45s cubic-bezier(.2,.7,.2,1),border-color .45s,box-shadow .45s}
.member:hover{transform:translateY(-6px) scale(1.03);border-color:var(--green);box-shadow:0 18px 44px rgba(0,0,0,.55);z-index:2}
.member img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.7,.2,1);opacity:1}
.member:hover img{transform:scale(1.08)}
.member .ov{position:absolute;left:0;bottom:0;width:100%;padding:14px;background:linear-gradient(transparent,rgba(5,5,5,.92));transform:translateY(8px);opacity:.85;transition:transform .4s,opacity .4s}
.member:hover .ov{transform:none;opacity:1}
.member .ov .nm{font-family:var(--disp);font-weight:600;font-size:16px;text-transform:uppercase;line-height:1}
.member .ov .rl{font-family:var(--mono);font-size:10.5px;color:var(--green);text-transform:uppercase;letter-spacing:.1em;margin-top:4px}
.founders{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:18px}
.founder{border:1px solid var(--line);border-radius:9px;padding:28px;transition:border-color .35s,transform .35s}
.founder:hover{border-color:var(--green);transform:translateY(-5px)}
.founder .role{font-family:var(--mono);font-size:11px;color:var(--green);letter-spacing:.16em}
.founder h3{font-family:var(--disp);font-weight:600;font-size:26px;text-transform:uppercase;margin:12px 0 12px}
.founder p{font-size:13.5px;color:#bdbdbd;line-height:1.6}

/* contact */
.contact{position:relative;overflow:hidden}
.contact-glow{position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 50% 40%,rgba(0,255,174,.1),transparent 70%);z-index:0}
.contact h2{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:clamp(32px,7vw,116px);line-height:1.06;text-align:center;padding-top:.08em;padding-bottom:.1em}
.contact h2 .g{color:var(--green)}
.cwrap{display:grid;grid-template-columns:1fr 1fr;gap:44px;margin-top:48px;align-items:start}
.cwrap .ccopy p{color:#c4c4c4;margin-top:18px;max-width:440px}
.cwrap .pts{margin-top:26px;display:flex;flex-direction:column;gap:13px}
.cwrap .pts div{display:flex;align-items:center;gap:12px;font-family:var(--mono);font-size:13px;text-transform:uppercase;letter-spacing:.05em}
.cwrap .pts div::before{content:"";width:9px;height:9px;background:var(--green);clip-path:polygon(0 0,100% 50%,0 100%);flex-shrink:0}
form{border:1px solid var(--line);border-radius:11px;padding:clamp(24px,3vw,34px);background:rgba(255,255,255,.02)}
.field{margin-bottom:16px}
.field label{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--green);display:block;margin-bottom:7px}
.field input,.field textarea{width:100%;background:rgba(0,0,0,.4);border:1px solid var(--line);border-radius:4px;padding:13px;color:#fff;font-family:var(--body);font-size:15px;transition:border-color .3s,background .3s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--green);background:rgba(0,255,174,.04)}
.field textarea{resize:vertical;min-height:80px}
form .btn{width:100%;justify-content:center;margin-top:4px}
.form-note{font-family:var(--mono);font-size:10px;color:var(--gray);text-align:center;margin-top:12px;letter-spacing:.06em}

/* footer */
.bigfoot{padding:clamp(28px,3.5vw,52px) 0 32px;border-top:1px solid var(--line);position:relative;z-index:1;background:var(--black);border-radius:26px 26px 0 0;box-shadow:0 -50px 90px rgba(0,0,0,.75)}
.bigfoot h2{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:clamp(20px,4.6vw,72px);line-height:1.02;letter-spacing:-.01em;padding-top:.04em;padding-bottom:.1em}
.bigfoot h2 .g{color:var(--green)}
.foot-cols{display:grid;grid-template-columns:1.3fr 1fr 1fr 1.2fr;gap:36px;margin-top:36px}
.foot-logo{height:34px;width:auto;display:block;margin-bottom:16px}
.foot-cols p.desc{color:#9a9a9a;font-size:14px;max-width:280px}
.foot-col h4{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--gray);margin-bottom:16px}
.foot-col a,.foot-col p{display:block;color:#cfcfcf;font-size:14px;margin-bottom:9px;transition:color .25s}
.foot-col a:hover{color:var(--green)}
.news{display:flex;gap:8px;margin-top:8px}
.news input{flex:1;background:rgba(0,0,0,.4);border:1px solid var(--line);border-radius:4px;padding:12px;color:#fff;font-family:var(--body);font-size:14px}
.news input:focus{outline:none;border-color:var(--green)}
.news button{background:var(--green);color:#000;border:0;border-radius:4px;padding:0 16px;font-family:var(--mono);font-weight:700;font-size:16px;cursor:pointer}
.foot-bot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;padding-top:28px;margin-top:50px;border-top:1px solid var(--line);font-family:var(--mono);font-size:11px;color:var(--gray);text-transform:uppercase;letter-spacing:.08em}

.wa-float{position:fixed;right:22px;bottom:22px;z-index:910;width:58px;height:58px;border-radius:50%;background:var(--green);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px rgba(0,255,174,.35);transition:transform .3s}
.wa-float:hover{transform:scale(1.08)}

/* ===== 3D PORTFOLIO DECK (flat 2D, bleed-proof) ===== */
.deck-journey{position:relative;z-index:0}
.deck-pin{position:relative;min-height:100vh;min-height:100svh;background:#090909;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:clamp(16px,2.5vh,32px);overflow:hidden}
.deck-head-wrap{text-align:center;position:relative;z-index:2;width:100%}
.deck-head-wrap h2 .g{color:var(--green)}
/* perspective removed: no child uses translateZ/rotateY anymore */
.deck-scene{width:100%;flex:1;display:flex;align-items:center;justify-content:center;position:relative;z-index:1;overflow:visible}
/* preserve-3d removed -> deterministic flat paint order driven by z-index */
.deck-group{position:relative;width:260px;height:360px}
/* opaque background = physical occluder; opacity stays 1.0 always (JS never touches it) */
.deck-card{position:absolute;left:0;top:0;width:260px;height:360px;border-radius:16px;border:1px solid rgba(255,255,255,.09);overflow:hidden;background:var(--panel);cursor:pointer;box-shadow:0 24px 64px rgba(0,0,0,.7);will-change:transform;transform-origin:50% 60%;transition:box-shadow .25s ease,border-color .25s ease,filter .25s ease;outline:none}
.deck-group .deck-card{cursor:grab}
.deck-group.is-grabbing,.deck-group.is-grabbing .deck-card{cursor:grabbing;user-select:none}
.deck-card img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}
.deck-card-cover{position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(0,0,0,.88) 100%);pointer-events:none}
.deck-card-info{position:absolute;bottom:0;left:0;right:0;padding:18px 16px;pointer-events:none}
.deck-card-name{color:#fff;font-family:var(--disp);font-weight:600;font-size:15px;text-transform:uppercase;letter-spacing:.04em}
.deck-card-metric{color:var(--green);font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;margin-top:5px}
/* neighbor dim uses filter (brightness), never opacity, so no translucency bleed */
.deck-card.is-dimmed{filter:brightness(.62)}
/* focused/selected card: neon-green ring */
.deck-card.is-focus,.deck-card:focus-visible{box-shadow:0 30px 80px rgba(0,0,0,.8),0 0 0 2px var(--green),0 0 40px rgba(0,255,174,.25);border-color:rgba(0,255,174,.55)}
/* sr-only live region for keyboard selection announcements */
.deck-sr{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

/* deck mobile — grid fallback (UNCHANGED behavior; neutralize new effects) */
@media(max-width:767px){
  .deck-journey{height:auto}
  .deck-pin{position:static;height:auto;padding:clamp(60px,10vw,80px) 0}
  .deck-scene{height:auto;perspective:none;flex:none}
  .deck-group{transform:none!important;display:grid;grid-template-columns:repeat(2,1fr);gap:12px;width:calc(100% - 2*var(--gut));max-width:460px;height:auto}
  .deck-card{position:static;width:100%;height:180px;transform:none!important;opacity:1!important;filter:none!important;z-index:auto!important;box-shadow:0 24px 64px rgba(0,0,0,.7)!important;border-color:rgba(255,255,255,.09)!important}
}
@media(min-width:768px) and (max-width:1024px){
  .deck-group{width:220px;height:300px}
  .deck-card{width:220px;height:300px}
}
@media (min-width:768px) and (prefers-reduced-motion:reduce), (min-width:768px) and (pointer:coarse){
  .deck-journey{height:auto}
  .deck-pin{position:static;height:auto;padding:clamp(60px,10vw,80px) 0}
  .deck-scene{flex:none;height:auto}
  .deck-group{transform:none!important;display:grid;grid-template-columns:repeat(2,1fr);gap:16px;width:min(720px,90vw);height:auto}
  .deck-card{position:static;width:100%;height:300px;transform:none!important;z-index:auto!important;filter:none!important;box-shadow:0 24px 64px rgba(0,0,0,.7)}
}
@media(prefers-reduced-motion:reduce){
  .deck-card{transition:none}
}

/* responsive */
@media(max-width:1024px){
  .menu-grid{grid-template-columns:1fr}
  .menu-side{border-left:0;border-top:1px solid var(--line);padding-left:0;padding-top:26px;margin-top:10px}
  .caps{grid-template-columns:repeat(2,1fr)}
  .team-grid{grid-template-columns:repeat(4,1fr)}
  .cwrap{grid-template-columns:1fr;gap:34px}
  .foot-cols{grid-template-columns:1fr 1fr;gap:30px}
}
@media(max-width:860px){
  .panels{grid-template-columns:1fr}
  .cat{min-height:auto;padding:34px}
  .panels>.cat:first-child{border-right:1px solid var(--line);border-radius:14px}
  .panels>.cat:last-child{border-radius:14px}
  .team-grid{grid-template-columns:repeat(3,1fr)}
  .founders{grid-template-columns:1fr}
}
@media(max-width:560px){
  .store-link{display:none}
  .caps{grid-template-columns:1fr}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .foot-cols{grid-template-columns:1fr}
  .marquee-t{font-size:20px;gap:20px}
  .wa-float{width:52px;height:52px;right:16px;bottom:16px}
  .hero-bottom{gap:18px}
}
/* small / short screens: drop sticky stacking to avoid clipping */
@media(max-width:1024px),(max-height:660px),(pointer:coarse){
  .scene{position:static;min-height:auto;padding-top:clamp(96px,16vw,120px);padding-bottom:clamp(60px,12vw,90px);border-radius:22px 22px 0 0}
  .hero{min-height:100svh;padding-top:120px}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .r{opacity:1!important;transform:none!important;clip-path:none!important}
}

/* =============================================================
   PÁGINAS INTERNAS (sobre, blog, post, privacidade)
   Mesma linguagem visual; adicionado para a versão multi-página.
   ============================================================= */

/* cabeçalho padrão de página interna */
.page-head{position:relative;overflow:hidden;background:var(--black);
  padding:clamp(96px,12vw,140px) 0 clamp(40px,6vw,72px);border-bottom:1px solid var(--line)}
.page-head .hero-grid{position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:72px 72px;mask-image:radial-gradient(ellipse 90% 80% at 50% 40%,#000 25%,transparent 80%);opacity:.4;z-index:0}
.page-head .hero-glow{position:absolute;width:60vw;height:60vw;max-width:720px;max-height:720px;border-radius:50%;background:radial-gradient(circle,rgba(0,255,174,.12),transparent 62%);top:-30%;right:-8%;z-index:0;filter:blur(10px)}
.page-head .wrap{position:relative;z-index:1}
.page-head h1{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:clamp(38px,8vw,104px);line-height:1.06;letter-spacing:-.01em;margin-top:16px;padding-top:.12em;padding-bottom:.06em}
.page-head h1 .g{color:var(--green)}
.page-head .lead{color:#bdbdbd;font-size:clamp(16px,1.8vw,20px);max-width:660px;margin-top:20px}
.breadcrumb{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--gray);display:flex;gap:8px;flex-wrap:wrap}
.breadcrumb a{color:var(--gray);transition:color .25s}
.breadcrumb a:hover{color:var(--green)}
.breadcrumb .sep{color:var(--green)}

/* ---------- Página de Contato ---------- */
.channels{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:14px}
.channel{border:1px solid var(--line);border-radius:12px;padding:clamp(22px,2.4vw,30px);background:var(--panel);display:flex;flex-direction:column;gap:10px;transition:border-color .35s,transform .35s}
.channel:hover{border-color:var(--green);transform:translateY(-6px)}
.channel .cnum{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--green);text-transform:uppercase}
.channel h3{font-family:var(--disp);font-weight:600;font-size:clamp(20px,2.2vw,26px);text-transform:uppercase}
.channel p{color:#bdbdbd;font-size:14.5px;line-height:1.55}
.channel .val{margin-top:auto;padding-top:6px;font-family:var(--mono);font-size:13px;color:#fff;display:inline-flex;align-items:center;gap:9px;letter-spacing:.04em;word-break:break-word}
.channel .val .ar{color:var(--green);transition:transform .3s}
.channel:hover .val .ar{transform:translateX(6px)}
@media(max-width:920px){.channels{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.channels{grid-template-columns:1fr}}
.contact-info{margin-top:32px;display:grid;gap:18px}
.contact-info .ci{display:flex;flex-direction:column;gap:5px}
.contact-info .ci .lab{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--gray);text-transform:uppercase}
.contact-info .ci a,.contact-info .ci span{color:#dcdcdc;font-size:15.5px;transition:color .25s}
.contact-info .ci a:hover{color:var(--green)}
.contact-socials{display:flex;gap:12px;flex-wrap:wrap;margin-top:4px}
.contact-socials a{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;border:1px solid var(--line);padding:9px 13px;border-radius:4px;color:#cfcfcf;transition:border-color .3s,color .3s}
.contact-socials a:hover{border-color:var(--green);color:var(--green)}

/* seção genérica de página interna */
.section{padding:clamp(56px,8vw,110px) 0;position:relative}
.section.alt{background:var(--black2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}

/* nav: estado ativo */
.menu-links a.active{opacity:1;color:var(--green)}
.store-link.active{color:var(--green)}
.foot-col a.active{color:var(--green)}

/* ===== SOBRE: missão / visão / valores ===== */
.mvv{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:14px}
.mvv .card{border:1px solid var(--line);border-radius:12px;padding:clamp(24px,2.6vw,34px);background:var(--panel);transition:border-color .4s,transform .4s;position:relative;overflow:hidden}
.mvv .card:hover{border-color:var(--green);transform:translateY(-6px)}
.mvv .card .cnum{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--green);text-transform:uppercase}
.mvv .card h3{font-family:var(--disp);font-weight:600;font-size:clamp(22px,2.4vw,28px);text-transform:uppercase;margin:12px 0 10px}
.mvv .card p{color:#bdbdbd;font-size:15.5px;line-height:1.6}
.mvv .card ul{list-style:none;margin-top:6px;display:flex;flex-direction:column;gap:10px}
.mvv .card li{display:flex;align-items:flex-start;gap:10px;color:#cfcfcf;font-size:15px}
.mvv .card li::before{content:"";width:9px;height:9px;margin-top:6px;background:var(--green);clip-path:polygon(0 0,100% 50%,0 100%);flex-shrink:0}

/* bloco de texto longo (história / compromisso / artigo) */
.prose{max-width:760px}
.prose.center{margin:0 auto}
.prose>p{color:#d2d2d2;font-size:clamp(16px,1.15vw,17.5px);line-height:1.8;margin:0 0 20px}
.prose>h2{font-family:var(--disp);font-weight:600;font-size:clamp(24px,3.2vw,38px);text-transform:uppercase;line-height:1.1;margin:42px 0 16px;padding-top:.06em}
.prose>h2 .g{color:var(--green)}
.prose>h3{font-family:var(--disp);font-weight:600;font-size:clamp(20px,2.4vw,27px);text-transform:uppercase;margin:30px 0 12px;color:#fff}
.prose ul,.prose ol{margin:0 0 20px;padding-left:4px;color:#d2d2d2;list-style:none}
.prose ol{counter-reset:li}
.prose li{position:relative;padding-left:26px;margin-bottom:11px;line-height:1.7;font-size:16.5px}
.prose ul>li::before{content:"";position:absolute;left:0;top:9px;width:9px;height:9px;background:var(--green);clip-path:polygon(0 0,100% 50%,0 100%)}
.prose ol>li{counter-increment:li}
.prose ol>li::before{content:counter(li);position:absolute;left:0;top:0;font-family:var(--mono);font-size:12px;color:var(--green)}
.prose strong{color:#fff;font-weight:600}
.prose em{color:#e6e6e6}
.prose a{color:var(--green);text-decoration:underline;text-underline-offset:3px}
.prose blockquote{border-left:3px solid var(--green);padding:4px 0 4px 22px;margin:26px 0;font-family:var(--disp);font-weight:500;font-size:clamp(20px,2.4vw,26px);line-height:1.2;text-transform:uppercase;color:#fff}

/* ===== BLOG: listagem ===== */
.blog-tools{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between;margin-bottom:34px}
.blog-search{position:relative;flex:1;min-width:240px;max-width:420px}
.blog-search input{width:100%;background:rgba(0,0,0,.4);border:1px solid var(--line);border-radius:6px;padding:13px 14px 13px 40px;color:#fff;font-family:var(--body);font-size:15px;transition:border-color .3s,background .3s}
.blog-search input:focus{outline:none;border-color:var(--green);background:rgba(0,255,174,.04)}
.blog-search svg{position:absolute;left:13px;top:50%;transform:translateY(-50%);opacity:.5}
.blog-count{font-family:var(--mono);font-size:12px;color:var(--gray);text-transform:uppercase;letter-spacing:.1em;white-space:nowrap}
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:start}
.pcard{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--panel);transition:border-color .4s,transform .4s}
.pcard:hover{border-color:var(--green);transform:translateY(-6px)}
.pcard .thumb{position:relative;aspect-ratio:16/10;width:100%;flex:0 0 auto;overflow:hidden;background:var(--black2)}
.pcard .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s,filter .4s}
.pcard:hover .thumb img{transform:scale(1.06)}
/* capa "marca BAM" gerada por CSS (posts sem imagem) */
.thumb.brand{display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 75% 25%,rgba(0,255,174,.18),transparent 55%),var(--panel)}
.thumb.brand::before{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:40px 40px;opacity:.4}
.thumb.brand img{width:46%;height:auto;object-fit:contain;opacity:.9;transform:none;filter:none}
.pcard:hover .thumb.brand img{transform:scale(1.04)}
.pcard .pbody{padding:22px;display:flex;flex-direction:column;gap:11px;flex:1}
.pcard .pmeta{font-family:var(--mono);font-size:11px;color:var(--green);text-transform:uppercase;letter-spacing:.1em;display:flex;gap:10px;flex-wrap:wrap}
.pcard .pmeta .pcat{color:var(--green)}
.pcard .pmeta .date{color:var(--gray)}
.pcard h3{font-family:var(--disp);font-weight:600;font-size:19px;line-height:1.12;text-transform:uppercase;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pcard p{color:#bdbdbd;font-size:14.5px;line-height:1.55;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;min-height:calc(1.55em * 3)}
.pcard .pgo{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--green);display:inline-flex;align-items:center;gap:8px;margin-top:2px}
.pcard .pgo .ar{transition:transform .3s}
.pcard:hover .pgo .ar{transform:translateX(5px)}
.no-results{display:none;color:var(--gray);font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;padding:40px 0}

/* ===== POST: artigo ===== */
.article{max-width:820px;margin:0 auto}
.article-head{max-width:820px;margin:18px auto 0}
.article-head .pmeta{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--green);display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.article-head .pmeta .dim{color:var(--gray)}
.page-head .article-head h1{font-size:clamp(30px,4.6vw,60px);line-height:1.05;letter-spacing:-.015em;margin-top:18px;padding-top:.02em;padding-bottom:.04em}
.article-cover{border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-bottom:36px;aspect-ratio:16/9;background:var(--black2)}
.article-cover img{width:100%;height:100%;object-fit:cover}
.article-foot{max-width:820px;margin:48px auto 0;padding-top:28px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px}
.article-foot .back{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--green);display:inline-flex;align-items:center;gap:8px}
.article-cta{margin-top:44px;border:1px solid var(--line);border-radius:14px;padding:clamp(28px,4vw,48px);text-align:center;background:radial-gradient(circle at 50% 0,rgba(0,255,174,.12),transparent 60%),var(--panel)}
.article-cta h3{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:clamp(24px,3.4vw,40px);line-height:1.06;padding-top:.04em}
.article-cta h3 .g{color:var(--green)}
.article-cta p{color:#bdbdbd;margin:14px auto 24px;max-width:480px}

/* ===== responsivo das páginas internas ===== */
@media(max-width:1024px){
  .posts{grid-template-columns:repeat(2,1fr)}
  .mvv{grid-template-columns:1fr}
}
@media(max-width:640px){
  .posts{grid-template-columns:1fr}
  .blog-tools{flex-direction:column;align-items:stretch}
  .article-foot{flex-direction:column;align-items:flex-start}
}

/* acessibilidade: link de pular para o conteúdo */
.skip-link{position:absolute;left:-9999px;top:0;z-index:10001;background:var(--green);color:#000;padding:10px 16px;font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.1em;border-radius:0 0 6px 0}
.skip-link:focus{left:0}

/* =============================================================
   PÁGINA DE PORTFÓLIO (portifolio.html)
   ============================================================= */
/* faixa de resultados */
.pf-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:8px}
.pf-stat{border:1px solid var(--line);border-radius:12px;padding:clamp(22px,2.4vw,30px);background:var(--panel);transition:border-color .4s,transform .4s}
.pf-stat:hover{border-color:var(--green);transform:translateY(-6px)}
.pf-stat .n{font-family:var(--disp);font-weight:700;font-size:clamp(32px,4.2vw,56px);line-height:1;color:var(--green);text-transform:uppercase;padding-bottom:.04em}
.pf-stat .l{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:#bdbdbd;margin-top:10px;display:block;line-height:1.4}
@media(max-width:860px){.pf-stats{grid-template-columns:repeat(2,1fr)}}

/* barra de filtros */
.pf-filter{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:clamp(24px,3vw,36px)}
.pf-chip{font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:#cfcfcf;background:transparent;border:1px solid var(--line);border-radius:40px;padding:11px 20px;cursor:pointer;transition:border-color .3s,color .3s,background .3s}
.pf-chip:hover{border-color:var(--green);color:var(--green)}
.pf-chip[aria-pressed="true"]{background:var(--green);color:#000;border-color:var(--green)}
.pf-chip .c{opacity:.55;margin-left:7px}
.pf-chip[aria-pressed="true"] .c{opacity:.75}

/* grade de trabalhos */
.pf-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.work{position:relative;display:block;width:100%;border:1px solid var(--line);border-radius:13px;overflow:hidden;background:var(--panel);cursor:pointer;aspect-ratio:4/5;padding:0;text-align:left;transition:border-color .45s,box-shadow .45s,transform .45s cubic-bezier(.2,.7,.2,1)}
.work:hover,.work:focus-visible{border-color:var(--green);box-shadow:0 18px 50px rgba(0,0,0,.6),0 0 30px rgba(0,255,174,.12);transform:translateY(-6px);outline:none}
.work img{width:100%;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.2,.7,.2,1)}
.work:hover img,.work:focus-visible img{transform:scale(1.07)}
.work .work-cover{position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,5,5,.5) 0%,transparent 26%,transparent 50%,rgba(5,5,5,.92) 100%);transition:opacity .4s}
.work-top{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:flex-start;gap:10px;padding:14px;z-index:1}
.work .wtag{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--green);background:rgba(4,6,5,.66);border:1px solid rgba(0,255,174,.32);border-radius:30px;padding:6px 11px;backdrop-filter:blur(4px)}
.work .wzoom{flex:0 0 auto;width:34px;height:34px;border-radius:50%;border:1px solid var(--green);background:rgba(4,6,5,.55);display:flex;align-items:center;justify-content:center;color:var(--green);opacity:0;transform:scale(.6) rotate(-25deg);transition:opacity .4s,transform .5s cubic-bezier(.34,1.56,.64,1);backdrop-filter:blur(4px)}
.work:hover .wzoom,.work:focus-visible .wzoom{opacity:1;transform:none}
.work .wzoom svg{width:15px;height:15px}
.work-info{position:absolute;left:0;right:0;bottom:0;padding:18px 16px;z-index:1}
.work .wmetric{font-family:var(--disp);font-weight:700;font-size:clamp(22px,2.4vw,30px);line-height:1;color:var(--green);text-transform:uppercase;margin-bottom:6px}
.work .wt{font-family:var(--disp);font-weight:600;font-size:clamp(17px,1.7vw,21px);text-transform:uppercase;line-height:1.1;color:#fff}
.work .wseg{font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.1em;color:#c4c4c4;margin-top:6px;display:block}
.work[hidden]{display:none}
.pf-empty{display:none;color:var(--gray);font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;padding:50px 0;text-align:center}
@media(max-width:860px){.pf-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1500px){.pf-grid{grid-template-columns:repeat(4,1fr)}}

/* lightbox */
.lightbox{position:fixed;inset:0;z-index:9999;background:rgba(3,4,4,.95);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .35s,visibility .35s;padding:clamp(16px,4vw,40px)}
.lightbox.open{opacity:1;visibility:visible}
.lb-stage{position:relative;max-width:min(94vw,700px);width:100%;display:flex;flex-direction:column;align-items:center;gap:16px;transform:scale(.95);transition:transform .4s cubic-bezier(.34,1.3,.64,1)}
.lightbox.open .lb-stage{transform:none}
.lb-img{max-width:100%;max-height:76vh;width:auto;border-radius:14px;border:1px solid rgba(0,255,174,.4);box-shadow:0 30px 80px rgba(0,0,0,.7),0 0 50px rgba(0,255,174,.14)}
.lb-cap{text-align:center}
.lb-cap .t{font-family:var(--disp);font-weight:600;font-size:clamp(18px,2.2vw,24px);text-transform:uppercase;color:#fff}
.lb-cap .s{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:var(--green);margin-top:7px}
.lb-btn{position:absolute;top:50%;transform:translateY(-50%);width:50px;height:50px;border-radius:50%;border:1px solid var(--line);background:rgba(4,6,5,.72);color:#fff;font-family:var(--disp);font-size:24px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .3s,color .3s;z-index:2}
.lb-btn:hover{border-color:var(--green);color:var(--green)}
.lb-prev{left:-10px}.lb-next{right:-10px}
.lb-close{position:fixed;top:20px;right:22px;width:48px;height:48px;border-radius:50%;border:1px solid var(--line);background:rgba(4,6,5,.72);color:#fff;font-size:24px;line-height:1;cursor:pointer;transition:border-color .3s,color .3s;z-index:3}
.lb-close:hover{border-color:var(--green);color:var(--green)}
.lb-count{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--gray);text-transform:uppercase}
@media(max-width:600px){.lb-prev{left:-2px}.lb-next{right:-2px}.lb-btn{width:42px;height:42px;font-size:20px}.lb-close{top:14px;right:14px}}

/* grade estática de logos de clientes (página de portfólio) */
.pf-clients{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-top:clamp(30px,4vw,46px)}
.pf-clients .logo{display:flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:11px;background:var(--panel);padding:22px 16px;min-height:104px;position:relative;overflow:hidden;transition:border-color .4s,transform .4s,background .4s,box-shadow .4s}
.pf-clients .logo::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 120%,rgba(0,255,174,.16),transparent 60%);opacity:0;transition:opacity .4s}
.pf-clients .logo:hover{border-color:var(--green);transform:translateY(-6px);box-shadow:0 16px 40px rgba(0,0,0,.5)}
.pf-clients .logo:hover::before{opacity:1}
.pf-clients .logo img{max-height:48px;max-width:100%;width:auto;object-fit:contain;position:relative;z-index:1;filter:grayscale(1) brightness(0) invert(1);opacity:.58;transition:opacity .4s,transform .5s cubic-bezier(.2,.7,.2,1)}
.pf-clients .logo:hover img{opacity:1;transform:scale(1.08)}
@media(max-width:1024px){.pf-clients{grid-template-columns:repeat(4,1fr)}}
@media(max-width:640px){.pf-clients{grid-template-columns:repeat(3,1fr);gap:10px}.pf-clients .logo{min-height:88px;padding:18px 12px}.pf-clients .logo img{max-height:40px}}
@media(max-width:420px){.pf-clients{grid-template-columns:repeat(2,1fr)}}

/* ===== HOME: BLOG SHOWCASE — janela do navegador (computador + blog) ===== */
.blogwide{position:relative;margin-bottom:0;padding:clamp(44px,6vw,80px) 0}
.blogwin{position:relative;margin-top:8px;border:1px solid var(--line);border-radius:16px;overflow:hidden;
  background:var(--panel);
  box-shadow:0 0 0 1px rgba(0,0,0,.4),0 30px 80px -42px rgba(0,255,174,.20),0 50px 130px -60px rgba(0,0,0,.9);
  transition:border-color .4s ease,box-shadow .4s ease}
.blogwin:hover{border-color:rgba(0,255,174,.35);box-shadow:0 0 0 1px rgba(0,0,0,.4),0 34px 90px -40px rgba(0,255,174,.28),0 50px 130px -60px rgba(0,0,0,.9)}

/* barra do navegador */
.blogwin-bar{display:flex;align-items:center;gap:14px;padding:13px 16px;
  background:linear-gradient(180deg,rgba(255,255,255,.05),transparent),var(--black2);
  border-bottom:1px solid var(--line)}
.bw-dots{display:flex;gap:7px;flex:0 0 auto}
.bw-dots i{width:11px;height:11px;border-radius:50%;background:rgba(255,255,255,.18)}
.bw-dots i:first-child{background:var(--green);box-shadow:0 0 10px rgba(0,255,174,.6)}
.bw-addr{flex:1;display:inline-flex;align-items:center;gap:8px;justify-content:center;
  max-width:420px;margin:0 auto;padding:7px 16px;border:1px solid var(--line);border-radius:999px;
  background:rgba(255,255,255,.03);font-family:var(--mono);font-size:12px;letter-spacing:.04em;color:var(--gray)}
.bw-lock{color:var(--green);flex:0 0 auto}
.bw-addr-txt{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bw-live{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 8px var(--green);
  flex:0 0 auto;animation:bwpulse 1.8s ease-in-out infinite}
@keyframes bwpulse{0%,100%{opacity:1}50%{opacity:.25}}
.bw-tabgo{flex:0 0 auto;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;
  color:var(--green);transition:opacity .3s}
.bw-tabgo:hover{opacity:.7}

/* corpo / grid */
.blogwin-body{position:relative;display:grid;grid-template-columns:1.45fr 1fr;gap:0}
.blogwin-body .cgrid{position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:42px 42px;opacity:.22;pointer-events:none;z-index:0}

/* DESTAQUE */
.bw-feature{position:relative;z-index:1;display:flex;flex-direction:column;border-right:1px solid var(--line)}
.bw-cover{position:relative;display:block;aspect-ratio:16/9;max-height:280px;overflow:hidden;background:var(--black2);
  border-bottom:1px solid var(--line)}
.bw-cover img{width:100%;height:100%;object-fit:cover;filter:saturate(.9);transition:transform .65s ease,filter .5s ease}
.bw-feature:hover .bw-cover img{transform:scale(1.05);filter:saturate(1.05)}
.bw-badge{position:absolute;top:14px;left:14px;font-family:var(--mono);font-size:10px;text-transform:uppercase;
  letter-spacing:.12em;color:#000;background:var(--green);padding:5px 10px;border-radius:6px;
  box-shadow:0 0 18px rgba(0,255,174,.45)}
.bw-fbody{padding:26px;display:flex;flex-direction:column;gap:13px;flex:1}
.bw-meta{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;display:flex;gap:12px}
.bw-meta .pcat{color:var(--green)}
.bw-meta .date{color:var(--gray)}
.bw-fbody h3{font-family:var(--disp);font-weight:600;font-size:clamp(21px,2.5vw,32px);line-height:1.08;
  text-transform:uppercase;transition:color .3s}
.bw-feature:hover .bw-fbody h3{color:var(--green2)}
.bw-fbody p{color:#bdbdbd;font-size:15px;line-height:1.55;max-width:48ch;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.bw-go{margin-top:auto;font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.08em;
  color:var(--green);display:inline-flex;align-items:center;gap:8px}
.bw-go .ar{transition:transform .3s}
.bw-feature:hover .bw-go .ar{transform:translateX(5px)}

/* ÚLTIMAS (lista) */
.bw-list{position:relative;z-index:1;display:flex;flex-direction:column}
.bw-list-label{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.2em;color:var(--gray);
  padding:20px 22px 14px;border-bottom:1px solid var(--line)}
.bw-row{display:grid;grid-template-columns:auto 88px 1fr 14px;gap:15px;align-items:center;
  padding:16px 22px;border-bottom:1px solid var(--line);transition:background .3s,padding-left .3s,border-color .3s}
.bw-row:last-child{border-bottom:0}
.bw-row:hover{background:rgba(0,255,174,.04);padding-left:28px;border-color:rgba(0,255,174,.35)}
.bw-no{font-family:var(--disp);font-weight:700;font-size:22px;line-height:1;color:transparent;
  -webkit-text-stroke:1px rgba(0,255,174,.5);transition:-webkit-text-stroke-color .3s}
.bw-row:hover .bw-no{-webkit-text-stroke-color:var(--green)}
.bw-rthumb{width:88px;height:62px;border-radius:8px;overflow:hidden;border:1px solid var(--line);background:var(--black2)}
.bw-rthumb img{width:100%;height:100%;object-fit:cover;filter:saturate(.8);transition:transform .5s,filter .4s}
.bw-row:hover .bw-rthumb img{transform:scale(1.08);filter:saturate(1.05)}
.bw-rtext{min-width:0}
.bw-rtext .date{font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.12em;color:var(--gray)}
.bw-rtext h4{font-family:var(--disp);font-weight:600;font-size:16px;line-height:1.14;text-transform:uppercase;margin-top:5px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;transition:color .3s}
.bw-row:hover .bw-rtext h4{color:var(--green2)}
.bw-chev{font-family:var(--disp);font-size:20px;color:var(--green);opacity:.6;transition:transform .3s,opacity .3s}
.bw-row:hover .bw-chev{transform:translateX(4px);opacity:1}

/* rodapé */
.blogwin-foot{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;
  padding:16px 22px;border-top:1px solid var(--line);background:var(--black2)}
.bw-crumb{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--gray)}

/* responsivo */
@media(max-width:900px){
  .blogwin-body{grid-template-columns:1fr}
  .bw-feature{border-right:0;border-bottom:1px solid var(--line)}
  .bw-list-label{padding-top:18px}
}
@media(max-width:560px){
  .bw-addr{max-width:none;font-size:11px;padding:6px 12px}
  .bw-tabgo{display:none}
  .bw-fbody{padding:20px}
  .bw-row{grid-template-columns:auto 70px 1fr;gap:12px;padding:14px 16px}
  .bw-row:hover{padding-left:20px}
  .bw-rthumb{width:70px;height:52px}
  .bw-chev{display:none}
  .bw-no{font-size:18px}
}
@media(prefers-reduced-motion:reduce){
  .bw-live{animation:none}
}

/* setas do carrossel do deck (navegação manual) */
.deck-nav{position:absolute;inset:0;z-index:25;pointer-events:none;opacity:0;transition:opacity .35s ease}
.deck-nav.show{opacity:1}
.deck-arrow{pointer-events:auto;position:absolute;top:50%;transform:translateY(-50%);width:clamp(44px,3.4vw,58px);height:clamp(44px,3.4vw,58px);border-radius:50%;border:1px solid var(--line);background:rgba(9,11,10,.66);color:#fff;font-family:var(--disp);font-size:30px;line-height:0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .25s,color .25s,background .25s,transform .18s,opacity .25s}
.deck-arrow:hover{border-color:var(--green);color:var(--green);background:rgba(0,255,174,.08)}
.deck-arrow:active{transform:translateY(-50%) scale(.92)}
.deck-arrow.prev{left:clamp(10px,4vw,64px)}
.deck-arrow.next{right:clamp(10px,4vw,64px)}
.deck-arrow:disabled{opacity:.26;pointer-events:none}
.deck-arrow span{display:block;margin-top:-6px}
@media(max-width:767px){.deck-nav{display:none}}

/* ===== PÁGINAS DE SERVIÇO ===== */
.svc-head .lead{max-width:790px}
.svc-intro{max-width:900px}
.svc-block h2{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:clamp(22px,3vw,34px);line-height:1.06;margin-bottom:18px}
.svc-grid2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,72px);align-items:start}
.svc-checklist{list-style:none;display:flex;flex-direction:column;gap:13px}
.svc-checklist li{position:relative;padding-left:30px;color:#cfcfcf;font-size:16px;line-height:1.55}
.svc-checklist li::before{content:"";position:absolute;left:0;top:6px;width:15px;height:15px;border-radius:4px;background:var(--green);clip-path:polygon(14% 47%,0 61%,40% 100%,100% 16%,86% 3%,38% 73%)}
.svc-steps{display:flex;flex-direction:column;counter-reset:svcstep}
.svc-step{display:flex;gap:18px;padding:18px 0;border-top:1px solid var(--line)}
.svc-step:first-child{border-top:0;padding-top:0}
.svc-step .n{counter-increment:svcstep;font-family:var(--mono);color:var(--green);font-size:13px;letter-spacing:.06em;flex:0 0 auto;padding-top:4px}
.svc-step .n::before{content:counter(svcstep,decimal-leading-zero)}
.svc-step h3{font-family:var(--disp);font-weight:600;font-size:18px;text-transform:uppercase;letter-spacing:.02em;margin-bottom:5px}
.svc-step p{color:var(--gray);font-size:15px;line-height:1.55}
/* galeria estilo dribbble (sites/LPs/trabalhos) — com placeholders */
.svc-shots{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:10px}
.svc-shot{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--panel);transition:border-color .4s,transform .4s,box-shadow .4s}
.svc-shot:hover{border-color:var(--green);transform:translateY(-6px);box-shadow:0 24px 60px rgba(0,0,0,.6)}
.svc-shot-img{position:relative;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;background:var(--black2);overflow:hidden}
.svc-shot-img::before{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:34px 34px;opacity:.35}
.svc-shot-img .ph{position:relative;z-index:1;font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--gray);border:1px dashed rgba(255,255,255,.25);border-radius:9px;padding:12px 16px;background:rgba(0,0,0,.28);max-width:80%;text-align:center;line-height:1.5}
.svc-shot-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:2;transition:transform .6s}
.svc-shot:hover .svc-shot-img img{transform:scale(1.05)}
.svc-shot figcaption{padding:16px 18px;display:flex;flex-direction:column;gap:6px}
.svc-shot figcaption b{font-family:var(--disp);font-weight:600;font-size:15px;text-transform:uppercase;letter-spacing:.02em;color:#fff}
.svc-shot figcaption p{font-size:13px;color:#bdbdbd;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.svc-shot .tag{font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.1em;color:var(--green)}
/* galeria de sites reais (cards clicáveis estilo portfólio) */
a.svc-shot{text-decoration:none;color:inherit}
.svc-shots.sites{grid-template-columns:repeat(2,1fr);gap:26px;max-width:1040px;margin-left:auto;margin-right:auto}
.svc-shot-cap{padding:16px 18px;display:flex;flex-direction:column;gap:6px}
.svc-shot-cap p{font-size:13px;color:#bdbdbd;line-height:1.5}
.svc-shot-go{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--green);transition:transform .3s}
a.svc-shot:hover .svc-shot-go{transform:translateX(4px)}
@media(max-width:700px){.svc-shots.sites{grid-template-columns:1fr}}
/* linha "sobre o cliente" na frente dos cases */
.case-sub{font-size:12px;color:#9aa0a0;line-height:1.4;margin-top:4px;letter-spacing:.01em}
/* faq (acordeão) */
.svc-faq{max-width:850px;margin:10px auto 0;border-top:1px solid var(--line)}
.svc-faq details{border-bottom:1px solid var(--line)}
.svc-faq summary{list-style:none;cursor:pointer;padding:20px 42px 20px 0;position:relative;font-family:var(--disp);font-weight:600;font-size:clamp(16px,1.8vw,20px);text-transform:uppercase;letter-spacing:.01em;transition:color .25s}
.svc-faq summary:hover{color:var(--green2)}
.svc-faq summary::-webkit-details-marker{display:none}
.svc-faq summary::after{content:"+";position:absolute;right:4px;top:50%;transform:translateY(-50%);color:var(--green);font-family:var(--mono);font-size:22px;line-height:0}
.svc-faq details[open] summary::after{content:"\2013"}
.svc-faq details p{padding:0 0 22px;color:#bdbdbd;font-size:15.5px;line-height:1.62;max-width:780px}
/* cta */
.svc-cta{text-align:center}
.svc-cta h2{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:clamp(26px,4vw,52px);line-height:1.05}
.svc-cta p{color:#bdbdbd;max-width:580px;margin:14px auto 26px;font-size:16px;line-height:1.6}
.svc-keywords{margin-top:30px;display:flex;flex-wrap:wrap;gap:9px}
.svc-keywords span{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--gray);border:1px solid var(--line);border-radius:999px;padding:6px 13px}
@media(max-width:900px){.svc-grid2{grid-template-columns:1fr}.svc-shots{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.svc-shots{grid-template-columns:1fr}}

