/* 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: #0093FF;
	--mainColor2: #064C80;
	--bgColorLight: #DAF2FF;
	--bgColorDark: #001526;

    --box-shadow-1: 0px 0px 70px 0px rgb(0 149 255 / 60%);
    --box-shadow-2: 0 0 40px 0 rgba(16, 185, 255, 0.2);
    
    
	--fontBody: "Montserrat";
	
	--marginTB: clamp(70px, 8vw, calc(100px + 2vw)) auto;
	--marginT: clamp(70px, 8vw, calc(100px + 2vw));
	--marginB: clamp(70px, 8vw, calc(100px + 2vw));

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

	--linkRadius: 50px;
	--imgRadius: 30px;
}
@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: 10px;
	--imgRadius: 20px;
	}
}



/***** 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 16px/180% var(--fontBody); letter-spacing: 0.6px;  color: #fff; background: var(--bgColorDark); position: relative;}

body.active_overflow				{ height: 100vh; overflow: hidden;}
main 								{ position: relative; z-index: 10;}
p 									{ margin-bottom: clamp(10px, 2vw, 15px);}
ul									{ list-style-type: none;}
a									{ text-decoration: none; position: relative; color: var(--mainColor1)}
img									{ border: none; }
strong, b							{ font-size: 17px; font-weight: 600;}

#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;}
strong, b							{ font-size: 16px;}
}



/***** 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, .read_more, .read_less { transition: all 300ms 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_3 							{ color: #fff}
.color_bg_1							{ background: var(--mainColor1);}
.color_bg_2 						{ background: var(--mainColor2);}

.titre_main	 						{ font: 500 40px/52px var(--fontBody); letter-spacing: 0; position: relative; margin-bottom: clamp(10px, 2vw, 15px);}
.titre_main span	 				{ color: var(--mainColor1); }
.titre	 						    { font: 500 35px/42px var(--fontBody); letter-spacing: 0; position: relative; margin-bottom: clamp(10px, 2vw, 15px);}

.titre_cap	 						{ font: 600 14px/120% var(--fontBody); letter-spacing: 2.2px; text-transform: uppercase; position: relative; margin-bottom: clamp(10px, 2vw, 15px);}

.sous_titre 						{ font: 500 25px/32px var(--fontBody); letter-spacing: 0; position: relative; margin-bottom: clamp(10px, 2vw, 15px);}
.sous_titre span					{ color:var(--mainColor1);}
.sous_titre.underline:after, .titre_main.underline:after                     { display: block; width: 120px; height: 2px; position: relative; background: linear-gradient(90deg,rgba(0, 255, 255, 1) 0%, rgba(0, 147, 255, 1) 50%, rgba(0, 21, 38, 1) 100%); z-index: 1; content: ""; margin-top: 20px}

.chapo		 						{ font: 500 16px/180% var(--fontBody); margin-bottom: clamp(10px, 2vw, 15px);}

lord-icon 							{ display: block; width: 70px; height: 70px; margin-bottom: 5px;}

@media (max-width:1200px) {
.titre_main	 						{ font-size: 40px; line-height: 48px;}
.titre_main span	 				{ font-size: 22px; line-height: 28px;}
.titre            	 				{ font-size: 30px; line-height: 38px;}
.sous_titre 						{ font-size: 22px; line-height: 28px;}
}
@media (max-width:700px) {
.titre_main	 						{ font-size: 30px; line-height: 38px;}
.titre            	 				{ font-size: 25px; line-height: 32px;}
.titre_cap	 						{ font-size: 12px; line-height: 140%;}
.sous_titre 						{ font-size: 20px; line-height: 28px;}
lord-icon 							{ width: 60px; height: 60px;}
}


/***** 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(--mainColor2); 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(--mainColor2Hover); }
.read_less:hover                    { color: #ffffff; border-color: var(--mainColor1Hover); }
}

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


@media (max-width:700px) {
/* .chapo 								{ display: none;}*/
}



/* link base */
.link 								{ font: 500 13px/56px var(--fontBody); letter-spacing: 2px; text-transform: uppercase; height: 54px; display: inline-block; color: #fff; padding: 0 30px; background: var(--mainColor1); cursor: pointer; border-radius: var(--linkRadius);}
.link span							{ font-weight: 800;}
.link.color_2 						{ background-image: linear-gradient(to top, var(--mainColor2) 0% 50%, var(--mainColor2Hover) 50% 100%);}


/* link cta v1 : icon + arrow */
.link.cta_v1						{ height: auto; padding: 0 80px 0 30px; text-align: left; border-radius: 15px;}
.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;}



/* link arrow */
.link_arrow                      	{ width: 60px; height: 60px; background: url("../images/arrow_link.svg") 15px 50% no-repeat var(--mainColor1); display: block; font-size: 0;}
.link_arrow:hover                   { background: url("../images/arrow_link.svg") 15px 50% no-repeat var(--mainColor2);}
.link_plus							{ font: 700 13px/50px var(--fontBody); letter-spacing: 0.8px; height: 50px; text-transform: uppercase; display: inline-block; color: var(--mainColor1); padding: 0 0 0 65px;}
.link_plus:after					{ width: 50px; height: 50px; border-radius: 50%; background: url("../images/plus_white.svg") 50% no-repeat var(--mainColor1); position: absolute; left: 0; top: 0; content: "";}


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


.ul_list li 						{ position: relative; padding-left: 30px; line-height: 25px; margin-bottom: 12px;}
.ul_list li:before					{ width: 19px; height: 14px; position: absolute; left: 0; top: 4px; background: url("../images/list.svg") 0 0 / contain no-repeat; content: "";}
.ul_list li:last-child				{ margin-bottom: 0;}

@media (min-width:1201px) {
.link:hover 						{ background-color: var(--mainColor2); color: #fff;}
}





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

.header_top                         { text-align: right;}
.header_top a 				        { color: #fff; font: 700 14px/50px var(--fontBody); letter-spacing: 0.4px; padding-left: 65px; position: relative; z-index: 1; display: inline-block; vertical-align: middle; margin-left: 40px;}
.header_top a i                     { position: absolute; left: 0; width: 50px; height: 50px; border-radius: 50%; display: grid; align-items: center; justify-content: center; background: var(--mainColor1);}

.header_right 						{ position: relative; z-index: 120;}
.header_right>span                  { font: 400 12px/30px var(--fontBody); letter-spacing: 0.4px; display: inline-block; vertical-align: middle;}
.header_nav							{ display: inline-block; vertical-align: middle; padding-right: 0; z-index: 50;}
.header_nav .menu					{ position: relative; margin: 0}
.header_nav .menu li				{ display: inline-block; vertical-align: top; position: relative; margin-left: 40px;}	
.header_nav .menu li a				{ font: 700 normal 16px/70px var(--fontBody); letter-spacing: 0.4px; height: 70px; display: block; transition-property: color, height, line-height; color: #fff;}
.header_nav .menu>li.active>a 		{ color: var(--mainColor1);}
.header_nav .sub					{ width: 300px; text-align: center; position: absolute; top:100%; left: 50%; margin-left: -150px; display: block; visibility: hidden; opacity: 0; background: var(--mainColor2); padding: 5px 0;}
.header_nav .sub li					{ width: 100%; margin: 0; position: relative; z-index: 1;}
.header_nav .sub li a				{ width: 100%; font: 400 14px/50px var(--fontBody); height: 50px; color: #fff; padding: 0;}
.header_nav .menu li:hover .sub		{ opacity: 1; visibility: visible; z-index: 999; top: 100%;}
.header_nav .menu .sub li.active a	{ color: var(--mainColor1);}
.sticky .header                     { top: -70px; box-shadow: var(--box-shadow-1); background: var(--bgColorDark);}
.sticky .header .logo               { top: 0; transform:scale(0.5);transition: all 400ms ease-in-out;}



@media (min-width:1201px) {

.header_nav .menu .vue_mobile,
.menu_mobile 						{ display: none;}
.header_nav .menu>li:hover>a        { color: var(--mainColor2);}
.header_nav .sub 					{ display: block !important; border-radius: 20px;}
.header_nav .sub:after 				{ width: 10px; height: 10px; position: absolute; left: 50%; top: -5px; margin: 0 0 0 -5px; transform: rotate(45deg); background: var(--mainColor2); content: "";}
.header_nav .menu>li:hover>a 		{ color: var(--mainColor2);}
.header_nav .sub li a:hover			{ color: var(--mainColor2);}
    
.header_top a:hover                 { color: var(--mainColor2);}
.header_top .lang:hover             { color: #fff; background: var(--mainColor2);}

.sticky .header_nav .menu>li>a		{ line-height: 100px; height: 100px; padding-bottom: 0;}
}
@media (max-width:1366px) {
.header_nav .menu li                { margin-left: 25px;}
}
@media (max-width:1200px) {
.menu_mobile						{ width: 50px; height: 50px; display: inline-block; vertical-align: middle; cursor: pointer; position: relative; margin: 20px -5px 20px 5px; transition: margin 400ms ease-in-out; border-radius: 50%;}
.menu_mobile div					{ width: 40px; height: 2px; background: var(--mainColor1); position: absolute; right: 50%; top: 50%; margin: -1px -20px 0 0;}
.menu_mobile div:before				{ width: 100%; height: 2px; background: var(--mainColor1); position: absolute; right: 0; top: 8px; content: "";}
.menu_mobile div:after				{ width: 100%; height: 2px; background: var(--mainColor1); position: absolute; right: 0; top: -8px; content: "";}
.menu_mobile.active div				{ height: 0;}
.menu_mobile.active div:before		{ top: 0; transform: rotate(-135deg);}
.menu_mobile.active div:after		{ top: 0; transform: rotate(-45deg);}
.header 							{ transition: box-shadow 400ms ease-in-out, height 400ms ease-in-out 400ms, top 400ms ease-in-out 0, background 400ms ease-in-out 0; padding: 0;}

.header .wrapper                    { max-width: initial;}

.header .logo                       { z-index: 123; bottom: auto; top: 80%; transform: translateY(-50%);}
.header .logo img                   { width: 165px;}
.header_top                         { z-index: 122; position: relative; padding: 0; display: grid; grid-template-columns: auto auto; justify-content: end; align-items: center; margin: 0 -5vw; padding: 0 5vw;}
.header_top a                       { margin: 0 30px 0 0;}
/*
.header_nav 	  					{ width: 100%; height: 100vh; background: var(--fourth-color); padding: 0; position: fixed; right: 100%; top :0; overflow-y: scroll; display: grid; z-index: 100; transition: all 0ms ease-in-out 400ms;}
*/
.header_top .rdv                    { margin-left: 0;}
.header_top .lang                   { margin-right: 0;}

.header_nav 	  					{ width: 100%; height: 100vh; position: fixed; right: -100%; top :0; overflow-y: scroll; display: grid; align-content: flex-start; background-color: var(--bgColorDark); z-index: 121;  padding-top: 110px; transition: all 400ms ease-in-out 600ms;}
.header_nav::-webkit-scrollbar		{ display: none;}
.header_nav .menu  					{ width: auto; text-align: left; margin: 5vw 10vw; position: relative; z-index: 100;  align-self: center; opacity: 0; transition: all 200ms ease-in-out 0ms;}
.header_nav .menu li 				{ width: 100%; display: block; margin: 0;}
.header_nav .menu li a				{ width: 100%; font-size: 18px; line-height: 50px; height: 50px;}
.header_nav .menu li i				{ width: 45px; height: 41px; display: block; margin-top: -48px; position: relative; z-index: 5; background: url("../images/arrow_down.svg") 50% no-repeat #fff; float: right; border-radius: 8px;}
.header_nav .menu li i.active		{ transform: rotate(180deg);}
.header_nav .menu li i.active		{ transform: rotate(180deg);}
.header_nav .menu .sub 				{ width: auto; visibility: visible; position: relative; left: auto; top: auto; margin: 15px 0; opacity: 1; display: none; text-align: left; padding: 20px 5vw;  border-radius: 5px;}
.header_nav .menu .sub li a 		{ line-height: 43px; height: 45px;}

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

.sticky .header                     { top: 0;}
.sticky .header .logo               { bottom: inherit; top: -36px; transform:scale(0.6);}

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

.header_top .rdv                    { padding: 0; font-size: 0; letter-spacing: 0; width: 50px; margin-right: 0;}
.header .logo span                  { font-size: 13px; line-height: 26px; left: 20px; bottom: 0;}
.header_top a:not(.lang)            { width: 45px; height: 45px; font-size: 0; padding: 0; border-radius: 50%; background-color: #fff; background-position: center; margin-right: 10px;}
.header_top .phone                  { background-image: url(../images/phone_blue.svg);}
}
@media (max-width:700px) {
.header_top                         { margin: 0 -7.5vw; padding: 0 7.5vw;}
.header_top .tel                    { display: none;}
.header_nav .menu  					{ padding: 7.5vw 0;}
}



/***** CTA *****/
.cta 								{ position: relative; display: grid; grid-template-columns: 1fr 1fr; align-items: center; background: var(--bgColorDark); color: var(--bgColorDark); border-radius: var(--imgRadius); overflow: hidden; text-align: center; box-shadow: var(--box-shadow-1);}
.cta .sous_titre				    { background: #fff; padding: 65px 40px; position: relative; z-index: 5; margin-bottom: 0;}
.cta .sous_titre span				{ color: var(--mainColor1); text-transform: uppercase; font-weight: 700;}
.cta .row     						{ position: relative; overflow: hidden; padding: 20px 30px;}
.cta .row .link   					{ text-align: left; padding: 0 30px 0 65px;}
.cta .row .tel   					{ display: inline-block; vertical-align: middle; margin-bottom: 20px;}
.cta .row .tel p 					{ color: #fff; margin-bottom: 5px;}
.cta .row .tel a 					{ background: url("../images/tel.svg") 30px 50% no-repeat var(--mainColor1);}


@media (min-width: 1201px){
.cta .row .link:hover 				{ color: var(--mainColor2);}
}
@media (max-width: 1200px){
.cta 								{ grid-template-columns: auto 1fr;}
}
@media (max-width: 1000px){
.cta 								{ grid-template-columns: 1fr;}
.cta .titre							{ padding: 30px;}
.cta .titre:before					{ right: 50%; margin: 0 7px 0 0; top: auto; bottom: -7px;}
}
@media (max-width: 700px){
.cta .sous_titre                    { padding: 20px 0; margin-bottom: 10px;}
.cta .titre							{ color: #fff; font-size: 16px; letter-spacing: 1.4px; font-weight: 700; text-transform: uppercase; padding: 0; background: none; margin: -5px 0 15px 0;}
.cta .titre:before					{ display: none;}
.cta .titre span					{ color: #fff;}
.cta .row:before					{ display: none;}
.cta .row .link   					{ display: block; text-align: center; padding: 0 20px;}
.cta .row .tel   					{ display: block;}
.cta .row .tel a 					{ background-image: none;}
}



/***** bloc grid *****/
.bloc_grid	                        { display: grid; grid-template-columns: 1fr 1fr; align-items: center; position: relative; margin: 95px 0; gap: 80px;}
.bloc_grid.align_top                { align-items: start;}
.bloc_grid .photo					{ position: relative; line-height: 0;}
.bloc_grid .photo img 				{ width: 100%; height: auto; object-fit: cover; display: block; position: relative; z-index: 10; border-radius: 40px;}
.bloc_grid .texte					{ position: relative;}
.bloc_grid .texte :last-child 		{ margin-bottom: 0;}
.bloc_grid p               			{ margin-bottom: 15px;}
.bloc_grid .link					{ margin-top: 10px;}
.bloc_grid.reverse .texte			{ grid-area: 1 / 1;}
.bloc_grid.reverse .photo        	{ grid-area: 1 / 2;}

@media (max-width:1200px) { 
.bloc_grid	                        { margin: 100px 0; gap: 50px;}
}
@media (max-width:1000px) { 
.bloc_grid	                        { grid-template-columns: 1fr; margin: 80px 0; gap: 60px;}
.bloc_grid.reverse .texte,
.bloc_grid .texte					{ padding: 0;}
.bloc_grid.reverse .texte			{ grid-area: 2;}
.bloc_grid.reverse .photo        	{ grid-area: 1;}
.bloc_grid .photo:before            { display: none;}

.bloc_grid .photo img ,
.bloc_grid.reverse .photo img       { height: 60vh;}

}
@media (max-width:700px) { 
.bloc_grid	                        { margin: 40px 0; grid-gap: 30px;}
.bloc_grid p               			{ margin-bottom: 10px;}
.bloc_grid .photo img               { border-radius: 20px; max-height: 280px;}
}



/***** bloc txt img *****/
.bloc_txt_img 											{ position: relative; margin: var(--marginTB); }
/*
.bloc_txt_img .item.img:before							{ position: absolute; right: calc(100% + 20px); top: 0; bottom: 0; background: var(--mainColor1); width: 100%; height: 100%; 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>.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>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 .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 .item.img:before					{ right: inherit; left: calc(100% + 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;}

.bloc_txt_img.small_av_ap .container 			        { grid-template-columns: 38% 1fr;}
.bloc_txt_img.reverse.small_av_ap .container 			{ grid-template-columns: 1fr 38%;}
.bloc_txt_img.reverse.small_av_ap .wrap      			{ max-width: inherit;}
.bloc_txt_img.small_av_ap .container .txt .wrap      	{ max-width: inherit;}
    

@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.small_av_ap .container 			        { grid-template-columns: 1fr;}
.bloc_txt_img.reverse.small_av_ap .container 			{ grid-template-columns: 1fr;}

}
@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;}
}


/* before after img */
.before_after_img                               		{ display: grid; position: relative; overflow: hidden; --position: 50%; border-radius: var(--imgRadius)}
.before_after_img img                         			{ width: 100%; height: 100%; object-fit: cover; object-position: left; border-radius:0;}
.before_after_img img.image_before                      { position: absolute; inset: 0; width: var(--position);}
.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; border-radius: 30px}
.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;}
}

.before_after_img img :first-of-type				{ border-radius: var(--imgRadius) 0 0 var(--imgRadius) ;}





/***** show hide *****/
.show_hide                        			{ position: relative; }
.show_hide.no_marge                        	{ margin: 0;}
.show_hide .item                  			{ margin-top: 10px;}
.show_hide .titre                 			{ font-size: 16px; line-height: 24px; font-weight: 500; position: relative; cursor: pointer; letter-spacing: 0.6px; color: var(--bgColorDark); padding: 20px 80px 22px 30px; margin: 0; border-radius: var(--linkRadius); background-color: #fff;}
.show_hide .hide                  			{ margin: 0; padding: 30px; display: none;}
.show_hide .hide p a						{ border-bottom: 1px solid var(--mainColor1); }
.show_hide .hide :last-child 	 			{ margin-bottom: 0;}

@media (min-width:1201px){
.show_hide .hide p a:hover     				{ border-color: var(--mainColor1);}
}
@media (max-width:1200px){
.show_hide .titre                 			{ padding: 20px 70px 20px 25px;}
.show_hide .hide                  			{ padding: 25px;}
}
@media (max-width:700px){

.show_hide .titre                 			{ padding: 15px 65px 15px 20px; font-size: 15px; line-height: 22px;}
.show_hide .hide                  			{ padding: 20px;}
}

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

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

/***** bloc rs *****/
.bloc_rs									{ font-size: 0; line-height: 0; letter-spacing: 0;}
.bloc_rs a									{ width: 50px; height: 50px; display: block; overflow: hidden; border-radius: 50%; 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") 48% 50% no-repeat;}

.bloc_rs .scroll:after 						{ background: url("../images/scrolltop.svg") 50% 48% no-repeat;}

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



/***** footer *****/
.footer										{ position: relative; color: #fff; background-color: var(--bgColorDark); padding-top: clamp(20px, 8vw, 120px); box-shadow: var(--box-shadow-1);}
.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 .logo 					{ width: 200px; height: auto; display: block;}
.footer .bloc_footer p						{ margin: 15px 0 0 0;}
.footer .bloc_footer p b					{ font-size: 25px; color: var(--mainColor1);}
.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_bleu.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 clamp(60px, 5vw, 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; content: "";}

.footer .bloc_rs							{ position: absolute; right: 0; top: 5px;}
.footer .bloc_rs a							{ display: inline-block; vertical-align: top; margin-right: 10px;}
.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: 20px; transition: bottom 300ms ease-in-out;}
.toponweb img								{ width: 70px; 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);}
}
@media (max-width:1200px) {
.footer .bloc_footer .logo 					{ width: 180px;}
.footer .bloc_rs							{ top: 0;}
}
@media (max-width:1000px) {
.footer										{ padding-top: var(--paddingT);}
.footer .bloc_footer.coordonnees			{ display: block; margin-bottom: clamp(20px, 7vw, 40px);}
.footer ul.bloc_footer     					{ margin: 0 clamp(60px, 5vw, 100px) 0 0;}
}
@media (max-width:700px) {
.footer .bloc_footer 						{ padding: 0; font-size: 14px; line-height: 24px;}
.footer .bloc_footer .logo 					{ width: 140px; padding-bottom: 5px;}
.footer ul.bloc_footer     					{ display: block; margin: 10vw 0;}
.footer ul.bloc_footer li   				{ margin-top: 10px;}
.footer .bloc_rs							{ top: -2px;}
.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;}
}



















