/* ============================================================
   Breez Why Section — Elementor widget (sticky scroll list/media)
   ============================================================ */

.breez-why-widget {
	--breez-why-top: 100px;
	--breez-why-gap: 48px;
	--breez-why-ratio: 812 / 920;
	--breez-why-radius: 24px;

	position: relative;
	width: 100%;
}

.breez-why-widget *,
.breez-why-widget *::before,
.breez-why-widget *::after {
	box-sizing: border-box;
}

.breez-why-widget__inner {
	display: block;
	width: 100%;
}

/* --- Heading -------------------------------------------------- */
.breez-why-widget__head {
	margin-bottom: 32px;
}

.breez-why-widget__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	margin-bottom: 16px;
}

.breez-why-widget__eyebrow-icon {
	display: block;
	width: 20px;
	height: 20px;
	object-fit: contain;
}

.breez-why-widget__heading {
	margin: 0;
	font-size: clamp(28px, 4vw, 48px);
	line-height: 1.15;
}

/* --- List ----------------------------------------------------- */
.breez-why-widget__list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.breez-why-widget__item {
	position: relative;
	padding-top: 40px;
	padding-bottom: 40px;
}

.breez-why-widget__item-line {
	display: none;
}

.breez-why-widget__item-iconwrap {
	margin-bottom: 24px;
}

.breez-why-widget__item-icon {
	display: block;
	width: 40px;
	height: 40px;
	object-fit: contain;
}

.breez-why-widget__item-title {
	font-family: "Montserrat", Sans-serif !important;
	font-size: 24px;
	font-weight: 600;
	line-height: 120%;
	letter-spacing: -4%;
	color: #fff;
	margin-bottom: 14px;
}

.breez-why-widget__item-text {
	margin: 0 0 0 0 !important;
	font-size: 20px;
	line-height: 130%;
	font-weight: 500;
	font-family: "Montserrat", Sans-serif !important;
	letter-spacing: -1%;
}

/* Inline image per item — mobile & tablet only */
.breez-why-widget__item-media {
	display: block;
	margin-top: 24px;
	position: sticky;
	top: var(--breez-why-top);
	z-index: 2;
	width: 100%;
	aspect-ratio: var(--breez-why-ratio);
	overflow: hidden;
	border-radius: var(--breez-why-radius);
}

.breez-why-widget__item-media-img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* Right column stack — desktop only */
.breez-why-widget__media-col {
	display: none;
}

/* ============================================================
   Defensive: allow position:sticky to work inside Elementor wrappers.
   ============================================================ */
.elementor-widget-breez_why_section,
.elementor-widget-breez_why_section>.elementor-widget-container {
	overflow: visible;
}

/* ============================================================
   Desktop layout (sticky list head + sticky right media)
   ============================================================ */
@media (min-width: 1025px) {

	/* Flex row: left track scrolls; right media pinned via GSAP when JS loads. */
	.breez-why-widget__inner {
		display: flex;
		flex-direction: row;
		align-items: flex-start;
		gap: var(--breez-why-gap);
	}

	.breez-why-widget__track {
		flex: 1 1 50%;
		min-width: 0;
	}

	.breez-why-widget__media-col {
		display: block;
		flex: 1 1 50%;
		min-width: 0;
		align-self: flex-start;
	}

	.breez-why-widget__head {
		position: sticky;
		top: var(--breez-why-top);
		z-index: 3;
		background: #0b1016;
		padding-bottom: 24px;
	}

	.breez-why-widget__media-col,
	.breez-why-widget__media,
	.breez-why-widget__media-inner,
	.breez-why-widget__slide,
	.breez-why-widget__slide-img {
		border: none;
		outline: none;
		box-shadow: none;
	}

	.breez-why-widget__slide-line {
		display: none !important;
	}

	.breez-why-widget__media {
		z-index: 2;
		width: 100%;
		max-height: calc(100vh - var(--breez-why-top));
	}

	/* GSAP pin when JS is ready; CSS sticky is the no-JS fallback. */
	.breez-why-widget:not([data-breez-why-init]) .breez-why-widget__media {
		position: sticky;
		top: var(--breez-why-top);
	}

	.breez-why-widget__media-inner {
		position: relative;
		width: 100%;
		max-height: calc(100vh - var(--breez-why-top));
		aspect-ratio: var(--breez-why-ratio);
		overflow: hidden;
		border-radius: var(--breez-why-radius);
		isolation: isolate;
	}

	.breez-why-widget__slide {
		position: absolute;
		inset: 0;
		opacity: 1;
		visibility: hidden;
		overflow: hidden;
		transform-origin: 50% 50%;
		will-change: transform;
		border-radius: 0;
		-webkit-backface-visibility: hidden;
		backface-visibility: hidden;
	}

	.breez-why-widget__slide.is-active {
		visibility: visible;
		z-index: 1;
	}

	.breez-why-widget__slide-img {
		display: block;
		width: 100%;
		height: 100% !important;
		object-fit: cover;
		border-radius: 0;
		transform: translateZ(0);
	}

	.breez-why-widget__item-line {
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 2px;
		background: #ffffff;
		transform-origin: 0 50%;
		transform: scaleX(0);
		pointer-events: none;
		z-index: 2;
	}

	.breez-why-widget__item {
		height: auto;
		min-height: 0;
		display: flex;
		flex-direction: column;
		justify-content: flex-start;
		opacity: 1;
		border-top: 1px solid #E1E1E133;
		max-width: 648px;
	}

	.breez-why-widget__item:not(.is-active) .breez-why-widget__item-title {
		color: rgba(255, 255, 255, 0.5);
	}

	.breez-why-widget__item:not(.is-active) .breez-why-widget__item-text {
		color: rgba(255, 255, 255, 0.45);
	}

	.breez-why-widget__item:not(.is-active) .breez-why-widget__item-iconwrap {
		opacity: 0.55;
	}

	.breez-why-widget__item.is-active .breez-why-widget__item-title,
	.breez-why-widget__item.is-active .breez-why-widget__item-text {
		color: #fff;
	}

	.breez-why-widget__item.is-active .breez-why-widget__item-iconwrap {
		opacity: 1;
	}

	.breez-why-widget__item.is-active {
		opacity: 1;
	}

	.breez-why-widget__item+.breez-why-widget__item {
		margin-top: 0;
	}

	/* Extra scroll runway so sticky media/head stay pinned until last item is in view. */
	.breez-why-widget__item:last-child {
		padding-bottom: calc(40px + 50vh - var(--breez-why-top));
	}

	/* Desktop uses the right sticky stack — hide inline item images */
	.breez-why-widget__item-media {
		display: none;
	}

	/* Fallback CSS-only image swap, in case JS hasn't booted yet.
	   GSAP overrides these the moment it initializes. */
	.breez-why-widget:not([data-breez-why-init]) .breez-why-widget__item.is-active .breez-why-widget__item-line {
		transform: scaleX(1);
	}

	.breez-why-widget:not([data-breez-why-init]) .breez-why-widget__slide {
		opacity: 1;
		visibility: hidden;
	}

	.breez-why-widget:not([data-breez-why-init]) .breez-why-widget__slide.is-active {
		visibility: visible;
	}
}

/* Tablet: same stacked layout as mobile (inline image per item) */
@media (min-width: 768px) and (max-width: 1024px) {
	.breez-why-widget__item-media {
		margin-top: 32px;
	}
}

/* Reduced motion: keep everything visible, no fading */
@media (prefers-reduced-motion: reduce) {

	.breez-why-widget__item,
	.breez-why-widget__slide,
	.breez-why-widget__item-media {
		transition: none !important;
		opacity: 1 !important;
		visibility: visible !important;
	}

	@media (min-width: 1025px) {
		.breez-why-widget__slide {
			position: relative;
			inset: auto;
		}
	}
}

.elementor-element.elementor-element-b36b6b1.elementor-widget.elementor-widget-brother_breeze_map {
	width: 100% !important;
}


@media (max-width: 767px) {
	span.breez-why-widget__eyebrow-text {
		font-size: 12px !important;
		margin-bottom: 16px !important;
		padding-left: 21px !important;
	}

	span.breez-why-widget__eyebrow-text::before {
		width: 11px !important;
		height: 11px !important;
		bottom: 2px !important;
	}

	h2.breez-why-widget__heading {
		font-size: 28px !important;
		letter-spacing: -4% !important;
	}

	.breez-why-widget__item {
		position: relative;
		border-top: 1px solid #E1E1E133;
	}

	.breez-why-widget__item-iconwrap {
		margin-bottom: 16px;
		display: none;
	}

	.breez-why-widget__item-title {
		font-size: 18px;
		margin-bottom: 15px;
	}

	.breez-why-widget__item-text {
		margin: 0;
		font-size: 14px;
		line-height: 135%;
		font-weight: 500;
		font-family: "Montserrat", Sans-serif !important;
		letter-spacing: -3%;
		color: #fff;
	}

	.breez-why-widget__item-media {
		height: 328px;
	}
}