/* ============================================================
   Delicious · /menu — table-optimised, app-like menu view
   Inherits brand vars + board + fonts from ../styles.css
   ============================================================ */

.menu-page {
  padding-bottom: 40px;
  /* room for iOS safe areas when QR-scanned in standalone */
  padding-left: env(safe-area-inset-left);
  padding-right: env(safe-area-inset-right);
}

/* One consistent centered column — every block lines up to the same edges */
.menu-shell { max-width: 760px; margin: 0 auto; }

/* ---------- Top bar (scrolls away) ---------- */
.menu-top {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px 10px;
}
.mt-brand .pill { background: #15191c; padding: 7px 11px; border-radius: 6px; display: inline-block; box-shadow: inset 0 1px 0 rgba(255,255,255,0.06); }
.mt-brand .pill img { height: 30px; display: block; }
.mt-right { display: flex; align-items: center; gap: 12px; }

.open-flag.mini { margin: 0; padding: 6px 11px; font-size: 11px; }

.lang-toggle { display: inline-flex; border: 1px solid var(--chalk-line); border-radius: 999px; overflow: hidden; }
.lang-toggle button {
  font-family: var(--f-label); letter-spacing: 0.1em; font-size: 12px;
  padding: 6px 12px; background: transparent; color: var(--chalk-dim);
  border: 0; cursor: pointer; transition: all .15s ease;
}
.lang-toggle button.active { background: var(--chalk-blue); color: var(--slate); }

/* ---------- Hero line ---------- */
.menu-hero { padding: 6px 20px 14px; }
.menu-hero h1 { font-size: clamp(40px, 12vw, 62px); margin: 0; color: var(--chalk); }
.menu-hero .script { font-size: 19px; color: var(--peach); margin-top: 2px; }

/* ---------- Specials ---------- */
.specials-card {
  margin: 6px 20px 18px; border-radius: 14px; border: 1px solid var(--chalk-line);
  padding: 16px 18px;
}
.specials-card .sc-label { color: var(--chalk-blue); margin-bottom: 12px; }
.sc-items { display: grid; gap: 12px; }
.sc-item { display: flex; align-items: baseline; gap: 10px; }
.sc-item .sc-name { font-family: var(--f-display); font-size: 22px; color: var(--chalk); transform: rotate(-1deg); line-height: 1; }
.sc-item .sc-desc { display: block; font-family: var(--f-body); font-size: 13px; color: var(--chalk-dim); transform: none; margin-top: 4px; }
.sc-item .sc-dots { flex: 1 1 auto; border-bottom: 1px dotted var(--chalk-line); transform: translateY(-5px); }
.sc-item .sc-price { font-family: var(--f-headline); font-size: 19px; color: var(--peach); white-space: nowrap; }

/* ---------- Sticky controls ---------- */
.menu-controls {
  position: sticky; top: 0; z-index: 30;
  background: rgba(14,17,19,0.92); backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--chalk-line);
  padding: 12px 20px 12px;
}
.mc-row { display: flex; gap: 12px; align-items: center; }
.mc-row + .mc-row { margin-top: 10px; }

.daypart { display: inline-flex; background: #15181a; border: 1px solid var(--chalk-line); border-radius: 999px; padding: 3px; flex: 0 0 auto; }
.daypart button {
  font-family: var(--f-label); text-transform: uppercase; letter-spacing: 0.1em; font-size: 11.5px;
  padding: 7px 13px; border-radius: 999px; border: 0; background: transparent; color: var(--chalk-dim); cursor: pointer;
  transition: all .15s ease; white-space: nowrap;
}
.daypart button.active { background: var(--chalk-blue); color: var(--slate); }

.search-box {
  flex: 1 1 auto; display: flex; align-items: center; gap: 8px;
  background: #15181a; border: 1px solid var(--chalk-line); border-radius: 999px; padding: 8px 14px;
  min-width: 0;
}
.search-box svg { width: 17px; height: 17px; color: var(--chalk-faint); flex: 0 0 auto; }
.search-box input {
  flex: 1 1 auto; min-width: 0; background: transparent; border: 0; outline: 0;
  color: var(--chalk); font-family: var(--f-body); font-size: 15px;
}
.search-box input::placeholder { color: var(--chalk-faint); }

/* daypart on the left, filters pushed to the right — always one line */
.mc-top { flex-wrap: nowrap; gap: 8px; }
.mc-top .filters { margin-left: auto; }
.mc-cats { overflow: hidden; }
.filters { display: inline-flex; gap: 7px; flex: 0 0 auto; }
.filters button {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--f-label); text-transform: uppercase; letter-spacing: 0.08em; font-size: 11px;
  padding: 7px 13px; border-radius: 999px; cursor: pointer; white-space: nowrap;
  background: transparent; color: var(--chalk-dim); border: 1px solid var(--chalk-line); transition: all .15s ease;
}
.filters button.active { background: var(--mint); color: var(--slate); border-color: var(--mint); }
/* dietary icons — tint with the button's text colour */
.filters button::before {
  content: ""; width: 14px; height: 14px; flex: 0 0 auto; background: currentColor;
  -webkit-mask: var(--fi) center / contain no-repeat; mask: var(--fi) center / contain no-repeat;
}
.filters button[data-filter="v"] {
  --fi: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M6.05 8.05c-2.73 2.73-2.73 7.17 0 9.9C7.42 19.32 9.21 20 11 20c1.79 0 3.58-.68 4.95-2.05C20.46 13.44 20.5 4 20.5 4S11.05 3.55 6.05 8.05z'/%3E%3C/svg%3E");
}
.filters button[data-filter="v"].active { background: var(--mint); border-color: var(--mint); }
.filters button[data-filter="gf"] {
  --fi: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.4'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Cline x1='5.6' y1='5.6' x2='18.4' y2='18.4'/%3E%3C/svg%3E");
}
.filters button[data-filter="gf"].active { background: var(--chalk-blue); border-color: var(--chalk-blue); }
/* tiny phones: let the filters drop under the daypart so they can never clip */
@media (max-width: 344px) {
  .mc-top { flex-wrap: wrap; }
  .mc-top .filters { margin-left: 0; margin-top: 8px; }
}

.cat-chips {
  display: flex; gap: 8px; overflow-x: auto; flex: 1 1 auto;
  scrollbar-width: none; -webkit-overflow-scrolling: touch; padding-bottom: 2px;
}
.cat-chips::-webkit-scrollbar { display: none; }
.cat-chips button {
  font-family: var(--f-label); text-transform: uppercase; letter-spacing: 0.1em; font-size: 12px;
  padding: 7px 14px; border-radius: 999px; cursor: pointer; white-space: nowrap; flex: 0 0 auto;
  background: #15181a; color: var(--chalk-dim); border: 1px solid var(--chalk-line); transition: all .15s ease;
}
.cat-chips button.active { background: var(--chalk); color: var(--slate); border-color: var(--chalk); }

/* ---------- Menu body ---------- */
.menu-body { padding: 20px 20px 0; }
.menu-group {
  scroll-margin-top: 168px; /* offset under the (now 3-row) sticky controls */
  /* reset the boxed-card style that leaks in from ../styles.css —
     on the menu page we want clean divider lines, not boxes */
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--chalk-line);
  border-radius: 0;
  margin: 0;
  padding: 10px 2px 24px;
}
.menu-group:last-child { border-bottom: 0; }
.menu-group h2 {
  font-family: var(--f-display); color: var(--chalk-blue); font-size: 30px;
  margin: 14px 0 2px; transform: rotate(-1deg); letter-spacing: 0.01em;
}
.menu-group .g-note { font-family: var(--f-script); font-size: 18px; color: var(--peach); margin: 2px 0; }
.menu-group .g-blurb { font-size: 14px; color: var(--chalk-dim); margin: 6px 0 6px; line-height: 1.4; }

.m-item {
  display: flex; align-items: baseline; gap: 10px; padding: 13px 0;
  border-bottom: 1px dotted var(--chalk-line);
}
.m-item:last-child { border-bottom: 0; }
.m-item .mi-main { flex: 1 1 auto; min-width: 0; }
.m-item .mi-name { font-size: 16px; font-weight: 500; color: var(--chalk); }
.m-item .mi-name .badge {
  display: inline-block; vertical-align: middle; margin-left: 7px;
  font-family: var(--f-label); text-transform: uppercase; letter-spacing: 0.08em;
  font-size: 9px; padding: 2px 6px; border-radius: 4px; line-height: 1.4;
}
.badge.v  { background: rgba(167,215,161,0.16); color: var(--mint); border: 1px solid rgba(167,215,161,0.4); }
.badge.gf { background: rgba(125,208,232,0.14); color: var(--chalk-blue); border: 1px solid rgba(125,208,232,0.4); }
.m-item .mi-desc { display: block; font-size: 13.5px; color: var(--chalk-dim); margin-top: 3px; line-height: 1.4; }
.m-item .mi-dots { flex: 1 1 auto; border-bottom: 1px dotted var(--chalk-line); transform: translateY(-5px); min-width: 16px; }
.m-item .mi-price { font-family: var(--f-headline); font-size: 18px; color: var(--peach); white-space: nowrap; letter-spacing: 0.02em; }

mark.hl { background: rgba(242,184,125,0.32); color: var(--chalk); border-radius: 2px; padding: 0 1px; }

.no-results { text-align: center; color: var(--chalk-dim); font-family: var(--f-script); font-size: 22px; padding: 40px 20px; }

/* ---------- Footer ---------- */
.menu-foot { padding: 30px 20px 10px; text-align: center; }
.mf-note { font-family: var(--f-label); text-transform: uppercase; letter-spacing: 0.14em; font-size: 11px; color: var(--chalk-dim); }
.mf-note.dim { color: var(--chalk-faint); margin-top: 5px; }
.mf-back { display: inline-block; margin: 18px 0 14px; color: var(--chalk-blue); text-decoration: none; font-family: var(--f-label); text-transform: uppercase; letter-spacing: 0.14em; font-size: 13px; }
.mf-back:hover { text-decoration: underline; }
.mf-base { font-family: var(--f-label); text-transform: uppercase; letter-spacing: 0.16em; font-size: 10px; color: var(--chalk-faint); padding-top: 14px; border-top: 1px solid var(--chalk-line); }

@media (max-width: 460px) {
  .mc-row:first-child { flex-wrap: wrap; }
  .search-box { order: 3; flex-basis: 100%; }
}
