/* =========================================================
   Fábrica de Posts | LP Teste Grátis (SaaS de criativos com IA)
   Design: "control room generativo", ink indigo + gradiente
   violeta/coral + ação lime. Bricolage Grotesque / Inter / JetBrains.
   ========================================================= */

:root{
  /* Canvas */
  --ink:        #0B0D1A;   /* fundo principal */
  --ink-2:      #0E1124;   /* fundo alternado */
  --panel:      #14182E;   /* cards */
  --panel-2:    #1A2040;   /* hover / card elevado */
  --line:       rgba(168,150,255,0.14);
  --line-2:     rgba(168,150,255,0.30);

  /* Acentos generativos */
  --violet:     #B98CFF;
  --violet-deep:#7C5CFF;
  --magenta:    #E26AC4;
  --coral:      #FF7A6B;
  --lime:       #C6FF4F;   /* ação primária */
  --lime-deep:  #A8E62E;

  /* Texto */
  --t1: #F4F2FF;   /* primário */
  --t2: #B9B6D4;   /* secundário */
  --t3: #7C7AA0;   /* muted */
  --on-lime: #0B0D1A;

  /* Gradiente assinatura */
  --grad: linear-gradient(105deg, var(--violet) 0%, var(--magenta) 48%, var(--coral) 100%);
  --grad-soft: linear-gradient(135deg, rgba(124,92,255,0.16), rgba(255,122,107,0.10));

  --font-display: "Bricolage Grotesque", "Inter", system-ui, sans-serif;
  --font-body: "Inter", system-ui, -apple-system, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, monospace;

  --maxw: 1180px;
  --radius: 18px;
  --radius-sm: 12px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{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(--t1);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ---------- Tipografia utilitária ---------- */
.grad{
  background:var(--grad);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}

.sec__label{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--font-mono);font-size:.74rem;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;color:var(--violet);
  margin-bottom:18px;
}
.sec__label::before{
  content:"";width:30px;height:2px;background:var(--grad);border-radius:2px;
  transform-origin:left center;transform:scaleX(0);
  transition:transform .9s var(--ease) .15s;
}
.is-visible .sec__label::before,
body.loaded .sec__label::before{transform:scaleX(1)}

.sec-head{max-width:720px;margin-bottom:54px}
.sec__title{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(1.7rem,4.4vw,2.85rem);line-height:1.08;
  letter-spacing:-0.02em;color:var(--t1);
}
.sec__lead{margin-top:18px;font-size:clamp(1rem,1.6vw,1.18rem);color:var(--t2);max-width:60ch}
.sec__note{margin-top:14px;font-family:var(--font-mono);font-size:.78rem;color:var(--t3);letter-spacing:.02em}

/* ---------- Botões ---------- */
.btn{
  --pad-y:14px;--pad-x:26px;
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--font-display);font-weight:600;font-size:1rem;
  padding:var(--pad-y) var(--pad-x);border-radius:999px;
  cursor:pointer;border:1px solid transparent;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .3s, border-color .3s, color .3s;
  overflow:hidden;isolation:isolate;white-space:nowrap;
  min-height:46px;
}
.btn::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(110deg, transparent 30%, rgba(255,255,255,.32) 50%, transparent 70%);
  transform:translateX(-130%);transition:transform .8s var(--ease);
}
.btn:hover::before{transform:translateX(130%)}
.btn--primary{
  background:var(--lime);color:var(--on-lime);
  box-shadow:0 8px 26px rgba(168,230,46,.28), inset 0 0 0 1px rgba(255,255,255,.18);
}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 14px 36px rgba(168,230,46,.42)}
.btn--ghost{
  background:rgba(255,255,255,.03);color:var(--t1);
  border-color:var(--line-2);backdrop-filter:blur(6px);
}
.btn--ghost:hover{transform:translateY(-2px);border-color:var(--violet);background:rgba(124,92,255,.10)}
.btn--sm{--pad-y:10px;--pad-x:18px;font-size:.9rem;min-height:40px}
.btn--lg{--pad-y:16px;--pad-x:32px;font-size:1.06rem;min-height:54px}
.btn--xl{--pad-y:19px;--pad-x:40px;font-size:1.14rem;min-height:60px}

/* ---------- Pill / tag ---------- */
.pill{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-mono);font-size:.8rem;font-weight:500;letter-spacing:.02em;
  color:var(--t1);background:rgba(124,92,255,.12);
  border:1px solid var(--line-2);padding:8px 16px;border-radius:999px;
  margin-bottom:26px;
}
.pill__dot{width:8px;height:8px;border-radius:50%;background:var(--lime);box-shadow:0 0 0 0 rgba(198,255,79,.5);animation:pulseDot 2.4s ease-in-out infinite}
@keyframes pulseDot{0%,100%{box-shadow:0 0 8px var(--lime),0 0 0 0 rgba(198,255,79,.45)}50%{box-shadow:0 0 12px var(--lime),0 0 0 8px rgba(198,255,79,0)}}

/* =========================================================
   TOPBAR
   ========================================================= */
.topbar{
  position:fixed;top:0;left:0;right:0;z-index:100;
  transition:background .4s, box-shadow .4s, border-color .4s;
  border-bottom:1px solid transparent;
}
.topbar.is-scrolled{
  background:rgba(11,13,26,.86);backdrop-filter:blur(14px);
  border-color:var(--line);box-shadow:0 6px 30px rgba(0,0,0,.4);
}
.topbar__inner{display:flex;align-items:center;justify-content:space-between;height:72px;gap:20px}
.brand{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:700;font-size:1.12rem;color:var(--t1)}
.brand__mark{width:30px;height:30px;display:grid;place-items:center;color:var(--violet)}
.brand__mark svg{width:30px;height:30px}
.topbar__nav{display:flex;gap:30px}
.topbar__nav a{font-size:.94rem;color:var(--t2);transition:color .25s;position:relative}
.topbar__nav a:hover{color:var(--t1)}
.topbar__nav a::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:2px;background:var(--grad);transition:width .3s var(--ease)}
.topbar__nav a:hover::after{width:100%}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;padding:150px 0 90px;overflow:clip;isolation:isolate;contain:layout paint}
.hero__bg{
  position:absolute;inset:0;z-index:-2;
  background-image:
    radial-gradient(900px 600px at 78% 42%, rgba(124,92,255,.16), transparent 60%),
    url('./assets/bg/hero.webp'),
    linear-gradient(var(--ink), var(--ink));
  background-repeat:no-repeat,no-repeat,no-repeat;
  background-position:center, center right, center;
  background-size:auto, cover, cover;
  opacity:.9;
  animation:kenBurns 30s ease-in-out infinite;
}
.hero::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(90deg, var(--ink) 8%, rgba(11,13,26,.78) 38%, rgba(11,13,26,.30) 62%, transparent 100%),
             linear-gradient(180deg, transparent 60%, var(--ink) 100%);
}
@keyframes kenBurns{
  0%{background-size:auto, cover, cover}
  50%{background-size:auto, 112% auto, cover}
  100%{background-size:auto, cover, cover}
}

.hero__inner{display:grid;grid-template-columns:1.06fr .94fr;gap:54px;align-items:center}
.hero__title{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(2.3rem,5.6vw,4.1rem);line-height:1.02;
  letter-spacing:-0.03em;color:var(--t1);margin-bottom:24px;
}
.hero__sub{font-size:clamp(1.05rem,1.8vw,1.26rem);color:var(--t2);max-width:54ch;margin-bottom:34px}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:46px}
.hero__stats{display:flex;flex-wrap:wrap;gap:14px 38px}
.hero__stats li{display:flex;flex-direction:column}
.hero__stats strong{font-family:var(--font-display);font-weight:700;font-size:1.7rem;color:var(--t1);line-height:1}
.hero__stats span{font-size:.86rem;color:var(--t3);margin-top:6px;max-width:18ch}

.hero__scroll{
  position:absolute;bottom:26px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:.62rem;text-transform:uppercase;letter-spacing:.28em;color:var(--t3);
  animation:scrollHint 2.8s ease-in-out infinite;
}
.hero__scroll svg{width:18px;height:18px}
@keyframes scrollHint{0%,100%{transform:translateX(-50%) translateY(0);opacity:.55}50%{transform:translateX(-50%) translateY(6px);opacity:.9}}

/* ---------- Signature: studio mockup ---------- */
.hero__demo{display:flex;justify-content:center}
.studio{
  width:100%;max-width:430px;
  background:linear-gradient(180deg, var(--panel), var(--ink-2));
  border:1px solid var(--line-2);border-radius:var(--radius);
  box-shadow:0 30px 70px rgba(0,0,0,.5), 0 0 0 1px rgba(124,92,255,.06);
  overflow:clip;contain:layout paint;
}
.studio__head{display:flex;align-items:center;gap:8px;padding:14px 18px;border-bottom:1px solid var(--line);background:rgba(255,255,255,.02)}
.studio__dot{width:11px;height:11px;border-radius:50%;background:var(--line-2)}
.studio__dot:nth-child(1){background:var(--coral)}
.studio__dot:nth-child(2){background:var(--magenta)}
.studio__dot:nth-child(3){background:var(--violet)}
.studio__title{margin-left:8px;font-family:var(--font-mono);font-size:.72rem;color:var(--t3);letter-spacing:.04em}
.studio__body{padding:22px 20px 26px}
.studio__inputs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.chip{
  font-family:var(--font-mono);font-size:.72rem;color:var(--t2);
  background:rgba(124,92,255,.10);border:1px solid var(--line);
  padding:6px 11px;border-radius:8px;
}
.chip--logo{color:var(--lime);border-color:rgba(198,255,79,.25);background:rgba(198,255,79,.06)}
.studio__arrow{display:flex;align-items:center;justify-content:center;gap:10px;margin:6px 0 18px;color:var(--violet)}
.studio__arrow svg{width:22px;height:22px}
.studio__gen{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--lime);position:relative}
.studio__gen::after{content:"";animation:dots 1.6s steps(4,end) infinite}
@keyframes dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}100%{content:""}}
.studio__out{display:flex;justify-content:center}
.studio__post{
  width:100%;background:var(--ink);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:14px;
}
.studio__post-img{
  position:relative;aspect-ratio:1/1;border-radius:10px;overflow:clip;margin-bottom:0;
  background:linear-gradient(135deg, var(--violet-deep), var(--magenta) 55%, var(--coral));
  contain:layout paint;
}
.studio__post-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.studio__shine{position:absolute;inset:0;background:linear-gradient(115deg,transparent 40%,rgba(255,255,255,.22) 50%,transparent 60%) no-repeat;background-size:300% 100%;background-position:200% 0;animation:shine 3.4s var(--ease) infinite}
@keyframes shine{0%,60%{background-position:200% 0}100%{background-position:-100% 0}}
.studio__post-line{height:10px;border-radius:6px;background:rgba(255,255,255,.12);margin-bottom:9px}
.studio__post-line--lg{width:70%;height:13px;background:rgba(255,255,255,.20)}
.studio__post-line:not(.studio__post-line--lg){width:90%}
.studio__post-cta{
  margin-top:12px;display:inline-block;font-family:var(--font-display);font-weight:600;font-size:.84rem;
  color:var(--on-lime);background:var(--lime);padding:7px 16px;border-radius:8px;
}

/* =========================================================
   PROBLEMA
   ========================================================= */
.problem{padding:96px 0;background:var(--ink-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.problem__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.problem__card{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:32px 28px;transition:transform .45s var(--ease),border-color .35s,box-shadow .45s,background .35s;
}
.problem__card:hover{transform:translateY(-6px);border-color:var(--line-2);box-shadow:0 18px 44px rgba(0,0,0,.4)}
.problem__icon{display:grid;place-items:center;width:52px;height:52px;border-radius:14px;background:var(--grad-soft);border:1px solid var(--line);margin-bottom:20px;color:var(--coral)}
.problem__icon svg{width:26px;height:26px}
.problem__card h3{font-family:var(--font-display);font-weight:700;font-size:1.22rem;margin-bottom:10px;color:var(--t1)}
.problem__card p{color:var(--t2);font-size:.98rem}

/* =========================================================
   COMO FUNCIONA
   ========================================================= */
.how{padding:104px 0}
.how__steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;counter-reset:none}
.how__step{
  position:relative;background:linear-gradient(180deg,var(--panel),var(--ink-2));
  border:1px solid var(--line);border-radius:var(--radius);padding:36px 30px 32px;
  transition:transform .45s var(--ease),border-color .35s,box-shadow .45s;
}
.how__step:hover{transform:translateY(-6px);border-color:var(--line-2);box-shadow:0 18px 44px rgba(0,0,0,.4)}
.how__num{
  position:absolute;top:24px;right:26px;
  font-family:var(--font-display);font-weight:800;font-size:3.6rem;line-height:1;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  opacity:.32;
}
.how__icon{display:grid;place-items:center;width:56px;height:56px;border-radius:16px;background:rgba(124,92,255,.12);border:1px solid var(--line-2);margin-bottom:22px;color:var(--violet)}
.how__icon svg{width:28px;height:28px;filter:drop-shadow(0 0 8px rgba(185,140,255,.35))}
.how__step h3{font-family:var(--font-display);font-weight:700;font-size:1.3rem;margin-bottom:10px}
.how__step p{color:var(--t2);font-size:.98rem;max-width:34ch}

/* =========================================================
   GALERIA / EXEMPLOS
   ========================================================= */
.gallery{padding:100px 0;background:var(--ink-2);border-top:1px solid var(--line)}
.gallery__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.gallery__item{transition:transform .45s var(--ease)}
.gallery__item:hover{transform:translateY(-6px)}
.gallery__media{
  position:relative;aspect-ratio:1/1;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);background:var(--panel);
  box-shadow:0 14px 40px rgba(0,0,0,.35);
}
.gallery__media::after{content:"";position:absolute;inset:0;border-radius:inherit;box-shadow:inset 0 0 0 1px rgba(255,255,255,.04);pointer-events:none}
.gallery__media img{width:100%;height:100%;object-fit:cover;opacity:1;transition:transform .6s var(--ease)}
.gallery__item:hover .gallery__media img{transform:scale(1.04)}
.gallery__item figcaption{
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  margin-top:14px;font-family:var(--font-display);font-weight:600;font-size:.96rem;color:var(--t1);
}
.gallery__tag{
  font-family:var(--font-mono);font-size:.68rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;
  color:var(--violet);background:rgba(124,92,255,.12);border:1px solid var(--line);
  padding:4px 10px;border-radius:7px;
}

/* =========================================================
   RECURSOS
   ========================================================= */
.features{padding:104px 0}
.features__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.feat{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 28px;transition:transform .45s var(--ease),border-color .35s,box-shadow .45s,background .35s;
}
.feat:hover{transform:translateY(-6px);border-color:var(--line-2);background:var(--panel-2);box-shadow:0 18px 44px rgba(0,0,0,.4)}
.feat__icon{display:grid;place-items:center;width:50px;height:50px;border-radius:14px;background:var(--grad-soft);border:1px solid var(--line);margin-bottom:20px;color:var(--lime)}
.feat__icon svg{width:25px;height:25px;filter:drop-shadow(0 0 8px rgba(198,255,79,.3))}
.feat h3{font-family:var(--font-display);font-weight:700;font-size:1.16rem;margin-bottom:9px}
.feat p{color:var(--t2);font-size:.96rem}

/* =========================================================
   PROVA SOCIAL
   ========================================================= */
.proof{padding:100px 0;background:var(--ink-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.proof__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.testimony{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 28px;display:flex;flex-direction:column;
  transition:transform .45s var(--ease),border-color .35s,box-shadow .45s;
}
.testimony:hover{transform:translateY(-6px);border-color:var(--line-2);box-shadow:0 18px 44px rgba(0,0,0,.4)}
.testimony__stars{display:flex;gap:3px;margin-bottom:16px}
.testimony__stars svg{width:18px;height:18px;fill:var(--lime)}
.testimony p{color:var(--t1);font-size:1.02rem;line-height:1.55;flex:1}
.testimony footer{display:flex;align-items:center;gap:12px;margin-top:22px;padding-top:18px;border-top:1px solid var(--line)}
.testimony__avatar{display:grid;place-items:center;width:42px;height:42px;border-radius:50%;background:var(--grad);color:var(--ink);font-family:var(--font-display);font-weight:700;font-size:1.1rem;flex-shrink:0}
.testimony footer span{display:flex;flex-direction:column;font-size:.86rem;color:var(--t3)}
.testimony footer strong{font-family:var(--font-display);font-weight:600;font-size:.98rem;color:var(--t1)}
.exemplo{display:inline-block;width:fit-content;margin-top:3px;font-family:var(--font-mono);font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;color:var(--coral);background:rgba(255,122,107,.10);border:1px solid rgba(255,122,107,.22);padding:1px 7px;border-radius:5px}

/* =========================================================
   TRIAL CTA
   ========================================================= */
.trial{padding:104px 0}
.trial__card{
  position:relative;overflow:hidden;
  background:
    radial-gradient(700px 360px at 18% 0%, rgba(124,92,255,.20), transparent 65%),
    radial-gradient(620px 320px at 92% 110%, rgba(255,122,107,.16), transparent 60%),
    var(--panel);
  border:1px solid var(--line-2);border-radius:28px;
  padding:60px clamp(28px,5vw,72px);text-align:center;
  box-shadow:0 30px 80px rgba(0,0,0,.45);
}
.trial__title{font-family:var(--font-display);font-weight:800;font-size:clamp(2rem,5vw,3.2rem);line-height:1.04;letter-spacing:-0.02em;margin:6px 0 16px}
.trial__sub{color:var(--t2);font-size:clamp(1rem,1.7vw,1.18rem);max-width:56ch;margin:0 auto 30px}
.trial__list{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 28px;margin-bottom:36px}
.trial__list li{display:inline-flex;align-items:center;gap:10px;font-size:.98rem;color:var(--t1)}
.trial__list svg{width:18px;height:18px;color:var(--lime);flex-shrink:0}
.trial__fine{margin-top:18px;font-family:var(--font-mono);font-size:.78rem;color:var(--t3)}

/* =========================================================
   FAQ
   ========================================================= */
.faq{padding:100px 0;background:var(--ink-2);border-top:1px solid var(--line)}
.faq__wrap{max-width:820px}
.faq__list{display:flex;flex-direction:column;gap:14px}
.faq__item{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-sm);
  overflow:hidden;transition:border-color .3s,background .3s;
}
.faq__item[open]{border-color:var(--line-2);background:var(--panel-2)}
.faq__item summary{
  list-style:none;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:22px 24px;font-family:var(--font-display);font-weight:600;font-size:1.06rem;color:var(--t1);
}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{
  content:"";flex-shrink:0;width:22px;height:22px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23B98CFF' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") center/contain no-repeat;
  transition:transform .35s var(--ease);
}
.faq__item[open] summary::after{transform:rotate(180deg)}
.faq__answer{padding:0 24px 24px}
.faq__answer p{color:var(--t2);font-size:1rem}
.faq__item[open] .faq__answer{animation:faqExpand .4s ease-out}
@keyframes faqExpand{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}

/* =========================================================
   CTA FINAL
   ========================================================= */
.final{padding:110px 0}
.final__inner{text-align:center;max-width:760px;margin:0 auto}
.final__title{font-family:var(--font-display);font-weight:800;font-size:clamp(2rem,5vw,3.1rem);line-height:1.05;letter-spacing:-0.02em;margin-bottom:16px}
.final__sub{color:var(--t2);font-size:clamp(1rem,1.7vw,1.18rem);margin-bottom:32px}
.final__tag{display:block;margin-top:18px;font-family:var(--font-mono);font-size:.8rem;color:var(--t3)}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{border-top:1px solid var(--line);padding:40px 0;background:var(--ink)}
.footer__inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.footer__brand{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:600;color:var(--t1)}
.footer__brand .brand__mark{color:var(--violet)}
.footer__by{font-family:var(--font-body);font-weight:400;color:var(--t3);font-size:.86rem}
.footer__meta{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.footer__copy{font-size:.84rem;color:var(--t3)}

/* =========================================================
   ANIMAÇÕES: default-visible, animation opt-in
   ========================================================= */
.reveal.fx-in{
  opacity:0;transform:translateY(28px);
  transition:opacity .9s var(--ease), transform .9s var(--ease);
  will-change:opacity,transform;
}
.reveal.fx-in.is-visible{opacity:1;transform:translateY(0)}
.reveal.fx-in.delay-1{transition-delay:.08s}
.reveal.fx-in.delay-2{transition-delay:.18s}
.reveal.fx-in.delay-3{transition-delay:.28s}
.reveal.fx-in.reveal--right{transform:translateX(40px) translateY(10px)}
.reveal.fx-in.reveal--right.is-visible{transform:none}

.word-reveal.fx-in > span{
  display:inline-block;opacity:0;
  transform:translateY(.5em) rotate(2deg);filter:blur(8px);
  transition:opacity .9s var(--ease), transform .9s var(--ease), filter .9s var(--ease);
}
.word-reveal.fx-in.is-visible > span{opacity:1;transform:none;filter:none}
.word-reveal.fx-in.is-visible > span:nth-child(1){transition-delay:.05s}
.word-reveal.fx-in.is-visible > span:nth-child(2){transition-delay:.11s}
.word-reveal.fx-in.is-visible > span:nth-child(3){transition-delay:.17s}
.word-reveal.fx-in.is-visible > span:nth-child(4){transition-delay:.23s}
.word-reveal.fx-in.is-visible > span:nth-child(5){transition-delay:.29s}
.word-reveal.fx-in.is-visible > span:nth-child(6){transition-delay:.35s}
.word-reveal.fx-in.is-visible > span:nth-child(7){transition-delay:.41s}
.word-reveal.fx-in.is-visible > span:nth-child(8){transition-delay:.47s}
.word-reveal.fx-in.is-visible > span:nth-child(9){transition-delay:.53s}
.word-reveal.fx-in.is-visible > span:nth-child(n+10){transition-delay:.59s}

/* =========================================================
   RESPONSIVO
   ========================================================= */
@media (max-width:980px){
  .hero{padding:128px 0 80px}
  .hero__inner{grid-template-columns:1fr;gap:44px}
  .hero__copy{order:1}
  .hero__demo{order:2}
  .hero::after{background:linear-gradient(180deg, rgba(11,13,26,.55) 0%, rgba(11,13,26,.86) 60%, var(--ink) 100%)}
  .hero__bg{background:radial-gradient(700px 500px at 70% 30%, rgba(124,92,255,.18), transparent 60%), url('./assets/bg/hero.webp') center / cover no-repeat, var(--ink)}
  .problem__grid,.how__steps,.gallery__grid,.features__grid,.proof__grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:760px){
  .topbar__nav{display:none}
  .topbar__inner{height:64px}
  .hero{padding:108px 0 70px}
  .hero__title{font-size:clamp(2rem,8.5vw,2.7rem)}
  .hero__stats{gap:18px 26px}
  .hero__scroll{display:none}
  .sec-head{margin-bottom:40px}
  .problem,.how,.gallery,.features,.proof,.trial,.faq,.final{padding:72px 0}
  .problem__grid,.how__steps,.gallery__grid,.features__grid,.proof__grid{grid-template-columns:1fr}
  .trial__card{padding:44px 24px}
  .footer__inner{flex-direction:column;align-items:flex-start;gap:20px}
}
@media (max-width:420px){
  .container{padding:0 18px}
  .hero__actions .btn{width:100%}
  .hero__stats{gap:16px 22px}
  .hero__stats li{min-width:42%}
}

/* Mobile: força visibilidade, defesa em profundidade */
@media (max-width:980px){
  .reveal,.reveal.fx-in{opacity:1 !important;transform:none !important;filter:none !important}
  .word-reveal,.word-reveal.fx-in > span{opacity:1 !important;transform:none !important;filter:none !important}
  .hero__bg,.studio__shine,.studio__post-img{animation:none !important}
  .sec__label::before{transform:scaleX(1) !important}
}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.01ms !important;transition-duration:.01ms !important;animation-iteration-count:1 !important}
  .reveal,.reveal.fx-in,.word-reveal.fx-in > span{opacity:1 !important;transform:none !important;filter:none !important}
  html{scroll-behavior:auto}
}

:focus-visible{outline:2px solid var(--lime);outline-offset:3px;border-radius:6px}
