/***** fonts et reset *****/
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');

:root {
    --main-color: #2d4175;
    --second-color: #96ac99;
    --white: #fff;
    --greylight: #c6c6c6;
    --grey: #666666;
    --beige: #f8f3ec;
    --black: #000;
    
    --font-main: "Poppins", sans-serif;   

    --body_font: 400 14px / 30px var(--font-main);
    --body_font-mobile: 400 13px / 26px var(--font-main);

    --titre-main: 400 40px/50px var(--font-main); 
    --titre-main-mobile: 400 22px/32px var(--font-main);

    --sous-titre: 400 20px/30px var(--font-main);
    --sous-titre-mobile: 400 16px/26px var(--font-main);

    --titre: 600 180px/130px var(--font-main);
    --titre-tablet: 600 90px/40px var(--font-main);
    --titre-mobile: 400 22px/35px var(--font-main);
}

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; box-sizing: border-box;}
strong, b							{ font-weight: 700;}
ul									{ list-style-type: none;}
body								{ font: var(--body_font);  letter-spacing: 0.5px; color: var(--grey); background: var(--white); position: relative; overflow-x: hidden;}
body.active_overflow				{ height: 100vh; overflow: hidden;}
a									{ text-decoration: none; color: var(--main-color); position: relative;}
img									{ border: none; }
main 								{ position: relative;}
#wrapper 							{ min-width: 320px; width: 100%;}
#wrapper *							{ box-sizing: border-box;}
#footer 							{ position: relative; z-index: 15;}

@media (max-width:700px) {
body								{ font-size: 14px; line-height: 28px;}
}


/***** scollbar *****/
::-webkit-scrollbar 				{ width: 6px; height: 6px; background-color: var(--white);}
::-webkit-scrollbar-thumb			{ background-color: var(--main-color);}


/***** transition *****/
@media (min-width:1201px) {
.link, :before, :after, a, a span, .logo, .header, .sub { transition: all 400ms ease-in-out;}
}


/***** class *****/
.wrapper 							{ width: 90vw; max-width: 1200px; margin: 0 auto; position: relative; clear: both;}
.wrapper_large						{ max-width: 1600px;}
.clear								{ clear: both; display: block;}
span.link-plus, span.link-moins     { cursor: pointer; border-bottom: 1px solid transparent; padding-bottom: 2px; color: var(--second-color); transition: all 400ms ease-in-out;}

.titre_main	 						{ font: var(--titre-main); position: relative; color: var(--main-color); margin-bottom: 15px; letter-spacing: 0.4px;}
.titre_main span                    { color: var(--main-color);}
.titre_main + .sous_titre           { margin-top: -15px;}
.sous_titre 						{ font: var(--sous-titre); letter-spacing: 0.5px; position: relative; color: var(--second-color); margin-bottom: 10px;}
.titre                              { font: var(--titre); color: var(--main-color); letter-spacing: 4px; text-transform: uppercase; position: absolute; top: 0; left: 50%; right: 0; transform: translateX(-50%); width: max-content; margin: auto; color: var(--beige);}
.chapo		 						{ font: 400 14px/30px var(--font-main); margin-bottom: 0;}
.link 								{ font: 500 14px/60px var(--font-main); height: 60px; display: inline-block; vertical-align: top; color: var(--white); padding: 0 30px; background: var(--main-color); border-radius: 5px; border: none; letter-spacing: 1px; cursor: pointer; position: relative;}


@media (min-width:1201px) {
.link:hover 						{ background-color: var(--second-color); color: var(--white);}
span.link-plus:hover, span.link-moins:hover {border-color: var(--second-color); color:  var(--second-color);}
}
@media (max-width:1200px) {
.wrapper 							{ min-width: inherit;}
}
@media (max-width:1280px) {
.titre                              { font: var(--titre-tablet);}
}

@media (max-width:1000px) {
.wrapper 							{ max-width: 750px;}
}
@media (max-width:700px) {
#wrapper::before                    { display: none;}
.wrapper 							{ width: 85vw;}
.titre_main	 						{ font: var(--titre-main-mobile);}
.titre                              { font: var(--titre-mobile); position: static; transform: none; letter-spacing: 0.4px; width: auto; color: var(--main-color); text-transform: initial;}
.sous_titre 						{ font: var(--sous-titre-mobile); margin-bottom: 10px;}
.chapo		 						{ font: 400 14px/26px var(--font-main);}
.link 								{ font-size: 13px; width: 100%; border-radius: 5px; text-align: center;}
}


/***** header et menu *****/
.header 							{ width: 100%; font-size: 0; line-height: 0; text-align: right; position: fixed; left: 0; top: 0; z-index: 100; transition: all 400ms ease-in-out;  z-index: 2000;}
.promo                              { text-align: center; background-color: var(--main-color); color: var(--white); padding: 0 10px; position: relative; z-index: 1; font: 400 14px/50px var(--font-main);}
.promo .label                       { border-radius: 5px; background: var(--white); padding: 0 10px; color: var(--main-color); border-radius: 5px; display: inline-block; vertical-align: middle; font: 700 10px/25px var(--font-main); margin-right: 15px;}
.promo a                            { color: var(--white); border-bottom: 1px solid var(--white); margin-left: 15px;}
.header .catalogue                  { position: absolute; right: 0; bottom: 0; text-align: center; color: var(--white); background: var(--second-color); padding: 20px 10px 45px; font: 500 15px/22px var(--font-main); letter-spacing: 0.5px; width: 190px; border-radius: 10px;}
.header .logo                       { position: absolute; left: 0; bottom: 10px; line-height: 0; z-index: 90; transform-origin: left;}
.header .logo img                   { display: inline-block; vertical-align: top; width: 100%;}
.header_nav							{ width:100%; display:block; position:relative; z-index:40;}
.header_nav .menu_top				{ position: relative; transition:margin 400ms ease-in-out; padding-top: 10px;}	
.header_nav .menu_top>*             { display: inline-block; vertical-align: top;}
.header_nav .menu_top li			{ display: inline-block; position: relative; top:0; padding-left: 35px;}	
.header_nav .menu_top li a			{ color: var(--black); font: 400 12px/45px var(--font-main); letter-spacing: 0.5px;}	
.header_nav .menu_top li:after     	{ content: ""; position: absolute; top: 50%; margin-top: -5px; left: 18px; width: 1px; height: 10px; background: var(--black);}
.header_nav .menu_top li:first-child::after { display:none;}

.header_nav .menu_top li.active a	{ color:var(--second-color);}


.header_nav .menu       			{ display:inline-block;}	
.header_nav .menu>li				{ display:inline-block; vertical-align:middle; margin-left: 45px; position: relative;}
.header_nav .menu li:first-child    { margin: 0;}
.header_nav .menu li a				{ font: 400 15px/45px var(--font-main); color: var(--black); letter-spacing: 1px; height: 55px; display: block; transition-property: all;}
.header_nav .menu>li.active>a		{ color:var(--second-color);}
.header_nav .sub					{ width: 164px; margin-left: -82px; left: 50%; text-align: left; position: absolute; top: 100%; display: block; visibility: hidden; opacity: 0; background: var(--second-color); padding: 0; border-radius: 5px;}
.header_nav .sub li					{ width: 100%; margin: 0;}
.header_nav .sub li a				{ width: 100%; letter-spacing: 0.4px; height: 40px; color: var(--white); line-height: 40px; display: grid; align-items: center; padding: 0 40px; font: 500 14px/40px var(--font-main); text-align: center; text-transform: initial;}
.header_nav .menu li:hover .sub		{ opacity: 1; visibility: visible; z-index: 999;}
.header_nav .menu .sub li.active a	{ color: var( --main-color) !important;}


@media (min-width:1201px) {
.header .catalogue.m                { display: none;}
.header .catalogue::after           { content: url(../images/icone_download.svg); display: block; position: absolute; left: 0; right: 0; bottom: 20px; line-height: 0;}
.promo a:hover                      { border-color: transparent;}
.header_nav .menu .vue_mobile,
.menu_mobile 						{ display: none;}
.sticky .header                     { box-shadow: 0 0 80px 0 rgba(0, 0, 0, 0.2);background: var(--white);}
.header_nav .menu>li:hover>a,
.header_nav li a:hover			    { color: var(--second-color);}
.header_nav .menu>li:hover>a		{ color: var(--second-color);}
.header_nav .menu>li:hover .sub	    { opacity: 1; visibility: visible; z-index: 10;}
.header_nav .menu_top li a:hover    { color: var(--second-color) !important;}
.header_nav .sub li a:hover			{ color: var(--main-color);}
.sticky .header                     { top: -125px;}
.header .catalogue:hover            { background-color: var(--main-color);}
.sticky .header .catalogue          { bottom: 13px; padding: 10px;}
.sticky .header .catalogue::after   { opacity: 0;}
.sticky .header .logo               { transform: scale(0.8); bottom: 0;}
.header .logo img                   { transition: all ease-in-out 400ms;}
.header_nav .menu li:hover .sub		{ opacity: 1; visibility: visible; z-index: 999;}
.sticky .header_nav .menu           { padding-top: 0;}
.sticky .header_nav .menu>li>a      { line-height: 90px; height: 90px;}
.sticky .header_nav .menu>li        { background-position: right center;}
.header .wrapper                    { padding: 20px 230px 0 0;}
}
@media (max-width:1200px) {
.promo                              { display: none;}
.sticky .header                     { top: 0;}
.header                             { z-index: 201; padding: 0; background: var(--white); padding-top: 40px;}
.sticky .header                     {box-shadow: 0 0 80px 0 rgba(0, 0, 0, 0.2);}
.header .logo                       { top: 50%; transform: translateY(-50%); bottom: auto;}
.header .logo img                   { width: 150px;}
.header .link                       { right: 70px; top: 20px;}
.menu_mobile						{ width:60px; height:60px; display:inline-block; vertical-align:middle; cursor:pointer; position:relative; z-index:60; margin: 20px -10px; transition:height 400ms ease-in-out;}
.menu_mobile div					{ width:40px; height:2px; background:var(--main-color); position:absolute; right:50%; top:50%; margin:-1px -20px 0 0;}
.menu_mobile div:before				{ width:100%; height:2px; background:var(--main-color); position:absolute; right:0; top:9px; content:"";}
.menu_mobile div:after				{ width:100%; height:2px; background:var(--main-color); position:absolute; right:0; top:-9px; content:"";}
.menu_mobile.active div				{ height:0;}
.menu_mobile.active div:before		{ top:0; transform:rotate(45deg);  width: 100%;}
.menu_mobile.active div:after		{ top:0; transform:rotate(-45deg);}
.header_nav 	  					{ width:100%; height:100vh; background:var(--white); position:fixed; right:0; top:-120%; overflow-y:scroll; display: flex; flex-direction: column; padding: 180px 0 0; z-index:50; transition:top 400ms ease-in-out 400ms;}
.header_nav::-webkit-scrollbar		{ display:none;}
.header_nav .menu_top				{ text-align: left; display: table; padding: 40px 0 0 0; order: 1; transition:opacity 400ms ease-in-out 0ms; opacity:0; position: relative; background: none; padding-bottom: 0; max-width:750px;margin:0 auto;width:90vw;}	
.header_nav .menu_top:before     	{ content: ""; width: 50px; height: 2px; top: 20px; left: 0; position: absolute; background-color: var(--white); }	
.header_nav .menu_top::after        { display: none; }
.header_nav .menu_top li 			{ display: block; margin: 0; padding: 0;}	
.header_nav .menu_top li a 			{ line-height: 40px;}	
.header_nav .menu_top li:after		{ display:none;}

.header_nav .menu  					{ width:100%; max-width: 750px; margin: 0 auto; width: 90vw; text-align:left; padding:0; transition:opacity 400ms ease-in-out 0ms; opacity:0;}
.header_nav .menu li 				{ width:100%; display:block; margin:0; background: none; padding: 0;}
.header_nav .menu>li>a				{ line-height:50px; height:auto;}
.header_nav .menu li i.active:after	{ opacity:1;}
.header_nav .menu li i				{ width: 50px; background-color: var(--main-color); height: 41px; display: block; margin-top: -46px; position: relative; z-index: 5;float: right; border-radius: 5px;}
.header_nav .menu li i::after       { content: ""; display: block; position: absolute;  transform-origin: center; transition: all ease 400ms; width: 100%; height: 100%; background: url(../images/chevron_down_white.svg) no-repeat center;}
.header_nav .menu li a	            { background: none;}
.header_nav .menu li i.active::after{ transform: rotate(180deg);}

.header .wrapper .catalogue         { display: none;}
.header .catalogue                  { left: 0; top: 0; bottom: auto; border-radius: 0; text-align: center; width: 100%; padding: 0 10px; line-height: 40px; height: 40px; z-index: 101;}
.header .catalogue span             { padding-left: 35px; background: url(../images/icone_download.svg) left center no-repeat; display: inline-block; vertical-align: top;}
    
/* sous-menu simple */
.header_nav .menu .sub 				{ width: 100%; position: relative; left: auto; top: auto; padding: 15px 0; margin: 0; opacity: 1; display: none; visibility: visible; z-index: 150;}
.header_nav .menu .sub li  			{ width: 100%;}
.header_nav .menu .sub li a			{ width: 100%; line-height: 50px; height: 50px; text-align: left;}

.header_nav.active					{ top:0; }
.header_nav.active .link		    { opacity:1; transition-delay:1200ms;}
.header_nav.active .menu_top		{ opacity:1; transition-delay:1000ms; background: none;}
.header_nav.active .menu			{ opacity:1; transition-delay:800ms;}
}

@media (max-width:700px) {
.menu_mobile                        { margin: 10px -10px;}
.header .logo img                   { width: 120px;}
.header .catalogue                  { font-size: 13px;}
.header_nav                         { padding: 150px 7.5vw 0; align-content: baseline;}
.header_nav .menu_top,
.header_nav .menu                   { width: 100%;}
}


.ul_list						    { margin: 15px 0; padding: 5px 0 0 0;}
ol						            { margin: 15px 0 15px 20px; padding: 5px 0 0 0;}
.ul_list li, ol li					{ padding: 5px 0 5px 25px; position: relative; line-height: 30px;}
.ul_list li::before                 { content: ""; display: block; position: absolute; top: 16px; left: 0; width: 8px; height: 8px; border-radius: 50%; background: var(--second-color);}
@media (max-width:700px) {
    .ul_list li, ol li              { line-height: 28px;}
}


/***** table plus *****/
.table_plus 						{ position: relative; margin: 90px 0 100px; clear: both;}
.table_plus .item:not(:last-of-type){ margin-bottom: 10px; border-bottom: none;}
.table_plus .sous_titre             { margin-bottom: 25px;}
.table_plus .hide 					{ padding: 20px 30px 10px; display: none;}
.table_plus .hide :last-child       { margin-bottom: 0;}
.table_plus .hide p                 { margin-bottom: 15px;}
.table_plus .hide ul 				{ padding-left: 20px;}
.titre_plus 						{ position: relative; letter-spacing: 0.4px; cursor: pointer; padding: 15px 80px 15px 30px; background: var(--beige); color: var(--grey); font: 400 14px/30px var(--font-main); transition: all 400ms ease-in-out; border-radius: 5px;}
.titre_plus:before					{ width: 20px; height: 2px; background: var(--main-color); position: absolute; right: 30px; top: 50%; margin-top: -1px; transition: all 400ms ease-in-out; content: "";}
.titre_plus:after					{ width: 2px; height: 20px; background: var(--main-color); position: absolute; right: 39px; top: 50%; margin-top: -10px; transition: all 400ms ease-in-out; content: "";}
.titre_plus.active:after 			{ transform: rotate(90deg);}

@media (max-width:1000px) {
.table_plus                         { margin: 80px 0;}
.table_plus .hide 					{ padding: 40px 0;}
}
@media (max-width:700px) {
.table_plus 						{ margin: 20px 0 50px;} 
.table_plus .sized					{ margin-bottom: 20px;} 
.table_plus .hide 					{ padding: 20px 0 10px;}
.titre_plus 						{ font-size: 13px; line-height: 25px; padding: 18px 55px 18px 20px; }
.titre_plus:before					{ right: 20px;}
.titre_plus:after					{ right: 29px;}
}


/***** documents *****/
.documents .grid                    { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px;}
.documents a                        { display: block; border-radius: 10px; background: var(--second-color); text-align: center; min-height: 210px; padding: 40px 30px;}
.documents a:last-child             { background-color: var(--main-color);}
.documents .icone                   { display: grid; height: 50px; align-items: end; justify-content: center;}
.documents .sous_titre              { color: var(--white); margin: 10px 0 0; display: block;}

@media (min-width:1201px) {
.documents a:hover                  { background: var(--main-color);}
.documents a:last-child:hover       { background-color: var(--second-color);}
}
@media (max-width:1280px) {
.documents                          { padding-top: 40px;}
}
@media (max-width:1000px) {
.documents .grid                    { gap: 10px;}
}
@media (max-width:700px) {
.documents .grid                    { grid-template-columns: 1fr;}
.documents .sous_titre              { margin-top: 0; font-size: 13px;}
.documents .icone,
.documents .sous_titre br           { display: none;}
.documents a                        { display: grid; align-items: center; justify-content: center; min-height: 60px; padding: 0 20px; border-radius: 5px;}
}



/***** bandeau *****/
.bandeau                            { text-align: center; font: 500 20px/30px var(--font-main); color: var(--white); background: var(--main-color); border-radius: 10px; padding: 40px; margin: 100px 0;}
.bandeau a                          { border-bottom: 1px solid transparent; color: var(--second-color);}

@media (min-width:1201px) {
.bandeau a:hover                    { border-color: var(--white); color: var(--white);}
}
@media (max-width:1000px) {
.bandeau                            { margin: 80px 0;}
}
@media (max-width:700px) {
.bandeau                            { display: none;}
}



/***** footer*****/
/***** footer*****/
.footer								{ width: 100%; position: relative; padding-top: 90px; color: var(--white); font-size: 0; background: var(--main-color);}
.footer .logo_footer                { font: 400 25px/35px var(--font-main); color: var(--white); text-transform: uppercase; margin-bottom: 15px;}
.footer .bloc_footer.coordonnees    { margin-top: 0; margin-right: 100px;}
.footer .bloc_footer 				{ line-height: 30px; font-size: 16px; margin-top: 67px; margin-right: 50px; display: inline-block; vertical-align: top;}
.footer .bloc_footer p				{ font-size: 14px;}
.footer .bloc_footer p a			{ color: var(--white); text-transform: none; display: inline-block; border: none;}
.footer .bloc_footer li a           { color: var(--white); padding-left: 25px; background: url(../images/list.svg) left center no-repeat; font-size: 14px;}
.footer .bloc_footer li             { margin-bottom: 10px;}
.footer .bloc_footer .phone         { background: url(../images/phone.svg) left center no-repeat; line-height: 30px; padding-left: 30px; margin-top: 0; margin-bottom: 15px;}
.footer .bloc_footer .tel           { background: url(../images/tel.svg) left center no-repeat; line-height: 30px; padding-left: 30px; margin-top: 0;}
.footer .bloc_footer .mail          { background: url(../images/mail.svg) left center no-repeat; line-height: 40px; padding-left: 30px; margin-bottom: 15px;}
.footer .bloc_footer .localisation  { background: url(../images/marker.svg) left 4px no-repeat; line-height: 26px; padding-left: 30px; margin-bottom: 15px;}
.footer	.rs							{ position: absolute; right: -15px; top: 5px;}
.footer	.rs a						{ display: inline-block; vertical-align: top; width: 50px; height: 50px;}
.footer	.rs .facebook			    { background: url(../images/facebook.svg) 50% no-repeat ; margin-right: 10px;}
.footer	.rs .scroll					{ background: url(../images/scrolltop.svg) center no-repeat;}
.footer_bottom   					{ padding: 20px 0; line-height: 0; margin-top:40px;}
.footer_bottom li:not(:last-child)::after { width: 1px; height: 9px; content: ""; position: absolute; right: -17px; top: 12px; background: var(--second-color);}
.footer_bottom li 					{ display: inline-block; font-size: 11px; line-height: 32px; margin-right: 35px; position: relative;}
.footer_bottom li a 				{ color: var(--white);}
.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:  var(--white); 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:not(.link):hover,
.footer_bottom li a:hover,
.footer .bloc_footer li a:hover 	{ color: var(--second-color);}
.footer	.rs .scroll:hover		    { background-color:var(--second-color);}
.footer	.rs .facebook:hover		    { background: url(../images/facebook_blue.svg) 50% no-repeat var(--second-color);}
.toponweb img                       { transition: all ease-in-out 400ms;}
.toponweb:hover span				{ background-color:  var(--second-color);}
.toponweb:hover img                 { filter: brightness(0) invert(1);}
}
@media (max-width:1200px) {
.toponweb                           { position: absolute;}
}
@media (max-width:1000px) {
.footer                             { padding-top: 50px; border-radius: 0;}
.footer .wrapper                    { display: block; padding-right: 0;}
.footer .bloc_footer 				{ margin: 0 0 40px; display: none;}
.footer .bloc_footer.coordonnees    { display: block;}
.footer .encart                     { grid-template-columns: auto 1fr;}
.footer .bloc_footer p              { margin: 0;}
.footer_bottom   					{ margin-top: 50px;}
}
@media (max-width:700px) {
.footer                             { text-align: center; padding-top: 45px;}
.footer .logo_footer                { font-size: 22px; line-height: 30px; margin-bottom: 5px;}
.footer .bloc_footer p              { font-size: 13px;}
.footer .bloc_footer .localisation  { margin-bottom: 20px;}
.footer .bloc_footer.coordonnees    { margin: 0 auto 30px;}

.footer .bloc_footer .localisation  { padding: 0; text-align: center; background: none; line-height: 30px;}
.footer .bloc_footer .tel,
.footer .bloc_footer .mail,
.footer .bloc_footer .phone         { padding: 0 20px; background: var(--white); color: var(--main-color); font: 500 13px/60px var(--font-main); letter-spacing: 0.5px; width: 100%; text-align: center; margin: 10px auto 0; max-width: 320px; display: block; border-radius: 5px;}

.footer	.rs							{ position: static; text-align: center;}
.footer .rs a                       { position: static;}
.footer .rs .facebook               { position: static; margin: 0;}
.footer .rs .scroll                 { right: 0; left: 0; top: auto; bottom: 10px; margin: auto;}
.footer_bottom 	 					{ margin-top: 20px; padding: 0 0 90px; text-align: center;}
.footer_bottom li 					{ display: block; margin-right: 0; line-height: 25px; font-size: 11px;}
.footer_bottom li:after				{ display: none;}
}


.link-moins,.link-plus              { cursor:pointer; color: var(--main-color); border-bottom: 1px solid var(--main-color);}
.textMore                           { display: none; padding-top: 15px;}
.textMore p:not(:first-of-type)     { margin-top: 15px;}
@media (min-width:1201px) {
.link-moins:hover,.link-plus:hover  { color: var(--main-color); border-color: transparent;}
}
@media (max-width:700px) {
.textMore                           { margin-top: 20px;}
}