/* Burgers & Dreams — static site styles
   Mirrors the CSS variables, fonts and animations from the React build. */

:root {
  --bd-dark: #0b2e54;
  --bd-ink: #08223e;
  --bd-pink: #fa4380;
  --bd-pink-hot: #e63571;
  --bd-blue: #14468c;
  --bd-blue-deep: #0b2e54;
  --bd-sky: #3fc8f0;
  --bd-light: #f5f5f5;
  --bd-cream: #f2ece2;
  --bd-body: #9a9a9a;
}

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: "Kanit", ui-sans-serif, system-ui, -apple-system, sans-serif;
  font-weight: 400;
  letter-spacing: 0.02em;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  background: var(--bd-dark);
  color: #fff;
  overflow-x: hidden;
}

::selection { background: var(--bd-pink); color: #fff; }
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: #0b0b0c; }
::-webkit-scrollbar-thumb { background: var(--bd-pink); }

/* Type utilities */
.font-display {
  font-family: "Kanit", sans-serif;
  font-weight: 800;
  letter-spacing: 0.03em;
  line-height: 0.92;
  text-transform: uppercase;
}
.font-body { font-family: "Kanit", sans-serif; font-weight: 400; letter-spacing: 0.02em; }

/* Ken Burns */
@keyframes kenBurns {
  0% { transform: scale(1) translate3d(0,0,0); }
  100% { transform: scale(1.12) translate3d(-1.5%,-1%,0); }
}
.ken-burns { animation: kenBurns 14s ease-out forwards; }

/* Float/bob */
@keyframes floatBob {
  0%,100% { transform: translateY(0) rotate(-2deg); }
  50% { transform: translateY(-16px) rotate(2deg); }
}
.float-bob { animation: floatBob 6s ease-in-out infinite; }

/* Marquee / ticker */
@keyframes marquee {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.marquee-track { animation: marquee 40s linear infinite; }
.marquee-track.pause:hover { animation-play-state: paused; }
.ticker-track { animation: marquee 28s linear infinite; }

/* Reveal on scroll */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.8s cubic-bezier(0.2,0.7,0.2,1), transform 0.8s cubic-bezier(0.2,0.7,0.2,1);
  will-change: opacity, transform;
}
.reveal.is-visible { opacity: 1; transform: translateY(0); }

/* Stagger */
.reveal-stagger > * {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 0.7s cubic-bezier(0.2,0.7,0.2,1), transform 0.7s cubic-bezier(0.2,0.7,0.2,1);
}
.reveal-stagger.is-visible > *:nth-child(1) { transition-delay: 0ms; }
.reveal-stagger.is-visible > *:nth-child(2) { transition-delay: 70ms; }
.reveal-stagger.is-visible > *:nth-child(3) { transition-delay: 140ms; }
.reveal-stagger.is-visible > *:nth-child(4) { transition-delay: 210ms; }
.reveal-stagger.is-visible > *:nth-child(5) { transition-delay: 280ms; }
.reveal-stagger.is-visible > *:nth-child(6) { transition-delay: 350ms; }
.reveal-stagger.is-visible > * { opacity: 1; transform: translateY(0); }

/* Hover lift */
.hover-lift {
  transition: transform 0.35s cubic-bezier(0.2,0.7,0.2,1), box-shadow 0.35s cubic-bezier(0.2,0.7,0.2,1);
}
.hover-lift:hover {
  transform: translateY(-4px);
  box-shadow: 0 30px 60px -20px rgba(250,67,128,0.35);
}

/* Image grow */
.img-grow { transition: transform 0.6s cubic-bezier(0.2,0.7,0.2,1), filter 0.6s cubic-bezier(0.2,0.7,0.2,1); }
.img-grow:hover { transform: scale(1.05); filter: brightness(1.08) saturate(1.05); }

/* Buttons */
.btn-pink {
  background: var(--bd-pink);
  color: #fff;
  transition: transform 0.25s ease, box-shadow 0.25s ease, background 0.25s ease;
  box-shadow: 0 10px 25px -10px rgba(250,67,128,0.55), inset 0 -3px 0 rgba(0,0,0,0.15);
}
.btn-pink:hover {
  transform: translateY(-2px) scale(1.03);
  background: var(--bd-pink-hot);
  box-shadow: 0 18px 40px -15px rgba(250,67,128,0.75), inset 0 -3px 0 rgba(0,0,0,0.2);
}
.btn-ghost {
  border: 2px solid #fff;
  color: #fff;
  background: transparent;
  transition: transform 0.25s ease, background 0.25s ease, color 0.25s ease;
}
.btn-ghost:hover { background: #fff; color: var(--bd-dark); transform: translateY(-2px) scale(1.03); }

/* Grain */
.grain { position: relative; }
.grain::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.35 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity: 0.25; mix-blend-mode: overlay;
}

/* Eyebrow */
.eyebrow {
  display: inline-flex; align-items: center; gap: 0.6rem;
  font-family: "Kanit", sans-serif; font-weight: 700; letter-spacing: 0.1em;
  text-transform: uppercase; font-size: 12px; color: var(--bd-pink);
}
.eyebrow::before { content: ""; width: 28px; height: 2px; background: currentColor; }

/* Specials scroller */
.specials-scroll { scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
.specials-scroll::-webkit-scrollbar { display: none; }
.specials-scroll > * { scroll-snap-align: start; }

/* Zoom parallax */
.zp-wrap { position: relative; height: 300vh; background: var(--bd-dark); }
.zp-sticky { position: sticky; top: 0; height: 100vh; overflow: hidden; }
.zp-item {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  will-change: transform;
}
.zp-inner { position: relative; height: 25vh; width: 25vw; }
.zp-inner img { width: 100%; height: 100%; object-fit: cover; display: block; }
/* per-index tile positions (must match React version) */
.zp-item[data-i="1"] .zp-inner { top: -30vh; left: 5vw; height: 30vh; width: 35vw; }
.zp-item[data-i="2"] .zp-inner { top: -10vh; left: -25vw; height: 45vh; width: 20vw; }
.zp-item[data-i="3"] .zp-inner { left: 27.5vw; height: 25vh; width: 25vw; }
.zp-item[data-i="4"] .zp-inner { top: 27.5vh; left: 5vw; height: 25vh; width: 20vw; }
.zp-item[data-i="5"] .zp-inner { top: 27.5vh; left: -22.5vw; height: 25vh; width: 30vw; }
.zp-item[data-i="6"] .zp-inner { top: 22.5vh; left: 25vw; height: 15vh; width: 15vw; }

/* Focus */
:focus-visible { outline: 3px solid var(--bd-sky); outline-offset: 3px; }

/* Hide #emergent-badge if injected */
#emergent-badge, a[href*="emergent.sh"] { display: none !important; }

/* ---------------------------------------------------------------
   Menu page — type-driven menu-board styles
--------------------------------------------------------------- */

/* Sticky category chip nav */
.menu-chipnav {
  position: sticky;
  top: 80px; /* sits below the fixed 80px navbar */
  z-index: 30;
  background: rgba(245, 245, 245, 0.92);
  backdrop-filter: saturate(1.2) blur(10px);
  -webkit-backdrop-filter: saturate(1.2) blur(10px);
  border-bottom: 1px solid rgba(11, 46, 84, 0.08);
}
.menu-chipnav .chip-track {
  display: flex;
  gap: 0.5rem;
  overflow-x: auto;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  padding: 14px 0;
}
.menu-chipnav .chip-track::-webkit-scrollbar { display: none; }
.menu-chip {
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
  padding: 0.5rem 1rem;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--bd-dark);
  background: transparent;
  border: 1.5px solid rgba(11, 46, 84, 0.15);
  transition: color 0.15s ease, background 0.15s ease, border-color 0.15s ease;
}
.menu-chip:hover { color: var(--bd-pink); border-color: var(--bd-pink); }
.menu-chip.is-active {
  color: #fff;
  background: var(--bd-pink);
  border-color: var(--bd-pink);
}

/* Menu section heading rule (numbered) */
.menu-section-rule {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid rgba(11, 46, 84, 0.12);
}
.menu-section-rule .num {
  font-family: "Kanit", sans-serif;
  font-weight: 800;
  letter-spacing: 0.08em;
  font-size: 12px;
  color: var(--bd-pink);
}
.menu-section-rule .label {
  font-family: "Kanit", sans-serif;
  font-weight: 800;
  letter-spacing: 0.22em;
  font-size: 12px;
  text-transform: uppercase;
  color: rgba(11, 46, 84, 0.55);
}

/* Two-column menu list (column flow) */
.menu-list {
  column-count: 1;
  column-gap: 4rem;
}
@media (min-width: 768px) {
  .menu-list { column-count: 2; }
}

/* Single menu row — type-driven, no card */
.menu-row {
  break-inside: avoid;
  padding: 1.5rem 0;
  border-bottom: 1px solid rgba(11, 46, 84, 0.10);
  transition: background 0.15s ease;
}
.menu-row:hover { background: rgba(250, 67, 128, 0.04); }
.menu-row:hover .menu-row-name { color: var(--bd-pink); }
.menu-row-name {
  font-family: "Kanit", sans-serif;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  font-size: 22px;
  line-height: 1.1;
  color: var(--bd-dark);
  transition: color 0.15s ease;
}
@media (min-width: 1024px) { .menu-row-name { font-size: 26px; } }
.menu-row-desc {
  margin-top: 0.5rem;
  font-size: 14px;
  line-height: 1.55;
  color: var(--bd-body);
  font-weight: 400;
}
@media (min-width: 1024px) { .menu-row-desc { font-size: 15px; } }

/* Tag chips */
.menu-tags {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-left: 0.6rem;
  vertical-align: middle;
}
.menu-tag {
  display: inline-flex;
  align-items: center;
  padding: 3px 8px;
  font-size: 9.5px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  line-height: 1;
  color: #fff;
  background: var(--bd-blue);
}
.menu-tag-signature { background: var(--bd-pink); }
.menu-tag-bestseller { background: var(--bd-pink); }
.menu-tag-top { background: #08223e; color: var(--bd-sky); }
.menu-tag-fan { background: var(--bd-sky); color: var(--bd-dark); }
.menu-tag-popular { background: var(--bd-sky); color: var(--bd-dark); }
.menu-tag-spicy { background: #ff3a30; }
.menu-tag-vegan { background: #2a8e3f; }
.menu-tag-veg { background: #2a8e3f; }
.menu-tag-loaded { background: var(--bd-blue); }
.menu-tag-share { background: #08223e; }
.menu-tag-kids { background: #ffb547; color: var(--bd-dark); }
.menu-tag-group { background: var(--bd-blue); }
.menu-tag-catering { background: #08223e; color: var(--bd-sky); }

/* Section visual chrome — watermark number + pink left rule */
.menu-section { position: relative; overflow: hidden; }
.menu-section--alt { background: #faf6ee; }
.menu-section .section-watermark {
  position: absolute;
  top: 0.5rem;
  right: -2.5rem;
  font-family: "Kanit", sans-serif;
  font-weight: 900;
  font-size: clamp(160px, 22vw, 340px);
  line-height: 0.82;
  letter-spacing: -0.06em;
  color: rgba(250, 67, 128, 0.07);
  pointer-events: none;
  user-select: none;
  z-index: 0;
}
.menu-section > .menu-section-inner { position: relative; z-index: 1; }
.menu-section-head {
  border-left: 6px solid var(--bd-pink);
  padding-left: 1.25rem;
}

/* Pink-square bullet before item name (menu-board feel) */
.menu-row-name { position: relative; padding-left: 1.4rem; }
.menu-row-name::before {
  content: "";
  position: absolute;
  left: 0; top: 0.55em;
  width: 10px; height: 10px;
  background: var(--bd-pink);
  transition: background 0.15s ease, transform 0.15s ease;
}
.menu-row:hover .menu-row-name::before { background: var(--bd-sky); transform: rotate(45deg); }

/* Brand marquee ticker between section groups */
.menu-ticker {
  background: var(--bd-pink);
  color: #fff;
  padding: 1rem 0;
  overflow: hidden;
  border-top: 2px solid rgba(0,0,0,0.05);
  border-bottom: 2px solid rgba(0,0,0,0.05);
}
.menu-ticker.alt { background: var(--bd-dark); color: #fff; }
.menu-ticker .track {
  display: inline-flex;
  white-space: nowrap;
  font-family: "Kanit", sans-serif;
  font-weight: 900;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-size: 13px;
  width: max-content;
  animation: marquee 32s linear infinite;
  align-items: center;
}
.menu-ticker .track > span { padding: 0 1.4rem; }
.menu-ticker .track .star {
  color: rgba(255,255,255,0.5);
  padding: 0 0.4rem;
}
.menu-ticker.alt .track .star { color: var(--bd-pink); }

