/* latin-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/montserrat/v30/JTUSjIg1_i6t8kCHKm459Wdhyzbi.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: 'Montserrat';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/montserrat/v30/JTUSjIg1_i6t8kCHKm459Wlhyw.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: #305bc6;
	--mainColor1Hover: #000;
	--mainColor2: #000;
	--mainColor2Hover: #305bc6;	
	--bgColorLight: #f2f2f2;
	--bgColorDark: #222;

	--fontBody: "Montserrat";
	
	--marginTB: clamp(20px, 10vw, 100px) auto;
	--paddingTB: clamp(20px, 10vw, 100px) 0;
	--gapSection: clamp(20px, 10vw, 100px);
	
	--maxWidthWrapper: 1200px;
	--maxWidthWrapperSmall: 1000px;
	--maxWidthWrapperLarge: 1800px;

	--imgRadius: 15px;
	--linkRadius: 10px;
}

@media (max-width:700px) {
	:root {
		--imgRadius: 5px;
		--linkRadius: 2px;
	}
}



/***** 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; position: relative;}
body								{ font: 500 15px/180% "Montserrat"; letter-spacing: 0.2px; color: var(--mainColor2); position: relative;}


body.active_overflow				{ height: 100vh; overflow: hidden;}
main 								{ position: relative; z-index: 10;}
p 									{ margin-bottom: clamp(10px, 2vw, 15px);}
ul									{ margin-bottom: clamp(10px, 2vw, 15px); list-style-type: none;}
a									{ text-decoration: none; color: #000; position: relative;}
img									{ border: none; }
strong, b							{ font-weight: 600; font-size: 16px;}

#wrapper 							{ min-width: 320px; position: relative;}
#wrapper *							{ box-sizing: border-box;}
#footer 							{ position: relative; z-index: 15;}

@media (max-width:700px) {
body								{ font-size: 14px; line-height: 26px;}
body:before 						{ display:none;}
strong, b							{ font-size: 14px;}
}



/***** scrollbar *****/
::-webkit-scrollbar 				{ width: 8px; height: 8px; background-color: #fff;}
::-webkit-scrollbar-thumb			{ background-color: #000;}


/***** 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: 85vw; max-width: var(--maxWidthWrapper); margin: 0 auto; position: relative;}
.wrapper_small						{ width: 85vw; max-width: var(--maxWidthWrapperSmall); margin: 0 auto; position: relative;}
.wrapper_large						{ width: 85vw; max-width: var(--maxWidthWrapperLarge); margin: 0 auto; position: relative;}
.no_wrapper							{ width: 85vw; margin: 0 auto; position: relative;}

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

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

.titre_main	 						{ font: 600 clamp(25px, 3vw, 40px)/120% "Montserrat"; position: relative; margin-bottom: clamp(10px, 2vw, 15px);}
.titre_main	i 						{ font-style: normal;}
.titre_main span					{ display: block; margin-top: clamp(5px, 0.5vw, 10px);; font-size: clamp(12px, 1.8vw, 20px); line-height: 140%; font-weight: 600;}
.titre_main.bigger					{ font-size: clamp(20px, 3vw, 50px); font-weight: 700; text-transform: uppercase; letter-spacing: 0.4px;}
.sous_titre 						{ font: 600 clamp(18px, 2vw, 28px)/140% "Montserrat"; position: relative; margin-bottom: clamp(10px, 2vw, 15px);}
.chapo		 						{ font: 500 15px/180% "Montserrat";}
.chapo span	 						{ display: block; margin-top: clamp(10px, 2vw, 15px);}

.link 								{ font: 600 12px/52px "Montserrat"; letter-spacing: 0.8px; height: 54px; text-transform: uppercase; display: inline-block; color: #fff; padding: 0 30px; background: linear-gradient(to top, #000 0% 50%, var(--mainColor1) 50% 100%); background-size: 100% 200%; background-position: 0 100%; cursor: pointer; border-radius: var(--linkRadius);}
.link.reverse 						{ background-image: linear-gradient(to top, var(--mainColor1) 0% 50%, #000 50% 100%);}

.ul_star li 						{ position: relative; padding-left: 28px; font-size: 16px; line-height: 25px; margin-bottom: clamp(10px, 2vw, 15px);}
.ul_star li:before					{ width: 18px; height: 20px; position: absolute; left: 0; top: 2px; background: url("../images/star.svg") 0 0 / contain no-repeat; content: "";}
.ul_star li:last-child				{ margin-bottom: 0;}

.ul_check li 						{ position: relative; padding-left: 30px; font-size: 16px; line-height: 25px; margin-bottom: clamp(10px, 2vw, 15px);}
.ul_check li:before					{ width: 19px; height: 14px; position: absolute; left: 0; top: 4px; background: url("../images/check.svg") 0 0 / contain no-repeat; filter: invert(1); content: "";}
.ul_check li:last-child				{ margin-bottom: 0;}

/***** Link a *****/
p a 		 { color: var(--mainColor2); border-bottom: 1px solid var(--mainColor2); }
.footer p a  { border-bottom: none; }
@media (min-width:1201px) {
p a:hover					{ color: var(--mainColor2); border-color: var(--mainColor2Hover); }
}

@media (min-width:1201px) {
.link:hover 						{ background-position: 0 0;}
}

@media (max-width:1400px) {
.wrapper 							{ width: 90vw;}
.wrapper_small						{ width: 90vw;}
.wrapper_large						{ width: 90vw; max-width: var(--maxWidthWrapper);}
.no_wrapper							{ width: 90vw;}
}

@media (max-width:700px) {
.ul_star li 	{ font-size: 14px;}
}


/***** header : simple *****/
.header 								{ width: 100%; padding: 25px 0 50px 0; position: relative; text-align: right; z-index: 900; transition: all 300ms ease-in-out;}
.header .logo							{ width: 220px; display: block; margin: 0 auto;}
.header .logo img						{ width: 100%; height: auto; display: block;}
.header .header_nav 					{ display: inline-block; vertical-align: middle; background: #fff; padding: 0 40px; border-radius: 10px; position: fixed; right: 30px; top: 30px; /*box-shadow: 0 0 30px 0 rgba(0,0,0,8%);*/}
.header .menu 							{ margin: 0; padding-right: 5px;}
.header .menu>li						{ position: relative; display: inline-block; vertical-align: top; margin-right: 30px;}
.header .menu>li:last-child				{ margin-right: 0;}
.header .menu>li a						{ font-size: 14px; line-height: 70px; font-weight: 700; height: 70px; display: block; letter-spacing: 0.6px; text-transform: uppercase;}
.header .menu>li.active>a				{ color: var(--mainColor2Hover);}
.header .sub							{ width: 300px; margin: 0 0 0 -150px; text-align: center; position: absolute; top: 60px; left: 50%; display: block; visibility: hidden; opacity: 0; padding: 20px 0; background: #000; border-radius: 10px;}
.header .sub li							{ width: 100%; margin: 0;}
.header .sub li a						{ width: 100%; font-size: 15px; padding: 5px 0; height: auto; line-height: 200%; font-weight: 500; letter-spacing: 0.4px; text-transform: none; color: #fff;}
.header .sub li.active a				{ opacity: 0.5;}


@media (min-width:1201px) {
.header .menu_mobile 					{ display: none;}
.header .sub:after 						{ width: 10px; height: 10px; position: absolute; left: 50%; top: -4px; margin: 0 0 0 -5px; transform: rotate(45deg); background: #000; content: "";}
.header .menu>li:hover .sub				{ opacity: 1; visibility: visible; z-index: 999;}
.header .menu>li:hover>a 				{ color: var(--mainColor1);}		
.header .sub li a:hover 				{ opacity: 0.5;}
}
@media (max-width:2000px) {
.header 								{ padding: 20px 0 40px 0;}
}
@media (max-width:1600px) {
.header 								{ padding: 20px 0 20px 0;}
.header .logo							{ width: 200px; margin: 0 0 0 5vw;}
}
@media (max-width:1400px) {
.header 								{ padding: 15px 0 20px 0;}
.header .logo							{ width: 180px;}
.header .header_nav 					{ right: 20px; top: 20px;}
}
@media (max-width:1200px) {
.header .menu_mobile					{ width: 50px; height: 50px; display: inline-block; vertical-align: middle; cursor: pointer; position: fixed; right: 1.5vw; top: 1.5vw; z-index: 850; background: var(--mainColor1); border-radius: var(--linkRadius);}
.header .menu_mobile div				{ width: 26px; height: 2px; background: #fff; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);}
.header .menu_mobile div:before			{ width: 100%; height: 2px; background: #fff; position: absolute; left: 0; top: 7px; content: "";}
.header .menu_mobile div:after			{ width: 100%; height: 2px; background: #fff; position: absolute; left: 0; top: -7px; 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 40px 0;}
.header ::-webkit-scrollbar				{ display: none;}
.header .logo							{ width: 220px; margin: 0 auto;}
.header .header_nav 					{ width: 100%; position: fixed; right: 1.5vw; top: 1.5vw; bottom: 0; overflow-y: scroll; display: grid; z-index: 800; background: var(--mainColor1); padding: 0; border-radius: 5vw; transform: scale(0); transform-origin: right top; transition: all 300ms ease-in-out 450ms;}
.header .menu  							{ display: block; width: 100%; text-align: center; padding: 5vw; 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-size: 6vw; line-height: 200%; font-weight: 600; height: auto; padding: 0; color: #fff; transition: none; display: inline-block; z-index: 10;}
.header .menu>li.active>a				{ color: #fff;}
.header .menu>li>i						{ width: 100%; height: 60px; display: block; margin-top: -100px; position: relative; z-index: 5; float: right;}
.header .menu>li>i:after					{ width: 44px; height: 44px; background: url("../images/arrow_down.svg") 50% 52% no-repeat #fff; border-radius: 5px; position: absolute; right: 0; top: 10px; content: "";}
.header .menu>li>i.active:after 			{ transform: rotate(180deg);}
.header .sub 							{ width: max-content; position: relative; left: auto; top: auto; padding: 20px 30px; margin: 15px auto; border-radius: 5px; background: #fff; visibility: visible; opacity: 1; display: none; z-index: 150;}
.header .sub li  						{ width: 100%;}
.header .sub li a						{ width: 100%; font-size: 16px; line-height: 24px; height: auto; padding: 10px 0; text-align: left; display: block; color: #000;}

.header.active .header_nav 				{ right: 0; top: 0; transform: scale(1); border-radius: 0; transition-delay: 150ms;}
.header.active .menu					{ opacity: 1; transform: translateY(0); padding-bottom: 7vw; transition-delay: 450ms;}
}

@media (max-width:1000px) {
.header .menu>li>i						{ margin-top: -90px;}
}

@media (max-width:800px) {
.header .menu>li>i						{ margin-top: -80px;}
}

@media (max-width:800px) {
.header .menu>li>i						{ margin-top: -70px;}
}

@media (max-width:700px) {
.header .menu_mobile { display: none;}
}

@media (max-width:600px) {
.header .menu { text-align: left;}
.header .sub { margin: 15px 0; width: 100%;}
.header .logo img { width: 70%; margin: 0 auto;}
}

@media (max-width:400px) {
.header .menu>li>i						{ margin-top: -50px; height: 40px;}
}

/***** side btn fixed *****/
.side_btn 								{ position: fixed; left: 30px; top: 50%; transform: translateY(-50%); z-index: 200; display: grid; grid-gap: 10px;}
.side_btn a								{ display: block; width: 50px; height: 50px; line-height: 50px; border-radius: 10px; position: relative; transition-duration: 0ms; transition-delay: 300ms;}
.side_btn a:after						{ position: absolute; left: 0; top: 50%; transform: translateY(-50%); background: 50% / contain no-repeat; width: 50px; z-index: 5; content: "";}
.side_btn a.tel:after					{ height: 20px; background-image: url("../images/tel.svg");}
.side_btn a.email:after					{ height: 14px; background-image: url("../images/email.svg");}
.side_btn a.facebook:after				{ height: 20px; background-image: url("../images/facebook.svg"); background-position: 48% 50%;}
.side_btn a.tarifs:after				{ height: 18px; background-image: url("../images/euro.svg"); background-position: 48% 50%;}
.side_btn a	span						{ display: block; width: 50px; height: 50px; position: absolute; top: 0; left: 0; background: var(--mainColor1); border-radius: 10px;}
.side_btn a	i							{ position: absolute; left: 0; top: 0; font-style: normal; width: 140px; padding-left: 5px; text-align: center; color: #fff; background: var(--mainColor1); border-radius: 10px; opacity: 0; transition: 100ms all 0ms;}

@media (min-width:1201px) {
.side_btn a:hover  						{ background: var(--mainColor1); transition-delay: 0ms;}
.side_btn a:hover span					{ width: 140px; left: 50%; border-radius: 10px;}
.side_btn a:hover span:after,
.side_btn a:hover span:before			{ opacity: 1; transition-delay: 200ms;}
.side_btn a:hover i						{ opacity: 1; transition-delay: 250ms;}
}
@media (max-width:1200px) {
.side_btn 								{ left: 1.5vw; top: 1.5vw; transform: none; grid-template-columns: repeat(4, 50px); z-index: 250;}
.side_btn a								{ width: 50px; height: 50px; overflow: hidden;}
.side_btn a:after						{ width: 50px;}
.side_btn a	span						{ width: 50px; height: 50px;}
.side_btn a.tarifs 						{ display: none;}
}


/* 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; z-index: 950; grid-template-columns: repeat(4, 1fr); grid-gap: 1px; background: #fff; left: 0; border-top: 1px solid #fff;}
.side_btn.mob_nav a									{ width: 100%; height: 60px; border-radius: 0; background: var(--mainColor1); font-size: 0; transition: none;}
.side_btn.mob_nav a:after							{ width: 100%; transition: none;}
.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: var(--mainColor1);}
.side_btn.mob_nav .menu_mobile div					{ width: 34px; height: 2px; background: #fff; position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);}
.side_btn.mob_nav .menu_mobile div:before			{ width: 100%; height: 2px; background: #fff; position: absolute; left: 0; top: 8px; content: "";}
.side_btn.mob_nav .menu_mobile div:after			{ width: 100%; height: 2px; background: #fff; position: absolute; left: 0; top: -8px; 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 txt img *****/
.bloc_txt_img 											{ position: relative; margin: var(--marginTB);}
.bloc_txt_img:before									{ position: absolute; left: 20px; right: 60%; top: 25%; bottom: 0; background: var(--mainColor1); 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: 150px 150px; grid-gap: 10px; margin-top: 30px;}
.bloc_txt_img .container .multi_links .link				{ margin: 0; text-align: center; padding: 0;}

.bloc_txt_img .container .img_grid_3    		   		{ display: grid; grid-gap: 20px; grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; align-items: stretch;}
.bloc_txt_img .container .img_grid_3 .photo_1      		{ grid-row: span 2;}
.bloc_txt_img .container .img_grid_3 .photo_3      		{ text-align: center; background: var(--mainColor1); border-radius: var(--imgRadius); position: relative;}
.bloc_txt_img .container .img_grid_3 .photo_3:before    { position: absolute; left: 0; right: 0; top: 10%; bottom: 10%; background: url("../images/star.svg") 50% / contain no-repeat; filter: brightness(200); opacity: 10%; content: "";}
.bloc_txt_img .container .img_grid_3 .photo_3 p    		{ color: #fff; display: block; position: relative; top: 50%; transform: translateY(-50%); font-size: 24px; line-height: 140%;}
.bloc_txt_img .container .img_grid_3 .photo_3 span 		{ text-transform: uppercase; font-size: 30px; line-height: 120%; display: block; margin-bottom: 15px;}

.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;}

.bloc_txt_img .container .img_grid_3 .photo_3 img 		{  width: 150px; height: auto; display: block; margin: 10px auto 0 auto;}

@media (max-width:1200px) { 
.bloc_txt_img .container	                        	{ grid-gap: 0 60px;}
.bloc_txt_img .container .img_grid_3 .photo_3 span 		{ font-size: 25px;}
.bloc_txt_img .container .img_grid_3 .photo_3 p			{ font-size: 20px;}
}
@media (max-width:1000px) { 
.bloc_txt_img .container 								{ grid-template-columns: 1fr; grid-gap: 40px;}
.bloc_txt_img .container .txt .wrap						{ max-width: none;}
.bloc_txt_img .container img 							{ height: 60vh;}

.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;}

.bloc_txt_img .container .img.img_grid_3    		   { display: grid; grid-gap: 20px; grid-template-columns: 1fr; grid-template-rows: 1fr; align-items: stretch; }
.bloc_txt_img .container .img.img_grid_3 .photo_1      { display:none;}
.bloc_txt_img .container .img.img_grid_3 .photo_2      { grid-area: 1 / 2 / 2 / 1;  height: 60vh; width: 100%; object-fit: cover;}
.bloc_txt_img .container .img.img_grid_3 .photo_3      { grid-area: 2 / 1; padding: 30px 0; width: 70%; margin: 0 auto; }	
}
@media (max-width:700px) { 
.bloc_txt_img .container	                        	{ grid-gap: 30px;}
.bloc_txt_img .container p               				{ margin-bottom: 10px;}
.bloc_txt_img .container .multi_links					{ grid-template-columns: 1fr 1fr; grid-gap: 10px; margin-top: 20px;}
.bloc_txt_img .container .img.img_grid_3 .photo_3       { width: 100%;}	
.bloc_txt_img .container .img.img_grid_3 .photo_3 span  {font-size:25px}
.bloc_txt_img .container .img.img_grid_3 .photo_3 p     {font: 500 15px/27px "Montserrat"; padding:40px;}
}



/***** show hide *****/
.show_hide                        			{ position: relative; margin: 25px 0;}
.show_hide.no_marge                        	{ margin: 0;}
.show_hide .item                  			{ border: none; margin: 10px 0; overflow: hidden; border-radius: var(--linkRadius); background: var(--bgColorLight);}
.show_hide .titre                 			{ line-height: 24px; position: relative; cursor: pointer; padding: 20px 80px 22px 30px; margin: 0; font-size: 16px; font-weight: 500;}
.show_hide .hide                  			{ margin: 0; padding: 5px 30px 30px 30px; display: none;}
.show_hide .hide p  						{ margin-bottom: 10px;}
.show_hide .hide p a						{ color: var(--mainColor1);}
.show_hide .hide :last-child 	 			{ margin-bottom: 0;}

@media (min-width:1201px){
.show_hide .hide p a:hover     				{ color: var(--mainColor3);}
}
@media (max-width:1200px){
.show_hide .titre                 			{ padding: 20px 70px 20px 25px;}
.show_hide .hide                  			{ padding: 0 25px 30px 25px;}
}
@media (max-width:700px){
.show_hide                        			{ margin: 20px 0;}
.show_hide .titre                 			{ padding: 15px 65px 15px 20px; font-size: 14px; line-height: 22px;}
.show_hide .hide                  			{ padding: 0 20px 20px 20px;}
}

/* custom titre plus */
.show_hide .titre_plus:after          		{ width: 20px; height: 2px; position: absolute; right: 30px; top: 50%; transform: translateY(-50%); background: var(--mainColor2); transition: none; content: "";}
.show_hide .titre_plus:before          		{ width: 2px; height: 20px; position: absolute; right: 39px; top: 50%; transform: translateY(-50%); background: var(--mainColor2); transition: none; content: "";}
.show_hide .titre_plus.active:before   		{ display: none;}

@media (max-width:700px){
.show_hide .titre_plus:after          		{ right: 20px;}
.show_hide .titre_plus:before          		{ right: 29px;}
}











/***** cta tarifs*****/
.cta_bloc_tarifs                         	{ display: block; margin: 0; text-align: center; height: auto;}
.cta_bloc_tarifs:after 						{ width: 24px; height: 100%; background: url("../images/arrow_link.svg") 100% 50% no-repeat; position: absolute; right: 30px; top: 0; content: "";}
.cta_bloc_tarifs>span 						{ height: 90px; display: grid; align-items: center; position: relative; font-size: 18px; line-height: 140%;}
.cta_bloc_tarifs>span:after					{ width: 42px; height: 100%; background: url("../images/money.svg") 50% / contain no-repeat; position: absolute; left: 0; top: 0; content: "";}


@media (max-width: 700px){
.cta_bloc_tarifs                          {height: 60px;  display: block; color: #fff; }
.cta_bloc_tarifs>span 					{ height: 60px; display: grid; align-items: center; position: relative; font-size:15px; margin: 60px 0}
.cta_bloc_tarifs>span:after				{ width: 20px;}

}




/***** moving text *****/
.moving_text 								{ width: 100%; overflow: hidden; margin: var(--marginTB); margin-bottom: 0;}
.moving_text .row 							{ display: flex;}
.moving_text .row .item 					{ display: grid; grid-template-columns: 1fr 1fr 1fr; grid-gap: 5vw; white-space: nowrap; font: 700 clamp(30px, 5vw, 100px)/110% "Montserrat"; text-transform: uppercase; letter-spacing: 15px; color: #fff; padding-left: 5vw; animation: scroll_text 35s linear infinite;}

@keyframes scroll_text {
0%											{ transform: translate(-100%, 0);}
100% 										{ transform: translate(0%, 0); }
}
@media (max-width:1600px) {
.moving_text .row .item 					{ font-size: 130px;}
}
@media (max-width:1200px) {
.moving_text 								{ display: none;}
}





/***** moving img *****/
.moving_img									{ position: relative; overflow: hidden; margin: var(--marginTB); padding: 20px 0;}
.moving_img .row 							{ width: auto; display: flex;}
.moving_img .row .grid 						{ width: auto; display: flex; animation: moving_img 80s linear infinite;}
.moving_img .row .grid div 					{ padding: 0 10px;}
.moving_img .row .grid img 					{ width: auto; height: 500px; display: block; border-radius: var(--imgRadius); object-fit: cover; transition: all 300ms ease-in-out;}

@keyframes moving_img {
0%											{ transform: translate(0, 0);}
100% 										{ transform: translate(-100%, 0);}
}
@media (max-width:1600px) {
.moving_img .row .grid div 					{ padding: 0 15px;}
.moving_img .row .grid img 					{ height: 420px;}
}
@media (max-width:1400px) {
.moving_img .row .grid img 					{ height: 400px;}
}
@media (max-width:1200px) {
.moving_img									{ margin-top: 40px;}
.moving_img .row .grid div 					{ padding: 0 10px;}
.moving_img .row .grid img 					{ height: 380px;}
}
@media (max-width:1000px) {
.moving_img									{ margin-top: 0;}
.moving_img .row .grid img 					{ height: 350px;}
}
@media (max-width:700px) {
.moving_img .row .grid div 					{ padding: 0 7px;}
.moving_img .row .grid img 					{ height: 60vw; max-height: 350px;}
}









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

@media (max-width:700px) {
.bloc_rs a.facebook							{ display: none;}
}
@media (max-width:400px) {
	.bloc_rs a.scroll						{ width: 40px; height: 40px;}
}

/***** footer *****/
.footer										{ position: relative; line-height: 170%; font-size: clamp(14px, 2.2vw, 15px); background: var(--bgColorDark); color: #fff; padding-top: clamp(20px, 10vw, 100px);}
.footer .bloc_footer 						{ display: inline-block; vertical-align: top; position: relative;}
.footer .bloc_footer.heading_top 			{ display: block; margin-bottom: 5px;}
.footer .bloc_footer .sous_titre			{ text-transform: uppercase; font-weight: 700; letter-spacing: 1.6px; font-size: clamp(16px, 2.2vw, 24px); line-height: 120%;}
.footer .bloc_footer p						{ margin: clamp(15px, 2vw, 20px) 0 0 0;}
.footer .bloc_footer p a					{ color: #fff; display: inline-block;}
.footer .bloc_footer .icon 					{ padding-left: 30px; position: relative;}
.footer .bloc_footer .icon:after 			{ width: 18px; height: 100%; position: absolute; left: 0; top: 0; content: "";}
.footer .bloc_footer .tel a:after 			{ background: url("../images/tel_blue.svg") 50% / contain no-repeat;}
.footer .bloc_footer .email a:after 		{ background: url("../images/email_blue.svg") 50% / contain no-repeat;}
.footer .bloc_footer .opening 				{ margin-top: 10px;}
.footer ul.bloc_footer     					{ margin-left: clamp(20px, 8vw, 80px);}
.footer ul.bloc_footer li   				{ margin-top: 15px;}
.footer ul.bloc_footer li a 				{ color: #fff; display: inline-block; padding: 0 0 0 20px; background: url("../images/list.svg") 0 50% no-repeat;}
.footer .bloc_rs 							{ position: absolute; right: 0; top: 0;}
.footer_bottom   							{ padding: 20px 0; line-height: 0; margin: clamp(20px, 8vw, 80px) 0 0 0;}
.footer_bottom li 							{ display: inline-block; font-size: 12px; line-height: 20px; margin-right: 30px; letter-spacing: 0.8px; position: relative;}
.footer_bottom li:after						{ width: 1px; height: 10px; content: ""; position: absolute; right: -18px; top: 4px; background: var(--mainColor1);}
.footer_bottom li:last-child:after 			{ display: none;}
.footer_bottom li a							{ color: #fff;}
.footer .partner 							{ position: absolute; right: 150px; top: 0; text-align: center;}
.footer .partner img						{ display: block; width: 100px; height: auto; margin: 0 auto 8px auto;}
.toponweb									{ display: block; z-index: 85; position: absolute; right: 0; bottom: 20px; transition: bottom 300ms ease-in-out;}
.toponweb img								{ width: 80px; height: auto; display: block; margin: 0 auto; filter: invert(0); transition: all 300ms ease-in-out;}

@media (min-width:1201px) {
.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) {
.footer ul.bloc_footer     					{ display: none;}
}
@media (max-width:700px) {
.footer .bloc_footer 						{ text-align: center; margin-top: 4vw;}
.footer .bloc_footer.heading_top 			{ margin: 0;}
.footer .bloc_footer 						{ display: block;}
.footer .bloc_footer .icon 					{ padding-left: 0;}
.footer .bloc_footer .icon:after 			{ display: none;}
.footer .bloc_footer .address 				{ margin-bottom: 6vw;}
.footer .bloc_footer .tel a, 
.footer .bloc_footer .email a 				{ background: #fff; color: var(--mainColor2); display: block; height: 56px; line-height: 54px; font-weight: 700;}
.footer .partner 							{ position: relative; right: inherit;  margin-top: 30px;}
.footer .scroll 							{ margin-top: -8px;}
.footer_bottom 	 							{ text-align: center; margin: 0; padding: 10vw 0;}
.footer_bottom li 							{ display: block; margin: 0; font-size: 12px; line-height: 28px;}
.footer_bottom li:after						{ display: none;}
.toponweb									{ position: static;}
.toponweb span								{ height: auto; padding: 15px; background: #ffffff15;}
.toponweb img								{ width: 70px; filter: invert(0);}
}






