/* =============================================================================
   tab-conversao.css  — Layout / composição específicos da página Conversão
   Regras de posicionamento, grids e dimensões pontuais.
   Cores: EXCLUSIVAMENTE tokens semânticos de colors.css.
   NÃO modifique colors.css, base.css, spacing.css, typography.css ou effects.css.
   ============================================================================= */

/* ── Esconde scrollbar (mantém scroll funcional) ──
   Aplica-se às páginas internas (carregam tab-conversao.css). O index não
   importa este arquivo, mantendo o scrollbar nativo do navegador. */
html,
body {
  scrollbar-width: none;
  /* Firefox */
  -ms-overflow-style: none;
  /* IE 10+ */
}

html::-webkit-scrollbar,
body::-webkit-scrollbar {
  width: 0;
  height: 0;
  display: none;
  /* Chrome/Safari/Opera */
}

/* ── Hero fold ──
   Container raiz da página: pelo menos 100dvh, mas cresce naturalmente
   quando o conteúdo da hero excede o espaço disponível — o fluxo do
   documento respeita o tamanho real do conteúdo, evitando overlap com
   a próxima seção (.description-section). Hierarquia:
     .cv-hero-fold (min-height: 100dvh, cresce com conteúdo)
     ├─ .nav (fixa)
     └─ .cv-wrap (cresce com conteúdo)
        ├─ .content / .cv-hero (top-anchored, sem overflow oculto)
        └─ .footer (position: sticky bottom — cola no bottom da viewport
                    inicial, scrolla pra fora quando user passa do hero) */
.cv-hero-fold {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  /* Fallback dvh — mais preciso em mobile (compensa a barra do browser). */
  min-height: 100dvh;
  height: auto;
  /* Compensa a nav fixa, igual ao .hero-fold do index.html */
  padding-top: var(--nav-height);
}

/* ── Wrap ──
   Cresce verticalmente com o conteúdo da hero. O footer (sticky) fica
   visível no bottom da viewport enquanto o usuário ainda está na área
   do hero, e desliza pra fora suavemente quando ele rola pra a próxima
   seção. */
.cv-wrap {
  position: relative;
  flex: 1 1 auto;
  width: 100%;
  display: flex;
  flex-direction: column;
}

/* Footer sticky — cola no bottom da viewport (em vez de absolute, que
   ancorava no bottom do wrap crescido e ficava abaixo da viewport).
   margin-top: auto empurra-o pro fim do flex column quando há espaço
   sobrando (tall viewports). */
.cv-wrap>.footer {
  position: sticky;
  bottom: 0;
  margin-top: auto;
  z-index: 2;
  width: 100%;
}

/* ── Override do .content para subpages ──
   No home.css, .content é flex column com align-items:center e ganha
   `flex:1; justify-content:center` em ≥64rem. Esse `justify-content:
   center` causava double-centering com .cv-hero e empurrava o conteúdo
   pra fora em viewports médias. Aqui (escopado a .cv-wrap, não afeta
   o homepage) forçamos top-anchored — o ritmo vertical é governado
   pelo padding do .cv-hero. */
.cv-wrap > .content {
  flex: 0 0 auto;
  justify-content: flex-start;
}

/* ── Hero section — stage relativo para os pills flutuantes ──
   Top-anchored: o conteúdo começa logo abaixo da nav (com --hero-pad-top
   de respiro). O .cv-hero tem altura natural do conteúdo (sem flex grow
   forçado), então quando o conteúdo é maior que o fold, o .cv-wrap e o
   .cv-hero-fold crescem proporcionalmente — o fluxo do documento fica
   correto e a próxima seção (.description-section) começa AFTER do
   conteúdo real do hero, com seu padding-block normal de respiro.

   Os tokens --hero-pad-top / --hero-pad-bottom estão em
   tokens/breakpoints.css e usam clamp() com base em vh, escalando
   suave entre mobile (~600px) e desktop wide (1440p+). */
.cv-hero {
  position: relative;
  flex: 0 0 auto;
  /* Garante expansão full-width dentro do .content (que usa align-items:center) */
  width: 100%;
  align-self: stretch;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  overflow: visible;
  /* Respiro nav → conteúdo (token fluido) */
  padding-top: var(--hero-pad-top);
  /* Clearance pra cima do footer */
  padding-bottom: var(--hero-pad-bottom);
}

/* ── Stage interno: container relativo de 1440 px para as coordenadas dos pills ──
   Container do conteúdo central (pills + headline + slot-exchange).
   O `gap` agora usa --hero-mid-gap, que é o respiro entre o bloco
   texto/CTAs (cv-center) e o componente principal (cv-exchange-wrap)
   — exatamente o "respiro entre o botão e o componente principal" do
   referencial Lumx. Padding interno foi removido; o ritmo vertical
   total é governado pelos paddings do .cv-hero. */
.cv-stage {
  position: relative;
  width: 100%;
  max-width: 1440px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--hero-mid-gap);
  padding: 0;
}

/* ── Coluna central: badge + h1 + desc + CTAs ── */
.cv-center {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: calc(var(--spacing) * 3);
  max-width: 564px;
  width: 100%;
  position: relative;
  z-index: 1;
}

/* Badge — reutiliza .sidebar-tag mas centraliza */
.cv-center .sidebar-tag {
  align-self: center;
  background: var(--surface-1);
  color: var(--text-primary);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: calc(var(--spacing) * 1.5) calc(var(--spacing) * 3);
  font-size: var(--text-xs);
}

/* Heading específico desta página */
.cv-h1 {
  /* Recalibrado: era clamp(text-3xl, 3.5vw, text-5xl) — em 480px o vw resolve
     pra ~17px que ficava abaixo do --text-3xl mínimo (1.875rem ≈ 30px).
     Agora 1.5rem (24px) → 5vw → 3rem (48px). Min ainda confortável em
     mobile pequeno (24px), max um pouco menor que antes (48 vs 60) pra
     evitar quebras feias em desktop com headlines longos. */
  font-size: clamp(1.5rem, 5vw, 3rem);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--tracking-tighter);
  line-height: 1.22;
  color: var(--text-primary);
  margin: 0;
  /* text-wrap: balance distribui as quebras de linha de forma equilibrada
     (suporte amplo em browsers modernos, fallback gracioso). */
  text-wrap: balance;
}

/* Description */
.cv-desc {
  font-size: var(--text-base);
  color: var(--text-secondary);
  line-height: var(--leading-relaxed);
  max-width: 470px;
  margin: 0;
}

/* CTAs — centraliza os botões */
.cv-center .sidebar-ctas {
  justify-content: center;
  align-items: center;
}

/* ── Exchange card no hero ── */
.cv-exchange-wrap {
  /* Fluid: encolhe entre 320px (suficiente pro exchange-container) e 471px
     (largura original). Resolve overflow horizontal entre 900-1200px onde
     471px + sidebar + icon-rail extrapolavam o viewport. */
  width: clamp(20rem, 90%, 471px);
  position: relative;
  z-index: 1;
}

/* ──────────────────────────────────────────────────────────────
   Currency dropdown — flanco esquerdo do slot-exchange.
   Posicionada absolutamente. Fica ATRÁS do slot (z-index: -1)
   espelhando o icon-rail à direita — o card principal aparece
   sempre por cima e o dropdown só "espia" por trás pela esquerda.
   Overlap reduzido a 32px (era 78px) pra dar mais respiro entre
   o texto do dropdown e o conteúdo do card.
   ────────────────────────────────────────────────────────────── */
.cv-currency-dropdown {
  position: absolute;
  right: calc(100% - 56px);
  top: 50%;
  transform: translateY(-50%);
  width: 180px;
  z-index: -1;
  display: flex;
  flex-direction: column;
  gap: calc(var(--spacing) * 2);
  padding: calc(var(--spacing) * 2) calc(var(--spacing) * 3);
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
}

.cv-currency-header {
  display: flex;
  align-items: center;
  gap: 2px;
  color: var(--text-primary);
}

.cv-currency-chevron {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  color: var(--icon-tertiary);
}

.cv-currency-title {
  font-size: var(--text-sm);
  font-weight: var(--font-weight-semibold);
  line-height: var(--leading-normal);
  color: var(--text-primary);
}

.cv-currency-divider {
  height: 1px;
  width: 100%;
  background: var(--border-default);
}

.cv-currency-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.cv-currency-item {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
  padding: calc(var(--spacing) * 1.5) calc(var(--spacing) * 3);
  background: transparent;
  border: 0;
  border-radius: var(--radius-md);
  cursor: pointer;
  font-family: inherit;
  font-size: var(--text-sm);
  font-weight: var(--font-weight-normal);
  line-height: var(--leading-normal);
  color: var(--text-primary);
  text-align: left;
  transition: background 200ms var(--xg-ease-out-expo), color 200ms var(--xg-ease-out-expo);
}

.cv-currency-item:hover {
  background: var(--surface-2);
}

.cv-currency-item.is-selected {
  background: var(--surface-2);
  color: var(--text-primary);
  font-weight: var(--font-weight-medium);
}

.cv-currency-item:focus-visible {
  outline: 2px solid var(--border-default);
  outline-offset: -2px;
}

/* ──────────────────────────────────────────────────────────────
   Icon rail — flanco direito do slot-exchange.
   Centralizado verticalmente em relação ao slot (top: 50% +
   yPercent: -50 via GSAP) e fica atrás do slot (z-index: -1)
   sobrepondo ~16 px da borda direita.
   ────────────────────────────────────────────────────────────── */
.cv-icon-rail {
  position: absolute;
  left: calc(100% - 68px);
  top: 50%;
  width: 100px;
  z-index: -1;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: calc(var(--spacing) * 2);
  padding: calc(var(--spacing) * 3) calc(var(--spacing) * 3);
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-3xl);
}

.cv-icon-rail-btn {
  width: 35px;
  height: 35px;
  flex-shrink: 0;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-default);
  background: var(--surface-1);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 200ms var(--xg-ease-out-expo),
    color 200ms var(--xg-ease-out-expo),
    transform 200ms var(--xg-ease-out-expo);
  color: var(--text-tertiary);
  padding: 0;
}

.cv-icon-rail-btn:hover {
  background: var(--surface-2);
  color: var(--text-primary);
  transform: scale(1.08);
}

.cv-icon-rail-btn:active {
  transform: scale(0.95);
}

.cv-icon-rail-btn svg {
  width: 14px;
  height: 14px;
}

/* Ajuste do slot-exchange no contexto hero: padding reduzido para caber na viewport */
.cv-exchange-wrap .slot-exchange {
  padding: 8px;
  height: auto;
}

.cv-exchange-wrap .exchange-section {
  /* Reduzido o padding horizontal (especialmente esquerdo) — antes 16px,
     ficava visualmente "alto"; 12px deixa o conteúdo mais alinhado com a
     borda do container sem ficar apertado. */
  padding: 10px 12px;
}

.cv-exchange-wrap .exchange-value,
.cv-exchange-wrap .exchange-placeholder {
  margin-bottom: 4px;
  font-size: var(--text-xl);
}

.cv-exchange-wrap .exchange-btn {
  margin-top: 8px;
  padding: 10px 14px;
}

/* ──────────────────────────────────────────────────────────────
   Pills flutuantes — REUTILIZA .moeda-pill (de sections.css).
   Aqui apenas posicionamos as instâncias dentro do .cv-stage.
   Visual, animação de respiração e hover já vêm da classe original.
   ────────────────────────────────────────────────────────────── */
.cv-stage>.moeda-pill {
  position: absolute;
  z-index: 0;
  border: 1px solid var(--border-default);
}

.features-networks-list>.moeda-pill {
  position: relative;
  z-index: 0;
  border: 1px solid var(--border-default);
}

/* Posicionamento responsivo:
   - Em viewports largas (~>=1440 px): vence o termo do design (50% + 470/400 px) — preserva layout original.
   - Em viewports estreitas (~960 a 1440 px): vence o termo de visibilidade (100% - 208 px),
     ancorando a borda externa da pill a 8 px da borda do .cv-stage para que não saia do canvas.
   208 px = largura máxima da pill (Ethereum ~196 px) + 12 px de margem horizontal. */
.cv-pill--eth {
  right: min(calc(100% - 208px), calc(50% + 470px));
  top: 18%;
}

.cv-pill--poly {
  right: min(calc(100% - 208px), calc(50% + 400px));
  top: 54%;
}

.cv-pill--sol {
  left: min(calc(100% - 208px), calc(50% + 470px));
  top: 22%;
}

.cv-pill--tron {
  left: min(calc(100% - 208px), calc(50% + 400px));
  top: 50%;
}

/* ─────────────────────────────────────────────────────────────────────────────
   ── Responsividade VERTICAL do hero ──
   A maior parte do trabalho é feita pelos clamps em --hero-pad-top,
   --hero-mid-gap e --hero-pad-bottom (em tokens/breakpoints.css), que
   escalam suave entre mobile e desktop wide. A antiga cascata de
   @media max-height (68.75rem / 56.25rem / 46.25rem) que reduzia o gap
   manualmente foi removida — em viewports curtas, a hero simplesmente
   cresce e a página rola, em vez de comprimir o ritmo visual.

   Mantemos só uma única safety net mínima: em alturas muito apertadas
   (≤46.25rem ≈ 740px), reduzimos o respiro pra que o usuário ainda
   consiga ver mais conteúdo na primeira dobra antes de precisar rolar.
   ───────────────────────────────────────────────────────────────────────────── */
@media (max-height: 46.25rem) {
  .cv-hero {
    padding-top: clamp(2rem, 5vh, 3rem);
    padding-bottom: clamp(2rem, 5vh, 3rem);
  }

  .cv-stage {
    gap: clamp(2rem, 4vh, 3rem);
  }
}

/* ── Oculta pills, dropdown lateral e icon rail em telas pequenas ── */
@media (max-width: 59.99rem) {
  .cv-stage>.moeda-pill {
    display: none;
  }

  .cv-currency-dropdown,
  .cv-icon-rail {
    display: none;
  }

  .cv-exchange-wrap {
    width: 100%;
  }
}

/* =============================================================================
   DESCRIPTION SECTION
   Card único com gradient leak à esquerda, bloco branco superior (canto
   inferior-esquerdo arredondado) com headline + par Fiat→Stablecoins, e
   faixa verde inferior com bolt + tagline. Aparece logo abaixo do hero.
   Todos os valores tipados consomem tokens de colors.css/typography.css/
   spacing.css/effects.css. Literais (largurinhas fixas do Figma) estão
   comentadas com justificativa.
   ============================================================================= */

.description-section {
  position: relative;
  padding-block: calc(var(--spacing) * 16);
  /* Padding lateral fluido: 24px no mobile → ~80px no desktop. O
     .description-card interno tem max-width 833px + margin-inline auto e
     fica centralizado. Em mobile (viewport < 833 + 48 = 881px), o card
     respeita o padding lateral da section, não encosta nas bordas. */
  padding-inline: var(--section-padding-x);
}

.description-card {
  position: relative;
  width: 100%;
  /* 833 px = largura fixa do card no Figma. Não há container token equivalente
     (--container-4xl = 56rem ≈ 896 px é o mais próximo, mas excede em 63 px). */
  max-width: 833px;
  margin-inline: auto;
  /* O gradient bg ocupa o lado esquerdo do card; o conteúdo é deslocado em
     112 px para a direita para "respeitar" o leak escuro. */
  padding-left: calc(var(--spacing) * 28);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  overflow: hidden;
  isolation: isolate;
}

/* Gradient bg cobre todo o card e fica atrás do conteúdo */
.description-card-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
  pointer-events: none;
}

/* ── Top: bloco branco com headline + cards Fiat/Stablecoins ──
   surface-1 com canto inferior-esquerdo grande (32 px). Os cantos não
   arredondados deixam o gradient bg vazar e formar o "L" escuro/verde. */
.description-card-top {
  position: relative;
  z-index: 1;
  background: var(--surface-1);
  padding: calc(var(--spacing) * 14) 0 calc(var(--spacing) * 14) calc(var(--spacing) * 14);
  border-bottom-left-radius: var(--radius-4xl);
}

.description-card-content {
  display: flex;
  flex-direction: column;
  gap: calc(var(--spacing) * 8);
}

.description-card-heading {
  display: flex;
  flex-direction: column;
  gap: calc(var(--spacing) * 2);
  /* 480 px = largura máxima do bloco de heading no Figma; não mapeia em
     nenhum container token (--container-xl = 36rem ≈ 576 px é o vizinho). */
  max-width: 480px;
}

.description-card-title {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--text-3xl);
  font-weight: var(--font-weight-medium);
  line-height: var(--leading-tight);
  color: var(--text-primary);
}

.description-card-desc {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--text-base);
  font-weight: var(--font-weight-normal);
  line-height: var(--leading-normal);
  color: var(--text-secondary);
}

/* ── Par Fiat → Stablecoins ── */
.description-card-pairs {
  display: flex;
  align-items: center;
  gap: calc(var(--spacing) * 6);
}

.description-pair {
  display: flex;
  flex-direction: column;
  gap: calc(var(--spacing) * 1);
  padding: calc(var(--spacing) * 4);
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  /* Fluid: 160-190px no desktop, escala com viewport pra evitar aperto
     em viewports 800-1024px onde o pair ficava espremido. Antes 190px
     literal. flex-shrink: 0 mantido pra não colapsar abaixo do min. */
  width: clamp(10rem, 22vw, 11.875rem);
  flex-shrink: 0;
}

/* Variante Stablecoins: borda primary, ocupa todo o espaço restante e perde
   os cantos direitos (mantém apenas left-rounded como no Figma).
   border-right: 0 elimina a linha vertical à direita que aparecia onde o
   card encostava na borda do container — mantém top/left/bottom intactos
   pra preservar o look "card aberto" das mídias maiores e responsivas. */
.description-pair--highlight {
  border-color: var(--color-primary-700);
  width: auto;
  flex: 1 1 0;
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
  border-right: 0;
}

.description-pair-title {
  font-size: var(--text-sm);
  font-weight: var(--font-weight-semibold);
  line-height: var(--leading-normal);
  color: var(--text-primary);
}

.description-pair-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: calc(var(--spacing) * 1);
}

.description-pair-list li {
  display: flex;
  align-items: center;
  gap: calc(var(--spacing) * 1);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-normal);
  line-height: var(--leading-normal);
  color: var(--text-secondary);
}

.description-pair-dot {
  width: calc(var(--spacing) * 2);
  height: calc(var(--spacing) * 2);
  border-radius: 50%;
  background: var(--on-primary-container);
  flex-shrink: 0;
}

/* Botão circular com seta (entre Fiat e Stablecoins) */
.description-pair-arrow {
  width: calc(var(--spacing) * 16);
  height: calc(var(--spacing) * 16);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--hover-light);
  border-radius: 50%;
  color: var(--icon-secondary);
}

.description-pair-arrow svg {
  width: calc(var(--spacing) * 6);
  height: calc(var(--spacing) * 6);
}

/* ── Bottom: faixa verde com bolt + tagline ──
   Sem background próprio: o gradient bg do card aparece através. */
.description-card-bottom {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  gap: calc(var(--spacing) * 5);
  padding: calc(var(--spacing) * 14) 0;
}

.description-bolt {
  width: calc(var(--spacing) * 16);
  height: calc(var(--spacing) * 16);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--primary-container);
  border-radius: var(--radius-sm);
  color: var(--color-white);
}

.description-bolt svg {
  width: calc(var(--spacing) * 8);
  height: calc(var(--spacing) * 8);
}

.description-tagline {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--text-lg);
  font-weight: var(--font-weight-medium);
  line-height: var(--leading-snug);
  color: var(--color-white);
  /* 337 px = largura fixa do bloco de texto no Figma. */
  max-width: 337px;
}

/* ── Reveal animation (xg-reveal já é tratada por animations.js) ── */
.description-section .xg-reveal.active {
  animation: xg-fade-up 0.9s var(--xg-ease-out-expo) forwards;
}

/* ── Responsivo ── */
@media (max-width: 48rem) {
  .description-card {
    padding-left: 0;
  }

  .description-card-top {
    padding: calc(var(--spacing) * 8) calc(var(--spacing) * 6);
    border-bottom-left-radius: 0;
  }

  .description-card-pairs {
    flex-wrap: wrap;
    gap: calc(var(--spacing) * 4);
    justify-content: center;
  }

  .description-pair {
    width: 100%;
    flex: 1 1 100%;
  }

  .description-pair--highlight {
    border-radius: var(--radius-lg);
    /* Em viewports estreitos os pairs viram cards empilhados completos —
       restaura o border-right que removemos no layout horizontal default. */
    border-right: 1px solid var(--color-primary-700);
  }

  .description-card-bottom {
    padding: calc(var(--spacing) * 8) calc(var(--spacing) * 6);
  }
}

/* prefers-reduced-motion: neutraliza a entrada animada */
@media (prefers-reduced-motion: reduce) {
  .description-section .xg-reveal {
    opacity: 1;
    animation: none !important;
  }
}

/* =============================================================================
   HOW IT WORKS #1 — Conversão de Fiat para stablecoins (On-ramp)
   Layout duas colunas (≥lg): copy à esquerda + card de demonstração à direita.
   Em <lg as colunas se empilham. Todos os valores tipados consomem tokens;
   literais (largurinhas pontuais do Figma e o radius 22 px) estão comentadas.
   ============================================================================= */

/* Section: full-viewport (100vw × 100vh) com 58 px de padding lateral
   herdado de .fold (--fold-padding). O conteúdo (.howitworks1-grid) é
   centralizado vertical e horizontalmente dentro deste container. */
.howitworks1-section {
  position: relative;
  width: 100%;
  min-height: 100vh;
  padding-block: var(--section-gap-y);
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Wrap interno: 100% de largura disponível, capado em --fold-max-width
   (1400 px) — mesmo container token usado pelas demais dobras do projeto. */
.howitworks1-grid {
  width: 100%;
  max-width: 1100px;
  margin-inline: auto;
  display: flex;
  align-items: center;
  gap: calc(var(--spacing) * 5);
}

/* ── Coluna esquerda: copy + fluxo numerado ── */
.howitworks1-copy {
  flex: 1 1 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: calc(var(--spacing) * 8);
}

.howitworks1-heading {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: calc(var(--spacing) * 2);
  /* 540 px = max-width do bloco de heading no Figma; não mapeia em token. */
  max-width: 540px;
}

.xg-section-eyebrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: calc(var(--spacing) * 2) calc(var(--spacing) * 4);
  background: var(--primary-container);
  color: var(--on-primary-container);
  border-radius: var(--radius-lg);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  /* Weight bump de normal → medium: text-xs (12px) em background colorido
     fica subdimensionado em normal (400). Medium (500) recupera leitura
     sem virar pesado demais. */
  font-weight: var(--font-weight-medium);
  line-height: var(--leading-normal);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}

.xg-section-title {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--text-3xl);
  font-weight: var(--font-weight-medium);
  line-height: var(--leading-tight);
  color: var(--text-primary);
}

.xg-section-desc {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--text-base);
  font-weight: var(--font-weight-normal);
  line-height: var(--leading-normal);
  color: var(--text-secondary);
}

/* ── Fluxo numerado ── */
.howitworks1-flow {
  display: flex;
  flex-direction: column;
  gap: calc(var(--spacing) * 2);
}

.howitworks1-flow-title {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--text-base);
  font-weight: var(--font-weight-semibold);
  line-height: var(--leading-normal);
  color: var(--text-primary);
}

.howitworks1-flow-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
}

.howitworks1-flow-item {
  display: flex;
  align-items: center;
  gap: calc(var(--spacing) * 1.5);
  padding-block: calc(var(--spacing) * 2);
  font-family: var(--font-sans);
  font-size: var(--text-base);
  font-weight: var(--font-weight-normal);
  line-height: var(--leading-normal);
}

/* Divisor entre passos — usa border-default. Não aparece após o último item. */
.howitworks1-flow-item+.howitworks1-flow-item {
  border-top: 1px solid var(--border-default);
}

.howitworks1-flow-num {
  font-family: var(--font-mono);
  color: var(--on-primary-container);
  flex-shrink: 0;
}

.howitworks1-flow-text {
  color: var(--text-secondary);
}

/* ── Coluna direita: card de demonstração ─────────────────────────────────
   Card de 316 px com borda 2 px primary e sombra primary-tinted (efeito
   de glow). O radius 22 px e a sombra primary-tinted são exclusivos deste
   card e não têm tokens equivalentes — comentados como literais. */
.howitworks1-card {
  flex-shrink: 0;
  /* 316 px = largura fixa do card no Figma; não há container token equivalente. */
  width: 316px;
  padding: calc(var(--spacing) * 3.5);
  background: var(--surface-1);
  border: 2px solid var(--color-primary-700);
  /* radius 22 px = valor exclusivo do card no Figma; entre --radius-2xl (16)
     e --radius-3xl (24). Mantido literal por ser específico. */
  border-radius: 22px;
  /* Glow primary-tinted: sombra exclusiva deste card (não há token equivalente
     para tinted shadows na paleta). Mantida literal. */
  box-shadow:
    0 47px 80px rgba(47, 244, 211, 0.09),
    0 19.6px 33.4px rgba(47, 244, 211, 0.06),
    0 10.5px 17.9px rgba(47, 244, 211, 0.05),
    0 5.9px 10px rgba(47, 244, 211, 0.05),
    0 3.1px 5.3px rgba(47, 244, 211, 0.04),
    0 1.3px 2.2px rgba(47, 244, 211, 0.03);
}

.howitworks1-card-inner {
  position: relative;
  display: flex;
  flex-direction: column;
  /* gap pequeno (8px) — combinado com o margin-block negativo do chevron,
     deixa o chevron centralizado SOBRE a "costura" entre rows adjacentes.
     Aumentar esse gap separa demais e o chevron fica flutuando. */
  gap: calc(var(--spacing) * 2);
}

/* Linha do card: PAGADOR / ROTA / CONTA GLOBAL / SALDO (varia por página).
   Espaçamento ampliado pra dar mais respiro às informações (match com
   referência do Figma): padding vertical mais generoso, gap entre label
   uppercase e name maior, padding horizontal proporcional. Hover sem
   slide pra não brigar com o respiro. */
.howitworks1-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: calc(var(--spacing) * 4);
  /* Padding 24px vertical / 20px horizontal — mais arejado. */
  padding: calc(var(--spacing) * 6) calc(var(--spacing) * 5);
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  /* radius INTERNO. card radius (22px) = row radius (8px) + card padding
     (14px) → segue a regra de cantos concêntricos. */
  border-radius: var(--radius-lg);
  transition: background 200ms ease;
}

.howitworks1-row:hover {
  background: var(--surface-2);
}

.howitworks1-row-value {
  transition: color 200ms ease;
}

.howitworks1-row:hover .howitworks1-row-value {
  color: var(--on-primary-container);
}

.howitworks1-row-left {
  display: flex;
  flex-direction: column;
  /* gap entre label uppercase e nome — antes não tinha gap e os textos
     ficavam colados. 6px deixa o label respirar sem virar dois blocos. */
  gap: calc(var(--spacing) * 1.5);
  flex: 1 1 0;
  min-width: 0;
}

.howitworks1-row-label {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-medium);
  line-height: var(--leading-normal);
  letter-spacing: var(--tracking-wide);
  color: var(--on-primary-container);
  text-transform: uppercase;
}

.howitworks1-row-name {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  font-weight: var(--font-weight-semibold);
  line-height: var(--leading-normal);
  color: var(--text-primary);
}

.howitworks1-row-value {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  font-weight: var(--font-weight-semibold);
  line-height: var(--leading-normal);
  color: var(--text-primary);
  text-align: right;
  flex-shrink: 0;
}

/* Chevron circular entre as rows. margin-block negativa de -20px colapsa
   parte do gap (que é 8px), fazendo o chevron sentar SOBRE a borda entre
   dois rows adjacentes — visual de "fluxo conectado" do Figma. */
.howitworks1-chevron {
  align-self: center;
  width: calc(var(--spacing) * 8);
  height: calc(var(--spacing) * 8);
  margin-block: calc(var(--spacing) * -5);
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: 50%;
  color: var(--icon-tertiary);
  z-index: 1;
}

.howitworks1-chevron svg {
  width: calc(var(--spacing) * 4);
  height: calc(var(--spacing) * 4);
}

/* ── Reveal animation (xg-reveal já é tratada por animations.js) ── */
.howitworks1-section .xg-reveal.active {
  animation: xg-fade-up 0.9s var(--xg-ease-out-expo) forwards;
}

.howitworks1-card.xg-reveal {
  /* Stagger leve no card para entrar logo após o copy */
  animation-delay: 120ms;
}

/* ── Responsivo ── */
@media (max-width: 64rem) {
  .howitworks1-grid {
    flex-direction: column;
    align-items: stretch;
    gap: calc(var(--spacing) * 12);
  }

  .howitworks1-card {
    width: 100%;
    max-width: 540px;
    margin-inline: auto;
  }
}

@media (max-width: 40rem) {
  .howitworks1-section {
    padding-block: calc(var(--spacing) * 16);
  }

  .howitworks1-row {
    padding: calc(var(--spacing) * 6);
    gap: calc(var(--spacing) * 4);
  }
}

/* prefers-reduced-motion: neutraliza a entrada animada */
@media (prefers-reduced-motion: reduce) {
  .howitworks1-section .xg-reveal {
    opacity: 1;
    animation: none !important;
  }
}

/* =============================================================================
   HOW IT WORKS #2 — Conversão para BRL via stablecoins (Off-ramp)
   Layout duas colunas (≥lg): copy à esquerda + card alto com gradient bg e
   badges à direita. Em <lg as colunas se empilham. Reutiliza .howitworks1-eyebrow
   (mesmo pill primary-container/on-primary-container do off-ramp).
   ============================================================================= */

.howitworks2-section {
  position: relative;
  width: 100%;
  min-height: 100vh;
  padding-block: var(--section-gap-y);
  display: flex;
  align-items: center;
  justify-content: center;
}

.howitworks2-grid {
  width: 100%;
  max-width: 1100px;
  margin-inline: auto;
  display: flex;
  align-items: center;
  gap: calc(var(--spacing) * 5);
}

/* ── Coluna esquerda: copy + 2 listas com checks ──
   flex:1 garante que ocupe o espaço restante após o card no row layout
   (≥lg). Em column layout (<lg) o max-width da media query expande para
   100%. Sem width fixa em %, evita texto comprimido no mobile. */
.howitworks2-copy {
  flex: 1 1 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: calc(var(--spacing) * 10);
}

.howitworks2-heading {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: calc(var(--spacing) * 2);
  /* Cap pra que parágrafos longos da .xg-section-desc não esticarem o
     bloco até a largura total do .howitworks2-copy (~780px no desktop)
     e virem uma linha enorme atravessando a tela. Match com
     .howitworks1-heading (540px) e .audience-heading (578px). */
  max-width: 540px;
}

.xg-desc-stack {
  display: flex;
  flex-direction: column;
  gap: calc(var(--spacing) * 4);
}

/* Bloco "Como funciona:" / "Na prática, você consegue:" */
.xg-list-block {
  display: flex;
  flex-direction: column;
  gap: calc(var(--spacing) * 4);
}

.xg-list-block-title {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--text-base);
  font-weight: var(--font-weight-semibold);
  line-height: var(--leading-normal);
  color: var(--text-primary);
}

.xg-checklist {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
}

.xg-checklist-item {
  display: flex;
  align-items: center;
  gap: calc(var(--spacing) * 1.5);
  padding-block: calc(var(--spacing) * 1);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-normal);
  line-height: var(--leading-normal);
  color: var(--text-secondary);
}

.xg-checklist-icon {
  width: calc(var(--spacing) * 6);
  height: calc(var(--spacing) * 6);
  flex-shrink: 0;
  color: var(--on-primary-container);
}

/* ── Coluna direita: card alto com gradient bg + badges ──
   Card de 316 × 633 px com gradient bg image (mesma da seção description).
   Os 4 badges ficam empilhados na base, com padding interno definido
   para reproduzir o offset 64 px do Figma. */
.howitworks2-card {
  position: relative;
  flex-shrink: 0;
  /* 316 px = largura fixa do card no Figma; sem token equivalente.
     Em <lg a media query força 100% / max-width 540, então o cap
     percentual não causa problemas. */
  width: 316px;
  /* 633 px = altura fixa do card no Figma; sem token equivalente. */
  height: 633px;
  border-radius: var(--radius-lg);
  overflow: visible;
  isolation: isolate;
}

.howitworks2-card-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
  pointer-events: none;
}

/* Container dos badges, ancorado na base. Offsets reduzidos de 64px → 32px
   pra dar espaço pros badges acomodarem labels longos como
   "Recarga via Pix (BRL)" e "Confirmação por webhook" sem vazar do card
   (que tem largura fixa de 316px). */
.howitworks2-badges {
  position: absolute;
  left: calc(var(--spacing) * 8);
  right: calc(var(--spacing) * 8);
  bottom: calc(var(--spacing) * 16);
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: calc(var(--spacing) * 4);
}

.howitworks2-badge {
  display: flex;
  align-items: center;
  /* width: 100% + max-width: 100% garantem que o badge nunca passe do
     container .howitworks2-badges (que agora tem offsets de 32px,
     deixando ~252px de espaço dentro do card de 316px). */
  width: 100%;
  max-width: 100%;
  gap: calc(var(--spacing) * 2);
  padding: calc(var(--spacing) * 2.5) calc(var(--spacing) * 3);
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  /* min-width: 0 + overflow: hidden permitem que o flex-child (text) aceite
     ellipsis se ainda assim faltar espaço, sem forçar overflow do badge. */
  min-width: 0;
  overflow: hidden;
}

.howitworks2-badge-icon {
  width: calc(var(--spacing) * 8);
  height: calc(var(--spacing) * 8);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--primary-container);
  border-radius: var(--radius-sm);
  color: var(--on-primary-container);
}

.howitworks2-badge-icon svg {
  /* Ícone menor que o container (32px) — 16px com 8px de respiro de cada lado.
     stroke-width: 1.5 sobrescreve os stroke-width="2" inline dos SVGs no HTML
     pra deixar o traço mais sutil, combinando com o tamanho menor. */
  width: calc(var(--spacing) * 4);
  height: calc(var(--spacing) * 4);
  stroke-width: 1.5;
}

.howitworks2-badge-text {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-semibold);
  line-height: var(--leading-normal);
  color: var(--text-primary);
  /* nowrap evita quebra; ellipsis fica como fallback se mesmo assim o
     espaço for insuficiente (ex.: viewports muito estreitos onde o card
     pode encolher abaixo de 316px). min-width:0 desbloqueia o ellipsis em
     flex children. */
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}

/* ── Reveal animation (xg-reveal já é tratada por animations.js) ── */
.howitworks2-section .xg-reveal.active {
  animation: xg-fade-up 0.9s var(--xg-ease-out-expo) forwards;
}

.howitworks2-card.xg-reveal {
  /* Stagger leve no card para entrar logo após o copy */
  animation-delay: 120ms;
}

/* ── Responsivo ── */
@media (max-width: 64rem) {
  .howitworks2-grid {
    flex-direction: column;
    align-items: stretch;
    gap: calc(var(--spacing) * 12);
  }

  .howitworks2-copy {
    max-width: 100%;
  }

  .howitworks2-card {
    width: 100%;
    max-width: 540px;
    margin-inline: auto;
  }
}

/* ── Compactação da descrição em desktop ──
   Em breakpoints >= 64rem (lg) o parágrafo de descrição usa entrelinha
   apertada para reduzir a altura visual. Mobile mantém entrelinha
   relaxada (definida na regra base) para legibilidade em telas pequenas. */
@media (min-width: 64rem) {
  .howitworks2-desc p {
    line-height: var(--leading-tight);
  }
}

@media (max-width: 40rem) {
  .howitworks2-section {
    padding-block: calc(var(--spacing) * 16);
  }

  .howitworks2-card {
    /* Em mobile, reduz a altura para acomodar viewport menor mantendo
       proporção visual do gradient + badges. */
    height: 520px;
  }

  .howitworks2-badges {
    left: calc(var(--spacing) * 6);
    right: calc(var(--spacing) * 6);
    bottom: calc(var(--spacing) * 6);
  }
}

/* prefers-reduced-motion: neutraliza a entrada animada */
@media (prefers-reduced-motion: reduce) {
  .howitworks2-section .xg-reveal {
    opacity: 1;
    animation: none !important;
  }
}

/* =============================================================================
   HOW IT WORKS #3 — Liquidação instantânea (On-ramp)
   Layout duas colunas (≥lg): copy à esquerda + stack vertical (status pill +
   3 step cards) à direita. Cada step card é 316×128 com gradient bg + painel
   branco inferior + badge "ETAPA N" rotacionado 90° no flanco direito.
   Reutiliza .howitworks1-eyebrow.
   ============================================================================= */

/* Section: full-viewport (100% × 100vh) com 58 px de padding lateral
   herdado de .fold (--fold-padding). Conteúdo (.howitworks3-grid) é
   centralizado vertical e horizontalmente — mesma lógica de howitworks1/2. */
.howitworks3-section {
  position: relative;
  width: 100%;
  min-height: 100vh;
  padding-block: var(--section-gap-y);
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Wrap interno: 100% de largura disponível, capado em 1100 px (mesmo valor
   adotado em howitworks1/2 — escala de container desta página). */
.howitworks3-grid {
  width: 100%;
  /* 1100 px = mesmo max-width usado em howitworks1/2; sem container token
     equivalente (--container-6xl = 72rem é vizinho mas ultrapassa). */
  max-width: 1100px;
  margin-inline: auto;
  display: flex;
  align-items: center;
  gap: calc(var(--spacing) * 5);
}

/* ── Coluna esquerda: copy + lista ──
   flex:1 garante que ocupe o espaço restante após o stack no row layout
   (≥lg). Sem width fixa em %, evita texto comprimido no mobile. */
.howitworks3-copy {
  flex: 1 1 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: calc(var(--spacing) * 8);
  /* 600 px = max-width do bloco de copy no Figma; sem token equivalente. */
  max-width: 600px;
}

.howitworks3-heading {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: calc(var(--spacing) * 2);
  /* Cap pra parágrafos longos da .xg-section-desc não atravessarem a tela
     em desktop. Match com howitworks1-heading. */
  max-width: 540px;
}

/* Bloco "Como funciona:" + lista */
/* ── Coluna direita: stack com status pill + step cards ── */
.howitworks3-stack {
  flex-shrink: 0;
  /* 316 px = largura fixa da coluna de cards no Figma; sem token equivalente.
     Em <lg a media query troca para 100% / max-width 540. */
  width: 316px;
  display: flex;
  overflow: visible;
  flex-direction: column;
  gap: calc(var(--spacing) * 4);
}

/* Status pill — capsule com bullet verde + label + meta */
.howitworks3-status {
  display: flex;
  align-items: center;
  gap: calc(var(--spacing) * 2);
  padding: calc(var(--spacing) * 1.5) calc(var(--spacing) * 3) calc(var(--spacing) * 1.5) calc(var(--spacing) * 2);
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  /* Pill capsule — radius extremo (999) padrão para pills no projeto. */
  border-radius: 999px;
}

.howitworks3-status-dot {
  width: calc(var(--spacing) * 2.75);
  height: calc(var(--spacing) * 2.75);
  flex-shrink: 0;
  border-radius: 50%;
  background: var(--primary);
}

.howitworks3-status-label {
  flex: 1 1 auto;
  min-width: 0;
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-normal);
  line-height: var(--leading-normal);
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.howitworks3-status-meta {
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-normal);
  line-height: var(--leading-normal);
  color: var(--text-tertiary);
  white-space: nowrap;
}

/* Step card — gradient bg + painel branco no rodapé + badge "ETAPA N" */
.howitworks3-step {
  position: relative;
  width: 100%;
  /* 128 px = altura fixa do card no Figma; sem token equivalente. */
  height: fit-content;
  flex-direction: column;
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  overflow: hidden;
  isolation: isolate;
}

.howitworks3-step-bg {
  position: relative;
  width: 100%;
  height: 8px;

  /* ── Estabilização do gradient-warp em superfície fina ──
     O shader do gradient-warp aplica um displacement voronoi cujo número
     de células escala com aspect ratio do elemento. Em strips finos
     (aspect alto) aparecem dezenas de células e o blend vira ruído; em
     cards altos como howitworks2-card (aspect baixo) cabem poucas células
     e o resultado já fica praticamente liso. Aqui desligamos o warp
     localmente para renderizar apenas o blend IDW dos 5 control points
     — produz a mesma estética suave do howitworks2-card, independente
     do tamanho do elemento. */
  --gw-warp: 0;
}

/* Painel branco ancorado no rodapé do card (deixa o gradient aparecer no topo) */
.howitworks3-step-panel {
  position: relative;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  display: flex;
  flex-direction: column;
  height: fit-content;
  gap: calc(var(--spacing) * 1);
  padding: calc(var(--spacing) * 6);
  background: var(--surface-1);
  overflow: visible;
  border-top: 1px solid var(--border-default);
  border-bottom-left-radius: var(--radius-lg);
  border-bottom-right-radius: var(--radius-lg);
}

.howitworks3-step-header {
  display: flex;
  align-items: center;
  gap: calc(var(--spacing) * 1);
}

.howitworks3-step-icon {
  width: calc(var(--spacing) * 5);
  height: calc(var(--spacing) * 5);
  flex-shrink: 0;
  color: var(--on-primary-container);
}

.howitworks3-step-title {
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-medium);
  line-height: var(--leading-normal);
  color: var(--text-primary);
}

.howitworks3-step-desc {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-normal);
  line-height: var(--leading-normal);
  color: var(--text-secondary);
  /* 249 px = max-width fixo da descrição no Figma (deixa espaço para o badge
     vertical à direita não sobrepor o texto). */
  max-width: 249px;
}

/* Badge "ETAPA N" rotacionado 90° no flanco direito do card */
.howitworks3-step-badge {
  position: absolute;
  right: -8px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
}

.howitworks3-step-badge>span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: calc(var(--spacing) * 1.5) calc(var(--spacing) * 3);
  background: var(--primary-container);
  color: var(--on-primary-container);
  /* Pill capsule — radius extremo padrão do projeto para pills. */
  border-radius: 999px;
  /* Rotação de 90° fixa no Figma — gira o pill para leitura vertical. */
  transform: rotate(-90deg);
  transform-origin: center;
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-medium);
  line-height: var(--leading-normal);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  white-space: nowrap;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

/* ── Reveal animation (xg-reveal já é tratada por animations.js) ── */
.howitworks3-section .xg-reveal.active {
  animation: xg-fade-up 0.9s var(--xg-ease-out-expo) forwards;
}

/* ── Responsivo ── */
@media (max-width: 64rem) {
  .howitworks3-grid {
    flex-direction: column;
    align-items: stretch;
    gap: calc(var(--spacing) * 12);
  }

  .howitworks3-copy {
    max-width: 100%;
  }

  .howitworks3-stack {
    width: 100%;
    max-width: 540px;
    margin-inline: auto;
  }
}

@media (max-width: 40rem) {
  .howitworks3-section {
    padding-block: calc(var(--spacing) * 16);
  }

  .howitworks3-step-desc {
    /* Em mobile, libera o max-width para usar todo o espaço disponível. */
    max-width: none;
    /* Reserva espaço para o badge vertical à direita. */
    padding-right: calc(var(--spacing) * 10);
  }
}

/* prefers-reduced-motion: neutraliza a entrada animada */
@media (prefers-reduced-motion: reduce) {
  .howitworks3-section .xg-reveal {
    opacity: 1;
    animation: none !important;
  }
}

/* =============================================================================
   FEATURES — Redes suportadas
   Bloco centralizado: eyebrow + headline + descrição (max 578 px), seguido de
   uma linha com 4 pills (Polygon / Solana / Ethereum / Tron). Reutiliza o
   eyebrow .howitworks1-eyebrow.
   ============================================================================= */

.features-section {
  position: relative;
  padding-block: var(--section-gap-y);
}

.features-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  /* 64 px de gap entre o bloco de heading e o bloco de pills (Figma). */
  gap: calc(var(--spacing) * 16);
  /* 1013 px = max-width do row no Figma; sem container token equivalente
     (--container-6xl = 72rem = 1152 px é o vizinho mais próximo mas excede). */
  max-width: 1013px;
  margin-inline: auto;
  text-align: center;
}

/* ── Heading centralizado ── */
.features-heading {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: calc(var(--spacing) * 2);
  /* 578 px = max-width do bloco de heading no Figma; sem token equivalente. */
  max-width: 578px;
}

/* ── Bloco de pills com subtitle "Atualmente disponível:" ── */
.features-networks {
  display: flex;
  flex-direction: column;
  align-items: center;
  /* 32 px de gap entre subtitle e pills no Figma. */
  gap: calc(var(--spacing) * 8);
  width: 100%;
}

.features-networks-title {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--text-base);
  font-weight: var(--font-weight-semibold);
  line-height: var(--leading-normal);
  color: var(--text-primary);
}

.features-networks-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  /* 24 px de gap entre pills no Figma. */
  gap: calc(var(--spacing) * 6);
}

/* Pill: surface-1 + ícone circular 48 px + nome à direita */
.features-network {
  display: inline-flex;
  align-items: center;
  /* 16 px de gap interno entre ícone e nome. */
  gap: calc(var(--spacing) * 4);
  /* py-16 / pl-24 / pr-64 (Figma). */
  padding: calc(var(--spacing) * 4) calc(var(--spacing) * 16) calc(var(--spacing) * 4) calc(var(--spacing) * 6);
  background: var(--surface-1);
  /* Pill capsule — radius extremo padrão do projeto. */
  border-radius: 999px;
}

.features-network-icon {
  /* 48 px (12 × spacing 4) = tamanho exato do ícone no Figma. */
  width: calc(var(--spacing) * 12);
  height: calc(var(--spacing) * 12);
  flex-shrink: 0;
  border-radius: 50%;
  object-fit: cover;
}

.features-network-name {
  font-family: var(--font-sans);
  /* Figma marca 28 px; --text-2xl (24 px) é o token mais próximo da escala. */
  font-size: var(--text-2xl);
  font-weight: var(--font-weight-normal);
  line-height: var(--leading-snug);
  color: var(--text-primary);
}

/* ── Reveal animation (xg-reveal já é tratada por animations.js) ── */
.features-section .xg-reveal.active {
  animation: xg-fade-up 0.9s var(--xg-ease-out-expo) forwards;
}

/* ── Responsivo ── */
@media (max-width: 64rem) {
  .features-networks-list {
    gap: calc(var(--spacing) * 4);
  }
}

@media (max-width: 40rem) {
  .features-section {
    padding-block: calc(var(--spacing) * 16);
  }

  .features-network {
    /* Em mobile, reduz o padding-right (pr-64) para caber na viewport. */
    padding: calc(var(--spacing) * 3) calc(var(--spacing) * 8) calc(var(--spacing) * 3) calc(var(--spacing) * 4);
    gap: calc(var(--spacing) * 3);
  }

  .features-network-icon {
    width: calc(var(--spacing) * 10);
    height: calc(var(--spacing) * 10);
  }

  .features-network-name {
    font-size: var(--text-xl);
  }
}

/* prefers-reduced-motion: neutraliza a entrada animada */
@media (prefers-reduced-motion: reduce) {
  .features-section .xg-reveal {
    opacity: 1;
    animation: none !important;
  }
}

/* =============================================================================
   INTERGRATION — Integração com sua operação (On-ramp)
   Layout duas colunas (≥lg): copy à esquerda + stack vertical de 4 step cards
   à direita, com gradient-warp como backdrop por trás dos cards. Cada step
   card tem badge numerada à esquerda (primary-container), título central e
   tag uppercase à direita (on-primary-container).
   ============================================================================= */

/* Section: full-viewport (100% × 100vh) com 58 px de padding lateral
   herdado de .fold (--fold-padding). Conteúdo (.intergration-grid) é
   centralizado vertical e horizontalmente — mesma lógica de howitworks1/2/3. */
.intergration-section {
  position: relative;
  width: 100%;
  min-height: 100vh;
  padding-block: var(--section-gap-y);
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Wrap interno: 100% de largura disponível, capado em 1100 px (mesmo valor
   adotado em howitworks1/2/3 — escala de container desta página). */
.intergration-grid {
  width: 100%;
  /* 1100 px = mesmo max-width de howitworks1/2/3; sem container token
     equivalente (--container-6xl = 72rem é vizinho mas ultrapassa). */
  max-width: 1100px;
  margin-inline: auto;
  display: flex;
  align-items: center;
  gap: calc(var(--spacing) * 5);
}

/* ── Coluna esquerda: copy + lista ──
   flex:1 garante que ocupe o espaço restante após o stack no row layout
   (≥lg). Sem width fixa em %, evita texto comprimido no mobile. */
.intergration-copy {
  flex: 1 1 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: calc(var(--spacing) * 8);
  /* 600 px = max-width do bloco de copy no Figma; sem token equivalente. */
  max-width: 600px;
}

.intergration-heading {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: calc(var(--spacing) * 2);
  /* Cap pra parágrafos longos não atravessarem a tela em desktop. */
  max-width: 540px;
}

/* ── Coluna direita: gradient pillar atrás + 4 step cards extrapolando ──
   No Figma, o gradient é um "pilar" estreito (249 px) e os cards são mais
   largos (316 px), saindo horizontalmente sobre o gradient nas duas pontas.
   Verticalmente, o gradient se estende acima e abaixo dos cards via
   padding-block do .intergration-stack. */
.intergration-stack {
  position: relative;
  flex-shrink: 0;
  /* 316 px = largura dos step cards no Figma; sem token equivalente. */
  width: 316px;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  /* 16 px de gap entre os 4 cards (Figma). */
  gap: calc(var(--spacing) * 4);
  /* Padding-block dá altura extra ao gradient pillar acima e abaixo dos
     cards (Figma: gradient ~476 px vs cards ~272 px → ~100 px cada lado). */
  padding-block: calc(var(--spacing) * 24);
  isolation: isolate;
}

/* Gradient pillar — vertical, mais estreito que os cards, centralizado.
   Cards extrapolam horizontalmente sobre ele (z-index acima). */
.intergration-stack-bg {
  position: absolute;
  /* 249 px = largura do gradient pillar no Figma; cards (316 px)
     extrapolam ~33 px de cada lado deliberadamente. */
  width: 249px;
  top: 0;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 0;
  border-radius: var(--radius-lg);
  pointer-events: none;
}

/* Step card: surface-1 com badge numerada + título + tag */
.intergration-step {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  /* 10 px de gap entre os 3 elementos do card no Figma. */
  gap: calc(var(--spacing) * 2.5);
  padding: calc(var(--spacing) * 3);
  background: var(--surface-1);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
}

/* Badge numerada à esquerda */
.intergration-step-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: calc(var(--spacing) * 8);
  height: calc(var(--spacing) * 8);
  background: var(--primary-container);
  color: var(--on-primary-container);
  border-radius: var(--radius-sm);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-semibold);
  line-height: var(--leading-normal);
}

/* Título central — ocupa todo o espaço restante */
.intergration-step-name {
  flex: 1 1 0;
  min-width: 0;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-semibold);
  line-height: var(--leading-normal);
  color: var(--text-primary);
}

/* Tag uppercase à direita */
.intergration-step-tag {
  flex-shrink: 0;
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-normal);
  line-height: var(--leading-normal);
  letter-spacing: var(--tracking-wide);
  color: var(--on-primary-container);
  text-transform: uppercase;
  text-align: right;
}

/* ── Reveal animation (xg-reveal já é tratada por animations.js) ── */
.intergration-section .xg-reveal.active {
  animation: xg-fade-up 0.9s var(--xg-ease-out-expo) forwards;
}

/* ── Responsivo ── */
@media (max-width: 64rem) {
  .intergration-grid {
    flex-direction: column;
    align-items: stretch;
    justify-content: space-around;
    gap: calc(var(--spacing) * 12);
  }

  .intergration-copy {
    max-width: 100%;
  }

  .intergration-stack {
    /* Em telas estreitas o stack assume 100% até 316 px (largura do
       card no design) e centraliza. Mantém o gradient pillar visível
       sem encolher os cards a uma largura ilegível. */
    width: 100%;
    max-width: 316px;
    height: fit-content;
    margin-inline: auto;
  }
}

@media (max-width: 40rem) {
  .intergration-section {
    padding-block: calc(var(--spacing) * 16);
  }
}

/* prefers-reduced-motion: neutraliza a entrada animada */
@media (prefers-reduced-motion: reduce) {
  .intergration-section .xg-reveal {
    opacity: 1;
    animation: none !important;
  }
}

/* =============================================================================
   AUDIENCE — Para quem é (Construída para quem opera em escala)
   Bloco centralizado: eyebrow + headline + descrição (max 578 px), seguido de
   uma row HORIZONTAL com 8 cards de público-alvo. Reutiliza .product-card do
   index.html (mesmo design) — esta seção contribui apenas com layout/wrapper
   e overrides pontuais para tirar as regras de grid (.product-card e
   .product-card:nth-child(4)) que só fazem sentido dentro de .products-grid.
   ============================================================================= */

.audience-section {
  position: relative;
  padding-block: var(--section-gap-y);
  display: flex;
  flex-direction: column;
  align-items: center;
  /* 80 px de gap entre heading e row de cards (Figma). */
  gap: calc(var(--spacing) * 20);
  /* Esconde overflow horizontal além da viewport: a row interna scrolla
     dentro de seu próprio container, não estoura a página. */
  overflow: hidden;
}

/* ── Heading centralizado (mesmo padrão de .features-heading) ── */
.audience-heading {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: calc(var(--spacing) * 2);
  text-align: center;
  /* 578 px = max-width do bloco de heading no Figma; sem token equivalente. */
  max-width: 578px;
  margin-inline: auto;
}

/* (.audience-desc removido — agora usa .xg-section-desc compartilhada) */

/* ── Carrossel marquee — viewport com mask fade ──
   Container .audience-cards é o "viewport" do carrossel: overflow hidden +
   mask-image lateral pra fade nas bordas. O .audience-cards-track contém
   2 sets idênticos de cards e desliza horizontalmente via keyframe
   xg-marquee (translateX 0 → -50%). */
.audience-cards {
  width: 100%;
  overflow: hidden;
  position: relative;
  -webkit-mask-image: linear-gradient(to right, transparent 0, #000 8%, #000 92%, transparent 100%);
  mask-image: linear-gradient(to right, transparent 0, #000 8%, #000 92%, transparent 100%);
}

.audience-cards-track {
  display: flex;
  align-items: stretch;
  gap: calc(var(--spacing) * 5);
  width: max-content;
  /* Velocidade ajustada de 60s → 40s — antes ficava lento demais com
     poucos cards visíveis simultaneamente. 40s ainda permite leitura
     confortável de cada card sem parecer estático. */
  animation: xg-marquee 40s linear infinite;
}

.audience-cards:hover .audience-cards-track,
.audience-cards-track:focus-within {
  animation-play-state: paused;
}

@keyframes xg-marquee {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-50%);
  }
}

/* Override das regras grid de .product-card (que só valem dentro de
   .products-grid). Aqui usamos largura fixa para o marquee. */
.audience-cards-track .product-card {
  flex: 0 0 430px;
  width: 430px;
  min-height: 236px;
  grid-column: auto;
}

/* Neutraliza a regra .product-card:nth-child(4) que centraliza no grid
   de section-products — não se aplica aqui. */
.audience-cards-track .product-card:nth-child(4) {
  grid-column: auto;
}

/* ── Reveal animation (xg-reveal já é tratada por animations.js) ── */
.audience-section .xg-reveal.active {
  animation: xg-fade-up 0.9s var(--xg-ease-out-expo) forwards;
}

/* ── Responsivo ── */
@media (max-width: 64rem) {
  .audience-section {
    gap: calc(var(--spacing) * 12);
    padding-inline: 0;
  }
}

@media (max-width: 40rem) {
  .audience-section {
    padding-block: calc(var(--spacing) * 16);
  }

  .audience-cards-track .product-card {
    flex-basis: 320px;
    width: 320px;
  }

  .audience-cards-track {
    animation-duration: 45s;
  }
}

@media (prefers-reduced-motion: reduce) {
  .audience-section .xg-reveal {
    opacity: 1;
    animation: none !important;
  }
}

/* =============================================================================
   ════════════════════════════════════════════════════════════════════════
   ── MICRO-INTERAÇÕES ──
   Hovers, transições e loops sutis para enriquecer o feedback visual sem
   prejudicar a performance ou acessibilidade. Todos os loops e parallax
   são desligados em prefers-reduced-motion.
   ════════════════════════════════════════════════════════════════════════
   ============================================================================= */

/* ╔════════════════════════════════════════════════════════════════════════════╗
   ║ 1. HERO — Pills, dropdown, icon rail, slot                                ║
   ╚════════════════════════════════════════════════════════════════════════════╝ */

/* Pause da animação "breathe" das pills no hover (já existe transform/scale
   no .moeda-pill:hover do tab-home.css) */
.cv-stage .moeda-pill {
  transition: transform 350ms cubic-bezier(0.16, 1, 0.3, 1),
    box-shadow 350ms cubic-bezier(0.16, 1, 0.3, 1);
}

.cv-stage .moeda-pill:hover {
  animation-play-state: paused;
}

/* Currency dropdown items — slide horizontal sutil + chevron fantasma */
.cv-currency-item {
  position: relative;
  transition: background 200ms ease, color 200ms ease, padding-left 250ms ease;
}

.cv-currency-item::after {
  content: "›";
  position: absolute;
  right: calc(var(--spacing) * 3);
  top: 50%;
  transform: translateY(-50%);
  opacity: 0;
  color: var(--on-primary-container);
  font-weight: var(--font-weight-bold, 700);
  transition: opacity 200ms ease, right 200ms ease;
}

.cv-currency-item:hover {
  padding-left: calc(var(--spacing) * 4);
}

.cv-currency-item:hover::after {
  opacity: 1;
  right: calc(var(--spacing) * 2);
}

/* Icon rail buttons — scale + halo no hover */
.cv-icon-rail-btn {
  transition: transform 250ms cubic-bezier(0.16, 1, 0.3, 1),
    background 200ms ease,
    box-shadow 250ms ease;
}

.cv-icon-rail-btn:hover {
  transform: scale(1.1);
  box-shadow: 0 0 0 4px var(--primary-container);
}

.cv-icon-rail-btn svg {
  transition: color 200ms ease;
}

.cv-icon-rail-btn:hover svg {
  color: var(--on-primary-container);
}

/* Exchange sections (BRL origem / USDT destino) — borda primary no hover */
.cv-exchange-wrap .exchange-section {
  transition: border-color 250ms ease, transform 250ms cubic-bezier(0.16, 1, 0.3, 1);
}

.cv-exchange-wrap .exchange-section:hover {
  border-color: var(--on-primary-container);
}

.cv-exchange-wrap .exchange-section:hover .exchange-value,
.cv-exchange-wrap .exchange-section:hover .exchange-placeholder {
  transform: scale(1.02);
}

.cv-exchange-wrap .exchange-value,
.cv-exchange-wrap .exchange-placeholder {
  transform-origin: left center;
  transition: transform 300ms cubic-bezier(0.16, 1, 0.3, 1);
}

/* Botão "Fazer Conversão" — gradient sweep + chevron slide */
.exchange-btn {
  position: relative;
  overflow: hidden;
  transition: transform 250ms cubic-bezier(0.16, 1, 0.3, 1),
    box-shadow 250ms ease;
}

.exchange-btn::before {
  content: "";
  position: absolute;
  top: 0;
  left: -60%;
  width: 50%;
  height: 100%;
  background: linear-gradient(110deg,
      transparent 30%,
      rgba(255, 255, 255, 0.25) 50%,
      transparent 70%);
  transition: left 600ms cubic-bezier(0.16, 1, 0.3, 1);
  pointer-events: none;
}

.exchange-btn:hover {
  transform: scale(1.02);
  box-shadow: 0 6px 18px rgba(28, 200, 172, 0.25);
}

.exchange-btn:hover::before {
  left: 130%;
}

.exchange-btn svg {
  transition: transform 250ms cubic-bezier(0.16, 1, 0.3, 1);
}

.exchange-btn:hover svg {
  transform: translateX(4px);
}

/* Hero card — sutil pulse loop chamando atenção a cada 8s */
@keyframes cv-card-pulse {

  0%,
  92%,
  100% {
    box-shadow: 0 0 0 0 rgba(28, 200, 172, 0);
  }

  94% {
    box-shadow: 0 0 0 8px rgba(28, 200, 172, 0.15);
  }

  98% {
    box-shadow: 0 0 0 16px rgba(28, 200, 172, 0);
  }
}

.cv-exchange-wrap .slot-exchange .exchange-container {
  animation: cv-card-pulse 8s ease-in-out infinite;
}

/* ╔════════════════════════════════════════════════════════════════════════════╗
   ║ 2. DESCRIPTION CARD — pares, bolt, bullets                                ║
   ╚════════════════════════════════════════════════════════════════════════════╝ */

/* Hover no card inteiro — leve lift */
.description-card {
  transition: transform 400ms cubic-bezier(0.16, 1, 0.3, 1),
    box-shadow 400ms ease;
}

.description-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(28, 200, 172, 0.08);
}

/* Pares Fiat / Stablecoins — hover individual com lift + arrow pulse */
.description-pair {
  transition: transform 300ms cubic-bezier(0.16, 1, 0.3, 1),
    box-shadow 300ms ease,
    border-color 300ms ease;
  cursor: default;
}

.description-pair:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(28, 200, 172, 0.10);
  border-color: var(--on-primary-container);
}

/* Bullets nos pares (BRL/USD/USDT/USDC) — dot anima no hover do item */
.description-pair-list li {
  transition: color 200ms ease;
  cursor: default;
}

.description-pair-list li:hover {
  color: var(--on-primary-container);
}

.description-pair-dot {
  transition: transform 250ms cubic-bezier(0.16, 1, 0.3, 1),
    background 200ms ease;
}

.description-pair-list li:hover .description-pair-dot {
  transform: scale(1.4);
  background: var(--on-primary-container);
}

/* Arrow do meio (entre Fiat e Stablecoins) — pulse no hover do par */
.description-pair-arrow {
  transition: transform 400ms cubic-bezier(0.16, 1, 0.3, 1),
    color 300ms ease;
}

.description-card:hover .description-pair-arrow {
  transform: translateX(3px);
  color: var(--on-primary-container);
}

/* Bolt (raio na faixa verde inferior) — tilt loop sutil + hover destacado */
@keyframes cv-bolt-tilt {

  0%,
  92%,
  100% {
    transform: rotate(0deg);
  }

  94% {
    transform: rotate(-8deg);
  }

  96% {
    transform: rotate(8deg);
  }

  98% {
    transform: rotate(0deg);
  }
}

.description-bolt {
  animation: cv-bolt-tilt 6s cubic-bezier(0.16, 1, 0.3, 1) infinite;
  transition: transform 300ms cubic-bezier(0.16, 1, 0.3, 1),
    box-shadow 300ms ease;
}

.description-bolt:hover {
  animation-play-state: paused;
  transform: scale(1.1) rotate(-5deg);
  box-shadow: 0 4px 16px rgba(28, 200, 172, 0.30);
}

/* ╔════════════════════════════════════════════════════════════════════════════╗
   ║ 3. HOWITWORKS #1 — lista numerada + card de fluxo                         ║
   ╚════════════════════════════════════════════════════════════════════════════╝ */

/* Items numerados — hover destaca número e texto */
.howitworks1-flow-item {
  transition: transform 250ms cubic-bezier(0.16, 1, 0.3, 1);
  cursor: default;
}

.howitworks1-flow-item:hover {
  transform: translateX(2px);
}

.howitworks1-flow-num {
  transition: color 200ms ease, transform 250ms cubic-bezier(0.16, 1, 0.3, 1);
}

.howitworks1-flow-text {
  transition: color 200ms ease;
}

.howitworks1-flow-item:hover .howitworks1-flow-num {
  color: var(--on-primary-container);
  transform: scale(1.15);
}

.howitworks1-flow-item:hover .howitworks1-flow-text {
  color: var(--text-primary);
}

/* Marker rotativo — controlado por JS, ativa via .is-current */
.howitworks1-flow-item.is-current .howitworks1-flow-num {
  color: var(--on-primary-container);
  position: relative;
}

.howitworks1-flow-item.is-current .howitworks1-flow-num::after {
  content: "";
  position: absolute;
  inset: -6px;
  border-radius: 50%;
  background: var(--on-primary-container);
  opacity: 0;
  animation: cv-marker-pulse 1.6s ease-out infinite;
  z-index: -1;
}

@keyframes cv-marker-pulse {
  0% {
    transform: scale(0.6);
    opacity: 0.45;
  }

  80%,
  100% {
    transform: scale(2.2);
    opacity: 0;
  }
}

/* Card de demo (4 linhas com chevrons) */
.howitworks1-card {
  transition: transform 400ms cubic-bezier(0.16, 1, 0.3, 1),
    box-shadow 400ms ease;
}

.howitworks1-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(28, 200, 172, 0.10);
}

/* (Bloco duplicado de .howitworks1-row removido — ele tinha
   margin: 0 -8px que vazava o row do card-inner e quebrava o "hug" do
   card. As regras de hover foram consolidadas no bloco principal mais
   acima, junto com padding e radius corretos.) */

/* Chevrons entre linhas — jump sequencial loop */
@keyframes cv-chevron-jump {

  0%,
  100% {
    transform: translateY(0);
  }

  50% {
    transform: translateY(-2px);
  }
}

.howitworks1-chevron {
  animation: cv-chevron-jump 2s ease-in-out infinite;
}

.howitworks1-chevron:nth-of-type(2) {
  animation-delay: 0.6s;
}

.howitworks1-chevron:nth-of-type(4) {
  animation-delay: 1.2s;
}

.howitworks1-chevron:nth-of-type(6) {
  animation-delay: 1.8s;
}

/* ╔════════════════════════════════════════════════════════════════════════════╗
   ║ 4. CHECKLIST (xg-checklist) — usado em howitworks2/3/intergration         ║
   ╚════════════════════════════════════════════════════════════════════════════╝ */

.xg-checklist-item {
  transition: padding-left 300ms cubic-bezier(0.16, 1, 0.3, 1),
    color 200ms ease;
  cursor: default;
}

.xg-checklist-item span {
  transition: color 200ms ease;
}

.xg-checklist-item:hover {
  padding-left: calc(var(--spacing) * 2);
}

.xg-checklist-item:hover .xg-checklist-icon {
  color: var(--primary-700, var(--on-primary-container));
  transform: scale(1.15);
}

.xg-checklist-item:hover span {
  color: var(--text-primary);
}

.xg-checklist-icon {
  transition: transform 250ms cubic-bezier(0.16, 1, 0.3, 1),
    color 200ms ease;
  /* Para o efeito "draw checkmark" via stroke-dasharray (loop) */
  stroke-dasharray: 24;
  stroke-dashoffset: 0;
}

@keyframes cv-checkmark-draw {
  0% {
    stroke-dashoffset: 24;
  }

  30% {
    stroke-dashoffset: 0;
  }

  90% {
    stroke-dashoffset: 0;
  }

  100% {
    stroke-dashoffset: 0;
  }
}

/* Loop de "redesenhar" o checkmark — escalonado entre os itens da lista */
.xg-checklist .xg-checklist-item:nth-child(1) .xg-checklist-icon {
  animation: cv-checkmark-draw 6s ease-in-out infinite;
  animation-delay: 0s;
}

.xg-checklist .xg-checklist-item:nth-child(2) .xg-checklist-icon {
  animation: cv-checkmark-draw 6s ease-in-out infinite;
  animation-delay: 0.4s;
}

.xg-checklist .xg-checklist-item:nth-child(3) .xg-checklist-icon {
  animation: cv-checkmark-draw 6s ease-in-out infinite;
  animation-delay: 0.8s;
}

.xg-checklist .xg-checklist-item:nth-child(4) .xg-checklist-icon {
  animation: cv-checkmark-draw 6s ease-in-out infinite;
  animation-delay: 1.2s;
}

.xg-checklist .xg-checklist-item:nth-child(5) .xg-checklist-icon {
  animation: cv-checkmark-draw 6s ease-in-out infinite;
  animation-delay: 1.6s;
}

/* ╔════════════════════════════════════════════════════════════════════════════╗
   ║ 5. HOWITWORKS #2 — card com badges (gradient bg + 4 badges)               ║
   ╚════════════════════════════════════════════════════════════════════════════╝ */

.howitworks2-card {
  transition: transform 400ms cubic-bezier(0.16, 1, 0.3, 1);
}

.howitworks2-card:hover {
  transform: translateY(-3px);
}

/* Badges individuais — hover lift + ícone pulse */
.howitworks2-badge {
  transition: transform 300ms cubic-bezier(0.16, 1, 0.3, 1),
    box-shadow 300ms ease,
    border-color 300ms ease;
  cursor: default;
}

.howitworks2-badge:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(28, 200, 172, 0.12);
  border-color: var(--on-primary-container);
}

.howitworks2-badge-icon {
  transition: transform 350ms cubic-bezier(0.34, 1.56, 0.64, 1);
}

.howitworks2-badge:hover .howitworks2-badge-icon {
  transform: scale(1.12);
}

.howitworks2-badge-text {
  transition: color 200ms ease;
}

.howitworks2-badge:hover .howitworks2-badge-text {
  color: var(--on-primary-container);
}

/* ╔════════════════════════════════════════════════════════════════════════════╗
   ║ 6. HOWITWORKS #3 — status pill + step cards                                ║
   ╚════════════════════════════════════════════════════════════════════════════╝ */

/* Status pill dot — pulse halo loop */
.howitworks3-status-dot {
  position: relative;
}

.howitworks3-status-dot::after {
  content: "";
  position: absolute;
  inset: -3px;
  border-radius: 50%;
  background: var(--primary);
  opacity: 0;
  animation: cv-marker-pulse 1.8s ease-out infinite;
  z-index: -1;
}

.howitworks3-status {
  transition: transform 250ms cubic-bezier(0.16, 1, 0.3, 1),
    box-shadow 300ms ease;
}

.howitworks3-status:hover {
  transform: scale(1.02);
  box-shadow: 0 4px 16px rgba(28, 200, 172, 0.15);
}

.howitworks3-status:hover .howitworks3-status-dot::after {
  animation-duration: 0.8s;
}

/* Step cards (Etapa 1/2/3) — hover lift + badge slide */
.howitworks3-step {
  transition: transform 350ms cubic-bezier(0.16, 1, 0.3, 1),
    box-shadow 350ms ease,
    border-color 300ms ease;
}

.howitworks3-step:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 28px rgba(28, 200, 172, 0.12);
  border-color: var(--on-primary-container);
}

.howitworks3-step-badge {
  transition: right 300ms cubic-bezier(0.16, 1, 0.3, 1),
    filter 300ms ease;
}

.howitworks3-step:hover .howitworks3-step-badge {
  right: -10px;
  filter: drop-shadow(0 2px 6px rgba(28, 200, 172, 0.30));
}

.howitworks3-step-icon {
  transition: transform 300ms cubic-bezier(0.16, 1, 0.3, 1);
}

.howitworks3-step:hover .howitworks3-step-icon {
  transform: scale(1.1);
}

/* Sequential highlight chain — controlado por JS via .is-active */
.howitworks3-step.is-active {
  border-color: var(--on-primary-container);
}

.howitworks3-step.is-active .howitworks3-step-icon {
  color: var(--on-primary-container);
  transform: scale(1.05);
}

/* ╔════════════════════════════════════════════════════════════════════════════╗
   ║ 7. FEATURES — pills de redes                                              ║
   ╚════════════════════════════════════════════════════════════════════════════╝ */

/* Hover já vem do .moeda-pill base. Adicionar destaque do nome */
.features-networks-list .moeda-pill {
  cursor: default;
}

.features-networks-list .moeda-pill .features-network-name {
  transition: color 200ms ease;
}

.features-networks-list .moeda-pill:hover .features-network-name {
  color: var(--on-primary-container);
}

/* Pulse aleatório controlado por JS via .is-pulsing */
.features-networks-list .moeda-pill.is-pulsing {
  animation: cv-pill-pulse 1.4s cubic-bezier(0.4, 0, 0.2, 1);
}

@keyframes cv-pill-pulse {
  0% {
    box-shadow: 0 0 0 0 rgba(28, 200, 172, 0);
  }

  30% {
    box-shadow: 0 0 0 8px rgba(28, 200, 172, 0.20);
  }

  100% {
    box-shadow: 0 0 0 16px rgba(28, 200, 172, 0);
  }
}

/* ╔════════════════════════════════════════════════════════════════════════════╗
   ║ 8. INTERGRATION — step cards numerados (chain flow)                        ║
   ╚════════════════════════════════════════════════════════════════════════════╝ */

.intergration-step {
  transition: transform 300ms cubic-bezier(0.16, 1, 0.3, 1),
    box-shadow 300ms ease,
    border-color 300ms ease;
}

.intergration-step:hover {
  transform: translateY(-2px) translateX(4px);
  box-shadow: 0 8px 20px rgba(28, 200, 172, 0.12);
  border-color: var(--on-primary-container);
}

.intergration-step-num {
  transition: transform 300ms cubic-bezier(0.34, 1.56, 0.64, 1),
    background 200ms ease;
}

.intergration-step:hover .intergration-step-num {
  transform: scale(1.1);
}

.intergration-step-name,
.intergration-step-tag {
  transition: color 200ms ease;
}

.intergration-step:hover .intergration-step-name {
  color: var(--text-primary);
}

/* Chain flow — controlado por JS via .is-flowing */
.intergration-step.is-flowing {
  border-color: var(--on-primary-container);
  box-shadow: 0 6px 18px rgba(28, 200, 172, 0.20);
}

.intergration-step.is-flowing .intergration-step-num {
  transform: scale(1.15);
  background: var(--on-primary-container);
  color: var(--surface-1);
}

/* ╔════════════════════════════════════════════════════════════════════════════╗
   ║ 9. AUDIENCE — product cards                                                ║
   ╚════════════════════════════════════════════════════════════════════════════╝ */

/* O carrossel já pausa no hover (regra existente). Adicionar lift individual */
.audience-cards-track .product-card {
  transition: transform 350ms cubic-bezier(0.16, 1, 0.3, 1),
    box-shadow 350ms ease;
}

.audience-cards-track .product-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 40px rgba(28, 200, 172, 0.15);
}

/* Footer do product-card já recebe primary-container no hover (rule existente).
   Adicionar deslize do svg do "Ver mais" — sobrescreve a regra padrão para 6px */
.audience-cards-track .product-card-link svg {
  transition: transform 250ms cubic-bezier(0.16, 1, 0.3, 1);
}

.audience-cards-track .product-card:hover .product-card-link svg {
  transform: translateX(6px);
}

/* ╔════════════════════════════════════════════════════════════════════════════╗
   ║ 10. CTA FINAL                                                              ║
   ╚════════════════════════════════════════════════════════════════════════════╝ */

/* Botão "Falar com o time" — chevron desliza + glow expandido (já tem
   rings parallax via JS). Aprimoramentos sutis. */
.cta-btn-primary {
  transition: transform 300ms cubic-bezier(0.16, 1, 0.3, 1);
}

.cta-btn-primary:hover {
  transform: scale(1.03);
}

.cta-btn-primary svg {
  transition: transform 300ms cubic-bezier(0.16, 1, 0.3, 1);
}

.cta-btn-primary:hover svg {
  transform: translateX(6px);
}

/* ╔════════════════════════════════════════════════════════════════════════════╗
   ║ 11. ACCESSIBILITY — desliga TUDO em prefers-reduced-motion                 ║
   ╚════════════════════════════════════════════════════════════════════════════╝ */

@media (prefers-reduced-motion: reduce) {

  /* Desliga todos os loops infinitos */
  .description-bolt,
  .howitworks1-chevron,
  .xg-checklist .xg-checklist-icon,
  .features-networks-list .moeda-pill.is-pulsing,
  .cv-exchange-wrap .slot-exchange .exchange-container {
    animation: none !important;
  }

  .howitworks3-status-dot::after,
  .howitworks1-flow-item.is-current .howitworks1-flow-num::after {
    animation: none !important;
    opacity: 0 !important;
  }

  /* Mantém transições essenciais (cor/borda) mas reduz motion */
  *,
  *::before,
  *::after {
    transition-duration: 100ms !important;
  }

  /* Hovers que envolvem transform — desativa só o transform, mantém cor */
  .moeda-pill:hover,
  .description-card:hover,
  .description-pair:hover,
  .description-bolt:hover,
  .howitworks1-flow-item:hover,
  .howitworks1-card:hover,
  .howitworks2-card:hover,
  .howitworks2-badge:hover,
  .howitwor