/* ==========================================================================
   Marquee Images V2 — CSS-only animation
   ========================================================================== */

/* --- Layout --- */

{{WRAPPER}} .marquee-v2 {
	position: relative;
	width: 100%;
	height: 400px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 16px;
	overflow: hidden;
}

{{WRAPPER}} .marquee-v2__viewport {
	position: relative;
	width: 100%;
	flex: 1 1 0;
	min-height: 0;
	overflow-x: clip;
	overflow-y: visible;
}

/* --- Pause / Play Button (above track) --- */

{{WRAPPER}} .marquee-v2__pause-btn {
	border: 0;
	padding: 0;
	margin: 0;
	background: transparent;
	cursor: pointer;
	font-size: 24px;
	line-height: 1;
	color: inherit;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

{{WRAPPER}} .marquee-v2__pause-btn:hover,
{{WRAPPER}} .marquee-v2__pause-btn:focus,
{{WRAPPER}} .marquee-v2__pause-btn:active {
	background: transparent;
	border: 0;
	padding: 0;
	outline: none;
	box-shadow: none;
}

{{WRAPPER}} .marquee-v2__pause-btn[aria-pressed="false"] .marquee-v2__icon-play {
	display: none;
}

{{WRAPPER}} .marquee-v2__pause-btn[aria-pressed="true"] .marquee-v2__icon-pause {
	display: none;
}

{{WRAPPER}} .marquee-v2__pause-btn[aria-pressed="true"] .marquee-v2__icon-play {
	display: inline;
}

/* --- Item (one per image, independently animated) --- */

{{WRAPPER}} .marquee-v2__item {
	position: absolute;
	top: 0;
	left: 100%;
	will-change: transform;
	animation: marquee-v2-scroll var(--m-duration, 20s) linear infinite;
	animation-delay: var(--m-delay, 0s);
}

/* --- Image ---
   !important is needed to override Elementor's global
   .elementor-widget img { height: auto !important }.
   Our {{WRAPPER}} specificity (0,3,0) beats theirs (0,1,1).
   ========================================================================== */

{{WRAPPER}} .marquee-v2__img {
	display: block;
	width: 100% !important;
	height: auto !important;
	object-fit: cover;
	border-radius: 12px;
}

{{WRAPPER}} .marquee-v2__item[style*="height:"] .marquee-v2__img {
	height: 100% !important;
}

/* --- Keyframes --- */

@keyframes marquee-v2-scroll {
	from {
		transform: translateX(0) translateY(var(--m-offset-y, 0));
	}
	to {
		transform: translateX(calc(-100vw - 100%)) translateY(var(--m-offset-y, 0));
	}
}

/* --- Pause state --- */

{{WRAPPER}} .marquee-v2.is-paused .marquee-v2__item {
	animation-play-state: paused;
}

/* --- Accessibility: reduced motion --- */

@media (prefers-reduced-motion: reduce) {
	{{WRAPPER}} .marquee-v2__item {
		animation-play-state: paused;
	}
}
