/* THE IDOL — Mini App SPA (P3).
   Дизайн-токены — единый источник из витрины (tasks/sale-design/assets/styles.css):
   accent-фиолетовый, charcoal, gold, sale-red, ok-green; острые углы (--r:0px);
   Manrope (display) / Inter (text) / Playfair Display (serif). Мобильный-first (webview). */

:root {
  --bg:#ffffff;
  --ink:#282828;
  --ink-strong:#1a1a1a;
  --muted:#6d6d6d;
  --line:#c4c4c4;
  --line-soft:#e4e2dd;
  --surface:#f5f6f9;
  --surface-2:#eeeeee;
  --accent:#7a48c0;        /* brand purple — всегда фиолетовый, в т.ч. в dark */
  --ok:#7ab838;
  --sale:#e29191;
  --gold:#9a7b4f;
  --gold-ink:#6e5226;
  --r:0px;                 /* острые углы = бренд */

  --f-display:"Manrope",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  --f-text:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  --f-serif:"Playfair Display",Georgia,"Times New Roman",serif;
}

/* Dark: bg/ink подхватывают тёмную тему Telegram, accent остаётся фиолетовым.
   Класс theme-dark ставит app.js по colorScheme/themeChanged. */
.theme-dark {
  --bg:#17181c;
  --ink:#e9e9ec;
  --ink-strong:#ffffff;
  --muted:#9aa0aa;
  --line:#3a3c44;
  --line-soft:#2a2c33;
  --surface:#1f2126;
  --surface-2:#262932;
}

* { box-sizing:border-box; }

html, body {
  margin:0; padding:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--f-text);
  font-size:15px;
  line-height:1.45;
  -webkit-font-smoothing:antialiased;
}

button { font-family:inherit; cursor:pointer; }
img { display:block; max-width:100%; }

/* --- Вордмарк-лого --------------------------------------------------------- */
.wordmark {
  font-family:var(--f-serif);
  font-weight:600;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--ink-strong);
}
.wordmark--gate { font-size:26px; margin-bottom:20px; }

/* --- Топбар ---------------------------------------------------------------- */
.topbar {
  position:sticky; top:0; z-index:20;
  display:flex; align-items:center; gap:12px;
  padding:12px 14px;
  background:var(--bg);
  border-bottom:1px solid var(--line);
}
.topbar__logo { height:22px; }
.topbar__logo svg { height:100%; width:auto; }
.topbar__cart {
  margin-left:auto;
  border:1px solid var(--line); background:transparent; color:var(--ink);
  border-radius:var(--r); padding:6px 12px; font-family:var(--f-display); font-weight:600;
}
.topbar__cart[data-count]:not([data-count="0"])::after {
  content:" · "attr(data-count); color:var(--accent);
}

/* --- Панель поиска + фильтров --------------------------------------------- */
.filters { padding:10px 14px; border-bottom:1px solid var(--line-soft); background:var(--bg); }
.filters__search {
  width:100%; padding:10px 12px; border:1px solid var(--line); border-radius:var(--r);
  background:var(--surface); color:var(--ink); font-family:var(--f-text); font-size:15px;
}
.filters__chips { display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; }
.chip {
  border:1px solid var(--line); background:transparent; color:var(--ink);
  border-radius:var(--r); padding:5px 11px; font-size:13px; white-space:nowrap;
}
.chip[aria-pressed="true"] { background:var(--accent); border-color:var(--accent); color:#fff; }
.filters__sort { display:flex; align-items:center; gap:8px; margin-top:8px; }
.filters__sort-label { font-family:var(--f-display); font-weight:600; font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--muted); }
.filters__sort-select {
  flex:0 0 auto; border:1px solid var(--line); border-radius:var(--r);
  background:var(--surface); color:var(--ink); font-family:var(--f-text); font-size:13px; padding:6px 10px;
}

/* --- Грид карточек (2 колонки, фото 3:4) ----------------------------------- */
.grid {
  display:grid; grid-template-columns:repeat(2, 1fr); gap:1px;
  background:var(--line-soft);      /* хэйрлайн-сетка между карточками */
  border-bottom:1px solid var(--line-soft);
}
.card { background:var(--bg); padding:0 0 12px; text-align:left; border:0; display:block; width:100%; }
.card__ph { position:relative; aspect-ratio:3/4; background:var(--surface); overflow:hidden; }
.card__ph img { width:100%; height:100%; object-fit:cover; }
.card__badge {
  position:absolute; top:8px; left:8px;
  background:var(--sale); color:#3a1414; font-family:var(--f-display); font-weight:700;
  font-size:12px; padding:2px 7px; border-radius:var(--r);
}
.card__body { padding:8px 10px 0; }
.card__brand { font-family:var(--f-display); font-weight:700; font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); }
.card__title { font-size:13px; color:var(--ink); margin:2px 0 6px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.price { display:flex; align-items:baseline; gap:7px; flex-wrap:wrap; }
.price__now { font-family:var(--f-display); font-weight:800; color:var(--ink-strong); }
.price__now--sale { color:var(--sale); }
.price__old { text-decoration:line-through; color:var(--muted); font-size:13px; }

/* --- Экран карточки товара ------------------------------------------------- */
.product { padding-bottom:96px; }
.product__gallery { background:var(--surface); }
.product__gallery img { width:100%; aspect-ratio:3/4; object-fit:cover; }
.product__info { padding:14px; }
.product__brand { font-family:var(--f-display); font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); font-size:12px; }
.product__title { font-family:var(--f-display); font-weight:700; font-size:20px; margin:4px 0 10px; color:var(--ink-strong); }
.product__price { margin-bottom:14px; }
.product__price .price__now { font-size:22px; }
.product__cond { color:var(--muted); font-size:13px; margin-bottom:14px; }
.sizes { display:flex; flex-wrap:wrap; gap:7px; margin:6px 0 16px; }
.size-chip {
  min-width:44px; text-align:center; border:1px solid var(--line); background:transparent;
  color:var(--ink); border-radius:var(--r); padding:8px 12px; font-family:var(--f-display); font-weight:600;
}
.size-chip[aria-pressed="true"] { background:var(--ink-strong); border-color:var(--ink-strong); color:var(--bg); }
.product__descr { color:var(--ink); font-size:14px; white-space:pre-wrap; }
.section-label { font-family:var(--f-display); font-weight:700; font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin:0 0 6px; }

/* --- Корзина / форма ------------------------------------------------------- */
.screen { padding:14px 14px 96px; }
.screen__h { font-family:var(--f-display); font-weight:700; font-size:20px; color:var(--ink-strong); margin:0 0 14px; }
.cart-row { display:flex; gap:10px; padding:10px 0; border-bottom:1px solid var(--line-soft); align-items:center; }
.cart-row.is-unavailable { opacity:.55; }
.cart-row__thumb { width:56px; height:72px; object-fit:cover; background:var(--surface); flex:0 0 auto; }
.cart-row__mid { flex:1 1 auto; min-width:0; }
.cart-row__title { font-size:13px; color:var(--ink); }
.cart-row__meta { color:var(--muted); font-size:12px; margin-top:2px; }
.cart-row__warn { color:var(--sale); font-size:12px; margin-top:2px; font-weight:600; }
.qty { display:flex; align-items:center; gap:0; margin-top:6px; }
.qty button { width:30px; height:30px; border:1px solid var(--line); background:transparent; color:var(--ink); font-size:16px; line-height:1; }
.qty span { min-width:34px; text-align:center; font-family:var(--f-display); font-weight:600; }
.cart-row__rm { margin-left:auto; border:0; background:transparent; color:var(--muted); font-size:20px; align-self:flex-start; }
.cart-total { display:flex; justify-content:space-between; align-items:baseline; margin-top:16px; padding-top:12px; border-top:1px solid var(--line); }
.cart-total__label { font-family:var(--f-display); font-weight:600; color:var(--muted); }
.cart-total__val { font-family:var(--f-display); font-weight:800; font-size:20px; color:var(--ink-strong); }

.field { margin-bottom:14px; }
.field label { display:block; font-family:var(--f-display); font-weight:600; font-size:13px; margin-bottom:5px; }
.field input, .field textarea {
  width:100%; padding:10px 12px; border:1px solid var(--line); border-radius:var(--r);
  background:var(--surface); color:var(--ink); font-family:var(--f-text); font-size:15px;
}
.field textarea { resize:vertical; min-height:66px; }
.field__ro { color:var(--muted); font-size:14px; padding:2px 0; }
.btn-secondary {
  border:1px solid var(--accent); background:transparent; color:var(--accent);
  border-radius:var(--r); padding:9px 14px; font-family:var(--f-display); font-weight:600;
}

.empty { text-align:center; color:var(--muted); padding:48px 20px; }
.empty__title { font-family:var(--f-display); font-weight:700; color:var(--ink); margin-bottom:6px; }

.load-more { text-align:center; padding:16px; }

/* --- Экран успеха / фолбэк-ошибки ------------------------------------------ */
.state {
  text-align:center; padding:60px 24px; max-width:420px; margin:0 auto;
}
.state__mark { font-family:var(--f-display); font-weight:800; font-size:40px; color:var(--accent); margin-bottom:10px; }
.state__title { font-family:var(--f-display); font-weight:700; font-size:20px; color:var(--ink-strong); margin-bottom:8px; }
.state__text { color:var(--muted); margin-bottom:20px; }
.state .btn-secondary { display:inline-block; }

/* --- Блок-экран (E6) ------------------------------------------------------- */
#gate {
  position:fixed; inset:0; display:flex; align-items:center; justify-content:center;
  background:var(--bg); padding:24px; z-index:100;
}
.gate__box { text-align:center; max-width:340px; }
.gate__title { font-family:var(--f-display); font-weight:700; font-size:19px; color:var(--ink-strong); margin:0 0 8px; }
.gate__hint { color:var(--muted); font-size:14px; }

/* --- Тосты ----------------------------------------------------------------- */
#toasts {
  position:fixed; left:0; right:0; bottom:16px; z-index:200;
  display:flex; flex-direction:column; align-items:center; gap:8px; pointer-events:none;
}
.toast {
  background:var(--ink-strong); color:#fff; padding:10px 16px; border-radius:var(--r);
  font-size:14px; max-width:88%; box-shadow:0 6px 24px rgba(0,0,0,.2);
}
.toast--err { background:var(--sale); color:#3a1414; }
