/***** fonts *****/

/* latin-ext */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 100 900;
  font-stretch: 100%;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3KUBGEe.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Roboto';
  font-style: normal;
  font-weight: 100 900;
  font-stretch: 100%;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/roboto/v49/KFO7CnqEu92Fr1ME7kSn66aGLdTylUAMa3yUBA.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}



/***** variables *****/
:root {
	--orange: #ff6b00;
	--gradient: linear-gradient(to bottom, #fca61b 0%, #ff7404 100%);
	--gradientLink: linear-gradient(to bottom, #ff7404 0%, #fca61b 50%, #ff7404 100%);
	--txtColor: #fff;
	
	--bgColorDark: #171715;
	
	--marginTB: clamp(70px, 8vw, calc(120px + 2vw)) auto;
	--marginT: clamp(70px, 8vw, calc(120px + 2vw));
	--marginB: clamp(70px, 8vw, calc(120px + 2vw));

	--paddingTB: clamp(60px, 5vw, calc(120px + 2vw)) 0;

	--maxWidthWrapper: 1200px;
	--maxWidthWrapperSmall: 1000px;
	--maxWidthWrapperMedium: 1400px;
	--maxWidthWrapperLarge: 1800px;

	--imgRadius: 10px;
	--linkRadius: 5px;

}
@media (max-width:1000px) {
	:root {
		--marginTB: clamp(45px, 12vw, 70px) auto;
		--marginT: clamp(45px, 12vw, 70px);
		--marginB: clamp(45px, 12vw, 70px);
	}
}


/***** reset *****/
/*html 									{ scroll-behavior: smooth;}*/
body, ul, li, ol, form, h1, h2, h3, h4, h5, h6, div, span, p { padding:0; margin:0; border:0; -webkit-text-size-adjust: none; -moz-text-size-adjust: none; text-size-adjust: none;}
article, aside, dialog ,figcaption, figure, footer, header, hgroup, main, nav, section { display: block;}  
input, textarea							{ -webkit-appearance: none; -ms-appearance: none; appearance: none; -moz-appearance: none; -o-appearance: none; border-radius: 0;}
*          								{ outline: none;}
strong, b								{ font-weight: 500; font-size: clamp(13px, 1.2vw, 16px);}
p										{ margin-bottom: clamp(10px, 2vw, 15px);}
ul										{ list-style-type: none; margin-bottom: clamp(10px, 2vw, 15px);}
body									{ font: 400 clamp(14px, 1.2vw, 16px)/180% "Roboto"; letter-spacing: 1px; color: var(--txtColor); background: var(--bgColorDark); position: relative;}
body.active_overflow					{ height: 100vh; overflow: hidden;}
a										{ text-decoration: none; position: relative; color: var(--txtColor);}
img										{ border: none;}
main 									{ position: relative; z-index: 10;}
#wrapper 								{ min-width: 320px; position: relative; overflow: hidden;}
#wrapper *								{ box-sizing: border-box;}
#footer 								{ position: relative; z-index: 15;}

@media (max-width:1200px) {
body									{ font-size: clamp(13px, 3vw, 15px);}
strong, b								{ font-size: clamp(13px, 3.2vw, 16px);}
}
@media (max-width:700px) {
body									{ line-height: 170%; letter-spacing: 0.2px;}
strong, b								{ font-weight: 600;}
}


/***** scollbar *****/
::-webkit-scrollbar 					{ width: 6px; height: 6px; background-color: var(--bgColorDark);}
::-webkit-scrollbar-thumb				{ background-color: var(--orange);}


/***** transition *****/
@media (min-width:1201px) {
.link, .slick-arrow, :before, :after, a, a span, .logo, .header, .sub, .read_more, .read_less { transition: all 300ms ease-in-out;}
}


/***** class *****/
.wrapper 								{ width: 90vw; max-width: var(--maxWidthWrapper); margin: 0 auto; position: relative;}
.wrapper_small							{ width: 90vw; max-width: var(--maxWidthWrapperSmall); margin: 0 auto; position: relative;}
.wrapper_medium							{ width: 90vw; max-width: var(--maxWidthWrapperMedium); margin: 0 auto; position: relative;}
.wrapper_large							{ width: 90vw; max-width: var(--maxWidthWrapperLarge); margin: 0 auto; position: relative;}
.wrapper_full							{ margin: 0 5vw; position: relative;}

.margin_top_bottom 						{ margin: var(--marginTB);}
.margin_top 							{ margin-top: var(--marginT);}
.margin_bottom 							{ margin-bottom: var(--marginB);}

.color_1 								{ color: var(--orange);}
.color_2 								{ color: #fff;}
.clear									{ clear: both; display: block;}
.anchor									{ position: absolute; left: 0; top: -140px;}

.titre_main	 							{ font: 700 clamp(25px, 4vw, 40px)/110% "Roboto"; text-transform: uppercase; position: relative; margin-bottom: clamp(10px, 2vw, 15px); letter-spacing: 0.8px;}
.titre_main.no_caps						{ font-size: clamp(32px, 4.5vw, 45px); font-weight: 600; text-transform: inherit; letter-spacing: 0.4px;}
.titre_cap 								{ font: 700 12px/160% "Roboto"; letter-spacing: 1.4px; text-transform: uppercase; color: var(--orange); display: block; padding-bottom: 5px;}
.titre_cap.color_2 						{ color: #fff;}


.sous_titre 							{ font: 500 clamp(20px, 1.6vw, 25px)/140% "Roboto"; position: relative; margin-bottom: clamp(10px, 2vw, 15px);}
.sous_titre.bigger						{ font-size: clamp(22px, 1.8vw, 30px);}
.sous_titre.smaller						{ font-size: 18px; font-weight: 400;}



.chapo		 							{ font: 400 clamp(14px, 1.1vw, 16px)/180% "Roboto"; margin-bottom: clamp(10px, 2vw, 15px);}
.chapo span	 							{ display: inline-block; margin-bottom: clamp(10px, 2vw, 15px);}

.link 									{ font: 700 clamp(13px, 2.5vw, 14px)/60px "Roboto"; letter-spacing: 1.2px; height: 60px; text-transform: uppercase; display: inline-block; color: #fff; padding: 0 30px; border-radius: var(--linkRadius); background: var(--gradientLink); background-size: 100% 200%; background-position: 0 100%; overflow: hidden;}

.link_txt 								{ font: 500 16px/180% "Roboto"; display: inline-block; /*border-bottom: 2px solid var(--orange); padding-bottom: 2px;*/ color: var(--orange);}


.link.devis								{ display: block; max-width: 480px; height: 80px; font-size: 16px; line-height: 78px; padding: 0 100px 0 30px; text-align: left; margin: 10px 0 0 0;}
.link.devis:after 						{ width: 40px; height: 100%; background: url("../images/arrow_link.svg") 50% no-repeat; position: absolute; right: 30px; top: 0; content: "";}
.link.devis span 						{ display: inline-block; padding-left: 60px; background: url("../images/devis.svg") 0 50% no-repeat;}


.read_more,.read_less 								{ display: inline-block; color: var(--orange); font-style: normal; cursor: pointer; transition: color 300ms ease-in-out;}
.hide 									{ display: none;}



/***** hide  *****/
.hide                      { display: none;}
.read_more 			   	   { cursor: pointer; color: var(--orange); }
.read_less                 { cursor: pointer; color: var(--orange);}
.hide_readMore .anchor     { top: -120px; position: relative;}
.hide_readMore             { margin-top: 25px; position: relative; background: var(--mainColor1); color: #ffffff; padding: 50px;}
.hide_readMore a           { color: var(--orange);}
.hide_readMore :last-child { margin-bottom: 0;}

@media (min-width:1201px) {
.read_more:hover   { color: #ffffff; }
.read_less:hover   { color: #ffffff;}
}

.ul_list								{ margin-bottom: clamp(10px, 2vw, 15px);}
.ul_list li								{ padding: 0 0 0 20px; position: relative; margin-top: clamp(5px, 1.5vw, 10px); background: url("../images/list.svg") 0 8px no-repeat;}

.ul_check   							{ margin: clamp(15px, 2vw, 20px) 0;}
.ul_check li 							{ position: relative; padding-left: 32px; line-height: 160%; margin-bottom: 12px;}
.ul_check li:before						{ width: 18px; height: 18px; position: absolute; left: 0; top: 2px; background: url("../images/check.svg") 0 0 / contain no-repeat; content: "";}
.ul_check li:last-child					{ margin-bottom: 0;}


.shape_glow								{ width: 40vw; height: clamp(200px, 100vw, 2600px); position: absolute; right: 0; top: 0; background: url("../images/glow_texture.webp") 100% 50% / contain no-repeat; transition: none; z-index: -1; animation: glow 8000ms ease-in-out infinite;}
.shape_glow.align_left					{ right: auto; left: 0; transform: rotate(180deg);}

@keyframes glow {
0%												{ opacity: 0.4;}
25% 											{ opacity: 1;}
50% 											{ opacity: 0.6;}
75% 											{ opacity: 1;}
100% 											{ opacity: 0.4;}
}



@media (min-width:1201px) {
.link:hover 							{ background-position: 0 0;}
.link_txt:hover							{ border-color: #fff; color: #fff;}


}
@media (max-width:1200px) {
.chapo									{ font-size: clamp(13px, 3vw, 15px);}
.link.devis								{ display: block; max-width: 480px; height: 80px; font-size: 16px; line-height: 78px; padding: 0 30px; text-align: center;}
.link.devis:after  					    { display: none;}
.link.devis span 						{ display: inline-block; padding: 0; background-image: none;}
.titre_cap 								{ display: none;}


}
@media (max-width:700px) {
.link 									{ height: 40px; line-height: 40px; padding: 0 25px;}
.link.devis								{ margin: 0 auto;}

}










/***** header et menu *****/
.header 									{ width: 100%; font-size: 0; line-height: 0; letter-spacing: 0; position: fixed; left: 0; top: 0; z-index: 100; text-align: right; padding: 0; transition: all 300ms ease-in-out;}
.header .logo								{ width: 170px; position: absolute; left: 0; top: 50px; transform-origin: left center; z-index: 850;}
.header .logo img							{ width: 100%; height: auto; display: block;}

.header .header_nav 						{ display: block; position: relative; padding: 60px 0 0 0; min-width: 50%; transition: all 300ms ease-in-out;}
.header .menu 								{ margin: 0;}
.header .menu>li							{ position: relative; display: inline-block; vertical-align: top; margin-right: 40px;}
.header .menu>li:has(.sub_big)				{ position: static;}
.header .menu>li:last-child					{ margin: 0;}
.header .menu>li>a							{ font-size: 14px; line-height: 80px; font-weight: 700; height: 80px; display: block; text-transform: uppercase; letter-spacing: 1.4px;}
.header .menu>li.active>a					{ color: var(--orange);}

.header .sub								{ width: 220px; position: absolute; top: 105%; left: calc(50% - 110px); display: block; visibility: hidden; opacity: 0; padding: 15px 0; background: #fff; box-shadow: 0 0 40px 0 rgba(0,0,0,25%); margin: 0; border-radius: var(--linkRadius);}
.header .sub li								{ width: 100%; margin: 0;}
.header .sub li>a							{ display: block; font-size: 14px; line-height: 20px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; color: #000; padding: 6px 25px; text-align: center;}
.header .sub li.active>a					{ color: var(--orange);}




.header .menu_small 						{ position: absolute; top: 0; right: 0; margin: 0; transition: all 300ms ease-in-out;}
.header .menu_small>li						{ position: relative; display: inline-block; vertical-align: top; margin-right: 35px;}
.header .menu_small>li:after 				{ width: 1px; height: 10px; background: #ccc; position: absolute; left: -20px; top: 24px; content: "";}
.header .menu_small>li:first-child:after,
.header .menu_small>li:last-child:after 	{ display: none;}
.header .menu_small>li:last-child  			{ margin: 0;}
.header .menu_small>li a:not(.link)			{ font-size: 14px; line-height: 40px; height: 40px; display: block; letter-spacing: 0.8px; margin: 10px 0;}
.header .menu_small>li a.tel				{ border-top-left-radius: 0; border-top-right-radius: 0; padding-left: 56px;}
.header .menu_small>li a.tel:after			{ width: 14px; height: 100%; background: url("../images/tel.svg") 50% / contain no-repeat; position: absolute; left: 28px; top: 0; content: "";}
.header .menu_small>li.active>a				{ color: var(--orange);}


@media (min-width:1201px) {
.header .menu_mobile 						{ display: none;}

.header .has_sub>li:hover .sub 				{ opacity: 1; visibility: visible; z-index: 999; top: 85%;}
.header .menu>li:hover 						{ z-index: 999;}		
.header .menu_small>li:hover>a:not(.link),		
.header .menu>li:hover>a,		
.header .sub li a:hover 					{ color: var(--orange);}


.header 									{ background: linear-gradient(to top, rgba(255,255,255,0) 0% 50%, rgba(0,0,0,60%) 50% 100%); background-size: 100% 200%; background-position: 0 100%;}
.sticky .header 							{ background-position: 0 0; backdrop-filter: blur(15px);}
.sticky .header .logo						{ top: 30px;}
.sticky:not(.scrolling_top) .header  		{ top: -60px;}
.sticky:not(.scrolling_top) .header .logo	{ width: 100px; top: 78px;}

}
@media (max-width:1200px) {
.header .menu_mobile						{ width: 60px; height: 100px; display: inline-block; vertical-align: middle; cursor: pointer; position: relative; z-index: 850; margin: 0 -10px 0 30px;}
.header .menu_mobile div					{ width: 40px; height: 2px; background: var(--orange); position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);}
.header .menu_mobile div:before				{ width: 100%; height: 2px; background: var(--orange); position: absolute; left: 0; top: 8px; content: "";}
.header .menu_mobile div:after				{ width: 100%; height: 2px; background: var(--orange); position: absolute; left: 0; top: -8px; content: "";}
.header .menu_mobile.active div				{ height: 0; width: 36px;}
.header .menu_mobile.active div:before		{ top: 0; transform: rotate(45deg);}
.header .menu_mobile.active div:after		{ top: 0; transform: rotate(-45deg);}

.header 									{ background: #00000000;}

.header ::-webkit-scrollbar					{ display: none;}
.header .logo								{ width: 140px; top: 20px;}

.header .header_nav 						{ width: 100%; position: fixed; right: -100%; top: 0; bottom: 0; overflow-y: scroll; z-index: 800; padding: 0; background: #000000; border-top: 100px solid #000000; transition: all 300ms ease-in-out 450ms;}
.header .menu  								{ display: block; width: auto; text-align: left; margin: 5vw 10vw; position: relative; z-index: 100; align-self: start; opacity: 0; transform: translateY(40px); transition: all 300ms ease-in-out 150ms;}
.header .menu>li 							{ width: 100%; display: block; margin: 0;}
.header .menu>li>a							{ font-size: 22px; line-height: 30px; height: auto; padding: 15px 0; color: #fff; transition: none; display: inline-block; z-index: 10;}
.header .menu>li>i							{ width: 100%; height: 60px; display: block; margin-top: -60px; position: relative; z-index: 5; float: right;}
.header .menu>li>i:after					{ width: 44px; height: 44px; background: url("../images/arrow_down.svg") 50% 52% no-repeat #fff; border-radius: 5px; position: absolute; right: 0; top: 10px; content: "";}
.header .menu>li>i.active:after 			{ transform: rotate(180deg);}
.header .sub 								{ width: 100%; position: relative; left: auto; top: auto; padding: 20px 30px; margin: 15px 0; border-radius: 5px; background: #fff; visibility: visible; opacity: 1; display: none; z-index: 150;}
.header .sub li  							{ width: 100%;}
.header .sub li a							{ width: 100%; font-size: 18px; line-height: 24px; height: auto; padding: 10px 0; text-align: left; display: block; background-position: center right;}

.header .menu_small>li a.tel				{ border-radius: var(--linkRadius); padding-left: 56px; margin-top: 40px;}

.header .menu_small 						{ position: relative; top: auto; right: auto; text-align: left; margin: 0 10vw 5vw 10vw; opacity: 0; transform: translateY(40px); transition: all 300ms ease-in-out 0ms;}
.header .menu_small>li						{ display: block; margin: 0 0 10px 0;}
.header .menu_small>li:after 				{ display: none;}
.header .menu_small>li a					{ font-size: 14px; font-weight: 500; height: 50px; line-height: 48px; padding: 0 25px; }
.header .menu_small>li>i					{ width: 60px; height: 50px; display: block; margin-top: -50px; position: relative; z-index: 5; float: right;}
.header .menu_small>li>i:after				{ width: 60px; height: 50px; background: url("../images/arrow_down.svg") 50% 52% no-repeat; float: right; border-radius: 8px; content: "";}
.header .menu_small>li>i.active:after 		{ transform: rotate(-180deg);}
.header .menu_small .sub					{ width: 100%; margin: 0; padding: 10px 0; border-radius: var(--linkRadius); border-top-left-radius: 0; border-top-right-radius: 0; top: -10px; box-shadow: none;}
.header .menu_small .sub li					{ width: 100%; margin: 0; text-align: left;}
.header .menu_small .sub li a				{ font-size: 13px; line-height: 40px; height: 40px; display: block;}

.header.active .header_nav 					{ right: 0; transition-delay: 150ms;}
.header.active .menu 						{ opacity: 1; transform: translateY(0); transition-delay: 450ms;}
.header.active .menu_small 					{ opacity: 1; transform: translateY(0); transition-delay: 600ms;}

.header .cta 								{ position: relative; right: auto; top: auto; vertical-align: middle; height: 50px; line-height: 50px; width: auto; padding: 0 30px 0 60px; text-align: left; z-index: 825;}
.header .cta:after 							{ top: 0; width: 22px; height: 100%; left: 20px; background-position: 0 48%;}

.sticky .header 						    { background: #000000;}

}
@media (max-width:1000px) {
.header .menu  								{ margin: 5vw;}
.header .menu_small 						{ margin: 0 5vw 5vw 5vw;}
}
@media (max-width:700px) {	
.header .menu_mobile						{ margin-left: 15px; height: 60px;}
.header 									{ padding: 5px 0;}
.header .logo								{ width: 100px; top: 10px;} 
.header .header_nav							{ border-top-width: 70px;}
.header .menu>li>a							{ font-size: 15px; line-height: 22px; padding: 12px 0;}
.header .menu>li>i							{ height: 46px; margin-top: -46px;}
.header .menu>li>i:after					{ width: 40px; height: 100%; background-color: transparent; top: 0;}
.header .sub 								{ padding: 12px 22px; margin: 10px 0;}
.header .sub li a							{ font-size: 14px; line-height: 18px; padding: 8px 0;}

.header .menu_small>li a					{ font-size: 13px; height: 44px; line-height: 44px; padding: 0 20px;}
.header .menu_small>li>i					{ width: 50px; height: 44px; margin-top: -44px;}
.header .menu_small>li>i:after				{ width: 50px; height: 44px;}
.header .menu_small .sub li a				{ background-position: right+20px center;}

.header .cta 								{ height: 40px; line-height: 40px; padding: 0 20px 0 40px; font-size: 12px;}
.header .cta:after 							{ width: 16px; left: 15px;}
}


/***** side btn fixed *****/
.side_btn 								{ position: fixed; right: 0; top: 50%; transform: translateY(-50%); z-index: 999;}
.side_btn a								{ display: block; width: 70px; background: #fff; border-radius: var(--linkRadius) 0 0 var(--linkRadius); text-align: center; padding: 10px;}
.side_btn a	img							{ display: block; width: 40px; height: auto; margin: 0 auto;}

.side_btn a	span						{ font-size: 16px; line-height: 20px; font-weight: 600; color: #000; display: block; margin-top: 5px; letter-spacing: 0;}


@media (max-width:1200px) {
.side_btn 								{ display: none;}	
}




/***** slick *****/
.slick-slider										{ position:relative; display: block; box-sizing: border-box; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; -webkit-touch-callout: none; -khtml-user-select: none; -webkit-tap-highlight-color: transparent;}
.slick-list											{ position: relative; display: block; overflow: hidden; margin: 0; padding: 0;}
.slick-list:focus									{ outline: none;}
.slick-list.dragging								{ cursor: pointer; cursor: hand;}
.slick-slider .slick-track,
.slick-slider .slick-list							{ -webkit-transform: translate3d(0 0,0); -moz-transform: translate3d(0,0,0); -ms-transform: translate3d(0,0,0); -o-transform: translate3d(0,0,0); transform: translate3d(0,0,0);}
.slick-track										{ position: relative; top: 0; left: 0; display: block;}
.slick-track:before, 
.slick-track:after 									{ display: table; content: '';}
.slick-track:after									{ clear: both;}
.slick-loading .slick-track							{ visibility: hidden;}
.slick-slide										{ display: none; float: left; height: 100%; min-height: 1px;}
[dir='rtl'] .slick-slide							{ float: right;}
.slick-slide img									{ display: block;}
.slick-slide.slick-loading img						{ display: none;}
.slick-slide.dragging img							{ pointer-events: none;}
.slick-initialized .slick-slide						{ display: block;}
.slick-loading .slick-slide							{ visibility: hidden;}
.slick-vertical .slick-slide 						{ display: block; height: auto; border: 1px solid transparent;}


/***** slick dots *****/
.slick-dots  										{ width: 100%; text-align: center; line-height: 0; margin: 0; position: absolute; left: 0; right: 0; bottom: clamp(-50px, -8vw, -25px);}
.slick-dots li 										{ display: inline-block; vertical-align: middle; margin: 0 8px;}
.slick-dots button									{ border: none; font-size: 0; padding: 0; width: 12px; height: 12px; background: #ccc;}
.slick-active button								{ background: #000;}


/***** slick arrows *****/
.slick-arrow										{ width: clamp(20px, 4vw, 50px); height: 60px; border: 0; padding: 0; font-size: 0; cursor: pointer; background: url("../images/arrow_slider.svg") 50% no-repeat;}
.slick-disabled 									{ opacity: 0.65; cursor: default;}
.slick-next											{ left: auto; float: right;}
.slick-prev											{ transform: rotate(180deg);}

@media (max-width:1200px) { 
.slick-dots button									{ width: 10px; height: 10px;}
}
@media (max-width:700px) { 
.slick-prev,
.slick-next											{ background-size: auto 20px;}
.slick-dots li 										{ margin: 0 7px;}
.slick-dots button									{ width: 8px; height: 8px;}
}




/***** CTA *****/
.cta_bloc  								{ position: relative;}
.cta_bloc .container 					{ position: relative; display: grid; grid-template-columns: 45% 1fr; align-items: center; background: var(--gradient); border-radius: var(--linkRadius); overflow: hidden; text-align: center;}
.cta_bloc .titre_main				    { background: #fff; color: var(--bgColorDark); padding: 45px 30px; position: relative; z-index: 5; margin-bottom: 0; font-size: 20px;}
.cta_bloc .titre_main span				{ color: var(--orange);}
.cta_bloc .titre_main:before 			{ position: absolute; right: -7px; top: 50%; background: #fff; width: 14px; height: 14px; transform: translateY(-50%) rotate(-45deg); transition: none; content: "";}
.cta_bloc .row     						{ position: relative; overflow: hidden; padding: 20px 30px;}
.cta_bloc .row .link   					{ text-align: left; padding: 0 30px 0 56px; color: var(--bgColorDark); display: block; letter-spacing: 0.6px;}
.cta_bloc .row .tel   					{ display: inline-block; vertical-align: middle;}
.cta_bloc .row .tel a 					{ background: url("../images/tel_orange.svg") 28px 50% no-repeat #fff;}
.cta_bloc .row .form   					{ display: inline-block; vertical-align: middle; margin-left: 5px;}
.cta_bloc .row .form a					{ background: url("../images/email_orange.svg") 22px 50% no-repeat #fff;}

@media (min-width: 1201px){
.cta_bloc .row .link:hover 				{ color: var(--orange);}
}
@media (max-width: 1200px){
.cta_bloc 								{ grid-template-columns: auto 1fr;}
}
@media (max-width: 1000px){
.cta_bloc 								{ grid-template-columns: 1fr;}
.cta_bloc .titre							{ padding: 30px;}
.cta_bloc .titre:before					{ right: 50%; margin: 0 7px 0 0; top: auto; bottom: -7px;}
}
@media (max-width: 700px){
.cta_bloc 								{ border-radius: 0; text-align: left; margin: 0; padding: 0; border-radius: 0; background: none;}
.cta_bloc .sous_titre                   { background: none; padding: 0; margin-bottom: 10px;}
.cta_bloc .titre						{ color: var(--white); font-size: 16px; letter-spacing: 1.4px; font-weight: 700; text-transform: uppercase; padding: 0; background: none; margin: -5px 0 15px 0;}
.cta_bloc .titre:before					{ display: none;}
.cta_bloc .titre span					{ color: var(--white);}
.cta_bloc .row     						{ padding: 40px 6vw; background: var(--main-color); border-radius: 5px;}
.cta_bloc .row:before					{ display: none;}
.cta_bloc .row .link   					{ display: block; text-align: center; padding: 0 20px;}
.cta_bloc .row .tel   					{ display: block;}
.cta_bloc .row .tel a 					{ background-image: none;}
.cta_bloc .row .form   					{ display: block; margin: 10px 0 0 0;}
.cta_bloc .row .form a 					{ background-image: none;}
}
@media (max-width: 600px){
.cta_bloc .titre_main { text-align: left; padding: 20px;}	
}


/***** bloc txt img *****/
.bloc_txt_img 											{ position: relative;}
.bloc_txt_img.shape:before								{ position: absolute; left: 0; right: 50%; top: 20%; bottom: 20%; background: var(--orange); visibility: visible; transition: none; content: "";}
.bloc_txt_img .container	                        	{ display: grid; grid-template-columns: 1fr 1fr; grid-gap: clamp(20px, 5vw, 80px); align-items: center; position: relative;}
.bloc_txt_img .container>.item							{ position: relative;}
.bloc_txt_img .container>.item :last-child 				{ margin-bottom: 0;}
.bloc_txt_img .container .txt  							{ margin: 0;}
.bloc_txt_img .container .txt .wrap						{ max-width: 580px; margin: 0 auto;}
.bloc_txt_img .container .img img, .bloc_txt_img .container .img video							{ width: 100%; height: auto; object-fit: cover; display: block; border-radius: var(--imgRadius);}


.bloc_txt_img .container .img.col_2  					{ display: grid; grid-template-columns: 1fr 1fr; grid-gap: 40px;}

.bloc_txt_img .container .link							{ margin-top: 10px;}
.bloc_txt_img .container .link_txt						{ margin-top: 8px;}

.bloc_txt_img .container .multi_links					{ display: grid; grid-template-columns: 140px 140px; grid-gap: 10px; margin-top: 25px;}
.bloc_txt_img .container .multi_links .link				{ margin: 0; text-align: center; padding: 0;}

.bloc_txt_img.reverse:before							{ left: 50%; right: 0;}
.bloc_txt_img.reverse .container 						{ grid-template-columns: 1fr 50%;}
.bloc_txt_img.reverse .container>.item:last-child		{ grid-area: 1 / 1;}
.bloc_txt_img.reverse .container>.item:first-child      { grid-area: 1 / 2;}

.bloc_txt_img.align_top .container                		{ align-items: start;}

.bloc_txt_img .shape_glow 								{ top: 50%; transform: translateY(50%);}
.bloc_txt_img .shape_glow.align_left					{ transform: rotate(180deg) translateY(50%);}

@media (max-width:1200px) { 
.bloc_txt_img .container	                        	{ align-items: start;}
}
@media (max-width:1000px) { 
.bloc_txt_img .container 								{ grid-template-columns: 100%; grid-gap: 40px;}
.bloc_txt_img .container .txt .wrap						{ width: 90vw; max-width: none;}
.bloc_txt_img.reverse .container 						{ grid-template-columns: 1fr;}
.bloc_txt_img.reverse .container>.item:last-child		{ grid-area: 2;}
.bloc_txt_img.reverse .container>.item:first-child      { grid-area: 1;}
.bloc_txt_img .container .img img						{ width: 100%; height: 70vh;}
}
@media (max-width:700px) { 
.bloc_txt_img .container	                        	{ grid-gap: 30px;}
.bloc_txt_img .container p               				{ margin-bottom: 10px;}
.bloc_txt_img .container .multi_links					{ grid-template-columns: 1fr 1fr; grid-gap: 10px; margin-top: 20px;}
.bloc_txt_img .container .img img						{ width: 100%; height: 50vh;}
}




.bloc_txt_img .video 							{ position: relative;}
.bloc_txt_img .video img 						{ display: block; width: 100%; height: auto; position: relative; z-index: 5;}
.bloc_txt_img .video a 							{ position: absolute; left: 0; top: 0; right: 0; bottom: 0; z-index: 5;}
.bloc_txt_img .video a span						{ position: absolute; left: 50%; top: 50%; width: 110px; height: 110px; background: url("../images/play.svg") 55% 50% no-repeat #fff; border-radius: 50%; transform: translate(-50%, -50%);}
#homepage .bloc_txt_img .video a span 			{ left: 50%; top: 90%; width: 80px; height: 80px; background: url("../images/play.svg") 55% 50% no-repeat #fff; transform: translate(-50%, -90%);}
.bloc_txt_img .grid 							{ display: grid; grid-template-columns: 1fr 1fr; grid-gap: 60px; margin-top: 60px;}
.bloc_txt_img .grid .link_arrow					{ margin-top: 25px;}

/* custom fancybox */
.fancybox-is-open .fancybox-bg 			        { opacity: 1;}
.fancybox-bg							        { background: rgba(0,0,0);}
.fancybox-slide 						        { cursor: url(../images/close.svg), auto;}
.fancybox-slide>* 						        { padding: 0; margin: 40px 0; max-width: 90vw; cursor: default;}

@media (min-width:1201px) {
.bloc_txt_img .video a:hover   					{ background: rgba(0,0,0,0.5);}
}

@media (max-width:1200px) {
.bloc_txt_img .grid 							{ grid-gap: 5vw;}
}
@media (max-width:1000px) {
.bloc_txt_img .titre_main 						{ margin: 40px 0 20px 0;}
.bloc_txt_img .video a span						{ width: 90px; height: 90px; background-size: 22px auto;}
.bloc_txt_img .grid 							{ grid-template-columns: 1fr; grid-gap: 50px; margin-top: 50px;}
}
@media (max-width:600px) {
.bloc_txt_img .video 							{ margin-top: 40px;}
.bloc_txt_img .video a span						{ width: 60px; height: 60px; background-size: 16px auto;}
.bloc_txt_img .grid 							{ grid-gap: 30px; margin-top: 40px;}
}


/***** grid bloc *****/
.grid_bloc	 											{ position: relative;}
.grid_bloc:before										{ width: auto; height: auto; position: absolute; left: 0; right: 0; top: 0; bottom: 0; background: var(--bgColorLight); transition: none; z-index: -1; visibility: hidden; content: "";}
.grid_bloc .container									{ display: grid; grid-gap: clamp(20px, 5vw, 80px);}
.grid_bloc .container img								{ width: 100%; height: auto; object-fit: cover; display: block; border-radius: var(--imgRadius);}

.grid_bloc .item :last-child							{ margin-bottom: 0;}

@media (max-width:1200px) {
.grid_bloc:before										{ left: 0; right: 0; top: 0; bottom: 0; border-radius: 0;}
}
@media (max-width:700px) {
.grid_bloc .container									{ grid-gap: 10px;}
}

/* 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);}
.grid_bloc.col_5 .container								{ grid-template-columns: repeat(5, 1fr);}
.grid_bloc.col_6 .container								{ grid-template-columns: repeat(6, 1fr);}
.grid_bloc.col_7 .container								{ grid-template-columns: repeat(7, 1fr);}
.grid_bloc.col_8 .container								{ grid-template-columns: repeat(8, 1fr);}

@media (max-width:1200px) {
.grid_bloc.col_4 .container								{ grid-template-columns: 1fr 1fr;}
.grid_bloc.col_7 .container								{ grid-template-columns: repeat(6, 1fr);}
}
@media (max-width:1000px) {
.grid_bloc.col_3 .container								{ grid-template-columns: 1fr;}
.grid_bloc.col_7 .container								{ grid-template-columns: repeat(4, 1fr);}
}
@media (max-width:700px) {
.grid_bloc.col_2 .container,	
.grid_bloc.col_3 .container,					
.grid_bloc.col_4 .container								{ grid-template-columns: 1fr;}
.grid_bloc.col_7 .container								{ grid-template-columns: repeat(3, 1fr);}
}

/* swipe mobile */ 
@media (max-width:700px) {
.swipe_mobile .container 								{ display: flex; gap: 10px; width: 100vw; margin-left: -5vw; overflow-x: auto; padding: 0 5vw;}
.swipe_mobile .container::-webkit-scrollbar 			{ display: none;}
.swipe_mobile .container .item 							{ min-width: clamp(280px, 75vw, 360px);}
}




.card_logo 												{ display: grid; grid-template-columns: clamp(120px, 40% ,200px) 1fr; grid-gap: 40px; align-items: center;}
.card_logo img											{ width: 100%; height: auto; object-fit: cover; aspect-ratio: 1/1; border-radius: var(--imgRadius)}

@media (max-width:1000px) {
.card_logo 												{ grid-template-columns: 100px 1fr; grid-gap: 30px; align-items: start;}	
}


.bloc_light 											{ background: #fff; letter-spacing: 0.4px; color: var(--bgColorDark); padding: clamp(20px, 5vw, 50px) clamp(20px, 5vw, 60px); border-radius: var(--imgRadius);}
.bloc_light p                                           { color: var(--bgColorDark);}
.bloc_light a										    { font-weight: 500; color: var(--orange);}
.bloc_light .link										{ margin-top: 10px; color: #fff}



.bloc_dark 												{ padding: clamp(20px, 5vw, 50px) clamp(20px, 5vw, 60px); border-radius: var(--imgRadius); background: rgba(0,0,0,35%);}
.bloc_dark .link										{ margin-top: 10px;}



.guide  												{ padding-top: 2vw;}
.guide .bloc_light										{ padding-right: 34%;}
.guide .bloc_light .img									{ position: absolute; right: 2%; bottom: 6%; width: 30%;}
.guide .bloc_light .img img								{ width: 100%; height: auto; display: block;}
.guide .bloc_light .img span							{ font-size: 20px; line-height: 26px; letter-spacing: 1px; color: #fff; font-weight: 600; text-align: center; position: absolute; left: -5%; top: -20px;}
.guide .bloc_light .img span:after						{ width: 55px; height: 70px; background: url("../images/arrow_show.svg") 50% / contain no-repeat; position: absolute; left: 50%; top: 120%; transition: none; content: "";}

@media (max-width:1200px) {
.guide .bloc_light .img 								{ bottom: 20%;}
}
@media (max-width:1100px) {
.guide .bloc_light .img									{ bottom: 0; top: -40px;}
}
@media (max-width:800px) {
.guide .bloc_light 										{ padding-right: 140px;}	
.guide .bloc_light .img	 								{ right: -80px;}
.guide .bloc_light .img span							{ display: none;}
}
@media (max-width:600px) {
.guide .bloc_light 										{ padding-right: 5vw;}	
.guide .bloc_light .img	 								{ display: none;}
}

/***** moving img *****/
.moving_img												{ position: relative; overflow: hidden; padding: 2vw 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: clamp(160px, 30vw, 525px); aspect-ratio: 1/1; display: block; border-radius: var(--imgRadius); object-fit: cover; transition: all 300ms ease-in-out; background: var(--gray);}

@keyframes moving_img {
0%														{ transform: translate(0, 0);}
100% 													{ transform: translate(-100%, 0);}
}
@media (max-width:700px) {
.moving_img .row .grid div 								{ padding: 0 5px;}
}







/***** bloc reviews *****/
.bloc_reviews 											{ position: relative; overflow: hidden;}
.bloc_reviews .list   									{ position: relative;}

.card_review 											{ background: #fff; position: relative; padding: clamp(20px, 3vw, 35px) clamp(20px, 3vw, 35px); color: var(--bgColorDark); letter-spacing: 0.4px; border-radius: var(--imgRadius)}
.card_review p											{ line-height: 170%; margin: 0;}
.card_review p.author									{ line-height: 20px; font-weight: 600;}
.card_review .note   									{ width: 100px; display: grid; grid-template-columns: repeat(5, 1fr); grid-gap: 5px; margin: 12px 0;}
.card_review .note svg 									{ width: 100%; height: auto; display: block; fill: #ffb504;}


/* if note global */
.bloc_reviews .note_global								{ display: grid; grid-template-columns: auto 92px auto 1fr; align-items: end; grid-gap: 20px; margin-bottom: 35px;}
.bloc_reviews .note_global img							{ width: 100%; height: auto; display: block; margin-bottom: -4px; filter: invert(1);}
.bloc_reviews .note_global .number						{ font-size: 40px; line-height: 40px; font-weight: 600;}
.bloc_reviews .note_global .all_link		 			{ padding-left: 10px; margin-bottom: -5px;}
.bloc_reviews .note_global .all_link a		 			{ display: inline-block;}


/* if slider */
.slider_reviews   										{ margin-right: -30px;}
.slider_reviews .slick-slide 							{ margin-right: 30px; min-height: 300px;}
.slider_reviews_nav 									{ position: absolute; right: -12px; top: -75px;}
.slider_reviews_nav .slick-arrow						{ width: 40px;}


@media (max-width: 1400px){
.bloc_reviews 												{ margin: 100px auto;}
}
@media (max-width: 1200px){
.bloc_reviews 												{ margin: 80px auto;}
.bloc_reviews .nav_slider 									{ top: -65px;}
.bloc_reviews .note_global									{ margin-bottom: 25px;}
.bloc_reviews .item 										{ padding: 25px; min-height: inherit; margin-right: 15px;}
}
@media (max-width: 700px){
.bloc_reviews 												{ margin: 50px auto 40px auto;}
.bloc_reviews ::-webkit-scrollbar 							{ display: none;}
.bloc_reviews .note_global									{ grid-template-columns: auto auto 80px 1fr; grid-gap: 0 10px; margin-bottom: 20px;}
.bloc_reviews .note_global .number							{ font-size: 30px; line-height: 32px;}
.bloc_reviews .note_global .stars 							{ width: 90px; margin-right: 4px;}
.bloc_reviews .note_global .all_link		 				{ padding: 5px 0 0 0; grid-column: span 4;}
.bloc_reviews .note_global .all_link a		 				{ line-height: 22px;}
.bloc_reviews .slider 										{ width: 100vw; overflow-x: auto; gap: 10px; display: flex; flex-wrap: nowrap; justify-content: start; align-items: start; padding: 0 6vw; margin: 0 -6vw;}
.bloc_reviews .item 										{ min-width: 300px; padding: 20px; margin: 0;}
.bloc_reviews .item p										{ font-size: 12px; line-height: 24px;}
.bloc_reviews .item p.author								{ font-size: 16px; line-height: 20px;}
.bloc_reviews .item .note   								{ width: 70px; margin: 10px 0;}
}
@media (max-width: 400px){
.bloc_reviews .item 										{ min-width: 75vw;}
}






/***** show hide *****/
.show_hide                        			{ position: relative; z-index: 5; margin: 25px 0; border-top: 1px solid #454544;}
.show_hide .item                  			{ border-bottom: 1px solid #454544;}
.show_hide .titre                 			{ font-size: 18px; line-height: 160%; font-weight: 400; position: relative; cursor: pointer; padding: 20px 40px 22px 0; margin: 0;}
.show_hide .hide                  			{ margin: 0; padding: 0 0 25px 0; line-height: 170%; display: none;}
.show_hide .hide p a						{ color: var(--orange); border-bottom: 1px solid #555; padding-bottom: 1px;}
.show_hide .hide :last-child 	 			{ margin-bottom: 0;}

@media (min-width:1201px){
.show_hide .hide p a:hover     				{ color: var(--mainColor1); border-bottom: 1px solid var(--orange);}
}
@media (max-width:700px){
.show_hide                        			{ margin: 20px 0;}
.show_hide .titre                 			{ padding: 12px 55px 12px 20px;}
.show_hide .hide                  			{ padding: 0 20px 15px 20px;}
}

.bloc_faq                   				{ border: none;}
.bloc_faq .item                  			{ background: #fff; overflow: hidden; margin: 10px 0 0 0; border-radius: var(--linkRadius); border: none;}
.bloc_faq .titre                 			{ font-weight: 500; letter-spacing: 0.4px; color: var(--bgColorDark); padding: 20px 60px 22px 30px;}
.bloc_faq .hide                  			{ padding: 0 30px 25px 30px; letter-spacing: 0.4px; color: var(--bgColorDark);}

/* custom titre arrow */
.show_hide .titre_arrow:after          		{ width: 20px; height: 100%; background: url("../images/arrow_down.svg") 50% / contain no-repeat; position: absolute; right: 0; top: 0; transition: none; content: "";}
.show_hide .titre_arrow.active:after        { transform: rotate(180deg);}

/* custom titre plus */
.show_hide .titre_plus:after          		{ width: 20px; height: 2px; position: absolute; right: 25px; top: 50%; transform: translateY(-50%); background: var(--orange); transition: none; content: "";}
.show_hide .titre_plus:before          		{ width: 2px; height: 20px; position: absolute; right: 34px; top: 50%; transform: translateY(-50%); background: var(--orange); transition: none; content: "";}
.show_hide .titre_plus.active:before   		{ display: none;}

@media (max-width:700px){
.show_hide .titre_plus:after          		{ right: 15px;}
.show_hide .titre_plus:before          		{ right: 24px;}
}




/***** social *****/
.rs a										{ width: 50px; height: 50px; display: inline-block; vertical-align: top; margin-right: clamp(5px, 2.5vw, 10px); background: 50% no-repeat var(--gradientLink); background-size: 100% 200%; background-position: 0 100%; border-radius: var(--linkRadius);}
.rs a:after									{ width: 100%; height: 100%; position: absolute; left: 0; top: 0; content: "";}
.rs .facebook:after							{ background: url("../images/facebook.svg") 50% no-repeat;}
.rs .linkedin:after							{ background: url("../images/linkedin.svg") 50% no-repeat;}
.rs .scroll									{ background: url("../images/scrolltop.svg") 50% no-repeat var(--bgColorDark);}

@media (min-width:1201px) {
.rs a:not(.scroll):hover					{ background-position: 0 0;}
}
@media (max-width:700px) {
.rs a										{ width: 40px; height: 40px;}
}




/***** footer *****/
.footer										{ position: relative; font-size: clamp(14px, 2.2vw, 15px); line-height: 180%; padding-top: 2vw;}

.footer .bloc_footer 						{ display: inline-block; vertical-align: top; position: relative;}
.footer .bloc_footer.heading_top 			{ display: block; margin-bottom: 25px;}
.footer .bloc_footer .sous_titre			{ text-transform: uppercase; font-weight: 700; letter-spacing: 2px;}
.footer .bloc_footer p						{ margin: clamp(10px, 2vw, 15px) 0 0 0;}
.footer .bloc_footer p a					{ color: #fff; display: inline-block;}
.footer .bloc_footer .icon 					{ padding-left: 35px; position: relative;}
.footer .bloc_footer .icon:after 			{ width: 20px; height: 100%; position: absolute; left: 0; top: 0; content: "";}
.footer .bloc_footer .address:after 		{ background: url(../images/map.svg) 2px 2px no-repeat;}
.footer .bloc_footer .tel a:after 			{ background: url(../images/tel_orange.svg) 3px 50% no-repeat;}
.footer .bloc_footer .email a:after 		{ background: url(../images/email_orange.svg) 1px 50% no-repeat;}
.footer .bloc_footer .hours:after 			{ background: url(../images/hours.svg) 2px 5px no-repeat;}
.footer ul.bloc_footer     					{ margin-left: clamp(20px, 8vw, 100px);}
.footer ul.bloc_footer li   				{ margin-top: clamp(10px, 2vw, 15px);}
.footer ul.bloc_footer li a 				{ color: #fff; display: inline-block; padding: 0 0 0 20px; background: url("../images/list.svg") 0 50% no-repeat;}

.footer .rs 								{ position: absolute; top: 0; right: 0; font-size: 0;}

.footer_bottom   							{ padding: 20px 0; line-height: 0; margin: clamp(20px, 8vw, 100px) 0 0 0;}
.footer_bottom li 							{ display: inline-block; font-size: 12px; line-height: 20px; margin-right: 30px; letter-spacing: 0.8px; position: relative;}
.footer_bottom li:after						{ width: 1px; height: 10px; content: ""; position: absolute; right: -18px; top: 4px; background: var(--orange);}
.footer_bottom li:last-child:after 			{ display: none;}
.footer_bottom li a							{ color: #fff;}

.toponweb									{ display: block; z-index: 85; position: absolute; right: 0; bottom: 20px; transition: bottom 300ms ease-in-out;}
.toponweb img								{ width: 80px; height: auto; display: block; margin: 0 auto; filter: invert(0); transition: all 300ms ease-in-out;}

@media (min-width:1201px) {
.footer .bloc_footer p a:hover, 
.footer .bloc_footer li a:hover, 	 
.footer_bottom li a:hover 	 				{ color: var(--orange);}
.toponweb:hover span						{ background-position: 0 0;}
}
@media (max-width:1200px) {
.footer ul.bloc_footer     					{ display: none;}
}
@media (max-width:700px) {
.footer  									{ padding-bottom: 15px;}
.footer .bloc_footer 						{ text-align: center; margin-top: 4vw; margin-bottom: 40px;}
.footer .bloc_footer.heading_top 			{ margin: 0;}
.footer .bloc_footer 						{ display: block;}
.footer .bloc_footer .icon 					{ padding-left: 0;}
.footer .bloc_footer .icon:after 			{ display: none;}
.footer_bottom 	 							{ text-align: center; margin: 0; padding: 80px 0 60px 0;}
.footer_bottom li 							{ display: block; margin: 0; font-size: 12px; line-height: 28px;}
.footer_bottom li:after						{ display: none;}
.toponweb									{ position: static;}
.toponweb span								{ height: auto; padding: 15px; background: #ffffff15;}
.toponweb img								{ width: 70px; filter: invert(0);}
.footer .rs 								{ top: inherit; left: 50%; transform: translateX(-50%); width: max-content;}
}















