/* =====================================================================
   FORNO DELLA NONNA — Pizza napoletana, forno a lenha
   "Um documentário de scroll sobre uma única massa."
   MODERNO + MOTION · mobile-first · Fraunces (display) + Inter (corpo)
   Anima só opacity/transform. prefers-reduced-motion respeitado.
   ===================================================================== */

/* -------------------------------------------------------------------
   TOKENS
   ------------------------------------------------------------------- */
:root {
  /* Paleta */
  --tijolo:   #7A1F12;  /* vermelho-tijolo · marca */
  --carvao:   #2A211C;  /* carvão quente · texto e seções imersivas */
  --creme:    #F4E9D8;  /* creme/farinha · fundo editorial */
  --brasa:    #E2622E;  /* laranja brasa · acento / CTA / hover */
  --dourado:  #C9A35B;  /* dourado-crosta · fios, números, detalhes */
  --fuligem:  #1A1512;  /* quase-preto · footer, overlays */

  --creme-2:  #EADDC6;  /* creme um tom abaixo (cards) */
  --carvao-2: #3A2E27;  /* carvão claro (linhas sobre escuro) */

  /* Tipografia */
  --serif: "Fraunces", Georgia, "Times New Roman", serif;
  --sans:  "Inter", system-ui, -apple-system, sans-serif;

  /* Escala fluida */
  --step--1: clamp(0.82rem, 0.78rem + 0.2vw, 0.92rem);
  --step-0:  clamp(1rem, 0.95rem + 0.25vw, 1.12rem);
  --step-1:  clamp(1.2rem, 1.05rem + 0.7vw, 1.5rem);
  --step-2:  clamp(1.5rem, 1.2rem + 1.4vw, 2.3rem);
  --step-3:  clamp(2.1rem, 1.5rem + 3vw, 3.8rem);
  --step-4:  clamp(3rem, 1.8rem + 6vw, 6.5rem);
  --step-5:  clamp(3.6rem, 2rem + 8.5vw, 9rem);

  /* Espaçamento */
  --gutter: clamp(1.25rem, 0.8rem + 2.2vw, 3.5rem);
  --section-y: clamp(4.5rem, 3rem + 7vw, 9rem);
  --maxw: 78rem;

  /* Motion */
  --ease: cubic-bezier(0.22, 0.61, 0.36, 1);
  --dur: 0.85s;
}

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

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

body {
  font-family: var(--sans);
  font-size: var(--step-0);
  line-height: 1.65;
  color: var(--carvao);
  background: var(--creme);
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

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

a { color: inherit; text-decoration: none; transition: color 0.3s var(--ease); }

h1, h2, h3 {
  font-family: var(--serif);
  font-weight: 500;
  line-height: 1.02;
  letter-spacing: clamp(-0.02em, -0.015em, -0.01em);
  font-optical-sizing: auto;
}

em { font-style: italic; }

::selection { background: var(--brasa); color: var(--creme); }

.skip-link {
  position: absolute;
  left: clamp(1rem, 1rem, 1rem);
  top: clamp(-100px, -100px, -100px);
  z-index: 200;
  background: var(--carvao);
  color: var(--creme);
  padding: clamp(0.6rem, 0.6rem, 0.6rem) clamp(1rem, 1rem, 1rem);
  border-radius: clamp(0.4rem, 0.4rem, 0.4rem);
  transition: top 0.2s var(--ease);
}
.skip-link:focus { top: clamp(1rem, 1rem, 1rem); }

:focus-visible {
  outline: clamp(0.18rem, 0.18rem, 0.18rem) solid var(--brasa);
  outline-offset: clamp(0.2rem, 0.2rem, 0.2rem);
  border-radius: clamp(0.2rem, 0.2rem, 0.2rem);
}

/* -------------------------------------------------------------------
   KICKER — etiqueta editorial recorrente
   ------------------------------------------------------------------- */
.kicker {
  display: flex;
  align-items: center;
  gap: clamp(0.5rem, 0.5rem, 0.5rem);
  font-family: var(--sans);
  font-size: var(--step--1);
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--tijolo);
}
.kicker--light { color: var(--dourado); }
.kicker__dot {
  width: clamp(0.45rem, 0.45rem, 0.45rem);
  height: clamp(0.45rem, 0.45rem, 0.45rem);
  border-radius: 50%;
  background: var(--brasa);
  flex: 0 0 auto;
  box-shadow: 0 0 0 clamp(0.25rem, 0.25rem, 0.25rem) rgba(226, 98, 46, 0.18);
}

/* =====================================================================
   TOPBAR
   ===================================================================== */
.topbar {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: clamp(0.5rem, 0.5rem, 0.5rem);
  padding: clamp(0.9rem, 0.7rem + 0.8vw, 1.4rem) var(--gutter);
  background: linear-gradient(to bottom, rgba(26, 21, 18, 0.55), rgba(26, 21, 18, 0));
  transition: background 0.4s var(--ease), backdrop-filter 0.4s var(--ease);
}
.topbar.is-stuck {
  background: rgba(42, 33, 28, 0.92);
  backdrop-filter: blur(clamp(0.5rem, 0.5rem, 0.5rem));
  box-shadow: 0 clamp(0.1rem, 0.1rem, 0.1rem) clamp(1.2rem, 1.2rem, 1.2rem) rgba(0, 0, 0, 0.3);
}

.topbar__sig {
  display: flex;
  align-items: center;
  gap: clamp(0.55rem, 0.55rem, 0.55rem);
  color: var(--creme);
}
.topbar__mark {
  font-family: var(--serif);
  font-weight: 600;
  font-size: clamp(1.05rem, 1.05rem, 1.05rem);
  letter-spacing: -0.04em;
  color: var(--brasa);
  border: clamp(0.09rem, 0.09rem, 0.09rem) solid var(--dourado);
  border-radius: 50%;
  width: clamp(2.1rem, 2.1rem, 2.1rem);
  height: clamp(2.1rem, 2.1rem, 2.1rem);
  display: grid;
  place-items: center;
  flex: 0 0 auto;
}
.topbar__name {
  font-family: var(--serif);
  font-size: clamp(1.05rem, 1.05rem, 1.15rem);
  font-weight: 500;
  letter-spacing: -0.01em;
}

.topbar__nav { display: none; }

.topbar__cta {
  font-size: var(--step--1);
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--carvao);
  background: var(--dourado);
  padding: clamp(0.55rem, 0.55rem, 0.7rem) clamp(0.95rem, 0.95rem, 1.3rem);
  border-radius: clamp(2rem, 2rem, 2rem);
  white-space: nowrap;
  transition: background 0.3s var(--ease), transform 0.3s var(--ease);
}
.topbar__cta:hover { background: var(--brasa); color: var(--creme); transform: translateY(clamp(-0.1rem, -0.1rem, -0.1rem)); }

/* =====================================================================
   HERO
   ===================================================================== */
.hero {
  position: relative;
  min-height: 90vh;
  min-height: 90svh;
  display: flex;
  flex-direction: column;
  /* mobile: conteúdo ancorado no topo p/ o título inteiro aparecer acima do dock fixo.
     desktop reancorará em flex-end (sem dock, hero generoso). */
  justify-content: flex-start;
  padding: clamp(5rem, 4rem + 5vw, 11rem) var(--gutter) clamp(5rem, 4rem + 3vw, 6rem);
  overflow: hidden;
  color: var(--creme);
  background: var(--carvao);
}
.hero__media { position: absolute; inset: 0; z-index: 0; }
.hero__fallback {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  animation: kenburns 24s ease-in-out infinite alternate;
  z-index: 0;
}
@keyframes kenburns {
  from { transform: scale(1.0); }
  to   { transform: scale(1.06); }
}
.hero__veil {
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    linear-gradient(to top, rgba(26, 21, 18, 0.92) 0%, rgba(26, 21, 18, 0.45) 45%, rgba(26, 21, 18, 0.55) 100%),
    radial-gradient(120% 80% at 70% 30%, rgba(226, 98, 46, 0.22), transparent 60%);
}

.hero__inner {
  position: relative;
  z-index: 3;
  max-width: 22ch;
}
.hero__kicker {
  display: flex;
  align-items: center;
  gap: clamp(0.5rem, 0.5rem, 0.5rem);
  font-size: var(--step--1);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--dourado);
  margin-bottom: clamp(1.2rem, 1.2rem, 1.6rem);
  max-width: none;
  flex-wrap: wrap;
}
.hero__title {
  /* título de 6 linhas: um pouco menor no celular p/ caber inteiro acima do dock */
  font-size: clamp(3.2rem, 1.6rem + 7vw, 9rem);
  font-weight: 400;
  line-height: 0.98;
  letter-spacing: -0.025em;
  margin-bottom: clamp(1.4rem, 1.4rem, 1.8rem);
}
.hero__line { display: block; }
.hero__line--accent { color: var(--brasa); }
.hero__line--accent em { color: var(--brasa); font-weight: 500; }
.hero__lead {
  font-size: var(--step-1);
  font-weight: 300;
  line-height: 1.5;
  color: rgba(244, 233, 216, 0.9);
  max-width: 32ch;
}

.hero__scroll {
  position: relative;
  z-index: 3;
  margin-top: clamp(2.5rem, 2.5rem, 3rem);
  display: inline-flex;
  align-items: center;
  gap: clamp(0.8rem, 0.8rem, 0.8rem);
  font-size: var(--step--1);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--dourado);
}
.hero__scroll-line {
  display: inline-block;
  width: clamp(3rem, 3rem, 4rem);
  height: clamp(0.06rem, 0.06rem, 0.06rem);
  background: var(--dourado);
  transform-origin: left;
  animation: pulseLine 2.4s var(--ease) infinite;
}
@keyframes pulseLine {
  0%, 100% { transform: scaleX(0.5); opacity: 0.5; }
  50%      { transform: scaleX(1); opacity: 1; }
}
.hero__scroll:hover { color: var(--brasa); }

/* =====================================================================
   DOCUMENTÁRIO / SCROLLYTELLING
   ===================================================================== */
.doc {
  background: var(--creme);
  padding: var(--section-y) var(--gutter);
}
.doc__intro {
  max-width: var(--maxw);
  margin: 0 auto clamp(2.5rem, 2.5rem, 4rem);
}
.doc__intro .kicker { margin-bottom: clamp(1rem, 1rem, 1.4rem); }
.doc__title {
  font-size: var(--step-4);
  color: var(--tijolo);
  margin-bottom: clamp(1.2rem, 1.2rem, 1.6rem);
}
.doc__title em { color: var(--carvao); }
.doc__lead {
  font-size: var(--step-1);
  font-weight: 300;
  max-width: 42ch;
  color: var(--carvao);
}

.scrolly { max-width: var(--maxw); margin: 0 auto; }

/* Mobile: imagem + texto empilhados por capítulo (sem pin agressivo) */
.scrolly__sticky { display: none; }

.scrolly__steps { list-style: none; }

.step {
  position: relative;
  padding: clamp(2rem, 2rem, 2.5rem) 0;
  border-top: clamp(0.06rem, 0.06rem, 0.06rem) solid rgba(122, 31, 18, 0.18);
}
.step:first-child { border-top: 0; }
.step__num {
  display: block;
  font-family: var(--serif);
  font-size: clamp(2.5rem, 2.5rem, 3rem);
  font-weight: 300;
  color: var(--dourado);
  line-height: 1;
  margin-bottom: clamp(0.8rem, 0.8rem, 1rem);
}
.step__title {
  font-size: var(--step-2);
  color: var(--tijolo);
  margin-bottom: clamp(0.8rem, 0.8rem, 1rem);
}
.step__text {
  font-size: var(--step-0);
  max-width: 50ch;
  color: var(--carvao);
}

/* Mobile: imagem da etapa aparece dentro de cada step */
.scrolly__img {
  width: 100%;
  height: auto;
  border-radius: clamp(0.6rem, 0.6rem, 0.8rem);
  margin-bottom: clamp(1.4rem, 1.4rem, 1.8rem);
  box-shadow: 0 clamp(1rem, 1rem, 1.5rem) clamp(2rem, 2rem, 3rem) rgba(42, 33, 28, 0.18);
  aspect-ratio: 1 / 1;
  object-fit: cover;
}
/* No mobile cada step ganha sua própria imagem (clonada via JS) */
.step__media {
  width: 100%;
  border-radius: clamp(0.6rem, 0.6rem, 0.8rem);
  overflow: hidden;
  margin-bottom: clamp(1.4rem, 1.4rem, 1.8rem);
  box-shadow: 0 clamp(1rem, 1rem, 1.5rem) clamp(2rem, 2rem, 3rem) rgba(42, 33, 28, 0.18);
}
.step__media img { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; }

/* =====================================================================
   FORNO — full-bleed escuro, pico dramático
   ===================================================================== */
.forno {
  position: relative;
  background: var(--fuligem);
  color: var(--creme);
  padding: calc(var(--section-y) + clamp(1rem, 1rem, 2rem)) var(--gutter);
  overflow: hidden;
}
.forno__media { position: absolute; inset: 0; z-index: 0; }
.forno__img {
  position: absolute;
  inset: clamp(-3rem, -3rem, -4rem) 0 0 0;
  width: 100%;
  height: calc(100% + clamp(6rem, 6rem, 8rem));
  object-fit: cover;
  opacity: 0.45;
  will-change: transform;
}
.forno__glow {
  position: absolute;
  inset: 0;
  background: radial-gradient(80% 60% at 50% 75%, rgba(226, 98, 46, 0.45), transparent 65%);
  animation: glowPulse 4.5s ease-in-out infinite;
  mix-blend-mode: screen;
}
@keyframes glowPulse {
  0%, 100% { opacity: 0.55; }
  50%      { opacity: 1; }
}
.forno__smoke {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(26, 21, 18, 0.95) 5%, rgba(26, 21, 18, 0.35) 50%, rgba(26, 21, 18, 0.85) 100%);
}

.forno__inner {
  position: relative;
  z-index: 1;
  max-width: var(--maxw);
  margin: 0 auto;
}
.forno__inner .kicker { margin-bottom: clamp(1rem, 1rem, 1.4rem); }
.forno__title {
  font-size: var(--step-4);
  color: var(--creme);
  margin-bottom: clamp(1.4rem, 1.4rem, 1.8rem);
}
.forno__title em { color: var(--brasa); }
.forno__text {
  font-size: var(--step-1);
  font-weight: 300;
  max-width: 44ch;
  color: rgba(244, 233, 216, 0.92);
  margin-bottom: clamp(2.5rem, 2.5rem, 3.5rem);
}

.forno__stats {
  display: grid;
  gap: clamp(1.6rem, 1.6rem, 2rem);
}
.stat { border-top: clamp(0.06rem, 0.06rem, 0.06rem) solid var(--carvao-2); padding-top: clamp(0.9rem, 0.9rem, 1.1rem); }
.stat__label {
  font-size: var(--step--1);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--dourado);
  margin-bottom: clamp(0.4rem, 0.4rem, 0.5rem);
}
.stat__num {
  font-family: var(--serif);
  font-size: clamp(3rem, 2rem + 5vw, 5rem);
  font-weight: 400;
  line-height: 1;
  color: var(--creme);
}
.stat__unit { font-size: 0.45em; color: var(--brasa); margin-left: clamp(0.2rem, 0.2rem, 0.2rem); }

/* =====================================================================
   CARDÁPIO
   ===================================================================== */
.menu {
  background: var(--creme);
  padding: var(--section-y) var(--gutter);
}
.menu__head {
  max-width: var(--maxw);
  margin: 0 auto clamp(2.5rem, 2.5rem, 4rem);
}
.menu__head .kicker { margin-bottom: clamp(1rem, 1rem, 1.4rem); }
.menu__title {
  font-size: var(--step-4);
  color: var(--tijolo);
  margin-bottom: clamp(1.2rem, 1.2rem, 1.6rem);
}
.menu__title em { color: var(--carvao); }
.menu__lead {
  font-size: var(--step-1);
  font-weight: 300;
  max-width: 44ch;
}

.menu__grid {
  list-style: none;
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  gap: clamp(2rem, 2rem, 2.5rem);
}

.dish__fig { margin: 0; }
.dish__media {
  position: relative;
  overflow: hidden;
  border-radius: clamp(0.6rem, 0.6rem, 0.9rem);
  aspect-ratio: 1 / 1;
  background: var(--creme-2);
}
.dish__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s var(--ease);
}
.dish:hover .dish__media img { transform: scale(1.04); }

.dish__cap { padding-top: clamp(1.2rem, 1.2rem, 1.4rem); position: relative; }
.dish__name {
  font-size: var(--step-2);
  color: var(--tijolo);
  margin-bottom: clamp(0.5rem, 0.5rem, 0.6rem);
  display: inline-block;
  position: relative;
}
.dish__name::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: clamp(-0.15rem, -0.15rem, -0.2rem);
  width: 100%;
  height: clamp(0.1rem, 0.1rem, 0.12rem);
  background: var(--dourado);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.5s var(--ease);
}
.dish:hover .dish__name::after { transform: scaleX(1); }
.dish__desc {
  font-size: var(--step-0);
  font-weight: 300;
  color: var(--carvao);
  max-width: 44ch;
  margin-bottom: clamp(0.8rem, 0.8rem, 1rem);
}
.dish__price {
  font-family: var(--serif);
  font-size: var(--step-1);
  font-weight: 500;
  color: var(--brasa);
}

.menu__note {
  max-width: var(--maxw);
  margin: clamp(2.5rem, 2.5rem, 3.5rem) auto 0;
  font-size: var(--step-0);
  font-style: italic;
  color: var(--tijolo);
  font-family: var(--serif);
  font-weight: 300;
}

/* =====================================================================
   QUEM FAZ
   ===================================================================== */
.quem {
  background: var(--carvao);
  color: var(--creme);
  padding: var(--section-y) var(--gutter);
  display: grid;
  gap: clamp(2.5rem, 2.5rem, 3.5rem);
}
.quem__portrait { margin: 0; max-width: var(--maxw); margin-inline: auto; width: 100%; }
.quem__media {
  overflow: hidden;
  border-radius: clamp(0.6rem, 0.6rem, 1rem);
  aspect-ratio: 4 / 5;
  box-shadow: 0 clamp(1.5rem, 1.5rem, 2rem) clamp(2.5rem, 2.5rem, 4rem) rgba(0, 0, 0, 0.4);
}
.quem__media img { width: 100%; height: 100%; object-fit: cover; }

.quem__text { max-width: var(--maxw); margin-inline: auto; width: 100%; }
.quem__text .kicker { color: var(--dourado); margin-bottom: clamp(1rem, 1rem, 1.4rem); }
.quem__title {
  font-size: var(--step-3);
  color: var(--creme);
  margin-bottom: clamp(1.2rem, 1.2rem, 1.6rem);
}
.quem__title em { color: var(--brasa); }
.quem__lead {
  font-size: var(--step-1);
  font-weight: 300;
  margin-bottom: clamp(1rem, 1rem, 1.4rem);
  color: rgba(244, 233, 216, 0.95);
}
.quem__text p { color: rgba(244, 233, 216, 0.85); font-weight: 300; max-width: 56ch; margin-bottom: clamp(1rem, 1rem, 1.2rem); }
.quem__text p strong { color: var(--creme); font-weight: 500; }
.quem__sign {
  font-family: var(--serif);
  font-style: italic;
  font-size: var(--step-1);
  color: var(--dourado) !important;
  margin-top: clamp(1.4rem, 1.4rem, 1.8rem);
}

/* =====================================================================
   SALÃO
   ===================================================================== */
.salao {
  background: var(--creme);
  padding: var(--section-y) var(--gutter);
}
.salao__head { max-width: var(--maxw); margin: 0 auto clamp(2.5rem, 2.5rem, 3.5rem); }
.salao__head .kicker { margin-bottom: clamp(1rem, 1rem, 1.4rem); }
.salao__title {
  font-size: var(--step-4);
  color: var(--tijolo);
}
.salao__title em { color: var(--carvao); }

/* Mobile: carrossel swipe */
.salao__gallery {
  list-style: none;
  display: flex;
  gap: clamp(1rem, 1rem, 1.2rem);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  padding-bottom: clamp(0.8rem, 0.8rem, 0.8rem);
  scrollbar-width: thin;
  scrollbar-color: var(--dourado) transparent;
}
.salao__item {
  flex: 0 0 82%;
  scroll-snap-align: center;
  border-radius: clamp(0.6rem, 0.6rem, 0.9rem);
  overflow: hidden;
  box-shadow: 0 clamp(1rem, 1rem, 1.5rem) clamp(2rem, 2rem, 3rem) rgba(42, 33, 28, 0.18);
}
.salao__item img { width: 100%; aspect-ratio: 1 / 1; object-fit: cover; }
.salao__item--tall img { aspect-ratio: 2 / 3; }

/* =====================================================================
   VOZES / AVALIAÇÕES
   ===================================================================== */
.vozes {
  background: var(--tijolo);
  color: var(--creme);
  padding: var(--section-y) var(--gutter);
}
.vozes__head { max-width: var(--maxw); margin: 0 auto clamp(2.5rem, 2.5rem, 3.5rem); }
.vozes__head .kicker { color: var(--dourado); margin-bottom: clamp(1rem, 1rem, 1.4rem); }
.vozes__title {
  font-size: var(--step-3);
  color: var(--creme);
}
.vozes__grid {
  list-style: none;
  max-width: var(--maxw);
  margin: 0 auto;
  display: grid;
  gap: clamp(1.8rem, 1.8rem, 2.2rem);
}
.voz {
  border-top: clamp(0.08rem, 0.08rem, 0.08rem) solid rgba(244, 233, 216, 0.25);
  padding-top: clamp(1.4rem, 1.4rem, 1.6rem);
}
.voz__stars { color: var(--dourado); font-size: var(--step-1); letter-spacing: 0.15em; margin-bottom: clamp(1rem, 1rem, 1.2rem); }
.voz__quote p {
  font-family: var(--serif);
  font-size: var(--step-1);
  font-weight: 300;
  font-style: italic;
  line-height: 1.45;
  color: var(--creme);
  margin-bottom: clamp(1rem, 1rem, 1.2rem);
}
.voz__meta { font-size: var(--step--1); color: rgba(244, 233, 216, 0.8); }
.voz__meta strong { color: var(--dourado); font-weight: 600; }

/* =====================================================================
   VISITE / RESERVE
   ===================================================================== */
.visite {
  background: var(--carvao);
  color: var(--creme);
  padding: var(--section-y) var(--gutter) calc(var(--section-y) + clamp(4rem, 4rem, 0rem));
  display: grid;
  gap: clamp(2.5rem, 2.5rem, 3.5rem);
}
.visite__info { max-width: var(--maxw); margin-inline: auto; width: 100%; }
.visite__info .kicker { margin-bottom: clamp(1rem, 1rem, 1.4rem); }
.visite__title {
  font-size: var(--step-4);
  color: var(--creme);
  margin-bottom: clamp(1.2rem, 1.2rem, 1.6rem);
}
.visite__lead {
  font-size: var(--step-1);
  font-weight: 300;
  max-width: 46ch;
  color: rgba(244, 233, 216, 0.9);
  margin-bottom: clamp(1.8rem, 1.8rem, 2.2rem);
}

.wa-btn {
  display: inline-flex;
  align-items: center;
  gap: clamp(0.6rem, 0.6rem, 0.7rem);
  background: var(--brasa);
  color: var(--creme);
  font-weight: 600;
  font-size: var(--step-0);
  padding: clamp(0.9rem, 0.9rem, 1.1rem) clamp(1.6rem, 1.6rem, 2rem);
  border-radius: clamp(2.5rem, 2.5rem, 2.5rem);
  transition: transform 0.3s var(--ease), box-shadow 0.3s var(--ease), background 0.3s var(--ease);
  box-shadow: 0 clamp(0.5rem, 0.5rem, 0.7rem) clamp(1.5rem, 1.5rem, 2rem) rgba(226, 98, 46, 0.35);
}
.wa-btn:hover { transform: translateY(clamp(-0.15rem, -0.15rem, -0.2rem)); box-shadow: 0 clamp(0.9rem, 0.9rem, 1.1rem) clamp(2rem, 2rem, 2.5rem) rgba(226, 98, 46, 0.5); background: #d4541f; }
.wa-btn__icon { width: clamp(1.3rem, 1.3rem, 1.5rem); height: clamp(1.3rem, 1.3rem, 1.5rem); fill: currentColor; flex: 0 0 auto; }

.visite__details {
  margin-top: clamp(2.5rem, 2.5rem, 3rem);
  display: grid;
  gap: clamp(1.4rem, 1.4rem, 1.6rem);
}
.visite__row { border-top: clamp(0.06rem, 0.06rem, 0.06rem) solid var(--carvao-2); padding-top: clamp(0.9rem, 0.9rem, 1rem); }
.visite__row dt {
  font-size: var(--step--1);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--dourado);
  margin-bottom: clamp(0.4rem, 0.4rem, 0.5rem);
}
.visite__row dd { font-size: var(--step-0); color: rgba(244, 233, 216, 0.92); }
.visite__row dd a:hover { color: var(--brasa); }

.visite__map { margin: 0; max-width: var(--maxw); margin-inline: auto; width: 100%; }
.visite__media {
  overflow: hidden;
  border-radius: clamp(0.6rem, 0.6rem, 1rem);
  aspect-ratio: 4 / 3;
  box-shadow: 0 clamp(1rem, 1rem, 1.5rem) clamp(2rem, 2rem, 3rem) rgba(0, 0, 0, 0.4);
}
.visite__media img { width: 100%; height: 100%; object-fit: cover; }
.visite__map-cap { margin-top: clamp(1rem, 1rem, 1.2rem); }
.visite__map-link {
  display: inline-flex;
  align-items: center;
  gap: clamp(0.4rem, 0.4rem, 0.5rem);
  font-size: var(--step--1);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--dourado);
}
.visite__map-link:hover { color: var(--brasa); }

/* =====================================================================
   FOOTER
   ===================================================================== */
.foot {
  background: var(--fuligem);
  color: rgba(244, 233, 216, 0.7);
  padding: clamp(3rem, 3rem, 4rem) var(--gutter) clamp(7rem, 7rem, 4rem);
  display: grid;
  gap: clamp(2rem, 2rem, 2.5rem);
}
.foot__brand .foot__mark {
  font-family: var(--serif);
  font-weight: 600;
  color: var(--brasa);
  border: clamp(0.09rem, 0.09rem, 0.09rem) solid var(--dourado);
  border-radius: 50%;
  width: clamp(2.4rem, 2.4rem, 2.4rem);
  height: clamp(2.4rem, 2.4rem, 2.4rem);
  display: grid;
  place-items: center;
  margin-bottom: clamp(0.8rem, 0.8rem, 1rem);
}
.foot__name { font-family: var(--serif); font-size: var(--step-2); color: var(--creme); }
.foot__tag { font-style: italic; font-family: var(--serif); color: var(--dourado); }

.foot__cols { display: grid; gap: clamp(1.6rem, 1.6rem, 2rem); }
.foot__h {
  font-family: var(--sans);
  font-size: var(--step--1);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--dourado);
  margin-bottom: clamp(0.5rem, 0.5rem, 0.6rem);
}
.foot__col p { font-size: var(--step-0); }
.foot__col a:hover { color: var(--brasa); }

.foot__by {
  font-size: var(--step--1);
  border-top: clamp(0.06rem, 0.06rem, 0.06rem) solid var(--carvao-2);
  padding-top: clamp(1.4rem, 1.4rem, 1.6rem);
}
.foot__by a { color: var(--dourado); }
.foot__by a:hover { color: var(--brasa); }
.foot__by span { color: var(--dourado); }

/* =====================================================================
   DOCK (sticky bar mobile)
   ===================================================================== */
.dock {
  position: fixed;
  inset: auto 0 0 0;
  z-index: 90;
  display: flex;
  gap: clamp(0.6rem, 0.6rem, 0.6rem);
  padding: clamp(0.7rem, 0.7rem, 0.7rem) clamp(0.9rem, 0.9rem, 0.9rem);
  padding-bottom: max(clamp(0.7rem, 0.7rem, 0.7rem), env(safe-area-inset-bottom));
  background: rgba(26, 21, 18, 0.96);
  backdrop-filter: blur(clamp(0.5rem, 0.5rem, 0.5rem));
  border-top: clamp(0.06rem, 0.06rem, 0.06rem) solid var(--carvao-2);
}
.dock__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: clamp(0.45rem, 0.45rem, 0.45rem);
  font-size: var(--step--1);
  font-weight: 600;
  padding: clamp(0.8rem, 0.8rem, 0.8rem);
  border-radius: clamp(2rem, 2rem, 2rem);
}
.dock__btn svg { width: clamp(1.1rem, 1.1rem, 1.1rem); height: clamp(1.1rem, 1.1rem, 1.1rem); fill: currentColor; }
.dock__btn--ghost { flex: 0 0 auto; color: var(--dourado); border: clamp(0.08rem, 0.08rem, 0.08rem) solid var(--dourado); padding-inline: clamp(1.1rem, 1.1rem, 1.1rem); }
.dock__btn--solid { flex: 1 1 auto; background: var(--brasa); color: var(--creme); }

/* =====================================================================
   MOTION — reveal states
   ===================================================================== */
.reveal {
  opacity: 0;
  transform: translateY(clamp(1.5rem, 1.5rem, 1.5rem));
  transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease);
  will-change: opacity, transform;
}
.reveal.is-in { opacity: 1; transform: translateY(0); }

.hero__line {
  opacity: 0;
  transform: translateY(clamp(1.2rem, 1.2rem, 1.2rem));
  animation: lineIn 0.9s var(--ease) forwards;
}
.hero__line:nth-child(1) { animation-delay: 0.15s; }
.hero__line:nth-child(2) { animation-delay: 0.30s; }
.hero__line:nth-child(3) { animation-delay: 0.45s; }
.hero__line:nth-child(4) { animation-delay: 0.60s; }
.hero__kicker, .hero__lead, .hero__scroll {
  opacity: 0;
  transform: translateY(clamp(0.8rem, 0.8rem, 0.8rem));
  animation: lineIn 0.9s var(--ease) forwards;
}
.hero__kicker { animation-delay: 0.05s; }
.hero__lead { animation-delay: 0.75s; }
.hero__scroll { animation-delay: 0.95s; }
@keyframes lineIn {
  to { opacity: 1; transform: translateY(0); }
}

/* =====================================================================
   ===========================  TABLET  ===============================
   ===================================================================== */
@media (min-width: 48rem) {
  .topbar__nav {
    display: flex;
    gap: clamp(1.4rem, 1.4rem, 2rem);
    font-size: var(--step--1);
    color: var(--creme);
    letter-spacing: 0.03em;
  }
  .topbar__nav a:hover { color: var(--brasa); }

  /* sem dock a partir daqui: hero volta a ancorar o conteúdo embaixo (editorial) */
  .hero { justify-content: flex-end; }
  .hero__inner { max-width: 28ch; }

  /* Cardápio 2 colunas, com a hero (margherita) ocupando a linha toda */
  .menu__grid { grid-template-columns: repeat(2, 1fr); }
  .dish--hero { grid-column: 1 / -1; }
  .dish--hero .dish__fig { display: grid; grid-template-columns: 1.2fr 1fr; gap: clamp(1.5rem, 1.5rem, 2.5rem); align-items: center; }
  .dish--hero .dish__cap { padding-top: 0; }

  /* Salão: grid em vez de carrossel */
  .salao__gallery {
    display: grid;
    grid-template-columns: 1fr 1fr;
    overflow: visible;
  }
  .salao__item { flex: initial; }
  .salao__item--tall { grid-row: span 2; }
  .salao__item--tall img { aspect-ratio: 3 / 4; height: 100%; }

  /* Vozes 3 colunas */
  .vozes__grid { grid-template-columns: repeat(3, 1fr); gap: clamp(1.4rem, 1.4rem, 2rem); }
  .voz__quote p { font-size: var(--step-0); }

  /* Forno stats lado a lado */
  .forno__stats { grid-template-columns: repeat(3, 1fr); }

  /* Quem faz: retrato + texto lado a lado */
  .quem {
    grid-template-columns: 0.9fr 1.1fr;
    align-items: center;
    max-width: var(--maxw);
    margin-inline: auto;
    gap: clamp(2.5rem, 2.5rem, 4rem);
  }
  .quem__portrait, .quem__text { max-width: none; }

  /* Visite: info + mapa lado a lado */
  .visite {
    grid-template-columns: 1fr 1fr;
    align-items: start;
    max-width: var(--maxw);
    margin-inline: auto;
    gap: clamp(2.5rem, 2.5rem, 4rem);
  }
  .visite__info, .visite__map { max-width: none; }
  .visite__map { position: sticky; top: clamp(6rem, 6rem, 6rem); }

  .dock { display: none; }
  .foot { padding-bottom: clamp(3rem, 3rem, 4rem); }
  .foot__cols { grid-template-columns: repeat(3, 1fr); }
}

/* =====================================================================
   ===========================  DESKTOP  ==============================
   ===================================================================== */
@media (min-width: 64rem) {
  .topbar { padding-inline: clamp(2.5rem, 2.5rem, 4rem); }

  .hero { padding-inline: clamp(2.5rem, 2.5rem, 5rem); padding-top: clamp(6rem, 3rem + 4vh, 8rem); }
  .hero__inner { max-width: 40rem; }

  /* SCROLLYTELLING DESKTOP: imagem pinada à esquerda, capítulos rolando à direita */
  .scrolly {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: clamp(3rem, 3rem, 5rem);
    align-items: start;
  }
  .scrolly__sticky {
    display: block;
    position: sticky;
    top: clamp(6rem, 6rem, 7rem);
    height: min(80vh, 42rem);
  }
  .scrolly__stage {
    position: relative;
    width: 100%;
    height: 100%;
    border-radius: clamp(0.8rem, 0.8rem, 1.2rem);
    overflow: hidden;
    box-shadow: 0 clamp(2rem, 2rem, 3rem) clamp(3rem, 3rem, 5rem) rgba(42, 33, 28, 0.25);
  }
  /* No desktop, as imagens dentro de cada step somem — fica só a pinada */
  .scrolly__steps .step__media { display: none; }
  .scrolly__img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    margin: 0;
    border-radius: 0;
    box-shadow: none;
    object-fit: cover;
    opacity: 0;
    transform: scale(1.04);
    transition: opacity 0.8s var(--ease), transform 1.2s var(--ease);
  }
  .scrolly__img.is-active { opacity: 1; transform: scale(1); }

  .scrolly__clock {
    position: absolute;
    left: clamp(1.5rem, 1.5rem, 2rem);
    bottom: clamp(1.5rem, 1.5rem, 2rem);
    z-index: 2;
    color: var(--creme);
    text-shadow: 0 clamp(0.1rem, 0.1rem, 0.1rem) clamp(0.8rem, 0.8rem, 1rem) rgba(0, 0, 0, 0.6);
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: 0 clamp(0.6rem, 0.6rem, 0.6rem);
    line-height: 1;
  }
  .scrolly__clock-num {
    font-family: var(--serif);
    font-size: clamp(3.5rem, 5vw, 5.5rem);
    font-weight: 400;
    color: var(--brasa);
  }
  .scrolly__clock-unit { font-family: var(--serif); font-size: clamp(1.5rem, 2vw, 2rem); color: var(--dourado); }
  .scrolly__clock-label {
    flex-basis: 100%;
    font-family: var(--sans);
    font-size: var(--step--1);
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--dourado);
    margin-top: clamp(0.3rem, 0.3rem, 0.4rem);
  }

  .scrolly__steps { padding-top: clamp(2rem, 2rem, 4rem); }
  .step { padding: clamp(6rem, 10vh, 11rem) 0; min-height: 60vh; display: flex; flex-direction: column; justify-content: center; border-top: 0; }
  .step:first-child { padding-top: clamp(2rem, 2rem, 3rem); }
  .step__title { font-size: var(--step-3); }

  /* Cardápio 3 colunas; margherita continua full-width destacada */
  .menu__grid { grid-template-columns: repeat(3, 1fr); gap: clamp(2.5rem, 2.5rem, 3rem); }
  .dish--hero .dish__fig { grid-template-columns: 1.3fr 1fr; gap: clamp(3rem, 3rem, 4rem); }
  .dish--hero .dish__name { font-size: var(--step-3); }

  .forno__title, .doc__title, .menu__title, .salao__title, .visite__title { max-width: 14ch; }
  .forno__inner, .doc__intro, .menu__head, .salao__head, .vozes__head { padding-block: 0; }

  .vozes__title, .quem__title { font-size: var(--step-4); }

  .foot {
    grid-template-columns: 1fr 2fr;
    align-items: start;
    padding-inline: clamp(2.5rem, 2.5rem, 5rem);
  }
  .foot__by { grid-column: 1 / -1; }
}

/* Telas largas: respiro extra no hero */
@media (min-width: 90rem) {
  .hero__inner { max-width: 46rem; }
}

/* =====================================================================
   REDUCED MOTION — tudo estático e visível
   ===================================================================== */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }
  .reveal { opacity: 1; transform: none; }
  .hero__line, .hero__kicker, .hero__lead, .hero__scroll { opacity: 1; transform: none; }
  .hero__fallback { animation: none; transform: none; }
  .scrolly__img { opacity: 1; transform: none; }
  .forno__glow { animation: none; opacity: 0.7; }
  .hero__scroll-line { animation: none; transform: scaleX(1); opacity: 1; }
  /* No desktop sem motion, mostrar todas as etapas como pilha legível */
}
@media (prefers-reduced-motion: reduce) and (min-width: 64rem) {
  .scrolly { grid-template-columns: 1fr; }
  .scrolly__sticky { display: none; }
  .scrolly__steps .step__media { display: block; }
  .step { min-height: auto; padding: clamp(2.5rem, 2.5rem, 3rem) 0; border-top: clamp(0.06rem, 0.06rem, 0.06rem) solid rgba(122, 31, 18, 0.18); }
}
