@charset "UTF-8";
/*!
Theme Name: Reacto
Description: Reacto theme - Blaaaz
Text Domain: reacto
Version: 1.0.0
Author: Blaaaz
Author URI: http://www.blaaaz.com
*/
:root {
  --white: hsla(0, 0%, 100%, 1);
  --lightgray: hsla(0, 0%, 86%, 1);
  --black: hsla(0, 0%, 0%, 1);
  --beige: hsla(51, 33%, 96%, 1);
  --darkblue: hsla(223, 47%, 23%, 1);
  --pink: hsla(287, 71%, 66%, 1);
  --darkpink: hsla(287, 56%, 51%, 1);
  --violet: hsla(253, 100%, 56%, 1);
  --blue-logo: hsla(208.33, 69.23%, 30.59%, 1);
  --lightblue: hsla(209, 100%, 95%, 1);
  --red: hsla(347.88, 85.02%, 44.51%, 1);
  --font-base: "Google Sans", sans-serif;
  --font-heading: "Montserrat", sans-serif;
  --fs-s: 0.875rem;
  --fs-reg: clamp(0.875rem, 0.8462rem + 0.1282vw, 1rem);
  --fs-m: clamp(1rem, 0.9423rem + 0.2564vw, 1.25rem);
  --fs-l: clamp(1.125rem, 0.9808rem + 0.641vw, 1.75rem);
  --fs-xl: clamp(1.25rem, 0.9904rem + 1.1538vw, 2.375rem);
  --fs-2xl: clamp(1.375rem, 1rem + 1.6667vw, 3rem);
  --fs-3xl: clamp(1.5rem, 0.9808rem + 2.3077vw, 3.75rem);
  --fs-4xl: clamp(2.25rem, 1.7308rem + 2.3077vw, 4.5rem);
  --fs-5xl: clamp(3rem, 2.3077rem + 3.0769vw, 6rem);
  --min-mobile-width: 320px;
  --min-tablet-width: 768px;
  --min-tablet-horizontal-width: 1025px;
  --min-desktop-width: 1280px;
  --medium-desktop: 1660px;
  --max-desktop-width: 1920px;
}

/**
 * BREAKPOINT (for-size)
 * 
 * deprecated
 */
/**
 * STRETCHED LINK (stretched-link)
 * Permet de rendre tout un bloc cliquable grâce au pseudo-élément `::after` de l'élément `<a>` enfant.
 */
.stretched-link {
  position: relative;
}
.stretched-link a[href]::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  z-index: 10;
}

/*@media (min-width: 1400px) {

	.container,
	.container-lg,
	.container-md,
	.container-sm,
	.container-xl,
	.container-xxl {
		max-width: 1660px;
	}
}*/
/**
 * REACTO GRADIENT
 * Dégradé principal de l'application
 * (pas au point)
 */
/**
 * BACKGROUND MODERN FORMATS
 * Gère AVIF et WebP pour les backgrounds CSS avec fallback
 * @param $path : le chemin de l'image
 * @param $rep : la répétition de l'image (no-repeat par défaut)
 * @param $pos : la position de l'image (center par défaut)
 * @param $size : la taille de l'image (cover par défaut)
 */
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
*::before, *::after {
  box-sizing: inherit;
}
*:focus {
  outline: none;
}

ul li {
  list-style-type: none;
}

a:active, a:focus, a:hover {
  outline: 0;
}

input[type=date],
input[type=datetime],
input[type=datetime-local],
input[type=email],
input[type=month],
input[type=number],
input[type=password],
input[type=range],
input[type=search],
input[type=tel],
input[type=text],
input[type=time],
input[type=url],
input[type=week] {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

html input[type=button],
input[type=reset],
input[type=submit] {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: auto;
  margin: 0;
  padding: 0;
  background: transparent;
  border: none;
  text-align: inherit;
  overflow: visible;
  cursor: pointer;
  -webkit-font-smoothing: inherit;
  -moz-osx-font-smoothing: inherit;
}

button[disabled],
input[disabled] {
  cursor: default;
}

input[type=checkbox],
input[type=radio] {
  box-sizing: border-box;
  padding: 0;
}

input[type=search] {
  -webkit-appearance: textfield;
  box-sizing: content-box;
}

input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

sub {
  font-size: 0.75em;
  vertical-align: baseline;
}

/*-------------------------------------------*\
	BASICS
\*-------------------------------------------*/
/**
 * body
 *
 */
html,
body {
  background-color: var(--beige);
  font-family: var(--font-base);
  font-size: var(--fs-text-base);
  color: var(--darkblue);
  line-height: 1.4;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  overflow-x: hidden;
}
html main:not(.main--no-margin),
body main:not(.main--no-margin) {
  margin-block-start: 9.25rem;
}

/*TITLE & FONT*/
.title1 {
  font-family: var(--font-heading);
  font-weight: 900;
  font-style: italic;
  font-size: var(--fs-4xl);
  line-height: 1;
  color: var(--white);
  text-transform: uppercase;
  letter-spacing: -0.02em;
}

.title2 {
  font-family: var(--font-heading);
  font-weight: 900;
  font-style: italic;
  font-size: var(--fs-3xl);
  line-height: 1;
  color: var(--darkblue);
  text-transform: uppercase;
  letter-spacing: -0.05em;
}

.title3 {
  font-family: var(--font-heading);
  font-weight: 900;
  font-style: italic;
  font-size: var(--fs-xl);
  line-height: 1;
  color: var(--darkblue);
  text-transform: uppercase;
  letter-spacing: -0.05em;
}

.title4 {
  font-family: var(--font-base);
  font-weight: 700;
  font-size: var(--fs-l);
  line-height: 1.3;
  color: var(--darkblue);
  letter-spacing: -0.05em;
}

.title-group > p {
  font-size: var(--fs-s);
  font-weight: 500;
  text-transform: uppercase;
}

/*CONTAINERS*/
.container_full {
  width: 100%;
  margin: auto;
}

.container_max {
  width: min(94%, 1920px);
  margin: auto;
}
.container_max__inner {
  max-width: 1660px;
  margin-inline: auto;
}

.container_medium {
  width: min(94%, 1660px);
  margin: auto;
}

/*
 * INPUTS FORM
 */
input,
textarea,
select,
button {
  font-family: var(--font-base);
}

/*
 * BOUTONS
 */
.btn, .ctis-load-more {
  position: relative;
  isolation: isolate;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 1.5em;
  background-color: transparent;
  color: var(--white);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1;
  border-radius: 5em;
  padding: 0 0 0 1.5em;
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
  border: 0;
}
.btn::before, .ctis-load-more::before {
  content: "";
  display: block;
  position: absolute;
  inset: 0 3em 0 0;
  border-radius: inherit;
  background-color: var(--pink);
  z-index: -1;
  transition: background-color 0.3s ease;
}
.btn::after, .ctis-load-more::after {
  content: "→";
  border-radius: inherit;
  background-color: var(--pink);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1em;
  width: 3em;
  height: 3em;
  font-weight: 400;
  box-sizing: border-box;
  transition: background-color 0.3s ease, transform 0.3s ease;
  transform-origin: 50% 50%;
}
.btn:hover::before, .ctis-load-more:hover::before {
  background-color: var(--darkpink);
}
.btn:hover::after, .ctis-load-more:hover::after {
  background-color: var(--darkpink);
  transform: rotate(-30deg);
}

.btn-menu {
  position: relative;
  isolation: isolate;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 1.5em;
  background-color: transparent;
  color: var(--white);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1;
  border-radius: 5em;
  padding: 0 1.5em 0 0;
  text-decoration: none;
  white-space: nowrap;
}
.btn-menu::before {
  content: "";
  display: block;
  position: absolute;
  inset: 0 0 0 3em;
  border-radius: inherit;
  background-color: var(--pink);
  z-index: -1;
  transition: background-color 0.3s ease;
}
.btn-menu::after {
  content: "≡";
  order: -1;
  border-radius: inherit;
  background-color: var(--pink);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5em;
  width: 2em;
  height: 2em;
  font-weight: 400;
  box-sizing: border-box;
  transition: background-color 0.3s ease, transform 0.3s ease;
  transform-origin: 50% 50%;
}
.btn-menu:hover::before {
  background-color: var(--darkpink);
}
.btn-menu:hover::after {
  background-color: var(--darkpink);
  transform: rotate(-30deg);
}

/**
 * Button menu with a tag inside
 * need to stretch the a tag to fill the button
 */
.btn-menu:not(a) {
  position: relative;
}
.btn-menu:not(a) > a::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 10;
}

/*
* LIQUID GLASS EFFECT
*/
.liquid-glass {
  border-radius: 10rem;
  position: relative;
  isolation: isolate;
  box-shadow: 0px 6px 24px rgba(0, 0, 0, 0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  border: none;
  background: none;
  text-decoration: none;
}

.liquid-glass:focus {
  outline: none;
}

.liquid-glass::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: 10rem;
  box-shadow: inset 0 0 20px -10px #ffffff;
  background-color: rgba(255, 255, 255, 0);
}

.liquid-glass::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  border-radius: 10rem;
  backdrop-filter: blur(20px) brightness(0.95);
  -webkit-backdrop-filter: blur(20px) brightness(0.95);
  filter: url(#glass-distortion);
  -webkit-filter: url(#glass-distortion);
}

.page_ml {
  padding-block: 5rem;
  padding-inline: 3rem;
}

/*-------------------------------------------*\
	SCROLLBARS
\*-------------------------------------------*/
::-webkit-scrollbar {
  width: 10px;
}

::-webkit-scrollbar-track {
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background-color: var(--pink);
  border-radius: 5px;
}

::-webkit-scrollbar-thumb:hover {
  background-color: var(--darkpink);
}

html {
  scrollbar-width: thin;
  scrollbar-color: var(--pink) hsla(0, 0%, 86%, 0.5);
}

/*!
Theme Name: Reacto
Description: Reacto theme - Blaaaz
Text Domain: reacto
Version: 1.0.0
Author: Blaaaz
Author URI: http://www.blaaaz.com
*/
.preheader {
  background-color: var(--violet);
  color: var(--white);
  padding: 0.75rem 0;
  text-align: center;
  font-size: 0.9rem;
}
.preheader p {
  margin: 0;
}
.preheader a {
  color: var(--white);
  text-decoration: underline;
  font-weight: 700;
  margin-left: 0.5rem;
  transition: opacity 0.3s ease;
}
.preheader a:hover {
  opacity: 0.8;
}

.header {
  position: absolute;
  top: auto;
  left: 0;
  width: 100%;
  z-index: 100;
  transition: background-color 0.3s ease, transform 0.3s ease;
}
.home .header {
  padding: 2rem 0 0 0;
}
.header.header-scroll {
  position: fixed;
  top: 0;
}
.header.header-hidden {
  transform: translateY(-100%);
}
.header__wrapper {
  margin: 1rem 2rem;
  padding: 2rem 2.5rem;
}
.header__content {
  width: 100%;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.header__logo {
  flex: 1 1 202px;
}
.header__logo-icon-svg {
  display: none;
  height: auto;
  width: min(100%, 50px);
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.15));
}
.header__logo-svg {
  display: block;
  height: auto;
  width: min(100%, 202px);
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.15));
}
.header__logo .logo-fill-primary {
  fill: var(--white);
  transition: fill 0.3s ease;
}
.header__nav .menu {
  display: flex;
  align-items: center;
  list-style: none;
  padding: 0;
  margin: 0;
  gap: 1rem;
}
.header__nav .menu a {
  color: var(--white);
  text-decoration: none;
  font-weight: 400;
  font-size: var(--fs-reg);
  transition: color 0.3s ease;
  display: block;
  white-space: nowrap;
}
.header__nav .menu li.btn a,
.header__nav .menu li.btn-menu a,
.header__nav .menu a.btn,
.header__nav .menu a.btn-menu {
  text-shadow: none;
}
.header.header--dark .logo-fill-primary {
  fill: var(--darkblue);
}
.menu-toggle {
  display: none;
  width: 2em;
  height: 2em;
  aspect-ratio: 1;
  border-radius: 5em;
  background-color: var(--pink);
  border: none;
  font-family: var(--font-base);
  color: var(--white);
  font-size: 1.5rem;
  font-weight: 400;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  z-index: 101;
  padding: 0;
  line-height: 1;
  transition: background-color 0.3s ease, transform 0.3s ease;
  transform-origin: 50% 50%;
}
.menu-toggle:hover {
  background-color: var(--darkpink);
  transform: rotate(-390deg);
}

.menu-close {
  display: none;
}

.mobile-menu-header {
  display: none;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  margin-bottom: 2rem;
  padding-bottom: 1rem;
  padding-inline: 1rem;
}
.mobile-menu-header .megamenu-logo {
  width: 120px;
  height: auto;
}
.mobile-menu-header .megamenu-logo svg {
  width: 100%;
  height: auto;
  display: block;
}
.mobile-menu-header .menu-close-text {
  background: none;
  border: none;
  cursor: pointer;
  font-size: var(--fs-s);
  font-weight: 400;
  color: var(--darkblue);
  font-family: var(--font-base);
  text-transform: none;
  padding: 0;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.mobile-menu-header .menu-close-text svg {
  display: block;
  width: 14px;
  height: 14px;
}
html:has(body.megamenu-open),
html:has(body.menu-open),
body.megamenu-open,
body.menu-open {
  overflow: hidden;
  height: 100vh;
  height: 100dvh;
  touch-action: none;
  overscroll-behavior: none;
}

body.menu-open .header {
  z-index: 2000;
}
body.menu-open::after {
  content: "";
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 1500;
}

/*!
Theme Name: Reacto
Description: Reacto theme - Blaaaz
Text Domain: reacto
Version: 1.0.0
Author: Blaaaz
Author URI: http://www.blaaaz.com
*/
.header__nav .menu-item-has-children > .sub-menu {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-top-right-radius: 1.5rem;
  border-bottom-right-radius: 1.5rem;
  background-color: var(--white);
  transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1), visibility 0.4s;
  overflow-y: auto;
  overflow-x: hidden;
  z-index: 9999;
  visibility: hidden;
  pointer-events: none;
}

.header__nav .menu-item.open-megamenu {
  z-index: 1000;
}
.header__nav .menu-item.open-megamenu > .sub-menu {
  background-color: var(--white);
  position: fixed;
  top: 0;
  left: 0;
  width: min(90%, 380px);
  height: auto;
  max-height: 100vh;
  max-height: 100dvh;
  border-top-right-radius: 1.5rem;
  border-bottom-right-radius: 1.5rem;
  box-shadow: -5px 0 25px rgba(0, 0, 0, 0.15);
  z-index: 99999;
  transform: translateX(-100%);
  transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1), visibility 0.4s;
  opacity: 1;
  visibility: hidden;
  pointer-events: none;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  padding-top: 6.25rem;
}
.header__nav .menu-item.open-megamenu > .sub-menu a {
  color: var(--darkblue);
  text-shadow: none;
  line-height: 1.5;
  padding-block: 0.5rem;
}
.header__nav .menu-item.open-megamenu > .sub-menu {
  /**
   * Titre de sous-menu non cliquable
   */
}
.header__nav .menu-item.open-megamenu > .sub-menu .titre-non-cliquable > a,
.header__nav .menu-item.open-megamenu > .sub-menu li.titre-non-cliquable > a {
  pointer-events: none;
  cursor: default;
  border-top: solid 1px var(--lightgray);
  padding-block-start: 2em;
  font-weight: bold;
  color: var(--pink);
  text-transform: uppercase;
  margin-inline: 0;
}
.header__nav .menu-item.open-megamenu > .sub-menu .megamenu-logo {
  display: none;
  position: absolute;
  top: 1.875rem;
  left: 1rem;
  width: 140px;
  height: auto;
  z-index: 20;
}
.header__nav .menu-item.open-megamenu > .sub-menu .megamenu-logo svg {
  display: block;
  width: 100%;
  height: auto;
}
.header__nav .menu-item.open-megamenu > .sub-menu .menu-close-panel {
  display: none;
  position: absolute;
  top: 2.8125rem;
  right: 1rem;
  cursor: pointer;
  font-size: var(-fs-s);
  font-weight: 400;
  color: var(--darkblue);
  z-index: 20;
  align-items: center;
  gap: 0.75rem;
}
.header__nav .menu-item.open-megamenu > .sub-menu .menu-close-panel svg {
  display: block;
  width: 14px;
  height: 14px;
}
.header__nav .menu-item.open-megamenu > .sub-menu > .menu-item:not(.collapsible-section):not(.back-button),
.header__nav .menu-item.open-megamenu > .sub-menu > .megamenu-scroll-content > .menu-item:not(.collapsible-section):not(.back-button) {
  margin-bottom: 2rem;
}
.header__nav .menu-item.open-megamenu > .sub-menu > .menu-item:not(.collapsible-section):not(.back-button) > a,
.header__nav .menu-item.open-megamenu > .sub-menu > .megamenu-scroll-content > .menu-item:not(.collapsible-section):not(.back-button) > a {
  font-size: 1.2rem;
  font-weight: 800;
  color: var(--pink);
  text-transform: uppercase;
  pointer-events: none;
  cursor: default;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  border-top: solid 1px var(--lightgray);
  padding-block-start: 2em;
}
.header__nav .menu-item.open-megamenu > .sub-menu > .menu-item:not(.collapsible-section):not(.back-button) > a::after,
.header__nav .menu-item.open-megamenu > .sub-menu > .megamenu-scroll-content > .menu-item:not(.collapsible-section):not(.back-button) > a::after {
  display: none;
}
.header__nav .menu-item.open-megamenu > .sub-menu > .menu-item:not(.collapsible-section):not(.back-button).header-with-view-all > a,
.header__nav .menu-item.open-megamenu > .sub-menu > .megamenu-scroll-content > .menu-item:not(.collapsible-section):not(.back-button).header-with-view-all > a {
  border-top: none;
  padding-block-start: 0;
}
.header__nav .menu-item.open-megamenu > .sub-menu > .menu-item:not(.collapsible-section):not(.back-button).header-with-view-all > a::after,
.header__nav .menu-item.open-megamenu > .sub-menu > .megamenu-scroll-content > .menu-item:not(.collapsible-section):not(.back-button).header-with-view-all > a::after {
  content: "Voir tout";
  display: block;
  font-size: 0.9rem;
  color: var(--darkblue);
  text-decoration: underline;
  font-weight: 500;
  text-transform: none;
  pointer-events: auto;
  cursor: pointer;
}
.header__nav .menu-item.open-megamenu > .sub-menu > .menu-item:not(.collapsible-section):not(.back-button).header-with-view-all > a:hover::after,
.header__nav .menu-item.open-megamenu > .sub-menu > .megamenu-scroll-content > .menu-item:not(.collapsible-section):not(.back-button).header-with-view-all > a:hover::after {
  color: var(--pink);
}
.header__nav .menu-item.open-megamenu > .sub-menu > .menu-item:not(.collapsible-section):not(.back-button).menu-item-has-children > .sub-menu,
.header__nav .menu-item.open-megamenu > .sub-menu > .megamenu-scroll-content > .menu-item:not(.collapsible-section):not(.back-button).menu-item-has-children > .sub-menu {
  position: static;
  transform: none;
  visibility: visible;
  opacity: 1;
  width: 100%;
  height: auto;
  background: transparent;
  box-shadow: none;
  padding: 0.5rem 0 0 0;
  display: block;
  pointer-events: auto;
  overflow: visible;
}
.header__nav .menu-item.open-megamenu > .sub-menu > .menu-item:not(.collapsible-section):not(.back-button).menu-item-has-children > .sub-menu > .menu-item > a,
.header__nav .menu-item.open-megamenu > .sub-menu > .megamenu-scroll-content > .menu-item:not(.collapsible-section):not(.back-button).menu-item-has-children > .sub-menu > .menu-item > a {
  font-size: 1rem;
  color: var(--darkblue);
  font-weight: 400;
  padding: 0.25rem 0;
}
.header__nav .menu-item.open-megamenu > .sub-menu > .menu-item:not(.collapsible-section):not(.back-button).menu-item-has-children > .sub-menu > .menu-item.menu-item-has-children,
.header__nav .menu-item.open-megamenu > .sub-menu > .megamenu-scroll-content > .menu-item:not(.collapsible-section):not(.back-button).menu-item-has-children > .sub-menu > .menu-item.menu-item-has-children {
  display: flex;
  align-items: center;
}
.header__nav .menu-item.open-megamenu > .sub-menu > .menu-item:not(.collapsible-section):not(.back-button).menu-item-has-children > .sub-menu > .menu-item.menu-item-has-children > a,
.header__nav .menu-item.open-megamenu > .sub-menu > .megamenu-scroll-content > .menu-item:not(.collapsible-section):not(.back-button).menu-item-has-children > .sub-menu > .menu-item.menu-item-has-children > a {
  flex: 1;
}
.header__nav .menu-item.open-megamenu > .sub-menu > .menu-item:not(.collapsible-section):not(.back-button).menu-item-has-children > .sub-menu > .menu-item.menu-item-has-children > a::after,
.header__nav .menu-item.open-megamenu > .sub-menu > .megamenu-scroll-content > .menu-item:not(.collapsible-section):not(.back-button).menu-item-has-children > .sub-menu > .menu-item.menu-item-has-children > a::after {
  display: none;
}
.header__nav .menu-item.open-megamenu > .sub-menu > .menu-item:not(.collapsible-section):not(.back-button).menu-item-has-children > .sub-menu > .menu-item.menu-item-has-children > .submenu-toggle,
.header__nav .menu-item.open-megamenu > .sub-menu > .megamenu-scroll-content > .menu-item:not(.collapsible-section):not(.back-button).menu-item-has-children > .sub-menu > .menu-item.menu-item-has-children > .submenu-toggle {
  background: none;
  border: none;
  padding: 0.25rem;
  min-width: 2.25rem;
  min-height: 2rem;
  color: var(--pink);
  font-size: 1.5em;
  line-height: 1;
  cursor: pointer;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.header__nav .menu-item.open-megamenu > .sub-menu .collapsible-section,
.header__nav .menu-item.open-megamenu > .sub-menu li.collapsible-section {
  display: flex;
  align-items: center;
  border-top: solid 1px var(--lightgray);
  padding-block-start: 2em;
}
.header__nav .menu-item.open-megamenu > .sub-menu .collapsible-section > a,
.header__nav .menu-item.open-megamenu > .sub-menu li.collapsible-section > a {
  flex: 1;
  pointer-events: none;
  cursor: default;
  font-weight: 800;
  font-size: 1.2rem;
  color: var(--pink);
  text-transform: uppercase;
}
.header__nav .menu-item.open-megamenu > .sub-menu .collapsible-section > a::after,
.header__nav .menu-item.open-megamenu > .sub-menu li.collapsible-section > a::after {
  display: none;
}
.header__nav .menu-item.open-megamenu > .sub-menu .collapsible-section > .submenu-toggle,
.header__nav .menu-item.open-megamenu > .sub-menu li.collapsible-section > .submenu-toggle {
  background: none;
  border: none;
  padding: 0.5rem;
  min-width: 2.75rem;
  min-height: 2.75rem;
  color: var(--pink);
  font-size: 1.5em;
  line-height: 1;
  cursor: pointer;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.header__nav .menu-item.open-megamenu > .sub-menu .back-button {
  display: block;
  margin-bottom: 1rem;
}
.header__nav .menu-item.open-megamenu > .sub-menu .back-button > a {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.85rem;
  text-transform: uppercase;
  font-weight: 800;
  color: var(--pink);
}
.header__nav .menu-item.open-megamenu > .sub-menu .back-button > a::before {
  content: "‹";
  font-size: 1.5em;
  line-height: 0;
  padding-block-end: 0.25em;
  transition: transform 0.2s ease;
}
.header__nav .menu-item.open-megamenu > .sub-menu .back-button > a::after {
  display: none;
}
.header__nav .menu-item.open-megamenu > .sub-menu .back-button > a:hover::before {
  transform: translateX(-6px);
}
.header__nav .menu-item.open-megamenu > .sub-menu .megamenu-scroll-content {
  overflow-y: auto;
  overflow-x: hidden;
}
.header__nav .menu-item.open-megamenu > .sub-menu .megamenu-scroll-content a:hover {
  text-decoration: underline;
}
.header__nav .menu-item.open-megamenu > .sub-menu .megamenu-scroll-content .back-button > a:hover,
.header__nav .menu-item.open-megamenu > .sub-menu .megamenu-scroll-content .header-with-view-all > a:hover,
.header__nav .menu-item.open-megamenu > .sub-menu .megamenu-scroll-content .collapsible-section > a:hover {
  text-decoration: none;
}
.header__nav .menu-item.open-megamenu > .sub-menu .megamenu-scroll-content .submenu-toggle {
  transition: transform 0.2s ease;
}
.header__nav .menu-item.open-megamenu > .sub-menu .megamenu-scroll-content .submenu-toggle:hover {
  transform: translateX(6px);
}
.header__nav .menu-item.open-megamenu > .sub-menu .megamenu-scroll-content {
  overscroll-behavior: contain;
  padding-inline: 0 1rem;
  margin: 0 1rem 2rem 0;
  flex: 1;
  min-height: 0;
}
.header__nav .menu-item.open-megamenu > .sub-menu .megamenu-scroll-content::-webkit-scrollbar {
  width: 5px;
}
.header__nav .menu-item.open-megamenu > .sub-menu .megamenu-scroll-content::-webkit-scrollbar-thumb {
  background-color: hsl(287, 71%, 66%);
  border-radius: 5px;
}
.header__nav .menu-item.open-megamenu > .sub-menu .megamenu-scroll-content::-webkit-scrollbar-thumb:active {
  background-color: hsl(287, 71%, 66%);
}
.header__nav .menu-item.open-megamenu > .sub-menu .megamenu-scroll-content {
  scrollbar-width: thin;
  scrollbar-color: hsl(287, 71%, 66%) hsla(0, 0%, 86%, 0.5);
}
.header__nav .menu-item-has-children > .sub-menu {
  transform: translateX(100%);
  z-index: 100;
  padding-inline: 2.5rem 0;
}
.header__nav .menu-item-has-children > .sub-menu.submenu-active {
  visibility: visible;
  pointer-events: auto;
}
.header__nav .menu-item-has-children > .sub-menu .menu-item-has-children > a {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.header__nav .menu-item-has-children > .sub-menu .menu-item-has-children > a::after {
  content: "›";
  color: var(--pink);
  font-size: 1.5em;
  line-height: 0;
}
/*!
Theme Name: Reacto
Description: Reacto theme - Blaaaz
Text Domain: reacto
Version: 1.0.0
Author: Blaaaz
Author URI: http://www.blaaaz.com
*/
.footer {
  margin-block-end: 2rem;
}
.footer a {
  color: var(--white);
  text-decoration: none;
}
.footer a:hover {
  text-decoration: underline;
}
.footer__inner {
  background-color: hsla(223, 47%, 23%, 0.6);
  background-image: radial-gradient(44.43% 94.78% at 0.73% 5.22%, rgba(203, 108, 230, 0.8) 0%, rgba(203, 108, 230, 0) 100%), radial-gradient(32.42% 69.17% at 100% 27.33%, rgba(145, 27, 213, 0.8) 0%, rgba(145, 27, 213, 0) 100%), -webkit-image-set(url("images/bg_footer_2k.avif") type("image/avif"), url("images/bg_footer_2k.webp") type("image/webp"));
  background-image: radial-gradient(44.43% 94.78% at 0.73% 5.22%, rgba(203, 108, 230, 0.8) 0%, rgba(203, 108, 230, 0) 100%), radial-gradient(32.42% 69.17% at 100% 27.33%, rgba(145, 27, 213, 0.8) 0%, rgba(145, 27, 213, 0) 100%), image-set(url("images/bg_footer_2k.avif") type("image/avif"), url("images/bg_footer_2k.webp") type("image/webp"));
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-blend-mode: color;
  border-radius: 1.5rem;
  color: var(--white);
  padding-block-start: clamp(0.625rem, 0.3077rem + 1.4103vw, 2rem);
}
.footer__inner .footer__content {
  width: min(90%, 1660px);
  margin-inline: auto;
}
.footer__inner .reassurance {
  margin-block-end: 2rem;
}
.footer__inner .reassurance__inner {
  padding: 1em;
  display: flex; /* Mobile default for Swiper */
  font-size: var(--fs-s);
}
.footer__inner .reassurance__item {
  padding: 1em 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 1.5em;
  line-height: 1.2;
}
.footer__inner .reassurance__item {
  /* Swiper fixes */
  height: auto;
}
.footer__inner .menus {
  margin-block: 1rem;
  display: grid;
  grid-template-columns: 1fr;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  line-height: 1.6;
}
.footer__inner .menus .title {
  font-size: inherit;
  font-weight: 700;
  text-transform: uppercase;
}
.footer__inner .menus ul {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
}
.footer__inner .menus .institutionnels ul {
  gap: 1rem;
}
.footer__inner .contact {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  text-align: center;
  gap: 1rem;
}
.footer__inner .contact .coordonnees {
  display: flex;
  flex-direction: column;
}
.footer__inner .contact .logo {
  width: 100%;
  max-width: 186px;
}
.footer__inner .contact .logo svg {
  width: 100%;
  height: auto;
}
.footer__inner .contact .social {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.5rem;
}
.footer__inner .logo_federation {
  display: block;
  width: 100%;
  margin-inline: auto;
  margin-block-end: 2rem;
  max-width: 184px;
}
.footer .legal {
  border-bottom: solid 1px var(--white);
  margin-block-end: 2rem;
  padding-block-end: 2rem;
}
.footer .legal ul {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
}
.footer__bottom {
  width: 104%;
  margin-inline-start: -1%;
}
.footer__bottom__logo {
  display: flex;
  justify-content: center;
  align-items: center;
}
.footer__bottom__logo svg {
  display: block;
  height: auto;
  margin-inline: auto;
  max-width: 100%;
}

/*!
Theme Name: Reacto
Description: Reacto theme - Blaaaz
Text Domain: reacto
Version: 1.0.0
Author: Blaaaz
Author URI: http://www.blaaaz.com
*/
.menu-item-search .search-form {
  position: relative;
  display: flex;
  align-items: center;
}
.menu-item-search label {
  width: 100%;
  margin-bottom: 0;
}
.menu-item-search .screen-reader-text {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.menu-item-search .search-field {
  width: auto;
  padding: 0.75rem 2.5rem 0.75rem 1.5rem;
  border-radius: 50px;
  border: solid 1px var(--lightgray);
  font-family: var(--font-base);
  font-size: var(--fs-reg);
  color: var(--darkblue);
  background-color: var(--white);
  outline: none;
}
.menu-item-search .search-field::-moz-placeholder {
  color: var(--darkblue);
  opacity: 1;
}
.menu-item-search .search-field::placeholder {
  color: var(--darkblue);
  opacity: 1;
}
.menu-item-search .search-field:focus {
  box-shadow: 0 0 0 2px var(--darkpink);
}
.menu-item-search .search-submit {
  position: absolute;
  right: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  display: block;
  width: 1.25rem;
  height: 1.25rem;
  font-size: 0;
  color: transparent;
  background-color: var(--darkpink);
  -webkit-mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><circle cx="11" cy="11" r="8"></circle><line x1="21" y1="21" x2="16.65" y2="16.65"></line></svg>') no-repeat center center;
  mask: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="black" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><circle cx="11" cy="11" r="8"></circle><line x1="21" y1="21" x2="16.65" y2="16.65"></line></svg>') no-repeat center center;
  -webkit-mask-size: contain;
  mask-size: contain;
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background-color 0.3s ease, transform 0.3s ease;
  transform-origin: 0 50%;
}
.menu-item-search .search-form:hover .search-submit {
  background-color: var(--pink);
  transform: translate(-50%, -20%) scale(1.2) rotate(-30deg);
}

#breadcrumbs {
  width: min(86%, 1660px);
  margin-inline: auto;
  font-size: var(--fs-s);
  line-height: var(--fs-s);
  margin-block: 1rem;
  color: var(--pink);
}
#breadcrumbs > span {
  font-size: 1.75em;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
#breadcrumbs a {
  font-size: var(--fs-s);
  color: var(--darkblue);
  text-decoration: none;
}
#breadcrumbs a:hover {
  text-decoration: underline;
}
#breadcrumbs strong {
  font-size: var(--fs-s);
  color: var(--darkblue);
}

.floating-cta {
  position: fixed;
  bottom: 1%;
  right: 1%;
  z-index: 200;
  display: flex;
  align-items: center;
}
.floating-cta__number-wrap {
  clip-path: inset(-30px 0px -30px 100%);
  transition: clip-path 0.45s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.floating-cta__number {
  display: flex;
  align-items: center;
  padding: 4px;
  height: 3rem;
  white-space: nowrap;
  text-decoration: none;
  transform: translateX(110%);
  transition: transform 0.45s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.floating-cta__number > span {
  display: flex;
  align-items: center;
  padding: 0 1.25em;
  height: 100%;
  background-color: var(--pink);
  border-radius: 10rem;
  color: var(--white);
  font-weight: 700;
  font-size: 1rem;
}
.floating-cta__trigger {
  flex-shrink: 0;
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  background-color: var(--pink);
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0px 6px 24px rgba(0, 0, 0, 0.2);
  transition: background-color 0.3s ease, transform 0.3s ease;
  position: relative;
  z-index: 1;
}
.floating-cta__trigger:hover {
  background-color: var(--darkpink);
  transform: scale(1.1);
}
.floating-cta.is-open .floating-cta__number-wrap {
  clip-path: inset(-30px);
}
.floating-cta.is-open .floating-cta__number {
  transform: translateX(0);
}

/*!
Theme Name: Reacto
Description: Reacto theme - Blaaaz
Text Domain: reacto
Version: 1.0.0
Author: Blaaaz
Author URI: http://www.blaaaz.com
*/
/*!
Theme Name: Reacto
Description: Reacto theme - Blaaaz
Text Domain: reacto
Version: 1.0.0
Author: Blaaaz
Author URI: http://www.blaaaz.com
*/
.realisations {
  padding: clamp(2.5rem, 1.3462rem + 5.1282vw, 7.5rem) clamp(0.625rem, 0.4231rem + 0.8974vw, 1.5rem);
  border-radius: 1.5rem;
  background: linear-gradient(0deg, hsla(281, 100%, 95%, 0.8), hsla(281, 100%, 95%, 0.8)), url("images/bg_1k.webp") no-repeat center center/cover;
  background: linear-gradient(0deg, hsla(281, 100%, 95%, 0.8), hsla(281, 100%, 95%, 0.8)), -webkit-image-set(url("images/bg_1k.avif") type("image/avif"), url("images/bg_1k.webp") type("image/webp")) no-repeat center center/cover;
  background: linear-gradient(0deg, hsla(281, 100%, 95%, 0.8), hsla(281, 100%, 95%, 0.8)), image-set(url("images/bg_1k.avif") type("image/avif"), url("images/bg_1k.webp") type("image/webp")) no-repeat center center/cover;
}
.realisations header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-block-end: 4rem;
}
.realisations__content {
  overflow: hidden;
  position: relative;
}
.realisations__content .swiper-button-next,
.realisations__content .swiper-button-prev {
  color: var(--white);
  background-color: var(--pink);
  width: 3em;
  height: 3em;
  border-radius: 50%;
  top: 50%;
  z-index: 10;
  transition: background-color 0.3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.realisations__content .swiper-button-next::after,
.realisations__content .swiper-button-prev::after {
  font-family: var(--font-base);
  font-size: 1em;
  font-weight: 400;
}
.realisations__content .swiper-button-next svg,
.realisations__content .swiper-button-prev svg {
  display: none;
}
.realisations__content .swiper-button-next:hover,
.realisations__content .swiper-button-prev:hover {
  background-color: var(--darkpink);
}
.realisations__content .swiper-button-prev {
  left: 0.5rem;
}
.realisations__content .swiper-button-prev::after {
  content: "←";
}
.realisations__content .swiper-button-next {
  right: 0.5rem;
}
.realisations__content .swiper-button-next::after {
  content: "→";
}
.realisations {
  /* Swiper Essential Styles */
}
.realisations .swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: flex;
  transition-property: transform;
  box-sizing: content-box;
}
.realisations .realisation-item {
  background-color: var(--white);
  border-radius: 1.5rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  aspect-ratio: 540/610;
  padding: 1.5rem;
  flex-shrink: 0;
}
.realisations .realisation-item__inner {
  width: 100%;
  height: 100%;
  background-color: var(--white);
  border-radius: 1rem;
  overflow: hidden;
  position: relative;
}
.realisations .realisation-item__inner:hover .realisation-item__client {
  opacity: 1;
  transform: translate(-50%, -50%);
}
.realisations .realisation-item__inner:hover img {
  opacity: 0.3;
}
.realisations .realisation-item__inner .realisation-item__link {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  position: relative;
  text-decoration: none;
}
.realisations .realisation-item__inner .realisation-item__client {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -40%);
  background-color: var(--darkblue);
  color: var(--white);
  padding: 0.5rem 1rem;
  border-radius: 2rem;
  font-family: var(--font-heading);
  font-weight: 800;
  text-transform: uppercase;
  font-size: var(--fs-s);
  white-space: nowrap;
  opacity: 0;
  transition: all 0.3s ease;
  pointer-events: none;
  z-index: 2;
}
.realisations .realisation-item__inner picture,
.realisations .realisation-item__inner img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  transition: opacity 0.3s ease;
}

/*!
Theme Name: Reacto
Description: Reacto theme - Blaaaz
Text Domain: reacto
Version: 1.0.0
Author: Blaaaz
Author URI: http://www.blaaaz.com
*/
.qsn-section {
  background-image: url("images/bg_hero_mob.webp");
  background-image: -webkit-image-set(url("images/bg_hero_mob.avif") type("image/avif"), url("images/bg_hero_mob.webp") type("image/webp"));
  background-image: image-set(url("images/bg_hero_mob.avif") type("image/avif"), url("images/bg_hero_mob.webp") type("image/webp"));
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-blend-mode: overlay;
  color: var(--white);
  padding: clamp(0.625rem, 0.3077rem + 1.4103vw, 2rem);
  border-radius: 2rem;
}
.qsn-section__wrapper {
  width: 100%;
  margin-inline: auto;
  display: grid;
  gap: clamp(0.625rem, 0.4808rem + 0.641vw, 1.25rem);
}
.qsn-section__wrapper .visuels img {
  display: block;
  border-radius: 2rem;
  width: 100%;
  height: 100%;
  aspect-ratio: 1/1;
  -o-object-fit: cover;
     object-fit: cover;
}
.qsn-section__wrapper .visuels .pic1 {
  display: block;
}
.qsn-section__wrapper .visuels .pic2 {
  display: none;
}
.qsn-section__wrapper .visuels .pic3 {
  display: none;
}
.qsn-section__wrapper .visuels .pic4 {
  display: none;
}
.qsn-section__wrapper .visuels .pic5 {
  display: none;
}
.qsn-section__wrapper .content {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  background-color: var(--white);
  padding: 2rem;
  border-radius: 2rem;
  color: var(--darkblue);
  line-height: 1.6;
}
.qsn-section__wrapper .stats {
  margin-block: 2rem;
}
.qsn-section__wrapper .stats li {
  color: var(--white);
}
.qsn-section__wrapper .stats li strong {
  font-size: var(--fs-4xl);
  font-style: italic;
  word-break: normal;
  color: var(--pink);
}
.qsn-section__wrapper .stats li span {
  font-family: var(--font-body);
  font-size: var(--fs-m);
  word-break: break-word;
  color: var(--white);
}

/*!
Theme Name: Reacto
Description: Reacto theme - Blaaaz
Text Domain: reacto
Version: 1.0.0
Author: Blaaaz
Author URI: http://www.blaaaz.com
*/
.partenaires {
  overflow: hidden;
}
.partenaires .title-group {
  margin-block-end: 3rem;
}
.partenaires__marquee {
  --marquee-gap: 2rem;
  display: flex;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  -webkit-mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent);
          mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent);
}
.partenaires__marquee .marquee-content {
  background-color: var(--beige);
  flex-shrink: 0;
  display: flex;
  justify-content: space-around;
  min-width: 100%;
  gap: var(--marquee-gap);
  animation: marquee 30s linear infinite;
}
.partenaires__marquee .marquee-group {
  display: flex;
  align-items: center;
  gap: var(--marquee-gap);
  flex-shrink: 0;
}
.partenaires__marquee .marquee-group picture {
  width: clamp(102px, 8vw, 150px);
  flex-shrink: 0;
}
.partenaires__marquee .marquee-group picture img {
  width: 100%;
  height: auto;
  display: block;
  -o-object-fit: contain;
     object-fit: contain;
  mix-blend-mode: multiply;
  /* Optionnel : passer en noir et blanc avant le mélange pour plus d'unité */
  filter: grayscale(100%);
}

@keyframes marquee {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(calc(-50% - 1rem));
  }
}
.home .main {
  margin-block-start: 1.25rem;
}
.home section {
  margin-block: min(14vw, 7.5rem);
}
.home .hero {
  margin-block-start: 0;
  background: url("images/lightning.svg") no-repeat top center/140%, url("images/hp/bg_hero_mob.webp") no-repeat center center/cover;
  background: url("images/lightning.svg") no-repeat top center/140%, -webkit-image-set(url("images/hp/bg_hero_mob.avif") type("image/avif"), url("images/hp/bg_hero_mob.webp") type("image/webp")) no-repeat center center/cover;
  background: url("images/lightning.svg") no-repeat top center/140%, image-set(url("images/hp/bg_hero_mob.avif") type("image/avif"), url("images/hp/bg_hero_mob.webp") type("image/webp")) no-repeat center center/cover;
  background-blend-mode: overlay;
  color: var(--white);
  padding: 2rem;
  border-radius: 2rem;
}
.home .hero__inner {
  padding-block: 8rem 6rem;
}
.home .hero__inner .visuel {
  position: relative;
}
.home .hero__inner .visuel picture {
  display: none;
}
.home .hero__inner .visuel picture.is-active {
  display: block;
}
.home .hero__inner .visuel picture img {
  width: 100%;
  height: auto;
  display: block;
}
.home .hero__inner .content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.home .hero__inner .content .title {
  width: 100%;
  margin-block-end: 2rem;
}
.home .hero__inner .content .title .title-svg {
  width: 100%;
  height: auto;
  display: block;
  overflow: visible;
}
.home .hero__inner .content .title .title-svg.on-mobile {
  display: block;
}
.home .hero__inner .content .title .title-svg.on-mobile text {
  text-anchor: middle;
}
.home .hero__inner .content .title .title-svg.on-desktop {
  display: none;
}
.home .hero__inner .content .title .title-svg.on-desktop text {
  text-anchor: start;
}
.home .hero__inner .content .title .title-svg text {
  font-family: var(--font-heading);
  font-weight: 900;
  font-style: italic;
  text-transform: uppercase;
  letter-spacing: -0.02em;
}
.home .hero__inner .content .title .title-svg text.line-solid {
  fill: var(--white);
}
.home .hero__inner .content .title .title-svg text.line-outline {
  fill: var(--black);
  stroke: var(--white);
  paint-order: stroke;
  stroke-width: 0.05em;
  mix-blend-mode: lighten;
}
.home .tendances header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-block-end: 3rem;
}
.home .tendances .tendances__list ul.products {
  margin: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 300px), 1fr));
  gap: 1.25rem;
  justify-content: center;
}
.home .tendances .tendances__list ul.products li.product.card {
  position: relative;
  width: 100%;
  max-width: 400px;
  margin: 0 auto;
  background-color: var(--white);
  border-radius: 1.5rem;
  padding: 0.625rem;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.home .tendances .tendances__list ul.products li.product.card:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05);
}
.home .tendances .tendances__list ul.products li.product.card .card__container {
  display: flex;
  flex-direction: column;
  height: 100%;
  width: 100%;
}
.home .tendances .tendances__list ul.products li.product.card .card__categories {
  font-weight: 700;
  font-size: 0.625rem;
  text-transform: uppercase;
  margin-block-end: 1.5rem;
}
.home .tendances .tendances__list ul.products li.product.card a.woocommerce-LoopProduct-link {
  display: flex;
  flex-direction: column;
  height: 100%;
  text-decoration: none;
  color: inherit;
}
.home .tendances .tendances__list ul.products li.product.card a.woocommerce-LoopProduct-link img {
  width: 100%;
  height: auto;
  aspect-ratio: 1/1;
  -o-object-fit: contain;
     object-fit: contain;
  margin-block-end: auto;
}
.home .tendances .tendances__list ul.products li.product.card a.woocommerce-LoopProduct-link .woocommerce-loop-product__title {
  color: var(--darkblue);
  padding: 0;
  font-size: var(--fs-reg);
  line-height: 1.2;
  text-transform: uppercase;
  height: 48px;
  display: flex;
  align-items: flex-end;
}
.home .tendances .tendances__list ul.products li.product.card .price {
  color: #1f2f56;
  font-size: 12px;
  line-height: 1.2;
  margin-top: 0.2em;
}
.home .tendances .tendances__list ul.products li.product.card .price .marquage-inclus {
  display: block;
  font-size: 0.85em;
}
.home .tendances .tendances__list ul.products li.product.card .button.add_to_cart_button {
  display: none;
}
.home .welcome_pack {
  display: none;
}
.home .welcome_pack .title-group {
  text-align: center;
  margin-block-end: 4rem;
}
.home .welcome_pack .title-group h2.title2 span {
  background-color: var(--darkblue);
  color: var(--white);
  padding: 0.2em 0.6em;
  border-radius: 5em;
  transform: rotate(-3deg);
  transform-origin: center;
  display: inline-block;
}
.home .welcome_pack__content {
  display: grid;
  gap: 1rem;
  grid-template-columns: 1fr;
}
.home .welcome_pack .step-card {
  position: relative;
  background-color: var(--white);
  border-radius: 2rem;
  padding: 4rem 2.6875rem 1.3125rem;
  display: flex;
  flex-direction: column;
  height: 100%;
  opacity: 0.5;
  filter: blur(5px);
  transform: translateY(20px);
}
.home .welcome_pack .step-card__badge {
  position: absolute;
  top: 0;
  left: 5%;
  transform: translateY(-50%);
  background-color: var(--darkblue);
  color: var(--white);
  padding: 0.4em 1.2em;
  border-radius: 5rem;
  font-family: var(--font-heading);
  font-weight: 900;
  font-style: italic;
  font-size: var(--fs-l);
  text-transform: uppercase;
  z-index: 2;
}
.home .welcome_pack .step-card__inner {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.home .welcome_pack .step-card__desc {
  font-size: var(--fs-m);
}
.home .welcome_pack .step-card__desc p {
  margin: 2em 0;
}
.home .welcome_pack .step-card__visual {
  margin-block-start: auto;
  display: flex;
  justify-content: center;
  align-items: center;
}
.home .welcome_pack .step-card__visual picture,
.home .welcome_pack .step-card__visual img {
  display: block;
  max-width: 100%;
  height: auto;
}
.home .welcome_pack .step-card:nth-child(1) {
  background: url("images/hp/bg_wp_1.webp") no-repeat center center/cover;
  background: url("images/hp/bg_wp_1.avif") type("image/avif"), url("images/hp/bg_wp_1.webp") type("image/webp") no-repeat center center/cover;
}
.home .welcome_pack .step-card:nth-child(2) {
  background: url("images/hp/bg_wp_2.webp") no-repeat center center/cover;
  background: url("images/hp/bg_wp_2.avif") type("image/avif"), url("images/hp/bg_wp_2.webp") type("image/webp") no-repeat center center/cover;
}
.home .welcome_pack .step-card:nth-child(3) {
  background: url("images/hp/bg_wp_3.webp") no-repeat center center/cover;
  background: url("images/hp/bg_wp_3.avif") type("image/avif"), url("images/hp/bg_wp_3.webp") type("image/webp") no-repeat center center/cover;
}
.home .welcome_pack__footer {
  max-width: 1220px;
  margin-block-start: 5rem;
  margin-inline: auto;
  background-color: var(--white);
  border: 2px solid var(--pink);
  border-radius: 10rem;
  padding: 2rem 5rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.home .welcome_pack__footer-content p {
  font-weight: 700;
  font-size: var(--fs-l);
}
.home .qsn {
  background-image: url("images/hp/bg_hero_mob.webp");
  background-image: -webkit-image-set(url("images/hp/bg_hero_mob.avif") type("image/avif"), url("images/hp/bg_hero_mob.webp") type("image/webp"));
  background-image: image-set(url("images/hp/bg_hero_mob.avif") type("image/avif"), url("images/hp/bg_hero_mob.webp") type("image/webp"));
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  background-blend-mode: overlay;
  color: var(--white);
  padding: clamp(0.625rem, 0.3077rem + 1.4103vw, 2rem);
  border-radius: 2rem;
}
.home .qsn__wrapper {
  width: 100%;
  margin-inline: auto;
  display: grid;
  gap: clamp(0.625rem, 0.4808rem + 0.641vw, 1.25rem);
}
.home .qsn__wrapper .visuels img {
  display: block;
  border-radius: 2rem;
  width: 100%;
  height: 100%;
  aspect-ratio: 1/1;
  -o-object-fit: cover;
     object-fit: cover;
}
.home .qsn__wrapper .visuels .pic1 {
  display: block;
}
.home .qsn__wrapper .visuels .pic2 {
  display: none;
}
.home .qsn__wrapper .visuels .pic3 {
  display: none;
}
.home .qsn__wrapper .visuels .pic4 {
  display: none;
}
.home .qsn__wrapper .visuels .pic5 {
  display: none;
}
.home .qsn__wrapper .content {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  background-color: var(--white);
  padding: 2rem;
  border-radius: 2rem;
  color: var(--darkblue);
  line-height: 1.6;
}
.home .qsn__wrapper .stats {
  position: relative;
  overflow: hidden;
  margin-block: 2rem;
  width: 100%;
}
.home .qsn__wrapper .stats ul {
  display: flex;
  align-items: flex-start;
  list-style: none;
  padding: 0;
  margin: 0;
}
.home .qsn__wrapper .stats ul li {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  height: auto;
  color: var(--white);
  flex-shrink: 0;
}
.home .qsn__wrapper .stats ul li strong {
  font-family: var(--font-heading);
  font-size: var(--fs-4xl);
  line-height: 1;
  font-style: italic;
  font-weight: 900;
  text-transform: uppercase;
  word-break: normal;
  color: var(--pink);
}
.home .qsn__wrapper .stats ul li span {
  font-family: var(--font-body);
  font-size: var(--fs-m);
  font-weight: 700;
  text-transform: uppercase;
  word-break: break-word;
  color: var(--white);
  margin-top: 0.5rem;
  line-height: 1.2;
}
.home .avis {
  background-color: var(--white);
  border-radius: 1.5rem;
  padding-block: clamp(1.5rem, 0.1154rem + 6.1538vw, 7.5rem);
  padding-inline-start: clamp(0.625rem, -0.8173rem + 6.4103vw, 6.875rem);
}
.home .avis header {
  margin-block-end: 4rem;
}
.home .avis__content {
  position: relative;
}
.home .avis__content .swiper-button-next,
.home .avis__content .swiper-button-prev {
  color: var(--white);
  background-color: var(--pink);
  width: 3em;
  height: 3em;
  border-radius: 50%;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  transition: background-color 0.3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.home .avis__content .swiper-button-next::after,
.home .avis__content .swiper-button-prev::after {
  font-family: var(--font-base);
  font-size: 1em;
  font-weight: 400;
}
.home .avis__content .swiper-button-next svg,
.home .avis__content .swiper-button-prev svg {
  display: none;
}
.home .avis__content .swiper-button-next:hover,
.home .avis__content .swiper-button-prev:hover {
  background-color: var(--darkpink);
}
.home .avis__content .swiper-button-next.swiper-button-disabled,
.home .avis__content .swiper-button-prev.swiper-button-disabled {
  display: none;
}
.home .avis__content .swiper-button-prev {
  left: 5rem;
}
.home .avis__content .swiper-button-prev::after {
  content: "←";
}
.home .avis__content .swiper-button-next {
  right: 5rem;
}
.home .avis__content .swiper-button-next::after {
  content: "→";
}
.home .avis .testimonial-card {
  background-color: var(--beige);
  border-radius: 1.5rem;
  padding: 2rem;
  height: auto;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.home .avis .testimonial-card__stars {
  display: flex;
  gap: 0.25rem;
  color: var(--pink);
  font-size: 1rem;
}
.home .avis .testimonial-card__stars .star {
  -webkit-text-stroke: 1px var(--pink);
}
.home .avis .testimonial-card__stars .star.filled {
  color: var(--pink);
}
.home .avis .testimonial-card__stars .star:not(.filled) {
  color: transparent;
}
.home .avis .testimonial-card__quote {
  font-size: var(--fs-s);
  flex-grow: 1;
}
.home .avis .testimonial-card__quote p {
  margin: 0;
}
.home .avis .testimonial-card__author {
  display: flex;
  flex-direction: column;
}
.home .avis .testimonial-card__name {
  font-size: var(--fs-m);
  font-weight: 700;
  text-transform: uppercase;
}
.home .avis .testimonial-card__function {
  font-size: var(--fs-s);
  font-weight: 500;
}

/*!
Theme Name: Reacto
Description: Reacto theme - Blaaaz
Text Domain: reacto
Version: 1.0.0
Author: Blaaaz
Author URI: http://www.blaaaz.com
*/
.qsn .separator {
  padding: 20px 0;
}
.qsn__header {
  display: flex;
  flex-direction: column-reverse;
  gap: 4.5vw;
  padding: 0 4%;
  align-items: center;
}
.qsn__header__texts {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 12px 0;
}
.qsn__header__texts span {
  color: var(--pink);
}
.qsn__header__paragraph {
  margin: 28px 0;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.qsn__header__title {
  text-transform: uppercase;
  font-size: var(--fs-s);
}
.qsn__header__visu img, .qsn__header__visu source {
  width: 100%;
  max-width: 820px;
}
.qsn__bg-section {
  margin-block-start: 0;
  background: url("images/qsn/qsn_bg.webp") no-repeat center center/cover;
  margin: 0 auto;
  background: -webkit-image-set(url("images/qsn/qsn_bg.avif") type("image/avif"), url("images/qsn/qsn_bg.webp") type("image/webp")) no-repeat center center/cover;
  background: image-set(url("images/qsn/qsn_bg.avif") type("image/avif"), url("images/qsn/qsn_bg.webp") type("image/webp")) no-repeat center center/cover;
  background-blend-mode: overlay;
  color: var(--white);
  padding: 2rem;
  border-radius: 2rem;
  position: relative;
}
.qsn__bg-section .pic1, .qsn__bg-section .pic2, .qsn__bg-section .pic3 {
  display: none;
}
.qsn__bg-section .pic1 {
  position: absolute;
  top: -6%;
  left: 3%;
}
.qsn__bg-section .pic2 {
  position: absolute;
  top: 25%;
  right: -7%;
}
.qsn__bg-section .pic3 {
  position: absolute;
  bottom: -10%;
  left: 6%;
}
.qsn__bg-section__title {
  color: var(--white);
  padding: 0 16.5% 40px;
}
.qsn__bg-section__title span {
  color: var(--pink);
}
.qsn__bg-section .content {
  padding: 5% 0;
  max-width: 1110px;
  margin: 0 auto;
  text-align: center;
  z-index: 1;
  position: relative;
}
.qsn__bg-section .stats {
  padding-top: 60px;
  max-width: 730px;
  margin: 0 auto;
}
.qsn__bg-section .stats li strong {
  color: var(--pink);
  font-size: var(--fs-4xl);
  font-style: italic;
}
.qsn__bg-section .stats li span {
  color: var(--white);
  font-family: var(--font-base);
  font-size: var(--fs-m);
}
.qsn__reacto {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8vw;
  max-width: 1420px;
  margin: 0 auto;
}
.qsn__reacto__text {
  max-width: 620px;
  padding-top: 40px;
}
.qsn__reacto source, .qsn__reacto img {
  width: 100%;
  max-width: 820px;
}
.qsn__reacto__bloc {
  max-width: 630px;
}
.qsn .realisations {
  margin-bottom: 20px;
}

/*!
Theme Name: Reacto
Description: Reacto theme - Blaaaz
Text Domain: reacto
Version: 1.0.0
Author: Blaaaz
Author URI: http://www.blaaaz.com
*/
.page_contact {
  margin-block: 3rem;
}
.page_contact .inner_contact {
  padding: clamp(2.5rem, 1.3462rem + 5.1282vw, 7.5rem) clamp(0.625rem, 0.4231rem + 0.8974vw, 1.5rem);
  border-radius: 1.5rem;
  background: linear-gradient(0deg, hsla(281, 100%, 95%, 0.8), hsla(281, 100%, 95%, 0.8)), url("images/bg_1k.webp") no-repeat center center/cover;
  background: linear-gradient(0deg, hsla(281, 100%, 95%, 0.8), hsla(281, 100%, 95%, 0.8)), -webkit-image-set(url("images/bg_1k.avif") type("image/avif"), url("images/bg_1k.webp") type("image/webp")) no-repeat center center/cover;
  background: linear-gradient(0deg, hsla(281, 100%, 95%, 0.8), hsla(281, 100%, 95%, 0.8)), image-set(url("images/bg_1k.avif") type("image/avif"), url("images/bg_1k.webp") type("image/webp")) no-repeat center center/cover;
  display: flex;
  flex-direction: column;
}
.page_contact .inner_contact .block_infos {
  flex: 1;
  padding-inline: 1rem;
  padding-block-end: 2rem;
  max-width: 720px;
}
.page_contact .inner_contact .block_infos h1,
.page_contact .inner_contact .block_infos h2 {
  font-family: var(--font-heading);
  font-size: var(--fs-3xl);
  text-transform: uppercase;
  display: block;
  line-height: 1.1;
}
.page_contact .inner_contact .block_infos h1 {
  padding-block-start: 2rem;
}
.page_contact .inner_contact .block_infos h2 {
  color: var(--pink);
}
.page_contact .inner_contact .block_infos p {
  font-weight: 700;
  padding-block: 2rem;
}
.page_contact .inner_contact .block_infos a {
  font-weight: 700;
  color: var(--darkblue);
  text-transform: uppercase;
  display: block;
}
.page_contact .inner_contact .block_infos a.tel {
  text-decoration: none;
}
.page_contact .inner_contact .block_gutenberg {
  flex: 1;
  padding-inline: 1rem;
}
.page_contact .inner_contact .block_gutenberg .gfield_required,
.page_contact .inner_contact .block_gutenberg .gfield_required_asterisk {
  color: var(--darkblue) !important;
}
.page_contact .inner_contact .block_gutenberg .gform-theme--foundation .gform-field-label:where(:not([class*=gform-field-label--type-]):not(.gfield_header_item):not(.ginput_quantity_label)),
.page_contact .inner_contact .block_gutenberg .gform-theme--foundation.gform_editor legend.gform-field-label > span {
  gap: 0 !important;
}
.page_contact .inner_contact .block_gutenberg {
  /* Modification de tous les champs de saisie Gravity Forms */
}
.page_contact .inner_contact .block_gutenberg .gform_wrapper input[type=text],
.page_contact .inner_contact .block_gutenberg .gform_wrapper input[type=email],
.page_contact .inner_contact .block_gutenberg .gform_wrapper input[type=tel],
.page_contact .inner_contact .block_gutenberg .gform_wrapper input[type=url],
.page_contact .inner_contact .block_gutenberg .gform_wrapper input[type=number],
.page_contact .inner_contact .block_gutenberg .gform_wrapper input[type=password],
.page_contact .inner_contact .block_gutenberg .gform_wrapper select,
.page_contact .inner_contact .block_gutenberg .gform_wrapper textarea {
  background-color: var(--white) !important;
  border: none !important;
  border-radius: 50px !important;
  padding: 1.5rem 1.8rem !important;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
  outline: none !important;
  color: var(--darkblue) !important;
  gap: 0 !important;
}
.page_contact .inner_contact .block_gutenberg .gfield_description.gform_fileupload_rules {
  display: none !important;
}
.page_contact .inner_contact .block_gutenberg {
  /* Cas particulier du Textarea (zone de texte multi-ligne) */
}
.page_contact .inner_contact .block_gutenberg .gform_wrapper textarea {
  border-radius: 25px !important;
}
.page_contact .inner_contact .block_gutenberg {
  /* Style au survol ou au clic (Focus) */
}
.page_contact .inner_contact .block_gutenberg .gform_wrapper input:focus,
.page_contact .inner_contact .block_gutenberg .gform_wrapper textarea:focus {
  background-color: var(--beige) !important;
}
.page_contact .inner_contact .block_gutenberg .gform_wrapper label {
  color: var(--darkblue) !important;
}
.page_contact .inner_contact .block_gutenberg {
  /* Ciblage précis du bouton de soumission */
}
.page_contact .inner_contact .block_gutenberg #gform_submit_button_1 {
  position: relative;
  isolation: isolate;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 1.5em;
  background-color: transparent !important;
  box-shadow: none !important;
  color: var(--white) !important;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1;
  border-radius: 5em;
  padding: 0 0 0 1.5em !important;
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
  border: 0 !important;
  min-width: 285px;
  height: 3em;
  transition: all 0.3s ease;
}
.page_contact .inner_contact .block_gutenberg #gform_submit_button_1::before {
  content: "";
  display: block;
  position: absolute;
  inset: 0 3em 0 0;
  border-radius: 5em;
  background-color: var(--pink);
  z-index: -1;
  transition: background-color 0.3s ease;
}
.page_contact .inner_contact .block_gutenberg #gform_submit_button_1::after {
  content: "→";
  border-radius: 50%;
  background-color: var(--pink);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2em;
  width: 2.5em;
  height: 2.5em;
  font-weight: 400;
  box-sizing: border-box;
  transition: background-color 0.3s ease, transform 0.3s ease;
  margin-right: 0.25em;
}
.page_contact .inner_contact .block_gutenberg #gform_submit_button_1:hover::before {
  background-color: var(--darkpink);
}
.page_contact .inner_contact .block_gutenberg #gform_submit_button_1:hover::after {
  background-color: var(--darkpink);
  transform: rotate(-30deg);
}
.page_contact .inner_contact .block_gutenberg {
  /* Conteneur principal */
}
.page_contact .inner_contact .block_gutenberg .ginput_container_fileupload {
  width: 100%;
  margin-top: 10px;
}
.page_contact .inner_contact .block_gutenberg {
  /* Ciblage de l'input file */
}
.page_contact .inner_contact .block_gutenberg .gform_wrapper .ginput_container_fileupload input[type=file] {
  background-color: #ffffff;
  border: none;
  border-radius: 50px !important;
  padding: 0 0 0 3rem !important;
  min-height: 45px;
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
  width: 100%;
  cursor: pointer;
  position: relative;
}
.page_contact .inner_contact .block_gutenberg .gform_wrapper .ginput_container_fileupload input[type=file]::before {
  content: "";
  display: block;
  position: absolute;
  left: 1rem;
  transform: translateY(-50%);
  top: 50%;
  width: 1rem;
  height: 1rem;
  background: url("images/picto_file.svg");
  background-size: 100%;
  background-repeat: no-repeat;
  transition: background-color 0.3s ease;
}
.page_contact .inner_contact .block_gutenberg {
  /* Style du bouton "Choisir un fichier" (le bouton interne) */
}
.page_contact .inner_contact .block_gutenberg .gform_wrapper .ginput_container_fileupload input[type=file]::file-selector-button {
  float: right;
  position: absolute;
  top: 0;
  bottom: 0;
  right: -12px;
  background-color: white;
  color: var(--pink);
  border: 2px var(--pink) solid;
  border-radius: 25px;
  max-height: 45px;
  padding: 8px 20px;
  margin-left: 15px;
  cursor: pointer;
  font-weight: 600;
  transition: background-color 0.3s ease;
}
.page_contact .inner_contact .block_gutenberg .gform_wrapper .ginput_container_fileupload input[type=file]::file-selector-button:hover {
  color: white !important;
  background-color: var(--pink);
}
.page_contact .inner_contact .block_gutenberg {
  /* Changement du texte "Choisir un fichier" par "Parcourir" */
  /* Note : Le texte dépend souvent de la langue du navigateur. 
                 Pour forcer "Parcourir", on utilise cette astuce : */
}
.page_contact .inner_contact .block_gutenberg .gform_wrapper .ginput_container_fileupload input[type=file]::file-selector-button {
  content: "Parcourir";
}
.page_contact .inner_contact .block_gutenberg {
  /* État survol du bouton interne */
}
.page_contact .inner_contact .block_gutenberg .gform_wrapper .ginput_container_fileupload input[type=file]::file-selector-button:hover {
  background-color: var(--darkpink);
}
.page_contact .inner_contact .block_gutenberg {
  /* Nettoyage du float pour les éléments suivants */
}
.page_contact .inner_contact .block_gutenberg .ginput_container_fileupload::after {
  content: "";
  display: table;
  clear: both;
}
.page_contact .inner_contact .block_gutenberg {
  /* Change le fond et la couleur du texte du bouton */
}
.page_contact .inner_contact .block_gutenberg .gform_wrapper .gform_drop_area button.gform_button_select_files {
  background-color: var(--white) !important;
  /* Remplacez par votre couleur */
  color: var(--pink) !important;
  /* Couleur du texte */
  border: 2px var(--pink) solid !important;
  padding: 10px 20px !important;
  border-radius: 5px !important;
}
.page_contact .inner_contact .block_gutenberg {
  /* Change la couleur au survol (Hover) */
}
.page_contact .inner_contact .block_gutenberg .gform_wrapper .gform_drop_area button.gform_button_select_files:hover {
  background-color: var(--pink) !important;
  color: var(--white) !important;
  cursor: pointer;
}
.page_contact .inner_contact .block_gutenberg {
  /* Pour changer la couleur de l'icône de téléchargement */
}
.page_contact .inner_contact .block_gutenberg .gform_wrapper .gform_drop_area::before {
  color: var(--pink) !important;
  /* Si c'est une icône de police */
  fill: var(--pink) !important;
  /* Si c'est un élément SVG */
}
.page_contact .inner_contact .block_gutenberg .gform_wrapper .gform_drop_area {
  background-color: #f8f9fa !important;
  /* Fond de la zone */
  border: none !important;
  /* Bordure en pointillés */
  padding: 25px !important;
  border-radius: 25px !important;
}

/*!
Theme Name: Reacto
Description: Reacto theme - Blaaaz
Text Domain: reacto
Version: 1.0.0
Author: Blaaaz
Author URI: http://www.blaaaz.com
*/
.page_realisations {
  margin-block: 1.25rem;
  padding: clamp(2.5rem, 1.3462rem + 5.1282vw, 7.5rem) clamp(0.625rem, 0.4231rem + 0.8974vw, 1.5rem);
  border-radius: 1.5rem;
  background: linear-gradient(0deg, hsla(281, 100%, 95%, 0.8), hsla(281, 100%, 95%, 0.8)), url("images/bg_1k.webp") no-repeat center center/cover;
  background: linear-gradient(0deg, hsla(281, 100%, 95%, 0.8), hsla(281, 100%, 95%, 0.8)), -webkit-image-set(url("images/bg_1k.avif") type("image/avif"), url("images/bg_1k.webp") type("image/webp")) no-repeat center center/cover;
  background: linear-gradient(0deg, hsla(281, 100%, 95%, 0.8), hsla(281, 100%, 95%, 0.8)), image-set(url("images/bg_1k.avif") type("image/avif"), url("images/bg_1k.webp") type("image/webp")) no-repeat center center/cover;
}
.page_realisations header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-block-end: 4rem;
}
.page_realisations .realisations-grid {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: repeat(2, 1fr);
  grid-auto-flow: dense;
}
.page_realisations .realisation-item {
  background-color: var(--white);
  border-radius: 1.5rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  aspect-ratio: 540/610;
  padding: 1.5rem;
}
.page_realisations .realisation-item__inner {
  width: 100%;
  height: 100%;
  background-color: var(--white);
  border-radius: 1rem;
  overflow: hidden;
  position: relative;
}
.page_realisations .realisation-item__inner:hover .realisation-item__client {
  opacity: 1;
  transform: translate(-50%, -50%);
}
.page_realisations .realisation-item__inner:hover img {
  opacity: 0.3;
}
.page_realisations .realisation-item__inner .realisation-item__link {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  position: relative;
  text-decoration: none;
}
.page_realisations .realisation-item__inner .realisation-item__client {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -40%);
  background-color: var(--darkblue);
  color: var(--white);
  padding: 0.5em 2em;
  border-radius: 2em;
  font-family: var(--font-heading);
  font-weight: 800;
  text-transform: uppercase;
  font-size: var(--fs-s);
  text-align: center;
  opacity: 0;
  transition: all 0.3s ease;
  pointer-events: none;
  z-index: 2;
}
.page_realisations .realisation-item__inner picture,
.page_realisations .realisation-item__inner img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  transition: opacity 0.3s ease;
}

/*!
Theme Name: Reacto
Description: Reacto theme - Blaaaz
Text Domain: reacto
Version: 1.0.0
Author: Blaaaz
Author URI: http://www.blaaaz.com
*/
.stats {
  position: relative;
  overflow: hidden;
  width: 100%;
}
.stats ul {
  display: flex;
  align-items: flex-start;
  list-style: none;
  padding: 0;
  margin: 0;
}
.stats li {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  height: auto;
  flex-shrink: 0;
}
.stats li strong {
  font-family: var(--font-heading);
  line-height: 1;
  font-weight: 900;
  text-transform: uppercase;
}
.stats li span {
  font-weight: 700;
  text-transform: uppercase;
  margin-top: 0.5rem;
  line-height: 1.2;
}

/**
*   woocommerce-shop
*/
.woocommerce.archive {
  /**
    *   woocommerce-products-header
    */
}
.woocommerce.archive .woocommerce-products-header {
  margin-top: 2.4em;
}
.woocommerce.archive .woocommerce-products-header::before {
  content: "PRODUITS";
  display: block;
  margin-bottom: -11px;
  font-size: 14px;
  font-weight: 500;
}
.woocommerce.archive .woocommerce-products-header h1 {
  font-family: var(--font-heading);
  font-size: var(--fs-3xl);
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: -0.01em;
}
.woocommerce.archive .woocommerce-products-header p {
  font-size: var(--fs-m);
}
.woocommerce.archive {
  /**
    *   woocommerce-shop widget(block) filters
    */
}
.woocommerce.archive .wp-block-woocommerce-product-filter-price ~ .wp-block-woocommerce-product-filter-attribute .wc-block-product-filter-chips__item,
.woocommerce.archive .wp-block-woocommerce-product-filter-price ~ .wp-block-woocommerce-product-filter-taxonomy .wc-block-product-filter-chips__item {
  border: none;
  border-radius: 50px;
  background: #fff7d5;
  color: #f0ae1e;
  text-transform: uppercase;
  font-weight: 700;
  position: relative;
}
.woocommerce.archive .wp-block-woocommerce-product-filter-price ~ .wp-block-woocommerce-product-filter-attribute .wc-block-product-filter-chips__item[data-wp-key*=engagement-ecologique],
.woocommerce.archive .wp-block-woocommerce-product-filter-price ~ .wp-block-woocommerce-product-filter-taxonomy .wc-block-product-filter-chips__item[data-wp-key*="taxonomy/product_cat-goodies-ecologiques"] {
  background: #d6f8de;
  color: #439f5b;
}
.woocommerce.archive .wp-block-woocommerce-product-filter-price ~ .wp-block-woocommerce-product-filter-attribute .wc-block-product-filter-chips__item[data-wp-key*=engagement-ecologique]:before,
.woocommerce.archive .wp-block-woocommerce-product-filter-price ~ .wp-block-woocommerce-product-filter-taxonomy .wc-block-product-filter-chips__item[data-wp-key*="taxonomy/product_cat-goodies-ecologiques"]:before {
  content: "🌱";
  display: inline-grid;
  place-content: center;
  width: 15px;
  height: 15px;
  font-size: 14px;
}
.woocommerce.archive .wp-block-woocommerce-product-filter-price ~ .wp-block-woocommerce-product-filter-attribute .wc-block-product-filter-chips__item[data-wp-key*=origine-made-in-france],
.woocommerce.archive .wp-block-woocommerce-product-filter-price ~ .wp-block-woocommerce-product-filter-taxonomy .wc-block-product-filter-chips__item[data-wp-key*="taxonomy/product_cat-made-in-france"] {
  background: #cfdbf9;
  color: #1f2f56;
}
.woocommerce.archive .wp-block-woocommerce-product-filter-price ~ .wp-block-woocommerce-product-filter-attribute .wc-block-product-filter-chips__item[data-wp-key*=origine-made-in-france]:before,
.woocommerce.archive .wp-block-woocommerce-product-filter-price ~ .wp-block-woocommerce-product-filter-taxonomy .wc-block-product-filter-chips__item[data-wp-key*="taxonomy/product_cat-made-in-france"]:before {
  content: "";
  display: inline-grid;
  place-content: center;
  width: 15px;
  height: 15px;
  background: url(images/icon-france.svg) no-repeat center;
}
.woocommerce.archive .wp-block-woocommerce-product-filter-price ~ .wp-block-woocommerce-product-filter-taxonomy .wc-block-product-filter-chips__item[data-wp-key*="taxonomy/product_cat-best-seller"]:before {
  content: "🌟";
  display: inline-grid;
  place-content: center;
  width: 15px;
  height: 15px;
  font-size: 14px;
}
.woocommerce.archive .wc-block-product-filter-removable-chips__items .wc-block-product-filter-removable-chips__item {
  background: #f5d0ff;
  border-radius: 20px;
  border: 0;
  line-height: 1;
  padding-left: 1.2em;
  padding-right: 0.9em;
}
.woocommerce.archive .wc-block-product-filter-checkbox-list__items > div:nth-child(n+11),
.woocommerce.archive .wc-block-product-filter-checkbox-list__show-more,
.woocommerce.archive .wc-block-product-filter-chips__show-more {
  display: none;
}
.woocommerce.archive input[type=checkbox].wc-block-product-filter-checkbox-list__input {
  border-radius: 50px;
  border: 1px solid #949DB2;
}
.woocommerce.archive .wc-block-product-filter-checkbox-list__input-wrapper:before {
  border-radius: 20px;
  opacity: 0.8;
  transform: scale(0.7);
}
.woocommerce.archive svg.wc-block-product-filter-checkbox-list__mark {
  color: #fff;
}
.woocommerce.archive .wc-block-product-filter-checkbox-list__input-wrapper:before,
.woocommerce.archive input[type=checkbox].wc-block-product-filter-checkbox-list__input,
.woocommerce.archive svg.wc-block-product-filter-checkbox-list__mark {
  height: 1.2em;
  width: 1.2em;
}
.woocommerce.archive .wc-block-product-filter--hidden {
  display: none !important;
}
.woocommerce.archive .wc-block-product-filter-price-slider .text input[type=text] {
  border-radius: 50px;
  border-color: #dbdbdb;
  font-weight: 700;
  font-family: var(--font-family-base);
  color: #1f2f56;
}
.woocommerce.archive {
  /* Filter Widget(block) - product categories : show only "made-in-france", "goodies-ecologiques", "best-seller" */
}
.woocommerce.archive .wp-block-woocommerce-product-filter-taxonomy .wc-block-product-filter-chips__item {
  display: none;
}
.woocommerce.archive .wp-block-woocommerce-product-filter-taxonomy .wc-block-product-filter-chips__item[value=made-in-france],
.woocommerce.archive .wp-block-woocommerce-product-filter-taxonomy .wc-block-product-filter-chips__item[value=goodies-ecologiques],
.woocommerce.archive .wp-block-woocommerce-product-filter-taxonomy .wc-block-product-filter-chips__item[value=best-seller] {
  display: flex;
  gap: 0.5em;
  align-items: center;
}
.woocommerce.archive .wp-block-woocommerce-product-filter-taxonomy .wc-block-product-filter-chips__item[aria-checked=true] {
  padding-left: 40px !important;
  outline: 1px solid currentColor;
}
.woocommerce.archive .wp-block-woocommerce-product-filter-taxonomy .wc-block-product-filter-chips__item[aria-checked=true]::after {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  background: currentColor url("images/icon-check-white.svg") no-repeat center;
  background-size: 10px;
  border-radius: 20px;
  position: absolute;
  left: 10px;
  top: 25%;
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  width: 23.55%;
  margin-right: 1.4%;
  padding: 10px;
  background: #fff;
  border-radius: 24px;
}

.woocommerce ul.products li.product .woocommerce-loop-category__title,
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h3 {
  text-transform: uppercase;
  color: #1f2f56;
  padding: 0;
  line-height: 1.2;
  height: 48px;
  display: flex;
  align-items: flex-end;
}

.woocommerce ul.products li.product .price {
  color: #1f2f56;
  font-size: 12px;
  line-height: 1.2;
  margin-top: 0.2em;
}
.woocommerce ul.products li.product .price .marquage-inclus {
  display: block;
  font-size: 0.85em;
}

.product_type_variable.add_to_cart_button {
  display: none !important;
}

.woocommerce .woocommerce-result-count {
  font-weight: 700;
}

/**
*   woocommerce - single product - remove tabs
*/
/* Masque uniquement les titres des onglets */
.woocommerce-tabs ul.tabs {
  display: none !important;
}

/* Force l'affichage du contenu de la description */
.woocommerce-tabs .woocommerce-Tabs-panel--description {
  display: block !important;
}
.woocommerce-tabs .woocommerce-Tabs-panel--description p + p {
  margin-top: 1.8em;
}

/* Optionnel : Supprime la bordure ou le cadre souvent présent */
.woocommerce-tabs {
  border: none !important;
}

.woocommerce #content div.product .woocommerce-tabs,
.woocommerce div.product .woocommerce-tabs,
.woocommerce-page #content div.product .woocommerce-tabs,
.woocommerce-page div.product .woocommerce-tabs {
  background: #fff;
  border-radius: 24px;
  padding: 6%;
}

.woocommerce div.product .woocommerce-tabs .panel {
  margin-bottom: 0;
}
.woocommerce div.product .woocommerce-tabs .panel h2 {
  margin-bottom: 0.7em;
  text-transform: uppercase;
  font-size: 16px;
}

/* product-attribute-tags */
.product-attribute-tags {
  container-type: inline-size;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 0.25rem 0.5rem;
}
.woocommerce div.product div.summary .product-attribute-tags {
  margin-bottom: 1em;
}
.product.card .product-attribute-tags {
  position: absolute;
  inset: 1rem 1rem auto 1rem;
}

.product-attribute-tags .product-tag {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  border-radius: 50px;
  padding: 4px 10px;
  font-weight: 700;
  font-size: 10px;
  text-transform: uppercase;
  background: #fff7d5;
  color: #f0ae1e;
}
@container (max-width: 200px) {
  .product-attribute-tags .product-tag {
    font-size: 0;
    padding: 4px;
  }
}
.product-attribute-tags .product-tag::before {
  content: "🌟";
  display: inline-grid;
  place-content: center;
  width: 11px;
  height: 11px;
  margin-right: 4px;
  font-size: 11px;
}
@container (max-width: 200px) {
  .product-attribute-tags .product-tag::before {
    width: 15px;
    height: 15px;
    margin-right: 0;
  }
}
.product-attribute-tags .product-tag.product-tag--goodies-ecologiques {
  background: #d6f8de;
  color: #439f5b;
}
.product-attribute-tags .product-tag.product-tag--goodies-ecologiques::before {
  content: "🌱";
}
.product-attribute-tags .product-tag.product-tag--made-in-france {
  background: #cfdbf9;
  color: #1f2f56;
}
.product-attribute-tags .product-tag.product-tag--made-in-france::before {
  content: "";
  background: url(images/icon-france.svg) no-repeat center;
  background-size: 100%;
}
@container (max-width: 200px) {
  .product-attribute-tags .product-tag.product-tag--made-in-france::before {
    background-size: 80%;
  }
}

.woocommerce div.product div.summary {
  margin-top: 0.8em;
}

.woocommerce div.product .product_title {
  font-family: var(--font-heading);
  font-size: var(--fs-xl);
  text-transform: uppercase;
  letter-spacing: -0.03em;
  line-height: 1.05;
}

.woocommerce:where(body:not(.woocommerce-uses-block-theme)) div.product p.price,
.woocommerce:where(body:not(.woocommerce-uses-block-theme)) div.product span.price {
  color: inherit;
  font-size: var(--fs-2xl);
  letter-spacing: -0.03em;
  margin-bottom: 0.3em;
}

.single-product.rtwpvs .reset_variations.show {
  display: none !important;
}

/* variation layout */
.woocommerce div.product form.cart .variations {
  margin-top: 0;
}

.woocommerce div.product form.cart .variations td,
.woocommerce div.product form.cart .variations th {
  display: block;
  text-align: left;
  margin-bottom: 0.4em;
}

.woocommerce div.product form.cart .variations .label {
  text-transform: uppercase;
}

.woocommerce div.product form.cart .variations .label span {
  text-transform: none;
  font-weight: 400;
  margin-left: 0.3em;
}

/* variation swatches */
.rtwpvs-term:not(.rtwpvs-radio-term) {
  width: 50px;
  height: 50px;
}

.rtwpvs .rtwpvs-terms-wrapper .rtwpvs-term:not(.rtwpvs-radio-term) {
  box-shadow: none;
}

.rtwpvs .rtwpvs-terms-wrapper .rtwpvs-term:not(.rtwpvs-radio-term):hover {
  box-shadow: 0 0 0 2px #cb6ce6;
}

.rtwpvs .rtwpvs-terms-wrapper .rtwpvs-term:not(.rtwpvs-radio-term).selected,
.rtwpvs .rtwpvs-terms-wrapper .rtwpvs-term:not(.rtwpvs-radio-term).selected:hover {
  box-shadow: 0 0 0 1px #cb6ce6;
}

.rtwpvs .reset_variations {
  color: var(--darkpink);
  font-weight: 500;
}

.rtwpvg-slider-wrapper {
  border-radius: 24px;
}

.rtwpvg-images.rtwpvg-has-product-thumbnail .rtwpvg-grid-layout .rtwpvg-thumbnail-wrapper .rtwpvg-thumbnail-slider .rtwpvg-thumbnail-image,
.rtwpvg-images.rtwpvg-has-product-thumbnail .rtwpvg-wrapper .rtwpvg-thumbnail-wrapper .rtwpvg-thumbnail-slider .rtwpvg-thumbnail-image {
  filter: saturate(0.4);
  opacity: 0.6;
}

.rtwpvg-images.rtwpvg-has-product-thumbnail .rtwpvg-grid-layout .rtwpvg-thumbnail-wrapper .rtwpvg-thumbnail-slider .rtwpvg-thumbnail-image.swiper-slide-thumb-active,
.rtwpvg-images.rtwpvg-has-product-thumbnail .rtwpvg-grid-layout .rtwpvg-thumbnail-wrapper .rtwpvg-thumbnail-slider .rtwpvg-thumbnail-image:hover,
.rtwpvg-images.rtwpvg-has-product-thumbnail .rtwpvg-wrapper .rtwpvg-thumbnail-wrapper .rtwpvg-thumbnail-slider .rtwpvg-thumbnail-image.swiper-slide-thumb-active,
.rtwpvg-images.rtwpvg-has-product-thumbnail .rtwpvg-wrapper .rtwpvg-thumbnail-wrapper .rtwpvg-thumbnail-slider .rtwpvg-thumbnail-image:hover {
  filter: saturate(1);
}

.woocommerce-product-details__short-description {
  margin: 0.8em 0;
  font-size: var(--fs-m);
}

.product_meta {
  display: none;
}

.custom-related-title {
  text-align: center;
  font-size: var(--fs-xl);
  font-family: var(--font-heading);
  text-transform: uppercase;
  letter-spacing: -0.03em;
  margin-top: 3.2em;
  margin-bottom: 1.6em;
}
.custom-related-title a {
  color: inherit;
}
.custom-related-title a:hover {
  color: var(--darkpink);
}

.acf-texte-avant-quantite {
  width: 100%;
  margin-bottom: 1em;
}

.woocommerce div.product form.cart,
.woocommerce div.product form.cart .woocommerce-variation-add-to-cart {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}

.woocommerce div.product form.cart .qty-label {
  text-transform: uppercase;
  font-weight: 700;
  margin-right: 0.8em;
}

/* visuel produit / slider thumbnail */
.rtwpvg-images.rtwpvg-has-product-thumbnail .rtwpvg-wrapper.rtwpvg-thumbnail-position-left .rtwpvg-thumbnail-wrapper {
  margin-right: 10px;
}

.rtwpvg-images.rtwpvg-has-product-thumbnail .rtwpvg-grid-layout .rtwpvg-thumbnail-wrapper .rtwpvg-thumbnail-slider .rtwpvg-thumbnail-image,
.rtwpvg-images.rtwpvg-has-product-thumbnail .rtwpvg-wrapper .rtwpvg-thumbnail-wrapper .rtwpvg-thumbnail-slider .rtwpvg-thumbnail-image {
  transform: scale(0.8);
  border-radius: 16px;
}

.rtwpvg-images.rtwpvg-has-product-thumbnail .rtwpvg-wrapper .rtwpvg-thumbnail-wrapper .rtwpvg-thumbnail-slider .rtwpvg-thumbnail-image.swiper-slide-thumb-active {
  border: 2px solid #cb6ce6;
}

/* link voir mon devis */
.yith-ywraq-add-to-quote a,
.yith_ywraq_add_item_browse_message a {
  text-decoration: none;
  color: #fff;
  background: #cb6ce6;
  font-size: 1em !important;
  font-weight: 400;
  padding: 10px 20px;
  border-radius: 40px;
  display: inline-block;
}

.ctis-load-more {
  display: inline-flex !important;
}

.ctis-load-more.btn::before, .ctis-load-more::before {
  display: block !important;
}

.rtwpvg-thumbnail-slider .swiper-button-disabled {
  display: none !important;
}

.yith-request-a-quote-page main.main {
  width: min(94%, 1920px);
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 4em;
}

.yith-request-a-quote-page h1 {
  opacity: 0;
}

.ywraq-form-table-wrapper.wide {
  flex-direction: row-reverse;
  gap: 0;
}
.ywraq-form-table-wrapper.wide form#yith-ywraq-form {
  width: 100%;
}
.ywraq-form-table-wrapper.wide form#yith-ywraq-form {
  transition: 0.2s;
}
.ywraq-form-table-wrapper.wide form#yith-ywraq-form.is-loading {
  opacity: 0.5;
  pointer-events: none;
}

.ywraq-form-table-wrapper.wide form#yith-ywraq-form table.shop_table_responsive tr td,
.ywraq-form-table-wrapper.wide form#yith-ywraq-form table.shop_table_responsive tr td {
  text-align: left !important;
}
.ywraq-form-table-wrapper.wide form#yith-ywraq-form table.shop_table_responsive tr td::before,
.ywraq-form-table-wrapper.wide form#yith-ywraq-form table.shop_table_responsive tr td::before {
  display: none;
}

.woocommerce table.shop_table#yith-ywrq-table-list {
  border: 0;
}

.ywraq-wrapper .ywraq-form-table-wrapper.wide #yith-ywraq-form table.cart thead {
  display: none;
}

.ywraq-wrapper .ywraq-form-table-wrapper.wide #yith-ywraq-form table.cart tr.cart_item {
  background: #fff;
  display: block;
  position: relative;
  padding: 20px 20px 18px 84px;
  border: 0;
  border-radius: 16px;
  margin: 1em 0;
}

.ywraq-wrapper .ywraq-form-table-wrapper.wide #yith-ywraq-form table.cart tr.cart_item td.product-remove {
  display: block;
  border: 0 !important;
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
}

.ywraq-wrapper .ywraq-form-table-wrapper.wide #yith-ywraq-form table.cart tr.cart_item td.product-thumbnail {
  display: block;
  border: 0 !important;
  position: absolute;
  left: 6px;
  top: 50%;
  transform: translateY(-50%);
}

.ywraq-wrapper .ywraq-form-table-wrapper.wide #yith-ywraq-form table.cart tr.cart_item .product-thumbnail img {
  max-width: 50px;
  width: 100%;
  border-radius: 10px;
  border: 1px solid #DBDBDB;
}

.ywraq-wrapper .ywraq-form-table-wrapper.wide #yith-ywraq-form table.cart tr.cart_item td.product-name {
  display: block;
  border: 0 !important;
  padding: 0;
  margin-bottom: 2px;
  line-height: 1.2;
  font-size: 14px;
}

.ywraq-wrapper .ywraq-form-table-wrapper.wide #yith-ywraq-form table.cart tr.cart_item td.product-name a {
  display: block;
  text-transform: uppercase;
  font-weight: 700;
  font-size: var(--fs-m);
  text-decoration: none;
  color: inherit;
}

.ywraq-wrapper .ywraq-form-table-wrapper.wide #yith-ywraq-form table.cart tr.cart_item td.product-quantity {
  display: block;
  border: 0 !important;
  text-align: left;
  padding: 0;
  margin: 0;
}

.woocommerce .quantity .qty {
  border-radius: 50px;
  border: 1px solid #DBDBDB;
  padding: 10px 20px;
  width: 98px;
  font-size: 16px;
  text-align: left;
}

#yith-ywraq-form .product-price,
#yith-ywraq-form .product-subtotal {
  padding: 0;
  font-size: 18px;
  font-weight: 500;
  border: 0;
}

#yith-ywraq-form .product-price {
  font-size: 28px;
  font-weight: 400;
  letter-spacing: -0.03em;
}

#yith-ywraq-form .product-subtotal {
  display: none;
}

.ywraq-wrapper .ywraq-form-table-wrapper.wide #yith-ywraq-form table.cart td.actions {
  border: 0;
  position: absolute;
  right: 2vw;
  margin-top: 16px;
  display: none;
  background: none;
}

.ywraq-wrapper .ywraq-form-table-wrapper.wide #yith-ywraq-form table.cart td.actions input {
  background-color: transparent;
  color: #CB6CE6;
  border: 2px solid #CB6CE6;
  border-radius: 30px;
  background: url(images/icon-reload.svg) no-repeat left 12px center;
  background-size: 20px;
  padding-left: 40px;
  filter: brightness(0) saturate(100%) invert(51%) sepia(40%) saturate(1934%) hue-rotate(241deg) brightness(97%) contrast(85%);
  padding: 14px 18px 14px 40px;
}

.ywraq-form-table-wrapper.wide .yith-ywraq-mail-form-wrapper {
  margin-left: 0;
  padding: 0;
}

.ywraq-form-table-wrapper.wide .yith-ywraq-mail-form-wrapper > h3 {
  font-family: var(--font-heading);
  font-size: var(--fs-xl);
  text-transform: uppercase;
  letter-spacing: -0.03em;
  line-height: 1.05;
}

.woocommerce form .form-row .input-text,
.woocommerce form .form-row select {
  border-radius: 24px;
  border: 1px solid #DBDBDB;
  padding: 15px 20px;
}

.woocommerce form .form-row .input-text:focus,
.woocommerce form .form-row select:focus {
  border-color: #CB6CE6;
}

.ywraq-form-table-wrapper.wide form#yith-ywraq-form h2 {
  font-family: var(--font-heading);
  font-size: var(--fs-xl);
  text-transform: uppercase;
  letter-spacing: -0.03em;
  line-height: 1.05;
}

.product-quantity__label {
  float: left;
  margin-top: 7px;
  margin-right: 8px;
  text-transform: uppercase;
  font-weight: 700;
}

.woocommerce a.remove,
.woocommerce a.remove:hover {
  background: url(images/icon-trash.svg) no-repeat center;
  padding: 16px;
  text-indent: -999px;
  overflow: hidden;
}

.woocommerce a.remove:hover {
  background-color: #f8deff;
}

.ywraq-wrapper .ywraq-form-table-wrapper.wide .yith-ywraq-mail-form-wrapper .raq-send-request {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  word-wrap: normal !important;
}

#rqa_privacy_row label {
  line-height: 1.3;
  font-size: 14px;
}

/* form custom file upload style */
.custom-file-upload {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border: 1px solid #e0e0e0;
  border-radius: 50px; /* Forme pilule */
  padding-left: 20px;
  background: #fff;
  position: relative;
  cursor: pointer;
}

/* On cache l'input d'origine mais il reste fonctionnel */
.custom-file-upload input[type=file] {
  position: absolute;
  opacity: 0;
  width: 100%;
  height: 100%;
  left: 0;
  cursor: pointer;
}

.file-placeholder {
  color: #a0a0a0;
  font-size: 14px;
}

/* Ajout de l'icône de trombone (optionnel via emoji ou font-awesome) */
.file-placeholder::before {
  content: "📎";
  margin-right: 10px;
  color: #333;
}

.btn-parcourir {
  background-color: transparent;
  color: #CB6CE6; /* Couleur violette de l'image */
  border: 2px solid #CB6CE6;
  border-radius: 30px;
  padding: 6px 25px;
  font-weight: bold;
  cursor: pointer;
  transition: all 0.3s ease;
}

.btn-parcourir:hover {
  background-color: #CB6CE6;
  color: white;
}

/* form custom datepicker style */
.datepicker-wrapper {
  position: relative;
  display: flex;
  align-items: center;
}

.datepicker-wrapper input[type=date] {
  padding-left: 50px !important;
}

/* On cache l'icône calendrier native de Chrome/Edge */
.datepicker-wrapper input[type=date]::-webkit-calendar-picker-indicator {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  margin: 0;
  padding: 0;
  cursor: pointer;
  opacity: 0; /* On la rend invisible mais elle reste active sur toute la zone */
}

/* Style de ton icône SVG personnalisée */
.calendar-icon {
  position: absolute;
  left: 18px;
  width: 20px;
  height: 20px;
  color: #1a2b4b; /* Couleur sombre comme sur ton image */
  pointer-events: none; /* L'icône ne doit pas bloquer le clic */
}

/* Optionnel : Changement de couleur au focus */
.datepicker-wrapper input[type=date]:focus {
  border-color: #CB6CE6;
}

.woocommerce .add-request-quote-button.button,
.woocommerce .add-request-quote-button-addons.button,
.yith-wceop-ywraq-button-wrapper .add-request-quote-button.button,
.yith-wceop-ywraq-button-wrapper .add-request-quote-button-addons.button {
  border-radius: 26px;
  font-size: 16px !important;
  padding: 16px 28px;
}
.woocommerce .add-request-quote-button.button, .woocommerce .add-request-quote-button.button:hover,
.woocommerce .add-request-quote-button-addons.button,
.woocommerce .add-request-quote-button-addons.button:hover,
.yith-wceop-ywraq-button-wrapper .add-request-quote-button.button,
.yith-wceop-ywraq-button-wrapper .add-request-quote-button.button:hover,
.yith-wceop-ywraq-button-wrapper .add-request-quote-button-addons.button,
.yith-wceop-ywraq-button-wrapper .add-request-quote-button-addons.button:hover {
  background-image: url(images/icon-file.svg);
  background-repeat: no-repeat;
  background-position: left 22px center;
  padding-left: 54px;
}

/* box */
.box {
  background: #fff;
  padding: 9% 20px;
  border-radius: 24px;
  text-align: center;
}
.box__content > *:not(:first-child) {
  margin-top: 1.8em;
}
.box h2 {
  font-family: var(--font-heading);
  font-size: var(--fs-3xl);
  text-transform: uppercase;
  letter-spacing: -0.01em;
  line-height: 1.05;
}
.box h2::before {
  content: "";
  display: block;
  width: 68px;
  height: 68px;
  background: url(images/smiley-sad.svg) no-repeat center;
  margin: 0px auto 0.5em;
}
.box h2.quote-sent::before {
  background: url(images/icon-check-large.svg) no-repeat center;
}

/* tendances */
.tendances {
  margin: 40px 0;
}
.tendances__title {
  font-family: var(--font-heading);
  font-size: var(--fs-3xl);
  text-transform: uppercase;
  letter-spacing: -0.01em;
  line-height: 1.05;
  margin-bottom: 0.6em;
}

.woocommerce form .form-row .required {
  color: inherit;
}

body.yith-request-a-quote-page .woocommerce-message {
  display: none;
}

/* HERE PUT HELPERS CSS */
.reacto_gradient {
  filter: contrast(170%) brightness(1000%);
  background: radial-gradient(32.42% 69.17% at 100% 27.33%, #911bd5 0%, rgba(145, 27, 213, 0) 100%), radial-gradient(44.43% 94.78% at 0.73% 5.22%, #cb6ce6 0%, rgba(203, 108, 230, 0) 100%), url("images/noise.svg");
  /* Mélange le bruit avec les couleurs en dessous */
  background-blend-mode: overlay;
}

body:not(.elementor-editor-active) {
  /* DEBUG : RED LINE AS HELPER FOR ALIGNMENT 
  &.logged-in {
  	&:active:before,
  	&:active:after {
  		content: "";
  		display: block;
  		pointer-events: none;
  		top: 0;
  		position: fixed;
  		z-index: 10000000;
  		height: 100vh;

  	}

  	&:active:before {
  		width: 1px;
  		background: red;
  		left: 50%;
  		right: auto;
  		border: 0; 
  	}
  	&:active:after {
  		width: auto;
  		max-width: 1420px;
  		margin: 0 auto;
  		background: transparent;
  		border-left: 1px solid red;
  		border-right: 1px solid red;
  		left: 20px;
  		right: 20px;
  		color: red;
  		font-weight: bold;
  	}

  	@media screen and (min-width: 411px) {
  		&:active:after {
  			left: 30px;
  			right: 30px;
  		}
  	}

  	@media screen and (min-width: 768px) {
  		&:active:after {
  			left: 4vw;
  			right: 4vw; 
  		}
  	}

  } */
}

@keyframes debug-line {
  0% {
    width: 1px;
    background: red;
    left: 50%;
    right: auto;
    border: 0;
  }
  19% {
    width: 1px;
    background: red;
    left: 50%;
    right: auto;
    border: 0;
  }
  20% {
    width: auto;
    max-width: 1140px;
    margin: 0 auto;
    background: transparent;
    border-left: 1px solid red;
    border-right: 1px solid red;
    left: 4vw;
    right: 4vw;
  }
  100% {
    width: auto;
    max-width: 1140px;
    margin: 0 auto;
    background: transparent;
    border-left: 1px solid red;
    border-right: 1px solid red;
    left: 4vw;
    right: 4vw;
  }
}

@media screen and (min-width: 601px) {
  .woocommerce.archive .wc-block-product-filters__overlay-content {
    background: #fff;
    display: flex;
    flex-direction: row;
    border-radius: 100px;
    padding: 20px 36px;
    flex-wrap: wrap;
    align-items: center;
    row-gap: 0.8em;
    margin: 1.8em 0;
    -moz-column-gap: 0.8em;
         column-gap: 0.8em;
  }
  .woocommerce.archive .wc-block-product-filters__overlay-content h2.wp-block-heading {
    font-size: 20px;
  }
  .woocommerce.archive .wp-block-woocommerce-product-filter-attribute,
  .woocommerce.archive .wp-block-woocommerce-product-filter-price {
    width: 20%;
    max-width: 250px;
    position: relative;
  }
  .woocommerce.archive .wp-block-woocommerce-product-filter-attribute:hover .wp-block-heading,
  .woocommerce.archive .wp-block-woocommerce-product-filter-price:hover .wp-block-heading {
    border-color: #cb6ce6;
    background: rgba(245, 208, 255, 0.2117647059);
  }
  .woocommerce.archive .wp-block-woocommerce-product-filter-price {
    margin-right: auto;
  }
  .woocommerce.archive .wp-block-woocommerce-product-filter-price ~ .wp-block-woocommerce-product-filter-attribute {
    width: auto;
  }
  .woocommerce.archive .wp-block-woocommerce-product-filter-price ~ .wp-block-woocommerce-product-filter-attribute .wc-block-product-filter-chips__item,
  .woocommerce.archive .wp-block-woocommerce-product-filter-price ~ .wp-block-woocommerce-product-filter-taxonomy .wc-block-product-filter-chips__item {
    font-size: 12px;
    padding: 8px 10px;
  }
  .woocommerce.archive .wp-block-woocommerce-product-filter-attribute .wp-block-heading,
  .woocommerce.archive .wp-block-woocommerce-product-filter-price .wp-block-heading {
    margin-bottom: 0 !important;
    border: 1px solid #dbdbdb;
    border-radius: 50px;
    padding: 10px 16px;
    font-size: 16px;
    font-weight: 400;
    cursor: pointer;
    transition: 0.25s;
  }
  .woocommerce.archive .wp-block-woocommerce-product-filter-checkbox-list,
  .woocommerce.archive .wp-block-woocommerce-product-filter-price-slider {
    border: 1px solid #dbdbdb;
    padding: 16px;
    border-radius: 30px;
    box-shadow: 0px 4px 25px 0px rgba(0, 0, 0, 0.1);
    position: absolute;
    left: 0;
    right: 0;
    top: 104%;
    z-index: 1;
    background: #fff;
    opacity: 0;
    transform: translateY(-20px);
    transition: all 0.2s ease;
    pointer-events: none;
  }
  .woocommerce.archive .wp-block-woocommerce-product-filter-checkbox-list.is-active,
  .woocommerce.archive .wp-block-woocommerce-product-filter-price-slider.is-active {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }
  .woocommerce.archive .wc-block-product-filter-checkbox-list__item {
    margin: 5px 0 0 0;
  }
  .woocommerce.archive .wp-block-woocommerce-product-filter-active {
    width: 100%;
    display: flex;
    align-items: center;
    margin-left: 80px;
  }
  .woocommerce.archive .wc-block-product-filter-removable-chips__items {
    gap: 8px;
  }
  .woocommerce.archive .wp-block-woocommerce-product-filter-clear-button .wp-block-buttons {
    margin: 0;
    margin-left: 20px;
  }
  .woocommerce.archive .wp-block-woocommerce-product-filter-clear-button .wp-block-buttons button {
    font-size: 14px;
    background: none;
    color: inherit;
    border: 0;
    text-decoration: underline !important;
    font-family: var(--font-family-base);
  }
}

@media screen and (min-width: 602px) {
  .home .tendances .tendances__list ul.products li.product.card .price {
    font-size: 14px;
  }
  .woocommerce ul.products li.product .price {
    font-size: 14px;
  }
}

@media (min-width: 640px) {
  .footer__inner .menus {
    grid-template-columns: repeat(2, 1fr);
    gap: 3.75rem;
    margin-block: 5rem 4rem;
  }
  .footer__inner .contact {
    align-items: flex-start;
    text-align: left;
    gap: 2rem;
  }
  .footer__inner .contact .coordonnees {
    gap: 1rem;
  }
  .footer__inner .logo_federation {
    margin-inline: 0;
  }
  .footer .legal ul {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem 2rem;
  }
}

@media (min-width: 768px) {
  .footer__inner .reassurance__inner {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
  }
  .footer__inner .reassurance__item {
    padding: 1em 0.25em;
  }
  .realisations__content .swiper-button-next,
  .realisations__content .swiper-button-prev {
    display: none;
  }
  .realisations__content {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    grid-template-rows: repeat(4, auto);
    gap: 1.25rem;
    overflow: visible;
  }
  .realisations__content .swiper-wrapper {
    display: contents;
  }
  .realisations .realisation-item--1 {
    grid-column: span 2;
    grid-row: span 2;
  }
  .realisations .realisation-item--4 {
    grid-column: span 2;
    grid-row: span 2;
  }
  .realisations .realisation-item--7 {
    grid-column: span 2;
    grid-row: span 2;
  }
  .realisations .realisation-item--8 {
    grid-column: span 2;
    grid-row: span 2;
  }
  .home .hero {
    background: url("images/lightning.svg") no-repeat -20% 30%/60%, url("images/hp/bg_hero_desk.webp") no-repeat center center/cover;
    background: url("images/lightning.svg") no-repeat -20% 30%/60%, -webkit-image-set(url("images/hp/bg_hero_desk.avif") type("image/avif"), url("images/hp/bg_hero_desk.webp") type("image/webp")) no-repeat center center/cover;
    background: url("images/lightning.svg") no-repeat -20% 30%/60%, image-set(url("images/hp/bg_hero_desk.avif") type("image/avif"), url("images/hp/bg_hero_desk.webp") type("image/webp")) no-repeat center center/cover;
  }
  .home .hero__inner {
    width: 88%;
    margin-inline: auto;
    display: grid;
    grid-template-columns: 1fr 1.5fr;
  }
  .home .hero__inner .content {
    align-items: flex-start;
    justify-content: flex-end;
  }
  .home .hero__inner .content .title .title-svg.on-mobile {
    display: none;
  }
  .home .hero__inner .content .title .title-svg.on-desktop {
    display: block;
  }
  .home .welcome_pack {
    display: block;
  }
  .home .welcome_pack__content {
    grid-template-columns: repeat(3, 1fr);
  }
  .home .qsn__wrapper .stats ul {
    justify-content: space-between;
    gap: 2rem;
    transform: none !important;
    width: 100% !important;
  }
  .home .qsn__wrapper .stats ul li {
    flex: 1;
    width: auto !important;
  }
  .qsn__header {
    flex-direction: row;
    padding: 0;
  }
  .qsn__header__texts {
    padding: 68px 0;
  }
  .qsn__bg-section {
    background: url("images/qsn/qsn_bg.webp") no-repeat center center/cover;
    background: -webkit-image-set(url("images/qsn/qsn_bg.avif") type("image/avif"), url("images/qsn/qsn_bg.webp") type("image/webp")) no-repeat center center/cover;
    background: image-set(url("images/qsn/qsn_bg.avif") type("image/avif"), url("images/qsn/qsn_bg.webp") type("image/webp")) no-repeat center center/cover;
  }
  .qsn__bg-section .content {
    width: 64%;
  }
  .qsn__reacto {
    flex-direction: row;
  }
  .qsn .realisations__content {
    display: grid;
    grid-template-rows: repeat(2, auto);
  }
  .page_realisations .realisations-grid {
    grid-template-columns: repeat(6, 1fr);
    grid-template-rows: repeat(4, auto);
  }
  .page_realisations .realisation-item:nth-child(12n+1), .page_realisations .realisation-item:nth-child(12n+4), .page_realisations .realisation-item:nth-child(12n+7), .page_realisations .realisation-item:nth-child(12n+8) {
    grid-column: span 2;
    grid-row: span 2;
  }
  .stats {
    overflow: visible;
  }
  .stats ul {
    justify-content: space-between;
    gap: 2rem;
    transform: none !important;
    width: 100% !important;
  }
  .stats li {
    flex: 1;
    width: auto !important;
  }
}

@media (min-width: 768px) and (max-width: 1025px) {
  .qsn__header__texts {
    max-width: 380px;
  }
}

@media screen and (min-width: 768px) {
  .page_contact .inner_contact {
    flex-direction: row;
  }
  .page_contact .inner_contact .block_infos {
    padding-block-end: 0;
    padding-inline: 2.5rem;
  }
  .woocommerce #content div.product .woocommerce-tabs,
  .woocommerce div.product .woocommerce-tabs,
  .woocommerce-page #content div.product .woocommerce-tabs,
  .woocommerce-page div.product .woocommerce-tabs {
    padding: 40px 6%;
  }
}

@media screen and (min-width: 769px) {
  .ywraq-form-table-wrapper.wide form#yith-ywraq-form {
    margin-left: 5%;
  }
  .tendances {
    margin: 3.8vw 0;
  }
}

@media (min-width: 1025px) {
  .footer__inner .reassurance__inner {
    gap: 1rem;
    font-size: var(--fs-reg);
  }
  .footer__inner .reassurance__item {
    padding: 1em 0.5em;
  }
  .footer__inner .menus {
    grid-template-columns: repeat(3, 1fr);
  }
  .qsn .separator {
    padding: 60px 0;
  }
  .qsn__header > * {
    width: 50%;
  }
  .qsn__bg-section {
    margin: 30px auto;
  }
  .qsn__bg-section .pic1, .qsn__bg-section .pic2, .qsn__bg-section .pic3 {
    display: block;
  }
}

@media screen and (min-width: 1025px) {
  .home .tendances .tendances__list ul.products li.product.card {
    padding: 1.25rem;
  }
  .woocommerce.archive .wc-block-product-filters__overlay-content {
    padding: 24px 42px;
    -moz-column-gap: 1.2em;
         column-gap: 1.2em;
  }
  .woocommerce ul.products li.product,
  .woocommerce-page ul.products li.product {
    padding: 20px;
  }
  .ywraq-wrapper .ywraq-form-table-wrapper.wide #yith-ywraq-form table.cart tr.cart_item {
    padding-left: 100px;
  }
  .ywraq-wrapper .ywraq-form-table-wrapper.wide #yith-ywraq-form table.cart tr.cart_item td.product-thumbnail {
    left: 12px;
  }
}

@media (min-width: 1025px) and (min-width: 1025px) and (max-width: 1920px) {
  .qsn__bg-section .pic1 img, .qsn__bg-section .pic1 source, .qsn__bg-section .pic2 img, .qsn__bg-section .pic2 source, .qsn__bg-section .pic3 img, .qsn__bg-section .pic3 source {
    width: 13vw;
  }
}

@media screen and (min-width: 1280px) {
  .header__nav .menu a {
    text-shadow: 0px 1px 3px rgb(0, 0, 0);
  }
  .header.header--dark .header__nav .menu > li > a {
    color: var(--darkblue);
    text-shadow: none;
  }
  .header.header--dark .header__nav .menu > li.btn > a,
  .header.header--dark .header__nav .menu > li.btn-menu > a,
  .header.header--dark .header__nav .menu > li > a.btn,
  .header.header--dark .header__nav .menu > li > a.btn-menu {
    color: var(--white);
  }
  .header__nav .menu-item.open-megamenu > .sub-menu .megamenu-logo {
    display: block;
    left: 2.5rem;
  }
  .header__nav .menu-item.open-megamenu > .sub-menu .menu-close-panel {
    display: flex;
    right: 2.5rem;
  }
  .header__nav .menu-item.open-megamenu > .sub-menu.panel-open {
    transform: translateX(0);
    visibility: visible;
    pointer-events: auto;
  }
  .header__nav .menu-item-has-children > .sub-menu {
    padding-top: 4rem;
  }
  .header__nav .menu-item-has-children > .sub-menu.submenu-active {
    transform: translateX(0);
  }
}

@media (min-width: 1280px) {
  .footer .legal ul {
    justify-content: space-between;
  }
  .qsn-section {
    background-image: url("images/bg_hero_desk.webp");
    background-image: -webkit-image-set(url("images/bg_hero_desk.avif") type("image/avif"), url("images/bg_hero_desk.webp") type("image/webp"));
    background-image: image-set(url("images/bg_hero_desk.avif") type("image/avif"), url("images/bg_hero_desk.webp") type("image/webp"));
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
  }
  .qsn-section__wrapper {
    width: 88%;
    margin-block: max(4rem, 2vw);
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 6fr 4fr;
    place-content: center;
  }
  .qsn-section__wrapper .visuels {
    grid-area: 1/1/3/2;
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    grid-template-rows: repeat(7, 1fr);
    gap: 1rem;
  }
  .qsn-section__wrapper .visuels .pic1 {
    display: none;
  }
  .qsn-section__wrapper .visuels .pic2 {
    display: block;
    grid-area: 4/3/8/7;
  }
  .qsn-section__wrapper .visuels .pic3 {
    display: block;
    grid-area: 4/1/6/3;
  }
  .qsn-section__wrapper .visuels .pic4 {
    display: block;
    grid-area: 2/5/4/7;
  }
  .qsn-section__wrapper .visuels .pic5 {
    display: block;
    grid-area: 1/2/4/5;
  }
  .qsn-section__wrapper .content {
    grid-area: 1/2/2/3;
  }
  .qsn-section__wrapper .stats {
    grid-area: 2/2/3/3;
    margin-block: auto;
  }
  .partenaires__marquee {
    --marquee-gap: 4rem;
  }
  .partenaires__marquee .marquee-content {
    animation-duration: 45s;
  }
  .home .tendances .tendances__list ul.products {
    grid-template-columns: repeat(4, 1fr);
  }
  .home .qsn {
    background-image: url("images/hp/bg_hero_desk.webp");
    background-image: -webkit-image-set(url("images/hp/bg_hero_desk.avif") type("image/avif"), url("images/hp/bg_hero_desk.webp") type("image/webp"));
    background-image: image-set(url("images/hp/bg_hero_desk.avif") type("image/avif"), url("images/hp/bg_hero_desk.webp") type("image/webp"));
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
  }
  .home .qsn__wrapper {
    width: 88%;
    margin-block: max(4rem, 2vw);
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 6fr 4fr;
    place-content: center;
  }
  .home .qsn__wrapper .visuels {
    grid-area: 1/1/3/2;
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    grid-template-rows: repeat(7, 1fr);
    gap: 1rem;
  }
  .home .qsn__wrapper .visuels .pic1 {
    display: none;
  }
  .home .qsn__wrapper .visuels .pic2 {
    display: block;
    grid-area: 4/3/8/7;
  }
  .home .qsn__wrapper .visuels .pic3 {
    display: block;
    grid-area: 4/1/6/3;
  }
  .home .qsn__wrapper .visuels .pic4 {
    display: block;
    grid-area: 2/5/4/7;
  }
  .home .qsn__wrapper .visuels .pic5 {
    display: block;
    grid-area: 1/2/4/5;
  }
  .home .qsn__wrapper .content {
    grid-area: 1/2/2/3;
  }
  .home .qsn__wrapper .stats {
    grid-area: 2/2/3/3;
    overflow: visible;
    margin-block: auto;
  }
}

@media screen and (min-width: 1281px) {
  .home .tendances .tendances__list ul.products li.product.card .price {
    font-size: 16px;
  }
  .woocommerce.archive .wp-block-woocommerce-product-filter-price ~ .wp-block-woocommerce-product-filter-attribute .wc-block-product-filter-chips__item,
  .woocommerce.archive .wp-block-woocommerce-product-filter-price ~ .wp-block-woocommerce-product-filter-taxonomy .wc-block-product-filter-chips__item {
    font-size: 16px;
    padding: 10px 14px;
  }
  .woocommerce.archive .wc-block-product-filter-chips__items {
    gap: 12px;
  }
  .woocommerce ul.products li.product .price {
    font-size: 16px;
  }
  .ywraq-wrapper .ywraq-form-table-wrapper.wide #yith-ywraq-form table.cart tr.cart_item {
    padding-left: 150px;
  }
  .ywraq-wrapper .ywraq-form-table-wrapper.wide #yith-ywraq-form table.cart tr.cart_item .product-thumbnail img {
    max-width: 100px;
  }
}

@media screen and (min-width: 1560px) {
  .header__nav .menu {
    gap: 2.5rem;
  }
}

@media (min-width: 1660px) {
  .footer__inner .footer__content {
    width: min(96%, 1660px);
  }
  .footer__inner .menus {
    grid-template-columns: repeat(6, 1fr);
  }
  .footer__bottom {
    width: auto;
    margin-inline-start: auto;
  }
}

@media screen and (max-width: 1440px) {
  .header__wrapper {
    padding: 1rem 1.5rem;
  }
  .menu-item-search .search-field {
    width: 10ch;
  }
}

@media screen and (max-width: 1279px) {
  .menu-toggle {
    display: flex;
  }
  .mobile-menu-header {
    display: flex;
  }
  .header__nav {
    position: fixed;
    top: 0;
    left: 0;
    width: min(380px, 90%);
    height: 100vh;
    height: 100dvh;
    background-color: var(--white);
    border-top-right-radius: 1.5rem;
    border-bottom-right-radius: 1.5rem;
    z-index: 1000;
    transform: translateX(-100%);
    transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
    padding: 2rem 0;
    box-shadow: 2px 0 10px rgba(0, 0, 0, 0.1);
  }
  .header__nav.toggled-on {
    transform: translateX(0);
  }
  .header__nav .menu {
    flex-direction: column;
    align-items: flex-start;
    gap: 1.5rem;
    width: 100%;
    padding-inline: 1rem;
  }
  .header__nav .menu a {
    color: var(--darkblue);
    font-size: var(--fs-m);
  }
  .header__nav .menu li.btn a,
  .header__nav .menu li.btn-menu a,
  .header__nav .menu a.btn,
  .header__nav .menu a.btn-menu {
    color: var(--white);
  }
  .header__nav .menu-item.open-megamenu > .sub-menu {
    width: 100%;
    height: 100%;
    transform: translateX(100%);
    z-index: 1100;
    padding-top: 2rem;
  }
  .header__nav .menu-item.open-megamenu > .sub-menu.panel-open, .header__nav .menu-item.open-megamenu > .sub-menu.submenu-active {
    transform: translateX(0);
    visibility: visible;
    pointer-events: auto;
  }
  .header__nav .menu-item.open-megamenu > .sub-menu .megamenu-scroll-content {
    padding-inline: 1rem;
    margin: 0 0 2rem 0;
  }
  .header__nav .menu-item-has-children > .sub-menu {
    z-index: 1200;
  }
  .header__nav .menu-item-has-children > .sub-menu {
    position: fixed;
    top: 2rem;
    left: 0;
    width: 100%;
    max-height: 100vh;
    max-height: 100dvh;
    padding: 0 1rem 1rem 1rem;
    transform: translateX(100%);
  }
  .header__nav .menu-item-has-children > .sub-menu.submenu-active {
    transform: translateX(0);
    visibility: visible;
    pointer-events: auto;
  }
  .header__nav .menu {
    position: relative;
    width: 100%;
    max-height: 100%;
    transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  }
  .header__nav .menu.sub-menu-active {
    transform: translateX(-100%);
  }
  .header__nav {
    overflow: hidden;
  }
}

@media screen and (max-width: 1820px) {
  .header__logo {
    flex: 1 0 50px;
  }
  .header__logo-icon-svg {
    display: block;
  }
  .header__logo-svg {
    display: none;
  }
}

@media (max-width: 768px) {
  .realisations header {
    flex-direction: column;
    align-items: center;
    margin-block-end: 1rem;
  }
  .realisations header .btn {
    display: none;
  }
  .home .tendances header {
    flex-direction: column;
    align-items: flex-start;
    gap: 1.5rem;
  }
  .home .avis__content .swiper-button-prev {
    display: none;
  }
  .home .avis__content .swiper-button-next {
    display: none;
  }
  .page_realisations header {
    flex-direction: column;
    align-items: center;
    margin-block-end: 1rem;
  }
  .page_realisations header .btn {
    display: none;
  }
}

@media (max-width: 767px) {
  .realisations__content {
    padding-block: 2rem;
  }
  .realisations__content .realisation-item {
    padding: 1rem;
  }
  .page_realisations .realisations-grid {
    padding-block: 2rem;
  }
  .page_realisations .realisation-item:nth-child(5n+1) {
    grid-column: span 2;
  }
}

@media screen and (max-width: 601px) {
  .home .tendances .tendances__list ul.products li.product.card a.woocommerce-LoopProduct-link .woocommerce-loop-product__title {
    font-size: 11px;
  }
  .woocommerce ul.products li.product .woocommerce-loop-category__title,
  .woocommerce ul.products li.product .woocommerce-loop-product__title,
  .woocommerce ul.products li.product h3 {
    font-size: 11px;
  }
}

@media screen and (max-width: 600px) {
  .woocommerce.archive :where(.wc-block-product-filters) .wc-block-product-filters__close-overlay,
  .woocommerce.archive :where(.wc-block-product-filters) .wc-block-product-filters__open-overlay {
    font-family: var(--font-family-base);
    background: #cb6ce6;
    color: #fff;
    font-weight: 700;
    border-radius: 50px;
    padding: 10px;
    display: flex;
    justify-content: center;
    margin: 20px 0 !important;
    cursor: pointer;
  }
}

@media screen and (max-width: 1025px) {
  .ywraq-wrapper .ywraq-form-table-wrapper.wide .yith-ywraq-mail-form-wrapper form .form-row {
    float: none;
    width: 100%;
  }
}

@media screen and (max-width: 769px) {
  .ywraq-wrapper .ywraq-form-table-wrapper.wide {
    padding: 30px 0;
    display: flex;
    flex-direction: column-reverse;
  }
}

@media screen and (max-width: 767px) {
  .ywraq-wrapper .ywraq-form-table-wrapper.wide #yith-ywraq-form table.cart td.actions {
    right: 10px;
  }
}

@media screen and (max-width: 1280px) {
  .ywraq-wrapper .ywraq-form-table-wrapper.wide #yith-ywraq-form table.cart td.actions input {
    text-indent: -999px;
    color: transparent;
    padding-right: 4px;
  }
}
/*# sourceMappingURL=style.css.map */
