/***** fonts *****/

/* latin-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: italic;
  font-weight: 100 900;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/montserrat/v31/JTUQjIg1_i6t8kCHKm459WxRxy7mw9c.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: italic;
  font-weight: 100 900;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/montserrat/v31/JTUQjIg1_i6t8kCHKm459WxRyS7m.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: 'Montserrat';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/montserrat/v31/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/v31/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: #00537e;
    --mainColor2: #709dbe;
    --mainColor3: #d7e5ef85;
	--txtColor: #000;
	
	--bgColorLight: #d7e5ef85;
    --bgColorDark: #00537e;
	
	--marginTB: clamp(70px, 8vw, calc(120px + 2vw)) auto;
	--marginT: clamp(70px, 8vw, calc(120px + 2vw));
	--marginB: clamp(70px, 8vw, calc(120px + 2vw));
	--paddingTB: clamp(70px, 8vw, calc(120px + 2vw)) 0;

	--maxWidthWrapper: 1200px;
	--maxWidthWrapperSmall: 1000px;
	--maxWidthWrapperMedium: 1400px;
	--maxWidthWrapperLarge: 1800px;

	--imgRadius: 8px;
	--linkRadius: 5px;

}

@media (max-width:1000px) {
	:root {
		--marginTB: clamp(50px, 12vw, 70px) auto;
		--marginT: clamp(50px, 12vw, 70px);
		--marginB: clamp(50px, 12vw, 70px);
		--paddingTB: clamp(50px, 12vw, 70px);
	}
}
@media (max-width:700px) {
	:root {

	}
}


/***** reset *****/
/*html 									{ scroll-behavior: smooth;}*/
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: 500; font-size: clamp(14px, 1.3vw, 16px);}
p										{ margin-bottom: clamp(10px, 2vw, 15px);}
ul										{ list-style-type: none;}
body									{ font: 400 clamp(13px, 1.2vw, 15px)/180% "Montserrat"; letter-spacing: 0.6px; background: #fff; position: relative;}
body.active_overflow					{ height: 100vh; overflow: hidden;}
a										{ text-decoration: none; position: relative; color: var(--mainColor2);}
img										{ border: none;}
main 									{ position: relative; z-index: 10;}
#wrapper 								{ min-width: 320px; position: relative; overflow: hidden;}
#wrapper *								{ box-sizing: border-box;}
#footer 								{ position: relative; z-index: 1;}

@media (max-width:700px) {
body									{ line-height: 170%; letter-spacing: 0.4px;}
strong, b								{ font-weight: 600;}
}


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


/***** transition *****/
@media (min-width:1201px) {
.link, .slick-arrow, :before, :after, a, a span, .logo, .header, .sub, a.mybroker  { 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							{ width: 90vw; max-width: var(--maxWidthWrapperLarge); margin: 0 auto; position: relative;}

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

.color_1 								{ color: var(--mainColor1);}
.color_2 								{ color: var(--mainColor2);}
.color_3 								{ color: var(--mainColor3);}
.clear									{ clear: both; display: block;}
.anchor									{ position: absolute; left: 0; top: -140px;}

.titre_main	 							{ font: 700 clamp(35px, 3vw, 50px)/110% "Montserrat"; position: relative; margin-bottom: clamp(10px, 2vw, 15px); letter-spacing: 0.2px;}
.titre_main span					    { display: block; font: 500 clamp(20px, 1.6vw, 22px)/140% "Montserrat"; letter-spacing: 0.4px; margin: 10px 0;}
.sous_titre	 							{ font: 700 clamp(20px, 1.6vw, 22px)/140% "Montserrat"; letter-spacing: 0.4px; position: relative; margin-bottom: clamp(10px, 2vw, 15px); color: var(--mainColor2);}
.chapo		 							{ font: 400 clamp(14px, 1.2vw, 15px)/180% "Montserrat"; margin-bottom: clamp(10px, 2vw, 15px);}
.chapo span	 							{ display: block; margin-top: clamp(10px, 2vw, 15px);}
.link 									{ font: 700 12px/58px "Montserrat"; letter-spacing: 1.2px; height: 60px; text-transform: uppercase; display: inline-block; color: #fff; padding: 0 30px; border-radius: var(--linkRadius); background: var(--mainColor1); overflow: hidden;}

.read_more								{ display: inline-block; color: var(--mainColor1); font-style: normal; cursor: pointer; transition: color 300ms ease-in-out;}
.hide 									{ display: none;}

.ul_list								{ margin-bottom: clamp(10px, 2vw, 15px);}
.ul_list li								{ padding: 0 0 0 20px; position: relative; margin-top: clamp(5px, 1.5vw, 10px); background: url("../images/list.svg") 0 8px no-repeat;}

.ul_check   							{ margin: clamp(15px, 2vw, 20px) 0;}
.ul_check li 							{ position: relative; padding-left: 32px; line-height: 160%; margin-bottom: 12px;}
.ul_check li:before						{ width: 18px; height: 18px; position: absolute; left: 0; top: 2px; background: url("../images/check.svg") 0 0 / contain no-repeat; content: "";}
.ul_check li:last-child					{ margin-bottom: 0;}


@media (min-width:1201px) {
.link:hover 							{ background-color:var(--mainColor2);}
.link_txt:hover							{ border-color: #fff; color: #fff;}
}
@media (max-width:1000px) {
.titre_main	 							{ font-size: clamp(22px, 4.6vw, 35px); line-height: 120%;}
.titre_main span					    { font-size: clamp(16px, 3vw, 20px); margin: 5px 0;}

.sous_titre	 							{ font-size: clamp(16px, 3vw, 22px); font-weight: 600;}
}
@media (max-width:700px) {
.link 									{ font-size: 11px; line-height: 48px; padding: 0 25px; height: 50px;}
}




/***** header et menu *****/
.header 									{ width: 100%; position: fixed; left: 0; top: 0; z-index: 950; background: #fff; transition: top 300ms ease-in-out;}
.header ::-webkit-scrollbar					{ display: none;}
.header .wrapper_large						{ display: grid; grid-template-columns: auto 1fr; grid-gap: 3vw; align-items: center;}
.header .logo								{ width: 200px; height: 90px; overflow: hidden; margin-top: 30px;}
.header .logo img							{ width: 100%; height: auto; position: absolute; left: 0; bottom: 0;}
.header .header_nav 						{ display: block; align-items: center;}
.header .menu 								{ text-align: right;}


.header .menu>li							{ display: inline-block; vertical-align: middle; margin-right: 35px; color: var(--mainColor1)}
.header .menu>li:last-child					{ margin-right: 0;}
.header .menu>li>span,
.header .menu>li>a 							{ font: 500 17px/78px "Montserrat"; height: 80px; letter-spacing: 0.6px; color: var(--mainColor1); display: block; transition: all 300ms ease-in-out;}
.header .menu>li>span 						{ position: relative; cursor: default;}
.header .menu>li.active>a, 
.header .menu>li.active>span				{ color: var(--mainColor2);}
.header .menu>li:has(.sub)					{ z-index: 5;}
.header .menu>li:has(.sub)>a				{ z-index: 800;}

.header .menu_small>li  					{ position: relative;}
.header .menu_small>li a					{ font-size: 12px; line-height: 40px; height: 40px; display: block; letter-spacing: 0.6px;}
.header .menu_small>li a.link				{ display: block; height: 40px; line-height: 38px; color: #fff; border-radius: 0 0 5px 5px}
.header .menu_small>li:after                { width: 1px; height: 9px; background: var(--mainColor1); position: absolute; left: -22px; top: 15px; content: "";}
.header .menu_small>li:first-child:after,
.header .menu_small>li:last-child:after 	{ display: none;}


.header .sub								{ width: 100%; position: absolute; top: 85%; right: 0; background: #fff; box-shadow: 0 50vh 0 200vh rgba(0, 0, 0, 30%); text-align: left; border-radius: var(--imgRadius);}
.header .sub .container						{ display: grid; grid-template-columns: repeat(6, auto); grid-gap: 20px 40px; padding: clamp(30px, 2.8vw, 60px);}
.header .sub .item     						{ margin: 0;}
.header .sub ul      						{ margin: 0;}
.header .sub ul a 							{ font-size: 14px; line-height: 20px; padding: 8px 0; letter-spacing: 0.4px; display: block; color: var(--mainColor2);}
.header .sub ul .head					    { font-size: 15px; line-height: 20px; padding: 8px 0; font-weight: 700; letter-spacing: 0.4px; color: var(--mainColor1); margin-bottom: 5px;}
.header .sub ul li.active a 				{ color: var(--mainColor1);}

.header .sub_pro .container					{ grid-template-columns: repeat(5, auto); padding-right: 0;}
.header .sub_pro .last						{ background: var(--bgColorLight); padding: clamp(30px, 2.8vw, 60px); margin: clamp(-60px, -2.8vw, -30px) 0;}
.header .sub_pro .last li:first-child		{ margin-bottom: 20px; padding-bottom: 20px; border-bottom: 1px solid var(--mainColor3);}


@media (min-width:1201px) {
.menu_mobile, 
.header .close_sub 							{ display: none;}
.header .sub 								{ visibility: hidden; opacity: 0;}

.header .menu>li:hover .sub					{ visibility: visible; opacity: 1;}		
.header .menu>li:hover 						{ z-index: 999;}		
.header .menu>li:hover>span					{ color: #fff; z-index: 999;}
.header .menu>li:hover>a:not(.link)			{ color: var(--mainColor2);}
.header .sub ul li					    { color: var(--mainColor1); background: linear-gradient(to right, var(--mainColor3) 0% 50%, transparent 50% 100%); background-size: 200% 100%; background-position: 100% 0; padding-left: 10px; transition: 300ms ease-in-out; border-radius: var(--linkRadius)}
.header .sub ul li:hover					{ background-position: 0 0; padding-left: 10px; width: calc(100% - 10px); transition: 300ms ease-in-out;}

	
.sticky .header   							{ box-shadow: rgba(112,157,190,25%) 0 0 60px 0;}
.sticky .header .logo 						{ width: 160px; margin-top: -15px;}
.sticky .header .menu>li>span,
.sticky .header .menu:not(.menu_small)>li>a { line-height: 68px; height: 70px;}
.sticky .header .sub						{ top: 90%;}

.sticky:not(.scrolling_top) .header .logo 	{ width: 200px; height: 16px; margin-top: 38px;}
.sticky:not(.scrolling_top) .header 		{ top: -40px;}
.sticky:not(.scrolling_top) .header .logo 	{ height: 16px; margin-top: 38px;}
}

@media (max-width:1400px) {
.header .sub .container						{ grid-template-columns: repeat(3, auto);}
.header .sub ul a 							{ padding: 5px 0;}
.header .sub ul .head					    { padding: 5px 0;}
.header .sub_pro .container					{ grid-template-columns: repeat(3, auto); grid-template-areas: ". . last" ". . last"; }
.header .sub_pro .last						{ grid-area: last;}
}
@media (max-width:1200px) {
.header .menu_mobile						{ width: 50px; height: 50px; background: var(--mainColor1); border-radius: var(--linkRadius); display: inline-block; vertical-align: middle; cursor: pointer; position: relative; z-index: 850;}
.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: 22px;}
.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;}
.header ::-webkit-scrollbar					{ display: none;}
.header .logo								{ width: 156px; height: 70px; margin: 0; z-index: 900;}
.header .wrapper_large						{ grid-template-columns: 1fr auto;}

.header .header_nav 						{ width: 100%; position: fixed; right: -120%; top: 0; bottom: 0; overflow-y: scroll; z-index: 800; padding: 0; border-top: 140px solid #fff; background: #fff; /*background: #eeeeee95; backdrop-filter: blur(15px);*/ display: grid; grid-template-rows: auto 1fr; grid-gap: 4vw; align-items: stretch; transition: right 300ms ease-in-out 450ms;}
.header .menu  								{ display: block; width: auto; text-align: left; position: static; z-index: 100; background: #fff; padding: 0 8vw; align-self: center; opacity: 0; transition: opacity 300ms ease-in-out 0ms;}
.header .menu>li 							{ width: 100%; display: block; margin: 0;}
.header .menu>li>span,
.header .menu>li>a							{ font-size: 20px; line-height: 50px; height: auto; font-weight: 700; letter-spacing: 0.4px; color: #000; transition: none; display: inline-block; z-index: 10;}
.header .menu>li>span 						{ position: static;}
.header .menu>li>i							{ width: 100%; height: 50px; display: block; margin-top: -50px; position: relative; z-index: 5; float: right;}
.header .menu>li>i:after					{ width: 50px; height: 36px; background: url("../images/arrow_link.svg") 50% 52% no-repeat var(--bgColorLight); background-size: 8px auto; position: absolute; right: 0; top: 7px; border-radius: var(--linkRadius); content: "";}

.header .menu_small  						{ grid-area: 2; background: var(--bgColorLight); padding: 5vw 8vw; align-self: stretch;}
.header .menu_small>li  					{ position: relative;}
.header .menu_small>li a					{ font-size: 14px; line-height: 36px; height: 36px; letter-spacing: 0.6px; font-weight: 600;}
.header .menu_small>li a.link				{ text-align: center; letter-spacing: 2px; font-size: 12px; font-weight: 500; border-radius: var(--linkRadius); margin-top: clamp(20px, 4vw, 30px);}
.header .menu_small>li:after                { display: none;}

.header .sub								{ position: fixed; top: 0; bottom: 0; right: -100%; z-index: 200; background: #fff; border-radius: 0; border-top: 180px solid #fff; overflow-y: scroll; transition: right 300ms ease-in-out 200ms; box-shadow: none;}
.header .sub .container						{ grid-template-columns: repeat(3, auto); grid-gap: 20px; padding: 4vw 8vw; opacity: 0; transition: opacity 300ms ease-in-out 0ms;}
.header .sub_pro .container					{ grid-template-columns: repeat(3, auto); grid-template-areas: inherit; }
.header .sub_pro .last						{ margin-bottom: 0; grid-area: auto; grid-column: span 2;}

.header .close_sub 							{ display: block; position: fixed; left: 5vw; top: 130px; height: 25px; line-height: 25px; font-size: 10px; font-weight: 600; text-transform: uppercase; padding: 0 12px 0 22px; background: var(--bgColorLight); border-radius: 5px; visibility: hidden; opacity: 0; transition: all 300ms ease-in-out 50ms;}
.header .close_sub:after					{ width: 9px; height: 9px; background: url("../images/arrow_link.svg") 50% / contain no-repeat; transform: rotate(180deg); position: absolute; left: 8px; top: 8px; content: "";}

.header.active .header_nav 					{ right: 0; transition-delay: 150ms;}
.header.active .menu 						{ opacity: 1; transition-delay: 450ms;}
.header .sub.active 						{ right: 0; transition-delay: 150ms;}
.header .sub.active .container 				{ opacity: 1; transition-delay: 300ms;}
.header .sub.active .close_sub 				{ visibility: visible; opacity: 1; transition-delay: 300ms;}
}
@media (max-width:1000px) {
.header .header_nav							{ border-width: 150px;}
.header .sub								{ border-width: 170px;}
.header .sub .container						{ grid-template-columns: repeat(2, auto);}
.header .sub_pro .last						{ margin: 4vw -8vw -4vw -8vw; padding: 8vw;}
}
@media (max-width:700px) {
.header .logo								{ width: 132px; height: 60px;}
.header .header_nav 						{ border-width: 120px;}
.header .menu>li>span,
.header .menu>li>a							{ font-size: 18px; line-height: 46px;}
.header .menu>li>i							{ height: 46px; margin-top: -46px;}
.header .menu>li>i:after					{ width: 46px; height: 34px; top: 6px;}
.header .menu_small>li a					{ font-size: 13px; line-height: 34px; height: 34px;}
.header .sub								{ border-width: 150px;}
.header .sub .container						{ grid-template-columns: 1fr;}
.header .sub_pro .last						{ grid-column: auto;}
.header .sub ul a 							{ font-size: 13px; padding: 5px 0;}
.header .sub ul .head					    { font-size: 14px; padding: 5px 0; margin-bottom: 2px;}
.header .close_sub 							{ top: 110px;}
}



.grid_links                                 { display: grid; grid-template-columns: 1fr 1fr; grid-gap: 10px; padding-top: 5px; text-align: center}

@media (max-width:500px) {
.grid_links                                 { grid-template-columns: 1fr;}
}


/***** side btn fixed *****/
.side_btn 								{ position: fixed; right: 0; top: 50%; transform: translateY(-50%); z-index: 960; display: grid; grid-gap: 10px;}
.side_btn a								{ display: block; width: 54px; height: 54px; line-height: 54px; position: relative; transition-duration: 0ms; transition-delay: 300ms;}
.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.tel:after					{ height: 20px; background-image: url("../images/tel.svg");}
.side_btn a.gsm:after					{ height: 24px; background-image: url("../images/gsm.svg");}
.side_btn a.map:after					{ height: 22px; background-image: url("../images/map.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.instagram:after				{ height: 22px; background-image: url("../images/instagram.svg");}
.side_btn a	span						{ display: block; width: 54px; height: 54px; position: absolute; top: 0; right: 0; background: var(--mainColor1); border-radius: 5px 0 0 5px}
.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);  opacity: 0; transition: 100ms all 0ms; border-radius: 5px 0 0 5px}

@media (min-width:1201px) {
.side_btn a:hover  						{ background: var(--mainColor1); transition-delay: 0ms;}
.side_btn a:hover span					{ width: 160px; right: 50%;}
.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 								{ right: calc(8vw + 50px); top: 25px; transform: none; grid-template-columns: repeat(4, 50px);}
.side_btn a								{ width: 50px; height: 50px; background: var(--mainColor1); border-radius: var(--linkRadius);}
.side_btn a:after						{ width: 50px;}
.side_btn a	span						{ display: none;}
}
@media (max-width:700px) {
.side_btn 								{ display: block; top: 20px;}
.side_btn a.map,
.side_btn a.email,
.side_btn a.facebook 					{ display: none;}
}



/***** bloc txt img *****/
.bloc_txt_img 											{ position: relative; margin: var(--marginTB);}
.bloc_txt_img .container	                        	{ display: grid; grid-template-columns: 50% 1fr; grid-gap: 0 80px; align-items: center; position: relative;}
.bloc_txt_img .container p a                        	{ border-bottom: 1px solid #555;}
.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 img 						{ width: 100%; height: auto; object-fit: cover; display: block; position: relative; z-index: 10; border-radius: var(--imgRadius);}
.bloc_txt_img .container .img:after                     { width: 100vw; height: 100%; background: var(--mainColor3); display: block; transform: skew(-10deg); position: absolute; right: 25%; top: 50px; z-index: -1; border-radius:var(--imgRadius); content: "";}

.bloc_txt_img .container .link							{ margin-top: 10px;}
.bloc_txt_img .container .img.col_2  					{ display: grid; grid-template-columns: 1fr 1fr; grid-gap: 60px; padding-top: 100px;}
.bloc_txt_img .container .img.col_2 img:first-child		{ transform: translateY(-100px);}

.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.reverse .img:after						{ transform: skew(-10deg); right: auto; left: 25%;}

.bloc_txt_img.align_top .container                		{ align-items: start;}

@media (max-width:1400px) { 
.bloc_txt_img .container .img:after                     { top: 40px;}
.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 (min-width:1201px) { 
.bloc_txt_img .container p a:hover                     	{ color: var(--mainColor1); border-bottom: 1px solid #555;}
}
@media (max-width:1200px) { 
.bloc_txt_img .container	                        	{ grid-gap: 0 5vw;}
.bloc_txt_img .container .img:after                     { top: -5vw; bottom: -5vw; height: auto;}

.bloc_txt_img .container .img.col_2  					{ grid-gap: 20px; padding-top: 5vw;}
.bloc_txt_img .container .img.col_2 img:first-child		{ transform: translateY(-5vw);}
}
@media (max-width:1000px) { 
.bloc_txt_img  											{ padding-top: 4vw;}	                        	
.bloc_txt_img .container,	                        	
.bloc_txt_img.reverse .container 						{ grid-template-columns: 1fr; grid-gap: 8vw;}
.bloc_txt_img .container .txt .wrap						{ max-width: none;}
.bloc_txt_img.reverse .container>.item:last-child,
.bloc_txt_img.reverse .container>.item:first-child      { grid-area: auto;}
}
@media (max-width:700px) { 
.bloc_txt_img .container	                        	{ grid-gap: 0 14vw;}
.bloc_txt_img .container .img:after                     { top: -8vw; bottom: -8vw;}
.bloc_txt_img  											{ padding-top: 6vw;}	                        	
.bloc_txt_img .container,	                        	
.bloc_txt_img.reverse .container 						{ grid-gap: 14vw;}
.bloc_txt_img .container .img.col_2  					{ grid-gap: 3vw; padding-top: 7vw;}
.bloc_txt_img .container .img.col_2 img:first-child		{ transform: translateY(-7vw);}
}


.bloc_txt_simple										{ position: relative; margin: 100px 0}
.bloc_txt_simple .container	                        	{ position: relative;}



/***** secteurs *****/
.secteurs											{ position: relative; margin: 80px 0;}
.secteurs .container	                        	{ display: grid; grid-template-columns: 10% 1fr; grid-gap: 0 80px; align-items: center; position: relative;}
.secteurs .container p a                        	{ border-bottom: 1px solid #555;}
.secteurs .container>.item.img						{ position: relative; background: var(--bgColorLight); border-radius: var(--imgRadius); width: 140px }
.secteurs .container .img img 						{ width: 50px; height: auto; display: block; position: relative; z-index: 10; margin: 50px auto }




/***** show hide *****/
.show_hide                        			{ position: relative; margin: var(--marginTB);}
.show_hide.no_marge                        	{ margin: 0;}
.show_hide .item                  			{ background-color: var(--mainColor3); margin: 10px 0; border-radius:var(--linkRadius)}
.show_hide .titre                 			{ font-size: 16px; line-height: 24px; font-weight: 600; position: relative; cursor: pointer; color: var(--mainColor1); letter-spacing: 0.2px; padding: 23px 80px 23px 30px; margin: 0;}
.show_hide .hide                  			{ margin: 0; padding: 0 30px 30px 30px; display: none;}
.show_hide .hide p a						{ color: var(--mainColor2); }
.show_hide .hide :last-child 	 			{ margin-bottom: 0;}

@media (min-width:1201px){
.show_hide .hide p a:hover     				{ color: var(--mainColor2);}
}
@media (max-width:1200px){
.show_hide .titre                 			{ padding: 20px 70px 20px 25px;}
.show_hide .hide                  			{ padding: 0 25px 25px 25px;}
}
@media (max-width:700px){
.show_hide                        			{ margin: 15px 0;}
.show_hide .titre                 			{ padding: 15px 60px 15px 20px; font-size: 14px; line-height: 20px; font-weight: 500;}
.show_hide .hide                  			{ padding: 0 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; }
.show_hide.collapse .item:last-child       	{ border: 0;}

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

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



/***** CTA *****/
.cta_bloc  								{ position: relative;}
.cta_bloc .container 					{ position: relative; display: grid; grid-template-columns: 45% 1fr; align-items: center; border-radius: var(--linkRadius); overflow: hidden; text-align: center;  background:var(--bgColorLight)}
.cta_bloc .titre_main				    { background: var(--bgColorDark); color:#fff ; padding: 45px 30px; position: relative; z-index: 5; margin-bottom: 0; font-size: 20px;}
.cta_bloc .titre_main:before 			{ position: absolute; right: -7px; top: 50%; background:var(--bgColorDark); width: 14px; height: 14px; transform: translateY(-50%) rotate(-45deg); transition: none; content: "";}
.cta_bloc .row     						{ position: relative; overflow: hidden; padding: 20px 30px;}
.cta_bloc .row .link   					{ text-align: left; padding: 0 30px 0 56px; color: var(--bgColorDark); display: block; letter-spacing: 0.6px;}
.cta_bloc .row .tel   					{ display: inline-block; vertical-align: middle;}
.cta_bloc .row .tel a 					{ background: url("../images/tel_blue.svg") 28px 50% no-repeat #fff;}
.cta_bloc .row .form   					{ display: inline-block; vertical-align: middle; margin-left: 5px;}
.cta_bloc .row .form a					{ background: url("../images/email_blue.svg") 22px 50% no-repeat #fff;}

@media (min-width: 1201px){
.cta_bloc .row .link:hover 				{ color: var(--orange);}
}
@media (max-width: 1200px){
.cta_bloc 								{ grid-template-columns: auto 1fr;}
}
@media (max-width: 1000px){
.cta_bloc 								{ grid-template-columns: 1fr;}
.cta_bloc .titre							{ padding: 30px;}
.cta_bloc .titre:before					{ right: 50%; margin: 0 7px 0 0; top: auto; bottom: -7px;}
}
@media (max-width: 700px){
.cta_bloc 								{ border-radius: 0; text-align: left; margin: 0; padding: 0; border-radius: 0; background: none;}
.cta_bloc .sous_titre                   { background: none; padding: 0; margin-bottom: 10px;}
.cta_bloc .titre						{ color: var(--white); font-size: 16px; letter-spacing: 1.4px; font-weight: 700; text-transform: uppercase; padding: 0; background: none; margin: -5px 0 15px 0;}
.cta_bloc .titre:before					{ display: none;}
.cta_bloc .titre span					{ color: var(--white);}
.cta_bloc .row     						{ padding: 40px 6vw; background: var(--main-color); border-radius: 5px;}
.cta_bloc .row:before					{ display: none;}
.cta_bloc .row .link   					{ display: block; text-align: center; padding: 0 20px;}
.cta_bloc .row .tel   					{ display: block;}
.cta_bloc .row .tel a 					{ background-image: none;}
.cta_bloc .row .form   					{ display: block; margin: 10px 0 0 0;}
.cta_bloc .row .form a 					{ background-image: none;}
}
@media (max-width: 600px){
.cta_bloc .titre_main { text-align: left; padding: 20px;}	
}




.anchor {
    position: absolute;
    top: -120px;
}


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

@media (min-width:1201px){
.bloc_rs a:hover							{ background: var(--mainColor2);}
}
@media (max-width:700px) {
.bloc_rs a									{ width: 50px; height: 50px;}
}


/***** footer *****/
.footer										{ position: relative; color: #fff; padding-top: clamp(20px, 10vw, 120px);}
.footer:before                              { background: linear-gradient(-60deg,rgba(0, 83, 126, 1) 0%, rgba(0, 56, 81, 1) 100%); position: absolute; left: 0; top: 0; bottom: 0; right: 0; z-index: -20; content: "";}
.footer .bloc_footer 						{ display: grid; grid-template-columns: auto auto 1fr; grid-gap: clamp(30px, 5vw, 80px);}
.footer .bloc_footer .logo 					{ width: auto; height: 80px; display: block; margin-bottom: clamp(25px, 4vw, 40px);}
.footer .bloc_footer .sous_titre			{ font-weight: 600;}
.footer .bloc_footer p						{ margin: 15px 0 0 0;}
.footer .bloc_footer p br					{ display: none;}
.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 .address:after 		{ background: url(../images/map.svg) 0 50% no-repeat;}
.footer .bloc_footer .tel a:after 			{ background: url(../images/tel.svg) 0 50% no-repeat;}
.footer .bloc_footer .email a:after 		{ background: url(../images/email.svg) 0 50% no-repeat;}
.footer .bloc_rs .scroll 					{ position: absolute; right: 0; top: 0;}
.footer_bottom   							{ padding: 20px 0; line-height: 0; margin: clamp(40px, 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: -15px; top: 4px; background: var(--mainColor2);}
.footer_bottom li:last-child:after 			{ display: none;}
.footer_bottom li a							{ color: #fff;}

.toponweb									{ display: block; z-index: 85; position: absolute; right: clamp(10px, 5vw, 30px); bottom: 20px; transition: bottom 300ms ease-in-out;}
.toponweb img								{ width: 70px; 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(--mainColor2);}
}
@media (max-width:1200px) {
.footer .bloc_footer.heading_float 			{ margin-right: 80px;}
.footer ul.bloc_footer     					{ display: none;}
}
@media (max-width:700px) {
.footer										{ padding-top: 12vw;}
.footer .bloc_footer 						{ grid-template-columns: 1fr; grid-gap: 10vw;}
.footer .bloc_footer .logo 					{ height: 70px;}
.footer .bloc_footer p br					{ display: block;}
.footer	.bloc_rs .scroll					{ position: absolute; right: 0; top: -10px;}
.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;}
}