/*
Theme Name: MayaMoyo Dishes
Theme URI: https://mayamoyodishes.com
Author: MayaMoyo Dishes
Description: A premium WordPress theme for MayaMoyo Dishes African catering in the DMV. Warm Afro-editorial design (deep green, antique gold, cream & terracotta), Fraunces + Hanken Grotesk typography, online ordering, catering inquiry, full local SEO with schema, and responsive design.
Version: 2.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: mayamoyo
*/

/* ============================================
   SELF-HOSTED FONTS (latin subsets only — drops unused unicode ranges)
   ============================================ */
/* Fraunces — display serif, normal weight, latin */
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url(fonts/fraunces-5.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* Hanken Grotesk — sans-serif, normal weight, latin */
@font-face {
  font-family: 'Hanken Grotesk';
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url(fonts/hanken-9.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

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

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

body {
  font-family: 'Hanken Grotesk', sans-serif;
  background-color: #112318;
  color: var(--text-body);
  line-height: 1.65;
  font-size: 1.0625rem;
  letter-spacing: 0.001em;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Fraunces', serif;
  color: var(--brand-yellow);
  line-height: 1.08;
  font-weight: 600;
  letter-spacing: -0.018em;
  font-optical-sizing: auto;
}

p {
  color: var(--text-body);
}

a {
  color: var(--brand-yellow);
  text-decoration: none;
  transition: color 0.2s ease;
}

a:hover {
  color: var(--brand-yellow-light);
}

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

button {
  font-family: 'Hanken Grotesk', sans-serif;
  cursor: pointer;
  border: none;
  background: none;
}

/* ============================================
   CSS CUSTOM PROPERTIES
   ============================================ */
:root {
  /* Deep, warm green-black — sophisticated, not flat */
  --brand-dark-green: #112318;
  --brand-dark-green-light: #18301F;
  --brand-dark-green-lighter: #21402B;
  /* Antique gold — refined, not neon */
  --brand-yellow: #E8B53F;
  --brand-yellow-light: #F3CE6C;
  --brand-yellow-dark: #C2902A;
  --accent: #E8B53F;
  /* West-African clay accent */
  --terracotta: #C75B39;
  --terracotta-light: #D9714E;
  /* Warm bone / cream editorial surfaces */
  --cream: #F4ECDC;
  --cream-card: #FBF6EB;
  --ink: #142319;
  --ink-soft: rgba(20, 35, 25, 0.74);
  --ink-faint: rgba(20, 35, 25, 0.55);
  /* Cards on dark */
  --card-bg: #17311F;
  --card-bg-light: #1F3C28;
  /* Warm off-white body text on dark */
  --text-body: #ECE3D1;
  --text-soft: rgba(236, 227, 209, 0.80);
  --border-color: rgba(232, 181, 63, 0.20);
  --border-color-light: rgba(232, 181, 63, 0.34);
  --hairline: rgba(236, 227, 209, 0.12);
  --text-muted: rgba(236, 227, 209, 0.66);
  --text-muted-light: rgba(236, 227, 209, 0.46);
  --radius: 0.625rem;
  --radius-lg: 1.125rem;
  --radius-xl: 1.625rem;
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.18);
  --shadow-md: 0 6px 16px -6px rgba(0,0,0,0.34), 0 2px 5px -2px rgba(0,0,0,0.22);
  --shadow-lg: 0 18px 40px -16px rgba(0,0,0,0.46), 0 6px 14px -8px rgba(0,0,0,0.30);
  --shadow-xl: 0 34px 64px -22px rgba(0,0,0,0.55), 0 12px 24px -12px rgba(0,0,0,0.34);
  --shadow-cream: 0 18px 44px -20px rgba(60, 42, 18, 0.30), 0 4px 12px -6px rgba(60, 42, 18, 0.16);
}

/* Google Fonts are loaded via functions.php wp_enqueue_style */

/* ============================================
   UTILITIES
   ============================================ */
.container-custom {
  max-width: 1280px;
  margin: 0 auto;
  padding-left: 1rem;
  padding-right: 1rem;
}

@media (min-width: 640px) {
  .container-custom {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }
}

@media (min-width: 1024px) {
  .container-custom {
    padding-left: 2rem;
    padding-right: 2rem;
  }
}

.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: var(--brand-yellow);
  color: #1A1206;
  font-weight: 600;
  padding: 0.9rem 1.85rem;
  border-radius: 999px;
  transition: transform 0.25s cubic-bezier(0.22,1,0.36,1), box-shadow 0.25s ease, background-color 0.25s ease;
  font-size: 0.95rem;
  letter-spacing: 0.01em;
  border: 1px solid var(--brand-yellow);
  cursor: pointer;
  text-decoration: none;
  box-shadow: 0 10px 24px -12px rgba(232, 181, 63, 0.7);
}

.btn-primary:hover {
  background-color: var(--brand-yellow-light);
  border-color: var(--brand-yellow-light);
  transform: translateY(-2px);
  box-shadow: 0 16px 30px -12px rgba(232, 181, 63, 0.8);
  color: #1A1206;
}

.btn-primary svg {
  margin-left: 0.5rem;
  width: 1.15rem;
  height: 1.15rem;
}

.btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: transparent;
  color: var(--brand-yellow);
  font-weight: 600;
  padding: 0.9rem 1.85rem;
  border-radius: 999px;
  transition: all 0.25s ease;
  font-size: 0.95rem;
  letter-spacing: 0.01em;
  border: 1px solid var(--border-color-light);
  cursor: pointer;
  text-decoration: none;
}

.btn-secondary:hover {
  background-color: var(--brand-yellow);
  border-color: var(--brand-yellow);
  color: #1A1206;
  transform: translateY(-2px);
}

/* Eyebrow / kicker label — editorial accent above titles */
.kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  font-family: 'Hanken Grotesk', sans-serif;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--brand-yellow);
  margin-bottom: 1rem;
}
.kicker::before {
  content: "";
  width: 1.75rem;
  height: 1px;
  background: var(--brand-yellow);
  opacity: 0.55;
}
.text-center .kicker, .kicker.centered { justify-content: center; }
.text-center .kicker::after, .kicker.centered::after {
  content: "";
  width: 1.75rem;
  height: 1px;
  background: var(--brand-yellow);
  opacity: 0.55;
}

.section-title {
  font-size: 2.1rem;
  font-weight: 600;
  text-align: center;
  margin-bottom: 1.5rem;
  color: var(--brand-yellow);
  font-family: 'Fraunces', serif;
  letter-spacing: -0.02em;
}

@media (min-width: 768px) {
  .section-title {
    font-size: 2.6rem;
  }
}

@media (min-width: 1024px) {
  .section-title {
    font-size: 3.1rem;
  }
}

.section-subtitle {
  font-size: 1.125rem;
  text-align: center;
  color: var(--text-muted);
  margin-bottom: 3rem;
  max-width: 44rem;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.7;
}

@media (min-width: 768px) {
  .section-subtitle {
    font-size: 1.25rem;
  }
}

/* ============================================
   ANIMATIONS
   ============================================ */
@keyframes heroZoom {
  from { transform: scale(1); }
  to { transform: scale(1.12); }
}

.hero-zoom {
  animation: heroZoom 18s ease-out forwards;
  will-change: transform;
}

@media (prefers-reduced-motion: reduce) {
  .hero-zoom { animation: none; }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes scaleIn {
  from {
    opacity: 0;
    transform: scale(0.94) translateY(16px);
  }
  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

@keyframes slideInLeft {
  from {
    opacity: 0;
    transform: translateX(-20px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes spin {
  to { transform: rotate(360deg); }
}

.animate-fade-in-up {
  animation: fadeInUp 0.7s ease forwards;
}

.animate-fade-in {
  animation: fadeIn 0.8s ease forwards;
}

.animate-scale-in {
  animation: scaleIn 0.6s ease forwards;
}

.animate-delay-1 { animation-delay: 0.1s; }
.animate-delay-2 { animation-delay: 0.2s; }
.animate-delay-3 { animation-delay: 0.3s; }
.animate-delay-4 { animation-delay: 0.4s; }
.animate-delay-5 { animation-delay: 0.5s; }

/* Scroll reveal */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

.reveal-scale {
  opacity: 0;
  transform: scale(0.94) translateY(16px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.reveal-scale.visible {
  opacity: 1;
  transform: scale(1) translateY(0);
}

/* Stagger children */
.stagger-container > *:nth-child(1) { transition-delay: 0.08s; }
.stagger-container > *:nth-child(2) { transition-delay: 0.16s; }
.stagger-container > *:nth-child(3) { transition-delay: 0.24s; }
.stagger-container > *:nth-child(4) { transition-delay: 0.32s; }
.stagger-container > *:nth-child(5) { transition-delay: 0.40s; }
.stagger-container > *:nth-child(6) { transition-delay: 0.48s; }

/* ============================================
   HEADER / NAVIGATION
   ============================================ */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 50;
  transition: all 0.5s ease-out;
  border-bottom: 1px solid transparent;
  padding: 1rem 0;
}

.site-header.scrolled {
  background-color: rgba(13, 28, 19, 0.82);
  backdrop-filter: blur(16px) saturate(140%);
  -webkit-backdrop-filter: blur(16px) saturate(140%);
  box-shadow: 0 8px 30px -12px rgba(0,0,0,0.5);
  padding: 0.5rem 0;
  border-bottom-color: var(--hairline);
}

.site-header .container-custom {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.site-logo {
  font-size: 1.55rem;
  font-weight: 600;
  font-family: 'Fraunces', serif;
  letter-spacing: -0.02em;
  color: var(--brand-yellow);
  text-decoration: none;
}
.site-logo::first-letter { color: var(--terracotta-light); }

.site-logo:hover {
  color: var(--brand-yellow-light);
}

/* Desktop nav */
.desktop-nav {
  display: none;
}

@media (min-width: 768px) {
  .desktop-nav {
    display: flex;
    align-items: center;
  }
}

.nav-menu {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  align-items: center;
  gap: 0.25rem;
}

.nav-menu li {
  position: relative;
}

.nav-menu a {
  position: relative;
  display: block;
  padding: 0.5rem 0.85rem;
  color: var(--text-body);
  font-weight: 500;
  font-size: 0.95rem;
  border-radius: var(--radius);
  transition: color 0.2s ease;
  text-decoration: none;
}

.nav-menu a::after {
  content: "";
  position: absolute;
  left: 0.85rem;
  right: 0.85rem;
  bottom: 0.3rem;
  height: 1.5px;
  background: var(--brand-yellow);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.28s cubic-bezier(0.22,1,0.36,1);
}

.nav-menu a:hover,
.nav-menu a.current {
  color: var(--brand-yellow);
}

.nav-menu a:hover::after,
.nav-menu a.current::after { transform: scaleX(1); }

.nav-separator {
  width: 1px;
  height: 1.5rem;
  background-color: var(--border-color);
  margin: 0 0.75rem;
}

/* Cart icon */
.cart-icon {
  position: relative;
  display: flex;
  align-items: center;
  padding: 0.5rem;
  color: var(--brand-yellow);
  transition: color 0.2s ease;
}

.cart-icon:hover {
  color: var(--brand-yellow-light);
}

.cart-icon svg {
  width: 1.5rem;
  height: 1.5rem;
}

.cart-badge {
  position: absolute;
  top: -4px;
  right: -4px;
  background-color: var(--accent);
  color: var(--brand-dark-green);
  font-size: 0.75rem;
  font-weight: 700;
  border-radius: 50%;
  width: 1.25rem;
  height: 1.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Order button */
.order-btn {
  display: flex;
  align-items: center;
  background-color: var(--brand-yellow);
  color: #1A1206;
  padding: 0.55rem 1.4rem;
  border-radius: 999px;
  font-weight: 600;
  font-size: 0.95rem;
  transition: transform 0.2s ease, background-color 0.2s ease, box-shadow 0.2s ease;
  text-decoration: none;
  margin-left: 0.75rem;
  box-shadow: 0 8px 20px -10px rgba(232,181,63,0.7);
}

.order-btn:hover {
  background-color: var(--brand-yellow-light);
  color: #1A1206;
}

/* Mobile menu */
.mobile-menu-btn {
  display: flex;
  align-items: center;
  color: var(--brand-yellow);
  padding: 0.5rem;
  background: none;
  border: none;
}

.mobile-menu-btn svg {
  width: 1.5rem;
  height: 1.5rem;
}

@media (min-width: 768px) {
  .mobile-menu-btn {
    display: none;
  }
}

.mobile-nav-wrapper {
  display: none;
  background-color: var(--brand-dark-green);
  border-top: 1px solid var(--border-color);
  overflow: hidden;
  transition: max-height 0.3s ease, opacity 0.3s ease;
}

.mobile-nav-wrapper.open {
  display: block;
}

.mobile-nav {
  list-style: none;
  padding: 1rem 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.mobile-nav a {
  display: block;
  padding: 0.5rem 0.75rem;
  color: var(--brand-yellow);
  font-weight: 500;
  border-radius: var(--radius);
  text-decoration: none;
  text-align: left;
  width: 100%;
}

.mobile-nav a:hover,
.mobile-nav a.current {
  background-color: var(--brand-yellow);
  color: var(--brand-dark-green);
}

.mobile-order-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--brand-yellow);
  color: var(--brand-dark-green);
  padding: 0.75rem;
  border-radius: var(--radius);
  font-weight: 600;
  margin-top: 0.5rem;
  text-decoration: none;
  width: 100%;
}

.mobile-order-btn:hover {
  background-color: var(--brand-yellow-light);
}

/* Mobile cart icon */
.mobile-header-icons {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

@media (min-width: 768px) {
  .mobile-header-icons {
    display: none;
  }
}

/* ============================================
   HERO SECTION
   ============================================ */
.hero-section {
  position: relative;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  overflow: hidden;
  margin-top: -80px;
  padding-top: 80px;
}

.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}

.hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  opacity: 0.92;
}

.hero-overlay {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(120% 90% at 50% 18%, rgba(17,35,24,0.10), rgba(17,35,24,0.62) 58%, rgba(12,26,18,0.92) 100%),
    linear-gradient(to top, rgba(12,26,18,0.96) 0%, rgba(17,35,24,0.34) 46%, rgba(17,35,24,0.30) 100%);
  z-index: 1;
}

.hero-content {
  position: relative;
  z-index: 10;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.hero-content h1 {
  font-size: 3.1rem;
  font-weight: 600;
  margin-bottom: 1.5rem;
  color: #FBF6EB;
  letter-spacing: -0.025em;
  line-height: 1.02;
  text-shadow: 0 2px 30px rgba(0,0,0,0.35);
}
.hero-content h1 em {
  font-style: italic;
  color: var(--brand-yellow);
}

@media (min-width: 768px) {
  .hero-content h1 {
    font-size: 4.4rem;
  }
}

@media (min-width: 1024px) {
  .hero-content h1 {
    font-size: 5.4rem;
  }
}

.hero-subtitle {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-size: 1.4rem;
  margin-bottom: 1.75rem;
  color: var(--brand-yellow);
  letter-spacing: 0;
}

@media (min-width: 768px) {
  .hero-subtitle {
    font-size: 1.7rem;
  }
}

.hero-description {
  font-size: 1.075rem;
  margin-bottom: 2.5rem;
  max-width: 40rem;
  color: rgba(251, 246, 235, 0.86);
  line-height: 1.7;
}

@media (min-width: 768px) {
  .hero-description {
    font-size: 1.25rem;
  }
}

/* ============================================
   SECTIONS
   ============================================ */
.section-padding {
  padding: 5rem 0;
}

@media (min-width: 768px) {
  .section-padding {
    padding: 7rem 0;
  }
}

.bg-brand {
  background-color: var(--brand-dark-green);
  position: relative;
}

/* Fine film grain over the whole page for tactile depth */
body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  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'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* Decorative underline accent under centered section titles */
.section-title::after {
  content: "";
  display: block;
  width: 3rem;
  height: 2px;
  margin: 1.1rem auto 0;
  background: var(--brand-yellow);
  opacity: 0.8;
  border-radius: 2px;
}

/* ============================================
   EDITORIAL CREAM SECTIONS (light rhythm)
   ============================================ */
.bg-secondary {
  background-color: var(--cream);
  color: var(--ink);
  position: relative;
}

/* Warm paper grain on cream sections */
.bg-secondary::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: radial-gradient(rgba(120, 88, 36, 0.05) 1px, transparent 1px);
  background-size: 4px 4px;
  opacity: 0.6;
}
.bg-secondary > * { position: relative; z-index: 1; }

.bg-secondary h1,
.bg-secondary h2,
.bg-secondary h3,
.bg-secondary h4,
.bg-secondary .section-title,
.bg-secondary .text-brand,
.bg-secondary .map-link h3 { color: var(--ink); }

.bg-secondary p,
.bg-secondary li,
.bg-secondary .split-section p,
.bg-secondary .about-grid p { color: var(--ink-soft); }

.bg-secondary .section-subtitle,
.bg-secondary .text-muted,
.bg-secondary .menu-section-note { color: var(--ink-faint); }

/* Eyebrow accent stays terracotta on cream */
.bg-secondary .kicker { color: var(--terracotta); }
.bg-secondary .kicker::before,
.bg-secondary .kicker::after { background: var(--terracotta); opacity: 0.5; }
.bg-secondary .section-title::after { background: var(--terracotta); }

/* Ivory cards on cream */
.bg-secondary .faq-item,
.bg-secondary .testimonial-card,
.bg-secondary .card,
.bg-secondary .card-large,
.bg-secondary .menu-item-card {
  background-color: var(--cream-card);
  border: 1px solid rgba(120, 88, 36, 0.14);
  box-shadow: var(--shadow-cream);
}
.bg-secondary .faq-item h3,
.bg-secondary .testimonial-card p,
.bg-secondary .menu-item-card h3 { color: var(--ink); }
.bg-secondary .testimonial-highlight { color: var(--terracotta); }
.bg-secondary .star-filled { color: var(--brand-yellow-dark); fill: var(--brand-yellow-dark); }

/* Primary CTA inverts to deep green on cream for contrast */
.bg-secondary .btn-primary {
  background-color: var(--brand-dark-green);
  color: var(--cream);
  border-color: var(--brand-dark-green);
}
.bg-secondary .btn-primary:hover {
  background-color: var(--terracotta);
  border-color: var(--terracotta);
  color: #fff;
}
.bg-secondary .split-section img,
.bg-secondary .about-image { border-color: rgba(120, 88, 36, 0.18); }

/* ============================================
   MENU ITEMS
   ============================================ */
.menu-item-card {
  background-color: var(--card-bg);
  padding: 1.5rem;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--border-color);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.menu-item-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-xl);
}

.menu-item-card h3 {
  font-size: 1.25rem;
  font-weight: 600;
  font-family: 'Fraunces', serif;
  color: var(--brand-yellow);
  margin-bottom: 0.5rem;
}

.menu-item-card h3 a {
  color: var(--brand-yellow);
  text-decoration: none;
  transition: color 0.2s ease;
}

.menu-item-card h3 a:hover {
  color: var(--brand-yellow-light);
}

.menu-item-card .price {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--accent);
  white-space: nowrap;
}

.menu-item-card p {
  color: var(--text-soft);
  font-size: 0.875rem;
}

.menu-item-card .view-link {
  display: inline-block;
  margin-top: 0.75rem;
  font-size: 0.875rem;
  color: var(--accent);
  text-decoration: none;
}

.menu-item-card .view-link:hover {
  color: var(--brand-yellow-light);
}

/* ============================================
   GRID SYSTEM
   ============================================ */
.grid-2 {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}

@media (min-width: 768px) {
  .grid-2 {
    grid-template-columns: repeat(2, 1fr);
  }
}

.grid-3 {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}

@media (min-width: 768px) {
  .grid-3 {
    grid-template-columns: repeat(3, 1fr);
  }
}

.grid-4 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5rem;
}

@media (min-width: 768px) {
  .grid-4 {
    grid-template-columns: repeat(4, 1fr);
  }
}

.grid-gallery {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}

@media (min-width: 640px) {
  .grid-gallery {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 768px) {
  .grid-gallery {
    grid-template-columns: repeat(4, 1fr);
  }
}

@media (min-width: 1024px) {
  .grid-gallery {
    grid-template-columns: repeat(5, 1fr);
  }
}

/* ============================================
   CARDS
   ============================================ */
.card {
  background-color: var(--card-bg);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--border-color);
}

.card-large {
  background-color: var(--card-bg);
  border-radius: var(--radius-lg);
  padding: 2rem;
  box-shadow: var(--shadow-xl);
  border: 1px solid var(--border-color);
}

@media (min-width: 768px) {
  .card-large {
    padding: 3rem;
  }
}

/* ============================================
   TESTIMONIALS
   ============================================ */
.testimonial-card {
  background-color: var(--card-bg);
  padding: 1.5rem;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  border: 1px solid var(--border-color);
  transition: transform 0.3s ease;
}

.testimonial-card:hover {
  transform: translateY(-5px);
}

.testimonial-highlight {
  color: var(--accent);
  font-weight: 700;
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 0.5rem;
}

.star-rating {
  display: flex;
  gap: 0.25rem;
  margin-bottom: 1rem;
}

.star-rating svg {
  width: 1.25rem;
  height: 1.25rem;
}

.star-filled {
  color: #E8B53F;
  fill: #E8B53F;
}

.star-empty {
  color: rgba(232, 181, 63, 0.3);
}

/* ============================================
   GALLERY
   ============================================ */
.gallery-item {
  overflow: hidden;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--hairline);
  position: relative;
}

.gallery-item::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(12,26,18,0.55), transparent 55%);
  opacity: 0;
  transition: opacity 0.4s ease;
  pointer-events: none;
}

.gallery-item:hover::after { opacity: 1; }

.gallery-item img {
  width: 100%;
  height: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  transition: transform 0.7s cubic-bezier(0.22,1,0.36,1);
}

.gallery-item:hover img {
  transform: scale(1.06);
}

/* ============================================
   FORMS
   ============================================ */
.form-group {
  margin-bottom: 1.5rem;
}

.form-group label {
  display: block;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--text-muted);
  margin-bottom: 0.25rem;
}

.form-input {
  width: 100%;
  padding: 0.75rem 1rem;
  background-color: rgba(255,255,255,0.03);
  border: 1px solid var(--border-color);
  border-radius: var(--radius);
  color: var(--text-body);
  font-family: 'Hanken Grotesk', sans-serif;
  font-size: 1rem;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.form-input::placeholder {
  color: var(--text-muted-light);
}

.form-input:focus {
  outline: none;
  border-color: var(--brand-yellow);
  box-shadow: 0 0 0 3px rgba(232, 181, 63, 0.1);
}

.form-input.with-icon {
  padding-left: 2.5rem;
}

.form-input-icon {
  position: relative;
}

.form-input-icon svg {
  position: absolute;
  left: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1.25rem;
  height: 1.25rem;
  color: var(--text-muted);
  pointer-events: none;
}

textarea.form-input {
  resize: vertical;
  min-height: 120px;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}

@media (min-width: 768px) {
  .form-row {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* Spinner */
.spinner {
  display: inline-block;
  width: 1.25rem;
  height: 1.25rem;
  border: 2px solid rgba(13, 28, 19, 0.3);
  border-top-color: var(--brand-dark-green);
  border-radius: 50%;
  animation: spin 1s linear infinite;
  margin-right: 0.75rem;
}

/* ============================================
   CART
   ============================================ */
.cart-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  background-color: var(--card-bg);
  padding: 1.5rem;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--border-color);
  margin-bottom: 1.5rem;
}

@media (min-width: 768px) {
  .cart-item {
    flex-direction: row;
  }
}

.cart-item-info {
  flex-grow: 1;
  margin-bottom: 1rem;
  text-align: center;
}

@media (min-width: 768px) {
  .cart-item-info {
    margin-bottom: 0;
    text-align: left;
  }
}

.cart-item-info h2 {
  font-size: 1.5rem;
  font-weight: 600;
  font-family: 'Fraunces', serif;
  color: var(--brand-yellow);
  margin-bottom: 0.25rem;
}

.cart-item-info .price {
  color: var(--accent);
  font-size: 1.125rem;
}

.cart-item-controls {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.qty-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border: 1px solid var(--brand-yellow);
  border-radius: var(--radius);
  color: var(--brand-yellow);
  background: transparent;
  transition: all 0.2s ease;
  cursor: pointer;
}

.qty-btn:hover {
  background-color: var(--brand-yellow);
  color: var(--brand-dark-green);
}

.qty-btn svg {
  width: 1rem;
  height: 1rem;
}

.qty-value {
  font-size: 1.25rem;
  font-weight: 700;
  width: 2.5rem;
  text-align: center;
}

.cart-item-total {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--brand-yellow);
  margin-left: 0;
  margin-top: 1rem;
}

@media (min-width: 768px) {
  .cart-item-total {
    margin-left: 2rem;
    margin-top: 0;
  }
}

.remove-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  color: #ef4444;
  background: transparent;
  border: none;
  cursor: pointer;
  margin-left: 0;
  margin-top: 1rem;
  transition: color 0.2s ease;
}

@media (min-width: 768px) {
  .remove-btn {
    margin-left: 1rem;
    margin-top: 0;
  }
}

.remove-btn:hover {
  color: #f87171;
}

.remove-btn svg {
  width: 1.25rem;
  height: 1.25rem;
}

.cart-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: calc(100vh - 10rem);
  text-align: center;
}

.cart-empty svg {
  width: 6rem;
  height: 6rem;
  color: rgba(232, 181, 63, 0.3);
  margin-bottom: 2rem;
}

.order-summary {
  background-color: var(--card-bg);
  padding: 2rem;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  border: 1px solid var(--border-color);
}

.order-summary-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.5rem;
}

.order-summary-header h2 {
  font-size: 1.5rem;
  font-weight: 600;
  font-family: 'Fraunces', serif;
  color: var(--brand-yellow);
}

.clear-cart-btn {
  color: rgba(239, 68, 68, 0.8);
  font-size: 0.875rem;
  background: none;
  border: none;
  cursor: pointer;
  transition: color 0.2s ease;
}

.clear-cart-btn:hover {
  color: #f87171;
}

.order-total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 1.5rem;
  font-weight: 700;
  padding-top: 1.5rem;
  border-top: 1px solid var(--border-color);
  margin-bottom: 2rem;
}

/* ============================================
   CHECKOUT
   ============================================ */
.checkout-progress {
  width: 100%;
  background-color: var(--border-color);
  border-radius: 999px;
  height: 0.625rem;
  margin-bottom: 2.5rem;
}

.checkout-progress-bar {
  background-color: var(--accent);
  height: 100%;
  border-radius: 999px;
  transition: width 0.5s ease-in-out;
}

.checkout-step-buttons {
  display: flex;
  justify-content: space-between;
  margin-top: 2.5rem;
}

.order-type-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}

@media (min-width: 768px) {
  .order-type-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.order-type-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  font-size: 1.125rem;
  background: transparent;
  color: var(--brand-yellow);
  border: 2px solid var(--brand-yellow);
  border-radius: var(--radius);
  cursor: pointer;
  transition: all 0.2s ease;
}

.order-type-btn:hover {
  background-color: var(--brand-yellow);
  color: var(--brand-dark-green);
}

.order-type-btn svg {
  width: 2rem;
  height: 2rem;
  margin-bottom: 0.5rem;
}

.payment-grid {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

@media (min-width: 768px) {
  .payment-grid {
    flex-direction: row;
    justify-content: center;
  }
}

/* How It Works — checkout step 3 */
.how-it-works-box {
  background-color: rgba(255,255,255,0.04);
  border: 1px solid var(--border-color);
  border-radius: var(--radius);
  padding: 1.75rem;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  margin-bottom: 1.5rem;
}

.how-step {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
}

.how-step-num {
  flex-shrink: 0;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 50%;
  background-color: var(--accent);
  color: var(--brand-dark-green);
  font-weight: 700;
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.how-step-text strong {
  display: block;
  color: var(--brand-yellow);
  margin-bottom: 0.25rem;
}

.how-step-text p {
  font-size: 0.9rem;
  color: var(--text-muted);
  margin: 0;
}

.no-payment-notice {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  background-color: rgba(255,255,255,0.06);
  border: 1px solid var(--border-color);
  border-radius: var(--radius);
  padding: 1rem 1.25rem;
  font-size: 0.9rem;
  color: var(--brand-yellow);
  margin-bottom: 0.5rem;
}

.no-payment-notice svg {
  flex-shrink: 0;
  color: var(--accent);
}

.place-order-btn {
  min-width: 14rem;
}

/* ============================================
   ORDER CONFIRMATION
   ============================================ */
.confirmation-icon {
  width: 5rem;
  height: 5rem;
  color: var(--accent);
  margin: 0 auto 1.5rem;
}

.order-reference {
  font-weight: 700;
  color: var(--accent);
}

.order-list {
  border-top: 1px solid var(--border-color);
  border-bottom: 1px solid var(--border-color);
  padding: 2rem 0;
  margin: 2rem 0;
}

.order-list-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.75rem;
}

.order-list-item:last-child {
  margin-bottom: 0;
}

.order-list-total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 1.25rem;
  font-weight: 700;
  padding-top: 1rem;
  border-top: 1px solid var(--border-color);
  margin-top: 1rem;
}

.order-details {
  text-align: left;
  margin-bottom: 2rem;
}

.order-details h2 {
  font-size: 1.5rem;
  font-weight: 600;
  font-family: 'Fraunces', serif;
  color: var(--brand-yellow);
  margin-bottom: 1.5rem;
}

.order-details p {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
  color: var(--text-body);
}

.order-details p svg {
  width: 1.25rem;
  height: 1.25rem;
  color: var(--accent);
  flex-shrink: 0;
}

/* ============================================
   FOOTER
   ============================================ */
.site-footer {
  background-color: #0C1A12;
  color: var(--brand-yellow);
  padding: 4rem 0 2rem;
  border-top: 1px solid var(--border-color);
}

.footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
}

@media (min-width: 768px) {
  .footer-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .footer-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

.footer-brand {
  font-size: 1.5rem;
  font-weight: 700;
  font-family: 'Fraunces', serif;
  color: var(--brand-yellow);
  display: inline-block;
  margin-bottom: 1rem;
  text-decoration: none;
}

.footer-brand:hover {
  color: var(--brand-yellow-light);
}

.footer-desc {
  color: var(--text-muted);
  margin-bottom: 1rem;
}

.footer-social {
  display: flex;
  gap: 1rem;
}

.footer-social a {
  color: var(--text-muted);
  transition: color 0.2s ease;
}

.footer-social a:hover {
  color: var(--brand-yellow);
}

.footer-social svg {
  width: 1.25rem;
  height: 1.25rem;
}

.footer-title {
  font-size: 1.25rem;
  font-weight: 500;
  color: var(--brand-yellow);
  display: block;
  margin-bottom: 1rem;
}

.footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-links li {
  margin-bottom: 0.5rem;
}

.footer-links a {
  color: var(--text-muted);
  transition: color 0.2s ease;
  text-decoration: none;
}

.footer-links a:hover {
  color: var(--brand-yellow);
}

.footer-contact-item {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}

.footer-contact-item svg {
  width: 1.25rem;
  height: 1.25rem;
  color: var(--brand-yellow);
  margin-top: 0.125rem;
  flex-shrink: 0;
}

.footer-contact-item span,
.footer-contact-item a {
  color: var(--text-muted);
  text-decoration: none;
}

.footer-contact-item a:hover {
  color: var(--brand-yellow);
}

.footer-hours p {
  color: var(--text-muted);
  margin-bottom: 0.25rem;
}

.footer-hours .time {
  color: var(--text-muted-light);
  font-size: 0.875rem;
}

.footer-bottom {
  border-top: 1px solid var(--border-color);
  margin-top: 3rem;
  padding-top: 2rem;
  text-align: center;
}

.footer-policy-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1.5rem;
  margin-bottom: 1rem;
}

.footer-policy-links a {
  color: var(--text-muted-light);
  font-size: 0.875rem;
  transition: color 0.2s ease;
}

.footer-policy-links a:hover {
  color: var(--brand-yellow);
}

.footer-copyright {
  color: var(--text-muted-light);
  font-size: 0.875rem;
}

/* ============================================
   CONTACT PAGE
   ============================================ */
.contact-hero {
  position: relative;
  padding: 6rem 0 8rem;
  text-align: center;
  overflow: hidden;
}

.contact-hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.contact-hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  opacity: 0.9;
}

.contact-hero-overlay {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(110% 80% at 50% 20%, rgba(13,28,19,0.20), rgba(13,28,19,0.70) 70%),
    linear-gradient(to top, rgba(12,26,18,0.94), rgba(17,35,24,0.35));
  z-index: 1;
}

.contact-hero-content {
  position: relative;
  z-index: 10;
  max-width: 48rem;
  margin: 0 auto;
}

.contact-hero-content h1 {
  font-size: 2.25rem;
  font-weight: 700;
  margin-bottom: 1.5rem;
  color: var(--brand-yellow);
}

@media (min-width: 768px) {
  .contact-hero-content h1 {
    font-size: 3rem;
  }
}

@media (min-width: 1024px) {
  .contact-hero-content h1 {
    font-size: 3.75rem;
  }
}

.contact-info-item {
  display: flex;
  align-items: flex-start;
  margin-bottom: 1.5rem;
}

.contact-info-item svg {
  width: 1.5rem;
  height: 1.5rem;
  color: var(--brand-yellow);
  margin-right: 1rem;
  margin-top: 0.25rem;
  flex-shrink: 0;
}

.contact-info-item h3 {
  font-size: 1.125rem;
  font-weight: 700;
  margin-bottom: 0.25rem;
  color: var(--brand-yellow);
}

.contact-info-item p,
.contact-info-item a {
  color: var(--text-body);
  text-decoration: none;
}

.contact-info-item a:hover {
  color: var(--accent);
}

.social-links-row {
  display: flex;
  gap: 1rem;
  margin-top: 2.5rem;
}

.social-links-row a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  background-color: var(--brand-yellow);
  color: var(--brand-dark-green);
  border-radius: 50%;
  transition: background-color 0.2s ease;
}

.social-links-row a:hover {
  background-color: var(--brand-yellow-light);
}

.social-links-row a svg {
  width: 1.25rem;
  height: 1.25rem;
}

/* Breadcrumb navigation */
.breadcrumb-nav {
  background-color: var(--brand-dark-green);
  border-bottom: 1px solid var(--border-color);
  padding: 0.65rem 0;
}
.breadcrumb-list {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  font-size: 0.82rem;
  color: var(--text-muted);
  margin: 0;
  padding: 0;
}
.breadcrumb-list li + li::before {
  content: '›';
  margin-right: 0.5rem;
  color: var(--text-muted);
}
.breadcrumb-list a {
  color: var(--text-muted);
  text-decoration: none;
}
.breadcrumb-list a:hover {
  color: var(--brand-yellow);
}
.breadcrumb-list [aria-current="page"] {
  color: var(--brand-yellow);
}

/* Map section */
.map-section {
  text-align: center;
}

.map-link {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  border: 2px solid var(--border-color);
  background-color: var(--brand-dark-green-light);
  padding: 4rem 1.5rem;
  transition: border-color 0.3s ease;
  text-decoration: none;
  position: relative;
}

.map-link:hover {
  border-color: rgba(232, 181, 63, 0.6);
}

.map-link-bg {
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at center, rgba(232, 181, 63, 0.08), transparent 70%);
}

.map-icon {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 4rem;
  height: 4rem;
  background-color: var(--brand-yellow);
  color: var(--brand-dark-green);
  border-radius: 50%;
  box-shadow: var(--shadow-md);
  transition: transform 0.3s ease;
}

.map-link:hover .map-icon {
  transform: scale(1.1);
}

.map-icon svg {
  width: 2rem;
  height: 2rem;
}

.map-link h3 {
  position: relative;
  margin-top: 1.5rem;
  font-size: 1.5rem;
  font-weight: 700;
  font-family: 'Fraunces', serif;
  color: var(--brand-yellow);
}

@media (min-width: 768px) {
  .map-link h3 {
    font-size: 1.875rem;
  }
}

.map-link p {
  position: relative;
  color: var(--text-soft);
  margin-top: 0.25rem;
}

.map-link .btn-maps {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 1.5rem;
  background-color: var(--brand-yellow);
  color: var(--brand-dark-green);
  padding: 0.625rem 1.25rem;
  border-radius: var(--radius);
  font-weight: 600;
  transition: background-color 0.2s ease;
}

.map-link .btn-maps:hover {
  background-color: var(--brand-yellow-light);
}

.map-link .btn-maps svg {
  width: 1rem;
  height: 1rem;
}

/* FAQ */
.faq-item {
  background-color: var(--card-bg);
  padding: 1.5rem;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  border: 1px solid var(--border-color);
  margin-bottom: 1.5rem;
}

.faq-item h3 {
  font-size: 1.25rem;
  font-weight: 700;
  font-family: 'Fraunces', serif;
  color: var(--brand-yellow);
  margin-bottom: 0.5rem;
}

/* ============================================
   ABOUT PAGE
   ============================================ */
.about-hero {
  position: relative;
  padding: 6rem 0 8rem;
  text-align: center;
  overflow: hidden;
}

.about-hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.about-hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  opacity: 0.9;
}

.about-hero-overlay {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(110% 80% at 50% 20%, rgba(13,28,19,0.20), rgba(13,28,19,0.70) 70%),
    linear-gradient(to top, rgba(12,26,18,0.94), rgba(17,35,24,0.35));
  z-index: 1;
}

.about-hero-content {
  position: relative;
  z-index: 10;
  max-width: 48rem;
  margin: 0 auto;
}

.about-hero-content h1 {
  font-size: 2.25rem;
  font-weight: 700;
  margin-bottom: 1.5rem;
  color: var(--brand-yellow);
}

@media (min-width: 768px) {
  .about-hero-content h1 {
    font-size: 3rem;
  }
}

@media (min-width: 1024px) {
  .about-hero-content h1 {
    font-size: 3.75rem;
  }
}

.about-image {
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  width: 100%;
  height: auto;
  object-fit: cover;
  aspect-ratio: 4/3;
  border: 1px solid rgba(232, 181, 63, 0.28);
}

.about-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  align-items: center;
}

@media (min-width: 768px) {
  .about-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.about-grid h2 {
  font-size: 1.875rem;
  font-weight: 700;
  margin-bottom: 1.5rem;
  font-family: 'Fraunces', serif;
  color: var(--brand-yellow);
}

@media (min-width: 768px) {
  .about-grid h2 {
    font-size: 2.25rem;
  }
}

.about-grid p {
  color: var(--text-body);
  margin-bottom: 1.5rem;
  line-height: 1.7;
}

/* ============================================
   MENU PAGE
   ============================================ */
.menu-hero {
  position: relative;
  padding: 5rem 0 7rem;
  text-align: center;
  overflow: hidden;
}

.menu-hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.menu-hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  opacity: 0.9;
}

.menu-hero-overlay {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(110% 80% at 50% 20%, rgba(13,28,19,0.22), rgba(13,28,19,0.72) 70%),
    linear-gradient(to top, rgba(12,26,18,0.94), rgba(17,35,24,0.38));
  z-index: 1;
}

.menu-hero-content {
  position: relative;
  z-index: 10;
  max-width: 48rem;
  margin: 0 auto;
}

.menu-hero-content h1 {
  font-size: 2.25rem;
  font-weight: 700;
  margin-bottom: 1rem;
  color: var(--brand-yellow);
}

@media (min-width: 768px) {
  .menu-hero-content h1 {
    font-size: 3rem;
  }
}

@media (min-width: 1024px) {
  .menu-hero-content h1 {
    font-size: 3.75rem;
  }
}

.menu-hero-content p {
  font-size: 1.125rem;
  margin-bottom: 2rem;
  color: var(--text-body);
}

@media (min-width: 768px) {
  .menu-hero-content p {
    font-size: 1.25rem;
  }
}

.menu-nav-buttons {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
}

@media (min-width: 640px) {
  .menu-nav-buttons {
    flex-direction: row;
    justify-content: center;
  }
}

.menu-nav-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: var(--brand-yellow);
  color: var(--brand-dark-green);
  font-weight: 600;
  padding: 0.75rem 1.5rem;
  border-radius: var(--radius);
  transition: all 0.3s ease;
  font-size: 1rem;
  border: 2px solid var(--brand-yellow);
  cursor: pointer;
  text-decoration: none;
}

.menu-nav-btn:hover {
  background-color: transparent;
  color: var(--brand-yellow);
}

.menu-category-title {
  font-size: 1.5rem;
  font-weight: 600;
  font-family: 'Fraunces', serif;
  color: var(--brand-yellow);
  margin-bottom: 1.5rem;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid var(--border-color);
}

.menu-section-title {
  font-size: 1.875rem;
  font-weight: 700;
  text-align: center;
  margin-bottom: 1rem;
  color: var(--brand-yellow);
  font-family: 'Fraunces', serif;
}

@media (min-width: 768px) {
  .menu-section-title {
    font-size: 2.25rem;
  }
}

.menu-section-note {
  text-align: center;
  color: var(--text-muted);
  margin-bottom: 2.5rem;
  font-style: italic;
}

.menu-divider {
  margin: 4rem 0;
  border-top: 4px dashed var(--border-color);
}

/* content-visibility: skip off-screen menu category layout — fixes 1,020ms TBT */
#events-party-menu .mb-12,
#weekend-menu .mb-12 {
  content-visibility: auto;
  contain-intrinsic-size: 0 420px;
}

.menu-event-cta {
  text-align: center;
  padding: 3rem 2rem;
  background-color: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  margin: 0 auto;
  max-width: 48rem;
}
.menu-event-cta h2 {
  font-family: var(--font-serif);
  font-size: 1.75rem;
  color: var(--brand-yellow);
  margin-bottom: 0.75rem;
}
.menu-event-cta p {
  color: var(--text-muted);
  margin-bottom: 1.5rem;
  line-height: 1.7;
}
.menu-event-cta p a {
  color: var(--accent);
  text-decoration: underline;
}
.menu-event-cta p a:hover {
  color: var(--brand-yellow);
}

/* ============================================
   DISH PAGE
   ============================================ */
.dish-page {
  min-height: 100vh;
  padding: 3rem 0;
}

.dish-card {
  background-color: var(--card-bg);
  padding: 2rem;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  border: 1px solid var(--border-color);
}

@media (min-width: 768px) {
  .dish-card {
    padding: 3rem;
  }
}

.dish-card h1 {
  font-size: 2.25rem;
  font-weight: 700;
  font-family: 'Fraunces', serif;
  color: var(--brand-yellow);
  margin-bottom: 1rem;
}

@media (min-width: 768px) {
  .dish-card h1 {
    font-size: 3rem;
  }
}

.dish-price {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--accent);
  margin-bottom: 1.5rem;
}

.dish-description {
  color: var(--text-body);
  font-size: 1.125rem;
  margin-bottom: 2rem;
}

.dish-quantity {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 2rem;
}

.dish-quantity-label {
  font-size: 1.125rem;
  font-weight: 500;
}

/* ============================================
   LEGAL PAGES (Terms, Privacy, Accessibility)
   ============================================ */
.legal-page {
  min-height: 100vh;
  padding: 5rem 0;
}

.legal-page h1 {
  font-size: 2.25rem;
  font-weight: 700;
  text-align: center;
  margin-bottom: 2.5rem;
  font-family: 'Fraunces', serif;
  color: var(--brand-yellow);
}

@media (min-width: 768px) {
  .legal-page h1 {
    font-size: 3rem;
  }
}

.legal-content {
  max-width: 48rem;
  margin: 0 auto;
  background-color: var(--card-bg);
  padding: 2rem;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  border: 1px solid var(--border-color);
}

@media (min-width: 768px) {
  .legal-content {
    padding: 2rem;
  }
}

.legal-content p {
  color: var(--text-body);
  margin-bottom: 1rem;
  line-height: 1.7;
}

.legal-content h2 {
  font-size: 1.25rem;
  font-weight: 600;
  margin-top: 1.5rem;
  margin-bottom: 0.75rem;
  color: var(--brand-yellow);
}

.legal-content ul {
  list-style: disc;
  padding-left: 1.5rem;
  margin-bottom: 1rem;
}

.legal-content ul li {
  color: var(--text-body);
  margin-bottom: 0.5rem;
}

/* ============================================
   POPULAR DISHES SECTION
   ============================================ */
.popular-dish-card {
  background-color: var(--card-bg);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  border: 1px solid var(--border-color);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.popular-dish-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-xl);
}

.popular-dish-card .dish-image {
  height: 12rem;
  overflow: hidden;
}

.popular-dish-card .dish-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.popular-dish-card .dish-content {
  padding: 1.5rem;
}

.popular-dish-card .dish-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 0.5rem;
}

.popular-dish-card .dish-header h3 {
  font-family: 'Fraunces', serif;
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--brand-yellow);
}

.popular-dish-card .dish-header .price {
  color: var(--accent);
  font-weight: 700;
}

.popular-dish-card .dish-content p {
  color: var(--text-soft);
  font-size: 0.875rem;
}

/* ============================================
   HOST WITH FLAVOR / SPLIT SECTION
   ============================================ */
.split-section {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  align-items: center;
}

@media (min-width: 768px) {
  .split-section {
    grid-template-columns: repeat(2, 1fr);
  }
}

.split-section img {
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  width: 100%;
  height: auto;
  object-fit: cover;
  aspect-ratio: 4/3;
  border: 1px solid rgba(232, 181, 63, 0.28);
}

.split-section h2 {
  font-size: 1.875rem;
  font-weight: 700;
  margin-bottom: 1.5rem;
  font-family: 'Fraunces', serif;
  color: var(--brand-yellow);
}

@media (min-width: 768px) {
  .split-section h2 {
    font-size: 2.25rem;
  }
}

.split-section p {
  color: var(--text-body);
  margin-bottom: 1.5rem;
  line-height: 1.7;
}

/* ============================================
   FINAL CTA SECTION
   ============================================ */
.cta-buttons {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  justify-content: center;
}

@media (min-width: 640px) {
  .cta-buttons {
    flex-direction: row;
  }
}

/* ============================================
   TOAST NOTIFICATIONS
   ============================================ */
.toast-container {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  z-index: 100;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.toast {
  background-color: var(--card-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  padding: 1rem 1.5rem;
  box-shadow: var(--shadow-xl);
  max-width: 24rem;
  animation: slideInRight 0.3s ease forwards;
  position: relative;
}

.toast.success {
  border-left: 4px solid #22c55e;
}

.toast.error {
  border-left: 4px solid #ef4444;
}

.toast.default {
  border-left: 4px solid var(--brand-yellow);
}

.toast-title {
  font-weight: 600;
  color: var(--brand-yellow);
  margin-bottom: 0.25rem;
}

.toast-description {
  font-size: 0.875rem;
  color: var(--text-muted);
}

.toast-close {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: 0.25rem;
}

.toast-close:hover {
  color: var(--brand-yellow);
}

@keyframes slideInRight {
  from {
    opacity: 0;
    transform: translateX(100%);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes slideOutRight {
  from {
    opacity: 1;
    transform: translateX(0);
  }
  to {
    opacity: 0;
    transform: translateX(100%);
  }
}

.toast.removing {
  animation: slideOutRight 0.3s ease forwards;
}

/* ============================================
   SCROLLBAR
   ============================================ */
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

::-webkit-scrollbar-track {
  background: none;
}

::-webkit-scrollbar-thumb {
  background: rgba(232, 181, 63, 0.3);
  border-radius: 3px;
}

::-webkit-scrollbar-thumb:hover {
  background: rgba(232, 181, 63, 0.5);
}

/* ============================================
   RESPONSIVE UTILITIES
   ============================================ */
.hide-mobile {
  display: none;
}

@media (min-width: 768px) {
  .hide-mobile {
    display: block;
  }
  .hide-desktop {
    display: none;
  }
}

/* ============================================
   PAGE HEADER SPACING
   ============================================ */
.page-content {
  padding-top: 5rem;
}

@media (min-width: 768px) {
  .page-content {
    padding-top: 6rem;
  }
}

/* ============================================
   BACK BUTTON
   ============================================ */
.back-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background: transparent;
  color: var(--brand-yellow);
  border: 1px solid var(--brand-yellow);
  padding: 0.5rem 1rem;
  border-radius: var(--radius);
  margin-bottom: 2rem;
  cursor: pointer;
  transition: all 0.2s ease;
  font-size: 1rem;
  text-decoration: none;
}

.back-btn:hover {
  background-color: var(--brand-yellow);
  color: var(--brand-dark-green);
}

.back-btn svg {
  width: 1rem;
  height: 1rem;
}

/* ============================================
   TEXT UTILITIES
   ============================================ */
.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }

.font-bold { font-weight: 700; }
.font-semibold { font-weight: 600; }
.font-medium { font-weight: 500; }

.text-brand { color: var(--brand-yellow); }
.text-accent { color: var(--accent); }
.text-muted { color: var(--text-muted); }

.max-w-2xl { max-width: 42rem; margin-left: auto; margin-right: auto; }
.max-w-3xl { max-width: 48rem; margin-left: auto; margin-right: auto; }

.mx-auto { margin-left: auto; margin-right: auto; }

.mb-2 { margin-bottom: 0.5rem; }
.mb-4 { margin-bottom: 1rem; }
.mb-6 { margin-bottom: 1.5rem; }
.mb-8 { margin-bottom: 2rem; }
.mb-12 { margin-bottom: 3rem; }

.mt-4 { margin-top: 1rem; }
.mt-6 { margin-top: 1.5rem; }
.mt-8 { margin-top: 2rem; }
.mt-12 { margin-top: 3rem; }
.mt-16 { margin-top: 4rem; }

.pt-8 { padding-top: 2rem; }
.pt-10 { padding-top: 2.5rem; }
.pt-12 { padding-top: 3rem; }

.pb-12 { padding-bottom: 3rem; }
.pb-20 { padding-bottom: 5rem; }

.py-12 { padding-top: 3rem; padding-bottom: 3rem; }
.py-20 { padding-top: 5rem; padding-bottom: 5rem; }

.p-6 { padding: 1.5rem; }
.p-8 { padding: 2rem; }

.gap-4 { gap: 1rem; }
.gap-6 { gap: 1.5rem; }
.gap-8 { gap: 2rem; }
.gap-12 { gap: 3rem; }

.space-y-2 > * + * { margin-top: 0.5rem; }
.space-y-4 > * + * { margin-top: 1rem; }
.space-y-6 > * + * { margin-top: 1.5rem; }

.min-h-screen { min-height: 100vh; }

.flex { display: flex; }
.flex-col { flex-direction: column; }
.items-center { align-items: center; }
.items-start { align-items: flex-start; }
.justify-between { justify-content: space-between; }
.justify-center { justify-content: center; }
.justify-end { justify-content: flex-end; }
.flex-grow { flex-grow: 1; }

.flex-wrap { flex-wrap: wrap; }

.relative { position: relative; }
.absolute { position: absolute; }

.w-full { width: 100%; }
.w-auto { width: auto; }

.h-full { height: 100%; }

/* ============================================
   MENU PAGE SPECIFIC
   ============================================ */
.menu-page-wrapper {
  min-height: 100vh;
}

.menu-page-content {
  padding: 4rem 0;
}

/* ============================================
   CONTACT FORM SUCCESS
   ============================================ */
.form-success {
  background-color: var(--card-bg);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  padding: 2rem;
  text-align: center;
}

.form-success svg {
  width: 3rem;
  height: 3rem;
  color: #22c55e;
  margin-bottom: 1rem;
}

.form-success h3 {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--brand-yellow);
  margin-bottom: 0.5rem;
}

.form-success p {
  color: var(--text-muted);
}

/* ============================================
   DISH DETAIL LINKS
   ============================================ */
.related-dishes {
  margin-top: 4rem;
  padding-top: 2.5rem;
  border-top: 1px solid var(--border-color);
}

.related-dishes h2 {
  font-size: 1.5rem;
  font-weight: 700;
  font-family: 'Fraunces', serif;
  color: var(--brand-yellow);
  margin-bottom: 1.5rem;
}

/* ============================================
   WORDPRESS DEFAULTS
   ============================================ */
.alignleft {
  float: left;
  margin-right: 1rem;
}

.alignright {
  float: right;
  margin-left: 1rem;
}

.aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.wp-caption {
  max-width: 100%;
}

.wp-caption-text {
  font-size: 0.875rem;
  color: var(--text-muted);
  text-align: center;
  margin-top: 0.5rem;
}

/* Screen reader text */
.screen-reader-text {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* WordPress admin bar fix */
.admin-bar .site-header {
  top: 32px;
}

@media screen and (max-width: 782px) {
  .admin-bar .site-header {
    top: 46px;
  }
}

/* ============================================
   CREAM SECTION OVERRIDES (source-order wins)
   Ensure headings/links on cream stay deep ink, not gold.
   ============================================ */
.bg-secondary .split-section h2,
.bg-secondary .about-grid h2,
.bg-secondary .map-link h3,
.bg-secondary .menu-category-title,
.bg-secondary .menu-section-title,
.bg-secondary .faq-item h3,
.bg-secondary .dish-card h1 { color: var(--ink); }

.bg-secondary .split-section p,
.bg-secondary .about-grid p,
.bg-secondary .menu-section-note { color: var(--ink-soft); }

.bg-secondary .menu-category-title { border-bottom-color: rgba(120, 88, 36, 0.20); }

/* ============================================
   TYPE-SCALE UTILITIES (used across templates)
   ============================================ */
.font-serif { font-family: 'Fraunces', serif; }
.font-sans { font-family: 'Hanken Grotesk', sans-serif; }
.text-xs { font-size: 0.78rem; }
.text-sm { font-size: 0.875rem; }
.text-base { font-size: 1rem; }
.text-lg { font-size: 1.125rem; }
.text-xl { font-size: 1.25rem; }
.text-2xl { font-size: 1.6rem; line-height: 1.18; }
.text-3xl { font-size: 1.95rem; line-height: 1.12; }
.text-4xl { font-size: 2.4rem; line-height: 1.08; }
.text-5xl { font-size: 3rem; line-height: 1.05; }
.text-6xl { font-size: 3.6rem; line-height: 1.03; }
@media (min-width: 768px) {
  .md\:text-xl { font-size: 1.25rem; }
  .md\:text-3xl { font-size: 1.95rem; }
  .md\:text-4xl { font-size: 2.5rem; line-height: 1.07; }
  .md\:text-5xl { font-size: 3.1rem; line-height: 1.04; }
  .md\:text-6xl { font-size: 3.85rem; line-height: 1.02; }
}

/* ============================================
   Sticky Mobile Tap-to-Call Bar — mobile only
   Primary mobile CTA for a local catering business.
   ============================================ */
.mobile-call-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    display: flex;
    gap: 1px;
    background: var(--brand-dark-green, #1a3a1a);
    box-shadow: 0 -4px 16px rgba(0, 0, 0, 0.25);
    padding-bottom: env(safe-area-inset-bottom, 0);
}
.mobile-call-bar__call,
.mobile-call-bar__order {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 56px;
    padding: 12px;
    font-family: 'Hanken Grotesk', sans-serif;
    font-weight: 700;
    font-size: 1rem;
    text-decoration: none;
    color: #fff;
    line-height: 1;
}
.mobile-call-bar__call {
    background: var(--brand-yellow, #f4d03f);
    color: #1a3a1a;
}
.mobile-call-bar__call svg { color: #1a3a1a; }
.mobile-call-bar__order {
    background: var(--brand-dark-green, #1a3a1a);
}
.mobile-call-bar__call:active,
.mobile-call-bar__order:active { opacity: 0.85; }

/* Hidden on desktop — mobile-first: shown by default below 768px */
@media (min-width: 768px) {
    .mobile-call-bar { display: none; }
}
/* Add bottom spacing on mobile so the bar never covers footer content */
@media (max-width: 767px) {
    .site-footer { padding-bottom: 70px; }
}
