/* ═══════════════════════════════════════════════════════════════
   MENU SHARED  –  Design tokens
   Used by: frontend/online-menu.html, dine_in/choose_items.html
   ═══════════════════════════════════════════════════════════════ */
:root {
  --mn-red:       #dd4045;
  --mn-primary:    #dd4045;
  --mn-primary-dk: #b91c1c;
  --mn-primary-lt: #fef2f2;
  --mn-bg:        #f3f4f6;
  --mn-surface:   #ffffff;
  --mn-ink-1:     #111827;
  --mn-ink-2:     #374151;
  --mn-ink-3:     #9ca3af;
  --mn-border:    #e5e7eb;
  --mn-shadow-xs: 0 1px 2px rgba(0,0,0,.05);
  --mn-shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.05);
  --mn-shadow:    0 4px 12px rgba(0,0,0,.08), 0 1px 3px rgba(0,0,0,.05);
  --mn-r:         12px;
  --mn-r-sm:       8px;
  --mn-r-xs:       6px;
}

.mn-page { background: var(--mn-bg); min-height: calc(100vh - 170px); font-family: -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif; }

/* ═══════════════════════════════════════════════════════════════
   HERO HEADER
   ═══════════════════════════════════════════════════════════════ */
.mn-hero {
  background: linear-gradient(135deg, var(--mn-primary) 0%, var(--mn-primary-dk) 100%);
  /*padding: env(safe-area-inset-top,0) 0 0;*/
  padding: 0px 0.75rem;
}
.mn-hero__inner {
  display: flex; align-items: center; gap: 12px;
  padding: 18px 0px 16px;
  max-width: 680px; margin: 0 auto;
}
.mn-hero__logo {
  width: 54px; height: 54px; border-radius: 14px;
  object-fit: cover; flex-shrink: 0;
  border: 2px solid rgba(255,255,255,.3);
  background-color: var(--mn-surface);
}
.mn-hero__logo-init {
  width: 54px; height: 54px; border-radius: 14px; flex-shrink: 0;
  background: rgba(255,255,255,.2); border: 2px solid rgba(255,255,255,.28);
  color: #fff; font-size: 22px; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
}
.mn-hero__text { flex: 1; min-width: 0; }
.mn-hero__name {
  font-size: 19px; font-weight: 800; color: #fff; margin: 0;
  line-height: 1.2; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.mn-hero__addr {
  font-size: 13px; color: rgba(255,255,255,.68);
  margin: 3px 0 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* ═══════════════════════════════════════════════════════════════
   STICKY CATEGORY BAR
   ═══════════════════════════════════════════════════════════════ */
.mn-cat-bar {
  background: var(--mn-surface);
  border-bottom: 1px solid var(--mn-border);
  position: sticky; top: 0; z-index: 100;
  box-shadow: var(--mn-shadow-xs);
  margin: 0px -0.75rem;
  padding: 0px 0.75rem;
}
.mn-cat-bar__inner {
  display: flex; align-items: center;
  max-width: 680px; margin: 0 auto;
}
.mn-cat-bar .service-group-menu {
  display: flex; gap: 6px;
  list-style: none; margin: 0;
  padding: 10px 10px 10px 14px;
  overflow-x: auto; -webkit-overflow-scrolling: touch;
  scrollbar-width: none; scroll-snap-type: x mandatory;
  flex: 1; min-width: 0;
}
.mn-cat-bar .service-group-menu::-webkit-scrollbar { display: none; }
.mn-cat-bar .service-group-menu li { flex-shrink: 0; scroll-snap-align: start; }
.mn-cat-bar .service-group-menu li ~ li,
.mn-cat-list.service-group-menu li ~ li {border: 0;}
.mn-cat-bar__actions {
  display: flex; gap: 6px; align-items: center;
  padding: 0 0px 0 8px; flex-shrink: 0;
  border-left: 1px solid var(--mn-border);
}
.mn-cat-bar__btn {
  width: 34px; height: 34px; border-radius: 50%;
  background: var(--mn-bg); border: 1.5px solid var(--mn-border);
  color: var(--mn-ink-2);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: background .15s, border-color .15s;
  -webkit-tap-highlight-color: transparent;
  flex-shrink: 0;
}
.mn-cat-bar__btn:active { background: var(--mn-border); }
.mn-cat-bar .service-group {
  display: inline-flex; align-items: center; height: 34px;
  padding: 0 15px; border-radius: 17px;
  font-size: 13.5px; font-weight: 600;
  color: var(--mn-ink-2); background: var(--mn-bg);
  border: 1.5px solid var(--mn-border);
  text-decoration: none; white-space: nowrap;
  transition: background .15s, border-color .15s, color .15s;
  -webkit-tap-highlight-color: transparent;
}
.mn-cat-bar .service-group.active,
.mn-cat-bar .service-group:active {
  background: var(--mn-primary) !important; border-color: var(--mn-primary) !important; color: #fff;
}

/* ═══════════════════════════════════════════════════════════════
   CONTENT WRAPPER
   ═══════════════════════════════════════════════════════════════ */
.mn-body { max-width: 680px; margin: 0 auto;}

/* ═══════════════════════════════════════════════════════════════
   PROMOTIONS CAROUSEL
   ═══════════════════════════════════════════════════════════════ */
.mn-promo-wrap { padding-top: 8px; }
.mn-promo-hd {
  display: flex; align-items: baseline; gap: 7px;
  padding: 10px 0px 8px;
}
.mn-promo-hd__title { font-size: 17px; font-weight: 800; color: var(--mn-ink-1); margin: 0; }
.mn-promo-hd__count { font-size: 13px; color: var(--mn-ink-3); }
.mn-promo-hd__scroll-hint { margin-left: auto; font-size: 12px; color: var(--mn-ink-3); font-style: italic; }
.mn-promo-row {
  display: flex; gap: 10px;
  overflow-x: auto; -webkit-overflow-scrolling: touch;
  scrollbar-width: none; scroll-snap-type: x mandatory;
  padding: 2px 4px 16px;
}
.mn-promo-row::-webkit-scrollbar { display: none; }
.mn-pc {
  scroll-snap-align: start; flex-shrink: 0; width: 165px;
  background: var(--mn-surface); border-radius: var(--mn-r);
  box-shadow: var(--mn-shadow-sm); overflow: hidden;
  cursor: pointer; -webkit-tap-highlight-color: transparent;
  transition: transform .12s;
}
.mn-pc:active { transform: scale(.96); box-shadow: none; }
.mn-pc__img-wrap {
  position: relative; width: 100%; height: 120px;
  background: #f9fafb; overflow: hidden;
}
.mn-pc__img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mn-pc__placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  font-size: 42px; font-weight: 800; color: var(--mn-primary-lt);
  background: var(--mn-primary-lt);
}
.mn-modal-img-ph {
  width: calc(100% + 32px); margin-left: -16px; height: 130px;
  background: var(--mn-primary-lt);
  display: flex; align-items: center; justify-content: center;
  font-size: 56px; font-weight: 800; color: var(--mn-primary-lt);
}
.mn-pc__sale {
  position: absolute; top: 8px; left: 8px;
  background: var(--mn-red); color: var(--mn-surface);
  font-size: 11px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
  padding: 2px 7px; border-radius: 5px;
}
.mn-pc__body { padding: 8px 10px 10px; }
.mn-pc__name {
  font-size: 14px; font-weight: 600; color: var(--mn-ink-1);
  margin: 0 0 5px; line-height: 1.3;
  height: 2.6em;
  overflow: hidden; display: -webkit-box;
  -webkit-line-clamp: 2; -webkit-box-orient: vertical;
}
.mn-pc__price-row { display: flex; align-items: baseline; flex-wrap: wrap; gap: 3px; }
.mn-pc__from { font-size: 10px; color: var(--mn-ink-3); }
.mn-pc__price { font-size: 14px; font-weight: 700; color: var(--mn-primary); }
.mn-pc__orig { font-size: 12px; color: var(--mn-ink-3); text-decoration: line-through; }

/* ═══════════════════════════════════════════════════════════════
   ITEM GROUP SECTION
   ═══════════════════════════════════════════════════════════════ */
.mn-group { padding-bottom: 4px; }
.mn-group-hd {
  display: flex; align-items: center; gap: 8px;
  padding: 18px 0 4px;
}
.mn-group-hd__title {
  font-size: 16px; font-weight: 800;
  color: var(--mn-ink-1); margin: 0; line-height: 1;
}
.mn-group-hd__title::before {
  content: '';
  display: inline-block;
  width: 4px; height: 16px;
  background: var(--mn-primary);
  border-radius: 2px;
  margin-right: 8px;
  vertical-align: middle;
}
.mn-group-hd__count { font-size: 13px; color: var(--mn-ink-3); }
.mn-group-desc {
  font-size: 13px; color: var(--mn-ink-3);
  padding: 3px 16px 4px; margin: 0; line-height: 1.45;
}
.mn-item-list {
  display: flex; flex-direction: column; gap: 6px;
  padding: 6px 0 2px;
}

/* ═══════════════════════════════════════════════════════════════
   ITEM CARD
   ═══════════════════════════════════════════════════════════════ */
.mn-ic {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 12px 12px 14px;
  background: var(--mn-surface); border-radius: var(--mn-r);
  box-shadow: var(--mn-shadow-sm);
  -webkit-tap-highlight-color: transparent;
  transition: box-shadow .12s, background .12s;
}
.mn-ic:active { background: #f9fafb; box-shadow: none; }
.mn-ic__body { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 3px; }
.mn-ic__name {
  font-size: 15px; font-weight: 700; color: var(--mn-ink-1); margin: 0;
  line-height: 1.35; overflow: hidden; display: -webkit-box;
  -webkit-line-clamp: 2; -webkit-box-orient: vertical;
}
.mn-ic__desc {
  font-size: 13px; color: var(--mn-ink-3); margin: 0; line-height: 1.4;
  overflow: hidden; display: -webkit-box;
  -webkit-line-clamp: 2; -webkit-box-orient: vertical;
}
.mn-ic__footer {
  display: flex; align-items: center; flex-wrap: wrap; gap: 5px; margin-top: 3px;
}
.mn-ic__from { font-size: 12px; color: var(--mn-ink-3); line-height: 1; }
.mn-ic__price { font-size: 15px; font-weight: 700; color: var(--mn-primary); }
.mn-ic__orig { font-size: 12.5px; color: var(--mn-ink-3); text-decoration: line-through; }
.mn-ic__tag {
  font-size: 11.5px; font-weight: 600;
  border-radius: 4px; padding: 1px 6px;
}
.mn-ic__tag--sizes { background: #d1fae5; color: #059669; }
.mn-ic__tag--addon { background: var(--mn-primary-lt); color: var(--mn-primary); }
.mn-ic__media { flex-shrink: 0; }
.mn-ic__img {
  width: 88px; height: 88px;
  object-fit: cover; border-radius: var(--mn-r-sm); display: block;
}
.mn-ic__img-ph {
  width: 88px; height: 88px; border-radius: var(--mn-r-sm);
  background: var(--mn-primary-lt);
  display: flex; align-items: center; justify-content: center;
  font-size: 28px; font-weight: 800; color: var(--mn-primary-lt);
}

/* ═══════════════════════════════════════════════════════════════
   EMPTY STATE
   ═══════════════════════════════════════════════════════════════ */
.mn-empty { text-align: center; padding: 28px 16px; }
.mn-empty__icon { font-size: 34px; }
.mn-empty__text { font-size: 12.5px; color: var(--mn-ink-3); margin: 6px 0 0; }

/* ═══════════════════════════════════════════════════════════════
   ITEM DETAIL MODAL CONTENT
   ═══════════════════════════════════════════════════════════════ */
.mn-modal-img {
  width: calc(100% + 32px); margin-left: -16px;
  height: 210px; object-fit: cover; display: block;
}
.mn-modal-name { font-size:19px; font-weight:700; margin:0 0 4px; line-height:1.3; }
.mn-modal-price-row { display:flex; align-items:baseline; gap:6px; flex-wrap:wrap; /*margin-bottom:10px;*/ }
.mn-modal-from { font-size:12px; color:#9ca3af; }
.mn-modal-price { font-size:19px; font-weight:700; color:var(--mn-primary); }
.mn-modal-price-orig { font-size:14px; color:#9ca3af; text-decoration:line-through; }
.mn-modal-special-badge { font-size:12px; font-weight:600; background:#fee2e2; color:var(--mn-primary); border-radius:20px; padding:2px 9px; }
.mn-modal-desc { font-size:14px; color:#374151; line-height:1.65; margin: .3rem 0 1.3rem; }
.mn-modal-section-label { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:#6b7280; margin:14px 0 8px; padding-bottom:4px; border-bottom:1px solid #f3f4f6; display: none; }
.mn-modal-opt-group { margin-bottom:1.3rem; }
.mn-modal-opt-header { display:flex; align-items:center; gap:6px; }
.mn-modal-opt-name { font-weight:700; font-size:15px; }
.mn-modal-opt-req { font-size:11px; font-weight:600; color:#dc2626; background:#fee2e2; border-radius:4px; padding:2px 7px; }
.mn-modal-opt-optional { font-size:11px; font-weight:600; color:#2563eb; background:#dbeafe; border-radius:4px; padding:2px 7px; }
.mn-modal-opt-hint { font-size:12px; color:#9ca3af; margin-top: 2px; margin-bottom: 8px; }
.mn-modal-opt-val { display:flex; justify-content:space-between; align-items:center; padding:10px 12px; background:#f9fafb; border-radius:8px; margin-bottom:3px; font-size:14px; }
.mn-modal-val-name { font-weight:500; display:flex; flex-direction:column; gap:2px; }
.mn-modal-val-hint { font-size:11.5px; color:var(--mn-ink-3); font-weight:400; line-height:1.4; }
.mn-modal-opt-val--has-hint { align-items:flex-start; }
.mn-modal-val-price { font-weight:600; color:#059669; font-size:14px; }
.mn-modal-opt-limit { font-size: 12px; color: #9ca3af; margin-left: 2px; padding-top: 3px; }

/* ═══════════════════════════════════════════════════════════════
   ITEM OPTION ROWS  (render_item_options templatetag)
   ═══════════════════════════════════════════════════════════════ */
.option-field-wrapper { display: flex; flex-direction: column; gap: 4px; margin-top:8px; }

.mn-opt-row {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 12px; min-height: 46px;
  background: var(--mn-bg);
  border: 1.5px solid transparent;
  border-radius: var(--mn-r-sm);
  transition: border-color .15s, background .15s;
}
.mn-opt-row--active,
.mn-opt-row:has(.mn-opt-chk:checked) {
  background: var(--mn-primary-lt);
  border-color: var(--mn-primary);
}

/* Hidden native checkbox — label + custom box handle visuals */
.mn-opt-chk { position: absolute; opacity: 0; width: 0; height: 0; }

.mn-opt-label {
  display: flex; align-items: center; gap: 10px;
  width: 100%; margin: 0; cursor: pointer; font-weight: normal;
}
.mn-opt-chk-box {
  flex-shrink: 0; width: 20px; height: 20px;
  border: 2px solid var(--mn-border); border-radius: 5px;
  background: var(--mn-surface);
  transition: border-color .15s, background .15s;
}
.mn-opt-chk:checked + .mn-opt-label .mn-opt-chk-box {
  background: var(--mn-primary) url("data:image/svg+xml,%3Csvg width='10' height='8' viewBox='0 0 10 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 4L3.5 6.5L9 1' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/60% no-repeat;
  border-color: var(--mn-primary);
}

.mn-opt-info { flex: 1; display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.mn-opt-name { font-size: 14px; font-weight: 500; color: var(--mn-ink-1); line-height: 1.3; }
.mn-opt-hint { font-size: 11.5px; color: var(--mn-ink-3); line-height: 1.4; }
.mn-opt-price { flex-shrink: 0; font-size: 13px; font-weight: 600; color: #059669; white-space: nowrap; }

/* Stepper control */
.mn-opt-stepper {
  display: flex; align-items: center; flex-shrink: 0;
  border: 1.5px solid var(--mn-border); border-radius: var(--mn-r-xs);
  overflow: hidden; background: var(--mn-surface);
  transition: border-color .15s;
}
.mn-opt-row--active .mn-opt-stepper { border-color: var(--mn-primary); }

.mn-opt-step-btn {
  width: 30px; height: 30px; padding: 0;
  background: transparent; border: none;
  font-size: 16px; line-height: 1; color: var(--mn-ink-2);
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: background .12s, color .12s;
}
.mn-opt-step-btn:hover:not([disabled]) { background: var(--mn-bg); color: var(--mn-primary); }
.mn-opt-step-btn[disabled] { opacity: .3; cursor: default; }
.mn-opt-step-val {
  width: 32px; height: 30px; padding: 0;
  border: none; border-left: 1.5px solid var(--mn-border); border-right: 1.5px solid var(--mn-border);
  background: transparent;
  text-align: center; font-size: 13px; font-weight: 600;
  color: var(--mn-ink-3);
}
.mn-opt-row--active .mn-opt-step-val { color: var(--mn-ink-1); }

/* ═══════════════════════════════════════════════════════════════
   DINE-IN ITEM DETAIL MODAL  (dine_in/include/item-detail-modal.html)
   ═══════════════════════════════════════════════════════════════ */
.mn-item-modal {
  position: relative; display: flex; flex-direction: column;
  max-height: 88vh; overflow: hidden;
}
.mn-item-modal__close {
  position: absolute; top: 12px; right: 12px; z-index: 10;
  width: 32px; height: 32px; border: none; border-radius: 50%;
  background: rgba(0,0,0,.42); color: #fff;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; -webkit-tap-highlight-color: transparent;
}
.mn-item-modal__img {
  width: calc(100% + 3rem); margin: 0 -1.5rem;
  height: 210px; object-fit: cover; display: block;
}
.mn-item-modal__img-ph {
  width: calc(100% + 3rem); margin: 0 -1.5rem; height: 150px;
  background: var(--mn-primary-lt);
  display: flex; align-items: center; justify-content: center;
  font-size: 56px; font-weight: 800; color: var(--mn-primary-lt);
}
.mn-item-modal__body { flex: 1; overflow-y: auto; overflow-x: hidden; padding: 0 1rem 8px; }
.mn-item-modal__sticky-hd {
  position: sticky; top: 0; z-index: 5;
  background: var(--mn-surface);
  margin: 0rem -1.5rem 0; padding: 1rem 1.5rem .5rem;
  /*border-bottom: 1px solid var(--mn-border);*/
}
.mn-item-modal__remarks { margin-top: 14px; padding-bottom: 1.5rem; }
.mn-item-modal__remarks-label {
  display: block; font-size: 14px; font-weight: 600;
  color: var(--mn-ink-1); margin-bottom: 6px;
}
.mn-item-modal__remarks-opt { font-weight: 400; color: var(--mn-ink-3); font-size: 12px; }
.mn-item-modal__remarks-ta {
  width: 100%; border: 1.5px solid #e5e7eb; border-radius: 8px;
  padding: 8px 10px; font-size: 14px; resize: none; outline: none;
  font-family: inherit; color: var(--mn-ink-1); display: block;
}
.mn-item-modal__remarks-ta:focus { border-color: var(--mn-primary); }

/* Footer */
.mn-item-modal__footer {
  display: flex; align-items: center; gap: 10px; flex-shrink: 0;
  padding: 10px 1rem calc(10px + env(safe-area-inset-bottom, 0px));
  border-top: 1px solid #f3f4f6; background: var(--mn-surface);
}
/* Qty stepper */
.mn-item-modal__qty {
  display: flex; align-items: center; flex-shrink: 0;
  border: 1.5px solid var(--mn-primary); border-radius: 8px; overflow: hidden;
}
.mn-item-modal__qty-btn {
  width: 36px; height: 40px; border: none; background: transparent;
  color: var(--mn-primary); font-size: 20px; font-weight: 600; line-height: 1;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  -webkit-tap-highlight-color: transparent; outline: none;
}
.mn-item-modal__qty-btn:disabled { opacity: .4; cursor: default; }
.mn-item-modal__qty-val {
  width: 36px; text-align: center;
  border: none; border-left: 1px solid var(--mn-primary); border-right: 1px solid var(--mn-primary);
  font-size: 15px; font-weight: 600; color: var(--mn-ink-1);
  background: transparent; height: 40px; padding: 0;
}
/* Add button */
.mn-item-modal__add-btn {
  flex: 1; height: 44px; border: none; border-radius: 10px;
  background: var(--mn-primary); color: var(--mn-surface);
  font-size: 15px; font-weight: 700;
  cursor: pointer; display: flex; align-items: center; justify-content: center; gap: 4px;
  transition: opacity .15s; -webkit-tap-highlight-color: transparent;
}
.mn-item-modal__add-btn:disabled { opacity: .5; cursor: not-allowed; }
.mn-item-modal__add-btn--loading {
  pointer-events: none; position: relative; color: transparent;
}
.mn-item-modal__add-btn--loading * { visibility: hidden; }
.mn-item-modal__add-btn--loading::after {
  content: '···';
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; letter-spacing: 3px;
  color: var(--mn-surface);
  animation: mn-dot-pulse 0.8s infinite;
}
.mn-item-modal__add-price { font-weight: 400; font-size: 14px; }
.mn-item-modal__already-in-cart {
  display: flex; align-items: center; gap: 6px;
  margin: 8px 1rem;
  padding: 7px 11px;
  background: #f0fdf4; border: 1px solid #bbf7d0; border-radius: 8px;
  font-size: 12.5px; color: #15803d; line-height: 1.4;
}

/* ═══════════════════════════════════════════════════════════════
   CATEGORY MODAL — improved list
   ═══════════════════════════════════════════════════════════════ */
.mn-cat-list { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:4px; }
.mn-cat-list a {
  display:flex !important; justify-content:space-between; align-items:center;
  padding:11px 14px !important; border-radius:var(--mn-r-sm);
  background:#f9fafb; border:1px solid var(--mn-border);
  text-decoration:none; font-size:14px !important; font-weight:600 !important; color:var(--mn-ink-1) !important;
  -webkit-tap-highlight-color: transparent;
  transition: background .12s;
}
.mn-cat-list a:active { background: var(--mn-primary-lt); }
.mn-cat-list li a.active { background: var(--mn-primary) !important; border-color: var(--mn-primary) !important; color: #fff !important; }
.mn-cat-list a .mn-cat-list__chevron { color: var(--mn-ink-3); flex-shrink: 0; }
.mn-modal-subtitle { font-size:12.5px; color:#6b7280; margin:2px 0 0; }

/* ═══════════════════════════════════════════════════════════════
   HERO — open/closed status strip
   ═══════════════════════════════════════════════════════════════ */
.mn-hero__status {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 16px; background: rgba(0,0,0,.15);
}
.mn-hero__status-dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.mn-hero__status-dot--open   { background: #4ade80; }
.mn-hero__status-dot--closed { background: #f87171; }
.mn-hero__status-text  { font-size: 12.5px; color: #fff; font-weight: 600; }
.mn-hero__status-hours { font-size: 12px; color: rgba(255,255,255,.65); }

/* ═══════════════════════════════════════════════════════════════
   HERO BANNER SLOT
   ═══════════════════════════════════════════════════════════════ */
.mn-hero-banner {
  margin: 10px 12px; border-radius: 14px;
  background: linear-gradient(120deg, #fde68a 0%, #fbbf24 100%);
  display: flex; align-items: center; gap: 8px;
  padding: 14px 16px; min-height: 76px;
}
.mn-hero-banner__text { flex: 1; }
.mn-hero-banner__title { font-size: 14px; font-weight: 800; color: #78350f; margin: 0; }
.mn-hero-banner__sub   { font-size: 12.5px; color: #92400e; margin: 3px 0 0; line-height: 1.4; }
.mn-hero-banner__emoji { font-size: 44px; flex-shrink: 0; line-height: 1; }

/* ═══════════════════════════════════════════════════════════════
   PROMO CAROUSEL — extras
   ═══════════════════════════════════════════════════════════════ */
.mn-promo-hd__see-all { margin-left: auto; font-size: 12.5px; color: var(--mn-primary); font-weight: 600; text-decoration: none; }
.mn-promo-dots { display: flex; justify-content: center; gap: 5px; padding-bottom: 6px; }
.mn-promo-dot  { width: 6px; height: 6px; border-radius: 50%; background: var(--mn-border); transition: width .2s, background .2s; }
.mn-promo-dot--active { width: 18px; border-radius: 3px; background: var(--mn-primary); }

/* ═══════════════════════════════════════════════════════════════
   SCROLL-TO-TOP FAB
   ═══════════════════════════════════════════════════════════════ */
.mn-fab-top {
  position: fixed;
  bottom: calc(20px + env(safe-area-inset-bottom, 0px));
  right: 16px;
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--mn-primary); color: #fff; border: none;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 14px rgba(221,64,69,.4);
  cursor: pointer; z-index: 90;
  transition: opacity .2s, transform .2s;
  -webkit-tap-highlight-color: transparent;
}
.mn-fab-top:active { transform: scale(.93); }

/* ═══════════════════════════════════════════════════════════════
   BOTTOM SHEET MODAL SHELL
   ═══════════════════════════════════════════════════════════════ */
/*.mn-bottom-sheet { border-radius: 24px 24px 0 0 !important; border: none !important; background: var(--mn-surface) !important; }
.mn-bottom-sheet__handle-row {
  display: flex; justify-content: center;
  padding: 10px 0 8px;
  position: sticky; top: 0; background: var(--mn-surface); z-index: 1;
  border-radius: 24px 24px 0 0;
}
.mn-bottom-sheet__handle { width: 36px; height: 4px; border-radius: 2px; background: var(--mn-border); }
.mn-bottom-sheet__body {
  padding-bottom: calc(20px + env(safe-area-inset-bottom, 0px)) !important;
  overflow-y: auto;
}*/
/*.mn-modal-cart-slot {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  height: 50px; margin-top: 18px; border-radius: 14px;
  background: #f8fafc; border: 2px dashed var(--mn-border);
  font-size: 13px; color: var(--mn-ink-3); font-weight: 600;
  display: none;
}*/

/* ═══════════════════════════════════════════════════════════════
   SEARCH MODAL
   ═══════════════════════════════════════════════════════════════ */
.mn-search-box { padding: 4px 1rem 10px; }
.mn-search-wrap {
  display: flex; align-items: center; gap: 8px;
  background: var(--mn-bg); border: 1.5px solid var(--mn-border);
  border-radius: var(--mn-r-sm); padding: 0 12px;
  transition: border-color .15s;
}
.mn-search-wrap:focus-within { border-color: var(--mn-primary); }
.mn-search-wrap__input {
  flex: 1; border: none; background: transparent;
  font-size: 16px; color: var(--mn-ink-1);
  padding: 11px 0; outline: none;
}
.mn-search-wrap__input::placeholder { color: var(--mn-ink-3); }
.mn-search-results {
  overflow-y: auto; max-height: 60vh;
  padding:5px 1rem calc(16px + env(safe-area-inset-bottom, 0px));
}
.mn-search-result { padding: 0; margin-bottom: 8px; list-style: none; }
.mn-search-result--empty { border: none !important; padding: 16px 24px 20px; }
.mn-search-empty { text-align: center; padding: 8px 0 20px; }
.mn-search-empty__icon {
  width: 72px; height: 72px; border-radius: 50%;
  background: var(--mn-primary-lt);
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 16px;
}
.mn-search-empty__icon i { color: var(--mn-primary); font-size: 25px; }
.mn-search-empty__title { font-size: 15px; font-weight: 700; color: var(--mn-ink-1); margin: 0 0 6px; }
.mn-search-empty__sub { font-size: 13px; color: var(--mn-ink-3); margin: 0; line-height: 1.5; }
.minimalist-modal .modal-header {
  padding: 1rem 1rem .5rem !important;
  display: flex;
}
/*.minimalist-modal .modal-title {
  font-size: 18px;
}*/
.minimalist-modal .btn-close { 
  background-color: var(--mn-bg);
  font-size: 12px;
  box-shadow: none;
  width: 20px;
  height: 20px;
  position: relative;
  margin: 0;
  right: 0;
}
.minimalist-modal .modal-body{
  padding: 1.5rem 1rem;
}

/* ═══════════════════════════════════════════════════════════════
   DINE-IN EXTENSIONS  –  cart controls
   Only used by dine_in/choose_items.html
   ═══════════════════════════════════════════════════════════════ */

/* ── Price + cart control row (simple items) ─────────────────
   Price on the left, Add/stepper on the right — Swiggy pattern  */
.mn-ic__cart-footer {
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px; margin-top: 6px;
}
.mn-ic__price-grp { display: flex; align-items: baseline; gap: 4px; flex: 1; min-width: 0; }

/* Add button — bordered pill, always visible */
.mn-ic__add-btn {
  display: inline-flex; align-items: center; justify-content: center;
  height: 30px; padding: 0 14px;
  border: 1.5px solid var(--mn-primary); border-radius: 6px;
  background: var(--mn-surface); color: var(--mn-primary);
  font-size: 13px; font-weight: 700; letter-spacing: .03em;
  text-decoration: none; white-space: nowrap; flex-shrink: 0;
  -webkit-tap-highlight-color: transparent; outline: none;
  transition: background .12s;
}
.mn-ic__add-btn:hover,
.mn-ic__add-btn:focus,
.mn-ic__add-btn:visited { color: var(--mn-primary); text-decoration: none; }
.mn-ic__add-btn:active { background: var(--mn-primary-lt); }

/* Quantity stepper */
.mn-ic__stepper {
  display: flex; align-items: center; flex-shrink: 0;
  border: 1.5px solid var(--mn-primary); border-radius: 6px;
  overflow: hidden;
}
.mn-ic__step-btn {
  width: 30px; height: 30px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: var(--mn-primary); color: var(--mn-surface);
  font-size: 16px; font-weight: 700;
  text-decoration: none; user-select: none;
  -webkit-tap-highlight-color: transparent;
}
.mn-ic__step-btn:active { background: var(--mn-primary-dk); color: #fff; }
.mn-ic__step-count {
  width: 32px; height: 30px; text-align: center;
  border: none; outline: none; background: var(--mn-surface);
  font-size: 13px; font-weight: 700; color: var(--mn-ink-1);
  pointer-events: none;
}

/* Shared badge styles — option-item corner badge and simple-item count badge */
.mn-ic__img-wrap { position: relative; display: inline-block; }
.mn-ic__badge,
.mn-ic__badge-num {
  width: 30px; height: 30px; border-radius: 50%;
  background: var(--mn-primary); color: #fff;
  font-size: 11px; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 1px 4px rgba(0,0,0,.25);
  border: 2px solid var(--mn-surface);
}

/* Option item badge — pinned to corner of img-wrap */
.mn-ic__badge {
  position: absolute; bottom: -4px; right: -4px;
}

/* Cart ctrl overlaid on card image — circle add button or count badge */
.mn-ic__img-wrap > .mn-ic__cart-ctrl {
  position: absolute;
  bottom: -6px; right: -4px; left: auto;
  width: 30px; height: 30px;
}
.mn-ic__img-wrap > .mn-ic__cart-ctrl > .mn-ic__add-btn {
  border-radius: 50%;
  font-size: 20px;
  letter-spacing: 0;
  padding: 0;
  box-shadow: 0 2px 8px rgba(0,0,0,.20);
  align-items: stretch;
}

/* Simple item count badge — centered inside the 30×30 ctrl */
.mn-ic__badge-num {
  position: absolute; inset: 0; margin: auto;
  text-decoration: none;
  opacity: 0;
  transform: scale(0.85);
  pointer-events: none;
  transition: opacity 180ms ease, transform 180ms ease;
  -webkit-tap-highlight-color: transparent;
}
.mn-ic__cart-ctrl--in-cart .mn-ic__badge-num {
  opacity: 1;
  transform: scale(1);
  pointer-events: auto;
}
.mn-ic__cart-ctrl--loading .mn-ic__badge-num {
  opacity: 0;
  transform: scale(0.85);
  pointer-events: none;
}

/* Option item card states */
.mn-ic--tappable { cursor: pointer; }
.mn-ic__body.btn-add-to-cart { cursor: pointer; }
.mn-ic--in-cart  { box-shadow: 0 0 0 2px var(--mn-primary), var(--mn-shadow-sm); }

/* Promo card: full-width button/stepper at bottom of body */
.mn-pc__cart-row { margin-top: 8px; }
.mn-pc__cart-row .mn-ic__add-btn  { width: 100%; justify-content: center; height: 28px; font-size: 12px; border-radius: 6px; box-shadow: none; }
.mn-pc__cart-row .mn-ic__stepper  { width: 100%; }
.mn-pc__cart-row .mn-ic__step-count { flex: 1; width: auto; }

/* Sticky cart bottom bar */
.mn-cart-bar {
  position: fixed;
  bottom: calc(12px + env(safe-area-inset-bottom, 0px));
  left: 50%; transform: translateX(-50%);
  width: calc(100% - 24px); max-width: 656px; z-index: 80;
  background: var(--mn-primary); border-radius: 14px;
  padding: 12px 16px;
  display: flex; align-items: center; justify-content: space-between;
  box-shadow: 0 4px 20px rgba(0,0,0,.18);
  text-decoration: none; outline: none;
  -webkit-tap-highlight-color: transparent;
  min-height: 54px;
}
.mn-cart-bar__left  { display: flex; align-items: center; gap: 10px; }
.mn-cart-bar__count {
  background: var(--mn-surface); color: var(--mn-primary);
  width: 20px; height: 20px; border-radius: 50%;
  font-size: 11px; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
}
.mn-cart-bar__total    { color: #fff; font-size: 16px; font-weight: 800; }
.mn-cart-bar__currency { color: rgba(255,255,255,.8); font-size: 13px; }
.mn-cart-bar__cta { color: #fff; font-size: 14px; font-weight: 700; display: flex; align-items: center; gap: 4px; }

/* ═══════════════════════════════════════════════════════════════
   CART CONTROL — morph wrapper (Add ↔ Stepper)
   ═══════════════════════════════════════════════════════════════ */

/* Wrapper reserves the stepper's dimensions so no layout shift */
.mn-ic__cart-ctrl {
  position: relative;
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  width: 92px;   /* step-btn×2(30+30) + step-count(32) */
  height: 30px;
}

/* Both children stack absolutely inside the ctrl */
.mn-ic__cart-ctrl > .mn-ic__add-btn,
.mn-ic__cart-ctrl > .mn-ic__stepper {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  transition: opacity 180ms ease, transform 180ms ease;
}

/* Add button overrides inside ctrl */
.mn-ic__cart-ctrl > .mn-ic__add-btn {
  opacity: 1;
  transform: scale(1);
  pointer-events: auto;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Stepper overrides inside ctrl — always rendered, starts hidden */
.mn-ic__cart-ctrl > .mn-ic__stepper {
  opacity: 0;
  transform: scale(0.85);
  pointer-events: none;
  display: flex !important;   /* never d-none; visibility via opacity */
}

/* ── Loading state ───────────────────────────────────────────── */
.mn-ic__cart-ctrl--loading > .mn-ic__add-btn,
.mn-ic__cart-ctrl--loading > .mn-ic__stepper {
  opacity: 0;
  transform: scale(0.85);
  pointer-events: none;
}

.mn-ic__cart-ctrl--loading::after {
  content: '···';
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  letter-spacing: 3px;
  color: var(--mn-primary);
  animation: mn-dot-pulse 0.8s infinite;
}

@keyframes mn-dot-pulse {
  0%, 100% { opacity: 0.3; }
  50%       { opacity: 1;   }
}

/* ── In-cart state ───────────────────────────────────────────── */
.mn-ic__cart-ctrl--in-cart > .mn-ic__add-btn {
  opacity: 0;
  transform: scale(0.85);
  pointer-events: none;
}

.mn-ic__cart-ctrl--in-cart > .mn-ic__stepper {
  opacity: 1;
  transform: scale(1);
  pointer-events: auto;
}

/* Promo card: ctrl fills the full cart-row width */
.mn-pc__cart-row .mn-ic__cart-ctrl {
  width: 100%;
}

/* ── Quantity bounce ─────────────────────────────────────────── */
@keyframes mn-bounce {
  0%   { transform: scale(1);   }
  40%  { transform: scale(1.4); }
  75%  { transform: scale(0.9); }
  100% { transform: scale(1);   }
}

.mn-ic__step-count--bounce {
  animation: mn-bounce 280ms ease;
}

/* ═══════════════════════════════════════════════════════════════
   CART PAGE
   Used by: dine_in/cart_items.html
   ═══════════════════════════════════════════════════════════════ */

/* ── Sticky sub-header (back + title + clear) ─────────────── */
.mn-cart-hd {
  background: var(--mn-surface);
  border-bottom: 1px solid var(--mn-border);
  position: sticky; top: 0; z-index: 100;
  box-shadow: var(--mn-shadow-xs);
  margin: 0 -0.75rem;
  padding: 0 0.75rem;
}
.mn-cart-hd__inner {
  display: flex; align-items: center; gap: 10px;
  max-width: 680px; margin: 0 auto;
  padding: 10px 4px;
}
.mn-cart-hd__back {
  width: 34px; height: 34px; border-radius: 50%;
  background: var(--mn-bg); border: 1.5px solid var(--mn-border);
  color: var(--mn-ink-2);
  display: flex; align-items: center; justify-content: center;
  text-decoration: none; flex-shrink: 0;
  -webkit-tap-highlight-color: transparent;
  transition: background .15s;
}
.mn-cart-hd__back:active { background: var(--mn-border); }
.mn-cart-hd__title {
  flex: 1; font-size: 16px; font-weight: 800; color: var(--mn-ink-1);
  display: flex; align-items: center; gap: 8px;
}
.mn-cart-hd__code {
  font-size: 12px; font-weight: 700; color: var(--mn-primary);
  background: var(--mn-primary-lt); border-radius: 5px; padding: 2px 7px;
}
.mn-cart-hd__clear {
  font-size: 13px; font-weight: 600; color: #ef4444;
  text-decoration: none; padding: 5px 8px; border-radius: 6px;
  -webkit-tap-highlight-color: transparent; flex-shrink: 0; cursor: pointer;
  transition: background .12s;
}
.mn-cart-hd__clear:active { background: #fee2e2; }

/* ── Body ─────────────────────────────────────────────────── */
.mn-cart-body { padding: 10px 0 10px; }

/* ── "Add more items" chip — reuses mn-primary-lt bg ──────── */
.mn-cart-actions { margin-bottom: 8px; }
.mn-cart-add-more {
  display: inline-flex; align-items: center; gap: 5px;
  height: 30px; padding: 0 13px;
  border: 1.5px solid var(--mn-primary); border-radius: 8px;
  background: var(--mn-primary-lt); color: var(--mn-primary);
  font-size: 13px; font-weight: 700; text-decoration: none;
  -webkit-tap-highlight-color: transparent; transition: filter .12s;
}
.mn-cart-add-more:hover,
.mn-cart-add-more:visited { color: var(--mn-primary); text-decoration: none; }
.mn-cart-add-more:active  { filter: brightness(.93); }

/* ── Cart item card ──────────────────────────────────────── */
.mn-cart-item {
  padding: 11px 14px;
  background: var(--mn-surface); border-radius: var(--mn-r);
  box-shadow: var(--mn-shadow-sm);
  display: flex; flex-direction: column;
}

/* Name left + total right on the same baseline row */
.mn-cart-item__top {
  display: flex; align-items: flex-start;
  justify-content: space-between; gap: 10px;
  margin-bottom: 3px;
}
.mn-cart-item__name {
  font-size: 15.5px; font-weight: 700; color: var(--mn-ink-1);
  margin: 0; line-height: 1.3; flex: 1; min-width: 0;
}
.mn-cart-item__total {
  font-size: 15.5px; font-weight: 800; color: var(--mn-ink-1);
  flex-shrink: 0; white-space: nowrap;
}

/* Unit price row — hidden via x-if when price is 0 */
.mn-cart-item__price-row { margin-bottom: 3px; display: flex; align-items: baseline; gap: 4px; }
.mn-cart-item__price       { font-size: 14px; font-weight: 600; color: var(--mn-primary); }
.mn-cart-item__price-muted { font-size: 13.5px; color: var(--mn-ink-3); }
.mn-cart-item__orig        { font-size: 13px; color: var(--mn-ink-3); text-decoration: line-through; }

/* Options — label above, each value as its own pill */
.mn-cart-item__opt-group { margin-bottom: 5px; }
.mn-cart-item__opt-name  {
  display: block; margin-bottom: 3px;
  font-size: 12px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .05em; color: var(--mn-ink-3);
}
.mn-cart-item__opt-vals  { display: flex; flex-wrap: wrap; gap: 4px; }
.mn-cart-item__opt-pill  {
  display: inline-flex; align-items: center; gap: 3px;
  padding: 2px 8px; border-radius: 4px;
  background: var(--mn-bg); border: 1px solid var(--mn-border);
  font-size: 13px; color: var(--mn-ink-2); line-height: 1.6;
}
.mn-cart-item__opt-qty   { font-weight: 700; color: var(--mn-ink-1); }
.mn-cart-item__opt-price { color: #059669; font-weight: 600; font-size: 12.5px; }

/* Stepper (left) + Remove link (right) */
.mn-cart-item__actions {
  display: flex; align-items: center;
  justify-content: space-between; margin-top: 8px;
}
.mn-cart-item__remove {
  display: inline-flex; align-items: center; gap: 4px;
  background: none; border: none; padding: 4px 6px;
  color: var(--mn-ink-3); font-size: 13.5px; font-weight: 600;
  cursor: pointer; border-radius: 6px;
  transition: color .12s, background .12s;
  -webkit-tap-highlight-color: transparent;
}
.mn-cart-item__remove:active { color: #ef4444; background: #fee2e2; }

/* Note — underline-only input (no heavy box) */
.mn-cart-item__note-wrap { margin-top: 6px; }
.mn-cart-item__note-btn {
  font-size: 12px; font-weight: 600; color: var(--mn-ink-3);
  cursor: pointer; text-decoration: none;
  display: inline-flex; align-items: center; gap: 4px;
  transition: color .12s;
}
.mn-cart-item__note-btn:active { color: var(--mn-primary); }
.mn-cart-item__note-field {
  display: flex; align-items: center; gap: 7px;
  border-bottom: 1.5px solid var(--mn-border);
  margin-top: 5px; padding: 4px 0;
  transition: border-color .15s;
}
.mn-cart-item__note-field:focus-within { border-color: var(--mn-primary); }
.mn-cart-item__note-icon { color: var(--mn-ink-3); flex-shrink: 0; }
.mn-cart-item__note-input {
  flex: 1; border: none; background: transparent;
  padding: 0; font-size: 12px; color: var(--mn-ink-1);
  outline: none; font-family: inherit;
}
.mn-cart-item__note-input::placeholder { color: var(--mn-ink-3); }

/* ── Stepper busy / processing state ─────────────────────── */
.mn-stepper--busy {
  pointer-events: none; opacity: 0.6;
}
.mn-stepper--busy .mn-ic__step-count {
  animation: mn-dot-pulse 0.7s ease infinite;
}

/* ── Empty state extensions ──────────────────────────────── */
.mn-empty--lg { padding: 48px 24px; }
.mn-empty--lg .mn-empty__icon { font-size: 48px; }
.mn-empty__title { font-size: 16px; font-weight: 800; color: var(--mn-ink-1); margin: 8px 0 4px; }
.mn-cart-start-btn {
  display: inline-flex; align-items: center; justify-content: center;
  height: 44px; padding: 0 28px; margin-top: 14px;
  background: var(--mn-primary); color: #fff; border-radius: 10px;
  font-size: 15px; font-weight: 700; text-decoration: none;
  -webkit-tap-highlight-color: transparent; transition: opacity .15s;
}
.mn-cart-start-btn:hover,
.mn-cart-start-btn:visited { color: #fff; text-decoration: none; }
.mn-cart-start-btn:active  { opacity: .85; }

/* ── Ordering-paused notice ──────────────────────────────── */
.mn-cart-disabled {
  background: #fffbeb; border: 1.5px solid #fcd34d;
  border-radius: var(--mn-r-sm); padding: 10px 14px;
  margin-bottom: 10px; font-size: 13px; color: #78350f; line-height: 1.5;
}

/* ── Floating confirm bar — entire pill is the tap target ─── */
.mn-confirm-bar {
  position: fixed;
  bottom: calc(10px + env(safe-area-inset-bottom, 0px));
  left: 50%; transform: translateX(-50%);
  width: calc(100% - 24px); max-width: 656px; z-index: 80;
  background: var(--mn-primary); border-radius: 14px;
  padding: 0 16px;
  display: flex; align-items: center; justify-content: space-between;
  min-height: 54px;
  box-shadow: 0 4px 20px rgba(0,0,0,.18);
  border: none; cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: opacity .15s, transform .1s;
}
.mn-confirm-bar:active:not([disabled]) {
  opacity: .88; transform: translateX(-50%) scale(.99);
}
.mn-confirm-bar[disabled] { opacity: .5; cursor: not-allowed; }
.mn-confirm-bar__left { display: flex; align-items: center; gap: 6px; }
.mn-confirm-bar__count {
  background: var(--mn-surface); color: var(--mn-primary);
  width: 22px; height: 22px; border-radius: 50%;
  font-size: 11px; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.mn-confirm-bar__label    { color: rgba(255,255,255,.8); font-size: 13px; }
.mn-confirm-bar__sep      { color: rgba(255,255,255,.4); }
.mn-confirm-bar__currency { color: rgba(255,255,255,.8); font-size: 13px; }
.mn-confirm-bar__total    { color: #fff; font-size: 16px; font-weight: 800; }
.mn-confirm-bar__cta {
  display: flex; align-items: center; gap: 4px;
  color: #fff; font-size: 14px; font-weight: 700; flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════════
   CONFIRM ORDER PAGE
   Used by: dine_in/confirm-order.html
   ═══════════════════════════════════════════════════════════════ */

/* ── Success banner ───────────────────────────────────────── */
.mn-order-success {
  display: flex; flex-direction: column; align-items: center;
  padding: 28px 16px 18px; text-align: center;
}
.mn-order-success__icon {
  width: 64px; height: 64px; border-radius: 50%;
  background: #d1fae5;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 14px;
  box-shadow: 0 0 0 8px #ecfdf5;
}
.mn-order-success__title {
  font-size: 20px; font-weight: 900; color: var(--mn-ink-1); margin: 0 0 6px;
}
.mn-order-success__sub {
  font-size: 14.5px; color: var(--mn-ink-3); margin: 0; line-height: 1.6;
  max-width: 320px;
}

/* ── Combined order card (queue + items + subtotal) ──────── */
.mn-order-card {
  background: var(--mn-surface); border-radius: var(--mn-r);
  box-shadow: var(--mn-shadow-sm); overflow: hidden;
  margin-bottom: 10px;
}
.mn-order-card__queue {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; padding: 14px 16px 0px;
  /*border-bottom: 1px solid var(--mn-border);*/
}
.mn-order-card__items-hd {
  font-size: 12px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; color: var(--mn-ink-3);
  padding: 9px 16px 8px;
  /*background: var(--mn-bg);*/
  border-bottom: 1px solid var(--mn-border);
}

/* ── Queue / status card (standalone fallback) ────────────── */
.mn-order-status-card {
  background: var(--mn-surface); border-radius: var(--mn-r);
  box-shadow: var(--mn-shadow-sm);
  padding: 14px 16px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
}
.mn-order-status-badge {
  display: inline-flex; align-items: center;
  font-size: 13.5px; font-weight: 700;
  padding: 6px 14px; border-radius: 20px; color: #fff;
  flex-shrink: 0;
}
.mn-order-queue-label {
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; color: var(--mn-ink-3); text-align: right;
}
.mn-order-queue-no {
  font-size: 22px; font-weight: 900; color: var(--mn-ink-1);
  text-align: right; letter-spacing: -.5px; line-height: 1.2;
}
.mn-order-time {
  font-size: 13px; color: var(--mn-ink-3); margin-top: 3px; text-align: right;
}

/* ── Section label ────────────────────────────────────────── */
.mn-section-label {
  font-size: 12px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; color: var(--mn-ink-3);
  padding: 14px 0 6px; margin: 0;
}

/* ── Receipt wrapper — single card for items + subtotal ───── */
.mn-order-receipt {
  background: var(--mn-surface); border-radius: var(--mn-r);
  box-shadow: var(--mn-shadow-sm); overflow: hidden;
}
.mn-item-list--receipt { padding: 0; gap: 0; }
.mn-item-list--receipt .mn-order-item {
  border-radius: 0; box-shadow: none;
  border-bottom: 1px solid var(--mn-border);
}
.mn-item-list--receipt .mn-order-item:last-child { border-bottom: none; }

/* ── Order item card (read-only) ──────────────────────────── */
.mn-order-item {
  padding: 12px 14px 12px 18px;
  background: var(--mn-surface); border-radius: var(--mn-r);
  box-shadow: var(--mn-shadow-sm);
  position: relative; overflow: hidden;
}
.mn-order-item__status-bar {
  position: absolute; left: 0; top: 0; bottom: 0; width: 4px;
}
.mn-order-item--cancelled { opacity: 0.55; }
.mn-order-item--cancelled .mn-order-item__name,
.mn-order-item--cancelled .mn-order-item__total { text-decoration: line-through; }

/* Two-column: fixed qty col (right-aligned) + body (all details) */
.mn-order-item__layout { display: flex; align-items: flex-start; gap: 10px; }
.mn-order-item__qty {
  flex-shrink: 0; min-width: 32px; text-align: right;
  font-size: 16.5px; font-weight: 800; color: var(--mn-primary);
  padding-top: 2px;
}
.mn-order-item__body { flex: 1; min-width: 0; }
.mn-order-item__top {
  display: flex; align-items: flex-start;
  justify-content: space-between; gap: 10px; margin-bottom: 1px;
}
.mn-order-item__name {
  font-size: 15.5px; font-weight: 700; color: var(--mn-ink-1);
  margin: 0; line-height: 1.4; flex: 1; min-width: 0;
}
.mn-order-item__total {
  font-size: 15.5px; font-weight: 800; color: var(--mn-ink-1);
  flex-shrink: 0; white-space: nowrap;
}
.mn-order-item__unit-price {
  font-size: 13.5px; color: var(--mn-ink-3); margin: 0 0 5px;
  display: flex; align-items: center; gap: 5px;
}
.mn-order-item__price-special { color: var(--mn-primary); font-weight: 600; }
.mn-order-item__price-orig  { text-decoration: line-through; color: var(--mn-ink-3); }
.mn-order-item__remarks {
  display: flex; align-items: center; gap: 6px;
  margin-top: 6px; padding: 7px 10px;
  background: #f0fdf4; border-radius: var(--mn-r-xs);
  border-left: 3px solid #86efac;
  font-size: 13.5px; color: var(--mn-ink-2); font-style: italic;
}
.mn-order-item__remarks-icon { color: #4ade80; flex-shrink: 0; }

/* ── Subtotal — footer row inside mn-order-receipt ─────────── */
.mn-order-summary {
  background: var(--mn-surface);
  border-top: 2px dashed var(--mn-border);
  padding: 14px 16px 12px;
}
.mn-order-summary__row {
  display: flex; justify-content: space-between; align-items: center;
}
.mn-order-summary__label {
  font-size: 13.5px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; color: var(--mn-ink-3);
}
.mn-order-summary__value {
  font-size: 20px; font-weight: 900; color: var(--mn-ink-1);
  letter-spacing: -.3px;
}
.mn-order-summary__note {
  margin: 9px 0; padding: 0;
  font-size: 12.5px; color: var(--mn-ink-3); line-height: 1.5;
}
.mn-order-summary__note .fa { margin-right: 3px; }
.mn-order-summary__note-link {
  color: var(--mn-primary); font-weight: 700; text-decoration: none;
  border-bottom: 1px solid var(--mn-primary-lt);
  transition: border-color .12s;
}
.mn-order-summary__note-link:hover { border-bottom-color: var(--mn-primary); }


/* ── Order history totals card ────────────────────────────── */
.mn-history-totals {
  background: var(--mn-surface); border-radius: var(--mn-r-sm);
  box-shadow: var(--mn-shadow-sm); overflow: hidden;
  margin-top: 12px;
}
.mn-history-totals__hd {
  font-size: 12px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; color: var(--mn-ink-3);
  padding: 20px 16px 9px;
  border-bottom: 1px solid var(--mn-border);
}
.mn-history-totals__row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 16px; border-bottom: 1px solid var(--mn-border);
  font-size: 14px; color: var(--mn-ink-2);
}
.mn-history-totals__label { }
.mn-history-totals__meta { color: var(--mn-ink-3); font-size: 12px; }
.mn-history-totals__value { font-weight: 600; color: var(--mn-ink-1); }
.mn-history-totals__value--discount { color: #059669; }
.mn-history-totals__grand {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 16px;
  background: var(--mn-surface);
  border-top: 2px solid var(--mn-border);
}
.mn-history-totals__grand-label {
  font-size: 13.5px; font-weight: 700; text-transform: uppercase;
  letter-spacing: .06em; color: var(--mn-ink-3);
}
.mn-history-totals__grand-value {
  font-size: 22px; font-weight: 900; color: var(--mn-primary);
  letter-spacing: -.4px; text-align: right;
}
.mn-history-totals__tax {
  font-size: 11.5px; color: var(--mn-ink-3); margin-top: 2px; text-align: right;
}

/* ── "Place New Order" floating bar (button or <a>) ────────── */
.mn-new-order-bar {
  position: fixed;
  bottom: calc(10px + env(safe-area-inset-bottom, 0px));
  left: 50%; transform: translateX(-50%);
  width: calc(100% - 24px); max-width: 656px; z-index: 80;
  border: none; cursor: pointer; padding: 0 20px;
  background: var(--mn-primary); border-radius: 14px;
  min-height: 54px;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  font-size: 15px; font-weight: 700; color: #fff;
  text-decoration: none;
  box-shadow: 0 4px 20px rgba(0,0,0,.18);
  -webkit-tap-highlight-color: transparent;
  transition: opacity .15s, transform .1s;
}
.mn-new-order-bar:visited { color: #fff; text-decoration: none; }
.mn-new-order-bar:active  { opacity: .88; transform: translateX(-50%) scale(.99); }
