/*
 * tdn-clients-logos — bandeau logos clients (Phase C.5 Bloc 8.2)
 *
 * 7 logos placeholders "Logoipsum" en grid horizontal desktop.
 * Continuité visuelle avec le bandeau testimonials au-dessus :
 * fond pink-100 identique, padding réduit pour transition douce.
 *
 * Logos = placeholders typographiques (à remplacer par exports Figma).
 */

.tdn-clients-logos {
	background: var(--tdn-color-pink-100, #F6C9D0);
	padding: 0 24px 100px;
}

.tdn-clients-logos__inner {
	max-width: var(--tdn-container-max, 1336px);
	margin: 0 auto;
}

.tdn-clients-logos__grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(7, minmax(0, 1fr));
	gap: 16px;
	align-items: center;
}

.tdn-clients-logos__item {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 64px;
	font-family: var(--tdn-font-family-brand, 'Nunito Sans', sans-serif);
	font-weight: var(--tdn-font-weight-bold, 700);
	font-size: var(--tdn-font-size-16, 16px);
	letter-spacing: var(--tdn-letter-spacing-wide, 1.2px);
	color: var(--tdn-color-pink-700, #9c413d);
	opacity: 0.7;
	text-transform: uppercase;
}

/* Variante --image : logo client cropé en rond (cover, sans fond) */
.tdn-clients-logos__item--image {
	opacity: 1;
	width: 80px;
	height: 80px;
	background: transparent;
	border-radius: 50%;
	padding: 0;
	box-sizing: border-box;
	margin: 0 auto;
	overflow: hidden;
}

.tdn-clients-logos__item--image a {
	display: contents;
}

.tdn-clients-logos__item--image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 200ms ease;
}

.tdn-clients-logos__item--image:hover img {
	transform: scale(1.05);
}

/* --- Responsive ------------------------------------------------ */

@media (max-width: 1024px) {
	.tdn-clients-logos__grid {
		grid-template-columns: repeat(4, minmax(0, 1fr));
		gap: 24px 12px;
	}
}

@media (max-width: 640px) {
	.tdn-clients-logos {
		padding: 0 16px 64px;
	}

	.tdn-clients-logos__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

/* ===== Marquee mobile : 2 rows logos qui défilent en sens opposés ============== */
/* Posé par tdn-clients-logos-marquee.js au boot mobile (clone DOM 2x par row).
 * Override les media queries ci-dessus quand .--marquee est posé par le JS. */
@media (max-width: 1023px) {
	.tdn-clients-logos__grid--marquee {
		display: flex !important;
		flex-direction: column;
		gap: 24px;
		grid-template-columns: none !important;
		overflow: hidden;
		padding: 0;
	}

	.tdn-clients-logos__row {
		overflow: hidden;
		width: 100%;
	}

	/* Gap 48px entre logos = row plus longue = les doublons ne sont jamais visibles
	 * simultanément dans le viewport. Animation plus lente (45s) pour compenser. */
	.tdn-clients-logos__row-inner {
		display: flex;
		flex-wrap: nowrap;
		gap: 48px;
		width: max-content;
		animation: tdn-clients-marquee 45s linear infinite;
	}

	.tdn-clients-logos__row--right .tdn-clients-logos__row-inner {
		animation-direction: reverse;
	}

	.tdn-clients-logos__row .tdn-clients-logos__item {
		flex-shrink: 0;
	}

	/* translateX -33.333% car le JS duplique 3x (vs 2x avant). Boucle = 1/3 de la row. */
	@keyframes tdn-clients-marquee {
		from { transform: translateX(0); }
		to { transform: translateX(-33.333%); }
	}
}

/* Pause marquee si prefers-reduced-motion */
@media (max-width: 1023px) and (prefers-reduced-motion: reduce) {
	.tdn-clients-logos__row-inner {
		animation: none;
	}
}
