/***** fonts et reset *****/
@font-face { font-family: "Poppins"; src: url("../font/Poppins-Bold.ttf"); font-weight: 700; font-style: normal; }
@font-face { font-family: "Poppins"; src: url("../font/Poppins-BoldItalic.ttf"); font-weight: 700; font-style: italic; }
@font-face { font-family: "Poppins"; src: url("../font/Poppins-Italic.ttf"); font-weight: 400; font-style: italic; }
@font-face { font-family: "Poppins"; src: url("../font/Poppins-Regular.ttf"); font-weight: 400; font-style: normal; }
@font-face { font-family: "Poppins"; src: url("../font/Poppins-Medium.ttf"); font-weight: 500; font-style: normal; }
@font-face { font-family: "Poppins"; src: url("../font/Poppins-MediumItalic.ttf"); font-weight: 500; font-style: italic; }
@font-face { font-family: "Poppins"; src: url("../font/Poppins-SemiBold.ttf"); font-weight: 600; font-style: normal; }
@font-face { font-family: "Poppins"; src: url("../font/Poppins-SemiBoldItalic.ttf"); font-weight: 600; font-style: italic; }
@font-face { font-family: "klavika"; src: url("../font/KlavikaMedium-TF.ttf");}

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;}
ul									{ list-style-type: none;}
body								{ font: 400 14px/30px "poppins"; letter-spacing: 0.5px; color: #333e45; background: #fff; position: relative;}
body.active_overflow				{ height: 100vh; overflow: hidden;}
a									{ text-decoration: none; color: #000; position: relative;}
p>a						            { color: #2dab66; border-bottom: 1px solid transparent; padding-bottom: 2px;}
p                                   { margin-bottom: 20px;}
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;}


/***** scollbar *****/
::-webkit-scrollbar 				{ width: 8px; height: 8px; background-color: #eee;}
::-webkit-scrollbar-thumb			{ background-color: #333e45;}


/***** transition *****/
@media (min-width:1201px) {
.link, .slick-arrow, :before, :after, a, a span, .sub { transition: all 400ms ease-in-out;}
p>a:hover                          { border-color: #2dab66;}
}


/***** class *****/
.wrapper 							{ width: 90vw; min-width: 1080px; max-width: 1200px; margin: 0 auto; position: relative;}
.clear								{ clear: both; display: block;}
.titre_main	 						{ font: 400 45px/60px "poppins"; position: relative; margin-bottom: 15px; color: #333e45; letter-spacing: 0.2px;}
.sous_titre 						{ font: 400 30px/38px "poppins"; position: relative; margin-bottom: 15px; color: #2dab66; letter-spacing: 0.2px;}
.chapo		 						{ font: 500 16px/30px "poppins"; letter-spacing: 0.5px; color: #2dab66;}
.link 								{ font: 600 12px/60px "poppins"; letter-spacing: 0.5px; text-transform: uppercase; height: 60px; border: none; display: inline-block; vertical-align: middle; color: #fff; padding: 0 30px; background: linear-gradient(to top, #2dab66 0%, #2dab66 50%, #333e45 50%, #333e45 100%); background-size: 100% 200%; background-position: 0 100%; cursor: pointer; text-align: center;}
.tel 								{ font: 500 15px/60px "poppins"; letter-spacing: 0.2px; text-transform: uppercase; height: 60px; border: none; display: inline-block; vertical-align: middle; color: #fff; padding: 0 30px; background-image: linear-gradient(to top, #2dab66 0%, #2dab66 50%, #333e45 50%, #333e45 100%);}
.tel:before                         { content:url(../images/tel.svg); display: inline-block; vertical-align: middle; margin-right: 15px; position: relative;top: -2px; line-height: 0;}
.link_plus							{ display: block; width: 60px; height: 60px; border-radius: 50%; background: url("../images/plus.svg") 50% no-repeat #14a5db;}
.intro 								{ text-align: center; margin: 170px 0 100px; background: #f0f0f0;}
.intro p						    { padding: 70px 90px;}
@media (max-width:1000px) {
.intro 								{ margin: 80px 0;}
}
@media (max-width:600px) {
.intro 								{ display: none;}
}
@media (min-width:1201px) {
.tel:hover,
.link:hover 						{ background-position: 0 0;}
.link_plus:hover					{ background-color: #007ead;}
}
@media (max-width:1200px) {
.wrapper 							{ min-width: inherit;}
}
@media (max-width:1000px) {
.wrapper 							{ max-width:750px;}
}
@media (max-width:600px) {
.titre_main	 						{ font-size: 25px; line-height: 35px; color: #2dab66;}
.sous_titre							{ font-size: 25px; line-height: 35px;}
.wrapper 							{ width: 85vw;}
body                                { font-size: 12px;}
.link        						{ font-size: 12px;}
.tel:before                         { display: none;}
}



/***** header et menu *****/
.header 							{ width: 100%; font-size: 0; line-height: 0; text-align: right; position: fixed; left: 0; top: 0; z-index: 100; transition: all 400ms ease-in-out;}
.header .wrapper 					{ background: #fff;}
.header .logo						{ width: 240px; height: 100%; padding: 0 60px 0 0; background: #fff; position: absolute; left: 0; bottom: 0; z-index: 90; transition: all 400ms ease-in-out;}
.header .logo img					{ width: 100%; height: auto; display: block; transition: all 400ms ease-in-out 0ms;}


.menu_top                 			{ display: none;}
.menu_top li            			{ display: inline-block; vertical-align: middle; position: relative; padding-right: 30px;}
.menu_top li::after               	{ content: ""; width: 1px; height: 10px; display: inline-block; position: absolute; right: 15px; top: 50%; background: #333e45; transform: translateY(-50%);}
.menu_top li:last-child           	{ padding: 0;}
.menu_top li:last-child::after    	{ display: none;}
.menu_top li:nth-child(3)          	{ padding: 0;}
.menu_top li:nth-child(3)::after    { display: none;}
.menu_top li a          			{ font: 400 12px/50px "Poppins"; letter-spacing: 0.5px; height: 50px; display: block; transition-property: all; color: #333e45;}
.menu_top>li.active>a   			{ color: #2dab66;}

.header_right 						{ position: absolute; bottom: 0; right: 0;}
.header_right .link					{ width: 190px; text-align: center;}

.header_nav                         { transition: all ease-in-out 400ms;}

.header_nav	.menu					{ display: block; z-index: 50; background: #283136; margin-top: 50px; padding: 0 50px; transition: all ease-in-out 400ms; margin-right: 190px; position: relative;}
.header_nav .menu li				{ display: inline-block; vertical-align: middle; position: relative; margin-left: 45px;}	
.header_nav .menu li a				{ font: 600 14px/58px "Poppins"; height: 60px; text-transform: uppercase; letter-spacing: 0.6px; display: inline-block; color: #fff;}
.header_nav .menu li.big_link		{ position: absolute; right: -190px;}
.header_nav .menu>li.active>a 		{ color: #2dab66;}

.header_nav .sub					{ width: 360px; text-align: center; position: absolute; top: calc(100% + 1px); left: 50%; margin-left: -180px; display: block; visibility: hidden; opacity: 0; background: #283136; padding: 15px 0;}
.header_nav .sub.sized				{ width: 280px; margin-left: -140px;}
.header_nav .sub li					{ width: 100%; margin: 0;}
.header_nav .sub li a				{ width: 100%; font: 400 12px/38px "Poppins"; text-transform: inherit; letter-spacing: 0.4px; height: 40px; color: #fff;}
.header_nav .menu li:hover .sub		{ opacity: 1; visibility: visible; z-index: 999;}
.header_nav .menu .sub li.active a	{ color: #2dab66;}

.sticky .header 					{ box-shadow: 0 0 30px 0 rgb(0 0 0 / 10%);}
.sticky .header .menu				{ margin-top: 0;}

@media (min-width:1201px) {
.header_nav .menu .vue_mobile,
.menu_mobile 						{ display: none;}
.header_nav .sub 					{ display: block !important;}
.header_nav .menu>li:hover>a		{ color: #2dab66;}
.header_nav .sub li a:hover	        { color: #2dab66;}
.menu_top li:hover>a    			{ color: #2dab66;}
.sticky .header .logo          		{ padding-top: 10px; }
.sticky .header .logo img      		{ width: 70%;}
.sticky .header                     { background: #fff;}

/*
.sticky .header_nav .menu>li>a		{ height: 70px; line-height: 68px;}
.sticky .header_right .link         { height: 70px; line-height: 68px}
*/

.header_right .link.tel,
.header .mobile     				{ display: none;}
}

@media (max-width:1400px) {
.header_nav .menu .no_small_desk    { display: none;}	
    
}
@media (min-width:1400px) {
.header_nav .menu .no_small_desk	{ display: block;}	
    
}

@media (max-width:1200px) {
.menu_mobile						{ width: 60px; height: 60px; display: inline-block; vertical-align: middle; cursor: pointer; position: relative; margin: 20px -10px; transition: margin 400ms ease-in-out;}
.menu_mobile div					{ width: 40px; height: 2px; background: #2dab66; position: absolute; right: 50%; top: 50%; margin: -1px -20px 0 0;}
.menu_mobile div:before				{ width: 100%; height: 2px; background: #2dab66; position: absolute; right: 0; top: 10px; content: "";}
.menu_mobile div:after				{ width: 100%; height: 2px; background: #2dab66; position: absolute; right: 0; top: -10px; content: "";}
.menu_mobile.active div				{ height: 0;}
.menu_mobile.active div:before		{ top: 0; transform: rotate(-135deg);}
.menu_mobile.active div:after		{ top: 0; transform: rotate(-45deg);}
.header 							{ height: 100px; background-color: #fff; transition: box-shadow 400ms ease-in-out, background-color 400ms ease-in-out 400ms, height 400ms ease-in-out 400ms;}
.header .logo						{ top: 25px; padding: 0; height: auto; transform: none; z-index: 120;}
.header .logo img					{ width: 160px;}
.header_right 						{ position: relative; margin: 0; z-index: 100;}
.header_right .link					{ margin-right: 5vw;}
    
.header_nav         				{ width: 100%; height: 100vh; padding: 0; position: fixed; right: 100%; top :0; overflow-y: scroll; z-index: 100; padding-top: 80px; transition: 0ms ease-in-out 400ms; display: grid; align-content: center;}
.header_nav::-webkit-scrollbar		{ display: none;}
.header_nav .menu  					{ width: 100%; text-align: left; position: relative; z-index: 100; align-self: center; opacity: 0; transform: translateY(40px); padding: 0 10vw; transition: all 400ms ease-in-out 0ms; background: none;}
.header_nav .menu li 				{ width: 100%; display: block; margin: 0;}
.header_nav .menu li.big_link		{ position: relative; right: inherit; }
.header_nav .menu li.big_link a		{ padding: 0; background: none; }
    
.header_nav .menu li a				{ font-size: 16px; line-height: 54px; height: 50px; color: #333e45}
.header .menu>li>i					{ width: 60px; height: 54px; display: block; position: relative; z-index: 25; background: url("../images/arrow_select.svg") 50% no-repeat #eee; float: right;}
.header_nav .menu li i:after		{ display: none;}
.header_nav .menu li i.active:after	{ opacity: 1;}
.header .menu .sub 					{ width: 100%; position: relative; left: auto; top: auto; padding: 15px 0; margin: 0 0 10px 0; visibility: visible; opacity: 1; display: none; transition: none;}
.header .menu .sub li  				{ width: 100%;}
.header .menu .sub li a				{ font-size: 16px; line-height: 46px; height: 46px; text-align: left; padding: 0 30px; background-position: right+25px center; color: #fff;}

.menu_top li a          	        { font-size: 16px; font-weight: 600; text-transform: uppercase; line-height: 54px; height: 50px; color: #333e45;}
.menu_top li           				{ display: block; padding: 0; text-align: center;}
.menu_top li::after     			{ display: none;}
/* active menu mobile */
.header.active 						{ height: 100vh; background-color: #fff; transition-delay: 0ms;}
.header_nav.active					{ right: 0; transition-delay: 0ms;}
.header_nav.active .menu_top,
.header_nav.active .menu			{ opacity: 1; transform: translateY(0); transition-delay: 400ms;}
.header_right .link.form     		{ display: none;}
.header_right .link  	     		{ width: 200px; }

}

@media (max-width:1000px) {
.header .logo						{ top: 25px;}
.header .logo img					{ height: 50px; width: auto;}
}

@media (max-width:600px) {
.header 							{ height: 80px;}
.header .menu .sub li a				{ font-size: 14px; }
.header .logo						{ width: auto; height: 40px; left: 50%; transform: translateX(-50% );}
.header .logo img					{ height: 40px;}
.header_right .link					{ width: 50px; height: 50px; font-size: 0; background: url("../images/tel.svg") 50% #2dab66 no-repeat; position: absolute; left: 0; top: 15px; margin: 0; padding: 0;}

.menu_mobile						{ margin: 10px -10px;}
.header_nav .menu  					{ padding: 0 7.5vw;}
.menu_top li a, 					
.header_nav .menu>li>a				{ font-size: 14px; line-height: 46px; height: 48px;}
.header_nav .menu li i				{ height: 44px;}
}



/***** bandeau téléphone *****/
.vers_site                          { background: #f1f1f1; padding: 45px 30px 60px; text-align: center; font-size: 18px; margin: 170px 0 130px; position: relative; z-index: 30;}
.vers_site::before                  { content: url(../images/services.svg); position: absolute; top: -35px; transform: translateX(-50%);}
.vers_site .link                    { position: absolute; bottom: -30px; transform: translateX(-50%)}
.vers_site p                        { margin: 0;}
@media (max-width:1000px) {
.vers_site                          { margin:50px 0 80px;}
}
@media (max-width:600px) {
.vers_site                          { font-size: 16px; padding: 40px 20px 30px;margin:80px 0 110px;}
.vers_site .link                    { width: 100%; bottom: -60px; transform: none;left: 0;}
}
/***** footer*****/
.footer								{ width: 100%; position: relative; padding-top: 100px; background: #333e45; color: #fff; font-size: 0;}
.footer .logo                       { display: block; width: 200px; margin-bottom: 20px;}
.footer .bloc_footer 				{ display: inline-block; vertical-align: top; margin-right: 100px; line-height: 30px;}
.footer .tel:before                 { display: none;}
.footer .bloc_footer.last			{ margin-right: 0;}
.footer .bloc_footer p				{ font-size: 14px; margin-top: 10px; margin-bottom: 10px;}
.footer .bloc_footer p b			{ display: block; font: 400 20px/30px "Poppins"; color:#fff; margin-bottom: 5px;}
.footer .bloc_footer p a			{ color: #fff;}
.footer .bloc_footer p .mail        { color: #2dab66;}
.footer .bloc_footer .link          { margin-top: 20px; font-size: 14px;background: linear-gradient(to top, #2dab66 0%, #2dab66 50%, #fff 50%, #fff 100%);background-position: 0 100%;background-size: 100% 200%;}
.footer .bloc_footer p span			{ display: inline-block;}
.footer .bloc_footer ul				{ margin-top: 5px; display: inline-block;vertical-align: top; margin-right: 70px;}
.footer .bloc_footer li a			{ font-size: 14px; color: #fff; margin-top: 3px; background:url(../images/list.svg) 0 48% no-repeat; padding-left: 25px; display: inline-block;}
.footer .rs							{ position: absolute; right: 0; top: 0;}
.footer	.rs a						{ display: inline-block; vertical-align: top; margin-right: 10px;}
.footer	.reseaux a					{ display: block; vertical-align: top; margin-top: 10px;}
.footer .reseaux 		 			{ margin-top: 0;} 
.footer .reseaux .cadres 			{ font: 500 14px/20px "klavika"; padding: 10px 30px 10px 75px; text-align: left;} 
.footer	.reseaux .facebook			{ background: url(../images/facebook.svg) no-repeat  center left 20px #fff; color: #3b5998;} 
.footer	.reseaux .instagram			{ background: url("../images/instagram.svg") no-repeat  center left 20px #fff; color: #A8164D;} 
.footer .reseaux .instagram span,
.footer .reseaux .facebook span     { font-size: 22px; display: block;}
.footer	.rs .scroll					{ background: url(../images/scrolltop.svg) 50% 46% no-repeat #fff; margin: 0; width: 60px; height: 60px;}
.footer_bottom   					{ padding: 20px 0; line-height: 0; margin-top: 90px;}
.footer_bottom li 					{ display: inline-block; font-size: 12px; line-height: 26px; margin-right: 25px; letter-spacing: 0.2px; position: relative;}
.footer_bottom li a 				{ color: #fff;}
.footer_bottom li:after				{ width: 1px; height: 9px; content: ""; position: absolute; right: -13px; top: 7px; background: #2dab66;}
.footer_bottom li:last-child:after 	{ display: none;}
.toponweb							{ display: block; z-index: 85; position: fixed; right: 0; bottom: -65px; transition: bottom 400ms ease-in-out;}
.toponweb span						{ width: auto; height: 60px; display: block; padding: 20px; background: linear-gradient(to left, #21282d 0%, #21282d 50%, #283136 50%, #283136 100%); background-size: 200% 100%; background-position: 100% 0;}
.toponweb img						{ width: 74px; height: auto; display: block; margin: 0 auto;}
.toponweb.show						{ bottom: 0;}

@media (min-width:1201px) {
.footer .bloc_footer p a:hover,
.footer .bloc_footer li a:hover,
.footer_bottom li a:hover			{ color: #2dab66;}
.footer	.rs .scroll:hover			{ background-color: #21282d;}
.footer	.rs .facebook:hover			{ background-color: #21282d;}
.footer .bloc_footer .link:hover   { background-position: 0 0; color: #2dab66;}
.toponweb:hover span				{ background-position: 0 0;}
}
@media (max-width:1200px) {
.footer .bloc_footer 				{ margin-right: 80px;}
.footer .bloc_footer.last			{ display: none;}
.toponweb                           { position: absolute;}
}
@media (max-width:1000px) {
.footer .bloc_footer 				{ display: block; margin: 0;}
.footer .bloc_footer p              { margin: 0 0 10px;}
.footer_bottom   					{ margin-top: 80px;}
.footer	.reseaux a					{ display: inline-block; margin-top: 35px; margin-right: 10px;}

}
@media (max-width:600px) {
.footer								{ padding-top: 60px; text-align: center;}
.footer .logo						{ width: 160px; margin: 0 auto 35px;}
.footer .bloc_footer 				{ margin: 0; }
.footer .bloc_footer p b			{ margin-bottom: 20px; font-size: 18px;}
.footer .bloc_footer p  			{ font-size: 12px;}
.footer .bloc_footer .link          { min-width: 200px; margin-top: 20px; font-size: 12px;}
.footer	.rs							{ position: static; margin-top: 10px;}
.footer	.reseaux 					{ margin-top: 30px;}
.footer	.reseaux a					{ display: block; width: 210px; margin: 10px auto}
.footer	.reaseaux .facebook   		{ margin: 0;padding-right: 24px;}
.footer	.rs	.scroll					{ display: none;}
.footer_bottom 	 					{ text-align: left; margin-top: 40px; padding: 0 0 30px 0;}
.footer_bottom li 					{ display: block; margin-right: 0; line-height: 25px; font-size: 11px;}
.footer_bottom li:after				{ display: none;}
}
@media (max-width:350px) {
.footer .logo						{ width: 150px;}
}




