@import url('https://use.typekit.net/gsx4vpk.css');


.MenuBox { display:none; }


#Choix6Suite.pointille .fl-row-content-wrap:before {
	bottom: -100vh;
}

* {
	box-sizing: border-box
}

.single main.Flix {
	position: relative;
	overflow: visible !important;
}

strong {
	font-weight: 700;
}

body ::-webkit-scrollbar,
html ::-webkit-scrollbar {
	width: 6px;
	background-color: #000;
}

body ::-webkit-scrollbar-thumb,
html ::-webkit-scrollbar-thumb {
	-webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, .3);
	background-color: #2f8547;
}

body ::-webkit-scrollbar-track,
html ::-webkit-scrollbar-track {
	background-color: #000;
}

body,
html {
	margin: 0;
	padding: 0
}

body {
	font-family: "forma-djr-micro", sans-serif;
	font-display: swap;
	color: #040E27;
	margin: 0;
	padding: 0;
	font-weight: 400;
	font-size: 14px;
}

section.SingleReaExp {
    margin: 0 10px;
    margin-bottom: 0;
    padding-bottom: 40px;
}

.Flix {
	overflow: hidden
}

a {
	color: #040E27;
	text-decoration: none;
}

a:hover {
	color: #308446;
	text-decoration: underline;
}

.btn {
	color: #fff;
	padding: 15px 25px;
	position: relative;
	text-decoration: none;
	z-index: 0;
	display: inline-flex;
	line-height: 1.3em;
	gap: 10px;
	align-items: center;
	transition: cubic-bezier(0.4, 0, 1, 1) 0.2s;
	box-shadow: inset 0px 0 0 0 #0a1428;
	border: 1px solid #0a1428;
	background: #0a1428;
	font-weight: 400;
	border-radius: 29px;
	padding-right: 40px;
}

.btn:hover {
	background: transparent !important;
	color: #fff !important;
	text-decoration: none;
	box-shadow: inset 400px 0 0 0 #0a1428;
	border: 1px solid #0a1428;
}

.flecheico {
	padding-right: 40px;
}

.btn.flecheico {
	box-shadow: inset 0px 0 0 0 #fff;
	padding-right: 40px;
}

.btn.flecheico:hover {
	box-shadow: inset 450px 0 0 0 #fff;
	border: 1px solid #fff;
	color: #0a1428 !important;
}

.btn.flecheico:hover img {
	filter: brightness(0) saturate(100%) invert(7%) sepia(15%) saturate(3984%) hue-rotate(190deg) brightness(96%) contrast(99%);
}

.btn strong {
	font-weight: normal;
}

a.btn.transpa {
	border: 1px solid rgb(255 255 255 / 50%);
	background: transparent;
}

.btn:hover {
	color: #000;
}

.btn.flecheico:after {
	background: url(/wp-content/uploads/2025/08/FLECHE-DROITE-PETIT-BLANC.svg);
	content: "";
	width: 10px;
	height: 11px;
	margin-top: 3px;
	background-size: contain !important;
	background-repeat: no-repeat;
	position: absolute;
	right: 16px;
}

.btn.flecheico:hover:after {
	filter: brightness(0) saturate(100%) invert(7%) sepia(18%) saturate(3597%) hue-rotate(191deg) brightness(95%) contrast(99%);
}


.wp-txt-center {
	text-align: center;
	line-height: 1.3em
}

.margin20 {
	margin-top: 20px;
	margin-bottom: 20px
}

.margin30 {
	margin-top: 30px;
	margin-bottom: 30px
}

.margin40 {
	margin-top: 40px;
	margin-bottom: 40px
}

.margin50 {
	margin-top: 50px;
	margin-bottom: 50px
}

.margin60 {
	margin-top: 60px;
	margin-bottom: 60px
}

.margin70 {
	margin-top: 70px;
	margin-bottom: 70px
}

.margin80 {
	margin-top: 80px;
	margin-bottom: 80px
}

.margin90 {
	margin-top: 90px;
	margin-bottom: 90px
}

.margin100 {
	margin-top: 100px;
	margin-bottom: 100px
}

.padding20 {
	padding-top: 20px !important;
	padding-bottom: 20px !important
}

.padding30 {
	padding-top: 30px !important;
	padding-bottom: 30px !important
}

.padding40 {
	padding-top: 40px !important;
	padding-bottom: 40px !important
}

.padding50 {
	padding-top: 50px !important;
	padding-bottom: 50px !important
}

.padding60 {
	padding-top: 60px !important;
	padding-bottom: 60px !important
}

.padding70 {
	padding-top: 70px !important;
	padding-bottom: 70px !important
}

.padding80 {
	padding-top: 80px !important;
	padding-bottom: 80px !important
}

.padding90 {
	padding-top: 90px !important;
	padding-bottom: 90px !important
}

.padding100 {
	padding-top: 100px !important;
	padding-bottom: 100px !important
}

.texteblanc {
	color: #fff
}

p {
	line-height: 1.4em;
	margin-bottom: 5px;
	margin-top: 5px;
}

.sticky .LayTexte {
	position: sticky;
	top: 0;
}

.sticky img.cover {
	height: auto;
	width: 100%;
}

.sticky .LayImg .cadre {
	margin-top: 5%;
	border-radius: 20px;
}

/* HEADER  */


:root {
	--navy: #0a1428;
	--green: #2f8547;
	--green-600: #2a7a41;
	--ink: #0e1420;
	--muted: #eef2f6;
	--radius-pill: 999px;
	--shadow: 0 12px 30px rgba(10, 20, 40, .08);
}

* {
	box-sizing: border-box
}

html,
body {
	margin: 0
}

body {
	font-family: Poppins, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
	color: var(--ink);
	background: #fff
}

/* ===== TOPBAR FULL WIDTH (alignée à droite) ===== */

.topbar {
	background: var(--navy);
	color: #fff;
	font-size: 14px
}

.topbar__inner {
	padding: 10px 28px;
	display: flex;
	justify-content: flex-end;
	align-items: center;
	gap: 40px;
	padding-right: 10%;
}

.topitem {
	display: flex;
	align-items: center;
	gap: 10px;
	opacity: .95
}

.topicon {
	width: 18px;
	height: 18px;
	color: #49b26a
}

.topitem b {
	font-weight: 600
}

/* ===== HEADER ===== */

.site-header {
	position: fixed;
	top: 40px;
	z-index: 50;
	background: #fff;
	border-bottom: 1px solid #e8edf2;
	width: 100%;
	transition: cubic-bezier(0.4, 0, 1, 1) 0.2s;
	box-shadow: 0px 8px 15px #00000029;
}

.site-header.scrolled {
	top: 0;
	border-top: 5px solid var(--navy);
}

.head-grid {
	display: grid;
	grid-template-columns: auto auto auto;
	align-items: center;
	gap: 18px;
	min-height: 78px;
	padding: 0 28px;
	position: relative;
}


.head-d {
	display: flex;
	gap: 20px;
}

.brand {
	display: flex;
	align-items: center;
	gap: 14px;
	text-decoration: none;
	color: #fff;
	position: relative;
	top: -18px;
}

.brand-wrap {
	position: relative;
	height: 78px;
	display: flex;
	align-items: center;
	padding-left: 26px;
	color: #fff;
	justify-content: center;
}

.brand-wrap::before {
	content: "";
	position: absolute;
	background: var(--green);
	clip-path: polygon(0 0, 81% 0, 74% 100%, 0 100%);
	z-index: -1;
	width: 150%;
	height: 122px;
	left: -65px;
	top: -41px;
	filter: drop-shadow(-2px 4px 6px rgba(0, 0, 0, 1));
}

a.brand img {
	width: 145px;
	height: 110px;
}


.site-header.scrolled .brand {
	top: 0px;
}

.site-header.scrolled .brand img {
	width: 100px;
	height: 70px;
}

.nav .menu {
	display: flex;
	align-items: center;
	gap: 15px;
	margin: 0;
	padding: 0;
	list-style: none;
	justify-content: space-evenly;
}

/* items */
.nav .menu>li {
	position: relative;
}

/* liens */

.nav .menu>li>a {
	position: relative;
	display: inline-block;
	text-decoration: none;
	color: var(--ink);
	font-weight: 400;
	font-size: 1.2em;
	padding: 20px 6px 20px 15px;
	line-height: 1.1;
	font-family: "handel-gothic", sans-serif;
}

.nav .menu>li>a:hover {
	color: #2f8547;
}

.nav .menu>li>a:hover::before {
	width: 2px;
}

.nav .menu>li+li>a::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 1px;
	height: 35px;
	background: var(--green);
	border-radius: 2px;
}

a.telephone strong {
	color: #fff;
	font-weight: normal;
}

/* sur mobile, on masque la nav desktop */
@media (max-width: 1024px) {
	.nav {
		display: none;
	}
}


/* CTA pilules */

.btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	white-space: nowrap;
	padding: 12px 20px;
	border-radius: var(--radius-pill);
	text-decoration: none;
	font-weight: 600;
	border: 1px solid transparent;
}


.btn .ico {
	width: 18px;
	height: 18px
}

.btn-outline {
	color: var(--green);
	border-color: var(--green);
	background: transparent
}

.btn-outline:hover {
	background: #f2faf5
}

.btn-solid {
	background: var(--green);
	color: #fff
}

.btn-solid:hover {
	background: var(--green-600)
}

/* Langue */
.lang {
	display: flex;
	align-items: center;
	gap: 10px;
	padding-left: 8px
}

.flag {
	width: 20px;
	height: 20px;
	border-radius: 50%;
	box-shadow: 0 0 0 1px #dfe5ea inset
}

.flag.fr {
	background: linear-gradient(90deg, #002395 33.33%, #fff 33.33% 66.66%, #ed2939 0)
}

.caret {
	width: 10px;
	height: 10px;
	border-right: 2px solid #8aa;
	border-bottom: 2px solid #8aa;
	transform: rotate(45deg)
}

/* ===== Burger ===== */
.nav-toggle {
	appearance: none;
	border: 0;
	background: none;
	cursor: pointer;
	width: 44px;
	height: 44px;
	border-radius: 10px;
	justify-self: end;
	display: none;
}

.nav-toggle:focus-visible {
	outline: 2px solid var(--green);
	outline-offset: 2px
}

.bars,
.bars::before,
.bars::after {
	display: block;
	width: 22px;
	height: 2px;
	background: #111;
	border-radius: 2px;
	position: relative;
	margin: 0 auto;
}

.bars::before,
.bars::after {
	content: "";
	position: absolute;
	left: 0
}

.bars::before {
	top: -6px
}

.bars::after {
	top: 6px
}

/* ===== Panneau mobile ===== */
.mobile-panel {
	display: none;
	position: absolute;
	left: 0;
	right: 0;
	top: 100%;
	background: #fff;
	box-shadow: var(--shadow);
	padding: 12px 16px 16px;
	border-bottom: 1px solid #e8edf2;
}

.mobile-panel.open {
	display: block;
	animation: fade .15s ease-out
}

@keyframes fade {
	from {
		opacity: 0;
		transform: translateY(-4px)
	}

	to {
		opacity: 1;
		transform: translateY(0)
	}
}

.mnav {
	list-style: none;
	margin: 8px 0 0;
	padding: 0
}

.mnav li {
	border-top: 1px solid #eef2f6
}

.mnav a {
	display: block;
	padding: 14px 6px;
	text-decoration: none;
	color: var(--ink);
	font-weight: 600
}

.mnav a small {
	display: block;
	font-weight: 400;
	font-size: 12px
}

.mcta {
	display: flex;
	gap: 10px;
	padding-top: 12px
}

.mcta .btn {
	flex: 1;
	justify-content: center
}


.ChargementLangue li:not(.CURRENTLANGUEACTIVE) {
	display: none !important;
}

.SelecteurLangue {
	width: 30px;
	position: relative;
}

.SelecteurLangue.open li {
	display: block !important;
	margin-bottom: 5px;
}

.SelecteurLangue.open .ChargementLangue {
	border: 1px solid #1d2327;
	padding-top: 5px;
	background: rgb(29 35 39 / 68%);
	padding-left: 5px;
	margin-left: 0;
	border-radius: 10px;
}

ul.ChargementLangue {
	border: 1px solid transparent;
	position: absolute;
	padding-right: 8px;
	top: 7px;
	left: 0px;
	z-index: 3;
	padding-left: 10px;
	margin: 0;
}

ul.ChargementLangue:after {
	content: "\276F";
	position: absolute;
	right: -15px;
	top: 4px;
	transform: rotate(90deg);
	color: #1d2327;
}

.ChargementLangue li {
	border-radius: 50%;
	overflow: hidden;
	width: 30px;
	height: 30px;
	border: 1px solid #1d2327;
}

.ChargementLangue li img {
	object-fit: cover;
	width: 29px;
	height: 28px;
	max-width: max-content !important;
}


/* SLIDER  */

#home_slider {
	position: relative;
	padding: 0;
	height: 670px;
	border-radius: 0;
	overflow: hidden;
	margin: 0;
	margin-top: 75px;
}

#home_slider .slick-track {
	position: relative;
	top: 0;
	left: 0;
	display: block;
	margin-left: 0;
	margin-right: 0;
}

#home_slider .overflowhiddenSlider {
	height: 670px;
	overflow: hidden;
	position: relative;
	width: 100%;
}

.overflowhiddenSlider .ItemSliderHome:after {
	position: absolute;
	content: "";
	left: 0;
	top: 0;
	height: 100%;
	width: 100%;
	z-index: 0;
	background: #040E27 0% 0% no-repeat padding-box;
	mix-blend-mode: multiply;
	opacity: 0.35;
}

.slider_homepage {
	position: relative;
	z-index: 1;
}

.fleches {
    display: flex;
    flex-direction: column;
    gap: 10px;
    position: absolute;
    bottom: 40%;
    left: 49%;
    transform: translate(-50%, -50%);
    z-index: 1;
}

.flechPrev,
.flechNext {
display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    border-radius: 20px;
    width: 35px;
    height: 35px;
    background: #0F2036;
    box-shadow: 0px 3px 15px #00000029;
}

.flechNext {
    transform: scaleX(-1);
}

.flechNext {
    margin-left: 15px;
}

.fleches img {
    width: 15px;
    filter: brightness(0) saturate(100%) invert(92%) sepia(93%) saturate(0%) hue-rotate(202deg) brightness(106%) contrast(106%);
    height: 14px;
}

.fleches div:hover img {
    filter: brightness(0) saturate(100%) invert(9%) sepia(11%) saturate(5330%) hue-rotate(182deg) brightness(97%) contrast(94%);
}

.fleches div:hover {
    background: #fff;
}


.ItemSliderHome {
	overflow: hidden;
	position: relative;
	height: 670px;
	background: #EFEFEF;
}

.ItemSliderHome img {
	position: absolute;
	top: 50%;
	right: 0;
	transform: translate(0, -50%);
	object-fit: cover;
	height: 100%;
	width: 85%;
}

#home_slider .fondImage {
	position: relative;
	z-index: 1;
}

#home_slider .fondTexte {
	position: absolute;
	bottom: 20%;
	left: 10%;
	z-index: 3;
	color: white;
	text-align: left;
	width: 80%;
}

.slick-list,
.slick-track {
	position: relative !important;
}

.cadreintern {
	z-index: 2;
	position: relative;
	top: 0;
	left: 0;
	color: #fff;
	width: 40%;
	padding-left: 8%;
	height: 730px;
	padding-top: 8%;
}

.cadreintern h1,
.cadreintern h2 {
	border-left: 2px solid #ffffff !important;
}

.cadreintern .btn {
	margin-top: 15px;
}

.cadreintern:before {
	content: "";
	position: absolute;
	background: var(--green);
	clip-path: polygon(0 0, 85% 0, 100% 100%, 0 100%);
	z-index: 1;
	width: 134%;
	height: 100%;
	left: 0;
	top: 0;
}

.cadreintern .aos-init {
	position: relative;
	z-index: 2;
}

.cadreintern ul {
	display: flex;
	padding: 0;
	list-style: none;
	gap: 15px;
}

.cadreintern ul li img {
	height: 30px;
	width: auto;
	object-fit: contain;
	position: relative;
	transform: none;
	top: initial;
	right: initial;
}


/* BAN INTERNE  */

div#banniereIntern {
	height: 35vh;
	position: relative;
	padding: 0;
	border-radius: 0;
	overflow: hidden;
	margin: 0;
}

#banniereIntern .cntimg {
    overflow: hidden;
    text-align: right;
}

div#banniereIntern:before {
	content: "";
	position: absolute;
	background: var(--green);
	clip-path: polygon(0 0, 85% 0, 100% 100%, 0 100%);
	z-index: 1;
	width: 40%;
	height: 100%;
	left: 0;
	top: 0;
}

div#banniereIntern:after {
	position: absolute;
	content: "";
	left: 0;
	top: 0;
	height: 100%;
	width: 100%;
	z-index: 0;
	background: #040E27 0% 0% no-repeat padding-box;
	mix-blend-mode: multiply;
	opacity: 0.35;
}

.tax-campaign #banniereIntern .cntimg img {
    width: 65%;
    height: 50%;
    object-fit: cover !important;
    margin-top: -10%;
}

#banniereIntern .cntimg img {
    width: 65%;
    height: 50%;
    object-fit: contain !important;
    margin-top: -8%;
}

#banniereIntern .cntTitle {
    position: absolute;
    top: 60%;
    left: 0%;
    z-index: 3;
    text-align: left;
    transform: translate(50%, -50%);
    width: 445px;
}

#banniereIntern .cntTitle em {
	letter-spacing: 1px;
	font-style: normal;
	color: #fff;
	font-weight: 300 !important;
	text-transform: uppercase;
	font-size: 1.2em;
	display: block;
	margin-bottom: 5px;
	font-family: "handel-gothic", sans-serif;
}

#banniereIntern .cntTitle h1 {
	color: #fff;
	font-style: normal;
	font-size: 1.8em;
	margin-bottom: 15px;
	margin-top: 5px;
	line-height: 1.1em;
	font-weight: 500;
	position: relative;
	font-family: "handel-gothic", sans-serif;
	padding-left: 15px;
	border-left: 2px solid #ffffff;
}


/* SPEC */


.encadrementContact {
	box-shadow: 0px 8px 15px #00000029;
	padding: 25px;
	background: #fff;
	position: relative;
	z-index: 1;
	border-radius: 10px;
	min-height: 170px;
}


.partenairestexte {
	position: relative;
}


.partenairestexte:after {
	content: "";
	background: url(/wp-content/uploads/2025/08/ILLUS-PARTENAIRES-COULEURS.svg);
	width: 33%;
	height: 325px;
	position: absolute;
	right: 9px;
	bottom: -10px;
	background-size: cover;
	background-repeat: no-repeat;
}

.presta-item {
	position: relative;
}

.presta-item:nth-child(even) {
	top: 60px;
}

.cadre-item {
	height: 380px;
	position: relative;
}

.cadre-item a {
	position: relative;
}

.cadre-item a .img-presta img,
.cadre-item a .ico-presta {
	transition: all 0.3s ease;
}

.cadre-item a:hover .img-presta img {
	transform: scale(1.07);
}

.cadre-item a:hover .ico-presta {
	background: #308446;
}

.cadre-item a:hover .texte-presta {
	background: #fff;
	color: #040E27;
}

.cadre-item a:hover .miniborder {
	border-top: 1px solid #040E27;
}

.cadre-item a:hover:after {
	content: url(/wp-content/uploads/2025/08/FLECHE-DROITE-PETIT-BLANC.svg);
	background: #040E27;
}

.cadre-item .img-presta:before {
	content: "";
	width: 100%;
	height: 100%;
	position: absolute;
	z-index: 1;
	background: transparent linear-gradient(180deg, #001D5500 0%, #000F2C 100%) 0% 0% no-repeat padding-box;
	mix-blend-mode: multiply;
}

.cadre-item a:after {
	content: url(/wp-content/uploads/2025/08/FLECHE-DROITE-PETIT-BLEU.svg);
	background: #fff;
	position: absolute;
	bottom: 10%;
	width: 35px;
	height: 35px;
	z-index: 1;
	padding: 10px;
	display: flex;
	border-radius: 50%;
	right: 6%;
}

.ico-presta {
	color: #fff;
	width: 60px;
	height: 60px;
	content: "";
	background: #040e27;
	position: absolute;
	transform: translate(-50%, -0%) rotate(45deg);
	top: -29px;
	left: 50%;
	z-index: 2;
	display: flex;
	justify-content: center;
	align-items: center;
	box-shadow: 0px 8px 15px #00000029;
}

.ico-presta img {
	width: 42px;
	height: 32px;
	object-fit: contain;
	transform: rotate(315deg);
	position: relative;
	top: -1px;
	left: -1px;
}

.img-presta {
	position: relative;
	height: 100%;
	cursor: pointer;
	border-radius: 0;
	overflow: hidden;
}

.img-presta img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.texte-presta {
	position: absolute;
	bottom: 0;
	z-index: 1;
	width: 100%;
	color: #fff;
	padding: 10px 76px 10px 35px;
	background: #040E27;
	min-height: 100px;
	clip-path: polygon(0 0, 80% 0, 100% 100%, 0 100%);
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-content: flex-start;
	font-size: 1.3em;
	line-height: 1.4em;
	transition: all 0.3s ease;
}

.texte-presta img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}


.expertise {
	text-align: center;
}

.expertise em {
	color: #308446;
	display: block;
	margin-top: 20px;
	font-size: 1.4em;
	font-style: normal;
}

.expertise img {
	height: 65px;
	width: 100%;
	object-fit: contain;
}


.icosup {
	background: #308446 0% 0% no-repeat padding-box;
	box-shadow: 0px 8px 15px #00000029;
	border: 8px solid #FFFFFF;
	text-align: center;
	border-radius: 50%;
	width: 110px;
	display: flex;
	height: 110px;
	justify-content: center;
	position: relative;
	margin: auto;
	align-items: center;
}

.icosup sup {
	position: absolute;
	right: -20px;
	background: #308446;
	color: #fff;
	font-family: "handel-gothic", sans-serif;
	font-size: 1.5em;
	padding: 5px;
	border-radius: 50%;
	width: 40px;
	height: 40px;
	display: flex;
	justify-content: center;
	align-items: center;
	top: -10px;
	transition: cubic-bezier(0.4, 0, 1, 1) 0.2s;
}

.expertise .fl-rich-text .icosup {
	transition: all 0.3s;
}

.expertise:hover .fl-rich-text .icosup {
	transform: translateY(-10px);
	background: #040E27;
}

.expertise:hover .fl-rich-text .icosup sup {
	background: #040E27;
}

.expertise:hover em {
	color: #040E27;
}


.cadrediag1 {
	min-height: 465px;
	background: #040E27;
}

.photodiag, .photodiag2 {
    position: relative;
    height: 100%;
}

.photodiag:before {
	content: "";
	position: absolute;
	transform: translate(-50%, -0%);
	top: 50%;
	left: 0;
	z-index: 2;
	box-shadow: 0px 8px 15px #00000029;
	width: 90px;
	height: 90px;
	background: #040e27 url(/wp-content/uploads/2025/08/PICTO-PRESTATION-OUVERTUREMUR-BLANC.svg);
	clip-path: polygon(50% 0, 100% 50%, 50% 100%, 0 50%);
	background-size: 33px;
	background-repeat: no-repeat;
	background-position: 46% center;
}

.photodiag2:before {
	content: "";
	position: absolute;
	transform: translate(-3px, 0%);
	top: 45%;
	right: -8%;
	z-index: 2;
	box-shadow: 0px 8px 15px #00000029;
	width: 90px;
	height: 90px;
	background: #040e27 url(/wp-content/uploads/2025/08/PICTO-PRESTATION-AMENAGEMENTEXT-BLANC.svg);
	clip-path: polygon(50% 0, 100% 50%, 50% 100%, 0 50%);
	background-size: 33px;
	background-repeat: no-repeat;
	background-position: 46% center;
}

.contenu-tax {
    padding: 25px 25px;
    position: relative;
    z-index: 2;
}

.photodiag .fl-photo-content.fl-photo-img-jpg {
    min-height: 465px;
    clip-path: polygon(0 0, 90% 0, 100% 100%, 0 100%);
    height: 100%;
}

.photodiag img {
    width: 100%;
    min-height: 465px;
    object-fit: cover;
    height: 100% !important;
}


.cadrediag2 {
	min-height: 465px;
	background: #040E27;
}

.photodiag2 .fl-photo-content.fl-photo-img-jpg {
	height: 465px;
	clip-path: polygon(10% 0, 100% 0, 100% 100%, 0 100%);
}

.photodiag2 img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}


.cta,
.engagement,
.prestationsection {
	position: relative;
}

.cta:after {
	content: "";
	background: rgb(4 14 39 / 69%);
	mix-blend-mode: multiply;
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
}

.cta .fl-col-group {
	width: 100%;
	z-index: 1;
	position: relative;
}

.cta h3:before {
	content: attr(data-titre);
	float: left;
	font-weight: bold;
	position: absolute;
	opacity: 0.2;
	font-size: 3em;
	width: 843px;
	line-height: 0.9em;
	top: -68px;
	left: -61px;
}

.partenairestexte h3:before {
	content: attr(data-titre);
	float: left;
	font-weight: bold;
	position: absolute;
	opacity: 0.2;
	font-size: 3em;
	width: 843px;
	line-height: 0.9em;
	top: -83px;
	left: -61px;
	color: #308446;
}

.cta .fl-col-content.fl-node-content {
	max-width: 1080px;
	margin: auto;
}

.engagement h3:before {
	content: attr(data-titre);
	float: left;
	font-weight: bold;
	position: absolute;
	opacity: 0.1;
	font-size: 3em;
	width: 900px;
	line-height: 0.9em;
	top: -80px;
	left: -132px;
	color: #308446;
}

.prestationsection h3:before {
	content: attr(data-titre);
	float: left;
	font-weight: bold;
	position: absolute;
	opacity: 0.1;
	font-size: 3em;
	width: 900px;
	line-height: 0.9em;
	top: -80px;
	left: -132px;
	color: #ffffff;
}


.barreblanche h3,
.barreblanche h2,
.barreblanche h4 {
	border-left: 2px solid #fff !important;
}

.barrebleu h3,
.barrebleu h2,
.barrebleu h4 {
	border-left: 2px solid #040E27 !important;
}


.fondimagegris {
	background: url(/wp-content/uploads/2025/08/WEB-FOND-BETON-GRIS.jpg);
	background-size: cover;
}

.fondvert {
	background: #308446;
}

.fondvertpale {
	background: #E3EEE5;
}


.minititre {
	font-weight: 300 !important;
	text-transform: uppercase;
	font-size: 1.2em;
	display: block;
	margin-bottom: 15px;
	font-family: "handel-gothic", sans-serif;
}

.titrebase h1 {
	font-size: 2.5em;
	margin-bottom: 15px;
	margin-top: 5px;
	line-height: 1.1em;
	font-weight: 700;
	position: relative;
	font-family: "handel-gothic", sans-serif;
	padding-left: 15px;
	border-left: 2px solid #308446;
}

.titrebase h2 {
	font-size: 2.5em;
	margin-bottom: 15px;
	margin-top: 5px;
	line-height: 1.1em;
	font-weight: 700;
	position: relative;
	font-family: "handel-gothic", sans-serif;
	padding-left: 15px;
	border-left: 2px solid #308446;
    color: #308446;
}

.titrebase h3 {
	font-size: 2.5em;
	margin-bottom: 15px;
	margin-top: 5px;
	line-height: 1.1em;
	font-weight: 700;
	position: relative;
	font-family: "handel-gothic", sans-serif;
	padding-left: 15px;
	border-left: 2px solid #308446;
}

.titrebase h4 {
	font-size: 2.5em;
	margin-bottom: 15px;
	margin-top: 5px;
	line-height: 1.1em;
	font-weight: 700;
	position: relative;
	font-family: "handel-gothic", sans-serif;
	padding-left: 15px;
	border-left: 2px solid #308446;
}

.titrebase h5 {
	font-size: 2.5em;
	margin-bottom: 15px;
	margin-top: 5px;
	line-height: 1.1em;
	font-weight: 700;
	position: relative;
	font-family: "handel-gothic", sans-serif;
	padding-left: 15px;
	border-left: 2px solid #308446;
}

.textblanc {
	color: #fff;
}

.CarouDecalage {
	overflow: hidden;
	max-width: 1120px;
	position: relative;
	z-index: 3;
	margin: 0 45px;
}

.CarouDecalage .carou_rea {
	min-height: 480px;
}

.item {
	position: relative;
	margin: 15px 2% 15px 0px;
	padding: 0;
	height: 380px;
	margin-bottom: 20px;
	overflow: hidden;
}

.item a:after {
	content: url(/wp-content/uploads/2025/08/FLECHE-DROITE-PETIT-BLEU.svg);
	background: #fff;
	position: absolute;
	bottom: 15%;
	width: 35px;
	height: 35px;
	z-index: 1;
	padding: 10px;
	display: flex;
	border-radius: 50%;
	right: 6%;
}

.item a:hover:after {
	content: url(/wp-content/uploads/2025/08/FLECHE-DROITE-PETIT-BLANC.svg);
	background: #040E27;
}

.item a:hover .cadrebtnActivite,
.item a:hover .categorie-titre {
	background: #fff;
}

.item a:hover .cadrebtnActivite h3 {
	color: #040E27;
}

.item a:hover hr.miniborder {
	border-top: 1px solid #040E27;
}

.item a:hover .categorie-titre span {
	filter: brightness(0) saturate(100%) invert(6%) sepia(16%) saturate(5954%) hue-rotate(202deg) brightness(93%) contrast(102%);
}


.item:before {
	content: "";
	width: 100%;
	height: 100%;
	position: absolute;
	z-index: 1;
	background: transparent linear-gradient(180deg, #001D5500 0%, #000F2C 100%) 0% 0% no-repeat padding-box;
	mix-blend-mode: multiply;
}

.categorie-titre {
	color: #fff;
	width: 100px;
	height: 100px;
	content: "";
	background: #040e27;
	display: flex;
	position: absolute;
	transform: translate(-50%, -0%);
	top: 52%;
	left: 14%;
	z-index: 2;
	clip-path: polygon(50% 0, 100% 50%, 48% 72%, 0 50%);
	align-items: center;
	justify-content: center;
}

.categorie-titre span {
	width: 38px !important;
	height: 29px !important;
	background-size: contain;
	transform: translate(0, 0%);
	background-repeat: no-repeat;
	z-index: 2;
	margin-top: -17px;
	margin-left: 7px;
}

.amenagement-exterieur-reseau {
	background: url(/wp-content/uploads/2025/08/PICTO-PRESTATION-AMENAGEMENTEXT-BLANC.svg);
}

.construction-gros-oeuvre {
	background: url(/wp-content/uploads/2025/08/PICTO-PRESTATION-CONSTRUCTION-BLANC.svg);
}

.ouverture-de-mur {
	background: url(/wp-content/uploads/2025/08/PICTO-PRESTATION-OUVERTUREMUR-BLANC.svg);
}

.renovation-extension {
	background: url(/wp-content/uploads/2025/08/PICTO-PRESTATION-RENOVATIONEXTENSION-BLANC.svg);
}


.ico-amenagement-exterieur-reseau.photodiag:before {
	background: #040e27 url(/wp-content/uploads/2025/08/PICTO-PRESTATION-AMENAGEMENTEXT-BLANC.svg);
	background-size: 33px;
	background-repeat: no-repeat;
	background-position: 46% center;
}

.ico-construction-gros-oeuvre.photodiag:before {
	background: #040e27 url(/wp-content/uploads/2025/08/PICTO-PRESTATION-CONSTRUCTION-BLANC.svg);
	background-size: 33px;
	background-repeat: no-repeat;
	background-position: 46% center;
}

.ico-ouverture-de-mur.photodiag:before {
	background: #040e27 url(/wp-content/uploads/2025/08/PICTO-PRESTATION-OUVERTUREMUR-BLANC.svg);
	background-size: 33px;
	background-repeat: no-repeat;
	background-position: 46% center;
}

.ico-renovation-extension.photodiag:before {
	background: #040e27 url(/wp-content/uploads/2025/08/PICTO-PRESTATION-RENOVATIONEXTENSION-BLANC.svg);
	background-size: 33px;
	background-repeat: no-repeat;
	background-position: 46% center;
}


.item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.item .CadreActiviteImage {
	position: relative;
	height: 100%;
	cursor: pointer;
	border-radius: 0;
	overflow: hidden;
}

.item .cadrebtnActivite {
    position: absolute;
    bottom: 0;
    z-index: 1;
    width: 100%;
    color: #fff;
    padding: 10px 70px 10px 35px;
    background: #040E27;
    min-height: 135px;
    clip-path: polygon(0 0, 80% 0, 100% 100%, 0 100%);
}

.item .cadrebtnActivite h3 {
    font-weight: 300;
    font-size: 13px;
    margin: 0;
    position: relative;
    z-index: 1;
    margin-top: 20px;
}

hr.miniborder {
	width: 50px;
	margin-left: 0;
	border: none;
	border-top: 1px solid #fff;
	margin-top: 15px;
}

.item a .CadreActiviteImage img,
.item .CadreActiviteImage img {
	transition: all 0.3s ease;
}

.item a:hover .CadreActiviteImage img,
.item .CadreActiviteImage:hover img {
	transform: scale(1.07);
}


.realise .fl-rich-text {
	position: relative;
}

.flexrealisations {
	display: flex;
	gap: 10px;
	position: absolute;
	right: 6px;
	top: 36%;
	flex-direction: column;
}

.flexrealisations div {
	display: flex;
	justify-content: center;
	align-items: center;
	cursor: pointer;
	border-radius: 20px;
	width: 35px;
	height: 35px;
	background: #0F2036;
	box-shadow: 0px 3px 15px #00000029;
}

.flexrealisations .next-t {
	transform: scaleX(-1);
}

.flexrealisations .prev-t {
	margin-left: 15px;
}

.flexrealisations div:hover {
	background: #fff;
}

.flexrealisations img {
	width: 15px;
	filter: brightness(0) saturate(100%) invert(92%) sepia(93%) saturate(0%) hue-rotate(202deg) brightness(106%) contrast(106%);
	height: 14px;
}

.flexrealisations div:hover img {
	filter: brightness(0) saturate(100%) invert(9%) sepia(11%) saturate(5330%) hue-rotate(182deg) brightness(97%) contrast(94%);
}


/* CONTENU + RESTE  */


.cadreimg1 {
	width: 485px;
	height: 480px;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 20px;
	position: relative;
}

.cadreimg1 img {
	object-fit: cover;
	width: 100%;
	height: 100%;
}

.cadreimg1 .img1 {
	min-height: 457px;
	position: relative;
	top: -30px;
}

.cadreimg1 .img2 {
	min-height: 457px;
}

.losange {
	position: absolute;
	transform: translate(-50%, -50%);
	top: 50%;
	left: 50%;
	color: #fff;
	text-align: center;
	font-size: 1.3em;
}

.losange span {
	position: relative;
	font-family: "handel-gothic", sans-serif;
}

.losange span em {
	font-style: normal;
	font-size: 1.8em;
}

.losange:before {
	background: #308446;
	width: 100px;
	height: 100px;
	content: "";
	display: block;
	position: absolute;
	transform: rotate(45deg) translate(-50%, -0%);
	top: 33%;
	left: 33%;
}


.planafter,
.realise {
	position: relative;
}

.planafter:after {
	content: "";
	background: url(/wp-content/uploads/2025/08/ILLUS-PERSONNESPLAN-COULEURS.svg);
	width: 35%;
	height: 390px;
	position: absolute;
	right: 9px;
	bottom: 0;
	background-size: cover;
	background-repeat: no-repeat;
}

.realise:after {
	content: "";
	background: url(/wp-content/uploads/2025/08/ILLUS-PERSONNESREALISATION-COULEURS.svg);
	width: 35%;
	height: 390px;
	position: absolute;
	left: -10%;
	bottom: 0;
	background-size: cover;
	background-repeat: no-repeat;
}


/* FORM  */

.flex-form {
	position: relative;
	display: flex;
	flex-wrap: wrap;
	gap: 10px 10px;
	z-index: 1;
	background: #FFFFFF 0% 0% no-repeat padding-box;
	padding: 20px;
	box-shadow: 0px 13px 26px #00000029;
	border-radius: 20px;
}

span.wpcf7-spinner {
	position: absolute;
}

.flex-form .full {
	position: relative;
	width: 100%
}

.flex-form .half {
	position: relative;
	width: 47.5%
}

.flex-form label {
	display: block;
	margin-bottom: 7px;
	font-size: 1em;
	font-weight: 500;
}

.flex-form p {
	margin: 0
}

.flex-form select,
.flex-form input:not(:is([type="button"], [type="submit"], [type="radio"], [type="checkbox"], [type="file"])) {
	height: 3rem;
}

.flex-form :is(input, textarea, select):not(:is([type="submit"], [type="button"])) {
	color: #818181;
	background: transparent;
	font-style: initial;
	font-family: sans-serif;
}

.flex-form select,
.flex-form textarea,
.flex-form input:not(:is([type="button"], .flex-form [type="submit"], .flex-form [type="radio"], .flex-form [type="checkbox"], .flex-form[type="file"])) {
	width: 100%;
	font-size: 14px;
	line-height: 1;
	outline: none;
	font-weight: 100;
	box-sizing: border-box;
	padding: .7375rem 0px;
	border: 1px solid #CCCCCC;
	border-radius: 10px;
	background: transparent;
	padding-left: 15px;
	padding-right: 15px;
}

.flex-form .wpcf7-acceptance span.wpcf7-list-item-label {
	line-height: 1.3em;
}

.full h3,
.full h4 {
	font-size: 1.8em;
	font-style: normal;
	margin-bottom: 10px;
	font-weight: 600;
	margin-top: 0;
	color: #308446;
	font-family: "handel-gothic", sans-serif;
}

.full em {
	font-style: normal;
}

.wpcf7-acceptance input {
	width: 1em;
	height: 1em;
	margin-top: .25em;
	vertical-align: top;
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	border: 1px solid #00000040;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	-webkit-print-color-adjust: exact;
	color-adjust: exact
}

input#acceptance,
#condition2 input,
input[name="acceptance-284"] {
	font-size: 20px;
	border-radius: 5px;
	min-width: 20px;
	border: 1px solid #c3c4c7;
	background: #fff;
}

input#acceptance:checked[type=checkbox],
#condition2 input:checked[type=checkbox],
input:checked[name="acceptance-284"] {
	background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23308446' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='M6 10l3 3l6-6'/%3e%3c/svg%3e")
}

input#acceptance:checked,
input#acceptance:focus,
#condition2 input:focus,
input[name="acceptance-284"]:focus {
	background-color: #f0ece2;
	border-color: #fff;
	border-color: #308446;
	outline: 0;
	box-shadow: 0 0 0 .11rem #090000
}

.wpcf7-acceptance span.wpcf7-list-item {
	margin: 0
}

.wpcf7-acceptance span.wpcf7-list-item-label {
	text-transform: none;
}

input.wpcf7-form-control.wpcf7-submit.has-spinner {
	background: transparent;
	border: none;
	color: #fff;
	text-transform: uppercase;
	font-size: 1em;
	font-weight: 400;
}

.wpcf7-acceptance label {
	font-size: 13px;
	display: flex;
	gap: 10px;
	align-items: center;
	justify-content: center;
	align-content: center;
	line-height: 1em;
}

/* FOO§TER  */

footer.footerbg {
	position: relative;
	padding-top: 40px;
	background: #308446;
	background: linear-gradient(110deg, rgba(48, 132, 70, 1) 32%, rgba(255, 255, 255, 1) 30%);
}

footer.footerbg h4 {
	color: #E41D17;
	font-size: 1.1em;
}

footer.footerbg p {
	margin: 10px 0;
	position: relative;
}

ul.reseauxsociaux {
	display: flex;
	gap: 10px;
}

.main-footer {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr 1fr;
	grid-template-areas: "logo nav reservation credits";
	color: #fff;
	padding: 0;
	gap: 0px 50px;
	max-width: 1280px;
	margin: auto;
	align-items: start;
	padding-bottom: 15px;
}

.main-footer a {
	text-decoration: none;
	margin: 0;
}

.main-footer .btn,
.main-footer .btn:hover {
	font-size: 14px;
	text-decoration: none;
}


.main-footer a:hover {
	text-decoration: underline;
	color: initial;
}

.main-footer ul {
	list-style: none;
	padding: 0
}

.main-footer ul li {
	margin-bottom: 15px;
}

.footer-logo {
	grid-area: logo;
	line-height: 1.2em;
}

.footer-logo .wp-image-122 {
	width: 380px;
	margin-left: -10%;
}

.footer-logo ul li {
	display: flex;
	align-items: flex-start;
	flex-direction: column;
}

.footer-logo ul li a {}

.footer-logo p {
	line-height: 1.5em;
}

.footer-nav {
	grid-area: nav;
	margin-left: 30px;
}

.footer-reservation {
	grid-area: reservation;
}

.footer-reservation a.reservation {
	max-width: 120px
}

nav.footer-nav li a,
.footer-reservation li a,
.footer-reservation li label {
	position: relative;
	color: #040E27;
}

.footer-credits {
	grid-area: credits;

}

.footer-credits .container {
	display: flex;
	margin: auto;
	justify-content: space-between;
	align-items: center;
}

.main-footer span strong {
	font-size: 1.2em;
}