/* =========== BASE GLOBAL: evita scroll horizontal del sitio =========== */
html, body {
	overflow-x: hidden;
}

/* =========== CARRUSELES (#logos-auto y #logos-auto-2) =========== */
#logos-auto, #logos-auto-2 {
	position: relative;
	max-width: min(1200px, 100%);
	margin: 0 auto;
/* anti-recorte al hacer hover (más aire vertical) */
/* ocultamos solo en X para los fades; en Y dejamos visible */
	overflow-x: hidden;
	overflow-y: visible;
}

/* Fades laterales (sugerencia de scroll) */
#logos-auto::before, #logos-auto::after,
#logos-auto-2::before, #logos-auto-2::after {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	width: 16px;
	pointer-events: none;
	z-index: 2;
	background: linear-gradient(to right, rgba(255,255,255,1), rgba(255,255,255,0));
}

#logos-auto::before, #logos-auto-2::before {
	left: 0;
}

#logos-auto::after,  #logos-auto-2::after {
	right: 0;
	transform: scaleX(-1);
}

/* Viewport: scroll manual aquí (mouse y dedo) */
#logos-auto .viewport, #logos-auto-2 .viewport {
	overflow-x: auto;
	overflow-y: visible;
/* visible para que no recorte el hover */
/* colchón interno */
}

#logos-auto .viewport::-webkit-scrollbar,
#logos-auto-2 .viewport::-webkit-scrollbar {
	display: none;
}

/* Cinta animada (autoplay). Recuerda: la secuencia está repetida 4 veces. */
#logos-auto .belt, #logos-auto-2 .belt {
	display: flex;
	align-items: center;
	gap: 6px;
	width: max-content;
	animation: logosMarquee 28s linear infinite;
/* velocidad del autoplay */
}

/* Pausar autoplay al interactuar (cursor encima, tocar, foco) */
#logos-auto:hover .belt, #logos-auto:active .belt, #logos-auto:focus-within .belt,
#logos-auto .viewport:hover .belt, #logos-auto .viewport:active .belt, #logos-auto .viewport:focus-within .belt,
#logos-auto-2:hover .belt, #logos-auto-2:active .belt, #logos-auto-2:focus-within .belt,
#logos-auto-2 .viewport:hover .belt, #logos-auto-2 .viewport:active .belt, #logos-auto-2 .viewport:focus-within .belt {
	animation-play-state: paused;
}

/* Respeta “Reducir movimiento” del sistema */
@media (prefers-reduced-motion: reduce) {
	#logos-auto .belt, #logos-auto-2 .belt {
		animation: none;
	}
}

/* Logos (tamaño + hover sin recortes) */
#logos-auto .logo, #logos-auto-2 .logo {
	flex: 0 0 auto;
	display: block;
	width: 240px;
	height: 120px;
/* ajusta aquí si quieres 260x130 o 280x140 */
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	scroll-snap-align: center;
	transition: transform .22s ease, filter .22s ease;
	transform-origin: center center;
/* evita recortes al escalar */
}

#logos-auto .logo:hover, #logos-auto .logo:focus-visible,
#logos-auto-2 .logo:hover, #logos-auto-2 .logo:focus-visible {
	transform: translateY(-2px) scale(1.06);
/* efecto suave sin tocar bordes */
	filter: saturate(.98);
	outline: 0;
}

/* Aviso “Desliza o espera” (se desvanece) */
#logos-auto .hint, #logos-auto-2 .hint {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	bottom: -6px;
	font-size: 12px;
	line-height: 1;
	background: rgba(0,0,0,.65);
	color: #fff;
	padding: 5px 8px;
	border-radius: 999px;
	white-space: nowrap;
	pointer-events: none;
	animation: hintFade 6s forwards;
	z-index: 2;
}

@keyframes hintFade {
	0%,80% {
		opacity: 1;
	}
	
	100% {
		opacity: 0;
	}
}

/* Autoplay en bucle perfecto: 4 copias ⇒ avanza el 25% (una secuencia) */
@keyframes logosMarquee {
	from {
		transform: translateX(0);
	}
	
	to {
		transform: translateX(-25%);
	}
}