/***** fonts et reset *****/
@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@500;600;700&family=Barlow:wght@400;500;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: 700;}
ul									{ list-style-type: none;}
body								{ font: 400 16px/30px "Barlow"; 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;}


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


/***** 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 35px/45px "Barlow Condensed";letter-spacing: 0.4px;color:#000;text-transform: uppercase;margin-bottom: 10px}
.titre_main span                    { color:#e00814}

.sous_titre                         { font:500 25px/40px "Barlow"; letter-spacing: 0.4px;color:#e00814;text-transform: none;margin-bottom: 20px}
.chapo		 						{ font: 400 16px/30px "Barlow";}
.link 								{ font: 700 18px/60px "Barlow Condensed"; letter-spacing: 0.8px; text-transform: uppercase; height: 60px; border: none; display: inline-block; vertical-align: middle; color: #fff; padding: 0 30px; background: linear-gradient(to top, #e00814 0%, #e00814 50%, #000 50%, #000 100%); background-size: 100% 200%; background-position: 0 100%; cursor: pointer; text-align: center;}

.link-plus, .link-moins  { border-bottom: 1px solid #000000; color: #000000;}

.link_arrow							{ display: inline-block; vertical-align: top; width: 60px; height: 60px; border-radius: 50%; background: url("../images/plus.svg") 50% no-repeat #e00814;}
.link.tel                           { background-image: linear-gradient(to top, #000 0%, #000 0% 50%, #e00814 50%, #e00814 100%); }
.link.tel::before                   { content: url(../images/tel.svg); display: inline-block; vertical-align: middle; margin-right: 15px; position: relative;top: 0; line-height: 0;}
.link.mail                          { color: #000; background-image: linear-gradient(to top, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 0% 50%, #e00814 50%, #e00814 100%); text-transform: initial;}
.link.mail::before                  { content: url(../images/mail_red.svg); filter: brightness(0) invert(0); display: inline-block; vertical-align: middle; margin-right: 15px; position: relative;top: 0; line-height: 0;}
.link.devis::after                  { content: url(../images/arrow_right.svg); display: inline-block; vertical-align: middle; margin-left: 30px; position: relative;top: 0; line-height: 0; position: relative; top: -2px;}

@media (min-width:1201px) {
.link_arrow:hover					{ background-color: #e00814;}
.link-plus:hover, .link-moins:hover             { border-bottom: 1px solid #e00814; color: #e00814;}
.link:hover:before                  { filter: brightness(0) invert(1);}
.link.mail:hover                    { color: #fff;}
}
@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) {
body                                { font-size: 15px;line-height: 26px;}
.wrapper 							{ width: 85vw;}
.titre_main	 						{ font-size: 22px; line-height: 30px; margin-bottom: 15px}
.sous_titre							{ font-size: 20px; line-height: 22px; margin-bottom: 15px}
.link                               { font-size: 16px;line-height: 60px;height: 60px;}
.link.devis::after                  { display: none;}
}
@media (max-width: 350px){
.content .link::before              { display:none!important;}
}

.ul_list							{ margin: -5px 0 20px 0;}
.ul_list li							{ padding: 5px 0 10px 35px; position: relative;background: url(../images/check.svg) left 0 top 7px no-repeat;}

@media (max-width: 600px){
.ul_list                            { margin-bottom: 15px}
.ul_list li                         { font-size: 12px;}

}

.link_devis							{ height: 70px; padding: 0 40px; margin-top: 5px; font-size: 15px;}
.link_devis span                    { color: #ffffff;display: inline-block;line-height: 70px;padding-left: 55px;background: url(../images/note.svg) no-repeat center left, url(../images/arrow.svg) no-repeat center right; position: relative; vertical-align: middle; padding-right: 55px;}





/** Lien **/
.morecontent p a, .textMore a, .intro a, .item a:not(.link), .texte p a, .bloc_texte p a, .page_content p a, .page_content .ul_list a { border-bottom:1px solid #000; color: #000} 

@media (min-width:1201px) {
    .morecontent p a:hover, .textMore a:hover,.intro a:hover, .item a:not(.link):hover, .texte p a:hover, .bloc_texte p a:hover, .page_content p a:hover, .page_content .ul_list a:hover { border-bottom:1px solid #e00814; color: #e00814;} 
}

@media (min-width:1201px) {
.tel:hover,
.link:hover 						{ background-position: 0 0;}
}



.mention_legale                    { color: #e00814; }
.header .mention_legale            { color: #000; background: transparent; font-size: 15px; line-height: 62px;}
.footer .mention_legale            { font-size: 17px; line-height: 26px; font-family: "Barlow Condensed"; letter-spacing: 0.8px; }
.footer .full                      { margin: 40px auto 0; }
@media (max-width:1200px) {
.header .mention_legale            { display: none;}
.footer .full                      { display: block; }
}
@media (max-width:600px) {
.footer .full                      { margin: 30px auto 30px; }
}



/***** header et menu *****/
.header 							{ width: 100%; background:transparent; 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                    { max-width: 1420px;}
.header .logo						{ width: 265px; position: absolute; left: 0; top: 55px; z-index: 90; transform-origin: left;}
.header .logo img					{ width: 100%; height: auto;}
.header_right 						{ display: block; position: relative; z-index: 120;}
.header_right .link					{ text-align: center; position: relative; font-weight: 500;}
.header_nav							{ display:block; z-index: 50;padding-right: 0}
.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 18px/80px "Barlow Condensed"; text-transform: uppercase; letter-spacing: 0.8px; height: 80px; display: block; transition-property: all;}
.header_nav .menu>li>a:after        { content: ""; display: block; position: absolute; left: 0; bottom: 0; height: 4px; width: 0; background: #000; transition: all ease 400ms;}
.header_nav .menu>li.active>a:after { width: 20px;}
.header_nav .sub					{ width: 240px; text-align: left; position: absolute; top: 100%; left: 0; display: block; visibility: hidden; opacity: 0; background: #000; padding: 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%; letter-spacing: 0.4px; height: 50px; color: #fff; line-height: 22px; display: grid; align-items: center; font-size: 16px; padding: 0 40px;}
.header_nav .menu li:hover .sub		{ opacity: 1; visibility: visible; z-index: 999;}
.header_nav .menu .sub li.active a	{ color: #e00814;}

.sticky .header 					{ box-shadow: 0 0 30px 0 rgb(0 0 0 / 10%); background: #fff;}


@media (min-width:1201px) {
.sticky .header                     { top: -60px;z-index: 99}
.header_nav .menu .vue_mobile,
.menu_mobile 						{ display: none;}
.header_nav .sub 					{ display: block !important;}
.header_nav .menu>li:hover>a:after  { width: 20px;}
.header_nav .sub li a:hover			{ color: #e00814;}
.sticky .header_nav .menu>li>a		{ line-height: 80px;}
.sticky .header .logo               { top: 65px; transform: scale(0.7);}
}
@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;background:#ffffff}
.header .logo						{ width: 180px; top: 28px; transform: none; z-index: 121;}
.header_right 						{ margin: 0;padding:0}
.header_right .link					{ margin-right: 0;}
.header_right .tel					{ margin-right: 40px;}

.header_nav 	  					{ width: 100%; padding: 0; position: fixed; right: 100%; top: 0; overflow-y: scroll;  z-index: 100;transition: 0ms ease-in-out 400ms;}
.header_nav::-webkit-scrollbar		{ display: none;}
.header_nav .menu  					{ width: 100%; margin: 0 auto; text-align: left; padding: 40px 5vw 100px 5vw; border-top: 100px solid #fff; position: relative; z-index: 100; 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: 20px; line-height: 50px; height: 50px;}
.header_nav .menu li i				{ width: 50px; height: 40px; display: block; margin-top: -45px; position:absolute;z-index:5; background:url(../images/arrow_down.svg) 50% no-repeat #f2f2f2; float:right; right: 0;}
.header_nav .menu li i.active 	    { transform: rotate(180deg);}
.header_nav .sub li a               { text-align: left;}
.header_nav .menu>li.active>a       { color: #e00814;}
.header_nav .menu>li>a:after        { display: none;}
.header_nav .menu .sub 				{ width: auto; visibility: visible; position: relative; left: auto; top: auto; padding: 20px 0; margin: 15px 0; opacity: 1; display: none;}
.header_nav .menu .sub li a			{ font-size: 16px; line-height: 40px; height: 40px; padding-left: 40px; letter-spacing: 0.8px; font-weight: 600;}

/* 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:800px) {
.header_right .link.mail            { display: none;}
}
@media (max-width:600px) {
.header 							{ height: 90px;}
.header .logo						{ width: 150px; left: 0; top: 25px;}
.header_right 						{ padding-right: 0;}
.header_right .mail                 { display: none;}
.header_right .tel					{ padding: 0; width: 50px; height: 50px; font-size: 0; background: url("../images/tel.svg") 50% no-repeat; margin-right: 15px; margin-left: 0; background-size: 20px;}
.menu_mobile						{ margin: 15px -15px;}
.header_nav .menu  					{ padding: 20px 7.5vw 100px 7.5vw; border-width: 90px;}
.header_nav .menu>li>a				{ font-size: 18px; line-height: 50px; height: 50px;}
.header_nav .menu .sub 				{ padding: 15px 0; margin: 10px 0;}
.header_nav .menu .sub li a			{ padding-left: 25px;}
.header_right .link::before         { display: none;}
}


/***** slide galerie *****/
.slidegal                           { margin: 100px -15px;}
.slidegal .item                     { padding: 0 15px;}
.slidegal .item img                 { width: 100%; height: auto;}
@media (max-width:600px) {
.slidegal                           { margin: 30px -5px;}
.slidegal .item                     { padding: 0 5px;}
.slidegal .item img                 { width: auto; height: 370px;}
}



/***** moving galerie *****/
.moving_galerie 							{ width: auto; left: 50%; transform: translateX(-50%); position: relative; text-align: center; margin: 80px 0 80px 0;}
.moving_galerie .row 						{ width: auto; display: flex;}
.moving_galerie .row .item 					{ width: auto; display: flex; animation: scroll_gallery 80s linear infinite;}
.moving_galerie .row .item div 				{ padding: 0 15px;}
.moving_galerie .row .item img 				{ width: auto; height: 550px; display: block; margin: 0 auto; transition: all 300ms ease-in-out;}

@keyframes scroll_gallery {
0%											{ transform: translate(0, 0);}
100% 										{ transform: translate(-100%, 0); }
}
@media (max-width:1400px) {
.moving_galerie .row .item img 				{ height: 480px;}
}
@media (max-width:1200px) {
.moving_galerie .row .item img 				{ height: 440px;}
}
@media (max-width:1000px) {
.moving_galerie 							{ margin: 60px 0;}
.moving_galerie .row .item img 				{ height: 380px;}
}
@media (max-width:600px) {
.moving_galerie 							{ margin: 40px 0;}
.moving_galerie .row .item div 				{ padding: 0 5px;}
.moving_galerie .row .item img 				{ height: 60vw;}
}





/***** footer*****/
.footer								{ width: 100%; position: relative; padding-top: 100px; background:#000; color: #fff; font-size: 0;}
.footer .bloc_footer 				{ display: inline-block; vertical-align: top; line-height: 30px;}
.footer .bloc_footer                { margin-right: 50px;}
.footer .bloc_footer.last			{ margin-right: 0;position: relative;top: 60px}
.footer .titre_main                 { font-size: 18px; line-height: 26px; color: #e00814;}
.footer .bloc_footer.coordonnees    { margin-right: 100px;}
.footer .bloc_footer p				{ font-size: 16px; margin-top: 10px;}
.footer .bloc_footer p a			{ color: #fff; padding-left: 30px;text-transform: none;font-weight: 400}
.footer .bloc_footer p .tel         { background: url(../images/tel.svg) left center no-repeat; line-height: 40px;font-size: 16px}
.footer .bloc_footer p .mail        { background: url(../images/mail_red.svg) left center no-repeat; line-height: 40px;font-size: 16px}
.footer .bloc_footer p span			{ display: inline-block;}
.footer .bloc_footer				{ margin-top: 5px; display: inline-block;vertical-align: top; margin-right: 50px;}
.footer .bloc_footer li a			{ font-size: 16px; color: #fff; margin-top: 5px; background:url(../images/list.svg) 0 48% no-repeat; padding-left: 25px; display: inline-block;}
.footer	.rs							{ position: absolute; right: 0; top: 15px;}
.footer	.rs a						{ width: 50px; height: 50px; display: inline-block; vertical-align: top; border-radius: 50%; margin-right: 10px;}
.footer	.rs .facebook			    { background: url(../images/facebook.svg) 50% no-repeat #e00814;}
.footer	.rs .instagram			    { background: url(../images/instagram.svg) 50% no-repeat #e00814;}
.footer	.rs .linkedIn			    { background: url(../images/linkedIn.svg) 50% no-repeat #e00814;}
.footer	.rs .scroll					{ background: url(../images/scrolltop.svg) center no-repeat #4d4d4d; margin: 0;}
.footer_bottom   					{ padding: 20px 0; line-height: 0; margin-top: 80px;}
.footer_bottom li 					{ display: inline-block; font-size: 12px; line-height: 20px; 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: 5px; background: #fff;}
.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, #4d4d4d 0%, #4d4d4d 50%, #e00814 50%, #e00814 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: #e00814;}
.footer	.rs a:hover                 { background-color: #4d4d4d;}
.footer	.rs .scroll:hover			{ background-color: #e00814;}
.toponweb:hover span				{ background-position: 0 0;}
}
@media (max-width:1200px) {
.footer .bloc_footer 				{ margin-right: 80px;}
.footer .bloc_footer:not(.coordonnees)			{ 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 .wrapper:after              { display:none}
}
@media (max-width:600px) {
.footer								{ padding-top: 50px;}
.footer .logo						{ width: 170px; margin-bottom: 15px;display: inline-block;}
.footer .bloc_footer 				{ margin: 0;}
.footer .bloc_footer p b			{ font-size: 20px; line-height: 40px; margin-bottom: 5px;}
.footer .bloc_footer p              { font-size: 12px;line-height: 26px}
.footer	.rs							{ position: static; margin-top: 20px;}
.footer p.infos                     { padding-bottom: 20px}
.footer_bottom 	 					{ text-align: left; margin-top: 35px; padding: 0 0 30px 0;}
.footer_bottom li 					{ display: block; margin-right: 0; line-height: 25px;}
.footer_bottom li:after				{ display: none;}
.footer .bloc_footer .link          { position: relative; text-transform: none; height:50px;border-radius: 25px;margin-bottom: 10px;font-size: 11px!important;line-height: 50px;font-weight: 600}
.toponweb span                      { background: linear-gradient(to left, #3b3b3b 0%, #3b3b3b 50%, #3b3b3b 50%, #3b3b3b 100%);}
}
@media (max-width:350px) {
.footer .logo						{ width: 150px;}
}