/* ============================================================
   КАФЕ ХАЯЛ — Дизайн-система (White Label ядро)
   Палитра, типографика, сетка 8px, радиусы 4/6/8
   ============================================================ */

:root {
  /* --- Бренд (переопределяется через White Label) --- */
  --primary:        #C25E1F;   /* CTA, акценты */
  --primary-dark:   #8B3E0B;   /* hover, заголовки */
  --primary-light:  #F4A261;   /* теги, мягкие акценты */
  --primary-wash:   #FBEEE2;   /* подложки primary */

  /* --- Поверхности --- */
  --bg:        #FAF7F2;   /* основной фон */
  --surface:   #FFFFFF;   /* карточки */
  --surface-2: #F4F0E8;   /* вторичные подложки */
  --navy:      #0F172A;   /* сайдбар, тёмные блоки */

  /* --- Текст --- */
  --ink:        #111827;  /* основной текст */
  --ink-soft:   #475569;  /* вторичный текст */
  --ink-mute:   #94A3B8;  /* подписи, плейсхолдеры */
  --on-dark:    #F8FAFC;  /* текст на тёмном */
  --on-dark-mute: #94A3B8;

  /* --- Статусы --- */
  --success: #059669;  --success-wash: #E7F5EF;
  --warning: #D97706;  --warning-wash: #FBF1E0;
  --danger:  #DC2626;  --danger-wash:  #FCEDED;
  --info:    #2563EB;  --info-wash:    #E8EFFD;

  --border:   #E2E8F0;
  --border-2: #EDE7DC;

  /* --- Типографика --- */
  --font-display: 'Plus Jakarta Sans', system-ui, sans-serif;
  --font-sans:    'Inter', system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, monospace;

  /* --- Радиусы --- */
  --r-xs: 4px;
  --r-sm: 6px;
  --r-md: 8px;
  --r-lg: 12px;
  --r-xl: 18px;
  --r-2xl: 26px;
  --r-pill: 999px;

  /* --- Тени (мягкие, минималистичные) --- */
  --sh-xs: 0 1px 2px rgba(15,23,42,.05);
  --sh-sm: 0 1px 3px rgba(15,23,42,.06), 0 1px 2px rgba(15,23,42,.04);
  --sh-md: 0 6px 20px -8px rgba(15,23,42,.14);
  --sh-lg: 0 18px 48px -16px rgba(15,23,42,.22);
  --sh-primary: 0 10px 26px -10px rgba(194,94,31,.5);

  /* --- Сетка --- */
  --maxw: 1240px;
  --gutter: 32px;
}

/* ============================================================
   RESET / BASE
   ============================================================ */
* { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-sans);
  background: var(--bg);
  color: var(--ink);
  font-size: 15px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  letter-spacing: -0.005em;
}
img { display: block; max-width: 100%; }
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
input, select, textarea { font-family: inherit; font-size: inherit; color: inherit; }
a { color: inherit; text-decoration: none; }
::selection { background: var(--primary-light); color: var(--navy); }

h1, h2, h3, h4, .display { font-family: var(--font-display); color: var(--ink); }
.display { font-weight: 800; font-size: clamp(40px, 5.2vw, 60px); line-height: 1.02; letter-spacing: -0.025em; }
h1 { font-weight: 800; font-size: 32px; line-height: 1.1; letter-spacing: -0.018em; }
h2 { font-weight: 700; font-size: 22px; line-height: 1.2; letter-spacing: -0.012em; }
h3 { font-weight: 700; font-size: 17px; line-height: 1.25; letter-spacing: -0.008em; }

.mono { font-family: var(--font-mono); }
.eyebrow {
  font-family: var(--font-mono);
  font-size: 12px; font-weight: 500;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ink-mute);
}
.price { font-family: var(--font-display); font-weight: 700; letter-spacing: -0.01em; font-variant-numeric: tabular-nums; }

/* ============================================================
   LAYOUT
   ============================================================ */
.wrap { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gutter); }
.app { min-height: 100vh; display: flex; flex-direction: column; }
.app-main { flex: 1; }
.section { padding: 72px 0; }
.section--tight { padding: 48px 0; }
.section-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; margin-bottom: 32px; }
.section-head__title { display: flex; flex-direction: column; gap: 10px; }

/* ============================================================
   ПЛЕЙСХОЛДЕР ИЗОБРАЖЕНИЯ
   ============================================================ */
.ph {
  position: relative;
  background-color: #EFE7DA;
  background-image: repeating-linear-gradient(
    -45deg,
    #EFE7DA, #EFE7DA 9px,
    #E7DDCB 9px, #E7DDCB 18px
  );
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  border-radius: var(--r-lg);
}
.ph__tag {
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: 0.04em;
  color: #97876C;
  background: rgba(250,247,242,.82);
  padding: 5px 10px; border-radius: var(--r-pill);
  backdrop-filter: blur(2px);
  white-space: nowrap;
  max-width: 86%;
  overflow: hidden; text-overflow: ellipsis;
}
.ph--dark {
  background-color: #1C2536;
  background-image: repeating-linear-gradient(-45deg,#1C2536,#1C2536 9px,#222C40 9px,#222C40 18px);
}
.ph--dark .ph__tag { color: #8FA0BC; background: rgba(15,23,42,.6); }

/* ============================================================
   КНОПКИ
   ============================================================ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  font-family: var(--font-sans); font-weight: 600; font-size: 14.5px;
  letter-spacing: -0.005em;
  padding: 0 20px; height: 46px;
  border-radius: var(--r-md);
  transition: transform .14s ease, background .16s ease, box-shadow .16s ease, color .16s, border-color .16s;
  white-space: nowrap; user-select: none;
}
.btn:active { transform: translateY(1px) scale(.99); }
.btn svg { width: 18px; height: 18px; flex: none; }
.btn--primary { background: var(--primary); color: #fff; box-shadow: var(--sh-primary); }
.btn--primary:hover { background: var(--primary-dark); }
.btn--dark { background: var(--navy); color: #fff; }
.btn--dark:hover { background: #1b2740; }
.btn--outline { background: var(--surface); color: var(--ink); box-shadow: inset 0 0 0 1.5px var(--border); }
.btn--outline:hover { box-shadow: inset 0 0 0 1.5px var(--ink); }
.btn--ghost { background: transparent; color: var(--ink); padding: 0 8px; }
.btn--ghost:hover { color: var(--primary); }
.btn--block { width: 100%; }
.btn--lg { height: 54px; padding: 0 28px; font-size: 15.5px; border-radius: var(--r-lg); }
.btn--sm { height: 38px; padding: 0 14px; font-size: 13.5px; border-radius: var(--r-sm); }
.btn[disabled] { opacity: .5; pointer-events: none; }

/* ============================================================
   ТЕГИ / БЕЙДЖИ
   ============================================================ */
.tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; font-weight: 600; line-height: 1;
  padding: 6px 10px; border-radius: var(--r-pill);
  background: var(--surface-2); color: var(--ink-soft);
  white-space: nowrap;
}
.tag .dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.tag--hit { background: var(--primary-wash); color: var(--primary-dark); }
.tag--new { background: var(--info-wash); color: var(--info); }
.tag--veg { background: var(--success-wash); color: var(--success); }
.tag--spicy { background: var(--danger-wash); color: var(--danger); }
.tag--gf { background: #EFEAFB; color: #6D45C9; }

.badge {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: 12.5px; font-weight: 600; line-height: 1;
  padding: 7px 11px; border-radius: var(--r-pill);
}
.badge .dot { width: 7px; height: 7px; border-radius: 50%; background: currentColor; }
.badge--new      { background: var(--danger);  color: #fff; }
.badge--confirmed{ background: var(--info-wash); color: var(--info); }
.badge--paid     { background: var(--success-wash); color: var(--success); }
.badge--delivered{ background: var(--success-wash); color: var(--success); }
.badge--cooking  { background: var(--warning-wash); color: var(--warning); }
.badge--ontheway { background: var(--primary-wash); color: var(--primary-dark); }
.badge--canceled { background: #EEF1F5; color: var(--ink-mute); }

/* ============================================================
   СТЕППЕР КОЛИЧЕСТВА
   ============================================================ */
.qty { display: inline-flex; align-items: center; background: var(--surface); border: 1.5px solid var(--border); border-radius: var(--r-md); height: 44px; }
.qty button { width: 42px; height: 100%; display: grid; place-items: center; color: var(--ink-soft); transition: color .15s, background .15s; border-radius: var(--r-sm); }
.qty button:hover { color: var(--primary); }
.qty button:disabled { color: var(--border); pointer-events: none; }
.qty span { min-width: 30px; text-align: center; font-family: var(--font-display); font-weight: 700; font-size: 15px; font-variant-numeric: tabular-nums; }
.qty--sm { height: 36px; }
.qty--sm button { width: 34px; }

/* ============================================================
   КАРТОЧКА БЛЮДА
   ============================================================ */
.card {
  background: var(--surface);
  border: 1px solid var(--border-2);
  border-radius: var(--r-xl);
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s;
}
.card:hover { transform: translateY(-4px); box-shadow: var(--sh-md); border-color: var(--border); }
.card__media { position: relative; aspect-ratio: 4/3; border-radius: 0; }
.card__media .ph { border-radius: 0; width: 100%; height: 100%; }
.card__fav {
  position: absolute; top: 12px; right: 12px;
  width: 38px; height: 38px; border-radius: 50%;
  background: rgba(255,255,255,.92); backdrop-filter: blur(4px);
  display: grid; place-items: center; color: var(--ink-soft);
  box-shadow: var(--sh-xs); transition: transform .15s, color .15s;
  z-index: 2;
}
.card__fav:hover { transform: scale(1.08); }
.card__fav.is-active { color: var(--danger); }
.card__fav.is-active svg { fill: var(--danger); }
.card__tags { position: absolute; top: 12px; left: 12px; display: flex; gap: 6px; flex-wrap: wrap; max-width: 70%; z-index: 2; }
.card__body { padding: 16px 16px 18px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.card__title { font-family: var(--font-display); font-weight: 700; font-size: 16px; letter-spacing: -0.01em; line-height: 1.25; cursor: pointer; }
.card__title:hover { color: var(--primary-dark); }
.card__meta { display: flex; align-items: center; gap: 10px; color: var(--ink-mute); font-size: 12.5px; }
.card__meta .star { color: var(--primary-light); display: inline-flex; align-items: center; gap: 3px; font-weight: 600; }
.card__desc { color: var(--ink-soft); font-size: 13px; line-height: 1.45; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.card__foot { margin-top: auto; padding-top: 6px; display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.card__price { font-size: 19px; }
.card__add {
  width: 44px; height: 44px; border-radius: var(--r-md);
  background: var(--primary-wash); color: var(--primary-dark);
  display: grid; place-items: center; transition: background .16s, color .16s, transform .16s;
  flex: none;
}
.card__add:hover { background: var(--primary); color: #fff; }
.card__add:active { transform: scale(.92); }

/* rating star inline */
.star-row { display: inline-flex; align-items: center; gap: 4px; color: var(--ink-soft); font-weight: 600; font-size: 13px; }
.star-row svg { width: 14px; height: 14px; color: var(--primary-light); }

/* ============================================================
   ИНПУТЫ / ФОРМЫ
   ============================================================ */
.field { display: flex; flex-direction: column; gap: 7px; }
.field label { font-size: 13px; font-weight: 600; color: var(--ink-soft); }
.field .req { color: var(--danger); }
.input, .textarea, .select {
  width: 100%; background: var(--surface); border: 1.5px solid var(--border);
  border-radius: var(--r-md); padding: 0 14px; height: 48px;
  font-size: 14.5px; transition: border-color .15s, box-shadow .15s;
}
.textarea { height: auto; padding: 12px 14px; min-height: 92px; resize: vertical; line-height: 1.5; }
.input:focus, .textarea:focus, .select:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px var(--primary-wash); }
.input::placeholder, .textarea::placeholder { color: var(--ink-mute); }

/* radio cards */
.choice-grid { display: grid; gap: 10px; }
.choice {
  display: flex; align-items: center; gap: 12px;
  border: 1.5px solid var(--border); border-radius: var(--r-md);
  padding: 14px 16px; cursor: pointer; transition: border-color .15s, background .15s;
  background: var(--surface);
}
.choice:hover { border-color: var(--ink-mute); }
.choice.is-active { border-color: var(--primary); background: var(--primary-wash); }
.choice__radio { width: 20px; height: 20px; border-radius: 50%; border: 2px solid var(--border); flex: none; display: grid; place-items: center; transition: border-color .15s; }
.choice.is-active .choice__radio { border-color: var(--primary); }
.choice.is-active .choice__radio::after { content: ''; width: 10px; height: 10px; border-radius: 50%; background: var(--primary); }
.choice__main { flex: 1; }
.choice__title { font-weight: 600; font-size: 14.5px; }
.choice__sub { font-size: 12.5px; color: var(--ink-mute); margin-top: 2px; }
.choice__price { font-family: var(--font-display); font-weight: 700; font-size: 14.5px; }

/* ============================================================
   УТИЛИТЫ
   ============================================================ */
.flex { display: flex; }
.col { display: flex; flex-direction: column; }
.between { justify-content: space-between; }
.center { align-items: center; }
.gap-4 { gap: 4px; } .gap-8 { gap: 8px; } .gap-12 { gap: 12px; } .gap-16 { gap: 16px; } .gap-24 { gap: 24px; }
.muted { color: var(--ink-soft); }
.mute { color: var(--ink-mute); }
.hr { height: 1px; background: var(--border); border: 0; }
.chip { display: inline-flex; align-items: center; gap: 7px; padding: 8px 14px; border-radius: var(--r-pill); background: var(--surface); border: 1.5px solid var(--border); font-size: 13.5px; font-weight: 600; color: var(--ink-soft); cursor: pointer; transition: all .15s; white-space: nowrap; }
.chip:hover { border-color: var(--ink-mute); color: var(--ink); }
.chip.is-active { background: var(--navy); border-color: var(--navy); color: #fff; }

.fade-up { animation: fadeUp .55s cubic-bezier(.16,.84,.44,1) both; }
@keyframes fadeUp { from { transform: translateY(16px); } to { transform: none; } }
@keyframes pop { 0%{transform:scale(.8);opacity:0} 60%{transform:scale(1.05)} 100%{transform:scale(1);opacity:1} }

/* scrollbars for filter rails */
.xscroll { display: flex; gap: 12px; overflow-x: auto; scrollbar-width: none; padding-bottom: 4px; }
.xscroll::-webkit-scrollbar { display: none; }

/* ============================================================
   ТОСТ
   ============================================================ */
.toast-wrap { position: fixed; left: 50%; bottom: 28px; transform: translateX(-50%); z-index: 200; display: flex; flex-direction: column; gap: 10px; align-items: center; pointer-events: none; }
.toast {
  display: flex; align-items: center; gap: 12px;
  background: var(--navy); color: #fff;
  padding: 13px 18px; border-radius: var(--r-md);
  box-shadow: var(--sh-lg); font-size: 14px; font-weight: 500;
  animation: pop .3s ease both;
}
.toast .ic { width: 28px; height: 28px; border-radius: 50%; background: var(--success); display: grid; place-items: center; flex: none; }
.toast .ic svg { width: 16px; height: 16px; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1080px) {
  :root { --gutter: 24px; }
}
@media (max-width: 760px) {
  :root { --gutter: 18px; }
  .section { padding: 48px 0; }
  h1 { font-size: 26px; }
  .section-head { flex-direction: column; align-items: flex-start; gap: 12px; }
}
