@font-face {
  font-family: Montserrat;
  src: url("fonts/montserrat.woff2") format("woff2");
  font-weight: 100 900;
}
@font-face {
  font-family: "PT Sans";
  src: url("fonts/ptsans-regular.woff2") format("woff2");
  font-weight: 400;
}
@font-face {
  font-family: "PT Sans";
  src: url("fonts/ptsans-bold.woff2") format("woff2");
  font-weight: 700;
}
@view-transition {
  navigation: auto;
}
@keyframes slide-in {
  0% {
    transform: translateX(100%);
  }
  100% {
    transform: translateX(0);
  }
}
::view-transition-old(root) {
  animation: 1s ease exist-pas;
}
::view-transition-new(root) {
  animation: 1s ease both slide-in;
}
@keyframes VaporIn {
  0% {
    filter: blur(5em);
  }
  100% {
    filter: blur(0em);
  }
}
.has-js .vapor-in {
  filter: blur(5em);
}
.has-js .fade-in {
  opacity: 0;
}
.has-js .active .vapor-in {
  animation: VaporIn 0.8s ease forwards;
}
.has-js .active .fade-in {
  animation: fadeIn 0.8s ease forwards;
}
:root {
  /* Colors */
  --color-hsl-primary: 46 33% 56%;
  --color-hsl-secondary: 0 0% 100%;
  --color-hsl-accent: 197 90% 61%;
  --color-hsl-background: 53 100% 98%;
  --color-hsl-text: 0 0% 0%;
  --color-primary: hsl(var(--color-hsl-primary));
  --color-secondary: hsl(var(--color-hsl-secondary));
  --color-accent: hsl(var(--color-hsl-accent));
  --color-background: hsl(var(--color-hsl-background));
  --color-text: hsl(var(--color-hsl-text));
  --color-light: #ffffff;
  --color-dark: #000000;
  /* Typography */
  --font-heading: Montserrat, sans-serif;
  --font-text: "PT Sans", sans-serif;
  --ft-size--2: clamp(0.7901rem, 0.7873rem + 0.0141vw, 0.8rem);
  --ft-size--1: clamp(0.8889rem, 0.8571rem + 0.1587vw, 1rem);
  --ft-size-0: clamp(1rem, 0.9286rem + 0.3571vw, 1.25rem);
  --ft-size-1: clamp(1.125rem, 1rem + 0.625vw, 1.5625rem);
  --ft-size-2: clamp(1.2656rem, 1.0692rem + 0.9821vw, 1.9531rem);
  --ft-size-3: clamp(1.4238rem, 1.1331rem + 1.4537vw, 2.4414rem);
  --ft-size-4: clamp(1.6018rem, 1.1875rem + 2.0714vw, 3.0518rem);
  --text-length: 64ch;
  /* Spacing */
  --gap: 1.5625rem;
  --margin-inline: clamp(1.25rem, -0.9507rem + 9.3897vw, 7.5rem);
  --pad-block: 5rem;
  --pad-block-large: clamp(3.75rem, 2.6786rem + 5.3571vw, 7.5rem);
  --max-width: 102.5rem;
  --page-padding: 2.3rem;
  /* Miscellaneous */
  --lines-thickness: clamp(0.5rem, -0.0714rem + 2.8571vw, 2.5rem);
  --font-awesome: "Font Awesome 5 Pro";
}
/**
 * Mixing.less
 */
/**
 * Utils.less
 */
#wp-admin-bar-rea__blog_public {
  background: red !important;
}
#wp-admin-bar-rea__blog_public:hover {
  background: red !important;
}
#wp-admin-bar-rea__environnement {
  background: #8B0000 !important;
}
#wp-admin-bar-rea__environnement:hover {
  background: #8B0000 !important;
}
.wrapper {
  max-width: var(--max-width);
  width: calc(100% - var(--page-padding));
  margin-inline: auto;
}
#wpadminbar {
  overflow: hidden;
  opacity: 0;
  top: -25px;
  transition: 200ms;
}
#wpadminbar .input[type=text] {
  width: auto;
}
#wpadminbar:hover {
  opacity: 1;
  top: 0;
  transition: 200ms;
}
.badge {
  display: inline-block;
  align-self: flex-start;
  font-size: var(--ft-size--1);
  padding: 0.2rem 1rem;
  margin-bottom: var(--_badge-margin, 0);
  color: var(--color-secondary);
  vertical-align: middle;
  background-color: var(--color-accent);
}
.text-intro {
  --_spacer: 1.36em;
  font-size: 1.15em;
  font-style: italic;
  margin-bottom: var(--_spacer);
}
.text-intro::after {
  content: "";
  display: block;
  height: 0.125rem;
  width: 100%;
  margin-top: var(--_spacer);
  background-color: black;
}
.text-right {
  text-align: end;
}
.text-center {
  --_text-cta-position: center;
  text-align: center;
  margin-inline: auto;
}
.text-framed {
  --max-width: var(--text-length);
  border-block: 1px solid hsl(0 0% 0% / 0.8);
  margin-block: 2.8rem;
  padding: 2.8rem;
}
.text-primary {
  color: var(--color-primary);
}
.text-accent {
  color: var(--color-accent);
}
.flow > * + * {
  margin-top: var(--flow-spacer, 1em);
}
.btn,
a.btn,
button.btn,
button.gform_button.btn.btn-primary {
  display: inline-block;
  width: fit-content;
  margin-bottom: 1em;
  padding: 0.75em 1.125em;
  border: 0.1875em solid var(--_button-color, var(--color-text));
  font-size: var(--ft-size--1);
  font-weight: 700;
  text-decoration: none;
  line-height: 1.1;
  color: var(--_button-color, var(--color-text));
  cursor: pointer;
  transition: background-color 400ms ease, color 400ms ease;
}
.btn::after,
a.btn::after,
button.btn::after,
button.gform_button.btn.btn-primary::after {
  transform: translate(0, -50%);
  content: "\f054";
  font-weight: 900;
  font-family: "Font Awesome 5 Pro";
  pointer-events: none;
  margin-inline-start: 0.8em;
}
.btn:hover,
a.btn:hover,
button.btn:hover,
button.gform_button.btn.btn-primary:hover {
  background-color: var(--_button-color, var(--color-text));
  color: var(--_button-cl-text, var(--color-secondary));
}
.btn.--dark,
a.btn.--dark,
button.btn.--dark,
button.gform_button.btn.btn-primary.--dark {
  border-color: var(--color-secondary);
  color: var(--color-secondary);
}
.btn.--dark:hover,
a.btn.--dark:hover,
button.btn.--dark:hover,
button.gform_button.btn.btn-primary.--dark:hover {
  background-color: var(--color-secondary);
  color: var(--color-text);
}
.btn.--pill,
a.btn.--pill,
button.btn.--pill,
button.gform_button.btn.btn-primary.--pill {
  border-radius: 50rem;
}
.btn.--landing-page,
a.btn.--landing-page,
button.btn.--landing-page,
button.gform_button.btn.btn-primary.--landing-page {
  display: flex;
  margin-top: 2rem;
  padding: 0.72em 2.2em;
  border: solid 0.04em #ffffff;
  border-radius: 50rem;
  font-family: var(--font-heading);
  font-size: var(--ft-size-1);
  color: inherit;
  background-color: #000000;
  transition-property: background-color, color;
  transition: 0.3s ease;
}
.btn.--landing-page:hover,
a.btn.--landing-page:hover,
button.btn.--landing-page:hover,
button.gform_button.btn.btn-primary.--landing-page:hover {
  background-color: #ffffff;
  color: #000000;
}
.btn.--landing-page:hover:before,
a.btn.--landing-page:hover:before,
button.btn.--landing-page:hover:before,
button.gform_button.btn.btn-primary.--landing-page:hover:before {
  color: #000000;
}
.btn.--landing-page.--alt,
a.btn.--landing-page.--alt,
button.btn.--landing-page.--alt,
button.gform_button.btn.btn-primary.--landing-page.--alt {
  border: none;
  background-color: var(--color-accent);
}
.btn.--landing-page.--alt:hover,
a.btn.--landing-page.--alt:hover,
button.btn.--landing-page.--alt:hover,
button.gform_button.btn.btn-primary.--landing-page.--alt:hover {
  background-color: #ffffff;
}
.btn.--phone::before,
a.btn.--phone::before,
button.btn.--phone::before,
button.gform_button.btn.btn-primary.--phone::before {
  content: "\f095";
  margin-right: 0.48em;
  font-family: var(--font-awesome);
  font-weight: 400;
}
.btn.--phone::after,
a.btn.--phone::after,
button.btn.--phone::after,
button.gform_button.btn.btn-primary.--phone::after {
  content: none;
  display: none;
}
table {
  width: 100%;
  border-collapse: collapse;
}
table th,
table td {
  text-align: start;
  padding: 1.625rem 1.125rem;
}
table thead {
  font-weight: 700;
  color: var(--color-light);
  background-color: var(--color-dark);
}
table tbody tr {
  border-bottom: solid 2px #000000;
}
table tbody th {
  background-color: hsl(0 0% 0% / 0.3);
}
.text-block {
  display: flex;
  flex-direction: column;
  font-weight: 700;
  width: fit-content;
  /*@media (min-width: 56.25em) {
		width: unset;
	}*/
}
.text-block > * + * {
  margin-top: 1em;
}
.text-block__title {
  margin-top: 0;
  font-size: var(--_tb-title-fs, var(--ft-size-4));
  font-weight: var(--_tb-fw, 800);
  text-transform: uppercase;
}
.text-block__subtitle {
  font-size: var(--ft-size-2);
  margin-top: 0.1em;
  text-wrap: pretty;
  line-height: 1.1;
}
.text-block__ctas {
  margin-top: 1em;
  text-align: var(--_text-cta-position, end);
}
.text-block__ctas.--start {
  text-align: start;
}
.text-block__ctas.--center {
  text-align: center;
}
.text-block__image-right {
  align-self: flex-start;
  margin-top: auto;
}
.text-block.--center-right {
  margin-inline: auto;
}
.text-block.--center {
  --_text-cta-position: center;
  margin-inline: auto;
  text-align: center;
}
.text-block.--end {
  text-align: end;
  margin-inline-start: auto;
}
*,
*::before,
*::after {
  box-sizing: border-box;
}
* {
  font: inherit;
  margin: 0;
  padding: 0;
}
html {
  hanging-punctuation: first last;
}
body {
  margin: 0;
  padding: 0;
  background-color: var(--color-background);
  color: var(--color-text);
  font: normal normal 400 var(--ft-size-0) / 1.4 var(--font-text);
  overflow-x: clip;
}
.home {
  background-color: var(--color-text);
  color: var(--color-secondary);
  --_button-color: var(--color-secondary);
  --_button-cl-text: var(--color-text);
  --max-width: 78.75rem;
}
p {
  text-wrap: pretty;
  max-width: var(--text-length);
}
a {
  transition: color 200ms ease;
  outline: 0;
  color: var(--_link-color, var(--color-accent));
  text-decoration: underline;
}
a:active,
a:focus,
a:visited {
  outline: 0;
}
a.--alt {
  color: var(--color-primary);
}
hr {
  display: block;
  height: 1px;
  margin: 1em 0;
  padding: 0;
  border: 0;
  border-top: 1px solid var(--color-ultralightgrey);
}
ul,
ol {
  --_size: 2.5rem;
  list-style: none;
  padding: 0;
  /*padding-left: calc(var(--_size) + 1em);*/
  margin-left: 0;
}
ol {
  counter-reset: arguments;
}
ol > li + li {
  margin-top: 1em;
}
:is(ul, ol) > li {
  display: flex;
  align-items: center;
  text-wrap: pretty;
}
:is(ul, ol) > li::before {
  left: -1em;
  margin-right: 1em;
}
ul > li::before {
  content: "\f054";
  font-family: var(--font-awesome);
  font-size: 1em;
  font-weight: 700;
}
ol > li {
  counter-increment: arguments;
}
ol > li::before {
  content: counter(arguments);
  display: flex;
  justify-content: center;
  align-items: center;
  align-self: flex-start;
  width: var(--_size);
  height: var(--_size);
  color: var(--color-secondary);
  line-height: 1;
  left: calc(var(--_size) * -1 - 1em);
  background-color: var(--color-accent);
}
button {
  border: none;
  background: none;
}
@media (hover: hover) {
  button:hover {
    cursor: pointer;
  }
}
img {
  max-width: 100%;
  height: auto;
}
strong {
  font-weight: 700;
}
h1,
.h1,
h2,
.h2,
h3,
.h3,
h4,
.h4 {
  font-family: var(--font-heading);
  font-weight: 700;
  line-height: 1.1;
  margin: 0;
  text-wrap: balance;
}
h1,
.h1 {
  font-size: var(--ft-size-4);
  text-transform: uppercase;
}
h2,
.h2 {
  font-size: var(--ft-size-3);
}
h3,
.h3 {
  font-size: var(--ft-size-2);
}
h4,
.h4 {
  font-size: var(--ft-size-1);
}
.mce-content-body {
  padding: 1em 0.8em;
}
.mce-content-body > * + * {
  margin-top: 1em;
}
.wp-image-311,
.wp-image-298 {
  object-position: top;
}
.grid {
  --_grid-cell-width: 32rem;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(var(--_grid-cell-width), 100%), 1fr));
  gap: 1.25rem;
}
.grid.--three {
  --_grid-cell-width: 21.875rem;
}
.page-template-tpl-landing-page header.main-header {
  color: var(--color-light);
  background-color: transparent;
  position: absolute;
  right: 0;
}
[class*=bg-] > .wrapper {
  padding-block: 2.8rem;
}
.bg-text {
  --_button-color: var(--color-secondary);
  --_button-cl-text: var(--color-text);
  background-color: var(--color-text);
  color: var(--color-secondary);
}
.bg-background {
  --_button-color: var(--color-text);
  --_button-cl-text: var(--color-secondary);
  background-color: var(--color-background);
  color: var(--color-text);
}
.bg-primary {
  --_button-color: var(--color-secondary);
  --_button-cl-text: var(--color-text);
  --_link-color: var(--color-text);
  background-color: var(--color-primary);
  color: var(--color-secondary);
}
.flex {
  display: flex;
}
.grid-x {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--gap);
}
.link {
  text-decoration: none;
}
.link::after {
  content: '\f054';
  font-weight: 900;
  font-family: 'Font Awesome 5 Pro';
  margin-inline-start: 0.2em;
}
.max-40ch {
  max-width: 40ch;
}
.max-20ch {
  max-width: 20ch;
}
.skew-section {
  border-block: solid var(--color-primary) var(--lines-thickness);
  transform: skew(0, -18.4deg);
  padding-top: 14rem;
  padding-bottom: 0;
  margin-top: clamp(-14.75rem, 1rem + -17.5vw, -2.5rem);
  position: relative;
  isolation: isolate;
  overflow: clip;
  backface-visibility: hidden;
  -webkit-font-smoothing: subpixel-antialiased;
}
.skew-section > * {
  transform: skew(0, 18.4deg);
  backface-visibility: hidden;
  -webkit-font-smoothing: subpixel-antialiased;
}
.skew-section::before {
  content: "";
  display: block;
  width: 0%;
  height: calc(var(--lines-thickness) * 2.8);
  position: absolute;
  top: calc(var(--lines-thickness) * 2);
  background-color: var(--color-accent);
  transition: width 0.5s ease;
}
.skew-section::after {
  content: "";
  display: block;
  background-color: var(--color-text);
  width: 100%;
  height: calc(var(--lines-thickness) * 1.2);
  position: absolute;
  bottom: 0;
}
.skew-section__image {
  position: absolute;
  top: -2.5%;
  right: calc(var(--page-padding) / 2);
  perspective: 1000px;
}
@media (min-width: 78.75em) {
  .skew-section__image {
    right: calc(50% - var(--max-width) / 2);
  }
}
.skew-section__image img {
  width: 280px;
}
.skew-section__image video {
  position: absolute;
  right: 6%;
  bottom: 18%;
  z-index: 1;
  transform: rotateY(-26deg) scale(0.55);
}
@media (min-width: 35em) {
  .skew-section__image {
    top: -80px;
  }
  .skew-section__image img {
    width: unset;
  }
  .skew-section__image video {
    right: 29%;
    bottom: 27.5%;
    transform: rotateY(-26deg) scale(0.99);
  }
}
.skew-section.rollit::before {
  width: 100%;
}
.skew-section + :is(div, section) {
  position: relative;
  z-index: 1;
}
.skew-section .google {
  display: flex;
  column-gap: 1.25rem;
  justify-content: center;
  align-items: flex-end;
  font-weight: 700;
  margin-bottom: 100px;
}
.skew-section .text-block__image-right {
  translate: 0 10%;
}
@media (min-width: 56.25em) {
  .skew-section {
    padding-bottom: 5rem;
  }
  .skew-section .text-block__image-right {
    translate: 0;
  }
}
@media (min-width: 35em) {
  .skew-section {
    padding-top: clamp(18rem, 40.9091rem + -25.4545vw, 32rem);
  }
}
.stack {
  margin-block: 100px;
}
@media screen and (max-width: 600px) {
  .stack {
    margin-bottom: 50px;
  }
}
.stack.padding {
  padding-block: 100px;
  margin-block: 0;
}
@media screen and (max-width: 600px) {
  .stack.padding {
    padding-bottom: 50px;
    margin-block: 0;
  }
}
.stack *:has(img) {
  margin-bottom: 0;
}
.stack img {
  border-radius: 10px;
  object-fit: cover;
  height: auto;
}
@media screen and (max-width: 850px) {
  .stack img {
    aspect-ratio: unset;
    height: 100%;
    max-height: 330px;
  }
}
.stack .swiper img {
  height: 100%;
  aspect-ratio: unset;
}
.accordions {
  --_underline-thickness: 0.375rem;
  display: flex;
  flex-direction: column;
  gap: 1.875rem;
  width: fit-content;
  min-width: min(100%, 50rem);
  margin-top: 2em;
}
.accordions__item {
  display: grid;
  grid-template-rows: min-content 0fr;
  overflow: hidden;
  transition-property: grid-template-rows;
  transition-timing-function: cubic-bezier(1, 0, 0, 1);
  transition-duration: var(--duration, 0.3s);
}
.accordions__item:has([aria-expanded='true']) {
  grid-template-rows: min-content 1fr;
}
.accordions__item .header {
  margin-bottom: 0.5em;
  padding-bottom: 0.5em;
  padding-right: 1.5em;
  position: relative;
  cursor: pointer;
  border: none;
  border-bottom: var(--_underline-thickness) solid var(--_border-color, var(--color-primary));
  font-family: var(--font-heading);
  font-size: var(--ft-size-3);
  font-weight: 700;
  text-align: start;
  background-color: transparent;
}
.accordions__item .header::after {
  content: "\f054";
  font-family: var(--font-awesome);
  position: absolute;
  right: 0;
  transition: transform 300ms ease,
				right 300ms ease;
}
.accordions__item .header[aria-expanded='true']::after {
  transform: rotateZ(90deg);
  right: 0.975rem;
}
.accordions__item .panel {
  overflow: hidden;
}
.accordions__item .panel[hidden] {
  display: none;
}
.accordions.--accent {
  --_border-color: var(--color-accent);
}
/* Stack Avantages Section */
.stack-avantages {
  --max-width: 1300px;
  font-family: var(--font-heading);
  /* Left Column */
  /* Right Column - Grid of Cards */
  /* Responsive */
}
.stack-avantages__titre {
  font-size: var(--ft-size-2);
  font-weight: 700;
  margin-bottom: 40px;
  color: #000;
}
.stack-avantages__content {
  display: grid;
  grid-template-columns: 1fr 1.7fr;
  gap: 120px;
  align-items: start;
}
.stack-avantages__left {
  font-size: var(--ft-size--1);
}
.stack-avantages__texte {
  line-height: 1.6;
  color: #333;
}
.stack-avantages__texte p {
  margin-bottom: 1em;
}
.stack-avantages__liste {
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 15px;
  list-style: none;
  margin-bottom: 20px;
}
.stack-avantages__liste-item {
  display: flex;
  align-items: center;
  gap: 20px;
}
.stack-avantages__liste-item::before {
  content: "";
  display: none;
}
.stack-avantages__liste svg {
  min-width: 32px;
  min-height: 32px;
  width: 32px;
  height: 32px;
}
.stack-avantages__liste-text {
  line-height: 1.5;
  color: #333;
  padding-top: 2px;
}
.stack-avantages__right {
  position: relative;
}
.stack-avantages__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
}
.stack-avantages__card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
  background-color: #f7f7f7;
  padding: 20px;
}
.stack-avantages__card-icon {
  width: 60px;
  height: 60px;
  background-color: var(--color-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 12px;
}
.stack-avantages__card-icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.stack-avantages__card-titre {
  font-size: var(--ft-size-0);
  font-weight: 600;
  margin: 0;
}
.stack-avantages__card-texte {
  font-size: var(--ft-size--2);
  line-height: 1.6;
}
.stack-avantages__card-texte p {
  margin: 0;
}
@media (max-width: 1024px) {
  .stack-avantages__content {
    gap: 40px;
  }
  .stack-avantages__grid {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }
}
@media (max-width: 768px) {
  .stack-avantages__titre {
    font-size: var(--ft-size-3);
    margin-bottom: 30px;
  }
  .stack-avantages__content {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .stack-avantages__card-icon {
    width: 50px;
    height: 50px;
  }
}
@media (max-width: 480px) {
  .stack-avantages__titre {
    font-size: var(--ft-size-2);
  }
  .stack-avantages__card-titre {
    font-size: var(--ft-size-0);
  }
  .stack-avantages__card-texte {
    font-size: var(--ft-size--2);
  }
}
.stack.forfaits {
  --max-width: 1300px;
  font-family: var(--font-heading);
  position: relative;
}
.stack.forfaits .bg-img {
  position: absolute;
  z-index: -1;
  bottom: 0;
  left: 0;
  width: 100%;
  height: auto;
  border-radius: 0;
}
.forfaits-title {
  font-size: var(--ft-size-3);
  font-weight: 700;
  color: #333333;
  margin-bottom: 40px;
  text-align: left;
}
@media (min-width: 768px) {
  .forfaits-title {
    margin-bottom: 60px;
  }
}
.forfaits-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 30px;
  grid-auto-rows: auto;
}
@media (min-width: 600px) {
  .forfaits-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1024px) {
  .forfaits-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.forfait-card {
  background: #ffffff;
  overflow: hidden;
  transition: all 0.3s ease;
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 5;
  position: relative;
  gap: 0;
}
.forfait-card--featured .forfait-card__header {
  padding-right: 0 !important;
}
.forfait-card__color-bar {
  height: 24px;
  width: 100%;
}
.forfait-card__header,
.forfait-card__subtitle,
.forfait-card__content,
.forfait-card__footer {
  border-left: 3px solid #d1d0d0;
  border-right: 3px solid #d1d0d0;
}
.forfait-card__separator {
  border-bottom: 1px solid #d1d0d0;
  margin-bottom: 20px;
}
.forfait-card__footer {
  border-bottom: 3px solid #d1d0d0;
}
.forfait-card__header {
  --arrow-width: 20px;
  padding: 20px 30px;
  position: relative;
  display: flex;
  align-items: center;
  gap: calc(var(--arrow-width) * 3);
}
.forfait-card__header h3 {
  margin-bottom: 0;
}
.forfait-card__title {
  font-size: var(--ft-size-2);
  font-weight: 700;
  margin: 0 0 10px 0;
  line-height: 1.3;
}
.forfait-card__badge {
  position: relative;
  left: 3px;
  padding: 8px 16px;
  border-radius: 0px;
  color: #ffffff;
  font-size: var(--ft-size--2);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.forfait-card__badge svg {
  position: absolute;
  top: 50%;
  left: calc(var(--arrow-width) / 2 * -1);
  transform: translateY(-50%);
  width: var(--arrow-width);
  height: auto;
}
.forfait-card__subtitle {
  padding: 0 30px 20px 30px;
  font-size: var(--ft-size-0);
  font-weight: 600;
  color: #333333;
  line-height: 1.5;
}
.forfait-card__subtitle span {
  display: flex;
  align-items: center;
  gap: 10px;
}
.forfait-card__content {
  padding: 0 30px 30px;
  color: #666666;
  font-size: var(--ft-size--1);
  line-height: 1.7;
}
.forfait-card__content ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.forfait-card__content ul li {
  padding: 8px 0;
  position: relative;
  padding-left: 0;
}
.forfait-card__content ul li::before {
  content: "";
  display: inline-block;
  width: 5px;
  height: 5px;
  background-color: #666666;
  border-radius: 50%;
  margin-right: 12px;
  vertical-align: middle;
}
.forfait-card__content p {
  margin: 0 0 15px 0;
}
.forfait-card__content p:last-child {
  margin-bottom: 0;
}
.forfait-card__content strong {
  color: #333333;
  font-weight: 600;
}
.forfait-card__footer {
  padding: 0 30px 30px;
  display: flex;
  align-self: end;
}
.forfait-card .btn {
  margin-left: auto;
}
@media (prefers-reduced-motion: reduce) {
  .forfait-card,
  .forfait-card__button,
  .forfait-card__button-icon {
    transition: none;
  }
  .forfait-card:hover {
    transform: none;
  }
}
@media print {
  .forfait-card {
    box-shadow: none;
    border: 1px solid #e0e0e0;
    page-break-inside: avoid;
  }
  .forfait-card:hover {
    transform: none;
  }
}
.stack-texte-en-colonne .contenus {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  column-gap: 100px;
  row-gap: 30px;
}
.stack-texte-en-colonne .contenus.frame {
  column-gap: 1.25rem;
}
.stack-texte-en-colonne .contenus.frame > * {
  border: 0.375rem var(--color-secondary) solid;
  background-color: var(--color-text);
  padding: 2.8125rem 2.375rem;
}
.stack-texte-en-colonne .contenus.contenus--2.contenus--reverse,
.stack-texte-en-colonne .contenus.contenus--3.contenus--reverse {
  flex-direction: column-reverse;
}
@media screen and (max-width: 991px) {
  .stack-texte-en-colonne .contenus {
    column-gap: 50px;
  }
}
.stack-texte-en-colonne .contenus.contenus--2,
.stack-texte-en-colonne .contenus.contenus--3 {
  grid-template-columns: repeat(2, 1fr);
}
.stack-texte-en-colonne .contenus.contenus--3 {
  grid-template-columns: repeat(3, 1fr);
}
@media screen and (max-width: 1280px) {
  .stack-texte-en-colonne .contenus.contenus--3 {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 850px) {
  .stack-texte-en-colonne .contenus.contenus--2,
  .stack-texte-en-colonne .contenus.contenus--3 {
    display: flex;
    flex-direction: column;
  }
}
.stack-documents-et-liens .texte {
  margin-bottom: 40px;
  max-width: 70ch;
}
.stack-documents-et-liens .documents-liens {
  display: flex;
  flex-direction: column;
  max-width: 70ch;
}
.stack-documents-et-liens .icon {
  width: 100%;
  height: auto;
  max-width: 40px;
  aspect-ratio: 1 / 1;
  background-color: black;
  border-radius: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.stack-documents-et-liens .icon svg {
  width: 40%;
  height: auto;
}
.stack-documents-et-liens .icon svg > * {
  fill: white;
}
.stack-documents-et-liens .grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  row-gap: 30px;
  column-gap: 100px;
}
@media screen and (max-width: 850px) {
  .stack-documents-et-liens .grid {
    grid-template-columns: 1fr;
  }
}
@media screen and (max-width: 850px) {
  .stack-documents-et-liens .col-right {
    order: -1;
  }
}
.stack-documents-et-liens a {
  transition: all 1000ms cubic-bezier(0.015, 0.98, 0.195, 0.99);
  /* custom */
  display: flex;
  align-items: center;
  gap: 15px;
  padding: 10px 0 10px 20px;
  text-decoration: none;
  font-weight: bold;
}
@media (hover: hover) {
  .stack-documents-et-liens a:hover {
    color: unset;
    padding-left: 35px;
  }
}
.stack-documents-et-liens a:nth-child(2n) {
  background-color: rgba(0, 0, 0, 0.2);
}
.carousel {
  --swiper-pagination-bullet-size: 1.125rem;
  --swiper-theme-color: var(--color-dark);
  --swiper-pagination-bullet-inactive-color: var(--color-light);
  --swiper-pagination-bottom: 1.25rem;
  --swiper-pagination-bullet-inactive-opacity: 1;
  position: relative;
}
.carousel:not([data-carousel-slides="1"]) {
  padding-inline: clamp(0rem, -0.8929rem + 4.4643vw, 3.125rem);
}
.carousel[data-carousel-slides="1"] {
  margin-inline: auto;
  max-width: 60rem;
}
.carousel .swiper-wrapper {
  align-items: center;
}
.carousel .swiper-slide {
  transform: scale(0.89);
  transition: transform 0.3s ease;
}
.carousel .swiper-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.carousel .swiper-button-next:after,
.carousel .swiper-button-prev:after {
  font-family: var(--font-awesome);
}
.carousel .swiper-button-prev {
  left: 0;
}
.carousel .swiper-button-prev::after {
  content: "\f053";
}
.carousel .swiper-button-next {
  right: 0;
}
.carousel .swiper-button-next::after {
  content: "\f054";
}
.carousel .swiper-pagination-bullet {
  border: 0.3125rem var(--color-dark) solid;
}
.carousel .swiper > .swiper-button-prev {
  left: clamp(0rem, -0.8929rem + 4.4643vw, 3.125rem);
}
.carousel .swiper > .swiper-button-next {
  right: clamp(0rem, -0.8929rem + 4.4643vw, 3.125rem);
}
.carousel .swiper-slide-active {
  transform: scale(1);
}
.stack-citations {
  height: 60dvh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.stack-citations .texte {
  max-width: 50ch;
  margin: 0 auto;
  font-size: clamp(1.25rem, 0.7386rem + 2.2727vw, 2.5rem);
  font-weight: bold;
  text-align: center;
}
header.main-header {
  position: sticky;
  top: 0;
  left: 0;
  z-index: 99;
  transition: transform 0.5s ease;
  background-color: var(--color-background);
  color: var(--color-text);
}
header.main-header ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
header.main-header li {
  display: block;
  margin: 0;
  position: static;
}
header.main-header li::before {
  content: unset;
}
header.main-header a {
  font-family: var(--font-heading);
  font-weight: 700;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}
header.main-header a:hover {
  color: var(--color-accent);
}
header.main-header svg {
  width: 30px;
  height: auto;
}
header.main-header > .wrapper {
  --max-width: 100%;
  display: flex;
  align-items: center;
  padding-block: 1.875rem;
}
header.main-header .logo {
  display: flex;
  column-gap: 1.25rem;
  margin-inline-end: auto;
}
header.main-header .logo img {
  height: auto;
}
header.main-header .logo__main {
  max-width: 8rem;
}
header.main-header .logo__secondary {
  max-width: 6.5rem;
}
@media (min-width: 33.75em) {
  header.main-header .logo__main {
    max-width: unset;
  }
  header.main-header .logo__secondary {
    max-width: unset;
  }
}
header.main-header nav {
  display: none;
  flex-direction: column-reverse;
  gap: 1rem;
  font-size: var(--ft-size--1);
  text-transform: uppercase;
}
header.main-header nav > .main-navigation {
  display: flex;
  gap: 4rem;
  text-align: center;
}
header.main-header nav > .secondary-navigation {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 4rem;
}
header.main-header nav > .secondary-navigation a {
  font-weight: 400;
}
header.main-header nav > .secondary-navigation .phone-number {
  font-size: var(--ft-size-0);
  font-weight: 700;
}
header.main-header .sub-menu {
  display: none;
  width: max-content;
  padding: 2.5rem 3.125rem;
  text-align: start;
  background-color: var(--color-background);
  position: absolute;
}
header.main-header .sub-menu > * + * {
  margin-top: 1em;
}
header.main-header .sub-menu a {
  font-family: var(--font-text);
  font-size: var(--ft-size-0);
  font-weight: 400;
}
header.main-header .menu-item-has-children > a::after {
  content: "\f077";
  margin-left: 0.5rem;
  font-family: var(--font-awesome);
  font-size: 1em;
}
header.main-header .menu-item-has-children:last-child > .sub-menu,
header.main-header .menu-item-has-children.--no-overflow > .sub-menu {
  right: 0;
}
header.main-header .menu-item-has-children.selected > a::after {
  content: "\f078";
}
header.main-header .menu-item-has-children.selected .sub-menu {
  display: block;
}
header.main-header.headroom--not-top {
  transform: translateY(-100%);
}
header.main-header.headroom--not-top .logo__secondary {
  display: none;
}
header.main-header.headroom--pinned {
  transform: translateY(0%);
}
@media (min-width: 96.875em) {
  header.main-header nav {
    display: flex;
  }
  header.main-header button {
    display: none;
  }
}
nav.mobile-menu {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-block: calc(var(--page-padding) * 1.5 + var(--ft-size-2)) var(--page-padding);
  padding-inline: calc(var(--page-padding) / 2);
  max-height: 100dvh;
  font-size: var(--ft-size-2);
  color: var(--color-text);
  background-color: var(--color-background);
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 99;
  clip-path: inset(0 0 100% 0);
  overflow-x: auto;
  transition: clip-path 0.6s ease;
}
nav.mobile-menu a {
  color: inherit;
  text-decoration: none;
}
nav.mobile-menu .main-navigation {
  display: flex;
  flex-direction: column;
  gap: 1em;
  margin: 0;
  padding: 0;
  list-style: none;
  font-family: Montserrat, sans-serif;
  font-weight: 700;
}
nav.mobile-menu .secondary-navigation {
  display: flex;
  flex-direction: column;
  gap: 0.2em;
  position: relative;
}
nav.mobile-menu .secondary-navigation::before {
  content: "";
  display: block;
  height: 1px;
  width: 100%;
  margin-block: 1em 0.7em;
  background-color: var(--color-primary);
  margin-inline: auto;
}
nav.mobile-menu button {
  display: block;
  position: absolute;
  top: 2.1875rem;
  right: calc(var(--page-padding) / 3.5);
}
@media (min-width: 33.75em) {
  nav.mobile-menu button {
    top: 3rem;
  }
}
nav.mobile-menu.selected {
  clip-path: inset(0 0 0 0);
}
.footer {
  --max-width: 94.75rem;
  padding-block: 2rem 0;
}
.footer .wrapper {
  padding-block: unset;
}
.footer__contents {
  display: grid;
  grid-template-columns: 1fr;
  column-gap: 5rem;
  row-gap: 2rem;
  align-items: start;
}
@media (min-width: 51.25em) {
  .footer__contents {
    grid-template-columns: 280px 1fr;
    grid-template-rows: auto auto;
  }
}
@media (min-width: 82.25em) {
  .footer__contents {
    grid-template-columns: 280px 2fr 1fr;
  }
}
.footer__logo img {
  max-width: 17.5rem;
}
.footer__links {
  display: flex;
  flex-wrap: wrap;
  column-gap: clamp(1rem, -2.169rem + 13.5211vw, 10rem);
  row-gap: 2em;
  font-family: Montserrat, sans-serif;
  font-size: var(--ft-size--1);
}
.footer__links a {
  display: block;
  margin-bottom: 1em;
  color: inherit;
  font-weight: 700;
  text-transform: uppercase;
  text-decoration: none;
  text-wrap: balance;
}
.footer__links a:hover {
  color: #b4a269;
  /*var(--color-accent);*/
}
@media (min-width: 51.25em) {
  .footer__links {
    grid-row: 2 / 3;
  }
}
@media (min-width: 82.25em) {
  .footer__links {
    grid-row: unset;
  }
}
.footer__contacts {
  display: grid;
  align-items: start;
  gap: 2rem;
}
@media (min-width: 51.25em) {
  .footer__contacts {
    grid-row: 1 / 3;
  }
}
@media (min-width: 82.25em) {
  .footer__contacts {
    grid-row: unset;
  }
}
.footer__copyright {
  margin-top: 3.125rem;
  padding-block: 1rem;
  font-size: var(--ft-size--1);
  text-align: center;
}
.footer__copyright p {
  max-width: unset;
}
.contact-info__title {
  font-weight: 700;
  text-transform: uppercase;
}
.contact-info__contents a {
  color: inherit;
  text-decoration: none;
}
.contact-info__contents p {
  margin-block: 0.2em;
}
.contact-info__socials {
  display: flex;
  column-gap: 0.5em;
  font-family: var(--font-awesome);
  font-size: var(--ft-size-2);
}
.contact-info__socials a {
  color: inherit;
  text-decoration: none;
}
.gform-theme--foundation.gform_wrapper.gform-theme {
  --gf-form-gap-y: 1rem;
  --gf-radius: 0 !important;
  --gf-ctrl-border-width: 0.1875rem;
  --gf-ctrl-border-color: var(--color-text) !important;
  --gf-ctrl-bg-color: transparent;
  --gf-color-primary: transparent !important;
  --gf-color-primary-contrast: var(--color-text) !important;
  --gf-ctrl-btn-border-width-primary: 0.1875rem !important;
  --gf-ctrl-btn-border-color-primary: var(--color-text);
  --gf-ctrl-btn-font-weight: 700;
  --gf-ctrl-btn-font-size-md: var(--ft-size--1);
  --gf-ctrl-btn-bg-color-hover-primary: var(--color-text);
  --gf-ctrl-btn-color-hover-primary: var(--color-secondary);
  --gf-font-size-tertiary: var(--ft-size-0) !important;
  --gf-font-size-secondary: var(--ft-size-0) !important;
  --gf-font-size-tertiary: var(--ft-size--1) !important;
}
.gform-theme--foundation.gform_wrapper.gform-theme .gform_footer {
  justify-content: flex-end;
}
.hero {
  --_tb-fw: 700;
  --_tb-title-fs: var(--ft-size-3);
  --max-width: 94.75rem;
  --_badge-margin: 0.5em;
  display: grid;
  position: relative;
  isolation: isolate;
  place-items: end stretch;
}
.hero > * {
  grid-row: 1 / 2;
  grid-column: 1 / 2;
}
.hero__content {
  padding-block: 5.9375rem;
  padding-right: calc(var(--page-padding) / 2);
  color: white;
  background-color: hsl(0 0% 0% / 0.6);
  z-index: 1;
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: end;
}
.hero__background {
  width: 100%;
  min-height: 34rem;
}
.hero__background img {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  object-fit: cover;
}
.hero__subtitle {
  font-size: var(--ft-size-4);
  text-transform: uppercase;
  font-family: "Montserrat", sans-serif;
}
.hero.--top {
  place-items: start stretch;
  text-align: center;
}
.hero.--middle {
  place-items: center stretch;
}
.hero .ctas {
  display: grid;
  justify-content: space-between;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  flex-wrap: wrap;
  column-gap: 20px;
  row-gap: 10px;
  padding-top: 20px;
}
.hero .ctas .btn {
  width: 100%;
  border: 5px solid var(--color-primary);
  font-size: var(--ft-size-2);
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 0;
}
.hero .ctas .btn span {
  max-width: 300px;
}
@media (pointer: fine) {
  .hero .ctas .btn:hover {
    background: var(--color-primary);
  }
}
.hero .ctas .btn::after {
  display: none;
}
.hero .text-block {
  max-width: 40rem;
  margin-left: auto;
}
.hero.hero-form {
  display: block;
  color: white;
}
.hero.hero-form::before {
  content: "";
  position: absolute;
  top: 0px;
  left: 0px;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.6);
  pointer-events: none;
  z-index: -1;
}
.hero.hero-form > * {
  grid-row: unset;
  grid-column: unset;
}
.hero.hero-form img {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  object-fit: cover;
  z-index: -2;
}
.hero.hero-form h1 {
  color: var(--color-primary);
  font-size: var(--ft-size-1);
  text-transform: unset;
  margin-bottom: 10px;
}
.hero.hero-form h2 {
  margin-bottom: 20px;
}
.hero.hero-form p {
  font-size: var(--ft-size-1);
}
.hero.hero-form .wrapper {
  height: 100%;
  display: flex;
  max-width: 1300px;
}
.hero.hero-form .grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: 50px;
  height: 100%;
  width: 100%;
  min-height: 100svh;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  .hero.hero-form .grid {
    grid-template-columns: 1fr;
  }
}
.hero.hero-form .grid .col-left {
  display: flex;
  flex-direction: column;
  justify-content: center;
  max-width: 550px;
  padding-block: 40px;
}
@media screen and (max-width: 768px) {
  .hero.hero-form .grid .col-left {
    max-width: 600px;
    margin: auto;
  }
}
.hero.hero-form .grid .col-right {
  padding: 20px 40px;
  background-color: var(--color-primary);
  display: flex;
  flex-direction: column;
  justify-content: center;
  max-width: 600px;
  margin-inline: auto;
  width: 100%;
}
@media screen and (min-width: 769px) {
  .hero.hero-form .grid .col-right {
    margin-left: auto;
    margin-right: 0;
  }
}
.hero.hero-form .grid .col-right h2 {
  font-size: var(--ft-size-2);
  max-width: 400px;
  margin-bottom: 1em;
}
.hero.hero-form .grid .col-right #gform_wrapper_3[data-form-index="0"].gform-theme,
.hero.hero-form .grid .col-right [data-parent-form="3_0"] {
  --gf-ctrl-bg-color: white;
  --gf-ctrl-font-size: var(--ft-size-0);
  --gf-ctrl-padding-y: 25px;
  --gf-ctrl-padding-x: 15px;
  --gf-ctrl-border-width: 0;
  --gf-ctrl-outline-style: none;
  --gf-ctrl-btn-bg-color-primary: white;
  --gf-ctrl-btn-font-size: var(--ft-size-0);
  --gf-ctrl-btn-padding-y: 10px;
  --gf-ctrl-btn-font-weight: 500;
  --gf-form-validation-color: #7c2f2f;
  --gf-form-validation-bg-color: #4d2727;
}
.hero.hero-form .grid .col-right #gform_wrapper_3[data-form-index="0"].gform-theme .validation_message,
.hero.hero-form .grid .col-right [data-parent-form="3_0"] .validation_message {
  color: var(--gf-form-validation-color);
}
.hero.hero-form .grid .col-right #gform_wrapper_3[data-form-index="0"].gform-theme .gform_validation_errors,
.hero.hero-form .grid .col-right [data-parent-form="3_0"] .gform_validation_errors {
  --gf-form-validation-border-width: 0;
  --gf-form-validation-border-style: none;
  --gf-form-validation-border-color: #4d2727;
  --gf-form-validation-radius: 0;
  --gf-form-validation-shadow: none;
  --gf-form-validation-gap: 0;
  --gf-form-validation-margin-y: 0;
  --gf-form-validation-padding-y: 10px;
  --gf-form-validation-padding-x: 20px;
  margin-bottom: 20px;
}
.hero.hero-form .grid .col-right #gform_wrapper_3[data-form-index="0"].gform-theme .gform_validation_errors h2,
.hero.hero-form .grid .col-right [data-parent-form="3_0"] .gform_validation_errors h2 {
  font-size: var(--ft-size-0);
  margin-bottom: 0;
  color: white;
}
.hero.hero-form .grid .col-right #gform_wrapper_3[data-form-index="0"].gform-theme .gform_validation_errors .gform-icon,
.hero.hero-form .grid .col-right [data-parent-form="3_0"] .gform_validation_errors .gform-icon {
  display: none;
}
.hero.hero-form .grid .col-right #gform_wrapper_3[data-form-index="0"].gform-theme .gform_validation_errors::before,
.hero.hero-form .grid .col-right [data-parent-form="3_0"] .gform_validation_errors::before {
  display: none;
}
.hero.hero-form .grid .col-right #gform_wrapper_3[data-form-index="0"].gform-theme .gform_button::after,
.hero.hero-form .grid .col-right [data-parent-form="3_0"] .gform_button::after {
  content: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="12.971" height="22.702" viewBox="0 0 12.971 22.702"><path id="chevron-up-solid" d="M10.206.475a1.623,1.623,0,0,1,2.295,0L22.227,10.2A1.623,1.623,0,1,1,19.932,12.5L11.351,3.915,2.77,12.491A1.623,1.623,0,0,1,.475,10.2L10.2.47Z" transform="translate(12.971) rotate(90)"/></svg>');
  transform: scale(0.6);
}
.hero.hero-form .grid .col-right #gform_wrapper_3[data-form-index="0"].gform-theme .gform_button:hover::after,
.hero.hero-form .grid .col-right [data-parent-form="3_0"] .gform_button:hover::after {
  content: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="12.971" height="22.702" viewBox="0 0 12.971 22.702"><path id="chevron-up-solid" d="M10.206.475a1.623,1.623,0,0,1,2.295,0L22.227,10.2A1.623,1.623,0,1,1,19.932,12.5L11.351,3.915,2.77,12.491A1.623,1.623,0,0,1,.475,10.2L10.2.47Z" transform="translate(12.971) rotate(90)" fill="%23fff"/></svg>');
}
.hero-landing-page {
  display: grid;
  place-items: center;
  overflow: hidden;
  isolation: isolate;
}
.hero-landing-page > * {
  grid-row: 1 / 2;
  grid-column: 1 / 2;
}
.hero-landing-page__media {
  width: 100%;
  height: 100%;
  overflow: hidden;
  position: relative;
}
.hero-landing-page__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  position: absolute;
  inset: 0;
}
.hero-landing-page__media iframe {
  width: var(--_video-width, 100%);
  height: var(--_video-height, 100%);
  position: absolute;
  inset: 0;
}
.hero-landing-page__content {
  display: grid;
  gap: 4.5rem clamp(2rem, 0.2857rem + 8.5714vw, 8rem);
  padding-block: 15.625rem 7rem;
  z-index: 1;
}
.hero-landing-page__content .google {
  display: flex;
  column-gap: 1.25rem;
  justify-content: start;
  align-items: flex-end;
  font-weight: 700;
  color: var(--color-light);
}
.hero-landing-page__content .google .logo {
  width: 3.5rem;
}
@media (min-width: 56.25em) {
  .hero-landing-page__content {
    grid-template-columns: 2fr 3fr;
  }
}
@media (min-width: 76.5em) {
  .hero-landing-page__content {
    grid-template-columns: 3fr 2fr;
  }
}
.hero-landing-page__titles {
  color: var(--color-light);
}
.hero-landing-page__title {
  text-transform: none;
}
.hero-landing-page__suptitle {
  margin-bottom: 0.5rem;
  font-family: var(--font-text);
  color: #efecd7;
}
.hero-landing-page__form {
  padding: 1.125rem 1.875rem 1.875rem 1.875rem;
  border-radius: 1.75rem;
  background-color: hsl(0 0% 100% / 0.9);
}
.hero-landing-page__form h2 {
  margin-bottom: 1.25rem;
}
.hero-landing-page__form h2 span {
  font-family: var(--font-text);
  font-weight: bold;
}
.hero-landing-page__form .gform_wrapper form .gfield input,
.hero-landing-page__form .gform_wrapper form .gfield textarea {
  --gf-local-border-block-start: 0px #000 solid;
  --gf-local-border-inline-start: 0px #000 solid;
  --gf-local-border-inline-end: 0px #000 solid;
  --gf-local-border-block-end: #000 solid 1px;
  --gf-local-bg-color: var(--color-background);
}
.hero-landing-page__form .gform_wrapper form .gform-footer button.gform_button.quote-submit {
  --gf-local-padding-y: 0.64em;
  --gf-local-padding-x: 3.36em;
  --gf-local-radius: 50rem;
  --gf-local-bg-color: #17263f;
  --gf-local-color: #ffffff;
  --gf-local-font-size: var(--font-size-1);
  --gf-local-transition: 0.3s ease;
  --gf-ctrl-btn-bg-color-hover-primary: #ffffff;
  --gf-ctrl-btn-color-hover-primary: #17263f;
  margin-inline: auto;
}
.home .hero {
  --_tb-fw: 700;
  --_tb-title-fs: var(--ft-size-3);
  --max-width: 94.75rem;
  --_badge-margin: 0.5em;
  display: grid;
  grid-template-columns: [full-width-start] auto [content-start] min(var(--max-width), 100%) [content-end] auto [full-width-end];
  place-items: center end;
  position: relative;
  isolation: isolate;
  overflow: clip;
}
.home .hero > * {
  grid-row: 1 / 2;
}
.home .hero__content {
  grid-column: content;
  padding-inline: calc(var(--page-padding) / 2);
  background-color: transparent;
  color: white;
  z-index: 1;
}
.home .hero__background {
  grid-column: full-width;
  width: 100%;
  min-height: clamp(28.125rem, 20.0893rem + 40.1786vw, 56.25rem);
}
.home .hero__background::before {
  content: "";
  display: block;
  position: absolute;
  inset: 0;
  background-image: linear-gradient(90deg, rgba(0, 0, 0, 0), #000000 50%);
}
.home .hero__background video {
  position: absolute;
  left: -23%;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: -1;
}
.home .hero__footer {
  --_roof-size: clamp(15.625rem, -1.6071rem + 86.1607vw, 75.9375rem);
  display: flex;
  align-items: flex-end;
  grid-column: full-width;
  align-self: end;
  width: 100%;
  z-index: 1;
}
.home .hero__footer::before {
  content: "";
  display: block;
  width: calc(100% - var(--_roof-size));
  height: var(--lines-thickness);
  background-color: var(--color-primary);
}
.home .hero__footer svg {
  max-width: var(--_roof-size);
}
@media (min-width: 120em) {
  .home .hero__footer::after {
    content: "";
    display: block;
    width: calc(100% - var(--_roof-size));
    height: var(--lines-thickness);
    background-color: var(--color-primary);
    flex-basis: clamp(0rem, -62.25rem + 51.875vw, 20.75rem);
  }
}
.deux-colonnes {
  padding-block-start: var(--pad-block-large);
}
.deux-colonnes:not(:has(.wrapper)),
.deux-colonnes .wrapper {
  display: grid;
  grid-template-columns: var(--_columns, 1fr);
  column-gap: var(--margin-inline);
  row-gap: var(--gap);
  justify-items: center;
}
.deux-colonnes:not(:has(.wrapper)).--reverse :first-child,
.deux-colonnes .wrapper.--reverse :first-child {
  grid-row: 2 / 3;
}
.deux-colonnes:not(:has(.wrapper)).--reverse :last-child,
.deux-colonnes .wrapper.--reverse :last-child {
  grid-row: 1 / 2;
}
@media (min-width: 56.25em) {
  .deux-colonnes {
    --_columns: repeat(2, 1fr);
  }
  .deux-colonnes.--larger-gap {
    --margin-inline: clamp(1.25rem, -3.8116rem + 21.5962vw, 15.625rem);
    --_columns: 1fr max-content;
  }
  .deux-colonnes:not(:has(.wrapper)).--reverse :first-child,
  .deux-colonnes .wrapper.--reverse :first-child,
  .deux-colonnes:not(:has(.wrapper)).--reverse :last-child,
  .deux-colonnes .wrapper.--reverse :last-child {
    grid-row: unset;
  }
}
.side-scroller {
  position: relative;
  --swiper-wrapper-transition-timing-function: linear;
  --_star-color: var(--color-accent);
  --_card-padding: 1.875rem;
}
.side-scroller .stars {
  position: absolute;
  top: var(--_card-padding);
  right: var(--_card-padding);
}
.side-scroller.--landing {
  --_card-padding: 2.5rem;
}
.side-scroller.--landing .card {
  border-radius: 2rem;
  color: #fff;
  background-color: #172640;
}
.timeline {
  display: grid;
  grid-template-columns: 1fr 22px 1fr;
  grid-template-areas: "content line .";
  width: fit-content;
  margin-inline: auto;
  column-gap: clamp(0.5rem, -1.8548rem + 10.0469vw, 7.1875rem);
}
.timeline img {
  vertical-align: bottom;
  object-fit: cover;
  aspect-ratio: 16 / 9;
}
.timeline__content {
  grid-area: content;
  font-size: var(--ft-size--1);
  position: relative;
}
.timeline__text {
  padding: 0.6em;
  color: #fff;
  background-color: hsl(0 0% 0% / 0.6);
}
@media (min-width: 56.25em) {
  .timeline__text {
    width: fit-content;
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
  }
}
.timeline__heading {
  font-size: var(--ft-size-0);
  font-weight: 700;
}
.timeline__line {
  grid-area: line;
  position: relative;
}
.timeline__line::before {
  content: "";
  display: block;
  width: 3px;
  margin-inline: auto;
  background-color: var(--color-primary);
  position: absolute;
  inset: 0;
}
.timeline__line.--dot::after {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  margin-inline: auto;
  border: 3px solid var(--color-background);
  border-radius: 50%;
  background-color: var(--color-primary);
  transform: translateY(-50%) translateX(-0.5px);
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
}
.timeline:nth-child(2n) {
  grid-template-areas: ". line content";
}
.accordion-slides {
  --_transition-duration: 0.3s;
  padding-block: 6.5rem;
  background-color: #ffffff;
}
.accordion-slides__title {
  max-width: 30ch;
  font-size: var(--ft-size-4);
}
.accordion-slides__content {
  grid-template-columns: 1fr 50%;
}
@media (min-width: 55.75em) {
  .accordion-slides__content {
    display: grid;
  }
}
.accordion-slides__title {
  margin-bottom: 2rem;
}
.accordion-slides__wrapper {
  max-width: 38.75rem;
}
.accordion-slides__accordion-item {
  display: grid;
  grid-template-rows: min-content 0fr;
  justify-items: start;
  row-gap: var(--_gap, 0);
  border-top: #707070 solid 1px;
  overflow: hidden;
  transition: grid-template-rows var(--_transition-duration) ease;
}
.accordion-slides__accordion-item[aria-expanded="true"] {
  grid-template-rows: min-content 1fr;
}
.accordion-slides__accordion-item[aria-expanded="true"] .accordion-slides__accordion-header::after {
  transform: rotateZ(90deg);
}
.accordion-slides__accordion-header {
  width: 100%;
  padding-block: 2rem;
  font-family: var(--font-heading);
  font-size: var(--ft-size-2);
  font-weight: 500;
  text-align: start;
  cursor: pointer;
}
.accordion-slides__accordion-header::after {
  content: "\f061";
  display: block;
  padding-inline: 3rem;
  float: right;
  font-family: var(--font-awesome);
  font-weight: 300;
  transition: transform var(--_transition-duration) ease;
}
.accordion-slides__accordion-panel {
  margin-bottom: var(--_panel-margin, 0);
  overflow-y: hidden;
  transition: margin-bottom var(--_transition-duration) ease;
}
.accordion-slides__slide {
  position: relative;
}
.accordion-slides__images {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  width: 80%;
  max-width: 35rem;
  aspect-ratio: 7 / 6;
  margin-inline: auto;
  margin-block: clamp(2rem, 1.5152rem + 2.4242vw, 4rem);
  border-radius: 2rem;
  overflow: clip;
}
.accordion-slides__images img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.accordion-slides__text-left,
.accordion-slides__text-right {
  padding: 1.5rem;
  border-radius: 2rem;
  font-family: var(--font-heading);
  text-align: center;
  color: var(--color-light);
}
@media (min-width: 48.75em) {
  .accordion-slides__text-left,
  .accordion-slides__text-right {
    position: absolute;
  }
}
.accordion-slides__text-left {
  font-weight: 500;
  background-color: #42c2f5;
  left: 0;
  bottom: clamp(6rem, 5.5152rem + 2.4242vw, 8rem);
}
.accordion-slides__text-left span {
  display: block;
  font-size: var(--ft-size-3);
  font-weight: 700;
}
.accordion-slides__text-right {
  font-size: var(--ft-size-2);
  font-weight: 700;
  background-color: #17263f;
  right: 0;
  top: 0;
}
@media (min-width: 48.75em) {
  .accordion-slides__text-right {
    max-width: 12ch;
  }
}
@media (max-width: 48.6875em) {
  .accordion-slides .swiper-pagination {
    position: unset;
  }
}
.mosaic-grid {
  --flow-spacer: 1.25rem;
  padding-block: 6.5rem;
}
.mosaic-grid__container {
  grid-template-columns: 3fr 2fr;
  justify-content: space-between;
  align-items: start;
}
@media (min-width: 62em) {
  .mosaic-grid__container {
    display: grid;
  }
}
.mosaic-grid__images {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: 1fr 1fr 1fr;
  gap: 0.75rem;
  margin-top: 2em;
}
.mosaic-grid__images > * {
  border-radius: 2.8125em;
}
@media (min-width: 62em) {
  .mosaic-grid__images {
    margin-top: 0;
  }
}
.mosaic-grid__image {
  overflow: hidden;
}
.mosaic-grid__image img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}
.mosaic-grid__image.--left {
  grid-row: 1 / 3;
}
.mosaic-grid__image.--right {
  grid-row: 2 / 4;
}
.mosaic-grid__darkblue {
  background-color: #17263f;
}
.mosaic-grid__blue {
  background-color: var(--color-accent);
}
.confiance {
  padding-block: 14.25rem 6.5rem;
  background-color: #fff;
}
.confiance__head {
  display: grid;
  justify-items: center;
  padding-inline: clamp(2rem, 0.5455rem + 7.2727vw, 8rem);
  border-radius: 2.625rem;
  color: #fff;
  background-color: #17263f;
}
.confiance__head h2 {
  font-size: var(--ft-size-4);
  text-wrap: unset;
}
@media (min-width: 88.625em) {
  .confiance__head {
    grid-template-columns: 2fr 1fr;
  }
}
.confiance__title {
  padding-block: 4rem;
}
.confiance__container {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  row-gap: 2.5rem;
  column-gap: 4rem;
  margin-block: 4.5rem;
  font-size: var(--ft-size-2);
  font-weight: 700;
  line-height: 1.1;
}
@media (min-width: 88.625em) {
  .confiance__container {
    justify-content: stretch;
  }
}
.confiance__shield {
  display: flex;
  align-items: center;
  gap: 1.125rem;
  width: min-content;
}
.confiance__shield::before {
  content: url("../images/shield-check-sharp-regular.svg");
  display: block;
  width: 4rem;
  height: 4rem;
}
@media (min-width: 46.375em) {
  .confiance__shield {
    padding-right: 4rem;
    border-right: solid 0.1rem #ffffff;
  }
}
.confiance__years {
  display: flex;
  align-items: center;
  width: min-content;
  gap: 1.125rem;
}
.confiance__years span {
  font-size: clamp(1.802rem, 1.227rem + 2.8752vw, 3.8147rem);
}
.confiance__image {
  display: none;
  align-self: end;
  margin-top: -10rem;
}
@media (min-width: 88.625em) {
  .confiance__image {
    display: block;
  }
}
.confiance__review-title {
  margin-block: 6.25rem;
  font-size: var(--ft-size-4);
}
.stack-catalogues .grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 30px;
  align-items: start;
}
@media (min-width: 768px) {
  .stack-catalogues .grid {
    grid-template-columns: 440px 1fr;
    gap: 40px;
  }
}
@media (min-width: 1024px) {
  .stack-catalogues .grid {
    gap: 60px;
  }
}
.stack-catalogues .col-left h2 {
  font-size: var(--ft-size-1);
}
.stack-catalogues .col-right {
  display: grid;
  gap: 15px;
  grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
  align-items: start;
}
.stack-catalogues .btn {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding: 20px 40px;
  margin-bottom: 0;
  text-transform: uppercase;
  font-size: 1.25rem;
  font-weight: 600;
  background-color: var(--color-background);
}
@media screen and (max-width: 991px) {
  .stack-catalogues .btn {
    font-size: 1rem;
  }
}
.stack-catalogues .btn::after {
  position: absolute;
  top: 50%;
  right: 20px;
}
.card {
  /* Cette variable sert également à positionner
	les étoiles au coin dans le bonne marge 
	(Voir side-scroller.less) */
  --flow-spacer: 0.5em;
  padding: var(--_card-padding, 0);
  position: relative;
  width: 100%;
  max-width: 50rem;
}
.card__title {
  margin-bottom: 0;
  font-family: var(--font-text);
  font-size: var(--ft-size-1);
  line-height: 0.8;
}
.card__subtitle {
  margin-top: 0;
}
.card img {
  width: 100%;
  max-height: 450px;
  object-fit: cover;
}
.card .stars {
  margin-top: 0;
}
.card.swiper-slide {
  height: auto;
}
.document-link {
  display: block;
  padding-top: 1.5625rem;
  padding-bottom: 1.5rem;
  padding-right: 2.5em;
  border-bottom: solid var(--color-primary) 0.375rem;
  text-decoration: none;
  color: inherit;
  transition: padding 600ms ease, color 200ms ease;
  position: relative;
}
.document-link::after {
  content: "\f1c1";
  display: flex;
  justify-content: flex-end;
  align-items: center;
  font-family: var(--font-awesome);
  font-size: 2em;
  position: absolute;
  inset: 0;
  transition: right 600ms ease;
}
.document-link:hover {
  background-color: var(--color-primary);
  color: var(--color-secondary);
  padding-inline: 1em 2.5em;
}
.document-link:hover::after {
  right: 1em;
}
.document-link.--link::after {
  content: "\f054";
  right: 0.3em;
}
.document-link.--link:hover::after {
  right: 1.3em;
}
.document-link__heading {
  font-size: var(--ft-size-1);
}
.document-link__filename {
  font-size: var(--ft-size--1);
  font-style: italic;
}
[class*=icon-] {
  display: flex;
  font-size: 1.15em;
}
[class*=icon-]::before {
  margin-right: 1em;
  padding-top: 0.2em;
}
[class*=icon-]:not(:first-of-type) {
  margin-top: 1em;
}
[class*=icon-] a {
  color: inherit;
  text-decoration: none;
}
.icon-phone::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1.5em' height='1.5em' viewBox='0 0 512 512'%3E%3Cpath fill='%23000' d='M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64c0 247.4 200.6 448 448 448c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368c-70.4-33.3-127.4-90.3-160.7-160.7l49.3-40.3c13.7-11.2 18.4-30 11.6-46.3l-40-96z'/%3E%3C/svg%3E");
}
.icon-mail::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1.5em' height='1.5em' viewBox='0 0 512 512'%3E%3Cpath fill='%23000' d='M48 64C21.5 64 0 85.5 0 112c0 15.1 7.1 29.3 19.2 38.4l217.6 163.2c11.4 8.5 27 8.5 38.4 0l217.6-163.2c12.1-9.1 19.2-23.3 19.2-38.4c0-26.5-21.5-48-48-48zM0 176v208c0 35.3 28.7 64 64 64h384c35.3 0 64-28.7 64-64V176L294.4 339.2a63.9 63.9 0 0 1-76.8 0z'/%3E%3C/svg%3E");
}
.icon-home::before {
  content: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='1.69em' height='1.5em' viewBox='0 0 576 512'%3E%3Cpath fill='%23000' d='M543.8 287.6c17 0 32-14 32-32.1c1-9-3-17-11-24L512 185V64c0-17.7-14.3-32-32-32h-32c-17.7 0-32 14.3-32 32v36.7L309.5 7c-6-5-14-7-21-7s-15 1-22 8L10 231.5c-7 7-10 15-10 24c0 18 14 32.1 32 32.1h32v69.7c-.1.9-.1 1.8-.1 2.8v112c0 22.1 17.9 40 40 40h16c1.2 0 2.4-.1 3.6-.2c1.5.1 3 .2 4.5.2h55.9c22.1 0 40-17.9 40-40v-88c0-17.7 14.3-32 32-32h64c17.7 0 32 14.3 32 32v88c0 22.1 17.9 40 40 40h56.5c1.4 0 2.8 0 4.2-.1c1.1.1 2.2.1 3.3.1h16c22.1 0 40-17.9 40-40v-16.2c.3-2.6.5-5.3.5-8.1l-.7-160.2h32z'/%3E%3C/svg%3E");
}
.link-list {
  --_underline-thickness: 0.375rem;
}
.link-list ul {
  margin: 0;
  padding: 0;
  list-style: none;
  font-family: var(--font-heading);
}
.link-list__link {
  display: list-item;
  font-size: var(--ft-size-2);
  font-weight: 600;
  position: relative;
  transition: padding-inline 0.5s ease;
}
.link-list__link:not(:has(.link-list__body))::before {
  content: "";
  display: block;
  height: var(--_underline-thickness);
  width: 100%;
  background-color: var(--_underline-color, var(--color-primary));
  position: absolute;
  bottom: 0;
  left: unset;
  z-index: -1;
  transition: height 0.5s ease;
}
.link-list__link:hover::before {
  height: 100%;
}
.link-list__link a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  text-decoration: none;
  color: inherit;
  padding-block: 1.5rem;
  transition: color 0.5s ease, padding-inline 0.5s ease;
}
.link-list__link a::after {
  content: "\f054";
  font-family: 'Font Awesome 5 Pro';
}
.link-list__link:hover a {
  padding-inline: 0.4em;
}
.link-list__link.--featured {
  --_underline-color: var(--color-accent);
  margin-top: 5rem;
}
.link-list__link.--featured::before {
  content: unset;
}
.link-list__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
  padding-block: 1.5rem;
}
.link-list__header::after {
  content: "";
  display: block;
  width: 100%;
  height: var(--_underline-thickness);
  background-color: var(--_underline-color, var(--color-primary));
  position: absolute;
  bottom: 0;
}
.link-list__body {
  position: relative;
}
.link-list__body a {
  padding-block-end: 2rem;
}
.link-list__body a h2 {
  margin-bottom: 0.5em;
}
.link-list__body a p {
  font-size: var(--ft-size-0);
  font-weight: 400;
  margin-top: 0.5em;
}
.link-list__body a p:last-child {
  margin-bottom: 0;
}
.link-list__body::before {
  content: "";
  display: block;
  height: var(--_underline-thickness);
  width: 100%;
  background-color: var(--_underline-color, var(--color-primary));
  position: absolute;
  bottom: 0;
  z-index: -1;
  transition: height 0.5s ease;
}
.link-list__body:hover {
  color: var(--color-secondary);
}
.link-list__body:hover::before {
  height: 100%;
}
.list-icon {
  --flow-spacer: 2.5em;
  padding-left: 0;
}
.list-icon__item {
  gap: 2.25rem;
}
.list-icon__item::before {
  content: unset;
}
.list-icon__item + .list-icon__item {
  margin-top: 3.25rem;
}
.list-icon__icon {
  display: grid;
  place-items: center;
  width: 5.25rem;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  background-color: #15233c;
}
.list-icon__title {
  font-size: var(--ft-size-1);
}
@keyframes reveal-in {
  0%,
  50% {
    clip-path: inset(0 0 0 0%);
  }
  100% {
    clip-path: inset(0 100% 0 0);
  }
}
.page-loader {
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #0b213e;
  clip-path: inset(0 100% 0 0%);
  position: fixed;
  inset: 0;
  z-index: 200;
}
.page-loader img {
  width: 300px;
}
@supports selector(::view-transition) {
  .page-loader {
    animation: 1.5s ease-in-out both reveal-in;
  }
}
.stars__group {
  fill: var(--_star-color, var(--color-primary));
}
.text-list {
  --_size: 2.5rem;
  width: fit-content;
}
.text-list > * + * {
  margin-top: 1em;
}
.text-list__title {
  font-size: var(--ft-size-2);
  text-transform: uppercase;
  /*margin-left: calc(var(--_size) + 0.6em);*/
}
.text-list__list li .heading {
  font-weight: 700;
}
.text-list__list li .content {
  text-wrap: pretty;
}
.text-list__ctas {
  text-align: end;
}
@media (min-width: 56.25em) {
  .text-list {
    width: unset;
  }
}
.post-type-archive-product {
  font-family: var(--font-heading);
}
.post-type-archive-product main .wrapper {
  max-width: 1300px;
}
.post-type-archive-product .hero__content {
  height: 100%;
  justify-content: start;
  background-color: hsl(0 0% 0% / 0.3);
}
.post-type-archive-product .hero__content h1 {
  max-width: 500px;
}
.post-type-archive-product .products {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 50px;
}
@media screen and (max-width: 991px) {
  .post-type-archive-product .products {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }
}
@media screen and (max-width: 400px) {
  .post-type-archive-product .products {
    grid-template-columns: 1fr;
  }
}
.post-type-archive-product .products::before,
.post-type-archive-product .products::after {
  display: none !important;
}
.post-type-archive-product .products li {
  width: 100% !important;
}
.post-type-archive-product .products li::before {
  display: none;
}
.woocommerce div.products a.product {
  width: 100%;
  height: auto;
  cursor: pointer;
  position: relative;
  text-decoration: none;
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 2;
  gap: 0;
  overflow: clip;
}
.woocommerce div.products a.product[href="javascript:void(0)"] {
  cursor: default;
}
@media (pointer: fine) {
  .woocommerce div.products a.product:not([href="javascript:void(0)"]):hover .product__image {
    transform: scale(1.03);
  }
}
.woocommerce div.products a.product .product__image {
  transition: 400ms;
  position: relative;
  aspect-ratio: 3/4;
  width: 100%;
  height: auto;
}
.woocommerce div.products a.product img:not(.product__category) {
  object-fit: cover;
  width: 100%;
  height: 100%;
  margin-bottom: 0;
}
.woocommerce div.products a.product img.product__category {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  opacity: 0.8;
  width: 80%;
  max-height: 100px;
  object-fit: contain;
  height: auto;
}
.woocommerce div.products a.product .woocommerce-loop-product__title {
  background: black;
  color: white;
  padding: 10px;
  font-size: var(--ft-size-0);
  z-index: 10;
}
.product-video-wrapper {
  position: relative;
  width: 100%;
  /* your desired width */
  aspect-ratio: 3 / 4;
  /* or use padding-bottom: 133.33% trick */
  overflow: hidden;
  margin-bottom: 0 !important;
}
.product-video-wrapper iframe {
  position: absolute;
  top: -12%;
  /* Shift up to crop the top */
  left: 50%;
  transform: translateX(-50%);
  /* Make iframe taller and wider to fill container and crop title */
  width: 195.56%;
  /* Adjusted for extra height */
  height: 112%;
  /* 10% extra to crop the title bar */
  pointer-events: none;
}
.toolbox__title {
  font-size: 1.5rem;
  text-transform: uppercase;
  color: hsl(0 0% 0% / 0.6);
}
.toolbox__content {
  display: grid;
  grid-template-columns: 1fr;
  row-gap: 25px;
  column-gap: 2rem;
  align-items: center;
}
@media (min-width: 640px) {
  .toolbox__content {
    grid-template-columns: 1fr 1fr;
  }
  .toolbox__content.--tight {
    grid-template-columns: max-content 1fr;
    padding-inline: 5rem;
  }
}
.toolbox__specs {
  color: hsl(0 0% 0% / 0.6);
}
.toolbox__columns {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: fit-content;
  justify-content: start;
  align-items: start;
}
.toolbox__columns > * {
  padding: 1em;
}
