/* Root is the viewport */
.wp-block-tclp-logo-reel {
	--reel-duration: 20s;
	position: relative;
	overflow: hidden;
	display: block;
}

.tclp-logo-reel__track {
	display: flex;
	gap: 0;
	width: max-content;
	align-items: center;
	animation: tclp-logo-reel-scroll var(--reel-duration) linear infinite;
	will-change: transform;
}

.tclp-logo-reel__group {
	display: flex;
	gap: 0;
	align-items: center;
	flex-wrap: nowrap;
}

.wp-block-tclp-logo-reel figure {
	margin: 0 2rem;
	display: block;
}
.tclp-logo-reel__item img {
	display: block;
	height: auto;
	width: 100%;
}

.tclp-logo-reel__overlays {
	position: absolute;
	top: 0;
	bottom: 0;
	width: 10%;
	pointer-events: none;
	z-index: 1;
}
.tclp-logo-reel__overlays.overlay-left {
	background-image: linear-gradient(to right, #fff, #fff0);
	left: 0;
}
.tclp-logo-reel__overlays.overlay-right {
	background-image: linear-gradient(270deg, #fff, #fff0);
	right: 0;
}

@media (max-width: 600px) {
	.wp-block-tclp-logo-reel figure {
		width: 60px !important;
	}
}

/* Seamless loop: translate by exactly one group width (two groups total) */
@keyframes tclp-logo-reel-scroll {
	from {
		transform: translate3d(0, 0, 0);
	}
	to {
		transform: translate3d(-50%, 0, 0);
	}
}

.wp-block-tclp-logo-reel:hover .tclp-logo-reel__track {
	animation-play-state: paused;
}
@media (prefers-reduced-motion: reduce) {
	.tclp-logo-reel__track {
		animation: none;
	}
}
