/***** fonts et reset *****/
@import url('https://fonts.googleapis.com/css2?family=Ubuntu:wght@400;500;700&display=swap');
@import url("https://use.typekit.net/nwe5jff.css");

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: 17px;}
ul									{ list-style-type: none;}
body								{ font: 400 16px/30px "Ubuntu"; letter-spacing: 0.4px; color: #1d2a4e; background: #fff; position: relative;}
body.active_overflow				{ height: 100vh; overflow: hidden;}
a									{ text-decoration: none; color: #1d2a4e; 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: 14px; line-height: 26px;}
strong, b							{ font-size: 15px;}
}


/***** scollbar *****/
::-webkit-scrollbar 				{ width: 6px; height: 6px; background-color: #fff;}
::-webkit-scrollbar-thumb			{ background-color: #1d2a4e;}


/***** 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: 1200px; margin: 0 auto; position: relative;}
.wrapper_large						{ max-width: 1600px;}
.clear								{ clear: both; display: block;}
.anchor								{ position: absolute; left: 0; top: -140px;}
.titre_main	 						{ font: 400 55px/60px "masqualero"; letter-spacing: 0.2px; position: relative; margin-bottom: 15px;}
.titre_main.smaller					{ font-size: 40px; line-height: 45px;}
.titre 								{ font: 400 25px/30px "Ubuntu"; margin-bottom: 15px;}
.sous_titre 						{ font: 400 25px/35px "Ubuntu"; position: relative; margin-bottom: 15px;}
.chapo		 						{ font: 400 16px/30px "Ubuntu"; margin-bottom: 15px;}
.chapo span	 						{ display: block; margin-top: 15px;}
.link 								{ font: 700 13px/58px "Ubuntu"; text-transform: uppercase; letter-spacing: 0.8px; height: 60px; border-radius: 5px; display: inline-block; color: #fff; padding: 0 30px; background: linear-gradient(to top, #1d2a4e 0% 50%, #2f406c 50% 100%); background-size: 100% 200%; background-position: 0 100%;}
.short_bloc 						{ max-width: 980px; margin: 0 auto; position: relative;}

@media (min-width:1201px) {
.link:hover 						{ background-position: 0 0; color: #fff;}
}
@media (max-width:1600px) {
.titre_main	 						{ font-size: 50px; line-height: 55px;}
.titre_main.smaller					{ font-size: 35px; line-height: 40px;}
.titre 								{ font-size: 22px;}
.sous_titre 						{ font-size: 22px;}
}
@media (max-width:1400px) {
.titre_main	 						{ font-size: 45px; line-height: 50px;}
}
@media (max-width:1200px) {
.wrapper 							{ min-width: inherit;}
.titre_main	 						{ font-size: 40px; line-height: 45px;}
.titre_main.smaller					{ font-size: 30px; line-height: 35px;}
.titre     	 						{ font-size: 20px; line-height: 28px;}
.sous_titre 						{ font-size: 20px; line-height: 28px;}
}
@media (max-width:1000px) {
.wrapper 							{ max-width: 750px;}
.titre_main	 						{ font-size: 30px; line-height: 35px;}
.titre_main.smaller					{ font-size: 25px; line-height: 30px;}
/*
.titre     	 						{ font-size: 18px; line-height: 26px;}
.sous_titre 						{ font-size: 18px; line-height: 26px;}
*/
}
@media (max-width:600px) {
.wrapper 							{ width: 85vw;}
.titre_main	 						{ font-size: 24px; line-height: 30px; margin-bottom: 10px;}
.titre_main.smaller					{ font-size: 20px; line-height: 26px;}
.titre     	 						{ font-size: 16px; line-height: 24px; margin-bottom: 10px; font-weight: 500;}
.sous_titre 						{ font-size: 16px; line-height: 24px; margin-bottom: 10px; font-weight: 500;}
.chapo		 						{ font-size: 14px; line-height: 26px; margin-bottom: 10px;}
.chapo span	 						{ margin-bottom: 10px;}
.link 								{ font-size: 11px; line-height: 50px; height: 50px; padding: 0 25px;}
}




/***** header et menu *****/
.header 								{ width: 100%; font-size: 0; line-height: 0; letter-spacing: 0; position: fixed; left: 0; top: 0; z-index: 100; padding: 20px 0; text-align: right; background: #fff; transition: all 300ms ease-in-out;}
.header .logo							{ display: grid; grid-template-columns: auto auto; grid-gap: 20px; align-items: center; position: absolute; left: 0; top: -20px; z-index: 205; transition: all 300ms ease-in-out;}
.header .logo img						{ width: 100%; height: auto; display: block; transition: all 300ms ease-in-out;}
.header .logo img:first-child			{ width: 110px; background: #1d2a4e; padding: 13px 14px;}
.header .logo img:last-child			{ width: 150px;}

/* menu */
.header .header_nav 					{ display: block; position: relative;}
.header .menu>li						{ display: inline-block; vertical-align: middle; margin-left: 35px; position: relative;}
.header .menu>li:last-child				{ margin-left: 50px;}
.header .menu>li a:not(.link)			{ font: 700 13px/70px "Ubuntu"; text-transform: uppercase; letter-spacing: 0.8px; height: 70px; display: block; color: #1d2a4e;}
.header .menu>li.active>a				{ color: #e8ab56;}

.header .menu .sub						{ width: 220px; text-align: center; position: absolute; top: 80%; left: 50%; margin-left: -110px; display: block; background: #fff; opacity: 0; visibility: hidden; border-radius: 5px; box-shadow: 0 5px 30px 0 rgb(0 0 0 / 10%); padding: 20px 30px;}
.header .menu .sub li a					{ text-transform: none; font-size: 16px; font-weight: 500; line-height: 40px; height: auto; letter-spacing: 0.6px;}
.header .menu .sub li:last-child a		{ border-bottom: 0;}
.header .menu .sub li.active a			{ color: #e8ab56;}

@media (min-width:1201px) {
.menu_mobile 							{ display: none;}
.header .menu_top>li a:hover,
.header .menu>li:hover>a:not(.link),	
.header .sub li a:hover 				{ color: #e8ab56;}
.header .menu>li:hover .sub				{ opacity: 1; visibility: visible; z-index: 999;}

.sticky .header							{ padding: 10px 0; box-shadow: 0 5px 40px 0 rgb(0 0 0 / 10%);}
.sticky .header .logo					{ top: -10px;}
.sticky .header .logo img:first-child 	{ background: #1d2a4e; padding: 13px 14px; width: 90px;}
.sticky .header .logo img:last-child 	{ width: 120px;}
.sticky .header .link 					{ line-height: 52px; height: 54px;}
}
@media (max-width:1300px) {
.header .menu>li						{ margin-left: 30px;}
.header .menu>li:last-child				{ margin-left: 40px;}

}
@media (max-width:1200px) {
.header 								{ padding: 0; background: none;}
.header:before							{ width: 100%; height: 0; background: #fff; position: absolute; left: 0; top: 0; transition: all 300ms ease-in-out;  content: "";}
.sticky .header:before 					{ height: 100%; /*box-shadow: 0 0 40px 0 rgb(0 0 0 / 10%);*/}

.header ::-webkit-scrollbar 			{ display: none;} 

.header .logo							{ top: 0;}
.header .logo img:first-child 			{ width: 90px; background: #1d2a4e; padding: 13px 14px;}
.header .logo img:last-child 			{ width: 120px;}

.menu_mobile							{ width: 60px; height: 90px; display: inline-block; vertical-align: middle; cursor: pointer; position: relative; z-index: 250; margin: 0 -10px; transition: height 300ms ease-in-out;}
.menu_mobile div						{ width: 40px; height: 2px; background: #1d2a4e; position: absolute; right: 50%; top: 50%; margin: -1px -20px 0 0;}
.menu_mobile div:before					{ width: 100%; height: 2px; background: #1d2a4e; position: absolute; right: 0; top: 8px; content: "";}
.menu_mobile div:after					{ width: 100%; height: 2px; background: #1d2a4e; 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 .header_nav 					{ width: 100%; height: 100vh; position: fixed; right: -100%; top :0; overflow-y: scroll; padding: 0; z-index: 200; background: #f3f4f7; border-top: 90px solid #fff; display: grid; grid-template-rows: auto 1fr; grid-gap: 50px; padding: 5vw; transition: all 300ms ease-in-out 300ms;}
.header .menu  							{ display: block; text-align: left; padding: 0; position: relative; z-index: 100; opacity: 0; transition: all 300ms ease-in-out 0ms;}
.header .menu>li 						{ display: block; margin: 0; position: relative;}
.header .menu>li:last-child				{ margin: 25px 0 0 0;}
.header .menu>li>a:not(.link) 			{ font: 400 30px/60px "masqualero"; height: 60px; text-transform: none; letter-spacing: 0.2px; transition: none;}
.header .menu>li>i						{ width: 50px; height: 50px; display: block; margin-top: -55px; position: relative; z-index: 5; float: right;}
.header .menu>li>i:after				{ width: 50px; height: 100%; background: url("../images/arrow_down.svg") 50% 52% no-repeat #1d2a4e; border-radius: 5px; float: right; content: "";}
.header .menu>li>i.active:after 		{ transform: rotate(180deg);}

.header .menu .sub 						{ width: 100%; position: relative; left: auto; top: auto; padding: 20px 30px; margin: 15px 0 20px 0; box-shadow: none; text-align: left; visibility: visible; opacity: 1; display: none;}
.header .menu .sub ul					{ padding: 0;}
.header .menu .sub li					{ width: 100%; margin: 0; position: relative;}

.header.active .header_nav 				{ right: 0; transition-delay: 0ms;}
.header.active .menu_top,
.header.active .menu					{ opacity: 1; transition-delay: 300ms;}
}
@media (max-width:600px) {
.header .logo							{ top: 0; grid-gap: 15px;}
.header .logo img:first-child 			{ width: 70px; padding: 12px 12px 11px 12px;}
.header .logo img:last-child 			{ width: 90px; margin-top: 5px;}
.menu_mobile							{ height: 70px;}
.menu_mobile.active div					{ transform: scale(0.9);}
.header .header_nav 					{ border-width: 70px; padding: 7vw 7vw 100px 7vw; grid-gap: 40px;}
.header .menu>li:last-child				{ margin: 20px 0 0 0;}
.header .menu>li>a:not(.link)			{ font-size: 20px; line-height: 50px; height: 50px;}
.header .menu>li>i						{ width: 40px; height: 40px; margin-top: -50px;}
.header .menu>li>i:after				{ width: 40px; background-size: 16px auto;}
.header .menu .sub 						{ padding: 10px 25px; margin: 10px 0 15px 0;}
.header .menu .sub li a					{ font-size: 14px;}
}



/***** cta moving text *****/
.moving_txt 								{ width: 2800px; left: 50%; transform: translateX(-50%); position: relative; height: 60px; background: #1d2a4e; color: #fdeed1; text-align: center; overflow: hidden;}
.moving_txt .row 							{ width: 5600px; display: flex;}
.moving_txt .row .item 						{ width: 2800px; display: grid; grid-template-columns: repeat(4, 1fr); white-space: nowrap; font: 400 25px/56px "Ubuntu"; animation: scroll_text 45s linear infinite;}

@keyframes scroll_text {
0%											{ transform: translate(0, 0);}
100% 										{ transform: translate(-100%, 0); }
}
@media (max-width:1200px) {
.moving_txt 								{ height: 50px;}
.moving_txt .row .item 						{ font-size: 20px; line-height: 46px;}
}
@media (max-width:1000px) {
.moving_txt 								{ width: 2400px;}
.moving_txt .row 							{ width: 4800px;}
.moving_txt .row .item 						{ width: 2400px; font-size: 18px;}
}
@media (max-width:600px) {
.moving_txt 								{ width: 1800px; height: 40px;}
.moving_txt .row 							{ width: 3600px;}
.moving_txt .row .item 						{ width: 1800px; line-height: 38px; font-size: 14px;}
}



/***** cta moving gallery *****/
.moving_gallery 							{ width: 3000px; left: 50%; transform: translateX(-50%); position: relative; text-align: center; overflow: hidden; background: #fdeed1; padding: 100px 0;}
.moving_gallery .row 						{ width: 6000px; display: flex;}
.moving_gallery .row .item 					{ width: 3000px; display: grid; grid-template-columns: repeat(6, 1fr); align-items: center; animation: scroll_gallery 45s linear infinite;}
.moving_gallery .row .item div				{ padding: 0 30px;}
.moving_gallery .row .item img				{ width: 100%; height: auto; display: block;}

@keyframes scroll_gallery {
0%											{ transform: translate(0, 0);}
100% 										{ transform: translate(-100%, 0); }
}
@media (max-width:2000px) {
.moving_gallery 							{ width: 2600px;}
.moving_gallery .row 						{ width: 5200px;}
.moving_gallery .row .item 					{ width: 2600px;}
}
@media (max-width:1600px) {
.moving_gallery 							{ width: 2400px;}
.moving_gallery .row 						{ width: 4800px;}
.moving_gallery .row .item 					{ width: 2400px;}
.moving_gallery .row .item div				{ padding: 0 25px;}
}
@media (max-width:1200px) {
.moving_gallery 							{ width: 2000px; padding: 80px 0;}
.moving_gallery .row 						{ width: 4000px;}
.moving_gallery .row .item 					{ width: 2000px;}
.moving_gallery .row .item div				{ padding: 0 20px;}
}
@media (max-width:1000px) {
.moving_gallery 							{ padding: 60px 0;}
}
@media (max-width:600px) {
.moving_gallery 							{ width: 1200px; padding: 40px 0;}
.moving_gallery .row 						{ width: 2400px;}
.moving_gallery .row .item 					{ width: 1200px;}
.moving_gallery .row .item div				{ padding: 0 8px;}
}



/***** ul list *****/
.ul_list							{ margin-bottom: 15px;}
.ul_list li							{ padding: 5px 0 5px 20px; position: relative;}
.ul_list li:before					{ position: absolute; left: 0; top: 17px; width: 6px; height: 6px; border-radius: 50%; background: #e8ab56; content: "";}

@media (max-width:600px) {
.ul_list							{ margin-bottom: 10px;}
.ul_list li							{ padding: 3px 0 3px 20px;}
}


/***** faq *****/
.show_hide                        	{ position: relative; margin: 20px 0;}
.show_hide .item                  	{ margin-bottom: 10px;}
.show_hide .titre                 	{ position: relative; cursor: pointer; padding: 20px 80px 20px 30px; font: 400 16px/24px "Ubuntu"; background: #f3f4f7; overflow: hidden; transition: all 300ms ease-in-out;}
.show_hide .titre:after          	{ width: 20px; height: 20px; background: url(../images/plus.svg) 50% no-repeat; border-radius: 50%; position: absolute; right: 30px; top: 50%; margin-top: -10px; transition: all 300ms ease-in-out; content: "";}
.show_hide .titre.active   			{ background-color: #1d2a4e; color: #fff;}
.show_hide .titre.active:after   	{ transform: rotate(45deg); filter: invert(1) brightness(200);}
.show_hide .hide                  	{ padding: 20px 30px; display: none;}
.show_hide .hide p 					{ margin-bottom: 15px;}
.show_hide .hide :last-child 	 	{ margin-bottom: 0;}

@media (min-width:1201px) {
.show_hide .titre:hover 			{ background-color: #1d2a4e; color: #fff; }
.show_hide .titre:hover:after   	{ filter: invert(1) brightness(200);}
}
@media (max-width: 600px){
.show_hide                        	{ margin: 15px 0;}
.show_hide .titre                 	{ padding: 15px 75px 15px 25px; font-size: 14px; line-height: 22px;}
.show_hide .titre:after          	{ right: 25px;}
.show_hide .hide                  	{ padding: 10px 20px;}
.show_hide .hide p 					{ margin-bottom: 10px;}
}


/***** points de vente *****/
.pdv 								{ position: relative; text-align: center;}
.pdv .map 							{ padding-top: 45%; background: #f5f5f5; margin-top: 40px;}

@media (max-width: 1200px){
.pdv 								{ margin: 0 -5vw;}
.pdv .map 							{ margin-top: 30px;}
}
@media (max-width: 1000px){
.pdv .map 							{ padding-top: 60%;}
}
@media (max-width: 600px){
.pdv .titre_main					{ display: none;}
.pdv .map 							{ margin: 0 -7.5vw; padding-top: 70%;}
}


/***** rs top ****/
.rs_top								{ position: absolute; right: 60px; top: 50%; font-size: 0; line-height: 0; letter-spacing: 0; z-index: 999; margin-top: -110px;}
.rs_top a							{ width: 60px; height: 60px; border-radius: 50%; display: block; vertical-align: top; margin: 10px 0;}
.rs_top .facebook					{ background: url("../images/facebook.svg") 50% no-repeat #fff;}
.rs_top .email 						{ background: url("../images/email_blue.svg") 50% no-repeat #fff;}

@media (min-width: 1201px){
.rs_top a:hover						{ opacity: 0.5;}
}
@media (max-width: 1200px){
.rs_top								{ display: none;}
}


/***** footer *****/
.footer								{ position: relative; background: #1d2a4e; color: #fff; font-size: 0; padding-top: 100px;}
.footer .sous_titre					{ color: #fdf0d1; font-size: 25px;}
.footer .sous_titre	span			{ font-size: 18px; display: block;}

.footer .bloc_footer 				{ display: inline-block; vertical-align: top;}
.footer .bloc_footer p				{ font-size: 14px; line-height: 26px; letter-spacing: 0.6px; margin-top: 15px;}
.footer .bloc_footer p a			{ color: #fff; padding: 0 0 0 30px; display: inline-block; border: none;}
.footer .bloc_footer p a.tel		{ background: url("../images/tel.svg") 0 52% no-repeat;}
.footer .bloc_footer p a.email		{ background: url("../images/email.svg") 1px 52% no-repeat;}

.footer .bloc_footer.contact 		{ margin: 64px 0 0 80px;}

.footer ul.bloc_footer     			{ margin: 64px 0 0 80px;}
.footer ul.bloc_footer li   		{ margin-bottom: 2px;}
.footer ul.bloc_footer li a 		{ font-size: 14px; line-height: 36px; letter-spacing: 0.6px; padding: 5px 0 5px 20px; background: url("../images/list_footer.svg") 0 50% no-repeat; color: #fff;}

.footer	.rs							{ position: absolute; right: 0; top: 0; font-size: 0; line-height: 0; letter-spacing: 0;}
.footer	.rs a						{ width: 60px; height: 60px; display: inline-block; vertical-align: top; margin-right: 10px; border-radius: 50%;}
.footer	.rs .scroll 				{ background: url("../images/scrolltop.svg") 50% 48% no-repeat #fdeed1; margin: 0;}
.footer	.rs .facebook				{ background: url("../images/facebook.svg") 50% no-repeat #fdeed1;}

.footer_bottom   					{ padding: 20px 0; line-height: 0; margin-top: 80px;}
.footer_bottom li 					{ display: inline-block; font-size: 11px; line-height: 20px; margin-right: 30px; letter-spacing: 0.8px; position: relative;}
.footer_bottom li a 				{ color: #fff;}
.footer_bottom li:after				{ width: 1px; height: 8px; content: ""; position: absolute; right: -16px; top: 6px; background: #fdeed1;}
.footer_bottom li:last-child:after 	{ display: none;}

.toponweb							{ display: block; z-index: 85; position: absolute; right: 0; bottom: 0; transition: bottom 300ms ease-in-out;}
.toponweb span						{ width: auto; height: 60px; display: block; padding: 20px; background: linear-gradient(to left, #fff 0% 50%, #fdf0d1 50% 100%); background-size: 200% 100%; background-position: 100% 0;}
.toponweb img						{ width: 76px; height: auto; display: block; margin: 0 auto; transition: all 300ms 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: #fdf0d1;}
.footer	.rs a:hover  				{ background-color: #fff;}
.toponweb:hover span				{ background-position: 0 0;}
}
@media (max-width:1200px) {
.footer								{ padding-top: 80px;}
.footer .sous_titre	span			{ font-size: 16px; padding-top: 5px;}
.footer ul.bloc_footer     			{ display: none;}
.footer_bottom   					{ margin-top: 60px;}
}
@media (max-width:1000px) {
.footer								{ padding-top: 60px;}
.footer_bottom   					{ margin-top: 40px;}
}
@media (max-width:600px) {
.footer								{ padding-top: 40px;}
.footer .bloc_footer 				{ width: 100%;}
.footer .bloc_footer.contact 		{ margin: 5px 0 0 0;}
.footer .bloc_footer .sous_titre	{ font-size: 20px;}
.footer .sous_titre	span			{ font-size: 14px;}
.footer .bloc_footer p				{ font-size: 13px; line-height: 22px;}
.footer	.rs							{ position: static; margin: 35px auto 30px auto;}
.footer	.rs a						{ width: 50px; height: 50px;}
.footer_bottom 	 					{ text-align: left; margin-top: 25px; padding: 0 0 20px 0;}
.footer_bottom li 					{ display: block; margin: 0; line-height: 26px;}
.footer_bottom li:after				{ display: none;}
}