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

/* latin-ext */
@font-face {
  font-family: 'Poppins';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/poppins/v22/pxiByp8kv8JHgFVrLDz8Z1JlFc-K.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: 'Poppins';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/poppins/v22/pxiByp8kv8JHgFVrLDz8Z1xlFQ.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: 'Poppins';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/poppins/v22/pxiEyp8kv8JHgFVrJJnecmNE.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: 'Poppins';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/poppins/v22/pxiEyp8kv8JHgFVrJJfecg.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: 'Poppins';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/poppins/v22/pxiByp8kv8JHgFVrLGT9Z1JlFc-K.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: 'Poppins';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/poppins/v22/pxiByp8kv8JHgFVrLGT9Z1xlFQ.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: 'Poppins';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/poppins/v22/pxiByp8kv8JHgFVrLEj6Z1JlFc-K.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: 'Poppins';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/poppins/v22/pxiByp8kv8JHgFVrLEj6Z1xlFQ.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: 'Poppins';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/poppins/v22/pxiByp8kv8JHgFVrLCz7Z1JlFc-K.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: 'Poppins';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/poppins/v22/pxiByp8kv8JHgFVrLCz7Z1xlFQ.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: 'Quicksand';
  font-style: normal;
  font-weight: 300 700;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/quicksand/v36/6xKtdSZaM9iE8KbpRA_hJVQNcOM.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: 'Quicksand';
  font-style: normal;
  font-weight: 300 700;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/quicksand/v36/6xKtdSZaM9iE8KbpRA_hK1QN.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 {
	--blue: #21beff;
	--darkBlue: #103fb6;
	--darkerBlue: #0f2884;
	--lightBlue: #eefbfe;
	--yellow: #ffb900;
	--green: #3de0d3;
	--lightGreen: #e7fbfa;
	--gradientBlue: radial-gradient(#0932c2 0%, #0f2884 85%);
	--gradientLinearBlue: linear-gradient(135deg, #0932c2 0%, #0f2884 85%);
	--txtColor: #252525;

	--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));
	
	--wrapperXS: 1000px;
	--wrapperS: 1200px;
	--wrapperM: 1600px;
	--wrapperL: 2000px;

	--radiusXS: 10px;
	--radiusS: 15px;
	--radiusM: clamp(15px, 2.4vw, 30px);
	--radiusL: clamp(20px, 3.2vw, 50px);
	--radiusXL: clamp(40px, 6vw, 100px);
	
}
@media (max-width:1200px) {
	:root {
	--radiusS: 12px;
	--radiusXL: 5vw;
	}
}
@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 {
	--radiusXS: 8px;
	--radiusS: 10px;
	}
}


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

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


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


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


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

.color_blue 							{ color: var(--blue);}
.color_darkblue 						{ color: var(--darkBlue);}
.color_green 							{ color: var(--green);}

.bloc_shadow, 
.bloc_white, 
.bloc_lightblue, 
.bloc_blue,
.bloc_darkblue, 
.bloc_darkerblue, 
.bloc_green, 
.bloc_lightgreen, 
.bloc_gradient,
.bloc_gradient_linear					{ border-radius: var(--radiusL); padding: clamp(20px, 3.5vw, 60px); position: relative;}

.bloc_shadow :last-child, 
.bloc_white :last-child, 
.bloc_lightblue :last-child, 
.bloc_blue :last-child,
.bloc_darkblue :last-child, 
.bloc_darkerblue :last-child, 
.bloc_green :last-child, 
.bloc_lightgreen :last-child, 
.bloc_gradient :last-child,
.bloc_gradient_linear :last-child 		{ margin-bottom: 0;}

.bloc_shadow 							{ background: #fff; box-shadow: 0 5px 30px 0 rgba(33, 190, 255, 12.5%);}
.bloc_white 							{ background: #fff; border: 1px solid #d7f1fd; box-shadow: 0 0 10px 0 #d7f1fd50;}
.bloc_lightblue 						{ background: var(--lightBlue);}
.bloc_blue 								{ background: var(--blue);}
.bloc_darkblue 							{ background: var(--darkBlue);}
.bloc_darkerblue 						{ background: var(--darkerBlue);}
.bloc_green 							{ background: var(--green);}
.bloc_lightgreen 						{ background: var(--lightGreen);}
.bloc_gradient 							{ background: var(--gradientBlue);}
.bloc_gradient_linear					{ background: var(--gradientLinearBlue);}

.bloc_inner 							{ border-radius: var(--radiusM); padding: clamp(20px, 3vw, 40px); margin: clamp(20px, 3.5vw, 30px) 0;}
.bloc_inner :last-child					{ margin-bottom: 0;}

.clear									{ clear: both; display: block;}
.anchor									{ position: absolute; left: 0; top: -140px;}
.hide 									{ display: none;}
.align_center 							{ text-align: center;}
.read_more								{ display: inline-block; color: var(--green); cursor: pointer; transition: color 300ms ease-in-out;}

.titre_main	 							{ font: 700 clamp(28px, 4.2vw, 52px)/120% "Quicksand"; position: relative; margin-bottom: clamp(10px, 1.6vw, 15px);}
.titre_main	span						{ display: inline-block;}
.titre_main.bigger						{ font-size: clamp(45px, 4.6vw, 70px); line-height: 110%;}
.titre_main.smaller 					{ font-size: clamp(22px, 3.4vw, 38px); line-height: 130%;}
.titre_main.fitter 						{ font-weight: 600;}

.titre	 								{ font: 500 clamp(20px, 2.2vw, 35px)/140% "Poppins"; position: relative; margin-bottom: clamp(10px, 1.6vw, 15px);}
.sous_titre 							{ font: 500 clamp(18px, 2vw, 30px)/140% "Poppins"; position: relative; margin-bottom: clamp(10px, 1.6vw, 15px);}
.sous_titre.smaller						{ font-size: clamp(16px, 1.8vw, 22px); line-height: 150%;}

.chapo		 							{ font: 500 clamp(16px, 1.4vw, 18px)/170% "Poppins";margin-bottom: clamp(10px, 2vw, 15px);}
.chapo span	 							{ display: block; margin-bottom: clamp(10px, 2vw, 15px);}
.chapo.smaller 							{ font-size: clamp(18px, 1.3vw, 20px);}
.chapo.bigger 							{ font-size: clamp(24px, 1.8vw, 40px); line-height: 150%;}

.link 									{ font: 500 16px/54px "Poppins"; letter-spacing: 0.6px; height: 56px; display: inline-block; color: #fff; padding: 0 30px; border-radius: var(--radiusS); background: linear-gradient(-15deg, var(--darkBlue) 0% 20%, var(--blue) 100%); background-size: 200% 100%; background-position: 100% 0; overflow: hidden; position: relative; transition-duration: 300ms;}
.link span								{ position: relative; z-index: 5;}
.link_small								{ height: 44px; line-height: 42px; padding: 0 20px; font-size: 14px;}
.link_txt_arrow 						{ font: 500 16px/30px "Poppins"; display: inline-block; padding-right: 32px; position: relative; color: var(--darkBlue);}
.link_txt_arrow:before 					{ width: 20px; height: 100%; position: absolute; right: 0; top: 0; background: url("../images/arrow_link.svg") 100% 50% no-repeat; content: "";}

.ul_list								{ margin-bottom: clamp(10px, 2vw, 15px);}
.ul_list li								{ padding: 0 0 0 20px; position: relative; margin-top: clamp(5px, 1.5vw, 10px);}
.ul_list li:before						{ width: 8px; height: 8px; position: absolute; left: 0; top: 9px; background: var(--green); border-radius: 3px; content: "";}

.ol_list 								{ list-style: none; counter-reset: item; margin: clamp(15px, 2vw, 20px) 0;}
.ol_list li 							{ position: relative; padding-left: 40px; margin-bottom: 15px;}
.ol_list li:before 						{ width: 28px; height: 28px; font-weight: 500; font-size: 15px; line-height: 28px; letter-spacing: 0; text-align: center; position: absolute; left: 0; top: 0; background: var(--blue); color: #fff; border-radius: var(--radiusXS); content: counter(item); counter-increment: item;}
.ol_list li:last-child 					{ margin-bottom: 0;}

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

.arrow_result 							{ margin-right: 3px;}


@media (min-width:1201px) {
.link:hover 							{ background-position: 25% 0;}
.link_txt_arrow:hover 					{ filter: brightness(1.5); transform: translateX(10px);}
}
@media (max-width:1000px) {
.bloc_shadow, 
.bloc_white, 
.bloc_lightblue, 
.bloc_blue,
.bloc_darkblue, 
.bloc_darkerblue, 
.bloc_green, 
.bloc_lightgreen, 
.bloc_gradient,
.bloc_gradient_linear					{ padding: clamp(25px, 5vw, 40px) clamp(20px, 4vw, 30px);}


.titre_main	 							{ font-size: clamp(30px, 5vw, 60px);}
.titre_main.bigger						{ font-size: clamp(35px, 6vw, 60px); line-height: 120%;}
.titre_main.smaller 					{ font-size: clamp(22px, 4vw, 40px);}

.titre	 								{ font-size: clamp(20px, 3vw, 24px);}
.sous_titre 							{ font-size: clamp(18px, 2.8vw, 20px);}
.sous_titre.smaller						{ font-size: clamp(18px, 2.8vw, 20px);}

.chapo		 							{ font-size: clamp(14px, 3vw, 17px);}
.chapo.bigger 							{ font-size: clamp(18px, 2.8vw, 24px);}

.link 									{ height: 50px; line-height: 48px;}
.link_txt_arrow 						{ font-size: 15px;}
}
@media (max-width:700px) {
.link 									{ height: auto; line-height: 130%; padding: 12px 25px 14px 25px; font-size: 15px; letter-spacing: 0.2px;}

.ul_list li								{ padding: 0 0 0 18px;}
.ul_list li:before						{ width: 8px; height: 8px; position: absolute; left: 0; top: clamp(6px, 1.3vw, 9px);}

.ol_list li 							{ padding-left: 36px; margin-bottom: 12px;}
.ol_list li:before 						{ width: 26px; height: 26px; font-size: 14px; line-height: 26px; border-radius: 9px;}

.ul_check li 							{ padding-left: 25px; margin-bottom: 10px;}
.ul_check li:before						{ width: 16px; height: 16px;}
}




.square    									{ position: absolute; z-index: 50;}
.square div  								{ transform-origin: center center; animation: square_rotate 18s linear infinite;}
.square div i								{ display: block; aspect-ratio: 1/1; border-radius: 30%; transform-origin: center center; animation: square 5s ease-in-out infinite;}

.square.size_1 div i						{ width: clamp(90px, 8vw, 150px);}
.square.size_2 div i						{ width: clamp(80px, 7vw, 130px);}
.square.size_3 div i						{ width: clamp(70px, 6vw, 110px);}
.square.size_4 div i						{ width: clamp(60px, 5vw, 90px);}

.square.delay_1 div i						{ animation-delay: 400ms;}
.square.delay_2 div i						{ animation-delay: 1600ms;}
.square.delay_3 div i						{ animation-delay: 2400ms;}
.square.delay_4 div i						{ animation-delay: 3200ms;}

.square.blue div i							{ background: var(--blue);}
.square.darkblue div i						{ background: var(--darkBlue);}
.square.green div i							{ background: var(--green);}
.square.yellow div i						{ background: var(--yellow);}


@media (max-width:1200px) {
.square    									{ display: none;}
}
@media (max-width:700px) {
.square.size_1 div i						{ width: clamp(50px, 8vw, 90px);}
.square.size_2 div i						{ width: clamp(45px, 7vw, 70px);}
.square.size_3 div i						{ width: clamp(40px, 6vw, 70px);}
.square.size_4 div i						{ width: clamp(35px, 5vw, 60px);}
}


@keyframes square {
0%  										{ transform: scale(1);}
50%  										{ transform: scale(0.7);}
100%  										{ transform: scale(1);}
}

@keyframes square_rotate {
0%  										{ transform: rotate(0deg);}
100%  										{ transform: rotate(360deg);}
}




/***** header et menu *****/
.header 									{ width: 100%; position: fixed; left: 0; top: 0; z-index: 950;}
.header ::-webkit-scrollbar					{ display: none;}
.header .header_bg							{ position: absolute; left: 0; right: 0; top: 0; padding: 30px 0; background: linear-gradient(to top, transparent 0% 50%, rgba(10,28,110,100%) 50% 100%); background-size: 100% 200%; background-position: 0 100%; transition: all 300ms ease-in-out;}
.header .wrapper_full						{ display: grid; grid-template-columns: auto 1fr; grid-gap: 5vw; align-items: center;}
.header .logo								{ width: 180px;}
.header .logo img							{ width: 100%; height: auto; display: block;}
.header .header_nav 						{ display: grid; grid-template-columns: 1fr auto; align-items: center; position: relative;}
.header .menu 								{ position: relative; z-index: 5;}
.header .menu.has_sub						{ z-index: 10;}
.header .menu>li							{ display: inline-block; vertical-align: middle; margin-right: clamp(20px, 1.8vw, 40px); position: relative;}
.header .menu>li:last-child					{ margin-right: 0;}
.header .menu>li>span,
.header .menu>li>a:not(.link)				{ font: 400 clamp(16px, 1.3vw, 18px)/70px "Poppins"; height: 70px; letter-spacing: 1px; color: #fff; display: block; transition: all 300ms ease-in-out;}
.header .menu>li>span 						{ position: relative;}
.header .menu>li.active>a, 
.header .menu>li.active>span				{ color: var(--blue);}
.header .menu>li:has(.sub)					{ z-index: 5;}
.header .menu>li:has(.sub)>a				{ z-index: 800;}

.header .menu.cta li a.tel					{ font-size: 16px; line-height: 50px; height: 50px; font-weight: 500; letter-spacing: 0.8px; padding-left: 40px;}
.header .menu.cta li a.tel lord-icon		{ width: 30px; height: 30px; position: absolute; left: 0; top: 50%; transform: translateY(-50%);}
.header .menu.cta li a.rdv					{ font-size: 16px; line-height: 50px; height: 50px; font-weight: 500; letter-spacing: 0.8px; padding-left: 38px;}
.header .menu.cta li a.rdv:before 			{ width: 22px; height: 100%; position: absolute; left: 0; top: 0; background: url("../images/calendar.svg") 50% 48% / contain no-repeat; content: "";}
.header .menu.cta li a.link					{ display: block; height: 50px; line-height: 48px; background-image: linear-gradient(-15deg, var(--darkBlue) 0%, var(--blue) 60% 100%);}

.header .sub								{ width: 1200px; position: absolute; top: 115%; left: -25px; background: #fff; border-radius: var(--radiusM);}
.header .sub .container						{ display: grid; grid-template-columns: 1.2fr 1fr 1fr; padding: 0 clamp(30px, 3.2vw, 50px) 0 0; grid-gap: clamp(20px, 1.8vw, 40px);}
.header .sub .item							{ padding: clamp(30px, 3vw, 45px) 0;}
.header .sub .heading						{ padding: 10px 20px 10px 10px; text-align: center; display: grid; grid-template-rows: 1fr 1fr; grid-gap: 10px;}
.header .sub .baseline						{ padding: 30px; background: var(--green); border-radius: calc(var(--radiusM) - 8px); display: grid; align-items: center;}
.header .sub .sous_titre					{ font-size: 21px; line-height: 145%; margin-bottom: 5px; opacity: 0.85;}
.header .sub .simulateur					{ padding: 30px; background: var(--blue); border-radius: calc(var(--radiusM) - 8px); display: grid; align-items: center; }
.header .sub .simulateur p					{ font-size: 18px; line-height: 145%; margin: 15px 0;}
.header .sub .simulateur .link.sim 			{ padding-left: 52px;}
.header .sub .simulateur .link.sim:before	{ width: 18px; height: 100%; position: absolute; left: 20px; top: 0; background: url("../images/calculator.svg") 50% / contain no-repeat; content: "";}
.header .sub ul      						{ margin: 0;}
.header .sub ul:nth-child(2)     			{ margin-top: 25px;}
.header .sub ul li a 						{ padding: 10px 15px 10px 15px; background: linear-gradient(to left, #fff 0% 50%, var(--lightBlue) 50% 100%); background-size: 200% 100%; background-position: 100% 0; line-height: 22px; font-weight: 400; letter-spacing: 0.4px; display: block; color: var(--txtColor); border-radius: var(--radiusS);}
.header .sub ul li a.head					{ font-size: 18px; line-height: 28px; font-weight: 500; color: var(--darkBlue);}
.header .sub ul li.active a 				{ color: var(--darkBlue);}

.reset_anim .header .header_bg				{ transition: none;}

.sticky .header .header_bg 					{ background-position: 0 0; padding: 0;}
.sticky.scrolling_down .header .header_bg 	{ top: -80px;}

@media (min-width:1201px) {
.mobile_only,
.menu_open,
.menu_close 								{ display: none;}
.header .menu>li>span 						{ cursor: default; z-index: 999;}
.header .sub 								{ max-width: 90vw; visibility: hidden; opacity: 0; box-shadow: 0 50vh 0 200vh rgba(5,20,50,65%); transition: all 200ms ease-in-out;}
.header .sub:before							{ width: 100%; height: 18px; position: absolute; left: 0; top: -20px; content: "";}

.header .menu>li:hover .sub					{ visibility: visible; opacity: 1; top: 100%;}		
.header .sub ul li a:hover					{ background-position: 0 0; color: var(--darkBlue); padding-left: 25px;}
.header .menu>li:hover 						{ z-index: 999;}		
.header .menu>li:hover>span					{ color: #fff;}
.header .menu>li:hover>a:not(.link)			{ color: var(--blue);}

.header .menu.cta li a.link:hover			{ background-position: 65% 0;}

.sticky .header .header_bg 					{ padding: 2px 0;}
.sticky .header .menu>li:hover .sub			{ top: 90%;}		
}
@media (max-width:1600px) {
.header .sub								{ left: calc(-180px - 5vw);}
.header .sub .sous_titre					{ font-size: 20px;}
}
@media (max-width:1200px) {
.menu_open									{ width: 50px; height: 50px; display: inline-block; cursor: pointer; position: relative; z-index: 900; border-radius: 18px; border: 2px solid #21beff50; box-shadow: 0 0 8px 0 #21beff35; transition: all 0ms ease-in-out 400ms;}
.menu_open.active							{ opacity: 0; visibility: hidden; transition-delay: 0ms;}
.menu_open div								{ width: 18px; height: 2px; background: #fff; position: absolute; left: 50%; top: 50%; transform: translate(-50%); margin-top: -1px;}
.menu_open div:before						{ width: 100%; height: 2px; background: #fff; position: absolute; left: 0; top: 6px; content: "";}
.menu_open div:after						{ width: 100%; height: 2px; background: #fff; position: absolute; left: 0; top: -6px; content: "";}

.menu_close									{ width: 50px; height: 50px; display: block; cursor: pointer; position: absolute; top: 15px; right: calc(-5vw + 25px); z-index: 950; opacity: 0; visibility: hidden; transition: all 200ms ease-in-out 0ms;}
.menu_close.active							{ opacity: 1; visibility: visible; transition-delay: 200ms;}
.menu_close:after							{ width: 100vw; position: fixed; top: 0; bottom: 0; right: 515px; content: "";}
.menu_close div								{ position: absolute; right: 0; left: 0; top: 0; bottom: 0;}
.menu_close div:before 						{ width: 24px; height: 2px; background: var(--txtColor); position: absolute; top: 50%; left: 50%; transform: translate(-50%) rotate(45deg); content: "";}
.menu_close div:after						{ width: 24px; height: 2px; background: var(--txtColor); position: absolute; top: 50%; left: 50%; transform: translate(-50%) rotate(-45deg); content: "";}
.sticky .menu_close  						{ top: 25px;}

.header:before								{ position: fixed; left: 0; right: 0; top: 0; bottom: 0; background: rgba(5,20,50,70%); mix-blend-mode: multiply; opacity: 0; visibility: hidden; transition: all 200ms ease-in-out 350ms; z-index: 20; content: "";}
.header .header_bg 							{ padding: 10px 0;}
.header .wrapper_full						{ grid-template-columns: auto auto; grid-gap: 0; justify-content: space-between; height: 80px;}
.header .logo  								{ width: 160px;}
  
.header .header_nav 						{ display: block; width: 500px; position: fixed; top: 15px; bottom: 87px; right: 15px; border-radius: 22px 22px 22px 0; padding: 60px; background: #fff; z-index: 200; transform: scale(0.95, 0.9); opacity: 0; visibility: hidden; transition: all 200ms ease-in-out 200ms;}
.header .header_nav:before					{ height: 72px; position: absolute; top: 100%; left: 0; right: 72px; background: #fff; border-radius: 0 0 22px 22px; content: "";}
.header .header_nav:after 					{ position: absolute; top: 100%; right: 30px; background: transparent; width: 42px; height: 42px; border-top-left-radius: 42px; box-shadow: -10px -10px 0 5px #fff; transition: none; content: "";}

.header .menu  								{ display: block; width: auto; opacity: 0; visibility: hidden; margin-top: 10px; transition: all 400ms ease-in-out 150ms;}
.header .menu>li 							{ width: 100%; display: block; margin: 0; position: static;}
.header .menu>li>span,
.header .menu>li>a:not(.link) 				{ font-size: clamp(18px, 5vw, 30px); font-weight: 600; line-height: clamp(55px, 10vw, 60px); letter-spacing: 0.2px; transition: none; display: block; color: var(--txtColor); height: auto; padding: 0; letter-spacing: 0.2px;}.header .menu>li.active>a, 
.header .menu>li.active>span				{ color: var(--darkBlue);}

.header .menu>li i 							{ width: 100%; height: clamp(55px, 10vw, 60px); float: right; margin-top: clamp(-60px, -10vw, -55px); z-index: 999; position: relative; background: url("../images/arrow_darkblue.svg") 100% 52% no-repeat;}
.header .menu>li i.active					{ position: fixed; top: -2px; left: -2px; margin: 0; width: 80px; height: 80px; background-image: url("../images/arrow_sub_back.svg"); background-position: 50% 48%; filter: brightness(0); opacity: 0.8;}
.header .menu>li i.active:before			{ content: "retour"; position: absolute; left: 80%; top: 50%; transform: translateY(-50%); font-size: 14px; line-height: 20px; font-style: normal; font-weight: 500; color: var(--darkBlue); min-width: 160px; padding-bottom: 2px;}

.header .menu>li i 							{ animation: menuLink 600ms ease-in-out;}
.header .menu>li i.active					{ animation: menuBack 600ms ease-in-out;}

@keyframes menuLink {
0%  										{ opacity: 0; visibility: hidden;}
100%  										{ opacity: 1; visibility: visible;}
}
@keyframes menuBack {
0%  										{ opacity: 0; visibility: hidden;}
100%  										{ opacity: 1; visibility: visible;}
}

.header .sub 								{ position: fixed; left: 0; top: 0; bottom: 0; width: 100%; background: #fff; z-index: 50; padding: 0 60px; border-radius: 22px; opacity: 0; visibility: hidden; transition: all 200ms ease-in-out 400ms;}
.header .sub:before							{ height: 72px; position: absolute; top: 100%; left: 0; right: 72px; background: #fff; border-radius: 0 0 22px 22px; content: "";}
.header .sub:after 							{ position: absolute; top: 100%; right: 30px; background: transparent; width: 42px; height: 42px; border-top-left-radius: 42px; box-shadow: -10px -10px 0 5px #fff; content: "";}

.header .sub .container 					{ overflow-y: scroll; max-height: calc(100% - 20px); grid-template-columns: 1fr; grid-gap: 15px; padding: 0; border-top: 75px solid transparent; opacity: 0; margin-top: 10px; position: relative; transition: all 400ms ease-in-out 0ms;}
.header .sub .item 							{ padding: 0;}
.header .sub .heading 						{ padding: 0; display: block; grid-area: 3; display: none;}
.header .sub .heading .baseline				{ display: none;}
.header .sub .simulateur 					{ border-radius: var(--radiusS); padding: 20px;}
.header .sub .simulateur p 					{ font-size: 16px; margin: 10px 0;}
.header .sub ul:nth-child(2) 				{ margin-top: 15px;}
.header .sub ul li a 						{ background: none; padding: 5px 0;}
.header .sub ul li a.head 					{ font-size: clamp(18px, 4vw, 20px); font-weight: 600; letter-spacing: 0;}


/** active menu + active sub  **/
.header.active:before						{ opacity: 1; visibility: visible; transition-delay: 0ms;}
.header.active .header_nav 					{ transition-delay: 150ms; opacity: 1; visibility: visible; transform: scale(1);}
.header.active .menu 						{ opacity: 1; visibility: visible; margin-top: 0; transition-delay: 400ms;}
.header.active .menu.mobile_only			{ transition-delay: 500ms;}
.header.active .menu.cta 					{ transition-delay: 600ms; }

/** active sub  **/
.header .sub.active							{ opacity: 1; visibility: visible; transition-delay: 0ms;}
.header .sub.active .container 				{ opacity: 1; margin-top: 0; transition-delay: 200ms;}

.header .contact_infos  					{ padding: 25px 0; font-size: 14px; font-weight: 500;}
.header .contact_infos p  					{ margin-bottom: 10px;}

.header .menu.cta  							{ padding-top: 0; /*display: grid; grid-template-columns: 1fr 1fr; grid-gap: 10px;*/}
.header .menu.cta li a.tel					{ display: none;}
.header .menu.cta li a.rdv					{ width: 100%; height: 50px; line-height: 48px; letter-spacing: 0.6px; padding: 0; text-align: center; color: #fff; border-radius: var(--radiusS); background: var(--darkBlue);}
.header .menu.cta li a.rdv:before 			{ display: none;}
.header .menu.cta li a.link					{ padding: 0; text-align: center; width: 100%; height: 50px; line-height: 48px; background: var(--blue);}
.header .menu.cta li a.link span			{ display: none;}
}
@media (max-width:700px) {
.menu_open									{ width: 44px; height: 44px; border-radius: 16px;}
.menu_open div								{ width: 16px;}

.menu_close									{ width: 44px; height: 44px; top: 25px;}
.menu_close:after 							{ display: none;}
.menu_close div:before 						{ width: 20px;}
.menu_close div:after						{ width: 20px;}

.header .wrapper_full						{ height: 70px;}
.header .header_bg   						{ padding: 0;}
.header .logo  								{ width: 140px; margin-top: 1px;}

.header .header_nav 						{ width: calc(100% - 40px); top: 20px; bottom: 76px; right: 20px; padding: 55px 8vw 8vw 8vw;}
.header .header_nav:before					{ height: 56px; right: 56px;}
.header .header_nav:after 					{ right: 18px; width: 38px; height: 38px; border-top-left-radius: 36px;}

.header .menu>li>span,
.header .menu>li>a:not(.link) 				{ border-bottom: 1px solid #ddd; border-color: #d7f1fd;}
.header .menu>li i 							{ background-position: 100% 50%;}
.header .menu>li i.active 					{ width: 70px; height: 70px; top: -5px; left: -5px;}
.header .menu>li i.active:before 			{ font-size: 13px;}

.header .sub 								{ padding: 0 8vw;}
.header .sub:before							{ height: 56px; right: 56px;}
.header .sub:after 							{ right: 18px; width: 38px; height: 38px; border-top-left-radius: 36px;}
.header .sub .container 					{ border-width: 60px;}
.header .sub ul li a 						{ padding: 4px 0;}

.header .contact_infos  					{ font-size: 13px; padding: 32px 0 20px 0;}

.header .menu.cta  							{ grid-gap: 5px;}
.header .menu.cta li a.rdv					{ font-size: 14px; letter-spacing: 0.4px; height: 46px; line-height: 44px;}
.header .menu.cta li a.link					{ height: 46px; line-height: 44px; letter-spacing: 0.2px;}
}
@media (max-width:450px) { 
.header .menu.cta  							{ grid-template-columns: 1fr;}
}




/***** page *****/
main 										{ position: relative;}
main li a, 
main p a									{ color: var(--darkBlue); font-weight: 500;}
main li a:after,
main p a:after								{ width: 13px; height: 13px; background: url("../images/arrow_sup.svg") 100% 0 no-repeat; display: inline-block; margin: 0 1px -2px 0; content: "";}

@media (min-width:1201px) {
main li a:hover, 
main p a:hover								{ filter: brightness(1.5);}
}



/***** txt dynamic *****/
.contact_infos .icon 					{ padding-left: 35px; position: relative;}
.contact_infos .icon:after 				{ width: 20px; height: 100%; position: absolute; left: 0; top: 0; content: "";}
.contact_infos .tel a:after 			{ background: url(../images/tel_blue.svg) 0 50% no-repeat;}
.contact_infos .email a:after 			{ background: url("../images/email_blue.svg") 0 50% no-repeat;}
.contact_infos .facebook a:after 		{ background: url("../images/facebook_blue.svg") 3px 50% no-repeat; background-size: 11px auto;}
.contact_infos .linkedin a:after 		{ background: url("../images/linkedin_blue.svg") 0 50% no-repeat; background-size: 18px auto;}





/***** 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: 35px; height: 60px; border-radius: 0; border: 0; padding: 0; font-size: 0; cursor: pointer; background: url("../images/arrow_slider.svg") 60% 50% no-repeat; /*background-size: auto 20px;*/}
.slick-disabled 									{ opacity: 0.35; cursor: default;}
.slick-prev											{ transform: rotate(180deg);}

/** slick dots **/
.slick-dots  										{ width: 100%; text-align: center; line-height: 0;;}
.slick-dots li 										{ display: inline-block; vertical-align: middle; margin: 0 8px;}
.slick-dots button									{ border: none; font-size: 0; border-radius: 50%; padding: 0; width: 10px; height: 10px; background: var(--blue); opacity: 0.35; cursor: pointer;}
.slick-active button								{ opacity: 1; transform: scale(1.2);}

@media (max-width:700px) { 
.slick-arrow										{ width: 30px; height: 50px;}
.slick-prev,
.slick-next											{ background-size: auto 20px;}

.slick-dots li 										{ margin: 0 5px;}
.slick-dots button									{ width: 8px; height: 8px;}
}



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

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

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

/* custom colums */
.grid_bloc.col_2 .container								{ grid-template-columns: repeat(2, 1fr);}
.grid_bloc.col_3 .container								{ grid-template-columns: repeat(3, 1fr);}
.grid_bloc.col_4 .container								{ grid-template-columns: repeat(4, 1fr);}
.grid_bloc.col_5 .container								{ grid-template-columns: repeat(5, 1fr);}
.grid_bloc.col_6 .container								{ grid-template-columns: repeat(6, 1fr);}
.grid_bloc.col_7 .container								{ grid-template-columns: repeat(7, 1fr);}
.grid_bloc.col_8 .container								{ grid-template-columns: repeat(8, 1fr);}

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

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







/***** tag *****/
.tags 											{ font-size: 0; letter-spacing: 0; margin: 0;}
.tags li										{ display: inline-block; height: 29px; text-align: center; font-size: 13px; line-height: 29px; letter-spacing: 0.4px; background: #06124950; backdrop-filter: blur(15px); padding: 0 12px; border-radius: var(--radiusXS); margin-right: 5px;}
.tags li.theme									{ background: var(--blue); color: #fff;}

@media (max-width:1200px) {
.tags li										{ height: 26px; font-size: 12px; line-height: 26px; padding: 0 10px; border-radius: 8px;}
}
@media (max-width:700px) {
.tags li										{ height: 23px; font-size: 11px; line-height: 23px; padding: 0 8px;}
}



/***** card team *****/
.card_team 										{ aspect-ratio: 1/1.1; box-shadow: 0 0 30px 0 rgba(33, 190, 255, 12.5%); background: #fff; border-radius: var(--radiusM); text-align: center; display: grid; align-items: center;}
.card_team .wrap								{ width: 100%;}
.card_team img									{ max-width: 45%; height: auto; display: block; margin: 0 auto; padding-bottom: 8px;}
.card_team .name								{ display: block; font-weight: 500; line-height: 24px; color: var(--blue);}
.card_team .fonction							{ font-size: 14px; line-height: 18px; display: block;}

@media (max-width:1200px) {
.card_team 										{ aspect-ratio: 1/1.2;}
.card_team .fonction							{ font-size: 13px;}
}
@media (max-width:700px) {
.card_team 										{ aspect-ratio: 1/1.3;}
.card_team img									{ max-width: 50%; padding-bottom: 10px;}
.card_team .name								{ line-height: 20px;}
.card_team .fonction							{ font-size: 12px; line-height: 16px;}
}
@media (max-width:450px) {
.card_team .name								{ line-height: 18px;}
.card_team .fonction							{ font-size: 10px;}
}



/***** card blog *****/
.card_blog 										{ position: relative;}
.card_blog a 									{ display: block; overflow: hidden; border-radius: var(--radiusM) var(--radiusM) 0 0;}
.card_blog .photo 								{ position: relative; overflow: hidden;}
.card_blog .photo img 							{ width: 100%; height: auto; display: block; object-fit: cover; aspect-ratio: 3/2; border-radius: 0; /*filter: brightness(0.9);*/}
.card_blog .tags 								{ position: absolute; left: 18px; top: 18px; color: #fff;}
.card_blog .tags .date							{ display: none;}
.card_blog .titre_card 							{ padding: 18px 30px 20px 30px; font-size: clamp(16px, 1.3vw, 18px); font-weight: 500; line-height: 140%; display: grid; align-items: center; min-height: 120px; color: var(--darkBlue); border: 1px solid #d7f1fd; border-top: 0; box-shadow: 0 0 10px 0 #d7f1fd50; border-radius: 0 0 var(--radiusM) var(--radiusM); background: #fff;}

@media (min-width:1201px) {
.card_blog a:hover  							{ transform: translateY(-10px);}
}
@media (max-width:1200px) {
.card_blog .tags 								{ left: 15px; top: 15px;}
.card_blog .titre_card 							{ padding: 10px 30px 15px 30px; min-height: 110px;}
}
@media (max-width:1000px) {
.card_blog .titre_card 							{ font-size: clamp(14px, 2.5vw, 16px);}
}
@media (max-width:700px) {
.card_blog .tags 								{ left: 12px; top: 12px;}
.card_blog .titre_card 							{ padding: 0 25px 5px 25px; min-height: 80px;}
}



/***** card ref *****/
.card_ref										{ border-radius: var(--radiusL); overflow: hidden; position: relative;}
.card_ref a										{ display: block; cursor: pointer;}
.card_ref img 									{ display: block; width: 100%; height: auto; object-fit: cover; /*aspect-ratio: 3/4;*/}
.card_ref .tags 								{ position: absolute; left: 30px; top: 30px; color: #fff; z-index: 5;}
.card_ref .tags .secteur						{ display: none;}
.card_ref .titre 								{ position: absolute; left: 35px; bottom: 30px; color: #fff; z-index: 5; margin: 0; font-size: clamp(20px, 2vw, 26px); font-weight: 500;}

@media (min-width:1201px) {
.card_ref img									{ transition: all 300ms ease-in-out;}
.card_ref:hover img 							{ transform: scale(1.05); filter: brightness(0.75);}
}
@media (max-width:1600px) {
.card_ref										{ border-radius: var(--radiusM);}
.card_ref .tags 								{ left: 20px; top: 20px;}
.card_ref .titre 								{ left: 30px; bottom: 22px;}
}
@media (max-width:1200px) {
.card_ref .tags 								{ left: 15px; top: 15px;}
.card_ref .titre 								{ font-size: clamp(18px, 4vw, 20px);}
}
@media (max-width:700px) {
.card_ref .tags 								{ left: 12px; top: 12px;}
.card_ref .titre 								{ left: 6vw; bottom: calc(6vw - 5px);}
}




/***** references *****/
.references										{ position: relative; overflow: hidden; padding: clamp(20px, 2vw, 40px) 0;}
.references .slider 							{ display: flex; gap: 10px; will-change: transform; animation: srolling_x 50s linear infinite;}
.references .slider .card_ref					{ width: clamp(400px, 25vw, 500px); flex-shrink: 0;}

@keyframes srolling_x {
0%												{ transform: translateX(0);}
100% 											{ transform: translateX(-100%);}
}
@media (min-width:1201px) {
.references .slider:hover						{ animation-play-state: paused;}
}
@media (max-width:2000px) {
.references .slider								{ animation-duration: 40s;}
}
@media (max-width:1600px) {
.references .slider								{ animation-duration: 30s;}
}
@media (max-width:1400px) {
.references .slider								{ animation-duration: 25s;}
}
@media (max-width:1200px) {
.references .slider								{ animation: none; overflow-x: auto; scroll-snap-type: x mandatory; padding-left: 5vw;}
.references .slider::-webkit-scrollbar			{ display: none;}
.references .slider .card_ref.clone				{ display: none;}
.references .slider .card_ref					{ width: clamp(200px, 90vw, 350px); scroll-snap-align: start; scroll-margin-left: 5vw;}
.references .slider .card_ref:last-child		{ margin-right: 5vw;}
}
@media (max-width:1000px) {
.references										{ padding: 0;}
.references .slider .card_ref					{ width: clamp(200px, 85vw, 380px);}
}
@media (max-width:700px) {
.references										{ margin-left: 5vw; overflow: hidden; border-radius: var(--radiusM) 0 0 var(--radiusM);}
.references .slider								{ padding-left: 0;}
.references .slider .card_ref					{ scroll-margin-left: 0;}
.references .slider .card_ref:last-child		{ margin-right: 10vw;}
}






/***** bloc reviews *****/
.bloc_reviews 									{ position: relative; overflow: hidden; padding: 30px 0; margin: -30px 0;}
.bloc_reviews .list   							{ position: relative; padding-top: 2vw;}

.card_review 									{ background: #fff; position: relative; padding: clamp(30px, 4vw, 60px) clamp(20px, 3vw, 45px); border-radius: var(--radiusL); text-align: center; width: clamp(280px, 25vw, 380px); min-height: 450px; box-shadow: 0 5px 30px 0 rgba(33, 190, 255, 12.5%);}
.card_review p									{ font-size: clamp(14px, 1.1vw, 15px); line-height: 175%; letter-spacing: 0.4px; margin: 0; color: var(--darkBlue);}
.card_review p.author							{ font-size: clamp(16px, 1.6vw, 20px); line-height: 120%; font-weight: 500; margin: 20px 0 14px 0;}
.card_review p.author span						{ font-size: 14px; line-height: 20px; font-weight: 400; display: block; color: var(--blue); padding-top: 5px;}
.card_review .note   							{ width: 140px; display: grid; grid-template-columns: repeat(5, 1fr); grid-gap: 6px; margin: 10px auto;}
.card_review .note img 							{ width: 100%; height: auto; display: block;}
.card_review .note img.nope						{ opacity: 0.3;}

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

/* if slider */
.slider_reviews .slick-list 					{ overflow: visible; cursor: grab;}
.slider_reviews .slick-list:active 				{ cursor: grabbing;}
.slider_reviews .slick-slide 					{ margin: 0 5px;}
.slider_reviews_nav 							{ position: absolute; left: 50%; bottom: 35px; height: 0; width: 360px; text-align: right; transform: translateX(-50%);}
.slider_reviews_nav .slick-arrow				{ background-image: url("../images/arrow_slider_small.svg")}
.slider_reviews_nav .slick-prev					{ float: left;}
.slider_reviews .slick-dots  					{ margin: clamp(20px, 4vw, 50px) 0 0 0;}

@media (max-width: 1600px){
.card_review 									{ border-radius: var(--radiusM);}
}
@media (max-width: 1200px){
.card_review 									{ min-height: inherit;}
.card_review p.author  							{ margin-bottom: 10px;}
.card_review p.author span						{ font-size: 13px; padding-top: 5px;}
.slider_reviews_nav 							{ display: none;}
}
@media (max-width: 1000px){
.card_review 									{ width: clamp(220px, 70vw, 300px);}
}
@media (max-width: 700px){
.bloc_reviews ::-webkit-scrollbar 				{ display: none;}
.card_review p									{ font-size: clamp(13px, 2.8vw, 15px);}
.card_review p.author							{ font-size: clamp(15px, 3.2vw, 18px);}
.card_review p.author span						{ font-size: 13px;}
.card_review .note   							{ width: 110px; grid-gap: 5px;}
}






/***** show hide *****/
.show_hide                        			{ position: relative; display: grid; grid-gap: 10px; margin: clamp(15px, 2.2vw, 25px) 0;}
.show_hide .item                  			{ border: 1px solid #d7f1fd; box-shadow: 0 0 8px 0 #d7f1fd85; border-radius: var(--radiusS); background: #fff;}
.show_hide .titre                 			{ font: 500 clamp(16px, 1.4vw, 20px)/160% "Poppins"; position: relative; cursor: pointer; padding: clamp(16px, 2.4vw, 28px) 70px clamp(14px, 2.5vw, 30px) 30px; margin: 0; transition: color 200ms ease-in;}
.show_hide .titre:after          			{ width: 30px; height: 30px; position: absolute; right: 20px; top: 50%; transform: translateY(-50%); background: url("../images/arrow_down.svg") 50% 55% no-repeat var(--darkBlue); border-radius: var(--radiusXS); transition: none; content: "";}
.show_hide .titre.active    				{ color: var(--darkBlue);}
.show_hide .titre.active:after   			{ transform: translateY(-50%) rotate(180deg);}

.show_hide .titre:has(.num)					{ display: grid; grid-template-columns: auto 1fr; grid-gap: 12px; align-items: center;}
.show_hide .titre .num						{ width: 32px; height: 32px; font-weight: 500; font-size: 15px; line-height: 32px; text-align: center; display: inline-block; background: #d7f1fd; color: var(--darkBlue); border-radius: 12px; margin: 0 0 0 -4px; letter-spacing: 0; padding: 0;}

.show_hide .hide                  			{ margin: 0; padding: 0 40px 40px 40px; display: none;}
.show_hide .hide :last-child 	 			{ margin-bottom: 0;}

.show_hide.v2 .titre                 		{ padding: 18px 65px 20px 25px; color: var(--darkBlue);}
.show_hide.v2 .titre:after          		{ width: 18px; height: 2px; position: absolute; right: 20px; top: 50%; transform: translateY(-50%); background: var(--darkBlue); transition: none; content: "";}
.show_hide.v2 .titre:before          		{ width: 2px; height: 18px; position: absolute; right: 28px; top: 50%; transform: translateY(-50%); background: var(--darkBlue); transition: none; content: "";}
.show_hide.v2 .titre.active:before   		{ width: 0;}
.show_hide.v2 .hide                  		{ padding-top: 15px;}

.show_hide.v3                      			{ grid-gap: 0; margin-top: -5px;}
.show_hide.v3 .item                  		{ border: none; border-bottom: 1px solid var(--blue); box-shadow: none; border-radius: 0; background: none;}
.show_hide.v3 .titre          				{ padding-left: 0; padding-right: 45px; color: var(--darkBlue);}
.show_hide.v3 .titre:after          		{ right: 0;}
.show_hide.v3 .hide                  		{ padding: 0 0 clamp(15px, 2.5vw, 30px) 0;}

@media (min-width:1201px){
.show_hide.v2 .titre                 		{ font-size: clamp(16px, 1.6vw, 18px); line-height: 140%;}
}
@media (max-width:1200px){
.show_hide .titre                 			{ font-size: clamp(13px, 3vw, 16px); padding-left: 20px;}
.show_hide .titre .num						{ margin: -2px 0 -2px -2px;}
.show_hide .hide                  			{ padding: 0 30px 30px 30px;}

.show_hide.v2 .titre                 		{ padding-bottom: 18px; padding-left: 20px;}
.show_hide.v2 .hide                  		{ padding-top: 10px;}
}
@media (max-width:700px){
.show_hide .titre                 			{ padding-right: 65px;}
.show_hide .titre:after          			{ width: 26px; height: 26px; right: 15px; background-size: 12px auto; background-position: 50% 52%;}
.show_hide .titre:has(.num) 				{ font-size: clamp(14px, 3vw, 16px);}
.show_hide .titre .num						{ width: 28px; height: 28px; font-size: 14px; line-height: 28px; border-radius: 10px;}
.show_hide .hide                  			{ padding: 0 25px 25px 25px;}

.show_hide.v2 .titre                 		{ padding-left: 15px; padding-right: 55px;}
.show_hide.v2 .titre:after          		{ width: 16px; right: 18px;}
.show_hide.v2 .titre:before          		{ height: 16px; right: 25px;}
.show_hide.v2 .hide                  		{ padding-top: 0;}

.show_hide.v3 .titre          				{ font-size: clamp(14px, 3vw, 16px);}
}





/***** cta fixed *****/
.cta_fixed 									{ position: fixed; right: 2vw; bottom: 2vw; z-index: 950; font-size: 15px; line-height: 20px; font-weight: 500;}
.cta_fixed .pop .wrap						{ width: 340px; border-radius: var(--radiusM); position: relative; overflow: hidden; box-shadow: 0 10px 30px 0 rgba(33, 190, 255, 15%); background: #fff; position: absolute; right: 0; bottom: 0;}
.cta_fixed .pop .head						{ display: grid; grid-template-columns: 60px 1fr; align-items: center; grid-gap: 8px; background: var(--lightBlue); margin: 8px 8px 0 8px; padding: 5px 10px; border-radius: calc(var(--radiusM) - 8px);}
.cta_fixed .pop .head b						{ font-weight: 500; font-size: 15px; letter-spacing: 0.4px; padding-top: 2px;}
.cta_fixed .pop .head b i					{ font-weight: 400; font-style: normal; font-size: 12px; display: block;}
.cta_fixed .pop .head img					{ padding: 5px; width: 100%; height: auto; display: block; mix-blend-mode: multiply;}
.cta_fixed .pop .content					{ padding: 16px 20px 20px 20px; background: #fff; font-size: 18px; line-height: 160%; text-align: center;}
.cta_fixed .pop .content p					{ margin-bottom: 16px;}
.cta_fixed .pop .grid_links					{ display: grid; grid-template-columns: 1fr; grid-gap: 8px; margin-top: 16px;}
.cta_fixed .pop .link						{ border-radius: 12px; line-height: 46px; height: 48px; text-align: center; padding: 0; display: block;}
.cta_fixed .pop .close						{ width: 77px; height: 77px; position: absolute; right: 0; top: 8px; background: none; border: none; padding: 0; cursor: pointer;}
.cta_fixed .pop .close:after	    		{ width: 34%; height: 2px; background: var(--txtColor); border-radius: 25em; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%) rotate(45deg); transition: none; content: "";}
.cta_fixed .pop .close:before	    		{ width: 2px; height: 34%; background: var(--txtColor); border-radius: 25em; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%) rotate(45deg); transition: none; content: "";}

.cta_fixed .pop .open						{ transition: all 200ms ease-in-out 0ms; width: 64px; height: 64px; border-radius: 50%; position: absolute; right: 0; bottom: 0; background: url("../images/email.svg") 50% no-repeat var(--green); background-size: 24px auto; transform: scale(0.5); opacity: 0; visibility: hidden; cursor: pointer;}
/*.cta_fixed .pop .open lord-icon				{ width: 30px; height: 30px; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);}*/
.cta_fixed .pop	.wrap						{ transition: all 200ms ease-in-out 200ms; transform-origin: right bottom;}

.cta_fixed .pop.off .wrap					{ transform: scale(0.75); opacity: 0; visibility: hidden; transition-delay: 0ms;}
.cta_fixed .pop.off .open					{ transform: scale(1); opacity: 1; visibility: visible; transition-delay: 200ms;}

.cta_fixed .pop.off_button .wrap			{ transform: scale(0.75); opacity: 0; visibility: hidden; transition-delay: 0ms;}
.cta_fixed .pop.off_button .open			{ transform: scale(1); opacity: 1; visibility: visible; transition-delay: 200ms;}

@media (max-width: 1600px){
.cta_fixed 									{ right: 20px; bottom: 20px;}
.cta_fixed .pop .open						{ width: 60px; height: 60px; background-size: 22px auto;}
}
@media (max-width: 1200px){
.cta_fixed 									{ right: 15px; bottom: 15px;}
}
@media (max-width: 700px){
.cta_fixed 									{ right: 12px; bottom: 12px;}
.cta_fixed .pop .open						{ width: 50px; height: 50px; background-size: 20px auto;}
}





/***** social *****/
.rs a										{ width: 46px; height: 46px; border-radius: var(--radiusS); display: inline-block; vertical-align: top; margin-right: 10px; background: 50% no-repeat var(--blue);}
.rs .facebook								{ background-image: url("../images/facebook.svg"); background-size: auto 20px;}
.rs .linkedin								{ background-image: url("../images/linkedin.svg"); background-size: 18px auto; background-position: 50% 45%;}
.rs .scroll									{ background-image: url("../images/scrolltop.svg"); background-position: 50% 48%; margin: 0;}

@media (min-width:1201px) {
.rs a:hover 	 							{ background-color: var(--darkBlue);}
}
@media (max-width:700px) {
.rs  										{ display: grid; grid-gap: 10px;}
.rs a										{ width: 40px; height: 40px; display: block; margin: 0;}
.rs .facebook								{ background-size: auto 18px;}
.rs .linkedin								{ background-size: 16px auto;}
.rs .scroll									{ background-size: 16px auto; grid-area: 1;}
}




/***** footer *****/
.footer										{ position: relative; background: var(--darkerBlue); color: #fff; padding-top: var(--paddingT); font-size: 14px; line-height: 170%; letter-spacing: 0.6px;}

.footer .bloc_footer 						{ display: inline-block; vertical-align: top; position: relative; margin-right: clamp(20px, 4vw, 100px);}
.footer .bloc_footer .logo 					{ width: 180px; height: auto; display: block; margin: -10px 0 clamp(20px, 3vw, 40px) 0;}
.footer .bloc_footer p						{ margin-top: 12px;}
.footer .bloc_footer p a, 
.footer .bloc_footer li a					{ color: #fff; display: inline-block;}
.footer .bloc_footer li a					{ padding: 5px 0;}
.footer .bloc_footer .sous_titre			{ font-size: clamp(16px, 2.2vw, 18px);}
.footer .contact_infos .tel a:after 		{ background-image: url(../images/tel.svg);}
.footer .contact_infos .email a:after 		{ background-image: url("../images/email.svg");}
.footer .contact_infos .email  				{ margin-bottom: 0;}
.footer .bloc_footer:nth-child(4)			{ margin: 0;}

.footer	.rs									{ font-size: 0; line-height: 0; letter-spacing: 0; position: absolute; right: 0; top: -12px;}
.footer .certis								{ display: grid; grid-template-columns: repeat(4, 1fr); grid-gap: 10px; width: 100%; max-width: 580px; margin: 4vw auto 0 auto;}
.footer .certis .item						{ background: #fff; border-radius: var(--radiusS); display: grid; align-items: center; justify-content: center; padding: 10px;}
.footer .certis .item img					{ width: auto; max-width: 100%; height: 56px; display: block;}

.footer .akiles 							{ display: block; position: absolute; right: 0; bottom: 20px;}
.footer .akiles span 						{ font-size: 12px; line-height: 20px; display: block; float: left; color: #fff; margin-right: 10px;}
.footer .akiles img 						{ width: 60px; height: auto; display: block; filter: brightness(200);}

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

@media (min-width:1201px) {
.footer .bloc_footer p a:hover 				{ color: #fff;}
.footer .bloc_footer li a:hover 			{ color: var(--green);} 	 
.footer_bottom li a:hover 	 				{ color: var(--blue);}
}
@media (max-width:1600px) {
.footer .akiles 							{ right: 30px;}
}
@media (max-width:1200px) {
.footer .wrapper_medium  					{ display: grid; grid-template-columns: auto auto auto;}
.footer .bloc_footer 						{ margin-right: 0;}
.footer .bloc_footer .logo 					{ width: 160px; margin-top: 0;}
.footer .contact_infos  					{ grid-column: span 3; margin-bottom: 5vw;}
.footer	.rs									{ top: 0;}
.footer .certis								{ position: absolute; top: 0; right: 200px; grid-template-columns: 1fr 1fr; margin: 0; max-width: 350px;}
.footer .akiles 							{ right: calc(90px - 5vw);}
.footer_bottom   							{ grid-column: span 3; padding-top: 0;}
}
@media (max-width:1000px) {
.footer .certis								{ position: relative; right: auto; top: auto; margin: 8vw auto 0 auto; grid-template-columns: repeat(4, 1fr); grid-column: span 3; max-width: 500px;}
.footer .certis .item img					{ height: 50px;}
}
@media (max-width:700px) {
.footer										{ font-size: 13px;}
.footer .wrapper_medium  					{ grid-template-columns: 1fr 1fr; grid-gap: clamp(30px, 10vw, 40px); padding: 0 2vw;}
.footer .bloc_footer   						{ display: block;}
.footer .bloc_footer .logo 					{ width: 140px;}
.footer .contact_infos  					{ grid-column: span 2; margin-bottom: 0;}
.footer .certis   							{ grid-column: span 2; margin: 0 auto; max-width: none;}
.footer	.rs									{ top: -5px;}
.footer_bottom   							{ grid-column: span 2;}
.footer .akiles 							{ right: calc(80px - 5vw);}
.footer .akiles img 						{ width: 46px;}
.footer_bottom  							{ padding-bottom: 20px; margin: 0;}
.footer_bottom li 							{ display: block; font-size: 11px; line-height: 26px; margin: 0;}
.footer_bottom li:after						{ display: none;}
}
@media (max-width:500px) {
.footer .wrapper_medium  					{ grid-template-columns: 1fr;}
.footer .contact_infos  					{ grid-column: auto;}
.footer .certis   							{ grid-column: auto; grid-template-columns: 1fr 1fr;}
.footer_bottom   							{ grid-column: auto;}
}










