/**
 * Оверлей загрузки страницы: белый фон и анимация до загрузки шрифтов и изображений.
 * Скрывается скриптом page-loader.js после готовности ресурсов.
 */

.page-loader-overlay {
	position: fixed;
	inset: 0;
	z-index: 999999;
	background: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: opacity 0.4s ease-out, visibility 0.4s ease-out;
}

.page-loader-overlay.is-hidden {
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
}

/* Контейнер анимации */
.page-loader-content {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1.5rem;
}

/* Спиннер: три точки пульсируют по очереди */
.page-loader-dots {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
}

.page-loader-dots span {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: #333;
	animation: page-loader-bounce 1.4s ease-in-out infinite both;
}

.page-loader-dots span:nth-child(1) { animation-delay: 0s; }
.page-loader-dots span:nth-child(2) { animation-delay: 0.16s; }
.page-loader-dots span:nth-child(3) { animation-delay: 0.32s; }

@keyframes page-loader-bounce {
	0%, 80%, 100% {
		transform: scale(0.6);
		opacity: 0.5;
	}
	40% {
		transform: scale(1);
		opacity: 1;
	}
}

/* Опциональная подпись */
.page-loader-label {
	font-family: system-ui, -apple-system, sans-serif;
	font-size: 14px;
	color: #666;
	letter-spacing: 0.02em;
}
