/***** fonts et reset *****/
@import url('https://fonts.googleapis.com/css?family=Poppins:400,500,600,700&display=swap');


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: 600; font-size: 16px;}
ul									{ list-style-type: none;}
body								{ font: 400 14px/28px "Poppins"; letter-spacing: 0.4px; color: #2e2e31; background: #fff; position: relative;}
body.active_overflow				{ height: 100vh; overflow: hidden;}
a									{ text-decoration: none; color: #171717; position: relative;}
img									{ border: none;}
main 								{ position: relative; z-index: 10;}
#wrapper 							{ min-width: 320px; overflow: hidden; position: relative;}
#wrapper *							{ box-sizing: border-box;}
#footer 							{ position: relative; z-index: 15;}

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


/***** scollbar *****/
::-webkit-scrollbar 				{ width: 6px; height: 6px; background-color: #eef4f9;}
::-webkit-scrollbar-thumb			{ background-color: #b3c43f;}


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


/***** class *****/
.wrapper 							{ width: 90vw; max-width: 1200px; margin: 0 auto; position: relative;}
.clear								{ clear: both; display: block;}
.anchor								{ position: absolute; left: 0; top: -140px;}
.titre    	 						{ font: 500 18px/30px "Poppins"; letter-spacing: 0.5px; position: relative; color: #2e2e31;}
.titre_main	 						{ font: 400 40px/50px "Poppins"; position: relative; letter-spacing: 0.6px; color: #fff; margin-bottom: 20px; }
.sous_titre 						{ font: 400 30px/40px "Poppins"; position: relative; color: #b3c43f; margin-bottom: 20px;}
.chapo		 						{ font: 400 14px/28px "Poppins"; margin-bottom: 15px; color: #2e2e31; }
.chapo span	 						{ display: block; margin-top: 15px;}
.link 								{ font: 500 15px/58px "Poppins"; letter-spacing: 0.5px; height: 60px; display: inline-block; color: #fff; padding: 0 30px; background-color: #2e2e31; margin-top: 20px;}
.link_arrow 						{ height: 60px; line-height: 58px; display: block; width: 100%; background: url("../images/arrow_long.svg") calc(100% - 30px) 50% no-repeat #2e2e31; } 
.link_rdv     						{ height: 70px; line-height: 68px; letter-spacing: 1.5px; padding: 0 50px 0 80px; font-size: 16px; background: url("../images/calendar.svg") 30px 50% no-repeat #b3c43f;} 

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

@media (max-width:1200px) {
.wrapper 							{ min-width: inherit;}
.titre_main	 						{ font-size: 24px; line-height: 32px;}
.link_arrow 						{ font-size: 14px; line-height: 60px; height: 60px; padding: 0 20px 0 30px;} 
}
@media (max-width:1000px) {
.wrapper 							{ max-width: 750px;}
.titre_main	 						{ font-size: 26px; line-height: 36px;}
}
@media (max-width:600px) {
.wrapper 							{ width: 85vw;}
.titre_main	 						{ font-size: 20px; line-height: 26px; margin-bottom: 10px;}
.sous_titre 						{ font-size: 16px; line-height: 26px; margin-bottom: 10px;}
.chapo		 						{ font-size: 12px; line-height: 24px; margin-bottom: 15px;}
.chapo span	 						{ margin-bottom: 15px;}
.link 								{ font-size: 13px; line-height: 50px; height: 50px; padding: 0 25px;}
.link_rdv							{ padding: 0 35px 0 75px; height: 60px; line-height: 58px; }
}


/***** annonce *****/
.annonce 							{ background: #bd4ba0; color:#fff; text-align:center;}
.annonce p							{ padding:15px 0; line-height:25px; letter-spacing:0.2px; color:#fff; }

@media (max-width:600px) {
.annonce p							{ font-size:14px; line-height:24px;}
}


.ul_list							{ margin: 30px 0;}
.ul_list li							{ padding: 8px 0 8px 50px; position: relative; background: url("../images/check.svg") 0px 10px no-repeat;}
.ul_list.grid						{ display: grid; grid-template-columns: 1fr 1fr; grid-gap: 0 40px;}
@media (max-width:1200px) {
.ul_list.grid						{ grid-template-columns: 1fr; grid-gap: 0; }
}



.bg_gris                            { background-color: #eee; }
.bg_gris.cadre                      { padding: 60px;}



.slogan                             { margin: 100px auto; position: relative; padding: 40px 50px 50px; background-color: #eee; text-align: center; }
.slogan:after                       { content: ""; background: url("../images/guillemets.svg") 50% no-repeat; width: 50px; height: 50px; display: block; position: absolute; top: -25px; left: 40px;}
.slogan .titre                      { font-size: 20px; font-weight: 400; }

@media (max-width:1200px) {
.slogan                             { margin: 80px auto;}
.slogan .titre br                   { display: none; } 
.slogan .titre                      { font-size: 18px; }
}
@media (max-width:1000px) {
.slogan                             { margin: 70px auto; padding: 40px 5vw;}
.slogan .titre                      { font-size: 15px; }
.slogan:after                       { left: 5vw}
}
@media (max-width:600px) {
.slogan                             { margin: 50px auto; padding: 35px 7.5vw;}
.slogan .titre                      { font-size: 13px; }
.slogan:after                       { background-size: 30px; left: 7.5vw}
}




.cta                                { margin: 100px auto; text-align: center; }
.cta .titre                         { font-size: 20px; }
.cta .titre a                       { color: #b3c43f; border-bottom: 1px solid transparent; }
@media (min-width:1201px) {
.cta .titre a:hover                 { color: #b3c43f; border-bottom: 1px solid #b3c43f; }
}
@media (max-width:1200px) {
.cta                                { margin: 80px auto;}
}
@media (max-width:1000px) {
.cta                                { margin: 70px auto;}
}
@media (max-width:600px) {
.cta                                { margin: 50px auto;}
.cta .titre                         { font-size: 16px; }
}



/***** questions fréquentes *****/
.table_plus 						{ position: relative; margin: 30px 0 130px;}
.table_plus .item 					{ margin-bottom: 10px;}
.table_plus .hide 					{ padding: 45px 40px 30px; display: none;}
.table_plus .hide p:last-child     	{ margin: 0px;}
.titre_plus 						{ font: 500 15px/25px "Poppins"; position: relative; letter-spacing: 0.2px; color: #fff; cursor: pointer; padding: 23px 30px 23px 30px; background: #2e2e31;}
.titre_plus:after					{ width: 30px; height: 30px; background: url("../images/plus.svg") 50% no-repeat; border-radius: 50%; position: absolute; right: 30px; top: 50%; margin-top: -15px; transition: all 400ms ease-in-out; content: "";}
.titre_plus.active:after 			{ transform: rotate(90deg);}
.table_plus p                       { margin-bottom: 30px; }

@media (max-width: 1200px){
.table_plus                         { margin:30px 0 80px;}
}
@media (max-width:1000px) {
.table_plus .hide 					{ padding: 40px 0;}
.titre_plus                         { padding: 23px 90px 23px 30px;}
}
@media (max-width:600px) {
.table_plus 						{ margin: 20px 0 50px;}
.table_plus .sized					{ margin-bottom: 20px;}
.table_plus .hide 					{ padding: 30px 0;}
.titre_plus 						{ font-size: 13px; line-height: 23px;padding: 20px 60px 20px 20px;}
.titre_plus:before					{ display: none;}
.titre_plus:after					{ right: 20px;}
}




/***** header et menu *****/
.header 							{ width: 100%; height: 150px; font-size: 0; line-height: 0; letter-spacing: 0; position: fixed; left: 0; top: 0; z-index: 100; text-align: right; background-color: transparent; transition: all 400ms ease-in-out;}
.header .logo						{ width: 145px; position: absolute; left: 0; top: 35px; z-index: 140; transition: all 400ms ease-in-out;}
.header .logo_fav					{ margin-bottom: 5px; opacity: 1; transition: all 300ms ease-in-out;}
.header .logo_txt					{ position: relative; top: 10px; transition: all 300ms ease-in-out;}
.header .logo img					{ width: 100%; height: auto; display: block; }

.header .header_nav 				{ display: inline-block; position: relative; top: 60px;}
.header .menu>li					{ position: relative; display: inline-block; vertical-align: top; margin-right: 40px;}
.header .menu>li:last-of-type		{ margin-right: 0;}
.header .menu>li a					{ font: 500 14px/90px "Poppins"; height: 90px; display: block; color: #fff; letter-spacing: 1.2px; }
.header .menu>li.active>a			{ color: #b3c43f;}

.header .sub						{ width: 320px; margin-left: -160px; text-align: center; position: absolute; top: 95px; left: 50%; display: block; visibility: hidden; opacity: 0; padding: 20px 0; background: #bbd531; border-radius: 5px;}
.header .sub li						{ width: 100%; margin: 0;}
.header .sub li a					{ width: 100%; font-size: 14px; letter-spacing: 1.2px; line-height: 43px; height: 45px; font-weight: 400; color: #fff;}
.header .sub li.active a			{ color: #2e2e31;}

.header .menu_top                   { position: absolute; right: 0; top: 30px;}
.header .menu_top .tel              { font-size: 12px; height: 40px; line-height: 38px; letter-spacing: 1.3px; color: #fff; padding-left: 35px; background: url("../images/tel_green.svg") 0 50% no-repeat;}

.sticky .header                	    { background-color: #2e2e31;}
.sticky .header .logo_fav      	    { opacity: 0; visibility: hidden; top: -20px;}
.sticky .header .logo_txt      	    { top: -15px;}

@media (max-width:1400px) {
.header .menu>li					{  margin-right: 30px;}
}
@media (min-width:1201px) {
.header .menu>li:hover>a:after      { display: block; content: ""; width: 10px; height: 15px; background: url(../images/menu_active.svg) 50% 50% no-repeat; margin: -25px 0px 0px -5px; position: absolute; left: 50%;  opacity: 1;}
.menu_mobile 						{ display: none;}
.header .menu>li:hover .sub			{ opacity: 1; visibility: visible; z-index: 999; top: 90px;}	
.header .sub li a:hover            	{ color: #2e2e31;}
.sticky .header                	    { background-color: #2e2e31; margin-top: -60px;}
}
@media (max-width:1200px) {
.menu_mobile						{ width: 60px; height: 60px; display: inline-block; vertical-align: middle; cursor: pointer; position: relative; z-index: 250; margin: 45px -15px; transition: all 400ms ease-in-out;}
.menu_mobile div					{ width: 30px; height: 2px; background: #fff; position: absolute; right: 50%; top: 50%; margin: -1px -15px 0 0;}
.menu_mobile div:before				{ width: 100%; height: 2px; background: #fff; position: absolute; right: 0; top: 7px; content: "";}
.menu_mobile div:after				{ width: 100%; height: 2px; background: #fff; position: absolute; right: 0; top: -7px; content: "";}
.menu_mobile.active div				{ height: 0;}
.menu_mobile.active div:before		{ top: 0; transform: rotate(45deg);}
.menu_mobile.active div:after		{ top: 0; transform: rotate(-45deg);}
.header ::-webkit-scrollbar			{ display: none;}
    
.header                             { height: 150px; background-color: transparent;}
.header .header_nav			        { width: 100%; height: 100vh; position: fixed; right: -100%; top :0; overflow-y: scroll; display: grid; z-index: 200; background: #2e2e31; transition: all 400ms ease-in-out 600ms;}
.header .logo     					{ top: 10px; z-index: 70;}    


.header .menu  						{ display: block; width: 100%; text-align: left; padding: 5vw 10vw; position: relative; z-index: 100; align-self: center; opacity: 0; transform: translateY(40px); transition: all 400ms ease-in-out 200ms;}
.header .menu>li 					{ width: 100%; display: block; margin: 0;}
.header .menu>li a					{ font-size: 18px; line-height: 60px; height: 60px; transition: none;}
.header .menu>li>i					{ width: 100%; height: 40px; display: block; margin-top: -50px; position: relative; z-index: 5; float: right;}
.header .menu>li>i:after			{ width: 80px; height: 100%; background: url("../images/scrolltop.svg") 50% 52% no-repeat #b3c43f; float: right; border-radius: 5px; transform: rotate(180deg); content: "";}
.header .menu>li.active>a           { color:#b3c43f; }
   
.header .menu_top                   { position: absolute; top: 55px; right: calc(5vw + 30px); transition: top 300ms ease-in-out}    
    
.header .sub 						{ width: 100%; position: relative; left: auto; top: auto; padding: 25px 40px; margin: 15px 0; border-radius: 5px; background: #bbd531; 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: 40px; height: 40px; text-align: left; color: #171717;}

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

.sticky .header                	    { height: 90px;}
.sticky .header .logo_txt      	    { top: -55px;}
.sticky .menu_mobile				{ margin: 15px -15px; }
.sticky .header .menu_top           { top: 25px;}    
}

@media (max-width:1000px) {
.header                             { background-color: #2e2e31;}

}

@media (max-width:600px) {
.menu_mobile						{ margin: 30px -15px; transition: all 400ms ease-in-out;}
    
.header 							{ height: 120px; padding: 0; background-color: #2e2e31;}
.header .logo						{ width: 110px; top: 18px; left: 50%; transform: translateX(-50%);}
.header .logo_txt      	            { top: 5px;}
 
.header .menu  						{ padding: 140px 7.5vw 60px 7.5vw; align-self: start;}
.header .menu>li a					{ font-size: 18px; line-height: 50px; height: 50px;}
.header .menu>li i					{ width: 70px; height: 36px; margin-top: -43px;}
.header .sub 						{ padding: 15px 25px; margin: 10px 0;}
.header .sub li a					{ font-size: 13px; line-height: 35px; height: 35px;}
    
.header .menu_top                   { top: 33px; left: 0;}    
.header .menu_top .tel              { line-height: 0; font-size: 0; background: url("../images/tel_green.svg") 50% no-repeat #fff; height: 50px; width: 50px; display: block; padding: 0;}    

.sticky .header                	    { height: 80px;}
.sticky .header .menu_top           { top: 15px; left: 0;}
.sticky .header .logo_txt      	    { top: -45px;}
.sticky .menu_mobile				{ margin: 10px -15px; }
}



/***** footer*****/
.footer								{ position: relative; color: #fff; font-size: 0; padding-top: 100px; background: #2e2e31; }
.footer:before						{ content: ""; width: 200vw; height: 10px; position: absolute; top: 0; right: -50vw; left: -50vw; background-color: #bd4ba0;}
.footer .bloc_footer 				{ display: inline-block; vertical-align: top; margin: 0 80px 0 0;}
.footer .bloc_footer .sous_titre	{ font: 400 23px/30px "Poppins"; color: #b3c43f;}
.footer .bloc_footer p				{ font-size: 14px; line-height: 30px; margin-top: 15px; letter-spacing: 0.6px;}
.footer .bloc_footer p a			{ color: #fff; padding-left: 30px;}
.footer .bloc_footer p a.tel		{ background: url("../images/tel_green.svg") 0 50% no-repeat;}
.footer .bloc_footer p a.mail		{ background: url("../images/mail_green.svg") 0 50% no-repeat;}
.footer ul.bloc_footer     			{ margin: 60px 50px 0 0;}
.footer ul.bloc_footer li a 		{ font-size: 14px; line-height: 34px; padding: 5px 0 5px 20px; background: url("../images/list.svg") 0 50% no-repeat; color: #fff;}
.footer	.rs							{ position: absolute; right: 0; top: 0;}
.footer	.rs a						{ width:50px; height:50px; display:inline-block; vertical-align:middle; margin-left:10px;}
.footer	.rs .scroll 				{ background: url("../images/scrolltop.svg") 50% 48% no-repeat #b3c43f; }
.footer	.rs .facebook				{ background: url("../images/facebook.svg") 50% no-repeat #b3c43f;}
.footer	.rs .linkedin				{ background: url("../images/linkedin.svg") 50% no-repeat #b3c43f;}
.footer_bottom   					{ padding: 20px 0; line-height: 0; margin-top: 60px;}
.footer_bottom li 					{ display: inline-block; font-size: 11px; line-height: 20px; margin-right: 25px; letter-spacing: 1px; position: relative;}
.footer_bottom li a 				{ color: #fff;}
.footer_bottom li:after				{ width: 1px; height: 9px; content: ""; position: absolute; right: -13px; top: 5px; background: #b3c43f;}
.footer_bottom li:last-child:after 	{ display: none;}
.toponweb							{ display: block; z-index: 85; position: absolute; right: 0; bottom: 0; transition: bottom 400ms ease-in-out;}
.toponweb span						{ width: auto; height: 60px; display: block; padding: 20px; background: linear-gradient(to left, #000000 0% 50%, #b3c43f 50% 100%); background-size: 200% 100%; background-position: 100% 0;}
.toponweb img						{ width: 76px; height: auto; display: block; margin: 0 auto; filter: invert(1); transition: all 400ms ease-in-out;}
.toponweb.show						{ bottom: 0;}

@media (min-width:1201px) {
.footer_bottom li a:hover, 			
.footer .bloc_footer li a:hover, 
.footer .bloc_footer p a:hover	 	{ color: #b3c43f;}
.footer	.rs a:hover,
.footer	.rs .scroll:hover:after 	{ background-color: #000000;}
.toponweb:hover span				{ background-position: 0 0;}
}
@media (max-width:1200px) {
.footer								{ padding-top: 80px; background-image: none;}
.footer ul.bloc_footer     			{ display: none;}
.footer_bottom   					{ margin-top: 60px;}
}
@media (max-width:1000px) {
}
@media (max-width:600px) {
.footer								{ padding-top: 40px;}
.footer .bloc_footer 				{ width: 100%;}
.footer .bloc_footer .sous_titre	{ font-size: 18px; line-height: 26px;}
.footer .bloc_footer p				{ font-size: 12px; line-height: 22px; margin-top: 10px;}
.footer	.rs							{ position: static; margin: 30px auto;}
.footer	.rs a						{ width: 50px; height: 50px;}
.footer_bottom 	 					{ text-align: left; margin-top: 30px; padding: 0 0 20px 0;}
.footer_bottom li 					{ display: block; margin: 0; font-size: 10px; line-height: 24px;}
.footer_bottom li:after				{ display: none;}
}






