/***** fonts et reset *****/
@import url('https://fonts.googleapis.com/css?family=Poppins:300,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: 500;}
ul									{ list-style-type: none;}
body								{ font: 400 14px/30px "Poppins"; letter-spacing: 0.2px; color: #0d0d0f; background: #fff; position: relative;}
body.active_overflow				{ height: 100vh; overflow: hidden;}
a									{ text-decoration: none; color: #000; 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;}


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


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


/***** class *****/
.wrapper 							{ width: 90vw; min-width: 1080px; max-width: 1200px; margin: 0 auto; position: relative;}
.clear								{ clear: both; display: block;}
.titre_main	 						{ font: 400 40px/50px "Poppins"; position: relative; margin-bottom: 15px;}
.sous_titre 						{ font: 400 25px/35px "Poppins"; position: relative; margin-bottom: 15px;}
.chapo		 						{ font: 400 25px/34px "Poppins";color: #d90200;}
.link 								{ font: 700 12px/60px "Poppins"; letter-spacing: 1px; text-transform: uppercase; height: 60px; border: none; display: inline-block; vertical-align: middle; color: #fff; padding: 0 30px; background: linear-gradient(to top, #d90200 0%, #d90200 50%, #0d0d0f 50%,#0d0d0f 100%); background-size: 100% 200%; background-position: 0 100%; cursor: pointer; border-radius: 5px; margin-top: 20px;}
.tel 								{display: inline-block; font: 600 12px/60px "Poppins"; border: none; color: #fff; margin-left: 30px;padding-left: 25px; letter-spacing: 1px; background: url(../images/tel.svg) center left no-repeat;}
.phone                              { background-image:url(../images/phone.svg);}
.link_plus							{ display: inline-block; vertical-align: top; width: 60px; height: 60px; border-radius: 50%; background: url("../images/plus.svg") 50% no-repeat #14a5db;}

@media (min-width:1201px) {
.link:hover 						{ background-position: 0 0;}
}
@media (max-width:1200px) {
.wrapper 							{ min-width: inherit;}
.titre_main	 						{ font-size: 35px; line-height: 45px;}
}
@media (max-width:1000px) {
.wrapper 							{ max-width:750px;}
}
@media (max-width:600px) {
.wrapper 							{ width: 85vw;}
.titre_main	 						{ font-size: 28px; line-height: 38px;}
.sous_titre							{ font-size: 20px; line-height: 35px;}
}


.header 	    					{ width: 100%; font-size: 0; line-height: 0; text-align: right; position: fixed; left: 0; top: 0; z-index: 200; transition: all 400ms ease-in-out;}
.header .logo .texte                { font: 500 25px/30px "Poppins";color: #102433;padding-left: 30px; text-transform: uppercase;} 
.header .logo                       { position: absolute; left: 0; top: 60px; z-index: 300; display: grid; grid-template-columns: auto auto; align-items: center;}

.header .logo h1, .header .logo span {font: 700 13px/13px "Poppins"; color: #d90200; text-transform: uppercase; letter-spacing: .7px; margin-top: 8px; display: block;}


.menu_mobile                        { display: none;}
.header .logo .texte span           { font-size: 15px;line-height: 20px;display: block; }
.header .logo img					{ width: auto; height: auto;}
.header_top                         { background: #0d0d0f;}
.header_top a.tel:last-child        { margin-right: 0; }
.header_right .link					{ font-size: 15px; line-height: 54px; height: 50px; padding: 0; width: 160px; text-align: center;}
.header_nav							{ display: inline-block; vertical-align: middle;padding-right: 50px;z-index: 50; background: #ffe402; width: 100%;}
.header_nav .menu					{ position: relative;}	
.header_nav .menu li				{ display: inline-block; vertical-align: middle; position: relative; margin-left: 35px;}	
.header_nav .menu li a				{ font: 700 13px/90px "Poppins"; text-transform: uppercase; height: 90px; display: block; transition-property: color,background, height, line-height; letter-spacing: 1px;}
.header_nav .menu>li.active>a 		{ color: #d90200;}
.header_nav .sub					{ width: 285px; text-align: center; position: absolute; top: 100%; left: 50%; margin-left: -140px; display: block; visibility: hidden; opacity: 0; background: #d90200;}
.header_nav .sub.sized				{ width: 280px; margin-left: -140px;}
.header_nav .sub li					{ width: 100%; margin: 0; transition: all ease-in-out 400ms;}
.header_nav .sub li a				{ width: 100%; font: 400 14px/50px "Poppins"; text-transform: inherit; letter-spacing: 0.2px; height: 50px; color: #ffffff;}
.header_nav .menu li:hover .sub		{ opacity: 1; visibility: visible; z-index: 999; top: 100%;}
.header_nav .menu .sub li.active a	{ color: #000;}
.sticky .header 					{ box-shadow: 0 0 30px 0 rgb(0 0 0 / 10%);}
@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: #d90200; }
.header_nav .sub li a:hover			{ background: #0d0d0f;}
.header_top  a.tel:hover            { color: #d90200; }
.header .wrapper                    { transition: all ease-in-out 400ms;}
.sticky .header                     { top: -60px;}
.sticky .header .wrapper            { width: 100%;max-width: 100%;}
.sticky .header_nav .menu>li>a		{ line-height: 90px; height: 90px;}
}
@media (max-width:1200px) {
.header .logo div:nth-child(1) img  { height: 80px;}
.header .wrapper                    { width: 100%;max-width: none; margin: auto;}
.menu_mobile						{ width: 60px; height: 60px; display: inline-block; vertical-align: middle; cursor: pointer; position: relative; margin: 10px -15px; transition: margin 400ms ease-in-out; margin-right:calc(5vw - 15px) }
.menu_mobile div					{ width: 30px; height: 2px; background: #0d0d0f; position: absolute; right: 50%; top: 50%; margin: -1px -15px 0 0;}
.menu_mobile div:before				{ width: 100%; height: 2px; background: #0d0d0f; position: absolute; right: 0; top: 8px; content: "";}
.menu_mobile div:after				{ width: 100%; height: 2px; background: #0d0d0f; position: absolute; right: 0; top: -8px; 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_nav .menu li i				{ width: 100%; height: 50px; position: absolute; left: 0; top: 0;}
.header_nav .menu li i:after		{ width: 10px; height: 10px; transform: rotate(45deg); position: absolute; left: 50%; bottom: -20px; margin-left: -5px; opacity: 0; transition: all 300ms ease-in-out; background: #d90200; content: "";}
.header_nav .menu li i.active:after	{ opacity: 1;}
.header 							{ background: #ffe402; transition: all ease-in-out 400ms; top: 0; height: 140px;}
.header_right 						{ position: relative; display: block; margin: 0;z-index: 200;}
.header_top     					{ padding-right: 5vw;}
.header_nav 	  					{ width: 100%; height: 100vh; padding: 0; position: fixed; right: 100%; top :0; overflow-y: scroll; display: grid; z-index: 100; padding-top: 80px; transition: 0ms ease-in-out 400ms; background: none;}
.header_nav::-webkit-scrollbar		{ display: none;}
.header_nav .menu  					{ width: 100%; text-align: center; padding: 5vw; position: relative; z-index: 100;  align-self: center; opacity: 0; transform: translateY(40px); transition: all 400ms ease-in-out 0ms;}
.header_nav .menu li 				{ width: 100%; display: block; margin: 0;}
.header_nav .menu li a				{ font-size: 16px; line-height: 54px; ; height: 50px;}
.header_nav .menu .sub 				{ width: auto; visibility: visible; position: relative; left: auto; top: auto; padding: 25px 0; margin: 15px 0; opacity: 1; display: none;}
.header_nav .menu .sub li a			{ font-size: 16px; line-height: 42px; height: 40px;}
/* active menu mobile */
.header.active 						{ height: calc(60px + 100vh);}
.header_nav.active					{ right: 0; transition-delay: 0ms;}
.header_nav.active .menu			{ opacity: 1; transform: translateY(0); transition-delay: 400ms;}
}
@media (max-width:1000px) {
.header                             { top: -60px;}
.header_right                       { padding-right: 5vw;}
.header_top                         { padding: 0;}
.menu_mobile                        { margin: 20px -15px;}
.header_top .tel                    { top: 75px; background-color: #0d0d0f; background-position: center; width: 50px;line-height: 50px; font-size: 0; border-radius: 5px;margin-right: 10px;}
.header .tel                        { right: 5vw;}
.header .phone                      { display: none;}
}
@media (max-width:600px) {
.header_top                         { margin-right: 20px;}
.header_right 						{ padding-right: 7.5vw;}
.header_nav .menu  					{ padding: 7.5vw;}
.header_nav .menu>li>a				{ font-size: 14px; line-height: 48px; ; height: 44px;}
.header_nav .menu li i				{ height: 44px;}
.header .logo						{ left: -40px;}
.header .logo div:nth-child(2) img  { width: 100%;}
.header .logo h1, .header .logo span { font-size: 10px;}
.header .logo {    grid-template-columns: auto 180px;}
}
@media (max-width:450px) {
.header .logo						{ left: -50px;}
.header .logo div:nth-child(2) img  { width: 90%;}
.header .logo h1, .header .logo span { font-size: 8px;}
.header .logo {    grid-template-columns: auto 130px;}
}

/***** Bandeau *****/
.bandeau                            { margin: 120px 0;padding: 45px 30px;background: url(../images/drapeau.svg) no-repeat top left/contain #0d0d0f;font-size: 20px;color: #fff;text-align: center;
}
.bandeau a                          { color: #ffe402; display: inline-block;}
@media (min-width: 1200px) {
.bandeau a:hover                    { color: #d90200;}
}
@media (max-width: 1000px) {
.bandeau                            { background: #0d0d0f; font-size: 16px; margin: 70px 0;}
}
@media (max-width: 600px) {
.bandeau                            { margin: 0 -7.5vw 60px; padding: 35px 40px;}
}
.partenaires                        { background: #f0f0f0; padding: 100px 0;}
.partenaires .slider                { margin: 0 -15px;}
.partenaires .item                  { background: #fff; display: grid; margin: 0 15px; place-items: center;}
.partenaires .item img              { width: 100%;}
@media (max-width: 1200px) {
.partenaires                         { padding: 50px 0;}
}
@media (max-width:1000px) {
.partenaires .slider                { margin: 0 -5px;}
.partenaires .item                  { margin: 0 5px; place-items: center;}
}
/***** footer*****/
.footer								{ width: 100%; position: relative; padding-top: 80px; background: #0d0d0f; color: #fff; font-size: 0;}
.footer .logo                       { width:auto;height: auto; display: block;margin: 0;}
.footer .bloc_footer 				{ display: inline-block; vertical-align: top; margin-right: 120px; line-height: 30px; margin-top: 40px;}
.footer .tel:before                 { display: none;}
.footer .bloc_footer.last			{ margin-right: 0;}
.footer .bloc_footer p				{ font-size: 14px;}
.footer .bloc_footer p b			{ display: block; font: 400 18px/24px "Poppins"; color:#d90200; margin-bottom: 5px;}
.footer .phone,.footer .tel         { margin: 0; font-weight: 400;}
.footer .phone::before              { display: none;}
.footer .bloc_footer p a			{ color: #fff; padding-left: 30px; font: 400 14px/40px "poppins"; letter-spacing: 0.2px;}
.footer .bloc_footer p .phone         { background: url(../images/phone.svg) left center no-repeat;}
.footer .bloc_footer p .tel         { background: url(../images/tel.svg) left center no-repeat;}
.footer .bloc_footer p .mail        { background: url(../images/mail.svg) left center no-repeat;}
.footer .bloc_footer p span			{ display: inline-block;}
.footer .bloc_footer ul				{ margin-top: 5px; display: inline-block;vertical-align: top; margin-right: 40px;}
.footer .bloc_footer li a			{ font-size: 14px; color: #fff; margin-top: 10px; background:url(../images/list.svg) 0 48% no-repeat; padding-left: 20px; display: inline-block;}
.footer	.rs							{ position: absolute; right: 0; top: 0; display: grid; justify-items: end;}
.footer	.rs a						{ width: 50px; height: 50px; display: block; border-radius: 50%;}
.footer	.rs .facebook			    { background: url(../images/facebook.svg) no-repeat center left 20px #fff; color: #3b5998; width: auto; height: auto; border-radius: 5px; font: 600 14px/24px "Poppins"; padding: 15px 25px 15px 75px; margin-top: 30px;}
.footer .rs .facebook span          { font: 600 25px/25px "Poppins";display: block;}
.footer	.rs .scroll					{ background: url(../images/scrolltop.svg) 50% 46% no-repeat #363636; margin: 0;}
.footer_bottom   					{ padding: 20px 0; line-height: 0; margin-top: 55px;}
.footer_bottom li 					{ display: inline-block; font-size: 12px; line-height: 20px; margin-right: 35px; letter-spacing: 0.2px; position: relative;}
.footer_bottom li a 				{ color: #fff;}
.footer_bottom li:after				{ width: 1px; height: 9px; content: ""; position: absolute; right: -18px; top: 5px; background: #d90200;}
.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, #363636 0%, #363636 50%, #d90200 50%,#d90200 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: #d90200;}
.footer	.rs .scroll:hover           { background-color: #d90200;}
.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: 40px 0 0;}
.footer .bloc_footer p              { margin: 0;}
.footer_bottom   					{ margin-top: 80px;}
}
@media (max-width:600px) {
.footer								{ padding-top: 45px;}
.footer .logo						{ width: 225px; margin-bottom: 0;}
.footer .bloc_footer 				{ margin: 40px 0 0;}
.footer .bloc_footer p b			{ font-size: 18px; line-height: 20px; margin-bottom: 20px;}
.footer	.rs							{ position: static; margin-top: 35px; display: block; }
.footer	.rs	.scroll        			{position: absolute; top: 0; right: 0; }
.footer	.rs	.facebook   			{ width: max-content; }
.footer_bottom 	 					{ text-align: left; margin-top: 40px; padding: 0 0 40px 0;}
.footer_bottom li 					{ display: block; margin-right: 0; line-height: 25px;}
.footer_bottom li:after				{ display: none;}
}
@media (max-width:350px) {
.footer .logo						{ width: 150px;}
}




