/* ===== Base & Fonts ===== */
:root{
  --maroon: #6a0f1a;
  --pearl: #ffffff;
  --muted: #6b6b6b;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { height: 100%; overflow-x: hidden; }
body { min-height: 100%; width: 100%; overflow-x: hidden; }
body {
  margin: 0;
  font-family: "Poppins", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  background: #fff; /* pure snow white */
  color: #222;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@500;700&family=Poppins:wght@300;400;600&display=swap');

:root{
  --pearl:#faf9f7;--maroon:#6a0f1a;--gold:#c9a45c;--muted:#6b6b6b;--dark-text:#0d1212;--bg:var(--pearl);--card:#fff;--shadow:rgba(16,16,16,0.06);--ease:cubic-bezier(.22,.9,.35,1);
}
.dark-theme{--bg:#0b0b0c;--card:#0f1011;--shadow:rgba(0,0,0,0.45);--dark-text:#efeae6;--muted:#bdb5b0}
*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:'Poppins',sans-serif;background:var(--bg);color:var(--dark-text);-webkit-font-smoothing:antialiased;transition:background .45s var(--ease), color .45s var(--ease)}
.container{max-width:1200px;margin:0 auto;padding:0 20px}.site-header{position:fixed;top:0;left:0;width:100%;height:72px;display:flex;align-items:center;z-index:999;background:linear-gradient(180deg,rgba(255,255,255,0.6),transparent);backdrop-filter:blur(6px);border-bottom:1px solid rgba(0,0,0,0.04)}.header-inner{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 0}.logo-img{height:52px}.nav a{margin-left:18px;text-decoration:none;color:var(--dark-text);font-weight:600}.theme-toggle{position:fixed;right:18px;top:14px;width:44px;height:44px;border-radius:12px;border:none;background:var(--card);box-shadow:0 8px 24px var(--shadow);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2000}.hero{position:relative;min-height:78vh;display:flex;align-items:center;justify-content:center;padding-top:84px;padding-bottom:40px;background-image:url('https://images.unsplash.com/photo-1504674900247-0877df9cc836?auto=format&fit=crop&w=1600&q=80');background-size:cover;background-position:center fixed}.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg, rgba(106,15,26,0.34), rgba(250,250,250,0.02));mix-blend-mode:multiply}.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center;padding:40px 0}.hero-title{font-family:'Playfair Display',serif;font-size:48px;color:#fff}.btn{cursor:pointer;border:0;padding:12px 18px;border-radius:12px;font-weight:700}.btn-maroon{background:linear-gradient(180deg,var(--maroon),#520712);color:#fff;box-shadow:0 12px 36px rgba(106,15,26,0.06)}.section{padding:80px 0}.section-title{font-family:'Playfair Display',serif;font-size:32px;color:var(--maroon);text-align:center;margin-bottom:12px}.menu-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px;margin-top:22px}.menu-card{background:var(--card);border-radius:14px;overflow:hidden;transition:transform .45s;box-shadow:0 8px 22px var(--shadow)}.menu-card:hover{transform:translateY(-12px)}.menu-card img{width:100%;height:220px;object-fit:cover}.service-card{position:relative;min-width:320px;border-radius:14px;overflow:hidden;flex-shrink:0;background:linear-gradient(180deg,var(--card),var(--card));box-shadow:0 14px 40px var(--shadow)}.services-slider{overflow:hidden;margin-top:24px}.slides{display:flex;gap:18px;align-items:stretch;will-change:transform}.reserve-wrap{position:absolute;right:6%;top:18%;width:360px;height:480px;perspective:1400px;display:none}.reserve-wrap.active{display:block}.reserve-card{width:100%;height:100%;position:relative;transform-style:preserve-3d;transition:transform .9s}.card-face{position:absolute;inset:0;border-radius:16px;overflow:hidden;backface-visibility:hidden;box-shadow:0 30px 70px var(--shadow)}.card-back{transform:rotateY(180deg)}.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s,transform .6s}.reveal.show{opacity:1;transform:none}@media(max-width:800px){.hero-inner{grid-template-columns:1fr;padding:28px 0}.logo-img{height:44px}.theme-toggle{right:12px;top:10px;width:40px;height:40px}.nav a{display:none}.hamburger{display:block}}

/* NAVBAR (glass) */
/* Navbar Glass */
.navbar {
  position: fixed; top: 0; width: 100%;
  padding: 15px 60px;
  display: flex; justify-content: space-between; align-items: center;
  backdrop-filter: blur(15px);
  background: rgba(255, 255, 255, 0.15);
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  z-index: 1000;
}
.logo { font-size: 1.8rem; font-weight: bold; color: maroon; }
.navbar ul { list-style: none; display: flex; gap: 25px; }
.navbar ul li a {
  text-decoration: none; color: #fff; font-size: 1rem;
  padding: 6px 12px; border-radius: 8px; transition: all .3s ease;
}
.navbar ul li a:hover { background: maroon; }

/* MENU TOGGLE + NAV-LINKS STYLING (desktop & mobile) */
.menu-toggle {
  display: none; /* shown on small screens via media queries */
  background: var(--maroon);
  color: #fff;
  border: none;
  padding: 8px 10px;
  border-radius: 10px;
  font-size: 1.1rem;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 8px 22px rgba(106,15,26,0.16);
}

.nav-links { display: flex; align-items: center; gap: 18px; }
.nav-links ul { display: flex; gap: 18px; list-style: none; margin: 0; padding: 0; }
.nav-links ul li a {
  display: inline-block;
  padding: 8px 12px;
  border-radius: 10px;
  text-decoration: none;
  color: var(--dark-text);
  font-weight: 700;
  transition: background .22s ease, color .22s ease, transform .14s ease;
}
.nav-links ul li a:hover {
  background: var(--maroon);
  color: #fff;
  transform: translateY(-2px);
}

/* Mobile behaviour: hidden by max-height and revealed by .active (animated) */
@media (max-width: 768px) {
  .menu-toggle { display: inline-flex; align-items: center; justify-content: center; }

  .nav-links {
    width: 100%;
    max-height: 0;
    overflow: hidden;
    transition: max-height .36s cubic-bezier(.2,.9,.2,1), padding .22s ease;
    background: rgba(255,255,255,0.98);
    box-shadow: 0 12px 40px rgba(0,0,0,0.06);
    border-radius: 12px;
    padding: 0 12px;
    margin-top: 8px;
    flex-direction: column;
  }

  .nav-links.active { max-height: 420px; padding: 12px; }

  .nav-links ul { flex-direction: column; gap: 8px; width: 100%; }
  .nav-links ul li { width: 100%; }
  .nav-links ul li a { width: 100%; padding: 10px 12px; color: var(--maroon); background: transparent; }
  .nav-links ul li a:hover { background: var(--maroon); color: #fff; }

  /* Visual polish: give the opened menu a slight inset and backdrop blur on modern browsers */
  .nav-links.active { backdrop-filter: blur(4px); }
}

/* Hero */
.hero {
  position: relative; min-height: 100vh;
  padding: 120px 60px 60px;
  display: flex; justify-content: space-between; align-items: center;
  background: url("https://images.unsplash.com/photo-1600891964599-f61ba0e24092?auto=format&fit=crop&w=1600&q=80") center/cover no-repeat;
}
.hero::after { content:""; position:absolute; inset:0; background:rgba(0,0,0,0.45);}
.hero-content { position: relative; z-index:1; max-width:550px; color:#fff; }
.hero-content h1 { font-size:3rem; margin-bottom:20px; }
.hero-content h1 span { color: maroon; }
.hero-content p { font-size:1.2rem; margin-bottom:25px; }
.btn { background:maroon; color:#fff; padding:12px 24px; border-radius:25px; text-decoration:none; transition:.3s; }
.btn:hover { background:#7a001f; transform:scale(1.05); }
.hero-images { position:relative; z-index:1; display:flex; align-items:center; }
.hero-main-img { border-radius:20px; overflow:hidden; box-shadow:0 15px 40px rgba(0,0,0,0.3); max-width:500px; transition:.4s; }
.hero-main-img:hover { transform:scale(1.03);}
.hero-overlay-img { position:absolute; right:-70px; bottom:-40px; border:8px solid #fff; border-radius:15px; overflow:hidden; width:200px; height:150px; box-shadow:0 10px 25px rgba(0,0,0,.3); animation:float 5s ease-in-out infinite;}
@keyframes float {0%,100%{transform:translateY(0);}50%{transform:translateY(-12px);}}
/* Menu nav (sticky under hero) */
.menu-nav {
  display: flex;
  gap: 12px;
  justify-content: center;
  align-items: center;
  padding: 10px 12px;
  position: sticky;
  top: 72px;
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(250,250,250,0.98));
  z-index: 999;
  border-bottom: 1px solid rgba(0,0,0,0.04);
  width: 100%;
  box-sizing: border-box;
  /* allow horizontal scroll on very small screens if the items overflow */
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scroll-behavior: smooth;
}
.menu-nav a {
  color: var(--maroon);
  text-decoration: none;
  font-weight: 700;
  padding: 8px 14px;
  border-radius: 999px;
  background: transparent;
  transition: background .18s ease, color .18s ease, transform .12s ease;
  white-space: nowrap;
  display: inline-block;
}
.menu-nav a:hover,
.menu-nav a:focus {
  background: var(--maroon);
  color: #fff;
  transform: translateY(-2px);
}
.menu-nav a.active {
  background: var(--maroon);
  color: #fff;
  box-shadow: 0 6px 18px rgba(106,15,26,0.12);
}

/* hide the native scrollbar but allow scroll on mobile */
.menu-nav::-webkit-scrollbar { height: 8px; }
.menu-nav::-webkit-scrollbar-thumb { background: rgba(0,0,0,0.06); border-radius: 10px; }

@media (max-width: 720px) {
  .menu-nav { justify-content: flex-start; padding: 10px 12px; gap: 10px; }
  /* ensure the first and last items have padding from the viewport edge */
  .menu-nav a { padding: 10px 14px; }
}

@media (max-width: 420px) {
  /* make items slightly larger and touch-friendly */
  .menu-nav a { padding: 12px 16px; font-size: 0.95rem; }
}

/* Accordion behavior for menu categories on small screens */
@media (max-width: 820px) {
  .menu-category {
    border-top: 1px solid rgba(0,0,0,0.04);
    padding-top: 12px;
    padding-bottom: 12px;
  }

  /* collapse grid by default to create unfolding effect */
  .menu-category .menu-grid {
    max-height: 0;
    overflow: hidden;
    transition: max-height .44s cubic-bezier(.2,.9,.2,1), padding .3s ease;
    padding-top: 0;
    padding-bottom: 0;
  }

  /* expanded state shows the grid (large max-height to accommodate cards) */
  .menu-category.expanded .menu-grid {
    max-height: 2400px; /* large enough to show content */
    padding-top: 12px;
    padding-bottom: 12px;
  }

  /* Make the section header tappable and show a caret */
  .menu-category h3 {
    display: flex;
    align-items: center;
    justify-content: space-between;
    cursor: pointer;
    gap: 12px;
    padding: 8px 6px;
    margin: 0;
  }

  .menu-category h3::after {
    content: '\25BC';
    font-size: 0.9rem;
    transform: rotate(0deg);
    transition: transform .28s ease;
    color: var(--maroon);
  }

  .menu-category.expanded h3::after {
    transform: rotate(180deg);
  }

  /* make cards slightly larger in expanded mobile view */
  .menu-category .menu-card { margin-bottom: 12px; }
}

/* ===== MENU: categories + cards ===== */
.menu-section{ padding:60px 18px 80px; max-width:1300px; margin: 0 auto; }
.menu-section h2{ text-align:center; font-family:"Playfair Display", serif; color:var(--maroon); font-size:2.25rem; margin-bottom:20px; }

.menu-category { margin:36px 0; padding: 8px 6px; }
.menu-category h3 { text-align:center; font-size:1.35rem; margin-bottom:18px; color:#333; font-weight:700; }

/* make cards slightly larger so they almost fill the line */
.menu-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 22px;
  align-items: start;
  margin: 0 auto;
  max-width: 1200px;
  width: 100%;
  padding: 0 12px; /* match the mobile inset */
  box-sizing: border-box;
}

/* CARD */
.menu-card {
  background: #fff;
  border-radius:14px;
  overflow:hidden;
  box-shadow: 0 14px 40px rgba(0,0,0,0.06);
  transition: transform .38s cubic-bezier(.2,.9,.2,1), box-shadow .38s;
  display:flex;
  flex-direction: column;
}
.menu-card img.menu-img{
  width:100%;
  height:100px; /* tall enough to feel premium */
  object-fit:cover;
  display:block;
  transition: transform .6s ease;
}
.menu-card .info{ padding:14px; text-align:center; flex:1 1 auto; }
.menu-card .info h3 { margin:0 0 6px; font-size:1.05rem; font-weight:700; color:#222; font-family:"Poppins",sans-serif; }
.menu-card .info p { margin:0; color:var(--maroon); font-weight:700; font-size:1rem; }

.menu-card:hover{ transform: translateY(-10px) scale(1.02); box-shadow: 0 28px 80px rgba(0,0,0,0.12); }
.menu-card:hover img.menu-img{ transform: scale(1.06); }

/* hide extras */
.hidden { display:none !important; }

/* view toggle (centered) */
.category-actions { text-align:center; margin-top:12px; }
.view-toggle {
  display:inline-block;
  padding:10px 22px;
  border-radius:26px;
  background:var(--maroon);
  color:#fff;
  font-weight:700;
  border:0;
  cursor:pointer;
  transition: transform .18s;
}
.view-toggle:hover{ transform: translateY(-3px); background:#8b121c; }

/* SERVICES slider (slightly longer/wider cards) */
.services{ padding:64px 18px; background: #fff; }
.services h2{ text-align:center; font-family:"Playfair Display", serif; color:var(--maroon); margin-bottom:18px; font-size:2rem; }
.slider { overflow:hidden; padding:10px 0; }
.slide-track { display:flex; gap:24px; align-items:stretch; animation: scroll 26s linear infinite; padding:10px 6px; }
.slide { width:300px; flex:0 0 300px; border-radius:14px; overflow:hidden; background:#fff; box-shadow: 0 18px 46px rgba(0,0,0,0.10); display:flex; flex-direction:column; }
.slide img{ width:100%; height:200px; object-fit:cover; display:block; }
.slide p{ margin:0; padding:12px; font-weight:700; text-align:center;}
.slider:hover .slide-track{ animation-play-state: paused; }

@keyframes scroll { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

/* INQUIRIES flipping */
.inquiries{ padding:60px 18px; background: #fff; text-align:center; }
.cards{ display:flex; gap:28px; justify-content:center; flex-wrap:wrap; }
.flip-card{ width:280px; height:220px; perspective:1200px; position:relative; }
.flip-card-inner{ position:relative; width:100%; height:100%; transition: transform .85s cubic-bezier(.2,.9,.2,1); transform-style:preserve-3d; }
.flip-card.flipped .flip-card-inner { transform: rotateY(180deg); }
.flip-card-front, .flip-card-back{ position:absolute; inset:0; border-radius:12px; backface-visibility:hidden; display:flex; align-items:center; justify-content:center; padding:14px; box-shadow:0 18px 50px rgba(0,0,0,0.08); }
.flip-card-front{ background:var(--maroon); color:#fff; font-weight:800; font-size:1.18rem;}
.flip-card-back{ background:#fff; transform: rotateY(180deg); flex-direction:column; gap:8px; }

/* CONTACT & FOOTER */
.contact{ padding:44px 18px; text-align:center; background:#fff; }
.footer{ padding:18px; text-align:center; background:var(--maroon); color:#fff; }

/* Responsive */
@media (max-width:980px){
  .hero-inner { flex-direction:column; gap:18px; text-align:center; }
  .hero-text { max-width:100%; }
  .hero-main-img{ width:100%; height:320px; }
  .hero-small-img{ position:relative; right:auto; bottom:auto; margin-top:-70px; width:200px; height:130px; }
  .menu-grid { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap:18px; }
  .slide { width:260px; }
}

/* ------------------ Mobile / Small-screen fixes ------------------ */
/* These rules fix overflow, scale images, simplify hero layout and
   hide decorative overlays on small screens to prevent horizontal scroll */

/* Critical mobile layout fixes */
:root { overflow-x: hidden; } /* catch any escaping absolutely positioned elements */
#root, #__next { overflow-x: hidden; } /* also handle common root IDs */

/* Force proper box model and prevent content from creating scrollbars */
*, *::before, *::after { box-sizing: border-box; }
body {
  position: relative; /* create new containing block */
  width: 100%;
  overflow-x: hidden;
  margin: 0;
  padding: 0;
}

/* Make hero more flexible on small screens */
.hero { background-attachment: scroll; /* avoid fixed backgrounds on mobile */ }

@media (max-width: 600px) {
  /* Force proper containment for mobile layout */
  .navbar, header, main, section, footer {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden;
    padding-left: 12px;
    padding-right: 12px;
  }
  
  /* Ensure hero section stays contained */
  .hero {
    padding: 84px 12px 36px; /* match the 12px inset */
    min-height: 60vh;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background-position: center;
    width: 100%;
    max-width: 100%;
    overflow: hidden; /* critical: prevent background/overlay overflow */
  }

  /* Ensure hero text and images stack nicely */
  .hero-content, .hero-images, .hero-inner { width: 100%; max-width: 100%; }
  .hero-content { text-align: center; padding: 8px 4px; }
  .hero-content h1 { font-size: clamp(1.6rem, 6vw, 2.4rem); line-height: 1.05; }
  .hero-content p { font-size: 1rem; }

  /* Make the main hero image responsive and avoid fixed overflow */
  .hero-main-img { max-width: 100%; height: auto; width: 95%; }
  .hero-main-img img, .hero-main-img > img { width: 100%; height: auto; display: block; }

  /* Hide decorative overlay image that causes horizontal scroll on small screens */
  .hero-overlay-img { display: none; }

  /* Navbar compacting */
  .navbar { padding: 10px 12px; }
  .navbar .logo { font-size: 1.2rem; }

  /* Make menu-grid single column for small phones to improve readability */
  .menu-grid { grid-template-columns: 1fr; gap: 16px; padding: 0 6px; }

  /* Slightly taller card images so cards look balanced on narrow screens */
  .menu-card img.menu-img { height: 160px; object-fit: cover; }

  /* Make slides smaller on narrow screens */
  .slide { width: 200px; flex: 0 0 200px; }

  /* Stack inquiry cards vertically */
  .cards { flex-direction: column; align-items: center; }
}

/* Extra safety: for very narrow devices */
@media (max-width: 380px) {
  .hero-content h1 { font-size: 1.5rem; }
  .btn { padding: 10px 14px; font-size: 0.95rem; }
}

/* Stronger hero overflow protection and medium-screen overlay hiding */
/* This prevents absolutely-positioned decorative images from creating a horizontal scrollbar */
.hero { overflow-x: hidden; }
.hero-images { max-width: 100%; }

@media (max-width: 900px) {
  /* Use the inline hero image on medium+small screens and remove the large CSS background
     This prevents the huge background + inline image stacking and avoids horizontal/inner scroll */
  .hero {
    background: none !important;
    min-height: auto;
    padding: 84px 14px 36px;
    align-items: center;
    justify-content: center;
  }

  /* hide the decorative overlay earlier to avoid any horizontal overflow */
  .hero-overlay-img { display: none !important; }

  /* Constrain the inline hero image so it never grows taller than the viewport on phones */
  .hero-main-img {
    max-width: 100%;
    width: 100%;
    max-height: 56vh; /* keep it visually prominent but not huge */
    overflow: hidden;
    border-radius: 14px;
  }
  .hero-main-img img { width: 100%; height: 100%; object-fit: cover; display: block; }

  .hero-images { display: flex; justify-content: center; align-items: center; margin-top: 12px; }
  .hero-content { max-width: 480px; }
}
@media (max-width:640px){
  .navbar{ padding:10px 12px; width: 100%; }
  .hero { padding:90px 12px 36px; width: 100%; }
  .hero-text h1 { font-size:2rem; }
  
  /* Force single-column cards with proper insets */
  .menu-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
    width: 100%;
    padding: 0 12px;
    margin: 0 auto;
  }
  
  /* Ensure cards fill the width minus padding */
  .menu-card {
    width: 100%;
    margin: 0;
  }
  
  .slide { width:220px; }
}

/* --- Full adaptive support for JS-driven navbar --- */
@media (min-width: 1200px) {
  .navbar {
    padding: 16px 6%;
  }
  .navbar .logo {
    height: 42px;
  }
  .navbar ul {
    gap: 30px;
  }
}

@media (max-width: 1199px) and (min-width: 769px) {
  .navbar {
    padding: 14px 4%;
  }
  .navbar .logo {
    height: 38px;
  }
  .navbar ul {
    gap: 20px;
  }
}

@media (max-width: 768px) {
  .menu-toggle {
    display: block;
    font-size: 1.8rem;
    background: none;
    border: none;
    color: var(--accent);
    cursor: pointer;
  }

  .navbar {
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    padding: 12px 4%;
  }

  .navbar nav,
  .navbar .nav-links {
    display: none;
    width: 100%;
  }

  .navbar nav.active,
  .navbar .nav-links.active {
    display: block;
    margin-top: 10px;
  }

  .navbar ul {
    flex-direction: column;
    gap: 12px;
    width: 100%;
  }

  .navbar ul li a {
    display: block;
    width: 100%;
    padding: 8px 0;
    font-size: 1rem;
  }

  .navbar .logo {
    height: 30px;
  }
}

@media (max-width: 480px) {
  .navbar {
    padding: 10px 5%;
  }
  .navbar ul li a {
    font-size: 0.95rem;
  }
}

/* Explicit mobile media queries using `screen and` to ensure mobile-only overrides */
@media screen and (max-width: 768px) {
  /* Make menu category grids single column and center them */
  .menu-grid {
    grid-template-columns: 1fr;
    gap: 16px;
    padding: 8px;
    max-width: 420px;
    margin: 0 auto;
  }

  /* Increase card radius and spacing for touch targets */
  .menu-card, .js-menu-card {
    border-radius: 14px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.08);
  }

  .menu-card img.menu-img, .js-menu-img {
    height: auto;
    max-height: 220px;
    width: 100%;
    object-fit: cover;
  }

  .menu-card .info, .js-card-info {
    padding: 14px;
  }
}

@media screen and (max-width: 480px) {
  .menu-grid {
    grid-template-columns: 1fr;
    gap: 14px;
    padding: 6px;
    max-width: 360px;
  }

  .menu-card img.menu-img, .js-menu-img {
    max-height: 180px;
  }

  .menu-card .info h3, .js-card-info h3 {
    font-size: 1rem;
  }

  .menu-card .info p, .js-card-info p {
    font-size: 1rem;
  }
}

/* Strong overrides for very small screens to force single-column and unify card styles
   Use high specificity so these rules win over previously set grid rules. */
@media screen and (max-width: 480px) {
  .menu-section .menu-grid,
  .menu-section .menu-grid[data-category] {
    grid-template-columns: 1fr !important;
    max-width: 380px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
  }

  /* Make both original and JS-created cards look identical on small screens */
  .menu-section .menu-card,
  .menu-section .js-menu-card,
  .menu-grid .menu-card,
  .menu-grid .js-menu-card {
    border-radius: 14px !important;
    box-shadow: 0 18px 50px rgba(0,0,0,0.06) !important;
    overflow: hidden;
    display: block;
  }

  /* Increase the visible image area so cards appear large like your screenshots */
  .menu-section .menu-card img.menu-img,
  .menu-section .js-menu-img,
  .menu-grid img.menu-img,
  .menu-grid .js-menu-img {
    width: 100% !important;
    height: 180px !important;
    max-height: 220px !important;
    object-fit: cover !important;
    display: block !important;
  }

  .menu-section .menu-card .info,
  .menu-section .js-card-info,
  .menu-grid .menu-card .info {
    padding: 14px !important;
  }
}

/* Reduce hero overlay darkness on small screens so hero content is clearer */
@media screen and (max-width: 900px) {
  .hero::after { background: rgba(0,0,0,0.22) !important; }
}

/* Ensure main content sits below the fixed header on all devices */
main { padding-top: 88px; }
