:root {
	--preloader-animation: cubic-bezier(0.4, 0, 0.2, 1);
	--preloader-bg: #000;
}

.preloader-loading {
	position: fixed;
	inset: 0;
	background-color: var( --preloader-bg );
	z-index: 9999;
	transform-origin: bottom;
	transition: 0.5s var( --preloader-animation );
	transition-delay: 0.5s;
}

.preloader-loading.preloader-loaded {
	transform: scaleY( 0 );
	pointer-events: none;
}

.preloader-inner {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate( -50%, -50% );
	text-align: center;
	color: #fff;
}

.preloader-logo {
	display: block;
	margin: 0 auto 1rem;
	max-width: 100%;
	height: auto;
	filter: drop-shadow( 0 0 10px rgb(255, 255, 255) );
	transition: opacity 0.3s ease-out;
}

.preloader-loading.preloader-loaded .preloader-logo,
.preloader-loading.preloader-loaded .preloader-title {
	opacity: 0;
}

.preloader-title {
	overflow: hidden;
	border-right: 0.15em solid #fff;
	white-space: nowrap;
	animation: typing 1.5s steps( 100, end ) infinite;
	font-size: 1.6rem;
	width: 0;
}

@keyframes typing {
	from {
		width: 0;
	}

	to {
		width: 500px;
	}
}

