/* == Fontes ================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inconsolata:wght@400;600&family=Inter:wght@400;500;600;700;800&family=Source+Serif+4:wght@400;600;700&display=swap');

/* == Tokens ================================================================ */
:root {

  /* Cores */
  --color-primary:         #C4452C;
  --color-primary-light:    #eb795d;
  --color-primary-surface: #9E3621;
  --color-primary-opacity: rgba(196, 69, 44, 0.3);

  --color-light:           #f3f1f0;
  --color-light-surface:   #e7e5e3;
  --color-light-opacity:   rgba(243, 241, 240, 0.8);

  --color-dark:            #1f1e1e;
  --color-dark-surface:    #333233;
  --color-dark-opacity:    rgba(36, 34, 35, 0.6);

  --color-error:           #9E2A1A;
  --color-success:         #2E6E4E;
  --color-warning:          #B88A1A;

  --color-secondary-dark:   #080808;
  --color-text-muted:       #8A8A8A;
  --color-background-muted: #E3DFD6;
  --color-border:          #D8D4CC;
  --color-border-strong:    #B0ABA1;

  /* Tipografia */
  --font-titles: "Source Serif 4", serif;
  --font-text:   "Inter", sans-serif;
  --font-label:  "Inconsolata", monospace;

  --weight-regular:   400;
  --weight-medium:    500;
  --weight-semibold:  600;
  --weight-bold:      700;
  --weight-extrabold: 800;

  /* Espaçamento (escala 4px) */
  --space-1:  0.25rem;
  --space-2:  0.5rem;
  --space-3:  0.75rem;
  --space-4:  1rem;
  --space-5:  1.25rem;
  --space-6:  1.5rem;
  --space-8:  2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --space-24: 6rem;

  /* Raios */
  --radius-s:    0.5rem;
  --radius-m:    1rem;
  --radius-l:    1.5rem;
  --radius-pill: 20rem;

  /* Sombras */
  --shadow-s: 0 1px 3px rgba(0,0,0,.08);
  --shadow-m: 0 4px 16px rgba(0,0,0,.10);
  --shadow-l: 0 8px 32px rgba(0,0,0,.12);

  /* Transições */
  --transition-fast:   0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
  --transition-medium: 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  --transition-slow:   0.8s cubic-bezier(0.23, 1, 0.32, 1);

  /* Layout */
  --max-width:         90rem;   /* 1440px — container padrão */
  --max-width-prose:   50rem;   /* 800px  — texto corrido */
  --header-height:     4.5rem;
  --section-padding-y: clamp(3rem, 9vw, 5.5rem);
  --section-padding-x: clamp(1.25rem, 5vw, 2rem);
}

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

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

@media (prefers-reduced-motion: no-preference) {
  html { scroll-behavior: smooth; }
}

[id] { scroll-margin-top: calc(var(--header-height) + 1rem); }

body {
  background-color: var(--color-light);
  color: var(--color-dark);
  font: 400 var(--text-base) var(--font-text);
  line-height: 1.65;
  min-height: 100dvh;
  overflow-x: hidden;
}

img, video, svg { max-width: 100%; display: block; height: auto; }
ul, ol { list-style: none; }
h1, h2, h3, h4, h5, h6 { text-wrap: balance; }
p { text-wrap: pretty; }
h1, h2, h3, h4, h5, h6, a, p, li { text-decoration: none; color: inherit; }
a, button { cursor: pointer; }
button { border: none; background: none; font: inherit; color: inherit; }
input, textarea, select { font: inherit; color: inherit; }

input:focus, textarea:focus, select:focus, button:focus { outline: revert; }

:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 3px;
  border-radius: var(--radius-s);
}

table { border-collapse: collapse; width: 100%; }

::placeholder { color: var(--color-dark-surface); opacity: 0.5; }
::selection   { background-color: var(--color-primary-opacity); }

/* == Tipografia ============================================================
   Escala padronizada — todos os tamanhos saem dos tokens --text-* definidos
   na camada de melhorias (seção "ESCALA TIPOGRÁFICA"). Nada de valores soltos.
   ========================================================================== */
p, .body, input, select, label, textarea, li {
  font: 400 var(--text-base) var(--font-text);
  line-height: 1.7;
  text-wrap: pretty;
}

h1, .h1 { font: 400 var(--text-5xl) var(--font-titles); line-height: 1.08; letter-spacing: -0.015em; }
h2, .h2 { font: 400 var(--text-3xl) var(--font-titles); line-height: 1.15; letter-spacing: -0.01em; }
h3, .h3 { font: 400 var(--text-2xl) var(--font-titles); line-height: 1.25; }
h4, .h4 { font: 500 var(--text-md)  var(--font-text);   line-height: 1.4; }

a, .link, button { font: 500 var(--text-nav) var(--font-text); }

.link {
  position: relative;
  text-decoration: none;
}

.link::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 0;
  height: 1px;
  background: currentColor;
  transition: width var(--transition-fast);
}

.link:hover::after {
  width: 100%;
}

.label {
  font: 600 var(--text-label) var(--font-label);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-dark-surface);
}

/* Modificadores do .label */
.label--on-dark { color: var(--color-light-opacity); }
.label--primary { color: var(--color-primary); }
.label--prose   { text-transform: none; letter-spacing: 0; } /* para labels em contexto de parágrafo */

/* ══════════════════════════════════════════════════════════════════════════
   Layout base

   Padrão unificado:
   - .section   → full-width (background ocupa 100% da viewport).
   - .container → limitado a 1440px e centralizado; flex-column com gap.
   - .stack     → agrupa elementos relacionados com gap menor.
   ══════════════════════════════════════════════════════════════════════════ */

/* == section ============================================================== */
.section {
  width: 100%;
  padding: var(--section-padding-y) var(--section-padding-x);
}

.section--dark    { background-color: var(--color-dark);          color: var(--color-light); }
.section--surface { background-color: var(--color-light-surface); }
.section--accent  { background-color: var(--color-primary);       color: #fff; }

/* == container ============================================================ */
.container {
  width: 100%;
  max-width: var(--max-width);
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-10);
}

.container--prose  { max-width: var(--max-width-prose); margin-inline: auto; }
.container--center { align-items: center; text-align: center; gap: var(--space-6); }

/* == stack ================================================================ */
.stack      { display: flex; flex-direction: column; gap: var(--space-4); }
.stack--xs  { gap: var(--space-2); }
.stack--sm  { gap: var(--space-3); }
.stack--lg  { gap: var(--space-6); }
.stack--xl  { gap: var(--space-8); }

/* == Títulos centralizados em seções específicas =========================== */
#diferenciais .stack--sm,
#para-quem   .stack--sm,
#precos      .stack--sm,
#faq         .stack--sm {
  text-align: center;
  align-items: center;
  max-width: 50rem;
  margin-inline: auto;
}

/* Garante que o parágrafo abaixo do título também centralize bem */
#precos .stack--sm > p,
#faq    .stack--sm > p {
  max-width: 38rem;
  margin-inline: auto;
}

/* == Grids de conteúdo ==================================================== */
.grid-2 { display: grid; grid-template-columns: 1fr; gap: var(--space-10); }
.grid-3 { display: grid; grid-template-columns: 1fr; gap: var(--space-8); }
.grid-4 { display: grid; grid-template-columns: 1fr; gap: var(--space-8); }

@media (min-width: 640px)  { .grid-3 { grid-template-columns: 1fr 1fr; } .grid-4 { grid-template-columns: 1fr 1fr; } }
@media (min-width: 768px)  { .grid-2 { grid-template-columns: 1fr 1fr; gap: var(--space-8); } }
@media (min-width: 1024px) { .grid-3 { grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
                             .grid-4 { grid-template-columns: repeat(4, 1fr); gap: var(--space-6); } }

/* ══════════════════════════════════════════════════════════════════════════
   Componentes
   ══════════════════════════════════════════════════════════════════════════ */

/* == btn ================================================================== */
.btn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 0.625rem;
  padding: 0.625rem 2rem;
  border-radius: var(--radius-pill);
  background-color: var(--color-dark);
  color: var(--color-light);
  font: 500 var(--text-base) var(--font-text);
  line-height: 1;
  border: 2px solid transparent;
  transition: background-color var(--transition-fast), color var(--transition-fast);
  white-space: nowrap;
  user-select: none;
}
.btn:hover    { background-color: var(--color-dark-surface); }
.btn:disabled { opacity: 0.45; pointer-events: none; }

/* Variantes de cor */
.btn--white               { background-color: var(--color-light); color: var(--color-dark); }
.btn--white:hover         { background-color: var(--color-light-surface); }
.btn--primary             { background-color: var(--color-primary); color: #fff; }
.btn--primary:hover       { background-color: var(--color-primary-surface); }
.btn--outline             { background-color: transparent; border-color: var(--color-dark); color: var(--color-dark); }
.btn--outline:hover       { background-color: var(--color-dark); color: var(--color-light); }
.btn--outline-primary     { background-color: transparent; border-color: var(--color-primary); color: var(--color-primary); }
.btn--outline-primary:hover { background-color: var(--color-primary); color: #fff; }

/* Variantes de tamanho */
.btn--sm   { padding: 0.4375rem 1.25rem; font-size: 0.8125rem; }
.btn--lg   { padding: 0.875rem 2.5rem;   font-size: 1.0625rem; }
.btn--icon { padding: 0.625rem; border-radius: var(--radius-m); }

/* == site-header ========================================================== */
.site-header {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 100;
  height: 5rem;
  background-color: var(--color-light);
  border-bottom: 1px solid transparent;
  transition: background-color var(--transition-medium), border-color var(--transition-medium), height var(--transition-medium);
}
.site-header.is-scrolled {
  height: var(--header-height);
  background-color: var(--color-light);
  border-color: var(--color-border);
  box-shadow: var(--shadow-s);
}

.site-header__nav {
  width: 100%; max-width: var(--max-width);
  margin-inline: auto;
  padding-inline: clamp(1rem, 3vw, 2rem);
  height: 100%;
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-8);
}

.site-header__logo-link { display: inline-flex; align-items: center; }
.site-header__logo      { height: 3.25rem; width: auto; max-width: none; transition: height var(--transition-medium); }
.site-header.is-scrolled .site-header__logo { height: 2.75rem; }

.site-header__nav-list { display: flex; align-items: center; gap: var(--space-6); }

.site-header__menu-trigger { display: none; }

@media (max-width: 767px) {
  .site-header__nav-list     { display: none; }
  .site-header__menu-trigger { display: flex; }
}

/* == mobile-menu ========================================================== */
.mobile-menu {
  display: none; position: fixed; inset: 0; z-index: 200;
  background-color: var(--color-light);
  padding: var(--space-16) var(--space-6) var(--space-8);
  flex-direction: column; gap: var(--space-6);
}
.mobile-menu.is-open { display: flex; }

.mobile-menu__close { position: absolute; top: var(--space-6); right: var(--space-6); }

/* == hero ================================================================= */
.hero {
  position: relative;
  /* Altura reduzida: antes 100svh. Agora um bloco mais enxuto e padronizado,
     com piso/teto controlados para não estourar em telas muito altas. */
  min-height: clamp(30rem, 72svh, 42rem);
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  background-color: var(--color-dark);
}

.hero__bg     { position: absolute; inset: 0; z-index: 0; background-color: var(--color-dark); }
.hero__bg img { width: 100%; height: 100%; object-fit: cover; object-position: center; }

.hero__overlay {
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(to top, var(--color-dark) 0%, var(--color-dark-opacity) 50%, transparent 100%);
}

.hero__content {
  position: relative; z-index: 2;
  width: 100%;
  max-width: var(--max-width);
  margin-inline: auto;
  padding: 0 var(--section-padding-x) var(--space-16);
  color: var(--color-light);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}
.hero__content .label,
.hero__content h1,
.hero__content p    { color: var(--color-light); }
.hero__content .btn { margin-top: var(--space-4); align-self: flex-start; }

/* == card ================================================================= */
.card {
  display: flex; flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-6);
  border-radius: var(--radius-m);
  background-color: var(--color-light);
}

.card h3 {
  text-wrap: nowrap;
}

/* Variantes de aparência */
.card--on-dark {
  background-color: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-top: 3px solid var(--color-primary);
  color: var(--color-light);
  border-radius: var(--radius-m);
}
.card--on-dark .label { color: var(--color-primary); }

.card__icon {
  font-size: 1.75rem;
  color: var(--color-primary);
  line-height: 1;
}

/* == audience-card =========================================================
   Card simples para a seção "Para quem é".
   Sem borda proeminente — leitura rápida, ícone + título + texto curto.
   ========================================================================== */
.audience-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-5) 0;
  border-top: 1px solid var(--color-border);
}

.card-row {
  display: flex;
  gap: var(--space-4);
}

.audience-card__icon {
  font-size: 1.5rem;
  color: var(--color-primary);
  line-height: 1;
}

.audience-card__title {
  font: 400 clamp(1.1rem, 2.5vw, 1.25rem) var(--font-titles);
}

.audience-card__text { color: var(--color-dark-surface); }

.audience-card__tags {
  text-transform: none;
  letter-spacing: 0;
  color: var(--color-text-muted);
}

/* == timeline ============================================================= */
.timeline {
  display: flex; flex-direction: column; gap: var(--space-8);
  max-width: 44rem; margin-inline: auto;
}

.timeline__item {
  display: flex; gap: var(--space-6); position: relative;
  padding-bottom: var(--space-8); align-items: flex-start;
}
.timeline__item:last-child { padding-bottom: 0; }

.timeline__body { display: flex; flex-direction: column; gap: var(--space-3); }

.timeline__number {
  font: 400 clamp(2.5rem, 6vw, 4rem) var(--font-titles);
  color: var(--color-primary); line-height: 1;
  flex-shrink: 0; min-width: 3rem;
}

.timeline__connector {
  position: absolute; left: 1.5rem; top: 4rem; bottom: 0;
  width: 1px; background-color: var(--color-border-strong);
}
.timeline__item:last-child .timeline__connector { display: none; }

/* == accordion ============================================================ */
.accordion__item             { border-bottom: 1px solid var(--color-border); }
.accordion__item:first-child { border-top: 1px solid var(--color-border); }
.accordion__item--open .accordion__icon { transform: rotate(45deg); }

.accordion__trigger {
  width: 100%;
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-5) 0;
  text-align: left;
  background: none; border: none; cursor: pointer; color: inherit;
}
.accordion__trigger:hover { color: var(--color-primary); }

.accordion__question { font: 400 clamp(1.0625rem, 2.4vw, 1.25rem) var(--font-titles); margin: 0; }

.accordion__icon {
  font-size: 1.5rem; color: var(--color-primary);
  transition: transform var(--transition-fast);
  flex-shrink: 0; line-height: 1;
}

.accordion__content { display: grid; grid-template-rows: 0fr; overflow: hidden; transition: grid-template-rows var(--transition-medium); }
.accordion__item--open .accordion__content { grid-template-rows: 1fr; }
.accordion__body                         { min-height: 0; padding: 0; }

/* == price-table ========================================================== */
.price-table__wrapper { overflow-x: auto; border-radius: var(--radius-m); border: 1px solid var(--color-border); }

.price-table__table { font-family: var(--font-label); font-size: 0.9375rem; background-color: var(--color-light); }

.price-table__head tr { background-color: var(--color-dark); color: var(--color-light); }
.price-table__head th { padding: var(--space-3) var(--space-10); text-align: left; font-weight: 600; letter-spacing: 0.04em; }

.price-table__body tr { border-bottom: 1px solid var(--color-border); }
.price-table__body td { padding: var(--space-3) var(--space-10); }

.price-table__head th:first-child,
.price-table__body td:first-child {
  width: 70%;
}

/* == price-tooltip ======================================================== */
.price-cell {
  display: inline-flex;
  align-items: flex-start;   
  gap: 0.25rem;
  white-space: nowrap;
}

.price-tooltip {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: help;
  outline: none;
}

.price-tooltip__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 0.875rem;           
  height: 0.875rem;
  margin-top: 0.125rem;      
  border-radius: 50%;
  background-color: var(--color-border);
  color: var(--color-dark);
  font-size: 0.625rem;     
  font-weight: 700;
  line-height: 1;
  transition: background-color var(--transition-fast);
}

.price-tooltip:hover .price-tooltip__icon,
.price-tooltip:focus-visible .price-tooltip__icon {
  background-color: var(--color-dark);
  color: var(--color-light);
}

.price-tooltip__bubble {
  position: absolute;
  bottom: calc(100% + 0.5rem);
  left: 50%;
  transform: translateX(-50%) translateY(4px);
  width: max-content;
  max-width: 14rem;
  padding: var(--space-2) var(--space-3);
  background-color: var(--color-dark);
  color: var(--color-light);
  border-radius: var(--radius-s);
  font-size: 0.8125rem;
  font-weight: 400;
  line-height: 1.4;
  text-align: center;
  white-space: normal;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition:
    opacity var(--transition-fast),
    visibility var(--transition-fast),
    transform var(--transition-fast);
  z-index: 10;
}

.price-tooltip__bubble::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 6px solid transparent;
  border-top-color: var(--color-dark);
}

.price-tooltip:hover .price-tooltip__bubble,
.price-tooltip:focus-visible .price-tooltip__bubble,
.price-tooltip:focus-within .price-tooltip__bubble {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}
/* == modal ================================================================ */
.modal-overlay {
  position: fixed; inset: 0; z-index: 300;
  background-color: var(--color-dark-opacity);
  display: flex; align-items: center; justify-content: center;
  padding: var(--space-4);
  backdrop-filter: blur(4px);
}

.modal {
  background-color: var(--color-light); border-radius: var(--radius-l);
  max-width: 48rem; width: 100%; max-height: 90svh;
  overflow-y: auto; box-shadow: var(--shadow-l);
}

.modal__header {
  position: sticky; top: 0; z-index: 1;
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-6);
  border-bottom: 1px solid var(--color-border);
  background-color: var(--color-light);
}

.modal__body  { padding: var(--space-6); display: flex; flex-direction: column; gap: var(--space-4); }

.modal__close       { font-size: 1.5rem; line-height: 1; color: var(--color-dark-surface); transition: color var(--transition-fast); }
.modal__close:hover { color: var(--color-dark); }

/* == split ================================================================ */
.split { display: grid; grid-template-columns: 1fr; gap: var(--space-10); align-items: center; }

.split__media   { border-radius: var(--radius-l); overflow: hidden; }
/* Espaçamento padronizado: o conteúdo do split usa o mesmo gap em todas as
   seções (antes vinha sobrescrito por style="gap:..." inline no HTML). */
.split__content { display: flex; flex-direction: column; gap: var(--space-8); }
.split__content > .stack { gap: var(--space-3); }
/* Timeline dentro de um split não centraliza (ocupa a coluna inteira). */
.timeline--flush { margin-inline: 0; max-width: none; }

.where-content {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

@media (min-width: 768px) {
  .split                          { grid-template-columns: 1fr 1fr; gap: var(--space-12); }
  .split--reverse .split__media   { order: 2; }
  .split--reverse .split__content { order: 1; }
}

/* == map-embed ============================================================ */
.map-embed        { border-radius: var(--radius-l); overflow: hidden; height: 600px; }
.map-embed iframe { width: 100%; height: 100%; border: 0; }

/* == location-info ======================================================== */
.location-info {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-3) var(--space-5);
}

/* == manifesto =============================================================
   Bloco de texto centralizado com linha ornamental (seção "O ofício").
   Largura máxima de 964px, dentro de .section--dark.
   ========================================================================== */
.manifesto {
  width: 100%;
  max-width: 60.25rem; /* 964px */
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--space-6);
}

.manifesto__title {
  font: 400 clamp(1.75rem, 5vw, 2.5rem) var(--font-titles);
  color: var(--color-light);
}

.manifesto__divider {
  width: 10rem;
  height: 1px;
  background-color: #E8651A;
  border: none;
  flex-shrink: 0;
}

.manifesto__body {
  max-width: 44rem;
  font: 400 1rem var(--font-text);
  line-height: 1.75;
  color: var(--color-light-surface);
}

/* == site-footer ========================================================== */
.site-footer { background-color: var(--color-light-surface); border-top: 1px solid var(--color-border); }

.site-footer__grid {
  width: 100%; max-width: var(--max-width); margin-inline: auto;
  padding: var(--space-12) var(--section-padding-x);
  display: grid; grid-template-columns: 1fr; gap: var(--space-8);
}

.site-footer__bottom {
  width: 100%; max-width: var(--max-width); margin-inline: auto;
  padding: var(--space-5) var(--section-padding-x);
  border-top: 1px solid var(--color-border);
  text-align: center;
}

/* Grid de 3 colunas (removida a coluna "Acompanhe") */
@media (min-width: 640px)  { .site-footer__grid { grid-template-columns: 1fr 1fr; gap: var(--space-8); } }
@media (min-width: 1024px) { .site-footer__grid { grid-template-columns: 2fr 1fr 1fr; gap: var(--space-8); } }

/* Links com ícone no footer */
.site-footer__link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--color-dark-surface);
  transition: color var(--transition-fast);
}
.site-footer__link:hover { color: var(--color-primary); }
.site-footer__link i     { font-size: 1rem; flex-shrink: 0; }

/* Itens de lista sem link (ícone + texto) */
.site-footer li { display: flex; align-items: center; gap: var(--space-2); }
.site-footer li > i { font-size: 1rem; color: var(--color-text-muted); flex-shrink: 0; }

/* ══════════════════════════════════════════════════════════════════════════
   Utilitários  (prefixo u-)
   ══════════════════════════════════════════════════════════════════════════ */
.u-hidden       { display: none !important; }
.u-sr-only      { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.u-flex-center  { display: flex; align-items: center; justify-content: center; }
.u-flex-wrap    { display: flex; align-items: center; flex-wrap: wrap; }
.u-flex-between { display: flex; align-items: center; justify-content: space-between; }
.u-flex-col     { display: flex; flex-direction: column; }

/* == Animações (controladas via JS) ======================================= */
.js-animate-ready [data-animate]               { opacity: 0; transition: opacity var(--transition-medium), transform var(--transition-medium); }
.js-animate-ready [data-animate="fade-up"]     { transform: translateY(2rem); }
.js-animate-ready [data-animate="fade-down"]   { transform: translateY(-2rem); }
.js-animate-ready [data-animate="slide-right"] { transform: translateX(-3rem); }
.js-animate-ready [data-animate="slide-left"]  { transform: translateX(3rem); }
.js-animate-ready [data-animate="scale-in"]    { transform: scale(0.92); }
.js-animate-ready [data-animate].is-visible    { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  .js-animate-ready [data-animate] { opacity: 1; transform: none; transition: none; }
}

/* ╔══════════════════════════════════════════════════════════════════════════╗
   ║                                                                          ║
   ║   MELHORIAS — USABILIDADE · DESIGN · EFEITOS                              ║
   ║                                                                          ║
   ║   Camada complementar adicionada sobre a base acima. Tudo aqui é          ║
   ║   aditivo: refina componentes existentes, padroniza espaçamentos e        ║
   ║   acrescenta micro-interações. Nenhuma regra remove comportamento —       ║
   ║   apenas aprimora. Todo movimento respeita prefers-reduced-motion         ║
   ║   (ver bloco final "REDUÇÃO DE MOVIMENTO").                               ║
   ║                                                                          ║
   ╚══════════════════════════════════════════════════════════════════════════╝ */

/* ══════════════════════════════════════════════════════════════════════════
   01 · TOKENS COMPLEMENTARES
   Novos custom properties para sombras em camadas, easings nomeados,
   espaçamentos semânticos e cores derivadas. Mantêm a escala original.
   ══════════════════════════════════════════════════════════════════════════ */
:root {
  /* Espaçamento semântico — dá nome ao "porquê" de cada gap/margem.
     Tudo deriva da escala 4px original, então nada quebra o ritmo. */
  --gap-section:      clamp(2.5rem, 6vw, 4rem);   /* entre blocos de uma seção */
  --gap-block:        var(--space-8);             /* entre componentes vizinhos */
  --gap-cluster:      var(--space-4);             /* entre itens de um grupo    */
  --gap-tight:        var(--space-2);             /* entre rótulo e valor       */
  --pad-card:         clamp(1.25rem, 3vw, 1.75rem);
  --pad-inline-edge:  var(--section-padding-x);

  /* Sombras em camadas — profundidade mais natural que sombra única. */
  --shadow-xs:    0 1px 2px rgba(15, 12, 10, 0.06);
  --shadow-soft:  0 2px 4px rgba(15, 12, 10, 0.05),
                  0 6px 16px rgba(15, 12, 10, 0.07);
  --shadow-card:  0 1px 2px rgba(15, 12, 10, 0.04),
                  0 8px 24px rgba(15, 12, 10, 0.08);
  --shadow-lift:  0 2px 6px rgba(15, 12, 10, 0.08),
                  0 18px 40px rgba(15, 12, 10, 0.14);
  --shadow-pop:   0 4px 10px rgba(15, 12, 10, 0.10),
                  0 24px 60px rgba(15, 12, 10, 0.20);
  --shadow-inset: inset 0 1px 0 rgba(255, 255, 255, 0.06);

  /* Brilho de destaque — usado em foco e hover de elementos primários. */
  --glow-primary: 0 0 0 4px rgba(196, 69, 44, 0.16);
  --glow-soft:    0 6px 22px rgba(196, 69, 44, 0.28);

  /* Easings nomeados — leitura mais clara que a curva crua. */
  --ease-out-soft:   cubic-bezier(0.22, 0.61, 0.36, 1);
  --ease-out-back:   cubic-bezier(0.34, 1.56, 0.64, 1);
  --ease-in-out-ct:  cubic-bezier(0.65, 0, 0.35, 1);
  --ease-spring:     cubic-bezier(0.16, 1, 0.3, 1);

  /* Durações — padroniza o "tempo" das micro-interações. */
  --dur-instant: 0.12s;
  --dur-quick:   0.22s;
  --dur-base:    0.34s;
  --dur-slow:    0.6s;
  --dur-crawl:   0.9s;

  /* Cores derivadas para superfícies translúcidas e bordas suaves. */
  --tint-primary-08: rgba(196, 69, 44, 0.08);
  --tint-primary-14: rgba(196, 69, 44, 0.14);
  --tint-primary-22: rgba(196, 69, 44, 0.22);
  --tint-dark-04:    rgba(31, 30, 30, 0.04);
  --tint-dark-08:    rgba(31, 30, 30, 0.08);
  --tint-light-06:   rgba(255, 255, 255, 0.06);
  --tint-light-10:   rgba(255, 255, 255, 0.10);
  --tint-light-16:   rgba(255, 255, 255, 0.16);

  /* Espessura de traços decorativos. */
  --rule-thin:   1px;
  --rule-medium: 2px;
  --rule-thick:  3px;

  /* Largura de leitura confortável para textos soltos. */
  --measure:        65ch;
  --measure-short:  42ch;
}

/* ══════════════════════════════════════════════════════════════════════════
   02 · RITMO VERTICAL E PADRONIZAÇÃO DE ESPAÇAMENTO
   Centraliza as decisões de espaçamento que antes estavam espalhadas em
   styles inline. Mesma família de valores para todos os elementos.
   ══════════════════════════════════════════════════════════════════════════ */

/* Container: gap único e previsível entre blocos internos. */
.container { gap: var(--gap-section); }
.container--prose { gap: var(--space-8); }

/* Primeiro e último filho nunca somam margem extra com o padding da seção. */
.section > .container > :first-child,
.section > .manifesto > :first-child { margin-top: 0; }
.section > .container > :last-child,
.section > .manifesto > :last-child  { margin-bottom: 0; }

/* Stacks com gaps consistentes — reforça a escala mesmo se algo for aninhado. */
.stack          { gap: var(--space-4); }
.stack--xs      { gap: var(--space-2); }
.stack--sm      { gap: var(--space-3); }
.stack--lg      { gap: var(--space-6); }
.stack--xl      { gap: var(--space-8); }

/* Texto corrido: parágrafos seguidos respiram igual em qualquer seção. */
.split__content > p + p,
.where-content   > p + p,
.manifesto__body + .manifesto__body { margin-top: var(--space-2); }

/* Cabeçalho de seção (rótulo + título + descrição) com ritmo fixo. */
.section-head {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.section-head > * { margin: 0; }

/* Grupo de botões padronizado — substitui os styles inline removidos do HTML. */
.btn-group {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--gap-cluster);
}
.btn-group--center  { justify-content: center; }
.btn-group--end     { justify-content: flex-end; }
.btn-group--between { justify-content: space-between; width: 100%; }
.btn-group--stack-sm { row-gap: var(--space-3); }

/* Margens de bloco padronizadas para conteúdo gerado solto. */
.flow > * + * { margin-top: var(--space-4); }
.flow--tight > * + * { margin-top: var(--space-2); }
.flow--loose > * + * { margin-top: var(--space-6); }

/* Espaço de respiro lateral consistente em qualquer wrapper centralizado. */
.container,
.site-header__nav,
.site-footer__grid,
.site-footer__bottom { padding-inline: var(--pad-inline-edge); }

/* Padroniza o scroll-margin de todas as âncoras (header fixo + folga). */
:where([id]) { scroll-margin-top: calc(var(--header-height) + var(--space-6)); }
html { scroll-padding-top: calc(var(--header-height) + var(--space-4)); }

/* ══════════════════════════════════════════════════════════════════════════
   03 · ACESSIBILIDADE E USABILIDADE
   Skip link visível, foco previsível, alvos de toque, realce de âncora.
   ══════════════════════════════════════════════════════════════════════════ */

/* Skip link: invisível até receber foco, então aparece com destaque. */
.u-sr-only:focus,
.u-sr-only:focus-visible {
  position: fixed;
  top: var(--space-3);
  left: var(--space-3);
  z-index: 999;
  width: auto;
  height: auto;
  margin: 0;
  padding: var(--space-3) var(--space-5);
  clip: auto;
  clip-path: none;
  overflow: visible;
  white-space: normal;
  background-color: var(--color-dark);
  color: var(--color-light);
  border-radius: var(--radius-s);
  box-shadow: var(--shadow-pop);
  font: 600 0.875rem var(--font-text);
}

/* Foco visível mais rico — anel duplo que funciona em fundo claro e escuro. */
:focus-visible {
  outline: var(--rule-medium) solid var(--color-primary);
  outline-offset: 3px;
  box-shadow: var(--glow-primary);
  border-radius: var(--radius-s);
}
.section--dark :focus-visible,
.hero :focus-visible,
.site-footer :focus-visible {
  outline-color: var(--color-primary-light);
}

/* Remove o anel para clique de mouse, mantém para teclado (já é o padrão,
   reforçado aqui para navegadores antigos). */
:focus:not(:focus-visible) { outline: none; box-shadow: none; }

/* Alvos de toque: garante área mínima confortável em controles pequenos. */
@media (pointer: coarse) {
  .link,
  .site-footer__link,
  .accordion__trigger,
  .btn--sm,
  .price-tooltip {
    min-height: 44px;
  }
  .site-header__nav-list a:not(.btn) {
    padding-block: var(--space-2);
  }
}

/* Realce ao chegar numa âncora — orienta o usuário sobre "onde caiu". */
:target {
  animation: target-flash 1.6s var(--ease-out-soft) 1;
}
.accordion__item:target,
.section:target {
  scroll-margin-top: calc(var(--header-height) + var(--space-8));
}

/* Estado ocupado / carregando para regiões dinâmicas. */
[aria-busy="true"] {
  cursor: progress;
  opacity: 0.7;
}

/* Elementos escondidos via atributo continuam escondidos mesmo se tiverem
   display definido por outra regra. */
[hidden] { display: none !important; }

/* Indicação clara de elementos desabilitados. */
[disabled],
.is-disabled {
  cursor: not-allowed;
  opacity: 0.5;
  filter: grayscale(0.3);
}

/* Cursor de ajuda explícito em termos com tooltip. */
[title]:not(a):not(button) { cursor: help; }

/* Sublinhado de leitura para abreviações, se houver. */
abbr[title] {
  text-decoration: underline dotted;
  text-underline-offset: 2px;
}

/* Preferência por mais contraste — reforça bordas e textos secundários. */
@media (prefers-contrast: more) {
  :root {
    --color-border:        #9a958c;
    --color-border-strong: #6f6a60;
    --color-text-muted:    #5f5f5f;
  }
  .card,
  .price-table__wrapper,
  .map-embed { border-width: var(--rule-medium); }
  .link::after { height: var(--rule-medium); }
  .btn { border-width: var(--rule-medium); }
}

/* Conexões lentas / economia de dados — desliga efeitos pesados. */
@media (prefers-reduced-data: reduce) {
  .hero__bg img { image-rendering: auto; }
  *,
  *::before,
  *::after { backdrop-filter: none !important; }
}

/* ══════════════════════════════════════════════════════════════════════════
   04 · BARRA DE ROLAGEM PERSONALIZADA
   Discreta, na paleta do site, sem atrapalhar a leitura.
   ══════════════════════════════════════════════════════════════════════════ */
@supports (scrollbar-width: thin) {
  html {
    scrollbar-width: thin;
    scrollbar-color: var(--color-border-strong) transparent;
  }
}
::-webkit-scrollbar {
  width: 12px;
  height: 12px;
}
::-webkit-scrollbar-track {
  background: var(--color-light-surface);
}
::-webkit-scrollbar-thumb {
  background-color: var(--color-border-strong);
  border-radius: var(--radius-pill);
  border: 3px solid var(--color-light-surface);
}
::-webkit-scrollbar-thumb:hover {
  background-color: var(--color-dark-surface);
}
::-webkit-scrollbar-corner { background: transparent; }

/* Barras internas (tabela de preços) ficam mais finas. */
.price-table__wrapper::-webkit-scrollbar { height: 8px; }
.price-table__wrapper::-webkit-scrollbar-thumb { border-width: 2px; }

/* ══════════════════════════════════════════════════════════════════════════
   05 · CABEÇALHO DO SITE
   Vidro fosco ao rolar, transição suave, navegação com mais feedback.
   ══════════════════════════════════════════════════════════════════════════ */
.site-header {
  transition:
    background-color var(--dur-base) var(--ease-out-soft),
    border-color var(--dur-base) var(--ease-out-soft),
    height var(--dur-base) var(--ease-out-soft),
    box-shadow var(--dur-base) var(--ease-out-soft);
  will-change: height, background-color;
}

/* Ao rolar: fundo translúcido + blur, dando profundidade sobre o conteúdo. */
@supports (backdrop-filter: blur(8px)) or (-webkit-backdrop-filter: blur(8px)) {
  .site-header.is-scrolled {
    background-color: rgba(243, 241, 240, 0.82);
    -webkit-backdrop-filter: blur(10px) saturate(1.4);
    backdrop-filter: blur(10px) saturate(1.4);
  }
}
.site-header.is-scrolled {
  box-shadow: var(--shadow-soft);
}

/* Linha de progresso de leitura no rodapé do header (decorativa, via JS
   opcional que ajusta --scroll-progress; degrada para 0 se ausente). */
.site-header::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -1px;
  height: 2px;
  width: 100%;
  transform-origin: 0 50%;
  transform: scaleX(var(--scroll-progress, 0));
  background: linear-gradient(90deg, var(--color-primary), var(--color-primary-light));
  opacity: 0;
  transition: opacity var(--dur-base) var(--ease-out-soft);
  pointer-events: none;
}
.site-header.is-scrolled::after { opacity: 1; }

/* Itens de navegação: leve subida + cor no hover. */
.site-header__nav-list a:not(.btn) {
  position: relative;
  transition: color var(--dur-quick) var(--ease-out-soft);
}
.site-header__nav-list a:not(.btn):hover { color: var(--color-primary); }

/* Logo com toque sutil de escala ao passar o mouse. */
.site-header__logo {
  transition:
    height var(--dur-base) var(--ease-out-soft),
    transform var(--dur-quick) var(--ease-out-soft),
    filter var(--dur-quick) var(--ease-out-soft);
}
.site-header__logo-link:hover .site-header__logo {
  transform: scale(1.03);
}
.site-header__logo-link:active .site-header__logo {
  transform: scale(0.99);
}

/* Botão hambúrguer: realce de fundo ao interagir. */
.site-header__menu-trigger {
  transition:
    background-color var(--dur-quick) var(--ease-out-soft),
    transform var(--dur-quick) var(--ease-out-soft);
}
.site-header__menu-trigger:hover  { background-color: var(--tint-dark-08); }
.site-header__menu-trigger:active { transform: scale(0.92); }

/* ══════════════════════════════════════════════════════════════════════════
   06 · BOTÕES
   Estados :active, profundidade, foco, variantes de carregamento e ícone.
   ══════════════════════════════════════════════════════════════════════════ */
.btn {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  transition:
    background-color var(--dur-quick) var(--ease-out-soft),
    color var(--dur-quick) var(--ease-out-soft),
    border-color var(--dur-quick) var(--ease-out-soft),
    transform var(--dur-quick) var(--ease-out-back),
    box-shadow var(--dur-base) var(--ease-out-soft);
}

/* Brilho que percorre o botão no hover (camada própria, atrás do texto). */
.btn::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -1;
  background: linear-gradient(
    120deg,
    transparent 30%,
    rgba(255, 255, 255, 0.22) 50%,
    transparent 70%
  );
  transform: translateX(-120%);
  transition: transform var(--dur-slow) var(--ease-out-soft);
}
.btn:hover::before { transform: translateX(120%); }

/* Elevação no hover, afundamento no clique — feedback físico. */
.btn:hover  { transform: translateY(-2px); box-shadow: var(--shadow-lift); }
.btn:active { transform: translateY(0) scale(0.98); box-shadow: var(--shadow-soft); }

/* Primário ganha um halo quente no hover. */
.btn--primary:hover { box-shadow: var(--shadow-lift), var(--glow-soft); }

/* Outline: preenche suavemente em vez de "piscar" a cor. */
.btn--outline,
.btn--outline-primary { transition-property: background-color, color, border-color, transform, box-shadow; }

/* Botão de ícone: gira/escala levemente. */
.btn--icon { transition: background-color var(--dur-quick), transform var(--dur-quick) var(--ease-out-back); }
.btn--icon:hover  { transform: scale(1.08); }
.btn--icon:active { transform: scale(0.94); }

/* Ícones internos do botão acompanham o movimento. */
.btn i,
.btn svg { transition: transform var(--dur-quick) var(--ease-out-back); }
.btn:hover i,
.btn:hover svg { transform: translateX(2px); }

/* Variante "ghost" para ações secundárias discretas. */
.btn--ghost {
  background-color: transparent;
  color: var(--color-dark);
  border-color: transparent;
}
.btn--ghost:hover { background-color: var(--tint-dark-08); }
.section--dark .btn--ghost,
.hero .btn--ghost { color: var(--color-light); }
.section--dark .btn--ghost:hover,
.hero .btn--ghost:hover { background-color: var(--tint-light-10); }

/* Variante "block" ocupa a largura toda (útil no mobile). */
.btn--block { display: flex; width: 100%; }

/* Estado de carregamento: esconde o texto e mostra um spinner. */
.btn.is-loading {
  color: transparent !important;
  pointer-events: none;
}
.btn.is-loading::after {
  content: '';
  position: absolute;
  inset: 0;
  margin: auto;
  width: 1.1em;
  height: 1.1em;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  color: var(--color-light);
  animation: spin 0.6s linear infinite;
}
.btn--outline.is-loading::after,
.btn--outline-primary.is-loading::after,
.btn--ghost.is-loading::after { color: var(--color-dark); }

/* CTA com pulso de atenção opcional (classe adicionada quando relevante). */
.btn--pulse { animation: cta-pulse 2.6s var(--ease-in-out-ct) infinite; }
.btn--pulse:hover { animation-play-state: paused; }

/* ══════════════════════════════════════════════════════════════════════════
   07 · CARDS (diferenciais)
   Elevação no hover, borda viva, ícone com vida própria.
   ══════════════════════════════════════════════════════════════════════════ */
.card {
  position: relative;
  isolation: isolate;
  padding: var(--pad-card);
  border: var(--rule-thin) solid var(--color-border);
  box-shadow: var(--shadow-xs);
  transition:
    transform var(--dur-base) var(--ease-spring),
    box-shadow var(--dur-base) var(--ease-out-soft),
    border-color var(--dur-base) var(--ease-out-soft);
  will-change: transform;
}
.card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lift);
  border-color: var(--tint-primary-22);
}

/* Faixa superior que cresce no hover — assinatura visual da marca. */
.card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  height: var(--rule-thick);
  width: 0;
  background: linear-gradient(90deg, var(--color-primary), var(--color-primary-light));
  border-radius: var(--radius-pill);
  transition: width var(--dur-base) var(--ease-out-soft);
}
.card:hover::before { width: 100%; }

/* Card em fundo escuro: brilho interno em vez de sombra. */
.card--on-dark {
  box-shadow: var(--shadow-inset);
  transition:
    transform var(--dur-base) var(--ease-spring),
    background-color var(--dur-base) var(--ease-out-soft),
    border-color var(--dur-base) var(--ease-out-soft),
    box-shadow var(--dur-base) var(--ease-out-soft);
}
.card--on-dark::before { display: none; } /* já tem border-top fixo */
.card--on-dark:hover {
  transform: translateY(-6px);
  background-color: var(--tint-light-06);
  border-color: var(--tint-light-16);
  box-shadow: var(--shadow-pop), var(--shadow-inset);
}

/* Ícone do card: escala e ganha um fundo circular suave no hover. */
.card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  border-radius: var(--radius-m);
  background-color: var(--tint-primary-08);
  transition:
    transform var(--dur-base) var(--ease-out-back),
    background-color var(--dur-base) var(--ease-out-soft);
}
.card:hover .card__icon {
  transform: scale(1.1) rotate(-4deg);
  background-color: var(--tint-primary-14);
}
.card--on-dark .card__icon { background-color: var(--tint-light-06); }
.card--on-dark:hover .card__icon { background-color: var(--tint-primary-22); }

/* Título e texto do card com hierarquia de cor mais clara. */
.card h3 { transition: color var(--dur-quick) var(--ease-out-soft); }
.card:hover h3 { color: var(--color-primary); }
.card--on-dark:hover h3 { color: var(--color-primary-light); }
.card p { color: var(--color-dark-surface); }
.card--on-dark p { color: var(--color-light-opacity); }

/* ══════════════════════════════════════════════════════════════════════════
   08 · AUDIENCE CARDS (para quem é)
   Cartão de leitura rápida — realce na borda e deslize do ícone.
   ══════════════════════════════════════════════════════════════════════════ */
.audience-card {
  padding: var(--space-6) var(--space-4);
  border-top: var(--rule-medium) solid var(--color-border);
  transition:
    border-color var(--dur-base) var(--ease-out-soft),
    background-color var(--dur-base) var(--ease-out-soft),
    transform var(--dur-base) var(--ease-spring);
}
.audience-card:hover {
  border-top-color: var(--color-primary);
  background-color: var(--tint-primary-08);
  transform: translateY(-3px);
}
.audience-card__icon {
  transition: transform var(--dur-base) var(--ease-out-back);
}
.audience-card:hover .audience-card__icon {
  transform: translateX(3px) scale(1.12);
}
.audience-card__title { transition: color var(--dur-quick) var(--ease-out-soft); }
.audience-card:hover .audience-card__title { color: var(--color-primary); }

/* Tags ganham um ponto separador sutil em telas maiores. */
.audience-card__tags { line-height: 1.7; }

/* ══════════════════════════════════════════════════════════════════════════
   09 · TIMELINE (como funciona)
   Conector com preenchimento progressivo, número com fundo, item com hover.
   ══════════════════════════════════════════════════════════════════════════ */
.timeline__item {
  transition: transform var(--dur-base) var(--ease-spring);
}
.timeline__item:hover { transform: translateX(4px); }

/* Número da etapa: ganha um disco de fundo discreto. */
.timeline__number {
  position: relative;
  display: inline-flex;
  align-items: flex-start;
  justify-content: center;
  transition: transform var(--dur-base) var(--ease-out-back);
}
.timeline__item:hover .timeline__number {
  transform: scale(1.06);
}

/* Conector mais nítido + ponto de junção no topo de cada etapa. */
.timeline__connector {
  background: linear-gradient(
    to bottom,
    var(--color-primary) 0,
    var(--color-border-strong) 2.5rem
  );
}
.timeline__item::before {
  content: '';
  position: absolute;
  left: calc(1.5rem - 3px);
  top: 0.35rem;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: var(--color-primary);
  box-shadow: 0 0 0 4px var(--tint-primary-14);
  transition: transform var(--dur-base) var(--ease-out-back);
}
.timeline__item:hover::before { transform: scale(1.4); }
.timeline__item:last-child::before { background-color: var(--color-success); }

/* Título da etapa muda de cor no hover do item. */
.timeline__body h3 { transition: color var(--dur-quick) var(--ease-out-soft); }
.timeline__item:hover .timeline__body h3 { color: var(--color-primary); }

/* ══════════════════════════════════════════════════════════════════════════
   10 · ACCORDION (FAQ)
   Espaçamento interno padronizado, transição de conteúdo mais suave,
   hover/aberto com fundo discreto e seta animada.
   ══════════════════════════════════════════════════════════════════════════ */

/* Padroniza o respiro interno — antes o corpo tinha padding 0. */
.accordion__body {
  padding-block: 0 var(--space-5);
  padding-inline: 0 var(--space-8);
  color: var(--color-dark-surface);
  opacity: 0;
  transform: translateY(-0.4rem);
  transition:
    opacity var(--dur-base) var(--ease-out-soft),
    transform var(--dur-base) var(--ease-out-soft);
}
.accordion__item--open .accordion__body {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 0.08s;
}

/* Linha inteira clicável com realce de fundo. */
.accordion__trigger {
  padding-inline: var(--space-4);
  margin-inline: calc(var(--space-4) * -1);
  border-radius: var(--radius-s);
  transition:
    color var(--dur-quick) var(--ease-out-soft),
    background-color var(--dur-quick) var(--ease-out-soft);
}
.accordion__trigger:hover { background-color: var(--tint-primary-08); }
.accordion__item--open > .accordion__trigger { color: var(--color-primary); }

/* Item aberto recebe um leve fundo e barra lateral. */
.accordion__item {
  position: relative;
  transition: background-color var(--dur-base) var(--ease-out-soft);
}
.accordion__item--open {
  background-color: var(--tint-dark-04);
}
.accordion__item--open::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: var(--rule-thick);
  background: linear-gradient(var(--color-primary), var(--color-primary-light));
  border-radius: var(--radius-pill);
}

/* Ícone "+" → "×" com rotação mais expressiva. */
.accordion__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 50%;
  background-color: var(--tint-primary-08);
  transition:
    transform var(--dur-base) var(--ease-out-back),
    background-color var(--dur-quick) var(--ease-out-soft);
}
.accordion__trigger:hover .accordion__icon { background-color: var(--tint-primary-22); }
.accordion__item--open .accordion__icon {
  transform: rotate(135deg);
  background-color: var(--color-primary);
  color: var(--color-light);
}

/* Pergunta com leve deslize ao abrir. */
.accordion__question { transition: transform var(--dur-quick) var(--ease-out-soft); }
.accordion__trigger:hover .accordion__question { transform: translateX(3px); }

/* ══════════════════════════════════════════════════════════════════════════
   11 · TABELA DE PREÇOS
   Zebra, hover de linha, cantos arredondados, foco no valor.
   ══════════════════════════════════════════════════════════════════════════ */
.price-table__wrapper {
  box-shadow: var(--shadow-soft);
  transition: box-shadow var(--dur-base) var(--ease-out-soft);
}
.price-table__wrapper:hover { box-shadow: var(--shadow-card); }

/* Linhas alternadas para leitura mais fácil. */
.price-table__body tr:nth-child(even) { background-color: var(--tint-dark-04); }

/* Hover de linha — destaca o serviço sob o cursor. */
.price-table__body tr {
  transition: background-color var(--dur-quick) var(--ease-out-soft);
}
.price-table__body tr:hover { background-color: var(--tint-primary-08); }
.price-table__body tr:last-child { border-bottom: none; }

/* Valor em destaque tipográfico. */
.price-table__body td:last-child {
  font-weight: 600;
  color: var(--color-primary-surface);
  white-space: nowrap;
}

/* Cabeçalho fixo ao rolar horizontalmente em telas estreitas. */
.price-table__head th:first-child { border-top-left-radius: var(--radius-m); }
.price-table__head th:last-child  { border-top-right-radius: var(--radius-m); }

/* Em telas muito estreitas, reduz o respiro lateral das células. */
@media (max-width: 480px) {
  .price-table__head th,
  .price-table__body td { padding-inline: var(--space-5); }
}

/* ══════════════════════════════════════════════════════════════════════════
   12 · TOOLTIP DE PREÇO
   Aparição mais suave, contraste reforçado, seta alinhada.
   ══════════════════════════════════════════════════════════════════════════ */
.price-tooltip__icon {
  width: 1rem;
  height: 1rem;
  font-size: 0.6875rem;
  transition:
    background-color var(--dur-quick) var(--ease-out-soft),
    transform var(--dur-quick) var(--ease-out-back);
}
.price-tooltip:hover .price-tooltip__icon,
.price-tooltip:focus-visible .price-tooltip__icon {
  transform: scale(1.15);
}
.price-tooltip__bubble {
  box-shadow: var(--shadow-pop);
  letter-spacing: 0.01em;
}
.price-tooltip:hover .price-tooltip__bubble,
.price-tooltip:focus-visible .price-tooltip__bubble,
.price-tooltip:focus-within .price-tooltip__bubble {
  transform: translateX(-50%) translateY(-2px);
}

/* ══════════════════════════════════════════════════════════════════════════
   13 · HERO
   Vinheta sutil, leve zoom de entrada na imagem, conteúdo com brilho de texto.
   ══════════════════════════════════════════════════════════════════════════ */

/* Vinheta radial sobre o fundo — concentra o olhar no conteúdo. */
.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(
      120% 80% at 20% 100%,
      rgba(31, 30, 30, 0.55) 0%,
      transparent 60%
    );
}

/* Imagem de fundo entra com um zoom-out lento e elegante. */
.hero__bg img {
  animation: hero-kenburns var(--dur-crawl) var(--ease-out-soft) both;
  transform-origin: 50% 70%;
}

/* Conteúdo do hero com sombra de texto para legibilidade em qualquer foto. */
.hero__content .label,
.hero__content h1,
.hero__content p {
  text-shadow: 0 1px 12px rgba(0, 0, 0, 0.35);
}

/* Rótulo do hero ganha um traço antes do texto. */
.hero__content .label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  width: fit-content;
}
.hero__content .label::before {
  content: '';
  width: 2rem;
  height: var(--rule-medium);
  background-color: var(--color-primary-light);
  flex-shrink: 0;
}

/* Limita a largura do título/parágrafo para um bloco de leitura agradável. */
.hero__content h1 { max-width: 20ch; }
.hero__content p  { max-width: 46ch; font-size: 1.0625rem; }

/* Indicador de rolagem decorativo no canto — pura CSS, não bloqueia clique. */
.hero__content .btn { position: relative; }

/* ══════════════════════════════════════════════════════════════════════════
   14 · SEÇÃO MANIFESTO ("o ofício")
   Aspas decorativas, divisor com brilho, texto com ritmo de leitura.
   ══════════════════════════════════════════════════════════════════════════ */
.manifesto { gap: var(--space-8); }
.manifesto__title { position: relative; }

/* Aspas tipográficas grandes atrás do título. */
.manifesto__title::before {
  content: '\201C';
  position: absolute;
  top: -1.4em;
  left: 50%;
  transform: translateX(-50%);
  font: 400 6rem var(--font-titles);
  color: var(--color-primary);
  opacity: 0.18;
  line-height: 1;
  pointer-events: none;
}

/* Divisor com leve brilho ao redor. */
.manifesto__divider {
  box-shadow: 0 0 12px rgba(232, 101, 26, 0.6);
  transition: width var(--dur-slow) var(--ease-out-soft);
}
.manifesto:hover .manifesto__divider { width: 14rem; }

.manifesto__body { max-width: var(--measure); }
.manifesto__body strong { color: var(--color-light); }

/* ══════════════════════════════════════════════════════════════════════════
   15 · RODAPÉ
   Hover de links com deslize, logo com brilho, divisórias suaves.
   ══════════════════════════════════════════════════════════════════════════ */
.site-footer__grid { gap: var(--space-10); }

.site-footer__logo {
  transition: transform var(--dur-base) var(--ease-out-back), filter var(--dur-base);
}
.site-footer__logo:hover { transform: scale(1.04); }

/* Links do rodapé deslizam e o ícone acompanha. */
.site-footer__link {
  width: fit-content;
  transition:
    color var(--dur-quick) var(--ease-out-soft),
    transform var(--dur-quick) var(--ease-out-soft);
}
.site-footer__link:hover { transform: translateX(4px); }
.site-footer__link i { transition: transform var(--dur-quick) var(--ease-out-back); }
.site-footer__link:hover i { transform: scale(1.2); }

/* Título de coluna do rodapé com um traço curto acima. */
.site-footer .label {
  position: relative;
  padding-top: var(--space-3);
}
.site-footer__grid > .stack .label::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 1.75rem;
  height: var(--rule-medium);
  background-color: var(--color-primary);
}

/* Barra inferior com leve diferença de tom. */
.site-footer__bottom { background-color: var(--tint-dark-04); }

/* ══════════════════════════════════════════════════════════════════════════
   16 · MENU MOBILE
   Entrada animada, itens em cascata, fechamento com feedback.
   ══════════════════════════════════════════════════════════════════════════ */
.mobile-menu {
  gap: var(--space-8);
  padding-top: var(--space-20);
}
.mobile-menu.is-open {
  animation: menu-in var(--dur-base) var(--ease-out-soft) both;
}

/* Itens entram em cascata quando o menu abre. */
.mobile-menu.is-open .mobile-menu__list > li {
  animation: menu-item-in var(--dur-base) var(--ease-out-soft) both;
}
.mobile-menu.is-open .mobile-menu__list > li:nth-child(1) { animation-delay: 0.06s; }
.mobile-menu.is-open .mobile-menu__list > li:nth-child(2) { animation-delay: 0.12s; }
.mobile-menu.is-open .mobile-menu__list > li:nth-child(3) { animation-delay: 0.18s; }
.mobile-menu.is-open .mobile-menu__list > li:nth-child(4) { animation-delay: 0.24s; }
.mobile-menu.is-open .mobile-menu__list > li:nth-child(5) { animation-delay: 0.30s; }

/* Links do menu mobile maiores e mais espaçados (alvo de toque). */
.mobile-menu__list { gap: var(--space-5); }
.mobile-menu__list .link {
  display: block;
  padding-block: var(--space-2);
  font: 400 1.5rem var(--font-titles);
}
.mobile-menu__list .link:hover { color: var(--color-primary); }

/* Botão de fechar gira ao passar o mouse. */
.mobile-menu__close {
  transition: transform var(--dur-quick) var(--ease-out-back), background-color var(--dur-quick);
}
.mobile-menu__close:hover  { transform: rotate(90deg); background-color: var(--tint-dark-08); }
.mobile-menu__close:active { transform: rotate(90deg) scale(0.9); }

/* ══════════════════════════════════════════════════════════════════════════
   17 · LINKS E SUBLINHADOS
   Variações de affordance para diferentes contextos.
   ══════════════════════════════════════════════════════════════════════════ */

/* Sublinhado padrão cresce do centro (mais elegante que da esquerda). */
.link::after {
  left: 50%;
  transform: translateX(-50%);
  background: linear-gradient(90deg, var(--color-primary), var(--color-primary-light));
  height: var(--rule-medium);
}

/* Variante: sublinhado sempre visível, sai no hover. */
.link--reverse::after { width: 100%; }
.link--reverse:hover::after { width: 0; }

/* Variante: link com seta que aparece no hover. */
.link--arrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
}
.link--arrow::before {
  content: '\2192';
  display: inline-block;
  transform: translateX(-0.3rem);
  opacity: 0;
  transition:
    transform var(--dur-quick) var(--ease-out-back),
    opacity var(--dur-quick) var(--ease-out-soft);
}
.link--arrow:hover::before { transform: translateX(0); opacity: 1; }

/* Links dentro de parágrafos de texto corrido. */
.where-content a:not(.btn),
.manifesto__body a:not(.btn),
.accordion__body a:not(.btn) {
  color: var(--color-primary);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  transition: text-decoration-color var(--dur-quick), color var(--dur-quick);
}
.where-content a:not(.btn):hover,
.manifesto__body a:not(.btn):hover,
.accordion__body a:not(.btn):hover {
  color: var(--color-primary-surface);
  text-decoration-thickness: 2px;
}

/* ══════════════════════════════════════════════════════════════════════════
   18 · IMAGENS E MÍDIA
   Zoom no hover, moldura, aparição suave, tratamento do mapa.
   ══════════════════════════════════════════════════════════════════════════ */

/* Mídia do split: zoom lento ao passar o mouse, dentro do overflow:hidden. */
.split__media {
  position: relative;
  box-shadow: var(--shadow-card);
}
.split__media img {
  transition: transform var(--dur-slow) var(--ease-out-soft);
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.split__media:hover img { transform: scale(1.05); }

/* Brilho diagonal que cruza a imagem no hover. */
.split__media::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    120deg,
    transparent 40%,
    rgba(255, 255, 255, 0.18) 50%,
    transparent 60%
  );
  transform: translateX(-100%);
  transition: transform var(--dur-crawl) var(--ease-out-soft);
  pointer-events: none;
}
.split__media:hover::after { transform: translateX(100%); }

/* Moldura do mapa: borda, sombra e leve dessaturação que some no hover. */
.map-embed {
  box-shadow: var(--shadow-card);
  border: var(--rule-thin) solid var(--color-border);
  transition: box-shadow var(--dur-base) var(--ease-out-soft);
}
.map-embed:hover { box-shadow: var(--shadow-lift); }
.map-embed iframe {
  filter: grayscale(0.25) contrast(1.02);
  transition: filter var(--dur-slow) var(--ease-out-soft);
}
.map-embed:hover iframe { filter: grayscale(0) contrast(1); }

/* Aparição suave de imagens — OPT-IN via classe .img-fade.
   Importante: NÃO esconde imagens por padrão. A imagem só fica invisível
   se receber .img-fade explicitamente, e volta com .is-loaded (JS opcional).
   Há um fallback temporizado caso o JS de load não exista. */
.img-fade {
  opacity: 0;
  transition: opacity var(--dur-slow) var(--ease-out-soft);
  animation: img-reveal 0.01s linear 2s forwards; /* rede de segurança */
}
.img-fade.is-loaded,
.img-fade[data-loaded] {
  opacity: 1;
  animation: none;
}

/* ══════════════════════════════════════════════════════════════════════════
   19 · TIPOGRAFIA — REFINAMENTOS
   Ritmo de leitura, hierarquia de cor, detalhes de renderização.
   ══════════════════════════════════════════════════════════════════════════ */
body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* Títulos com leitura mais firme e leve ajuste de entrelinha. */
h1, .h1 { line-height: 1.08; letter-spacing: -0.015em; }
h2, .h2 { line-height: 1.15; letter-spacing: -0.01em; }
h3, .h3 { line-height: 1.25; }

/* Parágrafos soltos respeitam uma medida de leitura confortável. */
.body-lg {
  font-size: clamp(1.0625rem, 2.2vw, 1.1875rem);
  line-height: 1.7;
  color: var(--color-dark-surface);
  max-width: var(--measure);
}
.section--dark .body-lg { color: var(--color-light-opacity); }

/* Destaques em negrito ganham a cor da marca em contexto de prosa. */
.where-content strong,
.accordion__body strong { color: var(--color-primary-surface); font-weight: 600; }
.section--dark strong { color: var(--color-light); }

/* Listas de definição (endereço/horário) com alinhamento firme. */
.location-info dt {
  font: 600 0.75rem var(--font-label);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  align-self: start;
  padding-top: 0.15rem;
}
.location-info dd { font-weight: 500; }

/* Primeira letra opcional em destaque para blocos de manifesto. */
.has-dropcap::first-letter {
  font: 400 3.2em var(--font-titles);
  float: left;
  line-height: 0.8;
  padding: 0.05em 0.1em 0 0;
  color: var(--color-primary);
}

/* Seleção de texto contextual — combina com o fundo da seção. */
.section--dark ::selection,
.hero ::selection {
  background-color: var(--color-primary);
  color: var(--color-light);
}

/* Texto com gradiente para destaques pontuais. */
.text-gradient {
  background: linear-gradient(120deg, var(--color-primary), var(--color-primary-light));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* ══════════════════════════════════════════════════════════════════════════
   20 · SEÇÕES — RITMO E ORNAMENTOS
   Padroniza o respiro entre seções e adiciona divisores discretos.
   ══════════════════════════════════════════════════════════════════════════ */

/* Cada seção mantém o padding vertical da escala — reforço explícito. */
.section { padding-block: var(--section-padding-y); }

/* Transição de cor entre seção clara e escura fica mais suave com uma
   borda-sombra interna no topo da seção escura. */
.section--dark { box-shadow: inset 0 1px 0 var(--tint-light-06); }

/* Divisor ornamental reutilizável (ponto central + linhas). */
.divider {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  width: 100%;
  color: var(--color-border-strong);
}
.divider::before,
.divider::after {
  content: '';
  height: var(--rule-thin);
  background-color: currentColor;
  flex: 1;
}
.divider__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: var(--color-primary);
  flex-shrink: 0;
}

/* Cabeçalho de seção centralizado reutilizável. */
.section-head--center {
  text-align: center;
  align-items: center;
  margin-inline: auto;
  max-width: 50rem;
}

/* Numerador de seção (ex.: "01 — Como funciona"). */
.section-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font: 600 0.75rem var(--font-label);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-primary);
}
.section-eyebrow::before {
  content: '';
  width: 1.5rem;
  height: var(--rule-medium);
  background-color: var(--color-primary);
}

/* ══════════════════════════════════════════════════════════════════════════
   21 · COMPONENTES NOVOS — BADGE, CHIP, TAG, KBD, NOTE
   Pequenas peças reutilizáveis no padrão visual do site.
   ══════════════════════════════════════════════════════════════════════════ */

/* Badge — selo curto de status ou destaque. */
.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: 0.25rem 0.625rem;
  border-radius: var(--radius-pill);
  font: 600 0.6875rem var(--font-label);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  background-color: var(--tint-primary-14);
  color: var(--color-primary-surface);
  line-height: 1;
}
.badge--dark    { background-color: var(--color-dark); color: var(--color-light); }
.badge--success { background-color: rgba(46, 110, 78, 0.16); color: var(--color-success); }
.badge--warning { background-color: rgba(184, 138, 26, 0.18); color: var(--color-warning); }
.badge--dot::before {
  content: '';
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background-color: currentColor;
}

/* Chip — item selecionável/filtro com hover. */
.chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0.375rem 0.875rem;
  border-radius: var(--radius-pill);
  border: var(--rule-thin) solid var(--color-border);
  background-color: var(--color-light);
  font: 500 0.8125rem var(--font-text);
  transition:
    border-color var(--dur-quick) var(--ease-out-soft),
    background-color var(--dur-quick) var(--ease-out-soft),
    transform var(--dur-quick) var(--ease-out-back);
}
.chip:hover {
  border-color: var(--color-primary);
  background-color: var(--tint-primary-08);
  transform: translateY(-1px);
}
.chip[aria-pressed="true"],
.chip.is-active {
  background-color: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
}

/* Tag — rótulo informativo simples. */
.tag {
  display: inline-block;
  padding: 0.125rem 0.5rem;
  border-radius: var(--radius-s);
  background-color: var(--tint-dark-08);
  font: 500 0.75rem var(--font-label);
  color: var(--color-dark-surface);
}

/* Kbd — representação de tecla. */
.kbd {
  display: inline-block;
  padding: 0.125rem 0.4375rem;
  border-radius: var(--radius-s);
  border: var(--rule-thin) solid var(--color-border-strong);
  border-bottom-width: var(--rule-thick);
  background-color: var(--color-light);
  font: 600 0.8125rem var(--font-label);
  line-height: 1.4;
}

/* Note / callout — bloco de aviso discreto. */
.note {
  display: flex;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-m);
  border-left: var(--rule-thick) solid var(--color-primary);
  background-color: var(--tint-primary-08);
  font-size: 0.9375rem;
}
.note--success { border-left-color: var(--color-success); background-color: rgba(46, 110, 78, 0.08); }
.note--warning { border-left-color: var(--color-warning); background-color: rgba(184, 138, 26, 0.10); }
.note__icon { color: var(--color-primary); font-size: 1.25rem; flex-shrink: 0; line-height: 1.3; }

/* Avatar / selo circular simples. */
.avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.75rem;
  height: 2.75rem;
  border-radius: 50%;
  background-color: var(--tint-primary-14);
  color: var(--color-primary-surface);
  font: 700 1rem var(--font-text);
  overflow: hidden;
}
.avatar img { width: 100%; height: 100%; object-fit: cover; }

/* Pílula de estatística (número + rótulo). */
.stat {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.stat__value {
  font: 400 clamp(2rem, 5vw, 2.75rem) var(--font-titles);
  color: var(--color-primary);
  line-height: 1;
}
.stat__label {
  font: 600 0.75rem var(--font-label);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}

/* ══════════════════════════════════════════════════════════════════════════
   22 · ESTADOS INTERATIVOS GLOBAIS
   Hover/active/focus consistentes para qualquer elemento clicável.
   ══════════════════════════════════════════════════════════════════════════ */

/* Qualquer link/botão respeita a mesma curva de transição base. */
a, button, .chip, .card, .audience-card, .accordion__trigger {
  -webkit-tap-highlight-color: transparent;
}

/* Feedback de clique universal para elementos sem estado :active próprio. */
.is-clickable {
  cursor: pointer;
  transition: transform var(--dur-instant) var(--ease-out-soft);
}
.is-clickable:active { transform: scale(0.98); }

/* Cartão inteiro clicável (quando envolto por <a>). */
.card-link {
  display: block;
  color: inherit;
  text-decoration: none;
  border-radius: var(--radius-m);
}
.card-link:focus-visible { outline-offset: 4px; }

/* Estado de foco-dentro para containers (ex.: grupo de formulário). */
.focus-ring:focus-within {
  box-shadow: var(--glow-primary);
  border-radius: var(--radius-s);
}

/* ══════════════════════════════════════════════════════════════════════════
   23 · UTILITÁRIOS DE LAYOUT E ESPAÇAMENTO
   Classes auxiliares para padronizar margens/paddings sem styles inline.
   ══════════════════════════════════════════════════════════════════════════ */

/* Margens verticais padronizadas (escala 4px). */
.mt-0  { margin-top: 0; }
.mt-2  { margin-top: var(--space-2); }
.mt-4  { margin-top: var(--space-4); }
.mt-6  { margin-top: var(--space-6); }
.mt-8  { margin-top: var(--space-8); }
.mt-12 { margin-top: var(--space-12); }
.mb-0  { margin-bottom: 0; }
.mb-2  { margin-bottom: var(--space-2); }
.mb-4  { margin-bottom: var(--space-4); }
.mb-6  { margin-bottom: var(--space-6); }
.mb-8  { margin-bottom: var(--space-8); }
.mb-12 { margin-bottom: var(--space-12); }

/* Centralização horizontal de bloco. */
.mx-auto { margin-inline: auto; }

/* Alinhamento de texto utilitário. */
.u-text-center { text-align: center; }
.u-text-left   { text-align: left; }
.u-text-right  { text-align: right; }

/* Variante de container com largura intermediária (entre prose e padrão). */
.container--narrow { max-width: 60.25rem; } /* 964px */

/* Largura de leitura ~40rem para parágrafos de apoio. */
.measure-40 { max-width: 40rem; }
.measure-38 { max-width: 38rem; }

/* Mídia quadrada padronizada (substitui style inline de aspect-ratio). */
.split__media img { aspect-ratio: 1 / 1; }

/* Paddings utilitários. */
.p-4  { padding: var(--space-4); }
.p-6  { padding: var(--space-6); }
.p-8  { padding: var(--space-8); }
.py-4 { padding-block: var(--space-4); }
.py-8 { padding-block: var(--space-8); }
.px-4 { padding-inline: var(--space-4); }
.px-6 { padding-inline: var(--space-6); }

/* Gaps utilitários para flex/grid ad-hoc. */
.gap-2 { gap: var(--space-2); }
.gap-4 { gap: var(--space-4); }
.gap-6 { gap: var(--space-6); }
.gap-8 { gap: var(--space-8); }

/* Larguras de leitura. */
.measure       { max-width: var(--measure); }
.measure-short { max-width: var(--measure-short); }

/* Layout em cluster (itens que quebram com gap uniforme). */
.cluster {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  align-items: center;
}
.cluster--tight { gap: var(--space-2); }
.cluster--center { justify-content: center; }

/* Layout "sidebar" — coluna fixa + coluna fluida. */
.with-sidebar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-8);
}
.with-sidebar > :first-child { flex-basis: 18rem; flex-grow: 1; }
.with-sidebar > :last-child  { flex-basis: 0; flex-grow: 999; min-width: 60%; }

/* Centralização absoluta de conteúdo numa caixa. */
.center-grid { display: grid; place-items: center; }

/* Espaçador flexível. */
.spacer { flex: 1 1 auto; }

/* Esconde visualmente mas mantém para leitores de tela (alias de u-sr-only). */
.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}

/* Razões de aspecto comuns. */
.ratio-16-9 { aspect-ratio: 16 / 9; }
.ratio-4-3  { aspect-ratio: 4 / 3; }
.ratio-1-1  { aspect-ratio: 1 / 1; }
.ratio-16-9 > *, .ratio-4-3 > *, .ratio-1-1 > * {
  width: 100%; height: 100%; object-fit: cover;
}

/* Truncamento de texto. */
.truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.line-clamp-2,
.line-clamp-3 {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.line-clamp-2 { -webkit-line-clamp: 2; }
.line-clamp-3 { -webkit-line-clamp: 3; }

/* ══════════════════════════════════════════════════════════════════════════
   24 · EFEITOS REUTILIZÁVEIS
   Classes de movimento aplicáveis a qualquer elemento (todas respeitam
   prefers-reduced-motion no bloco final).
   ══════════════════════════════════════════════════════════════════════════ */

/* Elevação genérica no hover. */
.fx-lift {
  transition: transform var(--dur-base) var(--ease-spring), box-shadow var(--dur-base) var(--ease-out-soft);
}
.fx-lift:hover { transform: translateY(-5px); box-shadow: var(--shadow-lift); }

/* Brilho pulsante de destaque. */
.fx-glow { transition: box-shadow var(--dur-base) var(--ease-out-soft); }
.fx-glow:hover { box-shadow: var(--glow-soft); }

/* Flutuação contínua suave. */
.fx-float { animation: float 4s var(--ease-in-out-ct) infinite; }

/* Brilho que percorre (shimmer) — útil em skeletons e destaques. */
.fx-shimmer {
  position: relative;
  overflow: hidden;
}
.fx-shimmer::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    100deg,
    transparent 30%,
    rgba(255, 255, 255, 0.45) 50%,
    transparent 70%
  );
  transform: translateX(-100%);
  animation: shimmer 2.2s var(--ease-in-out-ct) infinite;
}

/* Skeleton de carregamento. */
.skeleton {
  background-color: var(--color-light-surface);
  border-radius: var(--radius-s);
  position: relative;
  overflow: hidden;
}
.skeleton::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.6),
    transparent
  );
  transform: translateX(-100%);
  animation: shimmer 1.4s ease-in-out infinite;
}
.skeleton--text   { height: 0.85em; margin-block: 0.25em; }
.skeleton--title  { height: 1.6em; width: 60%; }
.skeleton--block  { height: 8rem; }

/* Rotação contínua (loaders). */
.fx-spin { animation: spin 0.8s linear infinite; }

/* Aparição ao entrar (quando o JS adiciona .is-inview). */
.fx-reveal {
  opacity: 0;
  transform: translateY(1.5rem);
  transition: opacity var(--dur-slow) var(--ease-out-soft), transform var(--dur-slow) var(--ease-out-soft);
}
.fx-reveal.is-inview { opacity: 1; transform: none; }

/* Gradiente animado de fundo. */
.fx-gradient-shift {
  background: linear-gradient(
    120deg,
    var(--color-primary),
    var(--color-primary-light),
    var(--color-primary-surface)
  );
  background-size: 200% 200%;
  animation: gradient-shift 6s var(--ease-in-out-ct) infinite;
}

/* Sublinhado animado reutilizável fora de .link. */
.fx-underline {
  background-image: linear-gradient(var(--color-primary), var(--color-primary));
  background-position: 0 100%;
  background-repeat: no-repeat;
  background-size: 0 var(--rule-medium);
  transition: background-size var(--dur-base) var(--ease-out-soft);
}
.fx-underline:hover { background-size: 100% var(--rule-medium); }

/* Inclinação 3D sutil no hover. */
.fx-tilt {
  transition: transform var(--dur-base) var(--ease-spring);
  transform-style: preserve-3d;
}
.fx-tilt:hover { transform: perspective(600px) rotateX(2deg) rotateY(-2deg) translateY(-3px); }

/* Escala de entrada para elementos pontuais. */
.fx-pop { animation: pop-in var(--dur-base) var(--ease-out-back) both; }

/* ══════════════════════════════════════════════════════════════════════════
   25 · SCROLL-DRIVEN ANIMATIONS (PROGRESSIVE ENHANCEMENT)
   Só ativam em navegadores com suporte; degradam sem efeito colateral.
   ══════════════════════════════════════════════════════════════════════════ */
@supports (animation-timeline: view()) {
  /* Elementos marcados aparecem conforme entram na viewport, sem JS.
     Atenção: NÃO aplicar em elementos com [data-animate] — esses já são
     controlados pelo IntersectionObserver do index.js e haveria conflito
     de propriedades (opacity/transform). Use .scroll-reveal só em elementos
     sem data-animate. */
  .scroll-reveal:not([data-animate]) {
    animation: scroll-fade-up linear both;
    animation-timeline: view();
    animation-range: entry 0% entry 55%;
  }

  /* Imagem do hero faz um parallax discreto ao rolar. */
  .hero__bg img {
    animation: hero-kenburns var(--dur-crawl) var(--ease-out-soft) both,
               hero-parallax linear both;
    animation-timeline: auto, view();
    animation-range: auto, entry 0% exit 100%;
  }

  /* Barra de progresso de leitura no header sem depender de JS. */
  .site-header.is-scrolled::after {
    animation: progress-grow linear both;
    animation-timeline: scroll(root);
    transform: scaleX(0);
  }
}

/* ══════════════════════════════════════════════════════════════════════════
   26 · RESPONSIVIDADE FINA
   Breakpoints intermediários para padronizar espaçamento em cada faixa.
   ══════════════════════════════════════════════════════════════════════════ */

/* Telas muito pequenas — compacta paddings e tipografia de apoio. */
@media (max-width: 380px) {
  :root { --section-padding-x: 1rem; }
  .btn { padding-inline: 1.5rem; }
  .btn--lg { padding-inline: 1.75rem; }
  .hero__content p { font-size: 1rem; }
  .card { padding: var(--space-5); }
}

/* Faixa mobile — empilha grupos de botões e centraliza CTAs. */
@media (max-width: 599px) {
  .btn-group { flex-direction: column; align-items: stretch; }
  .btn-group .btn { width: 100%; }
  .btn-group--center { align-items: center; }
  .btn-group--center .btn { width: auto; }
  .split { gap: var(--space-8); }
  .map-embed { height: 360px; }
  .timeline { gap: var(--space-6); }
  .timeline__item { gap: var(--space-4); padding-bottom: var(--space-6); }
}

/* Tablet — ajusta o ritmo entre seção e container. */
@media (min-width: 600px) and (max-width: 1023px) {
  :root { --gap-section: clamp(3rem, 5vw, 3.75rem); }
  .map-embed { height: 460px; }
  .hero__content { padding-bottom: var(--space-12); }
}

/* Desktop amplo — limita o crescimento e reforça o respiro lateral. */
@media (min-width: 1440px) {
  :root { --gap-section: 4.5rem; }
  .hero__content p { font-size: 1.125rem; }
}

/* Telas baixas (notebooks) — hero não estoura a altura útil. */
@media (max-height: 640px) and (min-width: 768px) {
  .hero { min-height: 32rem; }
  .hero__content { padding-bottom: var(--space-10); }
}

/* Orientação paisagem no celular — hero ainda mais enxuto. */
@media (max-height: 500px) and (orientation: landscape) {
  .hero { min-height: 26rem; }
  .hero__content { padding-bottom: var(--space-8); gap: var(--space-3); }
}

/* Ponteiro fino (mouse) — habilita micro-interações de hover mais ricas. */
@media (hover: hover) and (pointer: fine) {
  .card,
  .audience-card,
  .split__media { cursor: default; }
}

/* Ponteiro grosso (toque) — desliga efeitos de hover que "grudam". */
@media (hover: none) {
  .btn::before,
  .split__media::after { display: none; }
  .card:hover,
  .audience-card:hover { transform: none; }
}

/* ══════════════════════════════════════════════════════════════════════════
   27 · SEÇÃO ESCURA — POLIMENTO
   Garante contraste e coerência de todos os componentes sobre fundo escuro.
   ══════════════════════════════════════════════════════════════════════════ */
.section--dark .label { color: var(--color-light-opacity); }
.section--dark .section-eyebrow { color: var(--color-primary-light); }
.section--dark .section-eyebrow::before { background-color: var(--color-primary-light); }
.section--dark .divider { color: var(--tint-light-16); }
.section--dark .badge { background-color: var(--tint-light-10); color: var(--color-light); }
.section--dark .chip {
  background-color: var(--tint-light-06);
  border-color: var(--tint-light-16);
  color: var(--color-light);
}
.section--dark .chip:hover { background-color: var(--tint-light-10); }
.section--dark .note {
  background-color: var(--tint-light-06);
  color: var(--color-light-opacity);
}
.section--dark .kbd {
  background-color: var(--color-dark-surface);
  border-color: var(--tint-light-16);
  color: var(--color-light);
}
.section--dark .tag {
  background-color: var(--tint-light-10);
  color: var(--color-light-opacity);
}

/* ══════════════════════════════════════════════════════════════════════════
   28 · DETALHES FINAIS DE INTERFACE
   Pequenos ajustes que somam na percepção de acabamento.
   ══════════════════════════════════════════════════════════════════════════ */

/* Imagens nunca vazam de containers arredondados. */
.split__media,
.map-embed,
.price-table__wrapper,
.card { overflow: hidden; }

/* Ícones Remix alinhados verticalmente com o texto ao lado. */
.ri-1, [class^="ri-"], [class*=" ri-"] { vertical-align: middle; }

/* Texto não selecionável em elementos puramente decorativos. */
.hero__content .label::before,
.section-eyebrow::before,
.divider__dot,
.manifesto__divider { user-select: none; }

/* Suaviza o aparecimento do conteúdo ao trocar de âncora. */
main { transition: opacity var(--dur-quick) var(--ease-out-soft); }

/* Container de prosa centraliza e respira igual em qualquer seção. */
.container--prose { padding-inline: var(--pad-inline-edge); }

/* Garante que botões e links nunca fiquem com texto colado nas bordas. */
.btn { letter-spacing: 0.01em; }

/* Sombra de foco para a tabela quando navegada por teclado. */
.price-table__wrapper:focus-within { box-shadow: var(--shadow-card), var(--glow-primary); }

/* Realce na linha da tabela com foco interno. */
.price-table__body tr:focus-within { background-color: var(--tint-primary-14); }

/* Estado visitado de links de prosa — discreto, mantém legibilidade. */
.accordion__body a:visited,
.where-content a:visited { color: var(--color-primary-surface); }

/* Espaço entre parágrafos consecutivos em qualquer corpo de texto. */
.accordion__body > * + *,
.note > * + * { margin-top: var(--space-3); }

/* Cantos arredondados padronizados em todas as mídias retangulares. */
.split__media,
.map-embed { border-radius: var(--radius-l); }

/* Botão de WhatsApp ganha um leve verde no hover (afinidade com a marca
   do app), mantendo o primário como base. */
.btn[href*="whatsa.me"] .ri-whatsapp-line,
.site-footer__link[href*="whatsa.me"]:hover { color: inherit; }

/* Foco visível também em iframes (mapa). */
.map-embed iframe:focus-visible {
  outline: var(--rule-thick) solid var(--color-primary);
  outline-offset: -3px;
}

/* ══════════════════════════════════════════════════════════════════════════
   29 · KEYFRAMES
   Todas as animações nomeadas usadas acima.
   ══════════════════════════════════════════════════════════════════════════ */

/* Giro contínuo — usado em loaders e .fx-spin. */
@keyframes spin {
  to { transform: rotate(360deg); }
}

/* Pulso suave de chamada para ação. */
@keyframes cta-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(196, 69, 44, 0.45); }
  50%      { box-shadow: 0 0 0 14px rgba(196, 69, 44, 0); }
}

/* Realce ao chegar numa âncora. */
@keyframes target-flash {
  0%   { background-color: var(--tint-primary-22); }
  100% { background-color: transparent; }
}

/* Ken Burns lento na imagem do hero. */
@keyframes hero-kenburns {
  from { transform: scale(1.12); }
  to   { transform: scale(1); }
}

/* Parallax do fundo do hero conforme rola (scroll-driven). */
@keyframes hero-parallax {
  from { transform: translateY(0) scale(1); }
  to   { transform: translateY(8%) scale(1.06); }
}

/* Entrada do menu mobile. */
@keyframes menu-in {
  from { opacity: 0; transform: scale(1.02); }
  to   { opacity: 1; transform: scale(1); }
}

/* Itens do menu mobile entram em cascata. */
@keyframes menu-item-in {
  from { opacity: 0; transform: translateY(0.75rem); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Flutuação contínua. */
@keyframes float {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-8px); }
}

/* Brilho que percorre (shimmer/skeleton). */
@keyframes shimmer {
  to { transform: translateX(100%); }
}

/* Gradiente animado. */
@keyframes gradient-shift {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* Escala de entrada. */
@keyframes pop-in {
  from { opacity: 0; transform: scale(0.9); }
  to   { opacity: 1; transform: scale(1); }
}

/* Aparição de baixo para cima (scroll-driven). */
@keyframes scroll-fade-up {
  from { opacity: 0; transform: translateY(2rem); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Crescimento da barra de progresso de leitura. */
@keyframes progress-grow {
  from { transform: scaleX(0); }
  to   { transform: scaleX(1); }
}

/* Revelação simples de imagem (fallback de lazy load). */
@keyframes img-reveal {
  to { opacity: 1; }
}

/* Tremor curto para feedback de erro (opcional). */
@keyframes shake {
  0%, 100%      { transform: translateX(0); }
  20%, 60%      { transform: translateX(-4px); }
  40%, 80%      { transform: translateX(4px); }
}
.fx-shake { animation: shake 0.4s var(--ease-in-out-ct) 1; }

/* Batida dupla para confirmar uma ação (opcional). */
@keyframes heartbeat {
  0%, 100%   { transform: scale(1); }
  15%, 45%   { transform: scale(1.08); }
  30%        { transform: scale(1); }
}
.fx-heartbeat { animation: heartbeat 1s var(--ease-in-out-ct) 1; }

/* ══════════════════════════════════════════════════════════════════════════
   30 · REDUÇÃO DE MOVIMENTO
   Bloco mestre: para quem prefere menos animação, tudo aqui some.
   Mantém a interface 100% funcional, apenas sem movimento.
   ══════════════════════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }

  /* Desliga efeitos baseados em transform/animação contínua. */
  .btn::before,
  .split__media::after,
  .fx-shimmer::after,
  .skeleton::after { display: none; }

  .btn:hover,
  .btn:active,
  .card:hover,
  .card--on-dark:hover,
  .audience-card:hover,
  .timeline__item:hover,
  .site-footer__link:hover,
  .split__media:hover img,
  .fx-lift:hover,
  .fx-tilt:hover { transform: none; }

  .hero__bg img,
  .btn--pulse,
  .fx-float,
  .fx-gradient-shift,
  .fx-spin { animation: none; }

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

  /* Mantém o feedback de estado, só sem o "movimento". */
  .btn:hover { box-shadow: var(--shadow-lift); }
  .card:hover { box-shadow: var(--shadow-lift); }
}

/* ══════════════════════════════════════════════════════════════════════════
   31 · IMPRESSÃO
   Layout limpo para quando a página é impressa ou salva em PDF.
   ══════════════════════════════════════════════════════════════════════════ */
@media print {
  *,
  *::before,
  *::after {
    background: transparent !important;
    color: #000 !important;
    box-shadow: none !important;
    text-shadow: none !important;
    filter: none !important;
  }

  /* Esconde elementos puramente interativos/decorativos. */
  .site-header,
  .mobile-menu,
  .site-header__menu-trigger,
  .hero__overlay,
  .hero::before,
  .btn,
  .btn-group,
  .price-tooltip__bubble,
  .map-embed iframe { display: none !important; }

  body { font-size: 12pt; line-height: 1.4; }

  .section { padding-block: 1.5rem; }
  .hero { min-height: auto; }
  .hero__content { padding: 1.5rem 0; color: #000; }
  .hero__bg { position: relative; }
  .hero__bg img { max-height: 8cm; }

  /* Garante que blocos importantes não quebrem no meio da página. */
  .card,
  .audience-card,
  .timeline__item,
  .accordion__item,
  .price-table__wrapper { break-inside: avoid; }

  h1, h2, h3 { break-after: avoid; }

  /* Mostra o destino dos links no texto impresso. */
  a[href^="http"]::after {
    content: " (" attr(href) ")";
    font-size: 0.85em;
    color: #555 !important;
    word-break: break-all;
  }

  /* Acordeão sempre aberto na impressão. */
  .accordion__content { display: block !important; }
  .accordion__body { opacity: 1 !important; transform: none !important; padding-bottom: 0.5rem; }

  /* Borda visível na tabela de preços impressa. */
  .price-table__wrapper { border: 1px solid #000 !important; }
  .price-table__head tr { background: #ddd !important; }
  .price-table__body tr { border-bottom: 1px solid #999 !important; }
}

/* ╔══════════════════════════════════════════════════════════════════════════╗
   ║   MELHORIAS — RODADA 2                                                   ║
   ║   Escala tipográfica padronizada · Tabela de preços redesenhada ·        ║
   ║   Mais usabilidade, design e efeitos.                                    ║
   ╚══════════════════════════════════════════════════════════════════════════╝ */

/* ══════════════════════════════════════════════════════════════════════════
   32 · ESCALA TIPOGRÁFICA
   Fonte base subiu de 15px → 17px. Todos os tamanhos saem destes tokens —
   nada de px/rem soltos espalhados pelo CSS. Ritmo modular ~1.2.
   ══════════════════════════════════════════════════════════════════════════ */
:root {
  /* Tamanhos — base html = 16px */
  --text-2xs:  0.75rem;     /* 12px — micro-rótulo, uso raro          */
  --text-xs:   0.8125rem;   /* 13px — labels, captions, eyebrow       */
  --text-sm:   0.9375rem;   /* 15px — texto de apoio, notas           */
  --text-base: 1.0625rem;   /* 17px — CORPO PADRÃO                    */
  --text-md:   1.1875rem;   /* 19px — lead, texto de destaque         */
  --text-lg:   clamp(1.25rem,  1.05rem + 0.9vw, 1.4375rem);  /* subtítulos */
  --text-xl:   clamp(1.4375rem, 1.15rem + 1.5vw, 1.75rem);   /* preço      */
  --text-2xl:  clamp(1.625rem,  1.25rem + 1.9vw, 2.125rem);  /* h3         */
  --text-3xl:  clamp(1.9375rem, 1.45rem + 2.6vw, 2.75rem);   /* h2         */
  --text-4xl:  clamp(2.25rem,   1.65rem + 3.2vw, 3.25rem);   /* títulos XL */
  --text-5xl:  clamp(2.625rem,  1.9rem + 4.0vw, 4rem);       /* h1         */

  /* Aliases semânticos */
  --text-label: var(--text-xs);
  --text-nav:   1rem;
  --text-body:  var(--text-base);

  /* Alturas de linha padronizadas */
  --leading-tight:   1.12;
  --leading-snug:    1.3;
  --leading-normal:  1.65;
  --leading-relaxed: 1.78;

  /* Pesos nomeados (eco dos --weight-* originais) */
  --fw-regular:  400;
  --fw-medium:   500;
  --fw-semibold: 600;
  --fw-bold:     700;
  --fw-black:    800;

  /* Tracking */
  --tracking-tight:  -0.015em;
  --tracking-normal: 0;
  --tracking-wide:   0.04em;
  --tracking-wider:  0.08em;
}

/* ══════════════════════════════════════════════════════════════════════════
   33 · APLICAÇÃO DA ESCALA AOS COMPONENTES
   Cada componente passa a referenciar a escala. Corrige as "fontes muito
   pequenas" — nada abaixo de 13px, corpo em 17px, títulos com peso real.
   ══════════════════════════════════════════════════════════════════════════ */

/* Botões — variantes de tamanho realinhadas à escala. */
.btn        { letter-spacing: 0.01em; }
.btn--sm    { font-size: var(--text-sm); padding: 0.5rem 1.375rem; }
.btn--lg    { font-size: var(--text-md); padding: 0.9375rem 2.75rem; }

/* Navegação do header. */
.site-header__nav-list a:not(.btn) { font-size: var(--text-nav); font-weight: 500; }

/* Menu mobile — itens grandes e confortáveis ao toque. */
.mobile-menu__list .link { font-size: var(--text-2xl); }

/* Hero — parágrafo de apoio com presença. */
.hero__content p { font-size: var(--text-md); line-height: 1.55; }

/* Cards de diferenciais — título controlado (não estoura no grid de 4). */
.card h3 {
  font-size: var(--text-lg);
  font-weight: var(--fw-regular);
  line-height: var(--leading-snug);
  text-wrap: balance;
}
.card p { font-size: var(--text-base); line-height: var(--leading-normal); }

/* Audience cards. */
.audience-card__title { font-size: var(--text-lg); line-height: var(--leading-snug); }
.audience-card__text  { font-size: var(--text-base); line-height: var(--leading-normal); }
.audience-card__tags  { font-size: var(--text-sm); }

/* Timeline. */
.timeline__number   { font-size: clamp(2.75rem, 6vw, 4.25rem); }
.timeline__body h3  { font-size: var(--text-xl); }
.timeline__body p   { font-size: var(--text-base); }

/* Accordion — pergunta legível, resposta no corpo padrão. */
.accordion__question { font-size: var(--text-lg); line-height: var(--leading-snug); }
.accordion__body,
.accordion__body p   { font-size: var(--text-base); line-height: var(--leading-relaxed); }

/* Manifesto. */
.manifesto__title { font-size: var(--text-4xl); }
.manifesto__body  { font-size: var(--text-md); line-height: var(--leading-relaxed); }

/* Onde estamos. */
.where-content p      { font-size: var(--text-base); }
.location-info dt     { font-size: var(--text-xs); }
.location-info dd     { font-size: var(--text-base); font-weight: var(--fw-medium); }

/* Rodapé — nada de letra miúda. */
.site-footer p,
.site-footer li,
.site-footer__link    { font-size: var(--text-base); }
.site-footer__bottom .label { font-size: var(--text-xs); }

/* Texto de apoio grande. */
.body-lg { font-size: var(--text-md); line-height: var(--leading-relaxed); }

/* Componentes auxiliares. */
.section-eyebrow      { font-size: var(--text-xs); }
.badge                { font-size: var(--text-2xs); }
.tag                  { font-size: var(--text-xs); }
.kbd                  { font-size: var(--text-sm); }
.chip                 { font-size: var(--text-sm); }
.stat__label          { font-size: var(--text-xs); }
.price-tooltip__bubble { font-size: var(--text-sm); }
.note                 { font-size: var(--text-base); }

/* Cabeçalho de seção genérico. */
.section-head h2      { margin: 0; }
.section-head p       { font-size: var(--text-md); }

/* ══════════════════════════════════════════════════════════════════════════
   34 · UTILITÁRIOS DE TIPOGRAFIA
   Classes diretas para aplicar a escala sem criar regra nova.
   ══════════════════════════════════════════════════════════════════════════ */
.text-2xs  { font-size: var(--text-2xs); }
.text-xs   { font-size: var(--text-xs); }
.text-sm   { font-size: var(--text-sm); }
.text-base { font-size: var(--text-base); }
.text-md   { font-size: var(--text-md); }
.text-lg   { font-size: var(--text-lg); }
.text-xl   { font-size: var(--text-xl); }
.text-2xl  { font-size: var(--text-2xl); }
.text-3xl  { font-size: var(--text-3xl); }
.text-4xl  { font-size: var(--text-4xl); }
.text-5xl  { font-size: var(--text-5xl); }

.fw-regular  { font-weight: var(--fw-regular); }
.fw-medium   { font-weight: var(--fw-medium); }
.fw-semibold { font-weight: var(--fw-semibold); }
.fw-bold     { font-weight: var(--fw-bold); }
.fw-black    { font-weight: var(--fw-black); }

.font-title { font-family: var(--font-titles); }
.font-text  { font-family: var(--font-text); }
.font-label { font-family: var(--font-label); }

.leading-tight   { line-height: var(--leading-tight); }
.leading-snug    { line-height: var(--leading-snug); }
.leading-normal  { line-height: var(--leading-normal); }
.leading-relaxed { line-height: var(--leading-relaxed); }

.tracking-tight  { letter-spacing: var(--tracking-tight); }
.tracking-wide   { letter-spacing: var(--tracking-wide); }
.tracking-wider  { letter-spacing: var(--tracking-wider); }

.uppercase   { text-transform: uppercase; }
.capitalize  { text-transform: capitalize; }
.normal-case { text-transform: none; }

.text-balance { text-wrap: balance; }
.text-pretty  { text-wrap: pretty; }
.text-nowrap  { white-space: nowrap; }

.text-primary { color: var(--color-primary); }
.text-muted   { color: var(--color-text-muted); }
.text-dark    { color: var(--color-dark); }
.text-light   { color: var(--color-light); }

/* ══════════════════════════════════════════════════════════════════════════
   35 · TABELA DE PREÇOS — REDESIGN COMPLETO
   De tabela "crua" para um cartão de preços com hierarquia clara:
   ícone + nome da ferramenta de um lado, preço grande do outro.
   Sai o monospace apertado; entra ritmo, cor e profundidade.
   ══════════════════════════════════════════════════════════════════════════ */

/* Container da tabela: largura de leitura, centralizado, espaço pro selo. */
.price-table {
  position: relative;
  width: 100%;
  max-width: 40rem;
  margin-inline: auto;
  padding-top: var(--space-3); /* respiro para o ribbon que "sai" pra cima */
}

/* Selo flutuante no topo — "Sem surpresa no final". */
.price-table__ribbon {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0.4375rem 1rem;
  border-radius: var(--radius-pill);
  background: linear-gradient(135deg, var(--color-primary), var(--color-primary-light));
  color: #fff;
  font: var(--fw-bold) var(--text-2xs) var(--font-label);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  white-space: nowrap;
  box-shadow: var(--shadow-lift), var(--glow-soft);
}
.price-table__ribbon i { font-size: 1rem; }

/* Cartão que envolve a tabela. */
.price-table__wrapper {
  position: relative;
  overflow: hidden;
  border: var(--rule-thin) solid var(--color-border);
  border-radius: var(--radius-l);
  background-color: var(--color-light);
  box-shadow: var(--shadow-pop);
  transition: box-shadow var(--dur-base) var(--ease-out-soft),
              transform var(--dur-base) var(--ease-spring);
}
.price-table:hover .price-table__wrapper {
  transform: translateY(-3px);
  box-shadow: var(--shadow-pop), var(--glow-soft);
}

/* Faixa de gradiente no topo do cartão. */
.price-table__wrapper::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: var(--rule-thick);
  background: linear-gradient(90deg,
    var(--color-primary),
    var(--color-primary-light),
    var(--color-primary));
  z-index: 2;
}

/* A tabela em si — fonte de texto (adeus monospace apertado). */
.price-table__table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background-color: transparent;
  font-family: var(--font-text);
}

/* Cabeçalho — barra escura com rótulos em monospace. */
.price-table__head tr {
  background: linear-gradient(135deg, var(--color-dark), var(--color-dark-surface));
  color: var(--color-light);
}
.price-table__head th {
  padding: var(--space-4) clamp(1.25rem, 4vw, 2.25rem);
  font: var(--fw-semibold) var(--text-xs) var(--font-label);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--color-light-opacity);
  text-align: left;
}
.price-table__head th:last-child { text-align: right; }

/* Corpo — linhas altas, respiráveis. */
.price-table__body td {
  padding: clamp(0.875rem, 2.5vw, 1.375rem) clamp(1.25rem, 4vw, 2.25rem);
  border-bottom: var(--rule-thin) solid var(--color-border);
  vertical-align: middle;
  background-color: transparent;
}
.price-table__body tr {
  transition: background-color var(--dur-quick) var(--ease-out-soft);
}
.price-table__body tr:last-child td { border-bottom: none; }
.price-table__body tr:nth-child(even) { background-color: transparent; } /* zebra off — visual mais limpo */
.price-table__body tr:hover { background-color: var(--tint-primary-08); }

/* Coluna 1 — ferramenta com ícone. */
.price-table__body td:first-child { width: 62%; }

.price-table__tool {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}
.price-table__tool-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.875rem;
  height: 2.875rem;
  flex-shrink: 0;
  border-radius: var(--radius-m);
  background-color: var(--tint-primary-14);
  color: var(--color-primary);
  font-size: 1.5rem;
  transition:
    transform var(--dur-base) var(--ease-out-back),
    background-color var(--dur-base) var(--ease-out-soft),
    color var(--dur-base) var(--ease-out-soft);
}
.price-table__body tr:hover .price-table__tool-icon {
  transform: scale(1.1) rotate(-5deg);
  background-color: var(--color-primary);
  color: #fff;
}
.price-table__tool-name {
  font: var(--fw-semibold) var(--text-md) var(--font-text);
  color: var(--color-dark);
  line-height: var(--leading-snug);
}

/* Coluna 2 — preço em destaque. */
.price-table__body td:last-child { text-align: right; }

.price-table__price {
  display: inline-block;
  font: var(--fw-bold) var(--text-xl) var(--font-text);
  color: var(--color-primary-surface);
  letter-spacing: var(--tracking-tight);
  white-space: nowrap;
  line-height: 1;
}
.price-table__plus {
  font-size: 0.55em;
  font-weight: var(--fw-semibold);
  color: var(--color-text-muted);
  vertical-align: super;
  margin-left: 0.1em;
}
.price-table__body tr:hover .price-table__price {
  color: var(--color-primary);
}

/* Célula com tooltip — preço + "?" alinhados à direita. */
.price-cell {
  justify-content: flex-end;
  align-items: center;
  gap: var(--space-2);
}

/* Tooltip do "?" um pouco maior e mais visível. */
.price-tooltip__icon {
  width: 1.125rem;
  height: 1.125rem;
  font-size: 0.75rem;
}

/* Nota de rodapé da tabela — caixa de aviso elegante. */
.price-table__note {
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
  text-align: left;
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-m);
  border: var(--rule-thin) solid var(--color-border);
  background-color: var(--color-light);
  color: var(--color-dark-surface);
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
  box-shadow: var(--shadow-xs);
}
.price-table__note i {
  color: var(--color-primary);
  font-size: 1.25rem;
  flex-shrink: 0;
  line-height: 1.4;
}
.price-table__note span { flex: 1; }

/* ══════════════════════════════════════════════════════════════════════════
   36 · SEÇÃO "PREÇOS" — DESTAQUE
   A seção foi movida para logo após os Diferenciais e ganha tratamento
   visual próprio: fundo com leve brilho quente e respiro generoso.
   ══════════════════════════════════════════════════════════════════════════ */
.section--precos {
  position: relative;
  overflow: hidden;
  background-color: var(--color-light-surface);
}

/* Brilho radial quente atrás da tabela — dá foco sem pesar. */
.section--precos::before {
  content: '';
  position: absolute;
  top: -20%;
  left: 50%;
  transform: translateX(-50%);
  width: min(60rem, 120%);
  height: 70%;
  background: radial-gradient(
    ellipse at center,
    var(--tint-primary-14) 0%,
    transparent 70%
  );
  pointer-events: none;
  z-index: 0;
}

/* Linhas decorativas finas nas bordas da seção. */
.section--precos::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(to bottom, var(--tint-primary-22), transparent 6px),
    linear-gradient(to top, var(--tint-primary-22), transparent 6px);
  z-index: 0;
}

/* Garante que o conteúdo fique acima dos pseudo-elementos. */
.section--precos > .container { position: relative; z-index: 1; }

/* Eyebrow da seção centralizado. */
.section--precos .section-eyebrow {
  margin-inline: auto;
  justify-content: center;
}

/* Espaço extra entre os blocos da seção de preços. */
.section--precos > .container { gap: var(--space-12); }

/* ══════════════════════════════════════════════════════════════════════════
   37 · REFINO DE COMPONENTES PÓS-ESCALA
   Pequenos ajustes para que a tipografia maior não aperte nada.
   ══════════════════════════════════════════════════════════════════════════ */

/* Cards de diferenciais — mais respiro interno com a fonte maior. */
.card { padding: clamp(1.5rem, 3vw, 2rem); gap: var(--space-4); }

/* Grid de 4 — em telas médias, evita aperto do título maior. */
@media (min-width: 640px) and (max-width: 1023px) {
  .grid-4 { gap: var(--space-6); }
}

/* Header — leve aumento de altura para acomodar a navegação maior. */
@media (min-width: 768px) {
  .site-header__nav-list { gap: clamp(var(--space-4), 2.5vw, var(--space-6)); }
}

/* Accordion — gatilho com mais área agora que a pergunta é maior. */
.accordion__trigger { padding-block: var(--space-6); }

/* Timeline — corpo com mais espaço entre título e texto. */
.timeline__body { gap: var(--space-2); }

/* Botão grande não quebra linha em telas pequenas. */
.btn--lg { white-space: nowrap; }

/* Parágrafos de prosa nunca passam da medida de leitura. */
.where-content p,
.manifesto__body,
.accordion__body p { max-width: var(--measure); }

/* Títulos de seção centralizada respiram do parágrafo. */
.section-head--center h2 { margin-bottom: var(--space-1); }

/* ══════════════════════════════════════════════════════════════════════════
   38 · FORMULÁRIOS E CAMPOS
   Estilo base coerente para inputs (úteis em formulários futuros).
   ══════════════════════════════════════════════════════════════════════════ */
.field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.field__label {
  font: var(--fw-semibold) var(--text-sm) var(--font-text);
  color: var(--color-dark);
}
.field__hint {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}
.input,
.textarea,
.select {
  width: 100%;
  padding: 0.75rem 1rem;
  font-size: var(--text-base);
  color: var(--color-dark);
  background-color: var(--color-light);
  border: var(--rule-thin) solid var(--color-border-strong);
  border-radius: var(--radius-s);
  transition:
    border-color var(--dur-quick) var(--ease-out-soft),
    box-shadow var(--dur-quick) var(--ease-out-soft),
    background-color var(--dur-quick) var(--ease-out-soft);
}
.input:hover,
.textarea:hover,
.select:hover { border-color: var(--color-dark-surface); }
.input:focus,
.textarea:focus,
.select:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: var(--glow-primary);
  background-color: #fff;
}
.textarea { min-height: 7rem; resize: vertical; }
.input:disabled,
.textarea:disabled,
.select:disabled {
  background-color: var(--color-light-surface);
  cursor: not-allowed;
  opacity: 0.65;
}
.input--error,
.textarea--error { border-color: var(--color-error); }
.input--error:focus,
.textarea--error:focus { box-shadow: 0 0 0 4px rgba(158, 42, 26, 0.16); }

.field__error {
  font-size: var(--text-xs);
  color: var(--color-error);
  font-weight: var(--fw-medium);
}

/* Checkbox / radio com área de toque confortável. */
.choice {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  cursor: pointer;
  min-height: 2.5rem;
}
.choice input { width: 1.15rem; height: 1.15rem; accent-color: var(--color-primary); }

/* Grupo de campos lado a lado. */
.field-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
}
.field-row > .field { flex: 1 1 14rem; }

/* ══════════════════════════════════════════════════════════════════════════
   39 · LISTAS, CITAÇÕES E FIGURAS
   Estilos para conteúdo editorial que possa surgir nas seções.
   ══════════════════════════════════════════════════════════════════════════ */

/* Lista com marcador da marca. */
.list-checked {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.list-checked li {
  position: relative;
  padding-left: var(--space-8);
  font-size: var(--text-base);
}
.list-checked li::before {
  content: '\2713';
  position: absolute;
  left: 0;
  top: 0.05em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 50%;
  background-color: var(--tint-primary-14);
  color: var(--color-primary);
  font-size: 0.85rem;
  font-weight: var(--fw-bold);
}

/* Lista numerada estilizada. */
.list-numbered {
  counter-reset: li;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.list-numbered li {
  counter-increment: li;
  position: relative;
  padding-left: var(--space-10);
  font-size: var(--text-base);
}
.list-numbered li::before {
  content: counter(li, decimal-leading-zero);
  position: absolute;
  left: 0;
  top: 0;
  font: var(--fw-bold) var(--text-base) var(--font-label);
  color: var(--color-primary);
}

/* Citação destacada. */
.quote {
  position: relative;
  padding: var(--space-6) var(--space-8);
  border-left: var(--rule-thick) solid var(--color-primary);
  background-color: var(--tint-primary-08);
  border-radius: 0 var(--radius-m) var(--radius-m) 0;
  font: var(--fw-regular) var(--text-md) var(--font-titles);
  line-height: var(--leading-snug);
  color: var(--color-dark);
}
.quote cite {
  display: block;
  margin-top: var(--space-3);
  font: var(--fw-semibold) var(--text-sm) var(--font-text);
  font-style: normal;
  color: var(--color-text-muted);
}
.quote cite::before { content: '\2014\00a0'; }

/* Figura com legenda. */
.figure { display: flex; flex-direction: column; gap: var(--space-2); }
.figure img { border-radius: var(--radius-m); }
.figcaption {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  text-align: center;
}

/* Divisória horizontal simples reutilizável. */
.hr {
  height: var(--rule-thin);
  background-color: var(--color-border);
  border: none;
  margin-block: var(--space-8);
}
.hr--gradient {
  height: var(--rule-medium);
  background: linear-gradient(90deg, transparent, var(--color-primary), transparent);
}

/* ══════════════════════════════════════════════════════════════════════════
   40 · EFEITOS — RODADA 2
   Novas micro-interações reutilizáveis.
   ══════════════════════════════════════════════════════════════════════════ */

/* Brilho de borda que percorre (para destacar um cartão "premium"). */
.fx-border-run {
  position: relative;
  isolation: isolate;
}
.fx-border-run::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: var(--rule-medium);
  background: linear-gradient(
    120deg,
    transparent,
    var(--color-primary),
    var(--color-primary-light),
    transparent
  );
  background-size: 300% 100%;
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  animation: border-run 3s linear infinite;
  z-index: -1;
}

/* Aparição com leve giro. */
.fx-reveal-rotate {
  opacity: 0;
  transform: translateY(1.5rem) rotate(-1.5deg);
  transition:
    opacity var(--dur-slow) var(--ease-out-soft),
    transform var(--dur-slow) var(--ease-spring);
}
.fx-reveal-rotate.is-inview { opacity: 1; transform: none; }

/* Sublinhado "marca-texto" que cresce. */
.fx-highlight {
  background-image: linear-gradient(var(--tint-primary-22), var(--tint-primary-22));
  background-repeat: no-repeat;
  background-position: 0 88%;
  background-size: 0% 0.4em;
  transition: background-size var(--dur-base) var(--ease-out-soft);
}
.fx-highlight:hover,
.fx-highlight.is-active { background-size: 100% 0.4em; }

/* Ícone que "pula" no hover do pai. */
.fx-icon-bounce { transition: transform var(--dur-quick) var(--ease-out-back); }
*:hover > .fx-icon-bounce { transform: translateY(-3px); }

/* Zoom suave em imagem dentro de moldura. */
.fx-zoom { overflow: hidden; }
.fx-zoom img,
.fx-zoom > * {
  transition: transform var(--dur-slow) var(--ease-out-soft);
}
.fx-zoom:hover img,
.fx-zoom:hover > * { transform: scale(1.06); }

/* Pulso de anel único (para chamar atenção pontualmente). */
.fx-ring {
  position: relative;
}
.fx-ring::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: var(--rule-medium) solid var(--color-primary);
  opacity: 0;
  animation: ring-out 1.8s var(--ease-out-soft) infinite;
}

/* Texto que aparece letra a letra (quando JS adiciona is-inview). */
.fx-fade-chars { transition: opacity var(--dur-base); }

/* Sombra "elevada" progressiva ao focar dentro. */
.fx-focus-raise:focus-within {
  box-shadow: var(--shadow-lift);
  transform: translateY(-2px);
}

/* Card com inclinação que segue o cursor (precisa de var --mx/--my via JS;
   degrada para estático sem JS). */
.fx-parallax-card {
  transition: transform var(--dur-base) var(--ease-out-soft);
  transform:
    perspective(800px)
    rotateX(calc(var(--my, 0.5) * -6deg + 3deg))
    rotateY(calc(var(--mx, 0.5) * 6deg - 3deg));
}

/* ══════════════════════════════════════════════════════════════════════════
   41 · UTILITÁRIOS — RODADA 2
   Mais auxiliares de layout, posição e visibilidade.
   ══════════════════════════════════════════════════════════════════════════ */

/* Display. */
.d-none    { display: none; }
.d-block   { display: block; }
.d-flex    { display: flex; }
.d-grid    { display: grid; }
.d-inline-flex { display: inline-flex; }

/* Flex helpers. */
.flex-col     { flex-direction: column; }
.flex-wrap    { flex-wrap: wrap; }
.items-center { align-items: center; }
.items-start  { align-items: flex-start; }
.items-end    { align-items: flex-end; }
.justify-center  { justify-content: center; }
.justify-between { justify-content: space-between; }
.justify-end     { justify-content: flex-end; }
.flex-1       { flex: 1 1 0%; }
.flex-auto    { flex: 1 1 auto; }
.flex-none    { flex: none; }

/* Posição. */
.relative { position: relative; }
.absolute { position: absolute; }
.sticky   { position: sticky; }
.inset-0  { inset: 0; }
.z-1  { z-index: 1; }
.z-10 { z-index: 10; }

/* Largura / altura. */
.w-full   { width: 100%; }
.w-fit    { width: fit-content; }
.h-full   { height: 100%; }
.max-w-full { max-width: 100%; }
.min-w-0  { min-width: 0; }

/* Overflow. */
.overflow-hidden { overflow: hidden; }
.overflow-auto   { overflow: auto; }

/* Bordas e raios. */
.rounded-s    { border-radius: var(--radius-s); }
.rounded-m    { border-radius: var(--radius-m); }
.rounded-l    { border-radius: var(--radius-l); }
.rounded-pill { border-radius: var(--radius-pill); }
.border       { border: var(--rule-thin) solid var(--color-border); }
.border-strong{ border: var(--rule-thin) solid var(--color-border-strong); }
.border-top   { border-top: var(--rule-thin) solid var(--color-border); }

/* Sombras. */
.shadow-xs   { box-shadow: var(--shadow-xs); }
.shadow-soft { box-shadow: var(--shadow-soft); }
.shadow-card { box-shadow: var(--shadow-card); }
.shadow-lift { box-shadow: var(--shadow-lift); }
.shadow-none { box-shadow: none; }

/* Fundos. */
.bg-light       { background-color: var(--color-light); }
.bg-surface     { background-color: var(--color-light-surface); }
.bg-dark        { background-color: var(--color-dark); color: var(--color-light); }
.bg-primary     { background-color: var(--color-primary); color: #fff; }
.bg-tint        { background-color: var(--tint-primary-08); }

/* Cursor / seleção. */
.cursor-pointer { cursor: pointer; }
.select-none   { user-select: none; }
.pointer-none  { pointer-events: none; }

/* Opacidade. */
.opacity-0  { opacity: 0; }
.opacity-50 { opacity: 0.5; }
.opacity-100{ opacity: 1; }

/* ══════════════════════════════════════════════════════════════════════════
   42 · GRID E LAYOUT EXTRA
   Padrões de grade reutilizáveis e responsivos por padrão.
   ══════════════════════════════════════════════════════════════════════════ */

/* Grade automática — quantas colunas couberem, mínimo configurável. */
.auto-grid {
  display: grid;
  gap: var(--space-6);
  grid-template-columns: repeat(auto-fit, minmax(min(16rem, 100%), 1fr));
}
.auto-grid--sm { grid-template-columns: repeat(auto-fit, minmax(min(12rem, 100%), 1fr)); }
.auto-grid--lg { grid-template-columns: repeat(auto-fit, minmax(min(22rem, 100%), 1fr)); }

/* Duas colunas que viram uma no mobile. */
.cols-2 {
  display: grid;
  gap: var(--space-8);
  grid-template-columns: 1fr;
}
@media (min-width: 768px) {
  .cols-2 { grid-template-columns: 1fr 1fr; }
}

/* Conteúdo centralizado com largura máxima. */
.wrap {
  width: 100%;
  max-width: var(--max-width);
  margin-inline: auto;
  padding-inline: var(--pad-inline-edge);
}
.wrap--prose { max-width: var(--max-width-prose); }
.wrap--narrow { max-width: 60.25rem; }

/* Pilha com espaçamento de seção. */
.section-stack {
  display: flex;
  flex-direction: column;
  gap: var(--gap-section);
}

/* Alinhamento de itens ao baseline para números + rótulos. */
.baseline { display: flex; align-items: baseline; gap: var(--space-2); }

/* ══════════════════════════════════════════════════════════════════════════
   43 · ESTADOS E FEEDBACK
   Toasts, alertas, progress, indicadores — base pronta para uso futuro.
   ══════════════════════════════════════════════════════════════════════════ */

/* Alerta inline. */
.alert {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-m);
  font-size: var(--text-sm);
  border: var(--rule-thin) solid;
}
.alert__icon { font-size: 1.25rem; flex-shrink: 0; line-height: 1.3; }
.alert--info    { background: var(--tint-primary-08);   border-color: var(--tint-primary-22);   color: var(--color-primary-surface); }
.alert--success { background: rgba(46,110,78,.08);      border-color: rgba(46,110,78,.3);       color: var(--color-success); }
.alert--warning { background: rgba(184,138,26,.1);      border-color: rgba(184,138,26,.35);     color: var(--color-warning); }
.alert--error   { background: rgba(158,42,26,.08);      border-color: rgba(158,42,26,.3);       color: var(--color-error); }

/* Barra de progresso. */
.progress {
  width: 100%;
  height: 0.5rem;
  border-radius: var(--radius-pill);
  background-color: var(--color-light-surface);
  overflow: hidden;
}
.progress__bar {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--color-primary), var(--color-primary-light));
  transition: width var(--dur-slow) var(--ease-out-soft);
}

/* Indicador de status (bolinha + texto). */
.status {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  font-weight: var(--fw-medium);
}
.status::before {
  content: '';
  width: 0.625rem;
  height: 0.625rem;
  border-radius: 50%;
  background-color: var(--color-text-muted);
}
.status--online::before  { background-color: var(--color-success); box-shadow: 0 0 0 3px rgba(46,110,78,.2); }
.status--busy::before    { background-color: var(--color-warning); }
.status--offline::before { background-color: var(--color-text-muted); }

/* Toast (canto da tela). */
.toast {
  position: fixed;
  bottom: var(--space-6);
  left: 50%;
  transform: translateX(-50%) translateY(1rem);
  z-index: 400;
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-5);
  border-radius: var(--radius-m);
  background-color: var(--color-dark);
  color: var(--color-light);
  box-shadow: var(--shadow-pop);
  font-size: var(--text-sm);
  opacity: 0;
  visibility: hidden;
  transition:
    opacity var(--dur-base) var(--ease-out-soft),
    transform var(--dur-base) var(--ease-out-back),
    visibility var(--dur-base);
}
.toast.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}

/* Spinner standalone. */
.spinner {
  display: inline-block;
  width: 1.5rem;
  height: 1.5rem;
  border: 2.5px solid var(--color-border);
  border-top-color: var(--color-primary);
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
}
.spinner--lg { width: 2.5rem; height: 2.5rem; border-width: 3.5px; }

/* Ponto pulsante de "novo". */
.pip {
  display: inline-block;
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  background-color: var(--color-primary);
  position: relative;
}
.pip::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background-color: var(--color-primary);
  animation: ring-out 1.6s var(--ease-out-soft) infinite;
}

/* ══════════════════════════════════════════════════════════════════════════
   44 · RESPONSIVO — RODADA 2
   Ajustes finos por faixa para a nova escala tipográfica.
   ══════════════════════════════════════════════════════════════════════════ */

/* Mobile — tabela de preços compacta mas legível. */
@media (max-width: 599px) {
  .price-table__head th { padding-inline: var(--space-5); }
  .price-table__body td { padding-inline: var(--space-5); }
  .price-table__tool { gap: var(--space-3); }
  .price-table__tool-icon { width: 2.5rem; height: 2.5rem; font-size: 1.3rem; }
  .price-table__tool-name { font-size: var(--text-base); }
  .price-table__price { font-size: var(--text-lg); }
  .price-table__ribbon { font-size: 0.6875rem; padding-inline: 0.75rem; }
  .section--precos > .container { gap: var(--space-8); }
}

/* Telas bem estreitas — empilha ferramenta e preço. */
@media (max-width: 400px) {
  .price-table__body td:first-child { width: auto; }
  .price-table__tool-name { font-size: var(--text-sm); }
}

/* Tablet — equilíbrio entre densidade e respiro. */
@media (min-width: 600px) and (max-width: 1023px) {
  .price-table { max-width: 34rem; }
}

/* Desktop grande — a tabela pode crescer um pouco. */
@media (min-width: 1280px) {
  .price-table { max-width: 42rem; }
  .price-table__tool-name { font-size: var(--text-lg); }
}

/* Reduz o tamanho dos títulos em telas curtas para caber mais conteúdo. */
@media (max-height: 700px) and (min-width: 768px) {
  :root { --text-3xl: clamp(1.75rem, 1.3rem + 2vw, 2.25rem); }
}

/* ══════════════════════════════════════════════════════════════════════════
   45 · ACESSIBILIDADE — RODADA 2
   Reforços adicionais de leitura e navegação.
   ══════════════════════════════════════════════════════════════════════════ */

/* Aumento de fonte respeitado: tudo em rem/em escala junto. */
@media (min-width: 1px) {
  html { font-size: 100%; }
}

/* Foco dentro da tabela destaca a linha inteira. */
.price-table__body tr:focus-within {
  background-color: var(--tint-primary-14);
  outline: var(--rule-medium) solid var(--color-primary);
  outline-offset: -2px;
}

/* Link de pular conteúdo também cobre a navegação por preços. */
.price-tooltip:focus-visible {
  outline: var(--rule-medium) solid var(--color-primary);
  outline-offset: 2px;
  border-radius: var(--radius-s);
}

/* Texto nunca fica menor que 13px mesmo em zoom-out de componentes. */
small, .text-small { font-size: max(var(--text-xs), 0.8125rem); }

/* Garante contraste do preço mesmo em modo de mais contraste. */
@media (prefers-contrast: more) {
  .price-table__price { color: var(--color-primary-surface); font-weight: var(--fw-bold); }
  .price-table__head th { color: #fff; }
  .price-table__body td { border-bottom-width: var(--rule-medium); }
  .price-table__note { border-width: var(--rule-medium); }
}

/* Em telas de toque, a dica do tooltip também abre no foco. */
@media (hover: none) {
  .price-tooltip:focus .price-tooltip__bubble {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
  }
}

/* Realce de leitura para o item de FAQ aberto. */
.accordion__item--open { scroll-margin-top: calc(var(--header-height) + var(--space-10)); }

/* ══════════════════════════════════════════════════════════════════════════
   46 · KEYFRAMES — RODADA 2
   ══════════════════════════════════════════════════════════════════════════ */

/* Borda animada (.fx-border-run). */
@keyframes border-run {
  0%   { background-position: 0% 50%; }
  100% { background-position: 300% 50%; }
}

/* Anel que expande e some (.fx-ring, .pip). */
@keyframes ring-out {
  0%   { transform: scale(1);   opacity: 0.6; }
  100% { transform: scale(2.2); opacity: 0; }
}

/* Entrada do selo da tabela de preços. */
@keyframes ribbon-in {
  from { opacity: 0; transform: translateX(-50%) translateY(-0.75rem) scale(0.9); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0) scale(1); }
}
.price-table__ribbon { animation: ribbon-in var(--dur-base) var(--ease-out-back) both; animation-delay: 0.25s; }

/* Contagem de atenção sutil no preço ao entrar na viewport (opt-in). */
@keyframes price-pop {
  0%   { transform: scale(0.8); opacity: 0; }
  60%  { transform: scale(1.06); }
  100% { transform: scale(1); opacity: 1; }
}
.price-table.is-inview .price-table__price { animation: price-pop var(--dur-base) var(--ease-out-back) both; }

/* Brilho que cruza o cartão de preços uma vez ao revelar. */
@keyframes sheen {
  0%   { transform: translateX(-120%) skewX(-18deg); }
  100% { transform: translateX(220%) skewX(-18deg); }
}
.price-table__wrapper::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 40%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.35),
    transparent
  );
  transform: translateX(-120%) skewX(-18deg);
  pointer-events: none;
  z-index: 2;
}
.price-table:hover .price-table__wrapper::after {
  animation: sheen 0.9s var(--ease-out-soft) 1;
}

/* ══════════════════════════════════════════════════════════════════════════
   47 · REDUÇÃO DE MOVIMENTO — COMPLEMENTO
   Garante que as novas animações também respeitem a preferência.
   ══════════════════════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  .price-table__ribbon,
  .price-table.is-inview .price-table__price,
  .fx-border-run::before,
  .fx-ring::after,
  .pip::after,
  .spinner { animation: none; }

  .price-table:hover .price-table__wrapper,
  .price-table__body tr:hover .price-table__tool-icon,
  .fx-zoom:hover img,
  .fx-zoom:hover > *,
  .fx-focus-raise:focus-within,
  .fx-parallax-card { transform: none; }

  .price-table__wrapper::after { display: none; }

  .price-table__ribbon { opacity: 1; }
  .fx-reveal-rotate { opacity: 1; transform: none; }
}

/* ══════════════════════════════════════════════════════════════════════════
   48 · IMPRESSÃO — COMPLEMENTO TABELA DE PREÇOS
   ══════════════════════════════════════════════════════════════════════════ */
@media print {
  .section--precos::before,
  .section--precos::after,
  .price-table__ribbon,
  .price-table__wrapper::before,
  .price-table__wrapper::after { display: none !important; }

  .price-table__wrapper { box-shadow: none !important; border: 1px solid #000 !important; }
  .price-table__head tr  { background: #ddd !important; }
  .price-table__tool-icon { background: #eee !important; border: 1px solid #999 !important; }
  .price-table__price { color: #000 !important; }
  .price-table { max-width: 100%; }
}

/* ══════════════════════════════════════════════════════════════════════════
   FIM DAS MELHORIAS — RODADA 2
   ══════════════════════════════════════════════════════════════════════════ */