
.section.cases h2 {
	margin: 0 0 84px;
}
.cases_masonry {
	margin: 0 0 42px;
}
.cases_masonry .item {
	position: relative;
	z-index: 1;
	padding: 42px;
	color: var(--white);
}
.cases_masonry .item .gallery {
	position: absolute;
	z-index: -1;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}
.cases_masonry .item .h3 {
	margin: 0;
}
.cases_masonry .item:before {
	display: block;
	content: '';
	height: 100%;
	width: 100%;
	background: linear-gradient(180deg, rgba(0, 0, 0, 0.7) 0%, rgba(0, 0, 0, 0.5) 100%);
	position: absolute;
	z-index: 1;
	left: 0;
	top: 0;
	opacity: 0;
	pointer-events: none;
	transition: 0.3s;
}
.cases_masonry .item:after {
	display: block;
	content: '';
	height: 24px;
	width: 24px;
	background: url('arrow.svg');
	position: absolute;
	z-index: 1;
	right: 18px;
	bottom: 18px;
	opacity: 0;
	pointer-events: none;
	transition: 0.3s;
}
.cases_masonry .item a, .cases_masonry .item .h3, .cases_masonry .item .text {
	position: relative;
	z-index: 2;
	opacity: 0;
	pointer-events: none;
}
.cases_masonry .item a {
	display: block;
	height: 100%;
	width: 100%;
	position: absolute;
	z-index: 2;
	left: 0;
	top: 0;
}
.cases_masonry .item img {
	height: 100%;
	width: 100%;
	position: absolute;
	left: 0;
	top: 0;
	object-fit: cover;
}
.cases_masonry .item:hover:before,
.cases_masonry .item:hover:after,
.cases_masonry .item:hover a,
.cases_masonry .item:hover .h3,
.cases_masonry .item:hover .text,
.cases_masonry .item.active:before,
.cases_masonry .item.active:after,
.cases_masonry .item.active a,
.cases_masonry .item.active .h3,
.cases_masonry .item.active .text {
	opacity: 1;
	pointer-events: all;
}



@media (max-width: 1200px) {
	
	.cases_masonry .item {
		padding: 24px;
	}
	.cases_masonry .grid.row1, .cases_masonry .grid.row2 {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 991.98px) {

	.section.cases h2 {
		margin: 0 0 60px;
	}
}
@media (max-width: 767px) {
	
	.cases_masonry .item {
		min-height: 200px;
	}
	.cases_masonry .row1 > .item, .cases_masonry .row2 > .item {
		min-height: 300px;
	}
}

@media (max-width: 575px) {
	
	.cases_masonry .item {
		min-height: 150px;
	}
	.cases_masonry .row1 > .item, .cases_masonry .row2 > .item {
		min-height: 200px;
	}
	.cases_masonry .grid {
		gap: 16px;
	}
	.section.cases h2 {
		margin: 0 0 40px;
	}
}
@media (max-width: 450px) {
	.cases_masonry .grid.col2 {
		grid-template-columns: 1fr;
	}
	.cases_masonry .item {
		min-height: 80vw !important;
	}
}

