/* ============================================================
   Logos Loop — Styles Frontend
   ============================================================ */

/* Conteneur principal */
.ll-track-wrapper {
	position: relative;
	width: 100%;
	overflow: hidden;
	box-sizing: border-box;
}

/* Effets de fondu sur les bords */
.ll-track-wrapper.ll-has-fade::before,
.ll-track-wrapper.ll-has-fade::after {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	width: 120px;
	z-index: 2;
	pointer-events: none;
}

.ll-track-wrapper.ll-has-fade::before {
	left: 0;
	background: linear-gradient(to right, #ffffff, transparent);
}

.ll-track-wrapper.ll-has-fade::after {
	right: 0;
	background: linear-gradient(to left, #ffffff, transparent);
}

/* Piste du slider — contient les clones */
.ll-track {
	display: flex;
	width: max-content;
	will-change: transform;
}

/* Groupe interne (l'original + les clones s'y ajoutent) */
.ll-logos-inner {
	display: flex;
	align-items: center;
	flex-shrink: 0;
}

/* Chaque item */
.ll-logo-item {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	padding: 0 60px; /* valeur par défaut, écrasée par Elementor */
	cursor: default;
}

/* Lien optionnel */
.ll-logo-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	line-height: 0;
	text-decoration: none;
}

/* Image du logo */
.ll-logo-img {
	display: block;
	height: 60px;    /* valeur par défaut, écrasée par Elementor */
	width: auto;
	max-width: 100%;
	object-fit: contain;

	/* Filtre noir & blanc par défaut (écrasé par Elementor) */
	filter: grayscale(100%);
	opacity: 0.7;

	/* Transition fluide */
	transition: filter 400ms ease, opacity 400ms ease, transform 400ms ease;
	transform: scale(1);
	transform-origin: center center;

	/* Optimisation rendu */
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}

/* Survol : retour à la couleur originale */
.ll-logo-item:hover .ll-logo-img {
	filter: grayscale(0%);
	opacity: 1;
	transform: scale(1.1); /* valeur par défaut, écrasée par Elementor */
}

/* Animation de défilement */
@keyframes ll-scroll-left {
	0%   { transform: translateX(0); }
	100% { transform: translateX(-50%); }
}

@keyframes ll-scroll-right {
	0%   { transform: translateX(-50%); }
	100% { transform: translateX(0); }
}

.ll-track.ll-animate {
	animation-timing-function: linear;
	animation-iteration-count: infinite;
	animation-fill-mode: none;
}

.ll-track.ll-animate.ll-dir-normal {
	animation-name: ll-scroll-left;
}

.ll-track.ll-animate.ll-dir-reverse {
	animation-name: ll-scroll-right;
}

/* Pause de l'animation quand on survole (si option activée) */
.ll-track-wrapper.ll-pause-on-hover:hover .ll-track.ll-animate {
	animation-play-state: paused;
}

/* ============================================================
   Responsive
   ============================================================ */

/* Tablette */
@media (max-width: 1024px) {
	.ll-track-wrapper.ll-has-fade::before,
	.ll-track-wrapper.ll-has-fade::after {
		width: 60px;
	}
}

/* Mobile */
@media (max-width: 767px) {
	.ll-track-wrapper.ll-has-fade::before,
	.ll-track-wrapper.ll-has-fade::after {
		width: 40px;
	}

	.ll-logo-item {
		padding: 0 30px;
	}

	.ll-logo-img {
		height: 40px;
	}
}

/* Accessibilité : préférences de mouvement réduit */
@media (prefers-reduced-motion: reduce) {
	.ll-track.ll-animate {
		animation-duration: 0s !important;
		animation-play-state: paused !important;
	}
}
