/*
** Основные переменные шаблона
*/
:root {
  --color-primary: #519381; /* 1_основной */
  --color-secondary: #ff8194; /* 2_основной */
  --color-tertiary: #d1f4f6; /* 3_основной */
  --color-black: #3b4141; /* черный */
  --color-gray: #dceded; /* серый */
  --color-darkgray: #8dacac; /* темный серый */
  --color-lightgray: #e5eeed; /* фоновой2 */
  --color-background: #f0f6f4; /* фоновой f8f8ff */
  --color-primary-light: #85B3A7;
  --color-white: #fff;
  --color-text-primary: var(--color-black);
  --color-border: var(--color-lightgray);
  --color-border-secondary: var(--color-text-primary);
  --color-disabled: var(--color-lightgray);
  --color-error: #f9504d;
  --border-radius: 4px;
  --drop-shadow: 0 4px 12px rgb(86 81 132 / 10%);
  --scrollbar-width: 16px;
  --scrollbar-width-thin: 4px;
  --scrollbar-color: #D4E4E4;
  --duration: 300ms;
  --transition: all var(--duration) ease;
  --font-primary: "Nunito", "Arial", sans-serif;
  /* Глобальные настройки переменных */
  --button-small: 32px;
  --button-medium: 44px;
  --button-large: 48px;
  --text-size-small: 12px;
  --text-size-regular: 14px;
  --text-size-medium: 16px;
  --text-size-large: 18px;
  --line-height-small: 16px;
  --line-height-regular: 18px;
  --line-height-medium: 20px;
  --line-height-large: 24px;
  --icon-size-small: 14px;
  --icon-size-regular: 16px;
  --icon-size-medium: 20px;
  --icon-size-large: 24px;
  --heading-01: 36px;
  --heading-02: 32px;
  --heading-03: 28px;
  --heading-04: 24px;
  --heading-05: 22px;
  --heading-06: 18px;
}
/*
** Основные стили
*/
html {
  font-size: 100%;
  -webkit-font-smoothing: antialiased;
  scroll-behavior: smooth;
  scrollbar-gutter: stable;
}
body {
  color: var(--color-text-primary);
  font-size: var(--text-size-medium);
  font-family: var(--font-primary);
  background-color: var(--color-background);
}
/*
** Селекты
*/
.selects {position: relative;}
.selects select {height: 40px;padding-right: 32px;}
.selects svg {position: absolute;top: 50%;right: 16px;transform: translateY(-50%);pointer-events: none;}
/*
** Секции
*/
.section {margin-block: 48px;}
@media all and (min-width: 1024px) {
  .section {margin-block: 80px;}
}
/*
** Заголовки основных блоков
*/
.headline {margin-bottom: 40px;text-align: center;}
.headline__nav {margin-bottom: 40px;}
.headline--navigation {position: relative;display: flex;gap: 32px;align-items: center;justify-content: center;}
.headline--navigation :is(.swiper-button-next, .swiper-button-prev) {--swiper-navigation-sides-offset: auto;--swiper-navigation-top-offset: auto;position: relative;margin: 0;}
.headline__title {text-align: center;}
@media all and (max-width: 767px) {
  .headline {margin-bottom: 32px;}
	.headline__title {font-size: var(--heading-04);}
  .headline--navigation {gap: 16px;}
}
/*
** Swiper слайдер
*/
.swiper {width: 100%;--swiper-theme-color: var(--color-primary);}
.swiper-initialized .swiper-wrapper {gap: 0;}
.swiper .swiper-pagination {position: relative;margin-top: 24px;}
:is(.swiper-button-next, .swiper-button-prev) {
	--swiper-navigation-size: var(--button-large);
	--swiper-navigation-sides-offset: 0;
  --swiper-navigation-color: var(--color-gray);
  --swiper-theme-color: var(--color-primary);
  padding: 12px;
  background-color: rgb(255 255 255 / 40%);
  border: 1px solid var(--color-lightgray);
  border-radius: 100%;
	transition: all var(--duration);
}
.swiper-pagination-bullet {margin: 8px !important;--swiper-pagination-bullet-inactive-color: var(--color-darkgray);--swiper-pagination-bullet-inactive-opacity: 1;}
.swiper-pagination-bullet-active {outline: 1px solid var(--color-primary);outline-offset: 4px;}
@media (hover: hover) and (pointer: fine) {	
  :is(.swiper-button-next, .swiper-button-prev):hover {color: var(--color-primary);border-color: var(--color-primary);}
}
/*
** Дополнительные стили для форм
*/
.form__help {
  display: block;
  margin-top: 4px;
  color: var(--color-darkgray);
  font-size: var(--text-size-small);
  line-height: var(--line-height-small);
}
/*
** Товарные Иконки: Новинка, Хит, Скидка
*/
.sticker {
	position: relative;
	width: 44px;
	color: var(--color-white);
	font-weight: bold;
	font-size: var(--text-size-small);
  line-height: 20px;
  text-align: center;
  border-radius: 12px;
}
.sticker::before {position: relative;z-index: 2;}
.sticker--sales {background: var(--color-secondary);}
.sticker--sale {background: var(--color-secondary);}
.sticker--sale::before {content: 'sale';}
.sticker--best {background: #F4C054;}
.sticker--best::before {content: 'hit';}
.sticker--new {background: #53A1E2;}
.sticker--new::before {content: 'new';}
/*
** Шапка
*/
.header__inner {
  position: relative;
  display: flex;
  gap: 32px;
  align-items: center;
  padding: 8px 16px;
  background-color: var(--color-white);
  border-radius: 0 0 16px 16px;
}
.header-logo {flex-shrink: 0;margin-inline: 12px;}
.header-logo__link {display: flex;}
/* Шапка. Каталог */
.header-catalog__button {width: 40px;height: 40px;border-radius: 100%;}
/* Шапка. Поиск */
.search__form {position: relative;display: none;align-items: center;width: 100%;text-align: left;}
.search__form button {position: absolute;height: 100%;padding: 0;}
.search__form button svg {flex-shrink: 0;}
.search__input {color: var(--color-text-primary);font-size: var(--text-size-regular);padding-inline: 72px 96px;border-radius: 24px;}
.search__submit {right: 16px;pointer-events: none;padding-inline: 16px;}
.search--success .search__submit {pointer-events: all;}
.search__reset {right: 52px;width: 14px;opacity: 0;pointer-events: none;}
.search--filled .search__reset {opacity: 1;pointer-events: all;}
.search__loader {
  position: absolute;
  right: 72px;
  display: flex;
  align-items: center;
  width: 24px;
  height: 100%;
  opacity: 0;
}
.search__loader span {
	position: absolute;
	display: block;
	width: 16px;
	height: 16px;
	margin: 0;
	border: 2px solid;
	border-color: var(--color-gray) transparent transparent transparent;
	border-radius: 100%;
	animation: lds-ring 1.2s cubic-bezier(0.5, 0, 0.5, 1) infinite;
}
.search__loader span:nth-child(1) {animation-delay: -0.45s;}
.search__loader span:nth-child(2) {animation-delay: -0.3s;}
.search__loader span:nth-child(3) {animation-delay: -0.15s;}
.search--loading .search__loader {opacity: 1;}
@keyframes lds-ring {
	0% {transform: rotate(0deg);}
	100% {transform: rotate(360deg);}
}
/* Шапка. Добавить в */
.addto {display: flex;gap: 16px;align-items: center;}
.addto__link {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: center;
  font-size: var(--text-size-regular);
}
.addto__count {
  position: absolute;
  top: 0;
  right: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  font-weight: bold;
  font-size: 10px;
  background-color: var(--color-tertiary);
  border-radius: 100%;
}
.addto__count[value="0"] {display: none;}
/* Шапка. Контакты */
.header-contacts {
  display: flex;
  gap: 12px;
  align-items: center;
  padding: 8px 12px;
  background-color: var(--color-tertiary);
  border-radius: 16px;
}
.header-contacts__content {display: flex;flex-direction: column;gap: 8px;}
.header-contacts__icon {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  color: var(--color-text-primary);
  background-color: var(--color-white);
  border-radius: 100%;
}
.header-contacts__label {font-size: var(--text-size-regular);}
.header-contacts__link {font-weight: bold;font-size: var(--text-size-regular);}
/* Шапка. Адаптивность */
@media all and (min-width: 1024px) {
  #header {margin-block: 24px;}
  .header__inner {border-radius: 16px;}
	.header-search {position: relative;flex-grow: 1;}
	.search__icon {display: none;background-color: none;}
	.search__form {display: flex;}
  .header-catalog {position: absolute;top: -8px;left: -8px;z-index: 2;}
  .header-catalog__button {width: 60px;height: 60px;}
  .header-catalog__button svg {width: 30px;height: 30px;}
  .header-logo__link {width: 176px;height: 57px;}
}
@media all and (min-width: 1200px) {
  .header-search {width: 350px;}
	.header-contacts {width: 218px;}
}
@media all and (max-width: 1199px) {
	.header-contacts__content {display: none;}
}
@media all and (max-width: 1023px) {
  #header .container {padding: 0;}
  .header__inner {justify-content: space-between;}
  .header-logo__link {width: 134px;height: 44px;}
  .header-catalog {order: -1;}
	.header-contacts {display: none;}
	.header-search {display: contents;}
  .header-search.is-opened .search__form {
		position: absolute;
		top: 40px;
		left: 0;
		z-index: 2;
		display: flex;
		width: 100%;
	}
	.addto {display: none;}
}
/* Шапка. Меню */
#menu {margin-block: 24px;}
.mainnav {position: relative;}
.is-loading .mainnav {overflow: hidden;}
.mainnav__list {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  margin: 0;
  padding: 0;
  list-style: none;
}
.mainnav__link {padding: 8px 16px;line-height: var(--line-height-medium);white-space: nowrap;}
.mainnav__item--more {order: 2;}
.mainnav__dropdown {
	position: absolute;
	right: 0;
	z-index: 11;
	display: flex;
	flex-direction: column;
	gap: 12px;
	width: 200px;
	margin: 0;
	padding: 32px 24px;
	list-style: none;
	background-color: var(--color-white);
  border-radius: 32px;
	box-shadow: var(--drop-shadow);
	transform: scale(1, 0);
	transform-origin: right top;
	transition: transform var(--duration);
}
.is-opened .mainnav__item--more svg {transform: rotate(180deg);}
.mainnav.is-opened .mainnav__dropdown, .mainnav__dropdown.is-opened {transform: scale(1);}
@media all and (max-width: 1023px) {
  #menu {display: none;}
}
/* 
** Категории
*/
.categories__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(136px, 1fr));
  gap: 32px 16px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.categories__item {
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: center;
  justify-content: flex-start;
}
.categories__images {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  aspect-ratio: 1/1;
  overflow: hidden;
  background-color: var(--color-white);
  border: 3px solid var(--color-white);
  border-radius: 100%;
  transition: border-color var(--duration);
}
.categories__name {
	display: flex;
	align-items: flex-start;
	width: 100%;
	overflow: hidden;
  font-weight: bold;
  font-size: var(--text-size-large);
  text-align: center;
  word-break: break-all;
}
.categories__name span {
	display: -webkit-box;
	text-overflow: ellipsis;
  word-break: break-word;
	overflow-wrap: anywhere;
  -webkit-hyphens: auto;
  hyphens: auto;
  -webkit-user-select: none;
  user-select: none;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}
.categories__swiper--goods {}
.categories__grid--goods {grid-template-columns: 100%;gap: 16px;width: calc(100% - 108px);}
.categories__grid--goods .categories__item {
  flex-direction: row;
  padding: 0;
  overflow: hidden;
  background-color: var(--color-white);
  border-radius: 60px 16px 16px 60px;
}
.categories__grid--goods .categories__images {
  flex-shrink: 0;
  width: 60px;
  height: 60px;
  border: none;
  border-radius: 100%;
}
.categories__grid--goods .categories__name {
	height: calc(var(--line-height-medium) * 2);
  padding-inline: 12px;
  font-size: var(--text-size-medium);
	line-height: var(--line-height-medium);
  text-align: left;
}
@media (hover: hover) and (pointer: fine) {	
  .categories__images:hover {border-color: var(--color-primary);}
}
@media all and (min-width: 480px) {
  .categories__grid {grid-template-columns: repeat(auto-fill, minmax(132px, 1fr));}
  .categories__grid--goods {width: calc(100% - 120px);}
  .is-loading .categories__grid--goods {grid-template-columns: repeat(auto-fill, minmax(214px, 1fr));}
}
@media all and (min-width: 640px) {
  .categories__grid {grid-template-columns: repeat(auto-fill, minmax(136px, 1fr));}
  .is-loading .categories__grid--goods {grid-template-columns: repeat(auto-fill, minmax(288px, 1fr));}
}
@media all and (min-width: 768px) {
  .categories__grid {grid-template-columns: repeat(auto-fill, minmax(168px, 1fr));}
  .is-loading .categories__grid--goods {grid-template-columns: repeat(auto-fill, minmax(242px, 1fr));}
}
@media all and (min-width: 1024px) {
  .categories__grid {grid-template-columns: repeat(auto-fill, minmax(148px, 1fr));}
  .categories__grid--goods {width: calc(100% - 160px);}
  .is-loading .categories__grid--goods {grid-template-columns: repeat(auto-fill, minmax(244px, 1fr));}
}
@media all and (min-width: 1200px) {
  .categories__grid {grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));}
  .is-loading .categories__grid--goods {grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));}
}
/*
** Категории на главной
*/
.is-loading #categories .swiper-wrapper {display: flex;flex-wrap: nowrap;}
#categories {margin-bottom: 80px;}
#categories .categories__images {width: 94px;height: 94px;}
.categories__inner {position: relative;display: flex;align-items: center;justify-content: center;}
.categories__swiper {margin-inline: auto;width: calc(100% - 48px);}
#categories .categories__item {justify-content: center;}
@media all and (min-width: 480px) {
  .categories__swiper {margin-inline: auto;width: calc(100% - 128px);}
  #categories .categories__images {width: 126px;height: 126px;}
}
@media all and (min-width: 768px) {
  .categories__swiper {width: calc(100% - 144px);}
}
@media all and (min-width: 1024px) {
  #categories {margin-bottom: 120px;}
  .categories__swiper {width: calc(100% - 188px);}
  #categories .categories__images {width: 166px;height: 166px;}
}
@media all and (min-width: 1200px) {
  #categories .categories__images {width: 176px;height: 176px;}
}
/*
** Товар
*/
.product__item {position: relative;}
.product__images {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: center;
  overflow: hidden;
  background-color: var(--color-white);
  border-radius: 12px;
}
.product__image {
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background-color: var(--color-white);
  border-radius: 12px;
}
.product__sticker {display: flex;gap: 2px;}
.product__links {display: flex;gap: 4px;}
.product__link span {display: none;}
.product__link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background-color: var(--color-white);
  border-radius: 100%;
  box-shadow: 0 4px 12px rgb(86 81 132 / 10%);
  fill: currentcolor;
}
.product__shop {display: flex;flex-wrap: wrap;align-items: center;}
.product__name {
	display: flex;
	align-items: flex-start;
	width: 100%;
	height: 66px;
	overflow: hidden;
	line-height: 22px;
}
.product__name span {
	display: -webkit-box;
	text-overflow: ellipsis;
  word-break: break-word;
	overflow-wrap: anywhere;
  -webkit-hyphens: auto;
  hyphens: auto;
  -webkit-user-select: none;
  user-select: none;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
}
.product__addto {display: flex;gap: 8px;align-items: center;justify-content: space-between;width: 100%;}
.product__add {width: 34px;height: 34px;padding: 0;border-radius: 8px;}
.product__add span {display: none;}
.product__price {display: flex;flex-direction: column;align-items: flex-start;}
.price__now {font-weight: bold;font-size: var(--text-size-medium);white-space: nowrap;}
.price__old {
  position: relative;
	order: 2;
	overflow: hidden;
  font-weight: normal;
	font-size: var(--text-size-regular);
	white-space: nowrap;
  text-decoration: none;
	text-overflow: ellipsis;
}
.price__old::after {
  position: absolute;
  top: 50%;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 1px;
  background-color: var(--color-secondary);
  transform: rotate(-10deg);
  content: '';
}
.price__old + .price__now {color: var(--color-secondary);}
/*
** Товары таблицей
*/
.products__grid {display: grid;grid-template-columns: repeat(auto-fill, minmax(136px, 1fr));gap: 12px;}
.products__grid .product__image {width: 120px;height: 120px;}
.products__grid .product__shop {margin-top: 8px;padding: 6px 8px 6px 12px;background-color: var(--color-white);border-radius: 12px;box-shadow: 0 4px 12px 0 rgb(86 81 132 / 10%);}
.products__grid .product__price {width: calc(100% - 34px - 8px);}
.products__grid .product__images {padding: 8px 12px;}
.products__grid .product__links {
  position: absolute;
  top: 20px;
  right: 20px;
  z-index: 1;
  flex-direction: column;
}
.products__grid .product__sticker {
  position: absolute;
  top: 20px;
  left: 20px;
  z-index: 1;
  flex-direction: column;
}
@media all and (min-width: 480px) {
  .products__grid {grid-template-columns: repeat(auto-fill, minmax(216px, 1fr));}
  .products__grid .product__images {padding: 12px;}
  .products__grid .product__image {width: 192px;height: 192px;}
  .product__price {flex-direction: row;gap: 8px;align-items: center;}
}
@media all and (min-width: 640px) {
  .products__grid {grid-template-columns: repeat(auto-fill, minmax(192px, 1fr));}
  .products__grid .product__image {width: 168px;height: 168px;}
}
@media all and (min-width: 768px) {
  .products__grid {grid-template-columns: repeat(auto-fill, minmax(236px, 1fr));}
  .products__grid .product__image {width: 212px;height: 212px;}
}
@media all and (min-width: 1024px) {
  .products__grid {grid-template-columns: repeat(auto-fill, minmax(238px, 1fr));}
  .products__grid .product__image {width: 212px;height: 212px;}
}
@media all and (min-width: 1200px) {
  .products__grid {grid-template-columns: repeat(auto-fill, minmax(224px, 1fr));}
  .products__grid .product__image {width: 200px;height: 200px;}
}
@media all and (max-width: 479px) {
  .products__grid .price__now {font-size: var(--text-size-regular);line-height: 1.2;}
  .products__grid .price__old {font-size: var(--text-size-small);}
  .products__grid .product__name {height: 60px;font-size: var(--text-size-regular);line-height: var(--line-height-medium);}
}
/*
** Товары таблицей на главной
*/
.products__grid--visible .product__item {display: none;}
.products__grid--visible .product__item:nth-child(-n+4) {display: block;}
.pdt__visible.is-active .product__item {display: block;}
.pdt__visible.is-active [data-visible-button] svg {transform: rotate(-90deg);}
.products__buttons {margin-top: 20px;text-align: center;}
@media all and (min-width: 640px) and (max-width: 1023px) {
	.products__grid--visible .product__item:nth-child(-n+6) {display: block;}
}
@media all and (min-width: 1024px) and (max-width: 1199px) {
	.products__grid--visible .product__item:nth-child(-n+8) {display: block;}
	.products__buttons {margin-top: 32px;}
}
@media all and (min-width: 1200px) {
	.products__grid--visible .product__item:nth-child(-n+10) {display: block;}
	.products__buttons {margin-top: 40px;}
}
/*
** Товары списком
*/
.products__list {display: flex;flex-direction: column;gap: 16px;}
.products__list .product__form {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 12px;
  overflow: hidden;
  background-color: var(--color-white);
  border-radius: 12px;
}
.products__list:not(.products__list--small) .product__images {width: 80px;}
.products__list:not(.products__list--small) .product__shop {display: grid;grid-template-columns: 1fr 100px;gap: 8px 32px;align-items: flex-start;width: calc(100% - 80px - 12px);}
.products__list:not(.products__list--small) .product__links {margin-left: auto;}
.products__list:not(.products__list--small) .product__attributes {margin: 0;color: var(--color-darkgray);font-size: var(--text-size-regular);line-height: var(--line-height-medium);}
.products__list:not(.products__list--small) .product__attributes-name {display: inline;}
.products__list:not(.products__list--small) .product__attributes-value {display: inline;margin: 0;}
.products__list:not(.products__list--small) .product__name {grid-column: span 2;height: auto;}
.products__list:not(.products__list--small) .product__price {flex-wrap: wrap;justify-content: flex-end;}
@media all and (min-width: 480px) and (max-width: 639px) {
  .products__list:not(.products__list--small) .product__images {width: 120px;}
  .products__list:not(.products__list--small) .product__shop {grid-template-columns: 1fr 120px;width: calc(100% - 120px - 12px);}
}
@media all and (min-width: 640px) {
  .products__list:not(.products__list--small) .product__images {width: 160px;}
  .products__list:not(.products__list--small) .product__shop {grid-template-columns: 1fr 100px;width: calc(100% - 160px - 12px);}
  .products__list:not(.products__list--small) .product__addto {flex-direction: column;gap: 24px;align-items: flex-end;width: 100px;}
}
@media all and (min-width: 768px) {
  .products__list:not(.products__list--small) .product__shop {grid-template-columns: 1fr 220px;}
  .products__list:not(.products__list--small) .product__addto {width: 220px;}
  .products__list:not(.products__list--small) .product__add {justify-content: space-between;width: 100%;height: var(--button-large);padding-inline: 20px 6px;}
  .products__list:not(.products__list--small) .product__add span {display: block;}
  .products__list:not(.products__list--small) .product__add svg {
    display: flex;
    flex-shrink: 0;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    padding: 10px;
    color: var(--color-text-primary);
    background-color: var(--color-white);
    border-radius: 8px;
  }
  .products__list:not(.products__list--small) .product__cart {width: 100%;}
}
@media all and (min-width: 1200px) {
  .products__list:not(.products__list--small) .price__now {font-size: 20px;}
  .products__list:not(.products__list--small) .price__old {font-size: 14px;}
} 
@media all and (max-width: 639px) {
  .products__list:not(.products__list--small) .product__attributes {grid-column: span 2;}
  .products__list:not(.products__list--small) .product__price {flex-direction: row;gap: 4px 8px;align-items: center;justify-content: flex-start;}
  .products__list:not(.products__list--small) .product__addto {grid-column: span 2;}
}
@media all and (max-width: 479px) {
  .products__list .sticker + .sticker {display: none;}
}
/*
** Товары списком на главной
*/
.products__list--small {display: grid;flex-direction: row;grid-template-columns: repeat(auto-fill, minmax(356px, 1fr));gap: 12px;}
.products__list--small .product__images {width: 100px;}
.products__list--small .product__image {width: 100px;height: 100px;}
.products__list--small .product__shop {flex-direction: column;width: calc(100% - 100px - 12px);}
.products__list--small .product__links {position: absolute;top: 8px;right: 8px;flex-direction: column;}
.products__list--small .product__sticker {position: absolute;top: 8px;left: 8px;}
.products__list--small .sticker + .sticker {display: none;}
.products__list--small .product__addto {align-items: flex-end;}
/* 
** Подвал. Контакты
*/
#footer {margin-top: 150px;}
.footer__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  padding: 60px 20px 32px;
  background-color: var(--color-lightgray);
  border-radius: 32px;
}
.footer__copyright {color: var(--color-primary-light);font-size: var(--text-size-regular);text-align: center;}
.footer__title {margin-bottom: 24px;text-transform: none;}
.footer__blocks {display: contents;}
.footer__block--subscribe {flex-shrink: 0;width: 336px;}
.footer__block--contacts {grid-row: span 2;grid-column: 1;}
.footer__block--links {grid-column: span 2;}
.footer__links {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.footer__link {position: relative;transform: translateX(0);}
.footer__link:active {transform: translateX(8px);}
@media (hover: hover) and (pointer: fine) {	
  .footer__link:hover {transform: translateX(8px);}
}
@media all and (min-width: 480px) and (max-width: 1023px) {
  .footer__links--contacts {display: grid;grid-template-columns: 1fr 1fr;gap: 20px;}
}
@media all and (min-width: 640px) and (max-width: 1023px) {
  .footer__inner {grid-template-columns: 300px 1fr 1fr;}
  .footer__block--contacts {grid-column: span 3;order: 4;}
  .footer__block--company {margin-left: -64px;}
}
@media all and (min-width: 768px) and (max-width: 1023px) {
  .footer__inner {grid-template-columns: 340px 1fr 1fr;column-gap: 80px;}
  .footer__block--contacts {grid-column: span 3;order: 4;}
  .footer__block--company {margin-left: -64px;}
}
@media all and (min-width: 1024px) {
  .footer__inner {display: flex;column-gap: 64px;}
  .footer__blocks {
    display: grid;
    grid-auto-rows: auto;
    grid-template-columns: 244px 1fr 1fr;
    gap: 24px;
    width: calc(100% - 336px - 60px);
  }
}
@media all and (min-width: 1200px) {
  .footer__inner {padding: 60px;column-gap: 100px;}
  .footer__blocks {grid-template-columns: 280px 1fr 1fr;width: calc(100% - 336px - 100px);}
}
@media all and (max-width: 1023px) {
  .footer__block--links {grid-column: span 2;}
  .footer__block--subscribe {grid-row: span 2;}
}
@media all and (max-width: 767px) {
  #footer .container {padding: 0;}
  .footer__block--company {margin-left: -24px;}
  .footer__block--subscribe {width: 300px;}
}
@media all and (max-width: 639px) {
  .footer__block--subscribe {grid-column: span 2;width: 100%;}
  .footer__block--contacts {grid-column: span 2;}
  .footer__block--company {margin-left: 0;}
}
@media all and (max-width: 479px) {
  .footer__inner {padding-top: 0;}
}
/* 
** Подвал. Социальные сети
*/
.social__links {
  display: flex;
  gap: 12px;
  align-items: center;
  margin: 0;
  padding: 0;
  list-style: none;
}
.social__link {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background-color: var(--color-white);
  border-radius: 100%;
  transition: transform var(--duration);
}
.social__link span {display: none;}
.social__link:hover {transform: translateY(-8px);}
/* 
** Подвал. Способы оплаты
*/
.payments__links {
  display: flex;
  gap: 12px;
  align-items: center;
  margin: 20px 0 0;
  padding: 0;
  list-style: none;
}
.payments__link {color: var(--color-darkgray);fill: currentcolor;}
.payments__link:active {color: var(--color-primary);}
@media (hover: hover) and (pointer: fine) {	
  .payments__link:hover {color: var(--color-primary);}
}
/* 
** Подвал. Контакты
*/
.contacts__item {display: flex;gap: 12px;align-items: center;}
.contacts__label {margin-bottom: 12px;color: var(--color-darkgray);font-size: var(--text-size-regular);}
.contacts__icon {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: var(--button-large);
  height: var(--button-large);
  color: var(--color-primary);
  background-color: var(--color-tertiary);
  border: 2px solid var(--color-white);
  border-radius: 100%;
  fill: currentcolor;
}
.contacts__link {display: block;margin-top: 12px;font-size: var(--text-size-regular);}
.contacts__link:first-child {margin-top: 0;font-weight: bold;font-size: var(--text-size-medium);}
.contacts__link--phone {font-weight: bold;font-size: var(--text-size-medium);}
@media all and (min-width: 768px) {
  .contacts__item + .contacts__item {margin-top: 20px;}
}
/* 
** Подвал. Подписка
*/
.subscribe {position: relative;padding: 126px 32px 40px;text-align: center;background-color: var(--color-primary);border-radius: 40px;}
.subscribe__title {margin-bottom: 16px;color: var(--color-white);}
.subscribe-form__input {height: var(--button-large);color: var(--color-white);background-color: var(--color-darkgray);border-color: var(--color-darkgray);}
.subscribe-form__button {justify-content: space-between;width: 100%;height: var(--button-large);margin-top: 16px;padding-inline: 20px 6px;}
.subscribe-form__button svg {
  width: 38px;
  height: 38px;
  padding: 10px;
  color: var(--color-black);
  background-color: var(--color-white);
  border-radius: 8px;
}
.subscribe-form__policy {margin-top: 24px;color: var(--color-primary-light);}
.subscribe-form__policy a {color: inherit;text-decoration: underline;}
.subscribe__image {
  position: absolute;
  top: -126px;
  left: 50%;
  width: 240px;
  height: 226px;
  overflow: hidden;
  border: 10px solid var(--color-lightgray);
  border-radius: 32px;
  transform: translateX(-50%);
}
@media all and (max-width: 479px) {
  .subscribe {padding-inline: 24px;}
  .subscribe-form__policy {font-size: var(--text-size-regular);}
  .subscribe__title {font-size: var(--heading-06);}
  .subscribe__image {top: -70px;width: 182px;height: 170px}
}
/* 
** Новости
*/
.is-loading #news .swiper-wrapper {display: grid;grid-template-columns: 100%;gap: 16px;}
.news__item {overflow: hidden;background-color: var(--color-white);border-radius: 20px;}
.news__image {height: 178px;overflow: hidden;border-radius: 20px;}
.news__content {padding: 20px;}
.news__title {
	display: flex;
	align-items: flex-start;
	width: 100%;
	height: calc(var(--heading-03) * 2);
	overflow: hidden;
  font-weight: 800;
  font-size: var(--heading-05);
	line-height: 1.2;
  text-transform: uppercase;
}
.news__title span {
	display: -webkit-box;
	text-overflow: ellipsis;
	overflow-wrap: anywhere;
	hyphens: auto;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}
.news__date {color: var(--color-darkgray);font-size: var(--text-size-regular);}
.news__date::before {
  display: inline-block;
  width: 12px;
  height: 12px;
  margin-right: 8px;
  background-color: var(--color-secondary);
  border-radius: 100%;
  content: '';
}
.news__buttons {display: flex;gap: 12px;align-items: center;justify-content: space-between;margin-top: 8px;}
.news__button {border-radius: 32px;}
.news__desc {display: none;}
@media all and (min-width: 480px) {
  .is-loading #news .swiper-wrapper {grid-template-columns: repeat(2, 1fr);}
}
@media all and (min-width: 1024px) {
  .is-loading #news .swiper-wrapper {grid-template-columns: repeat(3, 1fr);}
}
/* 
** Баннеры
*/
#banners {margin-top: 120px;}
#banners .swiper-pagination-bullet-active {--swiper-theme-color: var(--color-tertiary);outline-color: var(--color-tertiary);}
.banners__inner {padding: 16px;background-color: var(--color-primary);border-radius: 32px;}
.banners__swiper {margin-top: -88px;}
.banners__list {display: grid;grid-template-columns: repeat(2, 1fr);gap: 12px;}
.banners__image {
  display: block;
  height: 100px;
  padding: 20px;
  overflow: hidden;
  background-color: var(--color-white);
  border-radius: 32px;
}
@media all and (min-width: 480px) {
  .banners__list {grid-template-columns: repeat(3, 1fr);}
}
@media all and (min-width: 640px) {
  .banners__list {grid-template-columns: repeat(4, 1fr);}
}
@media all and (min-width: 1024px) {
  .banners__list {grid-template-columns: repeat(5, 1fr);}
}
@media all and (min-width: 1200px) {
  .banners__list {grid-template-columns: repeat(6, 1fr);}
}
/* 
** Промо
*/
.promo__inner {position: relative;max-width: 360px;padding: 32px 24px;margin-inline: auto;}
.promo__list {display: grid;grid-template-columns: 100%;gap: 20px;}
.promo__item {display: flex;flex-direction: column;gap: 12px;align-items: flex-start;color: var(--color-white);}
.promo__icon {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 88px;
  height: 88px;
  color: var(--color-primary);
  background-color: var(--color-tertiary);
  border: 4px solid var(--color-white);
  border-radius: 100%;
  fill: currentcolor;
}
.promo__title {display: flex;gap: 8px;align-items: center;font-weight: 700;}
.promo__desc {font-size: var(--text-size-regular);line-height: var(--line-height-regular);margin-block: 6px 0}
.promo__step {
  display: inline-block;
  font-size: var(--text-size-small);
  line-height: var(--line-height-small);
  white-space: nowrap;
  text-align: center;
  text-transform: uppercase;
  background-color: var(--color-secondary);
  border-radius: 20px;
  padding-inline: 10px;
}
.promo_arrow {position: absolute;color: var(--color-primary-light);fill: currentcolor;}
@media all and (min-width: 480px) {
  .promo__title {font-size: var(--text-size-large);line-height: var(--line-height-large);}
  .promo__item {flex-direction: row;}
}
@media all and (min-width: 1024px) {
  .promo__inner {max-width: 100%;margin-top: 32px;}
  .promo__list {grid-template-columns: repeat(3, 1fr);}
  .promo_arrow--top {top: -38px;left: 60%;}
  .promo_arrow--bottom {bottom: -16px;left: 30%;}
}
@media all and (min-width: 1024px) and (max-width: 1199px) {
  .promo__title {flex-direction: column;align-items: flex-start;}
}
@media all and (min-width: 1200px) {
  .promo__desc {margin-block: 10px 0;}
  .promo_arrow--top {top: -16px;left: 64%;}
  .promo_arrow--bottom {bottom: 0;left: 28%;}
}
@media all and (max-width: 1023px) {
  .promo_arrow--bottom {top: 23%;left: -64px;transform: rotate(60deg);}
  .promo_arrow--top {top: 54%;right: -56px;transform: rotate(80deg);}
}
@media all and (max-width: 767px) {
  #banners .container {padding: 0;}
}
@media all and (max-width: 479px) {
  .promo_arrow--bottom {top: 28%;left: -40px;}
  .promo_arrow--top {top: auto;right: 16px;bottom: 24%;}
}
/* 
** Основное на главной
*/
.main__list {display: flex;flex-direction: column;gap: 32px;align-items: flex-start;max-width: 340px;}
.main__item {background-color: var(--color-white);border-color: currentcolor;border-width: 2px;border-radius: 46px;padding-inline: 24px;}
.main__item:nth-child(1) {color: var(--color-secondary);transform: rotate(-8.62deg) translate(8px, 0);}
.main__item:nth-child(2) {color: #F4C054;transform: rotate(5.45deg) translate(-8px, 8px);}
.main__item:nth-child(3) {color: var(--color-primary);transform: rotate(-2.63deg) translate(8px, -8px);}
.main__item:nth-child(4) {color: #3A94DE;transform: rotate(7.72deg) translate(-8px, -8px);}
.main__image {width: 100%;max-width: 100%;height: 180px;overflow: hidden;border-radius: 32px;}
.main__image img {object-fit: cover;}
.main__body {flex-grow: 1;padding: 32px 16px;background-color: var(--color-lightgray);border-radius: 32px;}
.main__title {font-size: var(--heading-02);}
.main__inner {display: grid;grid-template-columns: 100%;gap: 20px;}
.main__left {display: flex;flex-direction: column;gap: 16px;align-items: center;}
.main__right {display: flex;flex-direction: column;gap: 16px;}
.main__contacts {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  padding: 10px;
  overflow: hidden;
  background-color: var(--color-white);
  border-radius: 16px;
}
.main-contacts__content {flex-grow: 1;text-align: center;}
.main-contacts__link {
  display: block;
  margin-top: 4px;
  font-weight: bold;
  font-size: var(--text-size-large);
  line-height: var(--line-height-large);
}
.main-contacts__button {
  flex-shrink: 0;
  justify-content: space-between;
  width: 100%;
  height: var(--button-large);
  margin-left: auto;
  padding-inline: 16px 6px;
}
.main-contacts__button svg {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  padding: 10px;
  color: var(--color-text-primary);
  background-color: var(--color-white);
  border-radius: 8px;
}
.main-contacts__images {display: flex;align-items: center;justify-content: center;width: 100%;}
.main-contacts__image {
  width: var(--button-large);
  height: var(--button-large);
  overflow: hidden;
  border-radius: 100%;
  outline: 2px solid var(--color-white);
}
.main-contacts__image + .main-contacts__image {margin-left: -12px;}
@media (hover: hover) and (pointer: fine) {
  .main-contacts__image:hover img {transform: scale(1.1);}
  .main__item:hover {color: var(--color-white);}
  .main__item:nth-child(1):hover {background-color: var(--color-secondary);border-color: var(--color-secondary);}
  .main__item:nth-child(2):hover {background-color: #F4C054;border-color: #F4C054;}
  .main__item:nth-child(3):hover {background-color: var(--color-primary);border-color: var(--color-primary);}
  .main__item:nth-child(4):hover {background-color: #3A94DE;border-color: #3A94DE;}
}
@media all and (min-width: 480px) {
  .main__image {height: 280px;}
  .main__item:nth-child(1) {transform: rotate(-8.62deg) translate(80px, 28px);}
  .main__item:nth-child(2) {transform: rotate(5.45deg) translate(-28px, 16px);}
  .main__item:nth-child(3) {transform: rotate(-2.63deg) translate(36px, -6px);}
  .main__item:nth-child(4) {transform: rotate(7.72deg) translate(-16px, -8px);}
  .main-contacts__images {width: auto;}
  .main-contacts__link {padding-left: 20px;}
  .main-contacts__content {text-align: right;}
}
@media all and (min-width: 640px) {
  .main__contacts {flex-wrap: nowrap;}
  .main__image {max-width: 370px;}
  .main__left {flex-direction: row;}
  .main-contacts__content {text-align: left;}
  .main-contacts__button {width: 216px;}
  .main__item:nth-child(1) {transform: rotate(-8.62deg) translate(8px, 8px);}
  .main__item:nth-child(2) {transform: rotate(5.45deg) translate(-8px, 8px);}
  .main__item:nth-child(3) {transform: rotate(-2.63deg) translate(8px, -6px);}
  .main__item:nth-child(4) {transform: rotate(7.72deg) translate(-16px, -8px);}
}
@media all and (min-width: 768px) {
  .main__image {height: 315px;}
  .main__contacts {column-gap: 60px;}
}
@media all and (min-width: 1024px) {
  .main__contacts {padding-left: 24px;column-gap: 24px;}
  .main__image {width: 330px;}
  .main__inner {grid-template-columns: 330px 1fr;}
  .main__left {flex-direction: column;}
}
@media all and (min-width: 1200px) {
  .main__contacts {column-gap: 60px;}
  .main__image {width: 378px;}
  .main__inner {grid-template-columns: 378px 1fr;}
  .main__body {padding: 40px;}
}
@media all and (max-width: 767px) {
  .main__title {font-size: var(--heading-04);}
}
/* 
** Сезонная распродажа
*/
.pdtSales__inner {position: relative;padding: 100px 32px 32px;background-color: var(--color-lightgray);border-radius: 40px;}
.pdtSales__bg {
  position: absolute;
  top: -40px;
  left: 50%;
  width: 90%;
  text-align: center;
  transform: translateX(-50%);
}
.pdtSales__bg .headline__title {
  display: inline-flex;
  justify-content: center;
  width: 100%;
  max-width: 500px;
  padding: 16px;
  font-size: 16px;
  background-color: var(--color-tertiary);
  border: 8px solid var(--color-background);
  border-radius: 16px;
}
.pdtSales__bg-link {display: block;}
@media all and (min-width: 480px) {
  .pdtSales__bg .headline__title {font-size: 22px;}
}
@media all and (max-width: 1023px) {
  #pdtSales .container {padding: 0;}
}
/* 
** Таймер
*/
.blocktime {display: flex;align-items: center;justify-content: center;margin-top: -20px;}
.blocktime__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 54px;
  height: 54px;
  color: var(--color-white);
  background-color: var(--color-primary);
  border-radius: 100%;
  outline: 2px solid var(--color-white);
}
.blocktime__item span {font-size: var(--text-size-regular);}
.blocktime__item + .blocktime__item {margin-left: -12px;}
.blocktime__item:nth-child(1) {z-index: 4;}
.blocktime__item:nth-child(2) {z-index: 3;}
.blocktime__item:nth-child(3) {z-index: 2;}
.blocktime__item:nth-child(4) {z-index: 1;}
/* 
** Преимущества
*/
#advantage {margin-top: 140px;}
#advantage .swiper {margin-top: -88px;}
#advantage .swiper-pagination-bullet-active {--swiper-theme-color: var(--color-tertiary);outline-color: var(--color-tertiary);}
#advantage .swiper-wrapper {align-items: stretch;}
#advantage .swiper-slide {height: auto;}
.is-loading #advantage .swiper-wrapper {display: grid;grid-template-columns: 100%;gap: 16px;}
.advantage__inner {padding: 12px;background-color: var(--color-primary);border-radius: 32px;}
.advantage__item {height: 100%;border-radius: 16px;}
.advantage__image {
  width: 114px;
  height: 118px;
  margin-bottom: -16px;
  margin-left: -12px;
  overflow: hidden;
  border: 6px solid var(--color-primary);
  border-radius: 100% 100% 100% 16px;
}
.advantage__title {font-weight: 800;text-transform: uppercase;}
.advantage__text {font-size: var(--text-size-regular);line-height: var(--line-height-regular);margin-block: 6px 12px;}
.advantage__button {margin-top: auto;border-width: 2px;border-radius: 32px;}
.advantage__content {width: calc(100% - 114px);padding: 10px 6px 10px 16px;}
.advantage__body {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  height: calc(100% - 42px);
  padding: 8px 0 8px 8px;
  overflow: hidden;
  background-color: var(--color-white);
  border-radius: 16px 0 16px 16px;
}
.advantage__header {display: flex;align-items: center;justify-content: space-between;width: 100%;}
.advantage__date {
  flex-grow: 1;
  padding: 12px 6px;
  text-align: center;
  background-color: var(--color-background);
  border-radius: 16px;
}
.advantage__discount {
  width: 100px;
  padding: 8px 16px;
  color: var(--color-secondary);
  font-weight: 800;
  font-size: 26px;
  text-align: center;
  background-color: var(--color-white);
  border-radius: 16px 16px 0 0;
}
@media all and (min-width: 480px) {
  #advantage .swiper {margin-top: -80px;}
  .advantage__inner {padding: 16px;}
  .advantage__title {font-weight: 800;font-size: var(--heading-05);line-height: 1.2;}
  .advantage__date {font-size: var(--text-size-large);}
}
@media all and (min-width: 768px) {
  .is-loading #advantage .swiper-wrapper {grid-template-columns: repeat(auto-fill, minmax(344px, 1fr));}
}
@media all and (min-width: 1024px) {
  .is-loading #advantage .swiper-wrapper {grid-template-columns: repeat(auto-fill, minmax(458px, 1fr));}
  .advantage__inner {padding: 32px;}
}
@media all and (min-width: 1200px) {
  #advantage .swiper {margin-top: -96px;}
  .is-loading #advantage .swiper-wrapper {grid-template-columns: repeat(auto-fill, minmax(352px, 1fr));}
  .advantage__inner {padding: 20px 32px 48px;}
  .advantage__image {width: 168px;height: 174px;}
  .advantage__content {width: calc(100% - 168px);}
}
@media all and (max-width: 767px) {
  #advantage .container {padding: 0;}
}
/*
** Хлебные крошки
*/
.breadcrumbs {
	display: flex;
	flex-wrap: nowrap;
  justify-content: center;
	margin: 0;
	padding: 16px;
	overflow: auto hidden;
	white-space: nowrap;
	list-style: none;
  background-color: var(--color-lightgray);
  border-radius: 8px;
}
.breadcrumbs::-webkit-scrollbar {height: var(--scrollbar-width-thin);}
.breadcrumbs li {color: var(--color-darkgray);font-size: var(--text-size-regular);line-height: var(--line-height-regular);}
.breadcrumbs li:first-of-type::before {display: none;}
.breadcrumbs li::before {display: inline-block;margin-inline: 8px;content: '|';}
.breadcrumbs li:last-of-type {font-weight: bold;}
.breadcrumbs a {color: inherit;}
@media (hover: hover) and (pointer: fine) {
  .breadcrumbs a:hover {color: var(--color-primary);}
}
/*
** Пагинация
*/
.pages {
	display: flex;
	gap: 8px;
	align-items: center;
	justify-content: flex-end;
	margin: 24px 0 0;
	padding: 0;
	list-style: none;
}
.pages__link {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	font-weight: normal;
  background-color: var(--color-white);
  border-radius: 8px;
}
.pages__link.is-active {color: var(--color-text-primary);font-weight: bold;}
.pages__link.is-active span {position: relative;}
.pages__link svg {display: none;}
.pages__link--first {width: auto;padding-inline: 16px;}
.pages__link--last {width: auto;padding-inline: 16px;}
/*
** Акции
*/
.promotion__container {margin-bottom: 32px;padding: 4px 20px;background-color: var(--color-white);border-radius: 20px;}
.promotion__grid {
  display: grid;
  grid-template-columns: 100%;
  gap: 32px 16px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.promotion__item {position: relative;padding: 40px 20px 20px;background-color: var(--color-white);border-radius: 32px;}
.promotion__title {display: block;font-weight: bold;font-size: var(--heading-05);}
.promotion__desc {display: flex;align-items: flex-start;width: 100%;margin-block: 8px 0;}
.promotion__desc span {
	display: -webkit-box;
	text-overflow: ellipsis;
  word-break: break-word;
	overflow-wrap: anywhere;
  -webkit-hyphens: auto;
  hyphens: auto;
  -webkit-user-select: none;
  user-select: none;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
}
.promotion__header {display: flex;align-items: center;justify-content: space-between;width: 100%;}
.promotion__date {
  flex-grow: 1;
  padding: 12px;
  font-weight: bold;
  text-align: center;
  background-color: var(--color-tertiary);
  border-radius: 20px;
}
.promotion__discount {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 16px;
  color: var(--color-white);
  font-weight: 800;
  font-size: 20px;
  text-align: center;
  background-color: var(--color-secondary);
  border-radius: 20px;
}
.promotion__button {margin-top: 20px;border-radius: 32px;}
.promotion__inner {position: absolute;inset: -20px 12px auto;display: flex;align-items: center;}
.promotion__item--empty {color: var(--color-darkgray);}
.promotion__item--empty .promotion__date {color: var(--color-darkgray);background-color: var(--color-gray);}
.promotion__item--empty .promotion__discount {color: var(--color-darkgray);background-color: var(--color-gray);}
.promotion__item--empty .promotion__title {color: var(--color-darkgray);}
.promotion__item--empty .promotion__button {display: none;}
@media all and (min-width: 480px) {
  .promotion__inner {inset: -20px 20px auto;}
}
@media all and (min-width: 640px) {
  .promotion__grid {grid-template-columns: repeat(auto-fill, minmax(296px, 1fr));}
}
@media all and (min-width: 768px) {
  .promotion__grid {grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));}
}
@media all and (min-width: 1024px) {
  .promotion__grid {grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));}
}
@media all and (min-width: 1200px) {
  .promotion__grid {grid-template-columns: repeat(auto-fill, minmax(378px, 1fr));}
}
/* 
** Сайдбар
*/
.sidebar {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 6;
	width: 100%;
	max-width: 308px;
	height: 100dvh;
}
.sidebar::after {
	position: fixed;
	background-color: rgb(73 82 87 / 80%);
	cursor: pointer;
	content: '';
	inset: 0;
}
.sidebar__block {position: relative;z-index: 2;background-color: var(--color-white);}
.sidebar__header {
	position: sticky;
	top: 0;
	z-index: 3;
	display: flex;
	align-items: center;
	padding: 16px;
	font-weight: bold;
	font-size: var(--heading-05);
}
.sidebar__header-close {height: auto;margin-left: auto;}
.sidebar__content {
  display: flex;
  flex-direction: column;
  height: 100dvh;
  padding-inline: 16px;
  overflow: hidden auto;
  -webkit-overflow-scrolling: auto;
}
.sidebar__content::-webkit-scrollbar {width: var(--scrollbar-width-thin);}
@media all and (min-width: 1024px) {
  .products__container {display: flex;gap: 24px;align-items: flex-start;}
  .products__container .sidebar::after {display: none;}
  .products__container .sidebar__block {background-color: transparent;}
  .products__container .sidebar__content {height: auto;padding: 0;}
  .products__container .sidebar__header-close {display: none;}
  .products__filters {position: relative;display: block;flex-shrink: 0;width: 212px;height: auto;}
  .products__content {flex-grow: 1;flex-shrink: 0;width: calc(100% - 212px - 24px);}
}
/*
** Товары
*/
.categories__grid + .products__container {margin-top: 40px;}
.categories__inner + .products__container {margin-top: 40px;}
.products + .html-description {margin-top: 40px;}
.html-description {padding: 20px;line-height: var(--line-height-medium);background-color: var(--color-white);border-radius: 20px;}
.toolbar {margin-bottom: 24px;}
.toolbar__form {display: flex;flex-wrap: wrap;gap: 16px;}
.toolbar__sort {width: calc(100% - 100px - 16px - 84px - 16px);}
.toolbar__label {display: none;}
.toolbar__filters {order: 2;width: 100%;}
.toolbar__views {
  display: flex;
  align-items: center;
  justify-content: space-around;
  width: 100px;
  height: 40px;
  background-color: var(--color-white);
  border-radius: 8px;
  padding-inline: 6px;
}
.views__icon {display: flex;color: var(--color-gray);}
@media all and (min-width: 640px) {
  .toolbar__filters {order: 0;width: 180px;}
  .toolbar__sort {width: 180px;}
  .toolbar__views {margin-left: auto;}
}
@media all and (min-width: 1024px) {
  .toolbar__filters {display: none;}
}
@media all and (max-width: 479px) {
  .toolbar__show {display: none;}
  .pages__first, .pages__last {display: none;}
  .toolbar__sort {flex-grow: 1;}
}
/*
** Фильтры
*/
.filters__open {
  width: 100%;
  height: 40px;
  color: var(--color-black);
  font-weight: normal;
  border-color: var(--color-white);
  padding-inline: 16px;
}
.filters__open b {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  color: var(--color-white);
  font-size: 10px;
  background-color: var(--color-secondary);
  border-radius: 100%;
}
.filters__open b:empty {opacity: 0;}
.filters__open svg {margin-left: auto;}
.filter__form {display: flex;flex-direction: column;gap: 24px;}
.filter__list {margin: 0;padding: 0;border: none;}
.filter__title {margin-bottom: 16px;font-weight: bold;font-size: var(--text-size-large);line-height: var(--line-height-large);}
.filter__title svg {display: none;}
.filter__count {color: var(--color-darkgray);font-size: var(--text-size-regular);}
.filter__label {
  display: flex;
  gap: 4px;
  align-items: center;
  width: calc(100% - 24px);
  line-height: 24px;
  padding-inline: 8px;
}
.filter__value {
	display: -webkit-box;
	text-overflow: ellipsis;
  word-break: break-word;
	overflow-wrap: anywhere;
  -webkit-hyphens: auto;
  hyphens: auto;
  -webkit-user-select: none;
  user-select: none;
	-webkit-box-orient: vertical;
}
.filter__items {
  display: flex;
  flex-direction: column;
  gap: 12px;
	max-height: 120px;
	overflow: hidden auto;
	-webkit-overflow-scrolling: auto;
	scrollbar-width: thin;
	scrollbar-color: var(--scrollbar-color) var(--color-background);
}
.filter__items::-webkit-scrollbar {width: var(--scrollbar-width-thin);}
.filter__item {display: flex;flex-wrap: wrap;align-items: flex-start;}
.filter__item.is-disabled {color: var(--color-gray);pointer-events: none;}
/* Фильтры по цене */
.filter-price__blocks {display: flex;gap: 4px;}
.filter-price__block {position: relative;}
.filter-price__block label {position: absolute;bottom: 14px;left: 12px;color: var(--color-darkgray);font-size: var(--text-size-regular);}
.filter-price__block input {padding-inline: 32px 12px;}
.filter-price__button--clear {color: var(--color-darkgray);}
.filter-price__buttons {display: flex;justify-content: space-between;margin-top: 16px;}
.filter-active {display: none;}
.filters.has-filter .filter-active {display: block;}
.filter-active__clear {display: block;margin-top: 12px;color: var(--color-primary);}
.filter-active__items {display: flex;flex-wrap: wrap;gap: 4px;}
.filter-active__item {
  display: inline-flex;
  gap: 4px;
  align-items: center;
  padding: 12px;
  overflow: hidden;
  font-size: var(--text-size-regular);
  background-color: var(--color-white);
  border-radius: 8px;
}
.filters__clear {flex-shrink: 0;justify-content: space-between;width: 100%;height: var(--button-large);padding-inline: 20px 6px;}
.filters__clear svg {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  padding: 12px;
  color: var(--color-text-primary);
  background-color: var(--color-white);
  border-radius: 8px;
}
/* Стили для слайдера фильтра по цене */
.price-slider {position: relative;height: 20px;margin: 0 12px 20px;}
.price-slider__track {
  position: absolute;
  top: 50%;
  right: 0;
  left: 0;
  height: 6px;
  background-color: var(--color-gray);
  border-radius: 3px;
  transform: translateY(-50%);
  cursor: pointer;
}
.price-slider__range {
  position: absolute;
  top: 50%;
  height: 6px;
  background-color: var(--color-primary);
  border-radius: 3px;
  transform: translateY(-50%);
  pointer-events: none;
}
.price-slider__thumb {
  position: absolute;
  top: 50%;
  width: 20px;
  height: 20px;
  background-color: var(--color-white);
  border: 3px solid var(--color-primary);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  cursor: grab;
  transition: all 0.2s ease;
}
.price-slider__thumb:hover {transform: translate(-50%, -50%) scale(1.1);}
.price-slider__thumb:focus {outline: 2px solid var(--color-secondary);outline-offset: 2px;}
.price-slider__thumb.is-active {transform: translate(-50%, -50%) scale(1.2);cursor: grabbing;}
.price-slider__thumb--min {z-index: 2;}
.price-slider__thumb--max {z-index: 1;}
@media (hover: hover) and (pointer: fine) {
  .filter-active__item:hover {color: var(--color-primary);cursor: pointer;fill: currentcolor;}
  .filter-active__clear:hover {color: var(--color-black);}
}
@media all and (max-width: 1023px) {
  .filter-active__item {background-color: var(--color-background);}
  .filters .sidebar__content {height: calc(100dvh - 80px - 56px);}
  .sidebar__buttons {display: block;padding: 16px;}
  .filter-active__clear {display: none;}
}
@media all and (min-width: 1024px) {
  .filters__header {display: none;}
}