/***** fonts et reset *****/
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');

:root {
    --main-color: #00245e;
    --second-color: #10b9ff;
    --third-color: #f1f9ff;
    --fourth-color: #e7f5ff;
    --gradient-color1: #0069e0;
    --gradient-color2: #10b9ff;
    --gradient: linear-gradient(-64deg, var(--gradient-color1), var(--gradient-color2));
    --box-shadow-1: 0 0 80px 0 rgba(16, 185, 255, 0.2);
    --box-shadow-2: 0 0 40px 0 rgba(16, 185, 255, 0.2);
    --white: #fff;
    --black: #000;
    
    --font-main: "Inter", sans-serif;   

    --body_font: 400 16px / 30px var(--font-main);
    --body_font-mobile: 400 14px / 28px var(--font-main);

    --titre-main: 500 50px/50px var(--font-main); 
    --titre-main-mobile: 500 25px/35px var(--font-main);

    --sous-titre: 500 25px/35px var(--font-main);
    --sous-titre-mobile: 500 16px/26px var(--font-main);

    --titre: 700 italic 16px/22px 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;}
strong, b							{ font-weight: 700;}
ul									{ list-style-type: none;}
body								{ font: var(--body_font); letter-spacing: 0.4px; color: var(--main-color); background: linear-gradient(to bottom, var(--white) 0, var(--third-color) 200px calc(100% - 200px)); position: relative;}
body.active_overflow				{ height: 100vh; overflow: hidden;}
a									{ text-decoration: none; color: var(--second-color); 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:700px) {
body								{ font: var(--body_font-mobile);}
}


/***** scollbar *****/
::-webkit-scrollbar 				{ width: 6px; height: 6px; background-color: var(--white);}
::-webkit-scrollbar-thumb			{ background-color: var(--second-color);}


/***** transition *****/
@media (min-width:1201px) {
.link, .slick-arrow, :before, :after, a, a span, .logo, .header, .sub, .link-plus, .link-moins { 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;}
.anchor								{ position: absolute; left: 0; top: -140px;}

.titre_main	 						{ font: var(--titre-main); position: relative; color: var(--second-color); margin-bottom: 20px; letter-spacing: 0;}
.titre_main span                    { display: block; font: var(--sous-titre); color: var(--main-color); margin-top: 5px;}
.sous_titre 						{ font: var(--sous-titre); position: relative; color: var(--second-color); margin-bottom: 15px; letter-spacing: 0;}
.titre                              { color: var(--main-color); font: var(--titre);}
.chapo		 						{ font: 400 16px/30px var(--font-main); margin-bottom: 15px; letter-spacing: 0.4px;}
.link 								{ font: 700 italic 15px/60px var(--font-main); letter-spacing: 0.4px; height: 60px; display: inline-block; vertical-align: top; color: var(--white); padding: 0 30px; background: var(--gradient); border-radius: 30px; background-size: 100% 200%; background-position: 0 100%; text-align: center; overflow: hidden;}
.link span                          { position: relative; z-index: 1;}
.link::after                        { content: ""; display: block; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: var(--main-color); opacity: 0;}


@media (min-width:1201px) {
.link:hover 						{ background-position: 0 0; color: var(--white);}
.link:hover::after                  { opacity: 1;}
}
@media (max-width:1200px) {
.wrapper 							{ min-width: inherit;}
}
@media (max-width:1000px) {
.wrapper 							{ max-width: 750px;}
}
@media (max-width:700px) {
.wrapper 							{ width: 85vw;}
.sous_titre 						{ font-size: 15px; line-height: 27px; margin-bottom: 10px;}
.titre_main	 						{ font: var(--titre-main-mobile); margin-bottom: 10px;}
.titre_main span                    { font: var(--sous-titre-mobile);}
.chapo                              { font-size: 14px; line-height: 27px;}
.link 								{ font-size: 14px; padding: 0 25px; height: 50px; line-height: 50px; text-align: center; width: 100%;}
}



/***** header et menu *****/
.header 							{ width: 100%; font-size: 0; line-height: 0; text-align: right; position: fixed; left: 0; top: 0; z-index: 180; transition: all 400ms ease-in-out; padding-top: 20px;}
.header .logo                       { font-size: 0; letter-spacing: 0; position: absolute; left: 0; bottom: 25px; transform-origin: left;}
.header .logo img                   {display: block;}

.header_top                         { text-align: right;}
.header_top a 				        { color: var(--main-color); font: 700 italic 14px/50px var(--font-main); letter-spacing: 0.4px; padding-left: 65px; position: relative; z-index: 1; display: inline-block; vertical-align: middle; margin-left: 40px;}
.header_top a i                     { display: block; position: absolute; left: 0; width: 50px; height: 50px; border-radius: 50%; display: grid; align-items: center; justify-content: center; background: var(--gradient);}

.header_right 						{ position: relative; z-index: 120;}
.header_right>span                  { font: 400 12px/30px var(--font-main); letter-spacing: 0.4px; display: inline-block; vertical-align: middle;}
.header_nav							{ display: inline-block; vertical-align: middle; padding-right: 0; z-index: 50;}
.header_nav .menu					{ position: relative;}
.header_nav .menu li				{ display: inline-block; vertical-align: top; position: relative; margin-left: 40px;}	
.header_nav .menu li a				{ font: 700 italic 16px/70px var(--font-main); letter-spacing: 0.4px; height: 70px; display: block; transition-property: color, height, line-height; color: var(--main-color);}
.header_nav .menu>li.active>a 		{ color: var(--second-color);}
.header_nav .sub					{ width: 300px; text-align: center; position: absolute; top:100%; left: 50%; margin-left: -150px; display: block; visibility: hidden; opacity: 0; background: var(--second-color); padding: 5px 0;}
.header_nav .sub li					{ width: 100%; margin: 0; position: relative; z-index: 1;}
.header_nav .sub li a				{ width: 100%; font: 400 14px/50px var(--font-main); height: 50px; color: var(--white); padding: 0;}
.header_nav .menu li:hover .sub		{ opacity: 1; visibility: visible; z-index: 999; top: 100%;}
.header_nav .menu .sub li.active a	{ color: var(--main-color);}
.sticky .header                     { top: -70px; box-shadow: var(--box-shadow-2); background: var(--white);}

@media (min-width:1201px) {
.sticky .header .logo               { bottom: 5px; transform:scale(.8);}
.header_nav .menu .vue_mobile,
.menu_mobile 						{ display: none;}
.header_nav .menu>li:hover>a        { color: var(--second-color);}
.header_nav .sub 					{ display: block !important; border-radius: 20px;}
.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: "";}
.header_nav .menu>li:hover>a 		{ color: var(--second-color);}
.header_nav .sub li a:hover			{ color: var(--main-color);}
.header_top a:hover                 { color: var(--second-color);}
.header_top .lang:hover             { color: var(--white); background: var(--second-color);}

.sticky .header_nav .menu>li>a		{ line-height: 80px; height: 80px; padding-bottom: 0;}
}
@media (max-width:1366px) {
.header_nav .menu li                { margin-left: 25px;}
}
@media (max-width:1200px) {
.menu_mobile						{ width: 50px; height: 50px; display: inline-block; vertical-align: middle; cursor: pointer; position: relative; margin: 20px -5px 20px 5px; transition: margin 400ms ease-in-out; border-radius: 50%;}
.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: 8px; content: "";}
.menu_mobile div:after				{ width: 100%; height: 2px; background: var(--main-color); position: absolute; right: 0; top: -8px; content: "";}
.menu_mobile.active div				{ height: 0;}
.menu_mobile.active div:before		{ top: 0; transform: rotate(-135deg);}
.menu_mobile.active div:after		{ top: 0; transform: rotate(-45deg);}
.header 							{ transition: box-shadow 400ms ease-in-out, height 400ms ease-in-out 400ms, top 400ms ease-in-out 0, background 400ms ease-in-out 0; padding: 0;}

.header .wrapper                    { max-width: initial;}

.header .logo                       { z-index: 123; bottom: auto; top: 50%; transform: translateY(-50%);}
.header .logo img                   { width: 165px;}
.header_top                         { z-index: 122; position: relative; padding: 0; display: grid; grid-template-columns: auto auto; justify-content: end; align-items: center; margin: 0 -5vw; padding: 0 5vw;}
.header_top a                       { margin: 0 30px 0 0;}
.header_nav 	  					{ width: 100%; height: 100vh; background: var(--fourth-color); padding: 0; position: fixed; right: 100%; top :0; overflow-y: scroll; display: grid; z-index: 100; padding-top: 80px; transition: all 0ms ease-in-out 400ms;}
.header_top .rdv                    { margin-left: 0;}
.header_top .lang                   { margin-right: 0;}

.header_nav 	  					{ width: 100%; height: 100vh; position: fixed; right: -100%; top :0; overflow-y: scroll; display: grid; align-content: flex-start; z-index: 121; transition: all 400ms ease-in-out 600ms;}
.header_nav::-webkit-scrollbar		{ display: none;}
.header_nav .menu  					{ width: auto; text-align: left; margin: 5vw 10vw; position: relative; z-index: 100;  align-self: center; opacity: 0; transition: all 200ms ease-in-out 0ms;}
.header_nav .menu li 				{ width: 100%; display: block; margin: 0;}
.header_nav .menu li a				{ width: 100%; font-size: 14px; line-height: 40px; height: 40px;}
.header_nav .menu li i				{ width: 45px; height: 41px; display: block; margin-top: -48px; position: relative; z-index: 5; background: url("../images/scroll_down.svg") 50% no-repeat var(--white); float: right; border-radius: 8px;}
.header_nav .menu li i.active		{ transform: rotate(180deg);}
.header_nav .menu li i.active		{ transform: rotate(180deg);}
.header_nav .menu .sub 				{ width: auto; visibility: visible; position: relative; left: auto; top: auto; margin: 15px 0; opacity: 1; display: none; text-align: left; padding: 20px 5vw;  border-radius: 5px;}
.header_nav .menu .sub li a 		{ line-height: 43px; height: 45px;}

.header_nav.active					{ right: 0; transition-delay: 200ms;}
.header_nav.active .menu			{ opacity: 1; transform: translateY(0); transition-delay: 600ms;}

.sticky .header                     { top: 0;}

}
@media (max-width:1000px) {

.header_top .rdv                    { padding: 0; font-size: 0; letter-spacing: 0; width: 50px; margin-right: 0;}
.header .logo span                  { font-size: 13px; line-height: 26px; left: 20px; bottom: 0;}
.header_top a:not(.lang)            { width: 45px; height: 45px; font-size: 0; padding: 0; border-radius: 50%; background-color: var(--white); background-position: center; margin-right: 10px;}
.header_top .phone                  { background-image: url(../images/phone_blue.svg);}
}
@media (max-width:700px) {
.header_top                         { margin: 0 -7.5vw; padding: 0 7.5vw;}
.header_top .tel                    { display: none;}
.header_nav .menu  					{ padding: 7.5vw 0;}
}



/***** bandeau *****/
.bandeau                                { text-align: center; background: var(--main-color); color: var(--white); padding: 58px 30px; border-radius: 20px; margin: 100px 0; position: relative; z-index: 1;}
.bandeau a                              { color: var(--second-color); border-bottom: 2px solid transparent;}
.bandeau em                             { font-style: normal;}

@media (min-width:1201px) {
.bandeau a:hover                        { border-color: var(--second-color);}
}
@media (max-width:1000px) {
.bandeau                                { margin: 70px 0;}
}
@media (max-width:1000px) {
.bandeau                                { margin: 0 0 40px; border-radius: 20px; padding: 30px 20px 40px; font-size: 18px;}
.bandeau span                           { display: block; margin-bottom: 20px;}
.bandeau a                              { display: block; font: 700 italic 14px/50px var(--font-main); text-align: center; background: var(--white); border-radius: 30px; color: var(--second-color); border-bottom: 0; max-width: 300px; margin: 10px auto 0; text-transform: capitalize;}
.bandeau em                             { display: none;}
}


/***** faq *****/
.table_plus 						{ position: relative; margin: 90px 0 100px;}
.table_plus .item                   { text-align: left; margin-bottom: 10px;}
.table_plus .titre_main             { margin-bottom: 30px;}
.table_plus .item:not(:last-of-type){ border-bottom: none;}
.table_plus .hide 					{ padding: 40px 30px 30px; display: none;}
.table_plus .hide :last-child       { margin-bottom: 0;}
.table_plus .hide p                 { margin-bottom: 10px;}
.table_plus .hide ul 				{ padding-left: 20px;}
.titre_plus 						{ position: relative; letter-spacing: 0.8px; cursor: pointer; padding: 20px 80px 20px 30px; background: var(--white); color: var(--main-color); font-size: 16px; font-weight: 500; transition: all 400ms ease-in-out; border-radius: 35px;}
.titre_plus:before					{ width: 20px; height: 20px; background: url("../images/plus.svg") 50% no-repeat; border-radius: 50%; position: absolute; right: 30px; top: 50%; margin-top: -10px; transition: all 400ms ease-in-out; content: "";}
.titre_plus.active:before 			{ transform: rotate(135deg);}

@media (max-width:1000px) {
.table_plus .hide 					{ padding: 40px 0;}
}
@media (max-width:700px) {
.table_plus 						{ margin: 40px 0 50px;} 
.table_plus .titre_main             { margin-bottom: 20px;}
.table_plus .sized					{ margin-bottom: 20px;} 
.table_plus .hide 					{ padding: 20px 0;}
.titre_plus 						{ font-size: 14px; line-height: 26px; padding: 16px 60px 16px 20px; border-radius: 5px;}
.titre_plus:before					{ right: 20px; margin-top: -10px;}
.titre_plus.active:before 			{ background-color: transparent;}
}




/***** footer*****/
.footer								{ width: 100%; position: relative; padding-top: 90px; color: var(--white); font-size: 0; background: var(--main-color);}
.footer .logo_footer                { font: 400 30px/40px var(--font-main); color: var(--second-color); margin-bottom: 30px;}
.footer .bloc_footer.coordonnees    { margin-top: 0; margin-right: 180px;}
.footer .bloc_footer 				{ line-height: 30px; font-size: 16px; margin-top: 75px; display: inline-block; vertical-align: top;}
.footer .bloc_footer p				{ font-size: 15px; line-height: 40px;}
.footer .bloc_footer p a			{ color: var(--white); text-transform: none; display: inline-block; vertical-align: top; border: none; line-height: 40px;}
.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_blue.svg) left center no-repeat; padding-left: 30px;}
.footer .bloc_footer .tel           { background: url(../images/tel_blue.svg) left center no-repeat; padding-left: 30px;}
.footer .bloc_footer .mail          { background: url(../images/mail.svg) left center no-repeat; padding-left: 30px;}
.footer .bloc_footer .localisation  { background: url(../images/marker.svg) left center no-repeat; padding-left: 30px;}
.footer	.rs							{ position: absolute; right: -15px; top: 5px;}
.footer	.rs a						{ display: inline-block; vertical-align: top; width: 50px; height: 50px; border-radius: 50%; background: var(--gradient);}
.footer	.rs .facebook               { margin-right: 10px;}
.footer	.rs a::after                { content: ""; display: block; position: absolute; inset: -1px; background-position: center; background-repeat: no-repeat; border-radius: 50%;}
.footer	.rs a img                   { position: relative; z-index: 2;}
.footer	.rs .facebook::after        { background-image: url(../images/facebook.svg);}
.footer	.rs .scroll::after			{ background-image: url(../images/scrolltop.svg); background-color: var(--main-color);}
.footer_bottom   					{ padding: 20px 0; line-height: 0; margin-top:70px;}
.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::after    { background-color:transparent;}
.footer	.rs .facebook:hover::after  { background-color: 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: 25px; line-height: 30px; margin-bottom: 15px;}
.footer .bloc_footer p              { font-size: 13px;}
.footer .bloc_footer .localisation  { margin-bottom: 20px;}
.footer .bloc_footer.coordonnees    { margin: 0 auto 40px;}

.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(--second-color); font: 700 italic 14px/50px var(--font-main); letter-spacing: 0.4px; width: 100%; text-align: center; margin: 10px auto 0; max-width: 320px; display: block; border-radius: 30px;}

.footer	.rs							{ position: static; text-align: center;}
.footer .rs .facebook               { position: relative; margin: 0;}
.footer .rs .scroll                 {  position: absolute;top: -15px; right: -20px; margin: auto;}
.footer_bottom 	 					{ margin-top: 30px; padding: 0 0 70px; text-align: center;}
.footer_bottom li 					{ display: block; margin-right: 0; line-height: 25px; font-size: 11px;}
.footer_bottom li:after				{ display: none;}
}