/* ─── Ecto Image Slider ─── */

.ecto-is-wrap {
	--ecto-is-duration: 40s;
	--ecto-is-gap: 64px;
	--ecto-is-img-height: 40px;
	--ecto-is-fade-width: 120px;
	--ecto-is-fade-color: #ffffff;

	display: flex;
	align-items: center;
	width: 100%;
	overflow: hidden;
	position: relative;
	box-sizing: border-box;
}

.ecto-is-wrap--border {
	border-bottom: 1px solid #f4f4f5;
}

/* ── Label ── */

.ecto-is-label {
	flex-shrink: 0;
	font-size: 16px;
	font-weight: 500;
	line-height: 1.5;
	color: #4a5568;
	white-space: nowrap;
	padding-right: 32px;
	position: relative;
	z-index: 2;
}

/* ── Outer (clip area) ── */

.ecto-is-outer {
	flex: 1 1 auto;
	min-width: 0;
	overflow: hidden;
	position: relative;
}

/* ── Gradient fades ── */

.ecto-is-fade {
	position: absolute;
	top: 0;
	bottom: 0;
	width: var(--ecto-is-fade-width, 120px);
	z-index: 2;
	pointer-events: none;
}

.ecto-is-fade--left {
	left: 0;
	background: linear-gradient(to right, var(--ecto-is-fade-color, #ffffff) 0%, transparent 100%);
}

.ecto-is-fade--right {
	right: 0;
	background: linear-gradient(to left, var(--ecto-is-fade-color, #ffffff) 0%, transparent 100%);
}

/* ── Scrolling inner ── */

.ecto-is-inner {
	display: flex;
	align-items: center;
	width: max-content;
	will-change: transform;
	animation: ecto-is-scroll var(--ecto-is-duration, 40s) linear infinite;
}

@keyframes ecto-is-scroll {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}

.ecto-is-wrap[data-direction="right"] .ecto-is-inner {
	animation-direction: reverse;
}

.ecto-is-wrap[data-pause-hover="yes"]:hover .ecto-is-inner {
	animation-play-state: paused;
}

/* ── Item ── */

.ecto-is-item {
	display: flex;
	align-items: center;
	flex-shrink: 0;
	margin-right: var(--ecto-is-gap, 64px);
}

.ecto-is-item a {
	display: flex;
	align-items: center;
	text-decoration: none;
	outline-offset: 4px;
}

.ecto-is-item img {
	display: block;
	height: var(--ecto-is-img-height, 40px);
	width: auto;
	max-width: none;
	object-fit: contain;
	transition: opacity 0.3s ease, filter 0.3s ease;
	user-select: none;
	-webkit-user-drag: none;
	pointer-events: none;
}

/* Grayscale mode */

.ecto-is-wrap--grayscale .ecto-is-item img {
	filter: grayscale(100%);
}

.ecto-is-wrap--grayscale .ecto-is-item:hover img {
	filter: grayscale(0%);
}
