/* ── UIT Preloader ─────────────────────────────────────────────── */
#uit-preloader {
	position: fixed;
	inset: 0;
	z-index: 999999;
	display: flex;
	align-items: center;
	justify-content: center;
}

.uit-preloader-inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 24px;
	padding: 32px;
	position: relative;
	z-index: 2;
}

.uit-preloader-logo {
	display: block;
	height: auto;
	opacity: 0;
	transform: translateY(10px);
	animation: uitLogoIn 0.5s ease 0.1s forwards;
}

@keyframes uitLogoIn {
	to { opacity: 1; transform: translateY(0); }
}

/* ── progress bar ──────────────────────────────────────────────── */
.uit-progress-wrap {
	width: 260px;
	max-width: 80vw;
	height: 4px;
	background: rgba(255,255,255,0.2);
	border-radius: 4px;
	overflow: hidden;
}

.uit-progress-bar {
	height: 100%;
	width: 0%;
	/* color set via inline style from PHP / JS */
	background: var(--uit-bar-color, #00c8e0);
	border-radius: 4px;
	transition: width 0.12s linear;
}

.uit-progress-text {
	font-family: Arial, sans-serif;
	font-size: 13px;
	color: rgba(255,255,255,0.75);
	letter-spacing: 1px;
}

/* ════════════════════════════════════════════════════════════════
   EXIT ANIMATIONS
   All use transform so they work on every modern browser.
   The overlay splits into two halves for slide-lr.
   ════════════════════════════════════════════════════════════════ */

/* shared half panels used for slide-lr */
#uit-preloader .uit-half {
	position: absolute;
	top: 0; bottom: 0;
	width: 50%;
	z-index: 1;
	/* background inherited from parent via JS */
}
#uit-preloader .uit-half-left  { left: 0;  transform: translateX(0); }
#uit-preloader .uit-half-right { right: 0; transform: translateX(0); }

/* ── slide left & right ──── */
#uit-preloader.uit-exit-slide-lr .uit-half-left {
	animation: uitHalfLeft 0.55s cubic-bezier(0.4,0,0.2,1) forwards;
}
#uit-preloader.uit-exit-slide-lr .uit-half-right {
	animation: uitHalfRight 0.55s cubic-bezier(0.4,0,0.2,1) forwards;
}
#uit-preloader.uit-exit-slide-lr .uit-preloader-inner {
	animation: uitFadeContent 0.2s ease forwards;
}
@keyframes uitHalfLeft  { to { transform: translateX(-100%); } }
@keyframes uitHalfRight { to { transform: translateX(100%);  } }
@keyframes uitFadeContent { to { opacity: 0; } }

/* ── fade ──── */
#uit-preloader.uit-exit-fade {
	animation: uitFade 0.55s ease forwards;
}
@keyframes uitFade { to { opacity: 0; } }

/* ── slide up ──── */
#uit-preloader.uit-exit-slide-up {
	animation: uitSlideUp 0.5s cubic-bezier(0.4,0,0.2,1) forwards;
}
@keyframes uitSlideUp { to { transform: translateY(-100%); } }

/* ── slide down ──── */
#uit-preloader.uit-exit-slide-down {
	animation: uitSlideDown 0.5s cubic-bezier(0.4,0,0.2,1) forwards;
}
@keyframes uitSlideDown { to { transform: translateY(100%); } }

/* ── zoom ──── */
#uit-preloader.uit-exit-zoom {
	animation: uitZoom 0.5s ease forwards;
}
@keyframes uitZoom { to { transform: scale(1.08); opacity: 0; } }
