/* =============================================================================
   JL Leadership Widget
   Used for: Senior Leadership, Team Members (and similar sections)
   ========================================================================== */

/* ── Zero out parent Elementor container padding & gap ─────────────────── */
.e-con:has(> .elementor-widget-jl-leadership),
.e-con:has(> .e-con-inner > .elementor-widget-jl-leadership) {
	--padding-top: 0 !important;
	--padding-bottom: 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-leadership) > .e-con-inner {
	padding: 0 !important;
	gap: 0 !important;
	--padding-top: 0 !important;
	--padding-bottom: 0 !important;
	--padding-block-start: 0 !important;
	--padding-block-end: 0 !important;
}

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

/* ── Inner content area ────────────────────────────────────────────────── */
.jl-leadership__inner {
	max-width: 1352px; /* 1512px design width − 2×80px margin */
	width: 100%;
	margin-inline: auto;
}

/* ── Section heading ───────────────────────────────────────────────────── */
.jl-leadership__heading {
	font-family: "Gotham Office", sans-serif;
	font-size: clamp(1.5rem, 2.38vw, 2.25rem); /* 36px at 1512px — matches widget-cards */
	font-weight: 400;
	line-height: 1.1;
	letter-spacing: 1px;
	text-transform: uppercase;
	margin: 0 0 2.5rem; /* 40px — matches Figma heading-to-divider gap */
	color: var(--e-global-color-heading, #000);
	text-align: center;
}

/* ── Divider ───────────────────────────────────────────────────────────── */
.jl-leadership__divider {
	width: var(--jl-leadership-divider-width, 128px);
	height: var(--jl-leadership-divider-thickness, 2px);
	background: linear-gradient(to right, transparent, var(--jl-leadership-divider-color, var(--e-global-color-slate, #4b667c)) 25%, var(--jl-leadership-divider-color, var(--e-global-color-slate, #4b667c)) 75%, transparent);
	border: 0;
	outline: 0;
	margin: 0 auto 2.5rem !important; /* 40px below divider */
}

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

/* ── Members grid (shared) ─────────────────────────────────────────────── */
.jl-leadership__grid {
	gap: 2rem;
	align-items: stretch;
	width: 100%;
}

/* ── Mobile Portrait: always single column ─────────────────────────────── */
@media (max-width: 480px) {
	.jl-leadership__grid {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
	}
	.jl-leadership__grid .jl-leadership__member {
		flex: 1 1 100%;
	}
}

/* ── Mobile Landscape ───────────────────────────────────────────────────── */
@media (min-width: 481px) and (max-width: 767px) {
	.jl-leadership__grid--ml-flex {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
	}
	.jl-leadership__grid--ml-flex.jl-leadership__grid--ml-cols-1 .jl-leadership__member { flex: 1 1 100%; }
	.jl-leadership__grid--ml-flex.jl-leadership__grid--ml-cols-2 .jl-leadership__member { flex: 1 1 45%; }

	.jl-leadership__grid--ml-grid { display: grid; }
	.jl-leadership__grid--ml-grid.jl-leadership__grid--ml-cols-1 { grid-template-columns: 1fr; }
	.jl-leadership__grid--ml-grid.jl-leadership__grid--ml-cols-2 { grid-template-columns: repeat(2, 1fr); }
}

/* ── Tablet ─────────────────────────────────────────────────────────────── */
@media (min-width: 768px) and (max-width: 1023px) {
	.jl-leadership__grid--tablet-flex {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
	}
	.jl-leadership__grid--tablet-flex.jl-leadership__grid--tablet-cols-1 .jl-leadership__member { flex: 1 1 100%; }
	.jl-leadership__grid--tablet-flex.jl-leadership__grid--tablet-cols-2 .jl-leadership__member { flex: 1 1 40%; }
	.jl-leadership__grid--tablet-flex.jl-leadership__grid--tablet-cols-3 .jl-leadership__member { flex: 1 1 25%; }

	.jl-leadership__grid--tablet-grid { display: grid; }
	.jl-leadership__grid--tablet-grid.jl-leadership__grid--tablet-cols-1 { grid-template-columns: 1fr; }
	.jl-leadership__grid--tablet-grid.jl-leadership__grid--tablet-cols-2 { grid-template-columns: repeat(2, 1fr); }
	.jl-leadership__grid--tablet-grid.jl-leadership__grid--tablet-cols-3 { grid-template-columns: repeat(3, 1fr); }

}

/* ── Desktop ────────────────────────────────────────────────────────────── */
@media (min-width: 1024px) {
	.jl-leadership__grid--desktop-flex {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
	}
	.jl-leadership__grid--desktop-flex.jl-leadership__grid--desktop-cols-2 .jl-leadership__member { flex: 1 1 45%; }
	.jl-leadership__grid--desktop-flex.jl-leadership__grid--desktop-cols-3 .jl-leadership__member { flex: 1 1 30%; }
	.jl-leadership__grid--desktop-flex.jl-leadership__grid--desktop-cols-4 .jl-leadership__member { flex: 1 1 22%; }

	.jl-leadership__grid--desktop-grid { display: grid; }
	.jl-leadership__grid--desktop-grid.jl-leadership__grid--desktop-cols-2 { grid-template-columns: repeat(2, 1fr); }
	.jl-leadership__grid--desktop-grid.jl-leadership__grid--desktop-cols-3 { grid-template-columns: repeat(3, 1fr); }
	.jl-leadership__grid--desktop-grid.jl-leadership__grid--desktop-cols-4 { grid-template-columns: repeat(4, 1fr); }

}

/* ── Center Items mode (override container; members keep column-width but don't stretch) ── */
.jl-leadership__grid--center {
	display: flex !important;
	flex-wrap: wrap;
	justify-content: center;
}
.jl-leadership__grid--center > .jl-leadership__member {
	flex-grow: 0;
}
@media (min-width: 481px) and (max-width: 767px) {
	.jl-leadership__grid--center.jl-leadership__grid--ml-cols-1 > .jl-leadership__member { flex-basis: 100%; max-width: 100%; }
	.jl-leadership__grid--center.jl-leadership__grid--ml-cols-2 > .jl-leadership__member { flex-basis: calc(50% - 1rem); max-width: calc(50% - 1rem); }
}
@media (min-width: 768px) and (max-width: 1023px) {
	.jl-leadership__grid--center.jl-leadership__grid--tablet-cols-1 > .jl-leadership__member { flex-basis: 100%; max-width: 100%; }
	.jl-leadership__grid--center.jl-leadership__grid--tablet-cols-2 > .jl-leadership__member { flex-basis: calc(50% - 1rem); max-width: calc(50% - 1rem); }
	.jl-leadership__grid--center.jl-leadership__grid--tablet-cols-3 > .jl-leadership__member { flex-basis: calc(33.333% - 1.333rem); max-width: calc(33.333% - 1.333rem); }
}
@media (min-width: 1024px) {
	.jl-leadership__grid--center.jl-leadership__grid--desktop-cols-2 > .jl-leadership__member { flex-basis: calc(50% - 1rem); max-width: calc(50% - 1rem); }
	.jl-leadership__grid--center.jl-leadership__grid--desktop-cols-3 > .jl-leadership__member { flex-basis: calc(33.333% - 1.333rem); max-width: calc(33.333% - 1.333rem); }
	.jl-leadership__grid--center.jl-leadership__grid--desktop-cols-4 > .jl-leadership__member { flex-basis: calc(25% - 1.5rem); max-width: calc(25% - 1.5rem); }
}


/* ── Individual member card ────────────────────────────────────────────── */
.jl-leadership__member {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	background: var(--jl-leadership-card-bg, linear-gradient(to bottom, #fafafa, #ffffff));
	border: 1px solid #e5e5e5;
	border-radius: 8px;
	gap: 1rem;
}

/* ── Member photo (circular) ───────────────────────────────────────────── */
.jl-leadership__photo {
	width: 200px;
	height: 200px;
	border-radius: 50%;
	overflow: hidden;
	flex-shrink: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #1a1612;
}

.jl-leadership__photo img {
	width: 100% !important;
	height: 100% !important;
	max-width: 100% !important;
	max-height: 100% !important;
	object-fit: cover;
	display: block;
	transform-origin: center center;
}

/* ── Member name ───────────────────────────────────────────────────────── */
.jl-leadership__name {
	font-family: "Gotham Office", sans-serif;
	font-size: clamp(1.5rem, 1.85vw, 1.75rem); /* 24px → 28px at 1512px */
	font-weight: 400;
	line-height: 36px;
	letter-spacing: 0;
	margin: 0 0 0.5rem;
	color: var(--e-global-color-slate, #4b667c);
}

/* ── Member title ──────────────────────────────────────────────────────── */
.jl-leadership__title {
	font-family: "Gotham Office", sans-serif;
	font-size: 1rem; /* Fixed 16px for responsive flexibility */
	font-weight: 400;
	line-height: 24px;
	letter-spacing: 0.25px;
	color: var(--e-global-color-text, #343333);
}

.jl-leadership__title-line {
	margin: 0 0 0.5rem 0;
	line-height: 24px;
	letter-spacing: 0.25px;
}

.jl-leadership__title-line:first-child {
	margin-top: 0;
	font-size: 1.125rem; /* 18px */
}

.jl-leadership__title-line:last-child {
	margin-bottom: 0;
	font-size: 0.875rem; /* 14px */
	line-height: 20px;
	letter-spacing: 0.4px;
	color: var(--e-global-color-text-secondary, #606060);
}

/* ── Responsive tweaks ────────────────────────────────────────────────── */
@media (max-width: 767px) {
	.jl-leadership {
		padding: var(--jl-leadership-padding-y, 60px) 1rem;
	}

	.jl-leadership__photo {
		width: 160px;
		height: 160px;
		margin-bottom: 1rem;
	}
}

@media (max-width: 480px) {
	.jl-leadership {
		padding: var(--jl-leadership-padding-y, 40px) 1rem;
	}

	.jl-leadership__heading {
		font-size: 1.25rem;
		margin-bottom: 1.5rem;
	}

	.jl-leadership__photo {
		width: 140px;
		height: 140px;
		margin-bottom: 0.75rem;
	}
}
