/* =================================================================
   OTTO BURGER — Premium smoky-gourmet design system
   Visual direction: Urban premium burger · warm night glow
   Palette: charcoal/near-black · deep Otto green · warm gold/amber
   Type: Barlow Condensed/Bebas Neue (display) · Outfit (body)
   ================================================================= */

/* ---------- Design tokens ---------- */
:root {
  /* surfaces */
  --bg: #0c0e0c;
  --bg-2: #10130f;
  --surface: #14180f00; /* unused placeholder kept transparent */
  --card: #15180f;
  --card: #161a12;
  --card-2: #1c2117;

  /* brand */
  --green-deep: #0e2419;
  --green: #1c4435;
  --green-bright: #2e6b52;
  --gold: #c9a24a;
  --gold-bright: #e6c167;
  --amber: #d98a36;

  /* text */
  --fg: #f4f0e7;
  --fg-muted: #b3ac9b;
  --fg-dim: #837e71;
  --on-gold: #1a1407;

  /* lines */
  --border: rgba(201, 162, 74, 0.18);
  --border-soft: rgba(244, 240, 231, 0.08);
  --hairline: rgba(244, 240, 231, 0.1);

  /* effects */
  --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.35);
  --shadow: 0 18px 50px -18px rgba(0, 0, 0, 0.75);
  --shadow-gold: 0 22px 60px -24px rgba(201, 162, 74, 0.35);
  --glow-gold:
    0 0 0 1px rgba(201, 162, 74, 0.35), 0 0 28px rgba(201, 162, 74, 0.18);

  /* rhythm */
  --container: 1240px;
  --radius: 18px;
  --radius-sm: 12px;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --dur: 0.45s;

  --font-display: "Barlow Condensed", "Arial Narrow", system-ui, sans-serif;
  --font-hero:
    "Bebas Neue", "Barlow Condensed", "Arial Narrow", system-ui, sans-serif;
  --font-body: "Outfit", system-ui, -apple-system, Segoe UI, sans-serif;
}

/* ---------- Reset ---------- */
*,
*::before,
*::after {
  box-sizing: border-box;
}
* {
  margin: 0;
}
html {
  scroll-behavior: smooth;
  scroll-padding-top: 112px;
  -webkit-text-size-adjust: 100%;
  /* clip horizontal overflow at the scroll root too — body-only overflow-x
     is ignored by iOS Safari, which scrolls <html>. `clip` clips reliably
     without creating a scroll container (so position:fixed/sticky still work). */
  overflow-x: clip;
}
@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
}

body {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--fg);
  line-height: 1.6;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: clip;
}

/* warm vignette + film grain over the whole page */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background:
    radial-gradient(
      120% 80% at 50% -10%,
      rgba(201, 162, 74, 0.06),
      transparent 55%
    ),
    radial-gradient(
      100% 60% at 100% 0%,
      rgba(46, 107, 82, 0.07),
      transparent 60%
    );
}
body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 2;
  opacity: 0.035;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

img {
  display: block;
  max-width: 100%;
  height: auto;
}
a {
  color: inherit;
  text-decoration: none;
}
button {
  font-family: inherit;
  cursor: pointer;
}
:focus-visible {
  outline: 2px solid var(--gold-bright);
  outline-offset: 3px;
  border-radius: 4px;
}
.skip-link {
  position: fixed;
  left: 18px;
  top: 14px;
  z-index: 200;
  transform: translateY(-140%);
  padding: 10px 14px;
  border: 1px solid var(--gold);
  border-radius: 10px;
  background: rgba(8, 10, 8, 0.94);
  color: var(--fg);
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  transition: transform 0.25s var(--ease);
}
.skip-link:focus {
  transform: translateY(0);
}

/* ---------- Type ---------- */
h1,
h2,
h3,
.display {
  font-family: var(--font-display);
  font-weight: 700;
  line-height: 0.96;
  letter-spacing: 0.01em;
  text-transform: uppercase;
}
.eyebrow {
  font-family: var(--font-display);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.32em;
  font-size: 0.82rem;
  color: var(--gold);
  display: inline-flex;
  align-items: center;
  gap: 0.7em;
}
.eyebrow::before {
  content: "";
  width: 30px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold));
}
.eyebrow.center {
  justify-content: center;
}
.eyebrow.center::after {
  content: "";
  width: 30px;
  height: 1px;
  background: linear-gradient(90deg, var(--gold), transparent);
}

.gold {
  color: var(--gold);
}
.section-title {
  font-size: clamp(2.4rem, 6vw, 4.6rem);
  margin-top: 0.35em;
}
.lead {
  color: var(--fg-muted);
  font-size: 1.075rem;
  max-width: 56ch;
}

/* tabular numerals for prices */
.num {
  font-variant-numeric: tabular-nums;
}

/* ---------- Layout ---------- */
.container {
  width: 100%;
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: clamp(20px, 5vw, 48px);
  position: relative;
  z-index: 3;
}
.section {
  padding-block: clamp(72px, 11vw, 140px);
  position: relative;
  scroll-margin-top: 104px;
}
.section--tight {
  padding-block: clamp(48px, 7vw, 84px);
}
.section-head {
  max-width: 64ch;
}
.section-head.center {
  margin-inline: auto;
  text-align: center;
}
.section--snacks,
.section--craft,
.section--story,
.section--gallery,
.section--reviews,
.section--visit {
  overflow: clip;
  isolation: isolate;
}
/* A faded brand photo pools under the light for material/texture. The radial
   mask keeps it as a soft pool of grain, not a full rectangle of noise. */
.section--snacks::before,
.section--craft::before,
.section--story::before,
.section--gallery::before,
.section--reviews::before,
.section--visit::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  opacity: 0.07;
  filter: saturate(0.7) contrast(1.05) blur(16px);
  transform: scale(1.06);
  mask-image: radial-gradient(120% 100% at 50% 38%, #000 28%, transparent 80%);
  -webkit-mask-image: radial-gradient(
    120% 100% at 50% 38%,
    #000 28%,
    transparent 80%
  );
}
/* Editorial gold seam at the top boundary of each lit section — structure,
   not a tiled texture. Replaces the generic grid overlay. */
.section--snacks::after,
.section--craft::after,
.section--story::after,
.section--gallery::after,
.section--reviews::after,
.section--visit::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 1px;
  z-index: 2;
  pointer-events: none;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(201, 162, 74, 0.32) 22%,
    rgba(230, 193, 103, 0.6) 50%,
    rgba(201, 162, 74, 0.32) 78%,
    transparent
  );
}

/* Each section lit by its own two soft sources (warm gold + deep green),
   placed differently per section so the eye reads depth — a room with
   lighting, not a flat field. */
.section--snacks {
  background:
    radial-gradient(
      64% 52% at 16% 8%,
      rgba(201, 162, 74, 0.11),
      transparent 60%
    ),
    radial-gradient(
      58% 58% at 90% 96%,
      rgba(46, 107, 82, 0.13),
      transparent 62%
    ),
    linear-gradient(180deg, var(--bg), #0b100c 56%, var(--bg));
}
.section--craft {
  background:
    radial-gradient(
      60% 56% at 88% 6%,
      rgba(201, 162, 74, 0.1),
      transparent 58%
    ),
    radial-gradient(
      66% 60% at 6% 92%,
      rgba(46, 107, 82, 0.14),
      transparent 62%
    ),
    linear-gradient(180deg, #0a0d0b, #11150f 46%, #0a0d0b);
}
.section--story {
  background:
    radial-gradient(
      58% 70% at 96% 50%,
      rgba(217, 138, 54, 0.1),
      transparent 56%
    ),
    radial-gradient(
      56% 64% at 2% 30%,
      rgba(46, 107, 82, 0.12),
      transparent 60%
    ),
    linear-gradient(180deg, #0b0d0b, #10140f);
}
.section--gallery {
  background:
    radial-gradient(
      72% 46% at 50% -6%,
      rgba(201, 162, 74, 0.1),
      transparent 60%
    ),
    radial-gradient(
      60% 60% at 86% 104%,
      rgba(46, 107, 82, 0.1),
      transparent 64%
    ),
    linear-gradient(180deg, var(--bg-2), #0b0f0c);
}
.section--reviews {
  background:
    radial-gradient(58% 52% at 8% 6%, rgba(46, 107, 82, 0.13), transparent 60%),
    radial-gradient(
      62% 58% at 94% 94%,
      rgba(201, 162, 74, 0.1),
      transparent 60%
    ),
    linear-gradient(180deg, #0a0d0b, #0d110d);
}
.section--visit {
  background:
    radial-gradient(
      82% 56% at 50% 110%,
      rgba(217, 138, 54, 0.12),
      transparent 62%
    ),
    radial-gradient(54% 60% at 6% 4%, rgba(46, 107, 82, 0.11), transparent 60%),
    linear-gradient(180deg, #0b0d0b, #080a08);
}
.section--snacks::before {
  background-image: url("../img/card2.webp");
  background-position: center 42%;
}
.section--craft::before {
  background-image: url("../img/prepare_food.webp");
  background-position: center 40%;
}
.section--story::before {
  background-image: url("../img/chef.webp");
  background-position: 72% center;
}
.section--gallery::before {
  background-image: url("../img/reception.webp");
}
.section--reviews::before {
  background-image: url("../img/outside.webp");
  background-position: center 30%;
}
.section--visit::before {
  background-image: url("../img/outside.webp");
  background-position: center bottom;
}

/* ---------- Buttons ---------- */
.btn {
  --bg-btn: var(--gold);
  position: relative;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.6em;
  font-family: var(--font-display);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 1.02rem;
  padding: 0.95em 1.7em;
  border-radius: 100px;
  border: 1px solid transparent;
  background: var(--bg-btn);
  color: var(--on-gold);
  min-height: 52px;
  line-height: 1;
  transform: translate(var(--magx, 0px), var(--magy, 0px));
  transition:
    transform 0.5s var(--ease),
    box-shadow var(--dur) var(--ease),
    background-color var(--dur) var(--ease),
    color var(--dur) var(--ease);
  will-change: transform;
}
.btn::after,
.sauce-cta::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0;
  background: radial-gradient(
    180px circle at var(--mx, 50%) var(--my, 50%),
    rgba(255, 244, 202, 0.34),
    transparent 48%
  );
  transition: opacity 0.28s var(--ease);
}
.btn:hover::after,
.sauce-cta:hover::after {
  opacity: 0.72;
}
.btn:hover {
  box-shadow: var(--shadow-gold);
  background: var(--gold-bright);
}
.btn:active {
  transform: translate(var(--magx, 0px), var(--magy, 0px)) scale(0.97);
}
/* Coarse-pointer / no-JS fallback: keep a real hover lift since magnetism never engages */
@media (hover: hover) and (pointer: coarse) {
  .btn:hover {
    transform: translateY(-3px);
  }
}
.btn--ghost {
  background: transparent;
  color: var(--fg);
  border-color: var(--border);
}
.btn--ghost:hover {
  background: rgba(201, 162, 74, 0.08);
  border-color: var(--gold);
  color: var(--fg);
  box-shadow: none;
}
.btn svg {
  width: 20px;
  height: 20px;
}

/* ============================================================
   PREMIUM BRUSHED-GOLD CTA  (isolated — never reuses .btn)
   A polished gold metal plaque: beveled gold frame, thin dark
   channel, brushed-gold face (real texture), deep shadow + glow.
   Frame is a gradient border drawn with background-clip so it
   stays beveled AND respects the rounded corners. No inner outline.
   Size via the .premium-gold-btn--nav / --hero modifiers.
   ============================================================ */
.premium-gold-btn {
  position: relative;
  isolation: isolate;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4em;
  text-align: center;
  text-decoration: none;
  /* the transparent border is the gold FRAME area, painted below */
  border: 3px solid transparent;
  border-radius: 16px;
  /* sizing defaults — overridden by --nav / --hero */
  min-height: 56px;
  padding: 0 28px;
  /* dark engraved text on bright gold */
  color: #1b1206;
  font-family: var(--font-display);
  font-weight: 600;
  line-height: 1;
  text-transform: uppercase;
  white-space: nowrap;
  letter-spacing: 0.14em;
  /* Layered fills:
     1) face bevel sheen (lit top, shaded bottom)
     2) real brushed-gold texture (btn_textture.png, optimized)
     3) face base gold
     -> all clipped to the padding box (the FACE)
     4) beveled gold FRAME gradient -> clipped to the border box  */
  background:
    linear-gradient(
      180deg,
      rgba(255, 250, 224, 0.32) 0%,
      rgba(255, 248, 214, 0) 22%,
      rgba(0, 0, 0, 0) 60%,
      rgba(74, 48, 9, 0.3) 100%
    ),
    url("../img/btn-gold-texture.webp") center / cover no-repeat,
    linear-gradient(180deg, #e3c069, #b88c34),
    linear-gradient(180deg, #f7e1a0 0%, #e0bb60 36%, #bf8e2f 72%, #d8b457 100%);
  background-origin: padding-box, padding-box, padding-box, border-box;
  background-clip: padding-box, padding-box, padding-box, border-box;
  box-shadow:
    /* thin dark channel between frame and face */
    inset 0 0 0 1px rgba(38, 24, 5, 0.78),
    /* face top highlight just inside the channel */ inset 0 2px 1px
      rgba(255, 250, 225, 0.55),
    /* hairline dark seat outlining the frame */ 0 0 0 1px rgba(45, 29, 7, 0.8),
    /* deep drop shadow */ 0 16px 34px rgba(0, 0, 0, 0.6),
    /* subtle warm glow */ 0 0 24px rgba(214, 170, 70, 0.22);
  transform: translateZ(0);
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease,
    filter 0.2s ease;
}
/* ::before — gold light sweep / sheen across the face (accent + hover) */
.premium-gold-btn::before {
  content: "";
  position: absolute;
  inset: 0; /* relative to the padding box = the face only */
  z-index: 0;
  border-radius: 13px;
  pointer-events: none;
  background: linear-gradient(
    105deg,
    rgba(255, 255, 255, 0) 30%,
    rgba(255, 252, 232, 0.42) 47%,
    rgba(255, 255, 255, 0) 64%
  );
  background-size: 220% 100%;
  background-position: 120% 0;
  opacity: 0.5;
  mix-blend-mode: screen;
  transition:
    background-position 0.55s var(--ease),
    opacity 0.3s ease;
}
.premium-gold-btn__text {
  position: relative;
  z-index: 1;
  /* engraved relief */
  text-shadow:
    0 1px 0 rgba(255, 248, 214, 0.45),
    0 -1px 0 rgba(58, 36, 6, 0.22);
}
.premium-gold-btn svg {
  position: relative;
  z-index: 1;
  width: 20px;
  height: 20px;
}
.premium-gold-btn__icon {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  font-family: "Barlow Condensed", system-ui, sans-serif;
  font-weight: 300;
  line-height: 0.7;
  color: #1b1206;
  transform: translateY(-2px);
  transition: transform 0.2s ease;
}
.premium-gold-btn:hover {
  transform: translateY(-2px);
  filter: brightness(1.06) saturate(1.04);
  box-shadow:
    inset 0 0 0 1px rgba(38, 24, 5, 0.78),
    inset 0 2px 1px rgba(255, 252, 232, 0.65),
    0 0 0 1px rgba(45, 29, 7, 0.8),
    0 20px 40px rgba(0, 0, 0, 0.6),
    /* big soft warm glow halo (reference hover state) */ 0 0 48px 5px
      rgba(240, 196, 86, 0.55);
}
.premium-gold-btn:hover::before {
  background-position: -20% 0;
  opacity: 0.85;
}
.premium-gold-btn:hover .premium-gold-btn__icon {
  transform: translate(4px, -2px);
}
.premium-gold-btn:active {
  transform: translateY(0);
  filter: brightness(0.99);
}

/* ---- Size variant: small header CTA ---- */
.premium-gold-btn--nav {
  border-width: 2.5px;
  min-height: 46px;
  padding: 0 22px;
  border-radius: 12px;
  font-size: 1.02rem;
  font-weight: 600;
  letter-spacing: 0.12em;
}
.premium-gold-btn--nav::before {
  border-radius: 10px;
}

/* ---- Size variant: hero CTA — matched to the adjacent .btn--ghost size ---- */
.premium-gold-btn--hero {
  border-width: 3px;
  min-height: 52px;
  padding: 0 28px;
  gap: 0.5em;
  border-radius: 14px;
  font-size: 1.02rem;
  font-weight: 600;
  letter-spacing: 0.12em;
}
.premium-gold-btn--hero::before {
  border-radius: 12px;
}
.premium-gold-btn--hero .premium-gold-btn__icon {
  font-size: 1.55em;
  transform: translateY(-3px);
}

@media (max-width: 640px) {
  .premium-gold-btn--hero {
    width: 100%;
    min-height: 48px;
    padding: 0 22px;
    font-size: 0.95rem;
    letter-spacing: 0.1em;
  }
  .hero__actions .btn--ghost {
    width: 100%;
    min-height: 48px;
    padding: 0 22px;
    background: transparent;
    border: 1px solid rgba(232, 212, 154, 0.5);
    border-radius: 12px;
    color: #f3e9cf;
    font-size: 0.95rem;
    letter-spacing: 0.1em;
  }
  .hero__actions .btn--ghost svg {
    width: 16px;
    height: 16px;
  }
  /* Story + final-CTA use the smaller --nav gold button inside .hero__actions.
     Match it to the full-width ghost buttons so the stacked group is uniform
     (otherwise a narrow gold pill sits beside full-width bars). */
  .hero__actions .premium-gold-btn--nav {
    width: 100%;
    min-height: 48px;
  }
}

/* ============================================================
   GOLD MENU BUTTON — layered frame (nested spans, no fake border)
   Frame layers: outer glow · dark rim · gold stroke · inner dark line
   ============================================================ */
.gold-menu-btn {
  position: relative;
  display: inline-block;
  width: clamp(300px, 56vw, 760px);
  text-decoration: none;
  border-radius: 42px;
  filter: drop-shadow(0 18px 38px rgba(0, 0, 0, 0.65));
  transition:
    transform 220ms ease,
    filter 220ms ease;
}

.gold-menu-btn::before {
  content: "";
  position: absolute;
  inset: -14px;
  border-radius: 52px;
  background: radial-gradient(
    ellipse at center,
    rgba(255, 194, 58, 0.55) 0%,
    rgba(255, 166, 24, 0.28) 34%,
    rgba(255, 166, 24, 0.08) 58%,
    transparent 74%
  );
  opacity: 0;
  filter: blur(10px);
  transition: opacity 220ms ease;
  pointer-events: none;
}

.gold-menu-btn__rim {
  position: relative;
  display: block;
  padding: 8px;
  border-radius: 42px;

  background: linear-gradient(180deg, #ffe486 0%, #d69628 45%, #7a4308 100%);

  box-shadow:
    0 0 0 6px #050403,
    0 0 0 9px rgba(229, 169, 54, 0.96),
    inset 0 1px 0 rgba(255, 245, 184, 0.8),
    inset 0 -2px 0 rgba(80, 39, 0, 0.55);
}

.gold-menu-btn__surface {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;

  min-height: clamp(78px, 8vw, 116px);
  padding: clamp(20px, 3vw, 32px) clamp(34px, 6vw, 84px);

  border-radius: 32px;
  overflow: hidden;

  background:
    linear-gradient(
      180deg,
      rgba(255, 241, 167, 0.68) 0%,
      rgba(238, 176, 54, 0.42) 32%,
      rgba(157, 91, 13, 0.22) 56%,
      rgba(255, 203, 73, 0.46) 100%
    ),
    radial-gradient(
      ellipse at 50% 12%,
      rgba(255, 255, 220, 0.48) 0%,
      rgba(255, 224, 116, 0.22) 34%,
      transparent 70%
    ),
    url("../img/btn-gold-texture.webp");

  background-size: cover;
  background-position: center;
  background-blend-mode: screen, soft-light, normal;

  box-shadow:
    inset 0 2px 0 rgba(255, 248, 205, 0.72),
    inset 0 -8px 18px rgba(83, 44, 4, 0.32),
    inset 0 0 28px rgba(255, 214, 91, 0.18);
}

.gold-menu-btn__inner-line {
  position: absolute;
  inset: 10px;
  border-radius: 24px;
  border: 2px solid rgba(10, 7, 3, 0.86);

  box-shadow:
    inset 0 1px 0 rgba(255, 231, 135, 0.28),
    0 1px 0 rgba(255, 217, 96, 0.32);

  pointer-events: none;
  z-index: 2;
}

.gold-menu-btn__surface::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;

  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(255, 255, 255, 0.1) 36%,
    rgba(255, 255, 255, 0.36) 50%,
    rgba(255, 255, 255, 0.12) 64%,
    transparent 100%
  );

  opacity: 0.35;
  mix-blend-mode: soft-light;
  pointer-events: none;
  z-index: 1;
}

.gold-menu-btn__label {
  position: relative;
  z-index: 3;

  font-family: "Barlow Condensed", "Arial Narrow", sans-serif;
  font-size: clamp(42px, 6.2vw, 78px);
  font-weight: 800;
  line-height: 0.9;
  letter-spacing: 0.045em;
  text-transform: uppercase;

  color: #0b0804;

  text-shadow:
    0 1px 0 rgba(255, 235, 155, 0.32),
    0 -1px 0 rgba(0, 0, 0, 0.28);
}

.gold-menu-btn:hover {
  transform: translateY(-2px);
  filter: drop-shadow(0 20px 42px rgba(0, 0, 0, 0.72)) brightness(1.06)
    saturate(1.12);
}

.gold-menu-btn:hover::before {
  opacity: 1;
}

.gold-menu-btn:hover .gold-menu-btn__rim {
  box-shadow:
    0 0 0 6px #050403,
    0 0 0 9px rgba(255, 198, 66, 1),
    0 0 24px rgba(255, 186, 48, 0.72),
    0 0 70px rgba(255, 144, 18, 0.38),
    inset 0 1px 0 rgba(255, 245, 184, 0.9),
    inset 0 -2px 0 rgba(80, 39, 0, 0.48);
}

.gold-menu-btn:hover .gold-menu-btn__surface::before {
  opacity: 0.58;
}

@media (max-width: 640px) {
  .gold-menu-btn {
    width: min(100%, 420px);
    border-radius: 30px;
  }

  .gold-menu-btn__rim {
    padding: 6px;
    border-radius: 30px;

    box-shadow:
      0 0 0 5px #050403,
      0 0 0 7px rgba(229, 169, 54, 0.96),
      inset 0 1px 0 rgba(255, 245, 184, 0.8);
  }

  .gold-menu-btn__surface {
    min-height: 78px;
    padding: 20px 28px;
    border-radius: 24px;
  }

  .gold-menu-btn__inner-line {
    inset: 8px;
    border-radius: 18px;
  }

  .gold-menu-btn__label {
    font-size: clamp(38px, 13vw, 54px);
  }
}

/* ---------- Header / Nav ---------- */
.site-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 100;
  padding-block: 18px;
  transition:
    background-color 0.4s var(--ease),
    backdrop-filter 0.4s var(--ease),
    border-color 0.4s var(--ease),
    padding 0.4s var(--ease);
  border-bottom: 1px solid transparent;
}
.site-header.scrolled {
  background: rgba(10, 12, 10, 0.72);
  backdrop-filter: blur(14px) saturate(120%);
  -webkit-backdrop-filter: blur(14px) saturate(120%);
  border-bottom-color: var(--border-soft);
  padding-block: 11px;
}
.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: 11px;
}
.brand .mark {
  width: 38px;
  height: 38px;
  color: var(--gold);
  flex: none;
}
.brand .wordmark {
  font-family: var(--font-display);
  font-weight: 700;
  text-transform: uppercase;
  line-height: 0.9;
}
.brand .wordmark b {
  display: block;
  font-size: 1.32rem;
  letter-spacing: 0.04em;
}
.brand .wordmark span {
  display: block;
  font-size: 0.72rem;
  letter-spacing: 0.46em;
  color: var(--gold);
  font-weight: 600;
}

.nav-links {
  display: flex;
  align-items: center;
  gap: 30px;
  list-style: none;
}
.nav-links a {
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 1rem;
  font-weight: 500;
  color: var(--fg-muted);
  position: relative;
  padding: 6px 0;
  transition: color 0.3s var(--ease);
}
.nav-links a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  height: 2px;
  width: 0;
  background: var(--gold);
  transition: width 0.35s var(--ease);
}
.nav-links a:hover,
.nav-links a[aria-current="page"] {
  color: var(--fg);
}
.nav-links a:hover::after,
.nav-links a[aria-current="page"]::after {
  width: 100%;
}
.nav-cta {
  display: flex;
  align-items: center;
  gap: 14px;
}
.nav-phone {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--fg);
}
.nav-phone svg {
  width: 18px;
  height: 18px;
  color: var(--gold);
}

.nav-toggle {
  display: none;
  width: 46px;
  height: 46px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.02);
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 5px;
}
.nav-toggle span {
  display: block;
  width: 20px;
  height: 2px;
  background: var(--fg);
  border-radius: 2px;
  transition:
    transform 0.35s var(--ease),
    opacity 0.25s var(--ease);
}
body.menu-open .nav-toggle span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
body.menu-open .nav-toggle span:nth-child(2) {
  opacity: 0;
}
body.menu-open .nav-toggle span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* mobile drawer */
.mobile-nav {
  position: fixed;
  inset: 0;
  z-index: 99;
  background: rgba(8, 10, 8, 0.97);
  backdrop-filter: blur(8px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 6px;
  padding: 96px clamp(24px, 8vw, 56px) 48px;
  transform: translateY(-100%);
  opacity: 0;
  visibility: hidden;
  transition:
    transform 0.5s var(--ease),
    opacity 0.4s var(--ease),
    visibility 0.4s;
}
body.menu-open .mobile-nav {
  transform: translateY(0);
  opacity: 1;
  visibility: visible;
}
.mobile-nav a {
  font-family: var(--font-display);
  text-transform: uppercase;
  font-size: clamp(2rem, 9vw, 3rem);
  letter-spacing: 0.02em;
  color: var(--fg);
  padding: 10px 0;
  border-bottom: 1px solid var(--border-soft);
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.mobile-nav a .gold {
  font-size: 0.9rem;
}
.mobile-nav .btn,
.mobile-nav .premium-gold-btn {
  margin-top: 28px;
}

/* ============================================================
   HERO — full bleed
   ============================================================ */
.hero {
  position: relative;
  z-index: 3;
  min-height: 100vh;
  min-height: 100svh;
  display: flex;
  align-items: flex-end;
  overflow: clip;
}
.hero__media {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 60% 50%;
}
.hero__media::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(
      90deg,
      rgba(8, 9, 8, 0.82) 0%,
      rgba(8, 9, 8, 0.5) 34%,
      rgba(8, 9, 8, 0) 66%
    ),
    linear-gradient(
      0deg,
      rgba(8, 9, 8, 0.8) 0%,
      rgba(8, 9, 8, 0.32) 24%,
      rgba(8, 9, 8, 0) 52%
    );
}
.hero__inner {
  position: relative;
  z-index: 3;
  padding-bottom: clamp(56px, 9vw, 104px);
  padding-top: 120px;
  width: 100%;
}
.hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 16px;
  border: 1px solid var(--border);
  border-radius: 100px;
  background: rgba(14, 16, 14, 0.5);
  backdrop-filter: blur(6px);
  font-size: 0.85rem;
  color: var(--fg-muted);
  margin-bottom: 26px;
}
.hero__badge .stars {
  color: var(--gold);
  letter-spacing: 2px;
}
.hero__badge b {
  color: var(--fg);
}
.hero h1 {
  font-family: "Bebas Neue", sans-serif;
  font-weight: 400;
  letter-spacing: 0;
  line-height: 0.9;
  font-size: clamp(3.3rem, 11vw, 8.2rem);
  max-width: 14ch;
  text-shadow: 0 2px 40px rgba(0, 0, 0, 0.5);
}
.hero h1 .gold {
  color: var(--gold-bright);
}
.hero__sub {
  margin-top: 22px;
  font-size: clamp(1.05rem, 2.4vw, 1.3rem);
  color: var(--fg-muted);
  max-width: 46ch;
}
.hero__actions {
  margin-top: 36px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 14px;
}
.hero__scroll {
  position: absolute;
  left: 50%;
  bottom: 26px;
  transform: translateX(-50%);
  z-index: 3;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.25em;
  font-size: 0.72rem;
  color: var(--fg-muted);
}
.hero__scroll .line {
  width: 1px;
  height: 42px;
  background: linear-gradient(var(--gold), transparent);
  position: relative;
  overflow: hidden;
}
.hero__scroll .line::after {
  content: "";
  position: absolute;
  top: -50%;
  left: 0;
  width: 100%;
  height: 50%;
  background: var(--gold-bright);
  animation: scrolldot 1.8s var(--ease) infinite;
}
@keyframes scrolldot {
  0% {
    transform: translateY(0);
  }
  100% {
    transform: translateY(200%);
  }
}

/* ============================================================
   MARQUEE / trust strip
   ============================================================ */
.marquee {
  border-block: 1px solid var(--border-soft);
  background: linear-gradient(
    180deg,
    rgba(28, 68, 53, 0.18),
    rgba(12, 14, 12, 0)
  );
  overflow: hidden;
  padding-block: 18px;
}
.marquee__track {
  display: flex;
  gap: 56px;
  width: max-content;
  animation: marquee 38s linear infinite;
}
.marquee:hover .marquee__track {
  animation-play-state: paused;
}
.marquee__item {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 1.15rem;
  color: var(--fg-muted);
  white-space: nowrap;
}
.marquee__item .dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--gold);
  flex: none;
}
@keyframes marquee {
  to {
    transform: translateX(-50%);
  }
}

/* ============================================================
   STATS
   ============================================================ */
.stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border-soft);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius);
  overflow: hidden;
}
.stat {
  background: linear-gradient(180deg, var(--card), var(--bg-2));
  padding: 32px 26px;
  text-align: center;
}
.stat b {
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 5vw, 3.4rem);
  color: var(--gold);
  display: block;
  line-height: 1;
}
.stat span {
  display: block;
  margin-top: 10px;
  font-size: 0.82rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-muted);
}

/* ============================================================
   SIGNATURE CARDS
   ============================================================ */
.cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 26px;
  margin-top: 56px;
}
.card {
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--card);
  border: 1px solid var(--border-soft);
  transform: perspective(1100px) rotateX(var(--ry, 0deg))
    rotateY(var(--rx, 0deg)) translateY(var(--lift, 0px));
  transform-style: preserve-3d;
  transition:
    transform var(--dur) var(--ease),
    border-color var(--dur) var(--ease),
    box-shadow var(--dur) var(--ease);
  display: flex;
  flex-direction: column;
}
.card::before,
.review-card::before,
.reviews__top::before,
.visit__map::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  opacity: 0;
  background: radial-gradient(
    360px circle at var(--mx, 50%) var(--my, 50%),
    rgba(230, 193, 103, 0.16),
    transparent 44%
  );
  transition: opacity 0.35s var(--ease);
}
.card:hover::before,
.review-card:hover::before,
.reviews__top:hover::before,
.visit__map:hover::before {
  opacity: 1;
}
.card > * {
  position: relative;
  z-index: 2;
}
.card:hover {
  --lift: -8px;
  border-color: var(--border);
  box-shadow: var(--shadow);
}
.card__media {
  position: relative;
  aspect-ratio: 4/3;
  overflow: hidden;
}
.card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition:
    transform 0.8s var(--ease),
    filter 0.8s var(--ease);
}
.card:hover .card__media img {
  transform: scale(1.07) translate3d(var(--px, 0), var(--py, 0), 0);
  filter: saturate(1.08) contrast(1.04);
}
.card__rank {
  position: absolute;
  top: 14px;
  left: 14px;
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: rgba(10, 12, 10, 0.7);
  backdrop-filter: blur(6px);
  border: 1px solid var(--border);
  font-family: var(--font-display);
  font-weight: 700;
  color: var(--gold);
}
.card__price {
  position: absolute;
  bottom: 14px;
  right: 14px;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.35rem;
  color: var(--fg);
  background: rgba(10, 12, 10, 0.72);
  backdrop-filter: blur(6px);
  padding: 6px 14px;
  border-radius: 100px;
  border: 1px solid var(--border);
}
.card__body {
  padding: 22px 22px 26px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}
.card__body h3 {
  font-size: 1.85rem;
}
.card__body p {
  color: var(--fg-muted);
  font-size: 0.95rem;
  line-height: 1.5;
}
.card__tag {
  align-self: flex-start;
  margin-top: auto;
  padding-top: 14px;
  font-size: 0.76rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--gold);
  font-family: var(--font-display);
}

/* ============================================================
   SPLIT (why / story)
   ============================================================ */
.split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 5vw, 72px);
  align-items: center;
}
.split--rev .split__media {
  order: 2;
}
.split__media {
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
}
.split__media::after {
  content: "";
  position: absolute;
  inset: 0;
  box-shadow: inset 0 0 0 1px var(--border-soft);
  border-radius: var(--radius);
}
.split__media img {
  width: 100%;
  aspect-ratio: 4/5;
  object-fit: cover;
  transition:
    transform 0.9s var(--ease),
    filter 0.9s var(--ease);
}
.split__media:hover img {
  transform: scale(1.035) translate3d(var(--px, 0), var(--py, 0), 0);
  filter: saturate(1.06) contrast(1.04);
}
.split__media--wide img {
  aspect-ratio: 5/4;
}
.feature-list {
  list-style: none;
  margin-top: 32px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.feature-list li {
  display: flex;
  gap: 16px;
}
.feature-list .ic {
  flex: none;
  width: 46px;
  height: 46px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: linear-gradient(180deg, var(--green), var(--green-deep));
  border: 1px solid var(--border);
  color: var(--gold-bright);
}
.feature-list .ic svg {
  width: 22px;
  height: 22px;
}
.feature-list h4 {
  font-family: var(--font-display);
  font-size: 1.3rem;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}
.feature-list p {
  color: var(--fg-muted);
  font-size: 0.95rem;
  margin-top: 2px;
}

/* floating accent chip on media */
.media-chip {
  position: absolute;
  left: 22px;
  bottom: 22px;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  border-radius: 14px;
  background: rgba(10, 12, 10, 0.78);
  backdrop-filter: blur(10px);
  border: 1px solid var(--border);
}
.media-chip b {
  font-family: var(--font-display);
  font-size: 1.5rem;
  color: var(--gold);
  line-height: 1;
}
.media-chip span {
  font-size: 0.8rem;
  color: var(--fg-muted);
}

/* ============================================================
   MENU PREVIEW
   ============================================================ */
.menu-preview {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px 48px;
  margin-top: 48px;
}
.mp-col h3 {
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--gold);
  font-size: 1rem;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border-soft);
}
.mp-row {
  display: flex;
  align-items: baseline;
  gap: 12px;
  padding: 11px 0;
  border-bottom: 1px dashed var(--border-soft);
}
.mp-row .name {
  font-family: var(--font-display);
  font-size: 1.32rem;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.mp-row .lead-dots {
  flex: 1;
  border-bottom: 1px dotted var(--hairline);
  transform: translateY(-4px);
}
.mp-row .price {
  font-family: var(--font-display);
  font-weight: 700;
  color: var(--gold);
  font-size: 1.2rem;
}
.mp-row .desc {
  display: block;
  color: var(--fg-dim);
  font-size: 0.85rem;
  width: 100%;
  margin-top: -4px;
}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: 220px;
  gap: 14px;
  margin-top: 48px;
}
.gallery figure {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border-soft);
}
.gallery figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.9s var(--ease);
}
.gallery figure:hover img {
  transform: scale(1.08);
}
.gallery .span-2 {
  grid-column: span 2;
}
.gallery .row-2 {
  grid-row: span 2;
}
.gallery figcaption {
  position: absolute;
  inset: auto 0 0 0;
  padding: 16px;
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.9rem;
  background: linear-gradient(transparent, rgba(8, 10, 8, 0.85));
  opacity: 0;
  transform: translateY(8px);
  transition:
    opacity 0.4s var(--ease),
    transform 0.4s var(--ease);
}
.gallery figure:hover figcaption {
  opacity: 1;
  transform: translateY(0);
}

/* ============================================================
   VISIT
   ============================================================ */
.visit {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: clamp(28px, 4vw, 56px);
  align-items: stretch;
}
.visit__info {
  display: flex;
  flex-direction: column;
}
.info-rows {
  margin-top: 30px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.info-row {
  display: flex;
  gap: 18px;
  padding: 20px 0;
  border-bottom: 1px solid var(--border-soft);
}
.info-row .ic {
  flex: none;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  border: 1px solid var(--border);
  color: var(--gold-bright);
  background: rgba(201, 162, 74, 0.06);
}
.info-row .ic svg {
  width: 21px;
  height: 21px;
}
.info-row h4 {
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  font-size: 0.92rem;
  color: var(--fg-muted);
  margin-bottom: 4px;
}
.info-row p {
  color: var(--fg);
  font-size: 1.05rem;
}
.info-row .muted {
  color: var(--fg-dim);
  font-size: 0.9rem;
}
.hours-grid {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 4px 24px;
  font-size: 0.98rem;
}
.hours-grid dt {
  color: var(--fg-muted);
}
.hours-grid dd {
  text-align: right;
  color: var(--fg);
}
.hours-grid .today dt,
.hours-grid .today dd {
  color: var(--gold-bright);
  font-weight: 600;
}
.visit__map {
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--border);
  min-height: 420px;
  box-shadow: var(--shadow);
  background: var(--card);
}
.visit__map iframe {
  width: 100%;
  height: 100%;
  border: 0;
  filter: grayscale(0.3) contrast(1.05) brightness(0.92);
}
.visit__map::after {
  content: "40.2245 N / 28.9166 E";
  position: absolute;
  left: 18px;
  bottom: 18px;
  z-index: 2;
  padding: 8px 12px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: rgba(8, 10, 8, 0.7);
  backdrop-filter: blur(8px);
  font-family: var(--font-display);
  font-size: 0.8rem;
  letter-spacing: 0.12em;
  color: var(--gold-bright);
}
.order-out {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 26px;
}
.order-out a,
.order-out .order-link {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 12px 18px;
  border: 1px solid var(--border);
  border-radius: 100px;
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 0.95rem;
  color: var(--fg);
  transition:
    background-color 0.3s var(--ease),
    border-color 0.3s var(--ease),
    transform 0.3s var(--ease),
    opacity 0.3s var(--ease);
}
.order-out a:hover {
  background: rgba(201, 162, 74, 0.08);
  border-color: var(--gold);
  transform: translateY(-2px);
}
.order-out .is-disabled {
  color: var(--fg-dim);
  border-color: rgba(244, 240, 231, 0.055);
  cursor: not-allowed;
  opacity: 0.72;
}
.order-out .dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--green-bright);
}
.order-out .is-disabled .dot {
  background: rgba(131, 126, 113, 0.58);
}

/* ============================================================
   FINAL CTA
   ============================================================ */
.cta {
  position: relative;
  overflow: clip;
}
.cta__media {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.cta__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.cta__img--mobile {
  display: none;
}
.cta__media::after {
  content: none;
}
.cta__inner {
  position: relative;
  z-index: 3;
  padding-block: clamp(80px, 12vw, 150px);
}
.cta h2 {
  font-size: clamp(2.6rem, 7vw, 5.6rem);
  max-width: 18ch;
}
.cta p {
  color: var(--fg-muted);
  margin-top: 18px;
  max-width: 44ch;
  font-size: 1.1rem;
}
.cta .hero__actions {
  margin-top: 34px;
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer {
  border-top: 1px solid var(--border-soft);
  background: var(--bg-2);
  padding-block: 64px 36px;
}
.footer__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
  gap: 40px;
}
.footer h5 {
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.85rem;
  color: var(--gold);
  margin-bottom: 18px;
}
.footer ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 11px;
}
.footer a {
  color: var(--fg-muted);
  transition: color 0.3s var(--ease);
}
.footer a:hover {
  color: var(--fg);
}
.footer__about p {
  color: var(--fg-muted);
  margin-top: 18px;
  font-size: 0.95rem;
  max-width: 38ch;
}
.footer .brand {
  margin-bottom: 0;
}
.socials {
  display: flex;
  gap: 12px;
  margin-top: 20px;
}
.socials a {
  width: 42px;
  height: 42px;
  border: 1px solid var(--border);
  border-radius: 12px;
  display: grid;
  place-items: center;
  color: var(--fg);
  transition:
    background-color 0.3s,
    border-color 0.3s,
    transform 0.3s;
}
.socials a:hover {
  background: rgba(201, 162, 74, 0.08);
  border-color: var(--gold);
  transform: translateY(-2px);
  color: var(--gold-bright);
}
.socials svg {
  width: 20px;
  height: 20px;
}
.footer__bottom {
  margin-top: 48px;
  padding-top: 24px;
  border-top: 1px solid var(--border-soft);
  display: flex;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  color: var(--fg-dim);
  font-size: 0.85rem;
}

/* ============================================================
   MENU PAGE
   ============================================================ */
.page-hero {
  position: relative;
  padding-top: 150px;
  padding-bottom: 56px;
  overflow: clip;
  border-bottom: 1px solid var(--border-soft);
}
.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background: radial-gradient(
    80% 120% at 70% 0%,
    rgba(28, 68, 53, 0.28),
    transparent 60%
  );
}
.page-hero__inner {
  position: relative;
  z-index: 3;
}
.page-hero h1 {
  font-size: clamp(3rem, 9vw, 6.5rem);
}
.page-hero .lead {
  margin-top: 18px;
}
.menu-note {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 24px;
  padding: 10px 16px;
  border: 1px solid var(--border);
  border-radius: 100px;
  background: rgba(201, 162, 74, 0.06);
  color: var(--gold-bright);
  font-size: 0.9rem;
}
.menu-note svg {
  width: 18px;
  height: 18px;
}

.menu-cat {
  padding-block: clamp(40px, 6vw, 72px);
  border-bottom: 1px solid var(--border-soft);
}
.menu-cat__head {
  display: flex;
  align-items: baseline;
  gap: 18px;
  margin-bottom: 34px;
}
.menu-cat__head .ic {
  width: 34px;
  height: 34px;
  color: var(--gold);
  flex: none;
}
.menu-cat__head h2 {
  font-size: clamp(2rem, 5vw, 3rem);
}
.menu-cat__head .count {
  margin-left: auto;
  font-family: var(--font-display);
  color: var(--fg-dim);
  letter-spacing: 0.1em;
}

.menu-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 6px 56px;
}
.menu-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 4px 16px;
  padding: 18px 0;
  border-bottom: 1px dashed var(--border-soft);
  align-items: baseline;
}
.menu-item__head {
  display: flex;
  align-items: baseline;
  gap: 12px;
  min-width: 0;
}
.menu-item__name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.55rem;
  text-transform: uppercase;
  letter-spacing: 0.015em;
}
.menu-item__dots {
  flex: 1;
  border-bottom: 1px dotted var(--hairline);
  transform: translateY(-5px);
  min-width: 18px;
}
.menu-item__price {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.4rem;
  color: var(--gold);
  white-space: nowrap;
}
.menu-item__desc {
  grid-column: 1 / -1;
  color: var(--fg-muted);
  font-size: 0.92rem;
  line-height: 1.45;
  max-width: 52ch;
}
.menu-item.is-signature .menu-item__name {
  color: var(--fg);
}
.menu-item__name .badge {
  display: inline-block;
  vertical-align: middle;
  margin-left: 8px;
  font-family: var(--font-body);
  font-size: 0.6rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gold-bright);
  border: 1px solid var(--border);
  border-radius: 100px;
  padding: 3px 8px;
  font-weight: 600;
}

.menu-meta {
  padding-block: 48px;
}
.menu-meta__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.meta-card {
  padding: 24px;
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-sm);
  background: var(--card);
  display: flex;
  gap: 14px;
}
.meta-card .ic {
  color: var(--gold-bright);
  flex: none;
}
.meta-card .ic svg {
  width: 24px;
  height: 24px;
}
.meta-card h4 {
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-size: 1.05rem;
  margin-bottom: 4px;
}
.meta-card p {
  color: var(--fg-muted);
  font-size: 0.9rem;
}

/* ============================================================
   Reveal animations
   ============================================================ */
/* Reveals are gated behind .js so no-JS users always see content */
.js [data-reveal] {
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity 0.7s var(--ease),
    transform 0.7s var(--ease);
  will-change: opacity, transform;
}
.js [data-reveal="left"] {
  transform: translateX(-32px);
}
.js [data-reveal="right"] {
  transform: translateX(32px);
}
.js [data-reveal].in {
  opacity: 1;
  transform: none;
}
.js [data-stagger] > * {
  opacity: 0;
  transform: translateY(24px);
  transition:
    opacity 0.6s var(--ease),
    transform 0.6s var(--ease);
}
.js [data-stagger].in > * {
  opacity: 1;
  transform: none;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .footer__grid {
    grid-template-columns: 1fr 1fr;
    gap: 36px;
  }
  .gallery {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 900px) {
  .nav-links,
  .nav-phone {
    display: none;
  }
  .nav-cta .premium-gold-btn {
    display: none;
  }
  .nav-toggle {
    display: flex;
  }
  .split {
    grid-template-columns: 1fr;
    gap: 36px;
  }
  .split--rev .split__media {
    order: 0;
  }
  .split__media img,
  .split__media--wide img {
    aspect-ratio: 16/10;
  }
  .visit {
    grid-template-columns: 1fr;
  }
  .visit__map {
    min-height: 340px;
  }
  .menu-preview {
    grid-template-columns: 1fr;
  }
  .menu-list {
    grid-template-columns: 1fr;
    gap: 2px;
  }
  .stats {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 720px) {
  body {
    font-size: 16px;
  }
  .cards-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .menu-meta__grid {
    grid-template-columns: 1fr;
  }
  .hero {
    min-height: 100svh;
  }
  .hero__media img {
    object-position: 58% 50%;
  }
  .hero__media::after {
    background:
      linear-gradient(
        90deg,
        rgba(8, 9, 8, 0.85) 0%,
        rgba(8, 9, 8, 0.55) 42%,
        rgba(8, 9, 8, 0) 82%
      ),
      linear-gradient(
        0deg,
        rgba(8, 9, 8, 0.86) 0%,
        rgba(8, 9, 8, 0.4) 26%,
        rgba(8, 9, 8, 0) 54%
      );
  }
  .hero__scroll {
    display: none;
  }
  .hero__inner {
    padding-bottom: clamp(104px, 26vw, 168px);
  }
  .hero__sub {
    max-width: 300px;
    line-height: 1.65;
    color: rgba(255, 255, 255, 0.78);
  }
  .gallery {
    grid-auto-rows: 170px;
  }
  .footer__grid {
    grid-template-columns: 1fr;
  }
  .cta__img--desktop {
    display: none;
  }
  .cta__img--mobile {
    display: block;
  }
}
@media (max-width: 480px) {
  .gallery {
    grid-template-columns: 1fr;
    grid-auto-rows: 200px;
  }
  .gallery .span-2 {
    grid-column: span 1;
  }
  .stats {
    grid-template-columns: 1fr 1fr;
  }
}

/* ============================================================
   Reduced motion
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }
  .marquee__track {
    animation: none;
  }
  [data-reveal],
  [data-stagger] > * {
    opacity: 1 !important;
    transform: none !important;
  }
  .hero__scroll .line::after {
    display: none;
  }
}

/* ============================================================
   ADDITIONS — burger pills, sauces band, snacks, IG, reviews
   ============================================================ */

/* 4-up card grid variant (snacks) */
.cards-grid--4 {
  grid-template-columns: repeat(4, 1fr);
}
.card--compact .card__media {
  aspect-ratio: 1/1;
}
.card--compact .card__body {
  padding: 18px 18px 22px;
}
.card--compact .card__body h3 {
  font-size: 1.5rem;
}

/* "other burgers" pills */
.burger-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
  margin-top: 40px;
}
.burger-pills a {
  display: inline-flex;
  align-items: baseline;
  gap: 10px;
  padding: 11px 18px;
  border: 1px solid var(--border);
  border-radius: 100px;
  background: rgba(255, 255, 255, 0.02);
  transition:
    background-color 0.3s var(--ease),
    border-color 0.3s var(--ease),
    transform 0.3s var(--ease);
}
.burger-pills a:hover {
  background: rgba(201, 162, 74, 0.08);
  border-color: var(--gold);
  transform: translateY(-2px);
}
.burger-pills .pn {
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 1.1rem;
}
.burger-pills .pp {
  font-family: var(--font-display);
  color: var(--gold);
  font-weight: 700;
}

/* ---------- SAUCES band (brand differentiation) ---------- */
.soslar {
  position: relative;
  overflow: clip;
  background:
    radial-gradient(90% 120% at 0% 0%, rgba(28, 68, 53, 0.5), transparent 55%),
    radial-gradient(
      80% 120% at 100% 100%,
      rgba(201, 162, 74, 0.1),
      transparent 60%
    ),
    linear-gradient(180deg, var(--green-deep), var(--bg));
  border-block: 1px solid var(--border-soft);
}
.soslar__grid {
  display: grid;
  grid-template-columns: minmax(340px, 0.82fr) minmax(0, 1.28fr);
  gap: clamp(22px, 3vw, 36px);
  align-items: stretch;
  margin-top: 48px;
}
.sos-feature,
.sauce-card {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--border);
  background: rgba(8, 10, 8, 0.58);
  box-shadow: var(--shadow);
}
.sos-feature {
  border-radius: var(--radius);
  min-height: 100%;
  display: flex;
  flex-direction: column;
}
.sos-feature::before,
.sauce-card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 2;
  opacity: 0;
  background: radial-gradient(
    420px circle at var(--mx, 50%) var(--my, 50%),
    rgba(230, 193, 103, 0.2),
    transparent 46%
  );
  transition: opacity 0.35s var(--ease);
}
.sos-feature:hover::before,
.sauce-card:hover::before {
  opacity: 1;
}
.sos-feature::after,
.sauce-card::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(
    180deg,
    rgba(8, 10, 8, 0) 28%,
    rgba(8, 10, 8, 0.36) 58%,
    rgba(8, 10, 8, 0.9) 100%
  );
}
.sos-feature__media {
  position: relative;
  flex: 1;
  min-height: 420px;
}
.sos-feature__media img,
.sauce-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition:
    transform 0.7s var(--ease),
    filter 0.7s var(--ease);
}
.sos-feature__body {
  position: absolute;
  left: clamp(22px, 3vw, 34px);
  right: clamp(22px, 3vw, 34px);
  bottom: clamp(22px, 3vw, 34px);
  z-index: 1;
}
.sos-feature h3,
.sauce-card h3 {
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.02em;
  line-height: 0.92;
  text-wrap: balance;
}
.sos-feature h3 {
  font-size: clamp(2.4rem, 5vw, 4rem);
  margin-bottom: 12px;
}
.sos-feature p {
  color: var(--fg);
  max-width: 42ch;
  line-height: 1.55;
}
.sauce-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(14px, 1.8vw, 18px);
}
.sauce-card {
  min-height: 410px;
  border-radius: var(--radius-sm);
  transition:
    border-color 0.3s var(--ease),
    transform 0.3s var(--ease),
    box-shadow 0.3s var(--ease);
}
.sauce-card:hover,
.sos-feature:hover {
  border-color: rgba(230, 193, 103, 0.55);
  box-shadow: var(--shadow-gold);
}
.sauce-card:hover {
  transform: translateY(-4px);
}
.sauce-card:hover img,
.sos-feature:hover img {
  transform: scale(1.045) translate3d(var(--px, 0), var(--py, 0), 0);
  filter: saturate(1.08) contrast(1.04);
}
.sauce-card__body {
  position: absolute;
  z-index: 3;
  left: 20px;
  right: 20px;
  bottom: 20px;
  display: grid;
  gap: 12px;
  justify-items: center;
  text-align: center;
}
.sauce-card h3 {
  font-size: clamp(1.8rem, 2.4vw, 2.45rem);
}
.sauce-card p {
  color: var(--fg);
  font-size: 0.98rem;
  line-height: 1.5;
  max-width: 24ch;
}
.sauce-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 8px 18px;
  border: 1px solid rgba(230, 193, 103, 0.72);
  border-radius: 999px;
  color: var(--gold-bright);
  background: rgba(8, 10, 8, 0.64);
  font-family: var(--font-display);
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 0.13em;
  line-height: 1;
  text-transform: uppercase;
  white-space: nowrap;
}
.sauce-badge--float {
  position: absolute;
  top: 24px;
  right: 24px;
  z-index: 1;
  width: 96px;
  height: 96px;
  padding: 0 18px;
  border-radius: 50%;
  text-align: center;
  white-space: normal;
  line-height: 1.12;
}
.sauce-cta {
  position: relative;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  gap: 20px;
  min-height: 48px;
  margin-top: 22px;
  padding: 11px 26px;
  border: 1px solid var(--gold);
  border-radius: 8px;
  color: var(--gold-bright);
  background: rgba(8, 10, 8, 0.5);
  font-family: var(--font-display);
  font-size: 1.08rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  transition:
    background-color 0.25s var(--ease),
    border-color 0.25s var(--ease),
    transform 0.25s var(--ease);
}
.sauce-cta:hover {
  background: rgba(201, 162, 74, 0.12);
  border-color: var(--gold-bright);
  transform: translateY(-2px);
}

/* ---------- INSTAGRAM gallery ---------- */
.ig-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
  margin-bottom: 36px;
}
.ig-handle {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-display);
  font-size: 1.3rem;
  letter-spacing: 0.02em;
  color: var(--fg);
}
.ig-handle svg {
  width: 26px;
  height: 26px;
  color: var(--gold);
}
.ig-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 12px;
}
.ig-grid a {
  position: relative;
  aspect-ratio: 1/1;
  overflow: hidden;
  border-radius: var(--radius-sm);
  border: 1px solid var(--border-soft);
  display: block;
}
.ig-grid img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.8s var(--ease);
}
.ig-grid a::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(8, 10, 8, 0);
  transition: background-color 0.35s var(--ease);
}
.ig-grid a:hover img {
  transform: scale(1.08);
}
.ig-grid a:hover::after {
  background: rgba(8, 10, 8, 0.35);
}
.ig-grid .ig-ic {
  position: absolute;
  inset: 0;
  margin: auto;
  width: 30px;
  height: 30px;
  color: #fff;
  opacity: 0;
  transform: scale(0.8);
  transition:
    opacity 0.35s var(--ease),
    transform 0.35s var(--ease);
  z-index: 2;
}
.ig-grid a:hover .ig-ic {
  opacity: 1;
  transform: scale(1);
}
.ig-grid .tall {
  grid-row: span 2;
  aspect-ratio: auto;
}

/* ---------- REVIEWS ---------- */
.reviews__top {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(180px, 0.72fr) 1.28fr;
  gap: clamp(24px, 4vw, 56px);
  align-items: center;
  padding: clamp(30px, 4vw, 48px);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: linear-gradient(
    135deg,
    rgba(22, 26, 18, 0.92),
    rgba(9, 12, 9, 0.84)
  );
  box-shadow: var(--shadow);
}
.reviews__top > * {
  position: relative;
  z-index: 2;
}
.rscore {
  text-align: left;
  padding-right: clamp(20px, 3vw, 40px);
  border-right: 1px solid var(--border-soft);
}
.rscore b {
  font-family: var(--font-display);
  font-size: clamp(5.2rem, 10vw, 8rem);
  color: var(--gold);
  line-height: 0.78;
  display: block;
  letter-spacing: 0;
}
.rscore .rstars {
  color: var(--gold);
  letter-spacing: 3px;
  font-size: 1.05rem;
  margin-top: 8px;
}
.rscore .rcount {
  color: var(--fg-muted);
  font-size: 0.85rem;
  margin-top: 6px;
  letter-spacing: 0.08em;
}
.reviews__cta h3 {
  font-size: clamp(1.6rem, 3.5vw, 2.4rem);
}
.reviews__cta p {
  color: var(--fg-muted);
  margin: 8px 0 20px;
  max-width: 50ch;
}
.gbtn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.gbtn svg {
  width: 20px;
  height: 20px;
}
.review-cards {
  display: grid;
  grid-template-columns: 1.14fr 0.93fr 0.93fr;
  gap: 18px;
  margin-top: 24px;
  align-items: stretch;
}
.review-card {
  position: relative;
  overflow: hidden;
  padding: 26px;
  border: 1px solid var(--border-soft);
  border-radius: var(--radius);
  background: linear-gradient(
    180deg,
    rgba(22, 26, 18, 0.9),
    rgba(14, 18, 13, 0.76)
  );
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition:
    transform 0.35s var(--ease),
    border-color 0.35s var(--ease),
    box-shadow 0.35s var(--ease);
}
.review-card:first-child {
  padding: 32px;
}
.review-card:hover {
  transform: translateY(-4px);
  border-color: var(--border);
  box-shadow: var(--shadow);
}
.review-card > * {
  position: relative;
  z-index: 2;
}
.review-card .rstars {
  color: var(--gold);
  letter-spacing: 2px;
}
.review-card blockquote {
  color: var(--fg);
  font-size: 1.02rem;
  line-height: 1.55;
  flex: 1;
}
.review-card:first-child blockquote {
  font-size: clamp(1.1rem, 1.6vw, 1.34rem);
  line-height: 1.52;
}
.review-card .who {
  display: flex;
  align-items: center;
  gap: 12px;
}
.review-card .av {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: linear-gradient(180deg, var(--green-bright), var(--green-deep));
  display: grid;
  place-items: center;
  font-family: var(--font-display);
  color: var(--fg);
  border: 1px solid var(--border);
}
.review-card .who b {
  font-size: 0.98rem;
}
.review-card .who span {
  display: block;
  color: var(--fg-dim);
  font-size: 0.78rem;
}

@media (max-width: 1024px) {
  .cards-grid--4 {
    grid-template-columns: repeat(2, 1fr);
  }
  .ig-grid {
    grid-template-columns: repeat(4, 1fr);
  }
  .ig-grid .tall {
    grid-row: span 1;
    aspect-ratio: 1/1;
  }
  .review-cards {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 900px) {
  .soslar__grid {
    grid-template-columns: 1fr;
  }
  .reviews__top {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .rscore {
    border-right: 0;
    border-bottom: 1px solid var(--border-soft);
    padding: 0 0 24px;
  }
}
@media (max-width: 720px) {
  .cards-grid--4 {
    grid-template-columns: 1fr;
  }
  .sauce-grid {
    grid-template-columns: 1fr;
  }
  .ig-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
  }
}
