/* ─────────────────────────────────────────────────────────────
   Каталог роликов — desktop. По data/_disign/catalog-desktop.jsx.
   Токены — var(--*) из base.css. Карточки переиспользуют home.css
   (.h-card-916 / .h-card-169). Брейкпоинты: <768 мобайл,
   768-1023 компакт, 1024+ десктоп. Мобайл — отдельным заходом.
   ───────────────────────────────────────────────────────────── */

.catalog-page {
  display: block;          /* контейнер страницы; кнопка пагинации называется .catalog-pagenum (не .catalog-page!) во избежание коллизии */
  max-width: 1440px;
  width: 100%;
  box-sizing: border-box;
  margin: 0 auto;
  padding: 0 60px;
  font-family: 'Manrope', system-ui, sans-serif;
}

/* ── Hero ─────────────────────────────────────────────────────── */
.catalog-hero { padding: 32px 0 24px; }

.catalog-breadcrumb {
  display: flex; align-items: center; gap: 6px;
  font-size: 13px; font-weight: 500; color: var(--text-muted);
}
.catalog-breadcrumb a { color: var(--text-muted); text-decoration: none; }
.catalog-breadcrumb a:hover { color: var(--text); }
.catalog-breadcrumb svg { width: 12px; height: 12px; color: var(--text-dim); }
.catalog-breadcrumb-cur { color: var(--text); font-weight: 700; }

.catalog-hero-row {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 24px; margin-top: 12px;
}
.catalog-hero-l h1 {
  margin: 0; font-size: 44px; font-weight: 800;
  letter-spacing: -0.03em; color: var(--text); line-height: 1.05;
}
.catalog-hero-l p {
  margin: 10px 0 0; font-size: 15px; color: var(--text-muted); max-width: 540px;
}

/* Табы формата */
.catalog-format-tabs {
  display: flex; gap: 4px; padding: 4px; flex-shrink: 0;
  border-radius: 12px; background: var(--bg-elevated);
  border: 1px solid var(--divider);
}
.catalog-format-tab {
  height: 36px; padding: 0 14px; border: none; border-radius: 9px;
  background: transparent; color: var(--text-muted);
  font-size: 13px; font-weight: 700; cursor: pointer; font-family: inherit;
  white-space: nowrap; transition: color 0.18s, background 0.18s;
}
.catalog-format-tab.is-active {
  background: var(--card-solid); color: var(--text);
  box-shadow: 0 1px 3px rgba(0,0,0,0.06);
}

/* ── Layout: sidebar + main (двухколоночный grid) ─────────────────
   Именно grid, НЕ flex: глобальный ресет base.css задаёт
   main/aside/section { width: 100% }, и в flex это конфликтует с
   flex:1 (колонки расталкиваются). В grid width:100% на элементе =
   100% его трека — безвредно, колонки 280px / 1fr держатся жёстко. */
.catalog-layout {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  width: 100%;            /* растянуть на родителя; иначе grid схлопывался под min-content */
  gap: 32px;
  align-items: start;
  padding-bottom: 40px;
}

/* ── Sidebar ──────────────────────────────────────────────────── */
.catalog-sidebar {
  width: auto;                /* перебиваем base aside{width:100%} — ширину задаёт трек */
  background: var(--bg-elevated);
  border: 1px solid var(--divider);
  border-radius: 16px;
  padding: 4px 20px 16px;
  position: sticky; top: 88px;
}
.catalog-sidebar-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 0 0;
}
.catalog-sidebar-title { font-size: 16px; font-weight: 800; color: var(--text); letter-spacing: -0.01em; }
.catalog-sidebar-reset {
  background: none; border: none; cursor: pointer; padding: 0;
  font-size: 12px; color: var(--accent); font-weight: 700; font-family: inherit;
}

.catalog-fsec { padding: 20px 0; border-bottom: 1px solid var(--divider); }
.catalog-fsec:last-child { border-bottom: none; }
.catalog-fsec-title {
  font-size: 13px; font-weight: 800; color: var(--text);
  letter-spacing: 0.02em; text-transform: uppercase; margin-bottom: 14px;
}

/* Радио формата */
.catalog-radio-list { display: flex; flex-direction: column; gap: 8px; }
.catalog-radio {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; border-radius: 10px; cursor: pointer;
  border: 1px solid var(--divider); background: transparent;
  transition: background 0.18s, border-color 0.18s;
}
.catalog-radio input { position: absolute; opacity: 0; pointer-events: none; }
.catalog-radio-dot {
  width: 18px; height: 18px; border-radius: 50%;
  border: 1.5px solid var(--divider); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  transition: border-color 0.18s, background 0.18s;
}
.catalog-radio-label { font-size: 13px; font-weight: 600; color: var(--text); flex: 1; }
.catalog-radio-n { font-size: 11px; color: var(--text-muted); flex-shrink: 0; }
.catalog-radio.is-active { background: var(--accent-soft); border-color: var(--accent); }
.catalog-radio.is-active .catalog-radio-dot { border-color: var(--accent); background: var(--accent); }
.catalog-radio.is-active .catalog-radio-dot::after {
  content: ''; width: 6px; height: 6px; border-radius: 50%; background: #fff;
}
.catalog-radio.is-active .catalog-radio-label { color: var(--accent); }

/* Range slider длительности */
.catalog-range-vals {
  display: flex; justify-content: space-between;
  font-size: 12px; color: var(--text-muted);
  font-family: ui-monospace, Menlo, monospace; margin-bottom: 12px;
}
.catalog-range-track { position: relative; height: 6px; border-radius: 3px; background: var(--divider); }
.catalog-range-fill { position: absolute; top: 0; bottom: 0; background: var(--accent); border-radius: 3px; }
.catalog-range-track input[type="range"] {
  position: absolute; top: 50%; left: 0; width: 100%;
  transform: translateY(-50%); margin: 0;
  -webkit-appearance: none; appearance: none;
  background: transparent; pointer-events: none; height: 16px;
}
.catalog-range-track input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--card-solid); border: 2px solid var(--accent);
  cursor: pointer; pointer-events: auto;
}
.catalog-range-track input[type="range"]::-moz-range-thumb {
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--card-solid); border: 2px solid var(--accent);
  cursor: pointer; pointer-events: auto;
}
.catalog-range-ends {
  display: flex; justify-content: space-between; margin-top: 8px;
  font-size: 11px; color: var(--text-dim); font-family: ui-monospace, Menlo, monospace;
}

/* Чекбоксы жанров — список тянется по числу жанров, без внутреннего скролла */
.catalog-checks { display: flex; flex-direction: column; }
.catalog-check {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 0; cursor: pointer;
}
.catalog-check input { position: absolute; opacity: 0; pointer-events: none; }
.catalog-check-box {
  width: 18px; height: 18px; border-radius: 5px; flex-shrink: 0;
  border: 1.5px solid var(--divider); background: transparent;
  display: flex; align-items: center; justify-content: center;
  transition: border-color 0.18s, background 0.18s;
}
.catalog-check-box svg { width: 12px; height: 12px; color: #fff; opacity: 0; }
.catalog-check.is-active .catalog-check-box { border-color: var(--accent); background: var(--accent); }
.catalog-check.is-active .catalog-check-box svg { opacity: 1; }
.catalog-check-label { font-size: 13px; font-weight: 600; color: var(--text); flex: 1; }
.catalog-check-n { font-size: 11px; color: var(--text-muted); }

/* Поиск автора */
.catalog-author { position: relative; }
.catalog-author-field {
  height: 38px; border-radius: 9px; background: var(--bg);
  display: flex; align-items: center; gap: 8px; padding: 0 12px;
  border: 1px solid var(--divider);
}
.catalog-author-field svg { width: 14px; height: 14px; color: var(--text-dim); flex-shrink: 0; }
.catalog-author-field input {
  flex: 1; min-width: 0; border: none; background: transparent; outline: none;
  font-size: 13px; color: var(--text); font-family: inherit;
}
.catalog-author-clear {
  background: none; border: none; cursor: pointer; padding: 2px; display: flex;
  color: var(--text-dim);
}
.catalog-author-clear svg { width: 14px; height: 14px; }
.catalog-author-clear.is-hidden { display: none; }
.catalog-author-results {
  position: absolute; top: calc(100% + 6px); left: 0; right: 0; z-index: 20;
  background: var(--card-solid); border: 1px solid var(--divider);
  border-radius: 10px; box-shadow: 0 12px 32px rgba(0,0,0,0.16);
  overflow: hidden; display: none;
}
.catalog-author-results.is-open { display: block; }
.catalog-author-opt {
  display: flex; align-items: center; gap: 10px; width: 100%;
  padding: 9px 12px; border: none; background: transparent; cursor: pointer;
  font-family: inherit; text-align: left;
}
.catalog-author-opt:hover { background: var(--accent-soft); }
.catalog-author-opt-av {
  width: 28px; height: 28px; border-radius: 50%; flex-shrink: 0;
  background: var(--card) center/cover no-repeat; border: 1px solid var(--divider);
}
.catalog-author-opt-name { font-size: 13px; font-weight: 700; color: var(--text); flex: 1; }
.catalog-author-opt-n { font-size: 11px; color: var(--text-muted); }

/* ── Main ─────────────────────────────────────────────────────── */
.catalog-main { min-width: 0; }   /* grid-элемент; min-width:0 — чтобы сетка не распирала колонку */

/* Toolbar */
.catalog-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: 24px; border-bottom: 1px solid var(--divider); margin-bottom: 24px;
}
.catalog-count { display: flex; align-items: baseline; gap: 8px; }
.catalog-count-n { font-size: 15px; font-weight: 700; color: var(--text); }
.catalog-count-upd { font-size: 13px; color: var(--text-muted); }
.catalog-toolbar-right { display: flex; align-items: center; gap: 14px; }

.catalog-sort { position: relative; }
.catalog-sort-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 14px; border-radius: 10px;
  background: var(--bg-elevated); border: 1px solid var(--divider);
  font-size: 13px; font-weight: 700; color: var(--text); cursor: pointer; font-family: inherit;
}
.catalog-sort-btn svg { width: 14px; height: 14px; }
.catalog-sort-chev { color: var(--text-muted); }
.catalog-sort-menu {
  position: absolute; top: calc(100% + 6px); right: 0; z-index: 20; min-width: 200px;
  background: var(--card-solid); border: 1px solid var(--divider);
  border-radius: 10px; box-shadow: 0 12px 32px rgba(0,0,0,0.16);
  padding: 6px; display: none;
}
.catalog-sort-menu.is-open { display: block; }
.catalog-sort-opt {
  display: block; width: 100%; text-align: left;
  padding: 9px 12px; border: none; background: transparent; cursor: pointer;
  font-size: 13px; font-weight: 600; color: var(--text); font-family: inherit; border-radius: 7px;
}
.catalog-sort-opt:hover { background: var(--accent-soft); }
.catalog-sort-opt.is-active { color: var(--accent); font-weight: 800; }

/* Активные фильтры */
.catalog-active {
  display: flex; gap: 8px; flex-wrap: wrap; align-items: center; margin-bottom: 24px;
}
.catalog-active-label {
  font-size: 12px; font-weight: 700; color: var(--text-muted);
  margin-right: 4px; text-transform: uppercase; letter-spacing: 0.04em;
}
.catalog-chip {
  display: flex; align-items: center; gap: 8px;
  height: 30px; padding: 0 6px 0 12px; border-radius: 999px; border: none;
  background: var(--accent-soft); color: var(--accent);
  font-size: 12px; font-weight: 700; cursor: pointer; font-family: inherit;
}
.catalog-chip-x {
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--accent); color: #fff;
  display: flex; align-items: center; justify-content: center;
}
.catalog-chip-x svg { width: 10px; height: 10px; }
.catalog-reset-all {
  background: none; border: none; cursor: pointer; font-family: inherit;
  font-size: 12px; font-weight: 700; color: var(--text-muted);
  text-decoration: underline; text-underline-offset: 3px; margin-left: 6px;
}

/* Секции + сетки */
.catalog-sec + .catalog-sec { margin-top: 56px; }
.catalog-sec-title {
  font-size: 13px; font-weight: 800; color: var(--text-muted);
  letter-spacing: 0.04em; text-transform: uppercase; margin-bottom: 18px;
}
.catalog-grid { display: grid; gap: 24px; }
/* minmax(0,1fr), НЕ 1fr: иначе min-track = min-content карточки и сетка распирает main */
.catalog-grid-916 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.catalog-grid-169 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
/* Карточки в гриде занимают всю ячейку (в карусели ширину задавал слот).
   Hover-оживление карточек берётся из home.css (.h-card-*:hover) — работает. */
.catalog-grid .h-card-916,
.catalog-grid .h-card-169 { width: 100%; }

/* Пустое состояние */
.catalog-empty { text-align: center; padding: 80px 20px; color: var(--text-muted); }
.catalog-empty svg { width: 40px; height: 40px; color: var(--text-dim); margin-bottom: 16px; }
.catalog-empty-title { font-size: 18px; font-weight: 800; color: var(--text); margin-bottom: 6px; }
.catalog-empty-sub { font-size: 14px; color: var(--text-muted); }

/* Пагинация */
.catalog-pagination {
  display: flex; align-items: center; justify-content: center; gap: 6px; padding-top: 40px;
}
.catalog-pagenum, .catalog-page-arrow {
  min-width: 36px; height: 36px; padding: 0 12px; border-radius: 9px;
  border: 1px solid var(--divider); background: transparent; color: var(--text);
  font-size: 13px; font-weight: 700; cursor: pointer; font-family: inherit;
  display: inline-flex; align-items: center; justify-content: center; text-decoration: none;
}
.catalog-pagenum:hover, .catalog-page-arrow:hover { border-color: var(--accent); }
.catalog-pagenum.is-active { background: var(--text); color: var(--bg); border-color: var(--text); }
.catalog-page-arrow { padding: 0; width: 36px; }
.catalog-page-arrow svg { width: 14px; height: 14px; }
.catalog-page-arrow.is-disabled { opacity: 0.4; pointer-events: none; }
.catalog-page-dots { color: var(--text-muted); padding: 0 6px; }
.catalog-loading { opacity: 0.5; pointer-events: none; transition: opacity 0.18s; }

/* ── Интерактивный отклик новых контролов (hover/focus) ───────────
   Новые элементы каталога не имели :hover-состояний и казались «мёртвыми»
   на фоне остального сайта. Добавляем плавную обратную связь (0.18s). */

/* Табы формата (hero) */
.catalog-format-tab:not(.is-active):hover { color: var(--text); background: var(--accent-soft); }

/* Радио формата + чекбоксы жанров (сайдбар) */
.catalog-radio:not(.is-active):hover { border-color: var(--accent); background: var(--accent-soft); }
.catalog-check-label { transition: color 0.18s ease; }
.catalog-check:hover .catalog-check-box { border-color: var(--accent); }
.catalog-check:hover .catalog-check-label { color: var(--accent); }

/* Текстовые кнопки «Сбросить» / очистка автора */
.catalog-sidebar-reset, .catalog-reset-all, .catalog-author-clear { transition: color 0.18s ease, opacity 0.18s ease; }
.catalog-sidebar-reset:hover, .catalog-reset-all:hover { opacity: 0.7; }
.catalog-author-clear:hover { color: var(--text); }

/* Кнопка сортировки + поле автора (фокус) */
.catalog-sort-btn { transition: border-color 0.18s ease, background 0.18s ease; }
.catalog-sort-btn:hover { border-color: var(--accent); }
.catalog-author-field { transition: border-color 0.18s ease; }
.catalog-author-field:focus-within { border-color: var(--accent); }

/* Активные чипы фильтров — подсветка «будет удалён» при наведении */
.catalog-chip { transition: background 0.18s ease, color 0.18s ease; }
.catalog-chip:hover { background: var(--accent); color: #fff; }
.catalog-chip:hover .catalog-chip-x { background: #fff; color: var(--accent); }

/* Пагинация — плавность hover (само правило hover уже есть выше) */
.catalog-pagenum, .catalog-page-arrow { transition: border-color 0.18s ease, background 0.18s ease, color 0.18s ease; }

/* Мобильный топ-блок скрыт на десктопе (показывается ≤1023). */
.catalog-mtop { display: none; }

/* ── Bottom-sheet фильтров (мобайл). Невидим/инертен по умолчанию,
   выезжает снизу при .is-open. На десктопе не открывается. ── */
.catalog-sheet {
  position: fixed; inset: 0; z-index: 200;
  visibility: hidden; opacity: 0;
  transition: opacity 0.2s ease, visibility 0.2s ease;
}
.catalog-sheet.is-open { visibility: visible; opacity: 1; }
.catalog-sheet-overlay { position: absolute; inset: 0; background: rgba(0,0,0,0.45); }
.catalog-sheet-panel {
  position: absolute; left: 0; right: 0; bottom: 0;
  max-height: 86%; display: flex; flex-direction: column;
  background: var(--bg); border-radius: 20px 20px 0 0;
  padding: 10px 0 calc(20px + env(safe-area-inset-bottom, 0px));
  transform: translateY(100%); transition: transform 0.26s cubic-bezier(.32,.72,0,1);
}
.catalog-sheet.is-open .catalog-sheet-panel { transform: translateY(0); }
.catalog-sheet-handle { width: 36px; height: 4px; border-radius: 2px; background: var(--divider); margin: 4px auto 12px; }
.catalog-sheet-head { display: flex; align-items: center; justify-content: space-between; padding: 0 20px 14px; }
.catalog-sheet-title { font-size: 19px; font-weight: 800; color: var(--text); letter-spacing: -0.01em; }
.catalog-sheet-close { background: none; border: none; cursor: pointer; padding: 4px; display: flex; color: var(--text); }
.catalog-sheet-close svg { width: 20px; height: 20px; }
.catalog-sheet-body { overflow-y: auto; flex: 1; padding: 0 20px; -webkit-overflow-scrolling: touch; }
.catalog-sheet-sec { margin-bottom: 22px; }
.catalog-sheet-sectitle { font-size: 14px; font-weight: 700; color: var(--text); margin-bottom: 12px; }
.catalog-sheet-footer { display: flex; gap: 10px; padding: 14px 20px 0; border-top: 1px solid var(--divider); }
.catalog-sheet-reset {
  flex: 1; padding: 14px 0; border-radius: 12px; cursor: pointer; font-family: inherit;
  background: transparent; border: 1px solid var(--divider); color: var(--text); font-size: 14px; font-weight: 700;
}
.catalog-sheet-apply {
  flex: 2; padding: 14px 0; border-radius: 12px; cursor: pointer; font-family: inherit;
  background: var(--accent); border: none; color: #fff; font-size: 14px; font-weight: 700;
}
/* Цена free/paid */
.catalog-price-toggle { display: flex; gap: 10px; }
.catalog-price-btn {
  flex: 1; padding: 11px 0; border-radius: 10px; cursor: pointer; font-family: inherit;
  background: transparent; border: 1px solid var(--divider); color: var(--text);
  font-size: 13px; font-weight: 700; transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}
.catalog-price-btn:hover { border-color: var(--accent); }
.catalog-price-btn.is-active { background: var(--accent-soft); border-color: var(--accent); color: var(--accent); }
/* Сортировка-radio в шите */
.catalog-sheet-sorts { display: flex; flex-direction: column; gap: 8px; }
.catalog-sheet-sort {
  display: flex; align-items: center; justify-content: space-between;
  padding: 11px 14px; border-radius: 10px; cursor: pointer; font-family: inherit; text-align: left;
  background: transparent; border: 1px solid var(--divider); color: var(--text);
  font-size: 13px; font-weight: 500; transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}
.catalog-sheet-sort svg { width: 16px; height: 16px; opacity: 0; }
.catalog-sheet-sort.is-active { background: var(--accent-soft); border-color: var(--accent); color: var(--accent); font-weight: 700; }
.catalog-sheet-sort.is-active svg { opacity: 1; }

/* ── Адаптив: десктоп-сжатие 1024–1100 ───────────────────────── */
@media (max-width: 1100px) and (min-width: 1024px) {
  .catalog-grid-916 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .catalog-grid-169 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* Узкий десктоп 1024–1200: те же боковые поля, что и на странице видео
   (.video-page → 24px), чтобы ширина контента совпадала. */
@media (max-width: 1200px) and (min-width: 1024px) {
  .catalog-page { padding-left: 24px; padding-right: 24px; }
}

/* ── МОБАЙЛ / ПЛАНШЕТ ≤1023 ───────────────────────────────────── */
@media (max-width: 1023px) {
  .catalog-page { padding: 0; }
  /* Десктопные хром-элементы скрываем */
  .catalog-hero { display: none; }
  .catalog-sidebar { display: none; }
  .catalog-toolbar { display: none; }   /* счётчик/сортировка — в мобильном топ-блоке */
  .catalog-layout { display: block; }     /* одна колонка */
  .catalog-main { padding: 0 16px; }

  /* Мобильный топ-блок */
  .catalog-mtop { display: block; padding: 8px 16px 4px; }
  .catalog-mtop-titlerow { display: flex; align-items: flex-end; justify-content: space-between; padding-bottom: 14px; }
  .catalog-mtitle { margin: 0; font-size: 26px; font-weight: 800; letter-spacing: -0.02em; color: var(--text); }
  .catalog-mcount { font-size: 12px; color: var(--text-muted); margin-top: 4px; }
  .catalog-mfilters {
    position: relative; flex-shrink: 0; display: flex; align-items: center; gap: 6px;
    padding: 8px 12px; border-radius: 10px; cursor: pointer; font-family: inherit;
    background: transparent; border: 1px solid var(--divider); color: var(--text); font-size: 13px; font-weight: 700;
  }
  .catalog-mfilters svg { width: 16px; height: 16px; }
  .catalog-mfilters-badge {
    position: absolute; top: -6px; right: -6px; min-width: 18px; height: 18px; padding: 0 5px;
    border-radius: 9px; background: var(--accent); color: #fff; font-size: 10px; font-weight: 800;
    display: flex; align-items: center; justify-content: center;
  }
  /* Поиск */
  .catalog-msearch {
    display: flex; align-items: center; gap: 10px; height: 44px; padding: 0 14px; margin-bottom: 14px;
    border-radius: 12px; background: var(--bg-elevated); border: 1px solid var(--divider);
  }
  .catalog-msearch svg { width: 18px; height: 18px; color: var(--text-dim); flex-shrink: 0; }
  .catalog-msearch input { flex: 1; min-width: 0; border: none; background: transparent; outline: none; font-size: 14px; color: var(--text); font-family: inherit; }
  /* Чипы жанров */
  .catalog-mchips {
    display: flex; gap: 8px; overflow-x: auto; overflow-y: hidden; margin-bottom: 14px;
    padding-bottom: 2px; scrollbar-width: none;
  }
  .catalog-mchips::-webkit-scrollbar { display: none; }
  .catalog-mchip {
    flex-shrink: 0; height: 34px; padding: 0 14px; border-radius: 999px; cursor: pointer; font-family: inherit;
    background: var(--chip-bg); border: 1px solid var(--chip-border); color: var(--text);
    font-size: 13px; font-weight: 600; white-space: nowrap; transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease;
  }
  .catalog-mchip.is-active { background: var(--chip-active-bg); color: var(--chip-active-fg); border-color: transparent; }
  /* Тоггл формата */
  .catalog-mformat {
    display: flex; gap: 4px; padding: 4px; margin-bottom: 14px;
    border-radius: 12px; background: var(--bg-elevated); border: 1px solid var(--divider);
  }
  .catalog-mformat-btn {
    flex: 1; height: 34px; border: none; border-radius: 9px; cursor: pointer; font-family: inherit;
    background: transparent; color: var(--text-muted); font-size: 12px; font-weight: 700;
    transition: background 0.18s ease, color 0.18s ease;
  }
  .catalog-mformat-btn.is-active { background: var(--card-solid); color: var(--text); box-shadow: 0 1px 3px rgba(0,0,0,0.06); }
  /* Строка сортировки */
  .catalog-msort {
    width: 100%; display: flex; align-items: center; justify-content: space-between;
    padding: 0 0 14px; background: none; border: none; cursor: pointer; font-family: inherit;
  }
  .catalog-msort-l { display: flex; align-items: center; gap: 6px; color: var(--text-muted); font-size: 12px; font-weight: 600; }
  .catalog-msort-l svg { width: 14px; height: 14px; }
  .catalog-msort-r { display: flex; align-items: center; gap: 4px; color: var(--text); font-size: 13px; font-weight: 700; }
  .catalog-msort-r svg { width: 14px; height: 14px; }

  /* Сетка: вертикальные 2 колонки, горизонтальные 1 колонка */
  .catalog-sec + .catalog-sec { margin-top: 28px; }
  .catalog-grid { gap: 12px; }
  .catalog-grid-916 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .catalog-grid-169 { grid-template-columns: 1fr; }
  .catalog-active { padding: 0 0 14px; }
  .catalog-pagination { padding-top: 24px; }
}

/* Планшет (≈iPad, 768–1023): телефонный диапазон ≤1023 даёт мало колонок
   (вертикальные 2, горизонтальные 1) → карточки гигантские. На планшете
   возвращаем разумную плотность: вертикальные 3 кол., горизонтальные 2 кол.
   (как в тире 1024–1100). Идёт ПОСЛЕ блока ≤1023 → перебивает только 768–1023;
   <768 (телефон) и десктоп не затрагиваются. */
@media (min-width: 768px) and (max-width: 1023px) {
  .catalog-grid { gap: 16px; }
  .catalog-grid-916 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .catalog-grid-169 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* ── Блок «Теги» в боковом фильтре ──────────────────────────────── */
.catalog-tagsearch {
  height: 38px; border-radius: 9px; background: var(--bg);
  display: flex; align-items: center; gap: 8px; padding: 0 12px;
  border: 1px solid var(--divider); margin-bottom: 12px;
  transition: border-color 0.18s ease;
}
.catalog-tagsearch:focus-within { border-color: var(--accent); }
.catalog-tagsearch svg { width: 14px; height: 14px; color: var(--text-dim); flex-shrink: 0; }
.catalog-tagsearch input {
  flex: 1; min-width: 0; border: none; background: transparent; outline: none;
  font-size: 13px; color: var(--text); font-family: inherit;
}
.catalog-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.catalog-tag-chip {
  display: inline-flex; align-items: center; height: 30px; padding: 0 12px;
  border-radius: 999px; border: 1px solid var(--divider); background: var(--bg);
  color: var(--text-muted); font-size: 13px; font-weight: 600; font-family: inherit;
  cursor: pointer; transition: border-color 0.18s ease, background 0.18s ease, color 0.18s ease;
}
.catalog-tag-chip:hover { border-color: var(--accent); background: var(--accent-soft); color: var(--accent); }
.catalog-tag-chip.is-active {
  border-color: var(--accent); background: var(--accent); color: #fff;
}
