/***** fonts et 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;}
strong, b							{ font-weight: 600; font-size: 17px;}
ul									{ list-style-type: none;}
body								{ font: 400 16px/30px "Barlow"; letter-spacing: 0.6px; color: var(--noir); 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;}
#wrapper 							{ min-width: 320px; overflow: hidden; position: relative;}
#wrapper *							{ box-sizing: border-box;}
#footer 							{ position: relative;}

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


/***** scollbar *****/
::-webkit-scrollbar 				{ width: 4px; height: 4px; background-color: #fff;}
::-webkit-scrollbar-thumb			{ background-color: #000;}


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


:root {
--rouge: #d02027; 
--noir: #000; 
--gris: #eee; 
}


/***** class *****/
.wrapper 							{ width: 90vw; max-width: 1200px; margin: 0 auto; position: relative;}
.wrapper_large						{ max-width: 1800px;}
.clear								{ clear: both; display: block;}
.anchor 							{ position: absolute; left: 0; top: 0;}

.read_more                          { cursor: pointer; color: var(--rouge);}
.hide                               { display: none;}


.titre_main	 						{ font: 700 45px/55px "Barlow"; letter-spacing: 0.8px; color: var(--noir); margin-bottom: 15px; text-transform: uppercase;  }
.titre_main span					{ color: var(--rouge); }
.sous_titre 						{ font: 500 25px/35px "Barlow"; letter-spacing: 0.8px; color: var(--rouge); margin-bottom: 20px;}
.titre       						{ font: 800 15px/22px "Barlow"; letter-spacing: 1px; color: var(--rouge); margin-bottom: 10px; text-transform: uppercase;}
.chapo		 						{ font: 400 16px/30px "Barlow"; letter-spacing: 0.7px; color: var(--noir);}
.chapo span	 						{ display: block; margin-top: 20px;}

.link 								{ font: 700 14px/58px "Barlow"; height: 60px; display: inline-block; color: #fff; padding: 0 30px; background: var(--rouge); letter-spacing: 0.9px; border-radius: 5px; overflow: hidden; position: relative;}
.link_arrow 						{ color: var(--rouge); font-size: 16px; font-weight: 500; padding: 5px 40px 5px 0; position: relative; padding-right: 35px;}
.link_arrow:after					{ content: ""; background: url("../images/link_arrow_red.svg") 50% no-repeat; width: 13px; height: 13px; position: absolute; right: 0; top: 50%; transform: translateY(-50%);}

.tel                                { padding-left: 60px; background-image: url("../images/tel_white.svg") ; background-position: 25px 50%; background-repeat: no-repeat; }
.mail                               { padding-left: 60px; background-image: url("../images/mail_white.svg") ; background-position: 25px 50%; background-repeat: no-repeat; }

.bg_gris                            { background-color: var(--gris);}


.ul_list li a     					{ padding-bottom: 2px;}
.ul_list							{ margin: 15px 0 20px 0;}
.ul_list li							{ padding: 5px 0 5px 35px; position: relative; background: url("../images/list_red.svg") left top 14px no-repeat; }
.ul_list li	span     				{ font-size: 12px;}


@media (min-width:1201px) {
.link:hover 						{ background-color: var(--noir) }
.link_arrow:hover     				{ color: var(--noir); }
}
@media (max-width:1200px) {
.chapo		 						{ font-size: 15px; line-height: 30px;}
.titre_main	 						{ font-size: 30px; line-height: 40px;}
.sous_titre 						{ font-size: 20px; line-height: 30px;}
}
@media (max-width:1000px) {
}
@media (max-width:700px) {
.wrapper 							{ width: 85vw;}
.titre_main	 						{ font-size: 20px; line-height: 30px; margin-bottom: 10px;}
.sous_titre 						{ font-size: 18px; line-height: 28px; margin-bottom: 10px;}
.chapo		 						{ font-size: 13px; line-height: 26px; margin-bottom: 15px;}
.link 								{ height: 50px; line-height: 48px; font-size: 13px; padding: 0 20px; border-radius: 5px; display: block; width: 100%; }
.link.link_arrow 				    { font-size: 14px; padding: 0 60px 0 20px; }
.link.link_arrow:after			    { display: none;}
.link.link_arrow:before			    { background-image: url("../../images/arrow_link_orange.svg"); top: calc(50% - 7px); right: 20px;}
.cta .tel                           { padding-left: 30px; background-image: none;  }
.cta .mail                          { padding-left: 30px; background-image: none; }
}



.header 							{ width: 100%; font-size: 0; line-height: 0; text-align: right; position: fixed; left: 0; top: 0; z-index: 100; background-color: transparent; padding-bottom: 45px; transition: all 400ms ease-in-out;}
.header .logo						{ position: absolute; width: 130px; left: 0; top: 30px; z-index: 150; transition: all 400ms ease-in-out;}
.header .logo img     				{ display: block; width: 100%; height: auto;}
.header .link          				{ background-color: var(--rouge); padding-left: 60px; background-position: 25px 50%;}


.header_nav .langue				    { position: relative; transition:margin 400ms ease-in-out; font: 600 14px/50px "Barlow"; color: #fff; }	
.header_nav .langue>*               { display: inline-block; vertical-align: top;}
.header_nav .langue a			    { color: #fff; letter-spacing: 0.2px;}	
.header_nav .langue li:first-child::after { display:none;}

.header_nav .langue a.active	    { color: var(--rouge);}

/* Menu principal */

.header_nav  						{ position: relative;}	
.header_nav .menu					{ position: relative;}	
.header_nav .menu li				{ display: inline-block; vertical-align: middle; position: relative; margin-left: 40px;}	
.header_nav .menu li a				{ font: 700 16px/60px "Barlow"; text-transform: uppercase; letter-spacing: 0.8px; height: 60px; display: block; color: #fff;}
.header_nav .menu>li.active>a 		{ color: var(--rouge);}


/* Sous-menu */
.header_nav .sub					{ width: 280px; text-align: center; position: absolute; top: 100%; left: 50%; margin-left: -140px; display: block; visibility: hidden; opacity: 0; background: #eee; padding: 15px 0; border-radius: 8px;}
.header_nav .sub li					{ width: 100%; margin: 0;}
.header_nav .sub li a				{ width: 100%; font-size: 15px; line-height: 40px; height: 40px; color: #000000; font-weight: 400;}
.header_nav .menu .sub li.active a	{ color: var(--rouge);}

.sticky .header		                { background-color: var(--noir); }

@media (min-width:1201px) {
.header_top,
.menu_mobile 						{ display: none;}
.header_nav .sub 					{ display: block !important;}  
     
/* Menu principal */    
.header_nav .menu>li>a:hover 		{ color: var(--rouge);}
.header_nav .menu>li>a.tel:hover    { color: #ffffff;}
.header .link:hover                 { background-position: 20px 50%;}
.header_nav .langue a:hover         { color: var(--rouge) !important;}
    
/* Sous-menu */    
.header_nav .menu li:hover .sub		{ opacity: 1; visibility: visible; z-index: 999;}    
.header_nav .sub>li>a:hover 		{ color: var(--rouge);}  

/* Sticky */    
.sticky .header		                { top: -40px; padding-bottom: 10px;}
.sticky .header	.logo               { width: 80px; top: 50px;}
}


@media (max-width:1200px) {
/* menu mobile */
.menu_mobile						{ width: 60px; height: 60px; display: inline-block; vertical-align: middle; cursor: pointer; position: relative; margin: 20px -15px 20px 20px; transition: height 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(-135deg);}
.menu_mobile.active div:after		{ top: 0; transform: rotate(-45deg);}

/* général */
.header 							{ height: 90px; padding-bottom: 0; }
.header .logo						{ width: 100px; top: 20px; z-index: 121;}
.sticky .header .logo               { width: 80px; }  

/* menu top */        
.header_top                   		{ display: inline-block; position: relative; z-index: 120;}
.header_top .tel                    { padding: 0; top: 25px; width: 50px; height: 50px; font-size: 0; line-height: 0; background: url("../images/tel_white.svg") 50% no-repeat var(--rouge); border-radius: 50%; }
    
/* menu principal */        
.header_nav 	  					{ width: 100%; height: 100vh; background: var(--noir); position: fixed; right: -100%; top: 0; overflow-y: scroll; display: grid; grid-template-rows: auto auto; z-index: 100; padding-top: 110px; transition: all 400ms ease-in-out 400ms;}
.header_nav::-webkit-scrollbar		{ display: none;}
.header_nav .menu  					{ grid-area: 1; width: auto; text-align: left; margin: 40px 15vw 0; position: relative; z-index: 100; align-self: center; opacity: 0; transition: all 200ms ease-in-out 0ms;}
.header_nav .menu li 				{ width: 100%; display: block; margin: 0;}
.header_nav .menu li .link			{ margin-top: 20px;}
.header_nav .menu li a				{ width: 100%; font-size: 16px; line-height: 55px; height: 55px; color: #fff;}
.header_nav .menu li i				{ width: 70px; height: 41px; display: block; margin-top: -48px; position: relative; z-index: 5; background: url("../images/arrow_next_white.svg") 50% no-repeat; float: right; transform: rotate(90deg); }
.header_nav .menu li i.active		{ transform: rotate(270deg)}
.header_nav .langue				    { text-align: left; display: table; padding: 0 0 40px; transition:opacity 400ms ease-in-out 0ms; position: relative; background: none; margin: 25px 15vw; padding-top: 25px; width: auto;}	
.header_nav .langue:before     	    { content: ""; width: 50px; height: 2px; top: 0; left: 0; position: absolute; background-color: #fff; }	
.header_nav .langue::after          { display: none; }
.header_nav .langue li 			    { display: block; margin: 0; padding: 0;}	
.header_nav .langue li a 			{ line-height: 40px;}	
.header_nav .langue li:after		{ display:none;}

/* sous-menu */    
.header_nav .sub 					{ width: 100%; position: relative; left: auto; top: auto; padding: 20px 50px; margin: 20px 0; background: #eeeeee; opacity: 1; display: none; z-index: 150; visibility: visible;}
.header_nav .sub li  				{ width: 100%;  padding: 10px 0;}
.header_nav .sub li a				{ width: 100%; font-size: 14px; font-weight: 500; line-height: 20px; height: inherit; text-align: left; color: #000000;}

/* active menu mobile */
.header_nav.active					{ right: 0; transition-delay: 0ms;}
.header_nav.active .menu			{ opacity: 1; transition-delay: 400ms;}
}

@media (max-width:1000px) {
/*
.header_nav 	  					{ padding-top: 0; }
.header_nav .menu  					{ margin: 80px 10vw 0;}
.header_nav .menu li 				{ width: 100%;}
.header_nav .sub 					{ padding: 25px 40px;}
.header_nav .sub li a				{ border: none; line-height: 45px; height: 45px;}
*/
}

@media (max-width:700px) {
.header_top { width: 100%;}
.header .logo { left: 50%; transform: translateX(-50%);}
.menu_mobile { top: -50px;}
.header_nav .sub { padding: 20px;}
.header_nav .sub li a { text-transform: inherit;}


/*
.menu_mobile						{ margin: 15px -15px 15px 20px;}
.header .logo 						{ width: 80px; top: 10px;}
.header_top 						{ padding: 0 0;}

.header_nav .menu  					{ margin: 120px 7.5vw 0 7.5vw; align-self: start;}
.header_nav .menu>li>a				{ font-size: 14px; line-height: 50px; height: 50px;}
.header_nav .menu li i				{ height: 40px; margin-top: -45px;}
    
.header_nav .sub 					{ padding: 6vw 7.5vw; margin: 15px 0;}
.header_nav .sub li a				{ font-size: 14px; line-height: 30px; height: 30px; overflow: hidden;}
*/
}



.show_hide .hide p a,
.bloc_grid .texte p a,
.ul_list li a,
.right a,
.bloc_texte p a                     { color: var(--rouge); border-bottom: 1px solid var(--gris);}

@media (min-width:1201px) {
.show_hide .hide p a:hover,
.bloc_grid .texte p a:hover,
.ul_list a:hover,
.right a:hover,
.bloc_texte p a:hover 			    { color: var(--noir); border-color: var(--rouge);}
}


/***** show hide *****/
.show_hide                        	{ position: relative; margin: 20px auto 30px;}
.show_hide .item                  	{ margin-top: 10px; border-radius: 5px; overflow: hidden;}
.show_hide .titre                 	{ position: relative; cursor: pointer; padding: 17px 80px 19px 30px; font: 600 16px/24px "Barlow"; background: #fff; color: var(--noir); transition: color 400ms ease-in-out; margin-bottom: 0; transition: all 400ms ease-in-out;}
.show_hide .titre:after          	{ width: 40px; height: 40px; background: url("../images/plus_red.svg") 50% no-repeat transparent; border-radius: 50%; position: absolute; right: 10px; top: calc(50% - 20px); content: "";}
.show_hide .titre.active   			{ color: var(--rouge);background-color: var(--gris);}
.show_hide .titre.active:after   	{ transform: rotate(180deg);}
.show_hide .hide                  	{ display: none; padding: 0 40px 30px; color: var(--noir);}
.show_hide .hide p 					{ margin-bottom: 10px;}
.show_hide .hide :last-child 	 	{ margin-bottom: 0;}
@media (min-width:1201px) {
.show_hide .titre:hover 			{ color: var(--rouge); }
}
@media (max-width:1200px){
.show_hide                        	{ margin: 25px 0;}
.show_hide .hide                  	{ padding: 30px;}
}
@media (max-width:1000px){
.show_hide                        	{ margin: 20px 0;}
}
@media (max-width:700px){
.show_hide                        	{ margin: 15px 0;}
.show_hide .item                  	{ border-radius: 5px;}
.show_hide .titre                 	{ padding: 14px 60px 16px 20px; font-size: 14px; line-height: 22px;}
.show_hide .titre:after          	{ right: 10px;}
.show_hide .hide                  	{ padding: 18px 20px 20px 20px;}
}




.cta                                { margin: 100px auto; background-color: var(--gris); padding: 60px; border-radius: 20px; text-align: center;}
.cta .link                          { margin: 10px 5px 0 5px ; }
@media (max-width:1200px) {
.cta                                { margin: 80px auto; padding: 50px; border-radius: 15px; }
}
@media (max-width:1000px) {
.cta                                { margin: 60px auto; padding: 40px; border-radius: 12px; text-align: center; }
}
@media (max-width:700px) {
.cta                                { padding: 30px 7.5vw; margin: 0 -7.5vw 40px; border-radius: 0; }
}





.footer:before						{ content: ""; width: 100%; height: 10px; background-color: var(--rouge); position: absolute; top: 0; right: 0; left: 0;}
.footer:after						{ content: ""; width: 369px; height: 379px; background: url("../images/fav.svg") 50% / cover no-repeat; position: absolute; top: 50%; transform: translateY(-50%); right: 0; left: -184px; opacity: 0.1;}
.footer								{ padding-top: 90px; width: 100%; position: relative; background: url("../images/background-texture.webp") 50% / cover var(--noir); color: #fff; font-size: 0; overflow: hidden;}
.footer .logo .titre_main           { font: 700 30px/40px "Barlow"; letter-spacing: 0.7px; color: #fff; margin-bottom: 30px; text-transform: uppercase; }
.footer .logo .titre_main span      { color: #fff;}
.footer .titre	                    { color: #fff; font-size: 18px; letter-spacing: 0.6px; margin-bottom: 15px}
.footer .bloc_footer 				{ display: inline-block; vertical-align: top; margin-right: 100px; line-height: 30px;}
.footer .bloc_footer.last			{ margin-right: 0;}
.footer .bloc_footer p				{ font-size: 15px; margin-top: 10px; }
.footer .bloc_footer p a			{ color: #fff; padding: 0;}
.footer .bloc_footer p.tel			{ padding-left: 35px; background: url("../images/tel_red.svg") 0 50% no-repeat;}
.footer .bloc_footer p.mail			{ padding-left: 35px; background: url("../images/mail_red.svg") 0 50% no-repeat;}
.footer .bloc_footer p.marker     	{ padding-left: 35px; background: url("../images/marker_red.svg") 0 50% no-repeat;}

.footer .bloc_footer p span			{ display: inline-block;}
.footer .bloc_footer ul				{ margin-top: 10px; display: inline-block; vertical-align: top; margin-right: 50px;}
.footer .bloc_footer li a			{ font-size: 15px; color: #fff; background:url("../images/footer_list_red.svg") 0 50% no-repeat; padding-left: 25px; margin-top: 0; display: inline-block; line-height: 38px;}

.footer	.rs							{ position: absolute; right: 0; top: -15px;}
.footer	.rs a						{ width: 60px; height: 60px; border-radius: 50%; display: inline-block; vertical-align: top; margin-right: 10px; box-sizing: border-box;}
.footer	.rs .facebook			    { background: url("../images/facebook_white.svg") 50% no-repeat var(--rouge);}
.footer	.rs .scroll					{ background: url("../images/scrolltop_white.svg") 50% 48% no-repeat #494949; margin: 0;}

.footer_bottom   					{ padding: 20px 0 15px; line-height: 0; margin-top: 75px;}
.footer_bottom li 					{ display: inline-block; font-size: 11px; line-height: 21px; margin-right: 30px; letter-spacing: 0.5px; position: relative;}
.footer_bottom li a 				{ color: #fff;}
.footer_bottom li:after				{ width: 1px; height: 9px; content: ""; position: absolute; right: -16px; top: 6px; background: #fff;}
.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, #01161b 0%, #01161b 50%, var(--jaune) 50%, var(--jaune) 100%); background-size: 200% 100%; background-position: 100% 0;}
.toponweb img						{ width: 74px; height: auto; display: block; margin: 0 auto; filter: invert(0)}

@media (min-width:1201px) {
.footer .bloc_footer p a:hover,
.footer .bloc_footer li a:hover,
.footer_bottom li a:hover			{ color: var(--rouge);}
    
.footer	.rs .facebook:hover		    { background-color: var(--noir);}
.footer	.rs .scroll:hover			{ background-color: var(--noir);}
    
.toponweb:hover span				{ background-position: 0 0;}
}

@media (max-width:1200px) {
.footer .bloc_footer 				{ margin-right: 80px;}
.footer .bloc_footer.last			{ display: none;}
}

@media (max-width:1000px) {
.footer .bloc_footer 				{ display: block; margin: 0 0 50px 0;}
.footer .bloc_footer p              { margin: 0 0 10px;}
.footer_bottom   					{ margin-top: 80px;}
}

@media (max-width:700px) {
.footer								{ margin-top: 0; background-image: none}
.footer:before						{ display: none;}
.footer:after						{ display: none;}
.footer .logo						{ margin-bottom: 25px;}
.footer .bloc_footer 				{ margin: 0 0 30px 0;}
.footer	.rs							{ position: static; margin-top: 40px;}
.footer_bottom 	 					{ text-align: left; margin-top: 50px; padding: 0 0 30px 0;}
.footer_bottom li 					{ display: block; margin-right: 0; line-height: 28px;}
.footer_bottom li:after				{ display: none;}   

}





