.blog-posts-section {
	display: flex;
	flex-flow: column;
	margin-top: 16px;

	@include mobile {
		padding: 0 16px;
	}

	@include desktop {
		align-self: center;
		margin-top: 20px;
		width: calc(100% - 32px);
		max-width: $width-desktop;
	}
}

.blog-posts-section-title {
	font-size: 32px;
	font-weight: 700;
	letter-spacing: -0.03em;

	@include desktop {
		font-size: 56px;
	}
}

.blog-posts-section__menu {
	overflow: hidden;

	@include mobile {
		padding: 0 16px;
		margin: 16px -16px 0;
	}

	@include desktop {
		margin-top: 20px;
	}
}

.blog-posts-section__menu__link {
	display: flex !important;
	align-items: center;
	justify-content: center;
	width: unset !important;
	padding: 0px 14px;
	min-height: 36px;
	border-radius: 14px;
	border: 1px solid $color-border;
	font-size: 14px;
	font-weight: 500;
	line-height: 16px;
	box-sizing: border-box;

	&.active {
		border-color: $color-green;
	}

	@include desktop {
		min-height: 42px;
		padding: 0px 16px;
		border-radius: 16px;
		font-size: 16px;
		line-height: 18px;

		&:hover {
			border-color: $color-green;
		}
	}

	&:last-child {
		margin-right: 0 !important;
	}
}

.blog-posts-section__search-input {
	width: 100%;
	height: 48px;
	margin-top: 16px;
	padding: 0 calc(12px + 24px + 14px) 0 14px;
	font-size: 14px;
	border-radius: 14px;
	background-size: 24px;
	background-repeat: no-repeat;
	background-position: right 12px center;
	background-image: url("data:image/svg+xml,%3Csvg width='24' height='24' viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M17.5 17.5L22 22' stroke='%23737373' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3Cpath d='M20 11C20 6.02944 15.9706 2 11 2C6.02944 2 2 6.02944 2 11C2 15.9706 6.02944 20 11 20C15.9706 20 20 15.9706 20 11Z' stroke='%23737373' stroke-width='1.5' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-color: $color-surface;
	box-sizing: border-box;

	&::placeholder {
		color: $color-gray-md;
	}

	@include desktop {
		height: 54px;
		padding: 0 calc(16px + 24px + 16px) 0 16px;
		border-radius: 16px;
		font-size: 16px;
		background-position: right 16px center;
	}
}

.blog-posts-section__wrapper {
	display: grid;
	grid-template-columns: 1fr;
	gap: 32px;
	margin-top: 20px;

	@include desktop {
		grid-template-columns: 1fr 298px;
		gap: 20px;
		margin-top: 28px;
	}
}

.blog-posts-section__list-wrapper {
	display: flex;
	flex-flow: column;
	gap: 20px;

	@include desktop {
		gap: 40px;
	}
}

.blog-posts-section__list {
	display: grid;
	grid-template-columns: 1fr;
	gap: 8px;

	@include media('min', 'm') {
		grid-template-columns: repeat(2, 1fr);
		gap: 20px;
	}

	@include desktop {
		grid-template-columns: repeat(2, 1fr);
		gap: 20px;

		.blog-posts-section__popular {
			display: none;
		}
	}
}

.blog-posts-section__item {
	display: flex;
	flex-flow: column;
	gap: 6px;
	padding: 6px;
	border-radius: 28px;
	background-color: $color-surface;

	@include desktop {
		gap: 10px;
		padding: 10px;
		border-radius: 32px;

		&:hover {
			background-color: $color-white;
			box-shadow: 0px 8px 40px rgba(0, 0, 0, 0.08);
		}
	}
}

.blog-posts-section__item-cover {
	display: block;
	width: 100%;
	aspect-ratio: 316 / 177;
	border-radius: 20px;

	@include desktop {
		aspect-ratio: 21825 / 12241;
		border-radius: 24px;
	}
}

.blog-posts-section__item-main {
	display: flex;
	flex-flow: column;
	gap: 10px;
	padding: 10px;

	@include desktop {
		padding: 12px;
	}
}

.blog-posts-section__item-title {
	font-size: 16px;
	font-weight: 700;
	letter-spacing: -0.03em;

	@include desktop {
		font-size: 20px;
	}
}

.blog-posts-section__item-desc {
	font-size: 14px;
	line-height: 150%;
	color: $color-gray-md;

	@include desktop {
		font-size: 16px;
	}
}

.blog-posts-section__popular {
	display: flex;
	flex-flow: column;
	padding: 18px;
	border-radius: 20px;
	background-color: $color-surface;

	@include desktop {
		padding: 24px;
		border-radius: 24px;
	}
}

.blog-posts-section__popular-title {
	font-size: 18px;
	font-weight: 700;
	letter-spacing: -0.03em;

	@include desktop {
		font-size: 24px;
	}
}

.blog-posts-section__popular-item {
	display: flex;
	flex-flow: column;
	gap: 6px;
	padding-top: 18px;
	margin-top: 18px;
	border-top: 1px solid $color-border;

	@include desktop {
		gap: 10px;
		padding-top: 24px;
		margin-top: 24px;
	}
}

.blog-posts-section__popular-item__title {
	font-size: 14px;
	font-weight: 500;
	line-height: 16px;

	@include desktop {
		font-size: 16px;
		line-height: 18px;

		&:hover {
			color: $color-green;
		}
	}
}

.blog-posts-section__popular-item__date {
	font-size: 14px;
	line-height: 16px;
	color: $color-gray-md;

	@include desktop {
		font-size: 16px;
		line-height: 18px;
	}
}

.blog-posts-section__popular-item__stat {
	display: flex;
	flex-flow: row nowrap;
	align-items: center;
	gap: 20px;
}

.blog-posts-section__popular-item__stat-item {
	display: flex;
	flex-flow: row nowrap;
	align-items: center;
	gap: 4px;

	@include desktop {
		gap: 6px;
	}

	svg {
		width: 24px;
		height: 24px;
		color: $color-gray-md;
	}

	span {
		font-size: 14px;
		line-height: 16px;

		@include desktop {
			font-size: 16px;
			line-height: 18px;
		}
	}
}

.blog-posts-section__list-pagination {
	display: flex;
	flex-flow: column;
	gap: 16px;

	@include desktop {
		gap: 20px;
	}
}

.blog-posts-section__list-pagination__load-more-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 54px;
	padding: 0px 18px;
	border-radius: 14px;
	border: 1px solid $color-border;
	font-size: 14px;
	font-weight: 500;
	line-height: 16px;
	box-sizing: border-box;

	@include desktop {
		min-height: 64px;
		padding: 0px 24px;
		border-radius: 16px;
		font-size: 16px;
		line-height: 18px;

		&:hover {
			border-color: $color-green;
		}
	}
}

.blog-posts-section__list-pagination__nav {
	display: flex;
	flex-flow: row nowrap;
	align-items: center;
	justify-content: space-between;

	@include desktop {
		justify-content: center;
	}
}

.blog-posts-section__list-pagination__nav-link {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	height: 48px;
	max-width: 48px;
	border-radius: 10px;

	@include desktop {
		height: 54px;
		max-width: 54px;
		border-radius: 12px;
	}

	span {
		font-size: 14px;
		line-height: 16px;

		@include desktop {
			font-size: 16px;
			line-height: 18px;
		}
	}

	&--primary {
		color: $color-green;
		border-radius: 14px;
		background-color: $color-surface;

		@include desktop {
			border-radius: 16px;

			&:first-child {
				margin-right: 12px;
			}

			&:last-child {
				margin-left: 12px;
			}
		}

		svg {
			width: 24px;
			height: 24px;
		}
	}

	&.active {
		font-weight: 500;
		color: $color-white;
		background-color: $color-green;
	}
}

.blog-posts-section__aside {
	display: flex;
	flex-flow: column;
	gap: 24px;

	@include mobile {
		.blog-posts-section__popular {
			display: none;
		}
	}
}

.blog-posts-section__email-subscribe {
	position: relative;
	display: flex;
	flex-flow: row wrap;
	padding: 18px;
	border-radius: 28px;
	background-color: $color-green;
	overflow: hidden;

	@include desktop {
		padding: 24px;
		border-radius: 32px;
	}
}

.blog-posts-section__email-subscribe__icon {
	flex: 0 0 70px;
	aspect-ratio: 2 / 2;

	@include desktop {
		flex: 0 0 109px;
	}

	img {
		display: block;
		width: 100%;
		height: 100%;
		object-fit: contain;
		object-position: center;
		pointer-events: none;
	}
}

.blog-posts-section__email-subscribe__main {
	display: flex;
	flex-flow: column;
	gap: 6px;
	color: $color-white;
	flex: 0 0 calc(100% - 70px - 14px);

	@include mobile {
		margin-left: 14px;
	}

	@include desktop {
		flex: 0 0 100%;
		gap: 12px;
		margin-top: 20px;
	}
}

.blog-posts-section__email-subscribe__title {
	font-size: 18px;
	font-weight: 700;
	letter-spacing: -0.03em;

	@include desktop {
		font-size: 24px;
	}
}

.blog-posts-section__email-subscribe__desc {
	font-size: 14px;
	line-height: 150%;

	@include desktop {
		font-size: 16px;
	}
}

.blog-posts-section__email-subscribe__input {
	flex: 0 0 100%;
	margin-top: 20px;
}

.blog-posts-section__email-subscribe__submit-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 54px;
	margin-top: 14px;
	padding: 0px 18px;
	border-radius: 14px;
	border: 1px solid $color-white;
	flex: 0 0 100%;
	font-size: 14px;
	font-weight: 500;
	line-height: 16px;
	color: $color-white;
	box-sizing: border-box;

	@include desktop {
		min-height: 64px;
		margin-top: 16px;
		padding: 0px 24px;
		border-radius: 16px;
		font-size: 16px;
		line-height: 18px;
	}
}

.blog-posts-section__email-subscribe__success {
	position: absolute;
	inset: 0;
	display: flex;
	flex-flow: column;
	align-items: center;
	justify-content: center;
	color: white;
	padding: 24px;
	background-color: #1f895b;
	z-index: 2;

	&:not(.visible) {
		display: none;
	}

	svg {
		width: 54px;
		height: 54px;
	}

	b {
		margin-top: 20px;
		font-size: 32px;
		font-weight: 700;
		line-height: 100%;
		text-align: center;
		letter-spacing: -0.03em;
		color: #ffffff;
	}

	p {
		margin-top: 16px;
		font-size: 16px;
		line-height: 18px;
		text-align: center;
		color: #ffffff;
	}
}
