/* ─── Catalog Filters (icon buttons) ─── */
/* Горизонтальная полоса фильтров над сеткой товаров.
   Прокрутка по горизонтали — на случай большого числа кастомных
   плашек: без неё items вылезали за пределы вьюпорта и ломали
   layout страницы (горизонтальный скролл всего body).
   Скроллбар спрятан (паттерн как у .chips--scroll), но swipe и
   inertial scroll сохранены. */
.catalog-filters {
  /* --_gap вынесен в кастомное свойство, чтобы стрелки-перемотки
     могли использовать его в negative-margin'е (см. ниже). */
  --_gap: var(--sp-8);

  position: relative;

  display: flex;
  align-items: center;
  gap: var(--_gap);
  border-radius: var(--radius-sm);

  /* Главный фикс: ограничиваем строку шириной контейнера и
     включаем горизонтальный скролл. Без этого добавление
     кастомных плашек ломало всю страницу. */
  max-width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  flex-wrap: nowrap;
  -webkit-overflow-scrolling: touch;

  /* Скрываем нативный scrollbar (Firefox / Edge / WebKit). */
  scrollbar-width: none !important;
  -ms-overflow-style: none !important;
  scrollbar-color: transparent transparent;
}

.catalog-filters::-webkit-scrollbar,
.catalog-filters::-webkit-scrollbar-thumb,
.catalog-filters::-webkit-scrollbar-track,
.catalog-filters::-webkit-scrollbar-corner,
.catalog-filters::-webkit-scrollbar-button {
  width: 0 !important;
  height: 0 !important;
  display: none !important;
  background: transparent !important;
}

.catalog-filters__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: var(--radius-sm);
  background: var(--color-gray-light);
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
  flex-shrink: 0;
}

.catalog-filters__btn:hover {
  border-color: var(--color-black);
}

.catalog-filters__btn:active {
  background: var(--color-gray-light);
}

.catalog-filters__btn img {
  pointer-events: none;
}

.catalog-filters__btn--text {
  width: auto;
}

.catalog-filters__btn--text span {
  margin-left: 12px;
  font-size: var(--fs-md);
  font-weight: var(--fw-medium);
  line-height: 0.875;
  color: var(--color-black);
}

.catalog-filters__btn--text img {
  width: 36px;
  height: 36px;
}

/* ── Custom quick-filter chips (admin: CatalogQuickFilter) ──
   Геометрия по спецификации:
     • Фото: ширина 48px, на ВСЮ высоту плашки, прижата к левому краю
       без отступов; рамка скруглена вместе с самой плашкой.
     • После фото — 12px отступ до текста.
     • После текста — 12px отступ до правого края плашки.
     • Если фото нет — текст с отступом 12px слева и 12px справа.
   КРИТИЧНО: width: auto + flex-shrink: 0 — иначе flex-родитель
   сжимает плашку до 44px (наследие width: 44px от базовой
   .catalog-filters__btn — это размер icon-only-кнопки). */
.catalog-filters__btn--quick {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0;
  padding: 0;
  width: auto;
  min-width: 0;
  max-width: none;
  height: 44px;
  flex: 0 0 auto;
  flex-shrink: 0;
  overflow: hidden; /* фото обрезается скруглением плашки */
  border-radius: var(--radius-sm);
}

.catalog-filters__btn--quick img {
  position: relative;
  z-index: 2;
  width: 48px;
  height: 100%;
  flex: 0 0 48px;
  object-fit: cover;
  border-radius: 0;
  display: block;
}

.catalog-filters__btn--quick span {
  position: relative;
  z-index: 2;
  margin: 0 12px;
  font-size: var(--fs-md);
  font-weight: var(--fw-medium);
  line-height: var(--leading-none);
  white-space: nowrap;
  pointer-events: none;
}

/* Активная плашка: внутренняя обводка цветом текста, который владелец
   задал в админке. currentColor читает цвет шрифта (style="color: …"
   из шаблона). Рамку рисуем через ::after-pseudo на z-index: 1,
   а фото и текст «всплывают» над ней на z-index: 2 — рамка остаётся
   видимой только по периметру плашки и НЕ перекрывает картинку
   (картинка занимает левые 48px и закрывает там кусок рамки —
   визуально получается U-образная обводка вокруг текстовой части). */
.catalog-filters__btn--quick.is-active::after {
  content: '';
  position: absolute;
  inset: 0;
  border: 2px solid currentColor;
  border-radius: inherit;
  pointer-events: none;
  z-index: 1;
}

/* ─── Scroll arrows for the filter strip ─────────────────────────────────
   Появляются только когда плашки физически не влезают по ширине
   (видимость управляется через --visible классом из JS-хелпера
   ``createHorizontalScroller`` — он же отслеживает resize и scrollLeft).
   Внешний вид — копия .rose-scroll__arrow / .addon-scroll__arrow (тот
   же фон/blur/тень). Размер 44×44 (= высоте плашки, 1:1),
   border-radius: 50% — круглая кнопка, как в карусели сортов роз. */
.catalog-filters__arrow {
  position: sticky;

  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;

  width: 44px;
  height: 44px;

  background: rgba(255, 255, 255, 0.86);
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
  box-shadow: 0px 4px 16px 0px rgba(0, 0, 0, 0.12);

  border: none;
  border-radius: 50%;

  z-index: 3;
  opacity: 0;
  cursor: pointer;
  pointer-events: none;
  transition: opacity 0.25s ease;
}

.catalog-filters__arrow img {
  width: 20px;
  height: 20px;
  pointer-events: none;
}

.catalog-filters__arrow--prev {
  left: 0;
  /* Перекрываем следующий item на свой размер + gap, чтобы стрелка
     прилипала к левому краю, а scroll-content прокручивался под ней. */
  margin-right: calc(-44px - var(--_gap));
  order: -1;
}

.catalog-filters__arrow--next {
  right: 0;
  margin-left: calc(-44px - var(--_gap));
}

.catalog-filters__arrow--visible {
  opacity: 1;
  pointer-events: auto;
}

/* ─── Filter slider (pages) ─── */
.fslider {
  overflow: hidden;
}

.fslider__track {
  display: flex;
  width: 200%;
  transition: transform 0.3s cubic-bezier(0.32, 0.72, 0, 1);
}

.fslider__track--sub {
  transform: translateX(-50%);
}

.fslider__page {
  width: 50%;
  min-width: 0;
  height: fit-content;
  flex-shrink: 0;
  padding: 0 var(--sp-12);
  padding-bottom: var(--sp-12);
  box-sizing: border-box;
}

/* ─── Filter item (main page row) ─── */
.fitem {
  display: flex;
  align-items: center;
  gap: var(--sp-8);

  width: 100%;
  height: 48px;
  
  border-bottom: 1px solid var(--color-gray-divider);
  background: none;
  cursor: pointer;
}

.fitem:last-child {
  border-bottom: none;
}

.fitem--static {
  flex-direction: column;
  align-items: stretch;
  gap: var(--sp-14);

  height: auto;
  padding: var(--sp-12) 0;

  cursor: default;
}


.fitem__label {
  margin-bottom: -3px;
  font-size: var(--fs-md);
  font-weight: var(--fw-regular);
  line-height: 0.875;
  color: var(--color-black);
  pointer-events: none;
  white-space: nowrap;
}

.fitem__value {
  flex: 1;

  text-align: right;
  margin-bottom: -3px;
  font-size: var(--fs-md);
  font-weight: var(--fw-regular);
  line-height: 0.875;
  color: var(--color-black);

  opacity: 0.64;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.fitem__arrow {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  opacity: 0.64;
  pointer-events: none;
}

/* ─── Sub-page ─── */
.fsub__header {
  display: flex;
  align-items: center;
  height: 48px;

  border-bottom: 1px solid var(--color-gray-divider);
}

.fsub__back {
  height: 32px;
  width: 32px;

  display: flex;
  align-items: center;
  justify-content: flex-start;
  
  cursor: pointer;
  flex-shrink: 0;
}

.fsub__back img {
  width: 24px;
  height: 24px;

  pointer-events: none;
}

.fsub__title {
  flex: 1;
  margin-bottom: -2px;
  font-size: var(--fs-md);
  font-weight: var(--fw-medium);
  color: var(--color-black);
  background: none;
  border: none;
  text-align: left;
  cursor: pointer;
  padding: 0;
  font-family: var(--font-primary);
}

.fsub__spacer {
  width: 44px;
  flex-shrink: 0;
}

/* ─── Action button inside each page ─── */
.fslider__page-action {
  padding: var(--sp-12) 0;
  padding-top: var(--sp-24);
}

/* ─── Price range ─── */
.filter-range {
  width: 100%;
  padding-top: var(--sp-12) 0;

  display: flex;
  align-items: center;
  gap: var(--sp-12);
}

.filter-range__icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  opacity: 0.64;
}


/* ─── Floating-label field ─── */
.float-field {
  position: relative;
  flex: 1;
  min-width: 0;
}

.float-field__input {
  width: 100%;
  height: 48px;
  border: none;
  border-bottom: 1.5px solid var(--color-gray-light);
  border-radius: 0;
  padding: 16px 0 4px;
  font-family: var(--font-primary);
  font-size: var(--fs-md);
  color: var(--color-black);
  background: transparent;
  outline: none;
  transition: border-color 0.2s;
  -moz-appearance: textfield;
  appearance: textfield;
  box-sizing: border-box;
}

.float-field__input::-webkit-outer-spin-button,
.float-field__input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  appearance: none;
  margin: 0;
}

.float-field__label {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  font-family: var(--font-primary);
  font-size: var(--fs-md);
  color: #999;
  pointer-events: none;
  transition: top 0.2s ease, font-size 0.2s ease, color 0.2s ease, transform 0.2s ease;
  transform-origin: left top;
}

.float-field--focus .float-field__label,
.float-field--filled .float-field__label {
  top: 2px;
  transform: translateY(0);
  font-size: 11px;
  color: #999;
}

.float-field--focus .float-field__input {
  border-bottom-color: var(--color-black);
}

/* ─── Apply button (shared) ─── */
.filter-apply-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 60px;
  border-radius: 30px;
  background: var(--color-primary);

  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  line-height: var(--leading-none);
  color: var(--color-white);

  border: none;
  cursor: pointer;
  transition: opacity 0.15s;
}

.filter-apply-btn:active {
  opacity: 0.9;
}

.filter-reset-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: var(--touch-min);
  margin-top: var(--sp-8);

  font-size: var(--fs-base);
  font-weight: var(--fw-medium);
  line-height: var(--leading-none);
  color: var(--color-black);

  cursor: pointer;
  opacity: 0.64;
  transition: opacity 0.15s;
}

.filter-reset-btn:active {
  opacity: 0.86;
}

/* ─── Color dot ─── */
.filter-color-dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  flex-shrink: 0;
  border: 1px solid rgba(0, 0, 0, 0.1);
}

/* ─── Sort Sheet ─── */
.sort-options {
  display: flex;
  flex-direction: column;
  padding: 0 var(--sp-12);
  padding-bottom: var(--sp-12);
}

.sort-option {
  width: 100%;
  height: 48px;

  display: flex;
  align-items: center;
  justify-content: space-between;

  border-bottom: 1px solid var(--color-gray-divider);
  cursor: pointer;
}

.sort-option:last-child {
  border-bottom: none;
}

.sort-option__label {
  display: flex;
  align-items: center;
  gap: var(--sp-8);
}

.sort-option__text {
  margin-bottom: -3px;
  font-size: var(--fs-md);
  font-weight: var(--fw-regular);
  line-height: 0.875;
  color: var(--color-black);
  pointer-events: none;
}

.sort-option__icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

.sort-option--active .sort-option__text {
  font-weight: var(--fw-semibold);
  color: var(--color-primary);
}

.sort-option__check {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 2px solid var(--color-gray-border);
  flex-shrink: 0;
  transition: border-color 0.15s, background 0.15s;
}

.sort-option--active .sort-option__check {
  border-color: var(--color-primary);
  background: var(--color-primary);
  box-shadow: inset 0 0 0 3px var(--color-white);
}
