.slider_about img {
	border-radius: .6rem;
}
/* Прелоадер - анимация */
@keyframes spin {
	from {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(360deg);
	}
}
.text-truncate {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
@keyframes shimmer {
	0% {
		transform: translateX(-100%);
	}
	100% {
		transform: translateX(100%);
	}
}
@media (max-width: 1024px) {
	.action {
		color: black
	}
}
@media (max-width: 1024px) {
	.section:first-of-type {
		padding-top: var(--spacing-8);
		padding-bottom: var(--spacing-72);
	}
}
@media (min-width: 700.1px) and (max-width: 1024px) {
	.main {
		padding-top: var(--spacing-20);
	}
}
.line-container {
	display: flex;
	align-items: center;
}
.left-text,
.right-text {
	font-size: 2rem;
	line-height: 2rem;
	white-space: nowrap;
}
.line {
	flex-grow: 1;
	height: 1px;
	background-color: lightgray;
	margin: 0 8px;
	/* Отступы между текстом и линией */
	align-self: flex-end;
}
.line-container__ogrn .left-text,
.line-container__ogrn .right-text {
	font-size: 2rem;
	line-height: 2rem;
}
.line-container__ogrn .left-text {
	font-weight: 600;
}
.line-container {
	margin-top: 2.4rem;
}
.line-container + .line-container {
	margin-top: 1.2rem;
}
.action_favorite {
	position: relative;
}
/* Лоадер (анимация спиннера) */
.action_favorite.loading::after {
	content: '';
	width: 24px;
	height: 24px;
	border: 4px solid rgba(0, 0, 0, 0.2);
	border-top-color: #000;
	border-radius: 50%;
	animation: spin 1s linear infinite;
	position: absolute;
	top: 50%;
	left: 50%;
	margin: -12px 0 0 -12px;
}
/* Лоадер (анимация спиннера) */
.action_favorite.loading::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(246, 247, 251, 0.75);
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 8;
	opacity: 1;
	pointer-events: all;
}
/* Скрытие счётчика через opacity и scale */
.action__count.hidden {
	opacity: 0;
	transition: opacity 0.3s ease, transform 0.3s ease;
}
/* Показ счётчика */
.action__count {
	display: inline-block;
	opacity: 1;
	z-index: 9;
	transition: opacity 0.3s ease, transform 0.3s ease;
}
.product-card__favorite.loading,
.product-quick-card__favorite.loading,
.product__action.loading {
	pointer-events: none;
	/* Блокируем повторные клики */
	opacity: 0.6;
	/* Делаем кнопку полупрозрачной */
}
.product-quick-card__favorite,
.product__action {
	position: relative !important;
}
/* Спиннер */
.product-card__favorite.loading::after,
.product-quick-card__favorite.loading::after,
.product__action.loading::after {
	content: '';
	width: 16px;
	height: 16px;
	border: 4px solid rgba(0, 0, 0, 0.2);
	border-top-color: #000;
	border-radius: 50%;
	animation: spin 1s linear infinite;
	position: absolute;
	top: 50%;
	left: 50%;
	margin: -14px 0 0 -12px;
	z-index: 9;
}
.product-quick-card__favorite.loading::after {
	width: 26px;
	height: 26px;
	margin: -14px 0 0 -12px;
	z-index: 9;
}
/* Лоадер (анимация спиннера) */
.product-card__favorite.loading::before,
.product-quick-card__favorite.loading::before,
.product__action.loading::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(246, 247, 251, 0.75);
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 8;
	opacity: 1;
	pointer-events: all;
	border-radius: .6rem;
}
html.-modal-locked body::-webkit-scrollbar {
	pointer-events: none;
}
html.-modal-locked body {
	overflow-y: hidden;
	padding-right: 17px;
	/* Компенсация ширины скроллбара */
}
.checkbox input {
	width: 1px;
	height: 1px;
	visibility: visible;
	z-index: -1;
	opacity: 0;
	bottom: 0;
	left: 1rem;
	top: unset;
}
.section__header_h1 {
	padding: 0px !important;
}
.section__header_h1 h1 {
	/*text-align: center;*/
	margin-top: 2rem;
}
@media(min-width: 1024.1px) {
	.section_products {
		padding-top: 2rem !important;
	}
}
button[disabled],
input[type="submit"][disabled] {
	opacity: 0.5;
	/* Уменьшает прозрачность */
	/*cursor: not-allowed;*/
	/* Изменяет курсор на "запрещено" */
	background-color: #ccc;
	/* Цвет фона кнопки */
	/*color: #666;*/
	/* Цвет текста */
	border-color: #aaa;
	/* Цвет границы */
}
.field__input.invalid {
	background-color: #F7BABA;
	border-color: var(--color-accent);
}
.swiper {
	opacity: 0;
	/* Скрываем все слайды */
	transition: opacity 0.2s ease-out;
	/* Анимация появления */
}
.swiper.swiper-initialized {
	opacity: 1;
	/* Показываем, когда Swiper инициализирован */
}
#yam_main .ymaps-2-1-79-ground-pane {
	filter: grayscale(100%);
}
@media (max-width: 700px) {
	#yam_main {
		height: 32.8rem;
	}
}
@media (min-width: 700.1px) and (max-width: 1024px) {
	#yam_main {
		height: 31.2rem;
	}
}
@media (min-width: 1024.1px) {
	#yam_main {
		height: 50rem;
	}
}
.bx-yandex-map {
	position: relative;
	/* Чтобы ::before был относительно родительского контейнера */
	width: 100%;
	/* Ширина карты */
	height: 100%;
	/* Высота карты */
	background: #fff;
	/* Без фона, если карта загрузится */
	overflow: hidden;
	/* Предотвращает выход анимации за границы */
}
.bx-yandex-map::before {
	content: '';
	/* Пустое содержание для псевдоэлемента */
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(90deg,
			rgba(200, 200, 200, 0.2) 25%,
			rgba(220, 220, 220, 0.6) 50%,
			rgba(200, 200, 200, 0.2) 75%);
	animation: shimmer 1.5s infinite;
	z-index: 1;
	/* Чтобы заглушка находилась поверх карты */
}
.bx-yandex-map.loaded::before {
	display: none;
	/* Отключаем заглушку, если карта загрузилась */
}
/* Стили для кастомной иконки */
.ymaps__ume-icon {
	position: relative;
	box-shadow: rgba(0, 0, 0, 0.19) 0px 10px 20px, rgba(0, 0, 0, 0.23) 0px 6px 6px !important;
	border-radius: 6px;
}
/* Изображение внутри метки */
.ymaps__ume-icon img {
	border-radius: 6px;
	width: 100%;
	height: auto;
}
/* Стрелочка под меткой */
.ymaps__ume-icon::after {
	content: '';
	position: absolute;
	bottom: -10px;
	/* Расположить под меткой */
	left: 50%;
	transform: translateX(-50%);
	width: 0;
	height: 0;
	border-left: 10px solid transparent;
	/* Левая граница стрелочки */
	border-right: 10px solid transparent;
	/* Правая граница стрелочки */
	border-top: 10px solid #fff;
	/* Верхняя граница - цвет стрелочки */
}
.mobile_lang_select {
	margin-top: var(--spacing-16);
	color: var(--color-accent);
	font-weight: 600;
}
.mobile_lang_select .select__label {
	background-position: 20%;
}
.mobile_lang_select .select__dropdown {
	box-shadow: 2px 3px 4px rgba(0, 0, 0, 0.3);
}
@media (min-width: 700.1px) {
	.header__dropdown .mobile_lang_select {
		display: none;
	}
}
@media (max-width: 576px) {
	.product .product__form {
		grid-template-rows: 1fr 1fr;
		grid-template-columns: auto;
		justify-content: center;
	}
}
.counter [id^="product_quantity_"],
.product-card__counter .counter input {
	width: 100%;
}


/* favorites */

.product-quick-card__favorite .icon_heart-fill {
    display: none;
}

.product-quick-card__favorite.active .icon_heart {
    display: none;
}

.product-quick-card__favorite.active .icon_heart-fill {
    display: block!important;
}