/* ============================================================
   SAFE LIFE — Landing premium (editorial escuro · verde + dourado)
   Design system inspirado no estilo editorial do jusratio.com.br
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --bg:        #0a1410;   /* verde quase-preto */
  --bg-2:      #0c1812;   /* painel */
  --bg-3:      #0f1f17;   /* card */
  --bg-rise:   #12271c;   /* card hover / destaque */

  --ink:       #f3efe2;   /* creme principal */
  --ink-2:     #cdd2c5;   /* creme secundário */
  --muted:     #8a9a8b;   /* sálvia */
  --faint:     #5d6c5e;   /* legendas fracas */

  --gold:      #d8b25f;
  --gold-2:    #f1da9c;
  --gold-deep: #a9802f;

  --green:     #7fae6a;   /* verde Ora Safe (acento pontual) */
  --err:       #e08a6a;   /* erro (terracota, alinhado à paleta) */

  --line:      rgba(216,178,95,.16);
  --line-soft: rgba(243,239,226,.08);

  --rad:   18px;
  --rad-l: 26px;
  --maxw:  1240px;
  --hero-scale: 1.3;   /* tamanho padrão dos produtos no herói (ajustável via Tweaks) */
  --gut:   clamp(20px, 5vw, 64px);

  --sans: "Archivo", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --serif: "Newsreader", Georgia, serif;
  --mono: "Space Mono", ui-monospace, monospace;

  --ease: cubic-bezier(.22,.61,.36,1);
}

html[data-bg="black"]{ --bg:#070b09; --bg-2:#0a120d; --bg-3:#0c1812; }

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.6;
  font-weight:400;
  letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
::selection{ background:var(--gold); color:#0a0f0c; }

/* ---------- Helpers ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut); }
.section{ position:relative; padding-block:clamp(72px,11vw,150px); }
.rule{ height:1px; background:var(--line-soft); border:0; margin:0; }

.kicker{
  font-family:var(--mono);
  font-size:12.5px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--gold);
  display:inline-flex;
  align-items:center;
  gap:.7em;
  margin:0;
}
.kicker::before{
  content:""; width:26px; height:1px; background:var(--gold); opacity:.7;
}
.kicker--plain::before{ display:none; }

.gold-text{
  background:linear-gradient(120deg,var(--gold-2),var(--gold) 45%,var(--gold-deep));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.serif-accent{
  font-family:var(--serif);
  font-style:italic;
  font-weight:400;
}

.eyebrow-num{
  font-family:var(--mono);
  font-size:13px;
  letter-spacing:.1em;
  color:var(--gold);
}

/* ---------- Buttons ---------- */
.btn{
  --bh:54px;
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  height:var(--bh); padding-inline:26px;
  border-radius:999px;
  font-family:var(--sans); font-weight:600; font-size:15px; letter-spacing:.01em;
  cursor:pointer; border:1px solid transparent;
  transition:transform .25s var(--ease), background .25s var(--ease), box-shadow .25s var(--ease), color .2s;
  white-space:nowrap;
}
.btn svg{ width:18px; height:18px; }
.btn--gold{
  background:linear-gradient(120deg,var(--gold-2),var(--gold) 55%,var(--gold-deep));
  color:#15140c;
  box-shadow:0 14px 34px -16px rgba(216,178,95,.7);
}
.btn--gold:hover{ transform:translateY(-2px); box-shadow:0 22px 44px -16px rgba(216,178,95,.85); }
.btn--ghost{
  background:transparent; color:var(--ink);
  border-color:var(--line);
}
.btn--ghost:hover{ border-color:var(--gold); color:var(--gold-2); transform:translateY(-2px); }
.btn--sm{ --bh:44px; padding-inline:20px; font-size:14px; }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:sticky; top:0; z-index:50;
  background:color-mix(in srgb, var(--bg) 78%, transparent);
  backdrop-filter:blur(14px) saturate(1.2);
  -webkit-backdrop-filter:blur(14px) saturate(1.2);
  border-bottom:1px solid var(--line-soft);
}
.nav__in{
  display:flex; align-items:center; justify-content:space-between;
  height:74px;
}
.brand{ display:flex; align-items:center; gap:12px; }
.brand__logo{ height:38px; width:auto; display:block; }
.foot__brand .brand__logo{ height:42px; }
@media (max-width:560px){ .brand__logo{ height:32px; } }
.brand__mark{
  width:34px; height:38px; flex:none;
  display:grid; place-items:center;
}
.brand__mark svg{ width:100%; height:100%; }
.brand__txt{ display:flex; flex-direction:column; line-height:1; }
.brand__name{
  font-weight:800; font-size:18px; letter-spacing:.14em; white-space:nowrap;
}
.brand__sub{
  font-family:var(--mono); font-size:9.5px; letter-spacing:.42em;
  color:var(--muted); margin-top:4px; text-transform:uppercase;
}
.nav__links{ display:flex; align-items:center; gap:34px; }
.nav__links a{
  font-size:14px; color:var(--ink-2); letter-spacing:.02em;
  position:relative; transition:color .2s;
}
.nav__links a:hover{ color:var(--gold-2); }
.nav__right{ display:flex; align-items:center; gap:18px; }
@media (max-width:900px){ .nav__links{ display:none; } }

/* ============================================================
   HERO
   ============================================================ */
@property --accent{ syntax:"<color>"; inherits:true; initial-value:#8fc47a; }

.hero{ position:relative; overflow:hidden; --accent:#8fc47a; transition:--accent .7s var(--ease); }
.hero__bg{ position:absolute; inset:0; z-index:0; pointer-events:none; }
.hero__halo{
  position:absolute; right:-10%; top:-28%;
  width:min(115vw,1080px); aspect-ratio:1; border-radius:50%;
  background:radial-gradient(circle at center,
     color-mix(in srgb, var(--accent) 42%, transparent),
     color-mix(in srgb, var(--accent) 12%, transparent) 40%, transparent 64%);
  filter:blur(10px); opacity:.7;
}
.hero__bg::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 58%, var(--bg) 100%);
}
.hero__grain{
  position:absolute; inset:0; opacity:.5; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/></svg>");
}

.hero__inner{
  position:relative; z-index:2;
  display:grid; grid-template-columns:1.05fr .95fr; align-items:center;
  gap:clamp(28px,4vw,64px);
  padding-block:clamp(24px,3.5vw,56px) clamp(32px,4.5vw,68px);
}
.hero__copy{ max-width:620px; }
.hero__eyebrow{ color:var(--accent); }

.hero__name{
  font-weight:700; font-size:clamp(2.6rem,6.4vw,5rem);
  line-height:.95; letter-spacing:-.03em; margin:.3em 0 0; font-stretch:115%;
  background:linear-gradient(120deg, color-mix(in srgb,var(--accent) 72%, #ffffff), var(--accent));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.hero__tag{
  font-family:var(--serif); font-style:italic; font-weight:400;
  font-size:clamp(1.2rem,2vw,1.7rem); color:var(--ink); margin:.5em 0 0; line-height:1.2;
}
.hero__desc{ margin:1em 0 0; font-size:clamp(1rem,1.3vw,1.12rem); color:var(--ink-2); max-width:46ch; line-height:1.55; }
.hero__chips{ display:flex; flex-wrap:wrap; gap:8px; margin-top:18px; }
.hero__chips .chip{
  font-family:var(--mono); font-size:11.5px; letter-spacing:.03em;
  color:var(--ink-2); border:1px solid color-mix(in srgb, var(--accent) 38%, transparent);
  border-radius:999px; padding:5px 12px;
}
.hero__cta{ display:flex; flex-wrap:wrap; gap:12px; margin-top:26px; }
.hero__cta .btn{ flex:1 1 100%; }            /* empilhados, largura total (mobile) */
@media (min-width:760px){
  .hero__cta{ flex-wrap:nowrap; align-items:stretch; }
  .hero__cta .btn{ flex:0 1 auto; min-width:0; white-space:normal; text-align:center; line-height:1.2; }
}

/* animação de troca de texto */
.hero__fade{ animation:heroIn .5s var(--ease) both; }
@keyframes heroIn{ from{ opacity:0; } to{ opacity:1; } }

/* seletor de produtos */
.hero__select{
  display:flex; gap:10px; margin-top:30px; padding-top:24px;
  border-top:1px solid var(--line-soft); flex-wrap:wrap;
}
.thumb{
  flex:0 0 auto; width:80px; cursor:pointer; font-family:inherit;
  display:flex; flex-direction:column; align-items:center; gap:6px;
  background:var(--bg-3); border:1px solid var(--line-soft); border-radius:14px;
  padding:10px 6px 8px; transition:transform .25s var(--ease), border-color .3s, background .3s;
}
.thumb img{ height:42px; width:auto; filter:drop-shadow(0 6px 8px rgba(0,0,0,.4)); pointer-events:none; }
.thumb span{ font-family:var(--mono); font-size:9.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--muted); white-space:nowrap; transition:color .3s; }
.thumb:hover{ transform:translateY(-3px); border-color:var(--line); }
.thumb.active{ border-color:var(--accent); background:color-mix(in srgb, var(--accent) 12%, var(--bg-3)); box-shadow:0 0 0 1px var(--accent) inset; }
.thumb.active span{ color:var(--accent); }

/* palco / garrafa */
.hero__stage{ position:relative; z-index:2; display:grid; place-items:end center; }
.hero__glow{
  position:absolute; left:50%; top:46%; translate:-50% -50%;
  width:80%; aspect-ratio:1; border-radius:50%;
  background:radial-gradient(circle at center, color-mix(in srgb, var(--accent) 38%, transparent), transparent 62%);
  filter:blur(18px);
}
.hero__bottles{ position:relative; display:grid; place-items:end center; width:100%; scale:var(--hero-scale, 1); transform-origin:bottom center; }
.bottle{
  grid-area:1 / 1; place-self:end center;
  height:clamp(240px,26vw,380px); width:auto; max-width:100%; object-fit:contain;
  opacity:0; transform:translateY(16px) scale(.97);
  transition:opacity .55s var(--ease), transform .55s var(--ease);
  filter:drop-shadow(0 42px 60px rgba(0,0,0,.6));
  pointer-events:none;
}
.bottle.active{ opacity:1; transform:none; }
/* hover sutil igual aos cards da linha */
.hero__stage{ cursor:default; }
.hero__bottles:hover .bottle.active{ transform:translateY(-8px) scale(1.04); }

/* Efeito 3: scroll-scrub (pin) — só desktop e com efeitos ligados */
.hero-pin{ position:relative; }
@media (min-width:881px){
  html[data-scrub="on"] .hero-pin{ height:210vh; }
  html[data-scrub="on"] .hero-pin > .hero{
    position:sticky; top:0; min-height:100vh;
    display:flex; align-items:center;
  }
  html[data-scrub="on"] .hero-pin > .hero > .hero__inner{ width:100%; }
}

@media (max-width:880px){
  .hero__inner{ grid-template-columns:1fr; gap:22px; text-align:center; }
  .hero__copy{ max-width:100%; }
  .hero__stage{ order:2; }
  .hero__bottles{ width:auto; scale:1; margin-top:6px; }
  .bottle{ height:clamp(220px,42vw,300px); }
  .hero__benefits{ display:inline-grid; text-align:left; }
  .hero__cta{ justify-content:center; }
  .hero__eyebrow::before{ display:none; }
}
@media (max-width:560px){
  .hero__headline{ font-size:clamp(2.05rem,8.5vw,2.9rem); }
  .hero__sub{ font-size:1rem; }
  .bottle{ height:clamp(190px,46vw,260px); }
  .nav__right .btn span, .nav__right .btn{ font-size:13px; }
}

/* ============================================================
   FAIXA DE SELOS / MARQUEE DE CONFIANÇA
   ============================================================ */
.trust{
  border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
  background:var(--bg-2);
  overflow:hidden;
}
.trust__track{
  display:flex; width:max-content;
  animation:trustScroll 36s linear infinite;
}
.trust:hover .trust__track{ animation-play-state:paused; }
.trust__group{ display:flex; align-items:center; flex:none; }
.trust__item{
  display:flex; align-items:center; gap:12px;
  padding:26px 30px; white-space:nowrap;
  font-size:14px; letter-spacing:.02em; color:var(--ink-2);
  border-right:1px solid var(--line-soft);
}
.trust__item b{ color:var(--ink); font-weight:600; }
.trust__item svg{ width:28px; height:28px; color:var(--gold); flex:none; }
@keyframes trustScroll{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
@media (prefers-reduced-motion:reduce){
  .trust__track{ animation:none; flex-wrap:wrap; justify-content:center; width:auto; }
  .trust__group[aria-hidden]{ display:none; }
  .trust__group{ flex-wrap:wrap; justify-content:center; }
}

/* ============================================================
   BENEFÍCIOS — lista editorial numerada
   ============================================================ */
.bene__head{
  display:grid; grid-template-columns:1fr; gap:22px;
  max-width:760px; margin-bottom:clamp(40px,6vw,72px);
}
.bene__head h2{
  font-weight:700; font-size:clamp(2rem,4.6vw,3.5rem);
  line-height:1.02; letter-spacing:-.022em; margin:.3em 0 0;
}
.bene__list{ display:grid; gap:0; border-top:1px solid var(--line); }
.bene__item{
  display:grid; grid-template-columns:90px 1fr 1.3fr;
  gap:clamp(14px,3vw,46px); align-items:start;
  padding-block:clamp(26px,3.4vw,42px);
  border-bottom:1px solid var(--line);
  transition:background .3s var(--ease);
}
.bene__item:hover{ background:linear-gradient(90deg, rgba(216,178,95,.045), transparent 70%); }
.bene__n{ font-family:var(--mono); font-size:14px; color:var(--gold); padding-top:6px; }
.bene__item h3{
  font-weight:650; font-size:clamp(1.25rem,2.1vw,1.7rem);
  letter-spacing:-.01em; line-height:1.12; margin:0;
}
.bene__item p{ margin:0; color:var(--muted); font-size:15.5px; max-width:46ch; }
@media (max-width:760px){
  .bene__item{ grid-template-columns:54px 1fr; }
  .bene__item p{ grid-column:2; }
}

/* ============================================================
   VITRINE — 3 produtos
   ============================================================ */
.shop__head{ display:flex; flex-wrap:wrap; justify-content:space-between; align-items:flex-end; gap:24px; margin-bottom:clamp(36px,5vw,60px); }
.shop__head h2{ font-weight:700; font-size:clamp(2rem,4.4vw,3.3rem); line-height:1; letter-spacing:-.022em; margin:.35em 0 0; max-width:14ch; }
.shop__head p{ color:var(--muted); max-width:42ch; margin:0; }

.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.card{
  position:relative; display:flex; flex-direction:column;
  border:1px solid var(--line); border-radius:var(--rad-l);
  background:var(--bg-3); overflow:hidden;
  transition:transform .4s var(--ease), border-color .3s, box-shadow .4s var(--ease);
}
.card:hover{ transform:translateY(-8px); border-color:rgba(216,178,95,.4); box-shadow:0 40px 70px -40px rgba(0,0,0,.8); }
.card__media{
  position:relative; height:340px; display:grid; place-items:center;
  overflow:hidden;
}
.card__media img{
  height:300px; width:auto; z-index:2;
  filter:drop-shadow(0 26px 34px rgba(0,0,0,.5));
  transition:transform .5s var(--ease);
}
.card:hover .card__media img{ transform:translateY(-6px) scale(1.03); }
.card__media::before{
  content:""; position:absolute; inset:0; z-index:1;
  background:var(--tint, radial-gradient(120% 90% at 50% 0%, rgba(127,174,106,.18), transparent 60%));
}
.card[data-tint="ora"]{   --tint:radial-gradient(120% 95% at 50% 8%, rgba(127,174,106,.26), rgba(127,174,106,.05) 55%, transparent 72%); }
.card[data-tint="osteo"]{ --tint:radial-gradient(120% 95% at 50% 8%, rgba(214,219,226,.16), rgba(180,190,200,.04) 55%, transparent 72%); }
.card[data-tint="power"]{ --tint:radial-gradient(120% 95% at 50% 8%, rgba(216,178,95,.22), rgba(216,178,95,.05) 55%, transparent 72%); }
.card[data-tint="omega"]{ --tint:radial-gradient(120% 95% at 50% 8%, rgba(95,160,230,.24), rgba(95,160,230,.05) 55%, transparent 72%); }
.card[data-tint="lipo"]{  --tint:radial-gradient(120% 95% at 50% 8%, rgba(178,155,224,.24), rgba(178,155,224,.05) 55%, transparent 72%); }
.card[data-tint="calmin"]{--tint:radial-gradient(120% 95% at 50% 8%, rgba(147,199,166,.24), rgba(147,199,166,.05) 55%, transparent 72%); }

.card__body{ padding:26px 26px 28px; display:flex; flex-direction:column; gap:14px; flex:1; border-top:1px solid var(--line-soft); }
.card__tag{ font-family:var(--mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); }
.card__name{ font-weight:750; font-size:1.5rem; letter-spacing:-.01em; margin:0; line-height:1; }
.card__desc{ color:var(--muted); font-size:14.5px; margin:0; }
.card__specs{ display:flex; flex-wrap:wrap; gap:8px; margin-top:2px; }
.chip{
  font-family:var(--mono); font-size:11px; letter-spacing:.04em;
  color:var(--ink-2); border:1px solid var(--line); border-radius:999px;
  padding:5px 11px;
}
.card__foot{ margin-top:auto; padding-top:8px; }
.card__foot .btn{ width:100%; }
@media (max-width:880px){ .cards{ grid-template-columns:1fr; max-width:440px; margin-inline:auto; } }

/* ============================================================
   CTA FINAL — banda com folha
   ============================================================ */
.finale{ position:relative; padding-top:clamp(8px,2vw,24px); }
.lead{ padding-bottom:clamp(40px,6vw,84px); }
.finale__card{
  position:relative; overflow:hidden;
  border-radius:var(--rad-l);
  border:1px solid var(--line);
  background:linear-gradient(180deg,var(--bg-3),var(--bg-2));
}
.finale__bg{
  position:absolute; inset:0; z-index:0;
  background-image:var(--leaf, none);
  background-size:cover; background-position:center;
  opacity:.5;
}
.finale__bg::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(10,20,16,.55), rgba(10,20,16,.82));
}
.finale__in{
  position:relative; z-index:2;
  display:flex; flex-direction:column; align-items:center; text-align:center; gap:22px;
  padding:clamp(54px,8vw,104px) var(--gut);
}
.finale__in h2{
  font-weight:700; font-size:clamp(2.1rem,5vw,4rem);
  line-height:1.02; letter-spacing:-.024em; margin:.2em 0 0; max-width:18ch;
}
.finale__in p{ color:var(--ink-2); max-width:48ch; margin:0; font-size:1.05rem; }

/* ============================================================
   RODAPÉ
   ============================================================ */
.foot{ border-top:1px solid var(--line-soft); background:var(--bg-2); }
.foot__top{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; padding-block:clamp(48px,7vw,80px); }
.foot__brand .brand{ margin-bottom:18px; }
.foot__brand p{ color:var(--muted); font-size:14.5px; max-width:34ch; margin:0; }
.foot__col h4{ font-family:var(--mono); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin:0 0 16px; font-weight:400; }
.foot__col a, .foot__col span{ display:block; color:var(--ink-2); font-size:14.5px; padding:6px 0; transition:color .2s; }
.foot__col a:hover{ color:var(--gold-2); }
.foot__bot{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:14px; padding-block:24px; border-top:1px solid var(--line-soft); color:var(--faint); font-size:12.5px; }
.foot__legal{ max-width:760px; color:var(--faint); font-size:12px; line-height:1.6; padding-bottom:30px; }
@media (max-width:760px){ .foot__top{ grid-template-columns:1fr 1fr; gap:28px; } .foot__brand{ grid-column:1/-1; } }

/* ============================================================
   CADASTRO / FORMULÁRIO DE CAPTAÇÃO
   ============================================================ */
.lead__grid{ display:grid; grid-template-columns:.92fr 1.08fr; gap:clamp(34px,5vw,70px); align-items:start; }
.lead__intro h2{ font-weight:700; font-size:clamp(2rem,4.4vw,3.3rem); line-height:1.02; letter-spacing:-.022em; margin:.3em 0 0; max-width:15ch; }
.lead__intro > p{ color:var(--ink-2); margin:1.3em 0 0; max-width:44ch; }
.lead__points{ list-style:none; padding:0; margin:30px 0 0; display:grid; gap:14px; }
.lead__points li{ display:flex; align-items:center; gap:12px; color:var(--ink-2); font-size:15px; }
.lead__points svg{ width:22px; height:22px; color:var(--gold); flex:none; }
.lead__contact{ margin-top:30px; color:var(--muted); font-size:15px; }
.lead__contact a{ color:var(--gold-2); white-space:nowrap; border-bottom:1px solid var(--line); padding-bottom:2px; transition:opacity .2s; }
.lead__contact a:hover{ opacity:.8; }

.lead__formwrap{ position:relative; }
.lead__form{ position:relative; background:var(--bg-3); border:1px solid var(--line); border-radius:var(--rad-l); padding:clamp(24px,3vw,40px); overflow:hidden; }
.lead__formtitle{ font-weight:750; font-size:1.4rem; letter-spacing:-.01em; margin:0 0 22px; }
.field{ display:flex; flex-direction:column; gap:8px; margin-bottom:18px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field label{ font-family:var(--mono); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); }
.field input, .field select{
  height:52px; width:100%; background:var(--bg-2);
  border:1px solid var(--line-soft); border-radius:12px;
  color:var(--ink); padding:0 15px; font-family:var(--sans); font-size:15px;
  outline:none; transition:border-color .2s, box-shadow .2s, background .2s;
  -webkit-appearance:none; appearance:none;
}
.field input::placeholder{ color:var(--faint); }
.field select{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238a9a8b' stroke-width='2'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat:no-repeat; background-position:right 15px center; padding-right:40px; cursor:pointer;
}
.field select:invalid{ color:var(--faint); }
.field select option{ background:#0c1812; color:var(--ink); }
.field input:focus, .field select:focus{ border-color:var(--gold); box-shadow:0 0 0 3px color-mix(in srgb, var(--gold) 22%, transparent); background:var(--bg); }
.field.invalid input, .field.invalid select{ border-color:var(--err); }
.err{ display:none; color:var(--err); font-size:12.5px; font-family:var(--sans); letter-spacing:.01em; }
.field.invalid .err{ display:block; }
.err--consent{ display:none; color:var(--err); font-size:12.5px; margin:8px 0 0; }
.consent.invalid + .err--consent{ display:block; }

.consent{ display:flex; align-items:flex-start; gap:12px; cursor:pointer; margin-top:6px; position:relative; }
.consent input{ position:absolute; opacity:0; width:0; height:0; }
.consent__box{ width:20px; height:20px; flex:none; border:1px solid var(--line); border-radius:6px; background:var(--bg-2); margin-top:1px; display:grid; place-items:center; transition:border-color .2s, box-shadow .2s; }
.consent__box::after{ content:""; width:10px; height:10px; border-radius:2px; background:linear-gradient(120deg,var(--gold-2),var(--gold-deep)); transform:scale(0); transition:transform .18s var(--ease); }
.consent input:checked + .consent__box{ border-color:var(--gold); }
.consent input:checked + .consent__box::after{ transform:scale(1); }
.consent input:focus-visible + .consent__box{ box-shadow:0 0 0 3px color-mix(in srgb, var(--gold) 22%, transparent); }
.consent.invalid .consent__box{ border-color:var(--err); }
.consent__txt{ color:var(--muted); font-size:13px; line-height:1.45; }
.hp{ position:absolute !important; left:-9999px; top:0; width:1px; height:1px; overflow:hidden; }

.lead__submit{ width:100%; margin-top:24px; --bh:56px; }
.lead__note{ text-align:center; color:var(--faint); font-size:12px; margin:14px 0 0; }

.lead__success{
  position:absolute; inset:0; z-index:5;
  display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; gap:14px;
  padding:32px; background:linear-gradient(180deg,var(--bg-3),var(--bg-2));
  opacity:0; visibility:hidden; transition:opacity .35s var(--ease);
}
.lead__form.is-done .lead__success{ opacity:1; visibility:visible; }
.lead__check{ width:64px; height:64px; border-radius:50%; display:grid; place-items:center; color:#15140c; background:linear-gradient(120deg,var(--gold-2),var(--gold) 55%,var(--gold-deep)); box-shadow:0 14px 34px -14px rgba(216,178,95,.7); }
.lead__check svg{ width:30px; height:30px; }
.lead__success h3{ font-weight:750; font-size:1.5rem; margin:0; }
.lead__success > p{ color:var(--muted); font-size:14.5px; max-width:34ch; margin:0; }
.lead__success a{ color:var(--gold-2); text-decoration:underline; }
.lead__again{ margin-top:6px; }

@media (max-width:880px){
  .lead__grid{ grid-template-columns:1fr; }
  .lead__intro h2{ max-width:none; }
}
@media (max-width:480px){
  .field-row{ grid-template-columns:1fr; }
}

/* brilho dourado desligado (tweak) */
body.no-glow .hero__halo, body.no-glow .hero__glow{ display:none; }
body.no-glow .btn--gold{ box-shadow:none; }

/* ============================================================
   V2 — HERO de marca, autoridade e quiz
   ============================================================ */

/* botão grande */
.btn--lg{ --bh:58px; padding-inline:30px; font-size:16px; }
.btn--lg svg{ width:20px; height:20px; }

/* hero copy v2 */
.hero__headline{
  font-weight:700; font-size:clamp(2.3rem,4.8vw,4rem); line-height:1.02;
  letter-spacing:-.028em; margin:.34em 0 0; color:var(--ink); text-wrap:balance;
}
.hero__sub{
  margin:1.35em 0 0; font-size:clamp(1.02rem,1.35vw,1.18rem);
  color:var(--ink-2); max-width:50ch; line-height:1.55;
}
.hero__benefits{
  list-style:none; margin:26px 0 0; padding:24px 0 0; border-top:1px solid var(--line-soft);
  display:grid; grid-template-columns:1fr 1fr; gap:14px 28px;
}
.hero__benefits li{
  display:flex; align-items:center; gap:11px;
  font-size:15.5px; color:var(--ink); letter-spacing:.005em;
}
.hero__benefits svg{
  width:22px; height:22px; flex:none; color:var(--accent);
  background:color-mix(in srgb, var(--accent) 16%, transparent);
  border-radius:50%; padding:3px;
}
.hero__cta{ margin-top:26px; }
.hero__microcopy{
  margin:13px 0 0; font-family:var(--mono); font-size:12.5px;
  letter-spacing:.02em; color:var(--muted);
}

/* hero stage v2 (coluna: garrafa, legenda, thumbs) */
.hero__stage{ display:flex; flex-direction:column; align-items:center; gap:14px; }
.hero__caption{ margin:0; text-align:center; min-height:46px; }
.hero__caption figcaption{ display:flex; flex-direction:column; gap:3px; }
.hero__cap-name{ font-weight:750; font-size:1.15rem; letter-spacing:.02em; color:var(--accent); }
.hero__cap-tag{ font-size:13.5px; color:var(--muted); }

@media (max-width:880px){
  .hero__benefits{ grid-template-columns:1fr; }
  .hero__stage{ order:2; }
}

/* ---- Autoridade ---- */
.authority{ background:var(--bg-2); border-top:1px solid var(--line-soft); border-bottom:1px solid var(--line-soft); }
.authority__in{ display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(32px,5vw,72px); align-items:center; }
.authority__lead h2{ font-weight:700; font-size:clamp(1.9rem,3.8vw,3rem); line-height:1.05; letter-spacing:-.02em; margin:.3em 0 0; }
.authority__text{ margin:1.2em 0 0; color:var(--ink-2); font-size:1.05rem; line-height:1.6; max-width:52ch; }
.authority__grid{
  list-style:none; margin:0; padding:0;
  display:grid; grid-template-columns:1fr 1fr; gap:10px;
}
.authority__grid li{
  display:flex; align-items:center; gap:11px;
  padding:15px 16px; border:1px solid var(--line); border-radius:14px;
  background:var(--bg-3); font-size:14.5px; color:var(--ink); font-weight:500;
}
.authority__grid li::before{
  content:""; width:7px; height:7px; border-radius:50%; flex:none;
  background:var(--gold); box-shadow:0 0 0 4px color-mix(in srgb, var(--gold) 18%, transparent);
}
@media (max-width:760px){
  .authority__in{ grid-template-columns:1fr; }
  .authority__grid{ grid-template-columns:1fr 1fr; }
}

/* ---- Cards: lista "Ideal para" ---- */
.card__ideal{ list-style:none; margin:2px 0 0; padding:0; display:grid; gap:7px; }
.card__ideal li{ display:flex; align-items:flex-start; gap:10px; font-size:14px; color:var(--ink-2); line-height:1.4; }
.card__ideal li::before{
  content:""; flex:none; width:8px; height:8px; margin-top:6px;
  border-radius:50%; border:2px solid color-mix(in srgb, var(--gold) 70%, transparent);
}
.shop__quizlink{ color:var(--gold-2); border-bottom:1px solid color-mix(in srgb,var(--gold) 40%, transparent); white-space:nowrap; }
.shop__quizlink:hover{ color:var(--gold); }

/* ============================================================
   QUIZ
   ============================================================ */
.quiz__head{ max-width:720px; margin:0 auto clamp(32px,5vw,52px); text-align:center; }
.quiz__head h2{ font-weight:700; font-size:clamp(2rem,4.4vw,3.3rem); line-height:1.04; letter-spacing:-.022em; margin:.3em 0 0; }
.quiz__sub{ margin:1.1em auto 0; color:var(--ink-2); max-width:56ch; font-size:1.04rem; line-height:1.6; }
.quiz__sub::first-line{ font-weight:600; }

.quiz__card{
  position:relative; max-width:760px; margin-inline:auto;
  border:1px solid var(--line); border-radius:var(--rad-l);
  background:linear-gradient(180deg,var(--bg-3),var(--bg-2));
  box-shadow:0 40px 90px -50px rgba(0,0,0,.85);
  overflow:hidden;
}
.quiz__screen{ padding:clamp(28px,4vw,52px); }

/* intro */
.quiz__intro{ text-align:center; position:relative; }
.quiz__introglow{
  position:absolute; left:50%; top:-30%; translate:-50% 0; width:80%; aspect-ratio:1;
  background:radial-gradient(circle at center, rgba(216,178,95,.16), transparent 60%);
  filter:blur(20px); pointer-events:none;
}
.quiz__badge{
  position:relative; display:inline-block; font-family:var(--mono); font-size:11.5px;
  letter-spacing:.12em; text-transform:uppercase; color:var(--gold-2);
  border:1px solid var(--line); border-radius:999px; padding:7px 14px; background:var(--bg-3);
}
.quiz__badge--accent{ color:var(--accent); border-color:color-mix(in srgb,var(--accent) 40%, transparent); }
.quiz__intro h3{ position:relative; font-weight:700; font-size:clamp(1.6rem,3vw,2.3rem); letter-spacing:-.02em; margin:.6em 0 0; }
.quiz__intro p{ position:relative; color:var(--ink-2); max-width:44ch; margin:.8em auto 1.6em; line-height:1.6; }
.quiz__intro .btn{ position:relative; }
.quiz__reassure{ display:block; margin-top:14px; font-size:12.5px; color:var(--muted); }

/* progresso */
.quiz__progress{ margin-bottom:28px; }
.quiz__progress-meta{ display:flex; justify-content:space-between; align-items:center; margin-bottom:12px; }
.quiz__step{ font-family:var(--mono); font-size:12.5px; letter-spacing:.04em; color:var(--muted); }
.quiz__step b{ color:var(--gold-2); }
.quiz__back{ appearance:none; background:none; border:0; color:var(--muted); font:inherit; font-size:13px; cursor:pointer; padding:4px; }
.quiz__back:hover{ color:var(--ink); }
.quiz__bar{ height:5px; border-radius:999px; background:rgba(243,239,226,.1); overflow:hidden; }
.quiz__bar-fill{
  display:block; height:100%; width:0;
  background:linear-gradient(90deg,var(--gold-deep),var(--gold) 60%,var(--gold-2));
  border-radius:999px; transition:width .45s var(--ease);
}

/* perguntas */
.quiz__fade{ animation:quizIn .42s var(--ease) both; }
@keyframes quizIn{ from{ opacity:0; transform:translateY(12px); } to{ opacity:1; transform:none; } }
.quiz__q{ font-weight:650; font-size:clamp(1.3rem,2.4vw,1.85rem); line-height:1.15; letter-spacing:-.01em; margin:0 0 22px; text-wrap:balance; }
.quiz__opts{ display:grid; gap:11px; }
.quiz__opt{
  display:flex; align-items:center; gap:14px; text-align:left; width:100%;
  padding:16px 18px; border:1px solid var(--line); border-radius:14px;
  background:var(--bg-3); color:var(--ink); font:inherit; font-size:15.5px; cursor:pointer;
  transition:border-color .2s, background .2s, transform .15s var(--ease);
}
.quiz__opt:hover{ border-color:color-mix(in srgb,var(--gold) 50%, transparent); transform:translateX(3px); }
.quiz__opt-mark{
  width:22px; height:22px; flex:none; border-radius:50%;
  border:2px solid color-mix(in srgb,var(--ink) 28%, transparent); position:relative; transition:border-color .2s;
}
.quiz__opt.is-sel{ border-color:var(--gold); background:color-mix(in srgb,var(--gold) 10%, var(--bg-3)); }
.quiz__opt.is-sel .quiz__opt-mark{ border-color:var(--gold); }
.quiz__opt.is-sel .quiz__opt-mark::after{
  content:""; position:absolute; inset:4px; border-radius:50%;
  background:linear-gradient(120deg,var(--gold-2),var(--gold));
}

/* resultado */
.quiz__result{ --accent:#e3c06a; }
.quiz__result-head{ text-align:center; }
.quiz__result-obj{ margin:14px 0 0; color:var(--ink-2); font-size:1.05rem; }
.quiz__result-obj b{ color:var(--ink); }
.quiz__result-grid{
  display:grid; grid-template-columns:.8fr 1.2fr; gap:clamp(18px,3vw,38px);
  align-items:center; margin:26px 0 30px;
  padding:24px; border:1px solid color-mix(in srgb,var(--accent) 30%, var(--line));
  border-radius:18px; background:color-mix(in srgb,var(--accent) 7%, var(--bg-3));
}
.quiz__result-visual{ position:relative; display:grid; place-items:center; min-height:200px; }
.quiz__result-glow{
  position:absolute; inset:0; margin:auto; width:80%; aspect-ratio:1; border-radius:50%;
  background:radial-gradient(circle at center, color-mix(in srgb,var(--accent) 42%, transparent), transparent 64%);
  filter:blur(12px);
}
.quiz__result-visual img{ position:relative; height:clamp(180px,26vw,250px); width:auto; filter:drop-shadow(0 30px 44px rgba(0,0,0,.55)); }
.quiz__result-tag{ font-family:var(--mono); font-size:11.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); }
.quiz__result-name{ font-weight:750; font-size:clamp(1.8rem,3.4vw,2.6rem); line-height:1; margin:.25em 0 0; }
.quiz__result-why{ margin:.8em 0 0; color:var(--ink-2); font-size:15px; line-height:1.55; }
.quiz__result-points{ list-style:none; margin:16px 0 0; padding:0; display:grid; gap:9px; }
.quiz__result-points li{ display:flex; align-items:center; gap:10px; font-size:14.5px; color:var(--ink); }
.quiz__result-points svg{ width:20px; height:20px; flex:none; color:var(--accent); }
@media (max-width:620px){
  .quiz__result-grid{ grid-template-columns:1fr; text-align:center; }
  .quiz__result-points li{ justify-content:center; }
  .quiz__result-visual{ min-height:auto; }
}

/* form do quiz */
.quiz__form{ border-top:1px solid var(--line-soft); padding-top:26px; }
.quiz__form-title{ font-weight:650; font-size:1.3rem; letter-spacing:-.01em; margin:0; text-align:center; }
.quiz__form-title span{ color:var(--gold-2); }
.quiz__form-sub{ margin:.5em auto 20px; color:var(--muted); font-size:14px; text-align:center; max-width:46ch; }
.quiz__fields{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:12px; }
.quiz__submit{ width:100%; margin-top:18px; }
.quiz__privacy{ margin:14px 0 0; font-size:12px; color:var(--muted); text-align:center; line-height:1.5; }
.quiz__restart{ display:block; margin:18px auto 0; appearance:none; background:none; border:0; color:var(--muted); font:inherit; font-size:13px; cursor:pointer; }
.quiz__restart:hover{ color:var(--ink); }
@media (max-width:620px){ .quiz__fields{ grid-template-columns:1fr; } }

/* sucesso */
.quiz__success{ display:none; text-align:center; padding:10px 0 4px; }
.quiz__form.is-done .quiz__fields,
.quiz__form.is-done .quiz__submit,
.quiz__form.is-done .quiz__privacy,
.quiz__form.is-done .quiz__form-title,
.quiz__form.is-done .quiz__form-sub{ display:none; }
.quiz__form.is-done .quiz__success{ display:block; animation:quizIn .4s var(--ease) both; }

/* ============================================================
   Animações de entrada
   ============================================================ */
@media (prefers-reduced-motion:no-preference){
  html:not([data-scrollfx="off"]) [data-rise]{
    opacity:0; transform:translateY(30px) scale(.985); filter:blur(7px);
    transition:opacity 1s var(--ease), transform 1.05s var(--ease), filter 1s var(--ease);
    will-change:opacity, transform, filter;
  }
  html:not([data-scrollfx="off"]) [data-rise].in{ opacity:1; transform:none; filter:none; }
  html:not([data-scrollfx="off"]) [data-rise][data-delay="1"]{ transition-delay:.1s; }
  html:not([data-scrollfx="off"]) [data-rise][data-delay="2"]{ transition-delay:.2s; }
  html:not([data-scrollfx="off"]) [data-rise][data-delay="3"]{ transition-delay:.3s; }
}
