/* ============================================
   Banner CTA Section
   ============================================ */

.banner-section {
	position: relative;
	padding: clamp(80px, 12vw, 160px) 0;
	background-color: var(--color-true-black);
	color: var(--color-pure-white);
}

.banner-section .container {
	padding: 0;
}

.banner-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: clamp(40px, 8vw, 96px);
}

/* Text Block */
.banner-text-block {
	flex: 1;
	max-width: clamp(320px, 40vw, 640px);
	display: flex;
	flex-direction: column;
	gap: 24px;
}

.banner-title {
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0;
}

.banner-title-accent {
	color: var(--color-pure-white);
}

.banner-title-main {
	color: var(--color-sky-pulse);
}

.banner-description {
	color: var(--color-pure-white);
	max-width: clamp(320px, 36vw, 560px);
	margin: 0;
}

.banner-button {
	margin-top: 8px;
	width: auto;
	min-width: fit-content;
	max-width: 100%;
	align-self: flex-start;
}

.banner-buttons {
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: var(--spacing-md);
	flex-wrap: wrap;
	margin-top: 8px;
}

.banner-buttons .banner-button {
	width: auto;
	min-width: clamp(140px, 15vw, 160px);
	max-width: 100%;
}

/* Image Panels */
.banner-images {
	display: flex;
	gap: clamp(12px, 2vw, 24px);
	flex-shrink: 0;
	width: clamp(320px, 45vw, 551px);
	height: clamp(180px, 30vw, 302px);
	overflow: hidden; /* фиксированная высота, без появления скроллбаров */
	white-space: nowrap;
}

.banner-image-panel {
	flex: 0 0 170px; /* Fixed width for scrolling */
	overflow: hidden;
	border-radius: 12px;
	position: relative;
	height: 100%;
	min-height: 0;
}

.banner-image-panel img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Responsive */
@media (max-width: 1024px) {
	.banner-inner {
		flex-direction: column;
		align-items: flex-start;
	}
	
	.banner-text-block {
		flex: 1;
		max-width: 100%;
		display: flex;
		flex-direction: column;
		gap: 24px;
	}

	.banner-images {
		width: 100%;
		max-width: 970px;
		height: clamp(180px, 30vw, 302px);
	}
}

@media (max-width: 768px) {
	.banner-section {
		padding: clamp(60px, 10vw, 120px) 0;
	}

	.banner-text-block {
		max-width: 100%;
	}
	
	.banner-button {
		margin-top: 8px;
		width: auto;
		min-width: fit-content;
		max-width: 100%;
	}
}

@media (max-width: 320px) {
	.banner-section {
		padding: clamp(60px, 10vw, 120px) 16px !important;
	}
}