/* ======================================
   MENU.CSS
   Menu + dish-detail layer
   Load on:
   - menu.html
   - menu dish detail pages
   - menu-related landing pages that use menu cards or menu filters
   ====================================== */

.dish-hero{padding:28px 0 8px}

.breadcrumbs{
  font-size:.92rem;
  color:var(--muted);
  margin:8px 0 18px;
}
.breadcrumbs a{
  color:inherit;
  text-decoration:none;
}

.dish-grid{
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(280px,.8fr);
  gap:24px;
  align-items:start;
}

.dish-card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:20px;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.dish-card img{
  display:block;
  width:100%;
  height:auto;
  object-fit:cover;
}

.dish-copy{
  padding:18px 18px 22px;
}

.price-badge{
  display:inline-block;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,45,45,.08);
  border:1px solid rgba(255,45,45,.18);
  font-weight:800;
  margin:10px 0 16px;
}

.detail-list{
  display:grid;
  gap:10px;
  margin:0;
  padding:0;
  list-style:none;
}
.detail-list li{
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  padding:12px 14px;
}

.section-card{
  margin-top:18px;
  padding:18px;
  background:var(--card);
  border:1px solid var(--line);
  border-radius:20px;
  box-shadow:var(--shadow);
}

.pill-links{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:12px;
}
.pill-link{
  display:inline-flex;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid var(--line);
  text-decoration:none;
  color:var(--text);
  background:#fff;
}

/* Enhanced detail sections */
.dish-detail-section{
  margin-top:22px;
  padding:20px;
  background:var(--card,#fff);
  border:1px solid var(--line,#e7e7e7);
  border-radius:18px;
  box-shadow:var(--shadow,0 8px 24px rgba(0,0,0,.06));
}
.dish-detail-section h2{
  margin:0 0 12px;
  font-size:1.2rem;
  line-height:1.3;
}
.dish-detail-section p{
  margin:0 0 12px;
  line-height:1.7;
}

.dish-ingredients,
.dish-steps{
  margin:0;
  padding-left:20px;
  line-height:1.8;
}
.dish-ingredients li,
.dish-steps li{
  margin:6px 0;
}

.bilingual-ingredients li{
  margin:12px 0;
  line-height:1.6;
}
.bilingual-ingredients .ingredient-en{
  font-weight:700;
  color:var(--text,#194d2b);
}
.bilingual-ingredients .ingredient-th{
  display:inline-flex;
  align-items:center;
  margin-left:10px;
  padding:4px 10px;
  border-radius:999px;
  background:#f3ece7;
  border:1px solid #ddd0c5;
  color:#6a5d54;
  font-size:.9rem;
  line-height:1.2;
  font-weight:700;
}

.seasonality-badge-wrap{
  margin-bottom:12px;
}
.season-badge{
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  font-weight:700;
  font-size:.92rem;
}
.season-year-round{
  background:rgba(34,197,94,.12);
  color:#166534;
}
.season-variable{
  background:rgba(245,158,11,.14);
  color:#92400e;
}
.season-general{
  background:rgba(59,130,246,.12);
  color:#1d4ed8;
}

.dish-faq-list{
  display:grid;
  gap:10px;
}
.dish-faq-item{
  border:1px solid var(--line,#e7e7e7);
  border-radius:14px;
  padding:14px;
  background:#fff;
}
.dish-faq-item summary{
  cursor:pointer;
  font-weight:700;
}
.dish-faq-item p{
  margin:10px 0 0;
}

/* Menu page controls */
.menu-lang-btn{
  appearance:none;
  border:0;
  cursor:pointer;
  padding:10px 14px;
  border-radius:999px;
  background:#becdb738;
  color:#37412c;
  font-weight:800;
  letter-spacing:.02em;
}

/* Keep page media responsive */
img,svg,video,canvas{
  max-width:100%;
  height:auto;
}
iframe{
  max-width:100%;
}

/* Responsive */
@media (max-width:900px){
  .dish-grid{
    grid-template-columns:1fr;
  }
}

:root {
  --menu-pill-border: rgba(0, 0, 0, 0.08);
  --menu-pill-text: #23412b;
  --menu-pill-gap: 10px;
  --menu-pill-active-bg: linear-gradient(135deg, #1f5c34 0%, #2d7a49 100%);
  --menu-pill-active-shadow: 0 14px 30px rgba(31, 92, 52, 0.24);
  --menu-bar-bg: linear-gradient(to top, rgba(245, 236, 224, 0.98), rgba(245, 236, 224, 0.90));
  --menu-bar-shadow: 0 -10px 30px rgba(18, 24, 18, 0.10);
  --menu-bar-shadow-scrolled: 0 -14px 36px rgba(18, 24, 18, 0.16);
}

/* Bottom app bar */
.filters-wrap {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 60;
  display: flex;
  justify-content: center;
  padding: 10px 12px calc(10px + env(safe-area-inset-bottom));
  background: var(--menu-bar-bg);
  backdrop-filter: blur(14px);
  border-top: 1px solid rgba(0, 0, 0, 0.06);
  box-shadow: var(--menu-bar-shadow);
  transition:
    box-shadow 0.28s ease,
    transform 0.28s ease,
    background-color 0.28s ease;
}

.filters-wrap.is-scrolled {
  box-shadow: var(--menu-bar-shadow-scrolled);
}

/* Progress indicator */
.filters-progress {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  overflow: hidden;
  background: rgba(0, 0, 0, 0.05);
}

.filters-progress-bar {
  display: block;
  width: 0%;
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, #1f5c34 0%, #4faa67 100%);
  transition: width 0.14s linear;
}

/* Pill rail */
.filters {
  position: relative;
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: var(--menu-pill-gap);
  overflow-x: auto;
  overflow-y: hidden;
  width: min(100%, 980px);
  padding: 6px 2px;
  white-space: nowrap;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  scroll-snap-type: x proximity;
}

.filters::-webkit-scrollbar {
  display: none;
}

/* Sliding active pill */
.filters-active-pill {
  position: absolute;
  top: 6px;
  left: 0;
  width: 0;
  height: calc(100% - 12px);
  border-radius: 999px;
  background: var(--menu-pill-active-bg);
  box-shadow: var(--menu-pill-active-shadow);
  pointer-events: none;
  z-index: 0;
  opacity: 0;
  transition:
    transform 0.34s cubic-bezier(0.2, 0.8, 0.2, 1),
    width 0.34s cubic-bezier(0.2, 0.8, 0.2, 1),
    opacity 0.22s ease;
}

/* Base pill */
.filters .btn {
  position: relative;
  z-index: 1;
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 18px;
  border-radius: 999px;
  white-space: nowrap;
  scroll-snap-align: center;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid var(--menu-pill-border);
  color: var(--menu-pill-text);
  box-shadow: 0 4px 14px rgba(25, 33, 20, 0.06);
  transition:
    color 0.28s ease,
    background-color 0.28s ease,
    border-color 0.28s ease,
    box-shadow 0.28s ease,
    transform 0.18s ease;
  will-change: transform;
}

.filters .btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(25, 33, 20, 0.10);
}

.filters .btn:active {
  transform: scale(0.96);
}

.filters .btn.is-pressing {
  transform: scale(0.94);
}

.filters .btn.is-active {
  color: #fff;
  border-color: transparent;
  background: transparent;
  box-shadow: none;
}

.filters .btn:focus-visible {
  outline: 2px solid rgba(31, 92, 52, 0.38);
  outline-offset: 2px;
}

/* Keep content visible above bottom app bar */
main.menu-main {
  padding-bottom: 112px;
}

#cat-somtam,
#cat-larb,
#cat-a-la-carte,
#cat-rice,
#cat-sides {
  scroll-margin-top: 24px;
  scroll-margin-bottom: 112px;
}

/* Mobile */
@media (max-width: 768px) {
  .filters-wrap {
    padding: 8px 10px calc(8px + env(safe-area-inset-bottom));
  }

  .filters {
    width: 100%;
    justify-content: flex-start;
  }

  .filters .btn {
    min-height: 42px;
    padding: 0 16px;
    font-size: 14px;
  }

  main.menu-main {
    padding-bottom: 100px;
  }

  #cat-somtam,
  #cat-larb,
  #cat-a-la-carte,
  #cat-rice,
  #cat-sides {
    scroll-margin-bottom: 100px;
  }
}

/* Larger devices */
@media (min-width: 769px) {
  .filters-wrap {
    padding: 14px 18px 16px;
  }

  .filters {
    justify-content: center;
    overflow-x: visible;
    width: min(100%, 980px);
    gap: 14px;
  }

  .filters .btn {
    min-height: 52px;
    padding: 0 22px;
    font-size: 15px;
    font-weight: 700;
  }
}

@media (min-width: 1200px) {
  .filters {
    width: min(100%, 1040px);
    gap: 16px;
  }

  .filters .btn {
    min-height: 54px;
    padding: 0 24px;
    font-size: 15px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .filters-wrap,
  .filters-progress-bar,
  .filters-active-pill,
  .filters,
  .filters .btn {
    transition: none;
    scroll-behavior: auto;
  }
}

/* ======================================
   PREMIUM MENU LAYER
   Current premium menu cards / sticky rails / spice chips
   ====================================== */

.dish-hero{padding:28px 0 8px}

.breadcrumbs{
  font-size:.92rem;
  color:var(--muted);
  margin:8px 0 18px;
}
.breadcrumbs a{
  color:inherit;
  text-decoration:none;
}

.dish-grid{
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(280px,.8fr);
  gap:24px;
  align-items:start;
}

.dish-card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:20px;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.dish-card img{
  display:block;
  width:100%;
  height:auto;
  object-fit:cover;
}

.dish-copy{
  padding:18px 18px 22px;
}

.price-badge{
  display:inline-block;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,45,45,.08);
  border:1px solid rgba(255,45,45,.18);
  font-weight:800;
  margin:10px 0 16px;
}

.detail-list{
  display:grid;
  gap:10px;
  margin:0;
  padding:0;
  list-style:none;
}
.detail-list li{
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  padding:12px 14px;
}

.section-card{
  margin-top:18px;
  padding:18px;
  background:var(--card);
  border:1px solid var(--line);
  border-radius:20px;
  box-shadow:var(--shadow);
}

.pill-links{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:12px;
}
.pill-link{
  display:inline-flex;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid var(--line);
  text-decoration:none;
  color:var(--text);
  background:#fff;
}

/* Enhanced detail sections */
.dish-detail-section{
  margin-top:22px;
  padding:20px;
  background:var(--card,#fff);
  border:1px solid var(--line,#e7e7e7);
  border-radius:18px;
  box-shadow:var(--shadow,0 8px 24px rgba(0,0,0,.06));
}
.dish-detail-section h2{
  margin:0 0 12px;
  font-size:1.2rem;
  line-height:1.3;
}
.dish-detail-section p{
  margin:0 0 12px;
  line-height:1.7;
}

.dish-ingredients,
.dish-steps{
  margin:0;
  padding-left:20px;
  line-height:1.8;
}
.dish-ingredients li,
.dish-steps li{
  margin:6px 0;
}

.bilingual-ingredients li{
  margin:12px 0;
  line-height:1.6;
}
.bilingual-ingredients .ingredient-en{
  font-weight:700;
  color:var(--text,#194d2b);
}
.bilingual-ingredients .ingredient-th{
  display:inline-flex;
  align-items:center;
  margin-left:10px;
  padding:4px 10px;
  border-radius:999px;
  background:#f3ece7;
  border:1px solid #ddd0c5;
  color:#6a5d54;
  font-size:.9rem;
  line-height:1.2;
  font-weight:700;
}

.seasonality-badge-wrap{
  margin-bottom:12px;
}
.season-badge{
  display:inline-flex;
  align-items:center;
  padding:8px 12px;
  border-radius:999px;
  font-weight:700;
  font-size:.92rem;
}
.season-year-round{
  background:rgba(34,197,94,.12);
  color:#166534;
}
.season-variable{
  background:rgba(245,158,11,.14);
  color:#92400e;
}
.season-general{
  background:rgba(59,130,246,.12);
  color:#1d4ed8;
}

.dish-faq-list{
  display:grid;
  gap:10px;
}
.dish-faq-item{
  border:1px solid var(--line,#e7e7e7);
  border-radius:14px;
  padding:14px;
  background:#fff;
}
.dish-faq-item summary{
  cursor:pointer;
  font-weight:700;
}
.dish-faq-item p{
  margin:10px 0 0;
}

/* Menu page controls */
.menu-lang-btn{
  appearance:none;
  border:0;
  cursor:pointer;
  padding:10px 14px;
  border-radius:999px;
  background:#becdb738;
  color:#37412c;
  font-weight:800;
  letter-spacing:.02em;
}

/* Keep page media responsive */
img,svg,video,canvas{
  max-width:100%;
  height:auto;
}
iframe{
  max-width:100%;
}

/* Responsive */
@media (max-width:900px){
  .dish-grid{
    grid-template-columns:1fr;
  }
}

:root {
  --menu-pill-border: rgba(0, 0, 0, 0.08);
  --menu-pill-text: #23412b;
  --menu-pill-gap: 10px;
  --menu-pill-active-bg: linear-gradient(135deg, #1f5c34 0%, #2d7a49 100%);
  --menu-pill-active-shadow: 0 14px 30px rgba(31, 92, 52, 0.24);
  --menu-bar-bg: linear-gradient(to top, rgba(245, 236, 224, 0.98), rgba(245, 236, 224, 0.90));
  --menu-bar-shadow: 0 -10px 30px rgba(18, 24, 18, 0.10);
  --menu-bar-shadow-scrolled: 0 -14px 36px rgba(18, 24, 18, 0.16);
}

/* Bottom app bar */
.filters-wrap {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 60;
  display: flex;
  justify-content: center;
  padding: 10px 12px calc(10px + env(safe-area-inset-bottom));
  background: var(--menu-bar-bg);
  backdrop-filter: blur(14px);
  border-top: 1px solid rgba(0, 0, 0, 0.06);
  box-shadow: var(--menu-bar-shadow);
  transition:
    box-shadow 0.28s ease,
    transform 0.28s ease,
    background-color 0.28s ease;
}

.filters-wrap.is-scrolled {
  box-shadow: var(--menu-bar-shadow-scrolled);
}

/* Progress indicator */
.filters-progress {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  overflow: hidden;
  background: rgba(0, 0, 0, 0.05);
}

.filters-progress-bar {
  display: block;
  width: 0%;
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, #1f5c34 0%, #4faa67 100%);
  transition: width 0.14s linear;
}

/* Pill rail */
.filters {
  position: relative;
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: var(--menu-pill-gap);
  overflow-x: auto;
  overflow-y: hidden;
  width: min(100%, 980px);
  padding: 6px 2px;
  white-space: nowrap;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  scroll-snap-type: x proximity;
}

.filters::-webkit-scrollbar {
  display: none;
}

/* Sliding active pill */
.filters-active-pill {
  position: absolute;
  top: 6px;
  left: 0;
  width: 0;
  height: calc(100% - 12px);
  border-radius: 999px;
  background: var(--menu-pill-active-bg);
  box-shadow: var(--menu-pill-active-shadow);
  pointer-events: none;
  z-index: 0;
  opacity: 0;
  transition:
    transform 0.34s cubic-bezier(0.2, 0.8, 0.2, 1),
    width 0.34s cubic-bezier(0.2, 0.8, 0.2, 1),
    opacity 0.22s ease;
}

/* Base pill */
.filters .btn {
  position: relative;
  z-index: 1;
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 18px;
  border-radius: 999px;
  white-space: nowrap;
  scroll-snap-align: center;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid var(--menu-pill-border);
  color: var(--menu-pill-text);
  box-shadow: 0 4px 14px rgba(25, 33, 20, 0.06);
  transition:
    color 0.28s ease,
    background-color 0.28s ease,
    border-color 0.28s ease,
    box-shadow 0.28s ease,
    transform 0.18s ease;
  will-change: transform;
}

.filters .btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(25, 33, 20, 0.10);
}

.filters .btn:active {
  transform: scale(0.96);
}

.filters .btn.is-pressing {
  transform: scale(0.94);
}

.filters .btn.is-active {
  color: #fff;
  border-color: transparent;
  background: transparent;
  box-shadow: none;
}

.filters .btn:focus-visible {
  outline: 2px solid rgba(31, 92, 52, 0.38);
  outline-offset: 2px;
}

/* Keep content visible above bottom app bar */
main.menu-main {
  padding-bottom: 112px;
}

#cat-somtam,
#cat-larb,
#cat-a-la-carte,
#cat-rice,
#cat-sides {
  scroll-margin-top: 24px;
  scroll-margin-bottom: 112px;
}

/* Mobile */
@media (max-width: 768px) {
  .filters-wrap {
    padding: 8px 10px calc(8px + env(safe-area-inset-bottom));
  }

  .filters {
    width: 100%;
    justify-content: flex-start;
  }

  .filters .btn {
    min-height: 42px;
    padding: 0 16px;
    font-size: 14px;
  }

  main.menu-main {
    padding-bottom: 100px;
  }

  #cat-somtam,
  #cat-larb,
  #cat-a-la-carte,
  #cat-rice,
  #cat-sides {
    scroll-margin-bottom: 100px;
  }
}

/* Larger devices */
@media (min-width: 769px) {
  .filters-wrap {
    padding: 14px 18px 16px;
  }

  .filters {
    justify-content: center;
    overflow-x: visible;
    width: min(100%, 980px);
    gap: 14px;
  }

  .filters .btn {
    min-height: 52px;
    padding: 0 22px;
    font-size: 15px;
    font-weight: 700;
  }
}

@media (min-width: 1200px) {
  .filters {
    width: min(100%, 1040px);
    gap: 16px;
  }

  .filters .btn {
    min-height: 54px;
    padding: 0 24px;
    font-size: 15px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .filters-wrap,
  .filters-progress-bar,
  .filters-active-pill,
  .filters,
  .filters .btn {
    transition: none;
    scroll-behavior: auto;
  }
}

/* ===== Premium menu page upgrade ===== */






















.menu-page-section {
  padding-inline: clamp(14px, 2.2vw, 24px);
}







.menu-page-grid {
  max-width: 1240px;
  margin-inline: auto;
  gap: 18px;
}

.menu-page-card--premium {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 100%;
  overflow: hidden;
  border-radius: 26px;
  box-shadow: 0 12px 22px rgba(231, 141, 200, 0.42);
  border: 1px solid rgba(32, 39, 25, 0.08);
 /*background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(249,246,240,0.98));
  box-shadow: 0 16px 38px rgba(20, 24, 18, 0.08);*/
  transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease;
}

.menu-page-card--premium:hover {
  transform: translateY(-4px);
  box-shadow: 0 22px 46px rgba(20, 24, 18, 0.12);
  border-color: rgba(32,39,25,0.12);
}

.menu-page-card--premium:focus-visible {
  outline: 3px solid rgba(53, 112, 74, 0.24);
  outline-offset: 3px;
}

.menu-page-photo {
  position: relative;
  aspect-ratio: 1 / 0.86;
  overflow: hidden;
}

.menu-page-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s ease;
}

.menu-page-card--premium:hover .menu-page-photo img {
  transform: scale(1.05);
}

.menu-page-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 14px;
  padding: 14px;
  background: linear-gradient(to top, rgba(12,12,12,.35), rgba(12,12,12,.05) 45%, transparent 72%);
}

.menu-page-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.menu-page-tag {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.9);
  color: #203622;
  font-size: 12px;
  font-weight: 800;
  box-shadow: 0 8px 18px rgba(0,0,0,.10);
}

.menu-page-price--floating {
  align-self: flex-start;
  margin-top: auto;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(12, 22, 14, .78);
  color: #fff;
  backdrop-filter: blur(8px);
  box-shadow: 0 12px 24px rgba(0,0,0,.18);
}

.menu-page-body {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  gap: 12px;
  padding: 16px 16px 18px;
}

.menu-page-heading{
	border-radius: 10px;
	margin-bottom: 8px;
  position: relative;
  padding: 18px 20px;
  border-radius: 18px;
  background: linear-gradient( 135deg, rgba(255, 255, 255, 0.55), rgba(255, 255, 255, 0.25) );
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border: 1px solid rgba(255, 255, 255, 0.35);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08), inset 0 1px 0 rgba(255, 255, 255, 0.6);
  color: #1f2a1f;
}

.menu-page-row {
  align-items: flex-start;
}

.menu-page-names {
  min-width: 0;
}

.menu-page-name {
  margin: 0;
  line-height: 1.2;
}

.menu-page-desc {
  margin: 0;
  color: #536053;
  font-size: .95rem;
  line-height: 1.6;
}

.menu-page-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: auto;
}

.menu-page-meta span {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 6px 10px;
  border-radius: 999px;
  background: #f3efe8;
  color: #546255;
  border: 1px solid rgba(42,58,41,0.07);
  font-size: 12px;
  font-weight: 700;
}

.menu-page-actions {
  display: flex;
  gap: 10px;
  margin-top: 2px;
}

.menu-page-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 14px;
  border-radius: 14px;
  text-decoration: none;
  font-weight: 800;
  transition: transform .18s ease, box-shadow .18s ease, background-color .18s ease;
}

.menu-page-action:hover {
  transform: translateY(-1px);
}

.menu-page-action--primary {
  flex: 1 1 auto;
  background: linear-gradient(135deg, #193d24 0%, #2d6a3e 100%);
  color: #fff;
  box-shadow: 0 10px 22px rgba(25,61,36,.18);
}



.menu-discover-section .card,
.menu-guide-cta .card {
  border-radius: 24px;
  border: 1px solid rgba(32,39,25,0.08);
 /* background: linear-gradient(180deg, rgba(255,255,255,0.92), rgba(248,244,237,0.98));*/
  box-shadow: 0 16px 36px rgba(20,24,18,.08);
}

.menu-guide-cta .quickRow {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}

@media (max-width: 900px) {
  .menu-hero-badges,
  .menu-hero-stats {
    grid-template-columns: 1fr;
  }

  .menu-page-heading {
    flex-direction: column;
    align-items: stretch;
  }
}

@media (max-width: 768px) {
  .menu-hero-inner--premium {
    border-radius: 24px;
  }

  .menu-hero-kicker {
    font-size: 11px;
  }

  .menu-hero-actions--premium {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

  .menu-page-grid {
    gap: 14px;
  }

  .menu-page-card--premium {
    border-radius: 22px;
  }

  .menu-page-photo {
    aspect-ratio: 1 / 0.82;
  }

  .menu-page-body {
    padding: 14px 14px 16px;
  }

  .menu-page-actions {
    gap: 8px;
  }

  .menu-page-action {
    min-height: 42px;
    padding-inline: 12px;
    font-size: 14px;
  }
}

@media (max-width: 520px) {
  .menu-hero-actions--premium {
    grid-template-columns: 1fr;
  }

  .menu-page-meta {
    gap: 6px;
  }

  .menu-page-meta span,
  .menu-page-tag {
    font-size: 11px;
  }
}


/* v12.12.3 streamlined premium card structure */
.menu-page-card--premium .menu-page-body{
  gap: 10px;
}

.menu-page-card--premium .menu-page-row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}

.menu-page-card--premium .menu-page-meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top: 2px;
}

.menu-page-card--premium .menu-page-actions{
  display:flex;
  gap:10px;
  margin-top: 0;
}

.menu-page-card--premium .menu-page-actions > .menu-page-action--primary{
  flex: 1 1 auto;
  width: 100%;
}

.menu-page-card--premium .menu-page-action--ghost{
  display:none !important;
}

.menu-page-card--premium .menu-page-meta span + span{
  display:none !important;
}

@media (max-width: 720px){
  .menu-page-card--premium .menu-page-body{
    padding: 14px 14px 16px;
  }

  .menu-page-card--premium .menu-page-desc{
    font-size: .92rem;
    line-height: 1.55;
  }
}


/* v12.12.4 spice level chips */
.menu-page-spice{
  white-space: nowrap;
}


.menu-page-count{
 /*	padding: 8px;*/
  font-weight: 800;
 /*background: #fff3e7;
  margin-bottom: 8px;
  border-radius: 9px;*/
}

	





.menu-page-card--premium .menu-page-meta span + span{
  display:inline-flex !important;
}


.menu-hero {
padding: 2px 2px 4px 2px;
}
