/* =========================
   MENU PAGE (Hero + Sections)
   ========================= */

:root{
  --menu-tint: #F7F8F7;
}

/* Menu hero */
.menu_hero{
  padding: 64px 18px 46px;
  background: #fff;
  border-bottom: 1px solid rgba(17,24,39,0.06);
}

.menu_hero_inner{
  text-align: center;
  max-width: 900px;
  margin: 0 auto;
}

.menu_badge{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  border-radius: 999px;
  font-weight: 900;
  font-size: 13px;
  background: rgba(31,58,46,0.08);
  border: 1px solid rgba(31,58,46,0.16);
  color: var(--green);
  margin-bottom: 14px;
}

.menu_hero_title{
  margin: 0 0 10px;
  font-size: clamp(2.2rem, 4vw, 3.2rem);
  font-weight: 900;
  letter-spacing: -0.04em;
  line-height: 1.05;
  color: rgba(17,24,39,0.92);
}

.menu_hero_title span{
  color: var(--green);
}

.menu_hero_sub{
  margin: 0 auto;
  max-width: 700px;
  color: rgba(17,24,39,0.70);
  font-weight: 650;
  line-height: 1.7;
}

/* =========================
   MENU SECTIONS
   ========================= */

.menu_section{
  padding: 56px 18px;
  background: #fff;
}

.menu_section:nth-of-type(even){
  background: var(--menu-tint);
  box-shadow:
    inset 0 1px 0 rgba(17,24,39,0.04),
    inset 0 -1px 0 rgba(17,24,39,0.04);
}

.menu_section_title{
  margin: 0 0 22px;
  text-align: center;
  font-size: clamp(1.8rem, 2.8vw, 2.4rem);
  font-weight: 900;
  letter-spacing: -0.03em;
  color: rgba(17,24,39,0.92);
}

/* Make sure container stays consistent */
.menu_section .container{
  max-width: 1200px;
  margin: 0 auto;
}

/* Grid (3 cols desktop) */
.menu_section .grid{
  display: grid;
  gap: 16px;
}

.menu_section .grid.grid--3{
  grid-template-columns: repeat(3, 1fr);
}

/* Card */
.menu_section .card{
  background: #fff;
  border: 1px solid rgba(17,24,39,0.10);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 16px 40px rgba(17,24,39,0.06);
  transition: transform .18s ease, box-shadow .18s ease;
}

.menu_section .card:hover{
  transform: translateY(-2px);
  box-shadow: 0 20px 55px rgba(17,24,39,0.10);
}

/* Image: NOT cropped */
.menu_section .card_img{
  width: 100%;
  height: 190px;
  display: block;
  object-fit: cover;     /* shows full image */
  background: #eef2f1;
}

/* Text */
.menu_section .card_body{
  padding: 14px 14px 16px;
}

.menu_section .card_title{
  margin: 0 0 6px;
  font-size: 16px;
  font-weight: 900;
  color: rgba(17,24,39,0.92);
  letter-spacing: -0.01em;
}

.menu_section .card_text{
  margin: 0;
  color: rgba(17,24,39,0.68);
  line-height: 1.6;
  font-weight: 650;
  font-size: 14px;
}

/* Coming soon card */
.menu_section .card--coming{
  background: rgba(17,24,39,0.02);
  border: 1px dashed rgba(17,24,39,0.18);
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
}

.menu_section .card--coming .card_body{
  padding: 22px 16px;
}

.menu_section .card--coming .card_title{
  color: rgba(17,24,39,0.85);
}

.menu_section .card--coming .card_text{
  color: rgba(17,24,39,0.60);
}

/* Responsive */
@media (max-width: 1000px){
  .menu_section .grid.grid--3{
    grid-template-columns: 1fr 1fr;
  }
  .menu_section .card_img{
    height: 210px;
  }
}

@media (max-width: 650px){
  .menu_section{
    padding: 44px 16px;
  }
  .menu_section .grid.grid--3{
    grid-template-columns: 1fr;
  }
  .menu_section .card_img{
    height: 220px;
  }
}