/**
 * Frontend styles for CyberQ Logo Carousel
 */

.cyberq-lc-carousel-wrapper {
	width: 100vw;
	position: relative;
	left: 50%;
	right: 50%;
	margin-left: -50vw;
	margin-right: -50vw;
	padding: 40px 0;
	background: transparent;
}

.cyberq-lc-carousel-title {
	text-align: center;
	color: #ffffff;
	font-size: 2rem;
	font-weight: 600;
	margin-bottom: 40px;
	padding: 0 20px;
}

@media (max-width: 768px) {
	.cyberq-lc-carousel-title {
		font-size: 1.5rem;
		margin-bottom: 30px;
	}
}

.cyberq-lc-row-wrapper {
	margin-bottom: 30px;
}

.cyberq-lc-row-wrapper:last-child {
	margin-bottom: 0;
}

.cyberq-lc-marquee-container {
	width: 100%;
	overflow: visible;
	position: relative;
	mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent);
	-webkit-mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent);
}

.cyberq-lc-row-wrapper {
	overflow: visible;
}

.cyberq-lc-marquee-track {
	display: flex;
	gap: 40px;
	width: max-content;
	will-change: transform;
	overflow: visible;
}

/* Smooth infinite scroll animation for LTR */
.cyberq-lc-row-wrapper[data-direction="ltr"] .cyberq-lc-marquee-track {
	animation: cyberq-lc-scroll-ltr linear infinite;
}

/* Smooth infinite scroll animation for RTL */
.cyberq-lc-row-wrapper[data-direction="rtl"] .cyberq-lc-marquee-track {
	animation: cyberq-lc-scroll-rtl linear infinite;
}

/* LTR animation - moves from right to left */
@keyframes cyberq-lc-scroll-ltr {
	0% {
		transform: translateX(0);
	}
	100% {
		transform: translateX(-50%);
	}
}

/* RTL animation - moves from left to right */
@keyframes cyberq-lc-scroll-rtl {
	0% {
		transform: translateX(-50%);
	}
	100% {
		transform: translateX(0);
	}
}

.cyberq-lc-logo-item-frontend {
	flex-shrink: 0;
	width: 120px;
	height: 70px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(255, 255, 255, 0.95);
	border-radius: 8px;
	padding: 12px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
	transition: box-shadow 0.3s ease;
	backface-visibility: hidden;
	-webkit-backface-visibility: hidden;
	position: relative;
	z-index: 1;
	cursor: pointer;
}

.cyberq-lc-logo-item-frontend:hover {
	z-index: 10;
}

.cyberq-lc-logo-item-frontend img {
	max-width: 100%;
	max-height: 100%;
	width: auto;
	height: auto;
	object-fit: contain;
	transition: filter 0.3s ease, opacity 0.3s ease;
}

/* Greyscale effect - only when enabled */
.cyberq-lc-grayscale-enabled .cyberq-lc-logo-item-frontend img {
	filter: grayscale(100%);
	opacity: 0.7;
}

.cyberq-lc-grayscale-enabled .cyberq-lc-logo-item-frontend:hover img {
	filter: grayscale(0%);
	opacity: 1;
}

/* Full color - when greyscale is disabled */
.cyberq-lc-grayscale-disabled .cyberq-lc-logo-item-frontend img {
	filter: grayscale(0%);
	opacity: 1;
}

.cyberq-lc-grayscale-disabled .cyberq-lc-logo-item-frontend:hover img {
	filter: grayscale(0%);
	opacity: 1;
}

/* Pause all animations when hovering anywhere in the carousel wrapper */
.cyberq-lc-carousel-wrapper:hover .cyberq-lc-marquee-track {
	animation-play-state: paused;
}

/* Responsive adjustments */
@media (max-width: 768px) {
	.cyberq-lc-carousel-wrapper {
		padding: 30px 0;
	}
	
	.cyberq-lc-logo-item-frontend {
		width: 100px;
		height: 60px;
		padding: 10px;
	}
	
	.cyberq-lc-marquee-track {
		gap: 25px;
	}
}

