/**
 * Clients Grid — Shared Styles
 *
 * Base clients section with marquee and static variants.
 */

/* ── Base Clients Section ──────────────────────── */

.clients {
	padding: 4rem var(--container-padding);
	background: #fff;
}

.clients__container {
	max-width: var(--container-max);
	margin: 0 auto;
}

.clients__title {
	text-align: center;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	font-size: var(--fs-h3);
	color: var(--color-text);
	font-weight: 700;
	margin-bottom: 1rem;
}

.clients__subtitle {
	text-align: center;
	color: var(--color-text-light);
	margin-bottom: 3rem;
	margin-top: -1.5rem;
}

.clients__grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 3rem;
	align-items: center;
	justify-items: center;
}

.clients__logo-item {
	display: flex;
	align-items: center;
	justify-content: center;
}

.clients__logo-item .client-logo {
	height: 3rem;
	width: auto;
	object-fit: contain;
	filter: grayscale(100%);
	opacity: 0.4;
	transition: filter 0.4s ease, opacity 0.4s ease;
}

.clients__logo-item .client-logo:hover {
	filter: grayscale(0%);
	opacity: 1;
}

/* ── Variant: Marquee ──────────────────────────── */

.clients--marquee .clients__grid {
	/* Marquee grid inherits base grid; responsive handled separately */
}

.clients__slider {
	overflow: hidden;
	mask-image: linear-gradient(to left, transparent, black 10%, black 90%, transparent);
	-webkit-mask-image: linear-gradient(to left, transparent, black 10%, black 90%, transparent);
}

.clients__track {
	display: flex;
	gap: 3rem;
	width: max-content;
	animation: clients-marquee linear infinite;
	will-change: transform;
}

.clients__track:hover {
	animation-play-state: paused;
}

.clients__slide {
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0.4;
	filter: grayscale(100%);
	transition: all var(--transition-base);
}

.clients__slide:hover {
	opacity: 1;
	filter: grayscale(0%);
}

.clients__slide .client-logo {
	height: 3rem;
	width: auto;
	object-fit: contain;
}

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

/* ── Variant: Static ───────────────────────────── */

.clients--static {
	padding: 4rem var(--container-padding);
	background: var(--color-bg);
}

.clients--static .clients__container {
	max-width: var(--container-max);
	margin: 0 auto;
}

.clients--static .clients__grid {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 1.5rem;
}

@media (min-width: 768px) {
	.clients--static .clients__grid {
		gap: 6rem;
	}
}

.clients--static .clients__logo-item {
	flex: 0 0 auto;
}

.clients--static .clients__logo-item .client-logo {
	height: 3rem;
	width: auto;
	object-fit: contain;
	filter: grayscale(100%);
	opacity: 0.4;
	transition: filter 0.4s ease, opacity 0.4s ease;
}

.clients--static .clients__logo-item .client-logo:hover {
	filter: grayscale(0%);
	opacity: 1;
}

/* ── Responsive ───────────────────────────────── */

@media (max-width: 768px) {
	.clients--marquee .clients__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

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