/* =========================================================
   TRAVESSIA, Landing Page
   Sistema visual: verde sálvia + dourado + creme
   ========================================================= */

:root {
  --bg: #f6f1e8;          /* creme quente */
  --bg-2: #efe8dc;        /* creme mais profundo */
  --bg-deep: #3d4a30;     /* verde sálvia profundo */
  --bg-deeper: #2b331f;   /* verde quase preto */
  --ink: #1e2418;         /* texto principal */
  --ink-muted: #4a5240;   /* secundário */
  --ink-soft: #7a7d6e;    /* tertiary */
  --line: #d9cfbb;        /* linha creme */
  --gold: #b8924a;        /* dourado primário */
  --gold-2: #d4b072;      /* dourado claro */
  --gold-deep: #8c6b2a;   /* dourado profundo */
  --cream-card: #ebe2d0;  /* card cream */

  --display: "Fraunces", "EB Garamond", Georgia, serif;
  --sans: "Manrope", -apple-system, BlinkMacSystemFont, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, monospace;

  --radius-md: 16px;
  --radius-lg: 24px;
  --radius-xl: 32px;
  --radius-pill: 999px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: auto; }
html.lenis { height: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }
.lenis.lenis-smooth [data-lenis-prevent] { overscroll-behavior: contain; }
.lenis.lenis-stopped { overflow: hidden; }

body {
  font-family: var(--sans);
  background: var(--bg);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-size: 17px;
  line-height: 1.6;
  letter-spacing: 0;
  overflow-x: hidden;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }

/* ==================== Typography ==================== */
.serif { font-family: var(--display); font-weight: 400; letter-spacing: -0.01em; }
.eyebrow {
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--gold-deep);
}
.eyebrow--light { color: var(--gold-2); }
.eyebrow-line { display:inline-flex; align-items:center; gap: 14px; }
.eyebrow-line::before, .eyebrow-line::after {
  content: ""; width: 28px; height: 1px; background: currentColor; opacity: 0.5;
}
.eyebrow-line::after { display: none; }

h1, .display-title {
  font-family: var(--display);
  font-variation-settings: "SOFT" 100, "opsz" 144;
  font-weight: 450;
  font-size: 64px;
  line-height: 1.08;
  letter-spacing: -0.02em;
  color: var(--bg-deep);
}

h2 {
  font-family: var(--sans);
  font-weight: 600;
  font-size: 44px;
  line-height: 1.12;
  letter-spacing: -0.015em;
  color: var(--bg-deep);
}

h3 {
  font-family: var(--sans);
  font-weight: 600;
  font-size: 22px;
  line-height: 1.35;
  letter-spacing: -0.005em;
  color: var(--bg-deep);
}

h1 em, h2 em, h3 em { font-style: italic; color: var(--gold-deep); font-weight: 400; }
.on-dark h1, .on-dark h2, .on-dark h3 { color: #f2ecdc; }
.on-dark h1 em, .on-dark h2 em, .on-dark h3 em { color: var(--gold-2); }
.on-dark { color: #d9d2c0; }

p { max-width: 62ch; }
strong, b { font-weight: 600; color: var(--bg-deeper); }
.on-dark strong { color: #f5e9cf; }

small, .small {
  font-size: 14px;
  line-height: 1.5;
}

/* ==================== Layout helpers ==================== */
.wrap { width: min(1200px, 92vw); margin-inline: auto; }
.wrap-narrow { width: min(820px, 92vw); margin-inline: auto; }
.wrap-wide { width: min(1380px, 94vw); margin-inline: auto; }

section {
  position: relative;
  padding: clamp(80px, 12vh, 160px) 0;
}

/* ==================== Nav ==================== */
.nav {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 100;
  padding: 22px 0;
  transition: background 0.4s, backdrop-filter 0.4s, border-color 0.4s;
  border-bottom: 1px solid transparent;
}
.nav.is-scrolled {
  background: rgba(246,241,232,0.85);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border-bottom-color: rgba(138,106,42,0.12);
}
.nav--compact {
  padding: 8px 0;
  transition: padding 0.35s cubic-bezier(.2,.7,.2,1),
              background 0.4s,
              backdrop-filter 0.4s,
              border-color 0.4s;
}
.nav--compact .nav__links {
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease;
}
.nav--compact .nav__brand-name {
  font-size: 18px;
}
.nav--compact .nav__brand svg {
  width: 18px;
  height: 18px;
}
.nav--compact .nav__cta {
  padding: 8px 16px;
  font-size: 10px;
}
.nav__inner {
  display: flex; align-items: center; justify-content: space-between;
}
.nav__brand { display:flex; align-items:center; gap: 12px; }
.nav__brand svg { width: 22px; height: 22px; color: var(--gold); }
.nav__brand-name {
  font-family: var(--sans); font-size: 22px; letter-spacing: 0.18em;
  color: var(--bg-deep); font-weight: 500;
}
.nav__right { display:flex; align-items:center; gap: 28px; }
.nav__links { display:flex; gap: 28px; font-size: 13px; color: var(--ink-muted); }
.nav__links a:hover { color: var(--bg-deep); }
.nav__cta {
  display:inline-flex; align-items:center; gap:8px;
  padding: 11px 20px;
  border: 1px solid var(--bg-deep);
  background: var(--bg-deep);
  color: #f2ecdc;
  font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; font-weight: 500;
  transition: all 0.25s;
  border-radius: var(--radius-pill);
}
.nav__cta:hover { background: var(--bg-deeper); border-color: var(--bg-deeper); }
@media (max-width: 880px) {
  .nav__links { display: none; }
}

/* ==================== Buttons ==================== */
.btn {
  display: inline-flex; align-items: center; gap: 14px;
  padding: 20px 32px;
  background: var(--bg-deep);
  color: #f2ecdc;
  font-family: var(--sans);
  font-size: 14px; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 500;
  border: 1px solid var(--bg-deep);
  border-radius: var(--radius-pill);
  cursor: pointer;
  transition: transform 0.3s cubic-bezier(.2,.7,.2,1), background 0.3s, box-shadow 0.3s;
  position: relative; overflow: hidden;
}
.btn:hover { background: var(--bg-deeper); transform: translateY(-2px); box-shadow: 0 18px 40px -20px rgba(43,51,31,0.6); }
.btn__arrow {
  width: 28px; height: 1px; background: var(--gold-2); position: relative;
  transition: width 0.3s;
}
.btn__arrow::after {
  content: ""; position: absolute; right: 0; top: 50%;
  width: 7px; height: 7px; border-top: 1px solid var(--gold-2); border-right: 1px solid var(--gold-2);
  transform: translateY(-50%) rotate(45deg);
}
.btn:hover .btn__arrow { width: 36px; }
.btn--gold { background: var(--gold); border-color: var(--gold); color: #1c1508; }
.btn--gold .btn__arrow { background: var(--bg-deeper); }
.btn--gold .btn__arrow::after { border-color: var(--bg-deeper); }
.btn--gold:hover { background: var(--gold-deep); border-color: var(--gold-deep); color: #f2ecdc; }
.btn--gold:hover .btn__arrow { background: var(--gold-2); }
.btn--gold:hover .btn__arrow::after { border-color: var(--gold-2); }
.btn--lg { padding: 26px 40px; font-size: 13px; }
.btn--outline { background: transparent; color: var(--bg-deep); }
.btn--outline:hover { background: var(--bg-deep); color: #f2ecdc; }

/* ============ Reveal primitive ============ */
.reveal,
.reveal-stagger,
.reveal-stagger > * {
  will-change: transform, opacity, filter;
}

@media (prefers-reduced-motion: reduce) {
  .reveal,
  .reveal-stagger,
  .reveal-stagger > * { will-change: auto; }
}

/* ==================== Logo mark ==================== */
.travessia-mark {
  display: block;
  stroke: var(--gold); stroke-width: 1.1; fill: none;
}

/* =========================================================
   DOBRA 01 · Hero, editorial, high-contrast, sales-first
   ========================================================= */
.hero__bg-photo { display: none; }
.hero {
  position: relative;
  min-height: 100vh;
  display: flex; align-items: center;
  padding: 140px 0 140px;
  overflow: hidden;
  background:
    radial-gradient(ellipse 80% 60% at 20% 20%, #faf5ea 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 90% 80%, #ede3cf 0%, transparent 55%),
    linear-gradient(180deg, #f6f1e8 0%, #efe6d2 100%);
}
.hero__bg-mark {
  position: absolute;
  right: -6vw; top: 4vw;
  font-family: var(--sans);
  font-size: clamp(28rem, 46vw, 60rem);
  line-height: 0.78;
  color: rgba(140, 107, 42, 0.04);
  font-style: italic;
  pointer-events: none;
  user-select: none;
  z-index: 0;
  letter-spacing: -0.05em;
}
.hero__grid {
  position: relative; z-index: 2;
  display: grid;
  width: min(1560px, 88vw);
  grid-template-columns: minmax(0, 0.9fr) minmax(520px, 1.1fr);
  gap: clamp(40px, 4.2vw, 84px);
  align-items: center;
}
.hero__copy {
  min-width: 0;
  position: relative;
  z-index: 2;
}

/* Stamp / live pill */
.hero__stamp {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 9px 16px 9px 14px;
  border: 1px solid rgba(140,107,42,0.28);
  background: rgba(255,255,255,0.55);
  backdrop-filter: blur(4px);
  border-radius: 100px;
  font-family: var(--sans); font-size: 11.5px; letter-spacing: 0.18em;
  color: var(--gold-deep); text-transform: uppercase; font-weight: 500;
  margin-bottom: 36px;
}
.hero__stamp-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: #c04b2f;
  box-shadow: 0 0 0 4px rgba(192,75,47,0.15);
  animation: heroPulse 2s ease-in-out infinite;
}
@keyframes heroPulse {
  0%, 100% { box-shadow: 0 0 0 4px rgba(192,75,47,0.15); }
  50%      { box-shadow: 0 0 0 8px rgba(192,75,47,0.02); }
}

/* Title */
.hero__title {
  font-size: clamp(2.2rem, 4.1vw, 3.8rem);
  line-height: 1.05;
  margin-bottom: 28px;
  letter-spacing: -0.02em;
  color: var(--bg-deeper);
  font-weight: 400;
}
.hero__title-line {
  display: block;
  white-space: nowrap;
}
.hero__title-line--long {
  white-space: normal;
  max-width: 9.8em;
}
.hero__title-tail {
  display: block;
}
.hero__title-line--pressure {
  font-size: 1em;
  line-height: 1.05;
}
.hero__nowrap {
  white-space: nowrap;
}
.hero__title em {
  font-style: italic;
  color: var(--gold-deep);
  position: relative;
}
.hero__title em::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 4%;
  height: 0.18em;
  background: rgba(184,146,74,0.18);
  z-index: -1;
}
.hero__title .u-u {
  position: relative;
  display: inline-block;
}
.hero__title .u-u::after {
  content: "";
  position: absolute;
  left: -2%; right: -2%; bottom: 6%;
  height: 0.16em;
  background: rgba(107,122,84,0.22);
  z-index: -1;
}

/* Lede */
.hero__lede {
  font-size: clamp(17px, 1.35vw, 20px);
  line-height: 1.55;
  color: var(--ink);
  max-width: 50ch;
  margin-bottom: 16px;
}

.hero__lede--main {
  margin-bottom: 18px;
}

.hero__lede--main b {
  font-size: 1.18em;
  font-weight: 600;
  color: var(--gold-deep);
}

.hero__lede--sub {
  font-size: clamp(14px, 1.05vw, 16px);
  color: var(--ink-soft);
  font-style: italic;
  line-height: 1.55;
  margin-bottom: 40px;
  max-width: 48ch;
}

.hero__lede b { color: var(--bg-deeper); font-weight: 600; }

/* CTA row */
.hero__ctas {
  display: flex; align-items: center; gap: 32px; flex-wrap: wrap;
  margin-bottom: 72px;
}
.hero__cta-main { position: relative; }
.hero__cta-main::before {
  content: "";
  position: absolute; inset: -6px;
  border: 1px solid rgba(184,146,74,0.4);
  border-radius: var(--radius-pill);
  pointer-events: none;
}
.hero__cta-meta {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 13px; color: var(--ink-muted);
}
.hero__cta-meta svg { color: var(--gold-deep); flex: none; }
.hero__cta-meta b { color: var(--bg-deep); font-weight: 600; }

/* Proof row */
.hero__proof {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  padding-top: 36px;
  border-top: 1px solid rgba(61,74,48,0.18);
  position: relative;
}
.hero__proof-item {
  padding-right: 28px;
  position: relative;
  min-width: 0;
}
.hero__proof-item + .hero__proof-item { padding-left: 28px; border-left: 1px solid rgba(61,74,48,0.12); }
.hero__proof-n {
  font-family: var(--sans);
  font-size: clamp(1.75rem, 2.6vw, 2.4rem);
  color: var(--bg-deeper);
  line-height: 1;
  margin-bottom: 10px;
  letter-spacing: -0.02em;
  display: flex; align-items: baseline; gap: 2px;
}
.hero__proof-n em {
  font-style: italic; color: var(--gold-deep);
  font-size: 0.55em; margin-right: 1px;
  font-weight: 500;
}
.hero__proof-l {
  font-size: 12px; letter-spacing: 0.1em;
  color: var(--ink); text-transform: uppercase;
  line-height: 1.45;
  font-weight: 500;
}
.hero__proof-l span {
  display: block;
  font-size: 10px; color: var(--ink-soft);
  text-transform: none; letter-spacing: 0.04em;
  font-weight: 400;
  font-style: italic;
  margin-top: 2px;
}

/* Visual */
.hero__visual {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  border-radius: var(--radius-xl);
  transform: translateY(0);
}
.hero__visual::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 30% 30%, rgba(247,240,223,0.4), transparent 60%),
    linear-gradient(200deg, transparent 45%, rgba(43,51,31,0.38) 100%);
  z-index: 2; pointer-events: none;
}
.hero__visual img {
  width: 100%; height: 100%; object-fit: cover; object-position: right center;
  transform: scale(1.08);
  will-change: transform;
  transition: transform 1.2s cubic-bezier(.2,.7,.2,1);
}
.hero__visual-frame {
  position: absolute; inset: 16px;
  border: 1px solid rgba(236, 222, 184, 0.5);
  z-index: 3;
  pointer-events: none;
}

/* Stamp overlay, bottom left */
.hero__visual-stamp {
  position: absolute;
  left: 32px; bottom: 32px;
  z-index: 4;
  padding: 14px 20px;
  background: rgba(43,51,31,0.82);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(212,176,114,0.4);
  border-radius: 2px;
}
.hero__visual-stamp-inner {
  display: flex; flex-direction: column;
  font-family: var(--sans);
  color: #f2ecdc;
}
.hero__visual-stamp-inner span {
  font-family: var(--sans); font-size: 18px;
  letter-spacing: 0.04em; font-style: italic;
  color: var(--gold-2);
  margin-bottom: 2px;
}
.hero__visual-stamp-inner small {
  font-size: 9.5px; letter-spacing: 0.22em; text-transform: uppercase;
  color: rgba(242,236,220,0.7); font-weight: 400;
}

/* Quote chip, top right of image */
.hero__visual-quote {
  position: absolute;
  right: -14px; top: 40px;
  z-index: 4;
  max-width: 260px;
  padding: 22px 22px 22px 28px;
  background: #f6f1e8;
  border: 1px solid var(--line);
  border-radius: 2px;
  box-shadow: 0 30px 60px -30px rgba(43,51,31,0.3);
}
.hero__visual-quote svg {
  color: var(--gold);
  margin-bottom: 10px;
}
.hero__visual-quote p {
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.35;
  color: var(--bg-deep);
  font-style: normal;
}
.hero__visual-quote p i { color: var(--gold-deep); }

/* ============================================================
   Faixa de autoridade · entre Hero e Diagnóstico
   ============================================================ */
.authority-strip {
  background: var(--bg-2);
  padding: 22px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.authority-strip__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}

.authority-strip__item {
  display: flex;
  align-items: baseline;
  gap: 12px;
  flex: 1 1 auto;
  min-width: 0;
  padding: 0 8px;
  position: relative;
}

.authority-strip__item + .authority-strip__item::before {
  content: "";
  position: absolute;
  left: -12px;
  top: 12%;
  bottom: 12%;
  width: 1px;
  background: rgba(184, 146, 74, 0.22);
}

.authority-strip__num {
  font-family: var(--display);
  font-size: clamp(1.4rem, 1.8vw, 1.8rem);
  font-weight: 400;
  color: var(--bg-deep);
  line-height: 1;
  letter-spacing: -0.01em;
  flex-shrink: 0;
}

.authority-strip__num em {
  font-style: italic;
  font-size: 0.62em;
  color: var(--gold-deep);
  font-weight: 500;
  margin-right: 2px;
}

.authority-strip__label {
  font-family: var(--sans);
  font-size: 0.78rem;
  color: var(--ink-muted);
  letter-spacing: 0.04em;
  line-height: 1.35;
  text-transform: uppercase;
  font-weight: 500;
}

.authority-strip__label small {
  display: block;
  font-size: 0.86em;
  color: var(--ink-soft);
  text-transform: none;
  font-weight: 400;
  font-style: italic;
  letter-spacing: 0.02em;
  margin-top: 2px;
}

@media (max-width: 880px) {
  .authority-strip { padding: 18px 0; }
  .authority-strip__inner { gap: 18px; }
  .authority-strip__item {
    flex: 1 1 calc(50% - 18px);
    padding: 0;
  }
  .authority-strip__item + .authority-strip__item::before {
    display: none;
  }
}

@media (max-width: 540px) {
  .authority-strip__item { flex: 1 1 100%; }
  .authority-strip__num { font-size: 1.4rem; }
}

/* ============================================================
   Hero · Showcase de 3 superfícies (laptop + celular + chrome)
   ============================================================ */
.hero__visual--showcase {
  aspect-ratio: auto;
  background: transparent;
  border-radius: 0;
  overflow: visible;
  display: grid;
  place-items: center;
  padding: 0;
  justify-self: end;
  width: min(100%, 760px);
  z-index: 1;
}

.hero__visual--showcase::before { display: none; }

.hero__matrix-texture {
  position: absolute;
  inset: -24% -14% -28% -18%;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
  border-radius: 48px;
  opacity: 0.88;
  background:
    radial-gradient(ellipse at 46% 52%, rgba(255, 250, 236, 0.8) 0%, rgba(255, 250, 236, 0.42) 32%, transparent 68%),
    radial-gradient(ellipse at 70% 40%, rgba(184, 146, 74, 0.13) 0%, transparent 54%),
    repeating-linear-gradient(90deg, rgba(61, 74, 48, 0.08) 0 1px, transparent 1px 42px),
    repeating-linear-gradient(180deg, rgba(184, 146, 74, 0.09) 0 1px, transparent 1px 34px);
  -webkit-mask-image: radial-gradient(ellipse at 52% 50%, #000 0%, rgba(0,0,0,0.82) 44%, transparent 76%);
  mask-image: radial-gradient(ellipse at 52% 50%, #000 0%, rgba(0,0,0,0.82) 44%, transparent 76%);
}

.hero__matrix-texture::before {
  content:
    "01  META  JUROS  PRAZO  FLUXO  10  RESERVA  MAPA\A"
    "RENDA  11  PATRIMONIO  01  CLAREZA  10  ORDEM\A"
    "001  INVESTIR  SEGURANCA  101  OBJETIVOS  011\A"
    "MAPA  10  FUTURO  01  ROTINA  11  DIRECAO\A"
    "10  PRAZO  01  RENDA  JUROS  META  001  FLUXO\A"
    "OBJETIVOS  011  TRAVESSIA  10  RESERVA  01";
  position: absolute;
  inset: -18%;
  color: rgba(61, 74, 48, 0.17);
  font-family: var(--mono);
  font-size: clamp(9px, 0.78vw, 13px);
  line-height: 2.35;
  letter-spacing: 0.24em;
  white-space: pre;
  transform: rotate(-7deg);
  animation: heroMatrixDrift 18s linear infinite;
}

.hero__matrix-texture::after {
  content: "";
  position: absolute;
  inset: 18% 8% 16% 2%;
  background:
    linear-gradient(100deg, transparent 0%, rgba(255,255,255,0.46) 46%, transparent 68%),
    radial-gradient(ellipse at 48% 52%, rgba(246,241,232,0.66), transparent 62%);
  filter: blur(1px);
}

.hero-showcase {
  position: relative;
  width: 100%;
  max-width: none;
  aspect-ratio: 1.5 / 1;
  z-index: 1;
  transform-origin: 50% 78%;
  animation: heroImageBounce 6.8s cubic-bezier(.45, 0, .2, 1) infinite;
  will-change: transform;
}

/* Notebook (laptop) à esquerda */
.hero-showcase__laptop {
  position: relative;
  top: auto;
  left: auto;
  width: 100%;
  z-index: 1;
  filter:
    drop-shadow(0 46px 70px rgba(30, 36, 24, 0.26))
    drop-shadow(0 20px 30px rgba(30, 36, 24, 0.16))
    drop-shadow(0 4px 8px rgba(140, 107, 42, 0.12));
}

.hero-showcase__laptop::after {
  content: "";
  position: absolute;
  left: 9%;
  right: 10%;
  bottom: 2%;
  height: 15%;
  z-index: -1;
  background: radial-gradient(ellipse at center, rgba(30, 36, 24, 0.32) 0%, rgba(30, 36, 24, 0.13) 38%, transparent 72%);
  filter: blur(18px);
  transform: translateY(42%);
}

.hero-showcase__laptop img {
  width: 100%;
  height: auto;
  object-fit: contain;
  object-position: center;
  transform: none;
}

@keyframes heroImageBounce {
  0%, 100% { transform: translate3d(0, 0, 0) rotate(0deg); }
  42% { transform: translate3d(0, -16px, 0) rotate(-0.35deg); }
  56% { transform: translate3d(0, -11px, 0) rotate(0.18deg); }
  70% { transform: translate3d(0, -14px, 0) rotate(-0.12deg); }
}

@keyframes heroMatrixDrift {
  0% { transform: translate3d(0, -3%, 0) rotate(-7deg); }
  100% { transform: translate3d(-4%, 8%, 0) rotate(-7deg); }
}

@media (prefers-reduced-motion: reduce) {
  .hero-showcase,
  .hero__matrix-texture::before {
    animation: none;
  }
}

.hero-showcase__laptop-screen {
  background: #1a1a1a;
  padding: 12px 12px 16px;
  border-radius: 10px 10px 4px 4px;
  border: 1px solid #2a2a2a;
  box-shadow:
    0 22px 48px rgba(30, 36, 24, 0.22),
    0 6px 14px rgba(30, 36, 24, 0.10),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.hero-showcase__laptop-screen img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 3px;
}

.hero-showcase__laptop-base {
  width: 112%;
  margin-left: -6%;
  height: 12px;
  background: linear-gradient(180deg, #d4d4d4 0%, #b8b8b8 50%, #888 100%);
  border-radius: 0 0 10px 10px;
  position: relative;
  box-shadow: 0 6px 14px rgba(30, 36, 24, 0.18);
}

.hero-showcase__laptop-base::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 70px;
  height: 5px;
  background: #888;
  border-radius: 0 0 7px 7px;
}

/* Celular ao centro (foto pronta com mão) */
.hero-showcase__phone {
  position: absolute;
  top: 0;
  left: 36%;
  width: 36%;
  z-index: 3;
  filter: drop-shadow(0 24px 36px rgba(30, 36, 24, 0.28))
          drop-shadow(0 6px 14px rgba(30, 36, 24, 0.14));
}

.hero-showcase__phone img {
  display: block;
  width: 100%;
  height: auto;
}

/* Janela Chrome à direita */
.hero-showcase__chrome {
  position: absolute;
  top: 16%;
  right: 0;
  width: 36%;
  z-index: 2;
  border-radius: 10px;
  overflow: hidden;
  background: #fff;
  box-shadow:
    0 22px 44px rgba(30, 36, 24, 0.20),
    0 6px 12px rgba(30, 36, 24, 0.08);
}

.hero-showcase__chrome-bar {
  background: #e8e8e8;
  height: 26px;
  display: flex;
  align-items: center;
  padding: 0 10px;
  gap: 6px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.hero-showcase__chrome-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #ccc;
  flex-shrink: 0;
}

.hero-showcase__chrome-dot:nth-child(1) { background: #fc615d; }
.hero-showcase__chrome-dot:nth-child(2) { background: #fdbe40; }
.hero-showcase__chrome-dot:nth-child(3) { background: #34c84a; }

.hero-showcase__chrome-url {
  margin-left: 10px;
  padding: 2px 12px;
  background: #f7f7f7;
  border-radius: 999px;
  font-family: var(--mono);
  font-size: 10px;
  color: #888;
  flex: 1;
  max-width: 120px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.hero-showcase__chrome-screen img {
  display: block;
  width: 100%;
  height: auto;
}

@media (max-width: 1024px) {
  .hero-showcase { max-width: 540px; }
}

@media (max-width: 720px) {
  .hero-showcase {
    max-width: 100%;
    aspect-ratio: 1.05 / 1;
  }
  .hero-showcase__chrome-url { display: none; }
}

/* Scroll hint */
.hero__scroll {
  position: absolute;
  bottom: 90px; left: 50%;
  transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  font-family: var(--mono);
  font-size: 10px; letter-spacing: 0.3em;
  color: var(--ink-soft); text-transform: uppercase;
  z-index: 5;
}
.hero__scroll-line {
  width: 1px; height: 40px;
  background: linear-gradient(180deg, var(--gold) 0%, transparent 100%);
  position: relative;
  overflow: hidden;
}
.hero__scroll-line::after {
  content: "";
  position: absolute; left: 0; top: 0;
  width: 100%; height: 50%;
  background: var(--gold-deep);
  animation: scrollDown 1.8s cubic-bezier(.6,0,.4,1) infinite;
}
@keyframes scrollDown {
  0% { transform: translateY(-100%); }
  100% { transform: translateY(200%); }
}

@media (max-width: 1320px) and (min-width: 1101px) {
  .hero__grid {
    width: min(1360px, 90vw);
    grid-template-columns: minmax(0, 0.88fr) minmax(460px, 1.12fr);
    gap: clamp(32px, 3.4vw, 52px);
  }
  .hero__title {
    font-size: clamp(3.35rem, 4.45vw, 4.05rem);
    line-height: 1;
  }
  .hero__title-line--pressure {
    font-size: 0.9em;
  }
  .hero__title-line--long {
    max-width: 9.7em;
  }
  .hero__lede {
    max-width: 44ch;
  }
  .hero__visual--showcase {
    width: min(100%, 680px);
  }
  .hero__proof {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 20px 0;
  }
  .hero__proof-item {
    padding: 0 18px;
  }
  .hero__proof-item:nth-child(odd) {
    border-left: none;
    padding-left: 0;
  }
  .hero__proof-item:nth-child(even) {
    padding-right: 0;
  }
  .hero__proof-item:nth-child(n+3) {
    padding-top: 20px;
    border-top: 1px solid rgba(61,74,48,0.1);
  }
  .hero__scroll {
    display: none;
  }
}

/* Tablet: keep 2 columns, text still dominant, image smaller on right */
@media (max-width: 1100px) and (min-width: 721px) {
  .hero { padding: 110px 0 120px; }
  .hero__grid {
    width: min(980px, 90vw);
    grid-template-columns: 1fr;
    gap: 48px;
  }
  .hero__visual--showcase {
    aspect-ratio: auto;
    justify-self: center;
    width: min(82vw, 720px);
  }
  .hero__visual-quote { display: none; }
  .hero__visual-stamp { left: 20px; bottom: 20px; padding: 10px 14px; }
  .hero__title { font-size: clamp(2.6rem, 5.85vw, 4.05rem); line-height: 1.02; }
  .hero__title-line--pressure { font-size: 0.92em; }
  .hero__proof { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 20px 0; }
  .hero__proof-item { padding: 0 18px; }
  .hero__proof-item:nth-child(odd) { border-left: none; padding-left: 0; }
  .hero__proof-item:nth-child(even) { padding-right: 0; }
  .hero__proof-item:nth-child(n+3) { padding-top: 20px; border-top: 1px solid rgba(61,74,48,0.1); }
  .hero__bg-mark { font-size: 40rem; }
}
/* Mobile / small: full stack */
@media (max-width: 720px) {
  .hero {
    padding: 90px 0 72px;
  }
  .hero__bg-photo {
    display: block;
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    overflow: hidden;
  }
  .hero__grid {
    position: relative;
    z-index: 2;
  }
  .hero__bg-photo::before {
    content: "";
    position: absolute;
    right: -18%;
    top: 0;
    bottom: 0;
    width: 80%;
    background-image: url('assets/fundomobile.webp');
    background-size: contain;
    background-position: right 18%;
    background-repeat: no-repeat;
    opacity: 0.32;
    will-change: transform;
    transform: translate3d(0, var(--hero-bg-offset, 0), 0);
  }
  .hero__bg-photo::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
      linear-gradient(105deg,
        rgba(243, 237, 221, 0.95) 0%,
        rgba(243, 237, 221, 0.78) 35%,
        rgba(243, 237, 221, 0.3) 70%,
        rgba(243, 237, 221, 0.55) 100%),
      linear-gradient(180deg,
        rgba(243, 237, 221, 0) 55%,
        rgba(243, 237, 221, 0.85) 100%);
    pointer-events: none;
  }
  .hero__grid { width: 92vw; grid-template-columns: 1fr; gap: 28px; }
  .hero__copy,
  .hero__title,
  .hero__lede {
    width: 92vw;
    max-width: 92vw;
  }
  .hero__title {
    font-size: clamp(2.12rem, 8.7vw, 2.8rem);
    line-height: 1;
    margin-bottom: 22px;
  }
  .hero__title-line,
  .hero__title-line--long {
    white-space: normal;
    max-width: none;
  }
  .hero__title-line--pressure em {
    display: block;
    width: max-content;
  }
  .hero__eyebrow {
    display: block;
    max-width: 34ch;
    line-height: 1.65;
  }
  .hero__lede {
    width: min(360px, 92vw);
    max-width: min(360px, 92vw);
    overflow-wrap: anywhere;
    font-size: 15px;
    line-height: 1.5;
    margin-bottom: 28px;
  }
  /* Hide the image block on mobile, photo now lives in the hero bg */
  .hero__visual { display: none; }
  /* Compact CTA */
  .hero__ctas { margin-bottom: 44px; gap: 14px; }
  .hero__cta-main.btn--lg {
    padding: 18px 24px;
    font-size: 11.5px;
    letter-spacing: 0.16em;
    width: auto;
    align-self: flex-start;
  }
  .hero__cta-main .btn__arrow { width: 28px; }
  .hero__cta-meta { font-size: 12px; gap: 8px; }
  .hero__proof { width: 92vw; max-width: 92vw; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px 0; margin-bottom: 72px; }
  .hero__proof-l { font-size: 10px; letter-spacing: 0.07em; overflow-wrap: anywhere; }
  .hero__proof-item { padding: 0 14px; }
  .hero__proof-item:nth-child(odd) { border-left: none; padding-left: 0; }
  .hero__proof-item:nth-child(even) { padding-right: 0; }
  .hero__proof-item:nth-child(n+3) { padding-top: 18px; border-top: 1px solid rgba(61,74,48,0.1); }
  .hero__proof-n { font-size: clamp(1.8rem, 6vw, 2.2rem); }
  .hero__scroll { display: none; }
  .hero__bg-mark { font-size: 30rem; right: -10vw; top: 6vw; opacity: 0.12; }
}
@media (max-width: 520px) {
  .nav__brand-name { font-size: 18px; letter-spacing: 0.14em; }
  .nav__cta { display: none; }
  .hero__title { font-size: clamp(2.05rem, 8.8vw, 2.75rem); }
  .hero__ctas { gap: 20px; margin-bottom: 56px; }
  .hero__visual-quote { display: none; }
}

/* =========================================================
   DOBRA 02 · Linha do tempo
   ========================================================= */
.tline {
  background: var(--bg);
  padding: 140px 0 160px;
  position: relative;
}
.tline__head {
  display: grid; grid-template-columns: 1fr 1fr; gap: 80px;
  margin-bottom: 100px;
  align-items: end;
}
.tline__head-left .eyebrow { display: inline-flex; margin-bottom: 28px; }
.tline__head-left h2 {
  font-size: clamp(2.6rem, 5vw, 4.6rem);
  line-height: 1.0;
  letter-spacing: -0.02em;
}
.tline__head-left h2 em { color: var(--gold-deep); }
.tline__head-left h2 .u-serif {
  text-decoration: none;
  position: relative; font-style: italic;
}
.tline__head-left h2 .u-serif::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: 2%;
  height: 2px; background: var(--gold);
}
.tline__head-right {
  font-size: 17px; line-height: 1.7;
  color: var(--ink-muted);
  max-width: 46ch;
}
.tline__head-right b { color: var(--bg-deep); font-weight: 600; }

/* Horizontal rail */
.tline__rail {
  position: relative;
  padding: 60px 0 0;
}
.tline__rail-line {
  position: absolute;
  left: 0; right: 0;
  top: 158px;
  height: 2px;
  background: repeating-linear-gradient(90deg, var(--gold-deep) 0 6px, transparent 6px 12px);
  opacity: 0.5;
  z-index: 0;
}
.tline__rail-arrow {
  position: absolute;
  right: -8px; top: 145px;
  color: var(--gold-deep);
  z-index: 2;
  background: var(--bg);
  padding: 2px 0 2px 4px;
}
.tline__markers {
  display: grid;
  grid-template-columns: auto 1fr 1fr 1fr auto;
  gap: 36px;
  align-items: start;
  position: relative;
  z-index: 1;
}

/* Start & end caps */
.tline__start, .tline__end {
  align-self: start;
  padding-top: 110px;
  position: relative;
  text-align: center;
  min-width: 88px;
}
.tline__end { text-align: center; }
.tline__start-label, .tline__end-label {
  margin-top: 16px;
}
.tline__marker-day {
  font-family: var(--sans);
  font-size: 22px; font-style: italic;
  color: var(--bg-deep);
  line-height: 1;
  margin-bottom: 6px;
}
.tline__marker-hint {
  font-family: var(--sans);
  font-size: 10px; letter-spacing: 0.18em;
  color: var(--ink-soft); text-transform: uppercase;
  max-width: 12ch;
  margin: 0 auto;
  line-height: 1.4;
}

/* Step, each destrave */
.tline__step {
  position: relative;
  padding-top: 0;
}
.tline__marker {
  height: 90px;
  display: flex; align-items: flex-end; justify-content: center;
  margin-bottom: 12px;
  position: relative;
}
.tline__marker-n {
  font-family: var(--sans);
  font-size: clamp(4rem, 6vw, 6.5rem);
  font-style: italic;
  color: var(--gold-deep);
  line-height: 0.85;
  font-weight: 500;
  text-shadow: 2px 2px 0 rgba(184,146,74,0.12);
}
.tline__dot {
  width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--gold);
  border: 4px solid var(--bg);
  box-shadow: 0 0 0 1px var(--gold-deep);
  margin: 0 auto 24px;
  position: relative;
  z-index: 3;
}
.tline__dot--start, .tline__dot--end {
  width: 14px; height: 14px;
  background: var(--bg);
  border: 2px solid var(--gold-deep);
  box-shadow: none;
  margin-bottom: 0;
}
.tline__dot--end {
  background: var(--bg-deep);
  border-color: var(--bg-deep);
}

.tline__card {
  background: #fbf7ec;
  border: 1px solid var(--line);
  padding: 28px 26px 32px;
  position: relative;
  border-radius: var(--radius-lg);
  transition: transform 0.4s cubic-bezier(.2,.7,.2,1), box-shadow 0.4s, border-color 0.4s;
}
.tline__step:hover .tline__card {
  transform: translateY(-6px);
  box-shadow: 0 28px 50px -30px rgba(43,51,31,0.28);
  border-color: var(--gold);
}
.tline__card-head {
  display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 16px; margin-bottom: 18px;
  border-bottom: 1px solid var(--line);
}
.tline__card-time {
  font-family: var(--sans); font-size: 11px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-soft);
}
.tline__card-time b { color: var(--gold-deep); font-weight: 600; }
.tline__card-phase {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--bg-deep);
  padding: 4px 8px;
  border: 1px solid var(--line);
  background: var(--bg);
}
.tline__card-title {
  font-family: var(--sans);
  font-size: clamp(1.6rem, 2vw, 2.1rem);
  color: var(--bg-deep);
  line-height: 1.05;
  margin-bottom: 10px;
  letter-spacing: -0.01em;
}
.tline__card-promise {
  font-size: 14.5px; line-height: 1.5;
  color: var(--ink);
  padding-bottom: 20px;
  margin-bottom: 18px;
  border-bottom: 1px dashed rgba(140,107,42,0.2);
}
.tline__card-promise b { color: var(--bg-deep); font-weight: 600; }
.tline__card-list { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.tline__card-list li {
  display: grid; grid-template-columns: 16px 1fr; gap: 10px; align-items: start;
  font-size: 13.5px; line-height: 1.5;
  color: var(--ink-muted);
}
.tline__card-list li::before {
  content: "";
  margin-top: 8px;
  width: 8px; height: 1px;
  background: var(--gold-deep);
}
.tline__card-list li i { font-style: italic; color: var(--gold-deep); }

/* Foot */
.tline__foot {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 72px;
  padding-top: 28px;
  border-top: 1px solid var(--line);
  font-family: var(--sans);
  font-size: 14px;
  color: var(--ink-muted);
}
.tline__foot b { color: var(--bg-deep); font-weight: 600; }
.tline__jump {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--bg-deep); font-weight: 500;
  padding: 14px 22px;
  border: 1px solid var(--bg-deep);
  border-radius: 2px;
  transition: all 0.3s;
}
.tline__jump:hover { background: var(--bg-deep); color: var(--bg); }
.tline__jump span { font-family: var(--sans); font-style: italic; font-size: 15px; }

/* Tablet, 3 cards stay horizontal but smaller */
@media (max-width: 1080px) {
  .tline__head { grid-template-columns: 1fr; gap: 28px; }
  .tline__markers { gap: 24px; }
}

/* Mobile, vertical timeline with line on left */
@media (max-width: 820px) {
  .tline { padding: 100px 0 110px; }
  .tline__rail { padding: 40px 0 0 0; }
  .tline__rail-line {
    top: 0; bottom: 0; left: 24px; right: auto;
    width: 2px; height: auto;
    background: repeating-linear-gradient(180deg, var(--gold-deep) 0 6px, transparent 6px 12px);
  }
  .tline__rail-arrow {
    top: auto; right: auto;
    bottom: -10px; left: 15px;
    transform: rotate(90deg);
    background: var(--bg);
  }
  .tline__markers {
    grid-template-columns: 1fr;
    gap: 28px;
    padding-left: 60px;
    position: relative;
  }
  .tline__start, .tline__end {
    padding-top: 0;
    padding-left: 0;
    text-align: left;
    min-width: 0;
    display: grid; grid-template-columns: auto 1fr; align-items: center; gap: 12px;
  }
  .tline__start { margin-left: -50px; }
  .tline__end { margin-left: -50px; }
  .tline__dot--start, .tline__dot--end {
    margin: 0;
  }
  .tline__start-label, .tline__end-label {
    margin-top: 0; text-align: left;
  }
  .tline__marker-hint { margin: 0; max-width: none; }
  .tline__step { padding-top: 0; position: relative; }
  .tline__marker {
    position: absolute;
    top: 6px; left: -50px;
    height: auto;
    margin-bottom: 0;
    z-index: 2;
  }
  .tline__marker-n {
    font-size: 3rem;
    text-shadow: none;
  }
  .tline__dot {
    position: absolute;
    top: 26px; left: -38px;
    margin: 0;
  }
  .tline__card { padding: 22px 22px 26px; }
  .tline__foot { flex-direction: column; gap: 20px; align-items: flex-start; }
}

/* ============================================================
   Dobra 02 · Dossiê / Diagnóstico
   ============================================================ */

.dossie {
  position: relative;
  overflow: hidden;
  padding-top: 0;
}

.dossie__act {
  padding: clamp(96px, 14vh, 160px) 0;
  position: relative;
}

.dossie__act--entry {
  background: var(--bg-deep);
  color: #e4ddc8;
  padding-bottom: clamp(48px, 7vh, 82px);
}


.dossie__act--ledger {
  background: var(--bg);
  color: var(--ink);
  padding-top: clamp(48px, 7vh, 84px);
  padding-bottom: clamp(24px, 3vh, 40px);
  border-top: 1px solid rgba(138, 106, 42, 0.35);
  box-shadow: 0 -24px 48px -24px rgba(0, 0, 0, 0.45);
}

.dossie__act--ledger > .wrap {
  position: relative;
  z-index: 2;
}

/* ---- Welcoming discourse block, replaces the old bridge ---- */

.dossie__problema {
  max-width: 780px;
  margin: 0 auto 72px;
  padding-top: 24px;
}

.dossie__problema {
  text-align: center;
}

/* Mirrors .dossie__headline scale, Fraunces display to match the rest
   of the page's section titles, only color adapts for cream bg */
.dossie .dossie__problema-title {
  font-family: var(--display);
  font-variation-settings: "SOFT" 100, "opsz" 144;
  font-size: clamp(1.7rem, 3.2vw, 2.6rem);
  line-height: 1.15;
  letter-spacing: -0.015em;
  font-weight: 400;
  color: var(--ink);
  margin: 0 auto 32px;
  max-width: 26ch;
}

/* Word-by-word reveal. Each word fades + slides in with a staggered delay
   when the parent .dossie__problema (which has .reveal) intersects. */
.dossie__problema-word {
  display: inline-block;
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 720ms cubic-bezier(.2,.7,.2,1), transform 720ms cubic-bezier(.22,.61,.36,1);
}

.dossie__problema.is-visible .dossie__problema-word {
  opacity: 1;
  transform: none;
}

.dossie__problema.is-visible .dossie__problema-word:nth-child(1) { transition-delay: 160ms; }
.dossie__problema.is-visible .dossie__problema-word:nth-child(2) { transition-delay: 280ms; }
.dossie__problema.is-visible .dossie__problema-word:nth-child(3) { transition-delay: 400ms; }
.dossie__problema.is-visible .dossie__problema-word:nth-child(4) { transition-delay: 520ms; }
.dossie__problema.is-visible .dossie__problema-word:nth-child(5) { transition-delay: 640ms; }

@media (prefers-reduced-motion: reduce) {
  .dossie__problema-word {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

.dossie .dossie__problema-lead {
  font-family: var(--sans);
  font-size: clamp(0.98rem, 1.15vw, 1.08rem);
  line-height: 1.65;
  color: var(--ink-muted);
  margin: 0 auto 40px;
  max-width: 56ch;
}

.dossie__problema-question {
  font-family: var(--display);
  font-variation-settings: "SOFT" 100, "opsz" 144;
  font-size: clamp(1.3rem, 2.2vw, 1.7rem);
  font-style: italic;
  font-weight: 400;
  color: var(--gold-deep);
  text-align: center;
  margin: 0 auto 12px;
  letter-spacing: -0.01em;
}

.dossie__problema-answer {
  font-family: var(--display);
  font-variation-settings: "SOFT" 100, "opsz" 144;
  font-size: clamp(1.05rem, 1.4vw, 1.25rem) !important;
  font-style: italic;
  font-weight: 400;
  color: var(--gold-deep);
  text-align: center;
  margin: 0 auto 24px !important;
  letter-spacing: -0.005em;
  max-width: 56ch;
}

.dossie__problema-callout {
  background: var(--bg-deep);
  color: var(--bg);
  padding: 32px 36px;
  border-radius: var(--radius-lg);
  border-left: 3px solid var(--gold);
  position: relative;
  max-width: 680px;
  margin: 0 auto 24px;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.dossie__problema-callout p {
  margin: 0;
  color: var(--bg);
}

.dossie__problema-callout-intro {
  font-family: var(--sans);
  font-size: clamp(0.95rem, 1.15vw, 1.05rem);
  line-height: 1.5;
  font-weight: 400;
  opacity: 0.85;
}

.dossie__problema-callout-punch {
  font-family: var(--display);
  font-variation-settings: "SOFT" 100, "opsz" 144;
  font-size: clamp(1.5rem, 2.6vw, 2.05rem) !important;
  line-height: 1.2;
  letter-spacing: -0.01em;
  font-weight: 400;
  color: var(--gold-2) !important;
}

.dossie__problema-callout-punch em {
  font-style: italic;
  color: var(--gold-2);
  font-weight: 500;
}

/* Verde-sálvia do brand pra punch words */
.highlight-green,
.on-dark .highlight-green,
.on-dark strong.highlight-green {
  color: var(--bg-deep) !important;
  font-weight: 600 !important;
  font-style: normal;
  background: rgba(61, 74, 48, 0.10);
  padding: 1px 6px;
  border-radius: 4px;
}

.dossie__problema-detail {
  font-family: var(--sans);
  font-size: clamp(0.92rem, 1.05vw, 1rem);
  line-height: 1.65;
  color: var(--ink-soft);
  text-align: center;
  margin: 0 auto;
  max-width: 56ch;
  font-style: italic;
}

.dossie__problema-callout em {
  font-family: var(--display);
  font-variation-settings: "SOFT" 100, "opsz" 144;
  font-style: italic;
  font-weight: 500;
  color: var(--gold);
  letter-spacing: -0.01em;
}

/* Punchline, diagnostic reveal. Fraunces italic + gold rule underline
   (same gesture used on "90%" in ATO 1 and "renda" in the title). */
.dossie__problema-callout-reveal {
  font-family: var(--display);
  font-variation-settings: "SOFT" 100, "opsz" 144;
  font-style: italic;
  font-weight: 500;
  font-size: clamp(1.55rem, 2.4vw, 2.1rem);
  line-height: 1.3;
  letter-spacing: -0.012em;
  margin: 28px 0 0;
}

.dossie__problema-callout-reveal .dossie__mark--rule {
  white-space: normal;
}

@media (max-width: 720px) {
  .dossie__problema-callout-reveal {
    margin-top: 22px;
    font-size: clamp(1.4rem, 5.5vw, 1.8rem);
  }
}

@media (max-width: 720px) {
  .dossie__problema { margin-bottom: 48px; }
  .dossie__problema-callout { padding: 28px 24px; }
}

/* ---- Ato 1 · Entrada ---- */

.dossie__act--entry .wrap {
  text-align: center;
}

.dossie__overline {
  font-family: var(--mono);
  font-size: clamp(11px, 1.1vw, 13px);
  font-weight: 600;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--gold-2);
  margin: 0 0 28px;
  display: inline-block;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(212, 176, 114, 0.38);
}

.dossie__headline {
  font-family: var(--display);
  font-variation-settings: "SOFT" 100, "opsz" 144;
  font-size: clamp(1.7rem, 3.2vw, 2.6rem);
  line-height: 1.15;
  letter-spacing: -0.015em;
  font-weight: 400;
  max-width: 28ch;
  margin: 0 auto 36px;
  color: #f2ecdc;
}

.dossie__hook {
  font-family: var(--sans);
  font-size: clamp(1.05rem, 1.4vw, 1.18rem);
  line-height: 1.55;
  max-width: 56ch;
  margin: 0 auto;
  color: #d8d2c2;
  letter-spacing: 0;
  font-style: normal;
}

.dossie__hook em {
  font-style: italic;
  color: var(--gold-2);
  font-weight: 500;
}

/* ---- Ato 2 · Registro editorial (página creme) ---- */

.dossie__rule {
  height: 1px;
  background: linear-gradient(90deg, var(--gold) 0%, rgba(184, 146, 74, 0.2) 60%, transparent 100%);
  margin: 0 0 44px;
}

.dossie__prose p {
  font-family: var(--sans);
  font-size: clamp(1.1rem, 1.5vw, 1.3rem);
  line-height: 1.56;
  color: var(--ink);
  max-width: 58ch;
  margin: 0 0 24px;
}

.dossie__tried {
  font-family: var(--mono) !important;
  font-size: 14px !important;
  line-height: 1.8 !important;
  color: var(--ink-muted) !important;
  letter-spacing: 0.01em;
}

/* ---- Nota/Bilhete (Ato 2, após lista de sintomas) ---- */

.dossie__note {
  position: relative;
  max-width: 620px;
  margin: 52px auto 0;
  text-align: center;
}

/* Simplified: flat prose aside, calm and welcoming. */
.dossie__note-paper {
  position: relative;
}

/* Delay inner reveals so paper pouches first */
.dossie__note-paper .reveal {
  transition-delay: 200ms;
}

.dossie__note-headline {
  font-family: var(--sans);
  font-size: clamp(1.75rem, 3.2vw, 2.4rem);
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: -0.012em;
  color: var(--bg-deeper);
  margin: 0 0 1rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid rgba(184, 146, 74, 0.25);
}

.dossie__note-headline em {
  font-style: italic;
  color: var(--gold-deep);
}

.dossie__note-prose {
  margin: 0;
}

.dossie__note-prose p {
  font-family: var(--sans);
  font-size: clamp(1.0rem, 1.4vw, 1.2rem);
  font-weight: 400;
  line-height: 1.58;
  color: var(--ink-muted);
  max-width: 52ch;
  margin: 0;
}

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

.dossie__note-attrib {
  margin-top: 12px !important;
  font-family: var(--mono, var(--sans));
  font-size: 0.78rem !important;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-muted);
  opacity: 0.7;
}

.dossie__note-intro {
  font-family: var(--sans);
  font-size: clamp(0.95rem, 1.15vw, 1.05rem);
  line-height: 1.55;
  color: var(--ink-muted);
  font-style: italic;
  text-align: center;
  margin: 0 auto 24px;
  max-width: 48ch;
}

/* ---- Variant: nota com print do depoimento ---- */
.dossie__note--with-image .dossie__note-paper {
  display: grid;
  grid-template-columns: minmax(200px, 280px) 1fr;
  gap: clamp(20px, 3vw, 36px);
  align-items: center;
}

.dossie__note-image {
  position: relative;
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: 0 14px 32px rgba(30, 36, 24, 0.14), 0 3px 8px rgba(30, 36, 24, 0.06);
  background: var(--cream-card);
}

.dossie__note-image img {
  display: block;
  width: 100%;
  height: auto;
}

@media (max-width: 720px) {
  .dossie__note--with-image .dossie__note-paper {
    grid-template-columns: 1fr;
    gap: 20px;
    text-align: left;
  }
  .dossie__note-image {
    max-width: 280px;
    margin: 0 auto;
  }
}

@media (max-width: 540px) {
  .dossie__note { margin-top: 40px; }
  .dossie__note-paper { padding-left: 16px; }
}

/* ---- Régua dourada (gesto visual que rima entre "90%" e "ordem") ---- */

.dossie__mark--rule {
  position: relative;
  color: var(--gold-2);
  font-weight: 500;
  white-space: nowrap;
}

.dossie__mark--rule::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -0.08em;
  height: 2px;
  background: var(--gold-2);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 900ms cubic-bezier(.2, .7, .2, 1);
}

.dossie__mark--rule.is-drawn::after {
  transform: scaleX(1);
}

/* ---- Mobile ---- */

@media (max-width: 720px) {
  .dossie__act { padding: 72px 0; }
  .dossie__act--entry { padding-bottom: 48px; }
  .dossie__act--ledger { padding-top: 48px; }
  .dossie__overline {
    font-size: 10.5px;
    letter-spacing: 0.28em;
    margin-bottom: 22px;
  }
  .dossie__headline {
    font-size: clamp(2rem, 8.5vw, 2.8rem);
    margin-bottom: 40px;
  }
  .dossie__hook {
    font-size: clamp(1.35rem, 6vw, 1.8rem);
    padding-left: 18px;
  }
}

/* prefers-reduced-motion: skip the rule draw */
@media (prefers-reduced-motion: reduce) {
  .dossie__mark--rule::after {
    transition: none;
    transform: scaleX(1);
  }
}

/* =========================================================
   DOBRA 03 · Prova lógica · A virada
   (entre dossie e metodo, fundo creme escuro suave)
   ========================================================= */

.virada {
  background: var(--bg-2);
  padding: clamp(80px, 10vw, 140px) 0;
  position: relative;
}

.virada__inner {
  max-width: 880px;
  text-align: left;
}

.virada__eyebrow {
  display: block;
  margin-bottom: 24px;
}

.virada__title {
  font-size: clamp(2rem, 4vw, 2.8rem);
  line-height: 1.15;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin: 0 0 16px;
  font-weight: 400;
}

.virada__title em {
  font-style: italic;
  color: var(--gold-deep);
}

.virada__subhead {
  font-family: var(--display);
  font-size: clamp(1.3rem, 2.2vw, 1.7rem);
  line-height: 1.35;
  color: var(--ink-muted);
  margin: 0 0 56px;
  font-weight: 300;
}

.virada__subhead em {
  font-style: italic;
  color: var(--gold-deep);
  font-weight: 400;
}

.virada__sub-h {
  font-family: var(--display);
  font-size: clamp(1.4rem, 2.4vw, 1.9rem);
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin: 56px 0 18px;
  padding-top: 32px;
  border-top: 1px solid rgba(184, 146, 74, 0.22);
}

.virada__sub-h em {
  font-style: italic;
  color: var(--gold-deep);
}

/* Legacy contrast classes — kept for compatibility but unused now */
.virada__contrast {
  border-left: 2px solid var(--gold);
  padding: 4px 0 4px 28px;
  margin: 0 0 64px;
}

.virada__contrast-before,
.virada__contrast-after {
  font-family: var(--display);
  font-size: clamp(1.35rem, 2.4vw, 1.85rem);
  line-height: 1.35;
  margin: 0;
  font-weight: 300;
}

.virada__body p {
  font-family: var(--sans);
  font-size: clamp(1.02rem, 1.4vw, 1.15rem);
  line-height: 1.65;
  color: var(--ink-muted);
  margin: 0 0 22px;
  max-width: 60ch;
}

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

.virada__bridge {
  font-family: var(--sans) !important;
  font-size: clamp(1.02rem, 1.4vw, 1.18rem) !important;
  line-height: 1.6 !important;
  color: var(--ink) !important;
  margin: 36px 0 28px !important;
  padding: 24px 28px;
  background: rgba(184, 146, 74, 0.08);
  border-radius: var(--radius-md);
  border-left: 3px solid var(--gold);
  max-width: none !important;
}

.virada__bridge strong {
  color: var(--gold-deep);
  font-weight: 600;
}

.virada__bridge em {
  font-style: italic;
  color: var(--ink-soft);
  font-weight: 400;
}

.virada__principio {
  font-family: var(--display) !important;
  font-size: clamp(1.25rem, 2vw, 1.55rem) !important;
  line-height: 1.4 !important;
  color: var(--ink) !important;
  margin: 36px 0 !important;
  padding: 0 0 0 24px;
  border-left: 2px solid var(--gold-2);
  font-weight: 400 !important;
}

.virada__principio em {
  font-style: italic;
  color: var(--gold-deep);
}

.virada__entrega {
  margin-top: 48px;
}

.virada__entrega-lead {
  font-weight: 500 !important;
  color: var(--ink) !important;
  margin-bottom: 16px !important;
}

.virada__entrega-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.virada__entrega-list li {
  position: relative;
  padding-left: 28px;
  font-family: var(--sans);
  font-size: clamp(1rem, 1.35vw, 1.1rem);
  line-height: 1.6;
  color: var(--ink-muted);
}

.virada__entrega-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.7em;
  width: 14px;
  height: 1px;
  background: var(--gold);
}

.virada__entrega-list li strong {
  color: var(--ink);
  font-weight: 600;
}

.virada__close {
  margin: 56px 0 0;
  padding: 28px 32px;
  background: rgba(184, 146, 74, 0.06);
  border-radius: var(--radius-md);
  font-family: var(--display);
  font-size: clamp(1.15rem, 1.7vw, 1.4rem);
  line-height: 1.5;
  color: var(--ink);
  border: none;
  font-weight: 300;
}

.virada__close strong {
  color: var(--gold-deep);
  font-weight: 500;
}

/* ---- Depoimento como prova da virada ---- */
.virada__proof-intro {
  font-family: var(--display);
  font-size: clamp(1.1rem, 1.6vw, 1.35rem) !important;
  line-height: 1.4 !important;
  color: var(--ink) !important;
  text-align: center;
  margin: 64px auto 28px !important;
  max-width: 48ch;
  font-weight: 400 !important;
  font-style: normal !important;
}

.virada__proof-intro em {
  font-style: italic;
  color: var(--gold-deep);
  font-weight: 500;
}

.virada__proof {
  display: grid;
  grid-template-columns: minmax(220px, 300px) 1fr;
  gap: clamp(28px, 4vw, 48px);
  align-items: center;
  margin: 0 auto;
  max-width: 880px;
  padding: 32px;
  background: var(--bg);
  border-radius: var(--radius-lg);
  border: 1px solid var(--line);
}

.virada__proof-image {
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: 0 14px 32px rgba(30, 36, 24, 0.14);
  background: var(--cream-card);
}

.virada__proof-image img {
  display: block;
  width: 100%;
  height: auto;
}

.virada__proof-text blockquote {
  font-family: var(--display);
  font-size: clamp(1.15rem, 1.7vw, 1.35rem);
  line-height: 1.5;
  color: var(--ink);
  font-weight: 300;
  margin: 0 0 16px;
}

.virada__proof-text blockquote strong {
  color: var(--gold-deep);
  font-weight: 500;
  font-style: italic;
}

.virada__proof-text figcaption {
  font-family: var(--mono, var(--sans));
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-soft);
  font-weight: 500;
}

@media (max-width: 720px) {
  .virada { padding: 64px 0; }
  .virada__contrast { padding-left: 18px; margin-bottom: 44px; }
  .virada__principio { padding-left: 16px !important; }
  .virada__close { padding: 22px 20px; }
  .virada__sub-h { margin-top: 40px; padding-top: 24px; }

  .virada__proof {
    grid-template-columns: 1fr;
    padding: 24px;
    gap: 20px;
  }
  .virada__proof-image {
    max-width: 280px;
    margin: 0 auto;
  }
}

/* =========================================================
   Proof anchor · depoimento espalhado entre dobras
   ========================================================= */

.proof-anchor {
  padding: clamp(48px, 7vw, 80px) 0;
  background: var(--bg);
}

.proof-anchor__inner {
  max-width: 720px;
  text-align: center;
}

.proof-anchor__intro {
  font-family: var(--display);
  font-size: clamp(1.55rem, 2.35vw, 2.15rem);
  line-height: 1.18;
  color: var(--bg-deeper);
  text-align: center;
  margin: 0 auto 40px;
  max-width: 42ch;
  font-weight: 400;
  letter-spacing: -0.018em;
  position: relative;
}

.proof-anchor__intro::after {
  content: "";
  display: block;
  width: 72px;
  height: 2px;
  margin: 18px auto 0;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  opacity: 0.75;
}

.proof-anchor__intro strong {
  color: var(--bg-deeper);
  font-weight: 500;
}

.proof-anchor__intro em {
  display: inline-block;
  font-style: italic;
  color: var(--gold-deep);
  font-weight: 500;
  position: relative;
  white-space: nowrap;
  z-index: 0;
}

.proof-anchor__intro em::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0.02em;
  height: 0.14em;
  background: rgba(184,146,74,0.16);
  z-index: -1;
}

.proof-anchor__quote {
  margin: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}

.proof-anchor__mark {
  color: var(--gold);
  opacity: 0.55;
}

.proof-anchor__quote blockquote {
  font-family: var(--display);
  font-size: clamp(1.4rem, 2.6vw, 1.95rem);
  line-height: 1.4;
  font-weight: 300;
  color: var(--ink);
  margin: 0;
  max-width: 28ch;
}

.proof-anchor__quote blockquote strong {
  font-weight: 500;
  color: var(--gold-deep);
  font-style: italic;
}

.proof-anchor__quote figcaption {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  margin-top: 12px;
}

.proof-anchor__name {
  font-family: var(--sans);
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--ink);
}

.proof-anchor__ctx {
  font-family: var(--sans);
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  color: var(--ink-soft);
  text-transform: lowercase;
}

/* ---- Variant: depoimento com print ao lado ---- */
.proof-anchor--with-image .proof-anchor__inner {
  max-width: 1040px;
}

.proof-anchor__quote--with-image {
  display: grid;
  grid-template-columns: minmax(0, 0.8fr) minmax(0, 1fr);
  gap: clamp(32px, 5vw, 64px);
  align-items: center;
  text-align: left;
}

.proof-anchor__image {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: 0 18px 40px rgba(30, 36, 24, 0.14), 0 4px 10px rgba(30, 36, 24, 0.08);
  background: var(--cream-card);
}

.proof-anchor__image img {
  display: block;
  width: 100%;
  height: auto;
}

.proof-anchor__quote--with-image .proof-anchor__text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 18px;
}

.proof-anchor__quote--with-image blockquote {
  text-align: left;
  max-width: 32ch;
}

.proof-anchor__quote--with-image figcaption {
  align-items: flex-start;
  margin-top: 4px;
}

@media (max-width: 820px) {
  .proof-anchor__quote--with-image {
    grid-template-columns: 1fr;
    gap: 28px;
    text-align: center;
  }
  .proof-anchor__quote--with-image .proof-anchor__text {
    align-items: center;
  }
  .proof-anchor__quote--with-image blockquote {
    text-align: center;
  }
  .proof-anchor__quote--with-image figcaption {
    align-items: center;
  }
  .proof-anchor__image {
    max-width: 360px;
    margin: 0 auto;
  }
}

/* =========================================================
   DOBRA 05 · Solução + Jornada interativa
   ========================================================= */
.solucao {
  padding: 0;
  background: var(--bg);
  overflow: visible;
}
.solucao--editorial {
  background:
    linear-gradient(180deg, rgba(246,241,232,0.94) 0%, var(--bg) 42%, rgba(239,232,220,0.72) 100%),
    linear-gradient(115deg, rgba(184,146,74,0.08) 0%, transparent 34%, rgba(61,74,48,0.08) 100%);
}
.solucao__system-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}
.solucao__bg-grid {
  position: absolute;
  inset: 0 5vw auto;
  height: min(1050px, 92vh);
  opacity: 0.42;
  background:
    linear-gradient(rgba(140,107,42,0.12) 1px, transparent 1px),
    linear-gradient(90deg, rgba(140,107,42,0.09) 1px, transparent 1px);
  background-size: 88px 88px;
  mask-image: linear-gradient(180deg, transparent 0%, #000 16%, #000 72%, transparent 100%);
}
.solucao__bg-ledger {
  position: absolute;
  right: clamp(28px, 6vw, 92px);
  top: 22vh;
  display: grid;
  gap: 14px;
  padding-left: 24px;
  border-left: 1px solid rgba(140,107,42,0.24);
  color: rgba(61,74,48,0.2);
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  writing-mode: vertical-rl;
  text-orientation: mixed;
}
.solucao__bg-mark {
  position: absolute;
  left: max(20px, 4vw);
  top: 18vh;
  font-family: var(--sans);
  font-size: 13rem;
  line-height: 0.8;
  color: rgba(61,74,48,0.045);
}
.solucao__bg-rule {
  position: absolute;
  left: 13vw;
  right: 13vw;
  top: 50vh;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(140,107,42,0.54), transparent);
}
.solucao__intro {
  position: sticky;
  top: 0;
  z-index: 2;
  margin-inline: auto;
  will-change: opacity, transform, filter;
}
.solucao__intro-scroll {
  position: relative;
  z-index: 2;
  height: 320vh;
  min-height: 2140px;
}
.solucao__intro--editorial {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  row-gap: var(--solucao-row-gap, clamp(18px, 3vh, 34px));
  align-content: center;
  min-height: 100svh;
  padding-top: clamp(70px, 9vh, 98px);
  padding-bottom: clamp(34px, 6vh, 72px);
}
.solucao__intro-kicker {
  justify-self: center;
}
.solucao__intro-title {
  max-width: 1180px;
  margin: 0 auto;
  text-align: center;
  font-size: var(--solucao-title-size, 5.85rem);
  line-height: 0.94;
  letter-spacing: 0;
  color: var(--bg-deeper);
  transform-origin: center top;
  will-change: opacity, transform, filter, font-size;
}
.solucao__intro-title span {
  display: block;
}
.solucao__intro-title span + span {
  margin-top: 0.08em;
  font-size: 0.56em;
  line-height: 1.02;
  color: var(--bg-deep);
}
.solucao__intro-title em {
  position: relative;
  font-style: italic;
  color: var(--gold-deep);
}
.solucao__intro-title em::after {
  content: "";
  position: absolute;
  left: -0.08em;
  right: -0.08em;
  bottom: 0.02em;
  height: 0.1em;
  background: rgba(184,146,74,0.18);
  z-index: -1;
}
.solucao__tese {
  position: relative;
  width: min(1120px, 100%);
  margin: clamp(10px, 1.8vh, 20px) auto 0;
  padding: 0;
  border: none;
  background: none;
  color: var(--bg-deeper);
  quotes: none;
  will-change: opacity, transform, filter;
}
.solucao__tese::before {
  content: "";
  position: absolute;
  top: 18px;
  bottom: 20px;
  left: 23px;
  width: 1px;
  background: linear-gradient(180deg, rgba(140,107,42,0.1), rgba(140,107,42,0.5), rgba(140,107,42,0.1));
}
.solucao__tese-line {
  position: relative;
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr);
  gap: 18px;
  align-items: baseline;
  padding: var(--solucao-line-pad-y, 10px) 0 calc(var(--solucao-line-pad-y, 10px) + 2px);
  border-top: 1px solid rgba(140,107,42,0.18);
  transition:
    opacity 0.42s cubic-bezier(.2,.7,.2,1),
    transform 0.42s cubic-bezier(.2,.7,.2,1),
    filter 0.42s cubic-bezier(.2,.7,.2,1);
}
.solucao__tese-line:last-child {
  border-bottom: 1px solid rgba(140,107,42,0.24);
}
.solucao__tese-line--2 {
  margin-left: 0;
}
.solucao__tese-line--3 {
  margin-top: 0;
  margin-left: 0;
  padding-top: calc(var(--solucao-line-pad-y, 10px) + 2px);
  padding-bottom: calc(var(--solucao-line-pad-y, 10px) + 6px);
}
.solucao__tese-num {
  position: relative;
  z-index: 1;
  width: 46px;
  height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(140,107,42,0.28);
  background: rgba(246,241,232,0.82);
  border-radius: 50%;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  color: rgba(61,74,48,0.56);
}
.solucao__tese-copy {
  display: block;
  font-family: var(--sans);
  font-size: var(--solucao-tese-size, 2.82rem);
  line-height: 0.98;
  letter-spacing: 0;
  color: var(--bg-deep);
}
.solucao__tese-copy em {
  font-style: italic;
  color: var(--gold);
}
.solucao__tese-line--3 .solucao__tese-num {
  border-color: rgba(140,107,42,0.46);
  background: var(--bg-deeper);
  color: var(--gold-2);
}
.solucao__tese-line--3 .solucao__tese-copy {
  font-size: var(--solucao-tese-final-size, 2.82rem);
  line-height: 0.98;
  color: var(--bg-deeper);
}
.solucao__tese-line--3 .solucao__tese-copy em {
  color: var(--gold-deep);
}
.solucao__tese-line.is-active,
.solucao__tese-line.is-complete {
  opacity: 1;
  transform: none;
  filter: none;
}
.solucao__tese-line.is-active .solucao__tese-num,
.solucao__tese-line.is-complete .solucao__tese-num {
  border-color: rgba(140,107,42,0.48);
  box-shadow: 0 0 0 7px rgba(184,146,74,0.08);
}
.solucao__tese-line:not(.is-active):not(.is-complete) .solucao__tese-copy {
  color: rgba(61,74,48,0.54);
}
@media (max-width: 1100px) {
  .solucao__intro--editorial {
    grid-template-columns: 1fr;
    row-gap: 44px;
  }
  .solucao__intro-title {
    font-size: var(--solucao-title-size, 4.6rem);
  }
  .solucao__tese {
    grid-column: 1;
  }
  .solucao__tese-line--2,
  .solucao__tese-line--3 {
    margin-left: 0;
  }
}

@media (max-width: 960px) {
  .solucao {
    padding-top: 0;
  }
  .solucao__intro-scroll {
    height: auto;
    min-height: 0;
  }
  .solucao__intro {
    position: relative;
    top: auto;
  }
  .solucao__bg-ledger {
    display: none;
  }
  .solucao__bg-grid {
    inset: 92px 18px auto;
    height: 680px;
    background-size: 58px 58px;
  }
  .solucao__bg-mark {
    top: 138px;
    left: 18px;
    font-size: 7rem;
  }
  .solucao__intro--editorial {
    row-gap: 34px;
    min-height: auto;
    padding-top: 128px;
    padding-bottom: 54px;
  }
  .solucao__intro-kicker {
    justify-self: start;
  }
  .solucao__intro-title {
    margin-top: 0;
    text-align: left;
    font-size: 3.15rem;
    line-height: 0.96;
  }
  .solucao__intro-title span + span {
    font-size: 0.58em;
    line-height: 1.08;
  }
  .solucao__tese::before {
    left: 19px;
  }
  .solucao__tese {
    width: 100%;
    margin-top: 0;
  }
  .solucao__tese-line {
    grid-template-columns: 40px minmax(0, 1fr);
    gap: 14px;
    padding: 16px 0 18px;
    opacity: 1;
    transform: none;
    filter: none;
  }
  .solucao__tese-num {
    width: 40px;
    height: 40px;
    font-size: 9px;
  }
  .solucao__tese-copy,
  .solucao__tese-line--3 .solucao__tese-copy {
    font-size: 2.22rem;
    line-height: 0.98;
  }
}

/* ============ Método (static layout) ============ */
.metodo {
  padding: 48px 0 120px;
}

.metodo__head {
  max-width: 900px;
  margin: 0 auto 72px;
  text-align: center;
}

.metodo__eyebrow {
  display: inline-block;
  font-family: var(--sans);
  font-size: 11.5px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: 20px;
}

.metodo__title {
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 24px;
}

.metodo__lede {
  font-size: 19px;
  line-height: 1.55;
  color: var(--ink-muted);
  max-width: 560px;
  margin: 0 auto;
}

.metodo__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

/* ---- Steps · jornada visual horizontal alternada (zigzag) ---- */
.metodo__steps {
  list-style: none;
  padding: 0;
  margin: 0 auto;
  max-width: 1180px;
  display: flex;
  flex-direction: column;
  gap: clamp(56px, 7vw, 96px);
  position: relative;
}

/* Setinhas conectoras entre os steps (cara de trilha) */
.metodo__step:not(:last-child)::after {
  content: "";
  position: absolute;
  top: 100%;
  margin-top: clamp(14px, 1.6vw, 28px);
  left: 50%;
  transform: translateX(-50%);
  width: 36px;
  height: 36px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32' fill='none' stroke='%238c6b2a' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'><path d='M16 6 V24 M9 18 L16 25 L23 18'/></svg>");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  z-index: 5;
  opacity: 0.65;
}

.metodo__step {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(28px, 5vw, 64px);
  align-items: center;
  padding: clamp(36px, 4vw, 56px);
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  transition: box-shadow .25s ease-out, transform .25s ease-out;
}

.metodo__step:nth-child(even) {
  background: var(--cream-card);
}

.metodo__step:nth-child(even) .metodo__step-text {
  order: 2;
}

.metodo__step:nth-child(even) .metodo__step-media {
  order: 1;
}

.metodo__step:hover {
  box-shadow: 0 14px 38px rgba(61, 74, 48, 0.10);
  transform: translateY(-3px);
}

.metodo__step-text {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.metodo__step-num {
  font-family: var(--display);
  font-size: clamp(3.2rem, 6vw, 4.8rem);
  line-height: 0.9;
  font-weight: 300;
  color: var(--gold);
  letter-spacing: -0.02em;
  margin: 0 0 8px;
}

.metodo__step-title {
  font-family: var(--sans);
  font-size: clamp(1.45rem, 2.4vw, 1.85rem);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--bg-deep);
  margin: 0;
}

.metodo__step-title em {
  font-style: italic;
  font-weight: 500;
  color: var(--gold-deep);
}

.metodo__step-desc {
  font-family: var(--sans);
  font-size: clamp(0.98rem, 1.3vw, 1.08rem);
  line-height: 1.6;
  color: var(--ink-muted);
  margin: 0;
  max-width: 50ch;
}

.metodo__step-emojis {
  list-style: none;
  padding: 0;
  margin: 14px 0 0;
  display: flex;
  flex-wrap: wrap;
  gap: clamp(16px, 2.5vw, 28px);
}

.metodo__step-emojis li {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  font-family: var(--sans);
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  color: var(--ink-soft);
  text-transform: lowercase;
}

.metodo__step-emojis .emoji {
  font-size: 2rem;
  line-height: 1;
  filter: saturate(0.9);
}

/* Mockups: container shared between Chrome and MacBook variants */
.metodo__step-media {
  display: grid;
  place-items: center;
  width: 100%;
}

.mockup {
  width: 100%;
  max-width: 540px;
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 22px 48px rgba(30, 36, 24, 0.18), 0 4px 12px rgba(30, 36, 24, 0.08);
  transition: transform .35s ease;
}

.metodo__step:hover .mockup {
  transform: translateY(-4px);
}

/* Chrome window mockup */
.mockup--chrome {
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.06);
}

.mockup__chrome-bar {
  background: #e8e8e8;
  height: 32px;
  display: flex;
  align-items: center;
  padding: 0 14px;
  gap: 8px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.mockup__dot {
  width: 11px;
  height: 11px;
  border-radius: 50%;
  background: #ccc;
  flex-shrink: 0;
}

.mockup__dot:nth-child(1) { background: #fc615d; }
.mockup__dot:nth-child(2) { background: #fdbe40; }
.mockup__dot:nth-child(3) { background: #34c84a; }

.mockup__url {
  margin-left: 12px;
  padding: 4px 14px;
  background: #f7f7f7;
  border-radius: 999px;
  font-family: var(--mono);
  font-size: 11px;
  color: #888;
  flex: 1;
  max-width: 240px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.mockup__screen {
  background: #ffffff;
  display: block;
  line-height: 0;
}

.mockup__screen img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
}

/* MacBook mockup */
.mockup--macbook {
  background: transparent;
  box-shadow: none;
  border-radius: 0;
  overflow: visible;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.mockup__screen--macbook {
  background: #1a1a1a;
  padding: clamp(12px, 1.4vw, 18px) clamp(12px, 1.4vw, 18px) clamp(16px, 1.7vw, 22px);
  border-radius: 12px 12px 4px 4px;
  border: 1px solid #2a2a2a;
  box-shadow: 0 22px 48px rgba(30, 36, 24, 0.20), 0 4px 12px rgba(30, 36, 24, 0.10), inset 0 1px 0 rgba(255, 255, 255, 0.06);
  width: 100%;
  max-width: 540px;
}

.mockup__screen--macbook img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 8.2;
  border-radius: 4px;
  object-fit: cover;
  object-position: center;
}

.mockup__macbook-base {
  width: 110%;
  max-width: 600px;
  height: 14px;
  background: linear-gradient(180deg, #d4d4d4 0%, #b8b8b8 50%, #888 100%);
  border-radius: 0 0 14px 14px;
  position: relative;
  box-shadow: 0 6px 14px rgba(30, 36, 24, 0.15);
}

.mockup__macbook-base::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 80px;
  height: 6px;
  background: #888;
  border-radius: 0 0 8px 8px;
}

/* iPhone mockup */
.mockup--iphone {
  background: #1a1a1a;
  border-radius: 32px;
  padding: 8px;
  box-shadow: 0 22px 48px rgba(30, 36, 24, 0.22), 0 6px 14px rgba(30, 36, 24, 0.12);
  position: relative;
  max-width: 280px;
  margin: 0 auto;
}

.mockup__iphone-notch {
  position: absolute;
  top: 14px;
  left: 50%;
  transform: translateX(-50%);
  width: 90px;
  height: 22px;
  background: #1a1a1a;
  border-radius: 0 0 16px 16px;
  z-index: 2;
}

.mockup--iphone img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 26px;
}

/* Sheet mockup: wide spreadsheet inside a soft device frame */
.mockup--sheet {
  background: #1a1a1a;
  border-radius: 34px;
  padding: clamp(10px, 1.4vw, 14px);
  box-shadow: 0 26px 56px rgba(30, 36, 24, 0.22), 0 8px 18px rgba(30, 36, 24, 0.12);
  max-width: 640px;
  margin: 0 auto;
}

.mockup--sheet img {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  object-position: top center;
  border-radius: 24px;
}

/* iPad mockup */
.mockup--ipad {
  background: #1a1a1a;
  border-radius: 34px;
  padding: clamp(10px, 1.4vw, 14px);
  box-shadow: 0 22px 48px rgba(30, 36, 24, 0.22), 0 6px 14px rgba(30, 36, 24, 0.12);
  max-width: 640px;
  margin: 0 auto;
}

.mockup--ipad img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 7.4;
  object-fit: cover;
  object-position: center;
  border-radius: 22px;
}

/* ---- Combo: macbook principal + chrome flutuando ---- */
/* Combo é par (passo 02), então a mídia vem primeiro via order — colunas invertidas: media larga, texto estreito */
.metodo__step--combo {
  grid-template-columns: 1.45fr 0.55fr !important;
  gap: clamp(20px, 3vw, 40px) !important;
}

.metodo__step--combo .metodo__step-text {
  max-width: 100%;
}

.metodo__step--combo .metodo__step-desc {
  max-width: none;
}

.metodo__step-media--combo {
  position: relative;
  padding-bottom: 14%;
  width: 100%;
}

.metodo__step-media--combo .mockup--macbook {
  position: relative;
  z-index: 1;
  max-width: 72%;
  margin-left: 0;
  margin-right: auto;
}

.metodo__step-media--combo .mockup__screen--macbook {
  max-width: 100%;
}

.mockup--floating {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 60%;
  max-width: 360px;
  z-index: 2;
  transform: rotate(2deg);
  box-shadow: 0 22px 44px rgba(30, 36, 24, 0.24), 0 6px 12px rgba(30, 36, 24, 0.12);
  transition: transform .35s ease;
}

.metodo__step:hover .mockup--floating {
  transform: rotate(2deg) translateY(-4px);
}

@media (max-width: 1100px) {
  .metodo__step--combo {
    grid-template-columns: 1.35fr 0.65fr !important;
  }
}

@media (max-width: 820px) {
  .metodo__step--combo {
    grid-template-columns: 1fr !important;
  }
  .metodo__step-media--combo {
    padding-bottom: 0;
    display: flex;
    flex-direction: column;
    gap: 16px;
  }
  .metodo__step-media--combo .mockup--macbook {
    max-width: 100%;
  }
  .mockup--floating {
    position: static;
    width: 100%;
    max-width: 360px;
    margin: 0 auto;
    transform: none;
  }
  .metodo__step:hover .mockup--floating {
    transform: translateY(-3px);
  }
}

@media (max-width: 820px) {
  .metodo__step {
    grid-template-columns: 1fr;
    gap: 28px;
    padding: 32px 24px;
  }
  .metodo__step:nth-child(even) .metodo__step-text { order: 1; }
  .metodo__step:nth-child(even) .metodo__step-media { order: 2; }
  .metodo__step-num { font-size: 2.8rem; }
  .metodo__step-emojis { gap: 14px; }
  .metodo__step-emojis .emoji { font-size: 1.6rem; }
  .mockup { max-width: 100%; }
  .mockup__screen--macbook { padding: 10px 10px 14px; }
  .mockup__macbook-base { height: 10px; }
}

/* ---- Cards antigos (mantidos por enquanto, sem uso ativo) ---- */
.metodo__card {
  --metodo-card-enter: 0px;
  --metodo-card-shift: 0px;
  --metodo-card-hover: 0px;
  position: relative;
  padding: 28px 32px 36px;
  background: var(--cream-card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  transition: box-shadow .25s ease-out;
  transform: translateY(calc(var(--metodo-card-enter) + var(--metodo-card-shift) + var(--metodo-card-hover)));
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.metodo__card:hover {
  --metodo-card-hover: -2px;
  box-shadow: 0 8px 24px rgba(61, 74, 48, 0.10);
}

.metodo__card::before {
  content: attr(data-step);
  position: absolute;
  left: 32px;
  top: 24px;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: var(--bg-deep);
  border: 2px solid var(--bg);
  box-shadow: 0 0 0 1px rgba(184, 146, 74, 0.22);
  color: var(--bg);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  z-index: 1;
}

.metodo__card-eyebrow {
  min-height: 28px;
  display: flex;
  align-items: center;
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin: 0 0 8px 42px;
}

.metodo__card-time {
  display: block;
  padding-left: 14px;
  border-left: 2px solid rgba(184, 146, 74, 0.68);
  color: var(--gold-deep);
  font-family: var(--sans);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.01em;
  line-height: 1.35;
  margin: -4px 0 2px;
}

.metodo__card-title {
  font-family: var(--sans);
  font-size: 28px;
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: -0.01em;
  color: var(--bg-deep);
  margin: 0;
}

.metodo__card-promise {
  font-size: 16px;
  line-height: 1.55;
  color: var(--ink-muted);
  margin: 0;
}

.metodo__card-list {
  list-style: none;
  padding: 0;
  margin: 4px 0 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.metodo__card-list li {
  position: relative;
  padding-left: 20px;
  font-size: 15px;
  line-height: 1.55;
  color: var(--ink-muted);
}

.metodo__card-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  width: 10px;
  height: 1px;
  background: var(--gold);
}

.metodo__card-rule {
  margin-top: 12px;
  padding: 16px 18px;
  background: rgba(184, 146, 74, 0.06);
  border-left: 2px solid var(--gold);
  border-radius: 6px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.metodo__card-rule-label {
  font-family: var(--sans);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
}

.metodo__card-rule p {
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--ink-muted);
  font-style: italic;
  margin: 0;
}

@media (max-width: 960px) {
  .metodo { padding: 80px 0; }
  .metodo__head { margin-bottom: 48px; }
  .metodo__grid { grid-template-columns: 1fr; gap: 20px; }
  .metodo__card { padding: 28px; }
  .metodo__card-title { font-size: 24px; }
}

@media (max-width: 820px) {
  .metodo__grid {
    position: relative;
    gap: 18px;
    padding-left: 38px;
  }

  .metodo__grid::before {
    content: "";
    position: absolute;
    left: 13px;
    top: 36px;
    bottom: 36px;
    width: 1px;
    background: linear-gradient(180deg, rgba(184, 146, 74, 0) 0%, rgba(184, 146, 74, 0.55) 10%, rgba(184, 146, 74, 0.55) 90%, rgba(184, 146, 74, 0) 100%);
  }

  .metodo__card {
    padding: 28px 24px 24px;
    gap: 10px;
    border-radius: 20px;
    box-shadow: 0 14px 34px rgba(61, 74, 48, 0.08);
  }

  .metodo__card::before {
    left: -38px;
    top: 22px;
    width: 26px;
    height: 26px;
  }

  .metodo__card::after {
    content: "";
    position: absolute;
    left: -12px;
    top: 35px;
    width: 12px;
    height: 1px;
    background: rgba(184, 146, 74, 0.55);
  }

  .metodo__card-eyebrow {
    min-height: auto;
    margin-left: 0;
    margin-bottom: 4px;
  }

  .metodo__card-time { font-size: 13.5px; }
}

/* Journey: sticky scroll-driven experience */
.jornada {
  position: relative;
  z-index: 1;
  height: 410vh;
  background: var(--bg);
}
.jornada__sticky {
  position: sticky;
  top: 0;
  height: 100vh;
  overflow: hidden;
  display: flex; align-items: center;
  background: var(--bg);
}
.jornada__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
}
.jornada__bg-grid {
  position: absolute;
  inset: 8vh 6vw 10vh;
  opacity: 0.34;
  background:
    linear-gradient(rgba(140,107,42,0.13) 1px, transparent 1px),
    linear-gradient(90deg, rgba(140,107,42,0.1) 1px, transparent 1px);
  background-size: 96px 96px;
  mask-image: radial-gradient(ellipse at 52% 48%, #000 0%, transparent 68%);
}
.jornada__bg-ledger {
  position: absolute;
  right: 5vw;
  top: 18vh;
  display: grid;
  gap: 14px;
  padding-left: 28px;
  border-left: 1px solid rgba(140,107,42,0.28);
  color: rgba(61,74,48,0.16);
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.34em;
  text-transform: uppercase;
}
.jornada__bg-ledger span {
  display: block;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(140,107,42,0.16);
}
.jornada__bg-stamp {
  position: absolute;
  left: 45vw;
  bottom: 9vh;
  color: rgba(61,74,48,0.08);
  font-family: var(--sans);
  font-size: clamp(6rem, 12vw, 12rem);
  line-height: 0.78;
  letter-spacing: 0;
  white-space: nowrap;
}
.jornada__bg-compass {
  position: absolute;
  left: 8vw;
  top: 16vh;
  width: 170px;
  aspect-ratio: 1;
  opacity: 0.18;
  border: 1px solid rgba(140,107,42,0.28);
  border-radius: 50%;
  background:
    linear-gradient(90deg, transparent calc(50% - 1px), rgba(140,107,42,0.3) 50%, transparent calc(50% + 1px)),
    linear-gradient(0deg, transparent calc(50% - 1px), rgba(140,107,42,0.24) 50%, transparent calc(50% + 1px));
}
.jornada__bg-compass::before,
.jornada__bg-compass::after {
  content: "";
  position: absolute;
  inset: 28px;
  border: 1px dashed rgba(140,107,42,0.32);
  border-radius: 50%;
}
.jornada__bg-compass::after {
  inset: 68px;
  border-style: solid;
}
.jornada__stage {
  width: 100%;
  padding: 0 clamp(56px, 4.2vw, 88px);
  display: grid;
  grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
  gap: clamp(48px, 4vw, 72px);
  align-items: center;
  position: relative;
  z-index: 1;
}
.jornada__mobile-header {
  display: none;
}

/* Journey map (left), scrolling path w/ destraves */
.jornada__map {
  position: relative;
  width: 100%;
  height: 68vh;
  max-height: 680px;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
}
.jornada__map svg { width: 100%; height: 100%; overflow: visible; }

/* Map header, ancora o avatar no contexto da jornada enquanto o sticky trava */
.jornada__map-header {
  margin-bottom: clamp(18px, 2.8vh, 30px);
  opacity: 0;
  transform: translate3d(0, 18px, 0);
  filter: blur(8px);
  will-change: opacity, transform, filter;
}

.jornada__map-title {
  font-family: var(--display);
  font-variation-settings: "SOFT" 100, "opsz" 144;
  font-size: clamp(2.35rem, 4.2vw, 4.25rem);
  font-weight: 500;
  line-height: 0.92;
  letter-spacing: 0;
  color: var(--bg-deeper);
  margin: 0;
  white-space: nowrap;
}

.jornada__map-title em {
  font-style: italic;
  font-weight: 400;
  color: var(--gold-deep);
}

@media (prefers-reduced-motion: reduce) {
  .jornada__map-header {
    opacity: 1;
    transform: none;
    filter: none;
  }
}

.jornada__map-path {
  fill: none;
  stroke-linecap: round;
  vector-effect: non-scaling-stroke;
}
.jornada__map-path--aura {
  stroke: rgba(61,74,48,0.035);
  stroke-width: 8;
}
.jornada__map-path--guide {
  stroke: rgba(61,74,48,0.13);
  stroke-width: 2;
  stroke-dasharray: 3 13;
}
.jornada__map-path--steps {
  stroke: rgba(61,74,48,0.08);
  stroke-width: 3;
  stroke-dasharray: 1 34;
  stroke-linecap: round;
}
.jornada__map-path--active {
  stroke: var(--gold);
  stroke-width: 5;
  stroke-dasharray: none;
  filter: drop-shadow(0 8px 14px rgba(184,146,74,0.14));
}
.jornada__map-mark {
  transition: opacity 0.45s cubic-bezier(.2,.7,.2,1), transform 0.45s cubic-bezier(.2,.7,.2,1);
}
.jornada__map-halo {
  fill: rgba(184,146,74,0.16);
  stroke: rgba(184,146,74,0.34);
  stroke-width: 1.2;
  opacity: 0.58;
  transform-origin: center;
  transition: opacity 0.55s cubic-bezier(.2,.7,.2,1), transform 0.55s cubic-bezier(.2,.7,.2,1);
}
.jornada__map-ring {
  fill: rgba(247,240,227,0.92);
  stroke: rgba(61,74,48,0.7);
  stroke-width: 2;
  transition: fill 0.55s cubic-bezier(.2,.7,.2,1), stroke 0.55s cubic-bezier(.2,.7,.2,1), stroke-width 0.55s cubic-bezier(.2,.7,.2,1);
}
.jornada__map-node {
  fill: rgba(61,74,48,0.22);
  stroke: rgba(61,74,48,0.78);
  stroke-width: 2;
  transition: fill 0.55s cubic-bezier(.2,.7,.2,1), stroke 0.55s cubic-bezier(.2,.7,.2,1), stroke-width 0.55s cubic-bezier(.2,.7,.2,1);
}
.jornada__map-mark.is-complete .jornada__map-halo {
  opacity: 0.72;
  transform: scale(0.82);
}
.jornada__map-mark.is-complete .jornada__map-ring,
.jornada__map-node--active {
  fill: var(--gold);
  stroke: var(--gold-deep);
}
.jornada__map-mark.is-complete .jornada__map-node {
  fill: var(--bg-deep);
  stroke: var(--bg);
  stroke-width: 1.4;
}
.jornada__map-mark.is-current .jornada__map-halo {
  opacity: 1;
  transform: scale(1.08);
  animation: jornadaPulse 1.7s cubic-bezier(.2,.7,.2,1) infinite;
}
.jornada__map-mark.is-current .jornada__map-ring,
.jornada__map-node--current {
  stroke: var(--bg-deep);
  stroke-width: 2.4;
  fill: var(--bg);
}
.jornada__map-mark.is-current .jornada__map-node {
  fill: var(--gold);
  stroke: var(--bg-deep);
  stroke-width: 2.2;
}
.jornada__map-tag {
  filter: drop-shadow(0 10px 14px rgba(43,51,31,0.07));
  transition: transform 0.45s cubic-bezier(.2,.7,.2,1), filter 0.45s cubic-bezier(.2,.7,.2,1);
}
.jornada__map-tag-plate {
  fill: rgba(247,240,227,0.92);
  stroke: rgba(140,107,42,0.52);
  stroke-width: 1.15;
}
.jornada__map-label {
  font-family: var(--mono);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  fill: var(--bg-deep);
  transition: fill 0.45s cubic-bezier(.2,.7,.2,1), font-size 0.45s cubic-bezier(.2,.7,.2,1);
}
.jornada__map-label--active,
.jornada__map-mark.is-current .jornada__map-label,
.jornada__map-mark.is-complete .jornada__map-label { fill: var(--bg-deep); }
.jornada__map-mark.is-current .jornada__map-tag {
  filter: drop-shadow(0 14px 18px rgba(43,51,31,0.1));
}
.jornada__map-mark.is-current .jornada__map-tag-plate,
.jornada__map-mark.is-complete .jornada__map-tag-plate {
  fill: rgba(247,240,227,0.98);
  stroke: rgba(140,107,42,0.72);
}
.jornada__map-label--start {
  font-family: var(--sans);
  font-style: italic;
  font-size: 17px;
  font-weight: 500;
  letter-spacing: 0;
  fill: rgba(61,74,48,0.78);
}
.jornada__map-sub {
  font-family: var(--mono);
  font-size: 10px;
  fill: rgba(140,107,42,0.9);
  letter-spacing: 0.22em;
  font-weight: 700;
  transition: fill 0.45s cubic-bezier(.2,.7,.2,1);
}
.jornada__map-mark.is-current .jornada__map-sub,
.jornada__map-mark.is-complete .jornada__map-sub {
  fill: var(--gold-deep);
}
.jornada__map-sub--start {
  font-size: 8px;
  letter-spacing: 0.22em;
  fill: rgba(140,107,42,0.76);
}
@keyframes jornadaPulse {
  0%, 100% { transform: scale(0.92); opacity: 0.82; }
  50% { transform: scale(1.18); opacity: 0.34; }
}
@media (prefers-reduced-motion: reduce) {
  .jornada__map-mark.is-current .jornada__map-halo {
    animation: none;
  }
}

/* Journey content (right) */
.jornada__content {
  position: relative;
  height: 78vh;
  max-height: 720px;
}
.jornada__step {
  position: absolute;
  inset: 0;
  display: flex; flex-direction: column; justify-content: center;
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.7s cubic-bezier(.2,.7,.2,1), transform 0.7s cubic-bezier(.2,.7,.2,1);
  pointer-events: none;
}
.jornada__step.is-active { opacity: 1; transform: none; pointer-events: auto; }
.jornada__step[data-step="0"] {
  width: min(100%, 760px);
  margin-left: auto;
}
.jornada__step:not([data-step="0"]) {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  align-content: center;
  justify-items: stretch;
}
.jornada .tline__card {
  grid-area: 1 / 1;
  align-self: center;
  justify-self: end;
  width: min(100%, 760px);
  z-index: 1;
  display: flex;
  flex-direction: column;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.55) 0%, rgba(251,247,236,0.96) 42%, rgba(235,226,208,0.76) 100%);
  border: 1px solid rgba(140,107,42,0.34);
  padding: 40px 42px 38px;
  min-height: 0;
  box-shadow: 0 34px 70px -46px rgba(43,51,31,0.46), inset 0 1px 0 rgba(255,255,255,0.55);
  overflow: hidden;
}
.jornada .tline__card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 4px;
  background: linear-gradient(90deg, var(--bg-deep), var(--gold), rgba(184,146,74,0));
}
.jornada .tline__card-head {
  padding-bottom: 18px;
  margin-bottom: 22px;
}
.jornada .tline__card-title {
  font-size: clamp(2rem, 2.35vw, 2.65rem);
  line-height: 0.98;
  margin-bottom: 14px;
  max-width: none;
  white-space: nowrap;
  letter-spacing: 0;
}
.jornada .tline__card-title em {
  color: var(--gold-deep);
  font-style: italic;
}
.jornada .tline__card-meta {
  width: fit-content;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--gold-deep);
  padding-top: 18px;
  margin-bottom: 22px;
  border-top: 1px solid rgba(140,107,42,0.34);
}
.jornada .tline__card-promise {
  font-size: clamp(1.1rem, 1.22vw, 1.28rem);
  line-height: 1.45;
  color: var(--ink);
  max-width: 38ch;
  padding-bottom: 24px;
  margin-bottom: 22px;
  border-bottom: 1px dashed rgba(140,107,42,0.28);
}
.jornada .tline__card-list {
  gap: 14px;
  margin-bottom: 26px;
}
.jornada .tline__card-list li {
  grid-template-columns: 22px 1fr;
  font-size: 15.5px;
  line-height: 1.52;
}
.jornada .tline__card-list li::before {
  width: 14px;
  height: 2px;
  margin-top: 11px;
}
.jornada .tline__card-rule {
  margin-top: auto;
  padding: 18px 0 0 20px;
  border-top: 1px solid rgba(140,107,42,0.24);
  border-left: 2px solid var(--gold);
  max-width: 48ch;
}
.jornada .tline__card-rule span {
  display: block;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--gold-deep);
  margin-bottom: 8px;
}
.jornada .tline__card-rule p {
  margin: 0;
  font-size: 16px;
  line-height: 1.5;
  color: var(--bg-deep);
}
.jornada__step-num {
  font-family: var(--mono); font-size: 11px;
  color: var(--gold-deep); letter-spacing: 0.3em; text-transform: uppercase;
  margin-bottom: 18px;
  display: flex; align-items: center; gap: 14px;
}
.jornada__step-num::before {
  content: ""; display:block; width: 28px; height: 1px; background: var(--gold);
}
.jornada__step-title {
  font-family: var(--sans);
  font-size: clamp(2.4rem, 4vw, 3.8rem);
  line-height: 1.02;
  color: var(--bg-deep);
  margin-bottom: 24px;
}
.jornada__step-title em { font-style: italic; color: var(--gold-deep); }
.jornada__step-body {
  font-size: 18px; line-height: 1.6;
  color: var(--ink-muted);
  max-width: 50ch;
  margin-bottom: 28px;
}
.jornada__step-why {
  border-left: 1px solid var(--gold);
  padding: 8px 0 8px 20px;
  max-width: 50ch;
  font-family: var(--sans);
  font-style: italic;
  font-size: 16px;
  color: var(--ink-soft);
}
.jornada__step-why b { font-style: normal; color: var(--bg-deep); font-weight: 600; }

.jornada__dots {
  position: absolute;
  bottom: 40px; left: 5vw;
  display: flex; gap: 12px;
  z-index: 5;
}
.jornada__dot {
  width: 36px; height: 2px;
  background: rgba(61,74,48,0.15);
  transition: background 0.4s;
}
.jornada__dot.is-active { background: var(--bg-deep); }

@media (max-width: 1180px) {
  .jornada__stage {
    padding: 0 5vw;
    grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.18fr);
    gap: 44px;
  }
  .jornada .tline__card-title {
    white-space: normal;
  }
}

@media (max-width: 960px) {
  .jornada { height: auto; }
  .jornada__sticky { position: relative; height: auto; padding: 60px 0; }
  .jornada__stage { grid-template-columns: 1fr; padding: 0 6vw; gap: 40px; }
  .jornada__mobile-header {
    display: grid;
    margin-bottom: 8px;
    min-width: 0;
  }
  .jornada__mobile-header .jornada__map-title {
    font-size: clamp(2.8rem, 13vw, 4.5rem);
    line-height: 0.92;
    white-space: normal;
  }
  .jornada__bg { display: none; }
  .jornada__map, .jornada__content { height: auto; max-height: none; }
  .jornada__step {
    position: relative;
    display: grid;
    align-content: start;
    opacity: 1;
    transform: none;
    margin-bottom: 56px;
    pointer-events: auto;
    min-width: 0;
    overflow: hidden;
  }
  .jornada__step[data-step="0"] { margin-bottom: 70px; }
  .jornada .tline__card {
    grid-area: 1 / 1;
    width: 100%;
    max-width: 100%;
    padding: 26px 22px 30px;
    min-height: 0;
  }
  .jornada .tline__card-title {
    font-size: clamp(2rem, 10vw, 3rem);
    line-height: 1;
    max-width: 11.5ch;
  }
  .jornada .tline__card-meta {
    font-size: 10px;
    letter-spacing: 0.2em;
    line-height: 1.45;
    margin-bottom: 18px;
  }
  .jornada .tline__card-promise {
    font-size: 17px;
    line-height: 1.48;
  }
  .jornada .tline__card-list li {
    font-size: 14.5px;
  }
  .jornada .tline__card-rule {
    padding-left: 16px;
  }
  .jornada .tline__card-rule p {
    font-size: 15px;
  }
  .jornada__dots { display: none; }
  /* Header oculto em mobile: o mapa inteiro some, mas regra explícita para clareza */
  .jornada__map-header { display: none; }
  .jornada__map { display: none; }
}

@media (max-width: 520px) {
  .jornada__sticky { padding: 44px 0; }
  .jornada__stage { padding: 0 18px; }
  .jornada .tline__card { padding: 24px 18px 28px; }
  .jornada .tline__card-title { font-size: clamp(1.95rem, 11vw, 2.45rem); }
  .jornada .tline__card-meta { width: auto; }
}

.solucao__closer {
  margin-top: 0;
  padding: 0 20px 60px;
  max-width: 720px;
  margin-inline: auto;
  text-align: center;
  font-family: var(--sans); font-style: italic;
  font-size: clamp(1.2rem, 2vw, 1.5rem);
  color: var(--bg-deep);
  line-height: 1.5;
}

/* =========================================================
   CTA intermediário
   ========================================================= */
.cta-mid {
  padding: 100px 0;
  background: var(--bg-2);
  position: relative;
  overflow: hidden;
}
.cta-mid::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(184,146,74,0.1), transparent 60%);
  pointer-events: none;
}
.cta-mid__inner {
  text-align: center;
  position: relative; z-index: 2;
}
.cta-mid h2 {
  font-size: clamp(2rem, 3.6vw, 3rem);
  max-width: 26ch; margin: 0 auto 24px;
  line-height: 1.15;
}
.cta-mid p {
  margin: 0 auto 50px;
  color: var(--ink-muted);
  font-size: 17px;
  max-width: 58ch;
}
.cta-mid__action {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}
.cta-mid__meta {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 13px; color: var(--ink-soft);
}
.cta-mid__meta .shield { color: var(--gold-deep); }

.cta-mid--method {
  padding: 92px 0 98px;
}

.cta-mid--method::before {
  background:
    linear-gradient(90deg, transparent, rgba(184,146,74,0.08), transparent),
    radial-gradient(ellipse at 50% 0%, rgba(184,146,74,0.14), transparent 58%);
}

.cta-mid__method-title {
  max-width: 760px;
  margin: 0 auto 22px;
  font-size: clamp(2.2rem, 3.9vw, 3.45rem);
  line-height: 1.08;
  letter-spacing: -0.02em;
  color: var(--bg-deep);
}

.cta-mid__method-title em {
  color: var(--gold-deep);
  font-style: italic;
  font-weight: 500;
}

.cta-mid__method-copy {
  max-width: 720px;
  margin: 0 auto 44px;
}

.cta-mid__method-copy p {
  max-width: none;
  margin: 0 auto;
  color: var(--ink-muted);
  font-size: clamp(1.05rem, 1.35vw, 1.22rem);
  line-height: 1.6;
}

.cta-mid__method-copy p + p {
  margin-top: 12px;
  color: var(--ink);
}

.cta-mid__method-copy strong {
  color: var(--bg-deep);
  font-weight: 700;
}

.cta-mid__eyebrow {
  display: block !important;
  margin: 0 auto 18px !important;
  color: var(--gold-deep) !important;
}

.cta-mid__pillars {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(20px, 2.5vw, 32px);
  max-width: 980px;
  margin: 44px auto;
  text-align: left;
}

.cta-mid__pillar {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: clamp(24px, 2.5vw, 32px);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.cta-mid__pillar-tag {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold-deep);
  font-weight: 600;
}

.cta-mid__pillar p {
  font-family: var(--sans);
  font-size: clamp(0.95rem, 1.2vw, 1.05rem);
  line-height: 1.55;
  color: var(--ink-muted);
  margin: 0;
  max-width: none;
}

@media (max-width: 880px) {
  .cta-mid__pillars { grid-template-columns: 1fr; gap: 16px; max-width: 580px; }
}

@media (max-width: 640px) {
  .cta-mid__method-title {
    max-width: 14ch;
  }
}

/* =========================================================
   DOBRA 07 · Quem ensina
   ========================================================= */
.quem-ensina {
  padding: 180px 0;
  background: var(--bg);
}
.quem__grid {
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap: 80px;
  align-items: center;
}
.quem__photo {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  border-radius: var(--radius-xl);
}
.quem__photo::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(43,51,31,0.25) 100%);
  pointer-events: none;
}
.quem__photo img { width: 100%; height: 100%; object-fit: cover; transform: scale(1.04); }
.quem__photo-caption {
  position: absolute; bottom: 24px; left: 24px; right: 24px;
  display: flex; align-items: center; justify-content: space-between;
  color: #f2ecdc;
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.25em; text-transform: uppercase;
  z-index: 2;
}
.quem__photo-frame {
  position: absolute; inset: 20px;
  border: 1px solid rgba(242,236,220,0.35);
  pointer-events: none;
  z-index: 1;
}

.quem__content .eyebrow { margin-bottom: 26px; display: block; }
.quem__content h2 { margin-bottom: 32px; font-size: clamp(2rem, 3.6vw, 3rem); }
.quem__content p {
  font-size: 17px; line-height: 1.7; color: var(--ink-muted);
  margin-bottom: 22px;
}
.quem__content a.lnk {
  color: var(--gold-deep); border-bottom: 1px solid var(--gold);
}
.quem__stats {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  margin: 36px 0;
}
.quem__stat { padding: 24px 20px 24px 0; border-right: 1px solid var(--line); }
.quem__stat:last-child { border-right: none; padding-right: 0; padding-left: 20px; }
.quem__stat:nth-child(2) { padding-left: 20px; }
.quem__stat-n {
  font-family: var(--sans); font-size: clamp(1.8rem, 2.8vw, 2.4rem);
  color: var(--bg-deep); line-height: 1;
}
.quem__stat-n em { font-style: italic; color: var(--gold-deep); font-size: 0.8em; }
.quem__stat-l {
  font-size: 11px; letter-spacing: 0.12em;
  color: var(--ink-soft); text-transform: uppercase;
  margin-top: 8px;
}
.quem__quote {
  border-left: 2px solid var(--gold);
  padding-left: 24px;
  font-family: var(--sans); font-style: italic;
  font-size: clamp(1.1rem, 1.6vw, 1.3rem);
  color: var(--bg-deep);
  line-height: 1.5;
}
.quem__quote b { font-style: normal; color: var(--gold-deep); font-weight: 500; }

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

/* =========================================================
   DOBRA 09 · Produto / O que você recebe
   ========================================================= */
.produto {
  padding: 180px 0;
  background: var(--bg);
}

.quem-ensina + .produto {
  padding-top: 56px;
}
.produto__head {
  max-width: 880px; margin: 0 auto 64px;
  text-align: center;
}
.produto__head h2 { margin-bottom: 28px; font-size: clamp(2.2rem, 4vw, 3.4rem); }
.produto__head p { margin: 0 auto; color: var(--ink-muted); font-size: 17px; }

/* =========================================================
   Os 3 pilares · O que entra no acesso
   ========================================================= */

.produto__pillars {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(20px, 2.5vw, 32px);
  max-width: 1180px;
  margin: 0 auto 120px;
}

.produto-pillar {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  padding: clamp(28px, 3vw, 36px);
  display: flex;
  flex-direction: column;
  gap: 24px;
  transition: box-shadow 0.3s ease, transform 0.3s ease;
}

.produto-pillar:hover {
  box-shadow: 0 14px 36px rgba(61, 74, 48, 0.10);
  transform: translateY(-3px);
}

.produto-pillar__visual {
  background: var(--bg);
  border-radius: var(--radius-lg);
  padding: 24px 20px;
  min-height: 260px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}

.produto-pillar__content {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 0 4px;
}

.produto-pillar__num {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold-deep);
  font-weight: 600;
}

.produto-pillar__content h3 {
  font-family: var(--display);
  font-size: clamp(1.35rem, 2vw, 1.65rem);
  font-weight: 400;
  line-height: 1.2;
  color: var(--bg-deep);
  margin: 0;
  letter-spacing: -0.01em;
}

.produto-pillar__content p {
  font-family: var(--sans);
  font-size: 0.98rem;
  line-height: 1.55;
  color: var(--ink-muted);
  margin: 0;
}

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

/* === Visual 1: Ferramentas (janela Mac simples + fundo em camadas) === */
.produto-pillar__visual--tools {
  position: relative;
  min-height: clamp(340px, 28vw, 420px);
  padding: clamp(14px, 2.2vw, 22px);
  background:
    linear-gradient(180deg, rgba(246,241,232,0.54), rgba(239,232,220,0.72)),
    var(--bg);
}

.produto-pillar__visual--tools::before {
  content: "";
  position: absolute;
  inset: 16px;
  border-radius: calc(var(--radius-lg) - 6px);
  background:
    linear-gradient(180deg, rgba(246,241,232,0.34), rgba(246,241,232,0.74)),
    url("assets/objetivos.jpeg") center top / cover no-repeat;
  opacity: 0.66;
  filter: saturate(0.82) contrast(0.94);
  transform: scale(1.03);
}

.produto-pillar__visual--tools::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 50% 48%, rgba(255,255,255,0.54) 0%, rgba(255,255,255,0.28) 38%, transparent 70%),
    radial-gradient(ellipse at 74% 22%, rgba(184,146,74,0.10), transparent 44%);
  pointer-events: none;
}

.produto-pillar__tool-window {
  position: relative;
  z-index: 1;
  width: min(112%, 660px);
  border-radius: 16px;
  overflow: hidden;
  background: #fbfaf6;
  border: 1px solid rgba(61,74,48,0.10);
  box-shadow:
    0 26px 54px -30px rgba(30,36,24,0.44),
    0 10px 22px -16px rgba(140,107,42,0.35);
  transform: translateY(6px);
}

.produto-pillar__tool-window img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 7.5;
  object-fit: cover;
  object-position: center;
}

.produto-pillar__visual--tools .produto-pillar__chrome-bar {
  height: 28px;
  background: linear-gradient(180deg, #f5f1e8, #e7ddcb);
  border-bottom: 1px solid rgba(61,74,48,0.08);
  padding: 0 12px;
  gap: 6px;
}

.produto-pillar__visual--tools .produto-pillar__chrome-bar span {
  width: 9px;
  height: 9px;
}

.produto-pillar__phone {
  width: 100px;
  background: #1a1a1a;
  border-radius: 18px;
  padding: 4px;
  position: relative;
  z-index: 2;
  box-shadow: 0 12px 28px rgba(30, 36, 24, 0.22);
  transform: rotate(-5deg);
}

.produto-pillar__phone-notch {
  position: absolute;
  top: 8px;
  left: 50%;
  transform: translateX(-50%);
  width: 36px;
  height: 12px;
  background: #1a1a1a;
  border-radius: 0 0 8px 8px;
  z-index: 3;
}

.produto-pillar__phone img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 14px;
}

.produto-pillar__chrome {
  width: 180px;
  background: #fff;
  border-radius: 8px;
  overflow: hidden;
  position: absolute;
  right: 16px;
  top: 38%;
  z-index: 1;
  box-shadow: 0 12px 28px rgba(30, 36, 24, 0.22);
  transform: rotate(4deg);
}

.produto-pillar__chrome-bar {
  height: 18px;
  background: #e8e8e8;
  display: flex;
  align-items: center;
  padding: 0 8px;
  gap: 4px;
}

.produto-pillar__chrome-bar span {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #ccc;
}

.produto-pillar__chrome-bar span:nth-child(1) { background: #fc615d; }
.produto-pillar__chrome-bar span:nth-child(2) { background: #fdbe40; }
.produto-pillar__chrome-bar span:nth-child(3) { background: #34c84a; }

.produto-pillar__chrome img {
  display: block;
  width: 100%;
  height: auto;
}

/* === Visual 2: Aulas (player) === */
.produto-pillar__player {
  width: 100%;
  max-width: 280px;
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 12px 28px rgba(30, 36, 24, 0.18);
}

.produto-pillar__player-thumb {
  position: relative;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: #2a2a2a;
}

.produto-pillar__player-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.85);
}

.produto-pillar__play-btn {
  position: absolute;
  inset: 0;
  margin: auto;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.95);
  border: none;
  display: grid;
  place-items: center;
  cursor: pointer;
  color: var(--bg-deep);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.3);
  transition: transform 0.2s, background 0.2s;
}

.produto-pillar__play-btn svg {
  width: 24px;
  height: 24px;
  margin-left: 3px;
}

.produto-pillar__play-btn:hover {
  transform: scale(1.08);
  background: #fff;
}

.produto-pillar__player-meta {
  padding: 14px 16px;
  background: linear-gradient(135deg, #b8924a 0%, #8c6b2a 100%);
  color: #fff;
}

.produto-pillar__player-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-bottom: 10px;
}

.produto-pillar__player-num {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  opacity: 0.85;
}

.produto-pillar__player-title {
  font-family: var(--display);
  font-size: 1.05rem;
  font-weight: 400;
  line-height: 1.2;
}

.produto-pillar__player-progress {
  height: 4px;
  background: rgba(255, 255, 255, 0.25);
  border-radius: 999px;
  overflow: hidden;
}

.produto-pillar__player-progress-fill {
  height: 100%;
  width: 35%;
  background: #fff;
  border-radius: 999px;
}

/* === Visual 3: Comunidade (logos) === */
.produto-pillar__community-stack {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
}

.produto-pillar__brand-icon {
  width: 64px;
  height: 64px;
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 8px 20px rgba(30, 36, 24, 0.10);
  display: grid;
  place-items: center;
  padding: 12px;
  position: relative;
}

.produto-pillar__brand-icon--whatsapp {
  color: #25D366;
}

.produto-pillar__brand-icon--whatsapp svg {
  width: 100%;
  height: 100%;
}

.produto-pillar__brand-icon--meet {
  margin-top: -10px;
  margin-left: 50px;
  transform: rotate(3deg);
}

.produto-pillar__brand-icon--meet svg {
  width: 100%;
  height: 100%;
}

.produto-pillar__community-stack {
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  position: relative;
  gap: 0;
}

.produto-pillar__brand-icon--whatsapp {
  z-index: 2;
  transform: rotate(-4deg);
}

.produto-pillar__brand-icon--meet {
  margin: 0 0 0 -16px;
  transform: rotate(4deg);
}

.produto-pillar__community-pills {
  width: 100%;
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 16px;
}

.produto-pillar__community-pills span {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gold-deep);
  background: rgba(184, 146, 74, 0.12);
  padding: 5px 10px;
  border-radius: 999px;
  font-weight: 600;
}

@media (max-width: 980px) {
  .produto__pillars { grid-template-columns: 1fr; max-width: 540px; }
}

.cursos {
  margin-bottom: 160px;
}

.curso-destraves {
  display: flex;
  flex-direction: column;
  gap: clamp(64px, 8vw, 112px);
}

.curso-destrave {
  --destrave-accent: var(--gold);
  --destrave-accent-soft: rgba(184, 146, 74, 0.14);
  --destrave-panel: #ebe2d0;
  position: relative;
  display: grid;
  grid-template-columns: minmax(300px, 0.82fr) minmax(0, 1.18fr);
  gap: clamp(42px, 7vw, 92px);
  align-items: start;
  min-height: clamp(840px, 118vh, 1120px);
  padding: clamp(72px, 9vw, 128px) 0;
  border-top: 1px solid rgba(138, 106, 42, 0.18);
}

.curso-destrave:first-child { border-top: 0; padding-top: 0; }
.curso-destrave--sobra { --destrave-accent: #6f7f55; --destrave-accent-soft: rgba(111, 127, 85, 0.16); --destrave-panel: #e7ddc9; }
.curso-destrave--crescimento { --destrave-accent: #8c6b2a; --destrave-accent-soft: rgba(140, 107, 42, 0.17); --destrave-panel: #efe4cf; }

.curso-destrave__intro {
  min-height: clamp(420px, 44vw, 540px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: sticky;
  top: max(96px, calc(50vh - 270px));
  align-self: start;
  max-height: calc(100vh - 124px);
  padding: clamp(32px, 4vw, 50px);
  border-radius: var(--radius-xl);
  background:
    linear-gradient(135deg, rgba(61, 74, 48, 0.95), rgba(43, 51, 31, 0.98)),
    var(--bg-deep);
  color: #efe8dc;
  overflow: hidden;
  box-shadow: 0 28px 70px -46px rgba(29, 36, 24, 0.72);
}

.curso-destrave__fx {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 0;
}

.curso-destrave__fx span {
  position: absolute;
  color: rgba(140, 107, 42, 0.10);
  font-family: var(--mono);
  font-size: clamp(3.4rem, 8vw, 7.5rem);
  letter-spacing: -0.08em;
  line-height: 1;
  transform: translate3d(var(--fx-x, 0px), var(--fx-y, 0px), 0) rotate(var(--fx-rotate, 0deg));
  will-change: transform;
}

.curso-destrave__fx-mark {
  position: absolute;
  left: -8%;
  top: 18%;
  width: clamp(420px, 54vw, 780px);
  color: rgba(140, 107, 42, 0.15);
  stroke-width: 0.62;
  transform: translate3d(var(--fx-x, 0px), var(--fx-y, 0px), 0) rotate(var(--fx-rotate, 0deg));
  will-change: transform;
}

.curso-destrave__fx span:nth-of-type(1) { left: 7%; top: 12%; }
.curso-destrave__fx span:nth-of-type(2) { left: 43%; top: 58%; }
.curso-destrave__fx span:nth-of-type(3) { right: 5%; top: 26%; }

.curso-destrave__intro::before {
  content: "";
  position: absolute;
  inset: 20px;
  border: 1px solid rgba(212, 176, 114, 0.28);
  border-radius: calc(var(--radius-xl) - 12px);
  pointer-events: none;
}

.curso-destrave__intro::after {
  content: "";
  position: absolute;
  width: 220px;
  height: 220px;
  right: -86px;
  bottom: -86px;
  border: 1px solid rgba(212, 176, 114, 0.22);
  border-radius: 50%;
  box-shadow: inset 0 0 0 34px rgba(212, 176, 114, 0.035);
  pointer-events: none;
}

.curso-destrave__eyebrow,
.curso-card__tag,
.curso-card__tools-label {
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: 0.2em;
}

.curso-destrave__eyebrow {
  font-size: 11px;
  color: var(--gold-2);
  margin-bottom: clamp(12px, 1.5vw, 18px);
  position: relative;
  z-index: 1;
}

.curso-destrave__number {
  font-family: var(--display);
  font-variation-settings: "SOFT" 100, "opsz" 144;
  font-size: clamp(5rem, 8.3vw, 7.6rem);
  font-weight: 450;
  line-height: 0.78;
  letter-spacing: -0.05em;
  color: rgba(212, 176, 114, 0.30);
  margin: 0 0 clamp(18px, 2.2vw, 24px) -0.05em;
  position: relative;
  z-index: 1;
}

.curso-destrave__title {
  font-size: clamp(2.1rem, 3.7vw, 3.28rem);
  line-height: 1;
  letter-spacing: -0.025em;
  color: #f6f1e8;
  margin: 0 0 clamp(18px, 2vw, 22px);
  max-width: 12ch;
  position: relative;
  z-index: 1;
}

.curso-destrave__description {
  font-size: clamp(0.98rem, 1.2vw, 1.08rem);
  line-height: 1.56;
  color: rgba(246, 241, 232, 0.78);
  max-width: 34ch;
  margin: 0 0 clamp(18px, 2vw, 24px);
  position: relative;
  z-index: 1;
}

.curso-destrave__description em {
  color: var(--gold-2);
  font-style: italic;
}

.curso-destrave__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: clamp(18px, 2vw, 24px);
  position: relative;
  z-index: 1;
}

.curso-destrave__meta span {
  border: 1px solid rgba(212, 176, 114, 0.28);
  border-radius: var(--radius-pill);
  color: #efe8dc;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 7px 10px;
  background: rgba(246, 241, 232, 0.055);
}

.curso-destrave__focus {
  color: var(--gold-2);
  font-family: var(--display);
  font-style: italic;
  font-size: clamp(1.02rem, 1.32vw, 1.22rem);
  line-height: 1.3;
  margin: auto 0 0;
  position: relative;
  z-index: 1;
}

.curso-destrave__focus::before {
  content: "";
  display: inline-block;
  width: 32px;
  height: 1px;
  margin: 0 12px 0 0;
  vertical-align: middle;
  background: currentColor;
  opacity: 0.7;
}

@media (min-width: 961px) and (max-height: 820px) {
  .curso-destrave__intro {
    top: 92px;
    max-height: calc(100vh - 108px);
    padding: 30px 34px;
  }

  .curso-destrave__intro::before { inset: 18px; }

  .curso-destrave__eyebrow { margin-bottom: 10px; }

  .curso-destrave__number {
    font-size: clamp(4.4rem, 7vw, 6.45rem);
    margin-bottom: 16px;
  }

  .curso-destrave__title {
    font-size: clamp(1.95rem, 3.15vw, 2.85rem);
    margin-bottom: 16px;
  }

  .curso-destrave__description {
    font-size: 0.96rem;
    line-height: 1.48;
    margin-bottom: 16px;
  }

  .curso-destrave__meta {
    gap: 7px;
    margin-bottom: 14px;
  }

  .curso-destrave__meta span {
    font-size: 9.5px;
    padding: 6px 9px;
  }

  .curso-destrave__focus {
    font-size: 1rem;
    line-height: 1.28;
  }
}

.curso-destrave__list {
  display: flex;
  flex-direction: column;
  gap: 24px;
  padding-block: clamp(118px, 20vh, 176px);
  position: relative;
  z-index: 1;
}

.curso-card {
  position: relative;
  padding: clamp(34px, 3.8vw, 50px);
  background: linear-gradient(180deg, rgba(255,255,255,0.22), rgba(235,226,208,0.86)), var(--destrave-panel);
  border: 1px solid rgba(138, 106, 42, 0.16);
  border-left: 4px solid var(--destrave-accent);
  border-radius: var(--radius-md);
  box-shadow: 0 18px 44px -34px rgba(43, 51, 31, 0.52);
}

.curso-card__tag {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  font-weight: 600;
  color: var(--destrave-accent);
  margin-bottom: 26px;
  padding: 0;
  width: fit-content;
}

.curso-card__tag::before {
  content: "";
  width: 7px;
  height: 7px;
  background: currentColor;
  transform: rotate(45deg);
  opacity: 0.82;
}

.curso-card h4 {
  font-family: var(--sans);
  font-size: clamp(1.48rem, 2.05vw, 1.92rem);
  line-height: 1.1;
  letter-spacing: -0.018em;
  color: var(--bg-deep);
  margin: 0 0 18px;
  max-width: 100%;
}

.curso-card h4 .cond {
  display: inline-block;
  white-space: nowrap;
  color: var(--ink-soft);
  font-family: var(--sans);
  font-size: 0.62em;
  font-style: italic;
  font-weight: 500;
}

.curso-card p {
  color: var(--ink-muted);
  font-size: clamp(1rem, 1.16vw, 1.08rem);
  line-height: 1.68;
  max-width: 62ch;
  margin: 0;
}

.curso-card__lessons {
  margin-top: 28px;
  padding-top: 22px;
  border-top: 1px solid rgba(138, 106, 42, 0.16);
}

.curso-card__lessons summary {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  width: fit-content;
  color: var(--bg-deep);
  cursor: pointer;
  font-family: var(--sans);
  font-size: clamp(0.98rem, 1.08vw, 1.08rem);
  font-weight: 700;
  letter-spacing: 0.01em;
  list-style: none;
  outline: none;
}

.curso-card__lessons summary::-webkit-details-marker { display: none; }

.curso-card__lessons summary::before {
  content: "";
  width: 8px;
  height: 8px;
  background: var(--destrave-accent);
  transform: rotate(45deg);
  box-shadow: 0 0 0 6px rgba(194, 145, 57, 0.08);
}

.curso-card__lessons summary::after {
  content: "+";
  display: inline-grid;
  place-items: center;
  width: 22px;
  height: 22px;
  margin-left: 2px;
  border: 1px solid rgba(138, 106, 42, 0.22);
  border-radius: 50%;
  color: var(--destrave-accent);
  font-family: var(--mono);
  font-size: 13px;
  font-weight: 500;
  line-height: 1;
}

.curso-card__lessons[open] summary::after { content: "-"; }

.curso-card__lessons summary:hover,
.curso-card__lessons summary:focus-visible {
  color: var(--destrave-accent);
}

.curso-card__lessons summary:focus-visible {
  box-shadow: 0 3px 0 rgba(194, 145, 57, 0.24);
}

.curso-card__lesson-list {
  display: grid;
  gap: 10px;
  margin: 20px 0 0;
  padding: 0;
  list-style: none;
}

.curso-card__lesson-list--long {
  gap: 8px;
}

.curso-card__lesson-list li {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  align-items: baseline;
  gap: 12px;
  padding: 0 0 10px;
  border-bottom: 1px solid rgba(138, 106, 42, 0.10);
}

.curso-card__lesson-list li:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.curso-card__lesson-list span {
  color: var(--destrave-accent);
  font-family: var(--mono);
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.12em;
}

.curso-card__lesson-list p {
  color: var(--ink-muted);
  font-size: 0.95rem;
  line-height: 1.42;
  max-width: none;
  margin: 0;
}

.curso-card__tools {
  margin-top: 30px;
  padding-top: 20px;
  border-top: 1px solid rgba(138, 106, 42, 0.18);
}

.curso-card__tools-label {
  display: block;
  font-size: 10.5px;
  color: var(--gold-deep);
  margin-bottom: 14px;
  font-weight: 700;
}

.curso-card__tools-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 18px;
}

.curso-card__tool-chip {
  display: inline-flex;
  align-items: center;
  color: var(--gold-deep);
  font-family: var(--mono);
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0;
}

.curso-card__tool-chip::before {
  content: "";
  width: 5px;
  height: 5px;
  margin-right: 8px;
  border-radius: 50%;
  background: currentColor;
  opacity: 0.7;
}

@media (max-width: 960px) {
  .curso-destraves { gap: 72px; }
  .curso-destrave {
    grid-template-columns: 1fr;
    gap: 24px;
    padding: 56px 0;
  }
  .curso-destrave__intro {
    position: relative;
    top: auto;
    min-height: 0;
    padding: 36px 30px;
  }
  .curso-destrave__fx { display: none; }
  .curso-destrave__list { padding-block: 0; }
  .curso-destrave__title { max-width: 12ch; }
  .curso-card__lessons { margin-top: 24px; }
  .curso-card__lesson-list li {
    grid-template-columns: 30px minmax(0, 1fr);
    gap: 10px;
  }
  .curso-card__lesson-list p { font-size: 0.92rem; }
}

/* Pack de ferramentas */
.pack__head { text-align: center; margin-bottom: 70px; }
.pack__head .eyebrow { display:block; margin-bottom: 16px; }
.pack__head h3 { font-size: clamp(2rem, 3.6vw, 2.8rem); margin-bottom: 20px; }
.pack__head p { margin: 0 auto; color: var(--ink-muted); max-width: 60ch; }

.tools {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
  border-left: 1px solid var(--line);
}
.tool {
  padding: 36px 32px;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--bg);
  transition: background 0.3s;
  position: relative;
}
.tool:hover { background: var(--bg-2); }
.tool__num {
  font-family: var(--sans); font-style: italic;
  font-size: 28px; color: var(--gold);
  margin-bottom: 18px;
}
.tool h4 {
  font-family: var(--sans); font-size: 22px;
  color: var(--bg-deep); margin-bottom: 8px; line-height: 1.15;
}
.tool__sub {
  font-family: var(--sans); font-style: italic;
  color: var(--ink-soft); font-size: 14px;
  margin-bottom: 14px;
}
.tool p { font-size: 14px; color: var(--ink-muted); line-height: 1.55; }
.tool__label-pj {
  position: absolute; top: 20px; right: 20px;
  font-family: var(--mono); font-size: 9px; letter-spacing: 0.18em;
  color: var(--gold-deep); text-transform: uppercase;
}

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

.pack__note {
  margin-top: 60px;
  padding: 36px 48px;
  background: var(--bg-deep);
  color: #e8e1ce;
  text-align: center;
  font-family: var(--sans); font-style: italic;
  font-size: 19px;
  border-radius: var(--radius-lg);
}
.pack__note b { color: var(--gold-2); font-weight: 500; font-style: normal; }

/* =========================================================
   Ferramentas core (Dobra 06)
   ========================================================= */

.ferramentas-core {
  margin-top: clamp(80px, 10vw, 140px);
  padding: clamp(60px, 8vw, 100px) 0;
}

.ferramentas-core__head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 64px;
}

.ferramentas-core__head .eyebrow { display: block; margin-bottom: 16px; }

.ferramentas-core__head h3 {
  font-size: clamp(2rem, 3.6vw, 2.6rem);
  margin: 0 0 20px;
  line-height: 1.15;
}

.ferramentas-core__head p {
  margin: 0 auto;
  color: var(--ink-muted);
  max-width: 56ch;
  font-size: 1.05rem;
  line-height: 1.6;
}

.ferramentas-core__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(20px, 2.5vw, 32px);
  max-width: 1180px;
  margin: 0 auto;
}

.ferramenta-card {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  padding: clamp(28px, 3vw, 40px);
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: box-shadow 0.3s ease, transform 0.3s ease;
  position: relative;
}

.ferramenta-card:hover {
  box-shadow: 0 12px 32px rgba(61, 74, 48, 0.10);
  transform: translateY(-3px);
}

.ferramenta-card--featured {
  background: var(--cream-card);
  border: 1px solid rgba(184, 146, 74, 0.32);
}

.ferramenta-card--bonus {
  background: linear-gradient(135deg, var(--bg-2) 0%, var(--bg) 100%);
}

.ferramenta-card__tag {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold-deep);
  margin-bottom: 4px;
}

.ferramenta-card h4 {
  font-family: var(--display);
  font-size: clamp(1.6rem, 2.4vw, 2rem);
  font-weight: 400;
  line-height: 1.15;
  letter-spacing: -0.01em;
  color: var(--bg-deep);
  margin: 0;
}

.ferramenta-card__sub {
  font-family: var(--sans);
  font-size: 1rem;
  color: var(--gold-deep);
  font-style: italic;
  margin: 0 0 8px;
  font-weight: 400;
}

.ferramenta-card p {
  font-family: var(--sans);
  font-size: 0.98rem;
  line-height: 1.6;
  color: var(--ink-muted);
  margin: 0;
}

.ferramenta-card p strong {
  color: var(--ink);
  font-weight: 600;
}

.ferramenta-card__mockup {
  margin-top: auto;
  display: grid;
  place-items: end center;
  width: 100%;
  padding: clamp(30px, 3.4vw, 42px) 0 0;
  min-height: clamp(300px, 29vw, 390px);
}

.ferramenta-card--featured .ferramenta-card__mockup {
  min-height: auto;
  padding-top: clamp(18px, 2.2vw, 26px);
}

.ferramenta-card__mockup-placeholder {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-soft);
  opacity: 0.65;
}

.ferramenta-card__mockup--iphone .mockup--iphone { max-width: 360px; }
.ferramenta-card__mockup--ipad .mockup--ipad { max-width: 680px; }
.ferramenta-card__mockup--macbook .mockup--macbook { max-width: 760px; }
.ferramenta-card__mockup--chrome .mockup--chrome { max-width: 680px; }
.ferramenta-card__mockup--sheet .mockup--sheet { max-width: 560px; }

.ferramenta-card__mockup--macbook .mockup__screen--macbook {
  max-width: 100%;
  padding: clamp(10px, 1.2vw, 14px) clamp(10px, 1.2vw, 14px) clamp(14px, 1.5vw, 18px);
  border-radius: 18px 18px 5px 5px;
}

.ferramenta-card__mockup--macbook .mockup__macbook-base {
  max-width: 840px;
  height: 18px;
}

.ferramenta-card__mockup--chrome .mockup--chrome,
.ferramenta-card__mockup--sheet .mockup--sheet,
.ferramenta-card__mockup--ipad .mockup--ipad {
  width: min(100%, var(--mockup-width, 680px));
}

.ferramenta-card__mockup--chrome .mockup--chrome { --mockup-width: 680px; }
.ferramenta-card__mockup--sheet .mockup--sheet { --mockup-width: 560px; }
.ferramenta-card__mockup--ipad .mockup--ipad { --mockup-width: 680px; }

.ferramenta-card__mockup--chrome .mockup__screen img {
  aspect-ratio: 16 / 8.9;
  object-fit: cover;
  object-position: top center;
}

.ferramenta-card__mockup--chrome img[src$="objetivos.jpeg"] {
  aspect-ratio: 1600 / 737;
  object-fit: contain;
  object-position: center;
  background: #fff;
}

.ferramenta-card__mockup--chrome img[src$="Mapa%20travessia.jpeg"],
.ferramenta-card__mockup--chrome img[src$="Mapa travessia.jpeg"] {
  aspect-ratio: 1600 / 792;
  object-fit: contain;
  object-position: center;
  background: #fff;
}

.ferramenta-card__mockup--chrome img[src$="saidas-original.jpeg"] {
  aspect-ratio: 1600 / 1277;
  object-fit: contain;
  object-position: top center;
  background: #fff;
}

.ferramentas-core__note {
  text-align: center;
  margin: 68px auto 0;
  max-width: 720px;
  font-family: var(--display);
  font-style: italic;
  font-size: clamp(1.3rem, 2vw, 1.8rem);
  line-height: 1.35;
  color: var(--ink-muted);
  letter-spacing: -0.012em;
  position: relative;
}

.ferramentas-core__note::before {
  content: "";
  display: block;
  width: 72px;
  height: 2px;
  margin: 0 auto 20px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  opacity: 0.72;
}

.ferramentas-core__note strong {
  color: var(--bg-deeper);
  font-weight: 500;
  font-style: normal;
}

@media (max-width: 820px) {
  .ferramentas-core__grid { grid-template-columns: 1fr; }
}

/* Acompanhamento */
.acompanhamento {
  margin-top: 140px;
  padding: 96px 0;
  border-top: 1px solid var(--line);
}
.acompanhamento__head { text-align: center; margin-bottom: 70px; max-width: 720px; margin-inline: auto; }
.acompanhamento__head .eyebrow { display:block; margin-bottom: 16px; }
.acompanhamento__head h3 { font-size: clamp(1.8rem, 3vw, 2.4rem); margin-bottom: 20px; }
.acompanhamento__head p { margin: 0 auto; color: var(--ink-muted); font-family: var(--sans); font-style: italic; font-size: 17px; }
.acompanhamento__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; }
.acomp-card {
  background: var(--bg-2);
  padding: 40px 36px;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
}
.acomp-card__icon { color: var(--gold-deep); margin-bottom: 24px; }
.acomp-card h4 { font-family: var(--sans); font-size: 22px; color: var(--bg-deep); margin-bottom: 12px; }
.acomp-card p { font-size: 14.5px; color: var(--ink-muted); line-height: 1.6; }

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

/* ---- Aulas ao vivo · toggle list ---- */
.proof-anchor--inline {
  padding: clamp(40px, 6vw, 64px) 0;
  background: transparent;
}

.aovivo-temas {
  max-width: 760px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.aovivo-tema {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: box-shadow 0.25s ease;
}

.aovivo-tema:hover {
  box-shadow: 0 4px 14px rgba(61, 74, 48, 0.06);
}

.aovivo-tema summary {
  list-style: none;
  cursor: pointer;
  padding: 22px 28px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 16px;
  font-family: var(--sans);
  font-size: 1.05rem;
  font-weight: 500;
  color: var(--ink);
  user-select: none;
  transition: background 0.2s;
}

.aovivo-tema summary::-webkit-details-marker { display: none; }

.aovivo-tema summary:hover { background: rgba(184, 146, 74, 0.06); }

.aovivo-tema__icon {
  font-family: var(--sans);
  font-size: 1.1rem;
  color: var(--gold);
  font-weight: 300;
  transition: transform 0.3s;
}

.aovivo-tema[open] .aovivo-tema__icon {
  transform: rotate(90deg);
}

.aovivo-tema__title {
  line-height: 1.4;
}

.aovivo-tema__plus {
  width: 18px;
  height: 18px;
  position: relative;
  flex-shrink: 0;
}

.aovivo-tema__plus::before,
.aovivo-tema__plus::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  background: var(--ink-soft);
  transition: transform 0.25s ease, opacity 0.25s;
}

.aovivo-tema__plus::before {
  width: 12px;
  height: 1px;
  transform: translate(-50%, -50%);
}

.aovivo-tema__plus::after {
  width: 1px;
  height: 12px;
  transform: translate(-50%, -50%);
}

.aovivo-tema[open] .aovivo-tema__plus::after {
  opacity: 0;
  transform: translate(-50%, -50%) rotate(90deg);
}

.aovivo-tema__body {
  padding: 0 28px 24px;
}

.aovivo-tema__body p {
  margin: 0;
  font-family: var(--sans);
  font-size: 0.98rem;
  line-height: 1.6;
  color: var(--ink-muted);
  max-width: 60ch;
}

.acompanhamento__community {
  max-width: 760px;
  margin: 48px auto 0;
  padding: 28px 32px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 20px;
  align-items: start;
}

.acompanhamento__community-icon {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(184, 146, 74, 0.12);
  color: var(--gold-deep);
  display: grid;
  place-items: center;
  flex-shrink: 0;
}

.acompanhamento__community h4 {
  font-family: var(--sans);
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--bg-deep);
  margin: 0 0 6px;
}

.acompanhamento__community p {
  margin: 0;
  font-family: var(--sans);
  font-size: 0.95rem;
  line-height: 1.55;
  color: var(--ink-muted);
}

@media (max-width: 720px) {
  .aovivo-tema summary { padding: 18px 20px; font-size: 0.98rem; gap: 12px; }
  .aovivo-tema__body { padding: 0 20px 20px; }
  .acompanhamento__community { padding: 22px 20px; grid-template-columns: 1fr; }
}

/* =========================================================
   Dobra 09 · Caminhos opcionais
   ========================================================= */

.opcionais {
  margin-top: clamp(80px, 10vw, 120px);
  padding-top: clamp(60px, 8vw, 96px);
  border-top: 1px solid var(--line);
}

.opcionais__head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 56px;
}

.opcionais__head .eyebrow { display: block; margin-bottom: 16px; }

.opcionais__head h3 {
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  margin: 0 0 18px;
  line-height: 1.2;
}

.opcionais__head p {
  margin: 0 auto;
  color: var(--ink-muted);
  max-width: 56ch;
  font-size: 1rem;
  line-height: 1.6;
}

.opcionais__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(20px, 2.5vw, 28px);
  max-width: 1000px;
  margin: 0 auto;
}

.opcional-card {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: clamp(28px, 3vw, 36px);
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: box-shadow 0.25s ease, transform 0.25s ease;
}

.opcional-card:hover {
  box-shadow: 0 10px 28px rgba(61, 74, 48, 0.08);
  transform: translateY(-2px);
}

.opcional-card__icon {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(184, 146, 74, 0.12);
  color: var(--gold-deep);
  display: grid;
  place-items: center;
  margin-bottom: 4px;
}

.opcional-card__tag {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold-deep);
}

.opcional-card h4 {
  font-family: var(--display);
  font-size: clamp(1.4rem, 2vw, 1.7rem);
  font-weight: 400;
  line-height: 1.2;
  color: var(--bg-deep);
  margin: 0;
}

.opcional-card p {
  font-family: var(--sans);
  font-size: 0.98rem;
  line-height: 1.6;
  color: var(--ink-muted);
  margin: 0;
}

.opcional-card p strong {
  color: var(--ink);
  font-weight: 600;
}

.opcionais__note {
  text-align: center;
  margin: 36px auto 0;
  max-width: 540px;
  font-family: var(--sans);
  font-size: 0.92rem;
  font-style: italic;
  color: var(--ink-soft);
}

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

/* =========================================================
   Dobra 09 · Caminhos opcionais (pergunta-resposta)
   ========================================================= */

.opcional {
  margin-top: clamp(64px, 8vw, 104px);
  padding: 0 0 clamp(18px, 2.6vw, 34px);
}

.opcional + .opcional {
  margin-top: clamp(44px, 5.4vw, 76px);
}

.opcional__inner {
  max-width: 860px;
  margin: 0 auto;
}

/* Pergunta (estilo aspas, conversacional) */
.opcional__pergunta {
  position: relative;
  max-width: 760px;
  padding: 6px 0 8px 54px;
  margin: 0 auto 28px;
}

.opcional__pergunta-mark {
  position: absolute;
  left: 0;
  top: -16px;
  font-family: var(--display);
  font-size: 5rem;
  line-height: 1;
  color: var(--gold);
  opacity: 0.55;
  font-weight: 400;
}

.opcional__pergunta-text {
  font-family: var(--display);
  font-size: clamp(1.45rem, 2.4vw, 1.95rem);
  line-height: 1.3;
  color: var(--ink);
  margin: 0;
  font-weight: 400;
  font-style: italic;
}

/* Intro alternativa (segundo bloco, sem aspas) */
.opcional__intro {
  font-family: var(--display);
  font-size: clamp(1.2rem, 1.9vw, 1.55rem);
  line-height: 1.4;
  color: var(--ink);
  margin: 0 auto 30px;
  font-weight: 400;
  max-width: 56ch;
  text-align: center;
}

.opcional__intro strong {
  color: var(--gold-deep);
  font-weight: 500;
}

/* Resposta (lead + card) */
.opcional__resposta-lead {
  font-family: var(--sans);
  font-size: clamp(1rem, 1.3vw, 1.12rem);
  line-height: 1.55;
  color: var(--ink-muted);
  margin: 0 auto 24px;
  max-width: 48ch;
  text-align: center;
}

.opcional__resposta-lead strong {
  color: var(--gold-deep);
  font-weight: 600;
}

/* Card da trilha */
.opcional__card {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: clamp(28px, 3vw, 36px);
  max-width: 860px;
  margin-inline: auto;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 24px;
  align-items: start;
  transition: box-shadow 0.25s ease, transform 0.25s ease;
}

.opcional__card:hover {
  box-shadow: 0 12px 32px rgba(61, 74, 48, 0.10);
  transform: translateY(-2px);
}

.opcional__card-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: rgba(184, 146, 74, 0.14);
  color: var(--gold-deep);
  display: grid;
  place-items: center;
  flex-shrink: 0;
}

.opcional__card-body h4 {
  font-family: var(--display);
  font-size: clamp(1.3rem, 1.9vw, 1.6rem);
  font-weight: 400;
  line-height: 1.2;
  color: var(--bg-deep);
  margin: 0 0 10px;
}

.opcional__card-body p {
  font-family: var(--sans);
  font-size: 0.98rem;
  line-height: 1.6;
  color: var(--ink-muted);
  margin: 0;
}

.opcional__card-body p strong {
  color: var(--ink);
  font-weight: 600;
}

/* Nota final */
.opcional__note {
  text-align: center;
  margin: 48px auto 0;
  max-width: 540px;
  font-family: var(--sans);
  font-size: 0.95rem;
  font-style: italic;
  color: var(--gold-deep);
}

@media (max-width: 720px) {
  .opcional__pergunta { padding-left: 36px; }
  .opcional__pergunta-mark { font-size: 3.5rem; top: -8px; }
  .opcional__card {
    grid-template-columns: 1fr;
    gap: 16px;
    padding: 24px;
  }
}

/* =========================================================
   Dobra 11 · Depoimentos finais (grid focado)
   ========================================================= */

.depoimentos-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(20px, 2.5vw, 32px);
  max-width: 1180px;
  margin: 0 auto 80px;
}

.depoimento-card {
  background: rgba(242, 236, 220, 0.06);
  border: 1px solid rgba(242, 236, 220, 0.12);
  border-radius: var(--radius-xl);
  padding: clamp(24px, 2.5vw, 32px);
  display: grid;
  grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
  gap: clamp(20px, 2.5vw, 32px);
  align-items: center;
  transition: transform 0.3s ease, background 0.3s ease;
}

.depoimento-card:hover {
  transform: translateY(-4px);
  background: rgba(242, 236, 220, 0.10);
}

.depoimento-card--featured {
  grid-column: 1 / -1;
}

.depoimentos-grid > .depoimento-card:last-child {
  grid-column: 1 / -1;
  width: min(100%, 620px);
  justify-self: center;
}

.depoimento-card__images {
  display: grid;
  place-items: center;
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: 0 14px 32px rgba(0, 0, 0, 0.22);
  background: var(--cream-card);
}

.depoimento-card__images img {
  display: block;
  width: 100%;
  height: auto;
}

.depoimento-card__images--combo {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
  background: transparent;
  box-shadow: none;
}

.depoimento-card__images--combo img {
  border-radius: var(--radius-md);
  box-shadow: 0 14px 32px rgba(0, 0, 0, 0.22);
}

.depoimento-card__content {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.depoimento-card__content h3 {
  font-family: var(--display);
  font-size: clamp(1.5rem, 2.2vw, 1.85rem);
  font-weight: 400;
  line-height: 1.2;
  color: #f2ecdc;
  margin: 0;
  letter-spacing: -0.01em;
}

.depoimento-card__hook {
  font-family: var(--display);
  font-size: clamp(1.05rem, 1.4vw, 1.2rem);
  font-style: italic;
  color: var(--gold-2);
  margin: 0;
  font-weight: 400;
  line-height: 1.4;
}

.depoimento-card__hook em {
  font-style: italic;
}

.depoimento-card__content p {
  font-family: var(--sans);
  font-size: 0.98rem;
  line-height: 1.6;
  color: #d8d2c2;
  margin: 0;
}

.depoimento-card__content p strong {
  color: var(--gold-2);
  font-weight: 600;
}

@media (max-width: 880px) {
  .depoimentos-grid { grid-template-columns: 1fr; max-width: 540px; }
  .depoimento-card { grid-template-columns: 1fr; gap: 20px; }
  .depoimento-card--featured { grid-column: auto; }
  .depoimento-card__images--combo { grid-template-columns: 1fr 1fr; }
}

/* =========================================================
   Dobra 10 · Cursos macro (legado, agora removido do HTML)
   ========================================================= */

.cursos-macro {
  margin-top: clamp(80px, 10vw, 120px);
  padding-top: clamp(60px, 8vw, 96px);
  border-top: 1px solid var(--line);
}

.cursos-macro__head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 56px;
}

.cursos-macro__head .eyebrow { display: block; margin-bottom: 16px; }

.cursos-macro__head h3 {
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  margin: 0 0 18px;
  line-height: 1.2;
}

.cursos-macro__head p {
  margin: 0 auto;
  color: var(--ink-muted);
  max-width: 56ch;
  font-size: 1rem;
  line-height: 1.6;
}

.cursos-macro__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(20px, 2.5vw, 28px);
  max-width: 1000px;
  margin: 0 auto;
}

.cursomacro-card {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: clamp(28px, 3vw, 36px);
  display: flex;
  flex-direction: column;
  gap: 12px;
  position: relative;
  transition: box-shadow 0.25s ease;
}

.cursomacro-card:hover {
  box-shadow: 0 8px 22px rgba(61, 74, 48, 0.06);
}

.cursomacro-card__num {
  font-family: var(--display);
  font-size: 1.6rem;
  font-weight: 300;
  color: var(--gold);
  letter-spacing: 0.04em;
  margin-bottom: 4px;
}

.cursomacro-card h4 {
  font-family: var(--sans);
  font-size: clamp(1.15rem, 1.7vw, 1.3rem);
  font-weight: 600;
  line-height: 1.3;
  color: var(--bg-deep);
  margin: 0;
}

.cursomacro-card p {
  font-family: var(--sans);
  font-size: 0.96rem;
  line-height: 1.6;
  color: var(--ink-muted);
  margin: 0;
}

.cursomacro-card p strong {
  color: var(--ink);
  font-weight: 600;
}

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

/* =========================================================
   DOBRA 10 · Prova
   ========================================================= */
.prova {
  padding: 160px 0;
  background: var(--bg-deep);
  color: #d9d2c0;
  overflow: hidden;
}
.prova__head { text-align: center; margin-bottom: 90px; max-width: 740px; margin-inline: auto; }
.prova__head .eyebrow { color: var(--gold-2); display: block; margin-bottom: 16px; }
.prova__head h2 { color: #f2ecdc; font-size: clamp(2rem, 3.6vw, 3rem); }
.prova__head h2 em { color: var(--gold-2); }

/* ---------- Parede de depoimentos (marquee em 2 linhas) ---------- */
.dwall {
  --wall-gap: 22px;
  margin: 0 calc(50% - 50vw);
  padding: 0;
  position: relative;
}
.dwall__row {
  overflow: hidden;
  position: relative;
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
          mask-image: linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
  padding: 22px 0;
}
.dwall__row--tall  { padding-top: 24px; padding-bottom: 10px; }
.dwall__row--short { padding-top: 10px; padding-bottom: 24px; }

.dwall__track {
  display: flex;
  gap: var(--wall-gap);
  width: max-content;
  will-change: transform;
}
.dwall__track--right { animation: wallRight 72s linear infinite; }
.dwall__track--left  { animation: wallLeft  58s linear infinite; }

@keyframes wallRight {
  from { transform: translate3d(-50%, 0, 0); }
  to   { transform: translate3d(0, 0, 0); }
}
@keyframes wallLeft {
  from { transform: translate3d(0, 0, 0); }
  to   { transform: translate3d(-33.3333%, 0, 0); }
}

.dwall:hover .dwall__track { animation-play-state: paused; }

/* Frame card */
.dcard {
  flex-shrink: 0;
  position: relative;
  background: var(--bg);
  padding: 10px 10px 14px;
  border: 1px solid rgba(184,146,74,0.28);
  border-radius: var(--radius-lg);
  box-shadow:
    0 18px 36px -18px rgba(20,26,14,0.55),
    0 4px 10px -4px rgba(0,0,0,0.2);
  transition:
    transform 0.5s cubic-bezier(.2,.7,.2,1),
    box-shadow 0.5s cubic-bezier(.2,.7,.2,1),
    z-index 0s;
  transform-origin: center;
}
.dcard::after {
  content: "";
  position: absolute;
  inset: 5px;
  border: 1px dashed rgba(184,146,74,0.22);
  pointer-events: none;
  border-radius: 1px;
}
.dcard::before {
  content: "";
  position: absolute;
  top: 8px; right: 8px;
  width: 8px; height: 8px;
  background: var(--gold);
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
  opacity: 0.8;
  z-index: 3;
}
.dcard:nth-child(odd)  { transform: rotate(-0.7deg); }
.dcard:nth-child(even) { transform: rotate(0.6deg); }

.dcard:hover {
  transform: rotate(0) scale(1.04);
  box-shadow:
    0 36px 60px -24px rgba(20,26,14,0.7),
    0 8px 18px -6px rgba(0,0,0,0.3);
  z-index: 5;
}

.dcard img {
  display: block;
  width: auto;
  border-radius: 1px;
  background: #ece3d0;
  user-select: none;
  -webkit-user-drag: none;
}
.dcard--tall img  { height: 420px; max-width: 380px; }
.dcard--short img { height: 280px; max-width: 460px; }

/* Caption line */
.dwall__caption {
  display: flex; align-items: center; justify-content: center; gap: 18px;
  margin-top: 28px;
  font-family: var(--sans); font-style: italic;
  font-size: 14px;
  color: rgba(212,176,114,0.85);
  text-align: center;
}
.dwall__caption em { font-style: italic; letter-spacing: 0.01em; }
.dwall__caption .line {
  display: block; width: 60px; height: 1px;
  background: rgba(212,176,114,0.4);
}

@media (max-width: 960px) {
  .dwall { --wall-gap: 16px; }
  .dwall__row { padding: 14px 0; }
  .dcard { padding: 8px 8px 10px; }
  .dcard::after { inset: 4px; }
  .dcard::before { width: 7px; height: 7px; top: 6px; right: 6px; }
  .dcard--tall img  { height: 320px; max-width: 280px; }
  .dcard--short img { height: 220px; max-width: 360px; }
  .dwall__track--right { animation-duration: 55s; }
  .dwall__track--left  { animation-duration: 44s; }
  .dwall__caption { font-size: 13px; gap: 12px; }
  .dwall__caption .line { width: 36px; }
}

@media (max-width: 560px) {
  .dwall__row {
    -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 3%, #000 97%, transparent 100%);
            mask-image: linear-gradient(90deg, transparent 0, #000 3%, #000 97%, transparent 100%);
  }
  .dcard--tall img  { height: 280px; max-width: 240px; }
  .dcard--short img { height: 180px; max-width: 300px; }
  .dwall__track--right { animation-duration: 42s; }
  .dwall__track--left  { animation-duration: 34s; }
}

@media (prefers-reduced-motion: reduce) {
  .dwall__track { animation: none !important; transform: none !important; }
  .dwall__row {
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }
  .dcard { scroll-snap-align: center; }
  .dcard, .dcard:nth-child(odd), .dcard:nth-child(even) { transform: none; }
}

.prova__stats {
  margin-top: 90px;
  padding: 50px 0;
  border-top: 1px solid rgba(212,176,114,0.2);
  border-bottom: 1px solid rgba(212,176,114,0.2);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
  text-align: center;
}
.prova__stat .n {
  font-family: var(--sans); font-size: clamp(2rem, 3.2vw, 2.6rem);
  color: var(--gold-2); line-height: 1;
}
.prova__stat .l {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(217,210,192,0.7);
  margin-top: 10px;
}

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

/* =========================================================
   DOBRA 12-15 · Oferta
   ========================================================= */
.oferta {
  padding: 180px 0 140px;
  background: var(--bg-2);
  position: relative;
  overflow: hidden;
}
.oferta::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(184,146,74,0.14), transparent 55%),
    radial-gradient(ellipse at 90% 100%, rgba(107,122,84,0.08), transparent 60%);
  pointer-events: none;
}
.oferta__inner { position: relative; z-index: 2; }
.oferta__head { text-align: center; margin-bottom: 72px; max-width: 780px; margin-inline: auto; }
.oferta__head .eyebrow { display: block; margin-bottom: 16px; }
.oferta__head h2 { font-size: clamp(2.2rem, 4vw, 3.4rem); }
.oferta__lede {
  margin: 22px auto 0; max-width: 60ch;
  color: var(--ink-muted); font-size: clamp(1rem, 1.3vw, 1.125rem);
  line-height: 1.55;
}

.oferta__grid {
  display: block;
  width: min(650px, 100%);
  margin-inline: auto;
}

.offer-bonus {
  margin: 0 auto 54px;
  padding: clamp(30px, 4vw, 46px);
  border: 1px solid rgba(140, 107, 42, 0.22);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 8% 18%, rgba(212,176,114,0.22), transparent 28%),
    linear-gradient(135deg, rgba(255,255,255,0.36), rgba(232,217,180,0.70));
  box-shadow: 0 24px 70px -54px rgba(43, 51, 31, 0.55);
  position: relative;
  overflow: hidden;
}
.offer-bonus::before {
  content: "B";
  position: absolute;
  right: clamp(18px, 4vw, 44px);
  top: -0.24em;
  color: rgba(140, 107, 42, 0.08);
  font-family: var(--display);
  font-size: clamp(8rem, 18vw, 15rem);
  font-weight: 500;
  line-height: 1;
  pointer-events: none;
}
.offer-bonus__head {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(280px, 1.1fr);
  gap: clamp(24px, 4vw, 54px);
  align-items: end;
  margin-bottom: 34px;
}
.offer-bonus__eyebrow {
  display: block;
  grid-column: 1 / -1;
  color: var(--gold-deep);
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}
.offer-bonus__head h3 {
  color: var(--bg-deep);
  font-size: clamp(2rem, 3.3vw, 3rem);
  line-height: 1.04;
  letter-spacing: -0.02em;
  margin: 0;
  max-width: 12ch;
}
.offer-bonus__head h3 em {
  color: var(--gold-deep);
  font-style: italic;
}
.offer-bonus__head p {
  color: var(--ink-muted);
  font-size: clamp(1rem, 1.24vw, 1.12rem);
  line-height: 1.62;
  margin: 0;
  max-width: 52ch;
}
.offer-bonus__grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}
.offer-bonus__card {
  background: rgba(250, 246, 236, 0.58);
  border: 1px solid rgba(140, 107, 42, 0.18);
  border-left: 3px solid var(--gold);
  border-radius: var(--radius-md);
  padding: clamp(22px, 3vw, 30px);
}
.offer-bonus__tag {
  color: var(--gold-deep);
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: 16px;
}
.offer-bonus__card h4 {
  color: var(--bg-deep);
  font-family: var(--sans);
  font-size: clamp(1.24rem, 1.7vw, 1.55rem);
  line-height: 1.14;
  letter-spacing: -0.012em;
  margin: 0 0 12px;
}
.offer-bonus__card p {
  color: var(--ink-muted);
  font-size: 14.8px;
  line-height: 1.58;
  margin: 0;
}

.offer-bonus--pack {
  margin-top: 44px;
  margin-bottom: 0;
}

/* ---------- Price card ---------- */
.price-card {
  position: relative;
  top: auto;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(245,233,207,0.16), transparent 48%),
    radial-gradient(circle at 92% 8%, rgba(212,176,114,0.22), transparent 34%),
    radial-gradient(circle at 18% 70%, rgba(184,146,74,0.10), transparent 36%),
    linear-gradient(180deg, #2f3a24 0%, var(--bg-deeper) 100%);
  color: #e8e1ce;
  padding: clamp(38px, 5vw, 58px) clamp(30px, 5vw, 46px) clamp(34px, 4vw, 44px);
  border-radius: 36px;
  border: 1px solid rgba(212,176,114,0.28);
  box-shadow:
    0 42px 100px -34px rgba(20,26,14,0.62),
    0 18px 50px -44px rgba(212,176,114,0.62),
    0 0 0 1px rgba(245,233,207,0.05) inset;
  overflow: hidden;
}
.price-card::before {
  content: "";
  position: absolute; inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 85% 15%, rgba(212,176,114,0.1), transparent 40%),
    radial-gradient(circle at 15% 95%, rgba(107,122,84,0.15), transparent 45%);
  opacity: 0.9;
}
.price-card > * { position: relative; z-index: 2; }

/* Corner ribbon */
.price-card__ribbon {
  position: absolute;
  top: 18px;
  right: -52px;
  width: 180px;
  transform: rotate(38deg);
  transform-origin: center;
  background: linear-gradient(90deg, var(--gold-deep), var(--gold) 50%, var(--gold-deep));
  color: #1c1508;
  font-family: var(--mono); font-size: 9px;
  letter-spacing: 0.22em; text-transform: uppercase;
  text-align: center;
  padding: 6px 0;
  box-shadow: 0 8px 16px -8px rgba(0,0,0,0.5);
  z-index: 3;
}

/* Shine sweep that plays on reveal */
.price-card__shine {
  position: absolute; top: 0; left: -50%;
  width: 50%; height: 100%;
  background: linear-gradient(110deg, transparent, rgba(245,233,207,0.12) 50%, transparent);
  pointer-events: none;
  z-index: 1;
  transform: translateX(-40%);
  opacity: 0;
}
.price-card.is-visible .price-card__shine {
  animation: priceShineSweep 1.6s cubic-bezier(.4,0,.2,1) 0.4s forwards;
}
@keyframes priceShineSweep {
  0%   { opacity: 0; transform: translateX(-40%); }
  15%  { opacity: 1; }
  85%  { opacity: 1; }
  100% { opacity: 0; transform: translateX(420%); }
}

.price-card__top {
  display: flex; align-items: center; justify-content: space-between;
  gap: 18px;
  padding-bottom: 26px;
  border-bottom: 1px solid rgba(212,176,114,0.2);
  margin-bottom: 28px;
}
.price-card__logo { display: flex; align-items: center; gap: 10px; }
.price-card__logo svg { color: var(--gold-2); width: 27px; height: 27px; }
.price-card__logo-name {
  font-family: var(--sans); font-size: 23px; letter-spacing: 0.18em;
  color: #f2ecdc;
}
.price-card__tag {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.18em;
  color: var(--gold-2); text-transform: uppercase;
}

.price-card__ledger { display: flex; flex-direction: column; margin: 4px 0 2px; }
.price-card__row {
  display: flex; justify-content: space-between; align-items: baseline; gap: 16px;
  padding: 17px 0;
  font-size: 16.5px;
  color: #e8e1ce;
  border-bottom: 1px solid rgba(212,176,114,0.18);
  opacity: 0;
  transform: translateY(8px);
  transition:
    opacity 0.55s cubic-bezier(.2,.7,.2,1),
    transform 0.55s cubic-bezier(.2,.7,.2,1);
  transition-delay: calc(var(--i, 0) * 90ms + 200ms);
}
.price-card.is-visible .price-card__row { opacity: 1; transform: none; }
.price-card__row:last-child { border-bottom: none; }
.price-card__row .l {
  color: rgba(245,233,207,0.88);
  font-weight: 500;
  letter-spacing: -0.002em;
  position: relative;
  padding-left: 16px;
}
.price-card__row .l::before {
  content: "";
  position: absolute;
  left: 0; top: 50%;
  width: 6px; height: 1px;
  background: var(--gold-2);
  transform: translateY(-50%);
}
.price-card__row .v {
  font-family: var(--sans);
  color: #f5e9cf;
  font-size: 22px;
  letter-spacing: 0.005em;
  white-space: nowrap;
}

/* Total "if bought separately" line with animated strike */
.price-card__total {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 20px 0 12px;
  margin-top: 8px;
  border-top: 1px solid rgba(212,176,114,0.22);
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(217,210,192,0.55);
}
.price-card__strike {
  position: relative;
  font-family: var(--sans); font-style: italic;
  font-size: 18px;
  color: rgba(217,210,192,0.55);
  letter-spacing: normal;
  text-transform: none;
  padding: 0 2px;
}
.price-card__strike::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  top: 52%;
  height: 1px;
  background: var(--gold-2);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 0.7s cubic-bezier(.4,0,.2,1) 0.2s;
}
.price-card__strike.in-view::after { transform: scaleX(1); }

/* Savings badge */
.price-card__save {
  display: flex; align-items: center; justify-content: center;
  gap: 12px;
  margin: 12px 0 6px;
  padding: 14px 18px;
  border: 1px solid rgba(212,176,114,0.46);
  background: linear-gradient(90deg, rgba(212,176,114,0.11), rgba(212,176,114,0.20), rgba(212,176,114,0.11));
  border-radius: 999px;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 0.6s, transform 0.6s;
  transition-delay: 0.9s;
}
.price-card.is-visible .price-card__save { opacity: 1; transform: none; }
.price-card__save-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--gold-2);
  box-shadow: 0 0 0 0 rgba(212,176,114,0.5);
  animation: savePulse 2.4s ease-in-out infinite;
}
@keyframes savePulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(212,176,114,0.55); }
  50%      { box-shadow: 0 0 0 8px rgba(212,176,114,0);   }
}
.price-card__save-label {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.24em;
  color: rgba(245,233,207,0.8); text-transform: uppercase;
}
.price-card__save-value {
  font-family: var(--sans);
  font-size: 22px;
  color: var(--gold-2);
  letter-spacing: 0.01em;
}

.price-card__today {
  text-align: center;
  margin: 30px 0 24px;
}
.price-card__today-label {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.32em;
  color: var(--gold-2); text-transform: uppercase;
  margin-bottom: 12px;
}
.price-card__today-main {
  font-family: var(--sans);
  font-size: clamp(3.8rem, 7vw, 5.35rem);
  color: #f5e9cf;
  line-height: 1;
  letter-spacing: -0.015em;
  margin-bottom: 8px;
  opacity: 0;
  transform: scale(0.96);
  transition: opacity 0.7s cubic-bezier(.2,.7,.2,1), transform 0.7s cubic-bezier(.2,.7,.2,1);
  transition-delay: 1.05s;
}
.price-card.is-visible .price-card__today-main { opacity: 1; transform: none; }
.price-card__today-main em {
  font-style: italic; color: var(--gold-2);
  font-size: 0.56em; margin-right: 8px;
  vertical-align: 0.15em;
}
.price-card__cents { font-size: 0.48em; vertical-align: 0.35em; margin-left: 2px; color: rgba(245,233,207,0.85); }
.price-card__today-alt {
  color: rgba(217,210,192,0.8);
  font-size: 16.5px;
}
.price-card__today-alt b { color: #f2ecdc; font-weight: 500; }

.price-card__cta {
  width: 100%; justify-content: center;
  position: relative;
  overflow: hidden;
  white-space: nowrap;
  gap: 12px;
  font-size: 13px;
  min-height: 68px;
}
.price-card__cta::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(110deg, transparent 30%, rgba(255,255,255,0.25) 50%, transparent 70%);
  transform: translateX(-120%);
  transition: transform 0s;
  pointer-events: none;
}
.price-card.is-visible .price-card__cta::after {
  animation: ctaShimmer 5.5s cubic-bezier(.4,0,.2,1) 2.2s infinite;
}
@keyframes ctaShimmer {
  0%   { transform: translateX(-120%); }
  28%  { transform: translateX(130%); }
  100% { transform: translateX(130%); }
}
.price-card__cta:hover::after { animation: none; transform: translateX(130%); transition: transform 0.7s cubic-bezier(.4,0,.2,1); }

.price-card__reassure {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  margin: 20px 0 4px;
  padding: 15px 17px;
  background: rgba(212,176,114,0.06);
  border: 1px dashed rgba(212,176,114,0.22);
  border-radius: var(--radius-md);
  font-size: 14px;
  line-height: 1.45;
  color: rgba(232,225,206,0.82);
  max-width: none;
  text-align: center;
}
.price-card__reassure svg { width: 16px; height: 16px; color: var(--gold-2); flex-shrink: 0; }
.price-card__reassure b { color: #f5e9cf; font-weight: 500; }

.price-card__meta {
  margin-top: 20px;
  padding-top: 18px;
  border-top: 1px solid rgba(212,176,114,0.15);
  font-size: 12.5px;
  color: rgba(217,210,192,0.7);
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px 16px;
}
.price-card__meta span { display: flex; align-items: center; gap: 8px; }
.price-card__meta svg { width: 13px; height: 13px; color: var(--gold-2); flex-shrink: 0; }

@media (max-width: 960px) {
  .oferta { padding: 120px 0 100px; }
  .oferta__head { margin-bottom: 48px; }
  .oferta__grid { width: min(620px, 100%); }
  .offer-bonus { margin-bottom: 34px; }
  .offer-bonus__head {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .offer-bonus__head h3 { max-width: 13ch; }
  .offer-bonus__grid { grid-template-columns: 1fr; }
  .price-card { position: relative; top: 0; padding: 32px 22px 26px; }
  .price-card__ribbon { top: 10px; right: -50px; width: 170px; padding: 5px 0; font-size: 8.5px; }
  .price-card__top { padding-bottom: 18px; margin-bottom: 18px; flex-direction: column; align-items: flex-start; }
  .price-card__logo svg { width: 24px; height: 24px; }
  .price-card__logo-name { font-size: 20px; }
  .price-card__tag { font-size: 9px; letter-spacing: 0.14em; }
  .price-card__row { font-size: 15.5px; padding: 14px 0; gap: 12px; }
  .price-card__row .l { padding-left: 12px; }
  .price-card__row .l::before { width: 5px; }
  .price-card__row .v { font-size: 18.5px; }
  .price-card__total { padding: 16px 0 8px; font-size: 9.5px; letter-spacing: 0.2em; }
  .price-card__strike { font-size: 16px; }
  .price-card__save { padding: 10px 14px; gap: 8px; flex-wrap: wrap; }
  .price-card__save-value { font-size: 17px; }
  .price-card__today-main { font-size: clamp(3rem, 13vw, 3.8rem); }
  .price-card__today-alt { font-size: 15px; }
  .price-card__cta {
    padding: 20px 16px;
    font-size: 11.5px;
    letter-spacing: 0.08em;
    gap: 10px;
  }
  .price-card__cta .btn__arrow { width: 22px; }
  .price-card__cta:hover .btn__arrow { width: 28px; }
  .price-card__meta { grid-template-columns: 1fr 1fr; gap: 8px 12px; font-size: 11px; }
  .price-card__reassure { font-size: 12px; }
}

@media (max-width: 400px) {
  .price-card__cta { padding: 18px 12px; font-size: 11px; letter-spacing: 0.06em; }
}

@media (prefers-reduced-motion: reduce) {
  .price-card__shine,
  .price-card__save-dot,
  .price-card__cta::after { animation: none !important; }
  .price-card__row,
  .price-card__save,
  .price-card__today-main { opacity: 1 !important; transform: none !important; transition: none !important; }
  .price-card__strike::after { transform: scaleX(1); transition: none; }
}

/* =========================================================
   DOBRA 16 · Garantia
   ========================================================= */
.garantia {
  padding: 140px 0;
  background: var(--bg-2);
}
.garantia__inner {
  display: grid; grid-template-columns: 260px 1fr;
  gap: 72px; align-items: center;
}
.garantia__seal {
  position: relative;
  width: 100%; aspect-ratio: 1;
  background:
    radial-gradient(circle, #f5e9cf 0%, transparent 60%);
}
.garantia__seal svg {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  animation: rotate 40s linear infinite;
}
.garantia__seal-core {
  position: absolute; inset: 30%;
  display: flex; align-items: center; justify-content: center;
  flex-direction: column;
  text-align: center;
  color: var(--bg-deep);
}
.garantia__seal-core .n {
  font-family: var(--sans); font-style: italic;
  font-size: clamp(2.2rem, 3.6vw, 3rem); line-height: 1;
  color: var(--gold-deep);
}
.garantia__seal-core .l {
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.25em; text-transform: uppercase;
  margin-top: 8px;
}
@keyframes rotate { to { transform: rotate(360deg); } }

.garantia__content .eyebrow { display: block; margin-bottom: 18px; }
.garantia__content h2 { font-size: clamp(2rem, 3.4vw, 2.8rem); margin-bottom: 28px; }
.garantia__content p { font-size: 17px; color: var(--ink-muted); line-height: 1.65; margin-bottom: 18px; }
.garantia__content p b { color: var(--bg-deep); }
.garantia__content .closer {
  font-family: var(--sans); font-style: italic;
  color: var(--gold-deep); font-size: clamp(1.2rem, 1.8vw, 1.4rem);
  margin-top: 28px;
}

@media (max-width: 880px) {
  .garantia__inner { grid-template-columns: 1fr; text-align: center; }
  .garantia__seal { max-width: 220px; margin: 0 auto; }
}

/* =========================================================
   DOBRA 17 · FAQ
   ========================================================= */
.faq {
  padding: 160px 0;
  background: var(--bg);
}
.faq__head { text-align: center; margin-bottom: 70px; max-width: 640px; margin-inline: auto; }
.faq__head .eyebrow { display: block; margin-bottom: 16px; }
.faq__head h2 { font-size: clamp(2rem, 3.6vw, 3rem); }

.faq__list { max-width: 880px; margin: 0 auto; }

.faq__contact {
  max-width: 880px;
  margin: 56px auto 0;
  padding: clamp(28px, 3vw, 36px);
  background: linear-gradient(135deg, rgba(37, 211, 102, 0.06) 0%, rgba(184, 146, 74, 0.06) 100%);
  border: 1px solid rgba(37, 211, 102, 0.18);
  border-radius: var(--radius-xl);
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 24px;
  align-items: center;
}

.faq__contact-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #25D366;
  color: #fff;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  padding: 12px;
  box-shadow: 0 8px 18px rgba(37, 211, 102, 0.30);
}

.faq__contact-text p {
  margin: 0;
  font-family: var(--sans);
  font-size: clamp(0.98rem, 1.25vw, 1.08rem);
  line-height: 1.55;
  color: var(--ink);
}

.faq__contact-text strong {
  color: var(--bg-deep);
  font-weight: 600;
}

.faq__contact-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 22px;
  background: #25D366;
  color: #fff;
  font-family: var(--sans);
  font-size: 0.95rem;
  font-weight: 600;
  text-decoration: none;
  border-radius: 999px;
  white-space: nowrap;
  transition: transform 0.2s, box-shadow 0.2s, background 0.2s;
}

.faq__contact-btn:hover {
  background: #1fb854;
  transform: translateY(-2px);
  box-shadow: 0 12px 24px rgba(37, 211, 102, 0.32);
}

@media (max-width: 720px) {
  .faq__contact {
    grid-template-columns: 1fr;
    text-align: center;
    gap: 18px;
  }
  .faq__contact-icon { margin: 0 auto; }
  .faq__contact-btn { justify-self: center; }
}
.faq-item {
  border-bottom: 1px solid var(--line);
}
.faq-item:first-child { border-top: 1px solid var(--line); }
.faq-item__q {
  width: 100%;
  padding: 30px 0;
  background: none; border: none;
  display: flex; justify-content: space-between; align-items: center;
  cursor: pointer;
  text-align: left;
  font-family: var(--sans);
  font-size: clamp(1.15rem, 1.8vw, 1.35rem);
  color: var(--bg-deep);
  transition: color 0.3s;
}
.faq-item__q:hover { color: var(--gold-deep); }
.faq-item__q-toggle {
  width: 24px; height: 24px; flex-shrink: 0;
  position: relative;
}
.faq-item__q-toggle::before, .faq-item__q-toggle::after {
  content: "";
  position: absolute; top: 50%; left: 50%;
  width: 14px; height: 1px;
  background: var(--gold-deep);
  transform: translate(-50%, -50%);
  transition: transform 0.3s cubic-bezier(.2,.7,.2,1);
}
.faq-item__q-toggle::after { transform: translate(-50%, -50%) rotate(90deg); }
.faq-item.is-open .faq-item__q-toggle::after { transform: translate(-50%, -50%) rotate(0); }
.faq-item__a {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.5s cubic-bezier(.2,.7,.2,1);
}
.faq-item__a-inner {
  padding: 0 0 32px 0;
  max-width: 66ch;
  font-size: 16px; line-height: 1.65;
  color: var(--ink-muted);
}

/* =========================================================
   DOBRA 18 · Last call
   ========================================================= */
.last-call {
  padding: clamp(104px, 10vw, 132px) 0 clamp(88px, 8vw, 108px);
  background: var(--bg-deeper);
  color: #d9d2c0;
  position: relative;
  overflow: hidden;
}
.last-call::before {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(212,176,114,0.08), transparent 52%),
    radial-gradient(ellipse at 50% 100%, rgba(184,146,74,0.12), transparent 70%);
  pointer-events: none;
}
.last-call__inner { position: relative; z-index: 2; text-align: center; }
.last-call__mark { margin: 0 auto 26px; width: 44px; color: var(--gold-2); }
.last-call h2 {
  color: #f5e9cf;
  font-size: clamp(2rem, 3.55vw, 3.15rem);
  max-width: 27ch;
  margin: 18px auto 30px;
  line-height: 1.08;
  letter-spacing: -0.018em;
}
.last-call h2 em { color: var(--gold-2); font-style: italic; }
.last-call__list {
  list-style: none;
  padding: 0;
  margin: 0 auto 30px;
  max-width: 34ch;
  display: flex;
  flex-direction: column;
  gap: 0;
  font-family: var(--serif);
  font-size: clamp(1.05rem, 1.65vw, 1.28rem);
  color: #f5e9cf;
  text-align: center;
  font-style: italic;
}
.last-call__list li {
  position: relative;
  padding: 10px 0;
  border-top: 1px solid rgba(212,176,114,0.18);
}
.last-call__list li:first-child { border-top: none; }
.last-call__list li em { color: var(--gold-2); font-style: italic; }
.last-call__body {
  font-family: var(--serif);
  font-size: clamp(0.98rem, 1.28vw, 1.1rem);
  color: rgba(245,233,207,0.78);
  max-width: 54ch;
  margin: 0 auto 28px;
  line-height: 1.55;
}
.last-call__sub {
  font-family: var(--sans); font-style: italic;
  font-size: clamp(1.08rem, 1.55vw, 1.28rem);
  color: var(--gold-2);
  margin-bottom: 34px;
  letter-spacing: 0.04em;
}
.last-call__meta {
  margin-top: 22px;
  font-size: 13px;
  color: rgba(217,210,192,0.6);
  letter-spacing: 0.05em;
}

/* =========================================================
   Footer
   ========================================================= */
.foot {
  background: var(--bg-deeper);
  color: rgba(217,210,192,0.6);
  padding: 60px 0 40px;
  border-top: 1px solid rgba(212,176,114,0.15);
  font-size: 12px;
  letter-spacing: 0.04em;
}
.foot__inner {
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 20px;
}
.foot__brand { display: flex; align-items: center; gap: 10px; color: var(--gold-2); font-family: var(--sans); font-size: 16px; letter-spacing: 0.18em; }
.foot__brand svg { width: 16px; color: var(--gold-2); }
.foot__right { display: flex; gap: 22px; }

/* =========================================================
   Parallax helpers
   ========================================================= */
.parallax { will-change: transform; }

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  * { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

/* ==================== Typography scale, mobile ==================== */
@media (max-width: 768px) {
  h1, .display-title { font-size: 40px; line-height: 1.1; }
  h2 { font-size: 30px; line-height: 1.15; }
  h3 { font-size: 20px; }
  body, p, li { font-size: 16px; }
}

/* =========================================================
   COPY V3 · adições estruturais
   Hero eyebrow, lede accent
   D02 sintomas
   D03 checklist, quotes
   D05 Big Idea
   D06 Existe uma ordem
   "Na prática" rotina
   D15 Objeções
   ========================================================= */

/* Hero eyebrow + lede accent */
.hero__eyebrow {
  display: inline-block;
  margin-bottom: 24px;
  letter-spacing: 0.18em;
  font-size: 12px;
  color: var(--gold-deep);
}
.hero__lede--accent {
  font-style: italic;
  color: var(--bg-deep);
  border-left: 2px solid var(--gold-2);
  padding-left: 16px;
  margin-top: 18px;
}
.hero__lede--accent em {
  font-style: italic;
  color: var(--gold-deep);
}

/* D02 — pergunta âncora "Render pra quê?" */
.dossie__problema-title--pergunta {
  font-family: var(--serif);
  font-size: clamp(2.4rem, 5vw, 4rem);
  text-align: center;
  margin: 0 auto 28px;
  color: var(--bg-deep);
}
.dossie__problema-title--pergunta em {
  color: var(--gold-deep);
  font-style: italic;
}

/* D02 — lista de sintomas */
.dossie__sintomas {
  list-style: none;
  padding: 0;
  margin: 16px 0 36px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.dossie__sintomas li {
  position: relative;
  padding-left: 24px;
  font-size: clamp(1rem, 1.5vw, 1.15rem);
  line-height: 1.55;
  color: var(--ink);
}
.dossie__sintomas li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 12px;
  width: 12px;
  height: 1px;
  background: var(--gold);
}
.dossie__sintomas li em {
  font-style: italic;
  color: var(--ink-muted);
}
.dossie__sintomas li strong {
  color: var(--bg-deeper);
  font-weight: 600;
}

/* D02 — callout detail */
.dossie__problema-callout-detail {
  margin-top: 12px;
  font-size: 0.95rem;
  color: var(--ink-muted);
}

/* D03 — checklist de identificação */
.virada__checklist {
  background: var(--bg-2);
  border: 1px solid rgba(184,146,74,0.18);
  border-radius: 10px;
  padding: 28px 32px;
  margin: 36px 0;
}
.virada__checklist-lead {
  font-family: var(--serif);
  font-size: 1.15rem;
  color: var(--bg-deep);
  margin: 0 0 16px;
  font-weight: 500;
}
.virada__checklist ul {
  list-style: none;
  padding: 0;
  margin: 0 0 18px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.virada__checklist li {
  position: relative;
  padding-left: 26px;
  line-height: 1.5;
}
.virada__checklist li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 6px;
  width: 14px;
  height: 14px;
  border: 1.5px solid var(--gold);
  border-radius: 3px;
}
.virada__checklist-close {
  margin: 0;
  font-style: italic;
  color: var(--gold-deep);
  font-size: 0.95rem;
}

/* D03 — bloco de citações de pesquisa */
.virada__quotes {
  margin: 36px 0;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.virada__quotes blockquote {
  font-family: var(--serif);
  font-size: clamp(1.1rem, 2vw, 1.4rem);
  line-height: 1.4;
  color: var(--bg-deep);
  margin: 0;
  padding: 0 0 0 20px;
  border-left: 2px solid var(--gold-2);
}
.virada__quotes blockquote em {
  font-style: italic;
}

/* D05 — Big Idea */
.bigidea {
  background: var(--bg-2);
  padding: 120px 0;
  text-align: center;
  border-top: 1px solid rgba(184,146,74,0.12);
  border-bottom: 1px solid rgba(184,146,74,0.12);
}
.bigidea__inner {
  max-width: 760px;
  margin: 0 auto;
}
.bigidea__title {
  font-size: clamp(2rem, 3.6vw, 3rem);
  line-height: 1.15;
  color: var(--bg-deep);
  margin: 24px 0 36px;
}
.bigidea__title-soft {
  display: block;
  margin-top: 8px;
  font-size: 0.85em;
  color: var(--ink-muted);
}
.bigidea__punch {
  font-family: var(--serif);
  font-size: clamp(1.4rem, 2.6vw, 2rem);
  line-height: 1.3;
  color: var(--gold-deep);
  font-style: italic;
  margin: 0 auto 40px;
  max-width: 30ch;
}
.bigidea__body {
  text-align: left;
  max-width: 60ch;
  margin: 0 auto;
}
.bigidea__body p {
  font-size: clamp(1rem, 1.5vw, 1.1rem);
  line-height: 1.65;
  color: var(--ink);
  margin: 0 0 18px;
}
.bigidea__close {
  font-family: var(--serif);
  text-align: center;
  margin: 32px auto 0 !important;
  max-width: 38ch;
  font-size: clamp(1.45rem, 2.45vw, 2.25rem);
  line-height: 1.28;
  letter-spacing: -0.012em;
  color: var(--bg-deep);
  font-weight: 600;
}
.bigidea__close em {
  color: var(--gold-deep);
  font-style: italic;
  font-weight: 400;
}
.bigidea__lista {
  list-style: none;
  padding: 0;
  margin: 0 auto 44px;
  max-width: 56ch;
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.bigidea__lista li {
  position: relative;
  padding: 16px 22px 16px 52px;
  background: var(--bg);
  border-radius: 12px;
  border: 1px solid rgba(184,146,74,0.16);
  font-family: var(--serif);
  font-size: clamp(1.05rem, 1.6vw, 1.2rem);
  line-height: 1.45;
  color: var(--ink);
}
.bigidea__lista li::before {
  content: "✓";
  position: absolute;
  left: 18px;
  top: 50%;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gold-deep);
  font-weight: 700;
  font-size: 14px;
}
.bigidea__lista li strong {
  color: var(--gold-deep);
  font-weight: 600;
}
.bigidea__punch--soft {
  color: var(--bg-deep);
  font-style: normal;
  font-size: clamp(1.2rem, 2vw, 1.6rem);
  margin-bottom: 12px;
}

/* Price card · variant sem valores individuais */
.price-card__ledger--items-only .price-card__row {
  justify-content: flex-start;
}
.price-card__ledger--items-only .price-card__row .l {
  flex: 1;
}

/* D02 — Se hoje você (identificação) */
.se-hoje {
  padding: 120px 0;
  background: var(--bg);
}
.se-hoje__inner {
  max-width: 760px;
  margin: 0 auto;
}
.se-hoje__title {
  font-size: clamp(2rem, 3.6vw, 2.8rem);
  line-height: 1.15;
  color: var(--bg-deep);
  text-align: center;
  margin: 0 0 56px;
  letter-spacing: -0.01em;
}
.se-hoje__lista {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 18px;
  counter-reset: se-hoje;
}
.se-hoje__lista li {
  display: grid;
  grid-template-columns: 56px 1fr;
  align-items: start;
  gap: 24px;
  padding: 24px 28px;
  background: var(--bg-2);
  border-radius: 14px;
  border: 1px solid rgba(184,146,74,0.18);
  transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease;
}
.se-hoje__lista li:hover {
  transform: translateY(-2px);
  border-color: rgba(184,146,74,0.35);
  box-shadow: 0 18px 40px -28px rgba(43,51,31,0.25);
}
.se-hoje__num {
  font-family: var(--sans);
  font-size: 28px;
  font-weight: 300;
  color: var(--gold-deep);
  letter-spacing: 0.02em;
  line-height: 1;
  align-self: center;
}
.se-hoje__lista li p {
  margin: 0;
  font-family: var(--serif);
  font-size: clamp(1.05rem, 1.6vw, 1.2rem);
  line-height: 1.5;
  color: var(--ink);
}
.se-hoje__lista li p strong {
  color: var(--bg-deep);
  font-weight: 600;
}

@media (max-width: 768px) {
  .se-hoje { padding: 80px 0; }
  .se-hoje__title { margin-bottom: 36px; }
  .se-hoje__lista { gap: 14px; }
  .se-hoje__lista li {
    grid-template-columns: 40px 1fr;
    gap: 16px;
    padding: 20px 22px;
  }
  .se-hoje__num { font-size: 22px; }
}

/* D03 — ciclo (lista pra sair desse ciclo) */
.virada__ciclo {
  background: var(--bg-2);
  border: 1px solid rgba(184,146,74,0.18);
  border-radius: 10px;
  padding: 28px 32px;
  margin: 36px 0;
}
.virada__ciclo-lead {
  font-family: var(--serif);
  font-size: 1.15rem;
  color: var(--bg-deep);
  margin: 0 0 16px;
  font-weight: 500;
}
.virada__ciclo ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.virada__ciclo li {
  position: relative;
  padding-left: 26px;
  line-height: 1.5;
  font-size: 1rem;
  color: var(--ink);
}
.virada__ciclo li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--gold-deep);
  font-weight: 700;
}
.virada__ciclo li strong {
  color: var(--gold-deep);
  font-weight: 600;
}
.virada__close-sub {
  display: block;
  margin-top: 12px;
  font-family: var(--sans);
  font-size: 0.95rem;
  font-style: normal;
  color: var(--ink-muted);
  font-weight: 400;
}

/* D03 — redesign visual, mantendo a copy original */
.virada {
  padding: clamp(88px, 9vw, 132px) 0;
  background:
    radial-gradient(ellipse at 85% 18%, rgba(184,146,74,0.08), transparent 42%),
    linear-gradient(180deg, #f6f1e8 0%, #efe8dc 100%);
  overflow: hidden;
}

.virada::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(61,74,48,0.035) 1px, transparent 1px),
    linear-gradient(180deg, rgba(184,146,74,0.04) 1px, transparent 1px);
  background-size: 64px 64px;
  -webkit-mask-image: radial-gradient(ellipse at 70% 45%, rgba(0,0,0,0.7), transparent 68%);
  mask-image: radial-gradient(ellipse at 70% 45%, rgba(0,0,0,0.7), transparent 68%);
  pointer-events: none;
}

.virada__inner {
  max-width: min(1120px, 92vw);
  position: relative;
  z-index: 1;
  text-align: center;
}

.virada__title {
  max-width: none;
  margin: 0 auto 18px;
  font-size: clamp(2.25rem, 3.25vw, 3.05rem);
  line-height: 1.05;
  letter-spacing: -0.018em;
  color: var(--bg-deeper);
  white-space: nowrap;
}

.virada__title em {
  color: var(--gold-deep);
  font-weight: 350;
}

.virada__body {
  display: grid;
  gap: clamp(34px, 4.4vw, 58px);
}

.virada__body p {
  margin: 0;
}

.virada__intro {
  max-width: none !important;
  margin-inline: auto !important;
  font-size: clamp(1rem, 1.18vw, 1.12rem) !important;
  line-height: 1.38 !important;
  color: var(--ink-muted) !important;
  letter-spacing: 0;
  white-space: nowrap;
}

.virada__intro strong {
  position: relative;
  color: var(--bg-deeper);
  font-weight: 600;
  white-space: nowrap;
}

.virada__intro strong::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -0.08em;
  height: 0.08em;
  background: var(--gold-deep);
  opacity: 0.75;
}

.virada__principio {
  position: relative;
  max-width: none !important;
  margin: 10px 0 0 !important;
  padding: clamp(42px, 5vw, 68px) clamp(34px, 6vw, 86px) !important;
  border: 0 !important;
  border-radius: 16px;
  background:
    linear-gradient(145deg, rgba(31,55,29,0.98), rgba(19,42,23,0.98)),
    var(--bg-deeper);
  box-shadow: 0 26px 70px -44px rgba(20,38,21,0.55);
  overflow: hidden;
}

.virada__principio::before {
  content: "“";
  position: absolute;
  left: clamp(22px, 4vw, 46px);
  top: -8px;
  font-family: var(--display);
  font-size: clamp(7rem, 13vw, 11rem);
  line-height: 1;
  color: rgba(107,122,84,0.46);
  pointer-events: none;
}

.virada__principio::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(212,176,114,0.08) 1px, transparent 1px),
    linear-gradient(180deg, rgba(242,236,220,0.045) 1px, transparent 1px);
  background-size: 42px 42px;
  mask-image: radial-gradient(ellipse at 58% 50%, rgba(0,0,0,0.6), transparent 72%);
  pointer-events: none;
}

.virada__principio em {
  position: relative;
  z-index: 1;
  display: block;
  max-width: 36ch;
  margin-inline: auto;
  font-size: clamp(1.65rem, 3vw, 2.35rem);
  line-height: 1.55;
  color: #f5e9cf;
  font-weight: 500;
}

.virada__fear {
  max-width: none !important;
  padding: 2px 0 2px clamp(22px, 3vw, 36px);
  border-left: 4px solid var(--gold-2);
  font-size: clamp(1.15rem, 1.8vw, 1.45rem) !important;
  line-height: 1.72 !important;
  color: var(--ink) !important;
}

.virada__ciclo {
  margin: 0;
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
}

.virada__ciclo-lead {
  margin: 0 0 22px !important;
  font-family: var(--sans);
  font-size: clamp(0.92rem, 1.2vw, 1.08rem);
  line-height: 1.25;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold-deep);
  font-weight: 500;
}

.virada__ciclo ul {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(18px, 2.2vw, 28px);
}

.virada__ciclo li {
  min-height: 180px;
  padding: 74px clamp(22px, 2.6vw, 34px) 28px;
  border: 1px solid rgba(140,107,42,0.22);
  border-radius: 14px;
  background: rgba(246,241,232,0.58);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.46);
  color: var(--ink-muted);
  font-size: clamp(1rem, 1.35vw, 1.16rem);
  line-height: 1.52;
}

.virada__ciclo li::before {
  top: 28px;
  left: clamp(22px, 2.6vw, 34px);
  width: 24px;
  height: 24px;
  color: var(--gold-deep);
  font-size: 0;
  background-color: currentColor;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: 24px 24px;
  mask-size: 24px 24px;
}

.virada__ciclo li:nth-child(1)::before {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M12 5c5.5 0 9 6 9 7s-3.5 7-9 7-9-6-9-7 3.5-7 9-7Zm0 2C8.4 7 5.7 10.2 5.1 12c.6 1.8 3.3 5 6.9 5s6.3-3.2 6.9-5C18.3 10.2 15.6 7 12 7Zm0 2.5A2.5 2.5 0 1 1 12 14a2.5 2.5 0 0 1 0-5Z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M12 5c5.5 0 9 6 9 7s-3.5 7-9 7-9-6-9-7 3.5-7 9-7Zm0 2C8.4 7 5.7 10.2 5.1 12c.6 1.8 3.3 5 6.9 5s6.3-3.2 6.9-5C18.3 10.2 15.6 7 12 7Zm0 2.5A2.5 2.5 0 1 1 12 14a2.5 2.5 0 0 1 0-5Z'/%3E%3C/svg%3E");
}

.virada__ciclo li:nth-child(2)::before {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M7 20H4a2 2 0 0 1-2-2v-5a2 2 0 0 1 2-2h3V8a2 2 0 0 1 2-2h3V4a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2v16H7Zm0-7H4v5h3v-5Zm5-5H9v10h3V8Zm6-4h-4v14h4V4Z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M7 20H4a2 2 0 0 1-2-2v-5a2 2 0 0 1 2-2h3V8a2 2 0 0 1 2-2h3V4a2 2 0 0 1 2-2h4a2 2 0 0 1 2 2v16H7Zm0-7H4v5h3v-5Zm5-5H9v10h3V8Zm6-4h-4v14h4V4Z'/%3E%3C/svg%3E");
}

.virada__ciclo li:nth-child(3)::before {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M12 2 20 5.5V11c0 5.1-3.3 9.4-8 11-4.7-1.6-8-5.9-8-11V5.5L12 2Zm0 2.2L6 6.8V11c0 3.9 2.4 7.3 6 8.8 3.6-1.5 6-4.9 6-8.8V6.8l-6-2.6Z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='black' d='M12 2 20 5.5V11c0 5.1-3.3 9.4-8 11-4.7-1.6-8-5.9-8-11V5.5L12 2Zm0 2.2L6 6.8V11c0 3.9 2.4 7.3 6 8.8 3.6-1.5 6-4.9 6-8.8V6.8l-6-2.6Z'/%3E%3C/svg%3E");
}

.virada__ciclo li strong {
  display: block;
  margin-bottom: 8px;
  color: var(--bg-deeper);
  font-size: clamp(1.2rem, 1.7vw, 1.42rem);
  line-height: 1.1;
  font-weight: 600;
}

.virada__close {
  position: relative;
  margin: 6px 0 0;
  padding: clamp(34px, 4.6vw, 58px) clamp(30px, 5vw, 64px);
  border-radius: 18px;
  border: 1px solid rgba(212,176,114,0.22);
  background:
    radial-gradient(ellipse at 88% 20%, rgba(212,176,114,0.12), transparent 42%),
    linear-gradient(145deg, #244421, #132a17);
  color: #f5e9cf;
  box-shadow: 0 28px 80px -52px rgba(20,38,21,0.72);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  grid-template-areas:
    "main cta"
    "sub cta";
  align-items: center;
  gap: 12px clamp(28px, 5vw, 64px);
  text-align: left;
}

.virada__close::before {
  content: "";
  position: absolute;
  inset: 18px;
  border: 1px solid rgba(242,236,220,0.08);
  border-radius: 12px;
  pointer-events: none;
}

.virada__close em {
  color: var(--gold-2);
}

.virada__close-main {
  grid-area: main;
  display: block;
  font-family: var(--display);
  font-size: clamp(1.45rem, 2.3vw, 2.15rem);
  line-height: 1.22;
  color: #f5e9cf;
  letter-spacing: -0.012em;
}

.virada__close-sub {
  grid-area: sub;
  display: block;
  max-width: 43ch;
  margin-top: 0;
  color: rgba(242,236,220,0.66);
  font-size: clamp(1rem, 1.35vw, 1.14rem);
  line-height: 1.55;
}

.virada__close-cta {
  grid-area: cta;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  min-width: 178px;
  padding: 16px 22px;
  border: 1px solid rgba(242,236,220,0.32);
  border-radius: var(--radius-pill);
  color: #f5e9cf;
  font-family: var(--sans);
  font-size: 0.92rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  transition: transform 0.25s ease, border-color 0.25s ease, background 0.25s ease;
}

.virada__close-cta .btn__arrow {
  width: 22px;
  background: var(--gold-2);
}

.virada__close-cta .btn__arrow::after {
  border-color: var(--gold-2);
}

.virada__close-cta:hover {
  transform: translateY(-2px);
  border-color: rgba(212,176,114,0.72);
  background: rgba(242,236,220,0.06);
}

@media (max-width: 880px) {
  .virada {
    padding: 76px 0 84px;
  }

  .virada__title {
    font-size: clamp(2rem, 8vw, 2.75rem);
    line-height: 1.06;
    white-space: normal;
  }

  .virada__intro {
    font-size: clamp(1rem, 4.2vw, 1.14rem) !important;
    line-height: 1.38 !important;
    white-space: normal;
  }

  .virada__principio {
    padding: 38px 24px !important;
    border-radius: 14px;
  }

  .virada__principio::before {
    left: 18px;
    top: -2px;
    font-size: 7rem;
  }

  .virada__principio em {
    max-width: 24ch;
    font-size: clamp(1.32rem, 6vw, 1.82rem);
    line-height: 1.52;
  }

  .virada__ciclo ul {
    grid-template-columns: 1fr;
  }

  .virada__ciclo li {
    min-height: 0;
    padding: 64px 22px 24px;
  }

  .virada__close {
    padding: 36px 26px;
    grid-template-columns: 1fr;
    grid-template-areas:
      "main"
      "sub"
      "cta";
    text-align: center;
    justify-items: center;
  }

  .virada__close-sub {
    max-width: 34ch;
  }

  .virada__close-cta {
    margin-top: 10px;
  }
}

/* D07 · Infográficos (donut + linha) */
.infografico {
  position: relative;
  width: 100%;
  max-width: 360px;
  margin: 0 auto;
  padding: 28px;
  background: var(--bg);
  border-radius: 16px;
  border: 1px solid rgba(184,146,74,0.16);
  box-shadow: 0 24px 60px -32px rgba(43,51,31,0.18);
}
.infografico svg {
  width: 100%;
  height: auto;
  display: block;
}
.infografico__legenda {
  list-style: none;
  padding: 16px 0 0;
  margin: 16px 0 0;
  border-top: 1px solid rgba(184,146,74,0.16);
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px 16px;
  font-family: var(--sans);
  font-size: 12px;
  color: var(--ink-muted);
  letter-spacing: 0.01em;
}
.infografico__legenda li {
  display: flex;
  align-items: center;
  gap: 8px;
}
.infografico__legenda li span {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 2px;
  flex: none;
}
.infografico--linha {
  padding: 32px 28px 20px;
}

@media (max-width: 768px) {
  .infografico { padding: 22px 18px; }
  .virada__ciclo { padding: 22px 22px; }
  .infografico__legenda { grid-template-columns: 1fr 1fr; font-size: 11px; }
}

/* D06 — Existe uma ordem */
.ordem {
  padding: 120px 0 100px;
  background: var(--bg);
}
.ordem__inner {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
}
.ordem__title {
  font-size: clamp(2rem, 3.6vw, 3rem);
  line-height: 1.15;
  color: var(--bg-deep);
  margin: 20px 0 28px;
}
.ordem__sequence {
  font-family: var(--serif);
  font-size: clamp(1.15rem, 2vw, 1.4rem);
  line-height: 1.5;
  color: var(--bg-deep);
  margin: 0 auto 36px;
  max-width: 48ch;
}
.ordem__sequence strong {
  color: var(--gold-deep);
  font-weight: 600;
}
.ordem__body {
  text-align: left;
  max-width: 56ch;
  margin: 0 auto 36px;
}
.ordem__body p {
  font-size: 1rem;
  line-height: 1.65;
  color: var(--ink);
  margin: 0 0 18px;
}
.ordem__inversao {
  background: var(--bg-2);
  border-radius: 10px;
  padding: 28px 32px;
  text-align: left;
  max-width: 56ch;
  margin: 0 auto 28px;
}
.ordem__inversao-lead {
  font-family: var(--serif);
  font-size: 1.1rem;
  color: var(--bg-deep);
  margin: 0 0 14px;
}
.ordem__inversao ul {
  list-style: none;
  padding: 0;
  margin: 0 0 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.ordem__inversao li {
  position: relative;
  padding-left: 22px;
  font-size: 0.98rem;
  line-height: 1.5;
}
.ordem__inversao li::before {
  content: "✕";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--gold);
  font-weight: 600;
}
.ordem__inversao-result {
  margin: 0;
  color: var(--ink-muted);
  font-style: italic;
}
.ordem__close {
  font-family: var(--serif);
  font-size: clamp(1.2rem, 2vw, 1.5rem);
  color: var(--bg-deep);
  margin: 0 auto;
  max-width: 40ch;
}
.ordem__close em {
  color: var(--gold-deep);
  font-style: italic;
}

/* "Na prática" — rotina */
.rotina {
  margin: 60px auto;
  padding: 36px 32px;
  max-width: 620px;
  text-align: center;
  background: var(--bg-2);
  border-radius: 10px;
  border: 1px solid rgba(184,146,74,0.16);
}
.rotina__text {
  font-family: var(--serif);
  font-size: clamp(1rem, 1.5vw, 1.15rem);
  line-height: 1.55;
  color: var(--ink);
  margin: 16px 0 14px;
}
.rotina__punch {
  font-family: var(--serif);
  font-size: clamp(1.05rem, 1.6vw, 1.2rem);
  font-style: italic;
  color: var(--gold-deep);
  margin: 0;
}

/* D15 — Quebra de objeções */
.objecoes {
  padding: 100px 0;
  background: var(--bg);
}
.objecoes__head {
  text-align: center;
  max-width: 680px;
  margin: 0 auto 56px;
}
.objecoes__title {
  font-size: clamp(2rem, 3.6vw, 3rem);
  line-height: 1.15;
  color: var(--bg-deep);
  margin-top: 16px;
}
.objecoes__list {
  display: flex;
  flex-direction: column;
  gap: 32px;
  max-width: 760px;
  margin: 0 auto;
}
.objecao {
  background: var(--bg-2);
  border-radius: 10px;
  border: 1px solid rgba(184,146,74,0.14);
  padding: 32px 36px;
}
.objecao__quote {
  font-family: var(--serif);
  font-size: clamp(1.15rem, 2vw, 1.4rem);
  font-style: italic;
  color: var(--gold-deep);
  margin: 0 0 18px;
  line-height: 1.35;
}
.objecao p {
  font-size: clamp(1rem, 1.4vw, 1.05rem);
  line-height: 1.6;
  color: var(--ink);
  margin: 0 0 14px;
}
.objecao p:last-child { margin-bottom: 0; }
.objecao__close {
  color: var(--bg-deep) !important;
  font-style: italic;
}
.objecao__close em {
  font-style: italic;
}
.objecao__close strong {
  color: var(--bg-deeper);
  font-weight: 600;
}

@media (max-width: 768px) {
  .bigidea, .ordem, .objecoes { padding: 80px 0; }
  .virada__checklist, .ordem__inversao, .objecao { padding: 24px 22px; }
  .rotina { padding: 28px 22px; margin: 48px auto; }
  .dossie__problema-title--pergunta { font-size: 38px; }
}
