/* ============================================================
   AprovaPM — "Do Sonho à Farda"
   Design system + experiência. Zero dependências em runtime.
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --ink:#0A0B0D;
  --ink-1:#0D0F13;
  --ink-2:#14171C;
  --ink-3:#1B1F26;

  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.14);

  --red:#E30613;
  --red-600:#BE0510;
  --red-bright:#FF2233;
  --red-glow:rgba(227,6,19,.55);

  --silver:#C8CDD3;
  --steel:#5B6A78;
  --white:#F3F5F8;
  --cream:#E7EAEE;
  --fog:#9AA3AD;
  --fog-2:#6C7682;

  --font-display:'Archivo',system-ui,-apple-system,Segoe UI,sans-serif;
  --font-impact:'Anton','Archivo Narrow',var(--font-display);
  --font-body:'Inter',system-ui,-apple-system,Segoe UI,sans-serif;

  --container:1240px;
  --pad:clamp(20px,5vw,64px);
  --section-y:clamp(84px,13vh,170px);

  --ease:cubic-bezier(.2,.7,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

/* ---------- Reset & base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:clip}
body{
  margin:0;
  background:var(--ink);
  color:var(--cream);
  font-family:var(--font-body);
  font-size:clamp(16px,1.05vw,18px);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:clip;
  max-width:100vw;
}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul,ol{margin:0;padding:0;list-style:none}
h1,h2,h3{margin:0;font-family:var(--font-display);font-weight:800;line-height:1.02;letter-spacing:-.02em}
em{font-style:normal}
:focus-visible{outline:2px solid var(--red-bright);outline-offset:3px;border-radius:4px}
.skip-link{position:fixed;left:-9999px;top:12px;z-index:200;background:#fff;color:#000;padding:10px 16px;border-radius:8px}
.skip-link:focus{left:12px}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--pad)}
.section{position:relative;padding-block:var(--section-y);overflow-x:clip}

/* ---------- Overlays ---------- */
.grain{
  position:fixed;inset:0;z-index:120;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.vignette{position:fixed;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(120% 90% at 50% 30%,transparent 55%,rgba(0,0,0,.55) 100%)}

/* ---------- Scroll progress (top) ---------- */
.scroll-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:130;background:rgba(255,255,255,.05)}
.scroll-progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--red),var(--red-bright));box-shadow:0 0 12px var(--red-glow)}

/* ---------- Brand wordmark ---------- */
.brand{display:inline-flex;align-items:center;gap:.6rem;font-family:var(--font-display);font-weight:900;letter-spacing:-.01em}
.brand__logo{height:38px;width:auto;display:block}
.brand--xl .brand__logo{height:64px}
.brand--sm .brand__logo{height:30px}
.brand__mark{width:36px;height:25px;flex:none;
  background:repeating-linear-gradient(180deg,#EEF1F4 0 2.5px,#8A929B 2.5px 5px);
  clip-path:polygon(14% 0,86% 0,100% 50%,86% 100%,14% 100%,0 50%);
  filter:drop-shadow(0 1px 1px rgba(0,0,0,.4))}
.brand__text{font-size:1.22rem;color:var(--white);line-height:1;letter-spacing:.01em}
.brand__pm{color:var(--red)}
.brand--sm .brand__text{font-size:1rem}
.brand--xl{gap:1rem}
.brand--xl .brand__mark{width:74px;height:50px}
.brand--xl .brand__text{font-size:2.1rem}

/* ---------- Buttons ---------- */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  font-family:var(--font-body);font-weight:600;letter-spacing:.01em;color:var(--white);
  border:0;border-radius:999px;cursor:pointer;white-space:nowrap;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .35s var(--ease)}
.btn svg{flex:none}
.btn--sm{padding:.62rem 1.05rem;font-size:.86rem}
.btn--lg{padding:.95rem 1.6rem;font-size:1rem}
.btn--xl{padding:1.15rem 2.1rem;font-size:1.08rem}
.btn--primary{
  background:linear-gradient(180deg,#22c55e,#16a34a);
  box-shadow:0 8px 32px -8px rgba(34,197,94,.6),inset 0 1px 0 rgba(255,255,255,.3),inset 0 -1px 0 rgba(0,0,0,.2);
  position:relative;isolation:isolate}
.btn--primary::before,.btn--primary::after{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:transparent;border:2px solid rgba(34,197,94,.7);
  animation:radarRing 2.4s ease-out infinite;pointer-events:none}
.btn--primary::after{animation-delay:1.2s}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 18px 46px -12px rgba(34,197,94,.75),inset 0 1px 0 rgba(255,255,255,.35)}
.btn--primary:hover::before,.btn--primary:hover::after{animation:none;opacity:0}
@keyframes radarRing{
  0%  {transform:scale(1);   opacity:.8}
  70% {transform:scale(1.55);opacity:0}
  100%{transform:scale(1.55);opacity:0}
}
.btn--primary::after{content:"";position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.25) 50%,transparent 70%);
  background-size:220% 100%;background-position:120% 0;opacity:0;transition:opacity .4s}
.btn--primary:hover::after{opacity:1;animation:sheen 1.1s var(--ease) forwards}
@keyframes sheen{to{background-position:-120% 0}}
.btn--ghost{background:rgba(255,255,255,.04);border:1px solid var(--line-2);backdrop-filter:blur(10px)}
.btn--ghost:hover{background:rgba(255,255,255,.09);transform:translateY(-2px)}

/* ---------- Typography helpers ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:.7rem;margin:0 0 1.4rem;
  font-size:.78rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--silver)}
.eyebrow--center{justify-content:center}
.eyebrow__dot{width:7px;height:7px;border-radius:50%;background:var(--red);box-shadow:0 0 10px var(--red-glow);flex:none}
.h2{font-size:clamp(2rem,4.6vw,3.9rem);color:var(--white);max-width:18ch}
.method__head .h2{font-size:clamp(2rem,2.9vw,2.9rem)!important;max-width:none}
.h2 em{color:#22c55e;background:linear-gradient(180deg,#4ade80 0%,#16a34a 130%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.proof__same-dream{font-size:1.1em;font-weight:800;color:var(--white);white-space:nowrap}
.proof .eyebrow{display:block;color:rgba(255,255,255,.75);text-shadow:0 0 18px rgba(255,255,255,.18)}
.proof .eyebrow .eyebrow__dot{display:inline-block;vertical-align:middle;position:relative;top:-2px;margin-right:.55rem}
.lead{font-size:clamp(1.05rem,1.6vw,1.32rem);color:var(--fog);max-width:46ch;margin:1.2rem 0 0}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
.reveal.is-visible{opacity:1;transform:none}

/* ============================================================
   PRELOADER
   ============================================================ */
.preloader{position:fixed;inset:0;z-index:300;background:var(--ink);
  display:grid;place-items:center;transition:opacity .35s var(--ease),visibility .35s}
.preloader.is-done{opacity:0;visibility:hidden;pointer-events:none}
.preloader__inner{display:flex;flex-direction:column;align-items:center;gap:1.6rem;text-align:center;padding:24px}
.preloader .brand--xl{opacity:0;transform:translateY(12px);animation:plRise .9s var(--ease-out) .1s forwards}
.preloader__tag{display:flex;align-items:center;gap:.7rem;font-family:var(--font-impact);font-weight:400;
  letter-spacing:.34em;text-transform:uppercase;font-size:clamp(.85rem,2.8vw,1.15rem);color:var(--fog);
  opacity:0;animation:plRise .9s var(--ease-out) .35s forwards}
.preloader__tag i{font-style:italic;color:var(--red);font-family:var(--font-body);font-weight:600;letter-spacing:0;text-transform:lowercase}
.preloader__bar{width:min(230px,60vw);height:2px;background:var(--line);border-radius:2px;overflow:hidden}
.preloader__bar span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--red),var(--red-bright));
  box-shadow:0 0 12px var(--red-glow);animation:plBar 1.5s var(--ease) .2s forwards}
@keyframes plRise{to{opacity:1;transform:none}}
@keyframes plBar{to{width:100%}}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{position:fixed;top:0;left:0;right:0;z-index:110;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:clamp(14px,2vw,22px) var(--pad);
  transition:background .4s,backdrop-filter .4s,border-color .4s;
  border-bottom:1px solid transparent}
.site-header::before{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:linear-gradient(180deg,rgba(10,11,13,.6),transparent);transition:opacity .4s}
.site-header.is-solid{background:rgba(10,11,13,.72);backdrop-filter:blur(14px) saturate(1.2);border-color:var(--line)}
.site-header.is-solid::before{opacity:0}

/* Header: nav + ações */
.header__left{display:flex;align-items:center;gap:.9rem}
.site-nav{display:flex;align-items:center;gap:clamp(.7rem,2.2vw,2.2rem)}
.site-nav a{font-size:.88rem;font-weight:500;color:var(--silver);letter-spacing:.01em;
  transition:color .3s var(--ease);white-space:nowrap;padding:.25rem 0}
.site-nav a:hover{color:var(--white)}
/* Ações do header (Blog + Sou aluno) */
.header__actions{display:flex;align-items:center;gap:.6rem;flex:none}

/* Botões do header (Blog / Sou aluno) */
.btn--header-aluno{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.52rem 1.15rem;border-radius:999px;
  font-size:.84rem;font-weight:600;letter-spacing:.01em;
  color:var(--white);flex:none;white-space:nowrap;
  background:rgba(255,255,255,.05);border:1px solid var(--line-2);
  backdrop-filter:blur(10px);
  transition:background .3s,transform .2s,border-color .3s}
.btn--header-aluno svg{flex:none;color:var(--silver);transition:color .3s}
.btn--header-aluno:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.28);transform:translateY(-1px)}
.btn--header-aluno:hover svg{color:#fff}

/* Blog — variante "ghost" (mais discreta) */
.btn--header-blog{background:transparent;border-color:var(--line)}
.btn--header-blog:hover{background:rgba(255,255,255,.06)}

/* Sou aluno — azul pulsante */
.btn--header-cta{
  background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);
  border-color:transparent;
  box-shadow:0 0 0 0 rgba(37,99,235,.55);
  animation:headerCtaPulse 2.2s ease-in-out infinite}
.btn--header-cta svg{color:#fff}
.btn--header-cta:hover{background:linear-gradient(135deg,#3b82f6 0%,#2563eb 100%);border-color:transparent;transform:translateY(-1px)}
.btn--header-cta:hover svg{color:#fff}
@keyframes headerCtaPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(37,99,235,.55)}
  50%{box-shadow:0 0 0 7px rgba(37,99,235,0)}
}

/* ============================================================
   HEADER MOBILE — sem nav · só Blog + Sou aluno (ícone + texto)
   ============================================================ */
@media(max-width:980px){
  /* Nav de links some no mobile */
  .site-nav{display:none}
  /* Blog + Sou aluno: ícone + texto, compactos, à direita */
  .header__actions{gap:.5rem}
  .btn--header-aluno{padding:.5rem .9rem;font-size:.82rem;gap:.4rem}
  .btn--header-aluno svg{width:15px;height:15px}
}
/* Celulares pequenos: encolhe um pouco para caber tudo */
@media(max-width:400px){
  .btn--header-aluno{padding:.46rem .72rem;font-size:.78rem}
  .btn--header-aluno svg{width:14px;height:14px}
  .brand__logo{height:32px}
  .header__actions{gap:.4rem}
}

/* ============================================================
   WHATSAPP FLUTUANTE (FAB) — canto inferior direito
   ============================================================ */
/* ============================================================
   LEAD CAPTURE POPUP (ActiveCampaign)
   ============================================================ */
.lead-popup{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:1rem}
.lead-popup[hidden]{display:none}
.lead-popup.is-visible{display:flex}
.lead-popup__backdrop{position:absolute;inset:0;background:rgba(5,6,8,.85);backdrop-filter:blur(7px);animation:exitFadeIn .3s ease forwards}
.lead-popup__card{
  position:relative;z-index:1;width:100%;max-width:440px;max-height:94vh;overflow-y:auto;
  background:linear-gradient(160deg,#0f1014,#15171f);
  border:1px solid rgba(255,255,255,.09);border-radius:22px;
  box-shadow:0 40px 100px -20px rgba(0,0,0,.92),0 0 0 1px rgba(255,255,255,.04);
  padding:clamp(1.7rem,4vw,2.4rem);
  animation:exitSlideUp .4s cubic-bezier(.22,1,.36,1) forwards}
.lead-popup__card::-webkit-scrollbar{width:8px}
.lead-popup__card::-webkit-scrollbar-thumb{background:rgba(255,255,255,.14);border-radius:8px}
.lead-popup__close{
  position:absolute;top:14px;right:14px;z-index:2;width:34px;height:34px;border-radius:50%;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;color:var(--silver);cursor:pointer;transition:background .2s,color .2s}
.lead-popup__close:hover{background:rgba(255,255,255,.14);color:var(--white)}
.lead-popup__head{margin-bottom:1.4rem;padding-right:1.5rem}
.lead-popup__eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--red-bright);margin:0 0 .6rem}
.lead-popup__title{font-family:var(--font-display);font-size:clamp(1.5rem,3.6vw,2rem);font-weight:900;line-height:1.08;color:var(--white);text-transform:uppercase;letter-spacing:-.01em;margin:0 0 .7rem}
.lead-popup__title em{font-style:normal;background:linear-gradient(180deg,var(--red-bright),var(--red-600));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.lead-popup__text{font-size:.92rem;color:var(--fog);line-height:1.55;margin:0}

/* ============================================================
   EXIT-INTENT POPUP
   ============================================================ */
.exit-popup{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:1rem}
.exit-popup[hidden]{display:none}
.exit-popup.is-visible{display:flex}
.exit-popup__backdrop{position:absolute;inset:0;background:rgba(5,6,8,.82);backdrop-filter:blur(6px);animation:exitFadeIn .3s ease forwards}
.exit-popup__card{
  position:relative;z-index:1;display:grid;grid-template-columns:300px 1fr;
  max-width:780px;width:100%;
  background:linear-gradient(145deg,#0f1014,#161820);
  border:1px solid rgba(255,255,255,.08);border-radius:24px;
  box-shadow:0 40px 100px -20px rgba(0,0,0,.9),0 0 0 1px rgba(255,255,255,.04);
  overflow:hidden;animation:exitSlideUp .4s cubic-bezier(.22,1,.36,1) forwards}
.exit-popup__close{
  position:absolute;top:14px;right:14px;z-index:2;width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  color:var(--silver);cursor:pointer;transition:background .2s,color .2s}
.exit-popup__close:hover{background:rgba(255,255,255,.14);color:var(--white)}
.exit-popup__photo{position:relative;overflow:hidden;background:#0a0c10}
.exit-popup__photo img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;filter:saturate(1.05) brightness(.92)}
.exit-popup__photo::after{content:"";position:absolute;inset:0;background:linear-gradient(to right,transparent 70%,#0f1014 100%)}
.exit-popup__content{display:flex;flex-direction:column;justify-content:center;padding:clamp(1.8rem,3vw,2.6rem) clamp(1.8rem,3vw,2.6rem) clamp(1.8rem,3vw,2.6rem) 1.2rem}
.exit-popup__eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--red-bright);margin:0 0 .6rem}
.exit-popup__title{font-family:var(--font-display);font-size:clamp(1.8rem,3vw,2.4rem);font-weight:900;line-height:1.05;color:var(--white);text-transform:uppercase;letter-spacing:-.02em;margin:0 0 1rem}
.exit-popup__text{font-size:.95rem;color:var(--fog);line-height:1.65;margin:0 0 1.6rem;max-width:36ch}
.exit-popup__cta{width:100%;justify-content:center;max-width:340px}
.exit-popup__skip{margin:1rem 0 0;font-size:.78rem;color:var(--silver);opacity:.55;cursor:pointer;text-decoration:underline;text-underline-offset:3px;transition:opacity .2s}
.exit-popup__skip:hover{opacity:.9}
@keyframes exitFadeIn{from{opacity:0}to{opacity:1}}
@keyframes exitSlideUp{from{opacity:0;transform:translateY(28px) scale(.97)}to{opacity:1;transform:none}}
@media(max-width:660px){
  .exit-popup__card{grid-template-columns:1fr;max-width:400px}
  .exit-popup__photo{height:260px}
  .exit-popup__photo img{object-position:center 25%}
  .exit-popup__photo::after{background:linear-gradient(to bottom,transparent 60%,#0f1014 100%)}
  .exit-popup__content{padding:1.4rem 1.4rem 1.8rem}
  .exit-popup__title{font-size:1.8rem}
}

.wa-fab{
  position:fixed;right:clamp(16px,2.4vw,28px);bottom:clamp(16px,2.4vw,28px);
  z-index:100;
  width:60px;height:60px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:#fff;background:linear-gradient(180deg,#2bd673,#16a34a);
  box-shadow:0 10px 30px -6px rgba(34,197,94,.55),0 4px 12px rgba(0,0,0,.35);
  transition:transform .25s var(--ease),box-shadow .3s var(--ease)}
.wa-fab svg{position:relative;z-index:2;filter:drop-shadow(0 1px 1px rgba(0,0,0,.25))}
.wa-fab:hover{transform:translateY(-3px) scale(1.05);
  box-shadow:0 16px 40px -6px rgba(34,197,94,.7),0 6px 16px rgba(0,0,0,.4)}
.wa-fab:active{transform:scale(.96)}
/* Pulso de sonar verde */
.wa-fab__pulse{position:absolute;inset:0;border-radius:50%;z-index:1;
  background:rgba(37,211,102,.55);
  animation:waPulse 2.4s ease-out infinite;pointer-events:none}
@keyframes waPulse{
  0%{transform:scale(1);opacity:.6}
  70%{transform:scale(1.7);opacity:0}
  100%{transform:scale(1.7);opacity:0}}
@media(max-width:768px){
  .wa-fab{width:54px;height:54px}
  .wa-fab svg{width:26px;height:26px}}

/* ============================================================
   TIMELINE (lateral fixa)
   ============================================================ */
.timeline{position:fixed;left:clamp(18px,2.4vw,38px);top:50%;transform:translateY(-50%);z-index:70;
  padding-left:5px;opacity:0;transition:opacity .6s var(--ease)}
.timeline.is-visible{opacity:1}
.timeline__track{position:absolute;left:10px;top:7px;bottom:7px;width:2px;background:var(--line);border-radius:2px}
.timeline__fill{position:absolute;left:0;top:0;width:100%;height:100%;transform-origin:top;transform:scaleY(var(--p,0));
  background:linear-gradient(var(--red),var(--red-bright));box-shadow:0 0 12px var(--red-glow);border-radius:2px;will-change:transform}
.timeline__comet{position:absolute;left:1px;top:calc(var(--p,0) * 100%);width:11px;height:11px;border-radius:50%;
  background:#fff;transform:translate(-50%,-50%);box-shadow:0 0 10px 2px var(--red-bright),0 0 22px var(--red-glow);will-change:top}
.timeline__list{position:relative;display:flex;flex-direction:column;gap:30px}
.timeline__item a{display:flex;align-items:center;gap:14px;padding:3px 0}
.timeline__dot{width:13px;height:13px;border-radius:50%;background:var(--ink-2);border:2px solid var(--line-2);
  flex:none;transition:.4s var(--ease)}
.timeline__label{font:600 10.5px/1 var(--font-body);letter-spacing:.16em;text-transform:uppercase;color:var(--fog-2);
  opacity:0;transform:translateX(-8px);transition:.35s var(--ease);white-space:nowrap}
.timeline__item:hover .timeline__label,.timeline__item.is-active .timeline__label{opacity:1;transform:none}
.timeline__item.is-done .timeline__dot{background:var(--silver);border-color:var(--silver)}
.timeline__item.is-active .timeline__dot{background:var(--red);border-color:var(--red);
  box-shadow:0 0 0 4px rgba(227,6,19,.16),0 0 16px var(--red-glow)}
.timeline__item.is-active .timeline__label{color:var(--white)}
/* Finale: todos os checkpoints concluídos e acesos */
.timeline.is-complete .timeline__dot{background:var(--red);border-color:var(--red);
  box-shadow:0 0 0 3px rgba(227,6,19,.16),0 0 14px var(--red-glow);animation:tlPulse 1.6s var(--ease) infinite}
.timeline.is-complete .timeline__label{opacity:1;color:var(--silver)}
@keyframes tlPulse{0%,100%{box-shadow:0 0 0 3px rgba(227,6,19,.16),0 0 14px var(--red-glow)}50%{box-shadow:0 0 0 5px rgba(227,6,19,.10),0 0 22px var(--red-glow)}}

/* ============================================================
   HERO — layout 50/50 (texto | foto Alex)
   ============================================================ */
.hero{min-height:100svh;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);overflow:hidden;position:relative}

/* Coluna esquerda — texto */
.hero__content{
  display:flex;flex-direction:column;justify-content:center;
  padding:clamp(86px,11vh,118px) clamp(28px,4.5vw,72px) clamp(96px,13vh,148px) var(--pad);
  position:relative;z-index:2}
.hero__eyebrow-line{
  display:block;margin:0 0 1.6rem;
  font-size:.74rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;
  color:var(--silver);opacity:.85}
.hero__title{
  font-family:var(--font-display);font-weight:900;letter-spacing:-.026em;text-transform:uppercase;
  font-size:clamp(1.5rem,2.9vw,3.7rem);color:var(--white);line-height:1.08;margin:0 0 1rem}
.hero__accent{
  font-family:var(--font-display);font-weight:900;letter-spacing:-.022em;text-transform:uppercase;
  font-size:clamp(1.3rem,2.4vw,3rem);
  background:linear-gradient(180deg,var(--red-bright) 0%,var(--red-600) 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  line-height:1.08;margin:0 0 2.4rem}
.hero__sub{
  font-size:clamp(1.02rem,1.45vw,1.22rem);color:var(--fog);
  max-width:46ch;margin:0 0 2.8rem;line-height:1.7}
.hero__cta{display:flex;flex-wrap:wrap;gap:.9rem;align-items:center}
.hero__trust{width:100%;margin:0;font-size:.72rem;font-weight:500;letter-spacing:.08em;color:var(--silver);opacity:.7}

/* Coluna direita — foto */
.hero__photo{position:relative;overflow:hidden;background:#06080f}
.hero__photo img{
  position:absolute;inset:0;
  width:100%;height:100%;object-fit:cover;object-position:center top;display:block;
  filter:saturate(.92) brightness(.82);
  animation:heroPhotoIn 1.4s var(--ease-out) .3s both}
@keyframes heroPhotoIn{from{transform:scale(1.06) translateX(12px);opacity:0}to{transform:none;opacity:1}}
/* Gradiente para fundir a borda esquerda com o conteúdo */
.hero__photo::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(to right,var(--ink) 0%,rgba(10,11,13,.18) 24%,transparent 46%),
    linear-gradient(180deg,rgba(10,11,13,.55) 0%,transparent 16%,transparent 74%,rgba(10,11,13,.85) 100%)}

/* Scroll hint */
.hero__scroll{
  position:absolute;left:var(--pad);bottom:26px;z-index:3;
  display:flex;align-items:center;gap:14px;
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--fog)}
.hero__scroll-line{width:54px;height:1px;background:linear-gradient(90deg,var(--silver),transparent);position:relative;overflow:hidden}
.hero__scroll-line::after{content:"";position:absolute;top:0;left:-40%;width:40%;height:100%;background:var(--red-bright);animation:scrollLine 2.2s var(--ease) infinite}
@keyframes scrollLine{0%{left:-40%}60%,100%{left:110%}}

/* Responsive: mobile — foto como fundo, conteúdo por cima */
@media(max-width:860px){
  .hero{
    grid-template-columns:1fr;
    grid-template-rows:1fr;
    position:relative}
  /* Foto ocupa tudo como background */
  .hero__photo{
    position:absolute;inset:0;z-index:0;
    opacity:1}
  .hero__photo img{
    object-position:center 14%;
    filter:saturate(1.02) brightness(.96)}
  /* Alex nítido no topo · texto sobre gradiente escuro embaixo */
  .hero__photo::after{
    background:linear-gradient(180deg,
      rgba(10,11,13,.30) 0%,
      rgba(10,11,13,.06) 22%,
      rgba(10,11,13,.30) 44%,
      rgba(10,11,13,.74) 60%,
      rgba(10,11,13,.93) 76%,
      var(--ink) 100%)}
  /* Conteúdo ancorado embaixo, deixando o Alex aparecer no topo */
  .hero__content{
    position:relative;z-index:2;
    min-height:100svh;
    justify-content:flex-end;
    padding-top:clamp(190px,34vh,360px);
    padding-bottom:clamp(30px,6vh,60px);
    padding-right:var(--pad)}
}
@media(max-width:560px){
  .hero__title{font-size:clamp(1.2rem,6vw,2.4rem)}
  .hero__accent{font-size:clamp(1.05rem,5vw,2rem)}
  .hero__eyebrow-line{font-size:.68rem;letter-spacing:.14em}
  .hero__cta{flex-direction:column}
  .hero__cta .btn{width:100%;justify-content:center}
}

/* ============================================================
   BIG WORDS (momentos UAU)
   ============================================================ */
.bigword{position:relative;min-height:96svh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;overflow:hidden;padding:var(--pad);gap:1.4rem;max-width:100vw}
.bigword__text{font-family:var(--font-impact);font-weight:400;text-transform:uppercase;
  font-size:clamp(3.4rem,17vw,15rem);line-height:.9;letter-spacing:.005em;
  color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.22);
  background:linear-gradient(180deg,#fff 8%,var(--steel) 92%);-webkit-background-clip:text;background-clip:text;
  will-change:transform,opacity;text-align:center}
/* ============================================================
   CHEGOU SUA VEZ — linha única + sirene + underline sweep
   ============================================================ */
.bigword__text--siren{
  font-size:clamp(2.8rem,10vw,13rem);
  line-height:1.15;
  white-space:nowrap;
  position:relative;          /* ancora o ::after */
  overflow:visible;
  animation:sirenFlash .85s ease-in-out infinite}

/* --- Underline sirene: feixe de luz que varre e some ---
   Sequência: reveal (esq→dir) → feixe azul/branco/vermelho
   varrendo 3× em modo alternado → some suavemente          */
.bigword__text--siren::after{
  content:"";
  position:absolute;
  bottom:-10px;left:0;
  width:100%;height:5px;
  border-radius:3px;

  /* Feixe: azul(esq) → branco(centro) → vermelho(dir)
     ocupa ~55% do gradiente 3× mais largo que o elemento */
  background:linear-gradient(90deg,
    transparent          0%,
    rgba(10,60,255,.08)  6%,
    rgba(10,60,255,.9)   17%,
    rgba(130,190,255,1)  24%,
    #ffffff              28.5%,
    rgba(255,180,100,1)  33%,
    rgba(255,25,0,.9)    40%,
    rgba(255,25,0,.08)   51%,
    transparent          62%
  );
  background-size:300% 100%;
  background-position:150% 0;   /* feixe fora da tela, à esquerda */
  clip-path:inset(0 100% 0 0 round 3px); /* linha escondida */
  will-change:clip-path,background-position,box-shadow,opacity}

/* Quando a seção centraliza: sequência de 3 animações */
.bigword.is-stamped .bigword__text--siren::after{
  animation:
    sirenReveal  .85s cubic-bezier(.22,1,.36,1) .25s  forwards,
    sirenSweep   1.45s ease-in-out              1.15s 3 alternate forwards,
    sirenFadeOut .55s ease-out                  5.5s  forwards}

/* 1 — revela a linha da esquerda para a direita */
@keyframes sirenReveal{
  from{clip-path:inset(0 100% 0 0 round 3px)}
  to  {clip-path:inset(0 0% 0 0 round 3px)}}

/* 2 — feixe varre: bg-pos 150%→-50% faz o blob passar da esq à dir */
@keyframes sirenSweep{
  0%  {background-position:150% 0;
       box-shadow:none}
  18% {box-shadow:
         0 0 16px 4px rgba(10,80,255,.9),
         0 0 50px 14px rgba(0,60,255,.45)}
  50% {background-position:50% 0;
       box-shadow:
         0 0 22px 7px rgba(255,255,255,.95),
         0 0 60px 20px rgba(200,160,255,.55)}
  82% {box-shadow:
         0 0 16px 4px rgba(255,20,0,.9),
         0 0 50px 14px rgba(255,0,0,.45)}
  100%{background-position:-50% 0;
       box-shadow:none}}

/* 3 — some após as varreduras */
@keyframes sirenFadeOut{
  from{opacity:1}
  to  {opacity:0}}

/* --- Glow do texto alternando vermelho ↔ azul --- */
@keyframes sirenFlash{
  0%,42%{
    filter:
      drop-shadow(0 0 18px rgba(255,20,20,1))
      drop-shadow(0 0 55px rgba(255,0,0,.75))
      drop-shadow(0 0 120px rgba(255,0,0,.35))
      brightness(1.12)}
  50%,92%{
    filter:
      drop-shadow(0 0 18px rgba(40,110,255,1))
      drop-shadow(0 0 55px rgba(0,80,255,.75))
      drop-shadow(0 0 120px rgba(0,80,255,.35))
      brightness(1.12)}
  100%{
    filter:
      drop-shadow(0 0 18px rgba(255,20,20,1))
      drop-shadow(0 0 55px rgba(255,0,0,.75))
      drop-shadow(0 0 120px rgba(255,0,0,.35))
      brightness(1.12)}}

@media(max-width:860px){.bigword__text--siren{font-size:clamp(2.4rem,11vw,7rem)}}
@media(max-width:500px){
  .bigword__text--siren{font-size:clamp(2.6rem,13.5vw,5rem);line-height:1.04;white-space:normal;text-align:center}
  .bigword__text--siren::after{bottom:-7px;height:4px}}

/* Mobile: glow contido — remove o halo gigante que "ilumina" o fundo */
@media(max-width:768px){
  .bigword__text--siren{animation-name:sirenFlashSoft}
}
@keyframes sirenFlashSoft{
  0%,42%{filter:drop-shadow(0 0 8px rgba(255,20,20,.9)) brightness(1.08)}
  50%,92%{filter:drop-shadow(0 0 8px rgba(40,110,255,.9)) brightness(1.08)}
  100%{filter:drop-shadow(0 0 8px rgba(255,20,20,.9)) brightness(1.08)}}
.bigword[data-accent="true"] .bigword__text{
  background:linear-gradient(180deg,#ff4455 0%,#e30613 45%,#8b0000 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-stroke:1px rgba(200,0,0,.2)}
.bigword__sub{max-width:30ch;color:var(--fog);font-size:clamp(1rem,1.5vw,1.2rem);will-change:transform,opacity}
.bigword__sub--strong{color:var(--white);font-size:clamp(1.15rem,1.9vw,1.5rem);font-weight:700;letter-spacing:.01em}
.bigword__cta{margin-top:clamp(1.6rem,3vw,2.4rem)}

/* ============================================================
   QUEM CONSEGUIU (marquees)
   ============================================================ */
.proof{padding-bottom:clamp(90px,14vh,180px)}
.proof__head{margin-bottom:clamp(2.4rem,5vw,4rem)}
.marquees{display:flex;flex-direction:column;gap:clamp(14px,1.6vw,22px);overflow:hidden}
.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.marquee__track{display:flex;gap:clamp(14px,1.6vw,22px);width:max-content;will-change:transform;
  animation:marqueeL var(--dur,40s) linear infinite}
.marquee--reverse .marquee__track{animation-name:marqueeR}
/* hover não pausa mais — carrossel sempre em movimento */
/* -33.3333% = 1/3 do total (3x clonado) → loop contínuo sem buracos · menos nós no mobile */
@keyframes marqueeL{from{transform:translateX(0)}to{transform:translateX(-33.3333%)}}
@keyframes marqueeR{from{transform:translateX(-33.3333%)}to{transform:translateX(0)}}
.pcard{position:relative;flex:none;width:280px;height:214px;margin:0;border-radius:16px;overflow:hidden;
  background:var(--ink-2);border:1px solid var(--line);box-shadow:0 16px 36px -20px #000;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .5s}
.pcard--wide{width:280px}
.pcard img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease),filter .5s;filter:saturate(.96) brightness(.92)}
.pcard::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,transparent 45%,rgba(10,11,13,.82) 100%)}
.pcard:hover{transform:translateY(-6px) scale(1.015);border-color:rgba(227,6,19,.5);box-shadow:0 26px 60px -24px rgba(227,6,19,.45)}
.pcard:hover img{transform:scale(1.06);filter:saturate(1.05) brightness(1)}
.pcard__tag{position:absolute;left:9px;bottom:9px;z-index:2;display:inline-flex;align-items:center;gap:5px;
  padding:.3rem .56rem;border-radius:999px;background:rgba(22,163,74,.2);border:1px solid rgba(34,197,94,.45);
  backdrop-filter:blur(6px);font-size:.63rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#fff}
.pcard__tag::before{content:"";width:5px;height:5px;border-radius:50%;background:#22c55e;box-shadow:0 0 8px rgba(34,197,94,.8)}

/* ============================================================
   PREPARAÇÃO (jornada do método)
   ============================================================ */
.method{overflow:hidden}
.method__bigword{position:relative;display:flex;justify-content:center;margin-bottom:clamp(2rem,5vw,4rem)}
.method__bigword .bigword__text{opacity:.12;font-size:clamp(3rem,15vw,13rem)}
.method .container{position:relative}
.method__head{display:grid;grid-template-columns:minmax(0,60ch) minmax(0,1fr);gap:clamp(1.5rem,4vw,3.5rem);align-items:center;margin-bottom:clamp(2.6rem,6vw,5rem)}
.method__head-text{min-width:0}
.method__head-art{display:flex;justify-content:center;align-items:center}
.method-art{width:100%;max-width:300px;height:auto;overflow:visible}
.method-art__rays{transform-origin:214px 60px;animation:artRays 2.4s ease-in-out infinite}
.method-art__trophy{transform-origin:214px 80px;animation:artFloat 3.4s ease-in-out infinite;filter:drop-shadow(0 6px 22px rgba(34,197,94,.4))}
.method-art__stairs rect{transition:fill .3s}
@keyframes artFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes artRays{0%,100%{opacity:.35}50%{opacity:.7}}
/* Abaixo de 1025px: coluna única, sem ilustração */
@media(max-width:1024px){
  .method__head{grid-template-columns:1fr;gap:0}
  .method__head-art{display:none}
}
.steps{position:relative}
.steps::before{content:"";position:absolute;left:36px;top:54px;bottom:54px;width:2px;background:var(--line);border-radius:2px}
.steps::after{content:"";position:absolute;left:36px;top:54px;width:2px;border-radius:2px;
  height:calc((100% - 108px) * var(--rail,0));background:linear-gradient(var(--red),var(--red-bright));
  box-shadow:0 0 16px var(--red-glow);transition:height .15s linear}
.step{position:relative;display:grid;grid-template-columns:74px minmax(0,1fr) minmax(0,40%);
  gap:clamp(1.2rem,3vw,3rem);align-items:center;padding:clamp(2rem,4.5vw,3.4rem) 0}
.step__index{position:relative;align-self:center;height:100%;min-height:60px;display:flex;align-items:center;justify-content:center}
.step__num{font-family:var(--font-display);font-weight:800;font-size:1rem;color:var(--fog-2);position:absolute;top:-2px;left:50%;transform:translateX(-50%)}
.step__node{width:15px;height:15px;border-radius:50%;background:var(--ink);border:2px solid var(--line-2);z-index:2;
  transition:.5s var(--ease)}
.step.is-reached .step__node{background:var(--red);border-color:var(--red);
  box-shadow:0 0 0 5px rgba(227,6,19,.16),0 0 18px var(--red-glow)}
.step.is-reached .step__num{color:var(--silver)}
.step__node--goal{width:17px;height:17px}
.step.is-reached .step__node--goal{background:var(--red-bright)}
.step__body{opacity:.45;transform:translateY(8px);transition:.7s var(--ease)}
.step.is-reached .step__body{opacity:1;transform:none}
.step__icon{width:50px;height:50px;display:grid;place-items:center;border-radius:13px;margin-bottom:1.1rem;
  color:var(--red-bright);background:rgba(227,6,19,.08);border:1px solid rgba(227,6,19,.28)}
.step__icon--goal{color:#fff;background:linear-gradient(180deg,var(--red-bright),var(--red-600));border-color:transparent;box-shadow:0 0 24px var(--red-glow)}
.step__title{font-size:clamp(1.4rem,2.6vw,2.1rem);color:var(--white);margin-bottom:.5rem}
.step__text{color:var(--fog);max-width:44ch}
.step__shot{margin:0;border-radius:16px;overflow:hidden;border:1px solid var(--line);background:var(--ink-2);
  box-shadow:0 30px 60px -34px #000;aspect-ratio:16/10;opacity:.5;transform:translateY(14px) scale(.98);transition:.8s var(--ease)}
.step.is-reached .step__shot{opacity:1;transform:none}
.step__shot img,.step__shot video{width:100%;height:100%;object-fit:cover;display:block}
.step__shot--video{aspect-ratio:1280/632;background:#0a0c10}
.step__badge{display:inline-block;margin-bottom:.7rem;padding:.28rem .7rem;border-radius:999px;
  background:rgba(227,6,19,.14);border:1px solid rgba(227,6,19,.5);
  font-size:.66rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--red-bright)}
.step--goal .step__title{background:linear-gradient(180deg,#fff,var(--red-bright));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* ============================================================
   DECISÃO
   ============================================================ */
.decision{min-height:92svh;display:flex;align-items:center;text-align:center;overflow:hidden}
.decision__bg{position:absolute;inset:0;z-index:-1}
.decision__bg img{width:100%;height:100%;object-fit:cover;object-position:center 30%;filter:grayscale(.4) brightness(.4)}
.decision::before{content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(70% 70% at 50% 50%,rgba(10,11,13,.55),var(--ink) 92%)}
.decision__inner{display:flex;flex-direction:column;align-items:center}
.decision__title{font-size:clamp(2rem,5.6vw,4.6rem);color:#fff;max-width:20ch;margin:0 auto;line-height:1.04}
.decision__title em{color:var(--red);background:linear-gradient(180deg,#fff,var(--red-bright));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.decision__sub{font-size:clamp(1.5rem,3.4vw,2.7rem);font-family:var(--font-display);font-weight:800;letter-spacing:-.02em;color:#fff;max-width:24ch;margin:.7rem auto 0;line-height:1.1}
.decision__text{font-size:clamp(1.05rem,1.8vw,1.4rem);color:var(--cream);max-width:42ch;margin:1.6rem auto 2.6rem}

/* ============================================================
   INSTRUTOR
   ============================================================ */
/* overflow visible para o position:sticky da foto funcionar (sobrescreve .section{overflow-x:clip}) */
.instructor{overflow:visible}
.instructor__grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.2fr);gap:clamp(2rem,4vw,4.5rem);align-items:start}
.instructor__photo{position:sticky;top:clamp(84px,12vh,120px);align-self:start;margin:0;border-radius:22px;overflow:hidden;border:1px solid var(--line-2);
  box-shadow:0 40px 80px -40px #000;background:var(--ink-2);
  aspect-ratio:3/4;min-height:520px}
.instructor__photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 15%}
.instructor__photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(10,11,13,.55));pointer-events:none}
.instructor__badge{position:absolute;left:18px;top:18px;z-index:2;padding:.45rem .9rem;border-radius:999px;
  background:rgba(10,11,13,.6);border:1px solid var(--line-2);backdrop-filter:blur(8px);
  font-size:.7rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--silver)}
.instructor__content{max-width:58ch;padding-top:.5rem}
.instructor .eyebrow{font-size:clamp(.85rem,1.5vw,1.05rem);letter-spacing:.16em;color:var(--red-bright);font-weight:800;text-shadow:0 0 18px rgba(227,6,19,.3)}
.instructor__kicker{font-size:clamp(1.35rem,2.4vw,1.9rem);color:var(--white);margin:.5rem 0 1.1rem;font-style:normal;letter-spacing:-.01em;font-family:var(--font-display);font-weight:700;line-height:1.18}
.instructor__content .h2{font-size:clamp(1.25rem,2vw,1.7rem)!important;color:var(--silver);font-weight:700}
.instructor__bio{font-size:clamp(1.05rem,1.5vw,1.25rem);color:var(--cream);margin:.6rem 0 1.8rem;line-height:1.75}
.instructor__list{display:flex;flex-direction:column;gap:1rem;margin-bottom:2.2rem}
.instructor__list li{display:flex;align-items:flex-start;gap:.8rem;color:var(--cream);font-weight:500}
.instructor__list svg{color:var(--red-bright);margin-top:3px;flex:none}

/* ============================================================
   PRÓXIMO PASSO
   ============================================================ */
.next{text-align:center}
.next__inner{
  display:flex;flex-direction:column;align-items:center;
  max-width:680px;margin-inline:auto;
  background:linear-gradient(135deg,rgba(255,255,255,.05) 0%,rgba(255,255,255,.02) 100%);
  border:1px solid rgba(255,255,255,.1);
  border-radius:28px;
  padding:clamp(2.4rem,5vw,4rem) clamp(1.6rem,4vw,3.2rem);
  box-shadow:0 0 80px -20px rgba(34,197,94,.14),0 40px 100px -40px rgba(0,0,0,.7);
  position:relative;overflow:hidden}
/* ── Border beam PM: feixe de sirene percorrendo a borda do card ──
   Camada 1 (.next__border-beam): glow externo (drop-shadow).
   Camada 2 (span): máscara "donut" → mostra só a faixa de borda.
   Camada 3 (span::before): conic-gradient que GIRA 360° (1 volta). */
.next__border-beam{
  position:absolute;inset:0;
  border-radius:28px;
  pointer-events:none;
  z-index:0;
  opacity:0;
  filter:drop-shadow(0 0 6px rgba(120,170,255,.7))
         drop-shadow(0 0 12px rgba(255,55,40,.5))}

/* Anel: máscara que revela apenas ~2.5px de borda */
.next__border-beam span{
  position:absolute;inset:0;
  border-radius:28px;
  overflow:hidden;
  padding:2.5px;
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
          mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;
          mask-composite:exclude}

/* Feixe: azul(frente) → branco(centro) → vermelho(cauda), ~60° de arco */
.next__border-beam span::before{
  content:"";position:absolute;
  top:50%;left:50%;width:175%;aspect-ratio:1;
  transform:translate(-50%,-50%) rotate(0deg);
  background:conic-gradient(from 0deg,
    rgba(20,90,255,0)    0deg,
    rgba(20,90,255,1)    13deg,
    #cfe6ff              23deg,
    #ffffff              30deg,
    rgba(255,195,120,1)  37deg,
    rgba(255,30,10,1)    47deg,
    rgba(255,30,10,0)    60deg,
    transparent          360deg)}

/* Dispara ao entrar em viewport (classe via JS): 1 volta horária e some */
.next__border-beam.is-lit{animation:nextBeamFade 3.2s ease-out forwards}
.next__border-beam.is-lit span::before{
  animation:nextBeamSpin 3.2s cubic-bezier(.45,.05,.55,.95) forwards}

@keyframes nextBeamSpin{
  to{transform:translate(-50%,-50%) rotate(360deg)}}
@keyframes nextBeamFade{
  0%{opacity:0}5%{opacity:1}84%{opacity:1}100%{opacity:0}}

/* Linha verde brilhante no topo do card */
.next__inner::before{
  content:"";position:absolute;top:0;left:10%;right:10%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(34,197,94,.55) 50%,transparent);
  pointer-events:none}
/* Brilho radial verde suave no fundo */
.next__inner::after{
  content:"";position:absolute;bottom:-60%;left:50%;transform:translateX(-50%);
  width:80%;height:200px;
  background:radial-gradient(ellipse,rgba(34,197,94,.08),transparent 70%);
  pointer-events:none;z-index:0}
.next__inner > *:not(.next__border-beam){position:relative;z-index:1}
.next__title{font-size:clamp(1.9rem,4.6vw,3.6rem);color:#fff;margin:0 0 1.2rem}
.next__title em{color:var(--red);background:linear-gradient(180deg,#fff,var(--red-bright));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.next__text{font-size:clamp(1.05rem,1.6vw,1.3rem);color:var(--fog);margin:0 0 2.4rem;max-width:44ch}
.next__micro{margin:1.4rem 0 0;font-size:.82rem;letter-spacing:.06em;color:var(--fog-2)}

/* ============================================================
   FINALE
   ============================================================ */
.finale{position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;overflow:hidden;
  padding-block:clamp(80px,14vh,160px)}
.finale__bg{position:absolute;inset:0;z-index:-2}
.finale__bg img{width:100%;height:100%;object-fit:cover;object-position:center 26%;filter:grayscale(.5) brightness(.32) contrast(1.05)}
.finale::before{content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(60% 60% at 50% 45%,rgba(227,6,19,.18),transparent 60%),linear-gradient(180deg,var(--ink),rgba(10,11,13,.7) 40%,var(--ink))}
.finale__stage{display:flex;flex-direction:column;align-items:center;text-align:center;gap:clamp(2.4rem,6vh,5rem)}
.finale__line{opacity:0;transform:translateY(40px);transition:opacity 1s var(--ease-out),transform 1s var(--ease-out)}
.finale__line.is-visible{opacity:1;transform:none}
.finale__kicker{display:block;margin-bottom:1.2rem;font-size:.8rem;letter-spacing:.24em;text-transform:uppercase;color:var(--silver)}
.finale__word{display:inline-flex;align-items:center;gap:1rem;font-family:var(--font-impact);text-transform:uppercase;
  font-size:clamp(3rem,12vw,9rem);line-height:.92;color:#fff}
.finale__word .finale__ico{color:var(--silver);flex:none}
.finale__word--accent span{background:linear-gradient(180deg,#fff,var(--red-bright));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.finale__reveal{position:relative;width:min(360px,76vw);aspect-ratio:9/12;margin:0 auto 1.4rem;border-radius:20px;overflow:hidden;
  border:1px solid var(--line-2);box-shadow:0 40px 90px -40px #000,0 0 60px -20px var(--red-glow)}
.finale__video{width:100%;height:100%;object-fit:cover;background:#0c0d10}
.finale__reveal-glow{position:absolute;inset:0;pointer-events:none;box-shadow:inset 0 0 80px rgba(0,0,0,.6)}
.finale__final{display:flex;flex-direction:column;align-items:center;gap:2rem}
.finale__headline{font-size:clamp(2.2rem,6vw,5rem);color:#fff;line-height:1.04}
.finale__headline em{background:linear-gradient(180deg,#fff,var(--red-bright));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{border-top:1px solid var(--line);padding-block:clamp(36px,6vw,60px) 40px;background:var(--ink-1)}
.site-footer__inner{display:flex;align-items:center;justify-content:space-between;gap:1.4rem;flex-wrap:wrap;margin-bottom:1.6rem}
.site-footer__tag{font-family:var(--font-display);font-weight:600;letter-spacing:.04em;color:var(--fog);margin:0}
.site-footer__wa{display:inline-flex;align-items:center;gap:.5rem;color:var(--white);font-weight:600;
  padding:.6rem 1.1rem;border-radius:999px;border:1px solid var(--line-2);transition:.3s var(--ease)}
.site-footer__wa:hover{background:rgba(255,255,255,.06);transform:translateY(-2px)}
.site-footer__legal{font-size:.76rem;color:var(--fog-2);max-width:80ch}

/* ---------- Hero stats ---------- */
.hero__stats{display:flex;flex-wrap:wrap;gap:clamp(1.4rem,4vw,3rem);margin-top:1.7rem;padding-top:1.4rem;border-top:1px solid var(--line)}
.hero__stats li{display:flex;flex-direction:column;gap:.25rem}
.hero__stat-num{font-family:var(--font-display);font-weight:800;font-size:clamp(1.7rem,3vw,2.4rem);line-height:1;color:#fff;
  background:linear-gradient(180deg,#fff,var(--silver));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero__stats li:first-child .hero__stat-num{background:linear-gradient(180deg,#fff,var(--red-bright));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero__stat-label{font-size:.78rem;letter-spacing:.04em;color:var(--fog)}

/* ---------- Pull quote ---------- */
.pquote{margin:clamp(3rem,7vw,5rem) auto 0;max-width:58ch;text-align:center;border:0;padding:0}
.pquote p{font-family:var(--font-display);font-weight:600;font-style:italic;font-size:clamp(1.3rem,2.6vw,2rem);color:#fff;line-height:1.3;margin:0}
.pquote cite{display:block;margin-top:1rem;font-style:normal;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--red-bright)}

/* ---------- Scroll cue (tem mais abaixo) ---------- */
.scrollcue{
  display:flex;flex-direction:column;align-items:center;gap:13px;
  width:max-content;margin:clamp(2.6rem,6vh,4.6rem) auto clamp(.5rem,2vh,1.5rem);
  text-decoration:none;cursor:pointer;-webkit-tap-highlight-color:transparent}
.scrollcue__label{
  font-size:.7rem;font-weight:600;letter-spacing:.3em;text-transform:uppercase;
  color:var(--silver);opacity:.75;transition:opacity .3s,letter-spacing .3s}
.scrollcue:hover .scrollcue__label{opacity:1;color:var(--white);letter-spacing:.34em}
.scrollcue__track{
  position:relative;width:2px;height:56px;border-radius:2px;overflow:hidden;
  background:linear-gradient(180deg,rgba(255,255,255,.16),rgba(255,255,255,.03))}
.scrollcue__dot{
  position:absolute;left:50%;top:0;transform:translateX(-50%);
  width:2px;height:20px;border-radius:2px;
  background:linear-gradient(180deg,transparent,#1a64ff 35%,#ffffff 55%,var(--red-bright) 80%);
  box-shadow:0 0 12px var(--red-glow);
  animation:cueFlow 1.9s cubic-bezier(.5,.05,.5,.95) infinite}
@keyframes cueFlow{
  0%{top:-22px;opacity:0}
  20%{opacity:1}
  80%{opacity:1}
  100%{top:56px;opacity:0}}
.scrollcue__chev{
  color:var(--silver);margin-top:-2px;
  animation:cueBounce 1.9s ease-in-out infinite}
.scrollcue:hover .scrollcue__chev{color:var(--red-bright)}
@keyframes cueBounce{
  0%,100%{transform:translateY(0);opacity:.5}
  50%{transform:translateY(6px);opacity:1}}

/* ---------- Features (plataforma) ---------- */
.features-block{margin-top:clamp(4rem,9vw,7rem)}
.features-block__head{text-align:center;max-width:60ch;margin:0 auto clamp(2.4rem,5vw,3.6rem)}
.features-block__title{font-family:var(--font-display);font-weight:800;letter-spacing:-.02em;font-size:clamp(1.7rem,3.4vw,2.8rem);color:#fff;margin:0}
.features-block__sub{color:var(--fog);margin:1rem 0 0}
.features{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(12px,1.4vw,18px)}
.feature{padding:clamp(1.2rem,2vw,1.6rem);border-radius:16px;background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.015));
  border:1px solid var(--line);transition:transform .4s var(--ease),border-color .4s,background .4s}
.feature:hover{transform:translateY(-4px);border-color:rgba(227,6,19,.4);background:linear-gradient(180deg,rgba(227,6,19,.06),rgba(255,255,255,.02))}
.feature__icon{display:inline-grid;place-items:center;width:44px;height:44px;border-radius:12px;color:var(--red-bright);
  background:rgba(227,6,19,.08);border:1px solid rgba(227,6,19,.25);margin-bottom:1rem}
.feature__title{font-size:1.05rem;color:#fff;margin:0 0 .4rem}
.feature__text{font-size:.9rem;color:var(--fog);margin:0;line-height:1.5}

/* ---------- Decision kicker ---------- */
.decision__kicker{font-family:var(--font-display);font-weight:600;text-transform:uppercase;letter-spacing:.1em;
  font-size:clamp(.82rem,1.6vw,1.02rem);color:var(--silver);max-width:34ch;margin:0 auto 1.4rem}

/* ---------- Instructor role ---------- */
.instructor__role{font-family:var(--font-display);font-weight:600;letter-spacing:.01em;color:var(--red-bright);
  margin:.5rem 0 0;font-size:clamp(.95rem,1.5vw,1.12rem)}

/* ---------- Next benefits ---------- */
.next__benefits{display:flex;flex-wrap:wrap;justify-content:center;gap:.8rem 1.6rem;margin:0 0 2.2rem;padding:0}
.next__benefits li{display:inline-flex;align-items:center;gap:.5rem;font-size:.92rem;font-weight:500;color:var(--cream)}
.next__benefits svg{color:var(--red-bright);flex:none}

/* ---------- Footer (redesign) ---------- */
.site-footer__top{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(2rem,5vw,4rem);margin-bottom:2.4rem}
.site-footer__brandcol{max-width:46ch}
.site-footer__desc{color:var(--fog);margin:1.1rem 0 .8rem;line-height:1.7}
.site-footer__desc strong,.site-footer__desc b{color:var(--white)}
.site-footer__contact h3{font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;color:var(--silver);margin:0 0 1rem}
.site-footer__contact{display:flex;flex-direction:column;gap:.7rem}
.site-footer__contact a,.site-footer__contact span{color:var(--cream);font-weight:500;transition:color .3s var(--ease)}
.site-footer__contact a:hover{color:#fff}
.site-footer__contact span{color:var(--fog);font-weight:400}

/* ============================================================
   CAMADA CINEMATOGRÁFICA / STORYTELLING
   ============================================================ */

/* Arco emocional de cor — frio (sonho) → quente (conquista) */
.arc{position:fixed;inset:0;z-index:2;pointer-events:none;mix-blend-mode:soft-light;opacity:0;will-change:opacity}
.arc--cool{background:radial-gradient(80% 60% at 50% 14%,#4a7fbe,transparent 70%)}
.arc--warm{background:radial-gradient(86% 66% at 50% 86%,#ff222e,transparent 72%)}

/* HUD tático — molduras de canto */
.hud{position:fixed;inset:0;z-index:95;pointer-events:none}
.hud__corner{position:absolute;width:22px;height:22px;border:1.5px solid rgba(200,205,211,.26);opacity:0;animation:hudIn 1s var(--ease-out) 1.7s forwards}
.hud__corner--tl{top:16px;left:16px;border-right:0;border-bottom:0}
.hud__corner--tr{top:16px;right:16px;border-left:0;border-bottom:0}
.hud__corner--bl{bottom:16px;left:16px;border-right:0;border-top:0}
.hud__corner--br{bottom:16px;right:16px;border-left:0;border-top:0}
@keyframes hudIn{to{opacity:1}}

/* Timeline — leitura de fase (missão) */
.timeline__mission{position:absolute;bottom:calc(100% + 18px);left:2px;display:flex;flex-direction:column;gap:2px;white-space:nowrap}
.timeline__phase{font-family:var(--font-display);font-weight:700;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--red-bright);transition:color .4s}
.timeline__of{font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;color:var(--fog-2)}

/* Timeline — pulso ao ativar + rastro do cometa */
.timeline__item.is-active .timeline__dot{animation:dotPulse 1.8s var(--ease) infinite}
@keyframes dotPulse{0%,100%{box-shadow:0 0 0 4px rgba(227,6,19,.16),0 0 16px var(--red-glow)}50%{box-shadow:0 0 0 7px rgba(227,6,19,.05),0 0 24px var(--red-glow)}}
.timeline__comet::after{content:"";position:absolute;left:50%;top:0;width:3px;height:30px;transform:translate(-50%,-100%);
  background:linear-gradient(to top,var(--red-bright),transparent);border-radius:3px;opacity:.7}

/* Mosaico de alunos (bigword DISCIPLINA) */
.bigword--mosaic{overflow:hidden}
.mosaic{position:absolute;inset:0;z-index:0;display:grid;grid-template-columns:repeat(6,1fr);grid-template-rows:repeat(2,1fr);gap:3px}
.mosaic img{width:100%;height:100%;object-fit:cover;object-position:center 20%;filter:saturate(.7) brightness(.55);transition:filter .6s}
.bigword--mosaic:hover .mosaic img{filter:saturate(.85) brightness(.45)}
.mosaic__overlay{position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(65% 50% at 50% 50%,rgba(10,11,13,.3) 0%,rgba(10,11,13,.88) 100%),
    linear-gradient(180deg,rgba(10,11,13,.85) 0%,rgba(10,11,13,.45) 25%,rgba(10,11,13,.45) 75%,rgba(10,11,13,.85) 100%)}
.bigword--mosaic .bigword__text{position:relative;z-index:2;
  background:linear-gradient(180deg,#ffffff 0%,#e2e8f0 60%,#94a3b8 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  -webkit-text-stroke:0;filter:drop-shadow(0 0 30px rgba(255,255,255,.35)) drop-shadow(0 4px 24px rgba(0,0,0,1))}
.bigword--mosaic .bigword__sub{position:relative;z-index:2;
  color:#fff;font-weight:600;letter-spacing:.04em;
  text-shadow:0 2px 20px rgba(0,0,0,1),0 0 40px rgba(0,0,0,.9)}

/* ============================================================
   SCROLL HINT — "ROLE PARA DESCOBRIR" fixo na página inteira
   ============================================================ */
.scroll-hint{
  position:fixed;bottom:32px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:10px;
  pointer-events:none;z-index:90;
  transition:opacity .6s ease,transform .6s ease}
.scroll-hint.is-hidden{opacity:0;transform:translateX(-50%) translateY(12px)}

.scroll-hint__label{
  font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;
  color:rgba(255,255,255,.45);font-family:var(--font-body);
  text-shadow:0 1px 8px rgba(0,0,0,.8)}

/* Mouse outline */
.scroll-hint__mouse{
  width:24px;height:38px;
  border:1.5px solid rgba(255,255,255,.35);
  border-radius:12px;
  position:relative;
  box-shadow:0 0 14px rgba(255,255,255,.06)}

/* Scroll wheel — dot que desce */
.scroll-hint__mouse::before{
  content:"";
  position:absolute;top:6px;left:50%;
  transform:translateX(-50%);
  width:3px;height:7px;
  background:rgba(255,255,255,.65);
  border-radius:2px;
  animation:mouseWheel 1.8s ease-in-out infinite}

@keyframes mouseWheel{
  0%  {top:6px;opacity:1}
  80% {top:20px;opacity:0}
  100%{top:6px;opacity:0}}

/* Fade bottom em cada seção — indica mais conteúdo abaixo */
.section::after{
  content:"";position:absolute;bottom:0;left:0;right:0;height:100px;
  background:linear-gradient(to bottom,transparent,rgba(10,11,13,.75));
  pointer-events:none;z-index:1}
.decision::after,.instructor::after{display:none}

/* Palavras gigantes — stamp de impacto ao centralizar */
.bigword.is-stamped .bigword__text{animation:stamp .7s var(--ease-out)}
@keyframes stamp{0%{filter:brightness(2.3);letter-spacing:.05em}55%{filter:brightness(1.12)}100%{filter:brightness(1);letter-spacing:.005em}}

/* Reveal por clip-wipe (imagens cinematográficas) */
.wipe{clip-path:inset(0 0 100% 0);opacity:.35;transition:clip-path 1.1s var(--ease-out),opacity .7s ease}
.wipe.is-visible{clip-path:inset(0 0 0 0);opacity:1}

/* CTAs magnéticos + tilt de cards */
.btn[data-magnetic]{transition:transform .22s var(--ease-out),box-shadow .35s var(--ease),background .35s var(--ease)}
.feature[data-tilt]{transform-style:preserve-3d;will-change:transform}
.hero__stat-num{font-variant-numeric:tabular-nums}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1180px){
  .timeline{display:none}
}
@media (max-width:980px){
  .features{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:700px){
  .hud{display:none}
}
@media (max-width:860px){
  .instructor__grid{grid-template-columns:1fr;gap:2rem}
  .instructor__photo{position:relative;top:auto;max-width:440px}
  .site-footer__top{grid-template-columns:1fr;gap:2rem}
  .step{grid-template-columns:54px minmax(0,1fr);gap:1rem 1.2rem}
  .steps::before,.steps::after{left:26px}
  .step__shot{grid-column:1 / -1;margin-top:1.2rem;margin-left:54px}
  .pcard{width:236px;height:180px}
  .pcard--wide{width:236px}
}
@media (max-width:560px){
  :root{--section-y:clamp(42px,6.5vh,72px)}
  .hero{align-items:flex-end}
  .hero__cta{width:100%}
  .hero__cta .btn{flex:1 1 auto}
  .step__shot{margin-left:0}
  .step{grid-template-columns:40px minmax(0,1fr)}
  .steps::before,.steps::after{left:19px}
  .features{grid-template-columns:1fr}
  .hero__stats{gap:1.2rem 2rem}
  .hero__stat-num{font-size:1.5rem}
}

/* ============================================================
   MOBILE — afinação dedicada (80% do tráfego é mobile)
   ============================================================ */
@media (max-width:768px){
  :root{
    --pad:clamp(18px,5.2vw,30px);
    --section-y:clamp(42px,6.5vh,72px);
  }
  html{scroll-padding-top:70px}
  a,button,.btn,.pcard{-webkit-tap-highlight-color:transparent}

  /* Botões mais enxutos no mobile (alvo de toque ~48px) */
  .btn--lg{padding:.82rem 1.2rem;font-size:.92rem;min-height:48px}
  .btn--xl{padding:.9rem 1.3rem;font-size:.95rem;min-height:50px}
  .btn svg{width:16px;height:16px}
  /* CTAs em largura total dentro de blocos centrados */
  .next .btn,.decision .btn,.finale .btn,.instructor__content .btn{
    width:100%;max-width:340px;justify-content:center}

  /* Tipografia das seções */
  .h2{font-size:clamp(1.95rem,7.4vw,2.7rem);max-width:none}
  .method__head .h2{font-size:clamp(1.5rem,1.8vw,1.6rem)!important}
  .lead{font-size:1.04rem;max-width:none}
  .eyebrow{margin-bottom:1rem;font-size:.72rem;letter-spacing:.18em}

  /* HERO */
  .hero__eyebrow-line{margin-bottom:1.1rem}
  .hero__title{font-size:clamp(1.3rem,6vw,2.7rem)}
  .hero__accent{font-size:clamp(1.15rem,5vw,2.3rem);margin-bottom:1.4rem}
  .hero__sub{font-size:1.02rem;max-width:none;margin-bottom:1.8rem}

  /* BIGWORDS (siren mantém regra própria via :not) */
  .bigword{min-height:auto;padding-block:clamp(54px,11vh,88px)}
  .bigword__text:not(.bigword__text--siren){font-size:clamp(3.2rem,19vw,7rem)}
  .bigword__sub{font-size:1.04rem}
  /* Encurta o vão entre "Quem conseguiu" e "O SONHO É SEU" no mobile */
  .proof{padding-bottom:clamp(28px,5vh,52px)}
  #sua-vez{padding-top:clamp(36px,7vh,60px)}

  /* PROVA SOCIAL — cards menores, scroll mais leve */
  .pcard{width:170px;height:130px;border-radius:12px}
  .pcard--wide{width:170px}
  .pcard__tag{font-size:.6rem;padding:.3rem .56rem;left:9px;bottom:9px}

  /* PREPARAÇÃO */
  .step__title{font-size:clamp(1.35rem,5.6vw,1.8rem)}
  .step__text{max-width:none}
  .step__icon{width:44px;height:44px}

  /* INSTRUTOR */
  .instructor__photo{max-width:360px;margin-inline:auto}
  .instructor__content{max-width:none}
  .instructor__bio{font-size:1.05rem}

  /* PRÓXIMO PASSO */
  .next__inner{border-radius:22px;padding:2rem 1.35rem}
  .next__border-beam,.next__border-beam span{border-radius:22px}
  .next__title{font-size:clamp(1.8rem,7.4vw,2.5rem)}
  .next__text{font-size:1.04rem;max-width:none}
  .next__benefits{flex-direction:column;align-items:center;gap:.7rem}

  /* DECISÃO / FINALE */
  .decision__title{font-size:clamp(1.9rem,8vw,3rem)}
  .decision__sub{font-size:clamp(1.3rem,5.4vw,1.9rem)}
  .finale__word{font-size:clamp(2.8rem,15vw,6rem);gap:.6rem}
  .finale__headline{font-size:clamp(2rem,8vw,3.4rem)}

  /* FOOTER */
  .site-footer__inner{justify-content:center;text-align:center}
  .site-footer__legal{text-align:center}

  /* SCROLL HINT discreto */
  .scroll-hint{bottom:18px;gap:7px}
  .scroll-hint__label{font-size:.55rem;letter-spacing:.26em}
  .scroll-hint__mouse{width:21px;height:33px}
}

@media (max-width:430px){
  .hero__cta{flex-direction:column;width:100%}
  .hero__cta .btn{width:100%}
  /* Texto longo do CTA cabe sem apertar */
  .btn--lg,.btn--xl{padding:.8rem 1rem;font-size:.86rem;letter-spacing:.005em;gap:.45em}
  .btn svg{width:15px;height:15px}
  .pcard{width:150px;height:115px}
  .pcard--wide{width:150px}
  .bigword__text:not(.bigword__text--siren){font-size:clamp(2.8rem,20vw,5.5rem)}
  .next__inner{padding:1.8rem 1.15rem}
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
  .btn--primary{animation:none !important}
  .hero__img{animation:none;transform:scale(1.04)}
  .marquee__track{animation:none;transform:none;flex-wrap:wrap;justify-content:center}
  .reveal,.finale__line{opacity:1;transform:none}
  .hero__scroll-line::after{animation:none}
}
