/**
 * SC slideshow — frontend styles.
 * Container-agnostic, responsive from phones to 4K TVs.
 */

.sc-slideshow {
	position: relative;
	overflow: hidden;
	background: linear-gradient(160deg, var(--sc-bg1, #050d1f) 0%, var(--sc-bg2, #0a1e3f) 100%);
	color: #fff;
	border-radius: 18px;
	isolation: isolate;
}

/* Full-width breakout: escapes any parent container. */
.sc-slideshow--full {
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	border-radius: 0;
}

.sc-dna-canvas {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	z-index: 0;
	pointer-events: none;
}

.sc-slideshow__inner {
	position: relative;
	z-index: 1;
	max-width: 1400px; /* cap so 4K TVs don't get absurd product sizes */
	margin: 0 auto;
	padding: clamp(1.25rem, 3vw, 3rem);
}

.sc-slideshow__heading {
	margin: 0 0 clamp(0.75rem, 2vw, 1.5rem);
	font-size: clamp(1.4rem, 3.5vw, 2.4rem);
	font-weight: 700;
	letter-spacing: 0.02em;
	color: #fff;
	text-shadow: 0 0 24px color-mix(in srgb, var(--sc-accent, #22d3ee) 45%, transparent);
}

/* ---- Track / slides ---- */

.sc-viewport {
	overflow: hidden;
	touch-action: pan-y; /* keep vertical page scroll on touch */
}

.sc-track {
	display: flex;
	margin: 0;
	padding: 0;
	list-style: none;
	transition: transform 0.55s cubic-bezier(0.22, 1, 0.36, 1);
	will-change: transform;
}

.sc-slide {
	flex: 0 0 100%;
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(1rem, 2.5vw, 2.5rem);
	align-items: center;
	margin: 0;
	padding: 0 2px;
	opacity: 0.4;
	transition: opacity 0.45s ease;
}

.sc-slide.is-active {
	opacity: 1;
}

@media (min-width: 768px) {
	.sc-slide {
		grid-template-columns: minmax(0, 5fr) minmax(0, 6fr);
	}
}

.sc-slide__media {
	position: relative;
	display: flex;
	justify-content: center;
}

.sc-slide__img {
	display: block;
	width: 100%;
	max-width: min(600px, 100%);
	height: auto;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	border-radius: 14px;
	box-shadow:
		0 20px 50px rgba(0, 0, 0, 0.45),
		0 0 0 1px color-mix(in srgb, var(--sc-accent, #22d3ee) 25%, transparent),
		0 0 60px -20px var(--sc-accent, #22d3ee);
	background: rgba(255, 255, 255, 0.04);
}

.sc-slide__img--placeholder {
	min-height: 240px;
}

/* ---- Badges ---- */

.sc-badge {
	position: absolute;
	top: 0.9rem;
	padding: 0.35em 0.9em;
	font-size: clamp(0.7rem, 1.2vw, 0.85rem);
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	border-radius: 999px;
	backdrop-filter: blur(6px);
}

.sc-badge--rank {
	left: 0.9rem;
	background: color-mix(in srgb, var(--sc-accent, #22d3ee) 85%, #000);
	color: #04121a;
}

.sc-badge--sale {
	right: 0.9rem;
	background: color-mix(in srgb, var(--sc-accent2, #818cf8) 85%, #000);
	color: #0b0620;
}

/* ---- Slide body ---- */

.sc-slide__body {
	text-align: center;
}

@media (min-width: 768px) {
	.sc-slide__body {
		text-align: left;
	}
}

.sc-slide__title {
	margin: 0 0 0.5rem;
	font-size: clamp(1.5rem, 4vw, 3rem);
	line-height: 1.15;
	font-weight: 800;
}

.sc-slide__link {
	color: #fff;
	text-decoration: none;
}

.sc-slide__link:hover,
.sc-slide__link:focus-visible {
	color: var(--sc-accent, #22d3ee);
}

.sc-slide__price {
	margin: 0 0 clamp(1rem, 2vw, 1.75rem);
	font-size: clamp(1.1rem, 2.2vw, 1.6rem);
	font-weight: 600;
	color: var(--sc-accent, #22d3ee);
}

.sc-slide__price del {
	color: rgba(255, 255, 255, 0.45);
	font-weight: 400;
	margin-right: 0.4em;
}

.sc-slide__price ins {
	text-decoration: none;
}

.sc-slide__cta {
	display: inline-flex;
	align-items: center;
	gap: 0.5em;
	padding: 0.8em 1.7em;
	font-size: clamp(0.95rem, 1.6vw, 1.15rem);
	font-weight: 700;
	color: #04121a;
	background: linear-gradient(120deg, var(--sc-accent, #22d3ee), var(--sc-accent2, #818cf8));
	border-radius: 999px;
	text-decoration: none;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
	box-shadow: 0 8px 30px -8px var(--sc-accent, #22d3ee);
}

.sc-slide__cta:hover,
.sc-slide__cta:focus-visible {
	transform: translateY(-2px);
	box-shadow: 0 14px 40px -8px var(--sc-accent, #22d3ee);
	color: #04121a;
}

.sc-slide__cta-arrow {
	transition: transform 0.25s ease;
}

.sc-slide__cta:hover .sc-slide__cta-arrow {
	transform: translateX(4px);
}

/* ---- Controls (mouse, touch, keyboard, and TV/console D-pad) ---- */

.sc-controls {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: clamp(0.75rem, 2vw, 1.5rem);
	margin-top: clamp(1rem, 2.5vw, 2rem);
}

.sc-arrow {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: clamp(2.5rem, 4vw, 3.25rem);
	height: clamp(2.5rem, 4vw, 3.25rem);
	font-size: 1rem;
	color: #fff;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 50%;
	cursor: pointer;
	transition: background 0.2s ease, border-color 0.2s ease;
}

.sc-arrow:hover {
	background: rgba(255, 255, 255, 0.18);
	border-color: var(--sc-accent, #22d3ee);
}

.sc-dots {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.55rem;
}

.sc-dot {
	width: 0.65rem;
	height: 0.65rem;
	padding: 0;
	background: rgba(255, 255, 255, 0.28);
	border: none;
	border-radius: 50%;
	cursor: pointer;
	transition: transform 0.2s ease, background 0.2s ease;
}

.sc-dot:hover {
	background: rgba(255, 255, 255, 0.6);
}

.sc-dot.is-active {
	background: var(--sc-accent, #22d3ee);
	transform: scale(1.35);
	box-shadow: 0 0 12px var(--sc-accent, #22d3ee);
}

/* Big, obvious focus rings — critical for D-pad/remote navigation. */
.sc-slideshow :is(a, button):focus-visible {
	outline: 3px solid var(--sc-accent, #22d3ee);
	outline-offset: 3px;
}

/* ---- Reduced motion ---- */

@media (prefers-reduced-motion: reduce) {
	.sc-track {
		transition: none;
	}

	.sc-slide,
	.sc-slide__cta,
	.sc-slide__cta-arrow,
	.sc-dot {
		transition: none;
	}
}
