/***** fonts et reset *****/
@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500;1,600;1,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; font-size: 15px;}
ul									      { list-style-type: none;}
body								      { font: 400 14px/30px "Poppins"; letter-spacing: 0.4px; color: #000; 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;}
@media (max-width:600px) {
body							        { font-size: 12px; letter-spacing: 0.6px;}
strong, b						    	{ font-size: 13px;}
}

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


/***** 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: 700 14px/30px "Poppins"; position: relative; text-transform: uppercase; color: #e12b2b;}
.sous_titre 					  	{ font: 500 24px/40px "Poppins"; position: relative; color: #e12b2b; letter-spacing: 0.6px; margin-bottom: 15px;}
.stitre                   { font: 600 20px/40px "poppins"; color: #252525; margin-bottom: 15px;}
.chapo		 						    { font: 400 14px/30px "Poppins"; letter-spacing: 0.5px; color: #fff;}
.chapo span 						  { display: block; margin-top: 15px;}
.link 							    	{ font: 400 11px/60px "Poppins"; letter-spacing: 1.2px; text-transform: uppercase; height: 60px; border: none; display: inline-block; vertical-align: middle; color: #fff; padding: 0 30px;
background: linear-gradient(to top, #151515 0%, #151515 50%, #e12b2b 50%, #e12b2b 100%); background-size: 100% 200%; background-position: 0 100%; cursor: pointer; border-radius: 5px;}
.tel 								      { font: 400 14px/60px "Poppins"; border: none; color: #fff; letter-spacing: 0.3px; margin-left: 10px;}
.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: inline-block; vertical-align: top; width: 60px; height: 60px; border-radius: 50%; background: url("../images/plus.svg") 50% no-repeat #e12b2b;}

@media (min-width:1201px) {
.tel:hover,
.link:hover 						  { background-position: 0 0;}
.link_plus:hover					{ background-color: #e12b2b;}
}
@media (max-width:1200px) {
.wrapper 							    { min-width: inherit;}
}
@media (max-width:1000px) {
.wrapper 							    { max-width:750px;}
}
@media (max-width:600px) {
.wrapper 						    	{ width: 85vw;}
.titre_main               { font-size: 12px;}
.sous_titre						  	{ font-size: 20px; line-height: 30px; letter-spacing: 0.4px;}
.link 								    { font-size: 10px; height: 50px; line-height: 48px;}
}

/***** header et menu *****/
.header 							    { width: 100%; background: #fff; 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 .logo					  	{ width: 230px; position: absolute; left: 0; top: 25px; z-index: 90;}
.header .logo img					{ width: 100%; height: auto; display: block;}
.header_right 						{ display: inline-block; vertical-align: middle; position: relative; z-index: 120;}
.header .link					    { border-radius: 0 0 5px 5px;background-image: linear-gradient(to top, #e12b2b 0%, #e12b2b 50%, #151515 50%, #151515 100%); font: 600 12px/50px "poppins"; letter-spacing: 0.8px; height: 50px;}
.header .tel 				      { font: 500 14px/50px "Poppins"; border: none; color: #fff; letter-spacing: 0.3px; margin-left: 10px;}
.header_nav						  	{ display: inline-block; vertical-align: middle; z-index: 50;}
.header_nav .menu					{ position: relative;}	
.header_nav .menu li				{ display: inline-block; vertical-align: middle; position: relative; margin-left: 30px;}	
.header_nav .menu li a				{ font: 400 15px/98px "Poppins"; letter-spacing: 0.2px; height: 100px; display: block; transition-property: all;}
.header_nav .menu>li.active>a 		{ color: #e12b2b;}
.sticky .header 					{ box-shadow: 0 0 30px 0 rgb(0 0 0 / 10%); }

@media (min-width:1201px) {
.sticky .header 					{ top: -50px;}
.sticky .header .logo               { width: 150px; top: 75px;}
.header_nav .menu .vue_mobile,
.menu_mobile 						{ display: none;}
.header_nav .menu li:hover a     	{ color: #e12b2b;}

}
@media (max-width:1200px) {
.menu_mobile						{ width: 60px; height: 60px; display: inline-block; vertical-align: middle; cursor: pointer; position: relative; margin: 20px -15px; transition: margin 400ms ease-in-out;}
.menu_mobile div					{ width: 30px; height: 2px; background: #000; position: absolute; right: 50%; top: 50%; margin: -1px -15px 0 0;}
.menu_mobile div:before				{ width: 100%; height: 2px; background: #000; position: absolute; right: 0; top: 8px; content: "";}
.menu_mobile div:after				{ width: 100%; height: 2px; background: #000; 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 							{ height: 100px; transition: box-shadow 400ms ease-in-out, height 400ms ease-in-out 400ms;}
.header .logo						{ top: 25px; transform: none; z-index: 121; width: 150px;}
.header_right 						{ margin:0 0 0 35px;}
.header_top                         { display: inline-block; vertical-align: middle;}
.header_top .devis                  { display: none;}
.header_top .link					{ width: 60px; height: 60px; font-size: 0; background: url("../images/tel.svg") 50% #e12b2b no-repeat; border-radius: 8px;}
.header_top .tel::before            { display: none;}
.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;}
.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 li i				{ width:85px;height:41px;display:block;margin-top:-48px;position:relative;z-index:5; background:url(../images/arrow_down.svg) 50% no-repeat #f7f3ee;float:right;border-radius:8px;}

/* active menu mobile */
.header.active 						{ height: 100vh; transition-delay: 0ms;}
.header_nav.active					{ right: 0; transition-delay: 0ms;}
.header_nav.active .menu			{ opacity: 1; transform: translateY(0); transition-delay: 400ms;}
}
@media (max-width:600px) {
.header 							{ height: 80px;}
.header .logo						{ width: 120px;top: 20px;}
.menu_mobile						{ margin: 10px -15px;}
.header_nav .menu  					{ padding: 7.5vw;}
.header_nav .menu>li>a				{ font-size: 14px; line-height: 40px; ; height: 40px;}
.header_nav .menu li i				{ height: 50px;}
}


/***** bandeau téléphone *****/
.bandeau 						    { background: #151515; color: #fff; padding: 40px 40px 50px; border-radius: 8px; text-align: center; font-size: 20px; line-height: 30px;}
.bandeau p span                     { display: block; color: #e12b2b;}
.link_bandeau                       { margin-top: 20px;}
.link_bandeau .link                 { background-image: linear-gradient(to top, #e12b2b 0%, #e12b2b 50%, #fff 50%, #fff 100%); font-weight: 700;}
.link_bandeau .tel:before           { content: "";background: url(../images/tel.svg) no-repeat center; width: 14px; height: 24px; }
.link.form                          { position: relative; margin-left: 5px;}
.link.form::before                  {content:""; background: url(../images/mail.svg) no-repeat center; width: 16px; height: 12px; display: inline-block; vertical-align: middle; margin-right: 15px; position: relative;top: -2px; line-height: 0;}
@media (min-width:1201px) {
.link_bandeau .link:hover           { color: #e12b2b;}
.link.form:hover:before             { background-image: url(../images/mail_red.svg);}
.link_bandeau .tel:hover:before     { background-image: url(../images/tel_red.svg);}
}
@media (max-width:600px) {
.bandeau        					{ font-size: 16px; padding: 30px 20px 40px; position: relative; z-index: 1;}
.bandeau p span                     { display: inline-block; }
.link_bandeau .link                 { display: block; margin: 0 auto; max-width: 170px; }
.link_bandeau .link.form            { margin-top: 10px;}
}


/***** footer*****/
.footer								{ width: 100%; position: relative; padding-top: 75px; background: #151515; color: #fff; font-size: 0;}
.footer .bloc_footer 				{ display: inline-block; vertical-align: top; margin-right: 120px; line-height: 30px;}
.footer .tel:before                 { display: none;}
.footer .bloc_footer.last			{ margin:75px 0 0;}
.footer .bloc_footer p				{ font-size: 15px; margin-top: 10px;}
.footer .bloc_footer p b			{ display: block; font: 400 28px/40px "Poppins"; margin-bottom: 30px;}
.footer .bloc_footer p a			{ color: #fff; padding-left: 30px;}
.footer .bloc_footer p .tel         { background: url(../images/tel_red.svg) left center no-repeat; margin: 0; background-size: contain;}
.footer .bloc_footer p .mail        { background: url(../images/mail_red.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: 50px;}
.footer .bloc_footer li a			{ font-size: 15px; color: #fff; margin-top: 3px; background:url(../images/list.svg) 0 48% no-repeat; padding-left: 20px; display: inline-block; letter-spacing: 0.3px;}
.footer	.rs							{ position: absolute; right: 0; top: 15px;}
.footer	.rs a						{ width: 60px; height: 60px; display: inline-block; vertical-align: top; border-radius: 8px; margin-right: 10px;}
.footer	.rs .scroll					{ background: url(../images/scrolltop.svg) 50% 46% no-repeat #e12b2b; margin: 0;}
.footer_bottom   					{ padding: 20px 0; line-height: 0; margin-top: 45px;}
.footer_bottom li 					{ display: inline-block; font-size: 11px; line-height: 20px; margin-right: 30px; 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: #e12b2b;}
.footer_bottom li:last-child:after 	{ display: none;}
.toponweb							{ display: block; z-index: 85; position: absolute; 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, #e12b2b 0%, #e12b2b 50%, #151515 50%, #151515 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: #e12b2b;}
.footer	.rs .scroll:hover			{ background-color: #fff; background-image: url(../images/scrolltop_red.svg);}
.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: 40px;}
}
@media (max-width:600px) {
.footer								{ padding-top: 55px;}
.footer .logo						{ width: 170px; margin-bottom: 0;}
.footer .bloc_footer 				{ margin: 0;}
.footer .bloc_footer p b			{ font-size: 20px; line-height: 20px; margin-bottom: 35px;}
.footer .bloc_footer p              { font-size: 13px; margin: 0;}
.footer .bloc_footer p .tel         { font-size: 13px;}
.footer	.rs							{ position: static; margin-top: 30px;}
.footer_bottom 	 					{ text-align: left; margin-top: 30px; padding: 0 0 20px 0;}
.footer_bottom li 					{ display: block; margin-right: 0; line-height: 25px;}
.footer_bottom li:after				{ display: none;}
.footer .rs a                       { width: 55px; height: 55px;}
}
@media (max-width:350px) {
.footer .logo						{ width: 150px;}
}




