:root {
	--hue: 223;
	--bg: hsl(var(--hue),10%,90%);
	--fg: hsl(var(--hue),10%,10%);
	--primary: gold;
	--trans-dur: 0.3s;
	/* font-size: calc(16px + (20 - 16) * (100vw - 320px) / (1280 - 320)); */
}
#preloaderMain {
    background: var(--bg);
    background: linear-gradient(45deg, #00377f 80%, #041656 20%, #2FE3FE 40%, #5a3694 60%, #13bdce 0%, #6fc7b5 100%);
    background-size: 600%;
    background-position: 0% 100%;
    -webkit-animation: gradient 7s ease-in-out infinite;
    animation: gradient 7s ease-in-out infinite;
	color: var(--fg);
	height: 100vh;
	display: grid;
	place-items: center;
	transition: background-color var(--trans-dur), color var(--trans-dur);
    overflow: hidden;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 9999;
}
.preloader {
	text-align: center;
	/* max-width: 20em; */
	width: 100%;
}
.preloader-text {
	position: relative;
	height: 1.5em;
}
.preloader-msg {
	animation: msg 0.3s 13.7s linear forwards;
	position: absolute;
	width: 100%;
    color: white;
    font-size: 2rem;
}
.preloader-msg-last {
	animation-direction: reverse;
	animation-delay: 14s;
	visibility: hidden;
}
.cartSVG {
	display: block;
	margin: 0 auto 1.5em auto;
	width: 8em;
	height: 8em;
}
.cart-lines,
.cart-top,
.cart-wheel1,
.cart-wheel2,
.cart-wheel-stroke {
	animation: cartLines 2s ease-in-out infinite;
}
.cart-lines {
	stroke: var(--primary);
}
.cart-top {
	animation-name: cartTop;
}
.cart-wheel1 {
	animation-name: cartWheel1;
	transform: rotate(-0.25turn);
	transform-origin: 43px 111px;
}
.cart-wheel2 {
	animation-name: cartWheel2;
	transform: rotate(0.25turn);
	transform-origin: 102px 111px;
}
.cart-wheel-stroke {
	animation-name: cartWheelStroke
}
.cart-track {
	stroke: hsla(var(--hue),10%,10%,0.1);
	transition: stroke var(--trans-dur);
}

/* Dark theme */
@media (prefers-color-scheme: dark) {
	:root {
		--bg: hsl(var(--hue),10%,10%);
		--fg: hsl(var(--hue),10%,90%);
	}
	.cart-track {
		stroke: hsla(var(--hue),10%,90%,0.1);
	}
}

/* Animations */
@keyframes msg {
	from {
		opacity: 1;
		visibility: visible;
	}
	99.9% {
		opacity: 0;
		visibility: visible;
	}
	to {
		opacity: 0;
		visibility: hidden;
	}
}
@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;
	}
}
@-webkit-keyframes gradient {
    50% {
        background-position: 100% 0%;
    }
}

@keyframes gradient {
    50% {
        background-position: 100% 0%;
    }
}