/* ==========================================================================
   JL FAQ Section Widget
   Split layout (FAQs + image) or full-width (single or two-column FAQ list).
   ========================================================================== */

/* ── Zero out parent Elementor container padding ────────────────────────── */
.e-con:has(> .elementor-widget-jl-faq),
.e-con:has(> .e-con-inner > .elementor-widget-jl-faq),
.elementor-section:has(.elementor-widget-jl-faq) .elementor-container,
.elementor-section:has(.elementor-widget-jl-faq) .elementor-column,
.elementor-section:has(.elementor-widget-jl-faq) .elementor-widget-wrap {
	--padding-top: 0 !important;
	--padding-bottom: 0 !important;
	--padding-left: 0 !important;
	--padding-right: 0 !important;
	--padding-block-start: 0 !important;
	--padding-block-end: 0 !important;
	--padding-inline-start: 0 !important;
	--padding-inline-end: 0 !important;
	padding: 0 !important;
	margin-top: 0 !important;
	margin-bottom: 0 !important;
	gap: 0 !important;
}

.e-con:has(> .e-con-inner > .elementor-widget-jl-faq) > .e-con-inner {
	--padding-top: 0 !important;
	--padding-bottom: 0 !important;
	--padding-block-start: 0 !important;
	--padding-block-end: 0 !important;
	padding: 0 !important;
}

/* ── Section wrapper ─────────────────────────────────────────────────────── */
.jl-faq {
	background: var(--jl-faq-bg, #ffffff);
	padding: var(--jl-faq-padding-y, 80px) 1.5rem;
	width: 100vw;
	margin-left: calc(50% - 50vw);
}

/* ── Inner grid ──────────────────────────────────────────────────────────── */
.jl-faq__inner {
	max-width: 1352px;
	margin-inline: auto;
}

/* Split layout: FAQs left, image right */
.jl-faq--split .jl-faq__inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 5rem;
	align-items: start;
}

/* Image-left variant */
.jl-faq--split.jl-faq--image-left .jl-faq__content { order: 2; }
.jl-faq--split.jl-faq--image-left .jl-faq__media   { order: 1; }

/* Full-width: 2-column FAQ grid on large screens */
.jl-faq--full .jl-faq__list {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 1.5rem;
}

/* ── Heading ─────────────────────────────────────────────────────────────── */
.jl-faq__heading {
	font-family: 'Gotham Office', sans-serif;
	font-size: clamp(1.75rem, 2.12vw, 2rem);
	font-weight: 400;
	line-height: 1.25;
	letter-spacing: 1px;
	text-transform: uppercase;
	color: var(--e-global-color-heading, #1a1a1a);
	margin: 0 0 2.125rem;
}

/* ── Divider ─────────────────────────────────────────────────────────────── */
.jl-faq .jl-faq__divider {
	width: var(--jl-faq-divider-width, 128px);
	height: var(--jl-faq-divider-thickness, 2px);
	background: linear-gradient(to right, var(--jl-faq-divider-color, var(--e-global-color-slate, #4b667c)), var(--jl-faq-divider-color, var(--e-global-color-slate, #4b667c)) 60%, transparent);
	border: 0;
	outline: 0;
	margin: 0 0 2.125rem;
}

/* Editor-driven gradient style modifiers */
.jl-faq .jl-faq__divider.jl-faq__divider--narrow {
	background: linear-gradient(to right, transparent, var(--jl-faq-divider-color, var(--e-global-color-slate, #4b667c)) 50%, transparent);
}
.jl-faq .jl-faq__divider.jl-faq__divider--wide {
	background: linear-gradient(to right, transparent, var(--jl-faq-divider-color, var(--e-global-color-slate, #4b667c)) 25%, var(--jl-faq-divider-color, var(--e-global-color-slate, #4b667c)) 75%, transparent);
}
.jl-faq .jl-faq__divider.jl-faq__divider--left {
	background: linear-gradient(to right, var(--jl-faq-divider-color, var(--e-global-color-slate, #4b667c)), var(--jl-faq-divider-color, var(--e-global-color-slate, #4b667c)) 60%, transparent);
}

/* ── FAQ list ────────────────────────────────────────────────────────────── */
.jl-faq--split .jl-faq__list {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

/* ── FAQ card ────────────────────────────────────────────────────────────── */
.jl-faq__item {
	border: 1px solid #e5e5e5;
	border-radius: 8px;
	padding: 1.5rem;
	background: #ffffff;
}

.jl-faq__question {
	font-family: 'Gotham Office', sans-serif;
	font-size: clamp(0.9375rem, 1.06vw, 1rem);
	font-weight: 400;
	line-height: 1.4;
	letter-spacing: 0.1px;
	color: var(--e-global-color-heading, #1a1a1a);
	margin: 0 0 0.75rem;
}

.jl-faq__answer {
	font-family: 'Gotham Office', sans-serif;
	font-size: clamp(0.875rem, 0.99vw, 0.9375rem);
	line-height: 1.5;
	letter-spacing: 0.1px;
	color: var(--e-global-color-text, #444444);
	margin: 0;
}

/* ── Image ───────────────────────────────────────────────────────────────── */
.jl-faq__image {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
	border-radius: 8px;
}

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 767px) {
	.jl-faq--split .jl-faq__inner,
	.jl-faq--full .jl-faq__list {
		grid-template-columns: 1fr;
		gap: 2rem;
	}

	.jl-faq--split.jl-faq--image-left .jl-faq__content,
	.jl-faq--split.jl-faq--image-left .jl-faq__media {
		order: unset;
	}

	.jl-faq__media {
		display: none; /* hide image on mobile in split mode */
	}
}

@media (min-width: 768px) {
	.jl-faq {
		padding: var(--jl-faq-padding-y, 80px) 3rem;
	}
}

@media (min-width: 1280px) {
	.jl-faq {
		padding: var(--jl-faq-padding-y, 80px) 1.5rem;
	}
}
