@font-face {
	font-family: 'Archivo';
	src: url('/fonts/Archivo/Archivo-VariableFont_wdth,wght.ttf') format('truetype');
	font-weight: 100 900;
	font-stretch: 75% 125%;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: 'Archivo';
	src: url('/fonts/Archivo/Archivo-Italic-VariableFont_wdth,wght.ttf') format('truetype');
	font-weight: 100 900;
	font-stretch: 75% 125%;
	font-style: italic;
	font-display: swap;
}

@font-face {
	font-family: 'Inter';
	src: url('/fonts/Inter/Inter-VariableFont_opsz,wght.ttf') format('truetype');
	font-weight: 100 900;
	font-stretch: 75% 125%;
	font-style: normal;
	font-display: swap;
}
@font-face {
	font-family: 'Inter';
	src: url('/fonts/Inter/Inter-Italic-VariableFont_opsz,wght.ttf') format('truetype');
	font-weight: 100 900;
	font-stretch: 75% 125%;
	font-style: italic;
	font-display: swap;
}

body
{
	position:relative;
	margin:0;
	padding:0;
	font-family: Inter;
    font-size: 18px;
	font-weight: 300;
	line-height: 1.6;
	color:#000000;
	background:#ffffff;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

h1{
	position:relative;
	display: block;
	margin:60px 0 60px 0;
	padding:0;
	font-family: Archivo;
	font-size:60px;
	font-weight: 600;
	line-height: 1.0625;
	color:#000000;
}
@media screen and (min-width: 640px){
	h1{
		font-size:80px;
	}
}

h2{
	position:relative;
	display: block;
	margin:30px 0 30px 0;
	padding:0;
	font-family: Archivo;
	font-size:45px;
	font-weight: 600;
	line-height: 1.25;
	color:#000000;
}
@media screen and (min-width: 640px) {
	h2{
		font-size:55px;
	}
}

a{
	text-decoration: underline;
	color:#D82738;
}

p{
	position:relative;
	display: block;
	margin:20px 0 20px 0;
	padding:0;
}

.resume{
	margin:20px 0 55px 0;
	font-family: Archivo;
	font-size:25px;
	font-weight: bold;
	line-height: 1.4;
	color:#D82738;
}

.holder
{
	position: relative;
	display:block;
	padding:60px 0 60px 0;
}
.home .holder{
	padding:60px 0 60px 0;
}
@media screen and (min-width: 640px) {
	.home .holder{
		padding:180px 0 180px 0;
	}
}

.mainctn
{
	position:relative;
	max-width:1568px;
	margin:0 auto 0 auto;
	padding:0 20px 0 20px;

}

#topCtn{
	padding:0;
}
#topCtn .sliderctn{
	position:relative;
	inset:0;
	max-width:1920px;
	margin:0 auto 0 auto;
	z-index:1;
}
#topCtn .sliderctn:before{
	content:"";
	display: block;
	padding-top: 25%;
}
.home #topCtn .sliderctn:before{
	padding-top: 100%;
}
@media screen and (min-width: 640px){
	.home #topCtn .sliderctn:before{
		padding-top: 47.1875%;
	}
}

#topCtn .sliderctn .slider-element{
	position: absolute;
	display:none;
	inset:0;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
}
#topCtn .sliderctn .slider-element.current{
	display:block;
	opacity:1!important; /*pour éviter de voir le fond pendant animation*/
}

#topCtn .sloganctn{
	position: absolute;
	bottom: 11.2%;
	left: 0;
	width: 100%;
	z-index:2;
}
#topCtn .sloganctn h1{
	margin:0;
	color:#ffffff;
	font-size:30px;
}
@media screen and (min-width: 480px){
	#topCtn .sloganctn h1{
		font-size:40px;
	}
}
@media screen and (min-width: 640px){
	#topCtn .sloganctn h1{
		font-size:50px;
	}
}
@media screen and (min-width: 1024px){
	#topCtn .sloganctn h1{
		font-size:60px;
	}
}
@media screen and (min-width: 1200px){
	#topCtn .sloganctn h1{
		font-size:80px;
	}
}

#topCtn .menuctn{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	z-index:2;
}

#topCtn .menuctn .mainctn{
	display:flex;
	gap:60px;
	justify-content: flex-end;
	align-items: center;
}

#topCtn .menuctn .mainctn .logo{
	position:relative;
	display: block;
	width: 18.12%;
	max-width:284px;
	min-width:200px;
	background: url(/images/meroba-vs.jpg) no-repeat center center;
	background-size: contain;
	margin-right: auto; /* align a gauche le logo dans le flex*/
}
#topCtn .menuctn .mainctn .logo:before{
	content:"";
	display: block;
	padding-top: 52.465%;
}

#topCtn .menuctn .mainctn.desktop{
	position:fixed;
	box-sizing: border-box;
	top:0;left:0;right:0;
	overflow:hidden;
	height:0;
	background: #000000;
	z-index:2;
	justify-content: space-between;
	align-items: flex-start;
	overflow: scroll;
}
#topCtn .menuctn .mainctn.desktop .logo{
	display: none;
}

@media screen and (min-width:1024px){
	#topCtn .menuctn .mainctn.desktop{
		position:relative;
		top:auto;left:auto;right:auto;
		display: flex;
		height:auto;
		background: none;
		z-index:auto;
		justify-content: flex-start;
		align-items: center;
		overflow: visible	;
	}
	#topCtn .menuctn .mainctn.desktop .logo{
		display: block;
	}

	#topCtn .menuctn .mainctn.mobile{
		display: none;
	}
}

#topCtn .menuctn .mainctn .menuicon, #topCtn .menuctn .mainctn .menuclose{
	position:relative;
	text-decoration: none;
	width: 40px;
	height:40px;
}
#topCtn .menuctn .mainctn .menuicon span, #topCtn .menuctn .mainctn .menuicon:before, #topCtn .menuctn .mainctn .menuicon:after,
#topCtn .menuctn .mainctn .menuclose:before, #topCtn .menuctn .mainctn .menuclose:after{
	content: "";
	position: absolute;
	display: block;
	width: 100%;
	height: 4px;
	border-radius: 2px;
	background-color:#ffffff;
	top:4px;
	left:0;
}
#topCtn .menuctn .mainctn .menuicon:before{
	top:auto; bottom:4px;
}
#topCtn .menuctn .mainctn .menuicon:after{
	top:50%;
	transform: translateY(-50%);
}

#topCtn .menuctn .mainctn .menuclose{
	position:absolute;
	top:20px;right:20px;
}
#topCtn .menuctn .mainctn .menuclose:before{
	top:50%;
	transform: translateY(-50%) rotate(45deg);
	transform-origin: center center;
}
#topCtn .menuctn .mainctn .menuclose:after{
	top:50%;
	transform: translateY(-50%) rotate(-45deg);
	transform-origin: center center;
}

#topCtn .menuctn .mainctn .menu{
	position:relative;
	display: flex;
	flex-direction: column;
	width: 60%;
	gap: 40px;
}
@media screen and (min-width:1024px){
	#topCtn .menuctn .mainctn .menuclose{
		display:none;
	}
	#topCtn .menuctn .mainctn .menu{
		flex-direction: row;
		width: auto;
		gap: 60px;
	}
}

#topCtn .menuctn .mainctn .menu a{
	position:relative;
	font-family: Archivo;
	font-size: 20px;
	font-weight: 600;
	color:#ffffff;
	text-decoration: none;
}

#topCtn .menuctn .mainctn .lang{
	position:relative;
	display: block;
	width: 64px;
	height:33px;
	border-radius: 20px;
	background:#ffffff;
	text-decoration: none;
}
#topCtn .menuctn .mainctn .lang:before{
	content: "";
	position: absolute;
	right:5px;
	top:50%;
	transform: translateY(-50%);
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background-color:#414141;
}
#topCtn .menuctn .mainctn .lang span{
	position: absolute;
	text-transform: uppercase;
	left:10px;
	top:50%;
	transform: translateY(-50%);
	font-family: Archivo;
	font-size: 14px;
	font-weight: normal;
	line-height: 1;
	color:#414141;
}
.de #topCtn .menuctn .mainctn .lang:before{
	right:auto;
	left:5px;
}
.de #topCtn .menuctn .mainctn .lang span{
	left:auto;
	right:10px
}

#missionCtn{
	background: #F7F7FA;
}

.txt_img{
	position: relative;
	display: flex;
	flex-wrap: wrap;
	gap:0;
	box-sizing: border-box;
	margin-bottom:60px;

}
.txt_img:last-child{
	margin-bottom:0;
}
.txt_img .txt{
	box-sizing: border-box;
	width:100%;
	background:#ffffff;
	margin:0;
	padding: 20px 20px 20px 20px;
	box-shadow: 11px 22px 33px rgba(0, 0, 0, 0.16);
	z-index: 2;
}
.txt_img .txt h2{
	margin-top:0;
}
.txt_img .txt p:last-child{
	margin-bottom:0;
}

.txt_img .img{
	position:relative;
	display:block;
}
.txt_img .img img{
	display:block;
	width: 100%;
	height: calc(50% - 3px);
	object-fit: cover;
	object-position: center center;
	box-shadow: 11px 22px 33px rgba(0, 0, 0, 0.16);
}
.txt_img .img img + img{
	margin-top:6px;
}
.txt_img .img img:first-child:last-child{
	height:100%;
}
.txt_img .img img[src="/images/mission-1.jpg"]{
	object-position: center top;
}

.txt_img:nth-child(even){
	flex-direction: row-reverse;
}

@media screen and (min-width: 900px){
	.txt_img{
		flex-wrap: nowrap;
		margin-bottom:180px;
	}
	.txt_img .txt{
		width:80%;
		margin:4.5% 0 4.5% 0;
		padding: 40px 44px 40px 44px;
	}

	.txt_img .img{
		position:absolute;
		left:60%;
		right:0;
		top:0;
		bottom:0;
		max-width: 948px;
		z-index: 1;
	}
	.txt_img:nth-child(even) .img{
		left:0;
		right:60%;
	}
	.txt_img .img img{
		transform: rotateY(180deg);
	}
}

@media screen and (min-width: 1200px){
	.txt_img .txt{
		width:52.68%;
		padding: 80px 88px 80px 88px;
	}
	.txt_img .img{
		left:39.54%;
	}
	.txt_img:nth-child(even) .img{
		left:0;
		right:39.54%;
	}
	.txt_img .img img{
		transform: none;
	}
}

.aboutctn{
	display: flex;
	flex-direction: column;
	gap:40px;
	justify-content: space-between;
	align-items: center;
}

@media screen and (min-width: 960px){
	.aboutctn{
		flex-direction: row;
	}
	.aboutctn .abouttxt{
		width: 60%;
	}
	.aboutctn .aboutinfos{
		width: 50%;
	}
}
@media screen and (min-width: 1600px){
	.aboutctn{
		gap:0;
	}
	.aboutctn .abouttxt{
		width: 40.625%;
	}
	.aboutctn .aboutinfos{
		width: 35.9%;
	}
}

.aboutctn .aboutinfos{
	display: flex;
	flex-wrap: wrap;
	gap:6px;
}
.aboutctn .aboutinfos .i_infos{
	width: 100%;
	box-sizing: border-box;
	padding:24px;
	border-radius: 10px;
}

.aboutctn .aboutinfos .i_infos .num{
	display:inline-block;
	margin-left:-24px;
	margin-bottom:20px;
	padding:5px 20px 5px 20px;
	font-family:Archivo;
	font-size:16px;
	font-weight: bold;
	line-height:1.5;
}
.aboutctn .aboutinfos .i_infos .title{
	font-family: Archivo;
	font-size:19px;
	font-weight: bold;
	line-height: 1.26;
	margin-bottom:20px;
}
.aboutctn .aboutinfos .i_infos ul{
	list-style: none;
	padding:0;
	margin:0;
	font-size: 14px;
	font-weight: 300;
	line-height: 1.4;
}
.aboutctn .aboutinfos .i_infos ul li{
	position: relative;
	padding-left:12px;
	margin-bottom:10px;
}
.aboutctn .aboutinfos .i_infos ul li:before{
	content: "";
	position: absolute;
	left:0;
	top:6px;
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background-color: currentColor;
}

.aboutctn .aboutinfos .i_111{
	width: 100%;
	background: url(/images/bg_i_infos.png) no-repeat top left #E8E8E8;
}
.aboutctn .aboutinfos .i_111 .num{
	color:#ffffff;
	background: #D82738;
}
.aboutctn .aboutinfos .i_111 ul li{
	margin-bottom:20px;
}
.aboutctn .aboutinfos .i_111_2{
	width: 100%;
	background: #5A5A5A;
	color:#ffffff;
}
.aboutctn .aboutinfos .i_111_2 .num{
	color:#D82738;
	background: #ffffff;
}

.aboutctn .aboutinfos .i_img{
	width: 100%;
	aspect-ratio: 563 / 223;
	border-radius: 10px;
	overflow: hidden;
}
.aboutctn .aboutinfos .i_img img{
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center center;
}
@media screen and (min-width: 480px){
	.aboutctn .aboutinfos .i_infos{
		width: calc(50% - 3px);
	}
	.aboutctn .aboutinfos .i_111{
		width: calc(55% - 3px);
	}
	.aboutctn .aboutinfos .i_111_2{
		width: calc(45% - 3px);
	}
}

#linksCtn{
	background: #D82738;
	overflow: hidden;
}
#linksCtn .links{
	display:flex;
	flex-direction: column;
	gap:25px;
	align-items: center;
	justify-content: flex-end;
}

#linksCtn .links h2{
	position:relative;
	margin-right:auto;
	color:#ffffff;
}

#linksCtn .links a{
	position: relative;
	width: 100%;
	box-sizing: border-box;
	aspect-ratio: 530 / 260;
	padding:40px 20px 40px 20px;
	color:#414141;
	background-color: #ffffff;
	text-decoration: none;
	border-radius: 10px;
	box-shadow: 5px 11px 11px rgba(0, 0, 0, 0.16);
	transition: all .5s;
}

#linksCtn .links a:hover{
	padding-left:40px;
}
#linksCtn .links a .title{
	position: relative;
	display: block;
	margin:0 0 36px 0;
	font-family: Archivo;
	font-size: 35px;
	font-weight: bold;
	line-height: 1;
	color:#D82738;
	z-index:2;
}
#linksCtn .links a .txt{
	position: relative;
	display: block;
	font-size: 20px;
	font-weight: normal;
	line-height: 1.55;
	z-index:2;
}

#linksCtn .links a:before{
	content: "";
	position: absolute;
	inset:0;
	background: #ffffff;
	border-radius: 10px;
	transition: inset .5s;
	z-index:1;
}
#linksCtn .links a:hover:before{
	inset:-20px 0 -20px 0;
}
#linksCtn .links a:after{
	content: "";
	position: absolute;
	width: 10%;
	aspect-ratio: 54/38;
	right: 10%;
	bottom:10%;
	background: url(/images/arrow_red.svg) no-repeat center center;
	background-size: contain;
	z-index:3;
}

@media screen and (min-width: 640px){
	#linksCtn .links{
		flex-direction: row;
		flex-wrap: wrap;
		justify-content: space-between;
		align-items: stretch;
	}
	#linksCtn .links h2{
		width: 100%;
	}

	#linksCtn .links a{
		width:calc(50% - 12.5px);
		aspect-ratio:unset;

	}
}

@media screen and (min-width: 1200px){
	#linksCtn .links{
		flex-direction: row;
		flex-wrap: nowrap;
		align-items: center;
		justify-content: flex-end;
	}
	#linksCtn .links h2{
		width: auto;
	}

	#linksCtn .links h2:after{
		content:"";
		position: absolute;
		left:0;
		bottom:-60px;
		height: 3px;
		background-color: #ffffff;
		width: 100vw;
	}
	#linksCtn .links a{
		width:33.8%;
		aspect-ratio: 530 / 364;
		padding:60px 40px 60px 40px;
	}
	#linksCtn .links a:hover{
		padding-left:60px;
	}
}

#teamCtn .team{
	display:flex;
	flex-wrap: wrap;
	gap:40px 40px;
	justify-content: space-between;
	margin-top:60px;
}
#teamCtn .team .teammate{
	width:calc(25% - 30px);
	min-width:275px;
}
@media screen and (min-width: 640px) {
	#teamCtn .team {
		gap:80px 40px;
		margin-top:100px;
	}
}

#teamCtn .team .teammate .name{
	display:block;
	margin-bottom:10px;
	font-family: Archivo;
	font-size: 28px;
	font-weight: 600;
	line-height: 1.2;
}
#teamCtn .team .teammate .fct{
	display:block;
	margin-bottom:10px;
	font-size: 18px;
	font-weight: 600;
	line-height: 1.2;
	color:#D82738;
}
#teamCtn .team .teammate .fct:after{
	content:"";
	display: block;
	width: 20px;
	height: 1px;
	background-color: #000000;
	margin-top:10px;
}
#teamCtn .team .teammate .tel, #teamCtn .team .teammate .mail{
	display:block;
	color: #000000;
	text-decoration: none;
}

#footerCtn{
	background: #414141;
	color:#ffffff;
	padding: 100px 0 100px 0;
}

#footerCtn .footer{
	display: flex;
	flex-direction: column;
	gap:60px;
}
@media screen and (min-width: 640px){
	#footerCtn .footer{
		flex-direction: row;
	}
}

#footerCtn .footer .title{
	display: block;
	font-family: Archivo;
	font-size: 28px;
	font-weight: 600;
	margin-bottom:20px;
}
#footerCtn .footer .txt{
	display: block;
	font-family: Archivo;
	font-size: 18px;
	font-weight: 300;
	line-height: 1.55;
}
@media screen and (min-width: 640px){
	#footerCtn .footer .title{
		font-size: 35px;
	}
	#footerCtn .footer .txt{
		font-size: 20px;
	}
}
#footerCtn .footer a{
	text-decoration: none;
	color:#ffffff;
}

#footerCtn .mentionslegales{
	position: absolute;
	right:20px;
	bottom:-80px;
	color:#ffffff;
	text-decoration: none;
	font-size:14px;
}

#poweredCtn{
	background: #272727;
	color:#ffffff;
	padding: 30px 0 30px 0;
}
#poweredCtn a{
	display: block;
	aspect-ratio: 624/49;
	width: 150px;
	background: url(/images/by_boomerang.svg) no-repeat center center;
	background-size: contain;
}

