/* ============================================================================
   TSD-Эксперт — демо AI-поиска. Общие компоненты.
   Опирается на токены из tokens.css (подключать tokens.css ПЕРЕД app.css).
   Стиль: e-com TSD (тёмная шапка, красный логотип, оранжевый акцент), но
   нейтрально и чисто — движок наш, дизайн остаётся зоной партнёра.
   Имена классов фиксированы для фронт-агентов: .tsd-header .tsd-search .tsd-seg
   .tsd-card .tsd-chip .tsd-btn .tsd-overlay .tsd-chat .tsd-grid .tsd-context
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&display=swap');

/* --- Сброс и база ---------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--tsd-font);
  font-size: var(--tsd-fs-base);
  line-height: var(--tsd-lh-normal);
  color: var(--tsd-text);
  background: var(--tsd-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden; /* страховка от горизонтального скролла на мобайле */
}

img { max-width: 100%; display: block; }
button { font-family: inherit; }
a { color: inherit; text-decoration: none; }

h1, h2, h3, h4 { margin: 0; line-height: var(--tsd-lh-tight); font-weight: var(--tsd-fw-bold); }

.tsd-container {
  width: 100%;
  max-width: var(--tsd-container);
  margin-inline: auto;
  padding-inline: var(--tsd-gutter);
}

.tsd-section-title {
  font-size: var(--tsd-fs-xl);
  font-weight: var(--tsd-fw-extrabold);
  text-transform: uppercase;
  letter-spacing: var(--tsd-ls-caps);
  text-align: center;
  margin-block: var(--tsd-space-8) var(--tsd-space-6);
}

/* ============================================================================
   .tsd-header — тёмная шапка сайта (лого + контакты + строка поиска)
   ========================================================================== */
.tsd-header {
  position: sticky;
  top: 0;
  z-index: var(--tsd-z-header);
  background: var(--tsd-header-bg);
  color: var(--tsd-text-on-dark);
  box-shadow: var(--tsd-shadow-sm);
}

.tsd-header__top {
  display: flex;
  align-items: center;
  gap: var(--tsd-space-5);
  padding-block: var(--tsd-space-3);
}

.tsd-header__logo {
  display: inline-flex;
  align-items: center;
  flex: 0 0 auto;
}
.tsd-header__logo img,
.tsd-header__logo svg { height: 38px; width: auto; }

.tsd-header__contacts {
  display: flex;
  align-items: center;
  gap: var(--tsd-space-5);
  margin-left: auto;
  font-size: var(--tsd-fs-sm);
  color: var(--tsd-text-on-dark);
}
.tsd-header__phone {
  font-size: var(--tsd-fs-lg);
  font-weight: var(--tsd-fw-bold);
  white-space: nowrap;
}
.tsd-header__email { color: #c8ccd0; }

/* нижняя полоса-меню категорий под шапкой */
.tsd-header__nav {
  display: flex;
  align-items: center;
  gap: var(--tsd-space-1);
  background: var(--tsd-header-bg-2);
  padding-block: var(--tsd-space-1);
}
.tsd-header__nav-item {
  padding: var(--tsd-space-2) var(--tsd-space-4);
  font-size: var(--tsd-fs-sm);
  font-weight: var(--tsd-fw-medium);
  color: var(--tsd-text-on-dark);
  border-radius: var(--tsd-radius-sm);
  cursor: pointer;
  transition: background var(--tsd-dur) var(--tsd-ease);
}
.tsd-header__nav-item:hover,
.tsd-header__nav-item--active { background: var(--tsd-orange); color: var(--tsd-text-on-accent); }

/* ============================================================================
   .tsd-search — строка поиска с переключателем режима (segmented control)
   Раскладка: [ .tsd-seg ] [ input ] [ кнопка «Найти» ] ; снизу — .tsd-chat
   ========================================================================== */
.tsd-search {
  position: relative;
  display: flex;
  align-items: stretch;
  gap: var(--tsd-space-2);
  width: 100%;
  max-width: 640px;
}

.tsd-search__field {
  display: flex;
  flex: 1 1 auto;
  align-items: center;
  min-width: 0;
  background: var(--tsd-surface);
  border: 1px solid var(--tsd-line);
  border-radius: var(--tsd-radius-md);
  padding-inline: var(--tsd-space-3);
  transition: border-color var(--tsd-dur) var(--tsd-ease),
              box-shadow var(--tsd-dur) var(--tsd-ease);
}
.tsd-search__field:focus-within {
  border-color: var(--tsd-orange);
  box-shadow: 0 0 0 3px var(--tsd-orange-050);
}
.tsd-search__icon { flex: 0 0 auto; color: var(--tsd-text-3); margin-right: var(--tsd-space-2); }
.tsd-search__input {
  flex: 1 1 auto;
  min-width: 0;
  border: none;
  outline: none;
  background: transparent;
  font-size: var(--tsd-fs-md);
  color: var(--tsd-text);
  padding-block: var(--tsd-space-3);
}
.tsd-search__input::placeholder { color: var(--tsd-text-3); }

/* «нет результатов» для обычного поиска (воспроизводим боль) */
.tsd-search__empty {
  margin-top: var(--tsd-space-3);
  padding: var(--tsd-space-4) var(--tsd-space-5);
  background: var(--tsd-red-050);
  border: 1px solid #f3c9c9;
  border-radius: var(--tsd-radius-md);
  color: var(--tsd-red-600);
  font-size: var(--tsd-fs-sm);
  font-weight: var(--tsd-fw-medium);
}

/* --- .tsd-seg — segmented control «Обычный / ИИ-поиск» -------------------- */
.tsd-seg {
  display: inline-flex;
  flex: 0 0 auto;
  padding: 3px;
  background: var(--tsd-surface-2);
  border: 1px solid var(--tsd-line);
  border-radius: var(--tsd-radius-pill);
}
.tsd-seg__opt {
  display: inline-flex;
  align-items: center;
  gap: var(--tsd-space-1);
  padding: var(--tsd-space-2) var(--tsd-space-4);
  border: none;
  background: transparent;
  border-radius: var(--tsd-radius-pill);
  font-size: var(--tsd-fs-sm);
  font-weight: var(--tsd-fw-semibold);
  color: var(--tsd-text-2);
  white-space: nowrap;
  cursor: pointer;
  transition: background var(--tsd-dur) var(--tsd-ease),
              color var(--tsd-dur) var(--tsd-ease);
}
.tsd-seg__opt--active {
  background: var(--tsd-surface);
  color: var(--tsd-text);
  box-shadow: var(--tsd-shadow-xs);
}
/* активный режим ИИ подсвечивается оранжевым */
.tsd-seg__opt--ai.tsd-seg__opt--active { color: var(--tsd-orange-600); }

/* ============================================================================
   .tsd-btn — кнопки (primary / ghost / red / ghost-on-dark)
   ========================================================================== */
.tsd-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--tsd-space-2);
  padding: var(--tsd-space-3) var(--tsd-space-5);
  border: 1px solid transparent;
  border-radius: var(--tsd-radius-md);
  font-size: var(--tsd-fs-sm);
  font-weight: var(--tsd-fw-semibold);
  line-height: 1;
  cursor: pointer;
  white-space: nowrap;
  transition: background var(--tsd-dur) var(--tsd-ease),
              border-color var(--tsd-dur) var(--tsd-ease),
              box-shadow var(--tsd-dur) var(--tsd-ease),
              transform var(--tsd-dur-fast) var(--tsd-ease);
}
.tsd-btn:active { transform: translateY(1px); }
.tsd-btn:disabled { opacity: 0.5; cursor: not-allowed; }

.tsd-btn--primary {
  background: var(--tsd-orange);
  color: var(--tsd-text-on-accent);
}
.tsd-btn--primary:hover { background: var(--tsd-orange-600); box-shadow: var(--tsd-shadow-accent); }

.tsd-btn--red {
  background: var(--tsd-red);
  color: var(--tsd-text-on-accent);
}
.tsd-btn--red:hover { background: var(--tsd-red-600); }

.tsd-btn--ghost {
  background: var(--tsd-surface);
  color: var(--tsd-text);
  border-color: var(--tsd-line);
}
.tsd-btn--ghost:hover { border-color: var(--tsd-line-strong); background: var(--tsd-surface-2); }

.tsd-btn--ghost-accent {
  background: transparent;
  color: var(--tsd-orange-600);
  border-color: var(--tsd-orange);
}
.tsd-btn--ghost-accent:hover { background: var(--tsd-orange-050); }

.tsd-btn--block { width: 100%; }
.tsd-btn--sm { padding: var(--tsd-space-2) var(--tsd-space-3); font-size: var(--tsd-fs-xs); }
.tsd-btn--lg { padding: var(--tsd-space-4) var(--tsd-space-6); font-size: var(--tsd-fs-md); }

/* ============================================================================
   .tsd-chip — чип / таблетка (спеки товара, фильтры, подсказки)
   ========================================================================== */
.tsd-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--tsd-space-1);
  padding: var(--tsd-space-1) var(--tsd-space-3);
  background: var(--tsd-surface-2);
  border: 1px solid var(--tsd-line-2);
  border-radius: var(--tsd-radius-pill);
  font-size: var(--tsd-fs-xs);
  font-weight: var(--tsd-fw-medium);
  color: var(--tsd-text-2);
  white-space: nowrap;
}
.tsd-chip__ico { flex: 0 0 auto; opacity: 0.7; }

/* варианты акцента */
.tsd-chip--accent { background: var(--tsd-orange-050); border-color: #ffd9a8; color: var(--tsd-orange-600); }
.tsd-chip--red    { background: var(--tsd-red-050); border-color: #f3c9c9; color: var(--tsd-red-600); }
.tsd-chip--ok     { background: var(--tsd-success-050); border-color: #bfe6cd; color: var(--tsd-success); }

/* кликабельный чип-подсказка (саджесты, варианты ответа в чате) */
.tsd-chip--action {
  cursor: pointer;
  background: var(--tsd-surface);
  border-color: var(--tsd-line);
  color: var(--tsd-text);
  padding: var(--tsd-space-2) var(--tsd-space-3);
  transition: border-color var(--tsd-dur) var(--tsd-ease), background var(--tsd-dur) var(--tsd-ease);
}
.tsd-chip--action:hover { border-color: var(--tsd-orange); background: var(--tsd-orange-050); color: var(--tsd-orange-600); }

.tsd-chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--tsd-space-2);
}

/* ============================================================================
   .tsd-grid — сетка товаров (auto-fill, на мобайле одна колонка)
   ========================================================================== */
.tsd-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(var(--tsd-card-min), 1fr));
  gap: var(--tsd-grid-gap);
}

/* ============================================================================
   .tsd-card — карточка товара (фото, бренд, название, спеки-чипы, цена, кнопка)
   ========================================================================== */
.tsd-card {
  display: flex;
  flex-direction: column;
  background: var(--tsd-surface);
  border: 1px solid var(--tsd-line-2);
  border-radius: var(--tsd-radius-md);
  overflow: hidden;
  transition: border-color var(--tsd-dur) var(--tsd-ease),
              box-shadow var(--tsd-dur) var(--tsd-ease),
              transform var(--tsd-dur) var(--tsd-ease);
}
.tsd-card:hover {
  border-color: var(--tsd-line);
  box-shadow: var(--tsd-shadow-md);
  transform: translateY(-2px);
}

.tsd-card__media {
  position: relative;
  aspect-ratio: 4 / 3;
  background: var(--tsd-surface);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--tsd-space-4);
}
.tsd-card__media img { max-height: 100%; width: auto; object-fit: contain; }
/* плейсхолдер, если фото не загрузилось */
.tsd-card__media--empty { background: var(--tsd-surface-2); }
.tsd-card__media--empty::after {
  content: 'ТСД';
  font-weight: var(--tsd-fw-bold);
  font-size: var(--tsd-fs-sm);
  letter-spacing: .1em;
  color: var(--tsd-text-2);
  opacity: .4;
}

/* бейдж в углу фото (хит, распродажа) */
.tsd-card__badge {
  position: absolute;
  top: var(--tsd-space-3);
  left: var(--tsd-space-3);
  padding: 2px var(--tsd-space-2);
  border-radius: var(--tsd-radius-sm);
  font-size: var(--tsd-fs-xs);
  font-weight: var(--tsd-fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--tsd-ls-caps);
  color: var(--tsd-text-on-accent);
  background: var(--tsd-red);
}
.tsd-card__badge--hit { background: var(--tsd-orange); }

.tsd-card__body {
  display: flex;
  flex-direction: column;
  gap: var(--tsd-space-2);
  padding: var(--tsd-space-4);
  border-top: 1px solid var(--tsd-line-2);
  flex: 1 1 auto;
}
.tsd-card__brand {
  font-size: var(--tsd-fs-xs);
  font-weight: var(--tsd-fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--tsd-ls-caps);
  color: var(--tsd-text-3);
}
.tsd-card__name {
  font-size: var(--tsd-fs-md);
  font-weight: var(--tsd-fw-semibold);
  line-height: var(--tsd-lh-tight);
  color: var(--tsd-text);
  /* ограничение в 2 строки для ровной сетки */
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.tsd-card__specs { margin-top: var(--tsd-space-1); }

.tsd-card__foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--tsd-space-3);
  margin-top: auto;
  padding-top: var(--tsd-space-3);
}
.tsd-card__price {
  font-size: var(--tsd-fs-lg);
  font-weight: var(--tsd-fw-extrabold);
  color: var(--tsd-text);
  white-space: nowrap;
}
.tsd-card__price-note { font-size: var(--tsd-fs-xs); font-weight: var(--tsd-fw-regular); color: var(--tsd-text-3); }

/* «почему эта модель» — объяснение под карточкой в AI-выдаче и квизе */
.tsd-card__why {
  margin-top: var(--tsd-space-2);
  padding: var(--tsd-space-3);
  background: var(--tsd-orange-050);
  border-radius: var(--tsd-radius-sm);
  font-size: var(--tsd-fs-sm);
  line-height: var(--tsd-lh-normal);
  color: var(--tsd-text-2);
}
.tsd-card__why b { color: var(--tsd-orange-600); }

/* компактная карточка inline в чате */
.tsd-card--compact { flex-direction: row; align-items: stretch; }
.tsd-card--compact .tsd-card__media { flex: 0 0 96px; aspect-ratio: 1 / 1; padding: var(--tsd-space-2); }
.tsd-card--compact .tsd-card__body { border-top: none; border-left: 1px solid var(--tsd-line-2); padding: var(--tsd-space-3); }
.tsd-card--compact .tsd-card__name { font-size: var(--tsd-fs-sm); }

/* ============================================================================
   .tsd-overlay — затемнение + модалка (хост для квиза)
   ========================================================================== */
.tsd-overlay {
  position: fixed;
  inset: 0;
  z-index: var(--tsd-z-overlay);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--tsd-space-4);
  background: var(--tsd-overlay-bg);
  backdrop-filter: blur(2px);
  animation: tsd-fade var(--tsd-dur) var(--tsd-ease);
}
.tsd-overlay[hidden] { display: none; }

.tsd-overlay__dialog {
  position: relative;
  z-index: var(--tsd-z-modal);
  width: 100%;
  max-width: 560px;
  max-height: calc(100dvh - 2 * var(--tsd-space-8));
  display: flex;
  flex-direction: column;
  background: var(--tsd-surface);
  border-radius: var(--tsd-radius-lg);
  box-shadow: var(--tsd-shadow-lg);
  overflow: hidden;
  animation: tsd-pop var(--tsd-dur-slow) var(--tsd-ease);
}
.tsd-overlay__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--tsd-space-3);
  padding: var(--tsd-space-5) var(--tsd-space-6);
  border-bottom: 1px solid var(--tsd-line-2);
}
.tsd-overlay__title { font-size: var(--tsd-fs-lg); font-weight: var(--tsd-fw-extrabold); }
.tsd-overlay__close {
  flex: 0 0 auto;
  width: 32px; height: 32px;
  display: inline-flex; align-items: center; justify-content: center;
  border: none; background: var(--tsd-surface-2);
  border-radius: var(--tsd-radius-pill);
  color: var(--tsd-text-2); cursor: pointer;
  transition: background var(--tsd-dur) var(--tsd-ease);
}
.tsd-overlay__close:hover { background: var(--tsd-surface-3); }
.tsd-overlay__body {
  padding: var(--tsd-space-6);
  overflow-y: auto;
}
.tsd-overlay__foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--tsd-space-3);
  padding: var(--tsd-space-4) var(--tsd-space-6);
  border-top: 1px solid var(--tsd-line-2);
  background: var(--tsd-surface-2);
}

/* прогресс-бар квиза (один экран — одно действие) */
.tsd-overlay__progress {
  height: 4px;
  background: var(--tsd-surface-3);
  border-radius: var(--tsd-radius-pill);
  overflow: hidden;
  margin-bottom: var(--tsd-space-5);
}
.tsd-overlay__progress-bar {
  height: 100%;
  background: var(--tsd-orange);
  border-radius: var(--tsd-radius-pill);
  transition: width var(--tsd-dur-slow) var(--tsd-ease);
}

/* плитки-выборы шага квиза */
.tsd-choice {
  display: flex;
  align-items: center;
  gap: var(--tsd-space-3);
  width: 100%;
  padding: var(--tsd-space-4);
  background: var(--tsd-surface);
  border: 1.5px solid var(--tsd-line);
  border-radius: var(--tsd-radius-md);
  font-size: var(--tsd-fs-md);
  font-weight: var(--tsd-fw-medium);
  color: var(--tsd-text);
  text-align: left;
  cursor: pointer;
  transition: border-color var(--tsd-dur) var(--tsd-ease), background var(--tsd-dur) var(--tsd-ease);
}
.tsd-choice:hover { border-color: var(--tsd-orange); background: var(--tsd-orange-050); }
.tsd-choice--selected { border-color: var(--tsd-orange); background: var(--tsd-orange-050); color: var(--tsd-orange-600); }
.tsd-choices { display: grid; gap: var(--tsd-space-3); }

/* ============================================================================
   .tsd-chat — панель чат-ассистента (раскрывается из строки поиска)
   ========================================================================== */
.tsd-chat {
  display: flex;
  flex-direction: column;
  background: var(--tsd-surface);
  border: 1px solid var(--tsd-line);
  border-radius: var(--tsd-radius-lg);
  box-shadow: var(--tsd-shadow-md);
  overflow: hidden;
  animation: tsd-slide-down var(--tsd-dur-slow) var(--tsd-ease);
}
.tsd-chat[hidden] { display: none; }

.tsd-chat__head {
  display: flex;
  align-items: center;
  gap: var(--tsd-space-3);
  padding: var(--tsd-space-3) var(--tsd-space-4);
  border-bottom: 1px solid var(--tsd-line-2);
  background: var(--tsd-surface);
}
.tsd-chat__avatar {
  flex: 0 0 auto;
  width: 32px; height: 32px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: var(--tsd-radius-pill);
  background: var(--tsd-orange-050);
  color: var(--tsd-orange-600);
  font-weight: var(--tsd-fw-bold);
}
.tsd-chat__title { font-size: var(--tsd-fs-sm); font-weight: var(--tsd-fw-bold); }
.tsd-chat__subtitle { font-size: var(--tsd-fs-xs); color: var(--tsd-text-3); }
.tsd-chat__close { margin-left: auto; }

.tsd-chat__scroll {
  display: flex;
  flex-direction: column;
  gap: var(--tsd-space-3);
  padding: var(--tsd-space-4);
  max-height: 56vh;
  overflow-y: auto;
}

/* --- пузыри сообщений --- */
.tsd-msg {
  max-width: 88%;
  padding: var(--tsd-space-3) var(--tsd-space-4);
  border-radius: var(--tsd-radius-lg);
  font-size: var(--tsd-fs-sm);
  line-height: var(--tsd-lh-normal);
}
.tsd-msg--bot {
  align-self: flex-start;
  background: var(--tsd-surface-2);
  color: var(--tsd-text);
  border-bottom-left-radius: var(--tsd-radius-xs);
}
.tsd-msg--user {
  align-self: flex-end;
  background: var(--tsd-orange);
  color: var(--tsd-text-on-accent);
  border-bottom-right-radius: var(--tsd-radius-xs);
}
/* «печатает…» индикатор */
.tsd-msg--typing { display: inline-flex; gap: 4px; }
.tsd-msg--typing span {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--tsd-text-3);
  animation: tsd-typing 1s infinite ease-in-out;
}
.tsd-msg--typing span:nth-child(2) { animation-delay: 0.15s; }
.tsd-msg--typing span:nth-child(3) { animation-delay: 0.3s; }

/* карточки товаров inline в потоке чата */
.tsd-chat__cards { display: flex; flex-direction: column; gap: var(--tsd-space-2); align-self: stretch; }

/* чипы-подсказки / варианты ответа под потоком */
.tsd-chat__chips { padding: 0 var(--tsd-space-4) var(--tsd-space-3); }

/* поле ввода чата */
.tsd-chat__input {
  display: flex;
  align-items: center;
  gap: var(--tsd-space-2);
  padding: var(--tsd-space-3) var(--tsd-space-4);
  border-top: 1px solid var(--tsd-line-2);
  background: var(--tsd-surface);
}
.tsd-chat__input input {
  flex: 1 1 auto;
  min-width: 0;
  border: 1px solid var(--tsd-line);
  border-radius: var(--tsd-radius-pill);
  padding: var(--tsd-space-3) var(--tsd-space-4);
  font-size: var(--tsd-fs-sm);
  outline: none;
  transition: border-color var(--tsd-dur) var(--tsd-ease), box-shadow var(--tsd-dur) var(--tsd-ease);
}
.tsd-chat__input input:focus { border-color: var(--tsd-orange); box-shadow: 0 0 0 3px var(--tsd-orange-050); }
.tsd-chat__send {
  flex: 0 0 auto;
  width: 40px; height: 40px;
  display: inline-flex; align-items: center; justify-content: center;
  border: none; border-radius: var(--tsd-radius-pill);
  background: var(--tsd-orange); color: var(--tsd-text-on-accent);
  cursor: pointer;
  transition: background var(--tsd-dur) var(--tsd-ease);
}
.tsd-chat__send:hover { background: var(--tsd-orange-600); }

/* плашка «передать менеджеру» (тёплый лид) */
.tsd-chat__handoff {
  margin: 0 var(--tsd-space-4) var(--tsd-space-3);
  padding: var(--tsd-space-3) var(--tsd-space-4);
  background: var(--tsd-success-050);
  border: 1px solid #bfe6cd;
  border-radius: var(--tsd-radius-md);
  font-size: var(--tsd-fs-sm);
  color: var(--tsd-text);
}

/* ============================================================================
   .tsd-context — видимый блок «контекст диалога» (слоты ассистента)
   бизнес, задача, условия, бюджет, исключённые бренды
   ========================================================================== */
.tsd-context {
  background: var(--tsd-surface-2);
  border: 1px solid var(--tsd-line-2);
  border-radius: var(--tsd-radius-md);
  padding: var(--tsd-space-3) var(--tsd-space-4);
}
.tsd-context__title {
  display: flex;
  align-items: center;
  gap: var(--tsd-space-2);
  font-size: var(--tsd-fs-xs);
  font-weight: var(--tsd-fw-bold);
  text-transform: uppercase;
  letter-spacing: var(--tsd-ls-caps);
  color: var(--tsd-text-3);
  margin-bottom: var(--tsd-space-2);
}
.tsd-context__list {
  display: flex;
  flex-direction: column;
  gap: var(--tsd-space-2);
}
.tsd-context__row {
  display: flex;
  align-items: baseline;
  gap: var(--tsd-space-2);
  font-size: var(--tsd-fs-sm);
}
.tsd-context__key {
  flex: 0 0 auto;
  min-width: 92px;
  color: var(--tsd-text-3);
}
.tsd-context__val { color: var(--tsd-text); font-weight: var(--tsd-fw-medium); }
/* пустой слот — приглушённо */
.tsd-context__val--empty { color: var(--tsd-text-3); font-weight: var(--tsd-fw-regular); font-style: italic; }
/* исключённый бренд — перечёркнутый красный чип */
.tsd-context__excl {
  text-decoration: line-through;
  color: var(--tsd-red-600);
  background: var(--tsd-red-050);
  border-color: #f3c9c9;
}

/* ============================================================================
   Промо-баннеры и «популярные категории» (декор мок-сайта)
   ========================================================================== */
.tsd-promo {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--tsd-space-3);
  margin-block: var(--tsd-space-6);
}
.tsd-promo__item {
  position: relative;
  display: flex;
  align-items: flex-end;
  min-height: 150px;
  padding: var(--tsd-space-5);
  border-radius: var(--tsd-radius-md);
  color: var(--tsd-text-on-accent);
  font-size: var(--tsd-fs-xl);
  font-weight: var(--tsd-fw-extrabold);
  text-transform: uppercase;
  letter-spacing: var(--tsd-ls-caps);
  overflow: hidden;
  background: linear-gradient(135deg, var(--tsd-orange) 0%, var(--tsd-red) 100%);
}

.tsd-cats {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: var(--tsd-space-3);
}
.tsd-cats__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--tsd-space-2);
  padding: var(--tsd-space-4);
  background: var(--tsd-surface);
  border: 1px solid var(--tsd-line-2);
  border-radius: var(--tsd-radius-md);
  font-size: var(--tsd-fs-sm);
  font-weight: var(--tsd-fw-medium);
  color: var(--tsd-text);
  text-align: center;
  cursor: pointer;
  transition: border-color var(--tsd-dur) var(--tsd-ease), box-shadow var(--tsd-dur) var(--tsd-ease);
}
.tsd-cats__item:hover { border-color: var(--tsd-orange); box-shadow: var(--tsd-shadow-sm); }

/* ============================================================================
   Утилиты
   ========================================================================== */
.tsd-muted { color: var(--tsd-text-2); }
.tsd-center { text-align: center; }
.tsd-stack-2 > * + * { margin-top: var(--tsd-space-2); }
.tsd-stack-4 > * + * { margin-top: var(--tsd-space-4); }
.tsd-hide { display: none !important; }
.tsd-divider { height: 1px; background: var(--tsd-line-2); border: none; margin-block: var(--tsd-space-4); }

/* скелетон загрузки */
.tsd-skeleton {
  background: linear-gradient(90deg, var(--tsd-surface-3) 25%, var(--tsd-surface-2) 37%, var(--tsd-surface-3) 63%);
  background-size: 400% 100%;
  border-radius: var(--tsd-radius-sm);
  animation: tsd-shimmer 1.4s ease infinite;
}

/* ============================================================================
   Анимации
   ========================================================================== */
@keyframes tsd-fade { from { opacity: 0; } to { opacity: 1; } }
@keyframes tsd-pop { from { opacity: 0; transform: translateY(12px) scale(0.98); } to { opacity: 1; transform: none; } }
@keyframes tsd-slide-down { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: none; } }
@keyframes tsd-typing { 0%, 60%, 100% { transform: translateY(0); opacity: 0.5; } 30% { transform: translateY(-4px); opacity: 1; } }
@keyframes tsd-shimmer { 0% { background-position: 100% 0; } 100% { background-position: 0 0; } }

/* ============================================================================
   Адаптив. Цель: мобайл — одна колонка, scrollWidth == clientWidth.
   ========================================================================== */
@media (max-width: 900px) {
  .tsd-header__top { flex-wrap: wrap; gap: var(--tsd-space-3); }
  .tsd-search { max-width: 100%; order: 3; flex-basis: 100%; }
  .tsd-promo { grid-template-columns: 1fr; }
  .tsd-overlay__dialog { max-width: 100%; }
}

@media (max-width: 640px) {
  :root { --tsd-gutter: 14px; --tsd-grid-gap: 12px; }

  .tsd-header__contacts { gap: var(--tsd-space-3); }
  .tsd-header__email { display: none; }
  .tsd-header__nav { overflow-x: auto; -webkit-overflow-scrolling: touch; }

  /* строка поиска: сегмент-контрол над полем, чтобы ничего не вылезало */
  .tsd-search { flex-wrap: wrap; }
  .tsd-seg { width: 100%; }
  .tsd-seg__opt { flex: 1 1 0; justify-content: center; }
  .tsd-search__field { flex-basis: 100%; }

  /* сетка товаров — одна колонка */
  .tsd-grid { grid-template-columns: 1fr; }

  /* inline-карточка в чате становится вертикальной, чтобы не давать перенос вширь */
  .tsd-card--compact { flex-direction: column; }
  .tsd-card--compact .tsd-card__media { flex-basis: auto; aspect-ratio: 4 / 3; }
  .tsd-card--compact .tsd-card__body { border-left: none; border-top: 1px solid var(--tsd-line-2); }

  .tsd-msg { max-width: 92%; }
  .tsd-chat__scroll { max-height: 60vh; }

  .tsd-overlay { padding: 0; align-items: flex-end; }
  .tsd-overlay__dialog { max-width: 100%; max-height: 92dvh; border-radius: var(--tsd-radius-lg) var(--tsd-radius-lg) 0 0; }

  .tsd-context__key { min-width: 80px; }
}
