/**********/
/* COMMON */
/**********/

/* FONTS */

@font-face {
    font-family: 'Laro';
    src: url('../fonts/Laro-Thin.eot');
    src: local('Laro Thin'), local('Laro-Thin'),
        url('../fonts/Laro-Thin.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Laro-Thin.woff2') format('woff2'),
        url('../fonts/Laro-Thin.woff') format('woff'),
        url('../fonts/Laro-Thin.ttf') format('truetype');
    font-weight: 100;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Laro';
    src: url('../fonts/Laro-ExtraLight.eot');
    src: local('Laro ExtraLight'), local('Laro-ExtraLight'),
        url('../fonts/Laro-ExtraLight.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Laro-ExtraLight.woff2') format('woff2'),
        url('../fonts/Laro-ExtraLight.woff') format('woff'),
        url('../fonts/Laro-ExtraLight.ttf') format('truetype');
    font-weight: 200;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Laro';
    src: url('../fonts/Laro-Light.eot');
    src: local('Laro Light'), local('Laro-Light'),
        url('../fonts/Laro-Light.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Laro-Light.woff2') format('woff2'),
        url('../fonts/Laro-Light.woff') format('woff'),
        url('../fonts/Laro-Light.ttf') format('truetype');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Laro';
    src: url('../fonts/Laro-Regular.eot');
    src: local('Laro Regular'), local('Laro-Regular'),
        url('../fonts/Laro-Regular.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Laro-Regular.woff2') format('woff2'),
        url('../fonts/Laro-Regular.woff') format('woff'),
        url('../fonts/Laro-Regular.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Laro';
    src: url('../fonts/Laro-Medium.eot');
    src: local('Laro Medium'), local('Laro-Medium'),
        url('../fonts/Laro-Medium.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Laro-Medium.woff2') format('woff2'),
        url('../fonts/Laro-Medium.woff') format('woff'),
        url('../fonts/Laro-Medium.ttf') format('truetype');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Laro';
    src: url('../fonts/Laro-SemiBold.eot');
    src: local('Laro SemiBold'), local('Laro-SemiBold'),
        url('../fonts/Laro-SemiBold.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Laro-SemiBold.woff2') format('woff2'),
        url('../fonts/Laro-SemiBold.woff') format('woff'),
        url('../fonts/Laro-SemiBold.ttf') format('truetype');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Laro';
    src: url('../fonts/Laro-Bold.eot');
    src: local('Laro Bold'), local('Laro-Bold'),
        url('../fonts/Laro-Bold.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Laro-Bold.woff2') format('woff2'),
        url('../fonts/Laro-Bold.woff') format('woff'),
        url('../fonts/Laro-Bold.ttf') format('truetype');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Laro';
    src: url('../fonts/Laro-ExtraBold.eot');
    src: local('Laro ExtraBold'), local('Laro-ExtraBold'),
        url('../fonts/Laro-ExtraBold.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Laro-ExtraBold.woff2') format('woff2'),
        url('../fonts/Laro-ExtraBold.woff') format('woff'),
        url('../fonts/Laro-ExtraBold.ttf') format('truetype');
    font-weight: 800;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Laro';
    src: url('../fonts/Laro-Black.eot');
    src: local('Laro Black'), local('Laro-Black'),
        url('../fonts/Laro-Black.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Laro-Black.woff2') format('woff2'),
        url('../fonts/Laro-Black.woff') format('woff'),
        url('../fonts/Laro-Black.ttf') format('truetype');
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}

body {
	overflow-x: hidden;
	background: #fff;
	font-family: 'Laro';
	font-weight: 400;
	color: #000;
	font-size: 1.094vw;
	line-height: 100%;
}

*:focus {
	outline: 0 !important;
	box-shadow: none !important;
}

a, button {
	transition: all 0.25s ease;
	text-decoration: none;
}

.tel-link { 
	pointer-events: none;
  	cursor: default; 
}

#smooth-content {
	will-change: transform;
    padding-top: 1px;
    margin-top: -1px;
}

.loading {
	position: fixed;
	width: 100%;
	height: 100%;
	background-color: #fff;
	top: 0;
	left: 0;
	z-index: 1000;
}


/* Text*/

h1 {
	font-size: 3.646vw;
	line-height: 4.219vw;
	text-transform: uppercase;
	margin: 0 0 1.5vw 0;
	padding: 0;
}

.outline {
	-webkit-text-stroke-width: 3px;
	-webkit-text-stroke-color: #FFF;
	color: transparent;
}

h2 {
	font-size: 2.604vw;
	line-height: 2.969vw;
	margin: 0 0 1.5vw 0;
	padding: 0;
}

h3 {
	font-size: 1.719vw;
	line-height: 2.135vw;
	margin: 0 0 1.5vw 0;
	padding: 0;
}

p, ul { 
	font-size: 1.198vw;
	line-height: 1.823vw;
	margin-bottom: 1.5vw;
}



/**********/
/* HEADER */
/**********/

header.main {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 998;
	display: flex;
	justify-content: space-between;
	transition: all 0.25s ease;
}

header.main.sticky {
	background-color: rgba(0,0,0,.5);
	backdrop-filter: blur(10px);
}

.header__left {
	padding: 2vw 0 0 5vw;
}

header.main.sticky .header__left {
	padding: 0 0 0 5vw;
	display: flex;
	align-items: center;
}

.header__right {
	display: flex;
	align-items: flex-start;
	justify-content: flex-end;
}

header.main ul {
	line-height: 1;
}

.logo {
	width: 15vw;
	transition: all 0.25s ease;
}

header.main.sticky .logo {
	width: 7vw;
}

.logo_white {
	display: block;
}

.logo_black {
	display: none;
}

.mainmenu {
	margin: 0;
	padding: 1.823vw 2.344vw 0.885vw 2.344vw;
	list-style: none;
	display: flex;
	align-items: center;
	gap: 2.344vw;
	transition: all 0.25s ease;
}

.mainmenu a {
	color: #fff;
	font-weight: 500;
	position: relative;
}

.mainmenu a::after {
	content: "";
	width: 0.1vw;
	height: 2px;
	background-color: #fff;
	opacity: 0;
	position: absolute;
	top: 100%;
	left: 0;
	transition: all 0.25s ease;
}

.mainmenu a:hover::after {
	width: 2vw;
	opacity: 1;
}

/* Language Switcher */
.wpml-ls-legacy-list-horizontal {
	border: 0;
	padding: 0;
}

.language-switcher {
	padding: 1.823vw 5vw 0.885vw 0;
	display: flex;
	align-items: center;
}

.language-switcher ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: 2.344vw;
	align-items: center;
}

.language-switcher li {
	margin: 0;
	padding: 0;
}

.language-switcher a {
	color: #fff;
	font-weight: 500;
	position: relative;
	transition: all 0.25s ease;
}

.language-switcher a:hover {
	opacity: .75;
}

/* Language Switcher Mobile */
.language-switcher-mobile {
	padding: 2rem 0;
	display: flex;
	justify-content: center;
}

.language-switcher-mobile ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: 1rem;
	align-items: center;
}

.language-switcher-mobile li {
	margin: 0;
	padding: 0;
}

.language-switcher-mobile a {
	color: #fff;
	font-weight: 500;
	padding: 0.5rem 1rem;
	border-radius: 4px;
	transition: all 0.25s ease;
	text-transform: uppercase;
	font-size: 1.2em;
}

.language-switcher-mobile a:hover {
	background-color: rgba(255, 255, 255, 0.1);
}

.language-switcher-mobile .wpml-ls-current-language a {
	background-color: rgba(255, 255, 255, 0.2);
	font-weight: 600;
}

.wpml-ls-legacy-list-horizontal a {
	padding: 0;
}

.wpml-ls-legacy-list-horizontal a span {
    vertical-align: inherit;
}

.btn_phone {
	background-color: #000;
	color: #fff;
	font-weight: 500;
	display: flex;
	align-items: center;
	gap: 1.042vw;
	padding: 2.2vw 1.042vw 0.885vw 1.042vw;
	overflow: hidden;
}

.btn_phone:hover {
	color: #fff;
	background-color: rgba(0,0,0,.5);
	backdrop-filter: blur(10px);
}

footer.main {
	display: flex;
	justify-content: space-between;
	padding: 5vw 10vw;
}

.footer_left {
	width: 25%;
}

.footer_right {
	display: flex;
	flex-direction: column;
	gap: 1.5vw;
}

.footer_right a {
	color: #000;
	display: flex;
	align-items: center;
	gap: 1vw;
}

.footer_right a i {
	font-size: 1.5vw;
}

footer.main small {
	font-size: 0.781vw;
}

a.btn_facebook {
	color: #000;
	display: flex;
	align-items: center;
	gap: 2vw;
	font-size: 1.5vw;
	font-weight: 500;
	line-height: 1.1;
}

a.btn_facebook i {
	font-size: 3.5vw;
}

.btn_quote {
	position: fixed;
	top: 35%;
	right: 0;
	z-index: 200;
	background-color: #000;
	color: #fff;
	padding: 0.885vw;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.885vw;
	text-transform: uppercase;
	font-size: 0.938vw;
	line-height: 1.3;
	line-height: 1;
	width: 8.438vw;
	text-align: center;
	cursor: pointer;
	border: .5px solid rgba(255,255,255,.5);
	transition: all 0.25s ease;
}

.btn_quote:hover {
	background-color: rgba(0,0,0,.5);
	backdrop-filter: blur(10px);
}

.btn_quote:hover img {
	transform: rotate(-90deg);
}

.btn_quote img {
	width: 2.5vw;
	height: 2.5vw;
	transition: all 0.25s ease;
}



/* Home */

#hero {
	background-repeat: no-repeat;
	background-position: top center;
	background-size: cover;
	min-height: 100vh;
	display: flex;
	align-items: center;
	color: #fff;
	padding-left: 5vw;
	position: relative;
}

#hero h1 {
	margin: 0;
	position: relative;
	z-index: 10;
}

#home_about {
	background-color: #000;
	color: #fff;
	position: relative;
}

#home_about svg {
	width: 100%;
	height: 76%;
	display: block;
	margin-top: auto;
}

.home_about__content {
	padding: 10vw 10vw 10vw 5vw;
}

#home_solutions {
	padding: 10vw 5vw 5vw 5vw;
	text-align: center;
}

.home_solutions__items_wrapper {
	display: flex;
	gap: 1vw;
	margin-top: 3.5vw;
}

.home_solutions__items {
	overflow: hidden;
	position: relative;
	cursor: pointer;
}

.home_solutions__items:hover img {
	transform: scale(1.1);
}

.home_solutions__items span {
	position: absolute;
	z-index: 10;
	left: 0;
	bottom: 0;
	padding: 0 0 1.5vw 0;
	font-size: 1.563vw;
	line-height: 2.031vw;
	font-weight: 500;
	width: 100%;
	color: #fff;
}

.home_solutions__items img {
	transition: all 0.25s ease;
}

#home_cta {
	min-height: 100vh;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center center;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: flex-end;
	padding: 10vw;
	color: #fff;
}

#home_cta h2 {
	text-transform: uppercase;
}

.btn_bordered {
	display: inline-flex;
	align-items: center;
	gap: 1vw;
	border: 1px solid #000;
	color: #000;
	font-size: 1.302vw;
	line-height: 1;
	font-weight: 500;
	padding: 1vw 1.5vw;
	position: relative;
}

.btn_bordered:hover {
	background-color: #000;
	color: #fff;
}

.btn_bordered svg path {
	transition: all 0.25s ease;
}

.btn_bordered:hover svg path {
	fill: #fff !important;
}

.btn_bordered svg {
	width: 1.5vw;
}

/* Menu Burger Styles */
.hamburger {
	display: none;
	position: relative;
	width: 30px;
	height: 30px;
	cursor: pointer;
	z-index: 500;
}

.hamburger-box {
	width: 2rem;
	height: 2rem;
	display: inline-block;
	position: relative;
}

.hamburger-inner {
	display: block;
	top: 50%;
	margin-top: -2px;
	width: 100%;
	height: 4px;
	background-color: #fff;
	border-radius: 4px;
	position: relative;
	transition: all 0.3s ease;
}

.hamburger-inner::before,
.hamburger-inner::after {
	content: "";
	display: block;
	width: 100%;
	height: 4px;
	background-color: #fff;
	border-radius: 4px;
	position: absolute;
	transition: all 0.3s ease;
}

.hamburger-inner::before {
	top: -10px;
}

.hamburger-inner::after {
	bottom: -10px;
}

/* Animation du burger */
.hamburger--spin.is-active .hamburger-inner {
	transform: rotate(225deg);
	transition-delay: 0.12s;
	transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
}

.hamburger--spin.is-active .hamburger-inner::before {
	top: 0;
	opacity: 0;
	transition: top 0.1s ease-out, opacity 0.1s 0.12s ease-out;
}

.hamburger--spin.is-active .hamburger-inner::after {
	bottom: 0;
	transform: rotate(-90deg);
	transition: bottom 0.1s ease-out, transform 0.22s 0.12s cubic-bezier(0.215, 0.61, 0.355, 1);
}

/* Menu Panel Styles */
.menu_panel {
	position: fixed;
	top: 0;
	right: -100%;
	width: 100%;
	height: 100vh;
	background-color: rgba(0, 0, 0, 0.95);
	backdrop-filter: blur(10px);
	z-index: 1000;
	transition: right 0.3s ease;
	overflow-y: auto;
}

.menu_panel.open {
	right: 0;
}

.menu_panel__content {
	padding: 20vw 8vw 8vw 8vw;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	text-align: center;
	position: relative;
	z-index: 1002;
}

.menu_panel__close {
	position: absolute;
	top: 2rem;
	right: 2rem;
	background: none;
	border: none;
	color: #fff;
	cursor: pointer;
	padding: 0.5rem;
	border-radius: 50%;
	transition: all 0.3s ease;
	z-index: 1002;
	background-color: rgba(255, 255, 255, 0.1);
}

.menu_panel__close:hover {
	background-color: rgba(255, 255, 255, 0.1);
	transform: rotate(90deg);
}

.menu_panel__close svg {
	width: 1.5rem;
	height: 1.5rem;
}

.menu_panel__nav {
	list-style: none;
	margin: 0;
	padding: 0;
	margin-bottom: 8vw;
}

.menu_panel__nav a {
	color: #fff;
	font-size: 6vw;
	font-weight: 500;
	text-decoration: none;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	transition: all 0.3s ease;
	display: block;
	padding: 2vw 0;
}

.menu_panel__nav a:hover {
	color: #ccc;
	transform: translateX(2vw);
}

.menu_panel__contact {
	margin-top: 4vw;
}

.btn_phone_mobile {
	display: inline-flex;
	align-items: center;
	gap: 3vw;
	color: #fff;
	font-size: 4.5vw;
	font-weight: 500;
	text-decoration: none;
	padding: 3vw 6vw;
	border: 2px solid #fff;
	border-radius: 2vw;
	transition: all 0.3s ease;
}

.btn_phone_mobile:hover {
	background-color: #fff;
	color: #000;
}

/* Body scroll lock when menu is open */
body.noscroll {
	overflow: hidden;
}

.btn_bordered_white {
	display: inline-flex;
	align-items: center;
	gap: 1vw;
	border: 1px solid #fff;
	color: #fff;
	font-size: 1.302vw;
	line-height: 1;
	font-weight: 500;
	padding: 1vw 1.5vw;
	position: relative;
}

.btn_bordered_white:hover {
	background-color: #fff;
	color: #000;
}

.btn_bordered_white svg path {
	transition: all 0.25s ease;
}

.btn_bordered_white:hover svg path {
	fill: #000 !important;
}

.btn_bordered_white svg {
	width: 1.5vw;
}

.btn_bordered_white.double::before {
	content: "";
	position: absolute;
	z-index: -1;
	top: -6px;
	left: -6px;
	width: calc(100% + 12px);
	height: calc(100% + 12px);
	background-color: #000;
}

#home_careers {
	background-color: #000;
	color: #fff;
	padding: 10vw 0 10vw 10vw;
}

.home_careers__content {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 2.5vw;
	margin: auto 0 0 0;
	padding: 0 15vw 5vw 15vw;
}

.award {
	position: absolute;
	top: 0;
	right: 0;
	z-index: 10;
	transform: translate(50%, -50%);
	width: 10vw;
}


/* Inner pages */

#hero_inner {
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	min-height: 75vh;
	display: flex;
	align-items: flex-end;
	color: #fff;
	padding: 0 0 10vw 0;
}

.hero_inner__content {
	display: block;
	width: 100%;
	margin-top: auto;
	text-align: center;
}

.hero_inner__content h1 {
	font-weight: 700;
}

#our_services {
	padding: 5vw 10vw;
}

.our_services__item {
	display: flex;
	align-items: flex-start;
	gap: 3.5vw;
	margin: 0 0 2.5vw 0;
}

.our_services__item img {
	width: 25%;
	height: auto;
}

.our_services__item__content {
	display: flex;
	flex-direction: column;
	justify-content: center;
	border-radius: 2vw;
	border: 2px solid #000;
	padding: 1.5vw 5vw;
	width: 100%;
}

.our_services__item__content ul {
	margin-bottom: 0;
}

.num {
	display: block;
	-webkit-text-stroke-width: 1px;
	-webkit-text-stroke-color: #000;
	color: transparent;
	font-size: 5vw;
	line-height: 1;
	font-weight: 700;
	margin: 0 0 2.5vw 0;
}

#our_services .actions {
	display: flex;
	justify-content: flex-end;
	padding-top: 3.5vw;
}

#cta_achievements {
	background-color: #000;
	color: #fff;
	padding: 0 5vw 5vw 5vw;
}

.cta_achievements__intro {
	display: flex;
	align-items: center;
	gap: 5vw;
}

.cta_achievements__intro svg {
	width: 70vw;
    height: auto;
	padding-right: 2.5vw;
}

.cta_achievements__content {
	position: relative;
	z-index: 20;
	top: -7.5vw;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 2.5vw;
}

.cta_achievements__content img {
	width: calc(33.3% - 1.65vw);
}

#cta_achievements .actions {
	display: flex;
	justify-content: center;
}

#about {
	display: flex;
	flex-wrap: wrap;
	margin-top: 5vw;
}

.about_left {
	flex-basis: 35%;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
}

.about_left .award {
	top: inherit;
	right: inherit;
	transform: none;
	width: 15vw;
}

.about_right {
	flex-basis: 65%;
}

.about_content {
	padding: 0 10vw;
}

#team {
	padding: 5vw;
	color: #fff;
	background-color: #000;
}

#team h2 {
	text-transform: uppercase;
	margin: 0 0 5vw 0;
}

/* Team Grid - 3 columns using CSS Grid (left to right) */
.team_grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2.5vw;
}

.team_grid__item {
	display: flex;
	flex-direction: column;
	width: 100%;
	padding: 0 0 2vw 0;
}

.team_grid__item__img {
	width: 100%;
	margin-bottom: 2vw;
	overflow: hidden;
}

.team_grid__item__img img {
	width: 100%;
	height: auto;
	display: block;
}

.team_grid__item h3 {
	text-transform: uppercase;
	margin: 0 0 1.5vw 0;
	font-size: 1.5vw;
}

.team_grid__item h3 span {
	display: block;
	font-size: 1vw;
	text-transform: initial;
	font-weight: 400;
	margin-top: 0.5vw;
}

.team_grid__item__content {
	margin-top: 1.5vw;
	overflow: hidden;
}

.team_grid__item__content__hide {
	overflow: hidden;
}

.btn_txt_white {
	color: #fff;
	text-decoration: underline;
}

.btn_txt_white:hover {
	color: #fff;
	text-decoration: none;
}

#company_careers {
	position: relative;
	background-color: #000;
	color: #fff;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center center;
	height: 100vh;
	display: flex;
	align-items: center;
}

.company_careers__content {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 1vw;
	margin: auto 0 0 0;
	padding: 0 15vw 10vw 15vw;
	position: relative;
	z-index: 10;
}

.company_careers__content h3 {
	margin: 0;
	text-transform: uppercase;
}

#achievements_intro {
	background-color: #000;
	color: #fff;
	padding: 5vw 5vw 0 5vw;
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
}

.achievements_intro__text {
	flex-basis: 60%;
}

.achievements_intro__text p {
	padding-right: 10vw;
}

.achievements_intro__deco {
	flex-basis: 40%;
}

.achievements_intro__deco svg {
	width: 100%;
	height: auto;
}

#gallery {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	grid-template-rows: masonry;
	background-color: #000;
	color: #fff;
	padding: 5vw;
	gap: 2.5vw;
	align-items: start;
}

/* Fallback pour les navigateurs qui ne supportent pas masonry */
@supports not (grid-template-rows: masonry) {
	#gallery {
		display: flex;
		flex-wrap: wrap;
	}
}

.gallery_item {
	width: 100%;
	break-inside: avoid;
	page-break-inside: avoid;
	cursor: pointer;
	transition: box-shadow 0.3s ease;
	position: relative;
}

.gallery_item:hover {
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.3);
}

.gallery_item__image {
	overflow: hidden;
	position: relative;
	height: 25vw;
	width: 100%;
}

.gallery_item img {
	transition: transform 0.3s ease;
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transform-origin: center center;
}

.gallery_item:hover img {
	transform: scale(1.05);
}

/* Fallback pour les navigateurs qui ne supportent pas masonry */
@supports not (grid-template-rows: masonry) {
	.gallery_item {
		width: calc(33.3% - 1.65vw);
	}
}

.gallery_item__infos {
	display: flex;
	flex-direction: column;
	gap: .5vw;
	margin: 1vw 0 0 0;
}

.gallery_item__infos span:first-child {
	text-transform: uppercase;
	padding-bottom: .5vw;
	font-size: 1.198vw;
}

.gallery_item__infos span {
	font-size: 1vw;
}

/* Lightbox Styles */
.lightbox {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 9999;
	display: none;
	opacity: 0;
}

.lightbox__overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.95);
	backdrop-filter: blur(10px);
}

.lightbox__content {
	position: relative;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1vw;
	box-sizing: border-box;
}

.lightbox__image {
	max-width: 98%;
	max-height: 92%;
	object-fit: contain;
	border-radius: 0;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
}

.lightbox__info {
	display: none;
	position: absolute;
	bottom: 3vw;
	left: 0;
	width: 100%;
	background-color: rgba(0, 0, 0, 0.8);
	padding: 1.5vw 2vw;
	border-radius: 8px;
	text-align: center;
	color: #fff;
}

.lightbox__project-name {
	font-size: 1vw;
	font-weight: 600;
	margin-bottom: 0.5vw;
	text-transform: uppercase;
}

.lightbox__client-name,
.lightbox__photo-credit {
	font-size: 0.85vw;
	margin-bottom: 0.3vw;
	opacity: 0.8;
}

.lightbox__close,
.lightbox__prev,
.lightbox__next {
	position: absolute;
	background: rgba(255, 255, 255, 0.1);
	border: none;
	border-radius: 50%;
	width: 50px;
	height: 50px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	cursor: pointer;
	transition: all 0.3s ease;
	backdrop-filter: blur(10px);
}

.lightbox__close:hover,
.lightbox__prev:hover,
.lightbox__next:hover {
	background: rgba(255, 255, 255, 0.2);
	transform: scale(1.1);
}

.lightbox__close {
	top: 2vw;
	right: 2vw;
}

.lightbox__prev {
	left: 2vw;
	top: 50%;
	transform: translateY(-50%);
}

.lightbox__next {
	right: 2vw;
	top: 50%;
	transform: translateY(-50%);
}

.lightbox__prev:disabled,
.lightbox__next:disabled {
	opacity: 0.3;
	cursor: not-allowed;
	transform: translateY(-50%) scale(1);
}

.lightbox__prev:disabled:hover,
.lightbox__next:disabled:hover {
	background: rgba(255, 255, 255, 0.1);
	transform: translateY(-50%) scale(1);
}

#careers_intro {
	padding: 10vw 5vw;
}

.careers_intro__content {
	padding-right: 10vw;
}

#careers_advantages {
	background-color: #000;
	color: #fff;
	padding: 5vw;
}

#careers_advantages h2 {
	text-transform: uppercase;
	margin: 0 0 5vw 0;
}

.careers_advantages__items_wrapper {
	column-count: 2;
	column-gap: 2vw;
}

.careers_advantages__item {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	border-bottom: 1px solid #fff;
	padding: .5vw 0;
	break-inside: avoid;
	page-break-inside: avoid;
	margin-bottom: 1vw;
}

.careers_advantages__item__num {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-basis: 15%;
	font-size: 3.906vw;
	-webkit-text-stroke-width: 1px;
	-webkit-text-stroke-color: #fff;
	color: transparent;
	font-weight: 700;
	line-height: 1;
	margin-right: .5vw;
}

.careers_advantages__item__num img {
	width: .4vw;
}

#careers_jobs {
	padding: 10vw;
}

.careers_jobs__intro {
	position: relative;
	padding-right: 25vw;
	padding-bottom: 2vw;
}

.pastille {
	position: absolute;
	top: -2.5vw;
	right: 0;
	z-index: 10;
	width: 11vw;
}

.careers_jobs__intro h2 {
	text-transform: uppercase;
}

.careers_jobs__intro h3 {
	margin: 5vw 0 0 0;
}

.careers_jobs__listing__item {
	display: flex;
	align-items: flex-start;
	flex-direction: column;
	gap: 1.5vw;
	padding: 3.5vw;
	border: 2px solid #000;
	border-radius: 2vw;
	margin-bottom: 5vw;
}

.careers_jobs__listing__item h3, .careers_jobs__listing__item p {
	margin: 0;
}

.careers_jobs__listing__item:last-child {
	margin: 0;
}

#unsolicited_application {
	background-color: #F0F0F0;
	background-image: url('../images/box_white.svg');
	background-repeat: no-repeat;
	background-size: 30% auto;
	background-position: left bottom;
	padding: 5vw 10vw;
	min-height: 75vh;
}

#unsolicited_application h3 {
	text-align: center;
	margin: 0 0 2.5vw 0;
}

.form_wrapper {
	border-radius: 2vw;
	border: 2px solid #000;
	padding: 2.5vw;
}

body.single header.main {
	position: static;
}

body.single .logo_white {
	display: none;
}

body.single .logo_black {
	display: block;
}

body.single .mainmenu a {
	color: #000;
}

body.single .mainmenu a::after {
	background-color: #000;
}

body.single .language-switcher a {
	color: #000;
}

body.single .language-switcher a::after {
	background-color: #000;
}

/* Le bouton quote est maintenant affiché sur toutes les pages */
/* body.single .btn_quote {
	display: none;
} */

#single_infos {
	padding: 5vw 15vw 0 5vw;
}

#single_infos h3 {
	margin: 0 0 2.5vw 0;
}

#single_infos strong {
	font-weight: 500;
}

.single_specs {
	border-radius: 2vw;
	border: 2px solid #000;
	padding: 1.5vw;
}

.single_specs ul {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 1vw;
}

.single_specs ul li {
	display: flex;
	align-items: center;
	gap: 1vw;
	border-bottom: 1px solid #000;
	padding-bottom: 1vw;
	line-height: 1;
}

.single_specs ul li:last-child {
	border: 0;
	padding: 0;
}

.single_specs i {
	width: 1vw;
	color: #ccc;
}

.single_specs strong {
	text-transform: uppercase;
}

#single_infos .single_text h3 {
	margin: 0 0 1vw 0;
}

#single_form {
	padding: 5vw;
	position: relative;
}

.g-5, .gx-5 {
    --bs-gutter-x: 5vw;
}

.careers_cta_single {
	position: relative;
	overflow: hidden;
	margin-top: 2.5vw;
}

.careers_cta_single span {
	position: absolute;
	z-index: 10;
	width: 100%;
	left: 2vw;
	bottom: 2vw;
	color: #fff;
	font-weight: 500;
	font-size: 1.5vw;
	line-height: 1.3;
}

.careers_cta_single img {
	transition: all 0.25s ease;
}

.careers_cta_single:hover img {
	transform: scale(1.1);
}

body.page-template-contact .logo_white {
	display: none;
}

body.page-template-contact .logo_black {
	display: block;
}

body.page-template-contact .mainmenu a {
	color: #000;
}

body.page-template-contact .mainmenu a::after {
	background-color: #000;
}

body.page-template-contact .language-switcher a {
	color: #000;
}

body.page-template-contact .language-switcher a::after {
	background-color: #000;
}

#contact_infos {
	background-color: #F0F0F0;
	background-image: url('../images/box_white.svg');
	background-repeat: no-repeat;
	background-size: 55% auto;
	background-position: 0 8vw;
	padding: 15vw 15vw 5vw 5vw;
	min-height: 75vh;
}

#contact_infos .outline {
    -webkit-text-stroke-color: #000;
}

/* Quote Aside Styles */
.quote_aside {
    position: fixed;
    top: 0;
    right: 0;
	opacity: 0;
    width: 100%;
    height: 100vh;
    z-index: -1;
    transition: right 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    overflow-y: auto;
	display: flex
;
    align-items: center;
}

.quote_aside.open {
    right: 0;
	opacity: 1;
	z-index: 9999;
}

.quote_aside__overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    backdrop-filter: blur(10px);
    opacity: 0;
    transition: opacity 0.3s ease;
}

.quote_aside.open .quote_aside__overlay {
    opacity: 1;
}

.quote_aside__content {
    position: relative;
	color: #fff;
    background-color: #000;
    width: 100%;
    max-width: 50%;
    height: 70%;
    margin-left: auto;
    padding: 3vw;
    overflow-y: auto;
}

.quote_aside.open .quote_aside__content {
    transform: translateX(0);
}

.quote_aside__close {
    position: absolute;
    top: 2rem;
    right: 2rem;
    background: none;
    border: none;
    color: #fff;
    cursor: pointer;
    padding: 0.5rem;
    border-radius: 50%;
    transition: all 0.3s ease;
    z-index: 10;
    background-color: transparent;
	border: 1px solid #fff;
    width: 50px;
    height: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.quote_aside__close:hover {
    background-color: rgba(0, 0, 0, 0.1);
    transform: rotate(90deg);
}

.quote_aside__close svg {
    width: 1.5rem;
    height: 1.5rem;
}

.quote_aside__header {
    margin-bottom: 2vw;
    padding-top: 0;
}

.quote_aside__header h2 {
    font-size: 2.5vw;
    line-height: 1.2;
    margin: 0 0 1vw 0;
    text-transform: uppercase;
    color: #fff;
}

.quote_aside__header p {
    font-size: 1.2vw;
    line-height: 1.5;
    color: #fff;
    margin: 0;
}

/* Form Styles */
.quote_form {
    display: flex;
    flex-direction: column;
    gap: 2vw;
}

.form_group {
    display: flex;
    flex-direction: column;
    gap: 0.5vw;
}

.form_group label {
    font-size: 1.1vw;
    font-weight: 500;
    color: #000;
    margin-bottom: 0.5vw;
}

.form_group input,
.form_group select,
.form_group textarea {
    padding: 1vw 1.5vw;
    border: 2px solid #e0e0e0;
    border-radius: 0.5vw;
    font-size: 1vw;
    font-family: 'Laro', sans-serif;
    transition: all 0.3s ease;
    background-color: #fff;
}

.form_group input:focus,
.form_group select:focus,
.form_group textarea:focus {
    outline: none;
    border-color: #000;
    box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.1);
}

.form_group input::placeholder,
.form_group textarea::placeholder {
    color: #999;
}

.checkbox_group {
    display: flex;
    flex-direction: column;
    gap: 1vw;
}

.checkbox_label {
    display: flex;
    align-items: center;
    gap: 1vw;
    cursor: pointer;
    font-size: 1vw;
    font-weight: 400;
    color: #000;
}

.checkbox_label input[type="checkbox"] {
    width: 1.2vw;
    height: 1.2vw;
    margin: 0;
    cursor: pointer;
}

.checkbox_label span {
    flex: 1;
}

.btn_submit {
    background-color: #000;
    color: #fff;
    border: none;
    padding: 1.5vw 2vw;
    border-radius: 0.5vw;
    font-size: 1.2vw;
    font-weight: 500;
    font-family: 'Laro', sans-serif;
    cursor: pointer;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1vw;
    margin-top: 1vw;
    text-transform: uppercase;
}

.btn_submit:hover {
    background-color: #333;
    transform: translateY(-2px);
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2);
}

.btn_submit svg {
    width: 1.5vw;
    height: 1.5vw;
}

.btn_submit:disabled {
    background-color: #ccc;
    cursor: not-allowed;
    transform: none;
    box-shadow: none;
}


/* Body scroll lock when aside is open */
body.quote_aside_open {
    overflow: hidden;
}

/* Animation pour l'ouverture */
@keyframes slideInFromRight {
    from {
        transform: translateX(100%);
    }
    to {
        transform: translateX(0);
    }
}

.quote_aside.open .quote_aside__content {
    animation: slideInFromRight 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* Error States */
.form_group.error input,
.form_group.error select,
.form_group.error textarea {
    border-color: #e74c3c;
    box-shadow: 0 0 0 3px rgba(231, 76, 60, 0.1);
}

.error-message {
    color: #e74c3c;
    font-size: 0.9vw;
    margin-top: 0.5vw;
    display: block;
}



/* WPFORMS */

div.wpforms-container-full:not(:empty) {
    margin: 0 !important; 
}

.wpforms-form .wpforms-field-container .wpforms-field.wpforms-field-content {
    padding-top: 0 !important;
}

div.wpforms-container-full input[type=date], div.wpforms-container-full input[type=datetime], div.wpforms-container-full input[type=datetime-local], div.wpforms-container-full input[type=email], div.wpforms-container-full input[type=month], div.wpforms-container-full input[type=number], div.wpforms-container-full input[type=password], div.wpforms-container-full input[type=range], div.wpforms-container-full input[type=search], div.wpforms-container-full input[type=tel], div.wpforms-container-full input[type=text], div.wpforms-container-full input[type=time], div.wpforms-container-full input[type=url], div.wpforms-container-full input[type=week], div.wpforms-container-full select, div.wpforms-container-full textarea, .wp-core-ui div.wpforms-container-full input[type=date], .wp-core-ui div.wpforms-container-full input[type=datetime], .wp-core-ui div.wpforms-container-full input[type=datetime-local], .wp-core-ui div.wpforms-container-full input[type=email], .wp-core-ui div.wpforms-container-full input[type=month], .wp-core-ui div.wpforms-container-full input[type=number], .wp-core-ui div.wpforms-container-full input[type=password], .wp-core-ui div.wpforms-container-full input[type=range], .wp-core-ui div.wpforms-container-full input[type=search], .wp-core-ui div.wpforms-container-full input[type=tel], .wp-core-ui div.wpforms-container-full input[type=text], .wp-core-ui div.wpforms-container-full input[type=time], .wp-core-ui div.wpforms-container-full input[type=url], .wp-core-ui div.wpforms-container-full input[type=week], .wp-core-ui div.wpforms-container-full select, .wp-core-ui div.wpforms-container-full textarea {
    background-color: transparent !important;
    border-radius: 0 !important;
    color: #000 !important;
    border: 2px solid #000 !important;
    padding: 1vw !important;
    font-size: 1vw !important;
    height: auto !important;
}

.wpforms-container textarea.wpforms-field-large {
    height: 220px !important;
}

div.wpforms-container-full ::placeholder {
	opacity: 1 !important;
	color: #000 !important;
}

div.wpforms-container-full input[type=submit], div.wpforms-container-full button[type=submit], div.wpforms-container-full .wpforms-page-button, .wp-core-ui div.wpforms-container-full input[type=submit], .wp-core-ui div.wpforms-container-full button[type=submit], .wp-core-ui div.wpforms-container-full .wpforms-page-button {
    height: auto !important;
    background-color: transparent !important;
    border-radius: 0 !important;
    border: 2px solid #000 !important;
    color: #000 !important;
    padding: .5vw 1vw !important;
    font-family: 'Laro' !important;
    font-size: 1vw !important;
    line-height: 100%;
	transition: all 0.25s ease;
}

div.wpforms-container-full input[type=submit]:hover, div.wpforms-container-full input[type=submit]:active, div.wpforms-container-full button[type=submit]:hover, div.wpforms-container-full button[type=submit]:active, div.wpforms-container-full .wpforms-page-button:hover, div.wpforms-container-full .wpforms-page-button:active, .wp-core-ui div.wpforms-container-full input[type=submit]:hover, .wp-core-ui div.wpforms-container-full input[type=submit]:active, .wp-core-ui div.wpforms-container-full button[type=submit]:hover, .wp-core-ui div.wpforms-container-full button[type=submit]:active, .wp-core-ui div.wpforms-container-full .wpforms-page-button:hover, .wp-core-ui div.wpforms-container-full .wpforms-page-button:active {
    background: inherit !important;
	background-color: #000 !important;
	color: #fff !important;
}

div.wpforms-container-full .wpforms-field-file-upload .wpforms-uploader {
    background-color: transparent !important;
    border-radius: 0 !important;
    color: #000 !important;
    border: 2px solid #000 !important;
    font-size: 1vw !important;
}

.otgs-development-site-front-end {
	display: none;
}


/* WPFORMS Aside */

.quote_aside__content div.wpforms-container-full input[type=date], 
.quote_aside__content div.wpforms-container-full input[type=datetime], 
.quote_aside__content div.wpforms-container-full input[type=datetime-local], 
.quote_aside__content div.wpforms-container-full input[type=email], 
.quote_aside__content div.wpforms-container-full input[type=month], 
.quote_aside__content div.wpforms-container-full input[type=number], 
.quote_aside__content div.wpforms-container-full input[type=password], 
.quote_aside__content div.wpforms-container-full input[type=range], 
.quote_aside__content div.wpforms-container-full input[type=search], 
.quote_aside__content div.wpforms-container-full input[type=tel], 
.quote_aside__content div.wpforms-container-full input[type=text], 
.quote_aside__content div.wpforms-container-full input[type=time], 
.quote_aside__content div.wpforms-container-full input[type=url], 
.quote_aside__content div.wpforms-container-full input[type=week], 
.quote_aside__content div.wpforms-container-full select, 
.quote_aside__content div.wpforms-container-full textarea, 
.quote_aside__content .wp-core-ui div.wpforms-container-full input[type=date], 
.quote_aside__content .wp-core-ui div.wpforms-container-full input[type=datetime], 
.quote_aside__content .wp-core-ui div.wpforms-container-full input[type=datetime-local], 
.quote_aside__content .wp-core-ui div.wpforms-container-full input[type=email], 
.quote_aside__content .wp-core-ui div.wpforms-container-full input[type=month], 
.quote_aside__content .wp-core-ui div.wpforms-container-full input[type=number], 
.quote_aside__content .wp-core-ui div.wpforms-container-full input[type=password], 
.quote_aside__content .wp-core-ui div.wpforms-container-full input[type=range], 
.quote_aside__content .wp-core-ui div.wpforms-container-full input[type=search], 
.quote_aside__content .wp-core-ui div.wpforms-container-full input[type=tel], 
.quote_aside__content .wp-core-ui div.wpforms-container-full input[type=text], 
.quote_aside__content .wp-core-ui div.wpforms-container-full input[type=time], 
.quote_aside__content .wp-core-ui div.wpforms-container-full input[type=url], 
.quote_aside__content .wp-core-ui div.wpforms-container-full input[type=week], 
.quote_aside__content .wp-core-ui div.wpforms-container-full select, 
.quote_aside__content .wp-core-ui div.wpforms-container-full textarea {
    background-color: transparent !important;
    border-radius: 0 !important;
    color: #fff !important;
    border: 2px solid #fff !important;
    padding: .5vw !important;
    font-size: 1vw !important;
    height: auto !important;
}

.quote_aside__content input::placeholder,
.quote_aside__content textarea::placeholder {
    color: #fff !important;
}
.quote_aside__content .wpforms-container textarea.wpforms-field-large {
	height: 220px !important;
}

.quote_aside__content div.wpforms-container-full input[type=submit], 
.quote_aside__content div.wpforms-container-full button[type=submit], 
.quote_aside__content div.wpforms-container-full .wpforms-page-button, 
.quote_aside__content .wp-core-ui div.wpforms-container-full input[type=submit], 
.quote_aside__content .wp-core-ui div.wpforms-container-full button[type=submit], 
.quote_aside__content .wp-core-ui div.wpforms-container-full .wpforms-page-button {
    border: 2px solid #fff !important;
    color: #fff !important;
}

.quote_aside__content div.wpforms-container-full input[type=submit]:hover, 
.quote_aside__content div.wpforms-container-full input[type=submit]:active, 
.quote_aside__content div.wpforms-container-full button[type=submit]:hover, 
.quote_aside__content div.wpforms-container-full button[type=submit]:active, 
.quote_aside__content div.wpforms-container-full .wpforms-page-button:hover, 
.quote_aside__content div.wpforms-container-full .wpforms-page-button:active, 
.quote_aside__content .wp-core-ui div.wpforms-container-full input[type=submit]:hover, 
.quote_aside__content .wp-core-ui div.wpforms-container-full input[type=submit]:active, 
.quote_aside__content .wp-core-ui div.wpforms-container-full button[type=submit]:hover, 
.quote_aside__content .wp-core-ui div.wpforms-container-full button[type=submit]:active, 
.quote_aside__content .wp-core-ui div.wpforms-container-full .wpforms-page-button:hover, 
.quote_aside__content .wp-core-ui div.wpforms-container-full .wpforms-page-button:active {
	background-color: #fff !important;
	color: #000 !important;
}

.videobg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 1;
	opacity: 1;
	transition: all 0.25s ease;
}

.hero_video_filter {
	position: absolute;
	left: 0;
	top: 0;
	z-index: 2;
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,.25);
}


/* 
.team_grid__item__content {
    margin-top: 0;
    overflow: hidden;
    position: absolute;
    top: 0;
    left: 0;
    background-color: rgba(0, 0, 0, 0.5);
    padding: 1rem;
    max-height: 73.5%;
    overflow: auto;
}
*/

p.rbq {
	display: block;
	margin: 1vw 0 0 0;
	font-size: .85vw;
	font-weight: 700;
	text-align: center;
}