/*!
 * WooKit — Product Slider.
 * Touch-friendly product carousel. Native CSS scroll-snap gives us free
 * momentum + snapping on touch; JS layers on arrows/dots/autoplay/loop.
 * Card design reuses .wookit-product-grid-card (slider only changes layout).
 */

.wookit-product-slider {
	--per-view: var( --wookit-slider-per-view, 4 );
	--gap:      var( --wookit-slider-gap, 20px );
	font-family: var( --wookit-font, inherit ) !important;
	color: var( --wookit-body, inherit ) !important;
	position: relative;
	/* Container queries — layout reacts to the slider's own width, so it stays
	   sensible inside a narrow column / sidebar. */
	container-type: inline-size;
	container-name: wookit-slider;
}

.wookit-product-slider__heading {
	margin: 0 0 1rem !important;
	padding: 0 !important;
	font-family: inherit !important;
	font-size: clamp( 1.125rem, 0.95rem + 0.6cqi, 1.5rem ) !important;
	font-weight: 700 !important;
	line-height: 1.25 !important;
	color: var( --wookit-text, inherit ) !important;
	letter-spacing: -0.01em !important;
	text-transform: none !important;
}

/* ── Viewport (clipped) + arrows ─────────────────────────────────────────── */
.wookit-product-slider__viewport {
	position: relative;
	overflow: hidden;
}

.wookit-product-slider__arrow {
	position: absolute;
	top: 50%;
	transform: translateY( -50% );
	z-index: 2;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 40px !important;
	height: 40px !important;
	min-height: 0 !important;
	padding: 0 !important;
	margin: 0 !important;
	font-family: inherit !important;
	font-size: 0 !important;
	line-height: 1 !important;
	color: var( --wookit-text, #1f2937 ) !important;
	background: var( --wookit-surface, #fff ) !important;
	border: 1px solid var( --wookit-border, rgba( 0, 0, 0, 0.08 ) ) !important;
	border-radius: 999px !important;
	box-shadow: 0 4px 14px rgba( 0, 0, 0, 0.08 ) !important;
	cursor: pointer !important;
	outline: none !important;
	text-decoration: none !important;
	text-shadow: none !important;
	letter-spacing: normal !important;
	text-transform: none !important;
	transition: background-color 150ms ease, transform 150ms ease, opacity 150ms ease !important;
	-webkit-tap-highlight-color: transparent !important;
}

.wookit-product-slider__arrow svg {
	display: block;
	pointer-events: none;
}

.wookit-product-slider__arrow--prev { left: 8px; }
.wookit-product-slider__arrow--next { right: 8px; }

@media ( hover: hover ) and ( pointer: fine ) {
	.wookit-product-slider__arrow:hover {
		background: var( --wookit-accent, #1f2937 ) !important;
		color: var( --wookit-accent-fg, #fff ) !important;
		border-color: var( --wookit-accent, #1f2937 ) !important;
	}
}

.wookit-product-slider__arrow:focus-visible {
	box-shadow: 0 0 0 3px var( --wookit-accent, #1f2937 ) !important;
}

/* Hide arrows on small containers — they crowd the cards. */
@container wookit-slider ( max-width: 480px ) {
	.wookit-product-slider__arrow {
		display: none !important;
	}
}

/* ── Track + slides ──────────────────────────────────────────────────────── */
.wookit-product-slider__track {
	display: flex;
	flex-wrap: nowrap;
	gap: var( --gap );
	margin: 0 !important;
	padding: 0 !important;
	list-style: none !important;
	overflow-x: auto;
	overflow-y: hidden;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	scrollbar-width: none;             /* Firefox */
	-ms-overflow-style: none;          /* IE / old Edge */
	-webkit-overflow-scrolling: touch; /* iOS momentum */
	overscroll-behavior-x: contain;
	cursor: grab !important;
}

.wookit-product-slider__track::-webkit-scrollbar { display: none; }

.wookit-product-slider__track.is-dragging {
	cursor: grabbing !important;
	scroll-snap-type: none;            /* don't fight the user mid-drag */
	scroll-behavior: auto;
}

.wookit-product-slider__slide {
	margin: 0 !important;
	padding: 0 !important;
	list-style: none !important;
	/* per_view items visible, accounting for the inter-slide gap.
	   ((100% - gap*(n-1)) / n) is the exact width per slide. */
	flex: 0 0 calc( ( 100% - ( var( --gap ) * ( var( --per-view ) - 1 ) ) ) / var( --per-view ) );
	max-width: calc( ( 100% - ( var( --gap ) * ( var( --per-view ) - 1 ) ) ) / var( --per-view ) );
	scroll-snap-align: start;
	scroll-snap-stop: always;
	display: flex;
	flex-direction: column;
	gap: clamp( 0.875rem, 1.4cqi, 1.125rem );
}

.wookit-product-slider__slide::before { content: none !important; }

/* ── Container breakpoints (cap per_view as width shrinks) ───────────────── */
@container wookit-slider ( max-width: 960px ) {
	.wookit-product-slider__slide {
		flex-basis: calc( ( 100% - ( var( --gap ) * 2 ) ) / 3 );
		max-width:  calc( ( 100% - ( var( --gap ) * 2 ) ) / 3 );
	}
}

@container wookit-slider ( max-width: 640px ) {
	.wookit-product-slider__slide {
		flex-basis: calc( ( 100% - var( --gap ) ) / 2 );
		max-width:  calc( ( 100% - var( --gap ) ) / 2 );
	}
}

@container wookit-slider ( max-width: 380px ) {
	.wookit-product-slider__slide {
		flex-basis: 100%;
		max-width: 100%;
	}
}

/* ── Dots ────────────────────────────────────────────────────────────────── */
.wookit-product-slider__dots {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 0.5rem;
	margin-top: 0.875rem !important;
}

.wookit-product-slider__dot {
	width: 8px !important;
	height: 8px !important;
	min-height: 0 !important;
	padding: 0 !important;
	margin: 0 !important;
	border: 0 !important;
	border-radius: 999px !important;
	background: var( --wookit-border, #d1d5db ) !important;
	box-shadow: none !important;
	cursor: pointer !important;
	outline: none !important;
	transition: background-color 150ms ease, transform 150ms ease !important;
	-webkit-tap-highlight-color: transparent !important;
	font-size: 0 !important;
	line-height: 0 !important;
}

.wookit-product-slider__dot.is-active {
	background: var( --wookit-accent, #1f2937 ) !important;
	transform: scale( 1.25 );
}

.wookit-product-slider__dot:focus-visible {
	box-shadow: 0 0 0 3px var( --wookit-accent, #1f2937 ) !important;
}

/* ── Empty state ─────────────────────────────────────────────────────────── */
.wookit-product-slider__empty {
	text-align: center !important;
	padding: 2rem 1rem !important;
	color: var( --wookit-muted, #6b7280 ) !important;
	font-size: 0.9375rem !important;
}

/* Reduced motion — kill smooth scroll & autoplay transitions */
@media ( prefers-reduced-motion: reduce ) {
	.wookit-product-slider__track {
		scroll-behavior: auto;
	}
	.wookit-product-slider__arrow,
	.wookit-product-slider__dot {
		transition: none !important;
	}
}
