/***** fonts *****/
/* 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/v20/UcCm3FwrK3iLTcvnUwoT9nA2.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/v20/UcCm3FwrK3iLTcvnUwQT9g.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/v20/UcCo3FwrK3iLTcvsYwYL8g.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/v20/UcCo3FwrK3iLTcviYwY.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: 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 {
    --font-main: "Montserrat", sans-serif;   
    --mainColor1: #f36a2e;
	--mainColor1Hover: #bf430d;
	--mainColor2: #1E1E1E;
	--mainColor2Hover: #474747;	
	--bgColorLight: #f9eee9;
	--bgColorDark: #000;
	
	--marginTB: clamp(20px, 10vw, 120px) auto;
	--gapSection: clamp(20px, 10vw, 120px);
	
	--maxWidthWrapper: 1200px;
	--maxWidthWrapperSmall: 1000px;
	--maxWidthWrapperLarge: 1600px;

	--imgRadius: 0/*clamp(8px, 3vw, 20px)*/;
	--linkRadius: 0/*clamp(5px, 3vw, 10px)*/;
}

@media (max-width:1200px) {
  :root {
    --marginTB: clamp(20px, 10vw, 80px) auto;
  }
}

@media (max-width:1000px) {
  :root {
    --marginTB: clamp(20px, 10vw, 60px) auto;
  }
}

@media (max-width:700px) {
  :root {
    --marginTB: clamp(20px, 10vw, 40px) auto;
  }
}


/***** 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 15px/30px "Montserrat"; letter-spacing: 0.6px; color: var(--mainColor2); background: var(--bgColorLight); position: relative;}
body.active_overflow				{ height: 100vh; overflow: hidden;}
main 								{ position: relative; z-index: 10;}
p 									{ margin-bottom: 15px;}
ul									{ margin-bottom: 15px; list-style-type: none;}
a									{ text-decoration: none; color: var(--mainColor2); position: relative;}
img									{ border: none;}
strong, b							{ font-weight: 600; font-size: 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: 13px; line-height: 26px;}
strong, b							{ font-size: 14px;}
}



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


/***** 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_large						{ width: 90vw; max-width: var(--maxWidthWrapperLarge); margin: 0 auto; position: relative;}

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

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


.titre_main	 						{ font: 700 45px/55px "Montserrat"; letter-spacing: 0.6px; position: relative; margin-bottom: 15px; text-transform: uppercase;}
.titre_main.bigger	 				{ font-size: 60px; line-height: 68px;}
.sous_titre 						{ font: 700 30px/40px "Montserrat"; letter-spacing: 0.2px; position: relative; margin-bottom: 15px; text-transform: none;  }
.sous_titre span					{ text-transform: uppercase; color: var(--mainColor1);}
.sous_titre.smaller 				{ text-transform: none; font-size: 28px;}
.sous_titre.smaller span			{ text-transform: uppercase; font-size: 24px; color: var(--mainColor1);}

.chapo		 						{ font: 500 15px/30px "Montserrat"; position: relative; margin-bottom: 15px;}
.chapo span	p 						{ display: block; margin-top: 15px;}


@media (max-width:1200px) {
.titre_main	 						    { font-size: 35px; line-height: 45px;}
.titre_main.bigger	 				{ font-size: 40px; line-height: 50px;}
.sous_titre 						    { font-size: 22px; line-height: 30px;}
.sous_titre.smaller,
.sous_titre.smaller span    { font-size: 20px;}
}

@media (max-width:700px) {
.titre_main	 						     { font-size: 25px; line-height: 35px; margin-bottom: 10px;}
.titre_main.bigger           { font-size: 30px; line-height: 40px;}
.sous_titre 						     { font-size: 18px; line-height: 30px; margin-bottom: 10px;}
.sous_titre.smaller,
.sous_titre.smaller span     { font-size: 16px;}
.chapo		 						       { font-size: 13px; line-height: 26px; margin-bottom: 10px;}
.chapo span p 					     { margin-top: 10px;}
}



/* link base */
.link 								{ font: 500 14px/60px "Montserrat"; text-transform: uppercase; letter-spacing: 0.8px; height: 60px; display: inline-block; color: #fff; padding: 0 25px; background: var(--mainColor1); cursor: pointer; border-radius: var(--linkRadius);}
.link.color_2 						{ background-image: linear-gradient(to top, var(--mainColor2) 0% 50%, var(--mainColor2Hover) 50% 100%);}
.link_arrow                      	{ width: 60px; height: 60px; border-radius: 50%; background: url("../images/arrow_link.svg") 50% no-repeat var(--mainColor1); display: block; font-size: 0;}
.link_dwnld 						{ padding-right: 65px;}
.link_dwnld:before					{ width: 18px; height: 100%; position: absolute; right: 30px; top: 0; background: url("../images/dwnld.svg") 50% no-repeat; content: "";}

.link.tel  						    { padding-left: 65px;}
.link.tel:before					{ width: 18px; height: 100%; position: absolute; left: 30px; top: 0; background: url("../images/tel.svg") 50% no-repeat; content: "";}
.link.calculator  					{ padding: 0; font-weight: 600; height: 74px; line-height: 74px; padding-left: 0; font-size: 16px; text-align: center; background-color: #000; background: url("../images/arrow_link.svg") calc(100% - 30px) 50% no-repeat var(--mainColor1);}
.link.calculator:before				{ width: 24px; height: 100%; position: absolute; left: 30px; top: 0; background: url("../images/calculator.svg") 50% no-repeat; background-size: 24px auto; content: "";}

@media (min-width:1201px) {
.link:hover 						{ background-color: var(--mainColor2); color: #fff;}
.link_arrow:hover                  	{ background-color: var(--mainColor2); }
}
@media (max-width:700px) {
.link 								{ font-size: 14px; line-height: 48px; height: 50px; padding: 0 25px;}
.link.calculator  					{ height: 54px; line-height: 52px; font-size: 14px; }
.link.calculator:before				{ width: 20px; background-size: 20px auto;}
}



/* link cta v1 : icon + arrow */
.link.cta_v1						{ height: auto; padding: 0 80px 0 30px; text-align: left; border-radius: var(--linkRadius);}
.link.cta_v1:after 					{ width: 20px; height: 100%; background: url("../images/arrow_link.svg") 100% 50% no-repeat; position: absolute; right: 30px; top: 0; content: "";}
.link.cta_v1>span 					{ height: 80px; display: grid; align-items: center; position: relative; padding: 10px 0 10px 60px; font-size: 18px; line-height: 20px;}
.link.cta_v1>span:after				{ width: 30px; height: 100%; background: url("../images/devis_v1.svg") 50% / contain no-repeat; position: absolute; left: 0; top: 0; content: "";}
.link.cta_v1 i 						{ font-style: normal; font-size: 12px; display: block; padding-bottom: 2px;}

@media (max-width:700px) {
.link.cta_v1						{ padding: 0 60px 0 20px;}
.link.cta_v1:after 					{ right: 20px;}
.link.cta_v1>span 					{ height: 60px; padding: 5px 0 5px 45px; font-size: 16px; line-height: 18px;}
.link.cta_v1>span:after				{ width: 24px;}
}


/***** Link a *****/
p a, h2 a, .ul_check a 		      			{ color: var(--mainColor1); border-bottom: 1px solid var(--mainColor1); }
.footer p a                     			{ border-bottom: none; }
@media (min-width:1201px) {
p a:hover, h2 a:hover, .ul_check a:hover 	{ color: var(--mainColor2); border-color: var(--mainColor2); }
}


.txt_highlight						{ position: relative; }
.txt_highlight .wrapper				{ padding: clamp(20px, 5vw, 80px); background-color: #fff; }


.ul_check li 						{ position: relative; padding-left: 30px; line-height: 26px; margin-bottom: 15px;}
.ul_check li:before					{ width: 19px; height: 14px; position: absolute; left: 0; top: 4px; background: url("../images/check.svg") 0 0 / contain no-repeat; filter: invert(1); content: "";}
.ul_check li:last-child				{ margin-bottom: 0;}



    
/***** bandeau *****/
.bandeau                            { display: grid; align-items: center; justify-content: center; position: relative; text-align: center; color: #000; background-color: #fff; line-height: 25px; height: 105px; font-size: 17px;}
.bandeau strong                     { color: #f36a2e; font-size: 17px; transition: all ease 400ms;}
.bandeau::after                     { content: url("../images/arrow_link.svg"); filter: invert(1); line-height: 0; display: block; position: absolute; right: 30px; top: 50%; transform: translateY(-50%);}
.bandeau em                         { display: none;}
@media (min-width:1201px) {
.bandeau:hover                      { background-color: var(--mainColor1);}
.bandeau:hover strong               { color: #fff;}
.bandeau:hover::after               { filter: invert(0); }
}
@media (max-width:700px) {
.bandeau                            { background: var(--mainColor1); height: 56px; line-height: 54px; color: #fff;}
.bandeau::after,
.bandeau span                       { display: none;}
.bandeau em                         { display: block; font-style: normal;}
}





/***** hide  *****/
.hide                      { display: none;}
.read_more 			   	        { cursor: pointer; color: var(--mainColor2); border-bottom: 1px solid var(--mainColor2);}
.read_less                 { cursor: pointer; color: #ffffff; border-bottom: 1px solid #ffffff;}
.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: #ffffff;}
.hide_readMore :last-child { margin-bottom: 0;}

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






/***** 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; background: var(--third-color);}
.header::before			            { width: 75%; max-width: 1600px; height: 100%; background: var(--mainColor1); position: absolute; right: 0; top: 0; content: ""; opacity: 1; transition: all 300ms ease-in-out; }
.header .logo						{ width: 220px; position: absolute; left: 0; top: 50%; transform: translateY(-50%); z-index: 140; transition: all 300ms ease-in-out;}
.header .logo img					{ width: 100%; height: auto; display: block;}

.header .header_nav 				{ display: inline-block; position: relative; transition: all 300ms ease-in-out;}
.header .menu     					{ padding: 15px 0; margin: 0;}
.header .menu>li					{ position: relative; display: inline-block; vertical-align: top; margin-left: 45px;}
.header .menu>li:first-child 		{ margin-left: 0;}
.header .menu>li>a					{ font-size: 16px; line-height: 78px; font-weight: 600; height: 80px; letter-spacing: 0.8px; text-transform: none; color: #fff; display: block;}
.header .menu>li.active>a			{ color: var(--mainColor2);}

.header .menu .sub					{ width: 260px; margin-left: -130px; text-align: center; position: absolute; top: 54px; left: 50%; display: block; visibility: hidden; opacity: 0; padding: 20px 0; background: var(--mainColor2);}
.header .menu .sub li				{ width: 100%; margin: 0;}
.header .menu .sub li a				{ width: 100%; font-size: 15px; letter-spacing: 0.6px; line-height: 38px; height: 40px; font-weight: 400; text-transform: none; color: #fff;}
.header .menu .sub li.active a		{ color: var(--mainColor1);}

.header .menu .link.tel    			{ padding: 0 30px 0 70px; background: var(--mainColor2); line-height: 58px; height: 60px; margin: 10px 0;}


.sticky .header 					          { background-color: var(--bgColorLight); box-shadow: 0 5px 10px 0 rgba(91,60,37,0.15);}
.sticky .header .menu         		  { padding: 5px 0;}
.sticky .header .menu>li>a			    { color: var(--mainColor2);}
.sticky .header .menu>li.active>a	  { color: var(--mainColor1);}
.sticky .header .menu .link.tel     { background: var(--mainColor1); color: #fff; }

@media (min-width:1201px) {
.menu_mobile 						{ display: none;}
.header .menu>li:hover 				{ z-index: 999;}
.header .tel:hover,	
.header .menu>li:hover>a 			{ color: var(--mainColor2);}
.header .menu>li:hover .link 		{ color: #fff;}
.header .menu>li .sub a:hover 		{ color: var(--mainColor1);}
.header .menu>li:hover .sub			{ opacity: 1; visibility: visible; z-index: 999;}
.header .menu .sub:after 			{ width: 10px; height: 10px; position: absolute; left: 50%; top: -4px; margin: 0 0 0 -5px; transform: rotate(45deg); background: var(--second-color); content: "";}
.header .menu .sub:before 			{ width: 100%; height: 10px; position: absolute; left: 0; top: -10px; content: "";}
.header_nav .menu>li:hover .sub	    { opacity: 1; visibility: visible; z-index: 10;}
.header_nav .menu .sub 				{ display: block !important;}    
.header .menu .link.tel:hover		{ background: #fff; color: #000; }
.header .menu .link.tel:hover:before { filter: invert(1); }
    
.sticky .header .menu .link.tel:hover { background: #000; color: #fff; }
.sticky .header .menu .link.tel:hover:before { filter: invert(0); }

.sticky .header .menu>li:hover>a	  { color: var(--mainColor1);}

.sticky .header::before			    { opacity: 0;}
}

@media (max-width:1366px) {
.header .menu>li					{ margin-left: 35px;}
}

@media (max-width:1200px) {
.menu_mobile						{ width: 70px; height: 100px; display: inline-block; vertical-align: middle; cursor: pointer; position: relative; z-index: 250; margin: 0 -20px; transition: height 300ms ease-in-out;}
.menu_mobile div					{ width: 30px; height: 2px; background: #fff; position: absolute; right: 50%; top: 50%; margin: -1px -15px 0 0;}
.menu_mobile div:before				{ width: 100%; height: 2px; background: #fff; position: absolute; right: 0; top: 7px; content: "";}
.menu_mobile div:after				{ width: 100%; height: 2px; background: #fff; position: absolute; right: 0; top: -7px; content: "";}
.menu_mobile.active div				{ height: 0;}
.menu_mobile.active div:before		{ top: 0; transform: rotate(45deg);}
.menu_mobile.active div:after		{ top: 0; transform: rotate(-45deg);}

.header 							{ padding: 0; }
.header::before			            { width: 70%; }
.header ::-webkit-scrollbar			{ display: none;}
.header .logo						{ z-index: 250;}
.header .menu .link.tel 			{ margin-top: 40px; background-color: var(--mainColor1); display: inline-block;}

.header .header_nav 				{ width: 100%; position: fixed; right: -100%; top: 0; bottom: 0; overflow-y: scroll; z-index: 200; background: var(--mainColor2); border-top: 100px solid var(--mainColor2); padding: 60px 0 80px 0; transition: all 300ms ease-in-out 200ms;}
.header .menu  						{ display: block; width: auto; text-align: left; margin: 0 15vw; position: relative; z-index: 100; opacity: 0; transition: all 300ms ease-in-out 0ms;}
.header_nav .menu>li 				{ width: 100%; display: block; margin: 0;}
.header_nav .menu li                { margin: 0;}
.header_nav .menu>li>a				{ line-height: 60px; height: 60px; font-weight: 500; transition: none; color: #ffffff; border-top: none; border-bottom: none; padding: 0;}
.header_nav .menu>li>a:after        { right: auto; left: 0; bottom: 8px;}
.header_nav .menu>li.active>a       { border-top: none; border-bottom: none;}
.header_nav .menu>li>i				{ width: 100%; height: 40px; display: block; position: absolute; top: 5px; right: 0; z-index: 5;}
.header_nav .menu>li>i:after		{ width: 60px; height: 100%; background: url("../images/arrow_down.svg") 50% 52% no-repeat var(--bgColorLight); float: right;  content: ""; border-radius: 0;}
.header_nav .menu>li>i.active:after { transform: rotate(180deg);}
.header .menu .sub li.active a		{ color: var(--mainColor1);}
.header .menu>li.active>a			{ color: var(--mainColor1);}

.sticky .header .menu>li>a			    { color: #ffffff;}
    
.header_nav .menu .sub 				{ width: 100%; position: relative; left: auto; top: auto; padding: 10px 15px 10px 30px; margin: 15px 0; background-color: var(--bgColorLight); visibility: visible; opacity: 1; display: none; z-index: 150; transform: none; box-shadow: none;}
.header_nav .menu .sub li  			{ width: 100%; height: initial; border-bottom: 0; text-align: left;}
.header_nav .menu .sub li a			{ width: 100%; text-align: left; color: #000; padding: 0;}

.header.active .header_nav 			{ right: 0; transition-delay: 150ms;}
.header.active .logo      			{ filter: brightness(0) invert(1);}
.header.active .menu 				{ opacity: 1; transition-delay: 600ms;}
}
@media (max-width:1000px) {
.header .menu  						{ margin: 0 10vw;}
.header::before			            { width: 50%; }
}
@media (max-width:700px) {
.menu_mobile						{ height: 70px;}
.header 							{ padding: 0;}
.header::before			            { width: 30%; height: 70px;}
.header .logo						{ width: 170px;}
.header .menu .link.tel				{ width: 100%;}
.header .header_nav 				{ border-width: 80px; padding: 6vw 0 8vw 0;}
.header .menu  						{ margin: 0 8vw;}
.header .menu>li>a					{ font-size: 12px; height: 44px; line-height: 44px;}

.header .menu>li>i					{ height: 44px; margin-top: -44px;}
.header .menu>li>i:after			{ width: 40px; background-size: 16px auto;}
.header .menu li .sub li a			{ font-size: 13px;}

.sticky .header .menu         		{ padding: 0 0;}
}



/***** grid bloc *****/
.grid_bloc	 								{ position: relative; padding: 0; margin: var(--marginTB);}

.grid_bloc:before 							{ height: 90vh; position: absolute; left: 0; right: 0; bottom: 65%; background: linear-gradient(to top, #eee 0%, #fff 100%); z-index: -1; transition: none; content: "";}

.grid_bloc .container						{ display: grid; grid-gap: clamp(10px, 5vw, 40px); text-align: center;}

@media (max-width:1200px) {
.grid_bloc:before							{ left: 0; right: 0; top: 0; bottom: 0; border-radius: var(--imgRadius);}
}





/***** bloc txt img *****/
.bloc_txt_img 											{ position: relative; margin: var(--marginTB);}
.bloc_txt_img:before									{ position: absolute; left: 20px; right: 60%; top: 25%; bottom: 0; background: var(--bgColorLight); border-radius: var(--imgRadius); visibility: hidden; transition: none; content: "";}
.bloc_txt_img .container	                        	{ display: grid; grid-template-columns: 50% 1fr; grid-gap: 0 80px; align-items: center; position: relative;}
.bloc_txt_img .container.align_top                		{ align-items: start;}
.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 p               				{ margin-bottom: 15px;}
.bloc_txt_img .container .link							{ margin-top: 10px;}

.bloc_txt_img.reverse:before							{ left: 60%; right: 20px; top: 25%; bottom: -10%; background: var(--bgColorLight); border-radius: var(--imgRadius); visibility: visible; content: "";}
.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;}

@media (max-width:1200px) { 
.bloc_txt_img .container	                        	{ grid-gap: 0 60px;}
}
@media (max-width:1000px) { 
.bloc_txt_img .container 								{ grid-template-columns: 1fr; grid-gap: 40px;}
.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;}
.bloc_txt_img .container img 							{ height: 45vh;}
}
@media (max-width:700px) { 
.bloc_txt_img .container	                        	{ grid-gap: 30px;}
.bloc_txt_img .container p               				{ margin-bottom: 10px;}
}

/* multi links */
.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;}

@media (max-width:700px) { 
.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                        			{ position: relative; margin: 25px 0;}
.show_hide .item                  			{ border: 1px solid #373737; margin: 10px 0;}
.show_hide.no_marge .item               { margin: 0; border-top: none; border-right: none; border-left: none;}
.show_hide .titre                 			{ font-size: 16px; line-height: 24px; font-weight: 500; position: relative; cursor: pointer; letter-spacing: 0.6px; color: var(--mainColor2); padding: 23px 80px 23px 30px; margin: 0;}
.show_hide.no_marge .titre              { padding-left: 0;}
.show_hide .hide                  			{ margin: 0; padding: 0 30px 35px 30px; display: none;}
.show_hide .hide :last-child 	 			    { margin-bottom: 0;}


@media (max-width:1200px){
.show_hide .titre                 			{ padding: 20px 70px 20px 25px;}
.show_hide .hide                  			{ padding: 0 25px 30px 25px;}
}
@media (max-width:700px){
.show_hide                        			{ margin: 20px 0;}
.show_hide .titre                 			{ padding: 15px 65px 15px 20px; font-size: 14px; line-height: 22px;}
.show_hide .hide                  			{ padding: 0 20px 20px 20px;}
}

/* custom collapse */
.show_hide.collapse                  		{ border: 1px solid #ddd; border-radius: 0;}
.show_hide.collapse .item                  	{ border: 0; margin: 0; border-radius: 0; border-bottom: 1px solid #ddd;}
.show_hide.collapse .item:last-child       	{ border: 0;}

/* 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; content: ""; }
.show_hide .titre_arrow.active:after   		{ transform: rotate(180deg);}

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

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

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



/***** cta bloc v1 *****/
.cta_bloc.v1                           	{ background: var(--mainColor1); position: relative; text-align: center; font-size: 24px; line-height: 30px; font-weight: 700; padding: 40px; border-radius: 0; margin: 25px 0;}
.cta_bloc.v1:after                    	{ width: 80px; height: 80px; border-radius: 0; background: url(../images/gsm_v1.svg) no-repeat center #000; filter: invert(1); position: absolute; top: 50%; transform: translateY(-50%); left: 20px; content: "";}
.cta_bloc.v1>div                        { display: inline-block;}
.cta_bloc.v1 a                         	{ color: #000;}
.cta_bloc.v1 b                    		{ font-weight: 700; font-size: 24px; text-transform: uppercase;}

@media (min-width:1201px) {

}

@media (max-width:1000px) {

}
@media (max-width:700px) {

}



/***** cta bloc v2 *****/
.cta_bloc.v2 								{ position: relative; display: grid; grid-template-columns: 350px 1fr; background: var(--mainColor1); border-radius: 0; overflow: hidden; text-align: center; margin: 25px 0;}
.cta_bloc.v2 .titre							{ color: #fff; background: var(--mainColor2); font-size: 24px; line-height: 30px; font-weight: 600; letter-spacing: 0.8px; padding: 10px 40px 12px 40px; display: grid; align-items: center;}
.cta_bloc.v2 .row .tel   					{ display: inline-block; vertical-align: middle;}
.cta_bloc.v2 .row .tel a 					{ display: inline-block; background: url("../images/gsm_v1.svg") 0 50% no-repeat; padding: 35px 0 35px 50px; color: #fff; text-align: left; font-size: 14px; line-height: 20px;}
.cta_bloc.v2 .row .tel a span				{ display: block; font-size: 24px; line-height: 30px;}
.cta_bloc.v2 .row .form   					{ display: inline-block; vertical-align: middle; margin-left: 80px;}
.cta_bloc.v2 .row .form .link				{ background: #fff; color: #000;}

@media (min-width: 1201px){
.cta_bloc.v2 .form .link:hover				{ color: var(--mainColor1);}
}
@media (max-width: 1200px){
.cta_bloc.v2 								{ grid-template-columns: 280px 1fr;}
.cta_bloc.v2 .titre							{ font-size: 20px;}
.cta_bloc.v2 .row .form   					{ display: inline-block; vertical-align: middle; margin-left: 60px;}
.cta_bloc.v2 .row .tel a 					{ padding: 30px 0 30px 50px;}
.cta_bloc.v2 .row .tel a span				{ font-size: 20px;}
}
@media (max-width: 1000px){
.cta_bloc.v2 								{ grid-template-columns: 1fr; }
.cta_bloc.v2 .titre							{ font-size: 20px; line-height: 30px; padding: 25px;}
.cta_bloc.v2 .row .tel a 					{ padding: 25px 0 25px 50px;}
.cta_bloc.v2 .row .form   					{ margin-left: 50px;}
}
@media (max-width: 700px){
.cta_bloc.v2 .titre							{ font-size: 16px; padding: 3.5vw 5vw;}
.cta_bloc.v2 .row       					{ display: grid; grid-template-columns: 1fr; grid-gap: 3.5vw; padding: 5vw;}
.cta_bloc.v2 .row .tel a 					{ background-size: 24px auto; padding: 0 0 0 40px; font-size: 12px; line-height: 16px;}
.cta_bloc.v2 .row .tel a span				{ font-size: 18px;}
.cta_bloc.v2 .row .form   					{ margin-left: 0; }
.cta_bloc.v2 .row .form .link				{ display: block; width: 100%;}
}




/***** before after img *****/
.before_after_img                               		{ display: grid; place-content: center; position: relative; overflow: hidden; --position: 50%}
.before_after_img img                         			{ width: 100%; height: 100%; object-fit: cover; object-position: left; border-radius: var(--imgRadius);}
.before_after_img img.image_before                      { position: absolute; inset: 0; width: var(--position); filter: grayscale(100);}
.before_after_img .range                                { position: absolute; inset: 0; opacity: 0; width: 100%; height: 100%; margin: 0; cursor: grab;}
.before_after_img .range:active                         { cursor: grabbing;}
.before_after_img .range_line                          	{ position: absolute; inset: 0; width: 4px; height: 100%; background-color: #fff; left: var(--position); transform: translateX(-50%); pointer-events: none;}
.before_after_img .range_button 						{ position: absolute; background: #fff; display: grid; top: 50%; left: var(--position); transform: translate(-50%,-50%); pointer-events: none; width: 80px; grid-template-columns: 1fr 1fr; align-items: center;}
.before_after_img .range_button span                    { background: url("../images/arrow_slider.svg") 55% 50% no-repeat; display: block; height: 50px; filter: invert(1);}
.before_after_img .range_button span:first-child 		{ transform: rotate(180deg);}

@media (max-width:700px) { 
.before_after_img .range_line                          	{ width: 2px;}
.before_after_img .range_button 						{ width: 60px;}
.before_after_img .range_button span                    { height: 40px;}
}




/***** banner cta *****/
.banner_cta 								{ display: grid; align-items: center; text-align: center; min-height: 55vh; padding: 80px 6vw; background: url(../images/banner_bg_1.webp) 50% center / cover no-repeat fixed;}
.banner_cta .titre_main 					{ color: #fff; margin: 0;}
.banner_cta .titre_main a					{ color: var(--mainColor1); padding-bottom: 0; border: none;}
.banner_cta .titre_main i					{ font-style: normal;}

@media (min-width:1201px){
.banner_cta .titre_main a:hover 			{ color: #fff;}
}
@media (max-width:1200px){
.banner_cta 								{ min-height: inherit; height: 60vw; max-height: 650px; background-attachment: scroll;}
}
@media (max-width:1000px){
.banner_cta 								{ height: 65vw;}
}
@media (max-width:700px){
.banner_cta 								{ padding: 50px 6vw; height: auto; background: var(--mainColor2);}
.banner_cta .titre_main a 					{ font: 600 14px/48px "Montserrat"; letter-spacing: 0.6px; height: 50px; display: block; color: #fff; padding: 0 30px; background: var(--mainColor1); text-transform: capitalize; margin: 0 0 5px 0;}
.banner_cta .titre_main a:first-of-type 	{ line-height: 50px; margin: 15px 0 10px 0;}
.banner_cta .titre_main i					{ display: none;}
}




/***** bloc rs *****/
.bloc_rs									{ font-size: 0; line-height: 0; letter-spacing: 0;}
.bloc_rs a									{ width: 54px; height: 54px; display: block; overflow: hidden; border-radius: 0; background: var(--mainColor1);}
.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 .instagram:after					{ background: url("../images/instagram.svg") 50% no-repeat;}
.bloc_rs .youtube:after						{ background: url("../images/youtube.svg") 50% no-repeat;}
.bloc_rs .linkedin:after					{ background: url("../images/linkedin.svg") 50% 48% no-repeat;}
.bloc_rs .scroll:after 						{ background: url("../images/scrolltop.svg") 50% 46% no-repeat;}





/***** moving img *****/
.moving_img									{ width: 100vw; left: 50%; transform: translateX(-50%); position: relative; margin-top: 60px;}
.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 20px;}
.moving_img .row .grid img 					{ width: auto; height: 440px; display: block; 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 div 					{ padding: 0 15px;}
.moving_img .row .grid img 					{ height: 420px;}
}
@media (max-width:1400px) {
.moving_img .row .grid img 					{ height: 400px;}
}
@media (max-width:1200px) {
.moving_img									{ margin-top: 40px;}
.moving_img .row .grid div 					{ padding: 0 10px;}
.moving_img .row .grid img 					{ height: 380px;}
}
@media (max-width:1000px) {
.moving_img									{ margin-top: 0;}
.moving_img .row .grid img 					{ height: 350px;}
}
@media (max-width:700px) {
.moving_img .row .grid div 					{ padding: 0 7px;}
.moving_img .row .grid img 					{ height: 60vw; max-height: 350px;}
}





/***** footer *****/
.footer										{ position: relative; color: #fff; padding-top: clamp(20px, 10vw, 120px);}
.footer:before								{ position: absolute; left: 0; right: 0; top: 0; bottom: 0; background: var(--bgColorDark); content: "";}
.footer .bloc_footer 						{ display: inline-block; vertical-align: top; position: relative; font-size: 15px; line-height: 26px;}
.footer .bloc_footer.heading_top 			{ display: block; margin-bottom: clamp(20px, 7vw, 40px);}
.footer .bloc_footer.heading_float 			{ margin-right: 100px;}
.footer .bloc_footer .logo 					{ width: 180px; height: auto; display: block;}
.footer .bloc_footer .titre_footer			{ font-size: 18px; font-weight: 600; letter-spacing: 0.6px; margin: 0; 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: 30px; position: relative;}
.footer .bloc_footer .icon:after 			{ width: 18px; height: 100%; position: absolute; left: 0; top: 0; content: "";}
.footer .bloc_footer .address:after 		{ background: url(../images/map.svg) 0 50% no-repeat;}
.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 60% no-repeat;}
.footer .bloc_footer .email a:after 		{ background: url(../images/email.svg) 0 50% no-repeat;}

.footer ul.bloc_footer     					{ margin: 0 0 0 100px;}
.footer ul.bloc_footer li   				{ margin-top: 15px;}
.footer ul.bloc_footer li a 				{ color: #fff; display: inline-block; padding: 0 0 0 20px;}
.footer ul.bloc_footer li a:after			{ width: 6px; height: 100%; background: url(../images/list.svg) 0 50% no-repeat; position: absolute; left: 0; top: 0; filter: invert(1); content: "";}

.footer .bloc_rs							{ position: absolute; right: 0; top: -10px;}
.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, 7vw, 80px) 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: -15px; top: 4px; 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: 0; transition: opacity 300ms ease-in-out; opacity: 1;}
.toponweb span								{ width: auto; height: 60px; display: block; padding: 20px; }
.toponweb img								{ width: 76px; height: auto; display: block; margin: 0 auto;  transition: all 300ms ease-in-out;}

@media (min-width:1201px) {
.footer .bloc_rs a:hover     				{ background-color: #fff;}    
.footer .bloc_rs a:hover:after 				{ filter: invert(1);}    
.footer .bloc_footer p a:hover, 
.footer .bloc_footer li a:hover, 	 
.footer_bottom li a:hover 	 				{ color: var(--mainColor1);}
.toponweb:hover								{ opacity: 0.5;}
}
@media (max-width:1200px) {
.footer .bloc_footer.heading_float 			{ margin-right: 80px;}
.footer ul.bloc_footer     					{ display: none;}
}
@media (max-width:700px) {
.footer .bloc_footer 						{ width: 100%; padding: 0; font-size: 14px; line-height: 24px;}
.footer .bloc_footer.heading_float 			{ margin-right: 0; margin-bottom: clamp(20px, 7vw, 40px);}
.footer .bloc_footer .logo 					{ width: 120px; padding-bottom: 5px;}
.footer .bloc_footer :first-child			{ margin-top: 0;}
.footer	.bloc_rs							{ position: static; margin-top: 7vw;}
.footer	.bloc_rs a							{ width: 50px; height: 50px; margin: 0 10px 0 0;}
.footer	.bloc_rs .scroll					{ position: absolute; right: 0; top: -10px;}
.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;}
}




