/* ─── Page-specific styles ─────────────────────────────────────────────── */

/* ════════════════ HOME ════════════════ */
.hero {
  position: relative;
  min-height: clamp(720px, 100vh, 1000px);
  padding-top: clamp(7rem, 14vh, 11rem);
  padding-bottom: var(--s-8);
  overflow: hidden;
}
.hero__bloom {
  position: absolute;
  inset: -10% -5% -5% -5%;
  z-index: 0;
  background:
    radial-gradient(60% 50% at 28% 38%, var(--steam) 0%, transparent 60%),
    radial-gradient(45% 40% at 78% 70%, var(--steam-glow) 0%, transparent 60%);
  filter: blur(20px);
  opacity: 0.85;
  pointer-events: none;
}
.hero__inner {
  position: relative;
  z-index: 2;
}
.hero__eyebrow {
  display: flex;
  gap: var(--s-5);
  align-items: center;
  margin-bottom: var(--s-7);
}
.hero__eyebrow .dot {
  width: 8px; height: 8px; background: var(--chili); border-radius: 50%;
  animation: pulse 2.4s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50% { transform: scale(1.6); opacity: 0.5; }
}

.hero__title {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 144, "SOFT" 60;
  font-weight: 400;
  font-size: clamp(3.4rem, 11vw, 9.5rem);
  line-height: 0.92;
  letter-spacing: -0.035em;
  color: var(--ink);
}
.hero__title em {
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1;
  color: var(--chili);
}
.hero__title .word {
  display: inline-block;
  overflow: hidden;
  vertical-align: top;
}
.hero__title .word > span {
  display: inline-block;
  transform: translateY(110%);
  transition: transform 1s var(--ease-out);
}
.hero.is-ready .hero__title .word > span { transform: translateY(0); }

.hero__sub {
  margin-top: var(--s-7);
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: var(--s-7);
  align-items: end;
}
@media (max-width: 800px) { .hero__sub { grid-template-columns: 1fr; } }

.hero__lead {
  font-size: clamp(1.1rem, 1.5vw, 1.32rem);
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 38ch;
}
.hero__lead em { color: var(--ink); font-family: 'Fraunces', serif; font-style: italic; }

.hero__cta {
  display: flex;
  gap: var(--s-3);
  flex-wrap: wrap;
  margin-top: var(--s-5);
}

.hero__meta {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-5);
  font-size: var(--fs-small);
  border-top: var(--rule);
  padding-top: var(--s-4);
  color: var(--ink-soft);
}
.hero__meta strong {
  display: block;
  color: var(--ink);
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 144;
  font-style: italic;
  font-size: 1.6rem;
  font-weight: 400;
  margin-bottom: 4px;
}

/* ── Falling momos canvas ── */
.fall-stage {
  position: relative;
  min-height: 140vh;
  background: linear-gradient(180deg, var(--paper) 0%, var(--paper-deep) 100%);
  overflow: hidden;
  padding-block: var(--s-10);
}
.fall-stage__intro {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-7);
  align-items: end;
  margin-bottom: var(--s-9);
}
@media (max-width: 800px) { .fall-stage__intro { grid-template-columns: 1fr; } }

.fall-stage__title {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 144;
  font-size: clamp(2.6rem, 6vw, 5rem);
  line-height: 0.96;
  letter-spacing: -0.02em;
}
.fall-stage__title em {
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1;
}

.fall-grid {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--col-gap);
  z-index: 1;
}
@media (max-width: 900px) { .fall-grid { grid-template-columns: repeat(2, 1fr); } }

.fall-cell {
  position: relative;
  aspect-ratio: 1 / 1;
  border: 1px solid var(--line);
  background: var(--paper);
  display: grid;
  place-items: center;
  border-radius: var(--r-md);
  overflow: hidden;
  transition: border-color var(--d-base);
}
.fall-cell:hover { border-color: var(--ink); }
.fall-cell svg { width: 78%; height: auto; transition: transform var(--d-base) var(--ease-out); }
.fall-cell:hover svg { transform: rotate(-6deg) scale(1.04); }
.fall-cell figcaption {
  position: absolute;
  inset: auto var(--s-3) var(--s-3) var(--s-3);
  display: flex;
  justify-content: space-between;
  font-size: var(--fs-micro);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-soft);
}

/* "Falling" pre-state — JS toggles .is-settled */
.fall-cell .momo-art {
  transform: translateY(-160vh) rotate(-220deg);
  opacity: 0;
  transition: transform 1.4s var(--ease-spring), opacity 0.6s ease;
}
.fall-stage.is-settled .fall-cell .momo-art {
  transform: translateY(0) rotate(0);
  opacity: 1;
}

/* ── Signature dishes (editorial split) ── */
.signature {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: center;
  padding-block: var(--s-9);
  border-top: var(--rule);
}
.signature:nth-child(even) { grid-template-columns: 1fr 1.1fr; direction: rtl; }
.signature:nth-child(even) > * { direction: ltr; }
@media (max-width: 800px) {
  .signature, .signature:nth-child(even) { grid-template-columns: 1fr; direction: ltr; }
}
.signature__media {
  aspect-ratio: 5 / 6;
  background: var(--paper-deep);
  border-radius: var(--r-lg);
  display: grid;
  place-items: center;
  overflow: hidden;
  position: relative;
}
.signature__media svg { width: 70%; height: auto; }
.signature__media::after {
  content: attr(data-num);
  position: absolute;
  top: var(--s-4); left: var(--s-4);
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-variation-settings: "opsz" 144;
  font-size: 3rem;
  color: var(--ink);
  opacity: 0.16;
}
.signature__title {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 144;
  font-size: clamp(2.4rem, 5vw, 4rem);
  line-height: 1;
  letter-spacing: -0.02em;
  margin-block: var(--s-3) var(--s-5);
}
.signature__title em {
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1;
}
.signature__quote {
  margin-top: var(--s-5);
  border-left: 2px solid var(--chili);
  padding-left: var(--s-4);
}

/* ── Philosophy band ── */
.philosophy {
  background: var(--ink);
  color: var(--paper);
  padding-block: var(--s-10);
  position: relative;
  overflow: hidden;
}
.philosophy::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(700px 400px at 80% 20%, rgba(244,213,208,0.12) 0%, transparent 60%);
}
.philosophy__inner { position: relative; }
.philosophy__big {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 144, "SOFT" 80;
  font-size: clamp(2.6rem, 6vw, 5.4rem);
  line-height: 1;
  letter-spacing: -0.02em;
}
.philosophy__big em {
  color: var(--steam-deep);
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1;
}
.philosophy__cols {
  margin-top: var(--s-8);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-7);
}
@media (max-width: 800px) { .philosophy__cols { grid-template-columns: 1fr; } }
.philosophy__col h4 {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-variation-settings: "opsz" 144;
  font-size: 1.4rem;
  color: var(--steam);
  margin-bottom: var(--s-3);
}
.philosophy__col p { color: rgba(250,246,241,0.78); font-size: 0.98rem; line-height: 1.65; }

/* ════════════════ MENU page ════════════════ */
.menu-head {
  padding-top: clamp(8rem, 16vh, 11rem);
  padding-bottom: var(--s-7);
  border-bottom: var(--rule);
}
.menu-head__title {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 144;
  font-size: clamp(3.4rem, 9vw, 8rem);
  line-height: 0.94;
  letter-spacing: -0.03em;
}
.menu-head__title em {
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1;
}
.menu-head__lead { margin-top: var(--s-5); max-width: 60ch; }

.menu-filter {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  margin-top: var(--s-6);
}
.menu-filter button {
  padding: 0.45rem 0.95rem;
  border: 1px solid var(--line-strong);
  border-radius: var(--r-pill);
  font-size: 0.86rem;
  letter-spacing: 0.06em;
  color: var(--ink-soft);
  transition: all var(--d-fast);
}
.menu-filter button:hover { border-color: var(--ink); color: var(--ink); }
.menu-filter button[aria-pressed="true"] {
  background: var(--ink); color: var(--paper); border-color: var(--ink);
}

.menu-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(2rem, 4vw, 4rem) var(--col-gap);
  padding-block: var(--s-9);
}
@media (max-width: 900px) { .menu-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .menu-grid { grid-template-columns: 1fr; } }

/* ════════════════ STORY page ════════════════ */
.story-hero {
  padding-top: clamp(8rem, 16vh, 11rem);
  padding-bottom: var(--s-9);
  position: relative;
}
.story-hero__title {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 144, "SOFT" 80;
  font-size: clamp(3rem, 8vw, 7rem);
  line-height: 0.95;
  letter-spacing: -0.03em;
  max-width: 16ch;
}
.story-hero__title em {
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1;
  color: var(--chili);
}
.story-hero__lead { margin-top: var(--s-6); }

.chapter {
  display: grid;
  grid-template-columns: 1fr 2.4fr;
  gap: var(--s-7);
  padding-block: var(--s-9);
  border-top: var(--rule);
}
@media (max-width: 800px) { .chapter { grid-template-columns: 1fr; } }
.chapter__num {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-variation-settings: "opsz" 144;
  font-size: clamp(3rem, 6vw, 5rem);
  color: var(--ink-faint);
  font-weight: 300;
  line-height: 1;
}
.chapter__num small {
  display: block;
  font-style: normal;
  font-size: 0.7rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: var(--s-2);
}
.chapter__title {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 144;
  font-size: clamp(2rem, 4vw, 3.2rem);
  line-height: 1;
  letter-spacing: -0.02em;
  margin-bottom: var(--s-5);
}
.chapter__title em {
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1;
}
.chapter blockquote {
  margin-block: var(--s-6);
  padding-left: var(--s-5);
  border-left: 2px solid var(--chili);
}

/* ════════════════ ORDER page ════════════════ */
.order {
  padding-top: clamp(7rem, 14vh, 10rem);
  padding-bottom: var(--s-9);
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(2rem, 4vw, 4rem);
  align-items: start;
}
@media (max-width: 900px) { .order { grid-template-columns: 1fr; } }

.order__title {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 144;
  font-size: clamp(2.6rem, 6vw, 4.6rem);
  line-height: 0.95;
  letter-spacing: -0.02em;
}
.order__title em { font-style: italic; font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1; }

.cart-list {
  margin-top: var(--s-6);
  border-top: var(--rule);
}
.cart-row {
  display: grid;
  grid-template-columns: 56px 1fr auto auto auto;
  gap: var(--s-4);
  align-items: center;
  padding: var(--s-4) 0;
  border-bottom: var(--rule);
}
.cart-row__art {
  width: 56px; height: 56px; border-radius: var(--r-md);
  background: var(--paper-deep);
  display: grid; place-items: center;
  overflow: hidden;
}
.cart-row__art svg { width: 80%; height: auto; }
.cart-row__name {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 144;
  font-size: 1.1rem;
}
.cart-row__qty {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--line-strong);
  border-radius: var(--r-pill);
}
.cart-row__qty button { width: 32px; height: 32px; }
.cart-row__qty button:hover { background: var(--ink); color: var(--paper); border-radius: var(--r-pill); }
.cart-row__qty span { min-width: 28px; text-align: center; font-size: 0.95rem; }
.cart-row__price { font-family: 'Fraunces', serif; font-size: 1.05rem; }
.cart-row__rm {
  width: 28px; height: 28px;
  display: grid; place-items: center;
  border-radius: 50%;
  color: var(--ink-faint);
  transition: all var(--d-fast);
}
.cart-row__rm:hover { background: var(--chili); color: var(--paper); }

.cart-empty {
  padding: var(--s-7) 0;
  text-align: left;
  color: var(--ink-soft);
}
.cart-empty .display {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1;
  font-size: clamp(2rem, 4vw, 3.2rem);
  margin-bottom: var(--s-4);
  color: var(--ink);
}

.summary {
  position: sticky;
  top: 100px;
  background: var(--paper);
  border: 1px solid var(--ink);
  border-radius: var(--r-lg);
  padding: var(--s-6);
}
.summary h3 {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-variation-settings: "opsz" 144;
  font-size: 1.6rem;
  margin-bottom: var(--s-5);
}
.summary__row {
  display: flex;
  justify-content: space-between;
  padding-block: 0.4rem;
  font-size: 0.95rem;
  color: var(--ink-soft);
}
.summary__row.total {
  border-top: 1px solid var(--line-strong);
  margin-top: var(--s-3);
  padding-top: var(--s-3);
  color: var(--ink);
  font-size: 1.15rem;
}
.summary__row.total strong { font-family: 'Fraunces', serif; font-size: 1.35rem; font-weight: 500; }

.order-form {
  margin-top: var(--s-7);
  padding-top: var(--s-7);
  border-top: var(--rule);
  display: grid;
  gap: var(--s-5);
}
.order-form h3 {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 144;
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  margin-bottom: var(--s-4);
  letter-spacing: -0.01em;
}
.order-form h3 em { font-style: italic; }

.mode-toggle {
  display: inline-flex;
  border: 1px solid var(--ink);
  border-radius: var(--r-pill);
  padding: 4px;
  gap: 4px;
  background: var(--paper);
}
.mode-toggle button {
  padding: 0.55rem 1.1rem;
  border-radius: var(--r-pill);
  font-size: 0.9rem;
  letter-spacing: 0.04em;
  color: var(--ink-soft);
  transition: all var(--d-fast);
}
.mode-toggle button[aria-pressed="true"] {
  background: var(--ink);
  color: var(--paper);
}

.pay-options {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-3);
}
@media (max-width: 600px) { .pay-options { grid-template-columns: 1fr; } }
.pay-options label {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.85rem 1rem;
  border: 1px solid var(--line-strong);
  border-radius: var(--r-md);
  cursor: pointer;
  font-size: 0.92rem;
  transition: all var(--d-fast);
}
.pay-options label:hover { border-color: var(--ink); }
.pay-options input { accent-color: var(--chili); }
.pay-options label:has(input:checked) {
  border-color: var(--ink);
  background: var(--paper-deep);
}

/* ════════════════ VISIT page ════════════════ */
.visit-hero {
  padding-top: clamp(8rem, 16vh, 11rem);
  padding-bottom: var(--s-7);
}
.visit-hero__title {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 144;
  font-size: clamp(3rem, 8vw, 7rem);
  line-height: 0.95;
  letter-spacing: -0.03em;
}
.visit-hero__title em {
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1;
  color: var(--chili);
}

.visit-grid {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: clamp(2rem, 4vw, 4rem);
  padding-block: var(--s-7);
}
@media (max-width: 800px) { .visit-grid { grid-template-columns: 1fr; } }

.visit-card h4 {
  font-size: var(--fs-micro);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: var(--s-3);
}
.visit-card p { color: var(--ink); font-size: 1.05rem; line-height: 1.6; }
.visit-card + .visit-card { margin-top: var(--s-6); padding-top: var(--s-6); border-top: var(--rule); }

.visit-map {
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid var(--line-strong);
  aspect-ratio: 4 / 3;
  background: var(--paper-deep);
}
.visit-map iframe { width: 100%; height: 100%; border: 0; filter: grayscale(0.3) contrast(1.05); }

.hours-table {
  width: 100%;
  border-collapse: collapse;
}
.hours-table tr { border-bottom: var(--rule); }
.hours-table td { padding: 0.55rem 0; font-size: 0.95rem; }
.hours-table td:first-child { color: var(--ink-soft); letter-spacing: 0.04em; text-transform: uppercase; font-size: 0.78rem; }
.hours-table td:last-child { text-align: right; font-family: 'Fraunces', serif; font-size: 1.05rem; }
.hours-table tr.today td { color: var(--chili); font-weight: 500; }

/* ─── Reveal utility (IntersectionObserver) ─────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.9s var(--ease-out), transform 0.9s var(--ease-out);
  transition-delay: var(--reveal-delay, 0ms);
}
.reveal.is-in { opacity: 1; transform: translateY(0); }
