/* ====================================================================
   NAVALHA & LATÃO — Barbearia clássica para cavalheiros
   Pólo: LEVE + GENIAL. Conceito: "O Ritual de Cadeira."
   A direção de arte tipográfica e a materialidade quente carregam o
   design. O âmbar é escasso e precioso. Mobile-first → desktop por
   recomposição (assimetria, faixa horizontal, duas colunas de carta).
   ==================================================================== */

/* -------------------------------------------------------------------
   TOKENS
   ------------------------------------------------------------------- */
:root {
  /* Paleta */
  --grafite:    #1C1B19;   /* texto, fundos profundos (nunca #000) */
  --ambar:      #C8881F;   /* acento escasso: CTA, filetes, sublinhados */
  --ambar-luz:  #E0A847;   /* âmbar em hover sobre fundo escuro */
  --ambar-carta:#F2D08A;   /* latão claro p/ preços sobre tabaco (AA: 4.6:1) */
  --creme:      #F4EBDA;   /* fundo principal, respiro */
  --tabaco:     #7A5230;   /* blocos quentes, divisórias */
  --aco:        #6E665B;   /* texto secundário sobre creme (AA: ~5.2:1) */
  --aco-claro:  #A8A095;   /* legendas sobre madeira escura */
  --madeira:    #2E2A24;   /* rodapé, bloco de agendamento */

  /* Tipografia */
  --display:  "Playfair Display", Georgia, serif;
  --corpo:    "Hanken Grotesk", system-ui, -apple-system, sans-serif;
  --voz:      "EB Garamond", Georgia, serif;

  /* Escala fluida — toda com unidade, inclusive 0 */
  --step--1:    clamp(0.78rem, 0.74rem + 0.18vw, 0.86rem);
  --step-0:     clamp(1rem, 0.96rem + 0.2vw, 1.12rem);
  --step-1:     clamp(1.15rem, 1.05rem + 0.5vw, 1.4rem);
  --step-2:     clamp(1.5rem, 1.3rem + 1vw, 2rem);
  --display-xl: clamp(2.6rem, 1.5rem + 5.5vw, 6.5rem);
  --display-lg: clamp(2.1rem, 1.4rem + 3.6vw, 4.4rem);
  --display-md: clamp(1.8rem, 1.4rem + 2.2vw, 3.2rem);
  --numeral:    clamp(3.2rem, 2rem + 6vw, 9rem);

  /* Respiro */
  --gap-sec:  clamp(5rem, 3.4rem + 10vw, 10rem);
  --pad-x:    clamp(1.4rem, 0.8rem + 3.6vw, 5rem);
  --maxw:     1180px;
  --leitura:  39rem;   /* ~620px de largura de leitura */

  /* Filete pontilhado do cardápio */
  --pontilhado: radial-gradient(currentColor 0.5px, transparent 0.6px);

  /* Movimento */
  --ease: cubic-bezier(0.22, 0.61, 0.36, 1);
}

/* -------------------------------------------------------------------
   RESET / BASE
   ------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }

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

body {
  margin: 0;
  background: var(--creme);
  color: var(--grafite);
  font-family: var(--corpo);
  font-size: var(--step-0);
  font-weight: 400;
  line-height: 1.72;
  letter-spacing: 0.005em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;

  /* Textura sutil de papel (overlay baixíssimo, não polui o texto) */
  background-image:
    repeating-linear-gradient(0deg,
      rgba(122, 82, 48, 0.022) 0px,
      rgba(122, 82, 48, 0.022) 1px,
      transparent 1px,
      transparent 3px),
    radial-gradient(rgba(122, 82, 48, 0.03) 0.5px, transparent 0.6px);
  background-size: auto, 4px 4px;
}

img { display: block; max-width: 100%; height: auto; }

h1, h2, h3 { margin: 0; font-weight: 700; }

p { margin: 0 0 1.15em; }
p:last-child { margin-bottom: 0; }

a { color: inherit; text-decoration: none; }

em {
  font-family: var(--display);
  font-style: italic;
  font-weight: 700;
}

/* -------------------------------------------------------------------
   ACESSIBILIDADE
   ------------------------------------------------------------------- */
.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;
}

.skip-link {
  position: fixed; left: 1rem; top: -4rem; z-index: 999;
  background: var(--grafite); color: var(--creme);
  padding: 0.7rem 1.1rem;
  font-size: var(--step--1);
  letter-spacing: 0.14em; text-transform: uppercase;
  transition: top 0.2s var(--ease);
}
.skip-link:focus { top: 1rem; outline: 2px solid var(--ambar); outline-offset: 2px; }

a:focus-visible,
.placa__cta:focus-visible {
  outline: 2px solid var(--ambar);
  outline-offset: 3px;
}

/* -------------------------------------------------------------------
   REVEAL — só opacity/transform. Estado final garantido sem JS.
   ------------------------------------------------------------------- */
.no-js .reveal { opacity: 1; transform: none; }

.reveal {
  opacity: 1;
  transform: none;
}
html:not(.no-js) .reveal {
  opacity: 0;
  transform: translateY(16px);
  transition:
    opacity 0.6s var(--ease),
    transform 0.6s var(--ease);
}
html:not(.no-js) .reveal.is-in {
  opacity: 1;
  transform: none;
}

@media (prefers-reduced-motion: reduce) {
  html:not(.no-js) .reveal {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
  html { scroll-behavior: auto; }
}

/* -------------------------------------------------------------------
   PRIMITIVAS
   ------------------------------------------------------------------- */
.kicker {
  font-family: var(--corpo);
  font-size: var(--step--1);
  font-weight: 600;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--tabaco);
  margin: 0 0 1.4rem;
}
.kicker--claro { color: var(--ambar-luz); }

/* Filete âmbar como acento de seção */
.kicker::before {
  content: "";
  display: inline-block;
  width: clamp(1.6rem, 3vw, 2.6rem);
  height: 1px;
  background: var(--ambar);
  vertical-align: middle;
  margin-right: 0.8rem;
  margin-bottom: 0.18em;
}

/* Wrapper de mídia: isola a imagem (nenhum overlay vaza atrás de legenda) */
.media {
  position: relative;
  overflow: hidden;
  background: var(--tabaco);
}
.media__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
/* Hover de galeria: scale leve, sem sombra dramática */
.media--galeria .media__img {
  transition: transform 0.4s var(--ease);
}
@media (hover: hover) {
  .casa__item:hover .media--galeria .media__img { transform: scale(1.03); }
}
@media (prefers-reduced-motion: reduce) {
  .media--galeria .media__img { transition: none; }
}

/* ===================================================================
   CABEÇALHO — placa esmaltada
   =================================================================== */
.placa {
  position: sticky;
  top: 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.85rem var(--pad-x);
  background: color-mix(in srgb, var(--creme) 92%, transparent);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-bottom: 1px solid color-mix(in srgb, var(--tabaco) 22%, transparent);
}

.placa__marca { display: flex; flex-direction: column; line-height: 1.05; }
.placa__nome {
  font-family: var(--display);
  font-weight: 900;
  font-size: clamp(1.15rem, 1rem + 1vw, 1.6rem);
  letter-spacing: 0.04em;
  color: var(--grafite);
}
.placa__amp { color: var(--ambar); font-style: italic; }
.placa__sub {
  font-size: clamp(0.6rem, 0.55rem + 0.2vw, 0.7rem);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--aco);
  margin-top: 0.25rem;
}

.placa__cta {
  flex: none;
  font-size: var(--step--1);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--grafite);
  background: var(--ambar);
  padding: 0.7rem 1.1rem;
  border: 1px solid var(--ambar);
  transition: background 0.2s var(--ease), color 0.2s var(--ease);
}
@media (hover: hover) {
  .placa__cta:hover { background: transparent; color: var(--tabaco); }
}

/* ===================================================================
   SEÇÃO 1 — ABERTURA / O ESTABELECIMENTO
   =================================================================== */
.abertura {
  position: relative;
  padding-bottom: clamp(3rem, 6vw, 5rem);
}

.abertura__figura { margin: 0; }
.media--hero { aspect-ratio: 1024 / 1180; }
.media--hero::after {
  /* Gradiente sépia quente para legibilidade do scroll-hint, isolado no wrapper */
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(28, 27, 25, 0) 55%,
    rgba(28, 27, 25, 0.45) 100%);
  pointer-events: none;
}

.abertura__texto {
  padding: clamp(2.2rem, 5vw, 3.5rem) var(--pad-x) 0;
}
.abertura__titulo {
  font-family: var(--display);
  font-weight: 900;
  font-size: var(--display-xl);
  line-height: 0.98;
  letter-spacing: -0.01em;
  margin-bottom: 1.2rem;
}
.abertura__titulo em { display: inline-block; color: var(--tabaco); }
.abertura__lede {
  max-width: var(--leitura);
  font-size: var(--step-1);
  color: var(--aco);
  margin-bottom: 1.8rem;
}

/* CTA editorial com filete âmbar */
.abertura__cta,
.hora__cta {
  display: inline-flex;
  flex-direction: column;
  gap: 0.4rem;
  font-weight: 600;
  font-size: var(--step-0);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--grafite);
  align-self: flex-start;
}
.abertura__cta-filete,
.hora__cta-filete {
  display: block;
  height: 2px;
  width: 100%;
  background: var(--ambar);
  transform-origin: left;
  transform: scaleX(1);
  transition: transform 0.2s var(--ease), opacity 0.2s var(--ease);
  opacity: 0.85;
}
@media (hover: hover) {
  .abertura__cta:hover .abertura__cta-filete { transform: scaleX(0.5); opacity: 1; }
}

.abertura__role {
  display: none;
}

/* ===================================================================
   SEÇÃO 2 — O RITUAL
   =================================================================== */
.ritual {
  padding: var(--gap-sec) var(--pad-x);
  background: var(--creme);
}
.ritual__head { max-width: var(--leitura); margin-bottom: clamp(2.5rem, 6vw, 4rem); }
.ritual__titulo {
  font-family: var(--display);
  font-size: var(--display-lg);
  line-height: 1.02;
  margin-bottom: 1.1rem;
}
.ritual__titulo em { color: var(--tabaco); }
.ritual__lede { color: var(--aco); font-size: var(--step-1); }

.ritual__passos {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: clamp(2rem, 5vw, 2.6rem);
}
.ritual__passo {
  position: relative;
  padding-top: 1.6rem;
  border-top: 1px solid color-mix(in srgb, var(--tabaco) 28%, transparent);
}
.ritual__num {
  display: block;
  font-family: var(--display);
  font-weight: 900;
  font-size: var(--numeral);
  line-height: 0.8;
  color: var(--ambar);
  opacity: 0.9;
  letter-spacing: 0.02em;
  margin-bottom: 0.6rem;
}
.ritual__passo-titulo {
  font-family: var(--display);
  font-size: var(--step-2);
  margin-bottom: 0.7rem;
}
.ritual__passo p { color: var(--aco); max-width: 34rem; }

/* ===================================================================
   SEÇÃO 3 — A CARTA (cardápio)
   =================================================================== */
.carta {
  padding: var(--gap-sec) var(--pad-x);
  background: var(--tabaco);
  color: var(--creme);
}
.carta .kicker { color: var(--ambar-luz); }
.carta .kicker::before { background: var(--ambar-luz); }
.carta__head { max-width: var(--leitura); margin-bottom: clamp(2.5rem, 5vw, 3.5rem); }
.carta__titulo {
  font-family: var(--display);
  font-size: var(--display-md);
  margin-bottom: 0.9rem;
}
.carta__nota { color: color-mix(in srgb, var(--creme) 88%, var(--tabaco)); }

.carta__colunas { display: grid; gap: clamp(0rem, 4vw, 3.5rem); }
.carta__lista {
  list-style: none;
  margin: 0;
  padding: 0;
}
.carta__item {
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: baseline;
  column-gap: 0.6rem;
  padding: 1.3rem 0;
  border-bottom: 1px solid color-mix(in srgb, var(--creme) 18%, transparent);
}
.carta__item-nome {
  font-family: var(--display);
  font-size: var(--step-1);
  font-weight: 700;
}
/* Filete pontilhado entre nome e valor */
.carta__item-filete {
  align-self: flex-end;
  height: 1px;
  margin-bottom: 0.45rem;
  background-image: var(--pontilhado);
  background-size: 6px 1px;
  background-repeat: repeat-x;
  background-position: bottom;
  color: color-mix(in srgb, var(--creme) 45%, transparent);
}
.carta__item-preco {
  font-family: var(--voz);
  font-style: italic;
  font-size: var(--step-1);
  color: var(--ambar-carta);
  white-space: nowrap;
}
.carta__item-desc {
  grid-column: 1 / -1;
  margin: 0.55rem 0 0;
  font-size: var(--step--1);
  color: color-mix(in srgb, var(--creme) 86%, var(--tabaco));
  max-width: 34rem;
}

/* ===================================================================
   SEÇÃO 4 — O MESTRE
   =================================================================== */
.mestre {
  padding: var(--gap-sec) var(--pad-x);
  display: grid;
  gap: clamp(2rem, 6vw, 3rem);
}
.mestre__figura { margin: 0; max-width: 26rem; }
.media--retrato { aspect-ratio: 1024 / 1280; }
.mestre__texto { max-width: var(--leitura); }
.mestre__titulo {
  font-family: var(--display);
  font-size: var(--display-md);
  margin-bottom: 1.1rem;
}
.mestre__bio { color: var(--aco); }
.mestre__assinatura {
  font-family: var(--voz);
  font-style: italic;
  font-size: clamp(2rem, 1.5rem + 2vw, 3rem);
  color: var(--tabaco);
  margin: 1.4rem 0 0.1rem;
  line-height: 1;
}
.mestre__cargo {
  font-size: var(--step--1);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--aco);
}

/* ===================================================================
   SEÇÃO 5 — A CASA (galeria)
   =================================================================== */
.casa {
  padding: var(--gap-sec) var(--pad-x);
  background: var(--creme);
}
.casa__head { max-width: var(--leitura); margin-bottom: clamp(2rem, 5vw, 3rem); }
.casa__titulo {
  font-family: var(--display);
  font-size: var(--display-lg);
  line-height: 1.02;
}
.casa__titulo em { color: var(--tabaco); }

.casa__grid { display: grid; gap: clamp(0.9rem, 2.4vw, 1.4rem); }
.casa__item { margin: 0; }
.media--galeria { aspect-ratio: 1 / 1; }
.casa__item--grande .media--galeria { aspect-ratio: 16 / 10; }

/* ===================================================================
   SEÇÃO 6 — PALAVRA DE CLIENTE
   =================================================================== */
.palavra {
  padding: var(--gap-sec) var(--pad-x);
  background: var(--creme);
  display: grid;
  gap: clamp(2.6rem, 6vw, 4rem);
  max-width: 56rem;
  margin: 0 auto;
}
.palavra__voz { margin: 0; }
.palavra__texto {
  font-family: var(--voz);
  font-style: italic;
  font-size: clamp(1.3rem, 1rem + 1.6vw, 1.85rem);
  line-height: 1.45;
  color: var(--grafite);
  margin-bottom: 1rem;
  text-wrap: balance;
}
.palavra__voz::before {
  content: "";
  display: block;
  width: 2.4rem;
  height: 2px;
  background: var(--ambar);
  margin-bottom: 1.4rem;
}
.palavra__autor {
  font-size: var(--step--1);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--aco);
}

/* ===================================================================
   SEÇÃO 7 — HORA MARCADA
   =================================================================== */
.hora {
  padding: var(--gap-sec) var(--pad-x);
  background: var(--madeira);
  color: var(--creme);
}
.hora__bloco { max-width: var(--maxw); margin: 0 auto; }
.hora__titulo {
  font-family: var(--display);
  font-size: var(--display-lg);
  line-height: 1.02;
  margin-bottom: 1.1rem;
}
.hora__titulo em { color: var(--ambar-luz); }
.hora__lede {
  max-width: var(--leitura);
  font-size: var(--step-1);
  color: var(--aco-claro);
  margin-bottom: 2rem;
}

.hora__cta { color: var(--creme); margin-bottom: 2.6rem; }
.hora__cta-filete { background: var(--ambar); }
@media (hover: hover) {
  .hora__cta:hover .hora__cta-filete { transform: scaleX(0.5); }
}

.hora__info {
  font-style: normal;
  display: grid;
  gap: 1.1rem;
  margin-bottom: clamp(2.4rem, 5vw, 3.2rem);
  padding-top: 1.8rem;
  border-top: 1px solid color-mix(in srgb, var(--creme) 16%, transparent);
}
.hora__linha { margin: 0; max-width: 38rem; color: var(--creme); }
.hora__label {
  display: block;
  font-size: var(--step--1);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ambar-luz);
  margin-bottom: 0.25rem;
}
.hora__linha a { border-bottom: 1px solid color-mix(in srgb, var(--ambar) 60%, transparent); }
@media (hover: hover) {
  .hora__linha a:hover { color: var(--ambar-luz); }
}

.hora__mapa { margin: 0; }
.media--mapa { aspect-ratio: 16 / 10; }
.hora__mapa-cap {
  margin-top: 0.8rem;
  font-size: var(--step--1);
  color: var(--aco-claro);
}

/* ===================================================================
   RODAPÉ-PLACA
   =================================================================== */
.rodape {
  background: var(--grafite);
  color: var(--creme);
  text-align: center;
  padding: clamp(3rem, 7vw, 4.5rem) var(--pad-x) clamp(5.5rem, 8vw, 4.5rem);
}
.rodape__emblema { color: var(--ambar); display: flex; justify-content: center; margin-bottom: 1.4rem; }
.rodape__marca {
  font-family: var(--display);
  font-weight: 900;
  font-size: clamp(1.6rem, 1.2rem + 2vw, 2.4rem);
  letter-spacing: 0.04em;
  margin: 0 0 0.6rem;
}
.rodape__amp { color: var(--ambar); font-style: italic; }
.rodape__nota {
  max-width: 34rem;
  margin: 0 auto 1.6rem;
  color: var(--aco-claro);
  font-size: var(--step--1);
}
.rodape__redes {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 0.7rem;
  margin-bottom: 1.6rem;
  font-size: var(--step--1);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.rodape__rede { border-bottom: 1px solid transparent; transition: border-color 0.2s var(--ease); }
@media (hover: hover) {
  .rodape__rede:hover { border-color: var(--ambar); color: var(--ambar-luz); }
}
.rodape__sep { color: var(--tabaco); }
.rodape__fine {
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  color: var(--aco-claro);
  margin: 0;
}

/* ===================================================================
   STICKY CTA MÓVEL
   =================================================================== */
.sticky-cta {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 90;
  background: var(--ambar);
  color: var(--grafite);
  text-align: center;
  font-weight: 600;
  font-size: var(--step-0);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 1rem 1rem;
  padding-bottom: calc(1rem + env(safe-area-inset-bottom, 0px));
  box-shadow: 0 -2px 18px rgba(28, 27, 25, 0.25);
}
@media (hover: hover) {
  .sticky-cta:hover { background: var(--ambar-luz); }
}

/* ===================================================================
   TABLET — 640px (hero ainda empilhado, refinos de respiro)
   =================================================================== */
@media (min-width: 640px) {
  .ritual__passos { grid-template-columns: repeat(2, 1fr); column-gap: clamp(2rem, 4vw, 3rem); }
  .casa__grid {
    grid-template-columns: repeat(2, 1fr);
    grid-auto-flow: dense;
  }
  .casa__item--grande { grid-column: 1 / -1; }
}

/* ===================================================================
   DESKTOP — 1024px: reconfigura, não estica
   =================================================================== */
@media (min-width: 1024px) {

  /* O sticky móvel some; o CTA do header e a seção carregam a conversão */
  .sticky-cta { display: none; }

  /* --- HERO em duas colunas assimétricas --- */
  .abertura {
    display: grid;
    grid-template-columns: 1.15fr 1fr;
    align-items: stretch;
    min-height: 88vh;
    padding-bottom: 0;
  }
  .abertura__figura { grid-column: 1; }
  .media--hero { aspect-ratio: auto; height: 100%; min-height: 88vh; }
  .abertura__texto {
    grid-column: 2;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: var(--gap-sec) var(--pad-x) var(--gap-sec) clamp(2.5rem, 4vw, 4rem);
  }
  .abertura__role {
    display: block;
    position: absolute;
    left: var(--pad-x);
    bottom: clamp(1.5rem, 3vw, 2.5rem);
    font-size: 0.7rem;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: var(--creme);
    writing-mode: vertical-rl;
    text-orientation: mixed;
  }

  /* --- O RITUAL: faixa horizontal, numerais grandes em marca d'água --- */
  .ritual__passos { grid-template-columns: repeat(4, 1fr); gap: clamp(1.6rem, 2.6vw, 2.6rem); }
  .ritual__passo {
    padding-top: 0;
    border-top: none;
    position: relative;
  }
  .ritual__num {
    position: absolute;
    top: -0.3em;
    right: 0;
    font-size: clamp(5rem, 8vw, 9rem);
    color: var(--tabaco);
    opacity: 0.12;
    z-index: 0;
    pointer-events: none;
  }
  .ritual__passo-titulo,
  .ritual__passo p { position: relative; z-index: 1; }
  .ritual__passo-titulo {
    padding-top: 2.2rem;
    border-top: 1px solid var(--ambar);
  }

  /* --- A CARTA: duas colunas com régua central --- */
  .carta__colunas {
    grid-template-columns: 1fr 1px 1fr;
    column-gap: clamp(2.5rem, 4vw, 4rem);
    align-items: start;
  }
  .carta__colunas::before {
    content: "";
    grid-column: 2;
    align-self: stretch;
    width: 1px;
    background: color-mix(in srgb, var(--creme) 22%, transparent);
  }
  .carta__lista:first-child { grid-column: 1; }
  .carta__lista:last-child { grid-column: 3; }

  /* --- O MESTRE: retrato + bio lado a lado --- */
  .mestre {
    grid-template-columns: 0.85fr 1fr;
    align-items: center;
    column-gap: clamp(3rem, 5vw, 5rem);
    max-width: var(--maxw);
    margin: 0 auto;
  }
  .mestre__figura { max-width: none; }

  /* --- A CASA: grid editorial 12-col (1 grande + 3 pequenas) --- */
  .casa__grid {
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: auto auto;
    gap: clamp(1.1rem, 1.8vw, 1.6rem);
  }
  .casa__item--grande { grid-column: 1 / 3; grid-row: 1 / 3; }
  .casa__item--grande .media--galeria { aspect-ratio: auto; height: 100%; }

  /* --- HORA MARCADA: info + mapa lado a lado --- */
  .hora__bloco {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: clamp(3rem, 5vw, 5rem);
    align-items: start;
  }
  .hora .kicker,
  .hora__titulo,
  .hora__lede,
  .hora__cta { grid-column: 1 / -1; }
  .hora__info { grid-column: 1; border-top: none; padding-top: 0; }
  .hora__mapa { grid-column: 2; }

  /* Largura de leitura travada nas bios */
  .ritual__head,
  .carta__head,
  .casa__head { max-width: var(--leitura); }
}

/* ===================================================================
   DESKTOP LARGO — centraliza seções de texto numa coluna comum
   =================================================================== */
@media (min-width: 1280px) {
  .ritual,
  .carta__colunas,
  .casa__grid {
    max-width: var(--maxw);
    margin-left: auto;
    margin-right: auto;
  }
  .ritual { padding-left: var(--pad-x); padding-right: var(--pad-x); }
}
