/* ============================================================
   BEEROOM CRAFT PUB — styles.css
   Comic-book / Simpsons / graffiti / craft-beer maximalism
   ------------------------------------------------------------
   TABLE OF CONTENTS
   00. Design tokens (CSS variables)
   01. Reset & base
   02. Utilities & shared comic primitives
   03. Buttons
   04. Header & navigation
   05. Hero (homepage)
   06. Marquee strip
   07. Section scaffolding
   08. About
   09. Beer Experience + Random Mood
   10. Food preview / cards
   11. Events
   12. Gallery (masonry)
   13. Opening hours
   14. Find Us + contact form
   15. Footer
   16. Toasts
   17. Menu page (hero, tabs, controls, cards)
   18. Keyframes
   19. Responsive
   20. Reduced motion / print
   ============================================================ */

/* ===== 00. DESIGN TOKENS ================================== */
:root {
  /* Brand palette */
  --bg-deep:   #0b0f12;
  --charcoal:  #151515;
  --amber:     #f6b23c;
  --yellow:    #ffd84d;
  --red:       #9b1015;
  --cream:     #fff4d6;
  --hop:       #7fb069;
  --white:     #ffffff;
  --gray:      #a7a7a7;
  --ink:       #0a0a0a;

  /* Fonts */
  --font-display: 'Bangers', 'Luckiest Guy', system-ui, cursive;
  --font-alt:     'Luckiest Guy', 'Bangers', cursive;
  --font-marker:  'Permanent Marker', 'Bangers', cursive;
  --font-body:    'Montserrat', system-ui, -apple-system, sans-serif;

  /* Borders */
  --bw: 4px;
  --bw-thick: 6px;
  --border:       var(--bw) solid var(--ink);
  --border-thick: var(--bw-thick) solid var(--ink);
  --radius: 18px;
  --radius-sm: 10px;

  /* Comic offset shadows */
  --shadow:    6px 6px 0 var(--ink);
  --shadow-sm: 4px 4px 0 var(--ink);
  --shadow-lg: 10px 10px 0 var(--ink);
  --shadow-yellow: 6px 6px 0 var(--yellow);
  --shadow-red:    6px 6px 0 var(--red);

  /* Spacing scale */
  --sp-1: 0.5rem;
  --sp-2: 1rem;
  --sp-3: 1.5rem;
  --sp-4: 2rem;
  --sp-5: 3rem;
  --sp-6: 4.5rem;
  --sp-7: 7rem;

  --container: 1200px;
  --header-h: 76px;
}

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

html { scroll-behavior: smooth; scroll-padding-top: calc(var(--header-h) + 10px); }

body {
  font-family: var(--font-body);
  color: var(--cream);
  background-color: var(--bg-deep);
  background-image:
    radial-gradient(circle at 12% 8%,  rgba(155,16,21,0.18), transparent 38%),
    radial-gradient(circle at 88% 0%,  rgba(246,178,60,0.16), transparent 40%),
    radial-gradient(circle at 50% 120%, rgba(127,176,105,0.12), transparent 50%);
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* ===== PRELOADER (index.html, hides on window load) ====== */
.preloader {
  position: fixed; inset: 0; z-index: 5000;
  display: grid; place-items: center;
  background-color: var(--bg-deep);
  background-image:
    linear-gradient(180deg, rgba(11,15,18,0.82), rgba(11,15,18,0.92)),
    url("assets/images/hero-beeroom-exterior.webp");
  background-size: cover; background-position: center;
  transition: opacity 0.5s ease, visibility 0.5s ease;
}
.preloader.is-done { opacity: 0; visibility: hidden; pointer-events: none; }
.preloader-inner { display: flex; flex-direction: column; align-items: center; gap: 1.3rem; padding: 1.5rem; text-align: center; }
.preloader-logo {
  width: clamp(150px, 32vw, 260px);
  filter: drop-shadow(5px 7px 0 rgba(0,0,0,0.5));
  animation: preloaderPulse 1.4s ease-in-out infinite;
}
.preloader-bar {
  width: min(260px, 68vw); height: 16px; overflow: hidden;
  background: rgba(0,0,0,0.45); border: var(--border); border-radius: 30px; box-shadow: var(--shadow-sm);
}
.preloader-bar span {
  display: block; width: 40%; height: 100%; border-radius: 30px;
  background: linear-gradient(90deg, var(--amber), var(--yellow));
  animation: preloaderSlide 1.1s ease-in-out infinite;
}
.preloader-text { color: var(--cream); font-size: 1.3rem; letter-spacing: 0.5px; }
@keyframes preloaderPulse { 0%,100% { transform: scale(1) rotate(-1.5deg); } 50% { transform: scale(1.07) rotate(1.5deg); } }
@keyframes preloaderSlide { 0% { transform: translateX(-110%); } 100% { transform: translateX(260%); } }

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { font-family: inherit; cursor: pointer; }
input, textarea, select, button { font-family: inherit; font-size: 1rem; }

h1, h2, h3 { line-height: 1; letter-spacing: 0.5px; }

::selection { background: var(--yellow); color: var(--ink); }

/* Focus visibility (accessibility) */
:focus-visible {
  outline: 3px dashed var(--yellow);
  outline-offset: 3px;
}

.skip-link {
  position: absolute; left: -9999px; top: 0; z-index: 2000;
  background: var(--yellow); color: var(--ink);
  padding: 0.7rem 1.2rem; font-weight: 800; border: var(--border);
}
.skip-link:focus { left: 12px; top: 12px; }

/* ===== 02. UTILITIES & SHARED COMIC PRIMITIVES ============ */
.container { width: min(100% - 2.4rem, var(--container)); margin-inline: auto; }

.visually-hidden, .skip-link:not(:focus) { /* keep skip-link offscreen handled above */ }
.visually-hidden {
  position: absolute !important; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}

.marker { font-family: var(--font-marker); }

/* Halftone dot texture overlay */
.halftone {
  position: absolute; inset: 0; pointer-events: none; z-index: 1;
  background-image: radial-gradient(rgba(0,0,0,0.55) 1.4px, transparent 1.6px);
  background-size: 9px 9px;
  opacity: 0.28;
  mix-blend-mode: multiply;
}

/* Tilt helpers */
.tilt-l { transform: rotate(-2.2deg); }
.tilt-r { transform: rotate(2.2deg); }

/* Stickers */
.sticker {
  display: inline-block;
  font-family: var(--font-marker);
  font-size: 0.9rem;
  padding: 0.35rem 0.85rem;
  border: var(--border);
  border-radius: 40px;
  box-shadow: var(--shadow-sm);
  color: var(--ink);
  background: var(--yellow);
  white-space: nowrap;
}
.sticker-yellow { background: var(--yellow); }
.sticker-red    { background: var(--red); color: var(--cream); }
.sticker-green  { background: var(--hop); }
.sticker-cream  { background: var(--cream); }

/* Speech bubble */
.speech-bubble {
  position: relative;
  background: var(--cream);
  color: var(--ink);
  border: var(--border-thick);
  border-radius: 22px;
  padding: 1.1rem 1.4rem;
  box-shadow: var(--shadow);
  font-weight: 700;
}
.speech-bubble::after {
  content: "";
  position: absolute;
  left: 36px; bottom: -22px;
  border-width: 22px 18px 0 0;
  border-style: solid;
  border-color: var(--cream) transparent transparent transparent;
  filter: drop-shadow(0 4px 0 var(--ink));
}
.speech-bubble::before {
  content: "";
  position: absolute;
  left: 32px; bottom: -28px;
  border-width: 28px 24px 0 0;
  border-style: solid;
  border-color: var(--ink) transparent transparent transparent;
}

/* Framed media wrapper (image with comic frame + fallback) */
.media {
  position: relative;
  overflow: hidden;
  background:
    repeating-linear-gradient(45deg, #1c2126 0 14px, #232a30 14px 28px);
  display: grid;
  place-items: center;
}
.framed { border: var(--border-thick); border-radius: var(--radius); box-shadow: var(--shadow); }
.media img { width: 100%; height: 100%; object-fit: cover; position: absolute; inset: 0; z-index: 2; }
.media img.is-broken { opacity: 0; }
.media-fallback {
  font-family: var(--font-display);
  font-size: clamp(1.2rem, 3vw, 2rem);
  color: var(--amber);
  letter-spacing: 1px;
  text-align: center;
  padding: 1rem;
  z-index: 1;
}

/* Emoji fallback for missing character PNGs */
.emoji-floaty { display: grid; place-items: center; font-size: 4rem; line-height: 1; }
.emoji-floaty.big { font-size: clamp(4rem, 10vw, 9rem); filter: drop-shadow(4px 4px 0 rgba(0,0,0,0.4)); }

/* ===== 03. BUTTONS ======================================== */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 0.4rem;
  font-family: var(--font-display);
  font-size: 1.25rem;
  letter-spacing: 1px;
  padding: 0.7rem 1.5rem;
  border: var(--border);
  border-radius: 50px;
  box-shadow: var(--shadow-sm);
  color: var(--ink);
  background: var(--yellow);
  transition: transform 0.12s ease, box-shadow 0.12s ease, background 0.2s ease;
  text-align: center;
  line-height: 1.1;
}
.btn:hover, .btn:focus-visible { transform: translate(-2px, -2px); box-shadow: 7px 7px 0 var(--ink); }
.btn:active { transform: translate(2px, 2px); box-shadow: 2px 2px 0 var(--ink); }

.btn-yellow { background: var(--yellow); color: var(--ink); }
.btn-red    { background: var(--red);    color: var(--cream); }
.btn-outline{ background: transparent;   color: var(--cream); border-color: var(--cream); box-shadow: 4px 4px 0 var(--red); }
.btn-outline:hover { background: var(--cream); color: var(--ink); }
.btn-lg { font-size: 1.5rem; padding: 0.9rem 2rem; }
.btn-sm { font-size: 0.95rem; padding: 0.45rem 1rem; box-shadow: 3px 3px 0 var(--ink); }

/* ===== 04. HEADER & NAVIGATION ============================ */
.site-header {
  position: sticky; top: 0; z-index: 1000;
  background: var(--charcoal);
  border-bottom: var(--border-thick);
  box-shadow: 0 6px 0 rgba(0,0,0,0.35);
  transition: transform 0.3s ease;
}
.site-header.is-hidden { transform: translateY(-120%); }
.header-inner {
  display: flex; align-items: center; justify-content: space-between;
  height: var(--header-h); gap: 1rem;
}

.logo { display: flex; align-items: center; gap: 0.6rem; }
.logo-badge {
  width: 46px; height: 46px; border-radius: 50%;
  background: var(--ink); border: var(--border);
  display: grid; place-items: center; overflow: hidden;
  box-shadow: var(--shadow-sm);
  transition: transform 0.2s ease;
}
.logo:hover .logo-badge { transform: rotate(-12deg) scale(1.05); }
.logo-img { width: 100%; height: 100%; object-fit: contain; }
/* Hidden by default; the img's onerror handler reveals it only if the logo fails to load. */
.logo-fallback { display: none; align-items: center; justify-content: center; font-size: 1.6rem; }
/* Nav badge intentionally shows the emoji mark (no logo image). */
.logo-badge--mark .logo-fallback { display: flex; }
.logo-text {
  font-family: var(--font-display);
  font-size: 2rem; color: var(--yellow);
  -webkit-text-stroke: 1.5px var(--ink);
  letter-spacing: 2px;
}

.main-nav { display: flex; align-items: center; gap: 0.4rem; }
.nav-link {
  font-family: var(--font-display);
  font-size: 1.2rem; letter-spacing: 1px;
  color: var(--cream);
  padding: 0.4rem 0.7rem; border-radius: 8px;
  position: relative; transition: color 0.15s ease, transform 0.15s ease;
}
.nav-link::after {
  content: ""; position: absolute; left: 0.7rem; right: 0.7rem; bottom: 2px;
  height: 4px; background: var(--yellow); transform: scaleX(0); transform-origin: left;
  transition: transform 0.2s ease;
}
.nav-link:hover, .nav-link:focus-visible { color: var(--yellow); transform: translateY(-2px); }
.nav-link:hover::after, .nav-link.is-active::after { transform: scaleX(1); }
.nav-link.is-active { color: var(--yellow); }
.nav-ig { color: var(--amber); }
.nav-cta { margin-left: 0.5rem; font-size: 1.05rem; padding: 0.5rem 1rem; }

/* Hamburger */
.hamburger {
  display: none;
  flex-direction: column; gap: 5px;
  width: 50px; height: 44px;
  background: var(--yellow); border: var(--border); border-radius: 10px;
  box-shadow: var(--shadow-sm); padding: 9px 10px;
}
.hamburger span { display: block; height: 4px; background: var(--ink); border-radius: 4px; transition: transform 0.25s ease, opacity 0.2s ease; }
.hamburger.is-open span:nth-child(1) { transform: translateY(9px) rotate(45deg); }
.hamburger.is-open span:nth-child(2) { opacity: 0; }
.hamburger.is-open span:nth-child(3) { transform: translateY(-9px) rotate(-45deg); }

/* ===== 05. HERO ========================================== */
.hero {
  position: relative;
  /* Header is sticky (in flow), so the hero fills the rest of the screen.
     dvh override keeps it gap-free on mobile where the URL bar resizes. */
  min-height: calc(100vh - var(--header-h));
  min-height: calc(100dvh - var(--header-h));
  display: flex; align-items: center;
  padding: 2rem 0 3rem;
  overflow: hidden;
  border-bottom: var(--border-thick);
}
.hero-bg {
  position: absolute; inset: 0; z-index: 0;
  background-color: #10161b;
  background-image:
    linear-gradient(120deg, rgba(155,16,21,0.35), rgba(11,15,18,0.2)),
    url("assets/images/hero-beeroom-exterior.webp");
  background-size: cover; background-position: center;
  animation: heroPan 28s ease-in-out infinite alternate;
}
.hero-overlay {
  position: absolute; inset: 0; z-index: 1;
  background:
    radial-gradient(circle at 30% 30%, rgba(11,15,18,0.35), rgba(11,15,18,0.9) 80%),
    linear-gradient(to top, var(--bg-deep) 4%, transparent 45%);
}
.hero .halftone { z-index: 2; }
.hero-inner { position: relative; z-index: 5; text-align: center; max-width: 900px; }

.hero-kicker {
  display: inline-block;
  font-family: var(--font-marker);
  background: var(--red); color: var(--cream);
  border: var(--border); border-radius: 40px;
  padding: 0.35rem 1.1rem; box-shadow: var(--shadow-sm);
  transform: rotate(-1.5deg); margin-bottom: 1.2rem;
}
.hero-logo-wrap { display: flex; justify-content: center; }
.hero-logo { width: clamp(90px, 14vw, 150px); margin-bottom: 0.5rem; filter: drop-shadow(4px 4px 0 rgba(0,0,0,0.5)); }

.hero-title {
  font-family: var(--font-display);
  font-size: clamp(3.4rem, 13vw, 9rem);
  line-height: 0.86; margin-bottom: 0.6rem;
  display: flex; flex-direction: column; align-items: center;
}
.hero-title .word { -webkit-text-stroke: clamp(2px, 0.6vw, 5px) var(--ink); }
.hero-title .word-1 { color: var(--yellow); transform: rotate(-2deg); text-shadow: var(--shadow); }
.hero-title .word-2 { color: var(--red);    transform: rotate(1.5deg) translateY(-6px); text-shadow: 6px 6px 0 var(--yellow), 7px 7px 0 var(--ink); }

.hero-sub { font-size: clamp(1.5rem, 4vw, 2.6rem); color: var(--amber); margin-bottom: 1rem; transform: rotate(-1deg); }
.hero-desc { font-size: clamp(1rem, 2vw, 1.2rem); max-width: 620px; margin: 0 auto 1.8rem; color: var(--cream); font-weight: 600; }

.hero-btns { display: flex; flex-wrap: wrap; gap: 0.9rem; justify-content: center; }

/* Hero staggered load-in. Uses the individual `translate`/`scale`
   properties (not `transform`) so the entrance composes cleanly with
   each element's resting `transform: rotate(...)`. */
@keyframes heroRise { from { opacity: 0; translate: 0 30px; } to { opacity: 1; translate: 0 0; } }
@keyframes heroPop  { from { opacity: 0; translate: 0 36px; scale: 0.88; } to { opacity: 1; translate: 0 0; scale: 1; } }
.hero-kicker    { animation: heroRise 0.55s ease both 0.10s; }
.hero-logo-wrap { animation: heroRise 0.55s ease both 0.20s; }
.hero-title     { animation: heroPop 0.75s cubic-bezier(.2,.8,.25,1.3) both 0.30s; }
.hero-sub       { animation: heroRise 0.55s ease both 0.55s; }
.hero-desc      { animation: heroRise 0.55s ease both 0.68s; }
.hero-btns      { animation: heroRise 0.55s ease both 0.80s; }

/* Hold the hero entrance paused until the page is revealed, so the
   staggered animation plays AFTER the preloader fades (not behind it).
   JS adds `loaded` to <body>; without JS the page still shows because
   the menu/home boot always sets it. */
.hero-kicker, .hero-logo-wrap, .hero-title, .hero-sub, .hero-desc, .hero-btns { animation-play-state: paused; }
body.loaded .hero-kicker,
body.loaded .hero-logo-wrap,
body.loaded .hero-title,
body.loaded .hero-sub,
body.loaded .hero-desc,
body.loaded .hero-btns { animation-play-state: running; }

.floaty { position: absolute; z-index: 4; pointer-events: none; filter: drop-shadow(4px 6px 0 rgba(0,0,0,0.4)); }
.floaty--can-1  { width: 70px; top: 30%; left: 8%;  animation: floatY 7s ease-in-out infinite; }
.floaty--can-2  { width: 60px; bottom: 24%; left: 14%; animation: floatY 6s ease-in-out infinite 1s; }
/* z-index 7 lifts the characters in front of the hero content (.hero-inner is 5). */
.floaty--homer  { width: clamp(110px, 16vw, 200px); bottom: -10px; right: 2%; z-index: 7; }
.floaty--family { width: clamp(130px, 18vw, 230px); bottom: -10px; left: 1%; opacity: 0.96; z-index: 7; }

.scroll-cue {
  position: absolute; bottom: 18px; left: 50%; transform: translateX(-50%);
  z-index: 6; color: var(--yellow); text-align: center; font-size: 0.9rem;
  display: flex; flex-direction: column; align-items: center; gap: 4px;
}
.scroll-arrow { animation: bounceY 1.6s ease-in-out infinite; font-size: 1.2rem; }

/* ===== 06. MARQUEE ======================================= */
.marquee {
  background: var(--yellow);
  border-bottom: var(--border-thick);
  overflow: hidden; padding: 0.5rem 0;
}
.marquee-track {
  display: flex; gap: 2rem; white-space: nowrap; width: max-content;
  font-family: var(--font-display); font-size: 1.4rem; color: var(--ink);
  letter-spacing: 1px;
  animation: scrollX 28s linear infinite;
}
.marquee-track span { flex-shrink: 0; }

/* ===== 07. SECTION SCAFFOLDING =========================== */
.section { padding: var(--sp-7) 0; position: relative; }
.section-head { margin-bottom: var(--sp-5); max-width: 760px; }
.section-num {
  display: inline-block; font-family: var(--font-marker);
  color: var(--hop); letter-spacing: 2px; text-transform: uppercase;
  font-size: 0.85rem; margin-bottom: 0.5rem;
}
.section-title {
  font-family: var(--font-display);
  font-size: clamp(2.6rem, 7vw, 5rem);
  color: var(--yellow);
  -webkit-text-stroke: 2px var(--ink);
  text-shadow: 5px 5px 0 var(--red);
  transform: rotate(-1.2deg);
}
.section-lead { font-size: clamp(1rem, 2vw, 1.25rem); color: var(--cream); font-weight: 600; margin-top: 1rem; }

.center-cta { text-align: center; margin-top: var(--sp-4); }

/* ===== 08. ABOUT ========================================= */
.about {
  background-color: var(--bg-deep);
  background-image:
    linear-gradient(180deg, rgba(11,15,18,0.80), rgba(11,15,18,0.90)),
    url("assets/images/about-hero.webp");
  background-size: cover;
  background-position: center;
}
.about-grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: var(--sp-5); align-items: center; }
.big-bubble p { font-size: 1.08rem; line-height: 1.65; font-weight: 600; }
.sticker-row { display: flex; flex-wrap: wrap; gap: 0.8rem; margin-top: 1.6rem; }

.about-media { position: relative; }
.about-media .media { aspect-ratio: 1 / 1; }
.char { position: absolute; z-index: 10; filter: drop-shadow(4px 6px 0 rgba(0,0,0,0.4)); }
.char--marge { width: clamp(90px, 14vw, 150px); bottom: -20px; left: -28px; animation: floatY 6s ease-in-out infinite; }

.feature-grid {
  margin-top: var(--sp-6);
  display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-3);
}
.feat-card {
  background: var(--charcoal); border: var(--border); border-radius: var(--radius);
  box-shadow: var(--shadow); padding: 1.6rem 1.3rem;
  display: flex; flex-direction: column; gap: 0.7rem;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.feat-card:hover { transform: translateY(-8px) rotate(0deg) scale(1.02); box-shadow: var(--shadow-lg); }
.feat-ico { font-size: 2.4rem; }
.feat-card h3 { font-family: var(--font-display); font-size: 1.4rem; color: var(--cream); letter-spacing: 0.5px; }

/* ===== 09. BEER EXPERIENCE =============================== */
.beer-xp {
  background-color: var(--charcoal);
  background-image:
    linear-gradient(180deg, rgba(11,15,18,0.82), rgba(11,15,18,0.90)),
    url("assets/images/beer-hero.webp");
  background-size: cover;
  background-position: center;
  border-block: var(--border-thick);
}
.xp-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-4); }
.xp-card {
  position: relative; background: var(--bg-deep);
  border: var(--border-thick); border-radius: var(--radius);
  box-shadow: var(--shadow); padding: 2rem 1.6rem; text-align: center;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.xp-card:hover, .xp-card:focus-within { transform: rotate(0) translateY(-10px) scale(1.03); box-shadow: var(--shadow-lg); }
.xp-card--featured { background: var(--red); }
.xp-card--featured h3, .xp-card--featured p { color: var(--cream); }
.xp-tag {
  position: absolute; top: -16px; left: 50%; transform: translateX(-50%) rotate(-3deg);
  font-family: var(--font-marker); background: var(--yellow); color: var(--ink);
  border: var(--border); border-radius: 30px; padding: 0.2rem 0.9rem; box-shadow: var(--shadow-sm);
  white-space: nowrap;
}
.xp-ico { font-size: 3.4rem; display: block; margin: 0.6rem 0; }
/* Photo banner inside an experience card (taps / fridge / flight) */
.xp-media {
  aspect-ratio: 4 / 3; width: 100%;
  border: var(--border); border-radius: var(--radius-sm);
  margin: 0.4rem 0 0.9rem; box-shadow: var(--shadow-sm);
}
.xp-card--featured .xp-media { border-color: var(--ink); }
.xp-card h3 { font-family: var(--font-display); font-size: 2rem; color: var(--yellow); -webkit-text-stroke: 1px var(--ink); margin-bottom: 0.5rem; }
.xp-card p { color: var(--cream); font-weight: 600; margin-bottom: 1rem; }
.flight-price { display: inline-block; font-family: var(--font-marker); color: var(--yellow); font-size: 1.2rem; }
.flight-price strong { color: var(--amber); font-size: 1.5rem; }

.mood-zone {
  margin-top: var(--sp-6); position: relative;
  display: flex; align-items: center; justify-content: center; gap: 2rem;
}
.char--homer { position: relative; width: clamp(120px, 16vw, 200px); flex-shrink: 0; animation: floatY 6s ease-in-out infinite; }
.mood-box {
  background: var(--bg-deep); border: var(--border-thick); border-radius: var(--radius);
  box-shadow: var(--shadow); padding: 2rem; text-align: center; max-width: 520px; flex: 1;
}
.mood-title { font-size: 2rem; color: var(--amber); }
.mood-box p { margin-bottom: 1rem; font-weight: 600; }
.mood-result { margin-top: 1.4rem; font-family: var(--font-marker); font-size: 1.3rem; color: var(--ink); animation: pop 0.4s ease; }

/* ===== 10. FOOD =========================================
   Calm, compact highlight cards (4 items). No loud colour
   banners — small emoji icon + text on the dark comic card.
   The full menu lives on menu.html. */
.food {
  background-color: var(--bg-deep);
  background-image:
    linear-gradient(180deg, rgba(11,15,18,0.82), rgba(11,15,18,0.90)),
    url("assets/images/snack-hero.webp");
  background-size: cover;
  background-position: center;
}
.food-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-3);
}
.food-card {
  background: var(--charcoal); border: var(--border); border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  display: flex; flex-direction: column; gap: 0.6rem;
  padding: 1.3rem 1.2rem 1.4rem;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.food-card:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.food-head { display: flex; align-items: center; gap: 0.7rem; }
.food-emoji {
  flex-shrink: 0;
  width: 48px; height: 48px; border-radius: 12px;
  display: grid; place-items: center; font-size: 1.7rem; line-height: 1;
  background: var(--bg-deep); border: 3px solid var(--ink);
}
.food-name { font-family: var(--font-display); font-size: 1.3rem; color: var(--yellow); letter-spacing: 0.5px; line-height: 1.05; }
.food-desc { font-size: 0.88rem; color: var(--gray); font-weight: 500; flex: 1; }
.food-foot { display: flex; align-items: center; justify-content: space-between; gap: 0.5rem; margin-top: 0.2rem; }
.price-tag {
  font-family: var(--font-display); font-size: 1.5rem; color: var(--ink);
  background: var(--amber); border: var(--border); border-radius: 10px;
  padding: 0.1rem 0.7rem; box-shadow: var(--shadow-sm); transform: rotate(-2deg);
}
.tag-pills { display: flex; flex-wrap: wrap; gap: 0.35rem; }
.pill {
  font-size: 0.7rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.5px;
  padding: 0.18rem 0.55rem; border: 2px solid var(--ink); border-radius: 30px; color: var(--ink);
}
.pill::before { margin-right: 3px; }
.pill-vegan      { background: var(--hop); }
.pill-vegan::before      { content: "🌱"; }
.pill-vegetarian { background: #b6d97f; }
.pill-vegetarian::before { content: "🧀"; }
.pill-mild       { background: var(--amber); }
.pill-mild::before       { content: "🙂"; }
.pill-spicy      { background: #e8623a; color: var(--cream); border-color: var(--ink); }
.pill-spicy::before      { content: "🌶️"; }

/* ===== 11. EVENTS ======================================== */
.events { background: linear-gradient(180deg, rgba(155,16,21,0.18), transparent); }
.events-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-4); }
.event-card {
  position: relative; background: var(--charcoal); border: var(--border-thick);
  border-radius: var(--radius); box-shadow: var(--shadow); padding: 1.8rem;
  display: flex; gap: 1.4rem; align-items: flex-start; overflow: visible;
  transition: transform 0.2s ease;
}
.event-card:hover { transform: rotate(0) translateY(-6px); }
.event-date {
  flex-shrink: 0; width: 92px; height: 100px; background: var(--red); color: var(--cream);
  border: var(--border); border-radius: 14px; box-shadow: var(--shadow-sm);
  display: grid; place-content: center; text-align: center; transform: rotate(-4deg);
}
.event-day { font-family: var(--font-display); font-size: 3rem; line-height: 0.8; }
.event-mon { font-family: var(--font-display); font-size: 1.3rem; letter-spacing: 2px; }
.event-body h3 { font-family: var(--font-display); font-size: 1.9rem; color: var(--yellow); margin: 0.4rem 0; -webkit-text-stroke: 1px var(--ink); }
.event-body p { font-weight: 600; }
.char--krusty { position: absolute; width: 90px; bottom: -16px; right: -10px; animation: pop 5s ease-in-out infinite; }
.event-card--cta { flex-direction: column; justify-content: center; text-align: center; background: var(--bg-deep); }
.event-card--cta h3 { font-family: var(--font-display); font-size: 2rem; color: var(--amber); }
.event-card--cta p { font-weight: 600; margin: 0.6rem 0 1.2rem; }

/* ===== 12. GALLERY ======================================= */
.gallery {
  overflow: visible;
  background-color: var(--bg-deep);
  background-image:
    linear-gradient(180deg, rgba(11,15,18,0.82), rgba(11,15,18,0.90)),
    url("assets/images/feed-hero.webp");
  background-size: cover;
  background-position: center;
}
.char--bart { width: clamp(90px, 12vw, 160px); right: 4%; margin-top: -1rem; position: relative; z-index: 12; animation: floatY 7s ease-in-out infinite; }
.masonry { columns: 4; column-gap: var(--sp-3); }
.gtile {
  break-inside: avoid; margin-bottom: var(--sp-3); position: relative;
  border: var(--border-thick); border-radius: var(--radius); box-shadow: var(--shadow);
  overflow: hidden; transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.gtile:nth-child(3n)   { transform: rotate(1.5deg); }
.gtile:nth-child(3n+1) { transform: rotate(-1.5deg); }
.gtile:hover { transform: rotate(0) scale(1.03); box-shadow: var(--shadow-lg); z-index: 5; }
.gtile .media { width: 100%; }
.gtile-cap {
  position: absolute; top: 8px; left: 8px; z-index: 6;
  font-family: var(--font-marker); font-size: 0.8rem;
  background: var(--cream); color: var(--ink); border: 3px solid var(--ink);
  border-radius: 20px; padding: 0.1rem 0.6rem;
}
.gtile-over {
  position: absolute; inset: 0; z-index: 5;
  background: rgba(155,16,21,0.82);
  display: grid; place-items: center; text-align: center; padding: 1rem;
  font-family: var(--font-display); font-size: 1.4rem; color: var(--cream);
  -webkit-text-stroke: 0.5px var(--ink);
  opacity: 0; transition: opacity 0.2s ease;
}
.gtile:hover .gtile-over, .gtile:focus-within .gtile-over { opacity: 1; }

/* varied tile heights for masonry feel */
.gtile--tall .media  { aspect-ratio: 3 / 4; }
.gtile--wide .media  { aspect-ratio: 4 / 3; }
.gtile--square .media{ aspect-ratio: 1 / 1; }

/* ===== 13. OPENING HOURS ================================= */
.hours {
  text-align: center;
  background-color: var(--bg-deep);
  background-image:
    linear-gradient(180deg, rgba(11,15,18,0.82), rgba(11,15,18,0.90)),
    url("assets/images/hours-hero.webp");
  background-size: cover;
  background-position: center;
}
.hours-board {
  position: relative; max-width: 560px; margin: 0 auto;
  background: var(--charcoal); border: var(--bw-thick) solid var(--ink);
  border-radius: var(--radius); box-shadow: var(--shadow-lg);
  padding: 3.2rem 2rem 2.4rem;
}
.neon-sign {
  position: absolute; top: -28px; left: 50%; transform: translateX(-50%) rotate(-3deg);
  font-family: var(--font-display); font-size: 2.4rem; letter-spacing: 4px;
  color: var(--hop); background: var(--bg-deep);
  border: var(--border); border-radius: 12px; padding: 0.2rem 1.4rem;
  text-shadow: 0 0 8px var(--hop), 0 0 18px rgba(127,176,105,0.7);
  animation: neonFlicker 4s infinite;
}
.hours-list { text-align: left; }
.hours-list li {
  display: flex; justify-content: space-between; align-items: center;
  padding: 0.7rem 0.4rem; border-bottom: 2px dashed rgba(255,244,214,0.18);
  font-weight: 700; font-size: 1.1rem;
}
.hours-list .day { font-family: var(--font-display); font-size: 1.4rem; letter-spacing: 1px; color: var(--cream); }
.hours-list .time { color: var(--amber); font-family: var(--font-marker); font-size: 1.15rem; }
.hours-list .closed .time { color: var(--gray); }
.hours-list .closed { opacity: 0.7; }
.hours-list .late { background: rgba(246,178,60,0.1); border-radius: 8px; }
.hours-list .late .time { color: var(--yellow); }
.hours-list .late .time::after { content: " 🌙"; }
.hh-badge {
  display: inline-block; margin-top: 1.6rem;
  font-family: var(--font-display); font-size: 1.4rem; letter-spacing: 1px;
  background: var(--yellow); color: var(--ink); border: var(--border-thick);
  border-radius: 50px; padding: 0.5rem 1.4rem; box-shadow: var(--shadow); transform: rotate(-2deg);
}

/* ===== 14. FIND US + FORM ================================ */
.find-us {
  background-color: var(--bg-deep);
  background-image:
    linear-gradient(180deg, rgba(11,15,18,0.82), rgba(11,15,18,0.90)),
    url("assets/images/find-hero.webp");
  background-size: cover;
  background-position: center;
}
.find-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-5); align-items: start; }
.map-frame { aspect-ratio: 4 / 3; overflow: hidden; background: var(--charcoal); margin-bottom: 1.2rem; }
.map-frame iframe { width: 100%; height: 100%; border: 0; display: block; filter: saturate(1.1) contrast(1.05); }
.map-col { text-align: center; }

.form-col { position: relative; }
.char--lisa { width: clamp(80px, 10vw, 120px); top: -40px; right: 0; animation: floatY 6s ease-in-out infinite; }
.form-bubble { display: inline-block; margin-bottom: 1.4rem; transform: rotate(-1.5deg); font-family: var(--font-marker); }
.contact-form {
  background: var(--charcoal); border: var(--border-thick); border-radius: var(--radius);
  box-shadow: var(--shadow); padding: 2rem;
}
.form-title { font-size: 2rem; color: var(--yellow); margin-bottom: 1.2rem; }
.field { margin-bottom: 1.1rem; display: flex; flex-direction: column; gap: 0.4rem; }
.field label { font-family: var(--font-display); font-size: 1.15rem; letter-spacing: 1px; color: var(--cream); }
.field input, .field textarea {
  background: var(--bg-deep); color: var(--cream);
  border: var(--border); border-radius: 10px; padding: 0.7rem 0.9rem;
  transition: box-shadow 0.15s ease, transform 0.15s ease;
}
.field input:focus, .field textarea:focus { outline: none; box-shadow: var(--shadow-yellow); transform: translate(-2px,-2px); }
.field textarea { resize: vertical; }

/* ===== 15. FOOTER ======================================== */
.site-footer { position: relative; background: var(--charcoal); border-top: var(--border-thick); padding-top: var(--sp-4); overflow: hidden; }
.halftone--footer { opacity: 0.15; }
.footer-char { position: absolute; top: -26px; right: 3%; width: clamp(90px, 12vw, 150px); z-index: 1; filter: drop-shadow(4px 6px 0 rgba(0,0,0,0.4)); }
.footer-inner { position: relative; z-index: 2; display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: var(--sp-3) var(--sp-4); padding-bottom: var(--sp-3); }
.logo--footer .logo-text { font-size: 2rem; }
.footer-tag { color: var(--amber); font-size: 1.15rem; margin: 0.4rem 0; }
.footer-brand p { color: var(--gray); font-weight: 600; }
.footer-col h4 { font-family: var(--font-display); font-size: 1.3rem; color: var(--yellow); letter-spacing: 1px; margin-bottom: 0.5rem; }
.footer-col p { color: var(--gray); font-weight: 600; }
.footer-links li { margin-bottom: 0.45rem; }
.footer-links a { color: var(--cream); font-weight: 700; transition: color 0.15s ease; }
.footer-links a:hover { color: var(--yellow); }
.footer-bottom {
  position: relative; z-index: 2;
  border-top: var(--border); padding: 1.4rem 1.2rem;
  display: flex; flex-wrap: wrap; gap: 0.4rem 1.5rem; justify-content: space-between;
  background: var(--bg-deep); font-weight: 600; color: var(--gray); font-size: 0.9rem;
}
.footer-bottom .credit { font-family: var(--font-marker); color: var(--amber); }
.footer-bottom .credit a { color: var(--yellow); text-decoration: underline; text-underline-offset: 3px; transition: color 0.15s ease; }
.footer-bottom .credit a:hover { color: var(--cream); }

/* ===== 16. TOASTS ======================================== */

.toast-wrap {
  position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%);
  z-index: 2000; display: flex; flex-direction: column; gap: 0.7rem; align-items: center;
  width: min(92%, 420px); pointer-events: none;
}
.toast {
  pointer-events: auto;
  position: relative; width: 100%;
  background: var(--cream); color: var(--ink);
  border: var(--border-thick); border-radius: 22px;
  box-shadow: var(--shadow); padding: 0.9rem 1.2rem;
  font-family: var(--font-marker); font-size: 1.1rem; text-align: center;
  animation: toastIn 0.35s cubic-bezier(.18,.89,.32,1.28);
}
.toast::after {
  content: ""; position: absolute; left: 30px; bottom: -18px;
  border-width: 18px 16px 0 0; border-style: solid;
  border-color: var(--cream) transparent transparent transparent;
  filter: drop-shadow(0 3px 0 var(--ink));
}
.toast.toast--red { background: var(--red); color: var(--cream); }
.toast.toast--red::after { border-top-color: var(--red); }
.toast.is-leaving { animation: toastOut 0.3s ease forwards; }

/* ===== 17. MENU PAGE ===================================== */
.menu-hero {
  position: relative; padding: calc(var(--header-h) + 3rem) 0 3rem;
  border-bottom: var(--border-thick); overflow: hidden; text-align: center;
}
.menu-hero-bg {
  position: absolute; inset: 0; z-index: 0; background-color: #1a1410;
  background-image: linear-gradient(135deg, rgba(155,16,21,0.4), rgba(11,15,18,0.5)), url("assets/images/texture-graffiti.webp");
  background-size: cover; background-position: center;
}
.menu-hero .hero-overlay { background: linear-gradient(to bottom, rgba(11,15,18,0.55), var(--bg-deep)); }
.menu-hero-inner { position: relative; z-index: 5; }
.menu-title { align-items: center; }
.menu-title .word-2 { color: var(--yellow); text-shadow: 6px 6px 0 var(--red), 7px 7px 0 var(--ink); }
.menu-flight-bubble { display: inline-block; margin-top: 1.5rem; transform: rotate(-1.5deg); font-family: var(--font-marker); }
.floaty--lisa { width: clamp(90px, 12vw, 150px); bottom: -10px; right: 5%; z-index: 6; animation: floatY 6s ease-in-out infinite; }

.menu-app { padding: var(--sp-5) 0 var(--sp-7); }

/* Tabs */
.menu-tabs { display: flex; flex-wrap: wrap; gap: 0.7rem; justify-content: center; margin-bottom: var(--sp-4); }
.tab {
  font-family: var(--font-display); font-size: 1.25rem; letter-spacing: 1px;
  background: var(--charcoal); color: var(--cream);
  border: var(--border); border-radius: 50px; padding: 0.5rem 1.2rem;
  box-shadow: var(--shadow-sm); transition: transform 0.12s ease, background 0.2s ease, color 0.2s ease, box-shadow 0.12s ease;
}
.tab:hover { transform: translateY(-3px); }
.tab.is-active { background: var(--yellow); color: var(--ink); transform: rotate(-2deg) translateY(-2px); box-shadow: var(--shadow); }

/* Controls */
.menu-controls {
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 1rem;
  background: var(--charcoal); border: var(--border-thick); border-radius: var(--radius);
  box-shadow: var(--shadow); padding: 1.3rem; margin-bottom: 1.2rem;
}
.search-wrap { position: relative; display: flex; align-items: center; }
.search-ico { position: absolute; left: 14px; font-size: 1.1rem; pointer-events: none; }
#menuSearch {
  width: 100%; background: var(--bg-deep); color: var(--cream);
  border: var(--border); border-radius: 50px; padding: 0.7rem 1rem 0.7rem 2.6rem;
}
#menuSearch:focus { outline: none; box-shadow: var(--shadow-yellow); }
.control { display: flex; flex-direction: column; gap: 0.35rem; }
.control label { font-family: var(--font-display); font-size: 1rem; letter-spacing: 1px; color: var(--amber); }
.control select {
  background: var(--bg-deep); color: var(--cream);
  border: var(--border); border-radius: 10px; padding: 0.6rem 0.7rem; cursor: pointer;
}
.control select:focus { outline: none; box-shadow: var(--shadow-yellow); }

/* Tag filters */
.tag-filters {
  border: none; display: flex; flex-wrap: wrap; align-items: center; gap: 0.7rem;
  margin-bottom: 1.4rem;
}
.tag-filters-label { color: var(--amber); font-size: 1.3rem; margin-right: 0.3rem; }
.tag-toggle { position: relative; cursor: pointer; }
.tag-toggle input { position: absolute; opacity: 0; width: 0; height: 0; }
.tag-toggle span {
  display: inline-block; font-weight: 800; font-size: 0.9rem;
  background: var(--charcoal); color: var(--cream);
  border: var(--border); border-radius: 50px; padding: 0.4rem 0.9rem;
  box-shadow: var(--shadow-sm); transition: transform 0.12s ease, background 0.2s ease, color 0.2s ease;
}
.tag-toggle:hover span { transform: translateY(-2px); }
.tag-toggle input:checked + span { background: var(--hop); color: var(--ink); transform: rotate(-2deg); }
.tag-toggle input:focus-visible + span { outline: 3px dashed var(--yellow); outline-offset: 2px; }

.menu-note {
  font-family: var(--font-marker); color: var(--ink); background: var(--amber);
  border: var(--border); border-radius: 14px; box-shadow: var(--shadow-sm);
  padding: 0.8rem 1.2rem; margin-bottom: 1.4rem; transform: rotate(-0.6deg);
}
.menu-note:empty { display: none; }
.menu-note strong { font-weight: 900; }
.result-count { color: var(--gray); font-weight: 700; margin-bottom: 1rem; }

/* Menu cards */
.menu-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-3); }
.menu-card {
  position: relative; background: var(--charcoal);
  border: var(--border-thick); border-radius: var(--radius); box-shadow: var(--shadow);
  padding: 1.3rem 1.3rem 1.4rem; display: flex; flex-direction: column; gap: 0.6rem;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
  animation: cardIn 0.4s ease both;
}
.menu-card:hover { transform: rotate(-1.2deg) translateY(-6px); box-shadow: var(--shadow-lg); }
.menu-card:nth-child(even):hover { transform: rotate(1.2deg) translateY(-6px); }
.mc-cat {
  position: absolute; top: -14px; left: 16px; transform: rotate(-3deg);
  font-family: var(--font-marker); font-size: 0.75rem;
  background: var(--red); color: var(--cream); border: 3px solid var(--ink);
  border-radius: 20px; padding: 0.1rem 0.7rem; box-shadow: var(--shadow-sm);
}
.mc-sticker {
  position: absolute; top: -18px; right: -10px; font-size: 1.6rem;
  transform: rotate(12deg); filter: drop-shadow(2px 2px 0 rgba(0,0,0,0.4));
  transition: transform 0.2s ease;
}
.menu-card:hover .mc-sticker { transform: rotate(-12deg) scale(1.25); }
.mc-head { display: flex; justify-content: space-between; gap: 0.6rem; align-items: flex-start; margin-top: 0.4rem; }
.mc-name { font-family: var(--font-display); font-size: 1.4rem; color: var(--yellow); letter-spacing: 0.5px; line-height: 1.05; -webkit-text-stroke: 0.4px var(--ink); }
.mc-sub { font-size: 0.78rem; color: var(--hop); font-weight: 800; text-transform: uppercase; letter-spacing: 0.5px; }
.mc-style { font-weight: 700; color: var(--cream); }
.mc-desc { font-size: 0.88rem; color: var(--gray); font-weight: 500; }
.mc-meta { display: flex; flex-wrap: wrap; gap: 0.4rem; margin-top: 0.2rem; }
.mc-badge {
  font-size: 0.72rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.5px;
  background: var(--bg-deep); color: var(--amber);
  border: 2px solid var(--ink); border-radius: 30px; padding: 0.12rem 0.55rem;
}
.mc-badge--abv { background: var(--amber); color: var(--ink); }
.mc-foot { display: flex; align-items: flex-end; justify-content: space-between; gap: 0.6rem; margin-top: auto; padding-top: 0.6rem; }
.mc-prices { display: flex; flex-direction: column; gap: 0.15rem; }
.mc-price { font-family: var(--font-display); font-size: 1.5rem; color: var(--cream); line-height: 1; }
.mc-price-line { font-size: 0.8rem; color: var(--gray); font-weight: 700; }
.mc-price-line b { color: var(--amber); }
.mc-want {
  font-family: var(--font-display); font-size: 0.95rem; letter-spacing: 0.5px;
  background: var(--yellow); color: var(--ink); border: var(--border); border-radius: 40px;
  padding: 0.4rem 0.9rem; box-shadow: var(--shadow-sm); white-space: nowrap;
  transition: transform 0.12s ease, box-shadow 0.12s ease, background 0.2s ease;
}
.mc-want:hover { transform: translate(-2px,-2px); box-shadow: 5px 5px 0 var(--ink); background: var(--amber); }
.mc-want:active { transform: translate(1px,1px); box-shadow: 2px 2px 0 var(--ink); }

.empty-state { text-align: center; padding: var(--sp-5) 1rem; }
.empty-ico { font-size: 4rem; display: block; margin-bottom: 0.6rem; }
.empty-state h3 { font-family: var(--font-display); font-size: 2rem; color: var(--yellow); margin-bottom: 0.5rem; }
.empty-state p { color: var(--gray); font-weight: 600; margin-bottom: 1.4rem; }

/* ===== 18. KEYFRAMES ===================================== */
@keyframes heroPan { from { background-position: 50% 50%; } to { background-position: 55% 40%; } }
@keyframes floatY { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-16px); } }
@keyframes bounceY { 0%,100% { transform: translateY(0); } 50% { transform: translateY(8px); } }
@keyframes pop { 0%,100% { transform: scale(1); } 50% { transform: scale(1.06); } }
@keyframes scrollX { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@keyframes neonFlicker {
  0%, 18%, 22%, 100% { opacity: 1; }
  20%, 24% { opacity: 0.45; }
}
@keyframes toastIn { from { transform: translateY(30px) scale(0.85); opacity: 0; } to { transform: translateY(0) scale(1); opacity: 1; } }
@keyframes toastOut { to { transform: translateY(20px) scale(0.9); opacity: 0; } }
@keyframes cardIn { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: translateY(0); } }

/* Scroll reveal (added by JS) */
.reveal { opacity: 0; transform: translateY(30px); transition: opacity 0.6s ease, transform 0.6s ease; }
.reveal.in-view { opacity: 1; transform: none; }

/* ===== 19. RESPONSIVE ==================================== */
@media (max-width: 1024px) {
  .feature-grid { grid-template-columns: repeat(2, 1fr); }
  .food-grid { grid-template-columns: repeat(2, 1fr); }
  .menu-grid { grid-template-columns: repeat(2, 1fr); }
  .masonry { columns: 3; }
  .footer-inner { grid-template-columns: 1fr 1fr; }
  .menu-controls { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 820px) {
  :root { --header-h: 66px; }

  /* Mobile nav */
  .hamburger { display: flex; }
  .main-nav {
    position: fixed; inset: var(--header-h) 0 auto 0;
    flex-direction: column; align-items: stretch; gap: 0;
    background: var(--charcoal); border-bottom: var(--border-thick);
    padding: 1rem 1.2rem 1.6rem; max-height: calc(100vh - var(--header-h));
    overflow-y: auto;
    transform: translateY(-130%); transition: transform 0.3s ease;
    box-shadow: 0 12px 0 rgba(0,0,0,0.3);
  }
  .main-nav.is-open { transform: translateY(0); }
  .nav-link { font-size: 1.6rem; padding: 0.8rem 0.5rem; border-bottom: 2px dashed rgba(255,244,214,0.15); }
  .nav-link::after { display: none; }
  .nav-cta { margin: 0.8rem 0 0; align-self: flex-start; }

  .about-grid { grid-template-columns: 1fr; }
  .xp-grid { grid-template-columns: 1fr; }
  .mood-zone { flex-direction: column; }
  .char--homer { width: 150px; }
  .events-grid { grid-template-columns: 1fr; }
  .find-grid { grid-template-columns: 1fr; }
  .section { padding: var(--sp-6) 0; }
}

@media (max-width: 560px) {
  .feature-grid { grid-template-columns: 1fr; }
  .food-grid { grid-template-columns: 1fr; }
  .menu-grid { grid-template-columns: 1fr; }
  .masonry { columns: 2; column-gap: 0.8rem; }
  .gtile { margin-bottom: 0.8rem; }
  .menu-controls { grid-template-columns: 1fr; }
  .footer-inner { grid-template-columns: 1fr; }
  .floaty--family { display: none; }
  .btn { font-size: 1.1rem; }
  .hours-list li { flex-direction: column; align-items: flex-start; gap: 0.1rem; }
  /* Keep Lisa a small corner accent and leave room beside the flight bubble */
  .floaty--lisa { width: 64px; right: 2%; }
  .menu-flight-bubble { max-width: 82%; }
  /* Find Us: shrink Lisa and wrap the bubble clear of her so text isn't hidden */
  .char--lisa { width: 60px; top: -26px; }
  .form-bubble { max-width: calc(100% - 76px); }
}

/* ===== 20. PRINT ========================================= */
/* NOTE: Motion is intentionally ALWAYS ON at the owner's request.
   We deliberately do NOT honour prefers-reduced-motion here, so the
   bubbles, floating characters, marquee and reveals always animate —
   even when the OS "reduce animations" / "animation effects off"
   accessibility setting is enabled (which Chrome forwards to the page). */

@media print {
  .site-header, .toast-wrap, .hero-btns, .menu-controls, .tag-filters, .floaty { display: none !important; }
  body { background: #fff; color: #000; }
}
