/***** fonts et reset *****/
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Frank+Ruhl+Libre:wght@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: 500;}
ul									{ list-style-type: none;}
body								{ font: 400 14px/32px "Poppins"; letter-spacing: 0.2px; color: #272727; background: #113124; position: relative;}
body.active_overflow				{ height: 100vh; overflow: hidden;}
a									{ text-decoration: none; color: #272727; position: relative;}
p a                                 { color: #8cb239;}
img									{ border: none;}
main 								{ position: relative; z-index: 10;}
#wrapper 							{ min-width: 320px;margin: 0 auto;background: #ffffff; overflow: hidden; position: relative;}
#wrapper *							{ box-sizing: border-box;}
#footer 							{ position: relative; z-index: 15;}


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


/***** 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: 1380px; margin: 0 auto; position: relative;}
.clear								{ clear: both; display: block;}
.titre_main	 						{ font: 700 30px/35px "Frank Ruhl Libre"; position: relative; margin-bottom: 15px;letter-spacing: 0;color: #056839;}
.titre_main span					{ color: #8cb239;}
.sous_titre 						{ font: 400 22px/30px "Frank Ruhl Libre";letter-spacing: 0; position: relative; margin-bottom: 15px; color: #8cb239;}
.chapo		 						{ font: 400 14px/30px "Poppins";color: #272727;letter-spacing: 0.2px;}
.link 								{ font: 700 13px/60px "Poppins"; letter-spacing: 1px; text-transform: uppercase; height: 60px; border: none; display: inline-block; vertical-align: middle; color: #8cb239; padding: 0 40px; background: linear-gradient(to top, #ffffff 0%, #ffffff 50%, #056839 50%, #056839 100%); background-size: 100% 200%; background-position: 0 100%; cursor: pointer;border-radius: 5px;}
.link_plus							{ display: block; width: 60px; height: 60px; border-radius: 50%; background: url("../images/plus.svg") 50% no-repeat #8cb239;}
.second_link                        { font: 700 13px/30px "Poppins";letter-spacing:1px;text-transform: uppercase; color: #8cb239;background: url(../images/arrow.svg)right 20px center no-repeat;padding-right: 80px;display: inline-block;margin-top: 0; }

@media (min-width:1201px) {
.link:hover 						{ background-position: 0 0;color: #ffffff; }
.link_plus:hover					{ background-color: #8cb239;}
p a:hover                           { color: #16402f;}
.second_link:hover                  { background-position-x:120px ; }
}
@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: 25px; line-height: 35px;margin-bottom: 10px;}
.sous_titre							{ font-size: 18px; line-height: 28px;}
}

/***** header et menu *****/
.header 							{ width: 100%; /*background: #16402f0a;*/ font-size: 0; line-height: 0; text-align: right; position: absolute; top: 0;z-index: 100;margin: auto;transition: all 400ms ease-in-out;}
.header .logo						{ position: absolute; left: 5vw; top: 50%; transform: translateY(-50%); z-index: 90;}
.header .logo img					{ width: 100%; height: auto;filter: brightness(100);}
.header_right 						{ display: inline-block; vertical-align: middle; position: relative; z-index: 120; margin-left: 40px; padding-right: 5vw;}
.header_right .link					{ font-size: 12px; line-height: 60px; height: 60px; padding: 0; width: 160px; text-align: center;}
.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: 700 13px/120px "Poppins";color: #ffffff; text-transform: uppercase; letter-spacing: 1px; height: 120px; display: block; transition-property: color, height, line-height;}
.header_nav .menu>li.active>a 		{ color: #8cb239;}
.header_nav .sub					{ width: 320px; text-align: center; position: absolute; top: 100%; left: 50%; margin-left: -160px; display: block; visibility: hidden; opacity: 0; background: #f7f3ef; padding:0;border-radius: 5px;}
.header_nav .sub.sized				{ width: 280px; margin-left: -140px;}
.header_nav .sub li					{ width: 100%; margin: 0;}
.header_nav .sub li a				{ width: 100%; font: 400 13px/50px "Poppins"; text-transform: inherit; letter-spacing: 0.2px; height: 50px; color: #056839;transition: all 300ms ease-in-out;}
.header_nav .menu li:hover .sub		{ opacity: 1; visibility: visible; z-index: 999; top: 75%;}
.header_nav .menu .sub li.active a	{ color: #8cb239;}

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

@media (min-width:1201px) {
.header_nav .menu .vue_mobile,
.menu_mobile 						{ display: none;}
.header_nav .sub 					{ display: block !important;}
.header_nav .sub li                 { position: relative; }

.header_nav .menu>li:hover>a,
.header_nav .sub li a:hover			{ color: #8cb239;}
.header_nav .sub li a:hover			{ background: #ffffff;}
.header_nav .sub li:last-child a:hover            { border-radius: 0 0 5px 5px;}
.header_nav .sub li:nth-child(2) a::after         { width: 10px; height: 10px; position: absolute; left: 50%; top: -5px; margin: 0 0 0 -5px; transform: rotate(45deg); background: #f7f3ef; content: "";}
.header_nav .sub li:nth-child(2) a:hover::after   { background: #ffffff;}
.header_nav .sub li:nth-child(2) a:hover          { border-radius: 5px 5px 0 0;}

.sticky .header_nav .menu>li>a		{ line-height: 90px; height: 90px;}
}
@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: #ffffff; position: absolute; right: 50%; top: 50%; margin: -1px -15px 0 0;}
.menu_mobile div:before				{ width: 100%; height: 2px; background: #ffffff; position: absolute; right: 0; top: 8px; content: "";}
.menu_mobile div:after				{ width: 100%; height: 2px; background: #ffffff; 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: all ease-in-out 400ms;}
.header_right 						{ margin: 0;}
.header_right .link					{ margin-right: 5vw;}
.header .logo	                    { width: 150px;z-index: 150;top: 25px;transform: inherit;}

.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: 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: -22px; margin-left: -5px; opacity: 0; transition: all 300ms ease-in-out; background: #ffffff; content: "";}
.header_nav .menu li i.active:after	{ opacity: 1;}
.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 						{ background: #113124; height: 100vh;}
.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;background: #ffffff;}
.sticky .header 					{ box-shadow: 0 0 30px 0 rgb(0 0 0 / 10%);background: #ffffff;}
.header .logo                       { width: 128px;left: 50%;top:20px; transform: translateX(-50%); }
.header .logo img					{ filter:none;}
.header_right 						{ padding-right: 7.5vw;width: 100%;}
.header_right .link					{ width: 48px; height: 48px; font-size: 0; background: url("../images/tel.svg") 50% #056839 no-repeat; margin-right: 0;position: absolute;left: 7.5vw;top: 50%;transform: translateY(-50%);border-radius: 50%;}
.menu_mobile div,.menu_mobile div:before,
.menu_mobile div:after				{background: #056839;}
.menu_mobile						{ margin: 10px -15px;}
.header_nav .menu  					{ padding: 7.5vw;}
.header_nav .menu>li>a				{ font-size: 14px; line-height: 48px; ; height: 44px;color:#16402f;}
.header_nav .menu li i				{ height: 44px;}
/* active menu mobile */
.header.active 						{ background: #ffffff;}
}
@media (max-width:350px) {
.header .logo						{ width: 100px;top: 25px;}
}

/***** Bloc-custom *****/
.bloc_custom                        { position: relative; margin: 95px 0;background: #16402f;}
.bloc_custom .photo					{ position: absolute;width: 50%;height: 100%;}
.bloc_custom .photo	.link           { position: absolute;bottom: 50px;left: 50%;transform: translateX(-50%);z-index: 5;}
.bloc_custom .photo img             { width: 100%;height: 100%;object-fit: cover;}
.bloc_custom .texte                 { width: 50%;margin: auto  0 auto 50%;padding: 100px 80px 75px;background: #ffffff;}
.bloc_custom .subpage               { margin: 30px 0;}
.bloc_custom .subpage .item         { background: url(../images/arrow.svg)right center no-repeat ; height: 70px;display: grid;align-items: center;border-top:1px solid #e4e2e0;font: 700 13px/23px "Poppins";text-transform: uppercase; color: #8cb239;}
.bloc_custom .subpage .item:last-child{ border-bottom:1px solid #e4e2e0;}
.bloc_custom.reverse,
.bloc_custom.reverse .texte         { background: #f7f3ef;margin: 0;padding-left: 0;}
.bloc_custom.reverse .photo         { right: 0;}
.bloc_custom.reverse .texte         { margin: auto  50% auto 0; }
@media (min-width:1201px) {
.bloc_custom .subpage .item:hover   {color: #056839;background: url(../images/arrow_hover.svg)right center no-repeat ;}
}
@media (max-width:1400px) {
}
@media (max-width:1000px) {
.bloc_custom                        { background: #ffffff;margin: 60px 0;} 
.bloc_custom .photo	                { position: relative;width: 100%; }
.bloc_custom .texte                 { width: 100%;margin: auto;padding: 80px 0 0; }
}
@media (max-width:600px) {
.bloc_custom .photo img             { max-height: 320px;}
}

/***** bandeau téléphone *****/
.bandeau 						    { position: relative; background: #16402f; font: 400 20px/40px "Poppins"; color: #ffffff; display: block; text-align: center; padding:55px 5vw; margin: 105px 0 120px;}
.bandeau p                          { padding: 0 ;margin-bottom: 0;}
.bandeau p a                        { display: inline-block;}
@media (min-width:1201px) {
.bandeau a:hover					{ color: #056839;}
}
@media (max-width:1400px) {
.bandeau  						    { margin: 80px 0;}
}
@media (max-width:1000px) {
.bandeau  						    { margin: 80px 0;}
}
@media (max-width:600px) {
.bandeau     					    { padding: 40px 7.5vw;margin: 40px 0; }
.bandeau p     					    { font: 400 18px/30px "Poppins";letter-spacing: 0.2px;}
}

/***** blockquote *****/
.blockquote 							{ text-align: center; margin: 100px 0 105px;}
.blockquote img 						{ display: block; margin: 0 auto 20px;}
.blockquote .titre_main 				{ margin: 20px 0 0 0;}
.blockquote p				            { font:400 20px/40px "Poppins";letter-spacing: 0.2px;color: #272727;}

@media (max-width:760px) {
.blockquote                             { padding: 0 60px;margin: 80px 0;}
}
@media (max-width:600px) {
.blockquote                             { display: none; }
}

/***** footer*****/
.footer								{ width: 100%; position: relative; padding-top: 80px; background: url(../images/fond_footer.png)right bottom no-repeat,#16402f; color: #fff; font-size: 0;}
.footer .logo						{ height: auto; display: block; margin: 0 0 30px 0;}
.footer .logo img 					{ width: 100%; height: auto; }
.footer .bloc_footer 				{ display: inline-block; vertical-align: top; margin-right: 80px; line-height: 30px;}
.footer .bloc_footer .atelier       { margin-bottom: 35px;}
.footer .bloc_footer.last			{ margin-right: 0;}
.footer .bloc_footer p				{ font-size: 13px;line-height: 30px;letter-spacing: 0.2px; color: #ffffff; margin-top: 10px;}
.footer .bloc_footer p b			{ display: block; text-transform: uppercase; font: 400 13px/30px "Poppins"; letter-spacing: 0.2px; color:#8cb239; padding-bottom: 0;}
.footer .bloc_footer p a			{ color: #fff;}
.footer .bloc_footer p span			{ display: inline-block;}
.footer .bloc_footer ul				{ margin-top: 5px;}
.footer .bloc_footer li a			{ font-size: 13px;line-height: 30px;letter-spacing: 0.2px; color: #fff; margin-top: 3px; background:url(../images/list.svg) 0 48% no-repeat; padding-left: 20px; display: inline-block;}
.footer	.rs							{ position: absolute; right: 0; top: 0;}
.footer	.rs a						{ width: 50px; height: 50px; display: inline-block; vertical-align: top; border-radius: 50%;margin-left: 10px;}
.footer	.rs .facebook				{ background: url(../images/facebook.svg) 50% no-repeat #8cb239;}
.footer	.rs .youtube				{ background: url(../images/you_tube.png) 50% no-repeat #8cb239;}
.footer	.rs .instagram				{ background: url(../images/instagram.png) 50% no-repeat #8cb239;}
.footer	.rs .Linked_in				{ background: url(../images/linked_in.png) 50% no-repeat #8cb239;}
.footer	.rs .scroll					{ background: url(../images/scrolltop.svg) 50% 46% no-repeat #ffffff; margin-left: 10px;}
.footer_bottom   					{ padding: 20px 0; line-height: 0; margin-top: 70px;}
.footer_bottom li 					{ display: inline-block; font-size: 12px; line-height: 30px; 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: -12px; top: 10px; background: #8cb239;}
.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, #8cb239 0%, #8cb239 50%, #056839 50%, #056839 100%); background-size: 200% 100%; background-position: 100% 0;}
.toponweb img						{ width: 70px; 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: #8cb239;}
.footer	.rs .facebook:hover,.footer	.rs .youtube:hover,.footer	.rs .instagram:hover,
.footer	.rs .Linked_in:hover        { background-color: #056839;}
.footer	.rs .scroll:hover			{ background-color: #8cb239;background: url(../images/scrolltop_hover.svg) 50% 46% no-repeat #8cb239;}
.toponweb:hover span				{ background-position: 0 0;}
}
@media (max-width:1400px) {
.footer								{ padding-top: 9vw;}
.footer_bottom   					{ margin-top: 7vw;}
}
@media (max-width:1200px) {
.footer .bloc_footer 				{ margin-right: 80px;}
.footer .bloc_footer.last			{ display: none;}
}
@media (max-width:1000px) {
.footer								{ padding-top: 12vw;}
.footer .bloc_footer 				{ display: block; margin: 40px 0 0 0;}
.footer .services            	    { display: none;}
.footer_bottom   					{ margin-top: 40px;}
}
@media (max-width:600px) {
.footer								{ padding-top: 50px;text-align: center;background:#16402f;}
.footer .logo						{ width: 130px;margin:0 auto 35px;}
.footer .bloc_footer 				{ margin: 20px 0 0 0;}
.footer .bloc_footer .siege,       
.footer .bloc_footer .atelier       { margin: 20px 0 0;}
.footer .bloc_footer p b			{ font-size: 13px; line-height: 23px;letter-spacing: 0.2px;}
.footer .rs							{ position: static; margin-top: 45px;}
.footer .rs a                       { margin: 0 5px; }
.footer_bottom 	 					{ text-align: left; margin-top: 45px; padding: 0 0 45px 0;}
.footer_bottom li 					{ display: block; margin-right: 0; line-height: 30px;}
.footer_bottom li:after				{ display: none;}
}
@media (max-width:350px) {
.footer .logo						{ width: 150px;}
}




