/***** fonts et reset *****/
@import url('https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,300..800;1,300..800&display=swap');

:root {
    --main-color: #fecb00;
    --second-color: #152377;
    --third-color: #f7f2eb;
    --bg-color: var(--third-color);
    --cta-hover-color: var(--main-color);
    --title-font-family: "Open Sans", serif;
    --font-family: "Open Sans", sans-serif;
    --text-color: #000000;
}

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: 600;}
ul									{ list-style-type: none;}
body								{ font: 400 16px/30px var(--font-family);  letter-spacing: 0.4px; color: #000000; background: var(--bg-color); position: relative; overflow-x: hidden; height: 100vh; overflow-y: auto;}
body.active_overflow				{ height: 100vh; overflow: hidden;}
a									{ text-decoration: none; color: var(--second-color); position: relative;}
img									{ border: none;}
main 								{ position: relative;}
main p>a                            { text-underline-offset: .05em;}
#wrapper 							{ min-width: 320px; width: 100%; }
#wrapper *							{ box-sizing: border-box;}
#footer 							{ position: relative; z-index: 15;}

@media (max-width:700px) {
body								{ font-size: 15px; line-height: 28px;}
}


/***** scollbar *****/
::-webkit-scrollbar 				{ width: 6px; height: 6px; background-color: #fff;}
::-webkit-scrollbar-thumb			{ background-color: var(--second-color);}


/***** transition *****/
@media (min-width:1201px) {
    .link, .slick-arrow, :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;}
.wrapper_large						{ max-width: 1600px;}
.clear								{ clear: both; display: block;}

.titre_main	 						{ font: 700 40px/50px var(--title-font-family); position: relative; color: var(--second-color); margin-bottom: 10px; letter-spacing: 0.2px;}
.chapo                              { font: 500 20px/30px var(--font-family);}
.chapo_p                            { font: 400 15px / 30px var(--font-family);}
.sous_titre 						{ font: 700 20px/30px var(--font-family); position: relative; color: var(--second-color); margin-bottom: 15px; letter-spacing: 0.4px;}
.titre                              { font: 700 14px/24px var(--font-family);  color: var(--main-color); text-transform: uppercase; letter-spacing: 1.6px;}
.link 								{ font: 700 14px/60px var(--font-family); letter-spacing: 0.4px; min-height: 60px; display: inline-block; vertical-align: top; color: var(--main-color); padding: 0 30px; background: linear-gradient(to top, var(--second-color) 0% 50%, var(--main-color) 50% 100%); background-size: 100% 200%; background-position: 0 100%; text-align: center; text-transform: uppercase;}
.link_reverse                       { color: var(--second-color); background: linear-gradient(to top, var(--main-color) 0% 50%, var(--second-color) 50% 100%); background-size: 100% 200%; background-position: 0 100%;}
.texte p:not(:last-of-type)         { margin-bottom: 10px;}
.link_arrow                         { display: inline-flex; align-items: center; color: var(--main-color); font: 700 14px/22px var(--font-family); text-transform: uppercase; letter-spacing: 1.6px; padding-inline: 20px 50px; min-height: 60px; background: url(../images/link_arrow_yellow.svg) no-repeat top 50% right 20px var(--second-color);}
.ul_list						    { margin-bottom: 15px; padding: 5px 0 0 0;}
.ul_list li					        { padding: 5px 0 6px 40px; position: relative; background: url(../images/checklist.svg) center left / 22px no-repeat;}
.titre_bg                           { font: 700 14px/1.5 var(--font-family); text-transform: uppercase; color: var(--second-color); background-color: var(--main-color); padding: .7em 1.85em; width: fit-content; margin-bottom: 1.45em;}

@media (min-width:1201px) {
.link:hover 						{ background-position: 0 0; color: var(--second-color);}
.link_reverse:hover                 { color: var(--main-color);}
.link_arrow:hover                   { color: var(--second-color); background-image: url(../images/link_arrow_blue.svg); background-color: var(--main-color);}
}
@media (max-width:1200px) {
.wrapper 							{ min-width: inherit;}
}

@media (max-width:1000px) {
.wrapper 							{ max-width: 750px;}
#wrapper::after                     { display: none;}
.titre_main                         { font-size: 30px; line-height: 40px;}
}
@media (max-width:700px) {
.chapo                              { display: none;}
.wrapper 							{ width: 85vw;}
.link 								{ padding: 0 20px; font-size: 14px;}
.titre_main	 						{ font-size: 22px; line-height: 30px;}
.sous_titre 						{ font-size: 18px; line-height: 30px; margin-bottom: 10px;}
.titre                              { font-size: 14px; line-height: 26px;}
.link_arrow                         { line-height: 60px; height: 60px; font-size: 14px; display: block; background: var(--second-color); color: var(--main-color); text-align: center; padding-right: 0;}
}


.read_more, .read_less			    { display: inline-block; cursor: pointer; transition: color 300ms ease-in-out; transition: border .300s ease-in-out; text-decoration: underline; text-underline-offset: .3em;}
.hide_more 							{ display: none; }


@media (max-width:700px) {
.hidden-sm-down                     { display: none !important;}
}

@media (min-width: 701px) {
.hidden-md-up                       { display: none !important;}
}
@media (max-width:1000px) {
.hidden-md-down                     { display: none !important;}
}

@media (min-width: 1001px) {
.hidden-lg-up                       { display: none !important;}
}
@media (max-width:1200px) {
.hidden-lg-down                     { display: none !important;}
}

@media (min-width: 1201px) {
.hidden-xl-up                       { display: none !important;}
}


/***** header et menu *****/
.header 							{ width: 100%; font-size: 0; line-height: 0; text-align: right; position: fixed; left: 0; top: 0; transition: all 400ms ease-in-out; background: transparent; z-index: 100; }
.header .header_noscroll            { background-color: #fff;}
.header_right                       { display: inline-block; vertical-align: middle;}
.header .link                       { vertical-align: middle; margin-left: 40px;}
.header .logo                       { position: absolute; left: 0;  line-height: 0; z-index: 90; transform-origin: left; display: inline-block; top: 50%; transform: translateY(-50%); transform-origin: top left; line-height: 0; left: 0; transition: all 400ms ease-in-out;}
.header .logo img                   { display: inline-block; vertical-align: middle; height: auto;}
.header_nav							{ display:inline-block; vertical-align: middle; position:relative; z-index:40; transition: all ease-in-out 400ms;}
.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: 700 15px/60px var(--font-family); text-transform: uppercase; color: var(--second-color); letter-spacing: 0.4px; height:60px; display: inline-block; transition-property: all;}
.header_nav .menu>li.active>a		{ color:var(--main-color);}
.header_nav .sub					{ width: 310px; margin-left: -155px; text-align: left; position: absolute; top: 100%; left: 50%; display: block; background: var(--second-color); opacity: 0; visibility: hidden; text-align: center;}
.header_right .tel                  { position: relative; z-index: 100;}
.header_nav .sub li					{ width: 100%; margin: 0;}
.header_nav .sub li a				{ width: 100%; font: 400 16px/1.5 var(--font-family); min-height: 50px; height: auto; color: #fff; display: block; padding: 18px 40px; background: none; text-transform: initial;}
.header_nav .menu .sub li.active a  { color: var(--main-color); }
.sticky .header                     { box-shadow: 0 0 30px 0 rgba(32, 37, 43, 0.18);}

@media (min-width:1201px) {
.header_nav .menu .vue_mobile,
.menu_mobile 						{ display: none;}
.header                             { top: 50px;}

.header_nav .menu>li:hover>a,
.header_nav li a:hover			    { color: #000000;}
.header_nav .sub.large:after 		{ display: none}
.header_nav .menu>li:hover>a		{ color: var(--main-color);}
.header_nav .sub li a:hover			{ color: var(--main-color);}
.header_nav .menu li:hover .sub		{ opacity: 1; visibility: visible; z-index: 999;}
.sticky .header_nav .menu           { padding-top: 0;}
.header .link-mobile                { display: none;}
.sticky .header .logo               { transform: scale(0.625) translateY(-50%);}
.sticky .header_nav .menu>li>a      { line-height: 100px; height: 100px;}
.header_nav .sub:after 				{ width: 10px; height: 10px; position: absolute; left: 50%; top: -5px; margin: 0 0 0 -5px; transform: rotate(45deg); background: var(--second-color); content: ""; z-index: -1;}
.sticky .header                     { background: #fff; top: 0;}

}

@media (max-width:1200px) {
.sticky .header                     { top: 0;}
.header                             { z-index: 201; padding: 0; background-color: #fff;}
.header .link                       { margin-right: 30px;}
.header .logo                       { top: 0; transform: none;}
.menu_mobile						{ width:60px; height:60px; display:inline-block; vertical-align:middle; cursor:pointer; position:relative; z-index:60; margin: 20px 0 20px -10px; transition:height 400ms ease-in-out;}
.menu_mobile div					{ width:40px; height:2px; background:var(--second-color); position:absolute; right:50%; top:50%; margin:-1px -20px 0 0;}
.menu_mobile div:before				{ width:100%; height:2px; background:var(--second-color); position:absolute; right:0; top:9px; content:"";}
.menu_mobile div:after				{ width:100%; height:2px; background:var(--second-color); position:absolute; right:0; top:-9px; 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_nav 	  					{ width:100%; height:100vh; background:#fff; 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::after        { display: none; }
.header_nav .menu_top li 			{ display: block; margin: 0; padding: 0;}	
.header_nav .menu_top li:after		{ display:none;}
.menu_top                           { font-size: 0; display: inline-block; vertical-align: middle;}
.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; font-size: 18px; letter-spacing:0.4px; height:auto; background-position:100% 50%;}
.header_nav .menu li i.active:after	{ opacity:1;}
.header_nav .menu li i				{ width: 40px; background-color: var(--second-color); height: 31px; display: block; margin-top: 5px; position: relative; z-index: 5;float: right;}
.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/scrolltop.svg) no-repeat center; transform: rotate(180deg);}
.header_nav .menu li a	            { background: none;}
.header_nav .menu li i.active::after{ transform: rotate(180deg);}
/* sous-menu simple */
.header_nav .menu .sub 				{ width: 100%; position: relative; left: auto; top: auto; padding:10px 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%; font-size: 16px; font-weight: 500; padding-block: 13px; text-align: left; color: #fff;}

.header_nav.active					{ top:0; transition-delay: 0;}
.header_nav.active .menu			{ opacity:1; transition-delay:800ms;}
.sticky .header .logo               { transform: scale(.625);}

}

@media (max-width:1000px) {		
.header_nav .sub 					{ padding: 25px 40px;}
.header_nav .sub li a				{ border: none; line-height: 45px; height: 45px;}
.header                             { background-color: #fff;}
}

@media (max-width:700px) {
.header                             { padding: 0;}
.header_nav                         { padding: 150px 7.5vw 0; align-content: baseline;}
.header_nav .menu                   { width: 100%;}
.header_nav .menu li a 	        	{ font-size: 14px;}
.header_nav .menu_top li a 	        { font-size: 14px;}
.header_nav .menu .sub li a 		{ font-size: 14px; line-height: 32px; height: 34px;}
.header .logo img                   { width: 100px;}
.menu_mobile                        { margin: 0 0 0 -10px;}
.header_right .tel                  { background: url(../images/tel_blue.svg) no-repeat center; width: 60px; height: 60px; font-size: 0; line-height: 0; padding: 0; margin: 0 5px 0 0;}
.sticky .header .logo               { transform: scale(.6);}

}
@media (max-width:400px) {
    .header_nav .menu .sub li   { padding: 10px 0;}
    .header_nav .menu .sub li a { height: inherit; line-height: inherit;padding: 10px 20px; min-height: inherit;}
}


/*
.link-moins,.link-plus              { cursor:pointer; color: var(--main-color); }
.textMore                           { display: none; margin-top: 40px;}
.textMore p:not(:first-of-type)     { margin-top: 15px;}

@media (min-width:1201px) {
.link-moins:hover,.link-plus:hover  { color: #186647;}
}
@media (max-width:700px) {
.textMore                           { margin-top: 20px;}
}
*/

/***** table plus *****/
.table_plus 						{ position: relative; margin: 110px 0;} 
.table_plus .titre_bg				{ margin-bottom: 2.15em;} 
.table_plus .sous_titre             { margin-bottom: 25px;}
.table_plus .item:not(:last-of-type){ border-bottom: none;}
.table_plus .hide 					{ padding: 15px 50px 25px 40px; display: none;}
.table_plus .hide ul 				{ padding-left: 20px;}
.titre_plus 						{ position: relative; letter-spacing: 0.4px; cursor: pointer; padding: 20px 80px 20px 30px; background-color: #FFF; color: #000000; font-size: 18px; line-height: 35px; font-weight: 500; margin-bottom: 10px; transition: all 400ms ease-in-out;}
.titre_plus::after                  { content: ''; position: absolute; right: 30px; top: 50%; transform: translateY(-50%); width: 25px; height: 25px; background:url(../images/plus.svg) no-repeat center / contain;}
.titre_plus.active::after        	{ transform: translateY(-50%) rotate(135deg);}

@media (max-width:1000px) {
.table_plus .hide 					{ padding: 40px 0;}
.table_plus                         { margin: 60px 0;}
}
@media (max-width:700px) {
.table_plus 						{ margin: 50px 0;} 
.table_plus .sized					{ margin-bottom: 20px;} 
.table_plus .hide 					{ padding: 15px 20px 25px; line-height: 25px;}
.titre_plus 						{ font-size: 15px; line-height: 25px; padding: 8px 75px 8px 20px; background-position: right 20px center;}
}


/***** textecta *****/
.textecta                           { background: var(--second-color); color: #FFF; position: relative; text-align: center; font: 700 25px/30px var(--font-family); letter-spacing: .037em; margin: 105px 0; padding: 45px 50px; transition: all ease-in-out 400ms;}
.textecta::after                    { content: ""; background: url(../images/link.svg) no-repeat center / contain; width: 26px; height: 38px; position: absolute; top: 50%; left: 40px; transform: translateY(-50%);}
.textecta a                         { color: var(--main-color); border-bottom: 2px solid transparent;}
.textecta strong                    { font-weight: 700; text-transform: uppercase;}
.textecta b                         { font-weight: 700;}

@media (min-width:1201px) {
.textecta a:hover                   { border-color: currentColor;}
}

@media (max-width:1000px) {
.textecta                           { font-size: 18px; padding-left: 120px; margin: 50px 0;}
}

@media (max-width:700px) {
.textecta                           { color: var(--second-color); font-size: 0; background: none; padding: 0; line-height: 0; margin: 40px 0;}
.textecta::after                    { display: none;}
.textecta strong                    { font: 700 22px/30px var(--title-font-family); text-transform: uppercase; display: block;}
.textecta a                         { display: inline-block; background-color: var(--second-color); color: var(--main-color); height: 60px; font: 700 14px/60px var(--font-family); grid-area: 1;}
.textecta b                         { display: grid; margin-top: 15px; text-transform: uppercase; grid-template-columns: 1fr 1fr; gap: 0 10px;}
}



/***** footer*****/
.footer								{ width: 100%; position: relative; padding-top: 95px; color: #fff; font-size: 0; background-color: var(--second-color);}
.footer .bloc_footer.coordonnees    { margin-right: 105px; margin-top: 0;}
.footer .bloc_footer 				{ display: inline-block; vertical-align: top; line-height: 30px; margin-right: 40px; font-size: 16px; margin-top: 125px;}
.footer .sous_titre                 { font: 500 30px/40px var(--font-family); color: #fff; text-transform: uppercase; margin-bottom: 15px;}
.footer_contact                     { font-size: 1em; margin-bottom: 30px;}
.footer .link_footer                { position: relative; padding-left: 30px; font: 400 16px/50px var(--font-family); display: block; margin-bottom: 10px;}
.footer .link_footer::before        { position: absolute; content: ""; background: url(../images/marker.svg) no-repeat center; width: 20px; height: 25px; top: 50%; left: 0; transform: translateY(-50%);}
.footer .bloc_footer p				{ font-size: 16px;}
.footer .bloc_footer p a			{ color: #fff; text-transform: none; display: inline-block; border: none;}
.footer .bloc_footer li a           { color: #fff; padding-left: 25px; background: url(../images/list_footer.svg) left center no-repeat;}
.footer .bloc_footer li             { margin-bottom: 10px;}
.footer .bloc_footer .adresse:before{ background-image: url(../images/marker.svg)}
.footer .bloc_footer .phone:before  { background-image: url(../images/tel.svg)}
.footer .bloc_footer .mail:before   { background-image: url(../images/mail.svg)}
.footer .snoeck                     { margin-top: 30px;}
.footer	.rs							{ position: absolute; right: 0; top: 5px;}
.footer	.rs a						{ display: inline-block; vertical-align: top; margin-right: 10px; width: 50px; height: 50px;}
.footer	.rs .facebook			    { background: url(../images/facebook.svg) 50% / 12px no-repeat var(--main-color);}
.footer	.rs .scroll					{ background: url(../images/scrolltop.svg) center no-repeat ; margin: 0;}
.footer_bottom   					{ padding: 20px 0; line-height: 0; margin-top: 90px;}
.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.8px; position: relative;}
.footer_bottom li a 				{ color: currentColor;}
.footer_bottom li:after				{ width: 1px; height: 8px; content: ""; position: absolute; right: -13px; top: 7px; 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, #fff 0%, #fff 50%, #fecb00 50%, #fecb00 100%); background-size: 200% 100%; background-position: 100% 0;}
.toponweb img						{ width: 74px; height: auto; display: block; margin: 0 auto; transition: all ease-in-out 400ms;}
.toponweb.show						{ bottom: 0;}

@media (min-width:1201px) {
.footer	.rs .facebook:hover         { background-color:#fff;}
.toponweb:hover span				{ background-position: 0 0;}
.toponweb:hover span img	        { filter: brightness(0) invert(1);}
}
@media (max-width:1200px) {
.toponweb                           { position: absolute;}
.footer .bloc_footer                { margin-right: 40px;}
}
@media (max-width:1000px) {
.footer                             { padding-top: 50px;}
.footer .bloc_footer 				{ margin: 0 0 40px; display: none;}
.footer .bloc_footer.coordonnees    { display: block;}
.footer .bloc_footer p              { margin: 0;}
.footer .bloc_footer .adresse                    { margin-bottom: 10px;}
.footer_bottom   					{ margin-top: 80px;}
}
@media (max-width:600px) {
.footer								{ padding-top: 40px; text-align: center;}
.footer .sous_titre                 { font-size: 20px; line-height: 35px; margin-bottom: 10px;}
.footer .bloc_footer.coordonnees    { margin-right: 0; margin-bottom: 40px;}
.footer .bloc_footer .adresse       {  padding: 0; line-height: 30px; margin-bottom: 20px;}
.footer .bloc_footer .adresse::before{ display: none;}
.footer .bloc_footer .phone         { width: 100%; display: block; background-color: var(--main-color); color: var(--second-color); font: 700 14px/60px var(--font-family); padding:0 30px; text-transform: uppercase;}
.footer .bloc_footer .phone:before,         
.footer .bloc_footer .mail:before   { display: none;}
.rs a                               { width: 50px; height: 50px;}
.footer	.rs							{ position: static; margin-top: 0;}
.footer .bloc_footer p              { font-size: 15px;}
.footer_bottom 	 					{ text-align: left; margin-top: 40px; padding: 0 0 30px; text-align: center;}
.footer .rs .scroll                 { position: absolute; top:-10px; right: -15px;}
.footer_bottom li 					{ display: block; margin-right: 0; line-height: 25px;}
.footer_bottom li:after				{ display: none;}
}
