/* ============================================================
   OdontoFlow · Landing v3 · overlay sheet
   ------------------------------------------------------------
   Adições e refinamentos sobre styles.css para a versão v3
   (9 seções, Diagnóstico gratuito, novo bloco de Assistentes).
   ============================================================ */

/* ---- Microcopy de CTA (Gratuito · 1 hora · direto comigo) ---- */
.cta-micro {
  display: block;
  margin-top: var(--space-3);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-300);
  line-height: 1.6;
  max-width: 44ch;
}
.cta-micro .dot { color: var(--paper-200); padding: 0 6px; }
.section--dark .cta-micro { color: var(--paper-200); }
.section--dark .cta-micro .dot { color: var(--ink-500); }

/* ---- Layout do par de CTAs do Hero / Convite final ---- */
.cta-pair {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  margin-top: var(--space-8);
}
.cta-pair .cta { width: 100%; }
@container vp (min-width: 1024px) {
  .cta-pair .cta { width: auto; }
}

/* ============================================================
   HERO v3 — vídeo à direita no desktop
   ============================================================ */
.hero-v3 .hero__main {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
  align-items: start;
}
.hero-v3 .hero__headline {
  max-width: 18ch;
}
.hero-v3 .hero__sub {
  margin-top: var(--space-6);
}
.hero-v3 .hero__video {
  margin-top: 0;
  aspect-ratio: 16 / 9;
  width: 100%;
  background: var(--paper-100);
  border: 1px solid var(--paper-200);
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-4);
}
.hero-v3 .hero__video::after {
  content: "";
  position: absolute;
  inset: 12px;
  border: 1px dashed var(--paper-200);
  pointer-events: none;
}
.hero-v3 .hero__video-tag {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-300);
  max-width: 28ch;
  text-align: center;
  line-height: 1.6;
  padding: 0 var(--space-8);
  z-index: 1;
}
@container vp (min-width: 1024px) {
  .hero-v3 .hero__main {
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
    gap: var(--space-16);
    align-items: center;
  }
  .hero-v3 .hero__copy { padding-right: var(--space-8); }
}

/* ============================================================
   HERO v3 · modo sem vídeo (temporário)
   ------------------------------------------------------------
   Layout coluna única centralizada, ~720px de largura útil,
   respiração vertical generosa. Para reativar o vídeo, basta
   remover a classe `.hero--no-video` do <section>. O markup
   do vídeo permanece intacto, apenas com display: none aqui.
   ============================================================ */
.hero-v3.hero--no-video {
  padding-top: 96px;
  padding-bottom: 96px;
}
@container vp (min-width: 1024px) {
  .hero-v3.hero--no-video {
    padding-top: 140px;
    padding-bottom: 140px;
  }
}
.hero-v3.hero--no-video .hero__main {
  display: block;
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
  padding-top: var(--space-12);
}
.hero-v3.hero--no-video .hero__copy {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-right: 0;
  gap: var(--space-6);
}
.hero-v3.hero--no-video .hero__copy .kicker { text-align: center; }
.hero-v3.hero--no-video .hero__headline {
  max-width: 18ch;
  margin-left: auto;
  margin-right: auto;
}
.hero-v3.hero--no-video .hero__sub {
  max-width: 56ch;
  margin: 0 auto;
  text-align: center;
}
.hero-v3.hero--no-video .cta-pair {
  justify-content: center;
  margin-top: var(--space-8);
}
.hero-v3.hero--no-video .cta-micro {
  text-align: center;
  max-width: 60ch;
  margin-left: auto;
  margin-right: auto;
}
/* Esconde o placeholder do vídeo sem remover o nó do DOM */
.hero-v3.hero--no-video .hero__video { display: none; }

/* ============================================================
   FAIXA DE POSICIONAMENTO (entre Hero e Seção 02)
   ------------------------------------------------------------
   Linha única, fundo levemente diferenciado, altura modesta.
   Sem botão, sem ícone, sem decoração — apenas o texto.
   ============================================================ */
.positioning-strip {
  background: var(--paper-100);
  border-top: 1px solid var(--paper-200);
  border-bottom: 1px solid var(--paper-200);
  padding: var(--space-6) var(--container-pad);
}
.positioning-strip__inner {
  max-width: var(--container-max);
  margin: 0 auto;
  text-align: center;
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 17px;
  line-height: 1.4;
  color: var(--ink-700);
  letter-spacing: -0.005em;
  text-wrap: balance;
}
.positioning-strip__inner em {
  font-style: italic;
  color: var(--accent-deep);
}
@container vp (min-width: 768px) {
  .positioning-strip { padding-top: var(--space-8); padding-bottom: var(--space-8); }
  .positioning-strip__inner { font-size: 20px; }
}
@container vp (min-width: 1024px) {
  .positioning-strip__inner { font-size: 22px; }
}

/* ============================================================
   Bandeira de fechamento de seção (linha-âncora simples)
   ============================================================ */
.section-closer {
  margin-top: var(--space-16);
  padding-top: var(--space-8);
  border-top: 1px solid var(--paper-200);
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 22px;
  line-height: 1.35;
  color: var(--ink-900);
  max-width: 32ch;
}
@container vp (min-width: 1024px) {
  .section-closer { font-size: 28px; }
}

/* ============================================================
   SEÇÃO 05 — Assistentes virtuais (NEW)
   ============================================================ */
.assistants {
  background: var(--paper-50);
}
.assistants__head {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  max-width: 64ch;
  margin-bottom: var(--space-16);
}
.assistants__head .h1-serif { max-width: 22ch; }
.assistants__head .body { color: var(--ink-500); }

/* Bloco 1: 4 assistentes em grid 2x2 */
.assistants__block-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-300);
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  margin-bottom: var(--space-8);
}
.assistants__block-label::before {
  content: "";
  width: 24px;
  height: 1px;
  background: var(--ink-300);
  display: inline-block;
}

.assistants__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}
/* v3 · Com chat mockup ao lado, mantemos 1 coluna por card pra acomodar
   conforto de leitura do chat (~320px) sem espremer o texto. */
.assistants__grid { grid-template-columns: 1fr; }

/* Card padrão segue como estava */
.assistant-card {
  background: var(--paper-100);
  border: 1px solid var(--paper-200);
  padding: var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  position: relative;
  min-height: 280px;
}

/* Card com chat — layout interno em 2 colunas no desktop */
.assistant-card--chat {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  min-height: auto;
}
.assistant-card__main {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
@container vp (min-width: 760px) {
  .assistant-card--chat {
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
    gap: var(--space-12);
    align-items: center;
    padding: var(--space-12);
  }
}
@container vp (min-width: 1024px) {
  .assistant-card--chat {
    grid-template-columns: minmax(0, 1fr) 360px;
  }
}
.assistant-card__num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--accent-deep);
  font-weight: 500;
}
.assistant-card__title {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: 28px;
  line-height: 1.1;
  letter-spacing: -0.01em;
  color: var(--ink-900);
}
.assistant-card__title em {
  font-style: italic;
  color: var(--accent-deep);
}
.assistant-card__desc {
  font-size: 15px;
  line-height: 1.6;
  color: var(--ink-500);
  flex: 1;
}
.assistant-card__desc strong {
  color: var(--ink-900);
  font-weight: 500;
}
.assistant-card__tag {
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid var(--paper-200);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-300);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.assistant-card__tag .dot {
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--guarantee);
}
@container vp (min-width: 1024px) {
  .assistant-card__title { font-size: 32px; }
  .assistant-card { padding: var(--space-12) var(--space-8); }
}

/* ============================================================
   Chat mockup · WhatsApp estilizado (sem chrome do app)
   ------------------------------------------------------------
   - IA (out) à direita, bubble sage discreta
   - Paciente (in) à esquerda, bubble branca neutra
   - Sem header de contato, sem avatar, sem "online", sem emoji
   - Cantos arredondados com "tail" no canto inferior do remetente
   ============================================================ */
.chat {
  --chat-bg: #F4EFE3;
  --chat-in-bg: #FFFFFF;
  --chat-in-border: #E2DBC8;
  --chat-out-bg: #DCE8DA;
  --chat-out-border: #C3D6C0;
  background: var(--chat-bg);
  border: 1px solid var(--paper-200);
  border-radius: 18px;
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  width: 100%;
  max-width: 340px;
  justify-self: center;
  box-shadow: 0 1px 0 rgba(14,26,46,0.04), 0 8px 24px rgba(14,26,46,0.06);
}
@container vp (min-width: 760px) {
  .chat { justify-self: end; }
}

.chat__msg {
  display: inline-flex;
  flex-direction: column;
  max-width: 84%;
  padding: 7px 10px 5px;
  border-radius: 14px;
  position: relative;
}
.chat__msg--in {
  align-self: flex-start;
  background: var(--chat-in-bg);
  border: 1px solid var(--chat-in-border);
  border-bottom-left-radius: 4px;
}
.chat__msg--out {
  align-self: flex-end;
  background: var(--chat-out-bg);
  border: 1px solid var(--chat-out-border);
  border-bottom-right-radius: 4px;
}
/* Agrupa bubbles consecutivas do mesmo remetente — espaçamento menor */
.chat__msg + .chat__msg--in { margin-top: 2px; }
.chat__msg--out + .chat__msg--out { margin-top: 2px; }
.chat__msg--in + .chat__msg--out,
.chat__msg--out + .chat__msg--in { margin-top: 4px; }

.chat__text {
  font-family: var(--font-sans);
  font-size: 13px;
  line-height: 1.42;
  color: var(--ink-900);
  margin: 0;
  letter-spacing: -0.005em;
  text-wrap: pretty;
}
.chat__time {
  align-self: flex-end;
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.04em;
  color: var(--ink-300);
  margin-top: 2px;
  line-height: 1;
}

/* Bloco 2: Analista (banda escura, full-width) */
.analyst-band {
  margin-top: var(--space-16);
  background: var(--ink-900);
  color: var(--paper-50);
  padding: var(--space-16) var(--space-8);
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
  position: relative;
  border-radius: 2px;
}
@container vp (min-width: 900px) {
  .analyst-band {
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
    padding: var(--space-24) var(--space-16);
    gap: var(--space-16);
    align-items: start;
  }
}
.analyst-band__left {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}
.analyst-band .kicker { color: var(--accent-gold); }
.analyst-band__num {
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.14em;
  color: var(--accent-gold);
}
.analyst-band__title {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: 26px;
  line-height: 1.25;
  letter-spacing: -0.005em;
  color: var(--paper-50);
  max-width: 26ch;
  text-wrap: balance;
}
.analyst-band__title em {
  font-style: italic;
  color: var(--accent-gold);
}
@container vp (min-width: 1024px) {
  .analyst-band__title { font-size: 32px; max-width: 22ch; }
}
.analyst-band__right {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}
.analyst-band__lede {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 22px;
  line-height: 1.4;
  color: var(--paper-50);
  max-width: 32ch;
}
.analyst-band__body {
  font-size: 16px;
  line-height: 1.65;
  color: var(--paper-200);
  max-width: 46ch;
}
.analyst-band__body strong {
  color: var(--paper-50);
  font-weight: 500;
}

/* Mock visual: card "report on WhatsApp" */
.analyst-report {
  margin-top: var(--space-8);
  background: rgba(244,239,227,0.04);
  border: 1px solid rgba(244,239,227,0.12);
  padding: var(--space-6);
  border-radius: 2px;
  font-family: var(--font-mono);
  font-size: 12px;
  line-height: 1.7;
  color: var(--paper-200);
  max-width: 42ch;
}
.analyst-report__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--paper-200);
  margin-bottom: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px dashed rgba(244,239,227,0.18);
}
.analyst-report__head .time {
  color: var(--ink-300);
  letter-spacing: 0.12em;
  text-transform: none;
  font-size: 10px;
}

/* Insight block — topo, destaque */
.analyst-report__insight {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: var(--space-3) 0 var(--space-5);
  border-bottom: 1px dashed rgba(244,239,227,0.18);
  margin-bottom: var(--space-4);
}
.analyst-report__insight-label {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent-gold);
}
.analyst-report__insight-title {
  font-family: var(--font-sans);
  font-size: 17px;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: -0.005em;
  color: var(--paper-50);
}
.analyst-report__insight-context {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 400;
  line-height: 1.55;
  color: var(--paper-200);
  letter-spacing: 0;
  text-transform: none;
  margin-top: 2px;
}

/* Métricas — suporte, abaixo */
.analyst-report__metrics {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.analyst-report__row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-3);
  padding: 4px 0;
  font-size: 11px;
  color: var(--ink-300);
}
.analyst-report__row .val {
  color: var(--paper-200);
  font-variant-numeric: tabular-nums;
  font-weight: 500;
}

/* Bloco 3: Conforme sua clínica evolui */
.grow-block {
  margin-top: var(--space-16);
  padding-top: var(--space-12);
  border-top: 1px solid var(--paper-200);
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
}
@container vp (min-width: 900px) {
  .grow-block {
    grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
    gap: var(--space-16);
    align-items: start;
  }
}
.grow-block__title {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: 28px;
  line-height: 1.15;
  letter-spacing: -0.005em;
  color: var(--ink-900);
  max-width: 18ch;
}
.grow-block__title em { font-style: italic; color: var(--accent-deep); }
@container vp (min-width: 1024px) {
  .grow-block__title { font-size: 36px; }
}
.grow-block__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  list-style: none;
  padding: 0;
}
.grow-block__list li {
  display: grid;
  grid-template-columns: 28px 1fr;
  align-items: baseline;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--paper-200);
  font-size: 16px;
  line-height: 1.5;
  color: var(--ink-700);
}
.grow-block__list li::before {
  content: "+";
  font-family: var(--font-mono);
  color: var(--accent-deep);
  font-size: 14px;
}
.grow-block__caption {
  margin-top: var(--space-6);
  font-family: var(--font-mono);
  font-size: 12px;
  line-height: 1.7;
  color: var(--ink-500);
  max-width: 56ch;
}
.grow-block__caption strong { color: var(--ink-900); font-weight: 500; }
.grow-block__caption em { font-style: italic; color: var(--accent-deep); }

/* ============================================================
   SEÇÃO 08 — Como começa (3 passos, sem timeline horizontal)
   ============================================================ */
.howto__head {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  max-width: 64ch;
  margin-bottom: var(--space-16);
}
.howto-steps {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  border-top: 1px solid var(--paper-200);
}
.howto-step {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-8);
  padding: var(--space-12) 0;
  border-bottom: 1px solid var(--paper-200);
  align-items: start;
}
@container vp (min-width: 900px) {
  .howto-step {
    grid-template-columns: 120px minmax(0, 1.2fr) minmax(0, 1fr);
    gap: var(--space-12);
    align-items: baseline;
  }
}
.howto-step__num {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.22em;
  color: var(--accent-deep);
  white-space: nowrap;
}
.howto-step__title {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: 28px;
  line-height: 1.15;
  letter-spacing: -0.005em;
  color: var(--ink-900);
  max-width: 22ch;
}
.howto-step__title em { font-style: italic; color: var(--accent-deep); }
@container vp (min-width: 1024px) {
  .howto-step__title { font-size: 36px; }
}
.howto-step__desc {
  font-size: 16px;
  line-height: 1.6;
  color: var(--ink-500);
  max-width: 44ch;
  margin-top: var(--space-4);
}
@container vp (min-width: 900px) {
  .howto-step__desc { margin-top: 0; }
}
.howto-step__desc strong { color: var(--ink-900); font-weight: 500; }

.howto-closer {
  margin-top: var(--space-12);
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 22px;
  line-height: 1.35;
  color: var(--ink-700);
  max-width: 38ch;
}
@container vp (min-width: 1024px) {
  .howto-closer { font-size: 28px; max-width: 44ch; }
}
.howto-closer strong {
  font-style: normal;
  font-weight: 500;
  color: var(--ink-900);
}

/* ============================================================
   SEÇÃO 06 — Tabela refinada
   ------------------------------------------------------------
   Coluna "Comigo" recebe destaque visual: fundo paper-100,
   borda à esquerda em accent-gold, header em ink-900.
   ============================================================ */
.compare-table-v3 {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
  table-layout: fixed;
  display: none;
}
@container vp (min-width: 900px) {
  .compare-table-v3 { display: table; }
}
.compare-table-v3 thead th {
  text-align: left;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 500;
  color: var(--ink-300);
  padding: var(--space-6) var(--space-6);
  border-bottom: 1px solid var(--paper-200);
  vertical-align: bottom;
}
.compare-table-v3 thead .col-mine {
  color: var(--ink-900);
  background: var(--paper-100);
  border-left: 1px solid var(--accent-gold);
  border-bottom-color: var(--accent-gold);
  position: relative;
}
.compare-table-v3 thead .col-mine::before {
  content: "★";
  display: inline-block;
  color: var(--accent-gold);
  margin-right: 8px;
  font-size: 10px;
}
.compare-table-v3 tbody td {
  padding: var(--space-6);
  vertical-align: top;
  border-bottom: 1px solid var(--paper-200);
  line-height: 1.55;
}
.compare-table-v3 td.criterion {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-700);
  font-weight: 500;
  width: 22%;
}
.compare-table-v3 td.saas {
  color: var(--ink-500);
  width: 36%;
}
.compare-table-v3 td.mine {
  width: 42%;
  background: var(--paper-100);
  border-left: 1px solid var(--accent-gold);
  color: var(--ink-900);
}
.compare-table-v3 td.mine strong { font-weight: 500; }
.compare-table-v3 tbody tr:last-child td { border-bottom: 0; }

/* ============================================================
   QUEM ESTÁ DO OUTRO LADO — versão Seção 03 (foto + texto)
   ============================================================ */
.who {
  background: var(--paper-100);
}
.who__layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
  align-items: start;
}
@container vp (min-width: 900px) {
  .who__layout {
    grid-template-columns: 280px minmax(0, 1fr);
    gap: var(--space-16);
  }
}
.who__portrait {
  position: relative;
  width: 100%;
  max-width: 280px;
  aspect-ratio: 4 / 5;
  background: var(--ink-700);
  overflow: hidden;
  border-radius: 2px;
}
.who__portrait img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.who__portrait__caption {
  position: absolute;
  right: 16px;
  bottom: 14px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--paper-50);
  z-index: 2;
  text-shadow: 0 1px 2px rgba(0,0,0,0.4);
  text-align: right;
}
.who__copy { display: flex; flex-direction: column; gap: var(--space-6); }
.who__copy .h1-serif { max-width: 22ch; color: var(--ink-900); }
.who__bio { font-size: 17px; line-height: 1.6; color: var(--ink-500); max-width: 60ch; }
.who__bio strong { color: var(--ink-900); font-weight: 500; }
.who__creds {
  margin-top: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding-top: var(--space-6);
  border-top: 1px solid var(--paper-200);
}
.who__creds-row {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: var(--space-3);
  font-size: 15px;
  line-height: 1.45;
  color: var(--ink-700);
  align-items: baseline;
}
.who__creds-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-300);
}
.who__closer {
  margin-top: var(--space-8);
  padding-top: var(--space-6);
  border-top: 1px solid var(--paper-200);
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 22px;
  line-height: 1.35;
  color: var(--ink-900);
  max-width: 36ch;
}
@container vp (min-width: 1024px) {
  .who__closer { font-size: 26px; }
}

/* ============================================================
   FINAL INVITE — Seção 09 (convite) banda escura
   ============================================================ */
.final-invite { background: var(--ink-900); color: var(--paper-50); }
.final-invite .h1-serif { color: var(--paper-50); max-width: 22ch; }
.final-invite .h1-serif em { color: var(--accent-gold); }
.final-invite__sub {
  font-family: var(--font-serif);
  font-size: 22px;
  line-height: 1.4;
  color: var(--paper-200);
  max-width: 38ch;
  margin-top: var(--space-6);
}
@container vp (min-width: 1024px) {
  .final-invite__sub { font-size: 26px; }
}
.final-invite .cta-micro { color: var(--paper-200); }
.final-invite .cta-micro .dot { color: var(--ink-500); }
.final-invite__horarios {
  margin-top: var(--space-8);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent-gold);
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.final-invite__horarios::before {
  content: "";
  display: inline-block;
  width: 24px;
  height: 1px;
  background: var(--accent-gold);
}

/* ============================================================
   FAQ — manter base, ajustar afastamento
   ============================================================ */
.cap-11__head .h1-serif { max-width: 24ch; }

/* ============================================================
   Hairline divider entre seções (opcional)
   ============================================================ */
.section + .section:not(.section--dark):not(.assistants):not(.who):not(.final-invite) {
  border-top: 1px solid var(--paper-200);
}

/* ---- top-line: micro-stripe que aparece sob a seção que vem depois de uma dark ---- */
.section--dark + .section { border-top: 0; }

/* ============================================================
   Footer · linha-base centralizada (v3)
   ============================================================ */
.footer-bottom {
  align-items: center;
  text-align: center;
}
@container vp (min-width: 1024px) {
  .footer-bottom { align-items: center; text-align: center; }
}

/* ============================================================
   Hero · menu desktop (v3) — número + descrição, padrão do mobile
   ------------------------------------------------------------
   - 5 itens descritivos + CTA pill
   - Número em peso leve / cor clara, descrição em peso médio
   - Separador "·" com leve respiração
   ============================================================ */
.hero__nav {
  gap: var(--space-6);
  align-items: baseline;
}
.hero__nav a {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.04em;
  font-weight: 500;
  text-transform: none;
  color: var(--ink-700);
  white-space: nowrap;
}
.hero__nav a .nav-num {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 400;
  color: var(--ink-300);
  letter-spacing: 0.12em;
}
.hero__nav a .nav-sep {
  color: var(--paper-200);
  font-weight: 400;
}
.hero__nav a:hover .nav-num { color: var(--ink-500); }
.hero__nav a:hover .nav-sep { color: var(--ink-300); }

/* Em viewports apertados (1024–1180), aperta gap e font pra caber */
@container vp (min-width: 1024px) and (max-width: 1180px) {
  .hero__nav { gap: var(--space-4); }
  .hero__nav a { font-size: 10.5px; }
  .hero__nav a .nav-num { font-size: 9.5px; }
}

/* ============================================================
   Hero topbar · FIXED no topo (desktop only)
   ------------------------------------------------------------
   - Sempre visível enquanto o usuário rola
   - Fundo translúcido com blur, hairline embaixo
   - Largura interna respeita o container max-width via
     padding viewport-aware (sem precisar de wrapper extra)
   - Mobile permanece inalterado (in-flow)
   ============================================================ */
@media (min-width: 1024px) {
  .hero__topbar {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
    margin-bottom: 0 !important;
    padding-top: 16px;
    padding-bottom: 16px;
    padding-left: max(var(--container-pad), calc((100vw - var(--container-max)) / 2));
    padding-right: max(var(--container-pad), calc((100vw - var(--container-max)) / 2));
    background: rgba(14, 26, 46, 0.88);
    backdrop-filter: blur(10px) saturate(140%);
    -webkit-backdrop-filter: blur(10px) saturate(140%);
    border-bottom: 1px solid var(--ink-500);
  }
  /* Offset de âncoras pra não esconderem atrás do topbar */
  html { scroll-padding-top: 88px; }
  /* O hero perdeu a altura da topbar do seu fluxo — adiciona um cushion
     pra manter a sensação de hero "centralizado verticalmente" */
  .hero-v3.hero--no-video { padding-top: 72px; }
}

/* ============================================================
   Topbar · paleta do rodapé (v3) — desktop + mobile
   ------------------------------------------------------------
   Mesma aesthetic do <footer>: fundo ink-900, wordmark serif 32px
   em paper-50 + accent-gold no em, hairlines em ink-500.
   ============================================================ */

/* Wordmark clicável (header + footer) — leva ao topo */
.hero__wordmark,
.hero__wordmark:link,
.hero__wordmark:visited,
.footer-brand__wordmark,
.footer-brand__wordmark:link,
.footer-brand__wordmark:visited {
  color: var(--paper-50);
}
.hero__wordmark,
.footer-brand__wordmark {
  cursor: pointer;
  transition: color 180ms ease;
  display: inline-block;
}
.hero__wordmark em,
.footer-brand__wordmark em { color: var(--accent-gold); }
.hero__wordmark:focus-visible,
.footer-brand__wordmark:focus-visible {
  outline: 2px solid var(--accent-gold);
  outline-offset: 4px;
  border-radius: 2px;
}
.hero__wordmark:hover em,
.footer-brand__wordmark:hover em {
  filter: brightness(1.1);
}
.hero__topbar {
  background: var(--ink-900);
  border-bottom: 1px solid var(--ink-500);
  color: var(--paper-200);
}
.hero__wordmark {
  font-family: var(--font-serif);
  font-size: 32px;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--paper-50);
}
.hero__wordmark em { font-style: italic; color: var(--accent-gold); }

/* Nav links — light on dark */
.hero__nav a { color: var(--paper-200); }
.hero__nav a .nav-num { color: #6a7385; }
.hero__nav a .nav-sep { color: var(--ink-500); }
.hero__nav a:hover { color: var(--paper-50); }
.hero__nav a:hover .nav-num { color: var(--paper-200); }
.hero__nav a:hover .nav-sep { color: var(--paper-200); }
/* Override do underline-from-below (vinha em ink-700) */
.hero__nav a::after { background: var(--accent-gold) !important; }

/* CTA pill no topbar */
.hero__topbar-cta {
  color: var(--paper-50);
  border-bottom-color: var(--paper-200);
}
.hero__topbar-cta:hover {
  color: var(--accent-gold);
  border-bottom-color: var(--accent-gold);
}

/* Hamburger (mobile) — barras visíveis sobre dark */
.hero__menu-toggle {
  border-color: var(--ink-500);
}
.hero__menu-toggle span { background: var(--paper-50); }

/* Dropdown mobile — mesma paleta */
.hero-menu-mobile {
  background: var(--ink-900);
  border-bottom: 1px solid var(--ink-500);
}
.hero-menu-mobile nav a {
  color: var(--paper-200);
  border-bottom-color: var(--ink-500);
}
.hero-menu-mobile nav a:hover { color: var(--accent-gold); }
.hero-menu-mobile nav a .mono-meta { color: #6a7385; }
.hero-menu-mobile__cta {
  color: var(--paper-50);
  border-color: var(--paper-200);
}
.hero-menu-mobile__cta:hover {
  color: var(--accent-gold);
  border-color: var(--accent-gold);
}

/* Wordmark mantém 32px mesmo no breakpoint que tentava override pra 26px */
@media (min-width: 1024px) {
  .hero__wordmark { font-size: 32px; }
}

/* ---- Mobile · topbar full-bleed e sem gap acima ---- */
@media (max-width: 1023px) {
  /* Remove section padding-top pra o dark band tocar o topo do viewport */
  .hero { padding-top: 0; }
  .hero-v3.hero--no-video { padding-top: var(--space-12); }

  /* Bleed do dark band até as bordas do viewport */
  .hero__topbar {
    margin-left: calc(var(--container-pad) * -1);
    margin-right: calc(var(--container-pad) * -1);
    padding: 16px var(--container-pad);
    padding-left: calc(var(--container-pad) + 12px);
    margin-bottom: var(--space-12);
  }

  /* Dropdown abre logo abaixo do novo topbar (~72px de altura com wordmark 32px) */
  .hero-menu-mobile { top: 72px; }
}
