/**
 * Custom Accordion Pro - In-place sliding accordion.
 * Cards never move in DOM. cap-passed = before active (flipped, icon/right visible).
 * cap-preview = after active (icon/right visible). cap-active = current.
 *
 * @package Custom_Accordion_Pro
 * @author Md. Saidur Rahman
 * @link https://saidur-it.vercel.app/
 */

.cap-accordion-wrapper {
	width: 100%;
	max-width: 100%;
	overflow: hidden;
}

.cap-accordion {
	--cap-strip-pct: 14;
	--cap-count: 4;
	--cap-card-pct: calc((100 + (var(--cap-count) - 1) * var(--cap-strip-pct)) / var(--cap-count));
	position: relative;
	width: 100%;
	height: 420px;
	overflow: hidden;
}

.cap-card {
	position: absolute;
	left: calc(var(--cap-index, 0) * (var(--cap-card-pct) - var(--cap-strip-pct)) * 1%);
	top: 0;
	width: calc(var(--cap-card-pct) * 1%);
	height: 100%;
	display: flex;
	align-items: stretch;
	justify-content: center;
	overflow: hidden;
	padding: 20px;
	box-sizing: border-box;
	transition: left 0.45s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.4s ease, background-color 0.35s ease, z-index 0s;
}

/* Inactive upcoming cards: strip on right */
.cap-card.cap-preview {
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08), 2px 0 12px rgba(0, 0, 0, 0.06);
}

/* Active card */
.cap-card.cap-active {
	box-shadow: 0 12px 48px rgba(0, 0, 0, 0.18), 0 4px 24px rgba(0, 0, 0, 0.12);
}

/* Already-seen cards (before active): same strip appearance as preview */
.cap-card.cap-passed {
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08), -2px 0 12px rgba(0, 0, 0, 0.06);
	background-color: #eeeeee; /* fallback — overridden by Elementor inactive color */
}

.cap-card .cap-full-content {
	display: flex;
	width: 100%;
	height: 100%;
	opacity: 1;
}

/* Preview and passed cards: hide nav btn but keep space (so icon position matches active card) */
.cap-card.cap-preview .cap-nav-btn,
.cap-card.cap-passed .cap-nav-btn {
	pointer-events: none;
	visibility: hidden;
}

/* ALL inactive cards: hide text area */
.cap-card.cap-preview .cap-content-left,
.cap-card.cap-passed .cap-content-left {
	opacity: 0;
}

/*
 * PASSED cards: flip row so icon (cap-content-right) moves to the LEFT edge.
 * This makes it visible in the left strip (the only exposed part of a passed card).
 * Icon vertical position (top/center/bottom) stays exactly the same as active card
 * because the layout structure is identical — only the row direction is reversed.
 */
.cap-card.cap-passed .cap-full-content {
	flex-direction: row-reverse;
}

/* Previous button: rotate icon to point left */
.cap-card.cap-active .cap-btn-prev img,
.cap-card.cap-active .cap-btn-prev .cap-nav-arrow {
	transform: rotate(180deg);
}

/* Next button: normal direction */
.cap-card.cap-active .cap-btn-next img,
.cap-card.cap-active .cap-btn-next .cap-nav-arrow {
	transform: rotate(0deg);
}

.cap-content-left {
	width: 75%;
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	padding-right: 20px;
	overflow: hidden;
	min-width: 0;
	flex-shrink: 1;
	transition: opacity 0.3s ease;
}

.cap-main-image {
	width: 100%;
	object-fit: cover;
	margin-bottom: 12px;
}

.cap-title {
	margin: 0 0 8px;
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1.2;
}

.cap-description {
	margin: 0;
	font-size: 0.95rem;
	line-height: 1.5;
}

.cap-content-right {
	width: 25%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: space-between;
	flex-shrink: 0;
}

.cap-content-right .cap-icon-wrap {
	display: flex;
	flex: 1;
	align-items: center;
	justify-content: center;
}

.cap-content-right.cap-icon-pos-top .cap-icon-wrap {
	align-items: flex-start;
}

.cap-content-right.cap-icon-pos-center .cap-icon-wrap {
	align-items: center;
}

.cap-content-right.cap-icon-pos-bottom .cap-icon-wrap {
	align-items: flex-end;
}

.cap-content-right .cap-icon {
	width: 48px;
	height: 48px;
	object-fit: contain;
}

.cap-nav-btn {
	background: transparent !important;
	border: none !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	cursor: pointer;
	padding: 0 !important;
	margin: 0 !important;
	min-width: 0;
	min-height: 0;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: opacity 0.2s ease;
	flex-shrink: 0;
}

.cap-nav-btn:hover {
	opacity: 0.7;
}

.cap-nav-btn:focus {
	outline: 2px solid currentColor;
	outline-offset: 2px;
}

.cap-nav-btn:focus:not(:focus-visible) {
	outline: none;
}

.cap-nav-btn img {
	display: block;
}

.cap-nav-arrow {
	font-size: 24px;
	line-height: 1;
}

/* Mobile: active card on top, passed cards above (hidden), preview cards below — smooth translateY slide */
@media screen and (max-width: 768px) {
	.cap-accordion-wrapper,
	.elementor-widget-container .cap-accordion-wrapper {
		--cap-mobile-card-height: 220px;
		height: calc(2 * var(--cap-mobile-card-height)) !important;
		min-height: calc(2 * var(--cap-mobile-card-height));
		overflow: hidden !important;
		position: relative !important;
	}

	/* accordion becomes a positioned container for absolute cards */
	.cap-accordion-wrapper .cap-accordion,
	.elementor-widget-container .cap-accordion-wrapper .cap-accordion {
		position: relative !important;
		width: 100% !important;
		height: 100% !important;
		overflow: hidden !important;
	}

	/* All cards: absolute, full width, stacked vertically by --cap-mobile-index */
	.cap-accordion-wrapper .cap-accordion .cap-card,
	.elementor-widget-container .cap-accordion-wrapper .cap-accordion .cap-card {
		position: absolute !important;
		left: 0 !important;
		right: 0 !important;
		width: 100% !important;
		min-width: 0 !important;
		max-width: none !important;
		height: var(--cap-mobile-card-height) !important;
		min-height: var(--cap-mobile-card-height) !important;
		box-sizing: border-box !important;
		transition: top 0.45s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.35s ease !important;
	}

	/* Active card: always at top (position 0) */
	.cap-accordion-wrapper .cap-accordion .cap-card.cap-active,
	.elementor-widget-container .cap-accordion-wrapper .cap-accordion .cap-card.cap-active {
		top: 0 !important;
		opacity: 1 !important;
		box-shadow: 0 4px 20px rgba(0, 0, 0, 0.12);
	}

	/* Preview cards (after active): stacked below, each offset by card height */
	.cap-accordion-wrapper .cap-accordion .cap-card.cap-preview,
	.elementor-widget-container .cap-accordion-wrapper .cap-accordion .cap-card.cap-preview {
		top: calc((var(--cap-mobile-pos, 1)) * var(--cap-mobile-card-height)) !important;
		opacity: 1 !important;
		box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
	}

	/* Passed cards (before active): hidden above viewport */
	.cap-accordion-wrapper .cap-accordion .cap-card.cap-passed,
	.elementor-widget-container .cap-accordion-wrapper .cap-accordion .cap-card.cap-passed {
		top: calc(-1 * var(--cap-mobile-card-height)) !important;
		opacity: 0 !important;
		pointer-events: none !important;
	}

	/* Active card nav button: always visible */
	.cap-accordion-wrapper .cap-accordion .cap-card.cap-active .cap-nav-btn,
	.elementor-widget-container .cap-accordion-wrapper .cap-accordion .cap-card.cap-active .cap-nav-btn {
		pointer-events: auto !important;
		opacity: 1 !important;
		visibility: visible !important;
	}

	/* Inactive (preview & passed) cards: hide nav btn */
	.cap-accordion-wrapper .cap-accordion .cap-card.cap-preview .cap-nav-btn,
	.cap-accordion-wrapper .cap-accordion .cap-card.cap-passed .cap-nav-btn,
	.elementor-widget-container .cap-accordion-wrapper .cap-accordion .cap-card.cap-preview .cap-nav-btn,
	.elementor-widget-container .cap-accordion-wrapper .cap-accordion .cap-card.cap-passed .cap-nav-btn {
		display: none !important;
	}

	/* Preview & passed: hide left content; keep layout via opacity so icon stays aligned */
	.cap-accordion-wrapper .cap-accordion .cap-card.cap-preview .cap-content-left,
	.cap-accordion-wrapper .cap-accordion .cap-card.cap-passed .cap-content-left,
	.elementor-widget-container .cap-accordion-wrapper .cap-accordion .cap-card.cap-preview .cap-content-left,
	.elementor-widget-container .cap-accordion-wrapper .cap-accordion .cap-card.cap-passed .cap-content-left {
		opacity: 0 !important;
	}

	/* Passed cards mobile: flip row-reverse here too */
	.cap-accordion-wrapper .cap-accordion .cap-card.cap-passed .cap-full-content,
	.elementor-widget-container .cap-accordion-wrapper .cap-accordion .cap-card.cap-passed .cap-full-content {
		flex-direction: row-reverse !important;
	}

	.cap-accordion-wrapper .cap-accordion .cap-card.cap-preview .cap-content-right,
	.cap-accordion-wrapper .cap-accordion .cap-card.cap-passed .cap-content-right,
	.elementor-widget-container .cap-accordion-wrapper .cap-accordion .cap-card.cap-preview .cap-content-right,
	.elementor-widget-container .cap-accordion-wrapper .cap-accordion .cap-card.cap-passed .cap-content-right {
		position: relative !important;
		left: auto !important;
		right: auto !important;
		top: auto !important;
		bottom: auto !important;
		width: 100% !important;
		flex-direction: column !important;
		justify-content: center !important;
		align-items: center !important;
	}

	.cap-accordion-wrapper .cap-accordion .cap-card.cap-preview .cap-icon-wrap,
	.cap-accordion-wrapper .cap-accordion .cap-card.cap-passed .cap-icon-wrap,
	.elementor-widget-container .cap-accordion-wrapper .cap-accordion .cap-card.cap-preview .cap-icon-wrap,
	.elementor-widget-container .cap-accordion-wrapper .cap-accordion .cap-card.cap-passed .cap-icon-wrap {
		flex: none;
	}

	/* Mobile: active card nav button — Next points down (↓), Prev points up (↑) */
	.cap-accordion-wrapper .cap-accordion .cap-card.cap-active .cap-btn-next img,
	.cap-accordion-wrapper .cap-accordion .cap-card.cap-active .cap-btn-next .cap-nav-arrow,
	.elementor-widget-container .cap-accordion-wrapper .cap-accordion .cap-card.cap-active .cap-btn-next img,
	.elementor-widget-container .cap-accordion-wrapper .cap-accordion .cap-card.cap-active .cap-btn-next .cap-nav-arrow {
		transform: rotate(90deg) !important;
	}

	.cap-accordion-wrapper .cap-accordion .cap-card.cap-active .cap-btn-prev img,
	.cap-accordion-wrapper .cap-accordion .cap-card.cap-active .cap-btn-prev .cap-nav-arrow,
	.elementor-widget-container .cap-accordion-wrapper .cap-accordion .cap-card.cap-active .cap-btn-prev img,
	.elementor-widget-container .cap-accordion-wrapper .cap-accordion .cap-card.cap-active .cap-btn-prev .cap-nav-arrow {
		transform: rotate(-90deg) !important;
	}

	/* Mobile: active card – icon at bottom */
	.cap-accordion-wrapper .cap-accordion .cap-card.cap-active .cap-content-right,
	.elementor-widget-container .cap-accordion-wrapper .cap-accordion .cap-card.cap-active .cap-content-right {
		flex-direction: column-reverse !important;
	}
}
