/* ============================================================
   Scrolling Partners — Front-end styles
   ============================================================ */

/* --- Section wrapper ---------------------------------------- */
.sp-section {
	--sp-speed:     30s;
	--sp-gap:       60px;
	--sp-height:    60px;
	--sp-direction: normal;   /* normal = left, reverse = right */

	width: 100%;
	overflow: hidden;
	box-sizing: border-box;
}

/* --- Optional heading --------------------------------------- */
.sp-section-title {
	text-align: center;
	font-size: 0.85rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: #888;
	margin: 0 0 1.5rem;
}

/* --- Edge-fade mask ----------------------------------------- */
.sp-overflow-mask {
	--sp-mask-color: #ffffff;   /* Overridden per-instance via Elementor */
	--sp-mask-width: 120px;

	overflow:   hidden;
	position:   relative;

	/* Fade both sides with a CSS mask gradient */
	-webkit-mask-image:
		linear-gradient(
			to right,
			transparent 0,
			black var(--sp-mask-width),
			black calc(100% - var(--sp-mask-width)),
			transparent 100%
		);
	mask-image:
		linear-gradient(
			to right,
			transparent 0,
			black var(--sp-mask-width),
			black calc(100% - var(--sp-mask-width)),
			transparent 100%
		);
}

/* --- Scrolling track ---------------------------------------- */
.sp-track {
	display:    flex;
	align-items: center;
	width:      max-content;
	gap:        var(--sp-gap);
	animation:  sp-scroll var(--sp-speed) linear infinite var(--sp-direction);
	will-change: transform;
}

/* Pause on hover when the class is present */
.sp-pause-hover:hover {
	animation-play-state: paused;
}

/* Respect reduced-motion preference */
@media (prefers-reduced-motion: reduce) {
	.sp-track {
		animation: none;
	}
}

/* --- Keyframe – scrolls exactly one copy width then loops --- */
@keyframes sp-scroll {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}

/* --- Individual item ---------------------------------------- */
.sp-item {
	flex-shrink: 0;
	display:     flex;
	align-items: center;
}

.sp-item a {
	display:      flex;
	align-items:  center;
	text-decoration: none;
}

/* --- Logo image --------------------------------------------- */
.sp-logo {
	display:    block;
	height:     var(--sp-height);
	width:      auto;
	max-width:  180px;
	object-fit: contain;
	transition: filter 0.3s ease, opacity 0.3s ease;
}

/* Grayscale modifier */
.sp-grayscale {
	filter:  grayscale(100%);
	opacity: 0.6;
}

.sp-item:hover .sp-grayscale {
	filter:  none;
	opacity: 1;
}

/* --- Text fallback (when no logo image is set) -------------- */
.sp-logo-text {
	display:     flex;
	align-items: center;
	height:      var(--sp-height);
	font-size:   1.1rem;
	font-weight: 600;
	color:       #555;
	white-space: nowrap;
	transition:  color 0.3s ease;
}

.sp-item:hover .sp-logo-text {
	color: #111;
}

/* --- Empty state -------------------------------------------- */
.sp-empty {
	text-align: center;
	color: #999;
	padding: 2rem;
	font-size: 0.9rem;
}

/* --- Elementor editor notice -------------------------------- */
.sp-editor-notice {
	display:     flex;
	align-items: center;
	gap:         12px;
	padding:     20px 24px;
	border:      2px dashed #c8c8c8;
	border-radius: 6px;
	background:  #fafafa;
}

.sp-editor-notice .dashicons {
	font-size: 28px;
	color: #aaa;
}

.sp-editor-notice p {
	margin:    0;
	color:     #666;
	font-size: 13px;
}
