/***** banner *****/
.banner_txt_img 								{ position: relative; overflow: hidden; padding-top: 140px;}
.banner_txt_img:before 							{ height: 80%; position: absolute; left: 20px; right: 5vw; top: calc(100% - 40px); background: var(--bgColorLight); z-index: -1; border-radius: 20px; transition: none; content: ""; visibility: hidden;}
.banner_txt_img .container						{ display: grid; grid-template-columns: 1fr 55%; grid-gap: 60px; align-items: center;}
.banner_txt_img .img   							{ position: relative; z-index: 5;}
.banner_txt_img .img picture 					{ position: relative; display: block;}
.banner_txt_img .img img  						{ width: 100%; height: auto; object-fit: cover; position: relative; display: block; border-radius: var(--imgRadius); aspect-ratio: 3/2;}
.banner_txt_img .txt 							{ position: relative; text-align: right;}
.banner_txt_img .txt .wrap  					{ max-width: none; text-align: left;}
.banner_txt_img .txt .wrap>:first-child			{ margin-bottom: 5px;}

@media (max-width:1200px) {
.banner_txt_img 								{ padding-top: 120px;}
.banner_txt_img .container						{ grid-gap: 40px;}
.banner_txt_img .img img  						{ aspect-ratio: 1.1/1;}
}
@media (max-width:1000px) {
.banner_txt_img 								{ padding-top: 100px;}
.banner_txt_img .container						{ grid-template-columns: 1fr;}
.banner_txt_img .img   							{ grid-area: 1;}
.banner_txt_img .img img  						{ aspect-ratio: 3/2.2;}
.banner_txt_img .txt .wrap   					{ text-align: center;}
}
@media (max-width:700px) {
.banner_txt_img 								{ padding-top: 70px;}
.banner_txt_img .container						{ grid-gap: 25px;}
.banner_txt_img .img   							{ margin: 0 -5vw;}
.banner_txt_img .img img  						{ border-radius: 0;}
.banner_txt_img .txt:before 					{ width: 100vw; left: -5vw; bottom: 30px;}
}


/* custom link cta*/
.banner_txt_img .cta							{ height: 80px; font-size: 16px; line-height: 80px; padding: 0 90px 0 0; text-align: left; margin-top: 10px; overflow: hidden;}
.banner_txt_img .cta:after 						{ width: 40px; height: 100%; background: url("../images/arrow_link.svg") 50% no-repeat; position: absolute; right: 25px; top: 0; content: "";}
.banner_txt_img .cta span 						{ display: block; position: relative; padding-left: 105px;}
.banner_txt_img .cta span:after					{ width: 80px; height: 100%; background: url("../images/devis_v1.svg") 50% no-repeat #000; position: absolute; left: 0; top: 0; content: "";}

@media (max-width:700px) {
.banner_txt_img .cta							{ width: 100%; height: 60px; display: block; font-size: 14px; line-height: 60px; padding: 0 80px 0 0; text-align: left; margin-top: 20px;}
.banner_txt_img .cta:after 						{ right: 20px;}
.banner_txt_img .cta span 						{ padding-left: 80px;}
.banner_txt_img .cta span:after					{ width: 60px; background-size: 22px auto;}
}



/***** assets v1 *****/
.assets_v1 									{ text-align: center; position: relative; margin: 0; padding: clamp(20px, 10vw, 100px) 0;}
.assets_v1:before 							{ position: absolute; left: 20px; right: 20px; top: -40px; bottom: 0; border-radius: 40px 40px 0 0; background: var(--bgColorLight); z-index: -1; content: "";}
.assets_v1 .container 						{ display: grid; justify-content: space-between; position: relative;}
.assets_v1.col_3 .container 				{ grid-template-columns: repeat(3, 1fr);}
.assets_v1.col_4 .container 				{ grid-template-columns: repeat(4, 1fr);}
.assets_v1.col_5 .container 				{ grid-template-columns: repeat(5, 1fr);}
.assets_v1.col_6 .container 				{ grid-template-columns: repeat(6, 1fr);}
.assets_v1 .item img 						{ display: block; margin: 0 auto; border-radius: 0;}
.assets_v1 .item p 							{ width: 200px; height: 70px; display: grid; align-items: center; margin: 20px auto 0 auto; font-size: 16px; line-height: 22px; font-weight: 600; background: #fff; padding: 5px 15px; border-radius: 25em;}

@media (max-width: 1600px){
.assets_v1:before 							{ left: 0; right: 0; border-radius: 0;}
}
@media (max-width: 1200px){
.assets_v1 .item p 							{ width: 150px; height: 60px; font-size: 14px; line-height: 20px; padding: 5px 10px; border-radius: var(--linkRadius);}
}
@media (max-width: 1000px){
.assets_v1:before 							{ top: -50px;}
}
@media (max-width: 700px){
.assets_v1:before 							{ top: -30px; bottom: -45vw;}
.assets_v1.col_3 .container,
.assets_v1.col_4 .container,
.assets_v1.col_5 .container,
.assets_v1.col_6 .container					{ grid-template-columns: repeat(2, 1fr); grid-gap: clamp(15px, 5vw, 40px);}
.assets_v1 .item img 						{ width: 60px; height: auto;}
.assets_v1 .item p 							{ width: 100%; height: 54px; font-size: 13px; line-height: 18px; padding: 5px 10px; border-radius: var(--linkRadius);}
}




/***** card item : bg img + hover content */
.card_item_v2 								{ position: relative; border-radius: var(--imgRadius) var(--imgRadius) 0 var(--imgRadius); overflow: hidden; text-align: left;}
.card_item_v2 img							{ width: 100%; height: auto; display: block; aspect-ratio: 1/1; object-fit: cover; filter: brightness(0.9);}
.card_item_v2 .wrap							{ position: absolute; left: 0; bottom: 0; width: 100%; z-index: 5; padding: 40px 90px 40px 40px;}
.card_item_v2 .wrap:before             		{ position: absolute; bottom: 0; left: 0; right: 0; height: 250%; background: linear-gradient(to top, rgba(0,0,0,45%) 0%, rgba(0,0,0,0) 100%); transition: none; content: "";}
.card_item_v2 .wrap .sous_titre				{ color: #fff; font-size: 22px; line-height: 30px;}
.card_item_v2 .wrap :last-child				{ margin-bottom: -5px;}
.card_item_v2 .hover_show					{ position: absolute; left: 0; top: 0; color: #fff; background: rgba(0,0,0,75%); width: 100%; height: 100%; padding: 40px; display: none;}
.card_item_v2 .hover_show a        			{ z-index: 10;}
.card_item_v2 .hover_show p a        	    { z-index: 10; color: #fff; border-bottom: 1px solid #555; }
.card_item_v2 .link_pos                    	{ position: absolute; bottom: -10px; right: -10px; padding: 10px; background: #fff; border-top-left-radius: 35%; z-index: 10;}
.card_item_v2 .link_pos:before             	{ position: absolute; bottom: 10px; left: -20px; background: transparent; width: 20px; height: 20px; border-bottom-right-radius: var(--imgRadius); box-shadow: 10px 10px 0 10px #fff; transition: none; content: "";}
.card_item_v2 .link_pos:after              	{ position: absolute; top: -20px; right: 10px; background: transparent; width: 20px; height: 20px; border-bottom-right-radius: var(--imgRadius); box-shadow: 10px 10px 0 10px #fff; transition: none; content: "";}
.card_item_v2 .link_pos .link_arrow        	{ z-index: 20;}
.card_item_v2 .link_pos .link_arrow:after   { width: 100vw; height: 100vh; position: absolute; right: 0; bottom: 0; content: "";}

@media (min-width:1201px) {
.card_item_v2 .hover_show 					{ display: block; opacity: 0; visibility: hidden; transition: all 300ms ease-in-out;}
.card_item_v2:hover .hover_show 			{ opacity: 1; visibility: visible;}
}
@media (max-width:1600px) {
.card_item_v2 .wrap							{ padding: 30px 90px 30px 30px;}
}
@media (max-width:1200px) {
.card_item_v2 .wrap							{ padding: 30px 90px 30px 30px;}
.card_item_v2 .wrap .sous_titre				{ font-size: 20px; line-height: 28px;}
.card_item_v2 .link_pos .link_arrow:after   { height: 100vh;}
}
@media (max-width:700px) {
.card_item_v2 .wrap							{ padding: 25px 65px 25px 25px;}
.card_item_v2 .wrap :last-child				{ margin-bottom: -3px;}
.card_item_v2 .wrap .sous_titre				{ font-size: 16px; line-height: 22px;}
.card_item_v2 .link_pos                    	{ padding: 10px; border-top-left-radius: 30%;}
.card_item_v2 .link_pos:before             	{ left: -20px; width: 20px; height: 20px;}
.card_item_v2 .link_pos:after              	{ top: -20px; width: 20px; height: 20px;}
.card_item_v2 .link_pos .link_arrow        	{ width: 40px; height: 40px; border-top-left-radius: 10px;}
}



/***** grid bloc *****/
.grid_bloc	 								{ position: relative; padding: 0; margin: var(--marginTB); margin-top: 0;}
.grid_bloc:before 							{ position: absolute; left: 20px; right: 20px; bottom: 65%; top: 0; background: var(--bgColorLight); z-index: -1; border-radius: 0 0 40px 40px; transition: none; content: "";}
.grid_bloc .container						{ display: grid; grid-gap: 40px; text-align: center;}

@media (max-width:2000px) {
.grid_bloc .container						{ grid-gap: 30px;}
}
@media (max-width:1600px) {
.grid_bloc:before 							{ left: 0; right: 0; border-radius: 0;}
.grid_bloc .container						{ grid-gap: 20px;}
}
@media (max-width:1400px) {
.grid_bloc .container						{ grid-gap: clamp(10px, 5vw, 30px);}
}
@media (max-width:700px) {
.grid_bloc:before 							{ display: none;}
}

/* custom colums */
.grid_bloc.col_2 .container					{ grid-template-columns: repeat(2, 1fr);}
.grid_bloc.col_3 .container					{ grid-template-columns: repeat(3, 1fr);}
.grid_bloc.col_4 .container					{ grid-template-columns: repeat(4, 1fr);}

@media (max-width:1400px) {
.grid_bloc.col_4 .container					{ grid-template-columns: 1fr 1fr;}
}
@media (max-width:1000px) {
.grid_bloc.col_3 .container					{ grid-template-columns: 1fr 1fr;}
}
@media (max-width:800px) {
.grid_bloc.col_3 .container					{ grid-template-columns: 1fr;}
}
@media (max-width:700px) {
.grid_bloc.col_2 .container,	
.grid_bloc.col_3 .container,					
.grid_bloc.col_4 .container					{ grid-template-columns: 1fr;}
}



/***** quote : simple *****/
.quote_simple 											{ position: relative; text-align: center; margin: var(--marginTB);}
.quote_simple:before									{ position: absolute; width: 94vw; max-width: calc(47vw + 720px); left: auto; right: 3vw; top: 0; bottom: 0; background: #eee; border-radius: 50px; visibility: hidden; transition: none; content: "";}
.quote_simple svg										{ width: 60px; height: auto; display: block; margin: 0 auto 15px auto;}
.quote_simple p               							{ margin-bottom: 15px;}
.quote_simple .link										{ margin-top: 10px;}
.quote_simple :last-child								{ margin-bottom: 0;}
.quote_simple .multi_links								{ display: grid; grid-template-columns: 1fr 1fr; max-width: 300px; grid-gap: 10px; margin: 25px auto 0 auto;}
.quote_simple .multi_links .link						{ margin: 0; text-align: center; padding: 0;}

@media (max-width:700px) { 
.quote_simple svg										{ width: 40px; margin-bottom: 10px;}
.quote_simple p               							{ margin-bottom: 10px;}
.quote_simple .multi_links								{ max-width: none; margin-top: 20px;}
}


/* custom highlight */
.quote_simple span.txt_highlight    					{ padding-bottom: 2px; display: inline-block; margin: 2px 0; border-bottom: 2px solid var(--mainColor1); color: var(--mainColor1);}

@media (max-width:700px) { 
.quote_simple span.txt_highlight    					{ padding-bottom: 0;}
}




/***** about *****/
.about:before										{ visibility: visible;}
.about .titre_main 									{ margin-bottom: 5px;}
.about .show_hide .item:last-child 					{ margin-bottom: 0;}


/***** moving img *****/
.moving_img									{ position: relative; overflow: hidden; margin: var(--marginTB); padding: 20px 0 0 0;}
.moving_img .row 							{ width: auto; display: flex;}
.moving_img .row .grid 						{ width: auto; display: flex; animation: moving_img 80s linear infinite;}
.moving_img .row .grid div 					{ padding: 0 10px;}
.moving_img .row .grid img 					{ width: auto; height: auto; display: block; border-radius: var(--imgRadius); object-fit: cover; /*aspect-ratio: 4/3;*/ transition: all 300ms ease-in-out;}

@keyframes moving_img {
0%											{ transform: translate(0, 0);}
100% 										{ transform: translate(-100%, 0);}
}
@media (max-width:1600px) {
.moving_img .row .grid img 					{ height: 400px;}
}
@media (max-width:1200px) {
.moving_img .row .grid div 					{ padding: 0 10px;}
.moving_img .row .grid img 					{ height: 350px;}
}
@media (max-width:1000px) {
.moving_img									{ padding: 0;}
.moving_img .row .grid img 					{ height: 350px;}
}
@media (max-width:700px) {
.moving_img .row .grid div 					{ padding: 0 5px;}
.moving_img .row .grid img 					{ height: 60vw; max-height: 350px;}
}




