.promo-list {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 16px;
}

@media (max-width: 1833px) {
	.promo-list {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 1341px) {
	.promo-list {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 767px) {
	.promo-list {
		grid-template-columns: repeat(1, 1fr);
	}
}

.promo-item {
	display: flex;
	flex-direction: column;
	background: white;
	border-radius: 20px;
	padding-bottom: 50px;
}

.promo-item__img-container {
	width: calc(100% + 2 * var(--page-horizontal-padding));
	border-radius: 20px;
	display: flex;
	justify-content: center;
	align-items: center;
	overflow: hidden;
	text-align: center;
	margin-bottom: auto;
}

.promo-item__img {
	width: 100%;
	display: block;
	height: calc(100% - 50px);
	margin-bottom: 50px;
	object-fit: scale-down;
	object-position: center;
}

.promo-item__title {
	font-size: 24px;
	margin-bottom: 30px;
}


.promo-page {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 16px;
	align-items: start;
}

.promo-page__img {
	align-items: center;
	justify-content: center;
	border-radius: 20px;
	overflow: hidden;
}

.promo-page__img img {
	display: block;
	max-width: 100%;
	max-height: 100%;
}

.promo-page__text {
	padding: 50px 40px;
	align-self: stretch;
}

@media (max-width: 999px) {
	.promo-page {
		grid-template-columns: 1fr;
		background: white;
		border-radius: 20px;
	}
	.promo-page__img {
		max-height: 420px;
		width: 100%;
		overflow: hidden;
		border-radius: 20px;
	}
	.promo-page__img img {
		object-fit: contain;
		width: 100%;
		height: 100%;
	}
	.promo-page__text {
		padding: 24px;
	}
}