/**
 * Logo Grid Marquee – self-contained frontend styles.
 * No theme dependency. Slot dimensions ensure track has width for animation.
 */

/* Prevent horizontal scroll from 100vw */
body {
	overflow-x: clip;
}

/* Slot dimensions – ensures track has width; block works in any theme */
.wp-block-maota-blocks-logo-grid-marquee .logo-grid__slot {
	width: 263px;
	min-width: 263px;
	flex-shrink: 0;
	min-height: 157px;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0.5rem;
}
.wp-block-maota-blocks-logo-grid-marquee .logo-grid__slot img {
	max-width: 100%;
	height: auto;
	object-fit: contain;
}

.wp-block-maota-blocks-logo-grid-marquee {
	overflow: hidden !important;
	flex-shrink: 0;
	width: 100%;
}

.wp-block-maota-blocks-logo-grid-marquee.alignfull {
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
}

.wp-block-maota-blocks-logo-grid-marquee.alignwide {
	width: var(--wp--style--global--wide-size, var(--wp--custom--layout--wide-size, 1440px));
	max-width: 100%;
	margin-left: auto;
	margin-right: auto;
}

.wp-block-maota-blocks-logo-grid-marquee .logo-grid__track {
	display: flex;
	flex-wrap: nowrap;
	flex-shrink: 0;
	min-width: max-content;
	gap: var(--wp--preset--spacing--small, 0.5rem);
	animation: logo-grid-marquee var(--logo-grid-marquee-duration, 60s) linear infinite;
	animation-play-state: paused;
}

.wp-block-maota-blocks-logo-grid-marquee:hover .logo-grid__track {
	animation-play-state: running;
}

/* Touch devices: no hover, so animate automatically */
@media (hover: none) {
	.wp-block-maota-blocks-logo-grid-marquee .logo-grid__track {
		animation-play-state: running;
	}
}

.wp-block-maota-blocks-logo-grid-marquee .logo-grid__track[data-infinite-loop="false"] {
	animation: none;
}

@media (prefers-reduced-motion: reduce) {
	.wp-block-maota-blocks-logo-grid-marquee .logo-grid__track {
		animation: none;
	}
	.wp-block-maota-blocks-logo-grid-marquee:hover .logo-grid__track {
		animation: logo-grid-marquee var(--logo-grid-marquee-duration, 60s) linear infinite;
		animation-play-state: running;
	}
}

@keyframes logo-grid-marquee {
	0% {
		transform: translateX(0);
	}
	100% {
		transform: translateX(-50%);
	}
}
