/*** HELPERS & GENERAL ***/

:root {
	--green: #165933;
	--green-a-w: #e7eeea;
	--green-a: rgba(22,89,51,.1);
	--green-a-d: rgba(22,89,51,.2);
	--green-h: #13911F;
	--brown: #A6411C;
	--brown-a-w: #f6ebe7;
	--brown-a: rgba(166,65,28,.1);
	--brown-a-d: rgba(166,65,28,.2);
	--brown-h: #6E0F05;
	--grey: #545353;
	--grey-a-w: #ececec;
	--grey-a: rgba(84,83,83,.1);
	--grey-a-d: rgba(84,83,83,.2);
	--grey-h: #545353;

	--white: #ffffff;
	--black: #000000;

	--error: #DC3545;
	--error-w: #ED9AA2;
	--error-a-w: #F8D6DA;
	--success: #198754;
	--success-w: #8CC3A9;
	--success-a-w: #D1E7DD;

	--white-a: rgba(255,255,255,.1);
	--white-a-l: rgba(255,255,255,.05);
	--black-a: rgba(0,0,0,.1);
	--black-a-l: rgba(0,0,0,.05);

	--u-xs: 5px;
	--u-xs-n: -5px;
	--u-sm: 10px;
	--u-sm-n: -10px;
	--u: 20px;
	--u-n: -20px;
	--u-me: 30px;
	--u-me-n: -30px;
	--u-lg: 40px;
	--u-lg-n: -40px;
	--u-xl: 80px;
	--u-xl-n: -80px;
	--u-xxl: 100px;
	--u-xxl-n: -100px;

	--bw: 2px;
	--bw-n: -2px;
	--border: 1px solid var(--green-a);
	--border-b: 1px solid var(--brown-a);
/*	--border-lg: 2px solid var(--black-a-l);*/

	--shadow: 0 5px 20px rgba(0,0,0,.05);
	--shadow-lg: 0 5px 20px rgba(0,0,0,.1);

	--transition: .3s;
	--transition-bezier: .6s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

* {
	font-family: 'Montserrat', sans-serif;
	line-height: 110%;
}

::selection {color: var(--red); background: rgba(254,226,65,.66);}
::-moz-selection {color: var(--red); background: rgba(254,226,65,.66);}

/* ::-webkit-scrollbar {
	width: var(--u-sm);
	margin-left: var(--u-sm-n);
	border-left: var(--border);
}
::-webkit-scrollbar-track {
	background: var(--green-a);
}
::-webkit-scrollbar-thumb {
	background: var(--green);
	border-radius: var(--u-sm);
	transition: var(--transition);
	opacity: .5;
}
::-webkit-scrollbar-thumb:hover {opacity: 1;} */

body {
	background: var(--white);
}

main {overflow: hidden;}

img {
	vertical-align: middle;
	width: 100%;
	height: auto;
}

hr {
	margin: var(--u-lg) 0;
	border: 0;
	background: var(--black-a);
	height: 1px;
}

/*** COLOR & TYPOGRAPHY ***/

.green-text {color: var(--green) !important;}
.brown-text {color: var(--brown) !important;}
.grey-text {color: var(--grey) !important;}

.green {background: var(--green) !important;}
.brown {background: var(--brown) !important;}
.grey {background: var(--grey) !important;}

.bold, strong, b {font-weight: 600;}
.underline:hover {text-decoration: underline;}
.break-spaces {white-space: break-spaces;}

.border-b {border-color: var(--brown-a);}

h1, h2, h3, h4, h5, h6, p, blockquote, ul {color: inherit;}
h1:first-child, h2:first-child, h3:first-child, h4:first-child, h5:first-child, h6:first-child, p:first-child, blockquote:first-child, ul:first-child {margin-top: 0;}
h1:last-child, h2:last-child, h3:last-child, h4:last-child, h5:last-child, h6:last-child, p:last-child, blockquote:last-child, ul:last-child {margin-bottom: 0;}

h1, h2, h3, h4, h5, h6 {line-height: 100%;}

h1 {font-size: 3rem;}

h2 {font-size: 2.5rem;}

p, blockquote {
	color: var(--grey);
	font-size: 1rem;
}

.row:last-child {margin-bottom: 0;}

/*** COMPONENTS ***/

.visuel {pointer-events: none;}

.btn, button.btn {
	color: var(--white);
	font-family: 'Montserrat', sans-serif;
	border-radius: var(--u-lg);
	text-transform: none;
	font-weight: 600;
	background: var(--green);
	box-shadow: none;
	padding: var(--u) var(--u) !important;
	display: inline-flex;
	align-items: center;
	height: auto;
	transition: var(--transition) !important;
}

.btn:hover, .btn:focus, .btn:active, button:focus, button:active {
	background: var(--green-h) !important;
	box-shadow: 0 5px 20px var(--green-h) !important;
}

.btn.brown:hover, .btn.brown:focus, .btn.brown:active {
	background: var(--brown-h) !important;
	box-shadow: 0 5px 20px var(--brown-h) !important;
}

.btn.white {color: var(--green);}

.btn.white:hover, .btn.white:focus, .btn.white:active {color: var(--white) !important;}

.btn-link {
	display: flex;
	align-items: center;
	font-weight: 600;
	color: var(--green);
}

.btn-link:hover span:not(.emoji) {text-decoration: underline;}

.btn .feather, .btn-link .feather {
	margin-right: var(--u-sm);
	width: var(--u);
}

.emoji {
	font-size: 1.25rem;
	line-height: 1rem;
	margin-right: var(--u-xs);
	text-decoration: none !important;
}

.btn-i .emoji {margin-right: 0;}

a.card {display: block;}

.card {
	border-radius: var(--u);
	box-shadow: none;
	border: var(--border);
	background: transparent;
	margin: 0;
}

.card.border-b {border-color: var(--brown-a);}

.card.card-image {
	border: 0;
	overflow: hidden;
}

.card.card-image img {
	aspect-ratio: 16 / 10;
	object-fit: cover;
}

.card .card-content {padding: var(--u);}

.badge {
	background: var(--brown-a);
	border-radius: var(--u-lg);
	padding: var(--u-sm) var(--u);
	color: var(--brown);
	display: inline-flex;
	align-items: center;
}

.badge img {
	width: var(--u-me);
	margin-right: var(--u-xs);
}

section {
	padding: var(--u-xxl) 0;
	position: relative;
}

.floating-icon {
	position: absolute;
	width: calc(var(--u-xxl) * 2);
	height: calc(var(--u-xxl) * 2);
	left: var(--u-xxl);
	z-index: 9;
}

.floating-icon.fi-right {
	left: initial;
	right: var(--u-xxl);
}

.floating-icon.fi-top {top: var(--u-xxxl);}

.floating-icon.fi-bottom {bottom: var(--u-xxl);}

.floating-icon .fi-background {
	background-image: url('../img/visuels/visuel-mask-brown.svg');
	background-size: contain;
	background-position: center;
	background-repeat: no-repeat;
}

.floating-icon.fi-green .fi-background {
	background-image: url('../img/visuels/visuel-mask-green.svg');
}

.floating-icon img {
	padding: var(--u-me);
	width: 100%;
}

/*** GRID SYSTEM ***/

.g-1, .g-2, .g-3, .g-4, .g-5, .g-6 {gap: initial;}

.grid {
	display: flex;
	flex-wrap: wrap;
	margin: var(--u-sm-n);
	justify-content: center;
	transition: var(--transition);
}

.grid.g-small-margin {margin: var(--u-sm-n);}

.grid.narrowed {
	margin-left: 8.33%;
	margin-right: 8.33%;
}

.grid.centered {align-items: center;}

.grid.g-left {justify-content: flex-start;}

.grid-item {
	margin: var(--u-sm);
	transition: var(--transition);
}

.grid.g-small-margin .grid-item {margin: var(--u-sm);}

.grid-item.empty {
	width: calc(100% - var(--u));
	background: var(--white-lt);
	padding: var(--u-xxl);
	text-align: center;
	font-style: italic;
	color: var(--grey-dk);
	border-radius: var(--u-sm);
}

.grid.g-2 > .grid-item {width: calc(50% - var(--u));}

.grid.g-2.g-img > .grid-item.gi-img {width: calc(33.33% - var(--u));}

.grid.g-2.g-img > .grid-item.gi-img:first-child {padding-right: var(--u);}

.grid.g-2.g-img > .grid-item.gi-img:last-child {padding-left: var(--u);}

.grid.g-2.g-img > .grid-item:not(.gi-img) {width: calc(66.66% - var(--u));}

.grid.g-3 > .grid-item {width: calc(33.33% - var(--u));}

.grid.g-4 > .grid-item {width: calc(25% - var(--u));}

.grid.g-5 > .grid-item {width: calc(20% - var(--u));}

.grid.g-6 > .grid-item {width: calc(16.66% - var(--u));}

.grid.g-small-margin.g-2 > .grid-item {width: calc(50% - var(--u));}

.grid.g-small-margin.g-2.g-img > .grid-item.gi-img {width: calc(33.33% - var(--u));}

.grid.g-small-margin.g-2.g-img > .grid-item.gi-img:first-child {padding-right: var(--u);}

.grid.g-small-margin.g-2.g-img > .grid-item.gi-img:last-child {padding-left: var(--u);}

.grid.g-small-margin.g-2.g-img > .grid-item:not(.gi-img) {width: calc(66.66% - var(--u));}

.grid.g-small-margin.g-3 > .grid-item {width: calc(33.33% - var(--u));}

.grid.g-small-margin.g-4 > .grid-item {width: calc(25% - var(--u));}

.grid.g-small-margin.g-5 > .grid-item {width: calc(20% - var(--u));}

.grid.g-small-margin.g-6 > .grid-item {width: calc(16.66% - var(--u));}

.grid.grid-list {
	flex-direction: column;
	margin: 0;
}

.grid.grid-list > .grid-item {
	width: 100%;
	margin: 0;
}

/*** FORMS ***/

/* input, textarea {
	background: transparent !important;
	border: var(--border) !important;
	border-radius: var(--u-sm) !important;
	transition: var(--transition);
	padding: var(--u-sm) !important;
	padding-top: var(--u) !important;
	font-family: 'Montserrat', sans-serif;
}

input:hover, textarea:hover {border-color: var(--green) !important;}

input:focus, textarea:focus {border-color: var(--brown) !important;}

textarea {
	min-height: 100px;
	font-size: 1rem;
}

input + label, textarea + label {
	top: var(--u-sm) !important;
	left: var(--u-sm) !important;
}

input:focus + label, textarea:focus + label {color: var(--brown) !important;} */

/*** HEADER ***/

#loader {
	position: fixed;
	height: 100%;
	width: 100%;
	background: var(--white);
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 99999;
}

#loader img {
	width: 300px;
	animation: animLoader 1s;
}

@keyframes animLoader {
	0% {transform: scale(.5);}
	100% {transform: scale(1);}
}

header {
	position: relative;
	z-index: 20;
}

#pre-header {
	background: var(--green);
	padding: var(--u);
	position: relative;
	z-index: 9;
	color: var(--white);
}

#pre-header-content {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

#pre-header-content ul {
	display: flex;
	padding-right: 210px;
}

#pre-header-content ul li {list-style-type: none;}

#pre-header-content ul li:not(.last) {margin-right: var(--u);}

#pre-header-content ul li a {
	color: var(--white);
	display: flex;
	align-items: center;
	text-decoration: none;
}

#pre-header-content ul li a:hover span:not(.emoji) {
	text-decoration: underline;
}

#pre-header-content ul li a .feather {
	width: var(--u);
	min-width: var(--u);
	margin-right: var(--u-sm);
}

#pre-header-content ul li.last a {
	position: absolute;
	right: calc(var(--u-lg) + var(--u-xs));
	width: 114px;
	top: var(--u);
}

#pre-header-content ul li:not(.last) span {white-space: nowrap;}

#pre-header-content ul li.last a span.emoji {
	width: var(--u);
	min-width: var(--u);
	height: var(--u);
	font-size: 2rem;
	margin-right: var(--u-sm);
}

#pre-header-content ul li.last a span.emoji img {
	width: 100% !important;
	height: 100% !important;
}

#pre-header-content ul li.last a:hover span:not(.emoji) {text-decoration: underline;}

#pre-header-content img:not(.emoji) {
	position: absolute;
	width: 220px;
	z-index: -1;
	right: 0;
	top: 0;
}

#header-sticky-wrapper {
	z-index: 99;
	min-height: 159px
}

#header-sticky-wrapper.is-sticky {min-height: 101px;}

#header {
	padding: var(--u);
	border-bottom: var(--border);
	background: var(--white);
	transition: var(--transition);
}

.is-sticky #header {padding: 0 var(--u);}

body.admin-bar .is-sticky #header {top: 32px !important;}

#header-content {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.is-sticky #header-content {height: 100px;}

#header-content #header-logo {
	position: relative;
	margin: calc(var(--u-n) - 6px);
	margin-left: 0;
	transition: var(--transition-bezier);
}

.is-sticky #header-content #header-logo {
	transform: translateY(-100px);
	opacity: 0;
}

#header-content #header-logo-sticky {
	position: absolute;
	opacity: 0;
	margin-left: var(--u);
	transition: var(--transition);
}

.is-sticky #header-content #header-logo-sticky {opacity: 1;}

#header-content #header-logo::before, #header-content #header-logo::after {
	content: '';
	display: block;
	position: absolute;
	aspect-ratio: cos(30deg);
	clip-path: polygon(-50% 50%,50% 100%,150% 50%,50% 0);
	left: 50%;
	top: 50%;
	transform: translate(-50%,-50%);
}

#header-content #header-logo::before {
	width: calc(100% + 2px);
	background: var(--grey-a-w);
}

#header-content #header-logo::after {
	width: 100%;
	z-index: 1;
	background: var(--white);
}

#header-content #header-logo img {
	position: relative;
	z-index: 2;
	padding: var(--u);
	padding-top: var(--u-lg);
	padding-bottom: 0;
}

#header-content ul {
	display: flex;
	align-items: center;
	margin: 0;
}

#header-content ul li {
	list-style-type: none;
	position: relative;
}

#header-content ul li:not(:last-child) {margin-right: var(--u);}

#header-content ul li.active {position: relative;}

#header-content ul li:not(.header-sticky-links)::after {
	content: '';
	display: block;
	position: absolute;
	background: var(--brown);
	height: var(--green);
	width: calc(100% - var(--u-sm));
	height: var(--u-xs);
	border-radius: var(--u);
	bottom: var(--u-sm-n);
	opacity: 0;
	left: var(--u-sm);
	transition: var(--transition-bezier);
	transform: translateY(var(--u-sm-n));
}

#header-content ul li.active::after {
	transform: translateY(0);
	background: var(--green);
	opacity: 1;
}

#header-content ul li:not(.active):hover::after {
	transform: translateY(0);
	background: var(--brown);
	opacity: 1;
}

#header-content ul li a {
	font-size: 1.2rem;
	color: var(--grey);
	display: flex;
	align-items: center;
	position: relative;
	transition: var(--transition);
}

.is-sticky #header-content ul li a {font-size: 1rem;}

#header-content ul li a img {
	width: var(--u-lg);
	margin-right: var(--u-xs);
}

#header-content ul li.header-sticky-links {
	max-width: 0;
	overflow: hidden;
	transition: var(--transition);
	display: flex;
	gap: var(--u-xs);
	opacity: 0;
}

.is-sticky #header-content ul li.header-sticky-links {
	align-self: center;
	overflow: visible;
	max-width: 500px;
	opacity: 1;
}

#header-content ul li.header-sticky-links a:first-child {
	border-top-right-radius: var(--u-sm);
	border-bottom-right-radius: var(--u-sm);
}

#header-content ul li.header-sticky-links a:not(:first-child, :last-child) {
	white-space: nowrap;
	border-radius: var(--u-sm);
}

#header-content ul li.header-sticky-links a:last-child {
	border-top-left-radius: var(--u-sm);
	border-bottom-left-radius: var(--u-sm);
}

header .button-collapse {display: none;}

header .button-collapse img {width: var(--u-lg);}

.side-nav {border-radius: 0 var(--u) var(--u) 0;}

.side-nav #side-nav-logo {
	border-bottom: var(--border);
	margin-bottom: var(--u-sm);
	position: relative;
}

.side-nav #side-nav-logo a {padding: var(--u-lg) var(--u);}

.side-nav #side-nav-logo a img {width: 80%;}

.side-nav #side-nav-close {
	position: absolute;
	background: var(--brown-a) !important;
	border-radius: 50%;
	width: var(--u-lg);
	height: var(--u-lg);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 !important;
	top: 50%;
	transform: translateY(-50%);
	right: var(--u);
}

.side-nav #side-nav-close:hover {background: var(--brown-a) !important;}

.side-nav #side-nav-close img {
	width: var(--u);
	height: var(--u);
}

.side-nav li {height: auto;}

.side-nav li a {
	height: auto;
	display: flex;
	align-items: center;
	padding: var(--u-sm) var(--u);
}

.side-nav li.active, .side-nav li a:not(.btn):hover {background: transparent !important;}

.side-nav li a span {
	white-space: normal;
	font-size: 1.2rem;
}

.side-nav li a img {width: var(--u-lg);}

.side-nav li a.btn {margin: var(--u);}

.side-nav li.divider {
	border-top: var(--border);
	margin: var(--u-lg);
	margin-top: var(--u);
}

/*** HOME ***/

#home-intro {position: relative;}

#home-intro .visuel.visuel-intro {
	position: absolute;
	bottom: var(--u-xxl-n);
}

.hi-carousel {
	width: 50%;
	position: absolute;
	right: 0;
	top: 0;
	overflow: hidden;
}

.hi-carousel-hero-item img {
	aspect-ratio: 1;
	object-fit: cover;
}

.hi-carousel .visuel {
	position: absolute;
	height: 101%;
	width: 101%;
	bottom: -1px;
	left: -1px;
	object-fit: cover;
	object-position: left;
}

.visuel-maison {
	position: relative;
	z-index: 0;
}

#home-services {
	position: relative;
	background: var(--brown-a-w);
	border-radius: 0 0 var(--u-xl) var(--u-xl);
	z-index: 2;
}

#home-services #home-services-logo {width: 50%;}

#mask-hexa-container {
	position: relative;
	aspect-ratio: 1;
}

#mask-hexa {
	position: absolute;
	top: 50%;
	left: calc(var(--u-xxl-n) * 2);
	transform: translateY(-50%) rotate(-20deg);
	width: 120%;
	-webkit-mask:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" version="1.1" viewBox="0 0 711.81 809.85"><path d="m0,222.46c0-14.29,7.62-27.49,19.99-34.64L335.9,5.36c12.38-7.15,27.63-7.15,40.01,0l315.9,182.46c12.37,7.15,19.99,20.35,19.99,34.64v364.94c0,14.29-7.62,27.49-19.99,34.64l-315.9,182.45c-12.38,7.15-27.63,7.15-40.01,0L19.99,622.03C7.62,614.88,0,601.68,0,587.39V222.46Z"></path></svg>' ) center/contain no-repeat
}

#mask-hexa img {
	transform: rotate(20deg);
	aspect-ratio: 1;
	object-fit: cover;
}

#home-services #home-services-content {margin-top: var(--u-xl-n);}

#home-services .home-services-item {
	color: var(--brown);
	display: flex;
	align-items: center;
}

#home-services .home-services-item:not(:last-child) {
	margin-bottom: var(--u-lg);
	padding-bottom: var(--u-lg);
	border-bottom: var(--border-b);
}

#home-services .home-services-item img {
	width: var(--u-xxl);
	height: auto;
	min-width: var(--u-xxl);
	max-width: var(--u-xxl);
	margin-right: var(--u-sm);
}

#home-services .home-services-item h5 {
	margin-top: 0;
/*	width: 40%;*/
	padding-right: var(--u);
}

/*#home-services .home-services-item div {width: 60%;}*/

#home-realisations {
	position: relative;
	z-index: 1;
/*	margin-top: var(--u-xl-n);*/
}

#hr-carousel::before {
	content: '';
	display: block;
	position: absolute;
	width: 100%;
	height: 100%;
	background: var(--white);
	background: linear-gradient(0deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 33%);
	z-index: 1;
	pointer-events: none;
}

.hr-carousel-hero {
	border-radius: var(--u-lg);
	overflow: hidden;
}

#home-realisations #hr-carousel {position: relative;}

#home-realisations #hr-carousel .visuel {
	position: absolute;
	bottom: 0;
	left: 0;
	pointer-events: none;
}

#home-realisations #hr-carousel .hr-carousel-hero-item img {
	width: 100%;
	height: auto;
	aspect-ratio: 20 / 10;
	object-fit: cover;
}

#home-realisations .hr-carousel-nav {
	margin-top: var(--u-xl-n);
	z-index: 9;
}

#home-realisations .hr-carousel-nav::before, #home-realisations .hr-carousel-nav::after {
	content: '';
	display: block;
	position: absolute;
	left: 0;
	top: 0;
	width: 10%;
	height: 100%;
	z-index: 1;
	background: var(--white);
	background: linear-gradient(90deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 100%);
}

#home-realisations .hr-carousel-nav::after {
	left: initial;
	right: 0;
	background: var(--white);
	background: linear-gradient(-90deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 100%);
}

#home-realisations .hr-carousel-nav .slick-list {overflow: visible;}

/*#home-realisations .hr-carousel-nav .slick-track {margin-left: var(--u-sm-n);}*/

/*#home-realisations .hr-carousel-nav .col .card {margin: 0 var(--u-sm);}*/

#home-slogan-container {
	background: var(--green-a);
	border-radius: var(--u-xl);
	padding: var(--u-xxl);
}

#home-slogan-container h2 {font-size: 3.5rem;}

.pastille {
	display: inline-flex;
	width: calc(var(--u-xl) + var(--u-xs));
	height: calc(var(--u-lg) + var(--u-xs));
	border-radius: var(--u-lg);
	margin-top: var(--u-xs-n);
	object-fit: cover;
	transition-property: transform;
	transition-duration: 0.5s;
	transition-timing-function: cubic-bezier(0.68, -0.55, 0.27, 1.55);
}

.pastille:hover {transform: scale(1.5);}

.carousel-partners::before, .carousel-partners::after {
	content: '';
	display: block;
	position: absolute;
	left: 0;
	top: 0;
	width: 10%;
	height: 100%;
	z-index: 1;
	background: var(--white);
	background: linear-gradient(90deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 100%);
	pointer-events: none;
}

.carousel-partners::after {
	left: initial;
	right: 0;
	background: var(--white);
	background: linear-gradient(-90deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 100%);
}

.carousel-partners .slick-list {overflow: visible;}

/*.carousel-partners .slick-track .col .card {margin-left: var(--un-sm-n);}*/

.carousel-partners .slick-list .col .card {margin: 0 var(--u-sm);}

#home-valeurs {
	background: var(--brown-a);
	border-radius: var(--u-xl) var(--u-xl) 0 0;
}

/*#home-valeurs .card {height: 100%;}*/

#home-valeurs .card img {
	background: var(--brown-a);
	height: var(--u-xxl);
	width: var(--u-xxl);
	padding: var(--u);
	border-radius: var(--u-sm);
}

/*** PAGES ***/

.page-title {
	display: flex;
	align-items: center;
}

#psi-carousel-container {
	width: 40%;
	position: absolute;
	right: 0;
	top: 0;
	overflow: hidden;
}

#psi-carousel-container .psi-carousel-item img {
	aspect-ratio: 1;
	object-fit: cover;
}

#psi-carousel-container .visuel {
	position: absolute;
	height: 101%;
	width: 101%;
	bottom: -1px;
	left: -1px;
	object-fit: cover;
	object-position: left;
}

.visuel-maison {
	position: relative;
	z-index: 0;
}

.page-title img {
	width: calc(var(--u-xxl) * 2);
	margin-right: var(--u-sm);
	height: auto;
}

.page-title h1 {margin-top: 0;}

.page-content {
	background: var(--brown-a);
	border-radius: var(--u-xl) var(--u-xl) 0 0;
}

.page-content p, .page-content li {font-size: 1.1rem;}

#home-realisations.page-realisations {
	padding-top: 0;
	margin-top: var(--u-xl-n);
	background: var(--brown-a-w);
	z-index: 0 !important;
}

#home-realisations.page-realisations #hr-carousel::before {
	background: var(--brown);
	background: linear-gradient(0deg, rgba(246, 235, 231, 1) 0%, rgba(246, 235, 231, 0) 33%);
}

#home-realisations.page-realisations .hr-carousel-nav::before {
	background: var(--brown);
	background: linear-gradient(90deg, rgba(246, 235, 231, 1) 0%, rgba(246, 235, 231, 0) 100%);
}

#home-realisations.page-realisations .hr-carousel-nav::after {
	background: var(--brown);
	background: linear-gradient(-90deg, rgba(246, 235, 231, 1) 0%, rgba(246, 235, 231, 0) 100%);
}

#page-title {
	background: var(--brown-a);
	background: linear-gradient(-90deg, rgba(246, 235, 231, 1) 0%, rgba(246, 235, 231, 0) 33%);
	border-radius: 0 0 var(--u-xl) var(--u-xl);
	border-bottom: var(--border);
}

#page-title h1 {
	font-weight: 600;
	color: var(--brown);
}

/*** WP BLOCKS ***/

.wp-content h2, .wp-content h4 {
	color: var(--brown);
}

.wp-content h3, .wp-content h5 {
	color: var(--green);
}

.wp-content p, .wp-content li {color: var(--brown);}

.wp-content .wp-block-list {
	padding-left: var(--u);
}

.wp-content .wp-block-list li {
	list-style-type: disc;
}

.wp-content .wp-block-list li:not(:last-child) {
	margin-bottom: var(--u-sm);
}

.wp-content p a, .wp-content li a {
	color: var(--green);
	font-weight: 600;
}

.wp-content h2 a:hover, .wp-content h3 a:hover, .wp-content h4 a:hover, .wp-content h5 a:hover, .wp-content p a:hover, .wp-content li a:hover {
	text-decoration: underline !important;
}

blockquote {
	background: var(--green-a);
	padding: var(--u);
	border-radius: var(--u);
	border-left: 0;
	color: var(--green);
	font-size: 1.2rem;
	white-space: pre-line;
	text-align: justify;
}

.list-images {padding: 0;}

.list-images li {
	display: flex;
	align-items: center;
	margin-left: 0;
	color: var(--grey);
}

.list-images li:not(:last-child) {margin-bottom: var(--u-sm);}

.list-images span {
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--green-a);
	height: var(--u-lg);
	width: var(--u-lg);
	min-width: var(--u-lg);
	border-radius: var(--u-sm);
	margin-right: var(--u-sm);
}

.wp-content figure {}

.wp-content figure img {
	border-radius: var(--u);
}

figcaption {

}

figcaption img {border-radius: var(--u) var(--u) var(--u) 0;}

figcaption legend {
	padding-top: var(--u);
	padding-left: var(--u);
	border-left: 1px solid var(--brown);
	color: var(--brown);
	font-style: italic;
}

.wp-content .wp-block-separator {
	background: var(--brown-a);
	border: 0;
	margin: var(--u-lg) 0;
}

.wp-block-group.has-background {
	padding: var(--u);
	border-radius: var(--u);
}

/*** FOOTER ***/

#pre-footer-cta {
	height: var(--u-xl);
	background: var(--brown-a);
	border-radius: var(--u-xl) var(--u-xl) 0 0;
}

#footer-cta {
	position: relative;
/*	background: var(--brown-a);*/
}

#footer-cta .visuel:not(:first-child) {
	position: absolute;
	top: 0;
	left: 0;
}

#footer-cta-content {
/*	position: absolute;*/
/*	top: 75%;*/
/*	left: 50%;*/
/*	transform: translate(-50%,-50%);*/
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	width: 100%;
	margin-top: -600px;
}

#footer-cta-content img {
/*	position: absolute;*/
	width: calc(var(--u-xxl) * 6);
	top: calc(var(--u-xxl-n) * 4);
/*	left: 50%;*/
/*	transform: translateX(-50%);*/
}

#footer {
	background-image: url('../img/visuels/visuel-6.svg');
	background-repeat: no-repeat;
	background-size: cover;
	background-position: top;
	padding: calc(var(--u-xxl) + var(--u-xl)) 25% var(--u-xl) 10%;
}

#footer-content {display: flex;}

#footer-logo {
	display: block;
	min-width: 200px;
	max-width: 400px;
	margin: 0 auto;
}

#footer-content > div {margin-right: var(--u-xl);}

#footer-content > div:last-child {margin-right: 0;}

#footer-content ul {padding-left: 0;}

#footer-content ul li {list-style-type: none;}

#footer-content ul li:not(:last-child) {margin-bottom: var(--u-sm);}

#footer-content ul li a {
	display: flex;
	align-items: center;
	font-size: 1.1rem;
	color: var(--white);
}

#footer-content ul li a:hover {text-decoration: underline;}

#footer-content ul li a .feather, #footer-content ul li a img {
	margin-right: var(--u-xs);
	width: calc(var(--u-me) - var(--u-xs));
}

#footer-content .footer-contact li a {text-decoration: none !important;}

#footer-content .footer-contact li a:hover span:not(.emoji) {text-decoration: underline;}

#footer-rge img {
	margin-top: var(--u-lg);
	width: calc(var(--u-xxl) + var(--u-lg));
}

/*** JS ***/

.modal-overlay {background: var(--white);}

.modal {
	background: rgba(255,255,255,.66);
	backdrop-filter: blur(20px);
	box-shadow: var(--shadow-lg);
	border: var(--border);
}

.modal .modal-content {padding: var(--u-lg);}

.slick-slider {opacity: 0;}

.slick-slider.loaded {
	opacity: 1;
	animation: animSlickTrack 2s;
}

@keyframes animSlickTrack {
	0% {opacity: 0;}
	50% {opacity: 0;}
	100% {opacity: 1;}
}

.slick-arrow {
	height: calc(var(--u-lg) + var(--u));
	width: calc(var(--u-lg) + var(--u));
	border-radius: var(--u-lg);
	border: 0;
	background: var(--green);
	position: absolute;
	z-index: 9;
	top: 50%;
	transform: translateY(-50%);
	left: var(--u-xl);
	cursor: pointer;
	transition: var(--transition);
	display: flex;
	align-items: center;
	justify-content: center;
}

.slick-arrow:hover {
	background: var(--green-h);
	box-shadow: 0 5px 20px var(--green-h);
}

.slick-arrow.slick-next {
	left: initial;
	right: var(--u-xl);
}

.slick-arrow svg {
	width: var(--u-me);
	height: var(--me);
	stroke: var(--white);
}

.wp-content .ff_conv_section_wrapper.ff_conv_layout_media_right_full {
	min-height: 500px !important;
}

.wp-content .ffc_conv_wrapper.ffc_inline_form {
	border-radius: var(--u) !important;
	border: var(--border) !important;
	overflow: hidden !important;
}

.wp-content .ffc_inline_form.ffc_conv_wrapper .ff_conv_app {background: transparent !important;}

.wp-content .ff_conv_app_3 .q-inner .o-btn-action {
	border-radius: var(--u-xl) !important;
	font-weight: 600 !important;
	outline: none !important;
}

.wp-content .ff_conv_input .o-btn-action::after {border-radius: var(--u-xl) !important;}

.wp-content .ff_conv_app_3 .q-inner .o-btn-action, .wp-content .ff_conv_app_3 .footer-inner-wrap .f-nav, .wp-content .ff_conv_app_3 .vff-footer .f-progress-bar-inner, .wp-content .ff_conv_app_3 .f-answer .f-radios-wrap ul li.f-selected .f-key, .wp-content .ff_conv_app_3 .f-answer .f-radios-wrap ul li.f-selected .f-key-hint {background: var(--green) !important;}

.wp-content .ff_conv_app_3 .f-answer .f-radios-wrap ul li.f-selected .f-key {border-color: var(--brown) !important}

.wp-content .ff_conv_app_3 .f-enter .f-enter-desc, .wp-content .ff_conv_app_3 .ffc-counter-div span, .wp-content .ff_conv_app_3 .fh2 .f-text, .wp-content .ff_conv_app_3 .f-label-wrap, .wp-content .ff_conv_app_3 .f-answer {color: var(--brown) !important;}

.wp-content .ff_conv_app_3 .f-answer input, .wp-content .ff_conv_app_3 .f-answer textarea {
	color: var(--brown) !important;
	box-shadow: var(--brown-a) 0px 2px !important;
}

.wp-content .ff_conv_app_3 .f-answer input:focus, .wp-content .ff_conv_app_3 .f-answer textarea:focus {
	border-color: var(--green);
	box-shadow: var(--green) 0px 2px !important;
}

.wp-content .ff_conv_app_3 .f-answer .f-radios-wrap ul li:focus {
	background: var(--green-a);
}

.wp-content .ff_conv_app_3 .f-answer .f-radios-wrap ul li:hover, .wp-content .ff_conv_app_3 .f-label-wrap .f-key-hint, .wp-content .vff ul.f-radios li span.f-key, .wp-content .ff_conv_app_3 .f-label-wrap .f-key {
	border-color: var(--brown) !important;
	border-width: 2px !important;
}

.wp-content .ff_conv_app_3 .f-answer input::placeholder, .wp-content .ff_conv_app_3 .f-answer textarea::placeholder {color: #9491ac !important;}

.wp-content .ff_conv_app_3 .ffc-counter-div .counter-icon-span svg, .wp-content .ff_conv_app_3 .f-answer .f-radios-wrap ul li.f-selected svg {fill: var(--brown) !important;}

.wp-content .ff_conv_app_3 .vff-footer .f-progress-bar {background: var(--green-a) !important;}

.wp-content .vff .f-invalid, .wp-content .vff .text-alert, .wp-content .vff .f-required {color: var(--error) !important;}

.wp-content .ff_conv_app_3 .f-answer .f-radios-wrap ul li {
	background: var(--brown-a) !important;
	border: var(--border) !important;
}

.wp-content .ff-default .ff-el-form-control {
	border-radius: var(--u-sm) !important;
	border: var(--border) !important;
	font-family: 'Montserrat', sans-serif !important;	
	font-weight: 500;
	color: var(--grey);
}

.wp-content .ff-default .ff-el-form-control:focus {border-color: var(--brown) !important;}

.wp-content .ff-el-group.ff-el-is-error .ff-el-form-control {border-color: var(--error) !important;}

.wp-content .ff-el-group.ff-el-is-error .error.text-danger, .wp-content .fluentform .ff-el-input--label.ff-el-is-required.asterisk-right label::after {
	background: transparent !important;
	color: var(--error) !important;
}

.wp-content form.fluent_form_1 .ff-btn-submit:not(.ff_btn_no_style) {
	background: var(--brown) !important;
	font-weight: 600 !important;
	border-radius: var(--u-lg) !important;
	font-size: 1.25rem;
}

#cookie-notice {
	border-radius: var(--u) var(--u) 0 0;
	padding: var(--u);
}

#cookie-notice.cookie-notice-hidden {display: none;}

#cookie-notice #cookie-notice-container {
	display: flex;
	align-items: center;
	gap: var(--u);
}

/*** CHEATS ***/

.margin-u {margin: var(--u) 0 !important;}
.margin-u-xs {margin: var(--u-xs) 0 !important;}
.margin-u-sm {margin: var(--u-sm) 0 !important;}
.margin-u-me {margin: var(--u-me) 0 !important;}
.margin-u-lg {margin: var(--u-lg) 0 !important;}
.margin-u-xl {margin: var(--u-xl) 0 !important;}
.margin-t-u {margin-top: var(--u) !important;}
.margin-b-u {margin-bottom: var(--u) !important;}
.margin-t-u-xs {margin-top: var(--u-xs) !important;}
.margin-t-u-sm {margin-top: var(--u-sm) !important;}
.margin-t-u-me {margin-top: var(--u-me) !important;}
.margin-t-u-lg {margin-top: var(--u-lg) !important;}
.margin-t-u-xl {margin-top: var(--u-xl) !important;}
.margin-t-u-xxl {margin-top: var(--u-xxl) !important;}
.margin-b-u-xs {margin-bottom: var(--u-xs) !important;}
.margin-b-u-sm {margin-bottom: var(--u-sm) !important;}
.margin-b-u-me {margin-bottom: var(--u-me) !important;}
.margin-b-u-lg {margin-bottom: var(--u-lg) !important;}
.margin-b-u-xl {margin-bottom: var(--u-xl) !important;}
.margin-b-u-xxl {margin-bottom: var(--u-xxl) !important;}
.margin-u-n {margin: var(--u-n) 0 !important;}
.margin-t-u-n {margin-top: var(--u-n) !important;}
.margin-b-u-n {margin-bottom: var(--u-n) !important;}
.margin-t-u-xs-n {margin-top: var(--u-xs-n) !important;}
.margin-t-u-sm-n {margin-top: var(--u-sm-n) !important;}
.margin-t-u-me-n {margin-top: var(--u-me-n) !important;}
.margin-t-u-lg-n {margin-top: var(--u-lg-n) !important;}
.margin-t-u-xl-n {margin-top: var(--u-xl-n) !important;}
.margin-t-u-xxl-n {margin-top: var(--u-xxl-n) !important;}
.margin-b-u-xs-n {margin-bottom: var(--u-xs-n) !important;}
.margin-b-u-sm-n {margin-bottom: var(--u-sm-n) !important;}
.margin-b-u-me-n {margin-bottom: var(--u-me-n) !important;}
.margin-b-u-lg-n {margin-bottom: var(--u-lg-n) !important;}
.margin-b-u-xl-n {margin-bottom: var(--u-xl-n) !important;}
.margin-b-u-xxl-n {margin-bottom: var(--u-xxl-n) !important;}

.no-margin {margin: 0 !important;}
.no-margin-t {margin-top: 0 !important;}
.no-margin-b {margin-bottom: 0 !important;}

.padding-u {padding: var(--u) 0 !important;}
.padding-u-xs {padding: var(--u-xs) 0 !important;}
.padding-u-sm {padding: var(--u-sm) 0 !important;}
.padding-u-me {padding: var(--u-me) 0 !important;}
.padding-u-lg {padding: var(--u-lg) 0 !important;}
.padding-u-xl {padding: var(--u-xl) 0 !important;}
.padding-t-u {padding-top: var(--u) !important;}
.padding-b-u {padding-bottom: var(--u) !important;}
.padding-t-u-xs {padding-top: var(--u-xs) !important;}
.padding-t-u-sm {padding-top: var(--u-sm) !important;}
.padding-t-u-me {padding-top: var(--u-me) !important;}
.padding-t-u-lg {padding-top: var(--u-lg) !important;}
.padding-t-u-xl {padding-top: var(--u-xl) !important;}
.padding-t-u-xxl {padding-top: var(--u-xxl) !important;}
.padding-b-u-xs {padding-bottom: var(--u-xs) !important;}
.padding-b-u-sm {padding-bottom: var(--u-sm) !important;}
.padding-b-u-me {padding-bottom: var(--u-me) !important;}
.padding-b-u-lg {padding-bottom: var(--u-lg) !important;}
.padding-b-u-xl {padding-bottom: var(--u-xl) !important;}
.padding-b-u-xxl {padding-bottom: var(--u-xxl) !important;}
.padding-u-n {padding: var(--u-n) 0 !important;}
.padding-t-u-n {padding-top: var(--u-n) !important;}
.padding-b-u-n {padding-bottom: var(--u-n) !important;}
.padding-t-u-xs-n {padding-top: var(--u-xs-n) !important;}
.padding-t-u-sm-n {padding-top: var(--u-sm-n) !important;}
.padding-t-u-me-n {padding-top: var(--u-me-n) !important;}
.padding-t-u-lg-n {padding-top: var(--u-lg-n) !important;}
.padding-t-u-xl-n {padding-top: var(--u-xl-n) !important;}
.padding-t-u-xxl-n {padding-top: var(--u-xxl-n) !important;}
.padding-b-u-xs-n {padding-bottom: var(--u-xs-n) !important;}
.padding-b-u-sm-n {padding-bottom: var(--u-sm-n) !important;}
.padding-b-u-me-n {padding-bottom: var(--u-me-n) !important;}
.padding-b-u-lg-n {padding-bottom: var(--u-lg-n) !important;}
.padding-b-u-xl-n {padding-bottom: var(--u-xl-n) !important;}
.padding-b-u-xxl-n {padding-bottom: var(--u-xxl-n) !important;}

.no-padding {padding: 0 !important;}
.no-padding-t {padding-top: 0 !important;}
.no-padding-b {padding-bottom: 0 !important;} 