/* math */
@font-face {
  font-family: 'Open Sans';
  font-style: italic;
  font-weight: 300 800;
  font-stretch: 100%;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/opensans/v44/memtYaGs126MiZpBA-UFUIcVXSCEkx2cmqvXlWqWxU6F15M.woff2) format('woff2');
  unicode-range: U+0302-0303, U+0305, U+0307-0308, U+0310, U+0312, U+0315, U+031A, U+0326-0327, U+032C, U+032F-0330, U+0332-0333, U+0338, U+033A, U+0346, U+034D, U+0391-03A1, U+03A3-03A9, U+03B1-03C9, U+03D1, U+03D5-03D6, U+03F0-03F1, U+03F4-03F5, U+2016-2017, U+2034-2038, U+203C, U+2040, U+2043, U+2047, U+2050, U+2057, U+205F, U+2070-2071, U+2074-208E, U+2090-209C, U+20D0-20DC, U+20E1, U+20E5-20EF, U+2100-2112, U+2114-2115, U+2117-2121, U+2123-214F, U+2190, U+2192, U+2194-21AE, U+21B0-21E5, U+21F1-21F2, U+21F4-2211, U+2213-2214, U+2216-22FF, U+2308-230B, U+2310, U+2319, U+231C-2321, U+2336-237A, U+237C, U+2395, U+239B-23B7, U+23D0, U+23DC-23E1, U+2474-2475, U+25AF, U+25B3, U+25B7, U+25BD, U+25C1, U+25CA, U+25CC, U+25FB, U+266D-266F, U+27C0-27FF, U+2900-2AFF, U+2B0E-2B11, U+2B30-2B4C, U+2BFE, U+3030, U+FF5B, U+FF5D, U+1D400-1D7FF, U+1EE00-1EEFF;
}
/* symbols */
@font-face {
  font-family: 'Open Sans';
  font-style: italic;
  font-weight: 300 800;
  font-stretch: 100%;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/opensans/v44/memtYaGs126MiZpBA-UFUIcVXSCEkx2cmqvXlWqW106F15M.woff2) format('woff2');
  unicode-range: U+0001-000C, U+000E-001F, U+007F-009F, U+20DD-20E0, U+20E2-20E4, U+2150-218F, U+2190, U+2192, U+2194-2199, U+21AF, U+21E6-21F0, U+21F3, U+2218-2219, U+2299, U+22C4-22C6, U+2300-243F, U+2440-244A, U+2460-24FF, U+25A0-27BF, U+2800-28FF, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B00-2BFF, U+4DC0-4DFF, U+FFF9-FFFB, U+10140-1018E, U+10190-1019C, U+101A0, U+101D0-101FD, U+102E0-102FB, U+10E60-10E7E, U+1D2C0-1D2D3, U+1D2E0-1D37F, U+1F000-1F0FF, U+1F100-1F1AD, U+1F1E6-1F1FF, U+1F30D-1F30F, U+1F315, U+1F31C, U+1F31E, U+1F320-1F32C, U+1F336, U+1F378, U+1F37D, U+1F382, U+1F393-1F39F, U+1F3A7-1F3A8, U+1F3AC-1F3AF, U+1F3C2, U+1F3C4-1F3C6, U+1F3CA-1F3CE, U+1F3D4-1F3E0, U+1F3ED, U+1F3F1-1F3F3, U+1F3F5-1F3F7, U+1F408, U+1F415, U+1F41F, U+1F426, U+1F43F, U+1F441-1F442, U+1F444, U+1F446-1F449, U+1F44C-1F44E, U+1F453, U+1F46A, U+1F47D, U+1F4A3, U+1F4B0, U+1F4B3, U+1F4B9, U+1F4BB, U+1F4BF, U+1F4C8-1F4CB, U+1F4D6, U+1F4DA, U+1F4DF, U+1F4E3-1F4E6, U+1F4EA-1F4ED, U+1F4F7, U+1F4F9-1F4FB, U+1F4FD-1F4FE, U+1F503, U+1F507-1F50B, U+1F50D, U+1F512-1F513, U+1F53E-1F54A, U+1F54F-1F5FA, U+1F610, U+1F650-1F67F, U+1F687, U+1F68D, U+1F691, U+1F694, U+1F698, U+1F6AD, U+1F6B2, U+1F6B9-1F6BA, U+1F6BC, U+1F6C6-1F6CF, U+1F6D3-1F6D7, U+1F6E0-1F6EA, U+1F6F0-1F6F3, U+1F6F7-1F6FC, U+1F700-1F7FF, U+1F800-1F80B, U+1F810-1F847, U+1F850-1F859, U+1F860-1F887, U+1F890-1F8AD, U+1F8B0-1F8BB, U+1F8C0-1F8C1, U+1F900-1F90B, U+1F93B, U+1F946, U+1F984, U+1F996, U+1F9E9, U+1FA00-1FA6F, U+1FA70-1FA7C, U+1FA80-1FA89, U+1FA8F-1FAC6, U+1FACE-1FADC, U+1FADF-1FAE9, U+1FAF0-1FAF8, U+1FB00-1FBFF;
}
/* latin-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: italic;
  font-weight: 300 800;
  font-stretch: 100%;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/opensans/v44/memtYaGs126MiZpBA-UFUIcVXSCEkx2cmqvXlWqWt06F15M.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: 'Open Sans';
  font-style: italic;
  font-weight: 300 800;
  font-stretch: 100%;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/opensans/v44/memtYaGs126MiZpBA-UFUIcVXSCEkx2cmqvXlWqWuU6F.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;
}

/* math */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 300 800;
  font-stretch: 100%;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/opensans/v44/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTVOmu1aB.woff2) format('woff2');
  unicode-range: U+0302-0303, U+0305, U+0307-0308, U+0310, U+0312, U+0315, U+031A, U+0326-0327, U+032C, U+032F-0330, U+0332-0333, U+0338, U+033A, U+0346, U+034D, U+0391-03A1, U+03A3-03A9, U+03B1-03C9, U+03D1, U+03D5-03D6, U+03F0-03F1, U+03F4-03F5, U+2016-2017, U+2034-2038, U+203C, U+2040, U+2043, U+2047, U+2050, U+2057, U+205F, U+2070-2071, U+2074-208E, U+2090-209C, U+20D0-20DC, U+20E1, U+20E5-20EF, U+2100-2112, U+2114-2115, U+2117-2121, U+2123-214F, U+2190, U+2192, U+2194-21AE, U+21B0-21E5, U+21F1-21F2, U+21F4-2211, U+2213-2214, U+2216-22FF, U+2308-230B, U+2310, U+2319, U+231C-2321, U+2336-237A, U+237C, U+2395, U+239B-23B7, U+23D0, U+23DC-23E1, U+2474-2475, U+25AF, U+25B3, U+25B7, U+25BD, U+25C1, U+25CA, U+25CC, U+25FB, U+266D-266F, U+27C0-27FF, U+2900-2AFF, U+2B0E-2B11, U+2B30-2B4C, U+2BFE, U+3030, U+FF5B, U+FF5D, U+1D400-1D7FF, U+1EE00-1EEFF;
}
/* symbols */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 300 800;
  font-stretch: 100%;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/opensans/v44/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTUGmu1aB.woff2) format('woff2');
  unicode-range: U+0001-000C, U+000E-001F, U+007F-009F, U+20DD-20E0, U+20E2-20E4, U+2150-218F, U+2190, U+2192, U+2194-2199, U+21AF, U+21E6-21F0, U+21F3, U+2218-2219, U+2299, U+22C4-22C6, U+2300-243F, U+2440-244A, U+2460-24FF, U+25A0-27BF, U+2800-28FF, U+2921-2922, U+2981, U+29BF, U+29EB, U+2B00-2BFF, U+4DC0-4DFF, U+FFF9-FFFB, U+10140-1018E, U+10190-1019C, U+101A0, U+101D0-101FD, U+102E0-102FB, U+10E60-10E7E, U+1D2C0-1D2D3, U+1D2E0-1D37F, U+1F000-1F0FF, U+1F100-1F1AD, U+1F1E6-1F1FF, U+1F30D-1F30F, U+1F315, U+1F31C, U+1F31E, U+1F320-1F32C, U+1F336, U+1F378, U+1F37D, U+1F382, U+1F393-1F39F, U+1F3A7-1F3A8, U+1F3AC-1F3AF, U+1F3C2, U+1F3C4-1F3C6, U+1F3CA-1F3CE, U+1F3D4-1F3E0, U+1F3ED, U+1F3F1-1F3F3, U+1F3F5-1F3F7, U+1F408, U+1F415, U+1F41F, U+1F426, U+1F43F, U+1F441-1F442, U+1F444, U+1F446-1F449, U+1F44C-1F44E, U+1F453, U+1F46A, U+1F47D, U+1F4A3, U+1F4B0, U+1F4B3, U+1F4B9, U+1F4BB, U+1F4BF, U+1F4C8-1F4CB, U+1F4D6, U+1F4DA, U+1F4DF, U+1F4E3-1F4E6, U+1F4EA-1F4ED, U+1F4F7, U+1F4F9-1F4FB, U+1F4FD-1F4FE, U+1F503, U+1F507-1F50B, U+1F50D, U+1F512-1F513, U+1F53E-1F54A, U+1F54F-1F5FA, U+1F610, U+1F650-1F67F, U+1F687, U+1F68D, U+1F691, U+1F694, U+1F698, U+1F6AD, U+1F6B2, U+1F6B9-1F6BA, U+1F6BC, U+1F6C6-1F6CF, U+1F6D3-1F6D7, U+1F6E0-1F6EA, U+1F6F0-1F6F3, U+1F6F7-1F6FC, U+1F700-1F7FF, U+1F800-1F80B, U+1F810-1F847, U+1F850-1F859, U+1F860-1F887, U+1F890-1F8AD, U+1F8B0-1F8BB, U+1F8C0-1F8C1, U+1F900-1F90B, U+1F93B, U+1F946, U+1F984, U+1F996, U+1F9E9, U+1FA00-1FA6F, U+1FA70-1FA7C, U+1FA80-1FA89, U+1FA8F-1FAC6, U+1FACE-1FADC, U+1FADF-1FAE9, U+1FAF0-1FAF8, U+1FB00-1FBFF;
}
/* latin-ext */
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 300 800;
  font-stretch: 100%;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/opensans/v44/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTSGmu1aB.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: 'Open Sans';
  font-style: normal;
  font-weight: 300 800;
  font-stretch: 100%;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/opensans/v44/memvYaGs126MiZpBA-UvWbX2vVnXBbObj2OVTS-muw.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: #004e93 ;
	--mainColor1Hover: #D7C8AC;
	--mainColor2: #0c345f ;
	--bgColorLight: #f1ebe2 ;

    --paddingTB: clamp(30px, 10vw, 100px) ;
    --marginTB: clamp(60px, 8vw, 150px) auto;
	  --gapSection: clamp(20px, 10vw, 80px);
	
	--maxWidthWrapper: 1200px;
	--maxWidthWrapperSmall: 1000px;
	--maxWidthWrapperLarge: 1600px;

	--imgRadius: 0;
	--linkRadius: 0;
}

@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: 400 clamp(13px, 2.2vw, 15px)/180% "Open Sans"; letter-spacing: 0.4px; color: #06001B; background: #fff; position: relative;}
body.active_overflow				{ height: 100vh; overflow: hidden;}
main 								{ position: relative; z-index: 10;}
p 									{ margin-bottom: clamp(10px, 2vw, 15px);}
ul									{ margin-bottom: clamp(10px, 2vw, 15px); list-style-type: none;}
a									{ text-decoration: none; color: #06001B; position: relative;}
p a               { border-bottom: 1px solid var(--mainColor1);}
img									{ border: none;}
strong, b							{ font-weight: 600; font-size: clamp(14px, 2.4vw, 16px);}

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

@media (min-width:1201px) {
  p a:hover               { border-bottom: 1px solid var(--mainColor1Hover);}
}


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


/***** transition *****/
@media (min-width:1201px) {
.link, .slick-arrow, :before, :after, a, a span, .logo, .header, .sub { transition: all 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: 0; top: -180px;}

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

.titre_main	 						{ font: 400 clamp(22px, 3vw, 55px)/130% "Open Sans"; letter-spacing: 4px; text-transform: none; position: relative; margin-bottom: clamp(10px, 2vw, 15px);}
.titre_main span     				{ font: 500 clamp(15px, 1.8vw, 24px)/140% "Open Sans"; text-transform: uppercase; letter-spacing: 4.5px;}
.titre_main.smaller					{ font-size: 30px; font-weight: 600; text-transform: uppercase; color: var(--mainColor1);}
.titre_main.line					{ padding-left: 30px; }
.titre_main.line:after				{ content:""; width: 10px; height: 100%; background-color: var(--bgColorLight); display: block; position: absolute; left: 0; top: 1px;}

.titre_cap  						{ font: 400 clamp(15px, 1.8vw, 18px)/140% "Open Sans"; text-transform: uppercase; letter-spacing: 4.5px; position: relative; margin-bottom: clamp(10px, 2vw, 15px);}
.sous_titre 						{ font: 500 clamp(16px, 1.8vw, 24px)/140% "Open Sans"; letter-spacing: 3px; position: relative; margin-bottom: clamp(10px, 2vw, 15px);}
.chapo		 						{ font: 400 clamp(13px, 2.2vw, 14px)/190% "Open Sans"; margin-bottom: clamp(10px, 2vw, 15px);}
.chapo span	 						{ display: block; margin-top: clamp(10px, 2vw, 15px);}

.titre 						        { font: 500 clamp(12px, 1.5vw, 16px)/140% "Open Sans"; text-transform: uppercase; letter-spacing: 4.5px; position: relative; margin-bottom: clamp(10px, 2vw, 15px);}


.hide 								{ display: none;}

.ul_check   						{ margin: 15px 0 25px;}
.ul_check li 						{ position: relative; padding-left: 28px; font-size: clamp(14px, 2.4vw, 16px); line-height: 200%; margin-bottom: 12px;}
.ul_check li:before					{ width: 19px; height: 14px; position: absolute; left: 0; top: 8px; background: url("../images/check.svg") 0 2px / contain no-repeat; background-size: 16px; content: "";}
.ul_check li:last-child				{ margin-bottom: 0;}

.ul_list   							{ padding: clamp(3px, 1vw, 5px) 0;}
.ul_list li 						{ position: relative; padding-left: 10px; margin-bottom: clamp(5px, 1.8vw, 10px); line-height: 160%;}
.ul_list li:before					{ width: 5px; height: 2px; position: absolute; left: 0; top: 50%; transform: translateX(-50%); background-color: var(--mainColor2); content: "";}
.ul_list li:last-child				{ margin-bottom: 0;}

.link 								{ font: 500 14px/58px "Open Sans"; letter-spacing: 1.2px; height: 60px; display: inline-block; color: #fff; padding: 0 25px; background: var(--mainColor1); cursor: pointer; text-transform: uppercase;}

.link_arrow                      	{ display: inline-block; width: 80px; height: 42px; border-radius: 0%; background: url("../images/arrow_link_dark.svg") 50% no-repeat var(--bgColorLight); font-size: 0; position: relative; }
/*.link_arrow:after                 	{ content: ""; width: 40px; height: 40px; border-radius: 0%; border: 1px solid #000; background-color: transparent; display: block; position: absolute; left: 35px; z-index: -1; transform-origin: center; transform: scale(1) rotate(0deg);}*/

@media (min-width:1201px) {
.link:hover 						{ background-color: var(--mainColor2);}
.link_arrow:hover:after            	{ transform: rotate(-160deg); border-radius: 80px; /*left: 32px; top: 6px; width: 40px; height: 26px;*/}
}


@media (max-width:700px) {
.link 								{  height: 50px; line-height: 48px; display: inline-block; color: #fff; padding: 0 20px;  cursor: pointer; border: 1px solid #fff; text-transform: uppercase;}
.link_arrow                      	{ width: 60px; height: 30px}
.link_arrow:after                 	{ width: 20px; height: 20px; left: 40px;}
.titre_main.smaller					{ font-size: 20px; letter-spacing: 4px;}
.sous_titre     					{ letter-spacing: 2px;}
}


/***** header : simple *****/
.header 								{ width: 100%; font-size: 0; line-height: 0; letter-spacing: 0; position: fixed; left: 0; top: 0; padding: 0 0; background-color: #fff; z-index: 205; text-align: right; transition: all 300ms ease-in-out;}

.header .logo							{ width: 220px; position: absolute; left: 0; top: 25px; transform-origin: left center; z-index: 850; text-align: center; transition: all 300ms ease-in-out}
.header .logo img						{ width: 100%; height: auto; display: block; }
.header .header_nav 					{ display: inline-block; vertical-align: middle; position: relative;}
.header .menu 							{ margin: 0;}
.header .menu>li						{ position: relative; display: inline-block; vertical-align: top; margin-right: 45px;}
.header .menu>li:last-of-type     		{ margin-right: 0px;}
.header .menu>li a						{ font-size: 15px; line-height: 88px; text-transform: uppercase; font-weight: 500; color: var(--mainColor2); height: 90px; display: block; letter-spacing: 1.2px;}
.header .menu>li.active>a				{ color: var(--mainColor1Hover);}
.header .sub							{ width: 300px; margin: 0 0 0 -150px; text-align: center; position: absolute; top: 70px; left: 50%; display: block; visibility: hidden; opacity: 0; padding: 20px 0; background: var(--mainColor2); border-radius: 0;}
.header .sub li							{ width: 100%; margin: 0;}
.header .sub li a						{ width: 100%; font-size: 14px; letter-spacing: 0.8px; line-height: 38px; height: 40px; color: #fff;}
.header .sub li.active a				{ color: var(--mainColor1Hover);}
.header .link 							{ padding: 0 15px; text-align: center; min-width: 170px; vertical-align: middle; margin-left: 10px; z-index: 850;}
.header .tel 							{ text-align: left; padding: 0 30px 0 64px; font-size: 16px; line-height: 58px;}
.header .tel:after 						{ width: 18px; height: 100%; position: absolute; left: 28px; top: 0; background: url("../images/tel.svg") 50% / contain no-repeat; content: "";}
.header .gsm 							{ text-align: left; padding: 0 30px 0 60px; font-size: 16px; line-height: 58px;}
.header .gsm:after 						{ width: 14px; height: 100%; position: absolute; left: 28px; top: 0; background: url("../images/gsm.svg") 50% / contain no-repeat; content: "";}
.header .gsm span						{ background: var(--mainColor2); color: #fff; font-size: 12px; line-height: 17px; padding: 2px 5px 3px 5px; border-radius: 5px; position: absolute; right: 10px; top: -11px;}

.sticky .header							{ background-color: #fff; box-shadow: 0 5px 10px #9F8D7D1a; padding: 0 0;}


@media (min-width: 1201px) {
.header .menu_mobile 					{ display: none;}
.header .sub:after 						{ width: 10px; height: 10px; position: absolute; left: 50%; top: -4px; margin: 0 0 0 -5px; transform: rotate(45deg); background: var(--mainColor2); content: "";}
.header .menu>li:hover .sub				{ opacity: 1; visibility: visible; z-index: 999;}
.header .menu>li:hover>a 				{ color: var(--mainColor1Hover);}		
.header .sub li a:hover 				{ color: var(--mainColor1Hover);}

}

@media (max-width:1400px) {
.header .menu>li						{ margin-right: 30px;}
}

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

.header 								        { padding: 10px 0; }
.header ::-webkit-scrollbar			{ display: none;}
.header .logo							      { width: 160px; top: 50%; transform: translateY(-50%);}
.header .logo .logo_txt 				{ top: 15px; transition: all 300ms ease-in-out;}
    
.header .header_nav 					{ width: 100%; position: fixed; right: -100%; top: 0; bottom: 0; overflow-y: scroll; display: grid; z-index: 600; background: var(--mainColor2); transition: all 300ms ease-in-out 450ms; border-top: 80px solid #ffffff;}

.header .menu  							{ display: block; width: 100%; text-align: left; padding: 7vw; position: relative; z-index: 100; align-self: start; opacity: 0; transform: translateY(40px); transition: all 300ms ease-in-out 150ms;}
.header .menu>li 						{ width: 100%; display: block; margin: 0;}
.header .menu>li>a						{ font-size: 20px; line-height: 30px; height: auto; padding: 15px 0; color: #fff; transition: none; display: inline-block; z-index: 10;}
.header .menu>li.active>a				{ color: var(--mainColor1Hover);}
.header .menu>li>i						{ width: 100%; height: 60px; display: block; margin-top: -60px; position: relative; z-index: 5; float: right;}
.header .menu>li>i:after				{ width: 44px; height: 44px; background: url("../images/arrow_select.svg") 50% 52% no-repeat #fff; border-radius: 0; position: absolute; right: 0; top: 10px; content: "";}
.header .menu>li>i.active:after 		{ transform: rotate(180deg);}
.header .sub 							{ width: 100%; position: relative; left: auto; top: auto; padding: 20px 30px; margin: 15px 0; background: #fff; visibility: visible; opacity: 1; display: none; z-index: 150;}
.header .sub li  						{ width: 100%;}
.header .sub li a						{ width: 100%; font-size: 16px; line-height: 24px; height: auto; padding: 10px 0; letter-spacing: 0.4px; text-align: left; display: block; color: #000;}
.header .link							{ display: none;}
.header.active .header_nav 				{ right: 0; transition-delay: 150ms;}
.header.active .menu					{ opacity: 1; transform: translateY(0); transition-delay: 450ms;}
    
.sticky .header.active .logo		    { padding: 0;}
.sticky .header .header_nav { border-top: 60px solid #ffffff;}
    
}
@media (max-width:1000px) {
.header .menu>li>a						{ font-size: 18px;}
}
@media (max-width:700px) {
.header 								{ padding: 5px 0;}
.header .menu>li>a      { font-size: 16px;}
.sticky .header         { top: 0;}
}
@media (max-width:500px) {
  .header .menu>li>a { padding: 10px 0;}
  .header .menu>li>i:after { width: 34px; height: 34px;}
}



.txt_dec								{ padding-left: 60px; }
@media (max-width:700px) {
.txt_dec								{ padding-left: 30px; }
}


/***** text : simple *****/
.txt_simple 											{ position: relative; text-align: center; margin: var(--marginTB);}
.txt_simple.align_left									{ text-align: left;}
.txt_simple:before										{ position: absolute; width: 94vw; max-width: calc(47vw + 720px); left: auto; right: 3vw; top: 0; bottom: 0; background: #eee; border-radius: 50px; visibility: hidden; transition: none; content: "";}
.txt_simple svg											{ width: 60px; height: auto; display: block; margin: 0 auto 15px auto;}
.txt_simple p               							{ margin-bottom: 15px;}
.txt_simple .link										{ margin-top: 10px;}
.txt_simple .multi_links								{ display: grid; grid-template-columns: 1fr 1fr; max-width: 400px; grid-gap: 10px; margin: 25px 0 0 0;}
.txt_simple .multi_links .link							{ margin: 0; text-align: center; padding: 0;}

/* custom highlight */
.txt_simple .txt_highlight    							{ padding-bottom: 15px;}
.txt_simple .txt_highlight svg  						{ bottom: 0; left: 0; right: 0; margin: 0 auto;}
.txt_simple .txt_highlight svg path						{ fill: var(--mainColor1);}


/***** 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); 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>.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 .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 .show_hide .item                       	{ position: relative;}


.bloc_txt_img .show_hide .item:before                  	{ width: 40px; height: 3px; position: absolute; left: 0; bottom: 0; background: var(--mainColor1); transition: all 300ms ease-in-out; content: "";}
.bloc_txt_img .show_hide .item.active:before            { width: 100%; transition-delay: 400ms;}


.bloc_txt_img.reverse:before							{ left: 60%; right: 20px; top: 25%; bottom: -10%; background: var(--bgColorLight); 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;}
.bloc_txt_img.align_top .container                		{ align-items: start;}

@media (max-width:1200px) { 
.bloc_txt_img .container      { grid-gap: 0 60px;}
.bloc_txt_img.reverse:before  { bottom: 0;}
}
@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.reverse:before { content: none;}
}
@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;}
}



/***** CTA *****/
.cta 								{ position: relative; margin: var(--marginTB); display: grid; grid-template-columns: 1fr 1fr; align-items: center; background: var(--mainColor1); border-radius: 0; overflow: hidden; text-align: center;}
.cta .sous_titre				    { background: var(--bgColorLight); padding: 45px 50px; position: relative; z-index: 5; margin-bottom: 0; letter-spacing: 1.3px;}
.cta .sous_titre span				{ color:var(--mainColor2); 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; background-color: var(--bgColorLight); color: var(--mainColor1);}
.cta .row .tel   					{ display: inline-block; vertical-align: middle; }
.cta .row .tel a 					{ background: url("../images/tel-dark.svg") 30px 50% no-repeat var(--bgColorLight);}
.cta .row .form   					{ display: inline-block; vertical-align: middle; margin-left: 10px;}
.cta .row .form a					{ background: url("../images/email-dark.svg") 30px 50% no-repeat var(--bgColorLight);}

@media (min-width: 1201px){
.cta .row .link:hover 				{ color: var(--second-color);}
}
@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: 600px){
.cta .sous_titre {padding: 25px 30px;}
.cta .row .tel, .cta .row .form  { display: block; margin: 5px auto;}
.cta .row .form  { margin-left: 0;}
}




/***** show hide *****/
.show_hide                        			{ position: relative; margin: 25px 0 100px;}
.show_hide.no_marge                        	{ margin: 0;}
.show_hide .item                  			{ border: none; margin: 10px 0; overflow: hidden; border-bottom: 1px solid #DCDCDC;}
.show_hide .titre                 			{ font-size: clamp(14px, 2.6vw, 18px); line-height: 150%; font-weight: 400; position: relative; cursor: pointer; letter-spacing: 2px; color: #000; padding: 20px 80px 22px 0; margin: 0; border-radius: 0; text-transform: none;}
.show_hide .hide                  			{ margin: 0; padding: 0 0 20px 0; 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: 25px 25px 15px 25px;}
}
@media (max-width:700px){
.show_hide                        			{ margin: 20px 0;}
.show_hide .titre                 			{ padding: 15px 65px 15px 20px;}
.show_hide .hide                  			{ padding: 20px 20px 10px 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;}
}




/***** 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: 0; background: var(--mainColor1); border: none;}
.bloc_rs a:after							{ width: 100%; height: 100%; position: absolute; left: 0; top: 0; content: "";}

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

@media (min-width:1201px) {
.bloc_rs a:hover:after 						{ filter: invert(1);}
}
@media (max-width:1200px) {
.bloc_rs a									{ width: 50px; height: 50px;}
}



/***** footer *****/
.footer										{ position: relative; color: #fff; padding-top: 80px; background-color: var(--mainColor2); }
.footer .bloc_footer 						{ display: inline-block; vertical-align: top; position: relative; line-height: 160%; margin-right: 80px;}

.footer .bloc_footer .logo 					{ width: clamp(120px, 30vw, 220px); height: auto; display: block;  filter: brightness(0) invert(1);}
.footer .bloc_footer .titre_footer			{ font-size: 18px; font-weight: 500; letter-spacing: 0.6px; margin: 0;}
.footer .bloc_footer p						{ margin: clamp(10px, 2.4vw, 20px) 0 0 0;}
.footer .bloc_footer p a					{ color: #fff; display: inline-block; border-bottom: none;}
.footer .bloc_footer .icon 					{ padding-left: 40px; position: relative;}
.footer .bloc_footer .icon:after 			{ width: 20px; height: 100%; position: absolute; left: 0; top: 0; content: "";}
.footer .bloc_footer .address:after 		{ background: url(../images/pointer.svg) 0 50% / contain no-repeat;}
.footer .bloc_footer .tel a:after 			{ background: url("../images/tel.svg") 0 50% / contain no-repeat;}
.footer .bloc_footer .email a:after 		{ background: url("../images/email.svg") 0 50% / contain no-repeat;}


.footer .bloc_rs							{ position: absolute; right: 0; top: 0;}
.footer .bloc_rs a							{ display: inline-block; vertical-align: top; margin-right: 10px;}
.footer .bloc_rs .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.6px; position: relative;}
.footer_bottom li:after						{ width: 1px; height: 9px; content: ""; position: absolute; right: -18px; top: 6px; background: #fff;}
.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: bottom 300ms ease-in-out; border: none!important;}
.toponweb span								{ width: auto; height: 60px; display: block; padding: 20px; background: linear-gradient(to left, var(--mainColor2) 0% 50%, #fff 50% 100%); background-size: 200% 100%; background-position: 100% 0;}
.toponweb img								{ width: 76px; height: auto; display: block; margin: 0 auto; filter: invert(0); transition: all 300ms ease-in-out;}

@media (min-width:1201px) {
.footer .bloc_rs a.facebook:hover,
.footer .bloc_rs a.instagram:hover,
.footer .bloc_rs a.scroll:hover 			{ background: var(--mainColor1Hover); border-color: #000;}
.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(--mainColor1Hover);}
.toponweb:hover span						{ opacity: 0.65;}
}
@media (max-width:1200px) {
.footer .bloc_footer.heading_float 			{ margin-right: 5vw;}
.footer .bloc_footer .address  				{ margin: 0;}
}
@media (max-width:700px) {
.footer   									{ padding-bottom: 60px;}
.footer .wrapper							{ width: 100vw;}
.footer .bloc_footer 						{ width: 100%; padding: 0; margin: 0; text-align: center;}
.footer .bloc_footer.heading_float 			{ margin-right: 0; margin-bottom: clamp(20px, 7vw, 40px);}
.footer .bloc_footer .logo 					{ margin: 0 auto;}
.footer .bloc_footer p a					{ color: var(--mainColor3);}
.footer .bloc_footer .icon 					{ padding-left: 0;}
.footer .bloc_footer .icon:after 			{ display: none;}
.footer .bloc_footer p span					{ display: block;}
.footer	.bloc_rs							{ position: static; margin-top: 7vw; text-align: center;}
.footer	.bloc_rs a							{ width: 50px; height: 50px; margin: 0 10px 0 0;}
.footer_bottom 	 							{ text-align: center; padding: 0 0 20px 0;}
.footer_bottom li 							{ display: block; margin: 0; font-size: 11px; line-height: 220%;}
.footer_bottom li:after						{ display: none;}
.toponweb									{ display: block; width: 100%; bottom: -60px;}
}


/***** moving galerie *****/
.moving_galerie 							{ width: auto; left: 50%; transform: translateX(-50%); position: relative; text-align: center; margin: 80px 0 80px 0; overflow: hidden;}
.moving_galerie .row 						{ width: auto; display: flex;}
.moving_galerie .row .item 					{ width: auto; display: flex; animation: scroll_gallery 80s linear infinite;}
.moving_galerie .row .item div 				{ padding: 0 10px;}
.moving_galerie .row .item img 				{ border-radius: var(--imgRadius); width: auto; height: 400px; display: block; margin: 0 auto; transition: all 300ms ease-in-out;}

@keyframes scroll_gallery {
0%											{ transform: translate(0, 0);}
100% 										{ transform: translate(-100%, 0); }
}
@media (max-width:1200px) {
.moving_galerie .row .item img 				{ height: 380px;}
}
@media (max-width:1000px) {
.moving_galerie 							{ margin: 60px 0;}
.moving_galerie .row .item img 				{ height: 350px;}
}
@media (max-width:600px) {
.moving_galerie 							{ margin: 40px 0;}
.moving_galerie .row .item div 				{ padding: 0 5px;}
.moving_galerie .row .item img 				{ height: 60vw;}
.moving_galerie .row .item 					{ animation-duration: 50s;}
}




.link-moins,.link-plus              { cursor:pointer; color: var(--mainColor2); border-bottom: 1px solid var(--mainColor2);}
.textMore                           { display: none; padding-top: 15px;}
.textMore p:not(:first-of-type)     { margin-top: 15px;}
@media (min-width:1201px) {
.link-moins:hover,.link-plus:hover  { color: var(--mainColor2); border-color: var(--mainColor2);}
}
@media (max-width:700px) {
.textMore                           { margin-top: 20px;}
}