.cont-solutions {
	overflow: hidden;
	position: relative;
	padding: 4em 16% 2em 16%;
}

.cont-solutions:before {
	top: 10%;
	left: 8%;
	content: "";
	width: 245px;
	height: 245px;
	display: block;
	opacity: 0.5;
	position: absolute;
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
	background-image: url(/wp-content/uploads/2022/12/logo-icon.svg);
}


.cont-solutions:after {
	left: 0;
	right: 0;
	bottom: 12%;
	content: "";
	width: 100%;
	height: 30%;
	display: block;
	position: absolute;
	background-position: center;
	background-repeat: no-repeat;
	background-image: url(/wp-content/uploads/2022/12/solutions-overlay.svg);
}


.cont-solutions > div.titles {
	width: 60%;
	margin: auto;
	position: relative;
	text-align: center;
	display: flex;
	align-items: center;
	flex-direction: column;
	justify-content: center;
	margin-bottom: 2em;
}

.cont-solutions > div.titles:before {
	z-index: 9;
	color: #707070;
	position: absolute;
	content: "* Soumis à conditions de ressources";
}

.cont-solutions > div.titles:after {
	content: "";
	width: 20px;
	height: 20px;
	bottom: -2em;
	display: block;
	position: absolute;
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
	transition: all .5s ease-in-out;
	animation: slideDownUp 2s ease-out infinite;
	background-image: url("/wp-content/themes/astra-child/assets/img/arrow-m.svg");
}


@keyframes slideDownUp {
	0% {
		bottom: -1em;
	}
	50% {
		bottom: -3em;
	}
	100% {
		bottom: -1em;
	}
}

.cont-solutions > div.titles > span {
	z-index: 99;
	color: #ef720e;
	font-size: 35px;
	line-height: 16px;
	letter-spacing: 0;
	font-weight: 400;
	font-style: normal;
	font-family: adobe-handwriting-ernie, sans-serif;
}

.cont-solutions > div.titles > h1 {
	color: #731c6d;
	font-size: 40px;
	line-height: 43px;
	margin: 0!important;
	text-transform: uppercase;

}

.cont-solutions > div.titles > h1 > span {
	text-decoration: underline;
}

.swiper-solutions {
	padding: 2em;
}


.solut-items {
	padding-top: 2em;
	padding-bottom: 2em;
}

.item-solut {
	background-color: #ffffff;
	border-radius: 0 0 30px 0;
	box-shadow: 0 3px 30px #00000012;
}

.item-solut .item-bg {
	height: 230px;
	overflow: hidden;
	position: relative;
	background-size: cover;
	border-radius: 0 0 30px 0;
	background-position: center;
	background-repeat: no-repeat;
}

.item-solut .item-bg .bg {
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	position: absolute;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}

.item-solut .item-content {
	padding: 1.5em;
	text-align: center;
	border-radius: 0 0 30px 0;
}



.item-solut .item-content h2 {
	/*font-size: 38px;*/
	line-height: 40px;
	font-weight: 700;
	letter-spacing: 0;
	margin-bottom: 10px;
	opacity: 1!important;
	text-transform: none!important;
	font-size: calc(24px + 6 * ((100vw - 320px) / 680))!important;
}

.item-solut .item-content h2 span {
	opacity: 0.7;
	font-size: 13px;
	line-height: 16px;
	font-weight: 400;
	text-align: center;
	letter-spacing: 0.52px;
	text-transform: uppercase;
	font-family: "Montserrat", Sans-serif;
}

.item-solut .item-content .item-descr {
	color: #4D4D4D;
	/*font-size: 13px;*/
	line-height: 20px;
	font-weight: 400;
	text-align: center;
	padding-bottom: 1em;
	letter-spacing: 0.33px;
	font-family: "Montserrat", Sans-serif;
	font-size: calc(-1px + 6 * ((100vw - 320px) / 680))!important;
}

.item-solut .item-content a {
	color: #ffffff;
	display: flex;
	font-size: 16px;
	font-weight: 400;
	padding: 0.5em 1em;
	border-radius: 50px;
	align-items: center;
	text-decoration: none;
	background-color: #a8ab00;
	font-family: "Montserrat", Sans-serif;
}

.item-solut .item-content a > span {
	width: 100%;
	display: flex;
	padding-right: 4em;
	position: relative;
	align-items: center;
}

.item-solut .item-content a > span:after {
	right: 0;
	content: "";
	width: 16px;
	height: 16px;
	display: block;
	position: absolute;
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
	transition: all .5s ease-in-out;
	background-image: url("/wp-content/themes/astra-child/assets/img/arrow-w.svg");
}

.item-solut .item-content a:hover > span:after {
	right: 3em;
}

/*RESPONSIVE*/

/*phone*/
@media (max-width: 767px) {

	.cont-solutions:before {
		top: 10%;
		left: 0;
		width: 120px;
		height: 120px;
	}

	.cont-solutions > div.titles:before {
		top: -55%;
		font-size: 10px;
	}

	.cont-solutions > div.titles > span {
		font-size: 16px;
		line-height: 30px;
	}

	.cont-solutions > div.titles > h1 {
		font-size: 18px;
		line-height: 14px;
	}

	.item-solut {
		width: 310px;
	}

	.item-solut .item-bg {
		height: 180px;
	}

	.item-solut .item-content {
		padding: 1.2em;
	}

	.item-solut .item-content h2 {
		font-size: 26px;
		line-height: 30px;
	}

	.item-solut .item-content a > span {
		padding-right: 1em;
	}

	.item-solut .item-content .item-descr {
		font-size: 14px!important;
	}


}

/*tablet*/
@media (min-width: 768px) and (max-width: 1024px) {


	.cont-solutions:before {
		top: 15%;
		left: 15%;
		width: 120px;
		height: 120px;
	}

	.cont-solutions > div.titles:before {
		top: -42%;
		right: -5%;
		font-size: 10px;
	}

	.cont-solutions > div.titles > span {
		font-size: 31px;
		line-height: 20px;
	}

	.cont-solutions > div.titles > h1 {
		font-size: 36px;
		line-height: 40px;
	}

	.item-solut {
		width: 360px;
	}

	.item-solut .item-bg {
		height: 200px;
	}
	.item-solut .item-content h2 {
		line-height: 30px;
	}

	.item-solut .item-content .item-descr {
		font-size: 12px!important;
	}


}

/*mobile and tablet*/
@media (max-width: 1024px) {

	.cont-solutions {
		 padding: 3em 0 2em 0;
	}

	.cont-solutions > div.titles {
		width: 90%;
	}

	.cont-solutions:after {
		display: none!important;
	}

}

/*desktop*/
@media (min-width: 1025px) {


	.cont-solutions > div.titles:before {
		/*bottom: 0;*/
		top: -50%;
		left: -18%;
	}

}

/*pc portable*/
@media (min-width: 1025px) and (max-width: 1700px) {

	.cont-solutions {
		padding: 3em 8% 2em 8%;
	}

	.cont-solutions:before {
		left: 0;
		top: 10%;
		width: 220px;
		height: 220px;
	}

	.cont-solutions:after {
		bottom: 20%;
		height: 20%;
		background-size: 100%;
	}

	.cont-solutions > div.titles {
		width: 80%;
	}

	.cont-solutions > div.titles:before {
		top: -45%;
		left: 6%;
	}

	.item-solut .item-content {
		padding: 1em;
	}

	.item-solut .item-content .item-descr {
		/*font-size: 12px;*/
		font-size: calc(1.2px + 6 * ((100vw - 320px) / 680)) !important;
	}


}


/*RESPONSIVE*/
