/* ── CAHOPE Hero Slider ──────────────────────────────────────────────── */

.chs-slider {
	position: relative;
	width: 100%;
	height: 80vh;
	overflow: hidden;
	background: #000;
}

/* ── Track & Slides ──────────────────────────────────────────────────── */

.chs-track {
	position: absolute;
	inset: 0;
}

.chs-slide {
	position: absolute;
	inset: 0;
	z-index: 1;
	opacity: 0;
	transition: opacity var(--chs-trans, 1200ms) ease-in-out;
	pointer-events: none;
}

.chs-slide.is-active {
	opacity: 1;
	pointer-events: auto;
}

/* ── Background Image ────────────────────────────────────────────────── */

.chs-image {
	position: absolute;
	inset: -8%; /* breathing room for pan animations */
	background-size: cover;
	background-repeat: no-repeat;
	/* background-position set inline per slide */
	will-change: transform;
	transform-origin: center center;
}

/* ── Animation Keyframes ─────────────────────────────────────────────── */

@keyframes chs-zoom-in {
	from { transform: scale(1); }
	to   { transform: scale(var(--chs-scale, 1.15)); }
}

@keyframes chs-zoom-out {
	from { transform: scale(var(--chs-scale, 1.15)); }
	to   { transform: scale(1); }
}

@keyframes chs-pan-left {
	from { transform: translateX(5%); }
	to   { transform: translateX(0); }
}

@keyframes chs-pan-right {
	from { transform: translateX(-5%); }
	to   { transform: translateX(0); }
}

@keyframes chs-pan-top {
	from { transform: translateY(5%); }
	to   { transform: translateY(0); }
}

@keyframes chs-pan-bottom {
	from { transform: translateY(-5%); }
	to   { transform: translateY(0); }
}

/* Triggered by JS: stamp data-anim on .chs-image when slide becomes active */
.chs-slide.is-active .chs-image[data-anim="zoom-in"]  { animation: chs-zoom-in   var(--chs-anim-dur, 6s) ease-out forwards; }
.chs-slide.is-active .chs-image[data-anim="zoom-out"] { animation: chs-zoom-out  var(--chs-anim-dur, 6s) ease-out forwards; }
.chs-slide.is-active .chs-image[data-anim="left"]     { animation: chs-pan-left  var(--chs-anim-dur, 6s) ease-out forwards; }
.chs-slide.is-active .chs-image[data-anim="right"]    { animation: chs-pan-right var(--chs-anim-dur, 6s) ease-out forwards; }
.chs-slide.is-active .chs-image[data-anim="top"]      { animation: chs-pan-top   var(--chs-anim-dur, 6s) ease-out forwards; }
.chs-slide.is-active .chs-image[data-anim="bottom"]   { animation: chs-pan-bottom var(--chs-anim-dur, 6s) ease-out forwards; }

/* ── Gradient Overlay — always on top of all slides ─────────────────── */

.chs-overlay {
	position: absolute;
	inset: 0;
	z-index: 2;
	pointer-events: none;
	background: linear-gradient(
		to right,
		var(--chs-c-start, rgba(0,0,0,0.65)),
		var(--chs-c-end,   rgba(0,0,0,0.10))
	);
}

/* ── Arrows ──────────────────────────────────────────────────────────── */

.chs-arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	z-index: 10;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: rgba(255,255,255,0.15);
	border: 2px solid rgba(255,255,255,0.45);
	color: #fff;
	font-size: 2rem;
	line-height: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	backdrop-filter: blur(4px);
	transition: background 0.25s, border-color 0.25s;
}

.chs-arrow:hover,
.chs-arrow:focus-visible {
	background: rgba(255,255,255,0.35);
	border-color: #fff;
	outline: none;
}

.chs-arrow--prev { left: 1.25rem; }
.chs-arrow--next { right: 1.25rem; }

/* ── Dots ────────────────────────────────────────────────────────────── */

.chs-dots {
	position: absolute;
	bottom: 1.5rem;
	left: 50%;
	transform: translateX(-50%);
	z-index: 10;
	display: flex;
	gap: 0.5rem;
}

.chs-dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: rgba(255,255,255,0.40);
	border: 2px solid rgba(255,255,255,0.70);
	cursor: pointer;
	padding: 0;
	transition: background 0.25s, transform 0.25s;
}

.chs-dot.is-active,
.chs-dot:hover {
	background: #fff;
	transform: scale(1.3);
}

/* ── Mobile ──────────────────────────────────────────────────────────── */

@media (max-width: 767px) {
	.chs-image {
		inset: 0 !important;
		background-size: cover !important;
		background-position: center center !important;
		background-repeat: no-repeat !important;
		animation: none !important;
	}
}

/* ── Reduced Motion ──────────────────────────────────────────────────── */

@media (prefers-reduced-motion: reduce) {
	.chs-image { animation: none !important; }
	.chs-slide { transition: opacity 300ms ease-in-out; }
}
