/***** fonts et reset *****/
@import url('https://fonts.googleapis.com/css2?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');

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 14px/30px "poppins";  letter-spacing: 0.4px; color: #000000; background: #fff; position: relative; overflow-x: hidden; height: 100vh; overflow-y: auto;}
body.active_overflow				{ height: 100vh; overflow: hidden;}
a									{ text-decoration: none; color: #d7534a; position: relative;}
img									{ border: none;}
main 								{ position: relative;}
main p>a                            { color: #d7534a; border-bottom: 1px solid transparent;}
#wrapper 							{ min-width: 320px; width: 100%; overflow: hidden;}
#wrapper *							{ box-sizing: border-box;}
#footer 							{ position: relative;}

@media (max-width:600px) {
body								{ font-size: 13px; line-height: 24px;}
}


/***** scollbar *****/
::-webkit-scrollbar 				{ width: 6px; height: 6px; background-color: #fff;}
::-webkit-scrollbar-thumb			{ background-color: #113c4b;}


/***** transition *****/
@media (min-width:1201px) {
.link, .slick-arrow, :before, :after, a, a span, .logo, .header, .sub { transition: all 400ms ease-in-out;}
main p>a:hover                     { border-color: #d7534a;}

}


/***** class *****/
.wrapper 							{ width: 90vw; max-width: 1200px; margin: 0 auto; position: relative;}
.wrapper_large						{ max-width: 1600px;}
.clear								{ clear: both; display: block;}

.small_title { font: 500 14px/24px "poppins"; position: relative; color: #d7534a; margin-bottom: 15px; letter-spacing: 0.4px; }
.titre_main	 						{ font: 500 35px/45px "poppins"; position: relative; color: #000; margin-bottom: 15px; letter-spacing: 0.4px;}
.titre_main span                    { display: block; color: #d7534a;}
.sous_titre 						{ font: 500 20px/30px "poppins"; position: relative; color: #d7534a; margin-bottom: 15px; letter-spacing: 0.4px;}
.chapo		 						{ font: 400 14px/30px "poppins"; margin-bottom: 0;}
.titre                              { font: 500 18px/30px "poppins"; margin-bottom: 10px;}
.link 								{ font: 500 14px/60px "poppins"; letter-spacing: 0.4px; height: 60px; display: inline-block; vertical-align: top; color: #fff; padding: 0 30px; background: linear-gradient(to top, #d7534a 0% 50%, #113c4b 50% 100%); background-size: 100% 200%; background-position: 0 100%; text-align: center;}
.texte p:not(:last-of-type)         { margin-bottom: 10px;}
/*#wrapper:after                          { content: url(../images/shape.svg); position: absolute; right: 0; top: 0; z-index: -1;}*/
@media (min-width:1201px) {
.link:hover 						{ background-position: 0 0; color: #fff;}
}
@media (max-width:1200px) {
.wrapper 							{ min-width: inherit;}
.titre_main                         { font-size: 30px; line-height: 40px;}
}

@media (max-width:1000px) {
.wrapper 							{ max-width: 750px;}
.titre_main	 						{ font-size: 25px; line-height: 32px; margin-bottom: 15px;}
.sous_titre 						{ font-size: 18px; line-height: 30px; margin-bottom: 10px;}
#wrapper::after                    { display: none;}
}
@media (max-width:600px) {
.wrapper 							{ width: 85vw;}
.link 								{ font-size: 14px;display: block;}
}


/***** 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: 200;}

.header .link                       { letter-spacing: 0.5px; font-size: 14px; margin-left: 30px; padding-left: 20px; padding-right: 25px;}
.header .mail span                  { padding-left: 35px; background: url(../images/mail.svg) no-repeat center left;}
.content_logo                       { position: absolute; left: 0; top: 30px; transition: all ease-in-out 400ms; }
.header .logo                       { position: relative;  line-height: 0; z-index: 90; transform-origin: left; width: 250px; display: inline-block;  vertical-align: middle;transition: all 300ms ease-in-out; }
.header .info-plus                  { display: inline-block; font-size: 14px; line-height: 20px; font-weight: 400; letter-spacing: 0.4px; vertical-align: middle; width: 260px; color: #000000; margin-left: 20px; text-align: left; transition: all ease-in-out 400ms;}
.link_top                           { position: absolute; top: 0; right: 0; z-index: 200;}
.header .logo img                   { display: block; width: 100%; }
.header_nav							{ width:100%; display:block; position:relative; z-index:40; padding:10px 0 30px 0; transition: all ease-in-out 400ms;}
.menu_top				            { position: relative; transition:margin 400ms ease-in-out; font-size: 14px;}	
.menu_top a			                { color: #000; line-height: 50px;}	
.menu_top li.active a	            { color:#d7534a;}
.header_nav .menu       			{ display:inline-block; }	
.header_nav .menu>li				{ display:inline-block; vertical-align:middle; margin-left: 40px; position: relative; }
.header_nav .menu li:first-child    { margin: 0;}
.header_nav .menu li a				{ font: 500 15px/60px "poppins"; color: #000; letter-spacing: 0.5px; height:60px; display: inline-block; transition-property: all;}
.header_nav .menu>li.active>a		{ color:#d7534a;}
.header_nav .sub					{ width: 300px; margin-left: -150px; position: absolute; top: calc(100% + 10px); left: 50%; display: block; background: #1e596a;opacity: 0; visibility: hidden; text-align: center;}

.header_nav .sub li					{ width: 100%; margin: 0;}
.header_nav .sub li a				{ width: 100%; font: 400 14px/50px "poppins"; height: 50px; color: #fff; display: block; padding: 0 40px; background: none;}
.header_nav .menu .sub li.active a	{ background-color: #113c4b;}
.sticky .header                     { box-shadow: 0 0 30px 0 rgba(32, 37, 43, 0.18);}
.info-mobile                        { display: none;}
@media (max-width:1400px) {
.header .logo                       { width: 120px;}
.header_nav .menu>li                { margin-left: 25px;}
.header .info-plus                  { margin-left: 15px;}
}
@media (min-width:1400px) {
.sticky .content_logo               { top: 55px;}
.sticky .header .info-plus          { transform: translateX(-50px);}
}
@media (min-width:1200px) and (max-width:1400px) {
.sticky .content_logo               { top: 55px;}
.sticky .header .info-plus          { transform: translateX(-30px);}
}
@media (max-width:1280px) and (min-width:1200px) {
.header .info-plus                  { font-size: 12px; width: 230px;}
.sticky .content_logo               { top: 80px;}
.header_nav .menu>li                { margin-left: 20px; }
.header_nav .menu>li a              { font-size: 14px; }
}
@media (min-width:1201px) {
.header_nav .menu .vue_mobile,
.menu_mobile 						{ display: none;}
.header_nav .menu>li:hover>a,
.link_top .tel:hover,
.header_nav li a:hover			    { color: #000000;}
.header_nav .sub.large:after 		{ display: none}
.header_nav .menu>li:hover>a		{ color: #d7534a;}
.menu_top  a:hover                  { color: #d7534a !important;}
.header_nav .sub li a:hover			{ background-color: #113c4b; color: #fff!important;}
.sticky .header                     { top: -50px; background: #fff;}
.sticky .header_nav                 { transform: translateY(10px);}
.header_nav .menu li:hover .sub		{ opacity: 1; visibility: visible; z-index: 999; top: calc(100% + 10px);}
.sticky .header_nav .menu           { padding-top: 0;}
.header .link-mobile                { display: none;}
.sticky .header .logo               { transform: scale(0.8);  }

.header_nav .sub:after 				{ width: 10px; height: 10px; position: absolute; left: 50%; top: -5px; margin: 0 0 0 -5px; transform: rotate(45deg); background: #1e596a; content: ""; z-index: -1;}
}

@media (max-width:1200px) {
.sticky .header                     { top: 0; background-color: #fff;}
.header                             { z-index: 201; padding: 0;}
.header .logo                       { width: 150px; }
.header .content_logo               { top: 5px; z-index: 100;}
.header .link                       { display: none;}
.header .link-mobile                { display: inline-block; vertical-align: middle; margin-right: 10px; margin-left: 0; z-index: 200; position: relative; width: 60px; height: 60px; background: url(../images/mail_rose.svg) no-repeat center transparent;}
.menu_mobile						{ width:60px; height:60px; display:inline-block; vertical-align:middle; cursor:pointer; position:relative; z-index:60; margin: 15px -15px; transition:height 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:9px; content:"";}
.menu_mobile div:after				{ width:100%; height:2px; background:#000; 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;}
.menu_top a                         { display: inline-block; width: 40px; height: 40px; background: url(../images/tel_rose.svg) no-repeat center;  z-index: 100;}
.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: 50px; background-color: #d7534a; height: 41px; display: block; margin-top: 5px; position: relative; z-index: 5;float: right; border-radius: 0;}
.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/arrow_down.svg) no-repeat center}
.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: 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%; font-size: 16px; line-height: 50px; height: 50px; font-weight: 500; text-align: left; color: #fff;}

.header_nav.active					{ top:0; transition-delay: 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;}
.header_right                       { display: inline-block; vertical-align: middle;}

}

@media (max-width:1000px) {		
.header_nav .sub 					{ padding: 25px 40px;}
.header_nav .sub li a				{ border: none; line-height: 45px; height: 45px;}
.header .logo                       { width: 140px;}
.header                             { background-color: #fff;}
}

@media (max-width:600px) {
.header                             { padding: 0;}
.header .wrapper                    { width: 85vw;}
.header .link.tel span              { font-size: 0; padding: 0; display: block; background-position: center;}
.menu_mobile	                    { margin: 10px -15px;}
.header_nav                         { padding: 150px 7.5vw 0; align-content: baseline;}
.header_nav .menu_top,
.header_nav .menu                   { width: 100%;}
.header_nav .menu .sub 				{ border-radius: 0;}
.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 .info-plus                  { display: none;}
.info-mobile      { display: block; width:100%; background-color: #1e596a; padding:25px 7.5vw; margin: 0; color: #fff; transition: all ease-in-out 400ms; top: 80px; position: absolute; left: 0;}
.header .content_logo               { top:0}
.info-mobile span                   { max-width: 340px; display: block; font-size: 16px; line-height: 25px;}
.menu_top a                         { width: 35px; height: 35px;}
.page_interne .info-plus.info-mobile { display: none;}
}


/***** faq *****/
.table_plus 						{ position: relative; margin: 90px 0 120px;} 
.table_plus .titre_main             { margin-bottom: 20px;}
.table_plus .titre                  { margin: 20px 0;}
.table_plus .item:not(:last-of-type){ border-bottom: none;}
.table_plus .hide 					{ padding: 20px 30px 25px; 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: #d7534a; color: #fff; font-size: 18px; font-weight: 400; margin-bottom: 15px; transition: all 400ms ease-in-out; line-height: 35px;}
.titre_plus:before					{ width: 40px; height: 40px; background: url("../images/plus.svg") 50% no-repeat; position: absolute; right: 25px; top: 50%; margin-top: -20px; transition: all 400ms ease-in-out; content: ""; border-radius: 50%;}
.titre_plus.active:before 			{ transform: rotate(135deg); }
.titre_plus.active       			{ background-color: #113c4b; }
@media (min-width:1200px) {
.titre_plus:hover                   { background-color: #113c4b;}
}
@media (max-width:1000px) {
.table_plus .hide 					{ padding: 40px 0;}
.table_plus                         { margin: 50px 0;}
}
@media (max-width:700px) {
.table_plus 						{ margin: 20px 0 50px;} 
.table_plus .sized					{ margin-bottom: 10px;} 
.table_plus .hide 					{ padding: 20px 0;}
.titre_plus 						{ font-size: 14px; line-height: 25px; padding: 15px 100px 15px 30px; margin-bottom: 10px;}
.titre_plus:before					{ width: 30px; height: 30px; right: 30px; margin-top: -17px;}
}
@media (max-width:500px) {
.titre_plus                         { padding: 10px 100px 10px 30px; }
}


/***** footer*****/
.footer								{ width: 100%; position: relative; padding-top: 90px; color: #1e596a; font-size: 0; background-color: #eee;}
.footer .bloc_footer.coordonnees    { margin-right: 80px; margin-top: 0;}
.footer .bloc_footer 				{ display: inline-block; vertical-align: top; line-height: 30px; margin-right: 60px; font-size: 14px; margin-top: 65px;}
.footer .sous_titre                 { font: 500 40px/40px "poppins";color: #1e596a; margin-bottom: 25px;}
.footer .sous_titre span            { font-size:20px;}
.footer .bloc_footer p				{ font-size: 14px; margin-top: 10px;}
.footer .localisation               { padding-left: 30px; background: url("../images/local_rose.svg") no-repeat  left top 5px;}
.footer .bloc_footer p span         { display: block; margin-bottom: 20px; font: 700 15px/1.2 "poppins"; color: #1e596a; text-transform: uppercase; letter-spacing: 0.8px;}
.footer .bloc_footer li             { padding-left: 15px; background: url("../images/ul_list_blue.svg") no-repeat center left; margin-bottom: 10px;}
.footer .bloc_footer p a			{ color: #1e596a; text-transform: none; display: inline-block; border: none;}
.footer .bloc_footer li a           { color: #1e596a;}
.footer .bloc_footer .phone         { background: url("../images/tel_rose.svg") left center no-repeat; line-height: 35px; padding-left: 30px; margin-top: 0;}
.footer .bloc_footer .mail          { background: url("../images/mail_rose.svg") left center no-repeat; line-height: 35px; padding-left: 30px;}
.footer	.rs							{ position: absolute; right: 0; top: 5px;}
.footer	.rs a						{ display: inline-block; vertical-align: top; margin-right: 10px; width: 60px; height: 60px;}
.footer	.rs .facebook			    { background: url(../images/facebook.svg) 50% no-repeat #1e596a;}
.footer	.rs .instagram			    { background: url(../images/instagram.svg) 50% no-repeat #1e596a;}
.footer	.rs .scroll					{ background: url("../images/scrolltop_white.svg") center no-repeat #1e596a; margin: 0;}
.footer_bottom   					{ padding: 20px 0; line-height: 0; margin-top: 60px;}
.footer_bottom li 					{ display: inline-block; font-size: 11px; line-height: 20px; margin-right: 25px; letter-spacing: 1px; position: relative;}
.footer_bottom li a 				{ color: #1e596a;}
.footer_bottom li:after				{ width: 1px; height: 9px; content: ""; position: absolute; right: -13px; top: 5px; background: #1e596a;}
.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, #113c4b 0%, #113c4b 50%, #d7534a 50%, #d7534a 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:not(.link):hover,
.footer_bottom li a:hover,
.footer .bloc_footer li a:hover 	{ color: #d7534a;}
.rs a:hover			                { background-color:#113c4b !important;}
.toponweb:hover span				{ background-position: 0 0;}
.footer	.rs .facebook:hover 	    { background-image: url(../images/facebook_white.svg) ;}
.footer	.rs .instagram:hover	    { background-image: url(../images/instagram_white.svg);}
.footer	.rs .scroll:hover			{ background-image: url(../images/scrolltop_white.svg); }
}
@media (max-width:1200px) {
.toponweb                           { position: absolute;}
.footer .bloc_footer                { margin-right: 40px;}
}
@media (max-width:1000px) {
.footer .bloc_footer 				{ margin: 0 0 40px; display: none;}
.footer .bloc_footer.coordonnees    { display: block;}
.footer .bloc_footer p              { margin: 5px;}
.footer_bottom   					{ margin-top: 80px;}
}
@media (max-width:700px) {
.footer								{ padding-top: 40px;}
.footer .logo                       { font-size: 20px; margin-bottom: 45px;}
.footer .bloc_footer.coordonnees    { margin-right: 0;}
.footer .sous_titre                 { font-size: 25px; line-height: 25px;}
.footer	.rs							{ position: static; margin-top: 5px;}
.footer .bloc_footer p span         { font-size: 13px; margin-bottom: 15px;}
.footer_bottom 	 					{ text-align: left; margin-top: 30px; padding: 0 0 50px;}
.footer_bottom li 					{ display: block; margin-right: 0; line-height: 25px; font-size: 11px;}
.footer_bottom li:after				{ display: none;}
}

.cta                                { position: relative; padding: 40px 50px; transition: all ease-in-out 400ms; text-align: center; background: url(../images/link.svg) no-repeat center right 40px #d7534a; color: #fff; font:500 25px/32px "poppins"; margin-bottom: 90px; }
.cta .titre_main                    { color: #fff;}
.cta p a                            { color: #fff; border-bottom: 1px solid transparent; padding-bottom: 2px; display: inline-block;}

@media (min-width:1200px) {
.cta:hover                          { background-color: #113c4b;}
.cta p  a:hover                     { border-color: #fff;}
}

@media (max-width:1000px) {
.cta                                { font-size: 16px; padding: 30px 50px 30px 20px; margin-bottom: 80px; background-position: center right 20px;}
}
@media (max-width:600px) {
.cta                                { background: none; padding: 0; color: #fff; font-size: 0; background-color: #d7534a; height: 60px; margin-bottom: 40px;}
.cta span                           { display: block; font-size: 14px; line-height: 60px; }
.cta .formulaire                    { position: absolute; width: 100%; height: 100%; top: 0; left: 0;}
}
.link-moins,.link-plus              { cursor:pointer; color: #d7534a;}
.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: #d7534a;}
}
@media (max-width:600px) {
.textMore                           { margin-top: 20px;}
}