/* ============================================================
   PROJETO EU — Site institucional
   Editorial bold + cinematográfico · preto/branco/vermelho
   ============================================================ */

:root{
  --ink:        #0A0A0A;   /* preto base */
  --char:       #141414;   /* carvão (cards/seções) */
  --char-2:     #1c1c1c;
  --white:      #FFFFFF;
  --bone:       #F4F1EC;   /* off-white quente */
  --bone-2:     #E9E5DB;
  --red:        #E10600;   /* vermelho primário */
  --red-deep:   #9E0B0F;   /* vermelho profundo */
  --gray:       #8A8A8A;   /* cinza apoio */
  --gray-line:  rgba(255,255,255,0.10);
  --gray-line-d:rgba(10,10,10,0.12);

  --font-display: 'Anton', 'Arial Narrow', sans-serif;
  --font-sub:     'Archivo', system-ui, sans-serif;
  --font-body:    'Satoshi', system-ui, sans-serif;

  --ease: cubic-bezier(.22,.61,.36,1);
  --maxw: 1320px;
  --gut: clamp(20px, 5vw, 88px);
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--font-body);
  background:var(--ink);
  color:var(--bone);
  line-height:1.6;
  font-size:17px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
::selection{ background:var(--red); color:#fff; }

/* scrollbar */
::-webkit-scrollbar{ width:9px; height:9px; }
::-webkit-scrollbar-track{ background:#000; }
::-webkit-scrollbar-thumb{ background:#2a2a2a; }
::-webkit-scrollbar-thumb:hover{ background:var(--red-deep); }

/* ---------- GRÃO / NOISE ---------- */
.grain{
  position:fixed; inset:0; z-index:9000; pointer-events:none;
  opacity:0; transition:opacity .4s ease;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix type='saturate' values='0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.55'/></svg>");
  mix-blend-mode:overlay;
}
body[data-grain="on"] .grain{ opacity:.05; }

/* ============================================================
   TIPOGRAFIA UTIL
   ============================================================ */
.display{
  font-family:var(--font-display);
  font-weight:400;
  text-transform:uppercase;
  line-height:.92;
  letter-spacing:.005em;
}
.kicker{
  font-family:var(--font-sub);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.28em;
  font-size:12px;
  color:var(--gray);
}
.red{ color:var(--red); }
.secnum{
  font-family:var(--font-sub);
  font-weight:800;
  color:var(--red);
  font-size:13px;
  letter-spacing:.18em;
}

/* thin red rule */
.rule{ height:1px; width:100%; background:var(--red); opacity:.85; }
.rule-soft{ height:1px; width:100%; background:var(--gray-line); }

/* ============================================================
   NAV STICKY
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px var(--gut);
  background:linear-gradient(180deg, rgba(10,10,10,.85), rgba(10,10,10,0));
  transition:background .3s ease, border-color .3s ease, padding .3s ease, transform .4s var(--ease), opacity .4s ease;
  border-bottom:1px solid transparent;
}
.nav.hero-hide{ transform:translateY(-105%); opacity:0; pointer-events:none; }
.nav.solid{
  background:rgba(8,8,8,.92);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--gray-line);
  padding-top:11px; padding-bottom:11px;
}
.nav-logo{ display:flex; align-items:center; gap:2px; }
.brandmark{
  font-family:var(--font-display);
  font-size:26px; letter-spacing:.04em; color:#fff; line-height:1;
  display:flex; align-items:baseline;
}
.brandmark b{ font-weight:400; }
.brandmark .u{
  color:var(--red);
  text-shadow:0 0 1px rgba(225,6,0,.4);
}
.brandmark img{ height:26px; width:auto; }
.logo-img{ height:30px; width:auto; display:block; }
.foot-logo{ height:42px; margin-bottom:18px; }
.nav-links{ display:flex; align-items:center; gap:6px; }
.nav-links a{
  font-family:var(--font-sub); font-weight:600; font-size:12px;
  letter-spacing:.12em; text-transform:uppercase; color:var(--gray);
  padding:8px 13px; border-radius:2px; transition:color .2s ease;
  position:relative;
}
.nav-links a::after{
  content:""; position:absolute; left:13px; right:13px; bottom:4px; height:1px;
  background:var(--red); transform:scaleX(0); transform-origin:left; transition:transform .25s var(--ease);
}
.nav-links a:hover{ color:#fff; }
.nav-links a:hover::after, .nav-links a.active::after{ transform:scaleX(1); }
.nav-links a.active{ color:#fff; }
.nav-cta{
  font-family:var(--font-sub); font-weight:700; font-size:12px; letter-spacing:.12em;
  text-transform:uppercase; color:#fff; background:var(--red);
  padding:11px 20px; border-radius:2px; transition:background .2s ease, transform .2s ease;
}
.nav-cta:hover{ background:var(--red-deep); transform:translateY(-1px); }
.nav-burger{ display:none; flex-direction:column; gap:5px; padding:8px; background:none; border:0; }
.nav-burger span{ width:26px; height:2px; background:#fff; display:block; }

/* ============================================================
   HERO — EXPANSÃO NO SCROLL (sticky-pin)
   ============================================================ */
.sxhero{ position:relative; width:100%; background:var(--ink); }
.sxhero-pin{ position:sticky; top:0; height:100svh; overflow:hidden; isolation:isolate; }

/* fundo que some */
.sxhero-bg{ position:absolute; inset:0; z-index:0; will-change:opacity,transform; }
.sxhero-bg image-slot{ position:absolute; inset:0; width:100%; height:100%; }
.sxhero-bg-scrim{ position:absolute; inset:0; background:linear-gradient(180deg, rgba(10,10,10,.55), rgba(10,10,10,.35) 40%, rgba(10,10,10,.8)); }

/* título que se separa */
.sxhero-title{ position:absolute; z-index:3; inset:0; display:flex; align-items:center; justify-content:center; gap:.28em; pointer-events:none; will-change:transform,opacity; }
.sxhero-title span{ font-family:var(--font-display); text-transform:uppercase; font-size:clamp(48px,11vw,168px); line-height:.9; color:#fff; letter-spacing:.01em; text-shadow:0 6px 40px rgba(0,0,0,.55); will-change:transform; }
.sxhero-title .w2{ color:var(--red); }

/* mídia que expande */
.sxhero-media{
  position:absolute; z-index:2; top:50%; left:50%; transform:translate(-50%,-50%);
  width:320px; height:430px; max-width:95vw; max-height:86vh; border-radius:18px; overflow:hidden;
  background:#0a0a0a; box-shadow:0 30px 80px -20px rgba(0,0,0,.7); will-change:width,height,border-radius;
}
.sxhero-media image-slot{ position:absolute; inset:0; width:100%; height:100%; z-index:0; }
.sxhero-video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:1; opacity:0; transition:opacity .6s ease; }
.sxhero-video.ready{ opacity:1; }
.sxhero-media-scrim{ position:absolute; inset:0; z-index:2; pointer-events:none; background:linear-gradient(180deg, rgba(10,10,10,.15), rgba(10,10,10,.55)); opacity:0; }
.sxhero-hint{ position:absolute; left:0; right:0; bottom:18px; z-index:3; display:flex; flex-direction:column; align-items:center; gap:10px; font-family:var(--font-sub); font-weight:700; font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:#fff; will-change:opacity; }
.sxhero-hint .line{ width:1px; height:34px; background:rgba(255,255,255,.6); position:relative; overflow:hidden; }
.sxhero-hint .line::after{ content:""; position:absolute; inset:0; background:var(--red); animation:hintLine 1.8s var(--ease) infinite; }
@keyframes hintLine{ 0%{ transform:translateY(-100%);} 60%,100%{ transform:translateY(100%);} }

/* estado final: headline + CTAs */
.sxhero-final{ position:absolute; inset:0; z-index:4; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; gap:30px; padding:0 var(--gut); opacity:0; pointer-events:none; will-change:opacity,transform; }
.sxhero-final .hl{ font-family:var(--font-display); text-transform:uppercase; color:#fff; line-height:.9; letter-spacing:.004em; font-size:clamp(40px,7.2vw,128px); max-width:16ch; text-shadow:0 6px 44px rgba(0,0,0,.6); }
.sxhero-final .hl .red{ color:var(--red); }
.sxhero-final .hero-actions{ display:flex; gap:16px; flex-wrap:wrap; justify-content:center; }
@media (max-width:680px){ .sxhero-media{ width:260px; height:340px; } }

/* ============================================================
   HERO (3 variações controladas por body[data-hero])
   ============================================================ */
.hero{ position:relative; width:100%; min-height:100svh; overflow:hidden; isolation:isolate; }
.hero-media{ position:absolute; inset:0; z-index:-2; }
.hero-media image-slot{ position:absolute; inset:0; width:100%; height:100%; z-index:0; }
.hero-video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:1; opacity:0; transition:opacity .8s ease; }
.hero-video.ready{ opacity:1; }
.hero-media::after{ /* vignette + readability scrim */
  content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  background:
    radial-gradient(120% 80% at 70% 30%, rgba(225,6,0,.18), transparent 55%),
    linear-gradient(180deg, rgba(10,10,10,.55) 0%, rgba(10,10,10,.35) 35%, rgba(10,10,10,.92) 100%);
}
.hero-inner{
  position:relative; z-index:2; min-height:100svh;
  display:flex; flex-direction:column;
  padding:clamp(96px,14vh,150px) var(--gut) clamp(40px,7vh,72px);
}
.hero-scroll{
  position:absolute; left:var(--gut); bottom:28px; z-index:3;
  display:flex; align-items:center; gap:12px;
  font-family:var(--font-sub); font-weight:600; font-size:11px;
  letter-spacing:.22em; text-transform:uppercase; color:var(--gray);
}
.hero-scroll .line{ width:46px; height:1px; background:var(--gray); position:relative; overflow:hidden; }
.hero-scroll .line::after{ content:""; position:absolute; inset:0; background:var(--red); animation:scrollline 2.4s var(--ease) infinite; }
@keyframes scrollline{ 0%{ transform:translateX(-100%);} 60%,100%{ transform:translateX(100%);} }

/* eyebrow row */
.hero-eyebrow{
  display:inline-flex; align-items:center; gap:14px;
  font-family:var(--font-sub); font-weight:700; font-size:12px;
  letter-spacing:.24em; text-transform:uppercase; color:var(--bone);
}
.hero-eyebrow .tick{ width:34px; height:1px; background:var(--red); }
.hero-eyebrow .red{ color:var(--red); }

/* headline */
.hero h1{
  font-family:var(--font-display); font-weight:400; text-transform:uppercase;
  color:#fff; letter-spacing:.004em; line-height:.9;
  text-shadow:0 4px 40px rgba(0,0,0,.5);
}
.hero h1 .red{ color:var(--red); }
.hero-sub{
  max-width:46ch; color:var(--bone); font-size:clamp(16px,1.4vw,20px);
  line-height:1.5; opacity:.92;
}
.hero-attr{
  font-family:var(--font-sub); font-weight:700; letter-spacing:.22em;
  text-transform:uppercase; font-size:13px; color:var(--bone);
}
.hero-attr .red{ color:var(--red); }

.btn-red{
  display:inline-flex; align-items:center; gap:12px;
  font-family:var(--font-sub); font-weight:800; font-size:14px; letter-spacing:.14em;
  text-transform:uppercase; color:#fff; background:var(--red);
  padding:18px 30px; border-radius:3px; border:0;
  transition:background .25s ease, transform .25s ease, box-shadow .25s ease;
  box-shadow:0 14px 40px -12px rgba(225,6,0,.6);
}
.btn-red:hover{ background:var(--red-deep); transform:translateY(-2px); box-shadow:0 20px 50px -14px rgba(225,6,0,.7); }
.btn-red .arr{ transition:transform .25s var(--ease); }
.btn-red:hover .arr{ transform:translateX(5px); }
.btn-ghost{
  display:inline-flex; align-items:center; gap:12px;
  font-family:var(--font-sub); font-weight:700; font-size:13px; letter-spacing:.14em;
  text-transform:uppercase; color:#fff; background:transparent;
  padding:17px 26px; border:1px solid var(--gray-line); border-radius:3px;
  transition:border-color .25s ease, background .25s ease;
}
.btn-ghost:hover{ border-color:#fff; background:rgba(255,255,255,.05); }

/* ---- variação 1: QUOTE cinematográfico (centralizado) ---- */
body[data-hero="1"] .hero-inner{ align-items:center; justify-content:center; text-align:center; }
body[data-hero="1"] .hero-v1{ display:flex; }
body[data-hero="2"] .hero-v1, body[data-hero="3"] .hero-v1{ display:none; }
.hero-v1{ flex-direction:column; align-items:center; gap:30px; max-width:1100px; }
.hero-v1 .quote-mark{
  font-family:var(--font-display); color:var(--red); font-size:clamp(60px,9vw,120px);
  line-height:.5; margin-bottom:-10px;
}
.hero-v1 h1{ font-size:clamp(44px,8.2vw,150px); }
.hero-v1 .hero-actions{ display:flex; gap:16px; flex-wrap:wrap; justify-content:center; margin-top:6px; }

/* ---- variação 2: EDITORIAL split assimétrico ---- */
body[data-hero="2"] .hero-inner{ justify-content:flex-end; }
body[data-hero="2"] .hero-v2{ display:grid; }
body[data-hero="1"] .hero-v2, body[data-hero="3"] .hero-v2{ display:none; }
.hero-v2{
  grid-template-columns:minmax(0,1.5fr) minmax(0,1fr); gap:clamp(24px,5vw,72px);
  align-items:end; width:100%;
}
.hero-v2 .col-l{ display:flex; flex-direction:column; gap:26px; }
.hero-v2 h1{ font-size:clamp(46px,8vw,128px); }
.hero-v2 .hero-actions{ display:flex; gap:16px; flex-wrap:wrap; margin-top:4px; }
.hero-v2 .col-r{ display:flex; flex-direction:column; gap:22px; align-items:flex-start; padding-bottom:6px; }
.hero-stats{ display:flex; gap:clamp(20px,3vw,40px); flex-wrap:wrap; }
.hero-stat .n{
  font-family:var(--font-display); font-size:clamp(38px,5vw,72px); color:#fff; line-height:.85;
}
.hero-stat .n .red{ color:var(--red); }
.hero-stat .l{
  font-family:var(--font-sub); font-weight:600; font-size:11px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--gray); margin-top:8px;
}
.hero-v2 .col-r .rule{ width:100%; }

/* ---- variação 3: TYPE full-bleed + marquee ---- */
body[data-hero="3"] .hero-inner{ justify-content:flex-end; }
body[data-hero="3"] .hero-v3{ display:flex; }
body[data-hero="1"] .hero-v3, body[data-hero="2"] .hero-v3{ display:none; }
.hero-v3{ flex-direction:column; gap:30px; width:100%; }
.hero-v3 .top{ display:flex; justify-content:space-between; align-items:flex-end; gap:24px; flex-wrap:wrap; }
.hero-v3 h1{ font-size:clamp(52px,12.5vw,230px); letter-spacing:-.01em; }

/* palavra em destaque que troca de tipografia */
.fx-word{ display:inline-block; will-change:transform,filter; }
.fx-word.swap{ animation:fxSwap .45s cubic-bezier(.22,.61,.36,1); }
.fx-word.typing::after{ content:""; display:inline-block; width:.06em; height:.92em; margin-left:.04em; background:currentColor; vertical-align:baseline; animation:caret .7s steps(1) infinite; }
@keyframes caret{ 0%,50%{ opacity:1; } 50.01%,100%{ opacity:0; } }
@keyframes fxSwap{
  0%{ filter:blur(7px); opacity:.25; transform:translateY(.06em) scale(.9); }
  60%{ filter:blur(0); opacity:1; }
  100%{ filter:blur(0); opacity:1; transform:none; }
}
.hero-v3 .meta{ max-width:30ch; }
.hero-v3 .hero-actions{ display:flex; gap:16px; flex-wrap:wrap; }
.hero-meta{ display:flex; align-items:center; gap:18px; max-width:480px; }
.hero-meta-num{ font-family:var(--font-display); font-size:clamp(54px,5.2vw,86px); color:#fff; line-height:.78; flex-shrink:0; }
.hero-meta-num .red{ color:var(--red); }
.hero-meta p{ color:var(--bone); font-size:14.5px; line-height:1.45; opacity:.9; }
.hero-meta p strong{ display:block; margin-top:5px; color:#fff; font-family:var(--font-sub); font-weight:700; font-size:15px; }
@media (max-width:600px){ .hero-meta{ gap:14px; } .hero-meta-num{ font-size:48px; } }

/* entrada animada na carga (micro-animação) */
@media (prefers-reduced-motion:no-preference){
  body[data-hero="3"] .hero-v3 .top{ animation:heroUp .9s var(--ease) both; }
  body[data-hero="3"] .hero-v3 h1{ animation:heroUp 1s var(--ease) .12s both; }
  body[data-hero="3"] .hero-v3 .hero-actions{ animation:heroUp .9s var(--ease) .26s both; }
}
@keyframes heroUp{ from{ opacity:0; transform:translateY(34px); } to{ opacity:1; transform:none; } }

/* hero marquee strip (only v3 + global marquee component reuse) */
.marquee{
  width:100%; overflow:hidden; white-space:nowrap;
  border-top:1px solid var(--gray-line); border-bottom:1px solid var(--gray-line);
  padding:16px 0; -webkit-user-select:none; user-select:none;
}
.marquee.bare{ border:0; padding:0; }
.marquee-track{ display:inline-flex; gap:0; will-change:transform; animation:marq 30s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
body[data-marquee="off"] .marquee-track{ animation:none; }
.marquee-track span{
  font-family:var(--font-display); text-transform:uppercase; font-size:clamp(22px,2.4vw,34px);
  color:transparent; -webkit-text-stroke:1px rgba(244,241,236,.5); padding:0 28px;
  display:inline-flex; align-items:center; gap:28px;
}
.marquee-track span::after{ content:"✦"; color:var(--red); -webkit-text-stroke:0; font-size:.5em; }
.marquee-track span.fill{ color:var(--red); -webkit-text-stroke:0; }
@keyframes marq{ from{ transform:translateX(0);} to{ transform:translateX(-50%);} }

/* ============================================================
   SECTION SHELL
   ============================================================ */
.section{ padding:clamp(72px,11vh,140px) var(--gut); position:relative; }
.section.dark{ background:var(--ink); color:var(--bone); }
.section.char{ background:var(--char); color:var(--bone); }
.section.light{ background:var(--bone); color:var(--ink); }
.section.red{ background:var(--red); color:#fff; }
.wrap{ max-width:var(--maxw); margin:0 auto; }

.sec-head{ display:flex; align-items:baseline; gap:18px; margin-bottom:clamp(36px,5vw,64px); flex-wrap:wrap; }
.sec-head .secnum{ flex-shrink:0; }
.sec-title{
  font-family:var(--font-display); font-weight:400; text-transform:uppercase;
  line-height:.92; letter-spacing:.005em; font-size:clamp(34px,6vw,92px); color:inherit;
}
.section.light .sec-title{ color:var(--ink); }
.sec-title .red{ color:var(--red); }
.sec-title .out{ color:transparent; -webkit-text-stroke:1.4px currentColor; }

/* reveal */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; } .reveal.d4{ transition-delay:.32s; }

@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  .marquee-track,.hero-scroll .line::after{ animation:none; }
}

/* ============================================================
   01 — MANIFESTO
   ============================================================ */
.manifesto{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(32px,6vw,90px); align-items:start; }
.manifesto-lead{
  font-family:var(--font-sub); font-weight:600;
  font-size:clamp(30px,4vw,58px); line-height:1.12; letter-spacing:-.01em; color:var(--ink);
}
.manifesto-lead .red{ color:var(--red); }
.manifesto-body{ display:flex; flex-direction:column; gap:18px; }
.manifesto-body p{ font-size:17px; line-height:1.7; color:#2a2a2a; max-width:48ch; }
.manifesto-not{ display:flex; flex-wrap:wrap; gap:8px; margin-top:6px; }
.manifesto-not span{
  font-family:var(--font-sub); font-weight:700; font-size:11px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--gray); border:1px solid var(--gray-line-d); padding:7px 13px; border-radius:2px;
}
.manifesto-not span.is{ color:#fff; background:var(--ink); border-color:var(--ink); }

.stats-row{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; margin-top:clamp(40px,6vw,72px); border-top:1px solid var(--gray-line-d); }
.section.light .stat{ border-right:1px solid var(--gray-line-d); }
.stat{ padding:clamp(24px,3vw,40px) clamp(16px,2vw,30px) 0; }
.stat:last-child{ border-right:0; }
.stat .n{ font-family:var(--font-display); font-size:clamp(48px,7vw,108px); line-height:.85; color:var(--ink); }
.stat .n .red{ color:var(--red); }
.stat .l{ font-family:var(--font-sub); font-weight:600; font-size:13px; letter-spacing:.12em; text-transform:uppercase; color:var(--gray); margin-top:14px; }

/* big pull quote band */
.pullquote{ padding:clamp(72px,12vh,150px) var(--gut); background:var(--ink); position:relative; overflow:hidden; }
.pq-canvas{ position:absolute; inset:0; z-index:0; width:100%; height:100%; display:block; }
.pullquote .pq-center p{ text-shadow:0 2px 30px rgba(0,0,0,.7); }
.pullquote .wrap{ position:relative; z-index:2; }
.pullquote .mark{ font-family:var(--font-display); color:var(--red); font-size:clamp(80px,12vw,180px); line-height:.4; display:block; }
.pullquote p{
  font-family:var(--font-display); font-weight:400; text-transform:uppercase;
  font-size:clamp(34px,6.2vw,104px); line-height:.95; color:#fff; max-width:18ch; letter-spacing:.004em;
}
.pullquote p .red{ color:var(--red); }
.pullquote .src{ font-family:var(--font-sub); font-weight:700; letter-spacing:.22em; text-transform:uppercase; font-size:13px; color:var(--gray); margin-top:36px; }
.pullquote .pq-center{ display:flex; flex-direction:column; align-items:center; text-align:center; margin:0 auto; }
.pullquote .pq-center p{ max-width:22ch; font-size:clamp(40px,7.4vw,128px); }
.pullquote .pq-center .src{ margin-top:30px; }
.pullquote .ghost{
  position:absolute; right:-2%; top:50%; transform:translateY(-50%);
  font-family:var(--font-display); font-size:38vw; color:rgba(255,255,255,.025); line-height:.7; pointer-events:none; z-index:1;
}

/* ============================================================
   02 — PILARES (scroll horizontal fixado)
   ============================================================ */
.hsection{ position:relative; background:var(--ink); }
.hpin{ position:sticky; top:0; height:100svh; overflow:hidden; display:flex; align-items:center; }
.hpin-inner{ display:flex; flex-direction:column; justify-content:center; gap:clamp(20px,3vw,40px); width:100%; height:100%; padding:clamp(80px,11vh,120px) 0 clamp(40px,6vh,70px); }
.hhead{ display:flex; align-items:baseline; gap:18px; flex-wrap:wrap; padding:0 var(--gut); flex-shrink:0; }
.hhead .sec-title{ font-size:clamp(30px,4.6vw,68px); }
.hhint{ font-family:var(--font-sub); font-weight:700; font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--gray); display:inline-flex; align-items:center; gap:12px; margin-left:auto; }
.hhint-line{ width:40px; height:1px; background:var(--red); position:relative; overflow:hidden; }
.hhint-line::after{ content:""; position:absolute; inset:0; background:var(--bone); animation:scrollline 2.4s var(--ease) infinite; }

.htrack{ display:flex; gap:clamp(16px,1.8vw,26px); padding:0 var(--gut); align-items:stretch; will-change:transform; flex:1; }
.pcard{
  flex:0 0 clamp(330px,42vw,560px); background:var(--char); border:1px solid var(--gray-line);
  border-radius:6px; display:flex; flex-direction:column; position:relative; overflow:hidden;
  transition:border-color .4s ease, transform .5s var(--ease);
}
.pcard::before{ content:""; position:absolute; left:0; top:0; height:4px; width:0; background:var(--red); z-index:4; transition:width .6s var(--ease); }
.pcard.is-active{ border-color:var(--red); }
.pcard.is-active::before{ width:100%; }

.pcard-media{ position:relative; height:clamp(180px,26vh,320px); flex-shrink:0; overflow:hidden; background:#0c0c0c; }
.pcard-media image-slot{ position:absolute; inset:0; width:100%; height:100%; transition:transform .6s var(--ease); }
.pcard.is-active .pcard-media image-slot{ transform:scale(1.05); }
.pcard-media-scrim{ position:absolute; inset:0; z-index:1; pointer-events:none; background:linear-gradient(180deg, rgba(10,10,10,.5) 0%, rgba(10,10,10,.05) 42%, rgba(10,10,10,.6) 100%); }
.pidx{ position:absolute; top:18px; left:20px; z-index:2; font-family:var(--font-sub); font-weight:800; font-size:15px; letter-spacing:.1em; color:#fff; transition:color .4s ease; }
.pcard.is-active .pidx{ color:var(--red); }
.picon{ position:absolute; top:14px; right:16px; z-index:2; width:clamp(48px,3.6vw,66px); height:clamp(48px,3.6vw,66px); color:rgba(255,255,255,.85); transition:color .5s ease, transform .6s var(--ease); display:block; }
.picon svg{ width:100%; height:100%; }
.pcard.is-active .picon{ color:var(--red); transform:scale(1.06); }
.picon .draw{ stroke-dasharray:240; stroke-dashoffset:240; transition:stroke-dashoffset 1s var(--ease); }
.pcard.is-active .picon .draw{ stroke-dashoffset:0; }

.pcard-body{ padding:clamp(26px,2.4vw,40px); display:flex; flex-direction:column; flex:1; }
.pcard h3{ font-family:var(--font-display); text-transform:uppercase; font-size:clamp(28px,2.8vw,46px); line-height:.95; color:#fff; margin:0 0 16px; }
.pcard .rule-soft{ background:var(--gray-line); margin-bottom:16px; }
.pcard p{ color:var(--gray); font-size:15.5px; line-height:1.55; margin-bottom:18px; }
.pcard .ptag{ font-family:var(--font-sub); font-weight:700; font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--bone); opacity:.6; margin-top:auto; }
.pcard.is-active .ptag{ color:var(--red); opacity:1; }

/* fallback / mobile: scroll horizontal nativo com snap */
.hsection.no-pin{ height:auto !important; }
.hsection.no-pin .hpin{ position:static; height:auto; overflow:visible; }
.hsection.no-pin .hpin-inner{ height:auto; padding:clamp(72px,11vh,140px) 0; }
.hsection.no-pin .htrack{ overflow-x:auto; scroll-snap-type:x mandatory; transform:none !important; padding-bottom:18px; -webkit-overflow-scrolling:touch; }
.hsection.no-pin .htrack::-webkit-scrollbar{ height:4px; }
.hsection.no-pin .htrack::-webkit-scrollbar-thumb{ background:var(--red-deep); }
.hsection.no-pin .pcard{ scroll-snap-align:center; }
@media (prefers-reduced-motion:reduce){ .picon .draw{ stroke-dashoffset:0; } }

/* ============================================================
   03 — BRAÇOS (portfolio)
   ============================================================ */
.bracos-intro{ display:flex; justify-content:space-between; align-items:flex-end; gap:30px; flex-wrap:wrap; margin-bottom:40px; }
.bracos-intro p{ max-width:46ch; color:var(--gray); font-size:17px; line-height:1.6; }
.bracos{ display:grid; grid-template-columns:repeat(12,1fr); gap:clamp(14px,1.6vw,22px); }
.braco{
  position:relative; overflow:hidden; border-radius:5px; background:var(--char);
  min-height:380px; display:flex; flex-direction:column; justify-content:flex-end;
  isolation:isolate; cursor:pointer; border:1px solid var(--gray-line);
  transition:border-color .4s ease, transform .5s var(--ease);
}
.braco:hover{ border-color:var(--red); }
.braco image-slot{ position:absolute; inset:0; width:100%; height:100%; z-index:0; transition:transform .7s var(--ease); }
.braco:hover image-slot{ transform:scale(1.05); }
.braco .scrim{
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(180deg, rgba(10,10,10,.05) 0%, rgba(10,10,10,.35) 45%, rgba(10,10,10,.95) 100%);
  transition:background .4s ease;
}
.braco:hover .scrim{ background:linear-gradient(180deg, rgba(120,5,0,.22) 0%, rgba(10,10,10,.5) 45%, rgba(10,10,10,.97) 100%); }
.braco .body{ position:relative; z-index:2; padding:clamp(22px,2.2vw,38px); display:flex; flex-direction:column; gap:11px; }
.braco-idx{ font-family:var(--font-sub); font-weight:800; font-size:12px; letter-spacing:.22em; color:rgba(255,255,255,.55); margin-bottom:2px; }
.braco .tag{ font-family:var(--font-sub); font-weight:700; font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--red); }
.braco h3{ font-family:var(--font-display); text-transform:uppercase; font-size:clamp(26px,2.6vw,44px); line-height:.95; color:#fff; }
.braco p{ color:var(--bone); font-size:15px; line-height:1.5; opacity:.82; max-width:44ch; }
.braco .go{
  display:inline-flex; align-items:center; gap:10px; font-family:var(--font-sub); font-weight:700;
  font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:#fff; margin-top:6px;
}
.braco .go .arr{ color:var(--red); transition:transform .3s var(--ease); }
.braco:hover .go .arr{ transform:translateX(7px); }
/* spans / ritmo de portfólio */
.braco.feat{ grid-column:span 12; min-height:clamp(420px,52vw,620px); }
.braco.feat h3{ font-size:clamp(40px,5vw,88px); }
.braco.feat p{ font-size:clamp(16px,1.3vw,19px); max-width:54ch; }
.braco.half{ grid-column:span 6; min-height:clamp(380px,38vw,500px); }
.braco.half h3{ font-size:clamp(30px,3.2vw,56px); }
.braco.third{ grid-column:span 4; min-height:clamp(360px,30vw,440px); }
.braco.wide{ grid-column:span 12; min-height:clamp(300px,28vw,400px); justify-content:flex-end; }
.braco.wide h3{ font-size:clamp(32px,3.6vw,60px); }
@media (max-width:900px){
  .braco.feat,.braco.half,.braco.third,.braco.wide{ grid-column:span 12; min-height:340px; }
}

/* ============================================================
   04 — MOMENTOS (duas faixas deslizantes opostas)
   ============================================================ */
.photo-rows{ display:flex; flex-direction:column; gap:clamp(10px,1.2vw,16px); margin:clamp(8px,2vw,24px) calc(-1 * var(--gut)) 0; }
.photo-strip{ overflow:hidden; -webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent); mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent); }
.photo-track{ display:flex; gap:clamp(10px,1.2vw,16px); width:max-content; will-change:transform; animation:photoSlide 60s linear infinite; }
.photo-track.rev{ animation-direction:reverse; animation-duration:52s; }
.photo-strip:hover .photo-track{ animation-play-state:paused; }
.photo{ position:relative; height:clamp(170px,22vh,280px); border-radius:5px; overflow:hidden; background:#0a0a0a; flex-shrink:0; }
.photo image-slot{ position:absolute; inset:0; width:100%; height:100%; }
.photo.w-p{ width:clamp(150px,15vw,240px); }
.photo.w-m{ width:clamp(240px,24vw,380px); }
.photo.w-l{ width:clamp(340px,34vw,520px); }
@keyframes photoSlide{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
body[data-duotone="on"] .photo.duo image-slot{ filter:grayscale(1) contrast(1.12) brightness(.92); }
body[data-duotone="on"] .photo.duo::after{ content:""; position:absolute; inset:0; z-index:2; pointer-events:none; background:linear-gradient(140deg,rgba(225,6,0,.5),rgba(10,10,10,.5)); mix-blend-mode:color; }
body[data-duotone="on"] .braco.feat image-slot{ filter:none; }
@media (prefers-reduced-motion:reduce){ .photo-track{ animation:none; } }

.video-feature{ margin-top:clamp(16px,2vw,22px); position:relative; border-radius:4px; overflow:hidden; background:#000; min-height:clamp(260px,46vw,560px); border:1px solid var(--gray-line); }
.video-feature image-slot{ position:absolute; inset:0; width:100%; height:100%; }
.video-feature .scrim{ position:absolute; inset:0; background:linear-gradient(180deg,rgba(10,10,10,.2),rgba(10,10,10,.7)); z-index:1; }
.video-feature .vf-body{ position:absolute; inset:0; z-index:2; display:flex; flex-direction:column; justify-content:flex-end; padding:clamp(24px,4vw,56px); gap:14px; }
.play-btn{
  width:84px; height:84px; border-radius:50%; background:var(--red); border:0;
  display:flex; align-items:center; justify-content:center; align-self:flex-start;
  box-shadow:0 16px 50px -12px rgba(225,6,0,.7); transition:transform .25s ease, background .25s ease;
}
.play-btn:hover{ transform:scale(1.06); background:var(--red-deep); }
.play-btn svg{ width:26px; height:26px; fill:#fff; margin-left:4px; }
.video-feature h3{ font-family:var(--font-display); text-transform:uppercase; font-size:clamp(26px,3.5vw,52px); color:#fff; line-height:.95; }

/* ============================================================
   05 — DEPOIMENTOS EM VÍDEO
   ============================================================ */
.vcarousel{ position:relative; }
.vcar-track{ display:flex; gap:clamp(16px,2vw,26px); overflow-x:auto; scroll-snap-type:x mandatory; padding-bottom:8px; scrollbar-width:none; -webkit-overflow-scrolling:touch; }
.vcar-track::-webkit-scrollbar{ display:none; }
.vtesti{ flex:0 0 clamp(250px,27vw,360px); scroll-snap-align:start; display:flex; flex-direction:column; gap:16px; }
@media (max-width:600px){ .vtesti{ flex-basis:80vw; } }
.vtesti-video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:3; opacity:0; transition:opacity .3s ease; pointer-events:none; background:#000; }
.vtesti.playing .vtesti-video{ opacity:1; pointer-events:auto; cursor:pointer; }
.vtesti.playing .vtesti-scrim,
.vtesti.playing .vtesti-badge{ opacity:0; }
.vtesti.playing .play-btn.sm{ opacity:0; pointer-events:none; }
.play-btn.sm{ transition:transform .25s ease, opacity .3s ease, background .25s ease; }
.play-btn.sm.pulse{ animation:btnPulse .5s ease; }
@keyframes btnPulse{ 0%,100%{ transform:translate(-50%,-50%) scale(1);} 50%{ transform:translate(-50%,-50%) scale(1.16);} }
.vcar-controls{ display:flex; gap:10px; justify-content:flex-end; margin-top:26px; }
.vcar-nav{ width:54px; height:54px; border-radius:50%; border:1px solid var(--gray-line-d); background:transparent; color:var(--ink); font-size:20px; display:flex; align-items:center; justify-content:center; transition:background .25s ease, border-color .25s ease, color .25s ease, transform .25s ease; }
.vcar-nav:hover{ background:var(--red); border-color:var(--red); color:#fff; transform:translateY(-2px); }
.vcar-nav.dark{ border-color:var(--gray-line); color:var(--bone); }
.vcar-nav.dark:hover{ background:var(--red); border-color:var(--red); color:#fff; }

/* recaps em vídeo (landscape) */
.recap{ flex:0 0 clamp(300px,46vw,620px); scroll-snap-align:start; }
@media (max-width:600px){ .recap{ flex-basis:86vw; } }
.recap-media{ position:relative; aspect-ratio:16/9; border-radius:6px; overflow:hidden; background:#0a0a0a; border:1px solid var(--gray-line); cursor:pointer; transition:border-color .3s ease; }
.recap-media:hover{ border-color:var(--red); }
.recap-media image-slot{ position:absolute; inset:0; width:100%; height:100%; transition:transform .6s var(--ease); }
.recap-media:hover image-slot{ transform:scale(1.04); }
.recap-video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:3; opacity:0; transition:opacity .3s ease; pointer-events:none; background:#000; }
.recap.playing .recap-video{ opacity:1; pointer-events:auto; cursor:pointer; }
.recap-media .scrim{ position:absolute; inset:0; z-index:1; background:linear-gradient(180deg, rgba(10,10,10,.08), rgba(10,10,10,.66)); pointer-events:none; transition:opacity .3s ease; }
.recap .play-btn{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); z-index:2; transition:transform .25s ease, background .25s ease, opacity .3s ease; }
.recap .play-btn:hover{ transform:translate(-50%,-50%) scale(1.07); background:var(--red-deep); }
.recap .play-btn.pulse{ animation:btnPulse .5s ease; }
.recap-cap{ position:absolute; left:0; bottom:0; z-index:2; padding:clamp(18px,2vw,28px); display:flex; flex-direction:column; gap:8px; transition:opacity .3s ease; }
.recap-cap .tag{ font-family:var(--font-sub); font-weight:700; font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--red); }
.recap-cap h3{ font-family:var(--font-display); text-transform:uppercase; font-size:clamp(20px,2vw,32px); color:#fff; line-height:.95; }
.recap.playing .scrim,
.recap.playing .play-btn,
.recap.playing .recap-cap{ opacity:0; pointer-events:none; }
.recap-media iframe.yt-embed,
.vtesti-media iframe.yt-embed{ position:absolute; inset:0; width:100%; height:100%; border:0; z-index:5; }
.vtesti-media{
  position:relative; aspect-ratio:4/5; border-radius:6px; overflow:hidden; background:#0a0a0a;
  cursor:pointer; border:1px solid var(--gray-line-d); transition:border-color .3s ease, box-shadow .3s ease;
}
.vtesti-media:hover{ border-color:var(--red); box-shadow:0 26px 50px -28px rgba(10,10,10,.45); }
.vtesti-media image-slot{ position:absolute; inset:0; width:100%; height:100%; transition:transform .6s var(--ease); }
.vtesti-media:hover image-slot{ transform:scale(1.04); }
.vtesti-scrim{ position:absolute; inset:0; z-index:1; pointer-events:none; background:linear-gradient(180deg, rgba(10,10,10,.12) 0%, rgba(10,10,10,.15) 50%, rgba(10,10,10,.6) 100%); }
.vtesti-badge{ position:absolute; top:16px; left:16px; z-index:2; font-family:var(--font-sub); font-weight:700; font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:#fff; background:var(--red); padding:6px 12px; border-radius:2px; }
.play-btn.sm{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:66px; height:66px; z-index:2; box-shadow:0 12px 36px -10px rgba(225,6,0,.7); }
.vtesti-media:hover .play-btn.sm{ transform:translate(-50%,-50%) scale(1.08); }
.vtesti-foot .nm{ font-family:var(--font-sub); font-weight:700; font-size:15px; letter-spacing:.04em; text-transform:uppercase; color:var(--ink); }
.vtesti-foot .rl{ font-size:14px; color:var(--gray); margin-top:3px; }

/* ============================================================
   06 — FUNDADOR
   ============================================================ */
.founder{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(30px,5vw,80px); align-items:center; }
@media (max-width:880px){ .founder{ grid-template-columns:1fr; } }
.founder-photo{ position:relative; }
.founder-clip{ position:relative; width:100%; aspect-ratio:4/5; overflow:visible; border-radius:0; background:transparent; }
.founder-photo image-slot{ position:absolute; inset:0; width:100%; height:100%; mix-blend-mode:screen; }
.founder-photo .badge{
  position:absolute; bottom:-14px; left:-14px; background:var(--red); color:#fff;
  font-family:var(--font-display); text-transform:uppercase; font-size:clamp(16px,1.5vw,22px);
  padding:14px 22px; line-height:1; letter-spacing:.02em;
}
.founder-photo .badge small{ display:block; font-family:var(--font-sub); font-weight:600; font-size:10px; letter-spacing:.18em; margin-top:6px; opacity:.85; }
.founder-body h2{ font-family:var(--font-display); text-transform:uppercase; font-size:clamp(32px,4.5vw,72px); line-height:.92; color:#fff; margin-bottom:6px; }
.founder-body h2 .red{ color:var(--red); }
.founder-role{ font-family:var(--font-sub); font-weight:700; letter-spacing:.2em; text-transform:uppercase; font-size:12px; color:var(--gray); margin-bottom:26px; }
.founder-body p{ color:var(--bone); opacity:.86; font-size:17px; line-height:1.7; max-width:54ch; margin-bottom:18px; }
.founder-meta{ display:flex; gap:clamp(20px,3vw,44px); flex-wrap:wrap; margin-top:30px; padding-top:26px; border-top:1px solid var(--gray-line); }
.founder-meta .m .n{ font-family:var(--font-display); font-size:clamp(30px,3.4vw,52px); color:#fff; line-height:.85; }
.founder-meta .m .n .red{ color:var(--red); }
.founder-meta .m .l{ font-family:var(--font-sub); font-weight:600; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--gray); margin-top:10px; }
.founder-quote{ font-family:var(--font-display); text-transform:uppercase; font-size:clamp(22px,2.4vw,34px); line-height:1; color:var(--red); margin-top:30px; max-width:24ch; }

/* ============================================================
   07 — BRASIL ENTRA DE GRAÇA (red feature)
   ============================================================ */
.gratis{ display:block; }
.gratis-head{ margin-bottom:clamp(30px,4vw,56px); }
.gratis-head h2{ margin-top:18px; }
.gratis-cols{ display:grid; grid-template-columns:1.05fr .85fr; gap:clamp(30px,5vw,70px); align-items:start; }
@media (max-width:880px){ .gratis-cols{ grid-template-columns:1fr; } }
.gratis h2{ font-family:var(--font-display); text-transform:uppercase; font-size:clamp(44px,9vw,138px); line-height:.9; color:var(--ink); }
.gratis h2 .out{ color:transparent; -webkit-text-stroke:1.6px var(--red); }
.gratis .lead{ font-size:clamp(17px,1.6vw,21px); line-height:1.55; color:#33323a; margin:22px 0 30px; max-width:42ch; }
.gratis .card{ background:#fff; border:1px solid var(--gray-line-d); border-radius:6px; padding:clamp(24px,3vw,38px); box-shadow:0 24px 50px -34px rgba(10,10,10,.35); }
.gratis .card .row{ display:flex; gap:16px; padding:18px 0; border-bottom:1px solid var(--gray-line-d); }
.gratis .card .row:last-child{ border-bottom:0; padding-bottom:0; }
.gratis .card .row:first-child{ padding-top:0; }
.gratis .card .row .ic{ font-family:var(--font-display); color:var(--red); font-size:22px; line-height:1; min-width:34px; }
.gratis .card .row .tx strong{ display:block; font-family:var(--font-sub); font-weight:700; text-transform:uppercase; letter-spacing:.08em; font-size:13px; color:var(--ink); margin-bottom:4px; }
.gratis .card .row .tx span{ font-size:14.5px; color:#5a5a5a; line-height:1.5; }
.gratis .btn-red{ margin-top:30px; }

/* ============================================================
   08 — CTA FINAL + RODAPÉ
   ============================================================ */
.final{ text-align:center; padding:clamp(90px,16vh,200px) var(--gut); position:relative; overflow:hidden; }
.final .wrap{ position:relative; z-index:2; }
.final .kicker{ color:var(--red); margin-bottom:24px; }
.final h2{ font-family:var(--font-display); text-transform:uppercase; font-size:clamp(46px,10vw,170px); line-height:.88; color:#fff; text-shadow:0 4px 40px rgba(0,0,0,.6); }
.final h2 .red{ color:var(--red); }
.final p{ max-width:40ch; margin:26px auto 38px; color:var(--bone); opacity:.9; font-size:clamp(16px,1.5vw,20px); text-shadow:0 2px 24px rgba(0,0,0,.6); }
.final .actions{ display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }
.final .glow{ position:absolute; left:50%; top:60%; transform:translate(-50%,-50%); width:90vw; height:60vh; background:radial-gradient(ellipse, rgba(225,6,0,.22), transparent 60%); pointer-events:none; z-index:1; }

footer.site{ background:#060606; padding:clamp(50px,7vw,80px) var(--gut) 36px; border-top:1px solid var(--gray-line); }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:clamp(24px,3vw,50px); margin-bottom:46px; }
@media (max-width:860px){ .foot-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:520px){ .foot-grid{ grid-template-columns:1fr; } }
.foot-brand .brandmark{ font-size:40px; margin-bottom:18px; }
.foot-brand p{ color:var(--gray); font-size:15px; line-height:1.6; max-width:34ch; }
.foot-col h4{ font-family:var(--font-sub); font-weight:700; font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--gray); margin-bottom:18px; }
.foot-col a{ display:block; color:var(--bone); font-size:15px; padding:6px 0; transition:color .2s ease; opacity:.82; }
.foot-col a:hover{ color:var(--red); opacity:1; }
.foot-bottom{ display:flex; justify-content:space-between; align-items:center; gap:16px; flex-wrap:wrap; padding-top:28px; border-top:1px solid var(--gray-line); }
.foot-bottom p{ color:var(--gray); font-size:13px; }
.foot-social{ display:flex; gap:10px; }
.foot-social a{
  width:42px; height:42px; border:1px solid var(--gray-line); border-radius:50%;
  display:flex; align-items:center; justify-content:center; transition:all .25s ease;
}
.foot-social a:hover{ background:var(--red); border-color:var(--red); transform:translateY(-2px); }
.foot-social svg{ width:18px; height:18px; fill:var(--bone); }
.foot-social a:hover svg{ fill:#fff; }

/* ============================================================
   CURSOR CUSTOMIZADO (galeria)
   ============================================================ */
.cursor-dot{
  position:fixed; top:0; left:0; z-index:9500; pointer-events:none;
  width:90px; height:90px; border-radius:50%; background:var(--red); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-sub); font-weight:800; font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  transform:translate(-50%,-50%) scale(0); transition:transform .25s var(--ease), background .25s ease;
  mix-blend-mode:normal;
}
.cursor-dot.show{ transform:translate(-50%,-50%) scale(1); }
@media (hover:none){ .cursor-dot{ display:none; } }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  .manifesto{ grid-template-columns:1fr; }
  .stats-row{ grid-template-columns:1fr; }
  .section.light .stat{ border-right:0; border-bottom:1px solid var(--gray-line-d); padding-bottom:24px; }
  .hero-v2{ grid-template-columns:1fr; }
  .hero-v2 .col-r{ flex-direction:row; align-items:flex-end; flex-wrap:wrap; }
}
@media (max-width:760px){
  .nav-links{ display:none; }
  .nav-burger{ display:flex; }
  .nav.open .nav-links{
    display:flex; position:absolute; top:100%; left:0; right:0; flex-direction:column; align-items:flex-start;
    background:rgba(8,8,8,.98); padding:18px var(--gut); gap:4px; border-bottom:1px solid var(--gray-line);
  }
  .nav.open .nav-links a{ font-size:15px; padding:10px 0; }
  .stats-row{ grid-template-columns:1fr; }
}
