@font-face{font-family:'Albert Sans';font-style:italic;font-weight:400;font-display:swap;src:url('assets/fonts/albertsans-400i.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Albert Sans';font-style:normal;font-weight:400;font-display:swap;src:url('assets/fonts/albertsans-400.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Albert Sans';font-style:normal;font-weight:600;font-display:swap;src:url('assets/fonts/albertsans-600.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Albert Sans';font-style:normal;font-weight:700;font-display:swap;src:url('assets/fonts/albertsans-700.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Albert Sans';font-style:normal;font-weight:800;font-display:swap;src:url('assets/fonts/albertsans-800.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Albert Sans';font-style:normal;font-weight:900;font-display:swap;src:url('assets/fonts/albertsans-900.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Open Sans';font-style:normal;font-weight:400;font-display:swap;src:url('assets/fonts/opensans-400.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Open Sans';font-style:normal;font-weight:500;font-display:swap;src:url('assets/fonts/opensans-500.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Open Sans';font-style:normal;font-weight:600;font-display:swap;src:url('assets/fonts/opensans-600.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}

:root {
  --bg:            oklch(17% 0.008 95);
  --surface:       oklch(22% 0.012 95);
  --surface-hi:    oklch(26% 0.014 90);
  --fg:            oklch(98% 0.004 95);
  --muted:         oklch(72% 0.018 90);
  --border:        oklch(30% 0.016 90);
  --accent:        oklch(73% 0.110 62);
  --accent-strong: oklch(77% 0.102 65);
  --accent-dim:    oklch(61% 0.115 60);
  --paper:         oklch(97% 0.012 82);
  --paper-soft:    oklch(94% 0.018 82);
  --ink:           oklch(18% 0.018 82);
  --ink-muted:     oklch(42% 0.024 82);
  --paper-border:  rgba(27, 24, 18, 0.13);
  --danger:        oklch(60% 0.18 25);
  --font-display:  'Albert Sans', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  --font-body:     'Open Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  --font-mono:     ui-monospace, SFMono-Regular, Menlo, monospace;
  --r-sm:  6px;
  --r-md:  12px;
  --r-lg:  20px;
  --r-xl:  32px;
}

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

html { scroll-behavior: smooth; }

body {
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}

/* ── Typography ──────────────────────────────── */
h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.03em;
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  color: var(--accent-strong);
  font: 800 11px/1 var(--font-display);
  letter-spacing: 0.2em;
  text-transform: uppercase;
}
.gold { color: var(--accent-strong); }

/* ── Layout ──────────────────────────────────── */
.container {
  width: min(100%, 1100px);
  margin: 0 auto;
  padding: 0 24px;
}

section {
  padding: 96px 0;
  scroll-margin-top: 84px;
}

.section-label {
  display: block;
  margin-bottom: 20px;
}

/* ── Buttons ─────────────────────────────────── */
.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 18px 36px;
  border: 0;
  border-radius: 999px;
  background: var(--accent);
  color: #15110a;
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 900;
  letter-spacing: -0.01em;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.18s, transform 0.15s, box-shadow 0.18s;
  box-shadow: 0 12px 32px rgba(216,150,90,0.22);
}
.btn-primary:hover {
  background: var(--accent-strong);
  transform: translateY(-2px);
  box-shadow: 0 20px 48px rgba(216,150,90,0.32);
}
.btn-primary:active { transform: translateY(0); }

.btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 28px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: transparent;
  color: var(--muted);
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  text-decoration: none;
  transition: border-color 0.18s, color 0.18s;
}
.btn-ghost:hover {
  border-color: rgba(216,150,90,0.5);
  color: var(--fg);
}

/* ── Nav ─────────────────────────────────────── */
nav {
  position: sticky;
  top: 0;
  z-index: 100;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  background: rgba(17,17,14,0.92);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}
.nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  min-height: 72px;
  padding: 0 24px;
  width: min(100%, 1100px);
  margin: 0 auto;
}
.nav-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: var(--fg);
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 18px;
  letter-spacing: -0.02em;
}
.nav-brand img {
  width: 140px; height: auto;
  border-radius: 0;
  border: none;
}
.nav-links {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 32px;
}
.nav-link {
  color: var(--muted);
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 600;
  text-decoration: none;
  transition: color 0.18s;
}
.nav-link:hover {
  color: var(--accent);
}
.nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 44px;
  height: 44px;
  padding: 0;
  background: transparent;
  border: 0;
  cursor: pointer;
}
.nav-toggle span {
  display: block;
  width: 24px;
  height: 2px;
  margin: 0 auto;
  background: var(--muted);
  border-radius: 2px;
  transition: transform 0.3s ease, opacity 0.2s ease;
}
.nav-inner.is-open .nav-toggle span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-inner.is-open .nav-toggle span:nth-child(2) { opacity: 0; }
.nav-inner.is-open .nav-toggle span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ── Hero ────────────────────────────────────── */
#hero {
  padding: 100px 0 80px;
  position: relative;
  overflow: hidden;
}
#hero::before {
  content: "";
  position: absolute;
  top: -160px; left: 50%;
  transform: translateX(-50%);
  width: 900px; height: 700px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(216,150,90,0.13) 0%, transparent 68%);
  pointer-events: none;
}
.hero-inner {
  max-width: 880px;
  margin: 0 auto;
}
.hero-copy {
  max-width: 780px;
  margin: 0 auto;
  text-align: center;
}
.hero-copy .eyebrow { margin-bottom: 28px; }
.hero-copy h1 {
  font-size: clamp(44px, 5.5vw, 72px);
  line-height: 0.97;
  margin-bottom: 24px;
}
.hero-lead {
  font-size: 20px;
  color: var(--muted);
  line-height: 1.5;
  max-width: 620px;
  margin: 0 auto 40px;
}
.hero-actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
}
.hero-micro {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 7px;
  font-size: 13px;
  color: var(--muted);
  margin-top: 20px;
  text-align: center;
  line-height: 1.4;
}
.hero-micro svg { flex-shrink: 0; margin-top: 3px; }

/* Hero visual card */
.hero-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: 32px;
  position: relative;
  overflow: hidden;
}
.hero-card::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
}
.hero-card-label {
  font: 800 11px/1 var(--font-display);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent-strong);
  margin-bottom: 20px;
}
.hero-stat-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 24px;
}
.hero-stat {
  padding: 16px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--r-md);
}
.hero-stat-num {
  font: 800 32px/1 var(--font-display);
  color: var(--accent-strong);
  letter-spacing: -0.04em;
  margin-bottom: 6px;
}
.hero-stat-label {
  font-size: 13px;
  color: var(--muted);
  line-height: 1.3;
}
.hero-divider {
  height: 1px;
  background: var(--border);
  margin: 20px 0;
}
.hero-card-footer {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  color: var(--muted);
}
.hero-card-footer strong { color: var(--fg); }
.avatar-stack {
  display: flex;
}
.avatar-stack span {
  width: 32px; height: 32px;
  border-radius: 50%;
  border: 2px solid var(--surface);
  background: var(--surface-hi);
  display: flex; align-items: center; justify-content: center;
  font: 700 11px/1 var(--font-display);
  color: var(--accent);
  margin-left: -8px;
}
.avatar-stack span:first-child { margin-left: 0; }

/* ── Authority strip (faixa de números, estilo growin) ── */
.authority {
  padding: 0;                /* anula o padding 96px herdado de `section` — faixa compacta */
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(216,150,90,0.05), transparent 60%);
}
.authority-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px 30px;
  padding: 30px 24px;
  flex-wrap: wrap;
  text-align: center;
}
.auth-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 116px;
}
.auth-item strong {
  font: 800 clamp(23px, 2.8vw, 33px)/1 var(--font-display);
  color: var(--accent-strong);
  letter-spacing: -0.03em;
}
.auth-item span {
  font-size: 12.5px;
  color: var(--muted);
  line-height: 1.3;
}
.auth-sep {
  width: 1px;
  height: 40px;
  background: var(--border);
}
@media (max-width: 768px) {
  .auth-sep { display: none; }
  .authority-inner { gap: 16px 22px; padding: 24px 20px; }
  .auth-item { min-width: 104px; }
  .auth-item strong { font-size: 25px; }
}

/* ── Manifesto institucional ─────────────────── */
#manifesto {
  background: var(--paper);
  color: var(--ink);
  border-top: 1px solid var(--paper-border);
  border-bottom: 1px solid var(--paper-border);
}
.manifesto-inner {
  display: grid;
  grid-template-columns: 0.82fr 1.18fr;
  gap: 56px;
  align-items: center;
}
.manifesto-kicker {
  font: 800 11px/1 var(--font-display);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: oklch(56% 0.125 82);
  margin-bottom: 22px;
}
.manifesto-title {
  font-size: clamp(32px, 3.8vw, 50px);
  color: var(--ink);
}
.manifesto-copy {
  display: grid;
  gap: 16px;
}
.manifesto-copy p {
  color: var(--ink-muted);
  font-size: 17px;
  line-height: 1.55;
  max-width: 580px;
}
.manifesto-principles {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 14px;
  margin-top: 8px;
}
.manifesto-principle {
  min-height: 126px;
  padding: 20px;
  border: 1px solid var(--paper-border);
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.52);
}
.manifesto-principle span {
  display: block;
  margin-bottom: 16px;
  color: oklch(54% 0.13 82);
  font: 900 13px/1 var(--font-display);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.manifesto-principle strong {
  display: block;
  margin-bottom: 0;
  color: var(--ink);
  font-family: var(--font-display);
  font-size: 19px;
  line-height: 1.08;
  letter-spacing: -0.02em;
}
.manifesto-principle p {
  font-size: 0;
  line-height: 0;
  color: var(--ink-muted);
}
.manifesto-signature {
  margin-top: 4px;
  padding: 18px 20px;
  border-top: 1px solid var(--paper-border);
  border-bottom: 1px solid var(--paper-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  font-family: var(--font-display);
  color: var(--ink);
  background: rgba(255,255,255,0.42);
  border-radius: var(--r-md);
}
.manifesto-seal {
  width: 78px;
  height: 78px;
  border-radius: 50%;
  border: 1px solid rgba(164, 105, 27, 0.34);
  display: grid;
  place-items: center;
  color: oklch(56% 0.125 82);
  font: 900 18px/1 var(--font-display);
  letter-spacing: -0.04em;
  flex-shrink: 0;
}

/* ── Qualificação ────────────────────────────── */
#qualificacao {
  background: var(--surface);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.qualif-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 32px;
  margin-top: 56px;
}
.qualif-card {
  padding: 32px;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--r-lg);
  background: rgba(255,255,255,0.03);
  position: relative;
}
.qualif-card::before {
  content: attr(data-num);
  position: absolute;
  top: 24px; right: 28px;
  font: 800 48px/1 var(--font-display);
  color: rgba(216,150,90,0.12);
  letter-spacing: -0.05em;
}
.qualif-card h3 {
  font-size: 20px;
  margin-bottom: 10px;
  padding-right: 48px;
}
.qualif-card p { font-size: 15px; color: var(--muted); line-height: 1.5; }
.qualif-footer {
  margin-top: 56px;
  padding: 28px 32px;
  border: 1px solid rgba(216,150,90,0.3);
  border-radius: var(--r-lg);
  background: rgba(216,150,90,0.06);
  display: flex;
  align-items: center;
  gap: 16px;
}
.qualif-footer-icon {
  width: 44px; height: 44px; flex-shrink: 0;
  border-radius: 50%;
  background: rgba(216,150,90,0.16);
  display: flex; align-items: center; justify-content: center;
  font-size: 20px;
}
.qualif-footer p { font-size: 15px; color: var(--muted); }
.qualif-footer strong { color: var(--fg); }

/* ── Dores ───────────────────────────────────── */
#dores { padding: 96px 0; }
.dores-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
}
.dores-copy h2 { font-size: clamp(36px, 4vw, 52px); margin-bottom: 20px; }
.dores-copy p { color: var(--muted); font-size: 17px; line-height: 1.6; margin-bottom: 16px; }
.dores-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.dores-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 18px 20px;
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.07);
}
.dores-icon {
  width: 36px; height: 36px; flex-shrink: 0;
  border-radius: 8px;
  background: rgba(231,71,71,0.12);
  display: flex; align-items: center; justify-content: center;
  font-size: 16px;
}
.dores-item h4 { font-size: 15px; font-weight: 700; margin-bottom: 4px; }
.dores-item p { font-size: 14px; color: var(--muted); line-height: 1.4; margin: 0; }

/* ── Método ──────────────────────────────────── */
#metodo {
  background: var(--surface);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.metodo-header { text-align: center; max-width: 640px; margin: 0 auto 64px; }
.metodo-header h2 { font-size: clamp(36px, 4vw, 54px); margin: 20px 0 16px; }
.metodo-header p { font-size: 18px; color: var(--muted); }
.metodo-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-bottom: 64px;
}
.metodo-card {
  padding: 36px 28px;
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  background: var(--bg);
  position: relative;
  overflow: hidden;
  transition: border-color 0.2s, transform 0.2s;
}
.metodo-card:hover {
  border-color: rgba(216,150,90,0.4);
  transform: translateY(-4px);
}
.metodo-card::after {
  content: "";
  position: absolute;
  bottom: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
  opacity: 0;
  transition: opacity 0.2s;
}
.metodo-card:hover::after { opacity: 1; }
.metodo-num {
  width: 48px; height: 48px;
  border-radius: var(--r-md);
  border: 1px solid rgba(216,150,90,0.3);
  background: rgba(216,150,90,0.08);
  display: flex; align-items: center; justify-content: center;
  font: 800 22px/1 var(--font-display);
  color: var(--accent-strong);
  margin-bottom: 24px;
}
.metodo-card h3 { font-size: 22px; margin-bottom: 12px; }
.metodo-card p { font-size: 15px; color: var(--muted); line-height: 1.55; }
.metodo-card ul {
  list-style: none;
  margin-top: 18px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.metodo-card li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 14px;
  color: var(--muted);
}
.metodo-card li::before {
  content: "→";
  color: var(--accent);
  flex-shrink: 0;
  font-weight: 700;
}
.metodo-resultado {
  max-width: 820px;
  margin: 0 auto;
  padding: 24px 30px;
  border: 1px solid rgba(216,150,90,0.28);
  border-radius: var(--r-lg);
  background: linear-gradient(135deg, rgba(216,150,90,0.08), rgba(255,255,255,0.02));
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;
}
.metodo-resultado h3 { font-size: 20px; margin-bottom: 6px; }
.metodo-resultado p { font-size: 14.5px; color: var(--muted); max-width: 480px; line-height: 1.5; }
.metodo-resultado .btn-primary { padding: 14px 28px; font-size: 15px; }

/* ── Prova ───────────────────────────────────── */
#prova { padding: 96px 0; }
.prova-header { text-align: center; max-width: 560px; margin: 0 auto 64px; }
.prova-header h2 { font-size: clamp(36px, 4vw, 52px); margin: 20px 0 14px; }
.prova-header p { font-size: 17px; color: var(--muted); }
.prova-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  overflow: hidden;
  margin-bottom: 64px;
  background: var(--border);
}
.prova-stat {
  padding: 40px 28px;
  background: var(--surface);
  text-align: center;
}
.prova-stat-num {
  font: 800 52px/1 var(--font-display);
  color: var(--accent-strong);
  letter-spacing: -0.05em;
  margin-bottom: 10px;
  display: block;
}
.prova-stat-label {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.3;
}

/* ── Entregáveis (seção dark) ── */
#entregaveis { padding: 96px 0; }
.entregaveis-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}
.entregavel-card {
  padding: 28px 24px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--surface);
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.entregavel-num {
  font: 800 18px/1 var(--font-display);
  color: var(--accent-strong);
  letter-spacing: 0.04em;
}
.entregavel-card h3 {
  font: 700 18px/1.25 var(--font-display);
  color: var(--fg);
}
.entregavel-card p {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.5;
}
@media (max-width: 1024px) {
  .entregaveis-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .entregaveis-grid { grid-template-columns: 1fr; }
}

/* ── Resultados reais (seção dark) ── */
#resultados { padding: 96px 0; }
.resultados-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.resultado-card {
  padding: 34px 30px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--surface);
}
.resultado-num {
  display: block;
  font: 800 40px/1.05 var(--font-display);
  color: var(--accent-strong);
  letter-spacing: -0.04em;
  margin-bottom: 14px;
}
.resultado-num .resultado-unit {
  font-size: 19px;
  font-weight: 700;
  color: var(--muted);
  letter-spacing: 0;
}
.resultado-label {
  font-size: 15px;
  color: var(--muted);
  line-height: 1.45;
}
.marcas-strip {
  margin-top: 56px;
  padding-top: 40px;
  border-top: 1px solid var(--border);
  text-align: center;
}
.marcas-label {
  display: block;
  font-size: 13px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 22px;
}
.marcas-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 18px 44px;
}
.marcas-list span {
  font: 700 clamp(20px, 2.6vw, 30px)/1 var(--font-display);
  color: var(--fg);
  opacity: 0.8;
  letter-spacing: 0.02em;
}
@media (max-width: 768px) {
  .resultados-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
  .resultados-grid { grid-template-columns: 1fr; }
}
.prova-depoimentos {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.depoimento {
  padding: 32px;
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  background: var(--surface);
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.depoimento-stars {
  display: flex;
  gap: 3px;
  color: var(--accent);
  font-size: 16px;
}
.depoimento blockquote {
  font-size: 15px;
  color: var(--fg);
  line-height: 1.6;
  font-style: normal;
  flex: 1;
}
.depoimento-autor {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}
.autor-avatar {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--surface-hi);
  border: 2px solid rgba(216,150,90,0.3);
  display: flex; align-items: center; justify-content: center;
  font: 700 16px/1 var(--font-display);
  color: var(--accent);
  flex-shrink: 0;
}
.autor-info strong {
  display: block;
  font: 700 15px/1.2 var(--font-display);
}
.autor-info span { font-size: 13px; color: var(--muted); }

/* ── Como funciona ───────────────────────────── */
#como-funciona {
  background: var(--surface);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.como-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}
.como-copy h2 { font-size: clamp(36px, 4vw, 52px); margin: 20px 0 16px; }
.como-copy p { color: var(--muted); font-size: 17px; line-height: 1.6; margin-bottom: 32px; }
.como-steps {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.como-step {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  padding: 24px 0;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.como-step:last-child { border-bottom: 0; }
.como-step-num {
  width: 40px; height: 40px; flex-shrink: 0;
  border-radius: 50%;
  border: 1.5px solid rgba(216,150,90,0.4);
  background: rgba(216,150,90,0.08);
  display: flex; align-items: center; justify-content: center;
  font: 800 14px/1 var(--font-display);
  color: var(--accent-strong);
}
.como-step h4 { font-size: 16px; margin-bottom: 4px; }
.como-step p { font-size: 14px; color: var(--muted); line-height: 1.4; }
.como-card {
  padding: 36px;
  border: 1px solid rgba(216,150,90,0.28);
  border-radius: var(--r-xl);
  background: linear-gradient(135deg, rgba(216,150,90,0.07), rgba(255,255,255,0.02));
}
.como-card h3 { font-size: 22px; margin-bottom: 20px; }
.como-card-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 28px;
}
.como-card-item {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 15px;
}
.check-icon {
  width: 24px; height: 24px; flex-shrink: 0;
  border-radius: 50%;
  background: rgba(216,150,90,0.15);
  display: flex; align-items: center; justify-content: center;
  color: var(--accent);
  font-size: 12px;
  font-weight: 700;
}
.como-card-footer {
  padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,0.08);
  font-size: 13px;
  color: var(--muted);
  line-height: 1.5;
}
.como-card-footer strong { color: var(--fg); }

/* ── CTA Final ───────────────────────────────── */
#cta-final { padding: 120px 0; text-align: center; position: relative; overflow: hidden; }
#cta-final::before {
  content: "";
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 800px; height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(216,150,90,0.11), transparent 65%);
  pointer-events: none;
}
.cta-inner { position: relative; max-width: 700px; margin: 0 auto; }
.cta-inner .eyebrow { margin-bottom: 32px; }
.cta-inner h2 { font-size: clamp(40px, 5vw, 64px); margin-bottom: 20px; }
.cta-inner p { font-size: 19px; color: var(--muted); line-height: 1.5; margin-bottom: 40px; max-width: 560px; margin-left: auto; margin-right: auto; }
.cta-inner .btn-primary { font-size: 19px; padding: 22px 48px; }
.cta-trust {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 28px;
  margin-top: 32px;
  flex-wrap: wrap;
}
.cta-trust-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--muted);
}
.cta-trust-item svg { flex-shrink: 0; }
.cta-form {
  margin: 42px auto 0;
  padding: 28px;
  max-width: 760px;
  text-align: left;
  background: rgba(255,255,255,0.045);
  border: 1px solid rgba(216,150,90,0.22);
  border-radius: var(--r-lg);
}
.cta-form p {
  margin: 0 0 18px;
  max-width: none;
  font-size: 16px;
  color: var(--fg);
  text-align: center;
}
.cta-form-fields {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.cta-form input[type="text"],
.cta-form input[type="tel"],
.cta-form input[type="email"] {
  width: 100%;
  height: 48px;
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: var(--r-sm);
  background: rgba(0,0,0,0.24);
  color: var(--fg);
  font: 500 14px/1 var(--font-body);
  padding: 0 14px;
  outline: none;
}
.cta-form input::placeholder { color: rgba(255,255,255,0.52); }
.cta-form input:focus {
  border-color: rgba(216,150,90,0.75);
  box-shadow: 0 0 0 3px rgba(216,150,90,0.12);
}
.cta-form-revenue {
  grid-column: 1 / -1;
  padding-top: 6px;
}
.cta-form-revenue > label {
  display: block;
  margin-bottom: 12px;
  color: var(--fg);
  font: 700 14px/1.3 var(--font-display);
}
.cta-form-options {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
}
.cta-form-options label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 40px;
  padding: 9px 12px;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 999px;
  background: rgba(0,0,0,0.18);
  color: var(--muted);
  font-size: 13px;
  cursor: pointer;
}
.cta-form-options input { accent-color: #d8965a; }
.cta-form-submit {
  grid-column: 1 / -1;
  width: 100%;
  min-height: 56px;
  border: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, #d8965a, #e8bd8a);
  color: #15120a;
  font: 900 15px/1 var(--font-display);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  box-shadow: 0 16px 36px rgba(216,150,90,0.24);
}

/* ── Footer ──────────────────────────────────── */
footer {
  padding: 40px 24px;
  border-top: 1px solid var(--border);
  text-align: center;
}
.footer-inner {
  width: min(100%, 1100px);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  text-align: center;
}
.footer-legal { display: flex; flex-direction: column; gap: 4px; }
.footer-legal p { font-size: 13px; color: var(--muted); }
.footer-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 15px;
}
.footer-brand img { width: 140px; height: auto; display: block; }
.footer-nav { display: flex; gap: 24px; }
.footer-nav a { font-size: 14px; color: var(--accent); text-decoration: none; transition: color .2s ease; }
.footer-nav a:hover { text-decoration: underline; }
.footer-slogan { max-width: 600px; margin: 0 auto; font-size: 16px; font-style: italic; line-height: 1.6; color: var(--fg); }
footer p { font-size: 13px; color: var(--muted); }

/* ── Vídeos de depoimento ──────────────────────── */
.video-depo-header { text-align: center; max-width: 560px; margin: 0 auto 48px; }
.video-depo-header h3 { font-size: clamp(28px, 3vw, 38px); margin-bottom: 10px; }
.video-depo-header p { font-size: 16px; color: var(--muted); }
.video-scroll {
  display: flex;
  gap: 18px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding-bottom: 12px;
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
}
.video-scroll::-webkit-scrollbar { height: 4px; }
.video-scroll::-webkit-scrollbar-track { background: transparent; }
.video-scroll::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }
.video-item {
  position: relative;
  flex-shrink: 0;
  width: calc(33.333% - 13px);
  min-width: 200px;
  max-width: 320px;
  scroll-snap-align: start;
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid var(--border);
  background: #000;
  aspect-ratio: 9 / 16;
}
.video-item video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* botão de play grande — toque em qualquer lugar do vídeo ativa (mobile) */
.video-play {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 0;
  padding: 0;
  margin: 0;
  background: transparent;
  cursor: pointer;
  z-index: 2;
  transition: opacity 0.25s ease;
}
.video-play span {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: rgba(0,0,0,0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 24px rgba(0,0,0,0.45);
  transition: transform 0.15s ease, background 0.2s ease;
}
.video-play span svg { width: 26px; height: 26px; fill: #fff; margin-left: 3px; }
.video-play:hover span { transform: scale(1.08); background: rgba(216,150,90,0.92); }
.video-item.is-playing .video-play { opacity: 0; pointer-events: none; }

/* ── Instagram / Prova Social ──────────────────── */
#cases { padding: 64px 0 80px; overflow: hidden; }
#resultados-reais { padding: 80px 0 96px; overflow: hidden; }
.instagram-header { text-align: center; max-width: 760px; margin: 0 auto 42px; padding: 0 24px; }
.instagram-header h2 { font-size: clamp(22px, 2.8vw, 38px); line-height: 1.2; }
.insta-carousel { position: relative; }
.insta-carousel + .insta-carousel { margin-top: 58px; }
#insta-swiper .swiper-slide img,
#insta-clientes-swiper .swiper-slide img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 4px;
  background: #050505;
}
#insta-clientes-swiper .swiper-slide,
#insta-swiper .swiper-slide { overflow: hidden; }
/* Prints (Resultados reais): cards de altura uniforme; menores ficam centralizados sem cortar */
#insta-swiper .swiper-slide {
  aspect-ratio: 1 / 2;
  background: #050505;
  border-radius: 4px;
}
#insta-swiper .swiper-slide img {
  height: 100%;
  object-fit: contain;
  object-position: center;
  background: transparent;
}
.insta-pagination,
.insta-clientes-pagination { margin-top: 24px; text-align: center; }
.insta-pagination .swiper-pagination-bullet,
.insta-clientes-pagination .swiper-pagination-bullet { background: var(--border); opacity: 1; width: 8px; height: 8px; }
.insta-pagination .swiper-pagination-bullet-active,
.insta-clientes-pagination .swiper-pagination-bullet-active { background: var(--accent); opacity: 1; }
/* keep old selectors below until removed */
.marquee-wrap {
  overflow: hidden;
  mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
}
.marquee-track {
  display: flex;
  gap: 16px;
  width: max-content;
  animation: marquee 44s linear infinite;
}
.marquee-track:hover { animation-play-state: paused; }
.marquee-img {
  flex-shrink: 0;
  border-radius: var(--r-md);
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--surface);
}
.marquee-img img {
  width: 210px;
  height: auto;
  display: block;
  transition: transform 0.3s;
}
.marquee-img:hover img { transform: scale(1.04); }
@keyframes marquee { to { transform: translateX(-50%); } }

/* ── Quem está por trás ────────────────────────── */
#equipe { background: var(--surface); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.equipe-inner {
  display: grid;
  grid-template-columns: 420px 1fr;
  gap: 80px;
  align-items: center;
}
.equipe-img {
  position: relative;
  isolation: isolate;
  border-radius: var(--r-xl);
  overflow: hidden;
  padding: 14px;
  border: 1px solid rgba(216,150,90,0.34);
  box-shadow: 0 22px 56px rgba(0,0,0,0.34);
  background:
    linear-gradient(135deg, rgba(216,150,90,0.18), rgba(255,255,255,0.035) 34%, rgba(0,0,0,0) 68%),
    #090705;
}
.equipe-img::before {
  content: "";
  position: absolute;
  inset: 14px;
  z-index: 1;
  pointer-events: none;
  border: 1px solid rgba(216,150,90,0.5);
  border-radius: calc(var(--r-xl) - 10px);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.06);
}
.equipe-photo-crop {
  position: relative;
  width: 100%;
  height: 500px;
  overflow: hidden;
  border-radius: calc(var(--r-xl) - 10px);
  border: 1px solid rgba(255,255,255,0.08);
  background: #050403;
}
.equipe-photo-crop::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 34px;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(5,4,3,0), #050403 82%);
}
.equipe-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  filter: saturate(0.9) contrast(1.05);
  transform: scale(1.08);
  transform-origin: center top;
}
.equipe-copy h2 { font-size: clamp(32px, 3.5vw, 48px); margin-bottom: 22px; }
.equipe-copy > p { font-size: 17.5px; color: var(--muted); line-height: 1.65; margin-bottom: 18px; }
.equipe-copy > p:last-child { margin-bottom: 0; }
.equipe-copy p.equipe-closing {
  margin-top: 22px;
  padding-top: 20px;
  border-top: 1px solid var(--paper-border);
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 700;
  line-height: 1.32;
  letter-spacing: -0.01em;
  color: var(--fg);
}
.equipe-team {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.team-member {
  padding: 20px;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--r-lg);
  background: rgba(255,255,255,0.03);
}
.team-role {
  display: block;
  font: 800 11px/1 var(--font-display);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent-strong);
  margin-bottom: 6px;
}
.team-member strong {
  display: block;
  font: 700 16px/1.2 var(--font-display);
  margin-bottom: 6px;
  color: var(--fg);
}
.team-member p { font-size: 13px; color: var(--muted); line-height: 1.4; margin: 0; }

/* ── Variação DN Hair: blocos preto / branco ── */
#manifesto,
#prova,
#equipe {
  --fg: var(--ink);
  --muted: var(--ink-muted);
  --border: var(--paper-border);
  --surface: oklch(100% 0.004 82);
  --surface-hi: oklch(92% 0.02 82);
  --accent-strong: oklch(57% 0.115 68);
  background: var(--paper);
  color: var(--fg);
}

#prova,
#equipe { background: var(--paper-soft); }

#cases,
#metodo,
#publico,
#entregaveis,
#resultados-reais,
#faq,
#cta-final {
  background: var(--bg);
  border-top: 1px solid rgba(255,255,255,0.07);
  border-bottom: 1px solid rgba(255,255,255,0.07);
}

#equipe .team-member {
  background: rgba(255,255,255,0.78);
  border-color: var(--paper-border);
  box-shadow: 0 18px 48px rgba(36, 27, 16, 0.06);
}

#prova .prova-stats { border-color: var(--paper-border); background: var(--paper-border); }
#prova .prova-stat,
#prova .depoimento {
  background: rgba(255,255,255,0.8);
  border-color: var(--paper-border);
  box-shadow: 0 16px 42px rgba(36, 27, 16, 0.05);
}

#equipe .equipe-img {
  background:
    linear-gradient(135deg, rgba(216,150,90,0.24), rgba(255,255,255,0.045) 32%, rgba(0,0,0,0) 66%),
    #090705;
  border-color: rgba(164, 105, 27, 0.34);
}

#cases .instagram-header h2,
#resultados-reais .prova-header h2 { color: var(--fg); }
#cases .swiper-slide img,
#resultados-reais .swiper-slide img {
  box-shadow: 0 16px 42px rgba(0,0,0,0.28);
}

footer {
  background: var(--bg);
  border-top-color: rgba(255,255,255,0.08);
}

/* ── Responsive ──────────────────────────────── */
@media (max-width: 1024px) {
  .hero-inner { grid-template-columns: 1fr; gap: 48px; }
  .hero-card { max-width: 480px; }
  .hero-stat-grid { grid-template-columns: repeat(4,1fr); }
  .nav-inner {
    min-height: 0;
    padding: 14px 18px;
  }
  .nav-brand img { width: 118px; }
  .nav-links { gap: 22px; }
  .manifesto-inner { grid-template-columns: 1fr; gap: 32px; }
  .qualif-grid { grid-template-columns: repeat(3, 1fr); }
  .metodo-grid { grid-template-columns: repeat(3, 1fr); }
  .prova-stats { grid-template-columns: repeat(2,1fr); }
  .prova-depoimentos { grid-template-columns: 1fr 1fr; }
  .dores-inner { grid-template-columns: 1fr; gap: 48px; }
  .como-inner { grid-template-columns: 1fr; gap: 48px; }
  .equipe-inner { grid-template-columns: 1fr; gap: 48px; }
  .video-item { width: calc(50% - 10px); }
}

@media (max-width: 768px) {
  .nav-toggle { display: inline-flex; }
  .nav-inner { flex-wrap: nowrap; justify-content: space-between; gap: 12px; }
  .nav-links {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    background: rgba(17,17,14,0.98);
    border-bottom: 1px solid rgba(255,255,255,0.06);
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.32s ease;
  }
  .nav-inner.is-open .nav-links { max-height: 72vh; }
  .nav-links .nav-link {
    width: 100%;
    text-align: center;
    padding: 15px 0;
    font-size: 16px;
    border-top: 1px solid rgba(255,255,255,0.05);
  }
  section { padding: 72px 0; }
  #hero { padding: 72px 0 56px; }
  .hero-copy h1 { font-size: clamp(36px, 9vw, 56px); }
  .hero-stat-grid { grid-template-columns: 1fr 1fr; }
  .manifesto-principles { grid-template-columns: 1fr; }
  .manifesto-principle { min-height: 0; }
  .manifesto-signature { align-items: flex-start; flex-direction: column; }
  .qualif-grid { grid-template-columns: 1fr; }
  .metodo-grid { grid-template-columns: 1fr; }
  .metodo-resultado {
    grid-template-columns: 1fr;
    padding: 28px 24px;
    gap: 20px;
  }
  .prova-stats { grid-template-columns: 1fr 1fr; }
  .prova-depoimentos { grid-template-columns: 1fr; }
  .prova-stat { padding: 28px 20px; }
  .prova-stat-num { font-size: 38px; }
  .cta-trust { gap: 16px; }
  .cta-form { padding: 22px; }
  .cta-form-fields { grid-template-columns: 1fr; }
  .footer-inner { flex-direction: column; text-align: center; }
  .equipe-img {
    margin-right: 0;
    padding: 10px;
    border-radius: var(--r-lg);
  }
  .equipe-img::before {
    inset: 10px;
    border-radius: calc(var(--r-lg) - 7px);
  }
  .equipe-photo-crop {
    height: min(500px, 108vw);
    border-radius: calc(var(--r-lg) - 7px);
  }
  .equipe-team { grid-template-columns: 1fr; }
  .marquee-img img { width: 150px; height: auto; }
  .video-item { width: 65vw; min-width: 200px; max-width: 245px; }
}

@media (max-width: 480px) {
  .hero-lead { font-size: 17px; }
  .hero-actions { flex-direction: column; align-items: stretch; }
  .hero-actions .btn-primary,
  .hero-actions .btn-ghost { width: 100%; justify-content: center; }
  .prova-stats { grid-template-columns: 1fr 1fr; border-radius: var(--r-lg); }
  .nav-cta { display: none; }
}

/* ── FAQ ─────────────────────────────────────── */
.faq-list {
  max-width: 820px;
  margin: 48px auto 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.faq-item {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  overflow: hidden;
  transition: border-color 0.2s ease;
}
.faq-item[open] { border-color: var(--accent-dim); }
.faq-item summary {
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 22px 26px;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 18px;
  letter-spacing: -0.02em;
  color: var(--fg);
  transition: color 0.2s ease;
}
.faq-item summary:hover { color: var(--accent-strong); }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: "+";
  flex-shrink: 0;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 24px;
  line-height: 1;
  color: var(--accent);
  transition: transform 0.2s ease;
}
.faq-item[open] summary::after { content: "\2212"; }
.faq-answer {
  padding: 0 26px 24px;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.65;
}
.faq-answer p { margin: 0; }
@media (max-width: 640px) {
  .faq-item summary { padding: 18px 20px; font-size: 16px; }
  .faq-answer { padding: 0 20px 20px; font-size: 15px; }
}

/* ── Método Vórtice (timeline de 5 etapas) ─────── */
.vortice {
  max-width: 760px;
  margin: 0 auto 56px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: relative;
}
.vortice::before {
  content: "";
  position: absolute;
  top: 28px;
  bottom: 28px;
  left: 35px;
  width: 2px;
  background: linear-gradient(180deg, var(--accent), rgba(216,150,90,0.15));
  z-index: 0;
}
.vortice-step {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: 22px;
  padding: 22px 26px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--surface);
  transition: transform 0.18s, border-color 0.18s;
}
.vortice-step:hover { transform: translateX(4px); border-color: rgba(216,150,90,0.45); }
.vortice-num {
  width: 48px; height: 48px; flex-shrink: 0;
  border-radius: 50%;
  border: 1px solid rgba(216,150,90,0.4);
  background: linear-gradient(135deg, rgba(216,150,90,0.18), rgba(216,150,90,0.04));
  display: flex; align-items: center; justify-content: center;
  font: 800 18px/1 var(--font-display);
  color: var(--accent-strong);
  letter-spacing: -0.03em;
}
.vortice-body h3 { font-size: 20px; margin-bottom: 4px; }
.vortice-body p { font-size: 15px; color: var(--muted); line-height: 1.5; }
@media (max-width: 560px) {
  .vortice::before { left: 30px; }
  .vortice-step { gap: 16px; padding: 18px 18px; align-items: flex-start; }
  .vortice-num { width: 42px; height: 42px; font-size: 16px; }
  .vortice-body h3 { font-size: 18px; }
}

/* ── Quem ajudamos / não atendemos ─────────────── */
.publico-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
  max-width: 920px;
  margin: 0 auto;
}
.publico-card {
  padding: 32px 30px;
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  background: var(--surface);
}
.publico-card h3 {
  font-size: 22px;
  margin-bottom: 22px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--border);
}
.publico-card ul { list-style: none; display: flex; flex-direction: column; gap: 14px; }
.publico-card li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 16px;
  color: var(--fg);
  line-height: 1.4;
}
.publico-card li::before {
  flex-shrink: 0;
  width: 24px; height: 24px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px;
  font-weight: 700;
  margin-top: 1px;
}
.publico-yes { border-color: rgba(126,191,120,0.32); }
.publico-yes li::before {
  content: "✓";
  background: rgba(126,191,120,0.16);
  color: oklch(78% 0.15 150);
}
.publico-no { border-color: rgba(231,71,71,0.28); }
.publico-no li::before {
  content: "✕";
  background: rgba(231,71,71,0.14);
  color: oklch(70% 0.17 25);
}
.publico-no li { color: var(--muted); }
@media (max-width: 720px) {
  .publico-grid { grid-template-columns: 1fr; }
}

/* ── Grid de soluções (3 colunas) ──────────────── */
.entregaveis-grid--3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 1024px) {
  .entregaveis-grid--3 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .entregaveis-grid--3 { grid-template-columns: 1fr; }
}

/* ── CTA dentro de Resultados reais ────────────── */
.resultados-cta { margin-top: 40px; text-align: center; }

/* ── CTA do Método (só o botão, centralizado) ──── */
.metodo-cta { text-align: center; margin-top: 4px; }

/* ── Método Vórtice (animação de sucção) ───────── */
/* palco fixo 1920x1080 escalado por JS (--vscale) -> proporção nunca quebra */
.vortice-stage-wrap {
  position: relative;
  width: min(100%, 1040px);
  aspect-ratio: 1180 / 780;
  margin: 4px auto 48px;
  overflow: hidden;
}
/* palco 1920x1080: escalado e deslocado por JS pra "fechar" o enquadramento no vórtice */
.vortice-stage {
  position: absolute;
  top: 0; left: 0;
  width: 1920px;
  height: 1080px;
  transform-origin: top left;
  transform: scale(var(--vscale, 0.88));
}
.v-svg { position: absolute; inset: 0; width: 1920px; height: 1080px; overflow: visible; }

/* braços em espiral girando */
.v-arms {
  transform-box: view-box;
  transform-origin: 960px 640px;
  animation: vspin 46s linear infinite;
}
@keyframes vspin { to { transform: rotate(-360deg); } }
.v-arms path {
  fill: none;
  stroke: var(--accent);
  stroke-width: 1.5;
  stroke-opacity: 0.26;
  stroke-linecap: round;
  stroke-dasharray: 5 13;
  animation: vdrain 1.5s linear infinite;
}
@keyframes vdrain { to { stroke-dashoffset: 36; } }

/* trilhas de sucção */
.v-streaks path {
  fill: none;
  stroke: var(--accent);
  stroke-width: 2;
  stroke-opacity: 0.4;
  stroke-linecap: round;
  stroke-dasharray: 1 11;
}
.v-pellet { fill: url(#vPellet); }

/* núcleo pulsante */
.v-core {
  position: absolute;
  left: 960px; top: 640px;
  transform: translate(-50%, -50%);
  width: 208px; height: 208px;
  border-radius: 50%;
  z-index: 3;
  display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center;
  background: radial-gradient(circle at 50% 40%, #FCEEDB 0%, var(--accent-strong) 36%, var(--accent-dim) 74%, #8A4D22 100%);
  box-shadow:
    0 0 0 1px rgba(255,255,255,0.5),
    0 0 50px 10px rgba(216,150,90,0.42),
    0 0 130px 44px rgba(216,150,90,0.22);
  animation: vcorepulse 3.4s ease-in-out infinite;
}
@keyframes vcorepulse {
  0%,100% { box-shadow: 0 0 0 1px rgba(255,255,255,0.5), 0 0 50px 10px rgba(216,150,90,0.42), 0 0 130px 44px rgba(216,150,90,0.22); }
  50%     { box-shadow: 0 0 0 1px rgba(255,255,255,0.65), 0 0 66px 14px rgba(216,150,90,0.54), 0 0 165px 56px rgba(216,150,90,0.30); }
}
.v-core::after {
  content: "";
  position: absolute; inset: -15px;
  border-radius: 50%;
  border: 1px solid rgba(216,150,90,0.34);
  animation: vhalo 3.4s ease-in-out infinite;
}
@keyframes vhalo { 0%,100% { transform: scale(1); opacity: .6; } 50% { transform: scale(1.12); opacity: .22; } }
.v-core-lab {
  font: 800 13px/1 var(--font-display);
  letter-spacing: 0.3em; text-transform: uppercase;
  color: #5b3417; opacity: .9; margin-bottom: 5px;
}
.v-core-big {
  font: 800 28px/1 var(--font-display);
  color: #fff; letter-spacing: -0.01em;
  text-shadow: 0 1px 6px rgba(80,42,16,0.5);
}

/* chips dos 5 nós (px no palco 1920) — largura ajusta ao conteúdo p/ folga uniforme número→texto→borda */
.v-node {
  position: absolute;
  transform: translate(-50%, -50%);
  z-index: 4;
  width: max-content;
  display: flex; align-items: center; gap: 16px;
  padding: 16px 22px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 16px;
  box-shadow: 0 16px 34px rgba(0,0,0,0.36), 0 4px 12px rgba(0,0,0,0.24);
}
.v-num {
  font: 400 42px/1 var(--font-display);
  color: var(--accent-strong); flex: none;
}
.v-nm {
  font: 700 24px/1.12 var(--font-display);
  color: var(--fg); letter-spacing: -0.01em;
}

/* alterna animação (desktop) x lista (mobile) */
.vortice-list { display: none; }
@media (max-width: 860px) {
  .vortice-stage-wrap { display: none; }
  .vortice-list { display: flex; margin-top: 8px; }
}

@media (prefers-reduced-motion: reduce) {
  .v-arms, .v-core, .v-core::after, .v-pellet { animation: none; }
}
