/* ============================================================
   LANGUAGE ATELIER — Componentes & Seções
   ============================================================ */

/* ============================================================
   BOTÕES
   ============================================================ */
.btn {
  --btn-bg: var(--c-navy);
  --btn-fg: var(--c-ivory);
  --btn-bd: var(--c-navy);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-3);
  min-height: 48px;                 /* alvo de toque acessível */
  padding: 0.85em 1.9em;
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semi);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--btn-fg);
  background: var(--btn-bg);
  border: 1px solid var(--btn-bd);
  border-radius: var(--r-md);
  transition: transform var(--dur-fast) var(--ease),
              background var(--dur) var(--ease),
              color var(--dur) var(--ease),
              border-color var(--dur) var(--ease),
              box-shadow var(--dur) var(--ease);
  text-align: center;
}
.btn:hover { color: var(--btn-fg); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.btn:active { transform: translateY(0); }

.btn--primary { --btn-bg: var(--c-navy); --btn-fg: var(--c-ivory); --btn-bd: var(--c-navy); }
.btn--primary:hover { --btn-bg: var(--c-midnight); --btn-bd: var(--c-midnight); }

.btn--gold {
  --btn-bg: transparent; --btn-fg: var(--c-midnight); --btn-bd: var(--c-champagne);
}
.btn--gold:hover { --btn-bg: var(--c-champagne); --btn-fg: var(--c-white); }

.btn--ghost { --btn-bg: transparent; --btn-fg: var(--c-navy); --btn-bd: var(--c-ink-10); }
.btn--ghost:hover { --btn-bg: var(--c-navy); --btn-fg: var(--c-ivory); --btn-bd: var(--c-navy); }

.btn--on-dark { --btn-bg: var(--c-ivory); --btn-fg: var(--c-midnight); --btn-bd: var(--c-ivory); }
.btn--on-dark:hover { --btn-bg: transparent; --btn-fg: var(--c-ivory); }

.btn--block { display: flex; width: 100%; }

/* Link com seta (texto-CTA) */
.link-arrow {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  font-weight: var(--fw-semi); font-size: var(--fs-sm);
  letter-spacing: 0.03em; color: var(--c-navy);
}
.link-arrow::after { content: "\2192"; transition: transform var(--dur) var(--ease); }
.link-arrow:hover { color: var(--c-rose-gold); }
.link-arrow:hover::after { transform: translateX(5px); }
.section--dark .link-arrow { color: var(--c-rose-light); }

/* ============================================================
   CABEÇALHO  (atenção máxima — Tomo VII)
   ============================================================ */
.site-header {
  position: sticky;
  top: 0;
  z-index: var(--z-header);
  background: color-mix(in srgb, var(--c-ivory) 88%, transparent);
  -webkit-backdrop-filter: saturate(140%) blur(10px);
  backdrop-filter: saturate(140%) blur(10px);
  border-bottom: 1px solid transparent;
  transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.site-header.is-scrolled {
  background: color-mix(in srgb, var(--c-ivory) 97%, transparent);
  border-bottom-color: var(--line-gold);
  box-shadow: var(--shadow-sm);
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-5);
  min-height: var(--header-h);
}

/* Logo no header */
.brand { display: inline-flex; align-items: center; gap: var(--sp-3); flex-shrink: 0; color: var(--c-navy); }
.brand__mark { color: var(--c-navy); }   /* monograma inline herda via currentColor */
.footer-brand__mark { color: var(--c-ivory); }
.brand__mark { width: 40px; height: 40px; flex-shrink: 0; }
.brand__type { display: flex; flex-direction: column; line-height: 1; }
.brand__name {
  font-family: var(--font-display); font-weight: var(--fw-bold);
  font-size: 1.05rem; letter-spacing: 0.02em; color: var(--c-navy);
}
.brand__sub {
  font-family: var(--font-body); font-size: 0.58rem; font-weight: var(--fw-semi);
  text-transform: uppercase; letter-spacing: 0.24em; color: var(--c-champagne);
  margin-top: 4px;
}

/* Navegação primária (desktop) */
.primary-nav { display: none; }
.nav-list { display: flex; align-items: center; gap: clamp(0.5rem, 1.4vw, 1.6rem); list-style: none; }
.nav-link {
  display: inline-flex; align-items: center; gap: 6px;
  padding: var(--sp-2) var(--sp-2);
  font-size: var(--fs-sm); font-weight: var(--fw-medium);
  color: var(--c-ink); letter-spacing: 0.01em;
  position: relative;
}
.nav-link::after {
  content: ""; position: absolute; left: var(--sp-2); right: var(--sp-2); bottom: 2px;
  height: 1px; background: var(--c-champagne);
  transform: scaleX(0); transform-origin: left; transition: transform var(--dur) var(--ease);
}
.nav-link:hover, .nav-link[aria-current="page"] { color: var(--c-navy); }
.nav-link:hover::after, .nav-link[aria-current="page"]::after { transform: scaleX(1); }
.nav-link__caret { width: 9px; height: 9px; transition: transform var(--dur) var(--ease); }
.has-mega[aria-expanded="true"] .nav-link__caret { transform: rotate(180deg); }

.header-actions { display: flex; align-items: center; gap: var(--sp-4); flex-shrink: 0; }

/* Seletor de idioma (compacto no header) */
.lang-switch { position: relative; display: none; }
.lang-switch__btn {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: var(--fs-xs); font-weight: var(--fw-semi); letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--c-muted); padding: var(--sp-2);
}
.lang-switch__btn:hover { color: var(--c-navy); }
.lang-switch__menu {
  position: absolute; right: 0; top: calc(100% + 8px); min-width: 150px;
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-md);
  box-shadow: var(--shadow-md); padding: var(--sp-2); display: none;
}
.lang-switch[aria-expanded="true"] .lang-switch__menu { display: block; }
.lang-switch__menu a { display: block; padding: var(--sp-2) var(--sp-3); font-size: var(--fs-sm); border-radius: var(--r-sm); color: var(--c-ink); }
.lang-switch__menu a:hover { background: var(--c-marble); color: var(--c-navy); }
.lang-switch__menu a[aria-current="true"] { color: var(--c-champagne); font-weight: var(--fw-semi); }

.header-cta { display: none; }

/* Botão hambúrguer */
.nav-toggle {
  display: inline-flex; flex-direction: column; justify-content: center; gap: 5px;
  width: 48px; height: 48px; padding: 12px; flex-shrink: 0;
}
.nav-toggle span { display: block; height: 1.5px; width: 100%; background: var(--c-navy); transition: transform var(--dur) var(--ease), opacity var(--dur) var(--ease); }
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* ---------- MEGA MENU (desktop) ---------- */
.mega {
  position: absolute; left: 0; right: 0; top: 100%;
  z-index: var(--z-mega);
  background: var(--surface);
  border-top: 1px solid var(--line-gold);
  border-bottom: 1px solid var(--line);
  box-shadow: var(--shadow-lg);
  opacity: 0; visibility: hidden; transform: translateY(-8px);
  transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility var(--dur);
}
.has-mega[aria-expanded="true"] .mega { opacity: 1; visibility: visible; transform: translateY(0); }
.mega__inner { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-7); padding-block: var(--sp-7); }
.mega__feature { padding-right: var(--sp-7); border-right: 1px solid var(--line); }
.mega__feature h3 { font-size: var(--fs-xl); margin-bottom: var(--sp-3); }
.mega__grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-2) var(--sp-6); }
.mega__item { display: block; padding: var(--sp-3); border-radius: var(--r-md); transition: background var(--dur) var(--ease); }
.mega__item:hover { background: var(--c-marble); }
.mega__item strong { display: block; font-family: var(--font-display); font-weight: var(--fw-bold); font-size: var(--fs-base); color: var(--c-navy); }
.mega__item span { display: block; font-size: var(--fs-xs); color: var(--c-muted); margin-top: 2px; }

/* ---------- DRAWER MÓVEL ---------- */
.nav-overlay {
  position: fixed; inset: 0; z-index: var(--z-overlay);
  background: var(--c-navy-90);
  opacity: 0; visibility: hidden; transition: opacity var(--dur) var(--ease), visibility var(--dur);
}
body.nav-open .nav-overlay { opacity: 1; visibility: visible; }
.mobile-nav {
  position: fixed; top: 0; right: 0; bottom: 0; z-index: var(--z-drawer);
  width: min(86vw, 380px);
  background: var(--c-ivory);
  border-left: 1px solid var(--line-gold);
  transform: translateX(100%);
  transition: transform var(--dur-slow) var(--ease-out);
  display: flex; flex-direction: column;
  overflow-y: auto; -webkit-overflow-scrolling: touch;
  padding: var(--sp-6) var(--gutter) var(--sp-8);
}
body.nav-open .mobile-nav { transform: translateX(0); }
.mobile-nav__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--sp-6); }
.mobile-nav__close { width: 44px; height: 44px; display: inline-flex; align-items: center; justify-content: center; color: var(--c-navy); }
.mobile-nav__list { list-style: none; display: flex; flex-direction: column; }
.mobile-nav__list > li { border-bottom: 1px solid var(--line); }
.mobile-nav__link {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--sp-4) 0; font-family: var(--font-display); font-size: var(--fs-lg);
  font-weight: var(--fw-bold); color: var(--c-navy); width: 100%; text-align: left;
}
.mobile-sub { list-style: none; overflow: hidden; max-height: 0; transition: max-height var(--dur) var(--ease); }
.mobile-nav__link[aria-expanded="true"] + .mobile-sub { max-height: 520px; }
.mobile-sub a { display: block; padding: var(--sp-3) 0 var(--sp-3) var(--sp-4); font-size: var(--fs-sm); color: var(--c-ink); }
.mobile-sub a:hover { color: var(--c-rose-gold); }
.mobile-sub li:last-child a { padding-bottom: var(--sp-5); }
.mobile-nav__cta { margin-top: var(--sp-6); }
.mobile-nav__meta { margin-top: var(--sp-6); font-size: var(--fs-xs); color: var(--c-muted); }
.mobile-lang { display: flex; gap: var(--sp-3); margin-top: var(--sp-5); }
.mobile-lang a { font-size: var(--fs-xs); font-weight: var(--fw-semi); letter-spacing: 0.1em; text-transform: uppercase; color: var(--c-muted); }
.mobile-lang a[aria-current="true"] { color: var(--c-champagne); }

/* ============================================================
   HERO
   ============================================================ */
.hero { position: relative; overflow: hidden; }
.hero__grid {
  display: grid; gap: var(--sp-6); align-items: center;
  padding-block: clamp(2.5rem, 1.5rem + 6vw, 6rem);
}
.hero__eyebrow { color: var(--c-champagne); }
.hero__title { font-size: var(--fs-h1); }
.hero__title em { font-style: italic; color: var(--c-rose-gold); }
.hero__lead { margin-top: var(--sp-5); }
.hero__actions { display: flex; flex-wrap: wrap; gap: var(--sp-4); margin-top: var(--sp-6); }
.hero__media {
  position: relative; aspect-ratio: 4 / 5; border-radius: var(--r-lg);
  overflow: hidden; background: var(--c-marble);
}
.hero__media img { width: 100%; height: 100%; object-fit: cover; }
.hero__note { margin-top: var(--sp-5); font-size: var(--fs-xs); color: var(--c-muted); letter-spacing: 0.04em; }
.hero__tagline {
  font-family: var(--font-body); font-weight: var(--fw-semi); text-transform: uppercase;
  letter-spacing: 0.18em; font-size: var(--fs-eyebrow); color: var(--c-champagne);
  display: flex; flex-wrap: wrap; gap: var(--sp-2) var(--sp-4); margin-top: var(--sp-6);
}

/* ============================================================
   CABEÇALHO DE SEÇÃO
   ============================================================ */
.section-head { max-width: 64ch; margin-bottom: var(--sp-7); }
.section-head--center { margin-inline: auto; text-align: center; }
.section-head--center .rule-gold { margin-inline: auto; }
.section-head p { color: var(--text-soft); margin-top: var(--sp-3); }

/* ============================================================
   GRADE DE PILARES (4 pilares)
   ============================================================ */
.pillars { display: grid; gap: var(--sp-5); grid-template-columns: 1fr; }
.pillar {
  padding: var(--sp-6); background: var(--surface);
  border: 1px solid var(--line); border-top: 2px solid var(--c-champagne);
  border-radius: var(--r-md);
}
.pillar__icon { width: 32px; height: 32px; color: var(--c-rose-gold); margin-bottom: var(--sp-4); }
.pillar h3 { font-size: var(--fs-lg); margin-bottom: var(--sp-2); }
.pillar p { font-size: var(--fs-sm); color: var(--text-soft); }
.section--dark .pillar { background: rgba(251,249,244,0.04); border-color: rgba(251,249,244,0.12); border-top-color: var(--c-champagne); }
.section--dark .pillar p { color: rgba(251,249,244,0.78); }

/* ============================================================
   CARDS (idiomas / programas / genérico)
   ============================================================ */
.card-grid { display: grid; gap: var(--sp-5); grid-template-columns: 1fr; }
.card {
  display: flex; flex-direction: column;
  background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--r-lg); overflow: hidden;
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--line-gold); }
.card__media { aspect-ratio: 3 / 2; background: var(--c-marble); overflow: hidden; }
.card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-slow) var(--ease); }
.card:hover .card__media img { transform: scale(1.04); }
.card__body { padding: var(--sp-6); display: flex; flex-direction: column; gap: var(--sp-3); flex: 1; }
.card__kicker { font-size: var(--fs-eyebrow); text-transform: uppercase; letter-spacing: 0.16em; color: var(--c-champagne); font-weight: var(--fw-semi); }
.card__title { font-size: var(--fs-h3); }
.card__title--sm { font-size: var(--fs-xl); }
.card__text { font-size: var(--fs-sm); color: var(--text-soft); }
.card__foot { margin-top: auto; padding-top: var(--sp-3); }

/* Card de idioma (compacto) */
.lang-card .card__body { padding: var(--sp-5) var(--sp-6); }
.lang-card__native { font-family: var(--font-script); color: var(--c-rose-gold); font-size: var(--fs-xl); line-height: 1; }

/* ============================================================
   MÉTODO — 5 movimentos
   ============================================================ */
.method { display: grid; gap: var(--sp-5); grid-template-columns: 1fr; counter-reset: step; }
.method__step { display: flex; gap: var(--sp-5); align-items: flex-start; padding: var(--sp-5) 0; border-top: 1px solid var(--line); }
.method__num {
  counter-increment: step; flex-shrink: 0;
  font-family: var(--font-display); font-weight: var(--fw-bold);
  font-size: var(--fs-h3); color: var(--c-champagne); line-height: 1; min-width: 2ch;
}
.method__num::before { content: "0" counter(step); }
.method__body h3 { font-size: var(--fs-lg); margin-bottom: var(--sp-2); }
.method__body p { font-size: var(--fs-sm); color: var(--text-soft); }

/* ============================================================
   DEPOIMENTOS
   ============================================================ */
.quotes { display: grid; gap: var(--sp-5); grid-template-columns: 1fr; }
.quote {
  background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--r-lg); padding: var(--sp-6);
  display: flex; flex-direction: column; gap: var(--sp-4);
}
.quote__mark { font-family: var(--font-display); font-size: 3rem; line-height: 0.5; color: var(--c-champagne-40); height: 1.2rem; }
.quote__text { font-family: var(--font-display); font-style: italic; font-size: var(--fs-lg); color: var(--c-midnight); line-height: var(--lh-snug); }
.quote__by { font-size: var(--fs-sm); }
.quote__by strong { display: block; color: var(--c-navy); font-weight: var(--fw-semi); }
.quote__by span { color: var(--c-muted); }
.quote__stars { color: var(--c-champagne); letter-spacing: 0.2em; font-size: var(--fs-sm); }

/* ============================================================
   PASSOS — Como começamos
   ============================================================ */
.steps { display: grid; gap: var(--sp-6); grid-template-columns: 1fr; }
.step { text-align: left; }
.step__index { font-family: var(--font-display); font-size: var(--fs-h2); color: var(--c-rose-gold); line-height: 1; }
.step h3 { font-size: var(--fs-lg); margin: var(--sp-3) 0 var(--sp-2); }
.step p { font-size: var(--fs-sm); color: var(--text-soft); }

/* ============================================================
   FAQ — Acordeão acessível
   ============================================================ */
.faq { max-width: var(--container-text); margin-inline: auto; }
.faq__item { border-bottom: 1px solid var(--line); }
.faq__q {
  display: flex; align-items: center; justify-content: space-between; gap: var(--sp-4);
  width: 100%; text-align: left; padding: var(--sp-5) 0;
  font-family: var(--font-display); font-size: var(--fs-lg); font-weight: var(--fw-bold);
  color: var(--c-navy);
}
.faq__icon { position: relative; width: 16px; height: 16px; flex-shrink: 0; }
.faq__icon::before, .faq__icon::after { content: ""; position: absolute; background: var(--c-champagne); transition: transform var(--dur) var(--ease); }
.faq__icon::before { top: 50%; left: 0; right: 0; height: 1.5px; transform: translateY(-50%); }
.faq__icon::after { left: 50%; top: 0; bottom: 0; width: 1.5px; transform: translateX(-50%); }
.faq__q[aria-expanded="true"] .faq__icon::after { transform: translateX(-50%) scaleY(0); }
.faq__a { overflow: hidden; max-height: 0; transition: max-height var(--dur) var(--ease); }
.faq__q[aria-expanded="true"] + .faq__a { max-height: 480px; }
.faq__a > div { padding-bottom: var(--sp-5); color: var(--text-soft); font-size: var(--fs-base); }

/* ============================================================
   FAIXA CTA
   ============================================================ */
.cta-band { position: relative; overflow: hidden; text-align: center; }
.cta-band .container { position: relative; z-index: 1; }
.cta-band h2 { font-size: var(--fs-h2); max-width: 22ch; margin-inline: auto; }
.cta-band p { margin: var(--sp-4) auto 0; }
.cta-band .hero__actions { justify-content: center; }

/* ============================================================
   NEWSLETTER
   ============================================================ */
.newsletter { background: var(--bg-dark); color: var(--text-on-dark); border-radius: var(--r-lg); padding: clamp(2rem, 1.5rem + 3vw, 4rem); text-align: center; }
.newsletter h2 { color: var(--c-ivory); font-size: var(--fs-h3); }
.newsletter p { color: rgba(251,249,244,0.8); margin: var(--sp-3) auto var(--sp-6); }
.form-inline { display: flex; flex-wrap: wrap; gap: var(--sp-3); max-width: 540px; margin-inline: auto; }
.form-inline input { flex: 1 1 220px; }
.form-note { font-size: var(--fs-xs); color: rgba(251,249,244,0.6); margin-top: var(--sp-4); }

/* ============================================================
   FORMULÁRIOS
   ============================================================ */
.field { display: flex; flex-direction: column; gap: var(--sp-2); margin-bottom: var(--sp-5); }
.field > label { font-size: var(--fs-sm); font-weight: var(--fw-semi); color: var(--c-navy); }
.field .req { color: var(--c-rose); }
.input, .textarea, .select {
  width: 100%; padding: 0.85em 1em; min-height: 48px;
  font-size: var(--fs-base); color: var(--c-ink);
  background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-md);
  transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.input::placeholder, .textarea::placeholder { color: var(--c-muted); }
.input:focus, .textarea:focus, .select:focus { outline: none; border-color: var(--c-champagne); box-shadow: 0 0 0 3px var(--c-champagne-24); }
.textarea { min-height: 140px; resize: vertical; }
.newsletter .input { background: rgba(251,249,244,0.95); border-color: transparent; }
.field__error { font-size: var(--fs-xs); color: var(--c-rose); display: none; }
.field.is-invalid .input, .field.is-invalid .textarea, .field.is-invalid .select { border-color: var(--c-rose); }
.field.is-invalid .field__error { display: block; }
.form-grid { display: grid; gap: 0 var(--sp-5); grid-template-columns: 1fr; }
.form-status { padding: var(--sp-4); border-radius: var(--r-md); font-size: var(--fs-sm); margin-top: var(--sp-4); display: none; }
.form-status.is-ok { display: block; background: var(--c-champagne-12); border: 1px solid var(--line-gold); color: var(--c-midnight); }

/* ============================================================
   BREADCRUMBS
   ============================================================ */
.breadcrumb { font-size: var(--fs-xs); color: var(--c-muted); padding-block: var(--sp-4); }
.breadcrumb ol { display: flex; flex-wrap: wrap; gap: var(--sp-2); list-style: none; }
.breadcrumb li:not(:last-child)::after { content: "/"; margin-left: var(--sp-2); color: var(--c-ink-10); }
.breadcrumb a { color: var(--c-muted); }
.breadcrumb a:hover { color: var(--c-navy); }
.breadcrumb [aria-current="page"] { color: var(--c-navy); }

/* ============================================================
   FAIXA "FEATURED IN" / LOGOS
   ============================================================ */
.trust { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: clamp(1.5rem, 4vw, 4rem); }
.trust__label { width: 100%; text-align: center; font-size: var(--fs-eyebrow); letter-spacing: 0.2em; text-transform: uppercase; color: var(--c-muted); margin-bottom: var(--sp-2); }
.trust__logo { font-family: var(--font-display); font-weight: var(--fw-bold); font-size: var(--fs-lg); color: var(--c-muted); opacity: 0.75; }

/* ============================================================
   PÁGINA — cabeçalho interno (page hero)
   ============================================================ */
.page-hero { background: var(--bg-alt); }
.page-hero__inner { padding-block: clamp(2.5rem, 2rem + 4vw, 5rem); max-width: 60ch; }
.page-hero--dark { background: var(--bg-dark); color: var(--text-on-dark); }
.page-hero--dark .breadcrumb, .page-hero--dark .breadcrumb a, .page-hero--dark .breadcrumb [aria-current="page"] { color: rgba(251,249,244,0.7); }
.page-hero--dark p { color: rgba(251,249,244,0.82); }

/* ============================================================
   DIÁRIO (blog)
   ============================================================ */
.post-card { display: flex; flex-direction: column; gap: var(--sp-3); }
.post-card__media { aspect-ratio: 16/10; border-radius: var(--r-md); overflow: hidden; background: var(--c-marble); margin-bottom: var(--sp-2); }
.post-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-slow) var(--ease); }
.post-card:hover .post-card__media img { transform: scale(1.04); }
.post-card__cat { font-size: var(--fs-eyebrow); text-transform: uppercase; letter-spacing: 0.14em; color: var(--c-champagne); font-weight: var(--fw-semi); }
.post-card__title { font-size: var(--fs-xl); }
.post-card__title a { color: var(--c-navy); }
.post-card__title a:hover { color: var(--c-rose-gold); }
.post-card__meta { font-size: var(--fs-xs); color: var(--c-muted); }
.chips { display: flex; flex-wrap: wrap; gap: var(--sp-2); }
.chip {
  font-size: var(--fs-xs); padding: var(--sp-2) var(--sp-4);
  border: 1px solid var(--line); border-radius: var(--r-pill); color: var(--c-ink);
  transition: border-color var(--dur) var(--ease), color var(--dur) var(--ease);
}
.chip:hover, .chip[aria-current="true"] { border-color: var(--c-champagne); color: var(--c-navy); }

/* ============================================================
   RODAPÉ  (atenção máxima — Tomo VII)
   ============================================================ */
.site-footer { background: var(--c-midnight); color: var(--c-ivory); }
.footer-band {
  text-align: center; padding-block: var(--sp-5);
  border-bottom: 1px solid rgba(251,249,244,0.1);
}
.footer-band p { font-family: var(--font-display); font-style: italic; font-size: var(--fs-lg); color: var(--c-ivory); margin-inline: auto; }
.footer-main { padding-block: var(--sp-8) var(--sp-7); }
.footer-grid {
  display: grid; gap: var(--sp-7) var(--sp-6);
  grid-template-columns: 1fr;
}
.footer-brand__mark { width: 52px; height: 52px; margin-bottom: var(--sp-4); }
.footer-brand p { font-size: var(--fs-sm); color: rgba(251,249,244,0.72); max-width: 32ch; }
.footer-col h3 {
  font-family: var(--font-body); font-size: var(--fs-eyebrow); font-weight: var(--fw-bold);
  text-transform: uppercase; letter-spacing: 0.18em; color: var(--c-champagne);
  margin-bottom: var(--sp-4);
}
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: var(--sp-3); }
.footer-col a { color: rgba(251,249,244,0.78); font-size: var(--fs-sm); }
.footer-col a:hover { color: var(--c-rose-light); }
.footer-contact li { color: rgba(251,249,244,0.78); font-size: var(--fs-sm); line-height: var(--lh-snug); }
.footer-contact strong { color: var(--c-ivory); font-weight: var(--fw-semi); display: block; margin-bottom: 2px; }

.footer-social { display: flex; gap: var(--sp-3); margin-top: var(--sp-5); }
.footer-social a {
  width: 40px; height: 40px; display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid rgba(251,249,244,0.2); border-radius: var(--r-pill); color: var(--c-ivory);
  transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.footer-social a:hover { background: var(--c-champagne); border-color: var(--c-champagne); color: var(--c-midnight); }
.footer-social svg { width: 18px; height: 18px; }

.footer-legal {
  border-top: 1px solid rgba(251,249,244,0.1);
  padding-block: var(--sp-5);
  display: flex; flex-direction: column; gap: var(--sp-4);
  align-items: center; text-align: center;
}
.footer-legal__links { display: flex; flex-wrap: wrap; gap: var(--sp-2) var(--sp-5); justify-content: center; }
.footer-legal a, .footer-legal p { font-size: var(--fs-xs); color: rgba(251,249,244,0.6); }
.footer-legal a:hover { color: var(--c-rose-light); }
.footer-langs { display: flex; gap: var(--sp-4); }
.footer-langs a { font-size: var(--fs-xs); font-weight: var(--fw-semi); letter-spacing: 0.1em; text-transform: uppercase; color: rgba(251,249,244,0.6); }
.footer-langs a[aria-current="true"] { color: var(--c-champagne); }

/* ============================================================
   RESPONSIVO — pontos de quebra (mobile-first)
   ============================================================ */
@media (min-width: 600px) {
  .pillars { grid-template-columns: repeat(2, 1fr); }
  .card-grid { grid-template-columns: repeat(2, 1fr); }
  .quotes { grid-template-columns: repeat(2, 1fr); }
  .steps { grid-template-columns: repeat(3, 1fr); }
  .form-grid--2 { grid-template-columns: 1fr 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
}

@media (min-width: 720px) {
  .hero__tagline { font-size: var(--fs-eyebrow); }
}

@media (min-width: 900px) {
  .hero__grid { grid-template-columns: 1.05fr 0.95fr; gap: var(--sp-8); }
  .pillars { grid-template-columns: repeat(4, 1fr); }
  .card-grid--3 { grid-template-columns: repeat(3, 1fr); }
  .quotes { grid-template-columns: repeat(3, 1fr); }
  .method { grid-template-columns: 1fr 1fr; column-gap: var(--sp-8); }
  .footer-grid { grid-template-columns: 1.6fr 1fr 1fr 1.2fr; }
  .footer-legal { flex-direction: row; justify-content: space-between; text-align: left; }
}

@media (min-width: 1000px) {
  .primary-nav { display: block; }
  .nav-toggle { display: none; }
  .lang-switch { display: block; }
  .header-cta { display: inline-flex; }
}

@media (min-width: 1100px) {
  .card-grid--lang { grid-template-columns: repeat(3, 1fr); }
}
