/* foodino — client screens (Menu, Options, Cart, Success). Values ported from screens-client*.jsx */

.client-body { background: var(--cbg); }
.screen.client { background: var(--cbg); font-family: var(--font-text); color: var(--ink); }

/* ── MENU ─────────────────────────────────────────────────────────────── */
.menu-head { background: var(--cbg); border-bottom: 1px solid var(--line); }
.menu-head__top {
  padding: 6px 20px 0; display: flex; align-items: flex-start; gap: 13px;
}
.logo-slot {
  width: 48px; height: 48px; border-radius: 14px; flex-shrink: 0; margin-top: 2px;
  background: #fff; border: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center; overflow: hidden;
}
.logo-slot img { width: 100%; height: 100%; object-fit: cover; }
.logo-slot__ph {
  font-family: var(--font-mono); font-size: 9px; color: var(--ink45); letter-spacing: 0.3px;
  border: 1px dashed var(--line); border-radius: 5px; padding: 3px 5px;
}
.menu-brand { flex: 1; min-width: 0; }
.brand-row { display: flex; align-items: center; gap: 7px; margin-bottom: 3px; }
.brand-name { font-family: var(--font-display); font-weight: 800; font-size: 12.5px; letter-spacing: -0.3px; color: var(--orange); }
.brand-dot { width: 3px; height: 3px; border-radius: 9px; background: var(--ink45); }
.brand-sub { font-size: 12.5px; color: var(--ink45); font-weight: 500; }
.venue-title { font-family: var(--font-display); font-weight: 800; font-size: 28px; letter-spacing: -0.6px; line-height: 1; }
.menu-head__search { margin-top: 4px; }

.status-row { display: flex; gap: 7px; padding: 13px 20px 14px; flex-wrap: wrap; }

.cat-tabs { display: flex; gap: 8px; padding: 0 20px 13px; overflow-x: auto; }
.cat-tab {
  padding: 8px 15px; border-radius: 999px; font-size: 14px; font-weight: 600; white-space: nowrap;
  background: #fff; color: var(--ink70); border: 1px solid var(--line);
}
.cat-tab--on { background: var(--ink); color: #fff; border-color: var(--ink); }

.menu-list { padding: 4px 0 96px; }
.cat-label {
  padding: 16px 20px 8px; font-family: var(--font-display); font-weight: 700; font-size: 13px;
  letter-spacing: 0.4px; text-transform: uppercase; color: var(--ink45);
}
.menu-item {
  display: flex; gap: 14px; padding: 13px 20px; align-items: center;
  border-bottom: 1px solid var(--line-soft);
}
.menu-section .menu-item:last-child { border-bottom: none; }
.menu-item--out { opacity: 0.55; }
.menu-item .foodph { width: 72px; height: 72px; }
.mi-text { flex: 1; min-width: 0; }
.mi-name-row { display: flex; align-items: center; gap: 6px; min-width: 0; }
.mi-name { font-weight: 600; font-size: 16px; letter-spacing: -0.2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mi-name-row svg { flex-shrink: 0; }
.mi-desc { font-size: 13px; color: var(--ink45); margin-top: 2px; line-height: 1.3; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.mi-price { margin-top: 7px; display: flex; align-items: baseline; gap: 4px; }
.mi-from { font-size: 12.5px; color: var(--ink45); }
.money--mi { font-size: 15.5px; color: var(--ink); }
.money--mi-out { color: var(--ink45); }
.add-btn { width: 38px; height: 38px; border-radius: 11px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.add-btn--solid { background: var(--orange); box-shadow: 0 2px 8px rgba(255,90,31,0.3); }
/* inset-обводка рисуется ровно по всем сторонам (в отличие от 1.5px border) */
.add-btn--opt { background: #fff; box-shadow: inset 0 0 0 1.6px var(--orange); }
.add-btn--added { animation: edPop 0.3s ease; }
@keyframes edPop { 0% { transform: scale(1); } 35% { transform: scale(0.86); } 100% { transform: scale(1); } }
.out-pill { font-size: 12px; font-weight: 600; color: var(--ink45); background: var(--line-soft); padding: 5px 9px; border-radius: 999px; flex-shrink: 0; }

.cart-bar { position: absolute; left: 14px; right: 14px; bottom: calc(env(safe-area-inset-bottom, 0px) + 16px); z-index: 30; }
.cart-bar__inner {
  background: var(--orange); border-radius: 16px; padding: 13px 16px 13px 18px;
  display: flex; align-items: center; justify-content: space-between;
  box-shadow: 0 10px 28px rgba(255,90,31,0.4); color: #fff;
}
.cart-bar.is-bump .cart-bar__inner { animation: edBump 0.32s ease; }
@keyframes edBump { 0% { transform: scale(1); } 30% { transform: scale(1.05); } 100% { transform: scale(1); } }
.cart-bar__left { display: flex; align-items: center; gap: 11px; }
.cart-bar__title { font-weight: 700; font-size: 15px; line-height: 1; }
.cart-bar__count { font-size: 12.5px; opacity: 0.85; margin-top: 2px; }
.cart-bar__right { display: flex; align-items: center; gap: 8px; }

/* ── OPTIONS SHEET ────────────────────────────────────────────────────── */
.screen.options { background: rgba(26,24,21,0.55); }
.sheet-peek { height: 78px; flex-shrink: 0; }
.sheet {
  flex: 1; background: #fff; border-radius: 26px 26px 0 0; position: relative;
  display: flex; flex-direction: column; overflow: hidden; box-shadow: 0 -10px 40px rgba(0,0,0,0.2);
}
.sheet__grab { position: absolute; top: 10px; left: 50%; transform: translateX(-50%); width: 40px; height: 5px; border-radius: 9px; background: var(--line); z-index: 5; }
.sheet__close { position: absolute; top: 18px; right: 16px; z-index: 5; }
.sheet__body { flex: 1; overflow: auto; }
.sheet-hero { height: 168px; width: 100%; border-radius: 0; }
.sheet-title-wrap { padding: 18px 22px 8px; }
.sheet-title { font-family: var(--font-display); font-weight: 800; font-size: 23px; letter-spacing: -0.5px; }
.sheet-desc { font-size: 14px; color: var(--ink45); margin-top: 4px; line-height: 1.4; }

.opt-group { padding: 14px 22px 4px; }
.opt-group--sauce { padding: 18px 22px 8px; }
.group-head { display: flex; align-items: center; justify-content: space-between; padding-bottom: 2px; }
.group-title { font-family: var(--font-display); font-weight: 700; font-size: 17px; letter-spacing: -0.3px; }
.group-hint { font-size: 12px; font-weight: 700; padding: 4px 9px; border-radius: 999px; white-space: nowrap; flex-shrink: 0; background: var(--line-soft); color: var(--ink45); }
.group-hint--req { background: var(--orange-wash); color: var(--orange); }

.opt-row { display: flex; align-items: center; gap: 12px; padding: 13px 0; border-top: 1px solid var(--line-soft); }
.opt-ctl { width: 22px; height: 22px; flex-shrink: 0; border: 2px solid var(--line); background: #fff; display: flex; align-items: center; justify-content: center; }
.opt-ctl--radio { border-radius: 999px; }
.opt-ctl--check { border-radius: 7px; }
.opt-ctl--on { border-color: var(--orange); }
.opt-ctl--check.opt-ctl--on { background: var(--orange); }
.opt-radio-dot { width: 11px; height: 11px; border-radius: 999px; background: var(--orange); }
.opt-label { flex: 1; font-size: 15.5px; font-weight: 500; color: var(--ink); }
.opt-label--on { font-weight: 600; }
.opt-price { font-size: 14px; color: var(--ink70); font-weight: 600; white-space: nowrap; flex-shrink: 0; }
.opt-price--inc { color: var(--ink45); }

.sheet-foot {
  padding: 12px 20px calc(env(safe-area-inset-bottom, 0px) + 16px);
  border-top: 1px solid var(--line); display: flex; gap: 12px; align-items: center; background: #fff;
}
.qty { display: flex; align-items: center; gap: 14px; border: 1.5px solid var(--line); border-radius: 13px; padding: 7px 12px; flex-shrink: 0; }
.qty__n { font-family: var(--font-display); font-weight: 700; font-size: 17px; min-width: 14px; text-align: center; }
.qty__btn { background: none; border: none; padding: 0; margin: 0; display: flex; align-items: center; cursor: pointer; }
.opt-row { cursor: pointer; user-select: none; }
.qty--sm { gap: 11px; border-radius: 11px; padding: 6px 10px; }
.qty--sm .qty__n { font-size: 15px; min-width: 12px; }
.add-cta { flex: 1; background: var(--orange); border-radius: 13px; padding: 14px 18px; color: #fff; display: flex; align-items: center; justify-content: space-between; box-shadow: 0 6px 18px rgba(255,90,31,0.35); }
.add-cta__label { font-weight: 700; font-size: 16px; }

/* ── CART / CHECKOUT ──────────────────────────────────────────────────── */
.cart-head { background: var(--cbg); border-bottom: 1px solid var(--line); }
.cart-head__row { padding: 4px 16px 14px; display: flex; align-items: center; gap: 12px; }
.cart-back { width: 40px; height: 40px; border-radius: 999px; background: #fff; border: 1px solid var(--line); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.cart-title { font-family: var(--font-display); font-weight: 800; font-size: 21px; letter-spacing: -0.4px; line-height: 1; }
.cart-sub { font-size: 12.5px; color: var(--ink45); margin-top: 3px; }

.cart-body { padding: 14px 16px 110px; }
.card-list { background: #fff; border-radius: 16px; border: 1px solid var(--line); overflow: hidden; }
.cart-item { display: flex; gap: 13px; padding: 13px; align-items: center; }
.cart-item + .cart-item { border-top: 1px solid var(--line-soft); }
.cart-item .foodph { width: 58px; height: 58px; }
.ci-text { flex: 1; min-width: 0; }
.ci-name { font-weight: 600; font-size: 15.5px; letter-spacing: -0.2px; }
.ci-opts { font-size: 12.5px; color: var(--ink45); margin-top: 2px; }
.ci-price { margin-top: 6px; }
.money--ci { font-size: 15px; }

.add-more { display: flex; align-items: center; justify-content: center; gap: 6px; padding: 13px 0; color: var(--orange); font-weight: 600; font-size: 14px; }

.comment-box { background: #fff; border: 1px solid var(--line); border-radius: 13px; padding: 12px 14px; font-size: 14.5px; color: var(--ink45); min-height: 56px; margin-bottom: 16px; }
.comment-box__label { font-weight: 600; color: var(--ink45); }
.comment-box__ph { margin-top: 5px; color: var(--ink45); }

.section-label { font-family: var(--font-display); font-weight: 700; font-size: 13px; letter-spacing: 0.4px; text-transform: uppercase; color: var(--ink45); }
.section-label--contacts { padding: 0 2px 9px; }
.contacts-grid { display: grid; gap: 9px; }
.field { background: #fff; border: 1px solid var(--line); border-radius: 13px; padding: 11px 14px; display: flex; align-items: center; gap: 11px; }
.field__main { flex: 1; }
.field__label { font-size: 11.5px; color: var(--ink45); font-weight: 600; margin-bottom: 1px; }
.field__value { font-size: 15.5px; font-weight: 600; color: var(--ink); }
.field__value--ph { color: var(--ink45); }
.field__input { width: 100%; border: none; background: transparent; outline: none; padding: 0;
  font-family: var(--font-text); font-size: 15.5px; font-weight: 600; color: var(--ink); }
.field__input::placeholder { color: var(--ink45); font-weight: 500; }
.comment-input { width: 100%; border: none; background: transparent; outline: none; resize: none;
  margin-top: 5px; min-height: 40px; font-family: var(--font-text); font-size: 14.5px; color: var(--ink); }
.comment-input::placeholder { color: var(--ink45); }
.cart-empty { text-align: center; padding: 40px 0 8px; }
.cart-empty__t { font-family: var(--font-display); font-weight: 700; font-size: 17px; color: var(--ink70); }
.cart-empty__link { display: inline-block; margin-top: 8px; color: var(--orange); font-weight: 600; font-size: 14.5px; }

.pickup-card { margin-top: 16px; background: #fff; border: 1px solid var(--line); border-radius: 16px; overflow: hidden; }
.pickup-row { display: flex; gap: 12px; padding: 14px; align-items: center; }
.pickup-icon { width: 38px; height: 38px; border-radius: 11px; background: var(--orange-wash); flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.pickup-main { flex: 1; }
.pickup-title { font-weight: 700; font-size: 15.5px; }
.pickup-addr { font-size: 13px; color: var(--ink45); margin-top: 1px; }
.pickup-note { display: flex; gap: 9px; padding: 11px 14px; border-top: 1px solid var(--line-soft); background: var(--cbg); align-items: center; }
.pickup-note span { font-size: 13px; color: var(--ink70); font-weight: 500; }

.cart-foot { position: absolute; left: 0; right: 0; bottom: 0; background: #fff; border-top: 1px solid var(--line); padding: 12px 16px calc(env(safe-area-inset-bottom, 0px) + 12px); z-index: 30; }
.cart-foot__row { display: flex; align-items: center; gap: 14px; }
.cart-total-label { font-size: 12px; color: var(--ink45); font-weight: 600; }
.money--total { font-size: 22px; }
.cta { flex: 1; background: var(--orange); border-radius: 13px; padding: 15px 18px; color: #fff; text-align: center; font-weight: 700; font-size: 16px; box-shadow: 0 6px 18px rgba(255,90,31,0.35); }

/* ── SUCCESS ──────────────────────────────────────────────────────────── */
.success { flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 0 24px; }
.success-check { width: 76px; height: 76px; border-radius: 999px; background: var(--green-wash); display: flex; align-items: center; justify-content: center; margin-bottom: 22px; }
.success-check__inner { width: 50px; height: 50px; border-radius: 999px; background: var(--green); display: flex; align-items: center; justify-content: center; }
.success-title { font-family: var(--font-display); font-weight: 700; font-size: 22px; letter-spacing: -0.4px; }
.success-desc { font-size: 14.5px; color: var(--ink70); margin-top: 7px; line-height: 1.45; max-width: 260px; }
.code-box { margin: 26px 0; padding: 20px 40px; background: #fff; border: 1px solid var(--line); border-radius: 20px; box-shadow: 0 10px 30px rgba(26,24,21,0.05); }
.code-box__label { font-size: 12.5px; color: var(--ink45); font-weight: 600; letter-spacing: 0.4px; text-transform: uppercase; }
.code-box__num { font-family: var(--font-display); font-weight: 800; font-size: 64px; letter-spacing: -2px; line-height: 1.05; color: var(--orange); }
.info-card { width: 100%; max-width: 320px; background: #fff; border: 1px solid var(--line); border-radius: 16px; overflow: hidden; text-align: left; }
.info-row { display: flex; gap: 12px; padding: 12px 14px; align-items: center; }
.info-row + .info-row { border-top: 1px solid var(--line-soft); }
.info-row__main { flex: 1; }
.info-row__t { font-weight: 600; font-size: 14.5px; }
.info-row__s { font-size: 12.5px; color: var(--ink45); margin-top: 1px; }
.success-foot { padding: 14px 24px calc(env(safe-area-inset-bottom, 0px) + 16px); }
.back-link { background: var(--cbg); border: 1.5px solid var(--line); border-radius: 13px; padding: 14px; text-align: center; font-weight: 700; font-size: 15px; color: var(--ink); display: block; }
