/* =============================================================
 * membranes.css — стили только для /gallery/membranes.
 * Поверх catalog.css (page-hero, cta-block).
 *
 * Совместимость с membranes.js: классы .membrane-item, .groupCheckbox,
 * .collectionCheckbox, .btn-dark, .d-none и id #search-input/#button-search/
 * #manufacturerSelect сохранены — JS не трогаем.
 * ============================================================= */

.memb-page { padding-top: var(--sp-6); }

/* ──────── LAYOUT: на десктопе sidebar 280 + контент, на мобиле — стопка ──────── */
.memb-layout {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--sp-6);
  align-items: start;
}
/* Дети grid по умолчанию имеют min-width:auto и расширяются
   по естественному размеру содержимого. Без явного min-width:0
   .memb-content расходится на 3+ карточки и улетает за viewport
   на мобильной (ширина 486px при экране 390px). */
.memb-layout > * { min-width: 0; }
.memb-content { overflow: hidden; }   /* страховка от overflow-x на узких карточек */

@media (max-width: 992px) {
  .memb-layout { grid-template-columns: 1fr; gap: var(--sp-5); }
}

/* ──────── ОБЁРТКА ФИЛЬТРОВ (<details> для мобильного раскрытия) ──────── */
.memb-filters-wrap {
  background: var(--color-white);
  border: 1px solid var(--color-grey-200);
  border-radius: var(--radius-md);
}
.memb-filters-wrap__toggle {
  display: none;                              /* на десктопе скрыт — фильтры всегда видны */
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-4) var(--sp-5);
  font-weight: var(--fw-medium);
  font-size: var(--fs-base);
  cursor: pointer;
  list-style: none;
}
.memb-filters-wrap__toggle::-webkit-details-marker { display: none; }
.memb-filters-wrap__count {
  margin-left: auto;
  background: var(--color-grey-150);
  padding: 2px 10px;
  border-radius: var(--radius-full);
  font-size: var(--fs-sm);
  color: var(--color-text-secondary);
}
.memb-filters-wrap__toggle::after {
  content: "";
  width: 8px; height: 8px;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: rotate(45deg);
  transition: transform var(--duration-fast) var(--ease-out);
  opacity: 0.7;
}
.memb-filters-wrap[open] .memb-filters-wrap__toggle::after { transform: rotate(225deg); }

/* ──────── ФИЛЬТРЫ ──────── */
.memb-filters {
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
  padding: var(--sp-5);
  position: sticky;
  top: var(--sp-4);
}
@media (max-width: 992px) {
  .memb-filters { position: static; padding-top: 0; }
}

/* поиск */
.memb-search {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  background: var(--color-white);
  border: 1.5px solid var(--color-grey-300);
  border-radius: var(--radius-full);
  color: var(--color-text-secondary);
  transition: border-color var(--duration-fast) var(--ease-out),
              box-shadow var(--duration-fast) var(--ease-out);
}
.memb-search:hover { border-color: var(--color-grey-650); }
.memb-search:focus-within {
  border-color: var(--color-text);
  color: var(--color-text);
  box-shadow: 0 0 0 4px rgba(20, 18, 16, 0.08);
}
.memb-search input {
  border: 0; outline: 0; background: transparent;
  font-size: var(--fs-base); font-weight: var(--fw-medium);
  width: 100%; color: var(--color-text);
  caret-color: var(--color-accent);
  padding: 2px 0;
}
.memb-search input::placeholder { color: var(--color-text-secondary); font-weight: var(--fw-regular); opacity: 0.85; }
.memb-search:focus-within input::placeholder { opacity: 0.55; }
/* Стрелка-кнопка спрятана визуально (выглядит лишней). membranes.js всё ещё
   триггерит #button-search при Enter — поиск работает как раньше. */
.memb-search__btn { display: none; }

/* группа фильтра */
.memb-fgroup { display: flex; flex-direction: column; gap: var(--sp-2); }
.memb-fgroup__label {
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: var(--fw-semibold);
  color: var(--color-text-secondary);
}

/* select производителя */
.memb-select {
  width: 100%;
  padding: 8px 12px;
  font-size: var(--fs-sm);
  background: var(--color-white);
  border: 1px solid var(--color-grey-300);
  border-radius: var(--radius-sm);
  color: var(--color-text);
  cursor: pointer;
}
.memb-select:focus { outline: none; border-color: var(--color-text); }

/* чекбоксы категорий */
.memb-checks { display: flex; flex-direction: column; gap: 4px; }
.memb-check {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 8px 10px;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-size: var(--fs-sm);
  transition: background var(--duration-fast) var(--ease-out);
}
.memb-check:hover { background: var(--color-grey-150); }
.memb-check input {
  margin: 0; width: 16px; height: 16px;
  accent-color: var(--color-accent); cursor: pointer;
}
.memb-check__name { color: var(--color-text); line-height: 1.3; }
.memb-check__count { color: var(--color-text-secondary); font-size: var(--fs-xs); }

/* ──────── КОЛЛЕКЦИИ — компактный список-строки ──────── *
 * Раньше были pills с border-radius:full — длинные имена
 * («Матовые однотонные софты. Soft touch sweet feelings.») ломали ритм.
 * Стало: каждая коллекция — одна строка фикс. высоты, имя обрезается
 * ellipsis, счётчик прижат к правому краю, активная — accent-полоса слева.
 * Классы .btn-check/.btn-dark/.collectionCheckbox сохранены — membranes.js жив. */

.memb-pills {
  display: flex;
  flex-direction: column;        /* было flex-wrap row */
  gap: 6px;                      /* было 2 — на случай длинных имён даём воздух */
  max-height: 380px;             /* при большом числе коллекций — скролл */
  overflow-y: auto;
  padding-right: 2px;
  margin-right: -2px;            /* визуально компенсируем scrollbar */
  /* мягкий скроллбар */
  scrollbar-width: thin;
  scrollbar-color: var(--color-grey-300) transparent;
}
.memb-pills::-webkit-scrollbar { width: 6px; }
.memb-pills::-webkit-scrollbar-thumb { background: var(--color-grey-300); border-radius: 3px; }
.memb-pills::-webkit-scrollbar-thumb:hover { background: var(--color-grey-650); }

.btn-check { position: absolute; opacity: 0; pointer-events: none; }

/* строка коллекции */
.memb-pill {
  position: relative;
  display: grid;
  grid-template-columns: 1fr auto;
  /* align-items: start — длинное имя растёт вниз, счётчик прижат к 1-й строке */
  align-items: start;
  gap: 10px;
  /* Родитель .memb-pills — flex-column с max-height: 360px.
     Flex-items по default сжимаются (flex-shrink:1) к min-content,
     из-за чего длинный текст обрезался по 32px. Запрещаем сжатие. */
  flex-shrink: 0;
  height: auto;
  min-height: 32px;
  padding: 7px 12px 7px 14px;
  background: transparent;
  border: 0;
  border-radius: var(--radius-sm);
  font-size: var(--fs-sm);
  line-height: 1.35;
  color: var(--color-text);
  cursor: pointer;
  transition: background var(--duration-fast) var(--ease-out),
              color var(--duration-fast) var(--ease-out);
  text-decoration: none;
}
/* имя — может переноситься на 2-3 строки, ellipsis на 4-й.
   min-width:0 КРИТИЧНО для grid-item иначе текст не переносится. */
.memb-pill__name {
  min-width: 0;
  white-space: normal;
  overflow-wrap: anywhere;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
/* счётчик */
.memb-pill__count {
  color: var(--color-text-secondary);
  font-size: var(--fs-xs);
  font-variant-numeric: tabular-nums;
  min-width: 28px;
  text-align: right;
  white-space: nowrap;
  margin-top: 2px;
}
.memb-pill__count::before { content: "· "; }    /* унифицированный разделитель */

.memb-pill:hover { background: var(--color-grey-150); }

/* активная коллекция: акцент-полоса слева + bold, без чёрного фона */
.btn-check:checked + .memb-pill,
.memb-pill.btn-dark {
  background: var(--color-grey-150);
  color: var(--color-text);
  font-weight: var(--fw-semibold);
}
.btn-check:checked + .memb-pill::before,
.memb-pill.btn-dark::before {
  content: "";
  position: absolute;
  left: 4px;
  top: 50%;
  transform: translateY(-50%);
  width: 3px;
  height: 18px;
  background: var(--color-accent);
  border-radius: 2px;
}
.btn-check:checked + .memb-pill span,
.memb-pill.btn-dark span {
  color: var(--color-text);
  font-weight: var(--fw-medium);
}
.btn-check:focus-visible + .memb-pill {
  outline: none;
  background: var(--color-grey-150);
  box-shadow: 0 0 0 2px rgba(20, 18, 16, 0.15);
}

/* «Все · 1329» (первая строка) — визуально выделена как «Reset» */
.memb-pills > label:first-of-type {
  margin-bottom: 4px;
  border-bottom: 1px solid var(--color-grey-200);
  border-radius: 0;
  padding-bottom: 8px;
}

/* ──────── ГРУППА (заголовок секции) ──────── */
.memb-group { margin-bottom: var(--sp-8); }
.memb-group:first-child { margin-top: 0; }

.memb-group__head {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--sp-4);
  align-items: end;
  padding-bottom: var(--sp-4);
  margin-bottom: var(--sp-5);
  border-bottom: 1px solid var(--color-grey-200);
}
.memb-group__num {
  font-family: ui-monospace, "SF Mono", monospace;
  font-size: 48px;
  line-height: 0.9;
  font-weight: 300;
  color: var(--color-grey-300);
  letter-spacing: -0.02em;
}
.memb-group__title {
  font-size: var(--fs-2xl);
  font-weight: var(--fw-medium);
  margin: 0;
  letter-spacing: -0.015em;
}
.memb-group__sub {
  font-size: var(--fs-sm); color: var(--color-text-secondary); margin: 4px 0 0;
}

/* ──────── СЕТКА КАРТОЧЕК ──────── */
.memb-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: var(--sp-4);
}
@media (max-width: 768px) {
  .memb-grid { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: var(--sp-3); }
  .memb-group__num { font-size: 36px; }
}

.memb-card {
  background: var(--color-white);
  border: 1px solid var(--color-grey-200);
  border-radius: var(--radius-md);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: border-color var(--duration-fast) var(--ease-out),
              transform var(--duration-fast) var(--ease-out),
              box-shadow var(--duration-fast) var(--ease-out);
}
@media (hover: hover) {
  .memb-card:hover {
    border-color: var(--color-grey-300);
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(20, 18, 16, 0.08);
  }
}
/* «Нет в наличии»: приглушаем только фото, текст читаемый (WCAG AA). */
.memb-card.is-out .memb-card__media { opacity: 0.4; filter: grayscale(0.5); }
.memb-card.is-out .memb-card__name { color: var(--color-text-secondary); }
.memb-card.d-none { display: none; }       /* совместимость с membranes.js */

.memb-card__media {
  display: block;
  aspect-ratio: 1 / 1;                     /* плёнки — квадратные образцы */
  background: var(--color-grey-150);
  overflow: hidden;
}
.memb-card__media img {
  width: 100%; height: 100%;
  object-fit: cover; display: block;
  transition: transform var(--duration-normal) var(--ease-out);
}
@media (hover: hover) {
  .memb-card:hover .memb-card__media img { transform: scale(1.05); }
}

.memb-card__body {
  padding: var(--sp-3);
  display: flex; flex-direction: column; gap: 6px;
  border-top: 1px solid var(--color-grey-150);
  min-height: 78px;
}
.memb-card__name {
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  margin: 0;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.memb-card__meta { display: flex; flex-wrap: wrap; gap: 4px; margin-top: auto; }
.memb-card__cat {
  font-size: var(--fs-xs); color: var(--color-text-secondary);
  margin: 0; line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* tag (унифицированный) */
.memb-tag {
  display: inline-flex; align-items: center;
  padding: 2px 7px;
  background: var(--color-white);
  border: 1px solid var(--color-grey-300);
  border-radius: var(--radius-sm);
  font-size: 11px; font-weight: var(--fw-medium);
  color: var(--color-text); letter-spacing: 0.02em;
  white-space: nowrap;
}
.memb-tag--out {
  background: rgba(220,52,31,0.10);
  border-color: rgba(220,52,31,0.35);
  color: #a32414;
}

/* ──────── МОБИЛЬНАЯ ВЕРСИЯ ──────── */
@media (max-width: 992px) {
  .memb-filters-wrap__toggle { display: flex; }     /* показываем кнопку сворачивания */
  .memb-filters { padding-top: 0; }
  /* по умолчанию <details open> — пользователь может закрыть */
}
