/* ============================================================
   Kadence Category Slider Pro  •  slider.css  v3.0
   ============================================================ */

/* ── Variables ─────────────────────────────────────────────── */
:root {
	--kcs-accent:     #2563eb;
	--kcs-accent-rgb: 37, 99, 235;
	--kcs-radius:     12px;
	--kcs-nav:        46px;
	--kcs-img-h:      240px;
	--kcs-gap:        20px;
	--kcs-shadow:     0 2px 20px rgba(0,0,0,.08), 0 1px 4px rgba(0,0,0,.04);
	--kcs-shadow-hover: 0 12px 40px rgba(0,0,0,.14), 0 2px 8px rgba(0,0,0,.06);
}

/* ── Wrapper ────────────────────────────────────────────────── */
.kcs-wrap {
	position: relative;
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	padding-bottom: 52px; /* room for dots */
	/* Contain the swiper so slides never overflow the section */
	overflow: hidden;
	/* Add side padding so nav arrows don't get clipped */
	padding-left: 30px;
	padding-right: 30px;
}
.kcs-wrap *,
.kcs-wrap *::before,
.kcs-wrap *::after {
	box-sizing: border-box;
}

/* ── Swiper reset ───────────────────────────────────────────── */
.kcs-wrap .kcs-swiper {
	/* Never let swiper overflow the section width */
	overflow: hidden;
	width: 100%;
	max-width: 100%;
}
.kcs-wrap .swiper-wrapper {
	align-items: stretch;
}
.kcs-wrap .swiper-slide {
	height: auto;
	/* Prevent individual slides from overflowing */
	min-width: 0;
	flex-shrink: 0;
}

/* ── Card base ──────────────────────────────────────────────── */
.kcs-card {
	display: flex;
	flex-direction: column;
	height: 100%;
	border-radius: var(--kcs-radius);
	overflow: hidden;
	background: #fff;
	box-shadow: var(--kcs-shadow);
	/* hover lift (translateY) removed — was causing image section gap */
}

/* ── Image ──────────────────────────────────────────────────── */
.kcs-card__img {
	margin: 0;
	overflow: hidden;
	flex-shrink: 0;
	background: #f1f5f9;
}
.kcs-card__img img {
	width: 100%;
	height: var(--kcs-img-h);
	display: block;
	object-fit: cover;
	object-position: center;
	/* image zoom on hover removed — was causing oversized image section */
}


/* ── Card body ──────────────────────────────────────────────── */
.kcs-card__body {
	padding: 20px 22px 22px;
	display: flex;
	flex-direction: column;
	flex: 1;
	gap: 8px;
}
.kcs-card__title {
	margin: 0;
	font-size: 1.05rem;
	font-weight: 700;
	line-height: 1.35;
	color: #0f172a;
}
.kcs-card__excerpt {
	margin: 0;
	font-size: .875rem;
	line-height: 1.65;
	color: #475569;
	flex: 1;
}
.kcs-card__btn {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	align-self: flex-start;
	margin-top: 4px;
	padding: 9px 20px;
	border-radius: 100px;
	background: var(--kcs-accent);
	color: #fff !important;
	font-size: .85rem;
	font-weight: 600;
	text-decoration: none !important;
	letter-spacing: .01em;
	transition: background .2s, transform .2s;
}
.kcs-card__btn:hover {
	background: color-mix(in srgb, var(--kcs-accent) 80%, #000);
	transform: translateX(2px);
}
.kcs-btn-arrow {
	font-style: normal;
	transition: transform .2s;
}
.kcs-card__btn:hover .kcs-btn-arrow {
	transform: translateX(4px);
}

/* ─────────────────────────────────────────────────────────────
   Layout: Overlay
   ─────────────────────────────────────────────────────────────*/
.kcs-layout-overlay .kcs-card {
	position: relative;
}
.kcs-layout-overlay .kcs-card__img img {
	height: 340px;
	object-fit: cover;
	width: 100%;
}
.kcs-equal-h.kcs-layout-overlay .kcs-card__img img {
	height: var(--kcs-img-h);
}
.kcs-layout-overlay .kcs-card__body {
	position: absolute;
	bottom: 0; left: 0; right: 0;
	padding: 80px 22px 22px;
	background: linear-gradient(to top,
		rgba(0,0,0,.82) 0%,
		rgba(0,0,0,.4)  55%,
		transparent     100%
	);
	color: #fff;
}
.kcs-layout-overlay .kcs-card__title   { color: #fff; }
.kcs-layout-overlay .kcs-card__excerpt { color: rgba(255,255,255,.8); }
.kcs-layout-overlay .kcs-card__btn {
	background: rgba(255,255,255,.18);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	border: 1px solid rgba(255,255,255,.35);
}
.kcs-layout-overlay .kcs-card__btn:hover {
	background: rgba(255,255,255,.32);
}

/* ─────────────────────────────────────────────────────────────
   Layout: Minimal
   ─────────────────────────────────────────────────────────────*/
.kcs-layout-minimal .kcs-card {
	box-shadow: none;
	border: 1.5px solid #e2e8f0;
	background: #fafafa;
}
.kcs-layout-minimal .kcs-card:hover {
	border-color: var(--kcs-accent);
	box-shadow: 0 0 0 3px rgba( var(--kcs-accent-rgb), .12 );
}
.kcs-layout-minimal .kcs-card__btn {
	background: transparent;
	color: var(--kcs-accent) !important;
	border: 2px solid var(--kcs-accent);
	padding: 7px 18px;
}
.kcs-layout-minimal .kcs-card__btn:hover {
	background: var(--kcs-accent);
	color: #fff !important;
}

/* ─────────────────────────────────────────────────────────────
   Navigation buttons
   ─────────────────────────────────────────────────────────────*/
.kcs-nav {
	position: absolute;
	top: calc( ( var(--kcs-img-h, 240px) / 2 ) - ( var(--kcs-nav) / 2 ) );
	z-index: 20;
	display: flex;
	align-items: center;
	justify-content: center;
	width:  var(--kcs-nav);
	height: var(--kcs-nav);
	border-radius: 50%;
	background: #fff;
	border: none;
	cursor: pointer;
	padding: 0;
	box-shadow: 0 2px 12px rgba(0,0,0,.14);
	color: #0f172a;
	transition: background .2s, color .2s, transform .2s, box-shadow .2s;
}
/* Arrows sit inside the 30px padding zone on each side */
.kcs-nav--prev { left: 0; }
.kcs-nav--next { right: 0; }

.kcs-nav svg { width: 20px; height: 20px; }
.kcs-nav:hover {
	background: var(--kcs-accent);
	color: #fff;
	box-shadow: 0 4px 20px rgba( var(--kcs-accent-rgb), .4 );
	transform: scale(1.1);
}
.kcs-nav.swiper-button-disabled {
	opacity: .35;
	cursor: default;
	pointer-events: none;
}

/* ─────────────────────────────────────────────────────────────
   Pagination dots
   ─────────────────────────────────────────────────────────────*/
.kcs-dots {
	position: absolute !important;
	bottom: 14px !important;
	left: 0 !important;
	right: 0 !important;
	width: 100% !important;
	display: flex !important;
	align-items: center;
	justify-content: center;
	gap: 6px;
	pointer-events: none;
}
.kcs-dots .swiper-pagination-bullet {
	width: 7px;
	height: 7px;
	border-radius: 100px;
	background: #94a3b8;
	opacity: 1;
	transition: width .3s cubic-bezier(.22,1,.36,1), background .3s;
	cursor: pointer;
	pointer-events: all;
}
.kcs-dots .swiper-pagination-bullet-active {
	width: 22px;
	background: var(--kcs-accent);
}

/* ─────────────────────────────────────────────────────────────
   Empty state
   ─────────────────────────────────────────────────────────────*/
.kcs-empty {
	padding: 48px 32px;
	text-align: center;
	background: #f8fafc;
	border: 2px dashed #cbd5e1;
	border-radius: var(--kcs-radius);
	color: #64748b;
}
.kcs-empty svg {
	display: block;
	margin: 0 auto 14px;
	opacity: .4;
	color: #94a3b8;
}
.kcs-empty p {
	margin: 0;
	font-size: .9rem;
	line-height: 1.6;
	max-width: 420px;
	margin: 0 auto;
}
.kcs-empty p code {
	background: #e2e8f0;
	padding: 1px 6px;
	border-radius: 4px;
	font-size: .82rem;
	color: #334155;
}

/* ─────────────────────────────────────────────────────────────
   Responsive
   ─────────────────────────────────────────────────────────────*/
@media (max-width: 639px) {
	.kcs-wrap {
		padding-left:  24px;
		padding-right: 24px;
	}
	:root { --kcs-nav: 36px; }
	.kcs-card__body     { padding: 14px 16px 18px; }
	.kcs-card__title    { font-size: .95rem; }
	.kcs-card__excerpt  { font-size: .82rem; }
	.kcs-layout-overlay .kcs-card__img img { height: 220px; }
}
