/* Slava Big Carousel — Elementor Widget */

.slava-big-carousel {
	--accent-rgb: 214, 156, 116;
	--text: #f6efe6;
	position: relative;
	width: 100%;
	overflow: clip;
}

/* Placeholder (editor only) */
.slava-big-carousel__placeholder {
	display: grid;
	place-items: center;
	min-height: 320px;
	border: 2px dashed rgba(0, 0, 0, 0.15);
	border-radius: 1rem;
	color: #666;
	font-size: 0.95rem;
}

/* ── Viewport ── */
.slava-big-carousel__viewport {
	position: relative;
	height: clamp(420px, 68vh, 740px);
	padding: 2rem 0;
	overflow: visible;
	touch-action: pan-y;
	perspective: 1400px;
}

/* ── Halo glow ── */
.slava-big-carousel__halo {
	position: absolute;
	left: 50%;
	top: 48%;
	width: min(60vw, 620px);
	aspect-ratio: 1;
	transform: translate(-50%, -50%);
	border-radius: 50%;
	background: radial-gradient(
		circle,
		rgba(var(--accent-rgb), 0.25) 0%,
		rgba(var(--accent-rgb), 0.06) 40%,
		transparent 72%
	);
	filter: blur(12px);
	pointer-events: none;
	z-index: 0;
}

/* ── 3D Track ── */
.slava-big-carousel__track {
	position: absolute;
	inset: 0;
	transform-style: preserve-3d;
}

/* ── Slides ── */
.slava-big-carousel__slide {
	position: absolute;
	top: 50%;
	left: 50%;
	width: clamp(190px, 22vw, 310px);
	padding: 0;
	border: 0;
	background: none;
	transform:
		translate(-50%, -50%)
		translateX(calc(var(--offset, 0) * min(18vw, 220px)))
		translateY(calc(var(--abs, 0) * 18px))
		scale(calc(1 - (var(--abs, 0) * 0.13)))
		rotateY(calc(var(--offset, 0) * -15deg))
		rotateZ(calc(var(--offset, 0) * 1.2deg));
	opacity: calc(1 - (var(--abs, 0) * 0.15));
	filter:
		saturate(calc(1 - (var(--abs, 0) * 0.06)))
		brightness(calc(1 - (var(--abs, 0) * 0.06)));
	transition:
		transform 900ms cubic-bezier(0.2, 0.82, 0.2, 1),
		opacity 900ms cubic-bezier(0.2, 0.82, 0.2, 1),
		filter 900ms cubic-bezier(0.2, 0.82, 0.2, 1);
}

.slava-big-carousel__slide[data-hidden="true"] {
	opacity: 0;
	pointer-events: none;
}

/* ── Card frame ── */
.slava-big-carousel__card {
	position: relative;
	overflow: visible;
	border-radius: 1.8rem;
	background: linear-gradient(
		180deg,
		rgba(255, 255, 255, 0.15),
		rgba(255, 255, 255, 0.02)
	);
	padding: 0.6rem;
}

.slava-big-carousel__card::before {
	content: "";
	position: absolute;
	inset: 0.55rem;
	border-radius: 1.35rem;
	border: 1px solid rgba(255, 255, 255, 0.12);
	pointer-events: none;
}

/* Reflection */
.slava-big-carousel__card::after {
	content: "";
	position: absolute;
	left: 7%;
	right: 7%;
	top: calc(100% + 0.75rem);
	height: 28%;
	border-radius: 1.25rem;
	background-image: var(--img-url);
	background-position: center;
	background-size: cover;
	transform: scaleY(-1);
	opacity: 0.32;
	filter: blur(3px) saturate(0.9);
	mask-image: linear-gradient(to bottom, rgba(255, 255, 255, 0.48), transparent 90%);
	pointer-events: none;
}


.slava-big-carousel__slide,
.slava-big-carousel__slide:hover,
.slava-big-carousel__slide:focus,
.slava-big-carousel__slide:focus-visible,
.slava-big-carousel__slide:active,
.slava-big-carousel__slide *,
.slava-big-carousel__slide *:hover,
.slava-big-carousel__slide *:focus {
	outline: none !important;
	border-color: transparent !important;
	box-shadow: none !important;
}

.slava-big-carousel__slide img {
	display: block;
	width: 100%;
	aspect-ratio: 3 / 4;
	object-fit: cover;
	border-radius: 1.4rem;
}

/* ── Navigation buttons ── */
.slava-big-carousel__nav {
	position: absolute;
	top: 50%;
	z-index: 70;
	width: 3.5rem;
	height: 3.5rem;
	display: grid;
	place-items: center;
	border-radius: 50%;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.03)),
		rgba(6, 6, 10, 0.55);
	color: var(--text);
	border: 1px solid rgba(255, 255, 255, 0.08);
	box-shadow:
		0 18px 30px rgba(0, 0, 0, 0.2),
		inset 0 1px 0 rgba(255, 255, 255, 0.08);
	transform: translateY(-50%);
	cursor: pointer;
	font: inherit;
	font-size: 1.2rem;
}

.slava-big-carousel__nav,
.slava-big-carousel__nav:hover,
.slava-big-carousel__nav:focus,
.slava-big-carousel__nav:focus-visible,
.slava-big-carousel__nav:active {
	outline: none !important;
}

.slava-big-carousel__nav[data-direction="prev"] {
	left: 1.4rem;
}

.slava-big-carousel__nav[data-direction="next"] {
	right: 1.4rem;
}

/* ── Responsive ── */
@media (max-width: 1040px) {
	.slava-big-carousel__slide {
		width: clamp(170px, 26vw, 270px);
	}
}

@media (max-width: 720px) {
	.slava-big-carousel__viewport {
		height: clamp(360px, 60vh, 540px);
	}

	.slava-big-carousel__slide {
		width: clamp(150px, 42vw, 230px);
		transform:
			translate(-50%, -50%)
			translateX(calc(var(--offset, 0) * min(28vw, 160px)))
			translateY(calc(var(--abs, 0) * 14px))
			scale(calc(1 - (var(--abs, 0) * 0.16)))
			rotateY(calc(var(--offset, 0) * -14deg))
			rotateZ(calc(var(--offset, 0) * 1.1deg));
	}

	.slava-big-carousel__nav {
		width: 3rem;
		height: 3rem;
	}

	.slava-big-carousel__nav[data-direction="prev"] {
		left: 0.6rem;
	}

	.slava-big-carousel__nav[data-direction="next"] {
		right: 0.6rem;
	}
}

@media (max-width: 480px) {
	.slava-big-carousel__viewport {
		height: clamp(300px, 55vh, 440px);
		padding: 1.5rem 0;
	}

	.slava-big-carousel__slide {
		width: clamp(130px, 48vw, 190px);
		transform:
			translate(-50%, -50%)
			translateX(calc(var(--offset, 0) * min(24vw, 120px)))
			translateY(calc(var(--abs, 0) * 10px))
			scale(calc(1 - (var(--abs, 0) * 0.18)))
			rotateY(calc(var(--offset, 0) * -12deg))
			rotateZ(calc(var(--offset, 0) * 0.8deg));
	}

	.slava-big-carousel__card {
		border-radius: 1.2rem;
		padding: 0.4rem;
	}

	.slava-big-carousel__card::before {
		inset: 0.35rem;
		border-radius: 0.9rem;
	}

	.slava-big-carousel__slide img {
		border-radius: 0.9rem;
	}

	.slava-big-carousel__nav {
		width: 2.5rem;
		height: 2.5rem;
		font-size: 1rem;
	}

	.slava-big-carousel__nav[data-direction="prev"] {
		left: 0.4rem;
	}

	.slava-big-carousel__nav[data-direction="next"] {
		right: 0.4rem;
	}
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
	.slava-big-carousel__slide {
		transition: none;
	}

}
