/* ── CTA Scroll + car (no pin) ── */
.block-cta-scroll {
	--weblance-kicker-gap: 20px;
	--weblance-kicker-offset: calc(var(--weblance-kicker-width, 40px) + var(--weblance-kicker-gap));
	--cta-scroll-pad-y: 22vh;
	position: relative;
	z-index: 1;
	overflow: visible;
	box-sizing: border-box;
	isolation: isolate;
	display: flex;
	flex-direction: column;
	/* Panel — wysokość treści */
	align-items: stretch;
}

/* ── Content panel — wysokość = treść (nie rozciągaj do pełnego 100vh) ── */
.block-cta-scroll__panel {
	position: relative;
	z-index: 2;
	width: 100%;
	flex: 0 0 auto;
	display: flex;
	pointer-events: auto;
	will-change: transform;
}

.block-cta-scroll__container {
	position: relative;
	z-index: 1;
	width: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	padding: var(--cta-scroll-pad-y) var(--calc-padding);
	box-sizing: border-box;
}

/* Gdy bloki CTA Scroll wystepuja bezposrednio po sobie, usun duplikacje odstepu u gory kolejnego bloku. */
.block-cta-scroll + .block-cta-scroll .block-cta-scroll__container {
	padding-top: 0;
}

/* Wyrównanie copy (ACF): pozycja bloku + tekst + przyciski */
.block-cta-scroll--align-left .block-cta-scroll__container {
	align-items: flex-start;
}

.block-cta-scroll--align-left .block-cta-scroll__copy,
.block-cta-scroll--align-left .block-cta-scroll__copy-outer {
	text-align: left;
}

.block-cta-scroll--align-left .block-cta-scroll__buttons {
	justify-content: flex-start;
}

.block-cta-scroll--align-left .block-cta-scroll__copy::after {
	left: 100%;
	transform-origin: 0 100%;
	transform: rotate(30deg);
}

.block-cta-scroll--align-center .block-cta-scroll__container {
	align-items: center;
}

.block-cta-scroll--align-center .block-cta-scroll__copy,
.block-cta-scroll--align-center .block-cta-scroll__copy-outer {
	text-align: center;
}

.block-cta-scroll--align-center .block-cta-scroll__buttons {
	justify-content: center;
}

.block-cta-scroll--align-right .block-cta-scroll__container {
	align-items: flex-end;
}

.block-cta-scroll--align-right .block-cta-scroll__copy,
.block-cta-scroll--align-right .block-cta-scroll__copy-outer {
	text-align: right;
}

.block-cta-scroll--align-right .block-cta-scroll__buttons {
	justify-content: flex-end;
}

/* Wrapper copy + boczny kicker (kreska po prawej → kicker po lewej, jak Etapy etap 1). */
.block-cta-scroll__copy-outer {
	position: relative;
	max-width: 55%;
	width: 100%;
}

.block-cta-scroll__copy-outer .block-cta-scroll__copy {
	max-width: 100%;
}

.block-cta-scroll__copy-outer--kicker-left {
	margin-left: var(--weblance-kicker-offset);
}

.block-cta-scroll__copy-outer--kicker-left .weblance-copy-side-kicker {
	right: calc(100% + 20px);
}

/* ── Copy: kreska od prawego dolnego rogu (jak Etapy etap 1) ── */
.block-cta-scroll__copy {
	position: relative;
	overflow: visible;
	max-width: 55%;
	display: flex;
	flex-direction: column;
	gap: 20px;
	padding: 0 0 30px;
	border-bottom: 2px solid #fff;
}

.block-cta-scroll__copy::after {
	content: "";
	position: absolute;
	width: 300px;
	height: 2px;
	background: #fff;
	pointer-events: none;
	z-index: 2;
	left: 100%;
	bottom: 0;
	transform-origin: 0 100%;
	transform: rotate(30deg);
}

.block-cta-scroll__heading {
	margin: 0;
	color: #fff;
	font-size: var(--font-size-h2);
	font-weight: 400;
	line-height: 1.2;
}

.block-cta-scroll__heading p { margin: 0; }

.block-cta-scroll__heading strong {
	position: relative;
	display: inline-block;
	font-weight: 700;
	font-style: italic;
	z-index: 1;
}

.block-cta-scroll__heading strong::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 10%;
	height: 0.5em;
	background-image: url("/wp-content/themes/weblance/assets/images/hero-strong-underline.svg");
	background-repeat: no-repeat;
	background-size: 100% 100%;
	background-position: center;
	pointer-events: none;
	z-index: -1;
}

.block-cta-scroll__text {
	color: rgba(255, 255, 255, 0.8);
	font-size: var(--font-size-normal);
	line-height: 1.6;
}

.block-cta-scroll__text p { margin: 0 0 8px; }
.block-cta-scroll__text p:last-child { margin-bottom: 0; }

/* ── Buttons ── */
.block-cta-scroll__buttons {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 8px;
}

.block-cta-scroll__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 12px 24px;
	border-radius: 100px;
	text-decoration: none;
	font-size: var(--font-size-normal);
	font-weight: 400;
}

.block-cta-scroll__btn--secondary {
	border: 2px solid #ffffff33;
	border-radius: 100px;
	background: rgba(255, 255, 255, 0.04);
	box-shadow: 4px 4px 12.9px 0 rgba(0, 0, 0, 0.25);
	backdrop-filter: blur(2px);
	-webkit-backdrop-filter: blur(2px);
}

/* ── Car (absolute, desktop); GSAP: yPercent -50 + xPercent (środek pionowy bez kolizji z transform) ── */
.block-cta-scroll__car {
	position: absolute;
	top: 50%;
	right: 0;
	z-index: 0;
	pointer-events: none;
	width: 60%;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	will-change: transform;
}

.block-cta-scroll__car img {
	display: block;
	width: 100%;
	height: auto;
	object-fit: contain;
}

/* Lustrzane zakotwiczenie auta, gdy copy jest po prawej.
   Bez tego auto zostaje zakotwiczone po prawej (right: 0), a GSAP jedynie
   odbija wartości xPercent — w efekcie auto dryfuje do środka sekcji i
   nachodzi na copy. Przy align-right kotwiczymy auto po lewej; sam
   obrazek zostawiamy w oryginalnej orientacji (zakładamy, że w ACF
   został wgrany poprawny wariant dla tej wersji). */
.block-cta-scroll--align-right .block-cta-scroll__car {
	right: auto;
	left: 0;
	justify-content: flex-start;
}

/* ── Car lane (mobile only) ── */
.block-cta-scroll__car-lane {
	display: none;
}

/* ── Responsive ── */
@media (max-width: 1023px) {
	.block-cta-scroll__copy,
	.block-cta-scroll__copy-outer {
		max-width: 60%;
	}

	.block-cta-scroll__car {
		width: 55%;
	}
}

@media (max-width: 767px) {
	.block-cta-scroll {
		--weblance-kicker-width: 30px;
		--cta-scroll-pad-y: 10vh;
		padding-top: var(--cta-scroll-pad-y);
		padding-bottom: var(--cta-scroll-pad-y);
		overflow-x: clip;
		overflow-y: visible;
	}

	.block-cta-scroll + .block-cta-scroll {
		padding-top: 0;
	}

	.block-cta-scroll__panel {
		position: relative;
	}

	.block-cta-scroll__container {
		padding: 0 var(--calc-padding);
	}

	.block-cta-scroll__copy,
	.block-cta-scroll__copy-outer {
		max-width: 100%;
	}

	.block-cta-scroll__copy::after {
		width: min(180px, 34vw);
	}

	.block-cta-scroll__copy-outer {
		align-self: stretch;
	}

	.block-cta-scroll__copy-outer--kicker-left {
		width: calc(100% - var(--weblance-kicker-offset));
	}

	.block-cta-scroll__buttons,
	.block-cta-scroll__btn {
		width: 100%;
	}

	.block-cta-scroll__car {
		display: none;
	}

	.block-cta-scroll__car-lane {
		display: block;
		position: relative;
		width: 100%;
		height: 65vw;
		overflow: hidden;
		pointer-events: none;
	}

	.block-cta-scroll__car-lane img {
		position: absolute;
		top: 50%;
		left: 0;
		width: 130%;
		height: auto;
		object-fit: contain;
		will-change: transform;
	}

	/* Lustrzane zakotwiczenie pasa auta dla wariantu align-right (mobile).
	   Kotwiczymy pas po prawej; obrazka nie obracamy — zakładamy, że
	   w ACF wgrano auto w poprawnej orientacji dla tego wariantu. */
	.block-cta-scroll--align-right .block-cta-scroll__car-lane img {
		left: auto;
		right: 0;
	}
}

@media (prefers-reduced-motion: reduce) {
	.block-cta-scroll__car {
		transform: translateY(-50%);
	}
}
