/* ============================================
   Marquee Widget for Elementor
   ============================================ */

.me-marquee-wrapper {
	display: flex;
	align-items: center;
	overflow: hidden;
	position: relative;
	width: 100%;
	box-sizing: border-box;
}

/* --- Fade en los bordes --- */
.me-marquee-wrapper.me-has-fade::before,
.me-marquee-wrapper.me-has-fade::after {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	width: 80px;
	z-index: 2;
	pointer-events: none;
}
.me-marquee-wrapper.me-has-fade::before {
	left: 0;
	background: linear-gradient(to right, var(--me-fade-color, #fff) 0%, transparent 100%);
}
.me-marquee-wrapper.me-has-fade::after {
	right: 0;
	background: linear-gradient(to left, var(--me-fade-color, #fff) 0%, transparent 100%);
}

/* --- Etiqueta --- */
.me-marquee-label {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	white-space: nowrap;
	flex-shrink: 0;
	font-weight: 700;
	font-size: 13px;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	z-index: 3;
	position: relative;
	margin-right: 16px;
}

/* --- Pista de desplazamiento --- */
.me-marquee-track-container {
	overflow: hidden;
	flex: 1;
	position: relative;
	min-width: 0;
}

.me-marquee-track {
	display: block;
	white-space: nowrap;
	will-change: transform;
	animation-name: me-marquee-scroll;
	animation-timing-function: linear;
	animation-iteration-count: infinite;
	line-height: 1.6;
}

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

.me-marquee-wrapper.me-pause-on-hover:hover .me-marquee-track {
	animation-play-state: paused;
}

/* --- Item wrap: el separador vive en ::after, nunca toca el texto --- */
.me-marquee-item-wrap {
	display: inline-block;
	white-space: nowrap;
	vertical-align: middle;
}

/* Separador como pseudo-elemento: imposible que se superponga */
.me-marquee-item-wrap[data-sep]::after {
	content: attr(data-sep);   /* lee el valor del atributo PHP */
	display: inline-block;
	vertical-align: middle;
	opacity: 0.5;
	margin: 0 0.75em;
}

/* --- Texto del elemento --- */
.me-marquee-item {
	display: inline;
	white-space: nowrap;
	vertical-align: middle;
	transition: color 0.2s ease;
}

.me-marquee-item a {
	display: inline;
	color: inherit;
	text-decoration: none;
	white-space: nowrap;
	transition: color 0.2s ease;
}

@media (prefers-reduced-motion: reduce) {
	.me-marquee-track {
		animation-duration: 180s !important;
	}
}
