/* latin-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: italic;
  font-weight: 100 900;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/montserrat/v31/JTUQjIg1_i6t8kCHKm459WxRxy7mw9c.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: 'Montserrat';
  font-style: italic;
  font-weight: 100 900;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/montserrat/v31/JTUQjIg1_i6t8kCHKm459WxRyS7m.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;
}
/* latin-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/montserrat/v31/JTUSjIg1_i6t8kCHKm459Wdhyzbi.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: 'Montserrat';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/montserrat/v31/JTUSjIg1_i6t8kCHKm459Wlhyw.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 {

	--mainColor1: #f39207;
	--mainColor1Hover: #333;
	--mainColor2: #222;
	--mainColor2Hover: #444;	
	--txtColor: #111;
	--bgColorLight: #eee;
	--bgColorDark: #282828;
	--bgColorDarker: #111;
	--alertColor: #ec3838;


	--marginTB: clamp(70px, 8vw, calc(120px + 2vw)) auto;
	--marginT: clamp(70px, 8vw, calc(120px + 2vw));
	--marginB: clamp(70px, 8vw, calc(120px + 2vw));

	--paddingTB: clamp(70px, 8vw, calc(120px + 2vw)) 0;
	--paddingT: clamp(70px, 8vw, calc(120px + 2vw));
	--paddingB: clamp(70px, 8vw, calc(120px + 2vw));
	
	--wrapperS: 1000px;
	--wrapperM: 1200px;
	--wrapperL: 1600px;

	--linkRadius: 10px;
	--imgRadius: 15px;
	
}
@media (max-width:1400px) {
	:root {

	}
}
@media (max-width:1200px) {
	:root {

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

	--paddingTB: clamp(45px, 12vw, 70px) 0;
	--paddingT: clamp(45px, 12vw, 70px);
	--paddingB: clamp(45px, 12vw, 70px);
	}
}
@media (max-width:700px) {
	:root {
	--linkRadius: 8px;
	--imgRadius: 12px;
	}
}




/***** reset *****/
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;}
body								{ font: 500 clamp(14px, 2.2vw, 15px)/180% "Montserrat"; letter-spacing: 0.2px; color: var(--txtColor); background: #fff; position: relative;}
body.active_overflow				{ height: 100vh; overflow: hidden;}
main 								{ position: relative;}
p 									{ margin-bottom: clamp(10px, 2vw, 15px);}
ul									{ margin-bottom: clamp(10px, 2vw, 15px); list-style-type: none;}
a									{ text-decoration: none; color: #222; position: relative;}
img									{ border: none; }
strong, b							{ font-weight: 600; font-size: clamp(15px, 2.4vw, 16px);}

#wrapper 							{ min-width: 320px; position: relative; overflow: hidden;}
#wrapper *							{ box-sizing: border-box;}
#footer 							{ position: relative; z-index: 15;}

@media (max-width:700px) {
body								{ font-size: 14px; line-height: 26px;}
strong, b							{ font-size: 14px;}
}


/***** scollbar *****/
::-webkit-scrollbar 				{ width: 8px; height: 8px; background-color: #fff;}
::-webkit-scrollbar-thumb			{ background-color: var(--mainColor1);}



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


/***** class *****/
.wrapper_small						{ width: 90vw; max-width: var(--wrapperS); margin: 0 auto; position: relative;}
.wrapper 							{ width: 90vw; max-width: var(--wrapperM); margin: 0 auto; position: relative;}
.wrapper_large						{ width: 90vw; max-width: var(--wrapperL); 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);}

.clear								{ clear: both; display: block;}
.anchor								{ position: absolute; left: 0; top: -140px;}

.color_1							{ color: var(--mainColor1);}
.color_2 							{ color: var(--mainColor2);}
.color_alert 						{ color: var(--alertColor);}
.color_bg_1							{ background: var(--mainColor1);}
.color_bg_2 						{ background: var(--mainColor2);}

.titre_main	 						{ font: 500 clamp(25px, 3vw, 48px)/120% "Montserrat"; letter-spacing: 2.2px; text-transform: uppercase; position: relative; margin-bottom: clamp(10px, 2vw, 15px);}
.titre_cap	 						{ font: 600 18px/120% "Montserrat"; letter-spacing: 2.2px; text-transform: uppercase; position: relative; margin-bottom: clamp(10px, 2vw, 15px);}
.titre_cap.smaller					{ font-size: 14px;}
.sous_titre 						{ font: 600 clamp(18px, 2vw, 30px)/140% "Montserrat"; letter-spacing: 0; position: relative; margin-bottom: clamp(10px, 2vw, 15px);}
.sous_titre.bigger					{ font-size: clamp(22px, 2.2vw, 40px);}
.chapo		 						{ font: 500 clamp(14px, 2.2vw, 15px)/180% "Montserrat"; margin-bottom: clamp(10px, 2vw, 15px);}
.chapo span	 						{ display: block; margin-top: clamp(10px, 2vw, 15px);}

.link 								{ font: 600 12px/48px "Montserrat"; letter-spacing: 2px; text-transform: uppercase; height: 50px; display: inline-block; color: #fff; padding: 0 30px; background: linear-gradient(to top, var(--mainColor1) 0% 50%, var(--mainColor1Hover) 50% 100%); background-size: 100% 200%; background-position: 0 100%; cursor: pointer; border-radius: var(--linkRadius);}
.link_2ry 							{ background-image: linear-gradient(to top, var(--mainColor2) 0% 50%, var(--mainColor2Hover) 50% 100%);}
.link.small_txt 					{ font-size: 10px;}

.ul_check li 						{ position: relative; padding-left: 35px; margin-bottom: 10px;}
.ul_check li:before					{ width: 22px; height: 17px; position: absolute; left: 0; top: 4px; background: url("../images/check.svg") 0 0 / contain no-repeat; filter: invert(0); content: "";}
.ul_check li:last-child				{ margin-bottom: 0;}

.ul_list li 						{ position: relative; padding-left: 18px; margin-bottom: 12px; line-height: 160%;}
.ul_list li:before					{ width: 6px; height: 6px; border-radius: 50%; position: absolute; left: 0; top: 9px; background: var(--mainColor1); content: "";}
.ul_list li:last-child				{ margin-bottom: 0;}

.hide_more_txt						{ display: none;}
.read_more 							{ cursor: pointer; display: inline;}

@media (min-width:1201px) {
.link:hover 						{ background-position: 0 0;}
.link_2:hover 						{ background-position: 0 100%;}
}
@media (max-width:1000px) {
.titre_main	 						{ font-size: clamp(18px, 4vw, 25px); line-height: 140%;}
.sous_titre 						{ font-size: clamp(18px, 3vw, 22px);}
.sous_titre.bigger					{ font-size: clamp(20px, 4vw, 25px);}
}
@media (max-width:700px) {
.titre_cap	 						{ font-size: 16px; line-height: 130%;}
.titre_cap.smaller					{ font-size: 12px;}
.link 								{ height: 43px; line-height: 43px;}
}





/***** header *****/
.header 									{ width: 100%; font-size: 0; line-height: 0; letter-spacing: 0; position: absolute; left: 0; top: 0; z-index: 100; text-align: right; transition: all 200ms ease-in-out;}
.header .logo								{ width: 280px; position: absolute; left: 5vw; top: 40px; transform-origin: left center; z-index: 850;}
.header .logo img							{ width: 100%; height: auto; display: block; filter: invert(1);}
.header .header_nav 						{ background: #fff; border-radius: calc(var(--linkRadius) + 5px); padding: 7px 7px 7px 50px; position: fixed; right: 5vw; top: 35px; box-shadow: rgba(0 0,0,0.1) 0 0 60px 0;}
.header .menu 								{ margin: 0;}
.header .menu>li							{ position: relative; display: inline-block; vertical-align: top; margin-right: 35px;}
.header .menu>li:last-child					{ margin-right: 0;}
.header .menu>li a							{ font-size: 16px; font-weight: 600; line-height: 48px; height: 50px; display: block; transition: color 300ms ease-in-out;}
.header .menu>li.active>a					{ color: var(--mainColor1);}
.header .menu>li.active a.link				{ color: #fff;}
.header .menu>li .link 						{ text-transform: none; letter-spacing: 0.6px; font-weight: 400; transition-property: background;}

@media (min-width:1201px) {
.header .menu>li:hover>a:not(.link)			{ color: var(--mainColor1);}
}
@media (max-width:1400px) {
.header .logo								{ top: 30px; width: 270px;}
.header .header_nav 						{ padding: 7px 7px 7px 35px;}
.header .menu>li							{ margin-right: 25px;}
.header .menu>li a							{ font-size: 15px;}
.header .menu>li .link 						{ padding: 0 25px;}
}
@media (max-width:1200px) {
.header .menu_mobile						{ width: 54px; height: 54px; background: var(--mainColor1); border-radius: var(--imgRadius); cursor: pointer; position: fixed; top: 30px; right: 30px; z-index: 850;}
.header .menu_mobile div					{ width: 30px; height: 2px; background: #fff; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);}
.header .menu_mobile div:before				{ width: 100%; height: 2px; background: #fff; position: absolute; left: 0; top: 7px; content: "";}
.header .menu_mobile div:after				{ width: 100%; height: 2px; background: #fff; position: absolute; left: 0; top: -7px; content: "";}
.header .menu_mobile.active div				{ height: 0; width: 26px;}
.header .menu_mobile.active div:before		{ top: 0; transform: rotate(45deg);}
.header .menu_mobile.active div:after		{ top: 0; transform: rotate(-45deg);}

.header ::-webkit-scrollbar					{ display: none;}
.header .wrapper							{ padding: 0;}
.header .logo								{ width: 220px;}

.header .header_nav 						{ width: 100%; position: fixed; right: -100%; top: 0; bottom: 0; overflow-y: scroll; z-index: 800; padding: 0; background: var(--bgColorDarker); border-radius: 0; display: grid; transition: right 300ms ease-in-out 400ms;}
.header .menu  								{ display: block; width: auto; text-align: center; margin: 5vw 10vw; position: relative; align-self: center; z-index: 100; opacity: 0; transition: opacity 300ms ease-in-out 150ms;}
.header .menu>li 							{ width: 100%; display: block; margin: 0;}
.header .menu>li a:not(.link)				{ font-size: clamp(18px, 5vw, 30px); line-height: 160%; height: auto; padding: 10px 0; color: #fff; transition: none; display: inline-block; z-index: 10;}
.header .menu>li a.link 					{ margin: calc(15px + 2vw) 0; font-size: clamp(12px, 3vw, 14px); line-height: 100%; text-transform: uppercase; letter-spacing: 2px; height: auto; padding: 22px 30px; display: inline-block; transition: none;}
.header .menu>li.active a:not(.link)		{ color: var(--mainColor1);}
.header .menu>li.active a.link				{ color: #fff;}

.header.active .header_nav 					{ right: 0; transition-delay: 100ms;}
.header.active .menu 						{ opacity: 1; transition-delay: 400ms;}
}
@media (max-width:700px) {
.header .menu_mobile						{ width: 50px; height: 50px; top: 5vw; right: 5vw;}
.header .menu_mobile div					{ width: 26px;}
.header .menu_mobile.active div				{ width: 24px;}
.header .logo								{ width: 190px; top: 5vw;}
.header .menu>li a.link 					{ margin-bottom: 8vw;}
}



/***** side btn fixed *****/
.side_btn 									{ position: fixed; right: 30px; top: 40%; transform: translateY(-50%); z-index: 200; display: grid; grid-gap: 0; background: #fff; box-shadow: 0 0 60px 0 rgba(0, 0, 0, 10%); border-radius: var(--imgRadius); transition: border-radius 100ms ease-in 200ms;}
.side_btn a									{ display: block; width: 60px; height: 60px; line-height: 60px; border-radius: 0; position: relative; transition-duration: 0ms; transition-delay: 300ms;}
.side_btn a:after							{ position: absolute; right: 0; top: 50%; transform: translateY(-50%); background: 50% / contain no-repeat; width: 60px; z-index: 5; content: "";}
.side_btn a.devis:after						{ height: 28px; background-image: url("../images/devis.svg");}
.side_btn a.tel:after						{ height: 20px; background-image: url("../images/tel.svg");}
.side_btn a.gsm:after						{ height: 28px; background-image: url("../images/gsm.svg");}
.side_btn a.email:after						{ height: 16px; background-image: url("../images/email.svg");}
.side_btn a.facebook:after					{ height: 22px; background-image: url("../images/facebook_color.svg");}
.side_btn a	span							{ display: block; width: 0; height: 60px; position: absolute; top: 0; right: 100%; background: var(--mainColor1); border-radius: var(--imgRadius) 0 0 var(--imgRadius); overflow: hidden;}
.side_btn a	i								{ position: absolute; left: 0; top: 0; font-style: normal; width: 100%; text-align: center; color: #fff; border-radius: 0; opacity: 0; transition: 100ms all 0ms;}

@media (min-width:701px) {
.side_btn:has(a:first-child:hover)			{ border-top-left-radius: 0; transition-duration: 20ms; transition-delay: 0ms;}
.side_btn:has(a:last-child:hover)			{ border-bottom-left-radius: 0; transition-duration: 20ms; transition-delay: 0ms;}
.side_btn a:hover  							{ transition-delay: 0ms;}
.side_btn a:hover span						{ width: 160px; right: 100%;}
.side_btn a:hover span:after,
.side_btn a:hover span:before				{ opacity: 1; transition-delay: 200ms;}
.side_btn a:hover i							{ opacity: 1; transition-delay: 250ms;}
}
@media (max-width:1200px) {
.side_btn a									{ width: 54px;}
.side_btn a:after							{ width: 54px;}
}
@media (max-width:700px) {
.side_btn 									{ right: calc(8vw + 50px); top: 5vw; transform: none; background: var(--bgColorDarker); box-shadow: none;}
.side_btn a 								{ width: 50px; height: 50px; display: none;}
.side_btn a:after							{ width: 50px; filter: brightness(200);}
.side_btn a.tel 							{ display: block;}

body :has(#header.active) .side_btn 		{ background: var(--bgColorDark);}
}




/***** champs formulaire *****/ 
select,
input[type="text"],
input[type="email"],
input[type="date"],
textarea 									{ width: 100%; height: 54px; border: none; font: 400 14px/22px "Montserrat"; letter-spacing: 0.2px; padding: 0 20px 2px 20px; border-radius: var(--linkRadius); background: #fff; margin-bottom: clamp(10px, 2vw, 15px);}
select										{ -webkit-appearance: none; appearance: none; background: url("../images/arrow_select.svg") calc(100% - 20px) 50% no-repeat #fff; padding-bottom: 0;}
textarea									{ min-height: 160px; padding: 20px 25px; display: block;}
input[type=checkbox] 						{ -webkit-appearance: checkbox; -ms-appearance: checkbox; appearance: checkbox; -moz-appearance: checkbox; -o-appearance: checkbox; width: 20px; height: 20px; display: block; float: left; padding: 0; margin: 0;}

@media (max-width:700px) { 
select,
input[type="text"],
input[type="email"],
input[type="date"],
textarea 									{ font-size: 13px; height: 48px; padding: 0 18px;}
select										{ background-position: calc(100% - 16px) 50%;}
textarea									{ padding: 15px 20px;}
}




/***** cta form *****/
.cta   										{ padding: clamp(20px, 3vw, 60px); border-radius: calc(var(--linkRadius) + 5px); position: relative; background: var(--bgColorDarker); margin-top: -120px;}
.cta .formulaire .titre_main				{ color: #fff; font-size: 28px; line-height: 140%; margin-top: -5px;}
.cta .formulaire .titre_main span			{ color: var(--mainColor1); display: inline-block;}
.cta .formulaire .link 						{ width: 100%; height: 54px; border: none; margin-top: 5px;}

@media (max-width:1400px) {
.cta   										{ margin-top: -100px;}
}
@media (max-width:1200px) {
.cta .formulaire .titre_main				{ font-size: 24px;}
}
@media (max-width:1000px) {
.cta   										{ padding: 5vw; margin-top: -10vw;}
.cta .formulaire .titre_main				{ font-size: clamp(20px, 4.5vw, 24px); line-height: 130%;}
}
@media (max-width:700px) {
.cta   										{ padding: 10vw 8vw; margin: 0 -5vw; border-radius: 0;}
.cta .formulaire .titre_main				{ text-align: center;}
.cta .formulaire .link 						{ height: 48px; padding-bottom: 2px;}
}


/***** moving text *****/
.moving_text 								{ width: 100%; overflow: hidden; text-align: center; padding: clamp(30px, 2.4vw, 50px) 0 clamp(20px, 1.8vw, 30px) 0;}
.moving_text .row 							{ display: flex;}
.moving_text .row .item 					{ display: grid; grid-template-columns: repeat(6, auto); grid-gap: 5vw; white-space: nowrap;  padding-left: 5vw; animation: scroll_text 60s linear infinite;}
.moving_text .row .item span				{ font: 500 clamp(14px, 1.2vw, 18px)/120% "Montserrat"; text-transform: uppercase; letter-spacing: 4px; color: #fff; opacity: 0.25;}

@keyframes scroll_text {
0%											{ transform: translate(-100%, 0);}
100% 										{ transform: translate(0%, 0); }
}
@media (max-width:1200px) {
.moving_text 								{ padding: 60px 0 20px 0;}
}
@media (max-width:1000px) {
.moving_text 								{ padding: 5vw 0;}
}
@media (max-width:700px) {
.moving_text 								{ padding: 6vw 0 4vw 0;}
.moving_text .row .item span				{ font-size: 11px; letter-spacing: 2.8px; opacity: 0.35;}
}



/***** grid bloc *****/
.grid_bloc	 								{ position: relative;}
.grid_bloc .container						{ display: grid; grid-gap: clamp(10px, 3vw, 20px); text-align: left;}

/* 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:1300px) {
.grid_bloc.col_4 .container					{ grid-template-columns: 1fr 1fr;}
}
@media (max-width:1000px) {
.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;}
}


/* swipe mobile */
@media (max-width:700px) {
.swipe_mobile .container 								{ display: flex; gap: 3vw; width: 100vw; margin-left: -5vw; overflow-x: auto; padding: 0 5vw 8vw 5vw;}
.swipe_mobile .container:before							{ width: 5vw; height: 4px; background: #fff; position: absolute; left: -5vw; bottom: 0; content: "";}
.swipe_mobile .container:after							{ width: 5vw; height: 4px; background: #fff; position: absolute; right: -5vw; bottom: 0; content: "";}
.swipe_mobile .container::-webkit-scrollbar 			{ width: 4px; height: 4px; background-color: var(--bgColorLight);}
.swipe_mobile .container::-webkit-scrollbar-thumb		{ background-color: var(--mainColor1);}
.swipe_mobile .container .item 							{ min-width: clamp(220px, 65vw, 320px);}
}




/***** assets v1 *****/
.assets_v1 									{ text-align: center; position: relative; padding: clamp(30px, 10vw, 110px) 0;}
.assets_v1:before 							{ position: absolute; left: 5vw; right: 5vw; top: 0; bottom: 0; background: var(--bgColorDark); border-radius: var(--linkRadius); z-index: -1; content: "";}
.assets_v1 .container 						{ display: grid; grid-gap: 20px; position: relative; color: #fff;}
.assets_v1 .item lord-icon 					{ width: 80px; height: 80px; display: block; margin: -3% auto 0 auto;}
.assets_v1 .item p 							{ margin: 15px 0 0 0; font-size: 18px; font-weight: 600; line-height: 160%;}

.assets_v1.col_3 .container 				{ grid-template-columns: repeat(3, 1fr);}

@media (max-width: 1400px){
.assets_v1:before 							{ left: 0; right: 0; border-radius: 0;}
}
@media (max-width: 1200px){
.assets_v1 .item p 							{ max-width: 200px; margin: 15px auto 0 auto;}
}
@media (max-width: 1200px){
.assets_v1 .item lord-icon 					{ width: 70px; height: 70px;}
.assets_v1 .item p 							{ font-size: 16px; max-width: 200px; margin: 15px auto 0 auto;}
}
@media (max-width: 700px){
.assets_v1.col_3 .container					{ grid-template-columns: 1fr; grid-gap: 6vw;}
.assets_v1 .item lord-icon 					{ width: 64px; height: 64px; margin-top: 0;}
.assets_v1 .item p 							{ font-size: 15px; max-width: 180px; margin-top: 10px;}
}






/***** bloc txt img *****/
.bloc_txt_img 											{ position: relative;}
.bloc_txt_img:before									{ position: absolute; left: 0; right: 0; top: 0; bottom: 0; background: var(--bgColorDark); border-radius: var(--imgRadius); visibility: hidden; transition: none; content: "";}
.bloc_txt_img .container	                        	{ display: grid; grid-template-columns: 50% 1fr; grid-gap: clamp(40px, 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 .wrap						{ display: inline-block; text-align: left; max-width: 520px;}
.bloc_txt_img .container img 							{ width: 100%; height: auto; object-fit: cover; display: block; position: relative; z-index: 10; border-radius: var(--imgRadius);}
.bloc_txt_img .container .link							{ margin-top: 10px;}
.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 .container .img.col_2  					{ display: grid; grid-template-columns: 1fr 1fr; grid-gap: 20px;}
.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.reverse .container .txt					{ text-align: right;}
.bloc_txt_img.align_top .container                		{ align-items: start;}

@media (max-width:1000px) { 
.bloc_txt_img .container 								{ grid-template-columns: 1fr;}
.bloc_txt_img .container .txt .wrap						{ 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;}
}
@media (max-width:700px) { 
.bloc_txt_img .container	                        	{ grid-gap: 30px;}
.bloc_txt_img .container p               				{ margin-bottom: 10px;}
.bloc_txt_img .container .img.col_2  					{ grid-gap: 3vw;}
.bloc_txt_img .container .multi_links					{ grid-template-columns: 1fr 1fr; grid-gap: 10px; margin-top: 20px;}
}



/***** show hide *****/
.show_hide                        			{ position: relative; margin: 25px 0;}
.show_hide.no_marge                        	{ margin: 0;}
.show_hide .item                  			{ margin: 10px 0;}
.show_hide .titre                 			{ font-size: clamp(14px, 2.2vw, 16px); line-height: 140%; font-weight: 500; letter-spacing: 0.5px; position: relative; cursor: pointer; padding: 18px 80px 20px 25px; color: #fff; background: var(--mainColor1Hover); border-radius: calc(var(--linkRadius) - 2px); transition: all 200ms ease-in-out;}
.show_hide .titre.active           			{ background: var(--bgColorLight); color: var(--txtColor);}
.show_hide .hide                  			{ margin: 0; padding: 25px 30px 30px 30px; background: #fff; display: none;}
.show_hide .hide :last-child 	 			{ margin-bottom: 0;}

@media (min-width:1201px){
.show_hide .hide p a:hover     				{ color: var(--mainColor2);}
}
@media (max-width:1200px){
.show_hide .hide                  			{ padding: 20px;}
}
@media (max-width:700px){
.show_hide                        			{ margin: 20px 0;}
.show_hide .titre                 			{ padding: 15px 65px 15px 20px;}
.show_hide .hide                  			{ padding: 15px 10px 10px 10px;}
}


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

@media (max-width:700px){
.show_hide .titre_arrow:after          		{ right: 20px;}
}






/***** 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; -ms-touch-action: pan-y; touch-action: pan-y; -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 arrows *****/
.slick-arrow							{ width: 38px; height: 46px; border: 0; padding: 0; font-size: 0; cursor: pointer; background: url("../images/arrow_slider.svg") 55% 50% no-repeat var(--mainColor2); border-radius: calc(var(--linkRadius) - 2px);}
.slick-disabled 						{ opacity: 0.5; cursor: default;}
.slick-prev								{ transform: rotate(-180deg); margin-right: 5px;}

/**/
@media (min-width:1201px) { 
.slick-arrow:not(.slick-disabled):hover { background-color: var(--mainColor2Hover);}
}

@media (max-width:700px) { 
.slick-arrow							{ width: 32px; height: 40px;}
.slick-prev,
.slick-next								{ background-size: auto 16px;}
}





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

.card_review 											{ background: #fff; position: relative; padding: clamp(20px, 3vw, 35px) clamp(20px, 3vw, 40px); box-shadow: 0 0 60px 0 rgba(0,0,0,8%); border-radius: var(--linkRadius);}
.card_review p											{ line-height: 170%; margin: 0;}
.card_review p.author									{ font-size: 18px; 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;}

@media (max-width: 700px){
.bloc_reviews .card_review p.author						{ font-size: 14px; line-height: 20px;}
.bloc_reviews .card_review .note   						{ width: 90px; margin: 10px 0;}
}
@media (max-width: 700px){
.bloc_reviews ::-webkit-scrollbar 						{ display: none;}
}


/* if note global */
.bloc_reviews .note_global								{ display: grid; grid-template-columns: 120px auto 1fr; align-items: end; grid-gap: 30px; margin-bottom: 35px;}
.bloc_reviews .note_global img							{ width: 100%; height: auto; display: block; margin-bottom: -4px;}
.bloc_reviews .note_global .all_link a		 			{ display: inline-block; border-bottom: 2px solid var(--mainColor1);}

@media (max-width: 1200px){
.bloc_reviews .note_global								{ margin-bottom: 30px;}
}
@media (max-width: 700px){
.bloc_reviews .note_global								{ grid-template-columns: auto auto 1fr; grid-gap: 20px; margin-bottom: 25px;}
.bloc_reviews .note_global img							{ margin-bottom: 0;}
}


/* if slider */
.slider_reviews   										{ margin-right: -20px;}
.slider_reviews .slick-list 							{ overflow: visible !important;}
.slider_reviews .slick-slide 							{ margin-right: 20px;}
.slider_reviews_nav 									{ position: absolute; right: 0; top: -70px;}

@media (max-width: 1200px){
.slider_reviews   										{ margin-right: -15px;}
.slider_reviews .slick-slide 							{ margin-right: 15px;}
.slider_reviews_nav										{ top: -65px;}
}
@media (max-width: 700px){
.slider_reviews   										{ margin-right: -5vw;}
.slider_reviews .slick-slide 							{ margin-right: 5vw;}
.slider_reviews_nav										{ top: -60px;}
}

/* if swipe mobile */
@media (max-width: 700px){
.bloc_reviews .slider_reviews:not(.slick-slider) 					{ width: 100vw; overflow-x: auto; gap: 10px; display: flex; flex-wrap: nowrap; justify-content: start; align-items: start; padding: 60px 6vw; margin: -60px -6vw;}
.bloc_reviews .slider_reviews:not(.slick-slider) .card_review 		{ min-width: 82vw; max-width: 300px;}
}







/***** bloc rs *****/
.bloc_rs									{ font-size: 0; line-height: 0; letter-spacing: 0;}
.bloc_rs a									{ width: 50px; height: 50px; display: block; overflow: hidden; background: var(--mainColor1); border-radius: var(--linkRadius);}
.bloc_rs a:after							{ width: 100%; height: 100%; position: absolute; left: 0; top: 0; content: "";}
.bloc_rs .facebook:after					{ background: url("../images/facebook.svg") 50% no-repeat;}
.bloc_rs .scroll:after 						{ background: url("../images/scrolltop.svg") 50% 46% no-repeat; filter: invert(1);}

@media (max-width:700px) {
.bloc_rs a									{ width: 46px; height: 46px;}
}





/***** footer *****/
.footer										{ position: relative; color: #fff; padding-top: clamp(20px, 10vw, 120px); letter-spacing: 0.6px; background: var(--bgColorDark);}
.footer .bloc_footer 						{ display: inline-block; vertical-align: top; position: relative; line-height: 170%;}
.footer .bloc_footer .titre_cap				{ font-size: 20px; padding-bottom: 5px;}
.footer .bloc_footer p						{ margin: 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: 18px; height: 100%; position: absolute; left: 0; top: 0; content: "";}
.footer .bloc_footer .tel a:after 			{ background: url(../images/tel.svg) 0 50% no-repeat;}
.footer .bloc_footer .gsm a:after 			{ background: url(../images/gsm.svg) 2px 50% no-repeat;}
.footer .bloc_footer .email a:after 		{ background: url(../images/email.svg) 0 50% no-repeat;}
.footer .bloc_footer .hours 				{ padding-bottom: 10px;}

.footer ul.bloc_footer     					{ margin: 0 0 0 120px;}
.footer ul.bloc_footer li   				{ margin-top: 15px;}
.footer ul.bloc_footer li a 				{ color: #fff; display: inline-block;}

.footer .bloc_rs							{ position: absolute; right: 0; top: 0;}
.footer .bloc_rs a							{ display: inline-block; vertical-align: top; margin-right: 10px;}
.footer .bloc_rs a:after					{ filter: invert(0);}
.footer .bloc_rs .scroll 					{ margin: 0;}

.footer_bottom   							{ padding: 20px 0; line-height: 0; margin: clamp(20px, 8vw, 80px) 0 0 0;}
.footer_bottom li 							{ display: inline-block; font-size: 12px; line-height: 20px; font-weight: 400; margin-right: 30px; letter-spacing: 0.8px; position: relative;}
.footer_bottom li:after						{ width: 1px; height: 9px; content: ""; position: absolute; right: -18px; top: 5px; background: var(--mainColor1);}
.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(--mainColor1);}
.toponweb:hover span						{ background-position: 0 0;}
}
@media (max-width:1200px) {
.footer .bloc_footer .titre_cap				{ font-size: 18px;}
.footer ul.bloc_footer     					{ display: none;}
}
@media (max-width:700px) {
.footer .bloc_footer 						{ width: 100%;}
.footer .bloc_footer .titre_cap				{ font-size: 16px;}
.footer .bloc_footer .hours 				{ padding-bottom: 5px;}
.footer_bottom 	 							{ text-align: left; padding: 0 0 20px 0;}
.footer_bottom li 							{ display: block; margin: 0; font-size: 11px; line-height: 28px;}
.footer_bottom li:after						{ display: none;}
.toponweb									{ position: static; background: var(--bgColorDarker); margin: 0 -5vw; padding: 16px 0 12px 0;}
.toponweb img								{ width: 70px;}
}




#toast-iframe 								{ display: none!important;}










