:root{
    --loaderhue: 0;
	--loaderbg: hsl(var(--loaderhue),0%, 100%);
	--loaderfg: hsl(var(--loaderhue),10%,10%);
	--loaderprimary: hsl(var(--loaderhue),10%,10%);
	--trans-dur: 0.3s;
}

.anti_preloader {
    text-align: center;
    width: 100%;
    height: 100%;
    position: fixed;
    z-index: 100;
    background: rgba(0, 0, 0, 0.45);
    top: 0;
    left: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    backdrop-filter: blur(15px);
    -webkit-backdrop-filter: blur(15px);
}
.anti_preloader__text {
	position: relative;
}
.anti_preloader__msg {
    color: var(--bs-white);
    font-weight: bold;
    font-size: clamp(1.5em, 2vw, 2em);
}
.anti_preloader__msg--last {
	animation-direction: reverse;
	animation-delay: 14s;
	visibility: hidden;
}
.preloader_cart {
	display: block;
	margin: 0 auto 1.5em auto;
	width: 8em;
	height: 8em;
}
.preloader_cart__lines,
.preloader_cart__top,
.preloader_cart__wheel1,
.preloader_cart__wheel2,
.preloader_cart__wheel-stroke {
	animation: cartLines 2s ease-in-out infinite;
}
.preloader_cart__lines {
	stroke: var(--loaderprimary);
}
.preloader_cart__top {
	animation-name: cartTop;
}
.preloader_cart__wheel1 {
	animation-name: cartWheel1;
	transform: rotate(-0.25turn);
	transform-origin: 43px 111px;
}
.preloader_cart__wheel2 {
	animation-name: cartWheel2;
	transform: rotate(0.25turn);
	transform-origin: 102px 111px;
}
.preloader_cart__wheel-stroke {
	animation-name: cartWheelStroke
}
.preloader_cart__track {
	/* stroke: hsla(var(--loaderhue),0%, 0% , 0.55); */
	transition: stroke var(--trans-dur);
}

/* Dark theme */
/* @media (prefers-color-scheme: dark) {
	:root {
		--loaderbg: hsl(var(--loaderhue),10%,10%);
		--loaderfg: hsl(var(--loaderhue),10%,90%);
	}
	.preloader_cart__track {
		stroke: hsla(var(--loaderhue),10%,90%,0.1);
	}
} */

/* Animations */

@keyframes cartLines {
	from,
	to {
		opacity: 0;
	}
	8%,
	92% {
		opacity: 1;
	}
}
@keyframes cartTop {
	from {
		stroke-dashoffset: -338;
	}
	50% {
		stroke-dashoffset: 0;
	}
	to {
		stroke-dashoffset: 338;
	}
}
@keyframes cartWheel1 {
	from {
		transform: rotate(-0.25turn);
	}
	to {
		transform: rotate(2.75turn);
	}
}
@keyframes cartWheel2 {
	from {
		transform: rotate(0.25turn);
	}
	to {
		transform: rotate(3.25turn);
	}
}
@keyframes cartWheelStroke {
	from,
	to {
		stroke-dashoffset: 81.68;
	}
	50% {
		stroke-dashoffset: 40.84;
	}
}