/* =========================================
   ОБЩИЙ LAYOUT СТРАНИЦЫ
   ========================================= */

/*
  Основной layout страницы:
  - левая колонка с фильтрами около 27%
  - правая колонка с таблицами занимает остальное место
  - min-width: 0 нужен, чтобы правая колонка не распирала grid
*/


.test-filter .views-field-field-image img {
  max-width: 60px;
  max-height: 60px;
  height: auto;
  width: auto;
}

.test-filter thead tr th {
  font-weight: 600;
}

.view-conent_and_filters {
  display: grid;
  grid-template-columns: minmax(280px, 27%) minmax(0, 1fr);
  column-gap: 10px;
  align-items: start;
}

.view-conent_and_filters>* {
  min-width: 0;
}

.view-conent_and_filters .view-content {
  min-width: 0;
}

.view-conent_and_filters .view-content table {
  width: 100%;
}

.view-conent_and_filters td {
  font-family: "Montserrat", sans-serif;
  font-weight: 600;
}

.view-conent_and_filters td a {
  text-decoration: none;
}


/* =========================================
   ФИЛЬТРЫ
   ========================================= */

/*
  Уменьшили внутренние отступы фильтра:
  было 24px, стало 18px
  чтобы визуально ближе совпадало с табличными отступами
*/
.views-exposed-form.bef-exposed-form {
  /* background: #fff; */
  border: 1px solid #e6e6e6;
  border-radius: 14px;
  padding: 18px;
  box-sizing: border-box;
}

/* Верхний переключатель "В наличии на складе" */
.views-exposed-form.bef-exposed-form .form-item-quan-log {
  margin: 0 0 30px;
}

.views-exposed-form.bef-exposed-form .form-item-quan-log input.single-checkbox {
  position: absolute;
  opacity: 0;
  width: 1px;
  height: 1px;
  pointer-events: none;
}

.views-exposed-form.bef-exposed-form .form-item-quan-log label.option {
  position: relative;
  display: block;
  min-height: 24px;
  margin: 0;
  padding-left: 0;
  padding-right: 56px;
  font-size: 15px;
  line-height: 24px;
  color: #3a3a3a;
  cursor: pointer;
  font-size: 20px;
}

.views-exposed-form.bef-exposed-form .form-item-quan-log label.option::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  left: auto;
  width: 36px;
  height: 20px;
  margin-top: -10px;
  border: 0;
  border-radius: 999px;
  background: #d7d7d7;
  transition: background .2s ease;
}

.views-exposed-form.bef-exposed-form .form-item-quan-log label.option::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 18px;
  left: auto;
  width: 16px;
  height: 16px;
  margin-top: -8px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 3px rgba(0, 0, 0, .18);
  transition: right .2s ease, background .2s ease;
}

.views-exposed-form.bef-exposed-form .form-item-quan-log input.single-checkbox:checked+label.option::before {
  background: #980000;
}

.views-exposed-form.bef-exposed-form .form-item-quan-log input.single-checkbox:checked+label.option::after {
  content: "";
  right: 2px;
  left: auto;
  background: #fff;
}

.views-exposed-form.bef-exposed-form .form-item-quan-log input.single-checkbox:focus+label.option::before {
  box-shadow: 0 0 0 3px rgba(152, 0, 0, .15);
}

/* Группы фильтров */
.views-exposed-form.bef-exposed-form fieldset {
  margin: 0 0 28px;
  padding: 0;
  border: 0;
}

.views-exposed-form.bef-exposed-form fieldset:last-of-type {
  margin-bottom: 0;
}

.views-exposed-form.bef-exposed-form legend {
  margin: 0 0 14px;
  padding: 0;
}

.views-exposed-form.bef-exposed-form .fieldset-legend {
  font-size: 16px;
  font-weight: 600;
  line-height: 1.25;
  color: #2f2f2f;
}

/* Высота каждого блока фильтра */
.views-exposed-form.bef-exposed-form .fieldset-wrapper {
  max-height: 300px;
  overflow: auto;
  padding-right: 6px;
}

/* Скролл */
.views-exposed-form.bef-exposed-form .fieldset-wrapper::-webkit-scrollbar {
  width: 8px;
}

.views-exposed-form.bef-exposed-form .fieldset-wrapper::-webkit-scrollbar-thumb {
  background: #d2d2d2;
  border-radius: 999px;
}

.views-exposed-form.bef-exposed-form .js-form-type-checkbox {
  margin: 0 0 7px 0;
  font-weight: 600;
}

/* Обычные чекбоксы */
.views-exposed-form.bef-exposed-form .js-form-type-checkbox:not(.form-item-quan-log) input.form-checkbox {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.views-exposed-form.bef-exposed-form .js-form-type-checkbox:not(.form-item-quan-log) label.option {
  position: relative;
  display: block;
  margin: 0;
  padding-left: 30px;
  font-size: 14px;
  line-height: 1.45;
  color: #3a3a3a;
  cursor: pointer;
}

.views-exposed-form.bef-exposed-form .js-form-type-checkbox:not(.form-item-quan-log) label.option::before {
  content: "";
  position: absolute;
  top: 1px;
  left: 0;
  width: 18px;
  height: 18px;
  border: 1px solid #bdbdbd;
  border-radius: 4px;
  background: #fff;
  box-sizing: border-box;
  transition: .2s ease;
}

.views-exposed-form.bef-exposed-form .js-form-type-checkbox:not(.form-item-quan-log) input.form-checkbox:checked+label.option::before {
  background: #980000;
  border-color: #980000;
}

.views-exposed-form.bef-exposed-form .js-form-type-checkbox:not(.form-item-quan-log) input.form-checkbox:checked+label.option::after {
  content: "✓";
  position: absolute;
  top: 0;
  left: 4px;
  font-size: 13px;
  line-height: 18px;
  color: #fff;
}


.views-exposed-form.bef-exposed-form .form-item-quan-log {
  padding: 5px 19px 20px 0;
  border-bottom: 1px solid #aaa;
  margin-bottom: 25px;
}

/* Кнопки фильтров */
.views-exposed-form.bef-exposed-form .form-actions {
  display: grid;
  gap: 12px;
  margin-top: 28px;
}

.views-exposed-form.bef-exposed-form .form-actions .form-submit {
  width: 100%;
  min-height: 46px;
  border: 0;
  border-radius: 10px;
  background: #980000;
  color: #fff;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  transition: background .2s ease;
}

.views-exposed-form.bef-exposed-form .form-actions .form-submit:hover {
  background: #7f0000;
}

.views-exposed-form.bef-exposed-form .form-actions input[name="reset"] {
  background: #f3f3f3;
  color: #4b4b4b;
}

.views-exposed-form.bef-exposed-form .form-actions input[name="reset"]:hover {
  background: #e9e9e9;
}


/* =========================================
   ТАБЛИЦЫ VIEWS
   ========================================= */

/* Общий контейнер со списком таблиц */
.view-content.row {
  display: grid;
  gap: 28px;
  margin: 0;
}

/*
  Обёртка каждой таблицы:
  overflow-x: auto нужен, чтобы таблица не раздувала всю страницу,
  если какой-то набор колонок всё-таки окажется шире контейнера
*/
.view-content.row>.table-responsive.col {
  padding: 0;
  overflow-x: auto !important;
  overflow-y: visible;
  background: #efeded;
  border-radius: 14px;
  box-sizing: border-box;
}

/* Сама таблица */
.view-content.row table.views-view-table {
  width: 100%;
  margin: 0;
  padding: 0 8px 1px;
  border-collapse: separate;
  border-spacing: 0 10px;
  background: transparent;
  box-sizing: border-box;
}

/* Шапка карточки серии */
.view-content.row table.views-view-table>caption {
  caption-side: top;
  text-align: left;
  padding: 18px 18px 10px;
}

.view-content.row table.views-view-table>caption>div {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 264px;
  gap: 28px;
  align-items: start;
}

/* Левая часть шапки */
.view-content.row table.views-view-table .cap-desc {
  padding: 8px 0 0;
}

.view-content.row table.views-view-table .view-brand {
  margin-bottom: 18px;
}

.view-content.row table.views-view-table .view-brand img {
  display: block;
  max-height: 34px;
  width: auto;
}

.view-content.row table.views-view-table .turn-geom h2 {
  margin: 0 0 10px;
  font-size: 17px;
  line-height: 1.35;
  font-weight: 500;
  color: #424242;
}

.view-content.row table.views-view-table .turn-geom h2:first-child {
  font-size: 22px;
  line-height: 1.05;
  font-weight: 600;
  color: #1f1f1f;
}

.view-content.row table.views-view-table .turn-geom h2 a {
  color: inherit;
  text-decoration: none;
}

.view-content.row table.views-view-table .turn-geom h2 a:hover {
  color: #000;
}

.view-content.row table.views-view-table .views-description {
  margin-top: 14px;
  font-size: 15px;
  line-height: 1.5;
  color: #666;
}

.view-content.row table.views-view-table .views-description p {
  margin: 0;
}

/* Правая часть шапки с картинкой */
.view-content.row table.views-view-table>caption>div>.col-md-6.col-sm-12:last-child {
  width: 264px;
  max-width: 100%;
  min-height: 180px;
  padding: 14px;
  background: #ffffff;
  border-radius: 18px;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
  justify-self: end;
}

.view-content.row table.views-view-table>caption>div>.col-md-6.col-sm-12:last-child img {
  display: block;
  width: 100%;
  max-width: 264px;
  height: auto;
  object-fit: contain;
}

.view-content.row table.views-view-table>caption>div>.col-md-6.col-sm-12:last-child:empty {
  background: transparent;
  min-height: 0;
  padding: 0;
}

/*
  Даём шапке переносы по умолчанию,
  но оставляем nowrap на действительно коротких числовых колонках и корзине
*/
.view-content.row table.views-view-table thead th {
  white-space: normal;
}

.view-content.row table.views-view-table th.views-field-field-lf,
.view-content.row table.views-view-table th.views-field-field-h,
.view-content.row table.views-view-table th.views-field-field-l,
.view-content.row table.views-view-table th.views-field-field-re,
.view-content.row table.views-view-table th.views-field-add-to-cart,
.view-content.row table.views-view-table td.views-field-field-lf,
.view-content.row table.views-view-table td.views-field-field-h,
.view-content.row table.views-view-table td.views-field-field-l,
.view-content.row table.views-view-table td.views-field-field-re,
.view-content.row table.views-view-table td.views-field-field-quantity-in-stock-num {
  white-space: nowrap;
}

.view-content.row table.views-view-table thead th:first-child {
  border-radius: 6px 0 0 6px;
}

.view-content.row table.views-view-table thead th:last-child {
  border-radius: 0 6px 6px 0;
}

/* Одинаковая высота строк */
.view-content.row table.views-view-table tbody tr {
  height: 52px;
}

/* Ячейки */
.view-content.row table.views-view-table tbody td {
  padding: 4px 12px;
  border: 0;
  color: #232323;
  font-size: 17px;
  line-height: 1.35;
  vertical-align: middle;
}

/* Чередование строк */
.view-content.row table.views-view-table tbody tr:nth-child(odd) td {
  background: #ffffff;
}

.view-content.row table.views-view-table tbody tr:nth-child(even) td {
  background: #f3f1f1;
}

.view-content.row table.views-view-table tbody tr:hover td {
  background: #e9e6e6;
}

.view-content.row table.views-view-table tbody td:first-child {
  border-radius: 6px 0 0 6px;
}

.view-content.row table.views-view-table tbody td:last-child {
  border-radius: 0 6px 6px 0;
}

/* Текстовые ссылки */
.view-content.row table.views-view-table td.views-field-title a {
  color: #1f1f1f;
  text-decoration: none;
  font-weight: 600;
}

.view-content.row table.views-view-table td.views-field-title a:hover {
  color: #000;
}

/* Числовые поля */
.view-content.row table.views-view-table td.views-field-field-lf,
.view-content.row table.views-view-table td.views-field-field-h,
.view-content.row table.views-view-table td.views-field-field-l,
.view-content.row table.views-view-table td.views-field-field-re,
.view-content.row table.views-view-table td.views-field-field-quantity-in-stock-num {
  white-space: nowrap;
}

/* Корзина */
.view-content.row table.views-view-table th.views-align-center,
.view-content.row table.views-view-table td.views-align-center {
  text-align: center;
}

.view-content.row table.views-view-table .addtocart-quantity-wrapper-container {
  display: none !important;
}

/*
  Ужимаем контейнер корзины,
  чтобы последняя колонка не съедала лишнюю ширину таблицы
*/
.view-content.row table.views-view-table .addtocart-wrapper-container {
  display: flex;
  align-items: center;
  min-width: 44px;
  justify-content: center;
}

.addtocart-link-class {
  margin: 0;
  height: 36px;
}

/* Кнопка корзины как круглая иконка */
.view-content.row table.views-view-table .addtocart-link-class a,
.view-content.row table.views-view-table td.views-field-add-to-cart a.button,
.view-content.row table.views-view-table td.views-field-add-to-cart .button {
  display: inline-block;
  width: 36px;
  height: 36px;
  padding: 0;
  border: 0;
  border-radius: 50%;
  background: #820000 url('/themes/custom/newstratec3/images/icon-cart.svg') center center / 28px 28px no-repeat;
  background-position-x: 6px;
  box-shadow: none;
  text-indent: -9999px;
  overflow: hidden;
  white-space: nowrap;
  font-size: 0;
  line-height: 0;
  transition: background-color .2s ease, transform .2s ease;
}

.view-content.row table.views-view-table .addtocart-link-class a:hover,
.view-content.row table.views-view-table td.views-field-add-to-cart a.button:hover,
.view-content.row table.views-view-table td.views-field-add-to-cart .button:hover {
  background-color: #6e0000;
  /* transform: translateY(-1px); */
  outline: 1px solid #ff2828;
}

.view-content.row table.views-view-table td.views-field-add-to-cart {
  min-width: 56px;
  width: 56px;
  text-align: center;
}

.top-info-wrapper {
  display: flex;
  justify-content: space-between;
  padding: 0 40px 22px 40px;
}

.top-info-wrapper a {
  text-decoration: none;
}

/* Стили самого сообщения */
.ajax-addtocart-wrapper .messages,
.ajax-addtocart-wrapper .messages--status,
.ajax-addtocart-wrapper p.messages {
  margin: 0;
  padding: 10px 14px;
  border: 1px solid #bfe3c7;
  border-radius: 8px;
  background: #f3fbf5;
  color: #1f6b2e;
  font-size: 14px;
  line-height: 1.35;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.08);
}

.ajax-addtocart-wrapper {
  position: absolute;
  left: 0;
  top: calc(100% + 8px);
  z-index: 30;
  min-width: 220px;
  max-width: 300px;
  display: block !important;
  /* перебивает inline display:none */
  visibility: hidden;
  opacity: 0;
  transform: translateY(-6px);
  pointer-events: none;
  box-sizing: border-box;
}

.view-content tr td h2 {
  display: none;
}

/* Сетка опций */
.views-exposed-form.bef-exposed-form .bef-checkboxes {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 12px 18px;
}

/* =========================================
   СПЕЦИФИЧНЫЕ СЕТКИ ДЛЯ ОТДЕЛЬНЫХ ГРУПП ФИЛЬТРОВ
   ========================================= */

fieldset[data-drupal-selector="edit-f-100-1"] div.fieldset-wrapper .bef-checkboxes,
fieldset[data-drupal-selector="edit-f-100-2"] div.fieldset-wrapper .bef-checkboxes,
fieldset[data-drupal-selector="edit-f-100-3"] div.fieldset-wrapper .bef-checkboxes,
fieldset[data-drupal-selector="edit-f-100-4"] div.fieldset-wrapper .bef-checkboxes,
fieldset[data-drupal-selector="edit-f-100-5"] div.fieldset-wrapper .bef-checkboxes,
fieldset[data-drupal-selector="edit-f-100-6"] div.fieldset-wrapper .bef-checkboxes,
fieldset[data-drupal-selector="edit-f-long"] div.fieldset-wrapper .bef-checkboxes {
  grid-template-columns: 95%;
  gap: 1%;
  align-items: start;
  row-gap: 4px;
}

fieldset[data-drupal-selector="edit-m"] div.fieldset-wrapper .bef-checkboxes,
fieldset[data-drupal-selector="edit-f-50-1"] div.fieldset-wrapper .bef-checkboxes,
fieldset[data-drupal-selector="edit-f-50-2"] div.fieldset-wrapper .bef-checkboxes,
fieldset[data-drupal-selector="edit-f-50-3"] div.fieldset-wrapper .bef-checkboxes,
fieldset[data-drupal-selector="edit-f-50-4"] div.fieldset-wrapper .bef-checkboxes,
fieldset[data-drupal-selector="edit-f-50-5"] div.fieldset-wrapper .bef-checkboxes,
fieldset[data-drupal-selector="edit-f-50-6"] div.fieldset-wrapper .bef-checkboxes,
fieldset[data-drupal-selector="edit-f-50-7"] div.fieldset-wrapper .bef-checkboxes,
fieldset[data-drupal-selector="edit-f-alloy"] div.fieldset-wrapper .bef-checkboxes,
fieldset[data-drupal-selector="edit-f-chip"] div.fieldset-wrapper .bef-checkboxes {
  grid-template-columns: 42% 42%;
  gap: 5%;
  row-gap: 4px;
  display: grid;
  justify-content: space-between;
}

/* =========================================
   DESKTOP SORT BUTTON
   Одна кнопка сортировки справа над таблицами
========================================= */
/* 
@media (min-width: 768px) {
  .view-conent_and_filters.mobile-catalog-layout .mobile-catalog-toolbar {
    display: block;
    margin: 0;
    padding: 0;
    background: transparent;
    border: 0;
  }

  .view-conent_and_filters.mobile-catalog-layout .mobile-catalog-toolbar__btn,
  .view-conent_and_filters.mobile-catalog-layout .mobile-catalog-sort-panel {
    display: none !important;
  }

  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar-host {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    margin: 0 0 16px;
    min-height: 44px;
  }

  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar {
    position: relative;
    display: inline-flex;
    flex-direction: column;
    align-items: flex-end;
    z-index: 20;
  }

  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar__toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 180px;
    height: 44px;
    padding: 0 18px;
    border: 1px solid #d8d8d8;
    border-radius: 10px;
    background: #fff;
    color: #2d2d2d;
    font-size: 14px;
    line-height: 1;
    font-weight: 600;
    cursor: pointer;
    box-sizing: border-box;
    transition: border-color .2s ease, background .2s ease, color .2s ease;
  }

  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar__toggle:hover {
    border-color: #bfbfbf;
    background: #fafafa;
  }

  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar.is-open .desktop-catalog-sortbar__toggle {
    border-color: #980000;
    color: #980000;
  }

  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar__panel {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    width: 280px;
    padding: 14px;
    border: 1px solid #e3e3e3;
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.08);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(-6px);
    transition: opacity .2s ease, visibility .2s ease, transform .2s ease;
    box-sizing: border-box;
  }

  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar.is-open .desktop-catalog-sortbar__panel {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
  }

  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar__panel .form-item {
    margin: 0 0 12px;
  }

  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar__panel .form-item:last-child {
    margin-bottom: 0;
  }

  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar__panel label {
    display: block;
    margin: 0 0 6px;
    color: #4a4a4a;
    font-size: 13px;
    line-height: 1.3;
    font-weight: 600;
  }

  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar__panel select.form-select,
  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar__panel select {
    display: block;
    width: 100%;
    height: 42px;
    padding: 0 12px;
    border: 1px solid #d8d8d8;
    border-radius: 8px;
    background: #fff;
    color: #222;
    font-size: 14px;
    box-sizing: border-box;
  }

  .view-conent_and_filters.mobile-catalog-layout .view-filters .form-item-sort-by,
  .view-conent_and_filters.mobile-catalog-layout .view-filters .form-item-sort-order {
    display: none !important;
  }
} */

@media (min-width: 768px) {
  .view-conent_and_filters.mobile-catalog-layout .view-filters.mobile-catalog-filters {
    grid-column: 1;
    grid-row: 1 / 3;
  }

  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar-host {
    grid-column: 2;
    grid-row: 1;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    width: 100%;
    min-height: 44px;
    margin: 0 0 16px;
    padding: 0;
    box-sizing: border-box;
  }

  .view-conent_and_filters.mobile-catalog-layout .view-content.row,
  .view-conent_and_filters.mobile-catalog-layout .view-content.row.mobile-catalog-content {
    grid-column: 2;
    grid-row: 2;
  }

  .view-conent_and_filters.mobile-catalog-layout .mobile-catalog-toolbar {
    display: contents;
  }

  .view-conent_and_filters.mobile-catalog-layout .mobile-catalog-toolbar__btn,
  .view-conent_and_filters.mobile-catalog-layout .mobile-catalog-sort-panel {
    display: none !important;
  }

  .view-conent_and_filters.mobile-catalog-layout .view-filters .form-item-sort-by,
  .view-conent_and_filters.mobile-catalog-layout .view-filters .form-item-sort-order {
    display: none !important;
  }
}

@media (min-width: 768px) {
  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar {
    position: relative;
    display: inline-flex;
    flex-direction: column;
    align-items: flex-end;
    z-index: 20;
  }

  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar__toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 180px;
    height: 44px;
    padding: 0 18px;
    border: 1px solid #d8d8d8;
    border-radius: 10px;
    background: #fff;
    color: #2d2d2d;
    font-size: 14px;
    line-height: 1;
    font-weight: 600;
    cursor: pointer;
    box-sizing: border-box;
    transition: border-color .2s ease, background .2s ease, color .2s ease;
  }

  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar__toggle:hover {
    border-color: #bfbfbf;
    background: #fafafa;
  }

  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar.is-open .desktop-catalog-sortbar__toggle {
    border-color: #980000;
    color: #980000;
  }

  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar__panel {
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    width: 280px;
    padding: 14px;
    border: 1px solid #e3e3e3;
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.08);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(-6px);
    transition: opacity .2s ease, visibility .2s ease, transform .2s ease;
    box-sizing: border-box;
  }

  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar.is-open .desktop-catalog-sortbar__panel {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
  }

  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar__panel .form-item {
    margin: 0 0 12px;
  }

  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar__panel .form-item:last-child {
    margin-bottom: 0;
  }

  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar__panel label {
    display: block;
    margin: 0 0 6px;
    color: #4a4a4a;
    font-size: 13px;
    line-height: 1.3;
    font-weight: 600;
  }

  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar__panel select.form-select,
  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar__panel select {
    display: block;
    width: 100%;
    height: 42px;
    padding: 0 12px;
    border: 1px solid #d8d8d8;
    border-radius: 8px;
    background: #fff;
    color: #222;
    font-size: 14px;
    box-sizing: border-box;
  }
}

@media (min-width: 768px) {

  /* Хост кнопки должен жить только во 2 колонке grid */
  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar-host {
    grid-column: 2;
    grid-row: 1;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    width: 100%;
    margin: 0 0 0;
    min-height: 44px;
    padding: 0;
    box-sizing: border-box;
    margin-bottom: 10px;
  }

  /* Контент с таблицами тоже во 2 колонке и ниже кнопки */
  .view-conent_and_filters.mobile-catalog-layout .view-content.row,
  .view-conent_and_filters.mobile-catalog-layout .view-content.row.mobile-catalog-content {
    grid-column: 2;
    grid-row: 2;
  }

  /* Фильтры остаются слева */
  .view-conent_and_filters.mobile-catalog-layout .view-filters.mobile-catalog-filters {
    grid-column: 1;
    grid-row: 1 / 3;
  }

  /* Старый toolbar не должен влиять на раскладку */
  .view-conent_and_filters.mobile-catalog-layout .mobile-catalog-toolbar {
    display: contents;
  }

  .view-conent_and_filters.mobile-catalog-layout .desktop-catalog-sortbar {
    position: relative;
    display: inline-flex;
    flex-direction: column;
    align-items: flex-end;
    z-index: 20;
  }
}

/*
*  ФЛАГ
*
*/
th.views-field-link-flag {
  font-size: 26px;
  line-height: 0.4;
  color: #820000;
}

td.views-field-link-flag .action-flag a.use-ajax {
  color: transparent;
  -webkit-text-stroke: 1px #820000;
  font-size: 26px;
  line-height: 1;
}

td.views-field-link-flag .action-unflag a.use-ajax {
  color: #820000;
  -webkit-text-stroke: 0;
  font-size: 26px;
  line-height: 1;
}

.flag.flag-bookmark {
  position: relative;
}

.js-flag-message {
  position: absolute;
  top: -70px;
  right: 100px;
  width: max-content;
  padding: 10px 10px;
  background-color: #f3faef;

}

.view-bookmarks .view-conent_and_filters {
  display: block;
}

.view-content.row.mobile-catalog-content td div {
  display: flex;
  gap: 3px;
}

.views-exposed-form input[data-drupal-selector=edit-num-min],
.views-exposed-form input[data-drupal-selector=edit-num-max] {
  display: none;
}

.form-item-num-exact {
  margin-bottom: 25px;
  font-weight: 600;
  color: #333;
  display: flex;
  gap: 20px;
  align-items: center;
}

.form-item-num-exact input {
  border-radius: 5px;
  height: 30px;
  border: 1px solid #868686;
}