/* =========================================================
   SONO SERENO — Landing de conversão
   Sistema cromático (Manual de Identidade):
   night #0B1437 · night-2 #111E4D · night-3 #1A2A63
   amber #F2B25C (ACENTO · só CTA/conversão) · cream #FBF7EF · moon #EAF0FF
   Tipografia: Fraunces (display) + Inter (corpo)
   ========================================================= */

:root{
  --night:#0B1437;
  --night-2:#111E4D;
  --night-3:#1A2A63;
  --line:#26356f;
  --amber:#F2B25C;
  --amber-deep:#E59A36;
  --cream:#FBF7EF;
  --moon:#EAF0FF;
  --moon-dim:#AEB8DC;
  --moon-faint:#7F8AB8;

  --ink:#16213f;            /* texto sobre creme */
  --ink-dim:#4a5578;

  --font-display:'Fraunces', Georgia, serif;
  --font-body:'Inter', system-ui, -apple-system, sans-serif;

  --maxw:1160px;
  --pad:clamp(1.25rem, 5vw, 2.5rem);
  --radius:20px;
  --radius-sm:12px;

  --ease:cubic-bezier(.22,.61,.36,1);
  --shadow-amber:0 18px 40px -14px rgba(242,178,92,.45);
  --shadow-soft:0 30px 60px -30px rgba(0,0,0,.65);
}

/* ------------------------- RESET ------------------------- */
*,*::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(--night);
  color:var(--moon);
  line-height:1.65;
  font-size:clamp(1rem,.96rem + .25vw,1.0625rem);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--amber);color:var(--night)}

.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}

/* compensa a navbar fixa nos saltos por âncora */
#vsl,#metodo,#provas,#oferta,#faq,#topo{scroll-margin-top:84px}

/* ------------------------- TYPE ------------------------- */
.eyebrow{
  font-family:var(--font-body);
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--moon-dim);
  margin-bottom:1.1rem;
}
.eyebrow em{font-family:var(--font-display);font-style:italic;font-weight:500;letter-spacing:0;text-transform:none;font-size:1.05em;color:var(--moon)}
.eyebrow--amber{color:var(--amber)}
.eyebrow--ink{color:var(--ink-dim)}
.eyebrow--ink em{color:var(--ink)}

.h2{
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(2rem,1.4rem + 2.6vw,3.4rem);
  line-height:1.08;
  letter-spacing:-.015em;
  color:var(--moon);
}
.h2 em,.hero__title em,.final__title em{
  font-style:italic;font-weight:500;color:var(--amber);
  /* margem p/ o overhang do glyph itálico não ser cortado no fim da linha */
  padding-right:.08em;margin-right:-.06em;
}
.h2--ink{color:var(--ink)}
.h2--ink em{color:var(--amber-deep)}
.h3{font-family:var(--font-display);font-weight:600;font-size:clamp(1.4rem,1.1rem + 1.1vw,1.9rem);line-height:1.15;letter-spacing:-.01em}
.h3--ink{color:var(--ink)}

.lede{
  font-size:clamp(1.05rem,1rem + .35vw,1.22rem);
  color:var(--moon-dim);
  max-width:60ch;
  margin-top:1.4rem;
}
.lede strong{color:var(--moon);font-weight:600}
.lede--ink{color:var(--ink-dim)}
.lede--ink strong{color:var(--ink)}

.kicker{font-size:.78rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--amber-deep);margin-bottom:.6rem}

/* ------------------------- BUTTONS ------------------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  font-weight:600;font-size:1rem;
  padding:.95rem 1.6rem;border-radius:999px;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .3s;
  white-space:nowrap;line-height:1;
  -webkit-tap-highlight-color:transparent;
}
.btn__arrow{transition:transform .35s var(--ease)}
.btn:hover .btn__arrow{transform:translateX(4px)}
.btn:focus-visible{outline:3px solid var(--amber);outline-offset:3px}

/* AMBER = único CTA de conversão (regra de ouro do manual) */
.btn--amber{
  background:linear-gradient(180deg,#F6C074,var(--amber) 55%,var(--amber-deep));
  color:#3a2608;
  box-shadow:var(--shadow-amber);
  position:relative;overflow:hidden;isolation:isolate;
}
.btn--amber:hover{transform:translateY(-3px);box-shadow:0 24px 50px -14px rgba(242,178,92,.6)}
/* brilho que varre o botão (disparado por scroll via .sheen-run, ou no hover) */
.btn--amber::before{
  content:'';position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.55) 50%,transparent 70%);
  transform:translateX(-130%);
}
.btn--amber.sheen-run::before{animation:sheen 1.1s var(--ease) .2s 1}
.btn--amber:hover::before{animation:sheen 1.1s var(--ease) 1}
@keyframes sheen{to{transform:translateX(130%)}}
.btn--ghost{
  background:rgba(234,240,255,.04);
  color:var(--moon);
  border:1px solid var(--line);
  backdrop-filter:blur(6px);
}
.btn--ghost:hover{background:rgba(234,240,255,.09);transform:translateY(-2px)}
.btn--lg{padding:1.1rem 1.9rem;font-size:1.05rem}
.btn--xl{padding:1.25rem 2.4rem;font-size:1.12rem}
.btn--block{display:flex;width:100%}

.link-amber{
  display:inline-flex;align-items:center;gap:.4rem;
  color:var(--amber-deep);font-weight:600;margin-top:1.4rem;
  border-bottom:1px solid transparent;transition:border-color .3s,gap .3s var(--ease);
}
.link-amber:hover{border-color:var(--amber-deep);gap:.7rem}

/* ------------------------- BARRA DE PROGRESSO ------------------------- */
.progress{
  position:fixed;top:0;left:0;right:0;z-index:110;
  height:3px;background:rgba(234,240,255,.06);
  pointer-events:none;
}
.progress__bar{
  display:block;height:100%;width:0;
  transform-origin:left center;
  background:linear-gradient(90deg,#F6C074,var(--amber) 60%,var(--amber-deep));
  box-shadow:0 0 12px rgba(242,178,92,.55);
  will-change:width;
}

/* ------------------------- NAVBAR ------------------------- */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.85rem var(--pad);
  transition:background .4s,backdrop-filter .4s,border-color .4s,padding .4s;
  border-bottom:1px solid transparent;
}
.nav.is-stuck{
  background:rgba(8,15,42,.82);
  backdrop-filter:blur(14px) saturate(140%);
  border-bottom-color:var(--line);
  padding-block:.65rem;
}
.nav__logo{height:34px;width:auto}
.nav__links{display:flex;gap:2rem}
.nav__links a{font-size:.92rem;font-weight:500;color:var(--moon-dim);transition:color .25s}
.nav__links a:hover{color:var(--moon)}
.nav__cta{padding:.7rem 1.25rem;font-size:.92rem}

/* ===================================================== */
/* 1 · HERO                                               */
/* ===================================================== */
.hero{
  position:relative;
  min-height:100svh;
  display:flex;align-items:center;
  padding:clamp(7rem,12vh,9rem) 0 clamp(3rem,8vh,5rem);
  overflow:hidden;
  background:var(--night);
}
/* base: foto completa do banner (banner.png) — simples, sem lua/recorte */
/* inset negativo no topo/base dá folga para o parallax sem revelar borda */
.hero__base{
  position:absolute;inset:-8% 0;z-index:0;will-change:transform;
  background:url('../img/banner.png') right center/cover no-repeat, var(--night);
}
/* véu de legibilidade: escurece a esquerda (texto) e funde topo/base ao fundo */
.hero__veil{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(90deg, var(--night) 4%, rgba(11,20,55,.82) 30%, rgba(11,20,55,.22) 58%, transparent 100%),
    linear-gradient(180deg, rgba(11,20,55,.45) 0%, transparent 22%, transparent 56%, rgba(8,13,35,.92) 100%);
}
.hero__inner{
  position:relative;z-index:4;
  width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad);
}
.hero__copy{max-width:38rem}
.hero__title{
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(2.9rem,2rem + 5.2vw,5.6rem);
  line-height:1.02;
  letter-spacing:-.025em;
  margin:.4rem 0 0;
}
.hero__sub{font-size:clamp(1.08rem,1rem + .5vw,1.3rem);color:var(--moon-dim);max-width:48ch;margin-top:1.6rem}
.hero__actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2.2rem}
.hero__trust{
  display:flex;align-items:center;flex-wrap:wrap;gap:.9rem;
  list-style:none;margin-top:2.4rem;
  font-size:.92rem;color:var(--moon-dim);
}
.hero__trust strong{color:var(--moon);font-weight:700}
.hero__trust .dot{width:4px;height:4px;border-radius:50%;background:var(--moon-faint)}

.hero__scroll{
  position:absolute;bottom:1.8rem;left:50%;transform:translateX(-50%);z-index:3;
  width:26px;height:42px;border:1.5px solid var(--moon-faint);border-radius:14px;
  display:flex;justify-content:center;padding-top:7px;
}
.hero__scroll span{width:3px;height:8px;border-radius:2px;background:var(--moon-dim);animation:scrolldot 1.8s var(--ease) infinite}
@keyframes scrolldot{0%{opacity:0;transform:translateY(-3px)}40%{opacity:1}80%,100%{opacity:0;transform:translateY(12px)}}

/* ===================================================== */
/* 2 · VSL / PROBLEMA                                     */
/* ===================================================== */
.vsl{background:var(--night-2);padding:clamp(4.5rem,10vh,7rem) 0;border-top:1px solid var(--line)}
.vsl__inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.vsl__head .lede{margin-top:1.6rem}
.vsl__player{
  position:relative;aspect-ratio:16/10;border-radius:var(--radius);
  background:
    linear-gradient(180deg, rgba(11,20,55,.2), rgba(11,20,55,.75)),
    url('../img/banner.png') center/cover no-repeat;
  border:1px solid var(--line);
  box-shadow:var(--shadow-soft);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.vsl__play{
  width:84px;height:84px;border-radius:50%;
  background:var(--amber);box-shadow:var(--shadow-amber);
  display:grid;place-items:center;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
}
.vsl__play::after{
  content:'';position:absolute;inset:-14px;border-radius:50%;
  border:1px solid rgba(242,178,92,.45);animation:pulse 2.6s ease-out infinite;
}
.vsl__playicon{width:0;height:0;border-left:22px solid #3a2608;border-top:13px solid transparent;border-bottom:13px solid transparent;margin-left:5px}
.vsl__play:hover{transform:scale(1.06)}
@keyframes pulse{0%{transform:scale(.9);opacity:.8}100%{transform:scale(1.35);opacity:0}}
.vsl__label{
  position:absolute;bottom:1rem;left:1rem;
  font-size:.82rem;font-weight:500;color:var(--moon);
  background:rgba(8,13,35,.7);backdrop-filter:blur(6px);
  padding:.4rem .8rem;border-radius:999px;border:1px solid var(--line);
}
.vsl__video{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;background:#000;border-radius:var(--radius);
}
/* quando o vídeo está tocando, some a capa (botão + legenda) */
.vsl__player.is-playing .vsl__play,
.vsl__player.is-playing .vsl__label{opacity:0;pointer-events:none;transition:opacity .3s var(--ease)}

/* ===================================================== */
/* 3 · MIRROR (a dor reconhecida)                         */
/* ===================================================== */
.mirror{background:var(--night);padding:clamp(4.5rem,10vh,7rem) 0;text-align:center}
.mirror .eyebrow{color:var(--moon-dim)}
.mirror .eyebrow em{font-size:1.35rem;display:block;margin-top:.3rem;letter-spacing:-.01em}
.mirror__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;
  max-width:1020px;margin:2.6rem auto 0;text-align:left;
}
.mirror__line{
  background:var(--night-2);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;
  transition:transform .4s var(--ease),border-color .4s;
}
.mirror__line:hover{transform:translateY(-5px);border-color:#36488a}
/* espaço de imagem (troque os arquivos img/mirror-1..3.png) */
.mirror__media{
  display:block;position:relative;aspect-ratio:4/3;
  background:linear-gradient(150deg,#13234f,#0e1a40);
  overflow:hidden;
}
.mirror__media img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:saturate(.95);
}
/* placeholder elegante enquanto não houver imagem (img some via onerror) */
.mirror__media::after{
  content:'';position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(120% 80% at 80% 0%, rgba(242,178,92,.10), transparent 60%),
    repeating-linear-gradient(135deg, rgba(234,240,255,.035) 0 2px, transparent 2px 11px);
  pointer-events:none;
}
.mirror__media.is-empty::before{
  content:'Imagem';position:absolute;inset:0;z-index:1;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-body);font-size:.72rem;font-weight:600;letter-spacing:.18em;
  text-transform:uppercase;color:var(--moon-faint);
}
.mirror__media img{z-index:2}
/* some com o ícone de imagem quebrada quando o arquivo ainda não existe */
.mirror__media.is-empty img{display:none}
.mirror__line figcaption{
  padding:1.4rem 1.5rem;font-size:1.02rem;color:var(--moon-dim);
  position:relative;
}
.mirror__line figcaption::before{
  content:'';display:block;width:34px;height:2px;background:var(--moon-faint);
  margin-bottom:1rem;opacity:.6;
}
.mirror__turn{
  font-family:var(--font-display);font-style:italic;font-weight:400;
  font-size:clamp(1.3rem,1.1rem + 1vw,1.85rem);line-height:1.4;
  color:var(--moon);max-width:30ch;margin:2.8rem auto 0;
}

/* ===================================================== */
/* 4 · MÉTODO (seção clara — creme)                       */
/* ===================================================== */
.method{background:var(--cream);color:var(--ink);padding:clamp(5rem,11vh,8rem) 0}
.method__head{max-width:62ch}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3.2rem}
.step{
  background:#fff;border:1px solid #efe6d6;border-radius:var(--radius);
  padding:2rem 1.8rem;position:relative;overflow:hidden;
  box-shadow:0 1px 0 rgba(0,0,0,.02);
  transition:box-shadow .4s var(--ease);
  transform-style:preserve-3d;will-change:transform;
}
.step:hover{box-shadow:0 30px 50px -28px rgba(22,33,63,.28)}
.step__num{
  font-family:var(--font-display);font-weight:600;font-size:2.6rem;
  color:var(--amber-deep);display:block;line-height:1;margin-bottom:1.1rem;
}
.step__num::after{content:'';display:block;width:42px;height:3px;border-radius:2px;margin-top:.9rem;
  background-image:linear-gradient(90deg,var(--amber),var(--amber-deep));
  background-repeat:no-repeat;background-size:100% 3px;background-position:left center}
.step__title{font-family:var(--font-display);font-weight:600;font-size:1.35rem;color:var(--ink);margin-bottom:.7rem}
.step__text{color:var(--ink-dim);font-size:1rem}

.method__mock{
  display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center;
  margin-top:3.6rem;padding-top:3.4rem;border-top:1px solid #ece2d0;
}
.method__mock img{margin-inline:auto;width:min(420px,100%);filter:drop-shadow(0 30px 40px rgba(22,33,63,.22))}

/* ===================================================== */
/* 5 · NÚMEROS                                            */
/* ===================================================== */
.numbers{background:var(--night-2);padding:clamp(3.5rem,8vh,5.5rem) 0;border-block:1px solid var(--line)}
.numbers__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;text-align:center}
.stat{position:relative}
.stat:not(:last-child)::after{content:'';position:absolute;right:0;top:15%;height:70%;width:1px;background:var(--line)}
.stat__num{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(2.6rem,2rem + 2.6vw,4rem);line-height:1;
  color:var(--amber);display:block;font-variant-numeric:tabular-nums;
}
.stat__label{display:block;margin-top:.6rem;color:var(--moon-dim);font-size:.95rem}

/* ===================================================== */
/* 6 · DEPOIMENTOS                                        */
/* ===================================================== */
.praise{background:var(--night);padding:clamp(5rem,11vh,8rem) 0}
.praise__head{text-align:center;max-width:46ch;margin-inline:auto}
.praise__head .eyebrow em{display:block;margin-top:.3rem;font-size:1.4rem}
.praise__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
.quote{
  background:linear-gradient(180deg,var(--night-2),#101b46);
  border:1px solid var(--line);border-radius:var(--radius);
  padding:2rem 1.9rem;display:flex;flex-direction:column;gap:1.1rem;
  transition:transform .4s var(--ease),border-color .4s;
}
.quote:hover{transform:translateY(-5px);border-color:#36488a}
.quote__stars{color:var(--amber);letter-spacing:.15em;font-size:.95rem}
.quote blockquote{
  font-family:var(--font-display);font-weight:400;font-size:1.12rem;line-height:1.5;
  color:var(--moon);
}
.quote figcaption{margin-top:auto;color:var(--moon-dim);font-size:.92rem}
.quote figcaption strong{color:var(--moon)}

/* ===================================================== */
/* 7 · ANTES / DEPOIS                                     */
/* ===================================================== */
.contrast{background:var(--night-2);padding:clamp(4.5rem,10vh,7rem) 0;border-top:1px solid var(--line)}
.contrast__grid{display:grid;grid-template-columns:1fr auto 1fr;gap:clamp(1rem,3vw,2.4rem);align-items:center}
.ba{border-radius:var(--radius);padding:2rem 1.9rem}
.ba__tag{font-size:.78rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;margin-bottom:1.3rem;color:var(--moon-faint)}
.ba__tag--amber{color:var(--amber)}
.ba ul{list-style:none;display:flex;flex-direction:column;gap:.95rem}
.ba li{position:relative;padding-left:1.9rem;color:var(--moon-dim);font-size:1.02rem}
.ba li::before{position:absolute;left:0;top:.05em;font-size:1.05rem}
.ba--before{background:rgba(11,20,55,.5);border:1px solid var(--line)}
.ba--before li{color:var(--moon-faint)}
.ba--before li::before{content:'✕';color:#5e6aa0}
.ba--after{background:linear-gradient(180deg,#16234f,#101b46);border:1px solid rgba(242,178,92,.4);box-shadow:0 0 0 1px rgba(242,178,92,.1),0 30px 60px -34px rgba(242,178,92,.25)}
.ba--after li{color:var(--moon)}
.ba--after li::before{content:'✓';color:var(--amber);font-weight:700}
.contrast__arrow{font-family:var(--font-display);font-size:2.4rem;color:var(--moon-faint)}

/* ===================================================== */
/* 8 · O QUE VEM DENTRO + 9 · OFERTA                      */
/* ===================================================== */
.stack{background:var(--night);padding:clamp(5rem,11vh,8rem) 0}
.stack__head{text-align:center;max-width:40ch;margin-inline:auto}
.stack__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center;margin-top:3rem}
.stack__list{list-style:none;display:flex;flex-direction:column;gap:1rem}
.stack__list li{
  display:flex;align-items:flex-start;gap:1rem;
  background:var(--night-2);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:1.15rem 1.3rem;
}
.stack__list strong{display:block;color:var(--moon);font-weight:600;font-size:1.05rem}
.stack__was{font-size:.85rem;color:var(--moon-faint);text-decoration:line-through;margin-top:.2rem;display:inline-block}
.stack__check{
  flex-shrink:0;width:26px;height:26px;border-radius:50%;
  background:rgba(242,178,92,.14);border:1px solid rgba(242,178,92,.45);
  display:grid;place-items:center;margin-top:.1rem;
}
.stack__check::after{content:'';width:7px;height:12px;border:solid var(--amber);border-width:0 2px 2px 0;transform:rotate(45deg) translateY(-1px)}
.stack__mock img{width:min(460px,100%);margin-inline:auto;filter:drop-shadow(0 40px 60px rgba(0,0,0,.55))}

/* OFFER card — fechamento de conversão (inspirado em CTAs de checkout) */
.offer{
  position:relative;overflow:hidden;
  max-width:520px;margin:4rem auto 0;text-align:center;
  background:linear-gradient(180deg,#16244f 0%,#101b44 100%);
  border:1px solid rgba(242,178,92,.4);
  border-radius:24px;
  padding:clamp(2.6rem,6vw,3.4rem) clamp(1.5rem,5vw,2.8rem) clamp(2rem,5vw,2.6rem);
  box-shadow:0 50px 100px -45px rgba(0,0,0,.85), 0 0 0 1px rgba(242,178,92,.06);
}
.offer__glow{position:absolute;top:-45%;left:50%;transform:translateX(-50%);width:90%;height:85%;background:radial-gradient(circle,rgba(242,178,92,.2),transparent 64%);pointer-events:none}

/* badge no topo (pílula) */
.offer__badge{
  position:relative;display:inline-flex;align-items:center;gap:.45rem;
  font-family:var(--font-body);font-size:.74rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  color:#3a2608;background:linear-gradient(180deg,#F6C074,var(--amber));
  padding:.5rem 1.1rem;border-radius:999px;margin-bottom:1.4rem;
  box-shadow:0 10px 26px -12px rgba(242,178,92,.7);
}
.offer__badge::before{content:'';width:7px;height:7px;border-radius:50%;background:#3a2608;opacity:.8}

.offer__line{position:relative;color:var(--moon-dim);font-size:1.05rem;line-height:1.4}
.offer__line em{font-family:var(--font-display);font-style:italic;color:var(--moon)}

/* mini-lista de entregáveis dentro do card */
.offer__feats{
  position:relative;list-style:none;text-align:left;
  display:flex;flex-direction:column;gap:.7rem;
  max-width:300px;margin:1.6rem auto 0;
}
.offer__feats li{display:flex;align-items:flex-start;gap:.7rem;color:var(--moon-dim);font-size:.96rem;line-height:1.35}
.offer__tick{
  flex-shrink:0;width:20px;height:20px;border-radius:50%;margin-top:.05rem;
  background:rgba(242,178,92,.16);border:1px solid rgba(242,178,92,.5);position:relative;
}
.offer__tick::after{content:'';position:absolute;left:6.5px;top:3.5px;width:4px;height:8px;border:solid var(--amber);border-width:0 2px 2px 0;transform:rotate(45deg)}

/* bloco de preço destacado */
.offer__pricing{
  position:relative;margin-top:1.8rem;padding-top:1.7rem;
  border-top:1px solid rgba(242,178,92,.18);
}
.offer__from{color:var(--moon-dim);font-size:1rem;margin-bottom:.1rem}
.offer__from s{color:var(--moon-faint);text-decoration-thickness:2px;margin-right:.15rem}
.offer__price{position:relative;display:flex;align-items:baseline;justify-content:center;gap:.6rem}
.offer__install{font-family:var(--font-body);font-size:1.2rem;font-weight:600;color:var(--moon-dim)}
.offer__now{font-family:var(--font-body);font-weight:800;font-size:clamp(3.6rem,2.6rem + 3.4vw,5.2rem);line-height:1;color:var(--amber);letter-spacing:-.03em;font-variant-numeric:tabular-nums;font-feature-settings:'tnum' 1}
.offer__cur{font-size:.42em;font-weight:700;vertical-align:super;margin-right:.06em;letter-spacing:0}
.offer__cash{color:var(--moon-dim);font-size:.95rem;margin-top:.35rem}
.offer__save{
  display:inline-block;margin-top:.9rem;
  font-size:.8rem;font-weight:700;letter-spacing:.02em;
  color:#0c2a14;background:#34d27f;
  padding:.4rem .9rem;border-radius:999px;
}

.offer__cta{margin-top:1.8rem}
.offer .btn{position:relative}

.offer__seals{position:relative;list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem 1.3rem;margin-top:1.5rem;font-size:.85rem;color:var(--moon-dim)}
.offer__seals li{display:flex;align-items:center;gap:.45rem}
.seal{width:16px;height:16px;border-radius:50%;background:rgba(242,178,92,.18);position:relative;flex-shrink:0}
.seal::after{content:'';position:absolute;left:5px;top:3px;width:4px;height:7px;border:solid var(--amber);border-width:0 1.5px 1.5px 0;transform:rotate(45deg)}
.offer__secure{position:relative;margin-top:1.1rem;font-size:.8rem;color:var(--moon-faint)}

/* ===================================================== */
/* 10 · FAQ (seção clara)                                 */
/* ===================================================== */
.faq{background:var(--cream);color:var(--ink);padding:clamp(5rem,11vh,8rem) 0}
.faq__inner{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.faq__head{position:sticky;top:100px}
.faq__head .h2--ink em{color:var(--amber-deep)}
.faq__list{display:flex;flex-direction:column;gap:.8rem}
.qa{border:1px solid #ece2d0;border-radius:var(--radius-sm);background:#fff;overflow:hidden;transition:border-color .3s,box-shadow .3s}
.qa[open]{border-color:#e3cfa6;box-shadow:0 18px 36px -28px rgba(22,33,63,.3)}
.qa summary{
  list-style:none;cursor:pointer;
  padding:1.25rem 1.4rem;font-weight:600;font-size:1.05rem;color:var(--ink);
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
}
.qa summary::-webkit-details-marker{display:none}
.qa summary::after{
  content:'';flex-shrink:0;width:11px;height:11px;
  border-right:2px solid var(--amber-deep);border-bottom:2px solid var(--amber-deep);
  transform:rotate(45deg);transition:transform .3s var(--ease);margin-top:-3px;
}
.qa[open] summary::after{transform:rotate(-135deg);margin-top:3px}
.qa p{padding:0 1.4rem 1.35rem;color:var(--ink-dim);font-size:1rem;max-width:60ch}

/* ===================================================== */
/* 11 · CTA FINAL                                         */
/* ===================================================== */
.final{
  position:relative;overflow:hidden;text-align:center;
  padding:clamp(5.5rem,13vh,9rem) 0;
  background:
    radial-gradient(100% 100% at 50% 0%, #1a2a63 0%, transparent 60%),
    var(--night);
  border-top:1px solid var(--line);
}
.final__sky{position:absolute;inset:0;width:100%;height:100%;z-index:0;opacity:.9}
.final__inner{position:relative;z-index:2;max-width:660px}
.final__title{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(2.4rem,1.7rem + 3.4vw,4.4rem);line-height:1.05;letter-spacing:-.02em;
  margin:.4rem 0 0;
}
.final__sub{color:var(--moon-dim);font-size:clamp(1.05rem,1rem + .4vw,1.25rem);max-width:46ch;margin:1.5rem auto 2.4rem}
.final__seal{margin-top:1.5rem;font-size:.88rem;color:var(--moon-faint)}

/* ------------------------- FOOTER ------------------------- */
.foot{background:#070d23;padding:3rem 0 2.4rem;border-top:1px solid var(--line)}
.foot__inner{display:flex;flex-direction:column;align-items:center;text-align:center;gap:1.3rem}
.foot__logo{height:46px;width:auto;opacity:.95}
.foot__legal{color:var(--moon-faint);font-size:.82rem;line-height:1.7;max-width:60ch}
.foot__links{display:flex;gap:1.6rem}
.foot__links a{color:var(--moon-dim);font-size:.9rem;transition:color .25s}
.foot__links a:hover{color:var(--moon)}

/* ------------------------- STICKY MOBILE CTA ------------------------- */
.sticky-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:90;
  display:none;align-items:center;justify-content:space-between;gap:1rem;
  padding:.7rem 1.1rem calc(.7rem + env(safe-area-inset-bottom));
  background:rgba(8,13,35,.92);backdrop-filter:blur(14px);
  border-top:1px solid var(--line);
  transform:translateY(120%);transition:transform .4s var(--ease);
}
.sticky-cta.is-visible{transform:translateY(0)}
.sticky-cta__price{font-weight:600;color:var(--moon);font-size:1.05rem;font-variant-numeric:tabular-nums}
.sticky-cta__price s{color:var(--moon-faint);font-weight:400;margin-right:.35rem;font-size:.85em}
.sticky-cta__btn{
  background:linear-gradient(180deg,#F6C074,var(--amber));color:#3a2608;font-weight:600;
  padding:.8rem 1.3rem;border-radius:999px;box-shadow:var(--shadow-amber);white-space:nowrap;
}

/* ------------------------- REVEAL (GSAP fallback) ------------------------- */
.reveal{opacity:0;transform:translateY(26px)}
.is-revealed{opacity:1;transform:none}

/* ===================================================== */
/* RESPONSIVE                                             */
/* ===================================================== */
@media (max-width:1024px){
  /* banner ATRÁS do texto (como no desktop), mas sem zoom: a imagem é
     dimensionada pela largura (sem corte/ampliação) e ancorada no topo;
     gradiente vindo da esquerda + reforço embaixo para legibilidade */
  .hero{align-items:flex-end;min-height:92svh}
  .hero__copy{max-width:none;text-align:center;margin-inline:auto}
  .hero__sub,.hero__title{margin-inline:auto}
  .hero__actions,.hero__trust{justify-content:center}
  .hero__base{
    inset:0;
    background-position:right top;
    background-size:150% auto;
    background-color:var(--night);
  }
  .hero__veil{
    background:
      linear-gradient(90deg, var(--night) 0%, rgba(11,20,55,.55) 38%, rgba(11,20,55,.12) 70%, transparent 100%),
      linear-gradient(180deg, rgba(11,20,55,.25) 0%, transparent 30%, rgba(8,13,35,.78) 56%, var(--night) 78%);
  }
  .vsl__inner,.faq__inner{grid-template-columns:1fr}
  .faq__head{position:static}
  .method__mock{grid-template-columns:1fr;text-align:center}
  .method__mock .link-amber{margin-inline:auto}
  .stack__grid{grid-template-columns:1fr}
  .stack__mock{order:-1}
}
@media (max-width:760px){
  .nav__links{display:none}
  .nav__cta{display:none}
  .mirror__grid,.steps,.praise__grid,.numbers__grid{grid-template-columns:1fr}
  .stat:not(:last-child)::after{display:none}
  .stat{padding-bottom:1.6rem;border-bottom:1px solid var(--line)}
  .stat:last-child{border-bottom:none;padding-bottom:0}
  .contrast__grid{grid-template-columns:1fr}
  .contrast__arrow{transform:rotate(90deg);justify-self:center}
  .sticky-cta{display:flex}
  body{padding-bottom:0}
  .hero{min-height:90svh;padding-top:7rem;padding-bottom:clamp(2.5rem,7vh,3.5rem)}
  /* imagem com zoom, ancorada à direita; gradiente esquerda + base reforçada */
  .hero__base{background-size:160% auto;background-position:right top}
  .hero__veil{
    background:
      linear-gradient(90deg, var(--night) 0%, rgba(11,20,55,.6) 36%, rgba(11,20,55,.15) 72%, transparent 100%),
      linear-gradient(180deg, rgba(11,20,55,.3) 0%, transparent 28%, rgba(8,13,35,.82) 54%, var(--night) 76%);
  }
}
@media (max-width:420px){
  .hero__trust{font-size:.85rem;gap:.6rem}
  .offer__seals{flex-direction:column;align-items:center;gap:.55rem}
}

/* ------------------------- REDUCED MOTION ------------------------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
}
