/* ═══════════════════════════════════════════════════════════════
   CDI — Página de Vendas · SOFT PREMIUM
   Base: direção D4 (neutro quente · cantos arredondados · arejado).
   Seções alternam CLARO (branco/neutro) e NAVY ESCURO.
   Paleta 100% oficial Tracking HighEnd.
═══════════════════════════════════════════════════════════════ */

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

:root {
  /* ── claro ── */
  --bg: #F6F3EC;
  /* neutro quente */
  --bg-2: #FBF9F4;
  /* neutro mais claro */
  --white: #FFFFFF;
  --warm: #EEE7D8;
  /* tan suave p/ blocos */
  --ink: #13202E;
  /* navy texto */
  --ink-soft: #33414F;
  --mut: #646E78;
  /* secundário */
  --line: rgba(19, 32, 46, .1);
  --line-2: rgba(19, 32, 46, .06);
  /* ── navy (seções escuras) — night palette oficial ── */
  --night: #0A0C14;
  --night-2: #0D101C;
  --panel-d: #141829;
  --panel-d2: #181C2E;
  --sand: #EBD8C7;
  --sand-soft: #CABEB0;
  --mut-d: #8E92AD;
  --line-d: rgba(217, 200, 183, .12);
  --line-d2: rgba(217, 200, 183, .2);
  /* ── acentos oficiais ── */
  --gold: #CC9900;
  /* gold-3 — acento em claro */
  --gold-d: #A67D00;
  --gold-bright: #FFC30F;
  /* gold-2 — acento em escuro */
  --gold-soft: #F3E690;
  --copper: #C24412;
  /* problema em claro */
  --copper-br: #FC7148;
  /* problema em escuro */
  --green: #3E9A1A;
  /* positivo em claro */
  --green-br: #58D417;
  --blue: #1796D4;
  /* ── tipografia ── */
  --fd: 'Funnel Display', 'Times New Roman', serif;
  --fb: 'Plus Jakarta Sans', system-ui, sans-serif;
  --fm: 'JetBrains Mono', ui-monospace, monospace;
  --fs: 'Instrument Serif', Georgia, serif;
  /* ── layout ── */
  --maxw: 1340px;
  --narrow: 1340px;
  --gutter: clamp(18px, 3.5vw, 40px);
  --prose: min(52ch, 100%);
  --sect: clamp(76px, 10vw, 130px);
  --r: 18px;
  --r-lg: 24px;
  --r-pill: 100px;
}

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%
}

body {
  font-family: var(--fb);
  background: var(--bg);
  color: var(--ink-soft);
  line-height: 1.7;
  font-size: 17px;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased
}

::selection {
  background: rgba(204, 153, 0, .2);
  color: var(--ink)
}

a {
  color: inherit;
  text-decoration: none
}

img {
  max-width: 100%;
  display: block
}

strong {
  color: var(--ink);
  font-weight: 600
}

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

h1,
h2,
h3,
h4 {
  font-family: var(--fd);
  color: var(--ink);
  font-weight: 600;
  letter-spacing: -.025em;
  line-height: 1.08
}

h1 {
  font-size: clamp(2.4rem, 5vw, 3.85rem);
  letter-spacing: -.035em;
  line-height: 1.05
}

h2 {
  font-size: clamp(1.95rem, 3.9vw, 2.95rem);
  line-height: 1.08;
  letter-spacing: -.03em
}

h3 {
  font-size: clamp(1.2rem, 2vw, 1.5rem)
}

p {
  text-wrap: pretty
}

.serif {
  font-family: var(--fs);
  font-weight: 400;
  font-style: italic;
  letter-spacing: 0
}

.em-gold {
  color: var(--gold)
}

/* ── layout helpers ── */
.wrap {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 var(--gutter);
  width: 100%
}

.wrap-narrow {
  max-width: var(--narrow);
  margin: 0 auto;
  padding: 0 var(--gutter);
  width: 100%
}

section {
  padding: var(--sect) 0;
  position: relative
}

section.white {
  background: var(--white)
}

section.neutral {
  background: var(--bg)
}

section.warm {
  background: var(--bg-2)
}

/* ── SEÇÕES NAVY ── */
section.dark {
  background: var(--night);
  color: var(--sand-soft)
}

section.dark h1,
section.dark h2,
section.dark h3,
section.dark h4 {
  color: var(--sand)
}

section.dark strong {
  color: var(--sand)
}

section.dark .em-gold {
  color: var(--gold-bright)
}

/* ── eyebrow pill ── */
.ey {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-family: var(--fb);
  font-weight: 600;
  font-size: .76rem;
  letter-spacing: .01em;
  color: var(--gold-d);
  background: rgba(204, 153, 0, .12);
  padding: 7px 15px;
  border-radius: var(--r-pill);
  margin-bottom: 22px
}

.ey .d {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--gold)
}

.ey .n {
  font-variant-numeric: tabular-nums;
  opacity: .9
}

.dark .ey {
  color: var(--gold-bright);
  background: rgba(255, 195, 15, .1)
}

.dark .ey .d {
  background: var(--gold-bright)
}

/* ── buttons ── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  padding: 16px 30px;
  border-radius: var(--r-pill);
  font-family: var(--fb);
  font-weight: 700;
  font-size: 1rem;
  cursor: pointer;
  border: 1.5px solid transparent;
  line-height: 1;
  transition: transform .3s cubic-bezier(.16, 1, .3, 1), box-shadow .3s, background .3s, color .3s, border-color .3s
}

.btn .arrow {
  transition: transform .3s cubic-bezier(.16, 1, .3, 1)
}

.btn:hover .arrow {
  transform: translateX(4px)
}

.btn-primary {
  background: var(--gold);
  color: #1A1305;
  box-shadow: 0 12px 28px rgba(204, 153, 0, .3)
}

.btn:hover {
  transform: translateY(-2px) scale(1.02);
  filter: brightness(1.1)
}

.btn-primary:hover {
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 16px 34px rgba(204, 153, 0, .36)
}

.btn-ghost {
  background: transparent;
  color: var(--ink);
  border-color: var(--line)
}

.btn-ghost:hover {
  border-color: var(--gold);
  color: var(--gold-d)
}

.btn-lg {
  padding: 19px 38px;
  font-size: 1.06rem
}

.btn-block {
  width: 100%
}

.dark .btn-primary {
  background: linear-gradient(135deg, var(--gold-bright), var(--gold));
  color: #0A0C14;
  box-shadow: 0 12px 30px rgba(255, 195, 15, .22)
}

.dark .btn-ghost {
  color: var(--sand);
  border-color: var(--line-d2)
}

.dark .btn-ghost:hover {
  border-color: var(--gold-bright);
  color: var(--gold-bright)
}

/* ═════ NAV ═════ */
.nav {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 200;
  padding: 18px 0;
  transition: background .4s, box-shadow .4s, padding .4s
}

.nav.scrolled {
  background: rgba(246, 243, 236, .85);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow: 0 1px 0 var(--line);
  padding: 12px 0
}

.nav .wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px
}

.brand {
  display: flex;
  align-items: center;
  gap: 11px;
  flex-shrink: 0
}

.brand-mark {
  width: 27px;
  height: 29px;
  flex-shrink: 0
}

.brand-txt {
  display: flex;
  flex-direction: column;
  line-height: 1
}

.brand-name {
  font-family: var(--fd);
  font-weight: 700;
  font-size: 1.05rem;
  color: var(--ink);
  letter-spacing: -.01em
}

.brand-sub {
  font-family: var(--fm);
  font-size: .55rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--mut);
  margin-top: 4px
}

.nav-right {
  display: flex;
  align-items: center;
  gap: 18px
}

.nav-price {
  font-family: var(--fb);
  font-size: .84rem;
  color: var(--mut)
}

.nav-price b {
  color: var(--ink);
  font-weight: 700
}

.nav .btn {
  padding: 11px 22px;
  font-size: .86rem
}

@media(max-width:680px) {
  .nav-price {
    display: none
  }

  .brand-sub {
    display: none
  }
}

/* ═════ HERO ═════ */
.hero {
  padding: clamp(124px, 17vh, 170px) 0 var(--sect)
}

.hero-grid {
  display: grid;
  grid-template-columns: 1.06fr .94fr;
  gap: clamp(36px, 5vw, 64px);
  align-items: center
}

@media(max-width:940px) {
  .hero-grid {
    grid-template-columns: 1fr;
    gap: 46px
  }
}

.hero h1 {
  margin-bottom: 20px;
  max-width: none;
  text-wrap: balance
}

.hero h1 .em {
  color: var(--gold)
}

.hero-lead {
  font-family: var(--fs);
  font-style: italic;
  font-size: clamp(1.3rem, 2.1vw, 1.6rem);
  line-height: 1.4;
  color: var(--ink);
  margin-bottom: 16px;
  max-width: var(--prose)
}

.hero-sub {
  font-size: 1.05rem;
  color: var(--mut);
  line-height: 1.72;
  max-width: min(62ch, 100%);
  margin-bottom: 32px
}

.hero-cta {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
  margin-bottom: 36px
}

.hero-cta .note {
  font-family: var(--fb);
  font-size: .84rem;
  color: var(--mut)
}

.hero-cta .note b {
  color: var(--ink)
}

@media(max-width:520px) {
  .hero-cta .btn {
    width: 100%
  }
}

.proof {
  display: flex;
  gap: 32px;
  border-top: 1px solid var(--line);
  padding-top: 24px;
  flex-wrap: wrap
}

.proof .pf .n {
  font-family: var(--fd);
  font-size: 1.7rem;
  font-weight: 600;
  line-height: 1;
  color: var(--ink)
}

.proof .pf .n .u {
  color: var(--gold)
}

.proof .pf .l {
  font-family: var(--fb);
  font-size: .76rem;
  color: var(--mut);
  margin-top: 7px;
  max-width: none;
  line-height: 1.4
}

/* ── hero card (oferta resumo) ── */
.hcard {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  box-shadow: 0 34px 70px rgba(19, 32, 46, .1);
  padding: 30px
}

.hcard-h {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 22px
}

.hcard-t {
  font-family: var(--fd);
  font-weight: 600;
  font-size: 1.18rem;
  color: var(--ink)
}

.hcard-tag {
  font-family: var(--fb);
  font-size: .74rem;
  font-weight: 600;
  color: var(--gold-d);
  background: rgba(204, 153, 0, .13);
  padding: 6px 13px;
  border-radius: var(--r-pill)
}

.hmod {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 15px 0;
  border-bottom: 1px solid var(--line-2)
}

.hmod:last-of-type {
  border-bottom: 0
}

.hmod .ck {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: rgba(204, 153, 0, .15);
  color: var(--gold-d);
  display: grid;
  place-items: center;
  font-size: .82rem;
  flex-shrink: 0;
  font-weight: 700
}

.hmod .t {
  font-family: var(--fb);
  font-weight: 600;
  font-size: 1rem;
  color: var(--ink)
}

.hmod .t small {
  display: block;
  font-weight: 400;
  font-size: .83rem;
  color: var(--mut);
  margin-top: 2px
}

.hcard-f {
  margin-top: 22px;
  background: var(--warm);
  border-radius: var(--r);
  padding: 18px 20px;
  font-size: .9rem;
  line-height: 1.55;
  color: var(--ink-soft)
}

.hcard-f b {
  color: var(--gold-d)
}

/* ═════ STATS band ═════ */
.statband {
  background: var(--ink);
  border-radius: 0
}

.statband .wrap {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0
}

.statband .st {
  padding: clamp(36px, 5vw, 54px) 28px;
  text-align: center
}

.statband .st+.st {
  border-left: 1px solid var(--line-d)
}

.statband .st .n {
  font-family: var(--fd);
  font-weight: 600;
  font-size: clamp(2.2rem, 4.4vw, 3.2rem);
  color: var(--sand);
  line-height: 1;
  letter-spacing: -.03em
}

.statband .st .n .u {
  color: var(--gold-bright)
}

.statband .st .l {
  font-size: .86rem;
  color: var(--mut-d);
  margin-top: 12px;
  line-height: 1.5;
  max-width: 22ch;
  margin-inline: auto
}

@media(max-width:740px) {
  .statband .wrap {
    grid-template-columns: 1fr
  }

  .statband .st+.st {
    border-left: 0;
    border-top: 1px solid var(--line-d)
  }
}

/* ═════ section head ═════ */
.sec-head {
  max-width: var(--prose);
  margin-bottom: clamp(42px, 6vw, 68px)
}

.sec-head.wide {
  max-width: min(68ch, 100%)
}

.sec-head.full {
  max-width: none
}

.sec-head h2 {
  margin-bottom: 16px;
  text-wrap: balance
}

.sec-head .dek {
  font-size: 1.06rem;
  color: var(--mut);
  line-height: 1.7;
  max-width: min(68ch, 100%)
}

.dark .sec-head .dek {
  color: var(--sand-soft)
}

/* ═════ PROBLEMA (dark) ═════ */
.prob-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(38px, 5vw, 68px);
  align-items: center
}

@media(max-width:920px) {
  .prob-grid {
    grid-template-columns: 1fr;
    gap: 42px
  }
}

.prob-quote {
  font-family: var(--fs);
  font-style: italic;
  font-size: clamp(1.3rem, 2.4vw, 1.75rem);
  line-height: 1.42;
  color: var(--sand);
  padding-left: 22px;
  border-left: 2px solid var(--gold-bright)
}

.sym-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px
}

@media(max-width:520px) {
  .sym-cards {
    grid-template-columns: 1fr
  }
}

.sym-card {
  background: var(--panel-d);
  border: 1px solid var(--line-d);
  border-radius: var(--r);
  padding: 22px;
  display: flex;
  gap: 14px
}

.sym-card .x {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: rgba(252, 113, 72, .14);
  color: var(--copper-br);
  display: grid;
  place-items: center;
  font-size: .85rem;
  flex-shrink: 0;
  font-weight: 700
}

.sym-card p {
  font-size: .96rem;
  line-height: 1.58;
  color: var(--sand-soft)
}

.sym-card p b {
  color: var(--sand)
}

.prob-foot {
  margin-top: 30px;
  background: var(--panel-d);
  border: 1px solid var(--line-d);
  border-radius: var(--r);
  padding: 22px 24px;
  font-size: .98rem;
  color: var(--sand-soft);
  line-height: 1.65
}

.prob-foot strong {
  color: var(--gold-bright)
}

/* ═════ AUDIÊNCIA (light) ═════ */
.aud-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 22px
}

@media(max-width:880px) {
  .aud-grid {
    grid-template-columns: 1fr;
    gap: 18px
  }
}

.aud-col {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: clamp(26px, 3.4vw, 38px);
  box-shadow: 0 16px 40px rgba(19, 32, 46, .05)
}

.aud-col.yes {
  background: rgba(62, 154, 26, .06);
  border-color: rgba(62, 154, 26, .25)
}

.aud-col.no {
  background: var(--bg-2)
}

.aud-lab {
  font-family: var(--fd);
  font-weight: 600;
  font-size: 1.2rem;
  margin-bottom: 6px
}

.aud-col.yes .aud-lab {
  color: var(--green)
}

.aud-col.no .aud-lab {
  color: var(--copper)
}

.aud-lab .sm {
  display: block;
  font-family: var(--fb);
  font-weight: 400;
  font-size: .9rem;
  color: var(--mut);
  margin-top: 8px;
  line-height: 1.55
}

.aud-item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 13px;
  align-items: start;
  padding: 14px 0;
  border-bottom: 1px solid var(--line-2)
}

.aud-item:last-child {
  border-bottom: 0
}

.aud-item .mk {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: .74rem;
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 1px
}

.aud-col.yes .mk {
  background: rgba(62, 154, 26, .15);
  color: var(--green)
}

.aud-col.no .mk {
  background: rgba(100, 110, 120, .12);
  color: var(--mut)
}

.aud-item p {
  font-size: .96rem;
  color: var(--ink-soft);
  line-height: 1.55
}

.aud-item p strong {
  color: var(--ink)
}

.aud-note {
  grid-column: 1/-1;
  margin-top: 8px;
  text-align: left;
  font-size: .96rem;
  color: var(--mut);
  line-height: 1.7;
  max-width: min(72ch, 100%)
}

/* ═════ AUTORIDADE (dark) ═════ */
.auth-grid {
  display: grid;
  grid-template-columns: 1fr .9fr;
  gap: clamp(38px, 5vw, 68px);
  align-items: center
}

@media(max-width:920px) {
  .auth-grid {
    grid-template-columns: 1fr;
    gap: 42px
  }
}

.auth-body p {
  font-size: 1.06rem;
  color: var(--sand-soft);
  line-height: 1.78;
  margin-bottom: 18px
}

.auth-pull {
  font-family: var(--fs);
  font-style: italic;
  font-size: clamp(1.35rem, 2.5vw, 1.8rem);
  line-height: 1.38;
  color: var(--gold-soft);
  margin-top: 6px
}

.flow {
  background: var(--panel-d);
  border: 1px solid var(--line-d);
  border-radius: var(--r-lg);
  padding: 30px 26px
}

.flow-title {
  font-family: var(--fm);
  font-size: .66rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--mut-d);
  margin-bottom: 24px;
  text-align: center
}

.flow-track {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 4px
}

.flow-node {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  text-align: center
}

.flow-ico {
  width: 50px;
  height: 50px;
  border-radius: 14px;
  border: 1px solid var(--line-d2);
  display: grid;
  place-items: center;
  color: var(--sand);
  font-size: 1.15rem;
  background: rgba(235, 216, 199, .03)
}

.flow-node.key .flow-ico {
  border-color: rgba(255, 195, 15, .4);
  color: var(--gold-bright);
  background: rgba(255, 195, 15, .07)
}

.flow-node .nm {
  font-family: var(--fd);
  font-size: .92rem;
  color: var(--sand);
  font-weight: 500
}

.flow-node .sub {
  font-family: var(--fm);
  font-size: .55rem;
  letter-spacing: .04em;
  color: var(--mut-d);
  text-transform: uppercase
}

.flow-arr {
  align-self: center;
  color: var(--mut-d);
  font-size: .9rem;
  padding-top: 18px
}

.flow-cap {
  text-align: center;
  font-family: var(--fm);
  font-size: .64rem;
  letter-spacing: .06em;
  color: var(--gold-bright);
  margin-top: 24px;
  padding-top: 18px;
  border-top: 1px solid var(--line-d)
}

@media(max-width:600px) {
  .flow-track {
    flex-wrap: wrap;
    gap: 16px;
    justify-content: center
  }

  .flow-arr {
    display: none
  }

  .flow-node {
    flex: 0 0 38%
  }
}

/* ═════ O QUE RECEBE (light) ═════ */
.deliv {
  display: grid;
  gap: 22px
}

.deliv-card {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: 0 18px 44px rgba(19, 32, 46, .06)
}

.deliv-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: stretch
}

.deliv-grid.rev {
  direction: rtl
}

.deliv-grid.rev>* {
  direction: ltr
}

@media(max-width:840px) {

  .deliv-grid,
  .deliv-grid.rev {
    grid-template-columns: 1fr;
    direction: ltr
  }
}

.deliv-txt {
  padding: clamp(30px, 3.6vw, 44px);
  display: flex;
  flex-direction: column;
  justify-content: center
}

.deliv-cmd {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
  font-family: var(--fm);
  font-size: .7rem;
  color: var(--gold-d);
  background: rgba(204, 153, 0, .1);
  border-radius: var(--r-pill);
  padding: 6px 13px;
  margin-bottom: 16px
}

.deliv-cmd .d {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--green)
}

.deliv-txt h3 {
  margin-bottom: 12px;
  line-height: 1.18
}

.deliv-txt p {
  font-size: 1rem;
  color: var(--mut);
  line-height: 1.7;
  margin-bottom: 18px
}

.deliv-stack {
  display: flex;
  flex-wrap: wrap;
  gap: 8px
}

.chip {
  font-family: var(--fm);
  font-size: .68rem;
  color: var(--mut);
  border: 1px solid var(--line);
  border-radius: var(--r-pill);
  padding: 6px 13px;
  background: var(--bg-2)
}

.chip.on {
  border-color: rgba(204, 153, 0, .4);
  color: var(--gold-d);
  background: rgba(204, 153, 0, .08)
}

.deliv-media {
  position: relative;
  min-height: 300px;
  background: var(--warm)
}

@media(max-width:840px) {
  .deliv-media {
    min-height: 240px
  }
}

.deliv-media image-slot {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%
}

/* workflows */
.wf-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-top: 22px
}

@media(max-width:760px) {
  .wf-grid {
    grid-template-columns: 1fr 1fr
  }
}

@media(max-width:460px) {
  .wf-grid {
    grid-template-columns: 1fr
  }
}

.wf {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 22px 22px
}

.wf .wf-h {
  display: flex;
  align-items: baseline;
  gap: 10px;
  margin-bottom: 9px
}

.wf .wf-n {
  font-family: var(--fm);
  font-size: .66rem;
  color: var(--gold-d);
  font-weight: 500
}

.wf h4 {
  font-family: var(--fd);
  font-size: 1.08rem;
  color: var(--ink);
  font-weight: 600
}

.wf p {
  font-size: .88rem;
  color: var(--mut);
  line-height: 1.56
}

/* aulas */
.lessons {
  display: grid;
  gap: 14px;
  margin-top: 8px
}

.lesson {
  display: grid;
  grid-template-columns: 108px 1fr;
  gap: 24px;
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 24px 26px;
  align-items: start
}

@media(max-width:620px) {
  .lesson {
    grid-template-columns: 1fr;
    gap: 8px
  }
}

.lesson .ls-n {
  font-family: var(--fm);
  font-size: .8rem;
  color: var(--gold-d);
  padding-top: 4px;
  font-weight: 500
}

.lesson h4 {
  font-size: 1.16rem;
  margin-bottom: 7px;
  color: var(--ink)
}

.lesson p {
  font-size: .94rem;
  color: var(--mut);
  line-height: 1.62
}

/* ═════ COMPARATIVO (white) ═════ */
.cmp {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px
}

@media(max-width:760px) {
  .cmp {
    grid-template-columns: 1fr
  }
}

.cmp-col {
  border-radius: var(--r-lg);
  padding: clamp(28px, 3.4vw, 40px);
  border: 1px solid var(--line)
}

.cmp-col.without {
  background: var(--bg-2)
}

.cmp-col.with {
  background: linear-gradient(180deg, rgba(204, 153, 0, .08), var(--white) 70%);
  border-color: rgba(204, 153, 0, .3)
}

.cmp-col h3 {
  font-size: 1.18rem;
  margin-bottom: 22px;
  display: flex;
  align-items: center;
  gap: 10px
}

.cmp-col.without h3 {
  color: var(--copper)
}

.cmp-col.with h3 {
  color: var(--gold-d)
}

.cmp-col h3 .badge {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: .85rem;
  font-weight: 700
}

.cmp-col.without h3 .badge {
  background: rgba(194, 68, 18, .12);
  color: var(--copper)
}

.cmp-col.with h3 .badge {
  background: rgba(204, 153, 0, .16);
  color: var(--gold-d)
}

.cmp-item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  padding: 13px 0;
  border-bottom: 1px solid var(--line-2);
  font-size: .96rem;
  line-height: 1.5
}

.cmp-item:last-child {
  border-bottom: 0
}

.cmp-item .m {
  font-weight: 700;
  font-size: .9rem;
  line-height: 1.5
}

.cmp-col.without .cmp-item {
  color: var(--mut)
}

.cmp-col.without .m {
  color: var(--copper)
}

.cmp-col.with .cmp-item {
  color: var(--ink-soft)
}

.cmp-col.with .m {
  color: var(--green)
}

/* ═════ TRANSFORMAÇÃO (dark) ═════ */
.trans-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px
}

@media(max-width:720px) {
  .trans-grid {
    grid-template-columns: 1fr
  }
}

.trans {
  background: var(--panel-d);
  border: 1px solid var(--line-d);
  border-radius: var(--r-lg);
  padding: clamp(28px, 3.2vw, 38px)
}

.trans .tn {
  display: inline-block;
  font-family: var(--fm);
  font-size: .66rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--gold-bright);
  background: rgba(255, 195, 15, .08);
  padding: 5px 12px;
  border-radius: var(--r-pill);
  margin-bottom: 16px
}

.trans h3 {
  font-size: 1.28rem;
  margin-bottom: 12px;
  line-height: 1.2
}

.trans p {
  font-size: .97rem;
  color: var(--sand-soft);
  line-height: 1.7
}

.trans p strong {
  color: var(--sand)
}

/* ═════ PROFESSOR (light) ═════ */
.prof {
  display: grid;
  grid-template-columns: .78fr 1.22fr;
  gap: clamp(34px, 4.5vw, 60px);
  align-items: center
}

@media(max-width:840px) {
  .prof {
    grid-template-columns: 1fr;
    gap: 38px
  }
}

.prof-photo {
  position: relative;
  aspect-ratio: 4/5;
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--warm);
  box-shadow: 0 24px 54px rgba(19, 32, 46, .12)
}

.prof-photo image-slot {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%
}

.prof-photo .pf-tag {
  position: absolute;
  left: 14px;
  bottom: 14px;
  z-index: 3;
  font-family: var(--fb);
  font-weight: 600;
  font-size: .72rem;
  color: #1A1305;
  background: var(--gold);
  padding: 8px 14px;
  border-radius: var(--r-pill)
}

.prof-role {
  font-family: var(--fb);
  font-weight: 600;
  font-size: .82rem;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--gold-d);
  margin-bottom: 10px
}

.prof h3 {
  font-size: clamp(1.7rem, 3vw, 2.25rem);
  margin-bottom: 18px
}

.prof-body p {
  font-size: 1.04rem;
  color: var(--mut);
  line-height: 1.76;
  margin-bottom: 16px
}

.prof-body p strong {
  color: var(--ink)
}

.prof-tech {
  margin-top: 22px;
  padding: 22px 24px;
  border-radius: var(--r);
  background: var(--warm);
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 16px;
  align-items: start
}

.prof-tech .ic {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  background: var(--white);
  display: grid;
  place-items: center;
  font-size: 1.2rem;
  color: var(--gold-d)
}

.prof-tech p {
  font-size: .92rem;
  color: var(--ink-soft);
  line-height: 1.62;
  margin: 0
}

.prof-tech p strong {
  color: var(--ink)
}

/* ═════ TRANSPARÊNCIA (white) ═════ */
.transp {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px
}

@media(max-width:680px) {
  .transp {
    grid-template-columns: 1fr
  }
}

.transp-item {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--r);
  padding: 26px 28px
}

.transp-item .num {
  display: inline-block;
  font-family: var(--fb);
  font-weight: 700;
  font-size: .78rem;
  padding: 5px 13px;
  border-radius: var(--r-pill);
  margin-bottom: 14px
}

.transp-item.is .num {
  background: rgba(62, 154, 26, .12);
  color: var(--green)
}

.transp-item.not .num {
  background: rgba(194, 68, 18, .1);
  color: var(--copper)
}

.transp-item p {
  font-size: .98rem;
  color: var(--ink-soft);
  line-height: 1.64
}

.transp-item p strong {
  color: var(--ink)
}

/* ═════ OFERTA (warm light) ═════ */
.offer {
  max-width: none;
  width: 100%;
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  box-shadow: 0 34px 70px rgba(19, 32, 46, .1);
  overflow: hidden
}

.offer-top {
  padding: 16px 26px;
  background: var(--warm);
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-family: var(--fb);
  font-weight: 600;
  font-size: .8rem;
  color: var(--ink)
}

.offer-top .pulse {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--gold-d)
}

.offer-top .pulse i {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--gold)
}

.offer-body {
  display: grid;
  grid-template-columns: 1fr 1fr
}

.offer-col {
  padding: clamp(30px, 4vw, 46px)
}

.offer-col+.offer-col {
  border-left: 1px solid var(--line-2)
}

.offer-price {
  text-align: center;
  padding: 26px 0;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--r);
  margin-bottom: 24px
}

.offer-price .tag {
  font-family: var(--fb);
  font-weight: 600;
  font-size: .76rem;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--gold-d);
  margin-bottom: 12px
}

.offer-price .was {
  font-family: var(--fb);
  font-size: 1rem;
  color: var(--mut);
  text-decoration: line-through;
  margin-bottom: 2px
}

.offer-price .now {
  font-family: var(--fd);
  font-weight: 700;
  font-size: clamp(3rem, 7.5vw, 4.2rem);
  color: var(--ink);
  line-height: .95;
  letter-spacing: -.04em
}

.offer-price .now sup {
  font-size: .4em;
  vertical-align: super;
  color: var(--gold-d);
  font-weight: 500;
  margin-right: 4px
}

.offer-price .inst {
  font-family: var(--fb);
  font-size: .86rem;
  color: var(--mut);
  margin-top: 12px
}

.offer-benefits {
  display: grid;
  gap: 14px;
  margin-bottom: 28px
}

.offer-benefit {
  display: flex;
  align-items: center;
  gap: 11px;
  font-size: .92rem;
  color: var(--ink-soft)
}

.offer-benefit .ic {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: rgba(204, 153, 0, .12);
  color: var(--gold-d);
  display: grid;
  place-items: center;
  flex-shrink: 0;
  font-size: .84rem
}

.offer-guard {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  font-size: .88rem;
  color: var(--mut)
}

.offer-guard .sh {
  color: var(--gold-d)
}

.offer-col-title {
  font-family: var(--fb);
  font-weight: 600;
  font-size: .94rem;
  color: var(--ink);
  margin-bottom: 18px
}

.offer-list {
  display: grid;
  gap: 0;
  margin-bottom: 24px
}

.offer-row {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 14px;
  padding: 13px 0;
  border-bottom: 1px solid var(--line-2);
  align-items: start
}

.offer-row:last-child {
  border-bottom: 0
}

.offer-row .ck {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: rgba(204, 153, 0, .15);
  color: var(--gold-d);
  display: grid;
  place-items: center;
  font-weight: 700;
  font-size: .78rem;
  flex-shrink: 0;
  margin-top: 1px
}

.offer-row .ck.ck-green {
  background: rgba(62, 154, 26, .14);
  color: var(--green)
}

.offer-row p {
  font-size: .98rem;
  line-height: 1.55;
  color: var(--ink-soft)
}

.offer-row p b {
  color: var(--ink);
  font-weight: 600
}

.offer-roi {
  padding: 20px 22px;
  border-radius: var(--r);
  background: var(--warm);
  font-size: .95rem;
  color: var(--ink-soft);
  line-height: 1.64;
  text-align: center
}

.offer-roi strong {
  color: var(--gold-d)
}

@media(max-width:880px) {
  .offer-body {
    grid-template-columns: 1fr
  }

  .offer-col+.offer-col {
    border-left: 0;
    border-top: 1px solid var(--line-2)
  }
}

/* ═════ GARANTIA ═════ */
section[data-screen-label="Garantia"] {
  padding-top: clamp(28px, 4vw, 48px)
}

.guard-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(18px, 2.4vw, 28px);
  margin-top: clamp(48px, 6vw, 72px);
  margin-bottom: clamp(18px, 2.4vw, 28px)
}

.guard-card {
  position: relative;
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  box-shadow: 0 24px 54px rgba(19, 32, 46, .08);
  padding: clamp(64px, 7vw, 86px) clamp(28px, 3.6vw, 40px) clamp(34px, 4vw, 46px);
  text-align: center
}

.guard-seal {
  position: absolute;
  top: 0;
  left: 50%;
  width: clamp(124px, 15vw, 158px);
  height: auto;
  transform: translate(-50%, -50%);
  filter: drop-shadow(0 14px 28px rgba(19, 32, 46, .16))
}

.guard-card-title {
  font-family: var(--fd);
  font-weight: 600;
  font-size: 1.1rem;
  letter-spacing: -.01em;
  color: var(--ink);
  margin-bottom: 12px
}

.guard-card-text {
  font-size: .96rem;
  line-height: 1.62;
  color: var(--mut);
  max-width: 38ch;
  margin: 0 auto
}

.guard-card-text strong {
  color: var(--ink)
}

.guard-note {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  box-shadow: 0 24px 54px rgba(19, 32, 46, .08);
  padding: clamp(32px, 4vw, 44px) clamp(28px, 4vw, 56px);
  text-align: center
}

.guard-note-title {
  font-family: var(--fb);
  font-weight: 600;
  font-size: 1rem;
  color: var(--ink);
  margin-bottom: 14px
}

.guard-note-text {
  font-size: .98rem;
  line-height: 1.66;
  color: var(--mut);
  max-width: 64ch;
  margin: 0 auto 16px
}

.guard-note-em {
  font-family: var(--fs);
  font-style: italic;
  font-size: clamp(1.05rem, 2vw, 1.25rem);
  color: var(--gold-d);
  max-width: 52ch;
  margin: 0 auto
}

@media(max-width:760px) {
  .guard-grid {
    grid-template-columns: 1fr;
    gap: 92px;
    margin-top: 110px
  }

  .guard-card {
    padding-top: clamp(96px, 27vw, 116px)
  }

  .guard-seal {
    width: clamp(160px, 42vw, 204px)
  }
}

/* ═════ FAQ (light) ═════ */
.faq {
  display: grid;
  gap: 12px
}

.faq details {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r);
  overflow: hidden;
  transition: border-color .3s
}

.faq details[open] {
  border-color: rgba(204, 153, 0, .3)
}

.faq summary {
  list-style: none;
  cursor: pointer;
  padding: 22px 26px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  font-family: var(--fd);
  font-size: clamp(1.05rem, 1.7vw, 1.25rem);
  color: var(--ink);
  font-weight: 600
}

.faq summary::-webkit-details-marker {
  display: none
}

.faq summary .pm {
  flex: 0 0 auto;
  width: 22px;
  height: 22px;
  position: relative
}

.faq summary .pm::before,
.faq summary .pm::after {
  content: '';
  position: absolute;
  background: var(--gold-d);
  transition: opacity .3s, transform .3s
}

.faq summary .pm::before {
  top: 10px;
  left: 0;
  width: 22px;
  height: 2px
}

.faq summary .pm::after {
  top: 0;
  left: 10px;
  width: 2px;
  height: 22px
}

.faq details[open] summary .pm::after {
  opacity: 0
}

.faq .ans {
  padding: 0 26px 24px;
  font-size: 1rem;
  color: var(--mut);
  line-height: 1.74;
  max-width: none
}

/* ═════ FINAL CTA (dark) ═════ */
.final {
  text-align: left
}

.final h2 {
  margin-bottom: 20px;
  max-width: min(32ch, 100%);
  text-wrap: balance
}

.final h2 .em-gold {
  color: var(--gold-bright)
}

.final-sub {
  font-size: 1.08rem;
  color: var(--sand-soft);
  line-height: 1.7;
  max-width: min(64ch, 100%);
  margin: 0 0 14px
}

.final-price {
  font-family: var(--fs);
  font-style: italic;
  font-size: 1.3rem;
  color: var(--gold-soft);
  margin-bottom: 32px
}

.final .btn {
  margin-bottom: 18px
}

.final-meta {
  font-family: var(--fm);
  font-size: .78rem;
  letter-spacing: .04em;
  color: var(--mut-d)
}

/* ═════ FOOTER (dark) ═════ */
.foot {
  background: var(--night-2);
  padding: 50px 0 56px
}

.foot .wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 22px;
  align-items: center;
  justify-content: space-between
}

.foot .f-brand {
  display: flex;
  align-items: center;
  gap: 11px
}

.foot .f-brand .brand-mark {
  width: 24px;
  height: 26px
}

.foot .f-brand .brand-name {
  color: var(--sand)
}

.foot .f-tag {
  font-size: .9rem;
  color: var(--mut-d);
  max-width: 46ch;
  line-height: 1.6
}

.foot .f-disc {
  flex: 1 1 100%;
  margin-top: 10px;
  padding-top: 24px;
  border-top: 1px solid var(--line-d);
  font-size: .78rem;
  color: var(--mut-d);
  line-height: 1.6;
  opacity: .8
}

/* ═════ reveal ═════ */
.reveal {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .8s cubic-bezier(.16, 1, .3, 1), transform .8s cubic-bezier(.16, 1, .3, 1)
}

.reveal.in {
  opacity: 1;
  transform: none
}

.reveal[data-d="1"] {
  transition-delay: .08s
}

.reveal[data-d="2"] {
  transition-delay: .16s
}

@media(prefers-reduced-motion:reduce) {
  * {
    animation: none !important;
    transition: none !important;
    scroll-behavior: auto !important
  }

  .reveal {
    opacity: 1;
    transform: none
  }
}

/* ═════ PROBLEMA — Cinematic Dashboard (v2 port) ═════ */
.dark.prob-cinematic {
  background:
    radial-gradient(ellipse 90% 70% at 80% 30%, rgba(252, 113, 72, .05) 0%, transparent 55%),
    radial-gradient(ellipse 70% 50% at 10% 70%, rgba(23, 150, 212, .04) 0%, transparent 55%),
    var(--night)
}

.prob-cinematic::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255, 195, 15, .018) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 195, 15, .018) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse at 70% 50%, #000 0%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse at 70% 50%, #000 0%, transparent 75%)
}

.prob-cinematic>.wrap {
  position: relative;
  z-index: 1
}

.vc-grid {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: 80px;
  align-items: center
}

@media(max-width:1024px) {
  .vc-grid {
    grid-template-columns: 1fr;
    gap: 56px
  }
}

.vc-left {
  display: flex;
  flex-direction: column;
  gap: 32px
}

.vc-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: var(--fm);
  font-size: .62rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--copper-br);
  width: fit-content
}

.vc-eyebrow-line {
  width: 36px;
  height: 1px;
  background: var(--copper-br)
}

.vc-eyebrow-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--copper-br);
  box-shadow: 0 0 12px var(--copper-br);
  animation: vcPulse 1.6s ease-in-out infinite
}

@keyframes vcPulse {

  0%,
  100% {
    opacity: 1
  }

  50% {
    opacity: .35
  }
}

.vc-h2 {
  font-weight: 300;
  font-size: clamp(1.8rem, 3.4vw, 2.6rem);
  letter-spacing: -.035em;
  line-height: 1.08;
  margin: 0
}

.vc-h2 strong {
  font-weight: 500
}

.vc-syms {
  display: grid;
  gap: 0
}

.vc-sym {
  display: grid;
  grid-template-columns: 20px 1fr;
  gap: 14px;
  align-items: start;
  padding: 14px 0;
  border-bottom: 1px solid var(--line-d);
  font-size: .92rem;
  color: var(--sand-soft);
  line-height: 1.55;
  letter-spacing: -.003em
}

.vc-sym:first-child {
  border-top: 1px solid var(--line-d)
}

.vc-sym strong {
  color: var(--sand);
  font-weight: 600
}

.vc-sym-x {
  color: var(--copper-br);
  font-weight: 700;
  font-size: .95rem;
  line-height: 1.4;
  font-family: var(--fm)
}

.vc-quote {
  position: relative;
  padding-top: 24px;
  border-top: 1px solid var(--line-d);
  margin: 0
}

.vc-quote-mark {
  position: absolute;
  top: 8px;
  left: -4px;
  font-family: var(--fd);
  font-weight: 300;
  font-size: 3rem;
  line-height: .4;
  color: rgba(255, 195, 15, .35)
}

.vc-quote-text {
  font-family: var(--fs);
  font-style: italic;
  font-size: 1.05rem;
  color: var(--sand);
  line-height: 1.4;
  letter-spacing: -.01em;
  padding-left: 32px
}

.vc-dash-wrap {
  position: relative;
  perspective: 1400px
}

.vc-dash {
  position: relative;
  background: linear-gradient(180deg, rgba(11, 13, 24, .95) 0%, rgba(13, 15, 28, .92) 100%);
  border: 1px solid rgba(255, 195, 15, .18);
  border-radius: 16px;
  box-shadow: 0 50px 100px -20px rgba(0, 0, 0, .7), 0 30px 60px -15px rgba(252, 113, 72, .15), inset 0 1px 0 rgba(255, 255, 255, .05);
  overflow: hidden;
  transform: rotate3d(0, 1, 0, -3deg) rotate3d(1, 0, 0, 2deg);
  transition: transform .6s cubic-bezier(.16, 1, .3, 1)
}

.vc-dash-wrap:hover .vc-dash {
  transform: rotate3d(0, 1, 0, 0) rotate3d(1, 0, 0, 0)
}

@media(max-width:1024px) {

  .vc-dash,
  .vc-dash-wrap:hover .vc-dash {
    transform: none
  }
}

.vc-dash::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  z-index: -1;
  pointer-events: none;
  background: linear-gradient(135deg, rgba(252, 113, 72, .45) 0%, rgba(252, 113, 72, .06) 30%, rgba(255, 195, 15, .12) 65%, rgba(252, 113, 72, .32) 100%)
}

.vc-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  background: rgba(8, 9, 15, .7);
  border-bottom: 1px solid var(--line-d)
}

.vc-bar-dots {
  display: flex;
  gap: 6px
}

.vc-bar-dots span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(217, 200, 183, .18)
}

.vc-bar-path {
  font-family: var(--fm);
  font-size: .66rem;
  color: var(--mut-d);
  letter-spacing: .04em;
  margin-left: 8px;
  display: flex;
  align-items: center;
  gap: 8px
}

.vc-bar-tab {
  display: inline-block;
  padding: 3px 10px;
  background: rgba(252, 113, 72, .1);
  border: 1px solid rgba(252, 113, 72, .25);
  border-radius: 4px;
  color: var(--copper-br);
  font-weight: 600
}

.vc-bar-status {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 7px;
  font-family: var(--fm);
  font-size: .6rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--copper-br)
}

.vc-bar-status-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--copper-br);
  box-shadow: 0 0 8px var(--copper-br);
  animation: vcBlink 1.4s ease-in-out infinite
}

@keyframes vcBlink {

  0%,
  100% {
    opacity: 1
  }

  50% {
    opacity: .3
  }
}

.vc-body {
  padding: 24px 22px;
  background: radial-gradient(ellipse at 20% 0%, rgba(23, 150, 212, .04) 0%, transparent 50%), radial-gradient(ellipse at 80% 100%, rgba(252, 113, 72, .04) 0%, transparent 50%), #0f1220;
  display: grid;
  grid-template-columns: 1fr 28px 1fr 28px .58fr;
  gap: 0;
  align-items: stretch;
  position: relative
}

@media(max-width:760px) {
  .vc-body {
    grid-template-columns: 1fr;
    gap: 18px
  }

  .vc-neq-slot {
    display: none
  }
}

.vc-neq-slot {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  align-self: stretch;
  padding: 8px 0;
  gap: 8px
}

.vc-neq {
  font-family: var(--fd);
  font-weight: 400;
  font-size: 1.5rem;
  line-height: 1;
  color: var(--copper-br);
  letter-spacing: -.04em;
  text-shadow: 0 0 8px rgba(252, 113, 72, .5);
  animation: vcNeqPulse 1.4s ease-in-out infinite;
  user-select: none
}

@keyframes vcNeqPulse {

  0%,
  100% {
    opacity: 1
  }

  50% {
    opacity: .3
  }
}

.vc-app {
  background: #fff;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 10px 28px rgba(0, 0, 0, .45), 0 0 0 1px rgba(0, 0, 0, .4);
  font-family: 'Helvetica Neue', sans-serif;
  position: relative;
  transition: transform .35s cubic-bezier(.16, 1, .3, 1);
  display: flex;
  flex-direction: column
}

.vc-app:hover {
  transform: translateY(-3px)
}

.vc-app-head {
  padding: 12px 14px;
  display: flex;
  align-items: center;
  gap: 9px;
  color: #fff;
  font-size: .86rem;
  font-weight: 600;
  letter-spacing: -.008em
}

.vc-app-head svg {
  flex-shrink: 0;
  display: block
}

.vc-app--meta .vc-app-head {
  background: #1877F2
}

.vc-app--meta .vc-app-body {
  background: #1c2733;
  color: #e4e6eb
}

.vc-app--meta .vc-row {
  border-bottom: 1px solid rgba(255, 255, 255, .06)
}

.vc-app--meta .vc-row-key {
  color: #b0b3b8
}

.vc-app--meta .vc-row-val {
  color: #fff
}

.vc-app--sheets .vc-app-head {
  background: #0F9D58
}

.vc-app--sheets .vc-app-body {
  background: #fff;
  color: #202124
}

.vc-app--sheets .vc-row {
  border-bottom: 1px solid #e8eaed
}

.vc-app--sheets .vc-row-key {
  color: #5f6368;
  background: #f8f9fa;
  font-weight: 500
}

.vc-app--sheets .vc-row-val {
  color: #202124;
  font-variant-numeric: tabular-nums
}

.vc-app--checkout .vc-app-head {
  background: linear-gradient(135deg, #635BFF 0%, #5851EC 100%)
}

.vc-app--checkout .vc-app-body {
  background: #fff;
  color: #1a1f36
}

.vc-app--checkout .vc-row {
  border-bottom: 1px solid #f0f1f5
}

.vc-app--checkout .vc-row-key {
  color: #6b7c93;
  font-weight: 500
}

.vc-app--checkout .vc-row-val {
  color: #1a1f36;
  font-weight: 600;
  font-variant-numeric: tabular-nums
}

.vc-app-body {
  padding: 0;
  font-size: .88rem
}

.vc-row {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  position: relative
}

.vc-row:last-child {
  border-bottom: none
}

.vc-row-key {
  font-size: .8rem;
  letter-spacing: .005em
}

.vc-row-val {
  font-size: .88rem;
  font-weight: 600;
  font-variant-numeric: tabular-nums
}

.vc-row.is-empty .vc-row-key,
.vc-row.is-empty .vc-row-val {
  visibility: hidden
}

.vc-foot {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 20px;
  background: rgba(252, 113, 72, .08);
  border-top: 1px solid rgba(252, 113, 72, .25);
  font-family: var(--fm);
  font-size: .7rem;
  color: var(--copper-br);
  letter-spacing: .04em
}

.vc-foot-icon {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--copper-br);
  color: var(--night);
  display: grid;
  place-items: center;
  font-weight: 700;
  font-size: .78rem
}

.vc-foot strong {
  color: var(--sand);
  font-weight: 600
}

/* ═══════════════════════════════════════════════════════════════
   DATA-SURFACE · textura de instrumentação (autoridade em tracking)
   Superfície de plotagem em toda a página no lugar de fundos chapados.
   Claras: grade de pontos (canvas de dados). Escuras: grade técnica
   (blueprint). Sem glow ambiente, sem mesh, sem neon. Intensidade:
   sussurro (alpha baixo + bordas em fade por máscara).
═══════════════════════════════════════════════════════════════ */

/* stacking: conteúdo sempre acima da textura */
.hero,
section.neutral,
section.warm,
section.white,
section.dark:not(.prob-cinematic),
.foot {
  position: relative
}

.hero>.wrap,
section>.wrap,
.foot>.wrap {
  position: relative;
  z-index: 1
}

/* ── seções claras: canvas de pontos ── */
.hero::before,
section.neutral::before,
section.warm::before,
section.white::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background-image: radial-gradient(rgba(19, 32, 46, .055) 1.1px, transparent 1.3px);
  background-size: 30px 30px;
  background-position: center;
  -webkit-mask-image: radial-gradient(ellipse 94% 80% at 50% 42%, #000 48%, transparent 100%);
  mask-image: radial-gradient(ellipse 94% 80% at 50% 42%, #000 48%, transparent 100%);
}

section.white::before {
  background-image: radial-gradient(rgba(19, 32, 46, .045) 1.1px, transparent 1.3px)
}

/* ── seções escuras: background da hero + dot grid dourado ── */
section.dark:not(.prob-cinematic) {
  background: #06060A
}

section.dark:not(.prob-cinematic)::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background-image: radial-gradient(rgba(204,153,0,.12) 1.2px, transparent 1.2px);
  background-size: 30px 30px;
  -webkit-mask-image: radial-gradient(ellipse 96% 82% at 50% 30%, #000 42%, transparent 100%);
  mask-image: radial-gradient(ellipse 96% 82% at 50% 30%, #000 42%, transparent 100%);
}

/* ── HERO: mesa de comando · elevação de topo + convergência da marca ── */
.hero,
section.hero-like {
  background: linear-gradient(180deg, rgba(255, 255, 255, .55) 0%, transparent 26%), var(--bg)
}

section.hero-like {
  position: relative
}

section.hero-like::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background-image: radial-gradient(rgba(19, 32, 46, .055) 1.1px, transparent 1.3px);
  background-size: 30px 30px;
  background-position: center;
  -webkit-mask-image: radial-gradient(ellipse 94% 80% at 50% 42%, #000 48%, transparent 100%);
  mask-image: radial-gradient(ellipse 94% 80% at 50% 42%, #000 48%, transparent 100%);
}

section.hero-like > .wrap {
  position: relative;
  z-index: 1
}

.hero::after {
  content: '';
  position: absolute;
  top: clamp(88px, 11vh, 140px);
  right: clamp(8px, 3vw, 56px);
  z-index: 0;
  pointer-events: none;
  width: min(480px, 40vw);
  aspect-ratio: 14/15;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 130' fill='none'%3E%3Cline x1='6' y1='12' x2='60' y2='66' stroke='%2313202E' stroke-opacity='.08' stroke-width='.85' stroke-linecap='round'/%3E%3Cline x1='114' y1='12' x2='60' y2='66' stroke='%2313202E' stroke-opacity='.08' stroke-width='.85' stroke-linecap='round'/%3E%3Cline x1='60' y1='66' x2='60' y2='126' stroke='%23CC9900' stroke-opacity='.16' stroke-width='.85' stroke-linecap='round'/%3E%3Ccircle cx='6' cy='12' r='1.7' fill='%2313202E' fill-opacity='.12'/%3E%3Ccircle cx='114' cy='12' r='1.7' fill='%2313202E' fill-opacity='.12'/%3E%3Ccircle cx='60' cy='66' r='4.2' fill='%23CC9900' fill-opacity='.1'/%3E%3Ccircle cx='60' cy='66' r='4.2' stroke='%23CC9900' stroke-opacity='.24' stroke-width='.7'/%3E%3C/svg%3E");
  -webkit-mask-image: radial-gradient(ellipse 80% 80% at 55% 45%, #000 40%, transparent 78%);
  mask-image: radial-gradient(ellipse 80% 80% at 55% 45%, #000 40%, transparent 78%);
}

@media(max-width:940px) {
  .hero::after {
    display: none
  }
}

/* ── FOOTER: superfície técnica discreta ── */
.foot::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background-image:
    linear-gradient(rgba(235, 216, 199, .03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(235, 216, 199, .03) 1px, transparent 1px);
  background-size: 62px 62px;
  -webkit-mask-image: radial-gradient(ellipse 90% 90% at 50% 0%, #000 30%, transparent 90%);
  mask-image: radial-gradient(ellipse 90% 90% at 50% 0%, #000 30%, transparent 90%);
}

/* respeita reduced-motion já tratado; textura é estática, sem custo de repaint */
@media(prefers-reduced-motion:reduce) {

  .vc-eyebrow-dot,
  .vc-bar-status-dot,
  .vc-neq {
    animation: none !important
  }
}

/* ═══════════════════════════════════════════════════════════════
   HERO — copy no fluxo · diagrama cortado (img) logo abaixo
═══════════════════════════════════════════════════════════════ */
.hero-canvas.hero--diagram {
  --hero-copy-w: min(90ch, 100%);
  --hero-diag-max: 1500px;
  position: relative;
  isolation: isolate;
  text-align: center;
  overflow: visible;
  background: var(--bg);
}

.hero-canvas.hero--diagram::before {
  display: none !important
}

.hero-canvas.hero--diagram::after {
  content: '';
  display: block;
  height: clamp(48px, 7vw, 88px);
  background: #F8EFEA;
  position: relative;
  z-index: 2;
}

/* camada 1 — HTML hero (topo) */
.hero-canvas>.hero {
  position: relative;
  z-index: 3;
  margin: 0;
  padding: clamp(100px, 12vh, 130px) 0 clamp(8px, 1.5vw, 16px);
  background: transparent;
  text-align: center;
}

.hero-canvas>.hero::before,
.hero-canvas>.hero::after {
  display: none !important
}

/* camadas 2 e 3 — diagrama (degradê sobre a imagem) */
.hero-diagram {
  position: relative;
  z-index: 1;
  margin: clamp(-52px, -5.5vw, -80px) 0 0;
  padding: 0;
  line-height: 0;
  border: 0;
}

/* camada 3 — imagem (base) */
.hero-diagram img {
  position: relative;
  z-index: 1;
  display: block;
  width: min(100%, var(--hero-diag-max));
  max-width: 100%;
  height: auto;
  margin-inline: auto;
}

/* camada 2 — degradê entre copy e diagrama */
.hero-diagram::before {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: clamp(88px, 12vw, 140px);
  z-index: 2;
  pointer-events: none;
  background: linear-gradient(180deg,
      var(--bg) 0%,
      rgba(246, 243, 236, .92) 28%,
      rgba(246, 243, 236, .55) 55%,
      transparent 100%);
}

.hero-canvas+.prob-cinematic {
  margin-top: 0;
  padding-top: 0;
}

.hero-canvas+.prob-cinematic>.wrap {
  padding-top: var(--sect);
}

.hero-canvas .wrap {
  position: relative;
  z-index: 1;
  width: 100%;
  overflow: visible;
}

.hero-canvas .hero-head {
  width: 100%;
  max-width: var(--hero-copy-w);
  margin-inline: auto;
}

.hero-canvas h1 {
  max-width: 100%;
  margin: 0 auto clamp(10px, 1.4vh, 16px);
  font-size: clamp(1.85rem, 3.6vw, 3.05rem);
  line-height: 1.08;
  letter-spacing: -.035em;
  text-wrap: balance;
}

.hero-canvas .hero-head .hero-lead {
  max-width: 100%;
  margin: 0 auto clamp(6px, 1vh, 10px);
  font-size: clamp(1.05rem, 1.75vw, 1.45rem);
  line-height: 1.32;
  text-wrap: balance;
}

.hero-canvas .hero-head .hero-sub {
  max-width: 100%;
  margin: 0 auto clamp(10px, 1.4vh, 18px);
  font-size: clamp(.92rem, 1.5vw, 1.04rem);
  line-height: 1.45;
  text-wrap: balance;
}

.hero-canvas .hero-head .hero-cta {
  justify-content: center;
  margin-bottom: 0;
  gap: 12px;
}

.hero-canvas .nav.scrolled {
  position: fixed;
  inset: 0 0 auto 0
}

@media(max-width:720px) {
  .hero-canvas.hero--diagram {
    --hero-copy-w: 100%
  }

  .hero-canvas h1 {
    font-size: clamp(1.65rem, 6.8vw, 2.1rem)
  }
}
