/* =========================================================================
   MENU PAGE
   ========================================================================= */

/* ---------- HEAD ---------- */
.menuhead {
  background: var(--color-cream);
  padding: var(--s-16) 0 var(--s-12);
  text-align: center;
}
.menuhead__inner { max-width: 920px; margin: 0 auto; }
.menuhead__title {
  font-size: clamp(2.5rem, 6vw, var(--fs-96));
  margin: var(--s-4) 0 var(--s-6);
}
.menuhead__lede {
  font-size: var(--fs-18);
  color: var(--color-ink-soft);
  max-width: 60ch;
  margin: 0 auto var(--s-10);
  line-height: var(--lh-loose);
}
.menuhead__pills {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  justify-content: center;
  padding-top: var(--s-6);
  border-top: 1px solid var(--color-line);
}
.pill {
  padding: var(--s-2) var(--s-5);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-full);
  font-size: var(--fs-14);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  font-weight: var(--weight-medium);
  background: var(--color-cream-soft);
  transition: all var(--dur-fast) var(--ease-out);
}
.pill:hover { background: var(--color-cream-deep); }
.pill.is-active { background: var(--color-ink); color: var(--color-cream); border-color: var(--color-ink); }

/* ---------- SECTIONS ---------- */
.menusection { padding: var(--s-20) 0; scroll-margin-top: 100px; }
.menusection--alt { background: var(--color-cream-deep); }
.menusection__head {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--s-12);
  align-items: end;
  margin-bottom: var(--s-12);
  padding-bottom: var(--s-6);
  border-bottom: 1px solid var(--color-line);
}
.menusection__head h2 {
  font-size: clamp(2rem, 4.5vw, var(--fs-56));
  margin-top: var(--s-2);
}
.menusection__num {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-24);
  color: var(--color-burgundy);
  display: block;
}
.menusection__head p {
  font-size: var(--fs-16);
  color: var(--color-ink-soft);
  max-width: 48ch;
  text-align: right;
  justify-self: end;
  line-height: var(--lh-loose);
}

/* ---------- MENU GRID ---------- */
.menugrid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-6);
}
.menugrid--4 { grid-template-columns: repeat(4, 1fr); }

.menu-card {
  background: var(--color-paper);
  border: 1px solid var(--color-line-soft);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
  position: relative;
}
.menu-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.menu-card__media { aspect-ratio: 5 / 4; position: relative; }
.menu-card--compact .menu-card__media { aspect-ratio: 4 / 3; }
.menu-card__body {
  padding: var(--s-5) var(--s-6) var(--s-6);
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  flex: 1;
}
.menu-card__tag {
  font-size: var(--fs-12);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-burgundy);
  margin-bottom: var(--s-1);
}
.menu-card h3 {
  font-family: var(--font-display);
  font-size: var(--fs-24);
  font-weight: var(--weight-medium);
  color: var(--color-ink);
  line-height: var(--lh-snug);
}
.menu-card p {
  font-size: var(--fs-14);
  color: var(--color-ink-soft);
  line-height: var(--lh-normal);
  flex: 1;
}
.menu-card__foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: var(--s-4);
  padding-top: var(--s-4);
  border-top: 1px dashed var(--color-line);
}
.menu-card__price {
  font-family: var(--font-display);
  font-size: var(--fs-24);
  color: var(--color-burgundy);
  font-weight: var(--weight-medium);
}
.menu-card__price small { font-size: var(--fs-12); color: var(--color-ink-mute); font-family: var(--font-body); }
.menu-card__btn {
  background: var(--color-cream-deep);
  color: var(--color-ink);
  padding: var(--s-2) var(--s-4);
  border-radius: var(--radius-full);
  font-size: var(--fs-12);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  transition: all var(--dur-fast);
}
.menu-card__btn:hover { background: var(--color-ink); color: var(--color-cream); }
.menu-card__btn--lg { padding: var(--s-4) var(--s-8); font-size: var(--fs-14); margin-top: var(--s-2); align-self: flex-start; }

.menu-card--feature {
  grid-column: span 2;
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  background: var(--color-cream-soft);
  border-color: var(--color-line);
}
.menu-card--feature .menu-card__media { aspect-ratio: auto; }
.menu-card--feature .menu-card__body { padding: var(--s-10); }
.menu-card--feature h3 { font-size: var(--fs-32); }
.menu-card__opts {
  margin-top: var(--s-4);
  padding-top: var(--s-4);
  border-top: 1px dashed var(--color-line);
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
}
.menu-card__opts li {
  display: flex;
  justify-content: space-between;
  font-size: var(--fs-14);
  color: var(--color-ink-soft);
  padding: var(--s-2) 0;
}
.menu-card__opts strong {
  font-family: var(--font-display);
  font-size: var(--fs-18);
  color: var(--color-burgundy);
  font-weight: var(--weight-medium);
}

/* ---------- MENU LIST (salados restaurant-menu style) ---------- */
.menulist {
  max-width: 920px;
  margin: 0 auto;
}
.menulist__row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: baseline;
  gap: var(--s-4);
  padding: var(--s-6) 0;
  border-bottom: 1px solid var(--color-line);
}
.menulist__row:last-child { border-bottom: none; }
.menulist__name h3 {
  font-family: var(--font-display);
  font-size: var(--fs-24);
  font-weight: var(--weight-medium);
  color: var(--color-ink);
  margin-bottom: var(--s-1);
}
.menulist__sub {
  font-family: var(--font-body);
  font-size: var(--fs-14);
  font-style: italic;
  color: var(--color-ink-mute);
  font-weight: var(--weight-regular);
}
.menulist__name p { color: var(--color-ink-soft); font-size: var(--fs-14); line-height: var(--lh-normal); max-width: 60ch; }
.menulist__dots {
  flex: 1;
  border-bottom: 1px dotted var(--color-line);
  margin: 0 var(--s-3);
  transform: translateY(-8px);
}
.menulist__price {
  font-family: var(--font-display);
  font-size: var(--fs-32);
  color: var(--color-burgundy);
  font-weight: var(--weight-medium);
}

/* ---------- CAFE GRID ---------- */
.cafe-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-12);
  max-width: 1100px;
  margin: 0 auto;
}
.cafe-col__title {
  font-family: var(--font-body);
  font-size: var(--fs-12);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wider);
  color: var(--color-burgundy);
  margin-bottom: var(--s-5);
  padding-bottom: var(--s-3);
  border-bottom: 1px solid var(--color-line);
}
.cafe-row {
  display: flex;
  justify-content: space-between;
  padding: var(--s-3) 0;
  font-family: var(--font-display);
  font-size: var(--fs-20);
  border-bottom: 1px dotted var(--color-line-soft);
}
.cafe-row em { font-style: italic; color: var(--color-ink-mute); font-size: var(--fs-14); margin-left: var(--s-1); }
.cafe-row__price { color: var(--color-burgundy); font-weight: var(--weight-medium); }

/* ---------- CUSTOM CTA ---------- */
.custom-cta {
  background: var(--color-ink);
  color: var(--color-cream-soft);
  padding: var(--s-24) 0;
}
.custom-cta__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-12);
  align-items: center;
}
.custom-cta__copy .eyebrow { color: var(--color-butter); }
.custom-cta__copy h2 {
  color: var(--color-cream-soft);
  font-size: clamp(2rem, 5vw, var(--fs-72));
  margin: var(--s-4) 0 var(--s-6);
}
.custom-cta__copy h2 em { color: var(--color-butter); }
.custom-cta__copy p {
  color: var(--color-ink-mute);
  font-size: var(--fs-18);
  line-height: var(--lh-loose);
  margin-bottom: var(--s-8);
  max-width: 50ch;
}
.custom-cta__list { display: flex; flex-direction: column; gap: var(--s-3); margin-bottom: var(--s-8); }
.custom-cta__list div {
  font-size: var(--fs-16);
  color: var(--color-cream-soft);
  padding: var(--s-3) 0;
  border-bottom: 1px solid var(--color-ink-soft);
  display: flex;
  gap: var(--s-4);
}
.custom-cta__list strong {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--color-butter);
  font-weight: var(--weight-medium);
}

.custom-cta__art {
  position: relative;
  aspect-ratio: 1 / 1;
}
.custom-cta__photo { position: absolute; border-radius: var(--radius-lg); }
.custom-cta__photo.a { top: 0; right: 0; width: 70%; aspect-ratio: 4/5; }
.custom-cta__photo.b { bottom: 0; left: 0; width: 45%; aspect-ratio: 1/1; box-shadow: var(--shadow-lg); }
.custom-cta__photo.c { top: 18%; left: 8%; width: 36%; aspect-ratio: 1/1; transform: rotate(-4deg); box-shadow: var(--shadow-lg); }

/* ---------- RESPONSIVE ---------- */
@media (max-width: 1000px) {
  .menusection__head { grid-template-columns: 1fr; gap: var(--s-4); }
  .menusection__head p { text-align: left; justify-self: start; }
  .menugrid { grid-template-columns: repeat(2, 1fr); }
  .menugrid--4 { grid-template-columns: repeat(2, 1fr); }
  .menu-card--feature { grid-column: span 2; grid-template-columns: 1fr; }
  .menu-card--feature .menu-card__media { aspect-ratio: 16/9; }
  .cafe-grid { grid-template-columns: 1fr; gap: var(--s-8); }
  .custom-cta__inner { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .menugrid, .menugrid--4 { grid-template-columns: 1fr; }
  .menu-card--feature { grid-column: span 1; }
  .menulist__row { grid-template-columns: 1fr auto; }
  .menulist__dots { display: none; }
}
