/* latin-ext */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/inter/v19/UcCo3FwrK3iLTcvsYwYL8g.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/inter/v19/UcCo3FwrK3iLTcviYwY.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* latin-ext */
@font-face {
  font-family: 'Playfair';
  font-style: normal;
  font-weight: 300 900;
  font-stretch: 100%;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/playfair/v10/0nk2C9D7PO4KhmUJ5_zTZ-wCMUXynAK-5UQzXotagFk.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Playfair';
  font-style: normal;
  font-weight: 300 900;
  font-stretch: 100%;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/playfair/v10/0nk2C9D7PO4KhmUJ5_zTZ-wCMUXynAK-5UQzUIta.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}



/***** variables *****/
:root {
	--mainColor1: #3c7677;
	--mainColor2: #4c4141;
	--bgColorLight: #fff;
	--bgColorDark: #4c4141;
    --beigeColor: #f7f0e7;
    --mainColor1Hover: #4c4141;
	
	--maxWidthWrapper: 1200px;
	--maxWidthWrapperSmall: 1000px;
	--maxWidthWrapperMedium: 1400px;
	--maxWidthWrapperLarge: 1600px;

	--marginTB: clamp(70px, 8vw, calc(110px + 2vw)) auto;
	--marginT: clamp(70px, 8vw, calc(110px + 2vw));
	--marginB: clamp(70px, 8vw, calc(110px + 2vw));
	
	--imgRadius: 30px;
	--linkRadius: 10px;
    
    --fontBody: "Inter";
	--fontScript: "Playfair";
}
@media (max-width:1600px) {
	:root {
		--imgRadius: 25px;
	}
}
@media (max-width:1000px) {
	:root {
		--marginTB: clamp(45px, 12vw, 70px) auto;
		--marginT: clamp(45px, 12vw, 70px);
		--marginB: clamp(45px, 12vw, 70px);
		--imgRadius: 20px;
	}
}
@media (max-width:700px) {
	:root {
		--imgRadius: 15px;
	}
}



/***** reset *****/
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;}
body								{ font: 500 clamp(14px, 2.2vw, 16px)/180% var(--fontBody); letter-spacing: 0.2px; color: var(--mainColor2); position: relative; background-color: var(--beigeColor)}
body.active_overflow				{ height: 100vh; overflow: hidden;}
main 								{ position: relative; z-index: 20;}
p 									{ margin-bottom: clamp(10px, 2vw, 15px);}
ul									{ margin-bottom: clamp(10px, 2vw, 15px); list-style-type: none;}
a									{ text-decoration: none; color: var(--mainColor2); position: relative;}
img									{ border: none;}
strong, b							{ font-weight: 600; font-size: clamp(14px, 2.2vw, 16px);}
#wrapper 							{ min-width: 320px; position: relative;}
#wrapper *							{ box-sizing: border-box;}
#footer 							{ position: relative; z-index: 15;}

@media (max-width:700px) {
body								{ line-height: 180%;}
}






/***** scollbar *****/
::-webkit-scrollbar 				{ width: 6px; height: 6px; background-color: #fff;}
::-webkit-scrollbar-thumb			{ background-color: var(--mainColor1);}


/***** transition *****/
@media (min-width:1201px) {
.link, .slick-arrow, :before, :after, a, a span, .logo, .header, .sub { transition: all 300ms ease-in-out;}
}


/***** class *****/
.wrapper 							{ width: 90vw; max-width: var(--maxWidthWrapper); margin: 0 auto; position: relative;}
.wrapper_small						{ width: 90vw; max-width: var(--maxWidthWrapperSmall); margin: 0 auto; position: relative;}
.wrapper_medium						{ width: 90vw; max-width: var(--maxWidthWrapperMedium); margin: 0 auto; position: relative;}
.wrapper_large						{ width: 90vw; max-width: var(--maxWidthWrapperLarge); margin: 0 auto; position: relative;}
.wrapper_full						{ margin: 0 5vw; position: relative;}

.margin_top_bottom 					{ margin: var(--marginTB);}
.margin_top 						{ margin-top: var(--marginT);}
.margin_bottom 						{ margin-bottom: var(--marginB);}

.clear								{ clear: both; display: block;}
.anchor								{ position: absolute; left: 0; top: -140px;}

.color_1							{ color: var(--mainColor1);}
.color_2							{ color: var(--mainColor2);}

.titre_main	 						{ font: 700 clamp(28px, 3.5vw, 55px)/105% var(--fontScript); letter-spacing: 0; position: relative; color: var(--mainColor1); margin-bottom: clamp(10px, 2vw, 15px);}
.titre 								{ font: 700 clamp(25px, 3vw, 50px)/105% var(--fontScript); letter-spacing: 0; position: relative; color: var(--mainColor2); margin-bottom: clamp(10px, 2vw, 15px);}
.sous_titre 						{ display: block; font: normal 500 22px/140% var(--fontBody); color: var(--mainColor1); margin-bottom: clamp(10px, 2vw, 15px);}
.chapo		 						{ font-size: clamp(14px, 2.2vw, 16px); font-weight: 500; margin-bottom: clamp(10px, 2vw, 15px);}
.chapo span	 						{ display: block; margin-top: clamp(10px, 2vw, 15px);}
.link 								{ font: 500 14px/58px var(--fontBody); letter-spacing: 0.6px; height: 60px; display: inline-block; padding: 0 30px; border: none; background: var(--mainColor1); color: #fff; cursor: pointer; border-radius: var(--linkRadius);}
.read_more							{ font-style: normal; display: inline-block; color: var(--mainColor1); cursor: pointer; transition: color 300ms ease-in-out;}

.ul_check   						{ padding: clamp(3px, 1vw, 5px) 0;}
.ul_check li 						{ position: relative; padding-left: 28px; margin-bottom: clamp(5px, 1.8vw, 10px); line-height: 170%;}
.ul_check li:before					{ width: 18px; height: 14px; position: absolute; left: 0; top: 5px; background: url("../images/check.svg") 0 0 / contain no-repeat; filter: invert(0); content: "";}
.ul_check li:last-child				{ margin-bottom: 0;}

.ul_list   							{ padding: clamp(3px, 1vw, 5px) 0;}
.ul_list li 						{ position: relative; padding-left: 18px; margin-bottom: clamp(5px, 1.8vw, 10px); line-height: 170%;}
.ul_list li:before					{ width: 6px; height: 6px; position: absolute; left: 0; top: 10px; background: var(--mainColor1); border-radius: 50%; content: "";}
.ul_list li:last-child				{ margin-bottom: 0;}

.hide 								{ display: none;}

@media (min-width:1201px) {
.link:hover 						{ background-color: var(--mainColor2); color: #fff}
.link_text_arrow:hover				{ color: var(--mainColor1);}
}
@media (max-width:1000px) {
.titre_main	 						{ font-size: clamp(25px, 6vw, 32px); line-height: 120%;}
.titre 								{ font-size: clamp(25px, 6vw, 32px); line-height: 120%;}
.sous_titre 						{ font-size: clamp(16px, 3vw, 20px); line-height: 160%;}
}
@media (max-width:700px) {
.ul_check li:before					{ top: 3px;}
.ul_list li:before					{ top: 8px;}
.link 								{ padding: 0 20px; line-height: 48px; height: 50px; width: 100%; text-align: center;}
}


/***** header : simple *****/
.header 									{ width: 100%; font-size: 0; line-height: 0; letter-spacing: 0; position: fixed; left: 0; top: 0; z-index: 100; text-align: right; padding: 30px 0; transition: all 300ms ease-in-out;}
.header .logo								{ width: 220px; height: 155px; overflow: hidden; position: absolute; left: 0; top: 0; z-index: 850;}
.header .logo img							{ width: 100%; height: auto; display: block;}
.header .header_nav 						{ display: inline-block; position: relative; padding: 40px 170px 0 0; min-width: 50%; transition: all 300ms ease-in-out;}
.header .menu 								{ margin: 0;}
.header .menu>li							{ position: relative; display: inline-block; vertical-align: top; margin-right: 30px;}
.header .menu>li a							{ font-size: 16px; line-height: 38px; font-weight: 600; height: 40px; display: block; letter-spacing: 0.6px; color: var(--mainColor2);}
.header .menu>li.active>a					{ color: var(--mainColor1);}
.header .tel 								{ position: absolute; top: 0; right: 300px; font-size: 16px; line-height: 40px; color: var(--mainColor1); padding-left: 30px;}
.header .tel:before 						{ width: 18px; height: 100%; position: absolute; left: 0; top: 0; background: url(../images/tel.svg) 50% / contain no-repeat; content: "";}
.header .cta 								{ position: absolute; top: 0; right: 0; height: 80px; width: 160px; padding: 46px 0 0 0; text-align: center; line-height: 20px; z-index: 250;}
.header .cta:after 							{ width: 100%; height: 22px; background: url("../images/reserver.svg") 50% 0 / contain no-repeat; position: absolute; left: 0; top: 16px; content: "";}

@media (min-width:1201px) {
.header .menu_mobile 						{ display: none;}
.header .sub:after 							{ width: 8px; height: 8px; position: absolute; left: 50%; top: -4px; margin: 0 0 0 -4px; transform: rotate(45deg); background: #fff; content: ""; display: none;}
.header .has_sub>li:hover .sub 				{ opacity: 1; visibility: visible; z-index: 999; top: 100%;}
.header .menu>li:hover 						{ z-index: 999;}		
.header .menu_small>li:hover>a,		
.header .menu>li:hover>a,		
.header .sub li a:hover 					{ color: var(--mainColor1);}

.sticky .header									    { background: #fff;}
.sticky .header:not(.scrolling_top)					{ padding: 15px 0;}
.sticky .header:not(.scrolling_top) .logo			{ width: 120px; height: 62px; top: -5px; left: -28px;}
.sticky .header:not(.scrolling_top) .header_nav		{ padding-top: 0;}
.sticky .header:not(.scrolling_top) .menu>li>a 		{ line-height: 48px; height: 50px;}
.sticky .header:not(.scrolling_top) .tel  			{ top: -55px; opacity: 0;}
.sticky .header:not(.scrolling_top) .langs 			{ top: -55px; opacity: 0;}
.sticky .header:not(.scrolling_top) .cta 			{ height: 50px; padding-top: 15px;}
.sticky .header:not(.scrolling_top) .cta:after 		{ top: 0; opacity: 0;}
}
@media (max-width:1800px) {
.header .logo								{ width: 180px; height: 140px; top: -5px;}
}
@media (max-width:1200px) {
.header .menu_mobile						{ width: 60px; height: 60px; display: inline-block; vertical-align: middle; cursor: pointer; position: relative; z-index: 850; margin: 0 -10px;}
.header .menu_mobile div					{ width: 40px; height: 2px; background: var(--mainColor2); position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);}
.header .menu_mobile div:before				{ width: 100%; height: 2px; background: var(--mainColor2); position: absolute; left: 0; top: 8px; content: "";}
.header .menu_mobile div:after				{ width: 100%; height: 2px; background: var(--mainColor2); position: absolute; left: 0; top: -8px; content: "";}
.header .menu_mobile.active div				{ height: 0; width: 36px;}
.header .menu_mobile.active div:before		{ top: 0; transform: rotate(45deg);}
.header .menu_mobile.active div:after		{ top: 0; transform: rotate(-45deg);}

.header 									{ padding: 15px 0; background: #fff;}
.header ::-webkit-scrollbar					{ display: none;}
.header .logo								{ width: 100px;}
.header .header_nav 						{ width: 100%; position: fixed; right: -100%; top: 0; bottom: 0; overflow-y: scroll; z-index: 800; padding: 0; background: var(--mainColor2); border-top: 90px solid #fff; display: grid; transition: all 300ms ease-in-out 450ms;}
.header .menu  								{ display: block; width: auto; text-align: center; margin: 4vw 0 10vw 0; position: relative; z-index: 100; align-self: center; opacity: 0; transform: translateY(40px); transition: all 300ms ease-in-out 150ms;}
.header .menu>li 							{ width: 100%; display: block; margin: 0;}
.header .menu>li>a							{ font: 700 clamp(20px, 6vw, 35px)/160% var(--fontScript); padding: 5px 0; letter-spacing: 0; height: auto; color: #fff; transition: none; display: inline-block; z-index: 10;}
.header .menu>li.active>a					{ color: #fff; opacity: 0.3;}
.header.active .header_nav 					{ right: 0; transition-delay: 150ms;}
.header.active .menu 						{ opacity: 1; transform: translateY(0); transition-delay: 450ms;}
.header.active .menu_small 					{ opacity: 1; transform: translateY(0); transition-delay: 600ms;}
.header .cta 								{ position: relative; right: auto; top: auto; vertical-align: middle; height: 50px; line-height: 50px; width: auto; padding: 0 30px 0 60px; text-align: left; z-index: 825; margin-right: 5vw;}
.header .cta:after 							{ top: 0; width: 22px; height: 100%; left: 20px; background-position: 0 48%;}
.header .tel 								{ position: relative; right: auto; top: auto; display: inline-block; vertical-align: middle; margin-right: 5vw; z-index: 900;}
}
@media (max-width:700px) {
.header 									{ padding: 14px 0 12px 0; position: static;}
.header .logo								{ margin: 0; position: static; display: block; height: auto;}
.header .header_nav							{ border-top-width: 0;}
.header .tel,
.header .cta, 
.header .menu_mobile						{ display: none;}
}





.langs  							        { position: absolute; right: 210px; top: -5px; text-align: left; font: 600 15px/35px "Inter"; letter-spacing: 1.2px; text-transform: uppercase; color: var(--mainColor2); display: inline-flex; z-index: 300; margin-left: -10px; width: 70px; height: 40px; transition: all 300ms ease-in-out;}
.langs>.active 						        { display: none;}
.langs .choice 						        { width: 100%; position: absolute; left: 0; top: 0; border-radius: 5px; background: transparent; padding: 8px 0; transition: all 400ms ease-out; display: flex;}
.langs .choice 						        { width: 100%; position: absolute; left: 0; top: 0; border-radius: 5px; background: transparent; padding: 8px 0; transition: all 400ms ease-out; display: flex;}
.langs .choice a 					        { display: block;  color: var(--mainColor2);padding: 0 10px;}
.langs .choice .active_desktop		        {  color: var(--mainColor1); }

@media (min-width:1201px) {
.langs .choice a:hover				        { color: var(--mainColor1);}         
}
@media (max-width:1200px) {
.langs  							        { height: auto; font: 600 11px/35px "Poppins"; letter-spacing: 1.2px; text-transform: uppercase; background-color: var(--mainColor2); color: #fff; position: relative;  border-radius: 8px; margin: 0 10px 0 -15px; right: inherit; top: 5px; z-index: 800;}
.langs:before						        { width: 14px; height: 10px; position: absolute; right: 10px; top: 50%; margin-top: -4px; background: url("../images/arrow_down.svg") 50%/contain no-repeat; z-index: 5; filter: brightness(0) invert(1); content: "";}
.langs .active 						        { display: initial; width: 65px; height: 50px; line-height: 50px; cursor: pointer; padding-left: 15px;}
.langs span 						        { display: none;}
.langs .choice 						        { width: 100%; position: absolute; left: 0; top: 0; border-radius: 5px; background: var(--bgColorDark); padding: 8px 0; opacity: 0; visibility: hidden; transition: all 400ms ease-out; flex-direction: column;}
.langs .choice a 					        { display: block; color: #fff; padding-left: 15px;}
.langs:hover .choice				        { opacity: 1; visibility: visible;}    
}
@media (max-width:700px) {
.langs .active 						        { height: 46px; line-height: 46px;}
.langs .choice   				        	{ padding: 5px 0;}
.langs  							        { position: absolute; right: 2vw; top: 10px;}
}





/***** side btn fixed *****/
.side_btn 								{ position: fixed; right: -64px; top: 50%; transform: translateY(-50%); z-index: 999; display: grid; grid-gap: 0; padding: 15px 5px; background: #fff; border-radius: 20px 0 0 20px; transition: all 300ms ease-in-out 0ms;}
.side_btn a								{ display: block; width: 54px; height: 54px; line-height: 46px; border-radius: 25em; position: relative; transition-duration: 0ms; transition-delay: 300ms; font-size:14px; }
.side_btn a:after						{ position: absolute; right: 0; top: 50%; transform: translateY(-50%); background: 50% / contain no-repeat; width: 54px; z-index: 5; content: ""; }
.side_btn a.booking:after				{ height: 24px; background-image: url("../images/reserver_bleu.svg");}
.side_btn a.tel:after					{ height: 20px; background-image: url("../images/tel.svg");}
.side_btn a.email:after					{ height: 16px; background-image: url("../images/email.svg");}
.side_btn a.facebook:after				{ height: 20px; background-image: url("../images/facebook.svg");}
.side_btn a	span						{ display: block; width: 160px; height: 46px; position: absolute; top: 4px; right: 90%; border-radius: 25em; opacity: 0; visibility: hidden;}
.side_btn a	i							{ position: absolute; left: 0; top: 0; font-style: normal; width: 160px; padding-left: 5px; text-align: center; color: #fff;  background: var(--mainColor1); border-radius: 25em; opacity: 0; /*transition: 100ms all 0ms;*/}

@media (min-width:1201px) {
.sticky .side_btn 						{ right: 0; transition-delay: 300ms;}

.side_btn a:hover  						{ background: #fff; transition-delay: 0ms;}
.side_btn a:hover span					{ opacity: 1; visibility: visible;}
.side_btn a:hover span:after,
.side_btn a:hover span:before			{ opacity: 1;}
.side_btn a:hover i						{ opacity: 1;}
}

/* if side btn nav mob */
.side_btn.mob_nav .hide_desk 						{ display: none;}
.side_btn.mob_nav .hide_mob 						{ display: block;}

@media (max-width:700px) {
.side_btn.mob_nav .hide_desk 						{ display: block;}
.side_btn.mob_nav .hide_mob 						{ display: none;}

.side_btn.mob_nav 									{ width: 100vw; right: 0; top: auto; bottom: 0; transform: none; grid-template-columns: repeat(5, 1fr); background: #ccc; grid-gap: 1px; padding: 0; border-radius: 0; box-shadow: 0 0 40px 0 rgba(0, 0, 0, 8%);}
.side_btn.mob_nav a									{ width: 100%; height: 60px; border-radius: 0; background: var(--mainColor1); background: #fff; font-size: 0; transition: none;}
.side_btn.mob_nav a:after							{ width: 100%; transition: none;}
.side_btn.mob_nav a.home_btn:after 					{ height: 22px; background-image: url("../images/icon_home.svg");}
.side_btn.mob_nav a	span							{ display: none;}

.side_btn.mob_nav .menu_mobile						{ width: 100%; height: 60px; cursor: pointer; position: relative; z-index: 850; background: #fff;}
.side_btn.mob_nav .menu_mobile div					{ width: 34px; height: 2px; background: var(--mainColor1); position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);}
.side_btn.mob_nav .menu_mobile div:before			{ width: 100%; height: 2px; background: var(--mainColor1); position: absolute; left: 0; top: 7px; content: "";}
.side_btn.mob_nav .menu_mobile div:after			{ width: 100%; height: 2px; background: var(--mainColor1); position: absolute; left: 0; top: -7px; content: "";}
.side_btn.mob_nav .menu_mobile.active div			{ height: 0; width: 28px;}
.side_btn.mob_nav .menu_mobile.active div:before	{ top: 0; transform: rotate(45deg);}
.side_btn.mob_nav .menu_mobile.active div:after		{ top: 0; transform: rotate(-45deg);}
}




/***** bloc horaire *****/
.bloc_horaire							{ position: relative; color: var(--mainColor2); max-width: 420px;}
.bloc_horaire p							{ background: #fff; border-radius: var(--linkRadius); padding: 22px 30px 24px 30px; cursor: pointer; position: relative; line-height: 20px; font-weight: 500; margin: 0;}
.bloc_horaire p:after					{ width: 18px; height: 100%; position: absolute; right: 30px; top: 0; background: url("../images/arrow_down.svg") 50% no-repeat; content:"";}
.bloc_horaire p.active:after			{ transform: rotate(-180deg);}
.bloc_horaire .hide						{ width: 100%; background: var(--mainColor1); font-size: 14px; line-height: 22px; color: #fff; padding: 20px 30px; position: absolute; left: 0; top: 90%; border-bottom-left-radius: 10px; border-bottom-right-radius: 10px; border-top: 10px solid #fff; display: none;}

@media (max-width:1000px) {
.bloc_horaire                           { max-width: none;}
.bloc_horaire .hide						{ position: static; transform: translateY(-10px);}
}
@media (max-width:700px) {
.bloc_horaire p							{ padding: 14px 25px 16px 25px;}
.bloc_horaire p:after					{ right: 25px;}
.bloc_horaire .hide						{ font-size: 13px; line-height: 20px; padding: 15px 25px;}
}



/***** bloc txt img *****/
.bloc_txt_img 											{ position: relative;}
.bloc_txt_img:before									{ position: absolute; left: 20px; right: 60%; top: 25%; bottom: 0; background: var(--bgColorLight); border-radius: 20px; visibility: hidden; transition: none; content: "";}
.bloc_txt_img .container	                        	{ display: grid; grid-template-columns: 50% 1fr; grid-gap: 0 80px; align-items: center; position: relative;}
.bloc_txt_img .container>.item							{ position: relative;}
.bloc_txt_img .container>.item :last-child 				{ margin-bottom: 0;}
.bloc_txt_img .container .txt .wrap						{ display: inline-block; text-align: left; max-width: 520px;}
.bloc_txt_img .container img 							{ width: 100%; height: auto; object-fit: cover; display: block; position: relative; z-index: 10; border-radius: var(--imgRadius);}
.bloc_txt_img .container p               				{ margin-bottom: 15px;}
.bloc_txt_img .container .link							{ margin-top: 10px;}
.bloc_txt_img .container .multi_links					{ display: grid; grid-template-columns: 140px 140px; grid-gap: 10px; margin-top: 25px;}
.bloc_txt_img .container .multi_links .link				{ margin: 0; text-align: center; padding: 0;}

.bloc_txt_img .container .img.col_2  					{ display: grid; grid-template-columns: 1fr 1fr; grid-gap: 40px; padding-top: 100px;}
.bloc_txt_img .container .img.col_2 img:first-child		{ transform: translateY(-100px);}
.bloc_txt_img .container .col_2.align  					{ padding-top: 0;}
.bloc_txt_img .container .col_2.align img:first-child	{ transform: none;}

.bloc_txt_img.reverse:before							{ left: 60%; right: 20px; top: 25%; bottom: -10%; background: var(--bgColorLight); border-radius: 20px; visibility: visible; content: "";}
.bloc_txt_img.reverse .container 						{ grid-template-columns: 1fr 50%;}
.bloc_txt_img.reverse .container>.item:last-child		{ grid-area: 1 / 1;}
.bloc_txt_img.reverse .container>.item:first-child      { grid-area: 1 / 2;}
.bloc_txt_img.reverse .container .txt					{ text-align: right;}
.bloc_txt_img.align_top .container                		{ align-items: start;}

@media (max-width:1400px) { 
.bloc_txt_img .container .img.col_2  					{ grid-gap: 40px; padding-top: 80px;}
.bloc_txt_img .container .img.col_2 img:first-child		{ transform: translateY(-80px);}
}
@media (max-width:1200px) { 
.bloc_txt_img:before									{ display: none;}
.bloc_txt_img .container	                        	{ grid-gap: 0 60px;}
.bloc_txt_img .container .img.col_2  					{ grid-gap: 20px; padding-top: 80px;}
.bloc_txt_img .container .img.col_2 img:first-child		{ transform: translateY(-80px);}
}
@media (max-width:1000px) { 
.bloc_txt_img .container 								{ grid-template-columns: 1fr; grid-gap: clamp(30px, 7vw, 40px);}
.bloc_txt_img .container .txt .wrap						{ max-width: none;}
.bloc_txt_img.reverse .container 						{ grid-template-columns: 1fr;}
.bloc_txt_img.reverse .container>.item:last-child		{ grid-area: 2;}
.bloc_txt_img.reverse .container>.item:first-child      { grid-area: 1;}
}
@media (max-width:700px) { 
.bloc_txt_img .container .link							{ margin-top: 5vw;}
.bloc_txt_img .container .img.col_2  					{ grid-gap: 3vw; padding-top: 0;}
.bloc_txt_img .container .img.col_2 img:first-child		{ transform: translateY(0);}
}




/***** quote : txt + img *****/
.quote_txt_img 											{ position: relative;}
.quote_txt_img .container	                        	{ display: grid; grid-template-columns: auto 1fr; grid-gap: 0 clamp(20px, 5vw, 60px); align-items: center; position: relative; background: #fff; border-radius: var(--imgRadius); padding: clamp(20px, 5vw, 80px); margin: 0 auto;}
.quote_txt_img .container.align_top                		{ align-items: start;}
.quote_txt_img .container .item							{ position: relative;}
.quote_txt_img .container .item :last-child 			{ margin-bottom: 0;}
.quote_txt_img .container img 							{ width: 250px; height: auto; object-fit: cover; display: block; position: relative; z-index: 10; border-radius: 50%; border: 5px solid var(--mainColor2);}
.quote_txt_img .container p               				{ margin-bottom: clamp(10px, 2vw, 15px);}
.quote_txt_img .container .link							{ margin-top: 10px; text-align: center; padding: 0 30px;}
.quote_txt_img .container :last-child					{ margin-bottom: 0;}
.quote_txt_img .container .grid_links                   { display: grid; grid-template-columns: 1fr 1fr; grid-gap: 10px; padding-top: 10px;}
.quote_txt_img .container .grid_links .link 	        { margin: 0;}

.quote_txt_img.reverse .container 						{ grid-template-columns: 1fr auto;}
.quote_txt_img.reverse .container .item:last-child		{ grid-area: 1 / 1;}
.quote_txt_img.reverse .container .item:first-child     { grid-area: 1 / 2;}

@media (max-width:1000px) { 
.quote_txt_img 											{ padding-top: 70px;}
.quote_txt_img .container	                        	{ grid-template-columns: 1fr; grid-gap: 4vw; padding-top: 0;}
.quote_txt_img .container img 							{ width: 180px; margin: -90px auto 0 auto;}
}
@media (max-width:700px) { 
.quote_txt_img 											{ padding-top: 50px;}
.quote_txt_img .container img 							{ width: 140px; margin-top: -70px; border-width: 3px;}
.quote_txt_img .container .grid_links                   { grid-template-columns: 1fr;}
}




/***** grid bloc *****/
.grid_bloc	 											{ position: relative;}
.grid_bloc:before										{ width: auto; height: auto; position: absolute; left: 0; right: 0; top: 0; bottom: 0; background: var(--bgColorLight); transition: none; z-index: -1; visibility: hidden; content: "";}
.grid_bloc .container									{ display: grid; grid-gap: clamp(20px, 3vw, 40px);}
.grid_bloc .container img								{ width: 100%; height: auto; object-fit: cover; display: block; border-radius: var(--imgRadius);}

.grid_bloc .item :last-child							{ margin-bottom: 0;}

@media (max-width:1200px) {
.grid_bloc:before										{ left: 0; right: 0; top: 0; bottom: 0; border-radius: 0;}
}
@media (max-width:700px) {
.grid_bloc .container									{ grid-gap: 10px;}
}

/* custom colums */
.grid_bloc.col_2 .container								{ grid-template-columns: repeat(2, 1fr);}
.grid_bloc.col_3 .container								{ grid-template-columns: repeat(3, 1fr);}
.grid_bloc.col_4 .container								{ grid-template-columns: repeat(4, 1fr);}
.grid_bloc.col_5 .container								{ grid-template-columns: repeat(5, 1fr);}
.grid_bloc.col_6 .container								{ grid-template-columns: repeat(6, 1fr);}
.grid_bloc.col_7 .container								{ grid-template-columns: repeat(7, 1fr);}
.grid_bloc.col_8 .container								{ grid-template-columns: repeat(8, 1fr);}

@media (max-width:1200px) {
.grid_bloc.col_7 .container								{ grid-template-columns: repeat(6, 1fr);}
}
@media (max-width:1000px) {
.grid_bloc.col_4 .container								{ grid-template-columns: 1fr 1fr;}
.grid_bloc.col_3 .container								{ grid-template-columns: 1fr;}
.grid_bloc.col_7 .container								{ grid-template-columns: repeat(4, 1fr);}
}
@media (max-width:700px) {
.grid_bloc.col_2 .container,	
.grid_bloc.col_3 .container,					
.grid_bloc.col_4 .container								{ grid-template-columns: 1fr;}
.grid_bloc.col_7 .container								{ grid-template-columns: repeat(3, 1fr);}
}

/* swipe mobile */ 
@media (max-width:1000px) {
.swipe_mobile .container 								{ display: flex; gap: 3vw; width: 100vw; margin-left: -5vw; overflow-x: auto; padding: 0 5vw;}
.swipe_mobile .container::-webkit-scrollbar 			{ display: none;}
.swipe_mobile .container .item 							{ min-width: clamp(270px, 75vw, 400px);}
}



/***** show hide *****/
.show_hide                        			{ position: relative; margin: 25px 0;}
.show_hide .item                  			{ /*border: 1px solid #37373720;*/ background: #fff; border-radius: var(--linkRadius); margin: 10px 0;}
/*.show_hide.no_marge .item               	{ margin: 0; border-top: none; border-right: none; border-left: none;}*/
.show_hide h3.sous_titre                	{ font: 700 clamp(25px, 3vw, 50px) / 100% var(--fontScript); letter-spacing: 0; position: relative; color: var(--mainColor2);}
.show_hide h4.titre                     	{ font: 500 clamp(14px, 2.2vw, 16px) / 160% var(--fontBody); cursor: pointer; padding: 16px 70px 16px 25px; margin: 0;} 
.show_hide .hide                  			{ margin: 0; padding: 10px 30px 30px 30px; display: none;}
.show_hide .hide :last-child 	 			{ margin-bottom: 0;}

@media (max-width:700px){
.show_hide                        			{ margin: 20px 0;}
.show_hide .titre                 			{ padding: 14px 60px 14px 20px;}
.show_hide .hide                  			{ padding: 10px 20px 20px 20px;}
}

/* custom collapse */
.show_hide.collapse                  		{ border: 1px solid #ddd; border-radius: 0;}
.show_hide.collapse .item                  	{ border: 0; margin: 0; border-radius: 0; border-bottom: 1px solid #ddd;}
.show_hide.collapse .item:last-child       	{ border: 0;}

/* custom titre arrow */
.show_hide .titre_arrow:after          		{ width: 18px; height: 100%; position: absolute; right: 20px; top: 0; background: url("../images/arrow_down.svg") 50% 54% / contain no-repeat; content: ""; }
.show_hide .titre_arrow.active:after   		{ transform: rotate(180deg);}

@media (max-width:700px){
.show_hide .titre_arrow:after          		{ right: 15px;}
}



/***** bloc rs *****/
.bloc_rs									{ font-size: 0; line-height: 0; letter-spacing: 0;}
.bloc_rs a									{ width: 54px; height: 54px; display: block; overflow: hidden; border-radius: 50%; background: #fff;}
.bloc_rs a:after							{ width: 100%; height: 100%; position: absolute; left: 0; top: 0; content: "";}
.bloc_rs .facebook:after					{ background: url("../images/facebook.svg") 48% 50% no-repeat;}
.bloc_rs .scroll:after 						{ background: url("../images/scrolltop.svg") 50% 48% no-repeat;}



/***** footer *****/
.footer										{ position: relative; color: #fff; padding-top: clamp(20px, 10vw, 0); text-align: center;}
.footer:before								{ position: absolute; left: 0; right: 0; top: 70px; bottom: 0; background: var(--bgColorDark); content: "";}
.footer .bloc_footer 						{ display: block; position: relative; line-height: 26px;}
.footer .bloc_footer.heading_top  			{ margin-bottom: clamp(25px, 6vw, 50px);}

.footer .bloc_footer .logo 					{ width: 240px; height: auto; display: block; margin: 0 auto;}
.footer .bloc_footer p						{ margin: 15px 0 0 0;}
.footer .bloc_footer p a					{ color: #fff;}
.footer .bloc_footer .link 				    { background: #fff; color: var(--mainColor1); margin-top: 15px;}

.footer .bloc_rs							{ position: absolute; right: 0; top: 140px; width: 100%; text-align: left;}
.footer .bloc_rs a							{ display: inline-block; vertical-align: top; margin-right: 10px;}
.footer .bloc_rs a:after					{ filter: invert(0);}
.footer .bloc_rs .scroll 					{ margin: 0; float: right;}

.footer_bottom   							{ padding: 25px 0; line-height: 0; margin: clamp(25px, 6vw, 60px) 0 0 0; text-align: left;}
.footer_bottom li 							{ display: inline-block; font-size: 12px; line-height: 20px; margin-right: 30px; letter-spacing: 0.8px; position: relative;}
.footer_bottom li:last-child 				{ margin-right: 0;}
.footer_bottom li:after						{ width: 1px; height: 10px; content: ""; position: absolute; right: -15px; top: 4px; background: #fff;}
.footer_bottom li:last-child:after 			{ display: none;}
.footer_bottom li a							{ color: #fff;}

.toponweb									{ display: block; z-index: 85; position: absolute; right: 0; bottom: 20px;}
.toponweb img								{ width: 80px; height: auto; display: block; filter: invert(0);}

@media (min-width:1201px) {
.footer .bloc_footer .link:hover 			{ background-color: #2d2727; color: #fff}
.footer .bloc_footer p a:hover, 
.footer .bloc_footer li a:hover, 	 
.footer_bottom li a:hover 	 				{ color: var(--mainColor1);}
.toponweb:hover span						{ background-position: 0 0;}
}
@media (max-width:1200px) {

}
@media (max-width:700px) {
.footer										{ padding-bottom: 65px;}
.footer:before								{ top: 38px;}


.footer .bloc_footer 						{ width: 100%; padding: 0; font-size: 14px; line-height: 24px;}


.footer .bloc_footer .logo 					{ width: 140px;}
.footer .bloc_footer p						{ margin: 10px 0 0 0;}

.footer	.bloc_rs							{ position: static; margin-top: 7vw; text-align: center;}
.footer	.bloc_rs a							{ width: 46px; height: 46px; margin: 0 10px;}
.footer	.bloc_rs .scroll					{ float: none;}

.footer_bottom 	 							{ text-align: left; padding: 0 0 20px 0;}
.footer_bottom li 							{ display: block; margin: 0; font-size: 11px; line-height: 28px;}
.footer_bottom li:after						{ display: none;}
}

