/* =============================================================================
   JL Timeline Widget — "A Continuum of Growth"

   Stacked (below breakpoint): full-width slate year badges + cards, no rail.
   Alternating (at/above breakpoint): center vertical rail, year badge sits ON
   the rail, cards flow out to alternating sides. No node dots.

   Editor picks the activation breakpoint via `alternate_breakpoint` control:
     tablet_portrait  → ≥ 768px
     tablet_landscape → ≥ 1024px (alias of laptop)
     laptop           → ≥ 1024px
     desktop          → ≥ 1280px
     never            → always stacked

   Source: Figma node 2088:4437 (mobile stacked) + 297:22105 (desktop alt)
   ========================================================================== */

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

/* ── Section wrapper ───────────────────────────────────────────────────── */
.jl-timeline {
	background: var(--jl-timeline-bg, #fafafa);
	padding: var(--jl-timeline-padding-y, 40px) var(--jl-timeline-padding-x, 12px);
	width: 100vw;
	margin-left: calc(50% - 50vw);
}

.jl-timeline__inner {
	max-width: 1352px;
	width: 100%;
	margin-inline: auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 32px;
}

/* ── Section heading ───────────────────────────────────────────────────── */
.jl-timeline__heading {
	font-family: "Gotham Office", sans-serif;
	font-size: clamp(1.5rem, 2.38vw, 2rem);
	font-weight: 400;
	line-height: 40px;
	letter-spacing: 0;
	text-transform: uppercase;
	margin: 0;
	color: var(--e-global-color-heading, #000);
	text-align: center;
}

/* ── Divider ───────────────────────────────────────────────────────────── */
.jl-timeline__divider {
	width: var(--jl-timeline-divider-width, 128px);
	height: var(--jl-timeline-divider-thickness, 1px);
	background: linear-gradient(to right, transparent, var(--jl-timeline-divider-color, #000000) 50%, transparent);
	border: 0;
	outline: 0;
	margin: 0 !important;
}
.jl-timeline__divider.jl-timeline__divider--narrow {
	background: linear-gradient(to right, transparent, var(--jl-timeline-divider-color, #000000) 50%, transparent);
}
.jl-timeline__divider.jl-timeline__divider--wide {
	background: linear-gradient(to right, transparent, var(--jl-timeline-divider-color, #000000) 25%, var(--jl-timeline-divider-color, #000000) 75%, transparent);
}
.jl-timeline__divider.jl-timeline__divider--left {
	background: linear-gradient(to right, var(--jl-timeline-divider-color, #000000), var(--jl-timeline-divider-color, #000000) 60%, transparent);
}

/* ── Intro paragraph ───────────────────────────────────────────────────── */
.jl-timeline__intro {
	font-family: "Gotham Office", sans-serif;
	font-size: 1rem;
	line-height: 26px;
	color: #525252;
	text-align: center;
	max-width: 640px;
	margin: 0;
}

/* ============================================================================
   STACKED LAYOUT (default, used below the chosen breakpoint)
   — full-width slate year badges stacked above each card, no rail.
   ========================================================================= */
.jl-timeline__list {
	list-style: none;
	margin: 0;
	padding: 0;
	width: 100%;
	max-width: 520px;
	display: flex;
	flex-direction: column;
	gap: var(--jl-timeline-entry-gap, 32px);
	position: relative;
}

.jl-timeline__entry {
	position: relative;
	display: flex;
	flex-direction: column;
	gap: 12px;
	width: 100%;
}

/* ── Reveal state ──────────────────────────────────────────────────────── */
.jl-timeline__entry .jl-timeline__year,
.jl-timeline__entry .jl-timeline__card {
	opacity: 0;
	transition: opacity 0.32s ease-out, transform 0.32s cubic-bezier(0.22, 0.61, 0.36, 1);
	will-change: opacity, transform;
}
.jl-timeline__entry .jl-timeline__year {
	transform: translateY(8px) scale(0.96);
}
.jl-timeline__entry .jl-timeline__card {
	transform: translateY(16px);
}
.jl-timeline__entry.is-visible .jl-timeline__year,
.jl-timeline__entry.is-visible .jl-timeline__card {
	opacity: 1;
	transform: translateY(0) scale(1);
}

@media (prefers-reduced-motion: reduce) {
	.jl-timeline__entry .jl-timeline__year,
	.jl-timeline__entry .jl-timeline__card {
		opacity: 1;
		transform: none;
		transition: none;
	}
}

/* Year badge — slate pill, white text, full-width in stacked mode */
.jl-timeline__year {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 24px;
	padding: 4px;
	border-radius: 8px;
	background-color: var(--jl-timeline-year-bg, var(--e-global-color-slate, #4b667c));
	border: 1px solid rgba(0, 0, 0, 0.3);
	color: var(--jl-timeline-year-color, #ffffff);
	font-family: "Gotham Office", sans-serif;
	font-size: 12px;
	line-height: 16px;
	text-align: center;
	width: 100%;
	box-sizing: border-box;
	position: relative;
	z-index: 1;
}

/* Card */
.jl-timeline__card {
	background-color: var(--jl-timeline-card-bg, #fafafa);
	border: 1px solid var(--jl-timeline-card-border, #e5e7eb);
	border-radius: 8px;
	padding: 12px;
	box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
	display: flex;
	flex-direction: column;
	gap: 0;
	width: 100%;
	box-sizing: border-box;
}

.jl-timeline__card-heading {
	font-family: "Gotham Office", sans-serif;
	font-size: 14px;
	font-weight: 700;
	line-height: 20px;
	letter-spacing: 0.1px;
	text-transform: uppercase;
	color: var(--e-global-color-slate, #4b667c);
	margin: 0;
}

.jl-timeline__card-body {
	font-family: "Gotham Office", sans-serif;
	font-size: 14px;
	font-weight: 400;
	line-height: 20px;
	letter-spacing: 0.4px;
	color: #606060;
	margin: 0;
}

/* ============================================================================
   ALTERNATING LAYOUT — shared rules
   Activated at the editor-chosen breakpoint (see --alt-* media queries below).
   Year badge sits centered ON the rail; cards flow out to alternating sides.
   No node dots.
   ========================================================================= */
@mixin-alt {
	/* placeholder — real rules duplicated under each breakpoint below */
}

/* Helper: shared styles for when any alt-* class is active at its breakpoint.
   We duplicate the same ruleset inside each media query (one per breakpoint)
   so editors get one canonical control with multiple cutover options. */

/* ── Alternating-layout reveal: cards slide in from their home side.
   Year badge keeps the vertical pop-in from the base rule above.          */
@media (min-width: 768px) {
	[class*="jl-timeline__list--alt-"] .jl-timeline__entry--left .jl-timeline__card {
		transform: translateX(-32px);
	}
	[class*="jl-timeline__list--alt-"] .jl-timeline__entry--right .jl-timeline__card {
		transform: translateX(32px);
	}
	[class*="jl-timeline__list--alt-"] .jl-timeline__entry.is-visible .jl-timeline__card {
		transform: translateX(0);
	}
}

/* ── Activate at Tablet Portrait (≥ 768px) ─────────────────────────────── */
@media (min-width: 768px) {
	.jl-timeline__list--alt-tablet_portrait {
		max-width: 1000px;
		gap: var(--jl-timeline-entry-gap, 48px);
	}
	.jl-timeline__list--alt-tablet_portrait::before {
		content: "";
		position: absolute;
		top: 0;
		bottom: 0;
		left: 50%;
		transform: translateX(-50%);
		width: var(--jl-timeline-rail-thickness, 1px);
		background: var(--jl-timeline-rail-color, var(--e-global-color-slate, #4b667c));
		z-index: 0;
	}
	.jl-timeline__list--alt-tablet_portrait .jl-timeline__entry {
		display: grid;
		grid-template-columns: 1fr 96px 1fr;
		column-gap: 16px;
		row-gap: 0;
		align-items: center;
	}
	.jl-timeline__list--alt-tablet_portrait .jl-timeline__year {
		grid-column: 2;
		grid-row: 1;
		width: 96px;
		justify-self: center;
	}
	.jl-timeline__list--alt-tablet_portrait .jl-timeline__entry--left .jl-timeline__card {
		grid-column: 1;
		grid-row: 1;
		justify-self: stretch;
	}
	.jl-timeline__list--alt-tablet_portrait .jl-timeline__entry--right .jl-timeline__card {
		grid-column: 3;
		grid-row: 1;
		justify-self: stretch;
	}
}

/* ── Activate at Laptop / Tablet Landscape (≥ 1024px) ──────────────────── */
@media (min-width: 1024px) {
	.jl-timeline__list--alt-laptop,
	.jl-timeline__list--alt-tablet_landscape {
		max-width: 1100px;
		gap: var(--jl-timeline-entry-gap, 48px);
	}
	.jl-timeline__list--alt-laptop::before,
	.jl-timeline__list--alt-tablet_landscape::before {
		content: "";
		position: absolute;
		top: 0;
		bottom: 0;
		left: 50%;
		transform: translateX(-50%);
		width: var(--jl-timeline-rail-thickness, 1px);
		background: var(--jl-timeline-rail-color, var(--e-global-color-slate, #4b667c));
		z-index: 0;
	}
	.jl-timeline__list--alt-laptop .jl-timeline__entry,
	.jl-timeline__list--alt-tablet_landscape .jl-timeline__entry {
		display: grid;
		grid-template-columns: 1fr 96px 1fr;
		column-gap: 24px;
		row-gap: 0;
		align-items: center;
	}
	.jl-timeline__list--alt-laptop .jl-timeline__year,
	.jl-timeline__list--alt-tablet_landscape .jl-timeline__year {
		grid-column: 2;
		grid-row: 1;
		width: 96px;
		justify-self: center;
	}
	.jl-timeline__list--alt-laptop .jl-timeline__entry--left .jl-timeline__card,
	.jl-timeline__list--alt-tablet_landscape .jl-timeline__entry--left .jl-timeline__card {
		grid-column: 1;
		grid-row: 1;
		justify-self: stretch;
	}
	.jl-timeline__list--alt-laptop .jl-timeline__entry--right .jl-timeline__card,
	.jl-timeline__list--alt-tablet_landscape .jl-timeline__entry--right .jl-timeline__card {
		grid-column: 3;
		grid-row: 1;
		justify-self: stretch;
	}
}

/* ── Activate at Desktop (≥ 1280px) ────────────────────────────────────── */
@media (min-width: 1280px) {
	.jl-timeline__list--alt-desktop {
		max-width: 1200px;
		gap: var(--jl-timeline-entry-gap, 48px);
	}
	.jl-timeline__list--alt-desktop::before {
		content: "";
		position: absolute;
		top: 0;
		bottom: 0;
		left: 50%;
		transform: translateX(-50%);
		width: var(--jl-timeline-rail-thickness, 1px);
		background: var(--jl-timeline-rail-color, var(--e-global-color-slate, #4b667c));
		z-index: 0;
	}
	.jl-timeline__list--alt-desktop .jl-timeline__entry {
		display: grid;
		grid-template-columns: 1fr 96px 1fr;
		column-gap: 32px;
		row-gap: 0;
		align-items: center;
	}
	.jl-timeline__list--alt-desktop .jl-timeline__year {
		grid-column: 2;
		grid-row: 1;
		width: 96px;
		justify-self: center;
	}
	.jl-timeline__list--alt-desktop .jl-timeline__entry--left .jl-timeline__card {
		grid-column: 1;
		grid-row: 1;
		justify-self: stretch;
	}
	.jl-timeline__list--alt-desktop .jl-timeline__entry--right .jl-timeline__card {
		grid-column: 3;
		grid-row: 1;
		justify-self: stretch;
	}
}
