/* ===== Leonardo Sommariva — estilos globais (tema escuro) ===== */
:root{
  --cyan:#12A0BE;
  --cyan-bright:#19B7D6;
  --graphite:#1D2621;

  --bg:#10160F;
  --surface:#171F19;
  --surface-2:#1C261F;
  --ink:#F2F5F2;
  --ink-soft:rgba(242,245,242,0.66);
  --ink-faint:rgba(242,245,242,0.42);
  --line:rgba(255,255,255,0.09);
  --line-strong:rgba(255,255,255,0.2);
  --accent:#2FD4EF;
  --accent-ink:#08110E;
  --panel:#0B100D;
  --glow:0 0 50px -8px rgba(47,212,239,0.5);
  --grid-dot:rgba(47,212,239,0.11);
  --blob-a:rgba(47,212,239,0.18);
  --blob-b:rgba(47,212,239,0.08);
  --glass:rgba(255,255,255,0.04);
  --glass-line:rgba(255,255,255,0.1);
  --shadow:0 30px 70px -30px rgba(0,0,0,0.7);
  --shadow-soft:0 16px 40px -24px rgba(0,0,0,0.55);
  --cursor:block;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:clip}
body{
  background:var(--bg);color:var(--ink);
  font-family:'Inter',system-ui,sans-serif;line-height:1.6;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
h1,h2,h3,h4{font-family:'Space Grotesk',sans-serif;font-weight:600;line-height:1.04;letter-spacing:-0.025em;color:var(--ink)}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:1220px;margin:0 auto;padding:0 clamp(20px,5vw,40px)}
.section{padding:130px 0;position:relative}
@media(max-width:760px){.section{padding:84px 0}}
@media(max-width:480px){.section{padding:60px 0}}

/* progress bar */
#progress{position:fixed;top:0;left:0;height:3px;width:100%;background:linear-gradient(90deg,var(--accent),var(--cyan-bright));transform:scaleX(0);transform-origin:0 50%;z-index:120;box-shadow:var(--glow)}

/* cursor glow */
#cursorglow{position:fixed;top:0;left:0;width:480px;height:480px;margin:-240px 0 0 -240px;border-radius:50%;pointer-events:none;z-index:1;display:var(--cursor);
  background:radial-gradient(circle,rgba(47,212,239,0.10) 0%,rgba(47,212,239,0) 60%);mix-blend-mode:screen}

/* labels */
.kicker{display:inline-flex;align-items:center;gap:14px;margin-bottom:26px;
  font-family:'Space Mono',monospace;font-size:13px;font-weight:700;letter-spacing:0.24em;text-transform:uppercase;color:rgba(242,245,242,0.56)}
.kicker .num{color:var(--accent)}
.kicker .bar{width:46px;height:1px;background:var(--accent)}
.eyebrow{font-family:'Space Mono',monospace;font-size:13px;font-weight:700;letter-spacing:0.28em;text-transform:uppercase;color:var(--accent)}

/* buttons */
.btn-wrap{display:inline-block}
.btn{display:inline-flex;align-items:center;gap:12px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:16px;
  padding:17px 28px;border-radius:3px;border:1px solid transparent;cursor:pointer;white-space:nowrap;position:relative;overflow:hidden;
  transition:transform .25s ease,background .25s ease,box-shadow .3s ease,color .25s,border-color .25s}
.btn .arw{transition:transform .25s ease}
.btn:hover .arw{transform:translateX(5px)}
.btn-primary{background:var(--accent);color:var(--accent-ink);box-shadow:var(--glow)}
.btn-primary::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,0.35) 50%,transparent 70%);transform:translateX(-120%)}
.btn-primary:hover::after{transform:translateX(120%);transition:transform .7s ease}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 40px -16px rgba(47,212,239,0.6)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-strong)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}

/* ===== NAV ===== */
header.nav{position:relative;z-index:90;background:color-mix(in srgb,var(--bg) 80%,transparent);backdrop-filter:blur(16px);border-bottom:1px solid var(--line);transition:background .6s,border-color .6s}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:76px}

/* mini-header: versão condensada, entra fixa no topo quando o header sai da tela (site.js) */
.mini-nav{position:fixed;top:0;left:0;right:0;z-index:95;
  background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:blur(16px);
  border-bottom:1px solid var(--line);
  transform:translateY(-100%);opacity:0;visibility:hidden;pointer-events:none;
  transition:transform .4s cubic-bezier(.16,1,.3,1),opacity .3s,visibility .4s}
.mini-nav.is-visible{transform:none;opacity:1;visibility:visible;pointer-events:auto}
.mini-nav .nav-inner{height:60px}
.mini-nav .brand img{height:22px;width:auto}
.mini-nav .btn{padding:11px 20px;font-size:14px}
@media(max-width:560px){.mini-nav .btn-wrap{display:none}}
@media(prefers-reduced-motion:reduce){.mini-nav{transition:opacity .2s}}
.brand{display:flex;align-items:center}
.brand img{height:26px;width:178px;display:block}
.brand .plus{color:var(--accent);margin-left:1px}
.nav-links{display:flex;gap:20px;list-style:none}
.nav-links a{font-size:14px;font-weight:500;color:var(--ink-soft);transition:color .2s;position:relative;padding:4px 0;white-space:nowrap}
.nav-links a:hover{color:var(--ink)}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--accent);transition:width .25s}
.nav-links a:hover::after{width:100%}
.nav-links a.active{color:var(--ink)}
.nav-home{display:flex;align-items:center;color:var(--ink)}
.nav-home svg{display:block}
@media(max-width:1180px){.nav-links{display:none}}

/* menu "…" — itens dinâmicos do CMS (header desktop) */
.nav-more-wrap{position:relative;display:flex;align-items:center}
.nav-more{display:flex;align-items:center;justify-content:center;width:36px;height:30px;padding:0;border:1px solid var(--line-strong);border-radius:3px;background:transparent;color:var(--ink-soft);cursor:pointer;transition:color .2s,border-color .2s}
.nav-more:hover,.nav-more[aria-expanded="true"]{color:var(--ink);border-color:var(--accent)}
.nav-more svg{display:block}
.nav-more-menu{position:absolute;top:calc(100% + 14px);right:0;min-width:210px;list-style:none;margin:0;padding:6px;display:none;flex-direction:column;gap:2px;background:var(--panel);border:1px solid var(--line);border-radius:6px;box-shadow:0 24px 50px -24px rgba(0,0,0,.85);z-index:95}
.nav-more-wrap.open .nav-more-menu{display:flex}
.nav-more-menu a{display:block;padding:9px 12px;border-radius:4px;font-size:14px;font-weight:500;color:var(--ink-soft);white-space:nowrap;transition:background .2s,color .2s}
.nav-more-menu a:hover{background:color-mix(in srgb,var(--ink) 8%,transparent);color:var(--ink)}
.nav-more-menu a::after{display:none}

/* lista de arquivos das páginas dinâmicas do CMS (layout file_page) */
.page-files{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;max-width:760px}
.page-files a{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:15px 20px;border:1px solid var(--line);border-radius:6px;background:var(--surface);color:var(--ink);font-weight:500;transition:border-color .2s,background .2s}
.page-files a:hover{border-color:var(--accent)}
.page-files .arw{color:var(--accent);font-size:18px}

/* ----- hambúrguer + drawer mobile ----- */
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;margin-left:6px;
  padding:0;border:1px solid var(--line-strong);border-radius:3px;background:transparent;cursor:pointer;
  transition:border-color .25s}
.nav-toggle:hover{border-color:var(--accent)}
.nav-toggle span{display:block;width:20px;height:2px;margin:0 auto;background:var(--ink);border-radius:2px;
  transition:transform .3s cubic-bezier(.16,1,.3,1),opacity .2s}
body.nav-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.nav-open .nav-toggle span:nth-child(2){opacity:0}
body.nav-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(max-width:1180px){.nav-toggle{display:flex}}
@media(max-width:560px){header .nav-inner .btn-wrap{display:none}}

.nav-scrim{position:fixed;inset:0;z-index:100;background:rgba(0,0,0,.55);backdrop-filter:blur(2px);
  opacity:0;pointer-events:none;transition:opacity .3s}
.nav-scrim[hidden]{display:block}
body.nav-open .nav-scrim{opacity:1;pointer-events:auto}

.nav-drawer{position:fixed;top:0;right:0;z-index:110;height:100dvh;width:min(360px,86vw);
  display:flex;flex-direction:column;padding:24px clamp(22px,5vw,30px) calc(28px + env(safe-area-inset-bottom));
  background:var(--panel);border-left:1px solid var(--line);box-shadow:-30px 0 70px -30px rgba(0,0,0,.8);
  transform:translateX(100%);transition:transform .4s cubic-bezier(.16,1,.3,1);overflow-y:auto;overscroll-behavior:contain}
body.nav-open{overflow:hidden}
body.nav-open .nav-drawer{transform:none}
.drawer-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.drawer-head .brand img{height:24px;width:164px}
.drawer-close{width:42px;height:42px;display:grid;place-items:center;margin-right:-8px;
  border:1px solid var(--line-strong);border-radius:3px;background:transparent;color:var(--ink-soft);cursor:pointer;
  transition:color .25s,border-color .25s}
.drawer-close:hover{color:var(--accent);border-color:var(--accent)}
.drawer-nav{flex:1;display:flex;align-items:center;padding:18px 0}
.drawer-links{list-style:none;display:flex;flex-direction:column;gap:4px;width:100%}
.drawer-links a{display:flex;align-items:center;gap:11px;padding:12px 0;
  font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:clamp(20px,5.5vw,26px);letter-spacing:-0.02em;
  color:var(--ink-soft);border-bottom:1px solid var(--line);transition:color .25s,padding-left .25s}
.drawer-links a:hover,.drawer-links a:focus-visible{color:var(--accent);padding-left:6px}
.drawer-links a.active{color:var(--ink)}
.drawer-links a svg{flex:none;color:var(--accent)}
.drawer-cta{padding-top:20px}
.drawer-cta .btn{width:100%;justify-content:center}

/* reveal: keyframe on is-in; resting state is VISIBLE so content is never hidden */
@media(prefers-reduced-motion:no-preference){
  .js [data-reveal].is-in{animation:revUp 1.8s cubic-bezier(.16,1,.3,1) both}
  .js [data-reveal][data-d="1"].is-in{animation-delay:.2s}
  .js [data-reveal][data-d="2"].is-in{animation-delay:.4s}
  .js [data-reveal][data-d="3"].is-in{animation-delay:.6s}
  .js [data-reveal][data-d="4"].is-in{animation-delay:.8s}
}
@keyframes revUp{from{transform:translateY(34px)}to{transform:none}}

/* section divider */
.divider{height:1px;background:var(--line);position:relative;overflow:hidden}
.divider::after{content:"";position:absolute;inset:0;width:0;background:linear-gradient(90deg,var(--accent),transparent);transition:width 2.2s cubic-bezier(.16,1,.3,1)}
.divider.is-in::after{width:100%}

/* ===== COMPANIES (real logos, dark band) ===== */
.companies{background:var(--panel);border-top:1px solid rgba(255,255,255,0.08);border-bottom:1px solid rgba(255,255,255,0.08);padding:74px 0;overflow:hidden}
.companies .lbl{text-align:center;font-family:'Space Mono';font-size:12px;letter-spacing:0.24em;text-transform:uppercase;color:rgba(242,245,242,0.5);margin-bottom:44px}
.marquee{display:flex;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;align-items:center;animation:scroll 80s linear infinite;white-space:nowrap}
.companies:hover .marquee-track{animation-play-state:paused}
@keyframes scroll{to{transform:translateX(-50%)}}
.clogo{display:inline-flex;align-items:center;justify-content:center;height:80px;padding:0 34px}
.clogo img{max-height:48px;max-width:150px;width:auto;height:auto;object-fit:contain;opacity:.6;transition:opacity .3s,transform .3s}
.clogo:hover img{opacity:1;transform:scale(1.05)}

/* ===== FOOTER ===== */
footer.foot{background:var(--panel);color:rgba(242,245,242,0.7);padding:84px 0 40px}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:48px;padding-bottom:54px;border-bottom:1px solid rgba(255,255,255,0.1)}
.foot .brand{color:#fff;font-size:27px;margin-bottom:18px}
.foot .brand img{height:30px;width:205px}
.foot-blurb{font-size:14.5px;color:rgba(242,245,242,0.55);max-width:300px}
.foot h2{font-family:'Space Mono';font-weight:400;font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--cyan-bright);margin-bottom:18px}
.foot ul{list-style:none}
.foot li{margin-bottom:11px;font-size:14.5px}
.foot a{transition:color .2s}
.foot a:hover{color:#fff}
.foot .addr{font-size:13.5px;line-height:1.5;color:rgba(242,245,242,0.55);margin-bottom:16px}
.foot .addr b{color:rgba(242,245,242,0.85);font-weight:600;display:block;margin-bottom:3px;font-family:'Space Grotesk'}
.socials{display:flex;gap:12px;margin-top:8px}
.socials a{width:40px;height:40px;border:1px solid rgba(255,255,255,0.18);border-radius:3px;display:flex;align-items:center;justify-content:center;color:rgba(242,245,242,0.7);transition:all .25s;font-size:13px;font-family:'Space Mono'}
.socials a:hover{background:var(--cyan-bright);color:#08110E;border-color:var(--cyan-bright);transform:translateY(-2px)}
.socials a svg{width:18px;height:18px;display:block;fill:currentColor}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:30px;font-size:13px;color:rgba(242,245,242,0.6);flex-wrap:wrap;gap:12px}
@media(max-width:880px){.foot-top{grid-template-columns:1fr 1fr;gap:40px}}
@media(max-width:560px){.foot-top{grid-template-columns:1fr}}

@media(prefers-reduced-motion:reduce){
  .marquee-track{animation:none!important}
}

/* ============================================================
   COMPONENTES COMPARTILHADOS (usados pela home e demais páginas)
   Promovidos de pages/home/home.css — fonte única.
   ============================================================ */

/* ----- fundos de hero (home + page-hero) ----- */
.hero-bg{position:absolute;inset:0;z-index:-2;overflow:hidden}
.hero-bg canvas{position:absolute;inset:0;opacity:.9}
.blob{position:absolute;border-radius:50%;filter:blur(70px);z-index:-3}
.blob.a{width:560px;height:560px;background:var(--blob-a);top:-160px;right:-120px;animation:float1 32s ease-in-out infinite}
.blob.b{width:420px;height:420px;background:var(--blob-b);bottom:-160px;left:-100px;animation:float2 38s ease-in-out infinite}
@keyframes float1{0%,100%{transform:translate(0,0)}50%{transform:translate(-40px,40px)}}
@keyframes float2{0%,100%{transform:translate(0,0)}50%{transform:translate(40px,-30px)}}
.hero-dots{position:absolute;inset:0;z-index:-2;background-image:radial-gradient(var(--grid-dot) 1.3px,transparent 1.3px);background-size:30px 30px;
  mask-image:radial-gradient(ellipse at 60% 35%,#000 25%,transparent 80%);-webkit-mask-image:radial-gradient(ellipse at 60% 35%,#000 25%,transparent 80%)}
.grad{background:linear-gradient(100deg,var(--accent),var(--cyan-bright) 45%,var(--accent) 90%);background-size:220% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:shimmer 12s linear infinite}
@keyframes shimmer{to{background-position:220% 0}}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:50px}

/* ----- SOBRE / retrato + papéis ----- */
.about{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.about-grid{display:grid;grid-template-columns:0.82fr 1.18fr;gap:62px;align-items:start}
.portrait{position:relative;border-radius:4px;overflow:hidden;aspect-ratio:3/4;box-shadow:var(--shadow-soft);border:1px solid var(--line)}
.portrait img{width:100%;height:100%;object-fit:cover;transform:translateY(var(--py,0)) scale(1.05)}
.about h2{font-size:clamp(32px,3.6vw,46px);margin-bottom:8px}
.role-sub{font-family:'Space Grotesk';font-size:18px;color:var(--accent);font-weight:500;margin-bottom:30px}
.about p{color:var(--ink-soft);font-size:17px;margin-bottom:18px;max-width:640px;text-wrap:pretty}
.roles-emph{display:flex;flex-wrap:wrap;gap:8px 0;margin:30px 0 40px}
.role-chip{font-family:'Space Grotesk';font-weight:600;font-size:clamp(22px,2.6vw,34px);letter-spacing:-0.02em;color:var(--ink);transition:color .4s,opacity .4s;opacity:.55}
.role-chip:not(:last-child)::after{content:"/";color:var(--accent);margin:0 16px;font-weight:400;opacity:.5}
.role-chip.on{color:var(--accent);opacity:1;text-shadow:var(--glow)}
.creds{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:8px}
.cred{background:var(--surface);padding:24px 26px;transition:background .3s}
.cred:hover{background:var(--surface-2)}
.cred .ct{font-family:'Space Mono';font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--accent);margin-bottom:9px}
.cred .cd{font-size:15px;color:var(--ink-soft);line-height:1.45}
@media(max-width:920px){.about-grid{grid-template-columns:1fr;gap:42px}.portrait{max-width:360px}.creds{grid-template-columns:1fr}}

/* ----- cabeçalho de seção ----- */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:58px;flex-wrap:wrap}
.sec-head h2{font-size:clamp(30px,3.4vw,44px)}
.sec-head p{color:var(--ink-soft);max-width:380px;font-size:16px}

/* ----- SERVIÇOS ----- */
.services{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.svc{position:relative;background:var(--bg);border:1px solid var(--line);border-radius:4px;padding:40px 38px;overflow:hidden;
  transition:transform .35s cubic-bezier(.16,1,.3,1),border-color .35s,box-shadow .35s}
.svc::before{content:"";position:absolute;width:380px;height:380px;left:var(--mx,50%);top:var(--my,50%);transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(47,212,239,0.14),transparent 60%);opacity:0;transition:opacity .35s;pointer-events:none}
.svc:hover::before{opacity:1}
.svc:hover{transform:translateY(-5px);border-color:var(--accent);box-shadow:var(--shadow-soft)}
.svc .sn{font-family:'Space Mono';font-size:13px;color:var(--accent);letter-spacing:0.18em;margin-bottom:22px}
.svc h3{font-size:24px;margin-bottom:14px;position:relative;z-index:1}
.svc p{color:var(--ink-soft);font-size:15.5px;margin-bottom:24px;position:relative;z-index:1}
.svc .more{font-family:'Space Grotesk';font-weight:600;font-size:14px;color:var(--accent);display:inline-flex;gap:8px;align-items:center;position:relative;z-index:1}
.svc .more .arw{transition:transform .25s}
.svc:hover .more .arw{transform:translateX(5px)}
@media(max-width:760px){.svc-grid{grid-template-columns:1fr}}
.svc-feature{grid-column:1/-1;display:flex;gap:40px;align-items:center;
  background:linear-gradient(120deg,color-mix(in srgb,var(--accent) 12%,var(--bg)),var(--bg) 70%);
  border-color:var(--line-strong)}
.svc-feature:hover{border-color:var(--accent)}
.svc-feature .svc-feature-body{flex:1.5;min-width:0;position:relative;z-index:1}
.svc-feature .svc-feature-tags{flex:1;display:flex;flex-wrap:wrap;gap:10px;align-content:center;position:relative;z-index:1}
.svc-feature .svc-feature-tags span{font-family:'Space Mono';font-size:12px;letter-spacing:0.1em;text-transform:uppercase;color:var(--accent);
  border:1px solid var(--line-strong);border-radius:3px;padding:10px 16px;background:color-mix(in srgb,var(--accent) 7%,transparent)}
.svc-feature h3{font-size:28px}
@media(max-width:760px){.svc-feature{flex-direction:column;align-items:flex-start;gap:24px}}

/* ----- METODOLOGIA ----- */
.metodo{position:relative;overflow:hidden}
.pillars{position:relative;display:grid;grid-template-columns:repeat(5,1fr);gap:18px;padding-top:6px}
.pillars .rail{position:absolute;left:9%;right:9%;top:43px;height:2px;z-index:0;
  background:linear-gradient(90deg,transparent,var(--accent) 14%,var(--accent) 86%,transparent);opacity:.4}
.pillars .rail::before,.pillars .rail::after{content:"";position:absolute;top:50%;width:7px;height:7px;border-radius:50%;background:var(--accent);transform:translateY(-50%);box-shadow:var(--glow)}
.pillars .rail::before{left:-2px}.pillars .rail::after{right:-2px}
.pillar{position:relative;z-index:1;text-align:center;background:transparent;border:none;padding:0}
.pillar .pl{width:74px;height:74px;margin:0 auto 22px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:'Space Grotesk';font-weight:700;font-size:31px;letter-spacing:-0.02em;position:relative;
  transition:transform .45s cubic-bezier(.16,1,.3,1),box-shadow .45s,background .35s,color .35s}
.pillar .pl::after{content:"";position:absolute;inset:-7px;border-radius:50%;border:1px solid var(--line-strong);transition:border-color .45s,transform .45s}
.pillar.fill .pl{background:var(--accent);color:var(--accent-ink);box-shadow:var(--glow)}
.pillar.line .pl{background:var(--surface);color:var(--accent);border:2px solid var(--accent)}
.pillar:hover .pl{transform:translateY(-6px) scale(1.06)}
.pillar:hover .pl::after{border-color:var(--accent);transform:scale(1.04)}
.pillar .pidx{display:block;font-family:'Space Mono';font-size:10.5px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:7px}
.pillar h3{font-size:18px;margin-bottom:8px}
.pillar p{font-size:13.5px;color:var(--ink-soft);max-width:210px;margin:0 auto;text-wrap:pretty}
@media(max-width:980px){.pillars{grid-template-columns:repeat(2,1fr);gap:40px 18px}.pillars .rail{display:none}}
@media(max-width:520px){.pillars{grid-template-columns:1fr}}

/* ----- PALESTRAS (linhas editoriais) ----- */
.palestras-sec{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.talks-list{border-top:1px solid var(--line-strong)}
.talk-row{display:grid;grid-template-columns:auto 1fr auto;gap:28px 38px;align-items:center;padding:36px 4px;border-bottom:1px solid var(--line);
  transition:padding .45s cubic-bezier(.16,1,.3,1)}
.talk-row:hover{padding-left:22px;padding-right:22px}
.talk-row .tno{font-family:'Space Grotesk';font-weight:700;font-size:clamp(40px,5vw,62px);letter-spacing:-0.04em;color:var(--line-strong);line-height:.82;transition:color .45s}
.talk-row:hover .tno{color:var(--accent);text-shadow:var(--glow)}
.talk-row .tbody{min-width:0}
.talk-row h3{font-size:clamp(21px,2.5vw,30px);margin-bottom:9px;transition:color .25s}
.talk-row:hover h3{color:var(--accent)}
.talk-row p{font-size:15px;color:var(--ink-soft);max-width:600px}
.talk-row .tarw{font-size:25px;color:var(--ink-faint);justify-self:end;transition:transform .35s,color .35s}
.talk-row:hover .tarw{transform:translateX(7px);color:var(--accent)}
.talk-row .fmts{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.fmt-badge{font-family:'Space Mono';font-size:10px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;line-height:1;padding:6px 11px;border-radius:999px}
.fmt-badge.is-palestra{border:1px solid var(--accent);color:var(--accent)}
.fmt-badge.is-treino{background:var(--accent);color:var(--accent-ink)}
.talks-cta{display:flex;flex-wrap:wrap;gap:16px;align-items:center;margin-top:42px}
@media(max-width:680px){.talk-row{grid-template-columns:auto 1fr;gap:18px 22px}.talk-row .tarw{display:none}}

/* filtro de formato (catálogo /treinamentos/palestras) */
.talks-filter{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}
.tf-chip{display:inline-flex;align-items:center;gap:9px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:14px;
  padding:11px 18px;border-radius:999px;border:1px solid var(--line-strong);background:transparent;color:var(--ink-soft);cursor:pointer;
  transition:color .25s,border-color .25s,background .25s,box-shadow .3s,transform .2s}
.tf-chip:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}
.tf-chip .tf-count{font-family:'Space Mono',monospace;font-size:11px;font-weight:700;letter-spacing:0.06em;color:var(--ink-faint);transition:color .25s,opacity .25s}
.tf-chip:hover .tf-count{color:var(--accent)}
.tf-chip.is-active{background:var(--accent);color:var(--accent-ink);border-color:var(--accent);box-shadow:var(--glow)}
.tf-chip.is-active .tf-count{color:var(--accent-ink);opacity:.65}
.talks-empty{padding:46px 4px;color:var(--ink-faint);font-size:16px;border-bottom:1px solid var(--line)}
.talks-empty a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.tf-hidden{display:none!important}

/* ----- LIVRO ----- */
.book{background:var(--panel);color:#F2F5F2;position:relative;overflow:hidden}
.book .circuit{position:absolute;inset:0;z-index:0;opacity:.5;
  background-image:radial-gradient(rgba(47,212,239,0.14) 1.3px,transparent 1.3px);background-size:34px 34px;
  mask-image:radial-gradient(ellipse at 18% 50%,#000 20%,transparent 72%);-webkit-mask-image:radial-gradient(ellipse at 18% 50%,#000 20%,transparent 72%)}
.book .beam{position:absolute;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(47,212,239,0.22),transparent 60%);left:8%;top:50%;transform:translateY(-50%);filter:blur(30px);z-index:0;animation:beam 14s ease-in-out infinite}
@keyframes beam{0%,100%{opacity:.6}50%{opacity:1}}
.book-grid{display:grid;grid-template-columns:0.85fr 1.15fr;gap:74px;align-items:center;position:relative;z-index:2}
.book-cover{position:relative;justify-self:center;perspective:1200px}
.book-cover .tilt{transition:transform .25s ease;transform:perspective(1100px) rotateY(-14deg)}
.book-cover img{width:340px;height:auto;border-radius:5px;box-shadow:0 45px 90px -28px rgba(0,0,0,0.8)}
.book-cover .badge{position:absolute;top:-16px;right:-8px;z-index:5;background:var(--cyan-bright);color:#08110E;font-family:'Space Mono';font-weight:700;font-size:12px;letter-spacing:0.14em;text-transform:uppercase;padding:11px 17px;border-radius:3px;box-shadow:0 0 40px -6px rgba(47,212,239,0.7);transform:rotate(3deg);animation:bob 7s ease-in-out infinite}
@keyframes bob{0%,100%{transform:rotate(3deg) translateY(0)}50%{transform:rotate(3deg) translateY(-7px)}}
.book-content .eyebrow{color:var(--cyan-bright)}
.book-content h2{color:#fff;font-size:clamp(34px,4.2vw,54px);margin:18px 0}
.book-content .b-sub{font-size:clamp(16px,2.4vw,19px);color:rgba(242,245,242,0.8);max-width:520px;margin-bottom:26px}
.book-content p{color:rgba(242,245,242,0.62);font-size:16px;max-width:540px;margin-bottom:30px}
.book-formats{display:flex;gap:12px;margin-bottom:36px;flex-wrap:wrap}
.fmt{border:1px solid rgba(255,255,255,0.22);color:rgba(242,245,242,0.85);font-family:'Space Mono';font-size:12px;letter-spacing:0.12em;text-transform:uppercase;padding:10px 16px;border-radius:3px}
.book .btn-primary{background:var(--cyan-bright);color:#08110E;box-shadow:0 0 50px -10px rgba(47,212,239,0.6)}
@media(max-width:880px){.book-grid{grid-template-columns:1fr;gap:50px}.book-cover img{width:260px}.book-cover .tilt{transform:perspective(1100px) rotateY(-8deg)}}

/* ----- OUTROS LIVROS (vitrine multi-livro: grade de cards) ----- */
.books-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;margin-top:8px}
.book-card{display:flex;flex-direction:column;background:var(--bg);border:1px solid var(--line);border-radius:6px;overflow:hidden;transition:transform .35s cubic-bezier(.16,1,.3,1),border-color .35s}
.book-card:hover{transform:translateY(-4px);border-color:var(--accent)}
.book-card .bc-cover{position:relative;background:var(--surface);display:flex;align-items:center;justify-content:center;padding:30px;min-height:200px}
.book-card .bc-cover img{width:150px;height:auto;border-radius:4px;box-shadow:0 22px 48px -18px rgba(0,0,0,0.8)}
.book-card .bc-noimg{font-size:46px;opacity:.45}
.book-card .bc-badge{position:absolute;top:12px;right:12px;background:var(--cyan-bright);color:#08110E;font-family:'Space Mono';font-weight:700;font-size:10px;letter-spacing:0.12em;text-transform:uppercase;padding:6px 10px;border-radius:3px}
.book-card .bc-body{padding:22px 24px 26px;display:flex;flex-direction:column;gap:12px;flex:1}
.book-card h3{font-size:20px;color:#fff;line-height:1.28}
.book-card .bc-sub{font-size:14px;color:var(--ink-soft);line-height:1.5}
.book-card .bc-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:auto;padding-top:8px}
.book-card .bc-btn{display:inline-flex;align-items:center;gap:7px;font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:13.5px;color:var(--accent);border:1px solid var(--line);border-radius:3px;padding:9px 14px;transition:border-color .25s,color .25s,background .25s}
.book-card .bc-btn:hover{border-color:var(--accent);background:rgba(47,212,239,0.08)}
.book-card .bc-btn .arw{transition:transform .25s ease}
.book-card .bc-btn:hover .arw{transform:translateX(4px)}
@media(max-width:520px){.books-grid{grid-template-columns:1fr}}

/* ----- MÍDIA (home: vídeos lado a lado) ----- */
.vid-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.vid{position:relative;border-radius:4px;overflow:hidden;border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-soft);transition:transform .35s,border-color .35s}
.vid:hover{transform:translateY(-4px);border-color:var(--accent)}
.vid .thumb{position:relative;aspect-ratio:16/9;overflow:hidden}
.vid .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.vid:hover .thumb img{transform:scale(1.07)}
.vid .play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.vid .play span{width:66px;height:66px;border-radius:50%;background:var(--accent);color:var(--accent-ink);display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:var(--glow);transition:transform .3s}
.vid:hover .play span{transform:scale(1.12)}
.vid .vmeta{padding:22px 24px}
.vid .vt{font-family:'Space Grotesk';font-weight:600;font-size:18px}
.vid .vl{font-family:'Space Mono';font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--accent);margin-bottom:8px}
@media(max-width:760px){.vid-grid{grid-template-columns:1fr}}

/* ----- INSIGHTS (linhas de publicação na home) ----- */
.art-list{border-top:1px solid var(--line-strong)}
.art-row{display:grid;grid-template-columns:132px 1fr 28px;gap:34px;align-items:center;padding:30px 4px;border-bottom:1px solid var(--line);
  transition:padding .35s cubic-bezier(.16,1,.3,1)}
.art-row:hover{padding-left:18px}
.art-meta{display:flex;flex-direction:column;gap:11px}
.art-date{font-family:'Space Mono';font-size:11.5px;letter-spacing:0.12em;text-transform:uppercase;color:var(--ink-faint)}
.art-cat{font-family:'Space Mono';font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--accent);border:1px solid var(--line-strong);padding:6px 10px;border-radius:3px;align-self:flex-start}
.art-body{min-width:0}
.art-row h3{font-size:clamp(19px,2.2vw,25px);margin-bottom:6px;transition:color .25s}
.art-row:hover h3{color:var(--accent)}
.art-row p{font-size:14.5px;color:var(--ink-soft);max-width:620px}
.art-arw{font-size:21px;color:var(--ink-faint);transition:transform .35s,color .35s}
.art-row:hover .art-arw{transform:translateX(6px);color:var(--accent)}
@media(max-width:680px){.art-row{grid-template-columns:1fr auto;gap:14px 18px}.art-meta{grid-column:1/-1;flex-direction:row;align-items:center;gap:13px}}

/* ============================================================
   PÁGINAS INTERNAS (portado de styles.css do design)
   ============================================================ */

/* ----- page-hero (compacto) ----- */
.page-hero{position:relative;overflow:hidden;padding:84px 0 70px;isolation:isolate;border-bottom:1px solid var(--line)}
.page-hero .hero-bg{z-index:-2}
.page-hero .hero-dots{z-index:-1}
.crumb{display:inline-flex;align-items:center;gap:10px;font-family:'Space Mono',monospace;font-size:12px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:24px}
.crumb a{color:var(--ink-faint);transition:color .2s}
.crumb a:hover{color:var(--accent)}
.crumb .sep{color:var(--accent);opacity:.7}
.crumb .here{color:var(--accent)}
.page-hero h1{font-size:clamp(40px,5.4vw,72px);margin-bottom:22px;max-width:14ch}
.page-hero .grad{background:linear-gradient(100deg,var(--accent),var(--cyan-bright) 45%,var(--accent) 90%);background-size:220% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:shimmer 6s linear infinite}
.page-hero .lead{font-size:clamp(16px,2.6vw,20px);color:var(--ink-soft);max-width:620px;text-wrap:pretty}
.page-hero .hero-actions{margin-top:38px}

/* ----- hero em 2 colunas: texto + formulário de contato ----- */
.page-hero-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,440px);gap:clamp(40px,6vw,80px);align-items:start}
.hero-col-form{min-width:0}

/* ----- formulário de contato (lead) ----- */
.lead-form-card{background:color-mix(in srgb,var(--surface) 92%,transparent);backdrop-filter:blur(6px);
  border:1px solid var(--line-strong);border-radius:6px;padding:clamp(26px,3vw,38px);box-shadow:0 30px 70px -40px rgba(0,0,0,.8)}
.lead-form-title{font-size:clamp(21px,2.4vw,26px);line-height:1.12;color:var(--accent);margin-bottom:12px;text-wrap:balance}
.lead-form-sub{font-size:15px;color:var(--ink-soft);line-height:1.5;margin-bottom:26px;text-wrap:pretty}
.lf-field{display:flex;flex-direction:column;gap:7px;margin-bottom:20px}
.lf-field label{font-size:14px;color:var(--ink-soft)}
.lf-field input,.lf-field textarea,.lf-field select{width:100%;background:transparent;border:0;border-bottom:1px solid var(--line-strong);
  color:var(--ink);font-family:'Inter',sans-serif;font-size:16px;padding:9px 2px;transition:border-color .25s}
.lf-field textarea{resize:vertical;min-height:92px}
.lf-field select option{color:#10160F}
.lf-field input:focus,.lf-field textarea:focus,.lf-field select:focus{outline:none;border-bottom-color:var(--accent)}
.lf-field input:user-invalid,.lf-field textarea:user-invalid,.lf-field select:user-invalid{border-bottom-color:#ff6b6b}
.lf-options{display:flex;flex-wrap:wrap;gap:10px 18px;padding-top:4px}
.lf-opt{display:flex;align-items:center;gap:7px;font-size:15px;color:var(--ink);cursor:pointer}
.lf-opt input{width:auto;padding:0;border:0}
.lf-submit{width:100%;justify-content:center;margin-top:8px;letter-spacing:0.06em}
.form-msg{font-size:14px;border-radius:4px;padding:12px 14px;margin-bottom:20px;line-height:1.45}
.form-msg[hidden]{display:none}
.form-msg.ok{background:color-mix(in srgb,var(--accent) 16%,transparent);border:1px solid color-mix(in srgb,var(--accent) 45%,transparent);color:var(--ink)}
.form-msg.err{background:rgba(255,107,107,0.12);border:1px solid rgba(255,107,107,0.5);color:#ffd6d6}
/* honeypot: longe da viewport, fora do fluxo e do tab order */
.lf-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

@media(max-width:900px){
  .page-hero-grid{grid-template-columns:1fr;gap:44px}
  .hero-col-form{max-width:520px}
}

/* lead/intro genérico sob sec-head */
.sec-intro{color:var(--ink-soft);font-size:clamp(16px,2.4vw,18px);max-width:660px;text-wrap:pretty;margin-bottom:54px}

/* ----- TRAJETÓRIA (timeline) ----- */
.timeline{position:relative;margin-top:10px;padding-left:34px}
.timeline::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:linear-gradient(180deg,var(--accent),color-mix(in srgb,var(--accent) 10%,transparent))}
.tl-item{position:relative;padding:0 0 38px}
.tl-item:last-child{padding-bottom:0}
.tl-item::before{content:"";position:absolute;left:-34px;top:4px;width:16px;height:16px;border-radius:50%;background:var(--bg);border:2px solid var(--accent);box-shadow:var(--glow)}
.tl-item .tl-yr{font-family:'Space Mono';font-size:12px;letter-spacing:0.16em;text-transform:uppercase;color:var(--accent);margin-bottom:8px}
.tl-item h3,.tl-item h4{font-size:20px;margin-bottom:6px}
.tl-item p{font-size:15px;color:var(--ink-soft);max-width:560px;text-wrap:pretty}

/* ----- FACT GRID (números) ----- */
.fact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:8px}
.fact{background:var(--surface);padding:30px 26px;transition:background .3s}
.fact:hover{background:var(--surface-2)}
.fact .fn{font-family:'Space Grotesk';font-weight:700;font-size:34px;letter-spacing:-0.03em;color:var(--ink);line-height:1}
.fact .fl{font-size:13.5px;color:var(--ink-soft);margin-top:9px;line-height:1.4}
@media(max-width:760px){.fact-grid{grid-template-columns:1fr 1fr}}
@media(max-width:420px){.fact-grid{grid-template-columns:1fr}}

/* ----- STEPS (processo numerado) ----- */
.steps{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.step{background:var(--surface);padding:38px 36px;position:relative;transition:background .3s}
.step:hover{background:var(--surface-2)}
.step .stn{font-family:'Space Grotesk';font-weight:700;font-size:46px;letter-spacing:-0.04em;color:var(--line-strong);line-height:1;margin-bottom:16px;transition:color .3s}
.step:hover .stn{color:var(--accent)}
.step h2,.step h3{font-size:21px;margin-bottom:10px}
.step p{font-size:15px;color:var(--ink-soft);text-wrap:pretty}
@media(max-width:760px){.steps{grid-template-columns:1fr}}

/* ----- CASE CARDS (cases / mídia destaque) ----- */
.case-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.case{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:4px;overflow:hidden;display:flex;flex-direction:column;transition:transform .35s cubic-bezier(.16,1,.3,1),border-color .35s,box-shadow .35s}
.case:hover{transform:translateY(-5px);border-color:var(--accent);box-shadow:var(--shadow-soft)}
.case .case-thumb{position:relative;aspect-ratio:16/9;overflow:hidden}
.case .case-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.case:hover .case-thumb img{transform:scale(1.06)}
.case .play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.case .play span{width:62px;height:62px;border-radius:50%;background:var(--accent);color:var(--accent-ink);display:flex;align-items:center;justify-content:center;font-size:19px;box-shadow:var(--glow);transition:transform .3s}
.case:hover .play span{transform:scale(1.12)}
.case .case-body{padding:28px 30px;flex:1;display:flex;flex-direction:column}
.case .case-cat{font-family:'Space Mono';font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.case .case-body h3{font-size:22px;margin-bottom:10px}
.case .case-body p{font-size:15px;color:var(--ink-soft);text-wrap:pretty}
@media(max-width:760px){.case-grid{grid-template-columns:1fr}}
/* card "Em destaque" (mídias): layout horizontal com mídia em altura dobrada */
.case-feature{display:flex;flex-direction:row;align-items:stretch;min-height:400px;margin-top:8px}
.case-feature .case-thumb{flex:1.3;aspect-ratio:auto}
.case-feature .case-body{flex:1;justify-content:center}
@media(max-width:760px){.case-feature{min-height:0}}

/* ----- LOGO WALL (cases) ----- */
.logo-wall{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.logo-wall .lw{background:var(--surface);height:128px;display:flex;align-items:center;justify-content:center;padding:0 22px;transition:background .3s}
.logo-wall .lw:hover{background:var(--surface-2)}
.logo-wall .lw img{max-height:54px;max-width:140px;width:auto;object-fit:contain;opacity:.62;transition:opacity .3s,transform .3s}
.logo-wall .lw:hover img{opacity:1;transform:scale(1.05)}
@media(max-width:900px){.logo-wall{grid-template-columns:repeat(3,1fr)}}
@media(max-width:540px){.logo-wall{grid-template-columns:repeat(2,1fr)}}

/* ----- LIVRO: o que você vai aprender ----- */
.learn-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:8px}
.learn{background:var(--bg);border:1px solid var(--line);border-radius:4px;padding:32px 30px;transition:transform .35s cubic-bezier(.16,1,.3,1),border-color .35s}
.learn:hover{transform:translateY(-4px);border-color:var(--accent)}
.learn .ln{font-family:'Space Mono';font-size:13px;color:var(--accent);letter-spacing:0.16em;margin-bottom:16px}
.learn h3{font-size:19px;margin-bottom:9px}
.learn p{font-size:14.5px;color:var(--ink-soft);text-wrap:pretty}
@media(max-width:860px){.learn-grid{grid-template-columns:1fr}}

/* ----- PROSE (sobre, texto longo / conteúdo do CMS) ----- */
.prose p{color:var(--ink-soft);font-size:17px;margin-bottom:18px;max-width:680px;text-wrap:pretty}
.prose p strong{color:var(--ink);font-weight:600}
.prose h2{font-size:26px;margin:34px 0 14px}
.prose h3{font-size:20px;margin:28px 0 12px}
.prose h2:first-child,.prose h3:first-child{margin-top:0}
.prose ul,.prose ol{max-width:680px;margin:0 0 18px;padding-left:22px}
.prose li{color:var(--ink-soft);font-size:17px;margin-bottom:9px;text-wrap:pretty}
.prose li::marker{color:var(--accent)}
.prose li strong{color:var(--ink);font-weight:600}
.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}

/* ----- CTA BAND ----- */
.cta-band{background:var(--panel);color:#F2F5F2;position:relative;overflow:hidden;text-align:center}
.cta-band .circuit{position:absolute;inset:0;z-index:0;opacity:.5;background-image:radial-gradient(rgba(47,212,239,0.14) 1.3px,transparent 1.3px);background-size:34px 34px;mask-image:radial-gradient(ellipse at 50% 50%,#000 18%,transparent 70%);-webkit-mask-image:radial-gradient(ellipse at 50% 50%,#000 18%,transparent 70%)}
.cta-band .wrap{position:relative;z-index:2}
.cta-band .eyebrow{color:var(--cyan-bright)}
.cta-band h2{color:#fff;font-size:clamp(30px,4vw,52px);margin:18px 0 18px;max-width:760px;margin-left:auto;margin-right:auto}
.cta-band h2 em{font-style:normal;color:var(--cyan-bright)}
.cta-band p{color:rgba(242,245,242,0.66);font-size:18px;max-width:540px;margin:0 auto 38px}
.cta-band .btn-primary{background:var(--cyan-bright);color:#08110E;box-shadow:0 0 50px -10px rgba(47,212,239,0.6)}

/* ----- INSIGHTS: cards de post (capas geradas) ----- */
.posts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:900px){.posts-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.posts-grid{grid-template-columns:1fr}}
.post-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:4px;overflow:hidden;
  transition:transform .35s cubic-bezier(.16,1,.3,1),border-color .35s,box-shadow .35s;opacity:1}
.post-card:hover{transform:translateY(-6px);border-color:var(--c,var(--accent));box-shadow:var(--shadow-soft)}
.post-thumb{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--surface-2);display:grid;place-items:center;border-bottom:1px solid var(--line)}
.post-thumb::before{content:"";position:absolute;inset:0;background-image:radial-gradient(var(--grid-dot) 1.3px,transparent 1.3px);background-size:22px 22px;
  -webkit-mask-image:radial-gradient(ellipse at 70% 30%,#000 30%,transparent 85%);mask-image:radial-gradient(ellipse at 70% 30%,#000 30%,transparent 85%)}
.post-thumb::after{content:"";position:absolute;width:300px;height:300px;border-radius:50%;right:-90px;top:-90px;filter:blur(14px);transition:transform .55s;
  background:radial-gradient(circle,color-mix(in srgb,var(--c,var(--accent)) 32%,transparent),transparent 65%)}
.post-card:hover .post-thumb::after{transform:scale(1.18)}
.pt-glyph{position:relative;z-index:1;font-family:'Space Grotesk';font-weight:700;font-size:clamp(38px,5.4vw,56px);letter-spacing:-0.045em;line-height:1;
  color:transparent;-webkit-background-clip:text;background-clip:text;opacity:.95;transition:transform .55s;
  background:linear-gradient(125deg,var(--c,var(--accent)),color-mix(in srgb,var(--c,var(--accent)) 38%,var(--ink)))}
.post-card:hover .pt-glyph{transform:scale(1.06)}
.pt-cover{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;transition:transform .55s}
.post-card:hover .pt-cover{transform:scale(1.06)}
.pt-badge{position:absolute;z-index:2;top:14px;left:14px;font-family:'Space Mono';font-size:10px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--c,var(--accent));border:1px solid color-mix(in srgb,var(--c,var(--accent)) 50%,var(--line-strong));
  background:color-mix(in srgb,var(--c,var(--accent)) 10%,var(--surface));padding:6px 11px;border-radius:3px}
.pt-mark{position:absolute;z-index:2;bottom:12px;right:15px;font-family:'Space Grotesk';font-weight:700;font-size:13px;letter-spacing:-0.03em;color:var(--ink-faint);opacity:.55}
.pt-mark b{color:var(--c,var(--accent))}
.post-body{padding:24px 24px 26px;flex:1;display:flex;flex-direction:column}
.post-date{font-family:'Space Mono';font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:13px}
.post-card h3{font-size:18.5px;line-height:1.2;margin-bottom:10px;transition:color .25s;text-wrap:pretty}
.post-card:hover h3{color:var(--c,var(--accent))}
.post-card p{font-size:14px;color:var(--ink-soft);flex:1;text-wrap:pretty;margin-bottom:18px}
.post-more{font-family:'Space Grotesk';font-weight:600;font-size:13.5px;color:var(--c,var(--accent));display:inline-flex;gap:8px;align-items:center}
.post-more .arw{transition:transform .25s}
.post-card:hover .post-more .arw{transform:translateX(5px)}

/* ----- paginação ----- */
.pager{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:56px;flex-wrap:wrap}
.pager button{font-family:'Space Grotesk';font-weight:600;font-size:15px;min-width:46px;height:46px;padding:0 15px;border-radius:3px;
  border:1px solid var(--line-strong);background:transparent;color:var(--ink-soft);cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center}
.pager button:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}
.pager button.on{background:var(--accent);color:var(--accent-ink);border-color:var(--accent);box-shadow:var(--glow)}
.pager button:disabled{opacity:.32;cursor:not-allowed}
.pager .pg-arrow{font-size:17px;font-family:'Space Mono'}
.pager .pg-gap{color:var(--ink-faint);padding:0 2px}

/* ----- MÍDIAS: cards de vídeo paginados ----- */
.vids-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:900px){.vids-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.vids-grid{grid-template-columns:1fr}}
.vid-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:4px;overflow:hidden;
  transition:transform .35s cubic-bezier(.16,1,.3,1),border-color .35s,box-shadow .35s}
.vid-card:hover{transform:translateY(-6px);border-color:var(--c,var(--accent));box-shadow:var(--shadow-soft)}
.vid-cover{position:relative;aspect-ratio:16/9;overflow:hidden;background:var(--surface-2);display:grid;place-items:center;border-bottom:1px solid var(--line)}
.vid-cover img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.vid-card:hover .vid-cover img{transform:scale(1.07)}
.vid-cover.gen::before{content:"";position:absolute;inset:0;background-image:radial-gradient(var(--grid-dot) 1.3px,transparent 1.3px);background-size:22px 22px;
  -webkit-mask-image:radial-gradient(ellipse at 72% 28%,#000 30%,transparent 85%);mask-image:radial-gradient(ellipse at 72% 28%,#000 30%,transparent 85%)}
.vid-cover.gen::after{content:"";position:absolute;width:300px;height:300px;border-radius:50%;right:-90px;top:-100px;filter:blur(14px);transition:transform .55s;
  background:radial-gradient(circle,color-mix(in srgb,var(--c,var(--accent)) 30%,transparent),transparent 65%)}
.vid-card:hover .vid-cover.gen::after{transform:scale(1.18)}
.vc-glyph{position:relative;z-index:1;font-family:'Space Grotesk';font-weight:700;font-size:clamp(30px,4.4vw,46px);letter-spacing:-0.045em;line-height:1;
  color:transparent;-webkit-background-clip:text;background-clip:text;opacity:.95;
  background:linear-gradient(125deg,var(--c,var(--accent)),color-mix(in srgb,var(--c,var(--accent)) 38%,var(--ink)))}
.vid-play{position:absolute;z-index:3;inset:0;display:grid;place-items:center}
.vid-play span{width:60px;height:60px;border-radius:50%;background:var(--c,var(--accent));color:#06140f;display:grid;place-items:center;font-size:18px;
  box-shadow:var(--glow);transition:transform .3s}
.vid-card:hover .vid-play span{transform:scale(1.14)}
.vid-scrim{position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,transparent 45%,rgba(8,17,14,0.5) 100%)}
.vid-badge{position:absolute;z-index:4;top:13px;left:13px;font-family:'Space Mono';font-size:10px;font-weight:700;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--c,var(--accent));border:1px solid color-mix(in srgb,var(--c,var(--accent)) 50%,var(--line-strong));
  background:color-mix(in srgb,var(--c,var(--accent)) 12%,var(--surface));padding:6px 11px;border-radius:3px}
.vid-body{padding:22px 24px 24px;flex:1;display:flex;flex-direction:column}
.vid-body .vl{font-family:'Space Mono';font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--c,var(--accent));margin-bottom:10px}
.vid-card h3{font-size:18px;line-height:1.22;transition:color .25s;text-wrap:pretty}
.vid-card:hover h3{color:var(--c,var(--accent))}
.vid-desc{margin-top:10px;font-size:14px;line-height:1.5;color:var(--ink-soft);text-wrap:pretty;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ===== Sub-telas de detalhe: meta do artigo + embed de vídeo ===== */
.article-meta{display:inline-flex;align-items:center;gap:10px;font-family:'Space Mono',monospace;font-size:12px;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:18px}
.article-meta .am-cat{color:var(--accent)}
.article-meta .am-sep{color:var(--accent);opacity:.6}
.embed-yt{position:relative;aspect-ratio:16/9;width:100%;border-radius:18px;overflow:hidden;border:1px solid var(--line);background:#000}
.embed-yt iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
/* facade do YouTube: thumbnail + play; o iframe real só carrega no clique
   (zero cookies/scripts de terceiros até a interação) */
.yt-facade{position:absolute;inset:0;width:100%;height:100%;margin:0;padding:0;border:0;cursor:pointer;background:#000;display:block}
.yt-facade img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.yt-facade::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,0.05),rgba(0,0,0,0.4))}
.yt-facade-play{position:absolute;z-index:2;top:50%;left:50%;transform:translate(-50%,-50%);
  width:74px;height:74px;border-radius:50%;background:var(--accent);color:var(--accent-ink);
  display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:var(--glow);transition:transform .3s}
.yt-facade:hover .yt-facade-play,.yt-facade:focus-visible .yt-facade-play{transform:translate(-50%,-50%) scale(1.12)}

/* ===== Insight / blog: tela de leitura completa ===== */
.article-meta .am-read{color:var(--ink-faint)}
.post-hero h1{max-width:20ch}
.post-lead{margin-top:18px;max-width:720px}
.post-byline{display:flex;align-items:center;gap:14px;margin-top:30px}
.post-byline .pb-avatar{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;flex:none;
  font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:15px;letter-spacing:0.02em;color:var(--accent-ink);
  background:linear-gradient(135deg,var(--accent),var(--cyan-bright));box-shadow:var(--glow)}
.post-byline .pb-meta{display:flex;flex-direction:column;font-size:13px;color:var(--ink-faint);line-height:1.45}
.post-byline .pb-meta b{font-family:'Space Grotesk',sans-serif;font-weight:600;font-size:15px;color:var(--ink)}

.post-section{padding-top:84px;padding-bottom:96px}
.post-section.has-cover{padding-top:60px}
/* imagem de destaque (capa), entre o hero e o texto — como no post original */
.post-cover{max-width:920px;margin:-40px auto 0;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--surface-2);box-shadow:0 24px 60px -30px rgba(0,0,0,.6)}
.post-cover img{display:block;width:100%;height:auto}
@media(max-width:600px){.post-cover{margin-top:-20px;border-radius:12px}}
/* galeria de imagens adicionais, ao fim do artigo */
.post-gallery{max-width:760px;margin:50px auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.post-gallery .pg-item{display:block;aspect-ratio:4/3;overflow:hidden;border-radius:9px;border:1px solid var(--line);background:var(--surface-2);cursor:zoom-in}
.post-gallery .pg-item img{width:100%;height:100%;object-fit:cover;transition:transform .45s}
.post-gallery .pg-item:hover img{transform:scale(1.06)}
@media(max-width:600px){.post-gallery{grid-template-columns:repeat(2,1fr)}}

/* lightbox da galeria (zoom ao clicar) — visual no estilo do post original (Magnific Popup) */
.lightbox{position:fixed;inset:0;z-index:1042;display:none;opacity:0;transition:opacity .25s ease}
.lightbox.is-open{display:block;opacity:1}
.lightbox::before{content:"";position:fixed;inset:0;background:#0b0b0b;opacity:.86}
.lb-stage{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:40px 14px}
.lb-img{max-width:100%;max-height:100%;width:auto;height:auto;display:block;box-shadow:0 0 8px rgba(0,0,0,.6);cursor:auto}
.lb-img.is-in{animation:lb-in .3s cubic-bezier(.16,1,.3,1)}
@keyframes lb-in{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
.lb-counter{position:absolute;top:14px;left:16px;color:#ccc;font-family:'Space Mono';font-size:12px;letter-spacing:.08em;line-height:18px;white-space:nowrap;z-index:1046}
.lb-close{position:absolute;top:4px;right:10px;width:44px;height:44px;line-height:44px;border:0;background:transparent;color:#fff;font-size:30px;opacity:.65;cursor:pointer;z-index:1046;transition:opacity .2s}
.lb-close:hover,.lb-close:focus{opacity:1}
.lb-arrow{position:absolute;top:50%;transform:translateY(-50%);width:90px;height:110px;border:0;background:transparent;opacity:.65;cursor:pointer;z-index:1046;transition:opacity .2s}
.lb-arrow:hover,.lb-arrow:focus{opacity:1}
.lb-arrow::before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-top:21px solid transparent;border-bottom:21px solid transparent;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}
.lb-prev{left:0}
.lb-prev::before{transform:translate(-30%,-50%);border-right:27px solid #fff}
.lb-next{right:0}
.lb-next::before{transform:translate(-70%,-50%);border-left:27px solid #fff}
@media(max-width:900px){.lb-arrow{transform:translateY(-50%) scale(.72)}.lb-stage{padding:24px 6px}}
.post-article{max-width:760px;margin:0 auto}
.post-article > :first-child{margin-top:0}
.post-article p{color:var(--ink-soft);font-size:18px;line-height:1.78;margin-bottom:24px;max-width:none;text-wrap:pretty}
.post-article p strong{color:var(--ink);font-weight:600}
.post-article h2{font-size:clamp(25px,3vw,33px);margin:54px 0 18px;letter-spacing:-0.02em}
.post-article h3{font-size:clamp(20px,2.3vw,24px);margin:40px 0 14px}
.post-article h2 + p,.post-article h3 + p{margin-top:0}
.post-article ul,.post-article ol{list-style:none;margin:0 0 28px;padding:0}
.post-article ol{counter-reset:li}
.post-article li{position:relative;padding-left:34px;color:var(--ink-soft);font-size:17px;line-height:1.7;margin-bottom:13px;text-wrap:pretty}
.post-article ul > li::before{content:"";position:absolute;left:4px;top:12px;width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:var(--glow)}
.post-article ol > li::before{counter-increment:li;content:counter(li);position:absolute;left:0;top:2px;
  font-family:'Space Mono',monospace;font-size:12px;font-weight:700;color:var(--accent)}
.post-article li strong{color:var(--ink);font-weight:600}
.post-article a{color:var(--accent);text-decoration:underline;text-underline-offset:3px;text-decoration-color:color-mix(in srgb,var(--accent) 45%,transparent);transition:text-decoration-color .2s}
.post-article a:hover{text-decoration-color:var(--accent)}
/* abertura do artigo em destaque, só quando começa por parágrafo */
.post-article > p:first-child{font-size:21px;line-height:1.7;color:var(--ink)}

.post-foot{max-width:760px;margin:54px auto 0;padding-top:30px;border-top:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.post-share{display:flex;align-items:center;gap:10px}
.post-share .ps-label{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-faint);margin-right:4px}
.ps-btn{width:42px;height:42px;border:1px solid var(--line-strong);border-radius:3px;display:grid;place-items:center;
  font-family:'Space Mono',monospace;font-size:12px;font-weight:700;text-transform:uppercase;color:var(--ink-soft);transition:color .25s,border-color .25s,transform .25s}
.ps-btn:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
@media(max-width:560px){.post-article > p:first-child{font-size:19px}.post-article p{font-size:17px}}

/* reduções de espaço para mobile em blocos altos */
@media(max-width:760px){
  .companies{padding:54px 0}
  .page-hero{padding:64px 0 52px}
  footer.foot{padding:60px 0 32px}
  .foot-top{padding-bottom:40px}
}

/* reduções de movimento globais */
@media(prefers-reduced-motion:reduce){
  .blob,.beam,.badge,.grad{animation:none!important}
  .portrait img{transform:none!important}
  .nav-drawer,.nav-scrim,.nav-toggle span{transition:none!important}
}

/* Botão flutuante de WhatsApp (global) */
.wa-float{
  position:fixed; right:40px; bottom:40px; z-index:95;
  width:64px; height:64px; border-radius:50%;
  display:grid; place-items:center;
  background:var(--accent); color:var(--accent-ink);
  box-shadow:var(--glow), var(--shadow-soft);
  transition:transform .25s ease, box-shadow .25s ease;
}
.wa-float svg{width:30px; height:30px; fill:currentColor}
.wa-float:hover{transform:translateY(-2px);
  box-shadow:0 0 60px -6px color-mix(in srgb,var(--accent) 70%,transparent), var(--shadow-soft)}
.wa-float:focus-visible{outline:2px solid var(--accent); outline-offset:3px}

/* Vários WhatsApp: o botão vira toggle de uma lista de números (data-wa-wrap) */
.wa-float-wrap{
  position:fixed; right:40px; bottom:40px; z-index:95;
  display:flex; flex-direction:column; align-items:flex-end; gap:14px;
}
.wa-float-wrap .wa-float{position:static; right:auto; bottom:auto}
.wa-float-list{
  display:flex; flex-direction:column; gap:8px;
  width:max-content; max-width:min(76vw,300px);
  opacity:0; visibility:hidden; transform:translateY(10px) scale(.96);
  transform-origin:bottom right; pointer-events:none;
  transition:opacity .22s ease, transform .22s ease, visibility .22s;
}
.wa-float-wrap.open .wa-float-list{opacity:1; visibility:visible; transform:none; pointer-events:auto}
.wa-float-item{
  display:flex; flex-direction:column; gap:2px;
  padding:11px 16px; border-radius:14px;
  background:var(--surface-2); border:1px solid var(--line);
  box-shadow:var(--shadow-soft);
  transition:border-color .2s ease, transform .2s ease, background .2s ease;
}
.wa-float-item:hover{border-color:var(--accent); background:var(--surface); transform:translateY(-1px)}
.wa-float-item-name{font-family:'Space Grotesk',sans-serif; font-weight:600; font-size:15px; color:var(--ink)}
.wa-float-item-sub{font-size:13px; color:var(--ink-soft)}

@media(max-width:560px){.wa-float{right:24px; bottom:24px; width:58px; height:58px}
  .wa-float svg{width:30px; height:30px}
  .wa-float-wrap{right:24px; bottom:24px}}
@media(prefers-reduced-motion:reduce){.wa-float{transition:none}.wa-float:hover{transform:none}
  .wa-float-list{transition:opacity .01s linear}
  .wa-float-item{transition:none}.wa-float-item:hover{transform:none}}
