.filters > * {
	flex: 1 1 100%;
	gap: 0.5rem;
}
.mobile-filters-toggle {
	position: relative;
	margin-right: auto;
}
.filter-container {
	display: none;
	flex: 1 1 100%;
	flex-flow: row wrap;
	gap: 0.5rem;
	margin-bottom: 1px;
}
.mobile-filters-toggle:not(.hide) ~ .filter-container {
	display: flex;
}
.filter {
	display: flex;
	flex: 0 0 auto;
	position: relative;
	isolation: isolate;
	gap: 0.5rem;
	overflow: hidden;
	align-items: center;
	background: var(--filter);
	border: 1px solid var(--filter-hov);
	border-radius: var(--radius);
	z-index: 2;
}
.filter:hover {
	background: var(--filter-hov);
}
.filter-toggle {
	display: flex;
	flex: 1 1 100%;
	height: 100%;
	align-items: center;
	gap: 0.25rem;
	justify-content: space-between;
	padding: 0 0.5rem;
	font-weight: 500;
	cursor: pointer;
}
.filter-toggle > input[type='checkbox'] {
	cursor: pointer;
}
.filter-toggle input[type='checkbox'] {
	margin: 0;
}
.filter-toggle span {
	line-height: 1.5rem;
	min-width: max-content;
	margin-block: 0.2rem;
}
.filter-toggle .checkbox-container {
	margin-right: 0.25rem;
}
.filter .menu {
	position: absolute;
	display: none;
	top: calc(100% + 0.5rem);
	left: 0;
	background: var(--bg-color);
	padding: 0.5rem;
	border: 1px solid var(--filter-hov);
	box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
	border-radius: var(--radius);
}
.filter .menu .scrollable {
	width: max-content;
	max-height: 10rem;
	overflow-y: auto;
	margin-block: 0.5rem;
}
.filter .menu .scrollable .item {
	padding: 0.5rem 0.25rem;
	display: flex;
}
.filter .menu .scrollable .item > :first-child {
	flex: 0 1 auto;
	margin-right: 0.5rem;
}
.filter.open {
	overflow: visible;
	z-index: 3;
}
.filter .arrow {
	display: none;
	position: absolute;
	top: calc(100% + 0.5rem - 5px);
	left: 50%;
	z-index: 1;
	width: 10px;
	height: 10px;
	transform: translate(-50%) rotate(45deg);
	background: var(--bg-color);
	border: 1px solid var(--filter-hov);
	border-bottom: none;
	border-right: none;
}
.filter.open .arrow {
	display: initial;
}
.filter.open .menu {
	display: block;
	height: max-content;
	opacity: 1;
}
/* chips >> */
.chips-container {
	display: none;
	flex: 1 1 100%;
	align-items: center;
	flex-flow: row wrap;
	gap: 1rem;
	opacity: 1;
	padding-right: 0.25rem;
	margin-bottom: 0.5rem;
	max-width: 100%;
}
.chips-container > * {
	display: flex;
	flex: 1 1 0;
	align-items: center;
	align-self: stretch;
	position: relative;
}
.chips-container .front {
	display: none;
	flex: 0 0 auto;
}
.chips-container .front .counter {
	display: flex;
	justify-content: center;
	height: 1.75rem;
	width: 1.75rem;
	border: 1px solid var(--scndr);
	border-radius: var(--rad-maxi);
}
.chips-carousel .prev-btn:before {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	left: 100%;
	width: 0.75rem;
	z-index: 1;
	cursor: default;
	background-image: linear-gradient(-90deg, transparent, white);
}
.chips-carousel .next-btn:before {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	right: 100%;
	width: 0.75rem;
	z-index: 1;
	cursor: default;
	background-image: linear-gradient(90deg, transparent, white);
}
.chips-carousel {
	overflow: hidden;
}
.chips-carousel .track {
	flex: 1 1 auto;
	align-self: stretch;
	overflow: hidden;
	position: relative;
	scroll-behavior: smooth;
	display: flex;
}
.chips-container .back {
	display: flex;
	gap: 0.5rem;
}
.chips-carousel > span {
	font-weight: bolder;
	cursor: pointer;
	position: relative;
	display: flex;
	align-self: stretch;
	align-items: center;
	z-index: 1;
	background: white;
}
.chips-carousel span.prev-btn {
	padding-inline: 0.25rem 0.75rem;
}
.chips-carousel span.next-btn {
	padding-inline: 0.75rem 0.25rem;
}
.chips-container .front p.chip {
	border: 1px solid var(--dngr);
}
.chip .cancel-filter,
.chip .cancel-filters {
	cursor: pointer;
	filter: var(--fc-dngr);
}
.chip .cancel-filter:hover,
.chip .cancel-filters:hover {
	filter: var(--fc-dngr-hov);
}
.cancel-filters {
	display: none;
}
.cancel-filters.active {
	display: inline;
}
/* << chips */

/* md */
@media (min-width: 768px) {
	.mobile-filters-toggle {
		display: none;
		flex: 0 0 auto;
	}
	.products-top .filter-container {
		display: flex;
		flex: 1 1 auto;
		order: 2;
	}
	body.logged-in .products-top .filter-container {
		padding-right: 4.5rem;
	}
	.products-top .chips-container {
		order: 1;
	  	margin-right: auto;
    }
}
/* lg */
@media (min-width: 992px) {
	.filter:hover:before {
		transform: scalex(1);
		left: 0;
	}
}
/* xl */
@media (min-width: 1200px) {
	body.logged-in .products-top .filter-container {
		padding-right: unset;
	}
}