:root
{
	--primary-color: #F8F5D2;
	--dark-green: color(3);
	--light-green: color(4);
	--beige: color(5);
}

/* ----- BOILERPLATE ----- */

::selection,
::-moz-selection
{
	color: #000;
	background: var(--primary-color);
}

*,
*::before,
*::after
{
	box-sizing: border-box;
	touch-action: manipulation;
	-webkit-tap-highlight-color: transparent;
	-webkit-font-smoothing: antialiased;
}

html
{
	height: calc(100% - var(--wp-admin--admin-bar--height, 0px));
	overflow-x: hidden;
	font-size: 100%;
}

/* Scroll smooth uniquement si l'utilisateur ne préfère pas réduire les animations */
@media (prefers-reduced-motion: no-preference)
{
	html
	{
		scroll-behavior: smooth;
	}
}

body
{
	min-height: 100%;
	display: flex;
	flex-direction: column;
	text-rendering: optimizelegibility;
	overflow-wrap: break-word; /* Fallback text-wrap: pretty */
	text-wrap: pretty; /* Chrome 117+ */
}

h1,
h2,
h3,
h4,
h5,
h6
{
	overflow-wrap: break-word; /* Fallback text-wrap: balance */
	text-wrap: balance; /* Chrome 114+, Firefox 121+, Safari 17.5+ */
}

img
{
	-webkit-user-drag: none;
}

a
{
	transition: all ease 0.4s;
}


/* Navbar */

body #_header-161-8.oxy-header.oxy-overlay-header:not(.oxy-sticky-header-active) .oxy-header-row,
body #_header-161-8.oxy-header.oxy-overlay-header:not(.oxy-sticky-header-active)
{
    background-color: #0e2d01 !important;
}

/* [DEBUT] BREAKPOINT CUSTOM - BURGER MENU */

@media (max-width: 1400px)
{
    #-site-navigation-169-8.oxy-site-navigation > ul:not(.open)
    {
        display: none;
    }

    .oxy-site-navigation__mobile-open-button
    {
        display: flex !important;
    }

	body #-site-navigation-169-8.oxy-site-navigation > ul
	{
		padding: 64px 20px;
	}

    #-site-navigation-169-8.oxy-site-navigation ul.open
    {
		background-color: rgb(14 45 1 / 70%);
		-webkit-backdrop-filter: blur(10px); /* Safari */
		backdrop-filter: blur(10px);
        display: flex;
        flex-direction: column;
		justify-content: center;
		align-items: center;
		gap: 30px;
        position: fixed;
		height: 100vh;
		width: 100%;
		max-width: 100vw;
        top: 0;
        left: 0;
        right: 0;
        z-index: 999;
    }
}

/* [FIN] BREAKPOINT CUSTOM - BURGER MENU */

.oxy-header-container
{
	justify-content: space-between;
}

nav.oxy-site-navigation
{
	display: flex;
	justify-content: center;
	align-items: center;
}

nav.oxy-site-navigation > ul
{
	margin: 0;
	justify-content: flex-end;
}

.oxy-site-navigation li a,
.oxy-site-navigation > a
{
	padding: 0 16px !important;
	text-decoration: none;
}

nav.oxy-site-navigation ul > li > ul > li:hover
{
	background-color: rgba(255, 255, 255, 0.9) !important;
}

nav.oxy-site-navigation > ul > li > a::after
{
	content: "";
	position: absolute;
	bottom: -3px;
	width: 20px;
	height: 1px;
	left: 50%;
	transform: translateX(-50%);
	background-color: var(--oxynav-brand-color);
	opacity: 0;
	transition: opacity 0.3s ease;
}

nav.oxy-site-navigation > ul > li.current-menu-item > a::after,
nav.oxy-site-navigation > ul > li.current-menu-ancestor > a::after,
nav.oxy-site-navigation > ul > li:hover > a::after
{
	opacity: 1 !important;
}

@media (max-width: 1120px)
{
	body #-site-navigation-169-8.oxy-site-navigation ul > li
	{
		width: fit-content;
		max-width: 100%;
	}
}

@media (max-width: 991px)
{
	#-site-navigation-169-8.oxy-site-navigation .oxy-site-navigation__mobile-close-wrapper
	{
		display: none !important;
	}
}

nav.oxy-site-navigation .oxy-site-navigation__mobile-open-button
{
	position: relative;
	z-index: 9999;
	padding: 0;
	margin: 0;
}

/* Megamenu */
header nav ul li:has(> a[href="https://agence-louppe.com/offres/"])
{
  position: relative;
}

.oxy-site-navigation li > button
{
  display: none;
}

.megamenu
{
  background: rgb(37 101 9 / 80%);
  -webkit-backdrop-filter: blur(3px); /* Safari */
  backdrop-filter: blur(3px);
  position: absolute;
  left: 50%;
  opacity: 0;
  top: calc(100% + 30px);
  width: 1000px;
  height: min-content;
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  border-radius: 20px;
  transition: all ease 0.4s;
  pointer-events: none;
}

.megamenu::before
{
  content: "";
  position: absolute;
  width: 100%;
  height: 30px;
  bottom: 100%;
  left: 0;
}

.megamenu .megamenu-column
{
	width: 33.33%;
    padding: 50px 30px !important;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 15px;
}

.megamenu .megamenu-image
{
    max-width: 60px;
}

.megamenu .megamenu_text-wrapper
{
    text-align: center;
	text-wrap: wrap;
}

.megamenu .megamenu_text-wrapper .megamenu-heading
{
    margin: 0;
    font-size: 40px;
	line-height: 0.85;
}

.megamenu .megamenu_text-wrapper .megamenu-text
{
    margin: 0;
    font-size: 16px;
    text-transform: none;
}

header nav ul li:has(> a[href="https://agence-louppe.com/offres/"]):hover .megamenu
{
  transform: translate(-50%, 0%);
  opacity: 1;
  pointer-events: all;
}

.megamenu:hover .megamenu-column:not(:hover)
{
  opacity: 0.3;
  transition: opacity 0.3s ease;
}

@media (max-width: 1400px)
{
	#-site-navigation-169-8.oxy-site-navigation ul.open
	{
		.megamenu
		{
		margin-top: 15px;
		position: static;
		transform: none;
		left: unset;
		top: unset;
		width: 500px;
		max-width: 100%;
		background: none;
		-webkit-backdrop-filter: none; /* Safari */
		backdrop-filter: none;
		opacity: 1;
		}
	}

  .megamenu .megamenu-column
  {
    padding: 15px 10px !important;
  }

  header nav ul li:has(> a[href="https://agence-louppe.com/offres/"])
  {
    flex-direction: column;
    padding: 15px 10px;
    border: 1px solid rgba(255, 255, 255, 0.5);
    border-radius: 10px !important;
  }

  header nav ul li:has(> a[href="https://agence-louppe.com/offres/"]) a::after
  {
    top: 52px;
  }

  header nav ul li:has(> a[href="https://agence-louppe.com/offres/"]):hover .megamenu
  {
    transform: none;
  }

  p.megamenu-text
  {
    display: none;
  }
}

@media (max-width: 768px)
{
  .megamenu::before
  {
    display: none;
  }

  .megamenu .megamenu-column .megamenu_text-wrapper p.megamenu-heading
  {
    font-size: 30px;
  }
}

@media (max-width: 550px)
{
  header nav ul li:has(> a[href="https://agence-louppe.com/offres/"]) a::after
  {
    top: 42px;
  }

  .megamenu .megamenu-image
  {
    max-width: 40px;
  }
}

@media (min-width: 1400px)
{
  body .oxy-site-navigation > ul > li > ul:not(.megamenu)
  {
    display: none;
  }
}


/* Footer */
.footer-links,
.copyright a
{
	text-decoration: underline 2px transparent !important;
	text-underline-offset: 6px !important;
}

.footer-links:hover,
.copyright a:hover
{
	text-decoration-color: var(--primary-color) !important;
}

/* Désactive le clic sur les liens "vides" */
.oxy-site-navigation ul li a[href="#"]
{
	pointer-events: none;
}

.oxy-rich-text ul,
.oxy-rich-text ol,
.ct-text-block ul,
.ct-text-block ol
{
	padding-left: 20px;
}

.oxy-rich-text ul li,
.oxy-rich-text ol li,
.ct-text-block ul li,
.ct-text-block ol li
{
	margin-bottom: 10px;
}

.oxy-rich-text ul li::marker,
.oxy-rich-text ol li::marker,
.ct-text-block ul li::marker,
.ct-text-block ol li::marker
{
	color: var(--primary-color);
}

a,
.ct-link-button
{
	transition: all ease 0.4s !important;
}

.ct-link-button
{
	text-decoration: none !important;
}

.ct-inner-content
{
	flex-grow: 1;
	overflow: hidden !important;
}

/* Fix bug affichage map avant acceptation des cookies */
body .cmplz-placeholder-parent,
body .cmplz-placeholder-parent > iframe
{
	height: 400px;
	width: 100%;
}

/* Affichage cookies PPD */
#cmplz-cookies-overview summary
{
	margin-bottom: 15px;
}

#cmplz-cookies-overview summary *
{
	display: inline;
}

div#cmplz-document
{
	margin-inline: auto;
}

/* ----- FORMINATOR ----- */
.forminator-ui input,
.forminator-ui textarea
{
    padding: 10px;
    background: none;
	border-top: none;
	border-left: none;
	border-right: none;
    border-bottom: 1px solid var(--primary-color);
    font-size: 18px;
    color: #fff;
}

.forminator-ui textarea
{
    min-height: 250px;
}

.forminator-ui input::placeholder,
.forminator-ui textarea::placeholder
{
    color: var(--primary-color);
    opacity: .7;
    font-family: sans-serif;
}

.forminator-ui .forminator-consent__label > p
{
    margin-top: 0;
}

.forminator-ui .forminator-button-submit
{
    display: inline-block;
    background: var(--primary-color);
    padding: 13px 30px;
    border-radius: 50px;
    transition: 0.4s ease;
    border: none;
	font-family: sans-serif;
	font-size: 18px;
	cursor: pointer;
}

.forminator-ui .forminator-button-submit:hover
{
    transform: scale(0.9);
    box-shadow: none;
}

.forminator-checkbox-box
{
    background-color: transparent;
    border: 1.5px solid #5b5b5b;
    border-radius: 5px;
}

.forminator-checkbox-box::before
{
    color: var(--primary-color);
}

.forminator-checkbox__label a
{
    color: #000;
    font-weight: 600;
    text-decoration: 1px underline transparent;
    text-underline-offset: 3px;
    transition: all ease 0.4s;
}

.forminator-checkbox__label a:hover
{
    text-decoration: 1px underline #000;
}

body .forminator-ui#forminator-module-175.forminator-design--basic .forminator-response-message.forminator-success
{
    display: block;
    padding: 20px !important;
    background-color: #6fde89;
    color: #3b3b3b;
    box-shadow: none !important;
    border-radius: 8px;
    text-align: center;
    margin-bottom: 25px;

	& > p
	{
		font-size: 18px;
	}
}

.forminator-ui#forminator-module-175.forminator-design--basic .forminator-error-message
{
    background-color: #ffdae1;
    width: fit-content;
    border-radius: 15px;
}

.forminator-ui.forminator-design--default .forminator-label
{
    font-size: 16px;
}

.forminator-ui .select2-selection
{
    background: transparent;
    border: 2px solid var(--primary-color);
    border-radius: 8px;
}

.forminator-select-dropdown
{
    background: #fff;
    border: 2px solid var(--primary-color);
    border-radius: 8px;
}

.forminator-select2
+ .forminator-select
.selection
.select2-selection--single[role="combobox"]
.select2-selection__arrow
{
    color: var(--primary-color);
}

.forminator-select-dropdown-container--open
.forminator-dropdown--default
.select2-results
.select2-results__options
.select2-results__option:not(
    .select2-results__option--selected
).select2-results__option--highlighted
{
    background: var(--primary-color);
    color: #000;
}

.forminator-ui .select2-selection__placeholder
{
    color: #777771;
}

.forminator-ui.forminator-design--default .forminator-multiselect
{
    border: 2px solid var(--primary-color);
    border-radius: 8px;
    background-color: transparent;
}

.forminator-ui.forminator-design--default .forminator-multiselect .forminator-option:hover
{
    background: var(--primary-color);
}

.forminator-ui.forminator-design--default .forminator-multiselect::-webkit-scrollbar
{
    width: 8px;
}

.forminator-ui.forminator-design--default .forminator-multiselect::-webkit-scrollbar-track
{
    border-radius: 5px;
}

.forminator-ui.forminator-design--default .forminator-multiselect::-webkit-scrollbar-thumb
{
    background-color: #c7c7c7;
    border-radius: 5px;
}

.forminator-ui .forminator-slider .forminator-slide
{
    background: transparent;
}

.forminator-ui .forminator-slider .ui-slider-range,
.forminator-ui .forminator-slider .ui-slider-handle
{
    background: var(--primary-color);
}

.forminator-ui .forminator-label,
.forminator-slider-limit-min,
.forminator-slider-limit-max
{
    color: #000;
    font-weight: 400;
}

.forminator-slider-limit-min,
.forminator-slider-limit-max
{
    font-size: 13px;
}

.forminator-ui .forminator-description:has(+ textarea)
{
    display: none !important;
}

body .forminator-ui.forminator-design--default .forminator-consent,
body .forminator-ui.forminator-design--default .forminator-consent__label,
body .forminator-ui.forminator-design--default .forminator-consent__label p,
body .forminator-checkbox__label a,
body .forminator-ui.forminator-design--default .forminator-textarea,
body .forminator-ui.forminator-design--default .forminator-textarea:hover,
body .forminator-ui.forminator-design--default .forminator-textarea:focus,
body .forminator-ui.forminator-design--default .forminator-textarea:active,
body .forminator-ui.forminator-design--default .forminator-input,
body .forminator-ui.forminator-design--default .forminator-input:hover,
body .forminator-ui.forminator-design--default .forminator-input:focus,
body .forminator-ui.forminator-design--default .forminator-input:active
{
    color: currentColor;
}

.forminator-input-with-prefix input
{
    border: none;
}

.forminator-input-with-prefix,
.forminator-ui.forminator-design--default .forminator-radio .forminator-radio-bullet,
.forminator-ui.forminator-design--default .forminator-radio .forminator-radio-image
{
    background: none;
    border-radius: 8px;
    border: 2px solid var(--primary-color);
}

.forminator-ui.forminator-design--default .forminator-radio .forminator-radio-bullet:before,
.forminator-select-dropdown-container--open .forminator-dropdown--default .select2-results .select2-results__options .select2-results__option.select2-results__option--selected,
.forminator-select-dropdown-container--open .forminator-dropdown--default .select2-results .select2-results__options .select2-results__option.select2-results__option--selected span:not(.forminator-checkbox-box)
{
    background-color: var(--primary-color);
}

/* Oxygen navigation menu */

.oxy-site-navigation ul
{
	flex-wrap: wrap;
}

.oxy-header-container
{
	padding: 0;
}

.oxy-header-container > div:empty
{
	display: none;
}

@media (max-width: 1120px)
{
	.oxy-site-navigation > ul
	{
		max-width: 100%;
		justify-content: center;
	}
}

@media (max-width: 1050px)
{
	.oxy-gallery.oxy-gallery-masonry
	{
		column-count: 3 !important;
	}
}

@media (max-width: 750px)
{
	.oxy-gallery.oxy-gallery-masonry
	{
		column-count: 2 !important;
	}
}

@media (max-width: 450px)
{
	.oxy-gallery.oxy-gallery-masonry
	{
		column-count: 1 !important;
	}
}

/* Debug galeries masonry Oxygen */
.oxy-gallery-masonry .oxy-gallery-item .oxy-gallery-item-contents img
{
	min-width: 100%;
	object-fit: cover;
}

/* Comparaison d'images */
.ct-div-block.oxel-image-comparisonv2
{
	min-height: 100%;
	overflow: hidden;
	z-index: 1;
}

.oxel-image-comparisonv2__icon
{
	background-color: transparent !important;
	border: 2px solid #fff;
	-webkit-backdrop-filter: blur(10px); /* Safari */
	backdrop-filter: blur(10px);
}

.ct-fancy-icon.oxel-image-comparisonv2__icon::before,
.ct-fancy-icon.oxel-image-comparisonv2__icon::after
{
	content: "";
	position: absolute;
	height: 500px;
	width: 2px;
	left: calc(50% - 2px);
	background: #fff;
}

.ct-fancy-icon.oxel-image-comparisonv2__icon::before
{
	bottom: 50px;
}

.ct-fancy-icon.oxel-image-comparisonv2__icon::after
{
	top: 50px;
}

.oxel-image-comparisonv2__icon > svg
{
	fill: #fff !important;
}

.ct-new-columns > .ct-div-block:where(:has(> * :only-child), :not(:has(> :not(img))))
{
	display: flex;
	justify-content: center;
	align-items: center;
}

.copyright a
{
	color: currentColor;
}

@media (max-width: 768px)
{
	[class*="flex-space-"] > *
	{
		width: 100% !important;
	}
}

/* Fix bug modal */
body.oxy-modal-active
{
	height: unset !important;
	min-height: 100vh;
}

/* Page - Politique de confidentialité */
body.cmplz-document h1,
body.privacy-policy h1
{
	margin: 175px auto 50px;
	text-align: center;
	text-transform: none;
	font-family: sans-serif;
	font-size: 40px;
	font-weight: 700;
}

body.cmplz-document #cmplz-document,
body.cmplz-document .ct-inner-content:not(:has(#cmplz-document)),
body.privacy-policy #cmplz-document,
body.privacy-policy .ct-inner-content:not(:has(#cmplz-document))
{
	padding: 0 20px 100px;
}

body.cmplz-document #cmplz-document,
body.cmplz-document .ct-inner-content,
body.privacy-policy #cmplz-document,
body.privacy-policy .ct-inner-content
{
	margin: 0 auto;
	width: 1200px;
	max-width: 100%;
    color: black;
	font-family: sans-serif;
	font-size: 16px;
}

body.cmplz-document #cmplz-document h2,
body.cmplz-document #cmplz-document h3,
body.cmplz-document #cmplz-document .wp-block-paragraph:has(> strong),
body.cmplz-document .ct-inner-content h2,
body.cmplz-document .ct-inner-content h3,
body.cmplz-document .ct-inner-content .wp-block-paragraph:has(> strong),
body.privacy-policy #cmplz-document h2,
body.privacy-policy #cmplz-document h3,
body.privacy-policy #cmplz-document .wp-block-paragraph:has(> strong),
body.privacy-policy .ct-inner-content h2,
body.privacy-policy .ct-inner-content h3,
body.privacy-policy .ct-inner-content .wp-block-paragraph:has(> strong)
{
	margin-top: 50px;
	font-family: sans-serif;
	font-weight: 700;
}

body.cmplz-document .wp-block-paragraph > br,
body.privacy-policy .wp-block-paragraph > br
{
	display: none;
}


/* ----- CODE JUSTE POUR CE SITE ----- */

/* Fonts */
.triplex-font
{
	font-family: "triplexcondsansot-reg", sans-serif;
	font-weight: 400;
}

/* Buttons */
.btn::after
{
	top: 100%;
	right: -10px;
}

.btn:hover::after
{
	top: calc(100% + 5px);
	right: -20px;
	opacity: 1;
}

/* HEADER */
#-site-navigation-169-8 a
{
	text-decoration: none;
}

@media (max-width: 1400px)
{
	body #-site-navigation-169-8.oxy-site-navigation > ul
	{
		max-width: 100%;
		padding: 20px;
		-webkit-backdrop-filter: blur(10px); /* Safari */
		backdrop-filter: blur(10px);
		background-color: rgb(14 45 1 / 90%) !important;
		z-index: 9998;
		justify-content: center;
		align-items: center;
		gap: 40px;
	}

	body #-site-navigation-169-8.oxy-site-navigation > ul li.oxy-site-navigation__mobile-close-wrapper
	{
		display: none;
	}

	body #-site-navigation-169-8.oxy-site-navigation > ul li a
	{
		padding: 0;
		font-size: 30px;
		line-height: 1.2;
		text-align: center;
		text-wrap: wrap;
	}

	body #-site-navigation-169-8.oxy-site-navigation > ul li a::after
	{
		bottom: -5px;
	}
}

@media (max-width: 550px)
{
	body #-site-navigation-169-8.oxy-site-navigation > ul
	{
		gap: 30px;
	}

	body #-site-navigation-169-8.oxy-site-navigation > ul li a
	{
		font-size: 20px;
	}
}

/* Halo Background */
.has-halos
{
    position: relative;
    overflow: hidden;
	z-index: 0;
}

.has-halos::before
{
    content: '';
    position: absolute;
	top: -50vh;
	left: -20vh;
	height: 80vh;
	width: 90vh;
    border-radius: 500px;
    pointer-events: none;
	filter: blur(100px);
	transform: translate3d(0, 0, 0); /* Fix blur safari */
	background-color: #0f2f02;
    z-index: -1;
	animation: halo-green-animation 9s linear infinite reverse;
}

.has-halos::after
{
	content: "";
	position: absolute;
	bottom: -20vh;
	right: -10vh;
	height: 50vh;
	width: 50vh;
    border-radius: 500px;
    pointer-events: none;
	filter: blur(100px);
	transform: translate3d(0, 0, 0); /* Fix blur safari */
	background-color: #bcb4c8;
    z-index: -1;
	animation: halo-purple-animation 9s linear infinite reverse;
}

.darker-halos::after
{
	background-color: #7a7289;
}

.lighter-halos
{
	background-color: #dcdfda;
}

.lighter-halos::before
{
	background-color: #abb7a5;
}

.lighter-halos::after
{
	background-color: #c2b8ce;
}

@keyframes halo-green-animation
{
	0%
	{
		top: -30vh;
	}

	50%
	{
		top: -10vh;
		width: 120vh;
	}

	100%
	{
		top: -30vh;
	}
}

@keyframes halo-purple-animation
{
	0%
	{
		height: 60vh;
		width: 100vh;
	}

	50%
	{
		height: 50vh;
		width: 50vh;
	}

	100%
	{
		height: 60vh;
		width: 100vh;
	}
}

/* Section Hero */
.hero-section::after
{
	top: 70vh;
}

/* Section Three Cards */
.three-cards_link-wrapper:hover .three-cards_link-wrapper_icon
{
	transform: rotate(-45deg);
}

/* Sliding Text */
.sliding-text
{
	white-space: nowrap;
	will-change: transform;
}

.sliding-text .ct-text-block
{
	padding-right: 0.5em;
}

/* Section Réalisations */
.splide__slide
{
	position: relative;
	background-size: cover !important;
	background-image: none !important;
	gap: 10px;
	min-height: 23.5vw;
	justify-content: flex-end;
}

.splide__slide *
{
	margin: 0 !important;
	transition: all ease 0.4s;
}

.splide__slide .z-index_3
{
	z-index: 3 !important;
}

.splide__slide p:has(> span.oxy-stock-content-styles),
.splide__slide .ct-text-block:has(.carousel-content_text:empty),
.splide__slide p:empty
{
	display: none;
}

.splide__slide > img
{
	position: absolute;
	top: 30px;
	left: 30px;
	width: 58px;
}

.splide__slide .splide__image
{
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	z-index: 1;
	object-fit: cover;
}

.splide__slide .ct-text-block:has(> .carousel-tag)
{
	line-height: 1;
}

.splide__slide .ct-text-block:has(> .carousel-tag) span.carousel-tag > a
{
	pointer-events: none;
	color: var(--dark-green);
	font-weight: 600;
	text-decoration: none;
}

.splide__slide .wp-block-paragraph
{
	color: #0e2d01;
	font-size: 18px;
	line-height: 1.2;
	z-index: 3;
}

.splide__slide .wp-block-paragraph + figure
{
	display: none;
}

.splide__slide .carte-lien-overlay
{
	position: absolute;
	inset: 0;
	z-index: 5;
}

.splide__slide:hover::before
{
	top: 100%;
	right: 100%;
}

.splide__slide:hover *:not(.splide__image)
{
	opacity: 0;
}

.splide__pagination.splide__pagination--ltr
{
	display: none;
}

.splide__arrows .splide__arrow
{
	background: none;
}

.splide__arrows .splide__arrow--prev
{
	left: 0;
}

.splide__arrows .splide__arrow--next
{
	right: 0;
}

.section-realisations::before
{
	animation: halo-green-animation_section-realisations 9s linear infinite reverse;
}

@keyframes halo-green-animation_section-realisations
{
	0%
	{
		top: -30vh;
		left: -30vh;
		width: 80vh;
	}

	50%
	{
		top: -30vh;
		left: -30vh;
		width: 120vh;
	}

	100%
	{
		top: -30vh;
		left: -30vh;
		width: 80vh;
	}
}

@media (max-width: 1400px)
{
	.section-realisations::before
	{
		height: 60vh;
	}

	@keyframes halo-green-animation_section-realisations
	{
		0%
		{
			top: -30vh;
			left: -30vh;
			width: 60vh;
		}

		50%
		{
			top: -30vh;
			left: -30vh;
			width: 90vh;
		}

		100%
		{
			top: -30vh;
			left: -30vh;
			width: 60vh;
		}
	}
}

@media (max-width: 768px)
{
	@keyframes halo-green-animation_section-realisations
	{
		0%
		{
			top: -45vh;
			left: -30vh;
			width: 60vh;
		}

		50%
		{
			top: -45vh;
			left: -30vh;
			width: 90vh;
		}

		100%
		{
			top: -45vh;
			left: -30vh;
			width: 60vh;
		}
	}
}

/* FOOTER */
footer .footer_top-wrapper
{
	column-gap: 3vw;
	row-gap: 50px;
}

.footer-link:not(.footer_social-link_wrapper > .footer-link)
{
	text-decoration: underline !important;
	text-decoration-color: transparent !important;
	text-underline-offset: 5px;
}

.footer-link:not(.footer_social-link_wrapper > .footer-link):hover
{
	text-decoration-color: var(--beige) !important;
}

footer .footer_social-link_wrapper .footer_social-link_arrow > svg
{
	height: 100%;
	width: 100%;
	transform: rotate(-45deg);
	transition: all ease 0.4s;
}

footer .footer_social-link_wrapper:hover .footer_social-link_arrow > svg
{
	transform: rotate(0deg) translateX(2px);
}

@media (max-width: 530px)
{
	footer .footer_top-block
	{
		width: 100%;
		min-width: unset;
	}
}

/* ----- PAGES DE CONTENU ----- */
body:not(body.home) footer
{
	border-top: 1px solid rgb(255 255 255 / 10%);
}

.list ul
{
	margin: 0;
}

.list ul li
{
	margin-bottom: 0;
}

/* Breadcrumb */
.breadcrumb-link
{
	text-decoration: underline 1px transparent;
	text-underline-offset: 6px;
}

.breadcrumb-link:hover
{
	text-decoration-color: var(--beige);
}

/* Page Réalisations */
.oxy-gallery-masonry .oxy-gallery-item .oxy-gallery-item-contents img
{
	border-radius: 30px;
}

/* Square list */
.square-list ul
{
	padding-left: 0;
}

.square-list ul li
{
	list-style-type: none;
	position: relative;
}

.square-list ul li::marker
{
	font-size: 50px;
}

.square-list ul li::before
{
	content: "◼";
	margin-right: 7px;
}

/* Page - Les standistes X LOUPPE */
#div_block-191-34:hover #fancy_icon-194-34
{
    transform: rotate(0deg);
}

/* Page - Offres */
@media (max-width: 1350px)
{
	body #section-57-15 > .ct-section-inner-wrap
	{
		padding-top: 75px;
    	padding-bottom: 100px;
	}

	body #image-73-15
	{
		position: relative;
	}
}

/* Accordéons des pages Offres */
.oxel_accordion__content__hidden *
{
	opacity: 0;
}

/* Page - Brand Studio */
.livrables-list
{
	display: flex;
	flex-direction: column;
	gap: 0;
}

.livrables-list .livrable-line
{
	width: 100%;
	padding: 20px 0;
	border-bottom: 1px solid rgba(255,255,255,0.15);
	cursor: pointer;
	transition: all 0.3s ease;
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: 10px;
}

.livrable-puce
{
	color: var(--beige);
	font-weight: bold;
	font-size: 22px;
	opacity: 0;
	transform: scale(0.5);
	transition: all 0.25s ease;
}

.livrable-line:hover .livrable-puce
{
	opacity: 1;
	transform: scale(1);
}

.livrable-title
{
	line-height: 1;
	color: var(--beige);
	transition: all 0.3s ease;
}

.livrable-line:hover .livrable-title
{
	letter-spacing: 1px;
}

.livrable-preview
{
	position: fixed;
	top: 0;
	left: 0;
	pointer-events: none;
	opacity: 0;
	transition: opacity 0.3s ease;
	z-index: 1000;
	will-change: transform;
}

.livrable-preview.active
{
	opacity: 1;
}

.livrable-preview img
{
	width: 280px;
	height: 280px;
	object-fit: cover;
	box-shadow: 0 20px 60px rgba(0,0,0,0.4);
}

@media (max-width: 768px)
{
	.livrables-section { padding: 40px 20px; }
	.livrables-title { font-size: 32px; }
	.livrable-preview { display: none; }
}

/* FAQ - Pages Offres */
.faq-accordion .oxel_accordion__content__hidden
{
	margin-top: -30px;
}

/* FAQ - Page Notre Méthode */
.steps-accordion_row + .oxel_accordion__content__hidden
{
	margin-top: -45px;
}

/* Page - Réalisations */
.carousel-filters
{
	display: flex;
	justify-content: flex-start;
	align-items: center;
	flex-wrap: wrap;
	gap: 10px;
}

.carousel-filter-btn
{
	padding: 7px 15px 5px;
	border: 1px solid var(--primary-color);
	border-radius: 5px;
	background-color: transparent;
	text-transform: uppercase;
	font-size: 16px;
	color: var(--beige);
	transition: all ease 0.4s;
	cursor: pointer;
}

.carousel-filter-btn:hover,
.carousel-filter-btn.is-active
{
	background-color: #347525;
	border-color: #347525;
}

@media (max-width: 768px)
{
	.carousel-filter-btn
	{
		padding: 7px 10px 4px;
		font-size: 13px;
	}
}

.carousel_page-realisations
{
	gap: 75px;
}

.carousel_page-realisations .splide__list
{
	padding-bottom: 50px !important;
}

.carousel_page-realisations .splide__slide:nth-child(even)
{
	transform: translateY(50px);
}

/* Complianz */
#cmplz-manage-consent .cmplz-manage-consent
{
	box-shadow: rgba(0, 0, 0, 1) 0px 10px 20px, rgba(0, 0, 0, 0.23) 0px 6px 6px !important;
}