/*!****************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./assets/css/style.scss ***!
  \****************************************************************************************************************/
@import url(https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&family=Space+Mono:ital,wght@0,400;0,700;1,400;1,700&display=swap);
/*!********************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./assets/css/style.scss (1) ***!
  \********************************************************************************************************************/
@charset "UTF-8";
/**
 * Swiper 9.4.1
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * https://swiperjs.com
 *
 * Copyright 2014-2023 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: June 13, 2023
 */
@font-face {
  font-family: 'swiper-icons';
  src: url("data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA") format("woff");
  font-weight: 400;
  font-style: normal; }

:root {
  --swiper-theme-color: #007aff;
  /*
    --swiper-preloader-color: var(--swiper-theme-color);
    --swiper-wrapper-transition-timing-function: initial;
    */ }

.swiper,
swiper-container {
  margin-left: auto;
  margin-right: auto;
  position: relative;
  overflow: hidden;
  list-style: none;
  padding: 0;
  /* Fix of Webkit flickering */
  z-index: 1;
  display: block; }

.swiper-vertical > .swiper-wrapper {
  flex-direction: column; }

.swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: flex;
  transition-property: transform;
  transition-timing-function: var(--swiper-wrapper-transition-timing-function, initial);
  box-sizing: content-box; }

.swiper-android .swiper-slide,
.swiper-wrapper {
  transform: translate3d(0px, 0, 0); }

.swiper-horizontal {
  touch-action: pan-y; }

.swiper-vertical {
  touch-action: pan-x; }

.swiper-slide,
swiper-slide {
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  position: relative;
  transition-property: transform;
  display: block; }

.swiper-slide-invisible-blank {
  visibility: hidden; }

/* Auto Height */
.swiper-autoheight,
.swiper-autoheight .swiper-slide {
  height: auto; }

.swiper-autoheight .swiper-wrapper {
  align-items: flex-start;
  transition-property: transform, height; }

.swiper-backface-hidden .swiper-slide {
  transform: translateZ(0);
  backface-visibility: hidden; }

/* 3D Effects */
.swiper-3d.swiper-css-mode .swiper-wrapper {
  perspective: 1200px; }

.swiper-3d .swiper-wrapper {
  transform-style: preserve-3d; }

.swiper-3d {
  perspective: 1200px; }
  .swiper-3d .swiper-slide,
  .swiper-3d .swiper-slide-shadow,
  .swiper-3d .swiper-slide-shadow-left,
  .swiper-3d .swiper-slide-shadow-right,
  .swiper-3d .swiper-slide-shadow-top,
  .swiper-3d .swiper-slide-shadow-bottom,
  .swiper-3d .swiper-cube-shadow {
    transform-style: preserve-3d; }
  .swiper-3d .swiper-slide-shadow,
  .swiper-3d .swiper-slide-shadow-left,
  .swiper-3d .swiper-slide-shadow-right,
  .swiper-3d .swiper-slide-shadow-top,
  .swiper-3d .swiper-slide-shadow-bottom {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 10; }
  .swiper-3d .swiper-slide-shadow {
    background: rgba(0, 0, 0, 0.15); }
  .swiper-3d .swiper-slide-shadow-left {
    background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0)); }
  .swiper-3d .swiper-slide-shadow-right {
    background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0)); }
  .swiper-3d .swiper-slide-shadow-top {
    background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0)); }
  .swiper-3d .swiper-slide-shadow-bottom {
    background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0)); }

/* CSS Mode */
.swiper-css-mode > .swiper-wrapper {
  overflow: auto;
  scrollbar-width: none;
  /* For Firefox */
  -ms-overflow-style: none;
  /* For Internet Explorer and Edge */ }
  .swiper-css-mode > .swiper-wrapper::-webkit-scrollbar {
    display: none; }

.swiper-css-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: start start; }

.swiper-horizontal.swiper-css-mode > .swiper-wrapper {
  scroll-snap-type: x mandatory; }

.swiper-vertical.swiper-css-mode > .swiper-wrapper {
  scroll-snap-type: y mandatory; }

.swiper-css-mode.swiper-free-mode > .swiper-wrapper {
  scroll-snap-type: none; }

.swiper-css-mode.swiper-free-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: none; }

.swiper-centered > .swiper-wrapper::before {
  content: '';
  flex-shrink: 0;
  order: 9999; }

.swiper-centered > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: center center;
  scroll-snap-stop: always; }

.swiper-centered.swiper-horizontal > .swiper-wrapper > .swiper-slide:first-child {
  margin-inline-start: var(--swiper-centered-offset-before); }

.swiper-centered.swiper-horizontal > .swiper-wrapper::before {
  height: 100%;
  min-height: 1px;
  width: var(--swiper-centered-offset-after); }

.swiper-centered.swiper-vertical > .swiper-wrapper > .swiper-slide:first-child {
  margin-block-start: var(--swiper-centered-offset-before); }

.swiper-centered.swiper-vertical > .swiper-wrapper::before {
  width: 100%;
  min-width: 1px;
  height: var(--swiper-centered-offset-after); }

.swiper-lazy-preloader {
  width: 42px;
  height: 42px;
  position: absolute;
  left: 50%;
  top: 50%;
  margin-left: -21px;
  margin-top: -21px;
  z-index: 10;
  transform-origin: 50%;
  box-sizing: border-box;
  border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
  border-radius: 50%;
  border-top-color: transparent; }

.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader,
swiper-container:not(.swiper-watch-progress) .swiper-lazy-preloader,
.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader {
  animation: swiper-preloader-spin 1s infinite linear; }

.swiper-lazy-preloader-white {
  --swiper-preloader-color: #fff; }

.swiper-lazy-preloader-black {
  --swiper-preloader-color: #000; }

@keyframes swiper-preloader-spin {
  0% {
    transform: rotate(0deg); }
  100% {
    transform: rotate(360deg); } }

.swiper-fade.swiper-free-mode .swiper-slide {
  transition-timing-function: ease-out; }

.swiper-fade .swiper-slide {
  pointer-events: none;
  transition-property: opacity; }
  .swiper-fade .swiper-slide .swiper-slide {
    pointer-events: none; }

.swiper-fade .swiper-slide-active,
.swiper-fade .swiper-slide-active .swiper-slide-active {
  pointer-events: auto; }

.mf-cursor {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 250;
  direction: ltr;
  contain: layout style size;
  pointer-events: none;
  transition: opacity 0.3s, color 0.4s; }
  .mf-cursor:before {
    content: "";
    position: absolute;
    top: -24px;
    left: -24px;
    display: block;
    width: 48px;
    height: 48px;
    transform: scale(0.2);
    background: currentColor;
    border-radius: 50%;
    transition: transform 0.25s ease-in-out, opacity 0.1s; }
  .mf-cursor.-inverse {
    color: white; }
  @supports (mix-blend-mode: exclusion) {
    .mf-cursor.-exclusion {
      mix-blend-mode: exclusion; }
      .mf-cursor.-exclusion:before {
        background: white; } }
  .mf-cursor.-pointer:before {
    transform: scale(0.15); }
  .mf-cursor.-text:before {
    opacity: 0.85;
    transform: scale(1.7); }
  .mf-cursor.-text.-active:before {
    transform: scale(1.6);
    transition-duration: 0.2s; }
  .mf-cursor.-icon:before {
    transform: scale(1.5); }
  .mf-cursor.-icon.-active:before {
    transform: scale(1.4); }
  .mf-cursor.-hidden:before {
    transform: scale(0); }
  .mf-cursor-text {
    position: absolute;
    top: -18px;
    left: -18px;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    transform: scale(0) rotate(10deg);
    opacity: 0;
    color: #fff;
    font-size: 16px;
    line-height: 20px;
    text-align: center;
    transition: opacity 0.4s, transform 0.3s; }
    .mf-cursor.-text .mf-cursor-text, .mf-cursor.-icon .mf-cursor-text {
      opacity: 1;
      transform: scale(1); }
  .mf-cursor-media {
    position: absolute;
    width: 400px;
    height: 400px;
    margin: -200px 0 0 -200px; }
    .mf-cursor-media img, .mf-cursor-media video {
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      border-radius: 50%; }
      @supports (object-fit: cover) {
        .mf-cursor-media img, .mf-cursor-media video {
          position: static;
          width: 100%;
          height: 100%;
          object-fit: cover;
          transform: translateZ(0); } }
    .mf-cursor-media-box {
      position: relative;
      width: 100%;
      height: 100%;
      overflow: hidden;
      transform: scale(0) translateZ(0);
      padding: 1px;
      opacity: 0;
      border-radius: 50%;
      transition: transform 0.35s, opacity 0.2s 0.2s; }
      .mf-cursor.-media .mf-cursor-media-box {
        opacity: 1;
        transform: scale(0.696);
        transition-duration: 0.4s, 0.4s;
        transition-delay: 0s, 0s; }

@keyframes noise {
  0%, 100% {
    background-position: 0 0; }
  10% {
    background-position: -5% -10%; }
  20% {
    background-position: -15% 5%; }
  30% {
    background-position: 7% -25%; }
  40% {
    background-position: 20% 25%; }
  50% {
    background-position: -25% 10%; }
  60% {
    background-position: 15% 5%; }
  70% {
    background-position: 0% 15%; }
  80% {
    background-position: 25% 35%; }
  90% {
    background-position: -10% 10%; } }

@keyframes appear_blur {
  0% {
    filter: blur(20px);
    opacity: 0; }
  100% {
    filter: blur(0);
    opacity: 1; } }

:root {
  --rem: 1.75rem; }
  @media screen and (max-width: 992px) {
    :root {
      --rem: 1.5rem; } }
  @media screen and (max-width: 765px) {
    :root {
      --rem: 1.25rem; } }
  @media screen and (max-width: 572px) {
    :root {
      --rem: 1rem; } }

* {
  box-sizing: border-box;
  text-rendering: optimizeLegibility !important;
  -webkit-font-smoothing: antialiased !important;
  -moz-osx-font-smoothing: grayscale !important;
  backface-visibility: hidden; }

:root {
  --primary-color: #FDFBFB;
  --secondary-color: #536390;
  --font-color: #FDFBFB;
  --bg-color: #000;
  --highlight-color: #FDFBFB; }

[data-theme="dark"] {
  --primary-color: #19F979;
  --secondary-color: #818cab;
  --font-color: #FDFBFB;
  --bg-color:  #141516;
  --highlight-color: #C5ACFB; }

[data-theme="purple"] {
  --primary-color: #141516;
  --secondary-color: #818cab;
  --font-color: #141516;
  --bg-color:  #C5ACFB;
  --highlight-color: #141516; }

.--menu-active {
  --primary-color: #141516; }

svg {
  fill: currentColor; }

html {
  font-size: 20px;
  margin: 0; }
  html.--noscroll {
    height: 100vh;
    overflow: hidden; }

body {
  font-family: "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
  font-weight: 400;
  color: var(--font-color);
  font-size: .8rem;
  line-height: 1.4;
  background-color: #000;
  padding: 0 !important;
  margin: 0 !important;
  min-height: 100vh;
  width: 100%;
  transition: color 0.8s cubic-bezier(0.23, 1, 0.32, 1), background 0.8s cubic-bezier(0.23, 1, 0.32, 1); }
  @media screen and (min-width: 1921px) {
    body {
      font-size: 1rem; } }
  .--menu-active body {
    height: 100vh;
    overflow: hidden; }

.main-content {
  position: relative; }
  .main-content:not(:has(.homepage, .page)) {
    padding-top: 10rem; }

a, a:hover {
  color: inherit;
  text-decoration: none; }

a {
  transition: all 0.2s ease; }

figure {
  margin: 0; }

strong {
  font-weight: 600; }

svg {
  width: 1.6rem;
  height: 1.6rem; }

h1, h2, h3, h4, h5 {
  text-transform: uppercase; }

h1 {
  font-size: clamp(2rem, 4vw, 4.5rem); }

h2, h3, h4, h5 {
  font-weight: 700; }

h2 {
  font-size: .9rem; }

.container, .container-little, .flex-logos, .flex-chiffres {
  max-width: 100vw;
  width: 100%;
  padding: 0 4rem;
  margin: 0 auto; }
  @media screen and (max-width: 765px) {
    .container, .container-little, .flex-logos, .flex-chiffres {
      padding: 0 2rem;
      max-width: 100vw; } }
  .container-little, .flex-logos, .flex-chiffres {
    max-width: 1200px; }

.wysiwyg-text p, .homepage-paragraphs-smallText p, .flex-text p, .flex-text-2col p, .flex-text-2col-text p, .flex-textimages-text p,
.wysiwyg-text ul,
.homepage-paragraphs-smallText ul,
.flex-text ul,
.flex-text-2col ul,
.flex-text-2col-text ul,
.flex-textimages-text ul,
.wysiwyg-text figure,
.homepage-paragraphs-smallText figure,
.flex-text figure,
.flex-text-2col figure,
.flex-text-2col-text figure,
.flex-textimages-text figure {
  margin: 0 0 1rem; }
  .wysiwyg-text p:last-child, .homepage-paragraphs-smallText p:last-child, .flex-text p:last-child, .flex-text-2col p:last-child, .flex-text-2col-text p:last-child, .flex-textimages-text p:last-child,
  .wysiwyg-text ul:last-child,
  .homepage-paragraphs-smallText ul:last-child,
  .flex-text ul:last-child,
  .flex-text-2col ul:last-child,
  .flex-text-2col-text ul:last-child,
  .flex-textimages-text ul:last-child,
  .wysiwyg-text figure:last-child,
  .homepage-paragraphs-smallText figure:last-child,
  .flex-text figure:last-child,
  .flex-text-2col figure:last-child,
  .flex-text-2col-text figure:last-child,
  .flex-textimages-text figure:last-child {
    margin: 0; }

.wysiwyg-text a, .homepage-paragraphs-smallText a, .flex-text a, .flex-text-2col a, .flex-text-2col-text a, .flex-textimages-text a {
  transition: all 0.2s ease;
  font-weight: 600; }
  .wysiwyg-text a:hover, .homepage-paragraphs-smallText a:hover, .flex-text a:hover, .flex-text-2col a:hover, .flex-text-2col-text a:hover, .flex-textimages-text a:hover {
    color: #19F979; }

.background {
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  z-index: -1;
  background: #000; }
  .background-mobile {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    display: none;
    background-position: center center;
    background-size: cover; }
    @media screen and (max-width: 992px) {
      .background-mobile {
        display: block; } }

.animated-background {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  background: #000;
  will-change: transform;
  z-index: 0; }
  @media screen and (max-width: 992px) {
    .animated-background {
      display: none; } }
  .animated-background canvas {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    transform: translate3d(0, 0, 0); }
  .animated-background video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    transform: translate3d(0, 0, 0);
    object-fit: cover;
    object-position: center center;
    z-index: 4; }
  .animated-background-texture {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    z-index: 2;
    background-size: cover;
    mix-blend-mode: multiply;
    opacity: 0.4; }
  .animated-background-grain {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    z-index: 1;
    background-size: cover;
    mix-blend-mode: overlay;
    opacity: 0.25; }
  .animated-background.--grayscale {
    filter: grayscale(1) brightness(0.6); }
  .animated-background.--no-texture .animated-background-texture,
  .animated-background.--no-texture .animated-background-grain {
    display: none; }

.header {
  height: auto;
  position: fixed;
  z-index: 200;
  top: 0;
  left: 0;
  width: 100%; }
  @media screen and (max-width: 572px) {
    .header {
      height: 5rem; } }
  .header .container, .header .container-little, .header .flex-logos, .header .flex-chiffres {
    position: relative; }
  .header-wrapper {
    padding: 1rem 0 0 0;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: relative; }
    @media screen and (max-width: 992px) {
      .header-wrapper {
        align-items: flex-start; } }
    @media screen and (max-width: 765px) {
      .header-wrapper {
        height: 5rem;
        overflow: visible; } }
  .header-right {
    display: flex;
    align-items: center; }
  .header-logo {
    display: block;
    transform-origin: top left; }
    .header-logo svg {
      width: auto;
      height: 3rem; }
      .header-logo svg path {
        transition: opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1), fill 0.8s cubic-bezier(0.23, 1, 0.32, 1); }
        .--menu-active .header-logo svg path {
          fill: #000; }
      @media screen and (max-width: 572px) {
        .header-logo svg {
          height: 2rem; } }
  .header-lang {
    display: flex;
    align-items: center;
    margin: 0 1em 0 0; }
    @media screen and (max-width: 765px) {
      .header-lang {
        display: none; } }
    .header-lang svg {
      width: 1rem;
      height: 1rem; }
  @media screen and (min-width: 993px) {
    .header-burger {
      display: none !important; } }
  .header .menu {
    display: flex;
    gap: 2rem; }
    @media screen and (max-width: 992px) {
      .header .menu {
        display: none; } }
    .header .menu-item {
      padding: 0;
      margin: 0; }
      .header .menu-item-link {
        font-family: "Space Mono", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
        color: var(--primary-color) !important;
        transition: transform 0.8s cubic-bezier(0.23, 1, 0.32, 1); }
        .header .menu-item-link::before {
          content: "•";
          display: inline-block;
          margin: 0 .5rem 0 0;
          opacity: 0;
          transform: translateX(2rem);
          transition: opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1), transform 0.8s cubic-bezier(0.23, 1, 0.32, 1); }
        .header .menu-item-link:hover {
          transform: translateX(0.5rem);
          font-style: italic; }
          .header .menu-item-link:hover::before {
            opacity: 1;
            transform: translateX(0); }
        @media screen and (max-width: 765px) {
          .header .menu-item-link {
            background-color: var(--bg-color) !important; } }
        @media screen and (max-width: 572px) {
          .header .menu-item-link {
            font-size: .5rem;
            padding: 0.5rem !important;
            min-width: 7rem !important; } }
      .header .menu-item.link-home {
        display: none; }
  .header .submenu {
    display: none; }
  .header-button {
    display: none;
    position: relative;
    width: 30px;
    height: 24px;
    cursor: pointer;
    z-index: 1900; }
    .header-button-line1 {
      position: absolute;
      display: block;
      width: 26px;
      height: 2px;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      font-size: 0;
      background: #FDFBFB;
      margin-top: -8px;
      transition: all 0.35s ease;
      transform-origin: 50% 50%; }
    .header-button-line2 {
      position: absolute;
      display: block;
      width: 26px;
      height: 2px;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      font-size: 0;
      background: #FDFBFB;
      transition: all 0.35s ease;
      transform-origin: 50% 50%; }
    .header-button-line3 {
      position: absolute;
      display: block;
      width: 26px;
      height: 2px;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      font-size: 0;
      background: #FDFBFB;
      margin-top: 8px;
      transition: all 0.35s ease;
      transform-origin: 50% 50%; }
  .header-overlay {
    position: fixed;
    overflow: hidden;
    z-index: 1800;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    visibility: hidden;
    opacity: 0;
    transition: visibility 0s 0.35s, opacity 0.35s ease; }
  @media screen and (max-width: 992px) {
    .header .contact-button {
      display: none; } }
  .header-instalink {
    position: fixed;
    bottom: 3rem;
    right: 4rem;
    border-radius: 50%;
    display: grid;
    place-items: center;
    border: 2px solid #FDFBFB;
    padding: .7rem;
    z-index: -2; }
    @media screen and (max-width: 765px) {
      .header-instalink {
        right: 1rem; } }

.footer {
  min-height: 100vh;
  padding: 3rem 0;
  color: #FDFBFB;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  width: 100%;
  position: relative;
  overflow: hidden; }
  .footer-main {
    flex-grow: 1;
    height: 100%;
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    padding: 0 10rem 0 15rem; }
    @media screen and (max-width: 1280px) {
      .footer-main {
        justify-content: flex-end; } }
    @media screen and (max-width: 992px) {
      .footer-main {
        padding: 0 1.5rem 2rem 1.5rem; } }
  .footer-text {
    font-size: 2.8rem;
    font-family: "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
    text-transform: uppercase;
    font-weight: 700;
    z-index: 2;
    margin: 0 0 2rem 0; }
    @media screen and (max-width: 992px) {
      .footer-text {
        font-size: 1.6rem; } }
  .footer-button {
    z-index: 2; }
  .footer-bubble {
    position: absolute;
    top: 30%;
    left: 0;
    transform: translate(-30%, -30%);
    z-index: 0;
    pointer-events: none;
    width: 100%;
    aspect-ratio: 2/1; }
  .footer-bottom {
    border-bottom: 1px solid #FDFBFB;
    font-size: .7rem; }
    .footer-bottom > * {
      padding: .5rem 0; }
    .footer-bottom-line {
      display: grid;
      grid-template-columns: 5rem 10rem 1fr;
      align-items: end;
      gap: 4rem; }
      @media screen and (max-width: 992px) {
        .footer-bottom-line {
          gap: 1rem; } }
      @media screen and (max-width: 765px) {
        .footer-bottom-line {
          grid-template-columns: 1fr 1fr;
          gap: 0; } }
    .footer-bottom-contact {
      display: flex;
      flex-direction: column;
      justify-content: flex-start;
      align-items: flex-start; }
    .footer-bottom-tel, .footer-bottom-mail {
      color: #FDFBFB; }
      .footer-bottom-tel:hover, .footer-bottom-mail:hover {
        text-decoration: underline; }
    @media screen and (max-width: 765px) {
      .footer-bottom-mail {
        justify-self: flex-start;
        grid-row: 2; } }
    @media screen and (max-width: 765px) {
      .footer-bottom-adress {
        font-size: .7rem; } }
    .footer-bottom-adress + * {
      margin: 0 0 0 1rem; }
      @media screen and (max-width: 765px) {
        .footer-bottom-adress + * {
          margin: 1rem 0 0 0; } }
    .footer-bottom-adress p {
      padding: 0;
      margin: 0; }
      .footer-bottom-adress p strong {
        font-weight: 700; }
    .footer-bottom-links {
      display: flex;
      flex-direction: column;
      justify-content: flex-end;
      align-items: flex-end; }
      @media screen and (max-width: 992px) {
        .footer-bottom-links {
          grid-row: 1 / span 2;
          grid-column: 2;
          justify-self: end; } }
    .footer-bottom-link {
      color: #FDFBFB;
      display: flex;
      justify-content: flex-end;
      align-items: center;
      white-space: nowrap; }
      .footer-bottom-link svg {
        width: .8rem;
        height: .8rem;
        object-fit: contain;
        margin: 0 0 0 .5rem;
        transform: rotate(-90deg); }
    .footer-bottom-under {
      margin-top: .5rem;
      display: flex;
      justify-content: flex-start;
      align-items: flex-start; }
      @media screen and (max-width: 765px) {
        .footer-bottom-under {
          flex-direction: column; } }
  .footer-lang {
    justify-self: flex-start; }
  .footer .menu {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    font-size: .7rem;
    width: 50%; }
    @media screen and (max-width: 992px) {
      .footer .menu {
        width: 100%;
        flex-wrap: wrap; } }
    .footer .menu > li {
      margin: 0 2rem 0 0; }
      @media screen and (max-width: 765px) {
        .footer .menu > li {
          margin: 0 1rem 1rem 0; } }
      .footer .menu > li > a {
        margin: 0 0 .5rem 0;
        font-weight: 700;
        transition: color 0.8s cubic-bezier(0.23, 1, 0.32, 1); }
        .footer .menu > li > a:hover {
          color: #FDFBFB; }
      .footer .menu > li > ul {
        list-style-type: none;
        margin: 0;
        padding: 0; }
        .footer .menu > li > ul > li > a {
          font-weight: 300;
          margin: 0 0 .25rem 0; }
          .footer .menu > li > ul > li > a:hover {
            text-decoration: underline; }

.subfooter {
  padding: .5rem 0;
  font-size: .6rem;
  text-align: right; }
  .subfooter a {
    transition: color 0.8s cubic-bezier(0.23, 1, 0.32, 1); }
  .subfooter a:hover {
    color: #FDFBFB; }

.bim-landing {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  overflow-y: auto;
  z-index: 100000;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #000;
  color: #FDFBFB;
  text-align: center; }
  .bim-landing-wrapper {
    overflow: hidden; }
  .bim-landing-content {
    max-width: 630px;
    padding: 1.5rem; }
  .bim-landing-logo {
    margin-bottom: 2rem;
    display: flex;
    align-items: center;
    justify-content: center; }
    .bim-landing-logo img {
      max-width: 360px; }

.menu {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  margin: 0;
  padding: 0;
  list-style-type: none; }
  .menu-item {
    margin: 0.5rem; }
    .menu-item-link {
      display: block; }
      .menu-item-link svg {
        display: block; }
  .menu-header {
    position: absolute;
    top: calc(50% + .5rem);
    left: 50%;
    transform: translate(-50%, -50%); }

button,
.button,
button-primary,
.button-primary,
button-secondary,
.button-secondary {
  display: inline-flex;
  border: none;
  font-family: "Space Mono", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
  font-weight: 700;
  background: transparent;
  color: #000;
  font-size: 0.8rem;
  padding: 0.75rem 1.5rem;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  min-width: 10rem;
  text-align: center; }
  button svg,
  .button svg,
  button-primary svg,
  .button-primary svg,
  button-secondary svg,
  .button-secondary svg {
    width: 0.8rem;
    height: 0.8rem; }
  button-wrapper svg,
  .button-wrapper svg {
    margin: 0 1rem 0 0;
    transition: transform 0.8s cubic-bezier(0.23, 1, 0.32, 1);
    transform-origin: center; }
  button-wrapper:hover svg,
  .button-wrapper:hover svg {
    transform: rotate(-45deg); }
  button-primary,
  .button-primary {
    color: var(--primary-color);
    border: 2px solid var(--primary-color);
    border-radius: 1.5rem; }
    button-primary:hover,
    .button-primary:hover {
      background-color: #FDFBFB;
      border-color: #FDFBFB;
      color: #000; }
  button-secondary,
  .button-secondary {
    background-color: #FDFBFB;
    color: #000;
    border-radius: 1.5rem; }
    button-secondary:hover,
    .button-secondary:hover {
      color: #000; }

.contact {
  width: 100%;
  height: 100vh;
  background-color: #D9D9D9;
  position: fixed;
  top: 100%;
  left: 0;
  overflow-y: auto;
  padding: 5rem 8rem;
  border-radius: 2rem 2rem 0 0;
  z-index: 400;
  transition: transform 0.8s cubic-bezier(0.23, 1, 0.32, 1);
  overflow: hidden;
  --primary-color: #000;
  --bg-color: #FDFBFB;
  /*  &-button{
        z-index: 440;
        position: fixed;
        left: 50%;
        bottom: 0;
        transform: translateX(-50%);
        background-color: transparent;
        font-family: $font-secondary;
        font-weight: 600;
        text-transform: uppercase;
        transition: $ts-smooth;
        transition-delay: .3s;
        border-radius: 1.5rem 1.5rem 0 0;
        background-color: $green;
        min-width: 415px;
        height: 100px;
        @media screen and (max-width: 765px) {
            width: calc(100% - 2rem);
            height: 75px;
        }

        &.hidden{
            transform: translateX(-50%) translateY(2rem);
            visibility: hidden;
            opacity: 0;
        }
    } */ }
  @media screen and (max-width: 992px) {
    .contact {
      padding: 6rem 1.5rem 2rem 1.5rem;
      height: 100dvh; } }
  .contact.ready {
    transform: translateY(-2rem); }
  .contact.visible {
    transform: translateY(-100%);
    overflow: auto; }
  .contact-container {
    max-width: 1440px;
    margin-left: auto !important;
    margin-right: auto !important;
    width: 100%; }
    @media screen and (max-width: 765px) {
      .contact-container {
        max-width: 100vw; } }
  .contact-close {
    position: absolute;
    top: 2rem;
    left: 50%;
    transform: translateX(-50%); }

.mf-cursor {
  color: var(--highlight-color);
  mix-blend-mode: difference;
  z-index: 450; }
  .mf-cursor.-pointer:before {
    transform: scale(0.15); }
  .mf-cursor.-fill:before {
    transform: scale(0.9); }
  .mf-cursor.-button:before {
    transform: scale(1); }
  .mf-cursor.-text, .mf-cursor.-icon {
    mix-blend-mode: initial;
    backdrop-filter: blur(5px); }
    .mf-cursor.-text:before, .mf-cursor.-icon:before {
      opacity: 1;
      transform: scale(2);
      background-color: rgba(255, 255, 255, 0.2) !important;
      backdrop-filter: blur(5px); }
    .mf-cursor.-text.-active:before, .mf-cursor.-icon.-active:before {
      transform: scale(1.6);
      transition-duration: 0.2s; }
  .mf-cursor.-contact {
    filter: none;
    mix-blend-mode: initial; }
    .mf-cursor.-contact:before {
      background-color: var(--highlight-color);
      transform: scale(5); }
  .mf-cursor.-icon:before {
    transform: scale(1.5); }
  .mf-cursor.-icon.-active:before {
    transform: scale(1.4); }
  .mf-cursor.-hidden:before {
    transform: scale(0); }
  .mf-cursor.-hidden .mf-cursor-text {
    transform: scale(0); }
  .mf-cursor-text {
    text-transform: uppercase;
    font-family: "Space Mono", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
    color: #000;
    font-weight: 700; }
  .mf-cursor .cursor-svg {
    fill: #FDFBFB; }

.bim-popup {
  position: fixed;
  z-index: 100000;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  visibility: visible;
  opacity: 1;
  transition: opacity 0.35s ease; }
  .bim-popup.--inactive {
    visibility: hidden;
    opacity: 0;
    transition: visibility 0s 0.35s, opacity 0.35s ease; }
  .bim-popup-overlay {
    position: absolute;
    z-index: 0;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.6); }
  .bim-popup-content {
    position: relative;
    z-index: 1;
    background: #FDFBFB;
    max-width: 630px;
    padding: 1.5rem;
    max-height: calc(100vh - 2rem);
    overflow-y: auto; }
  .bim-popup-close {
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 0.25rem;
    right: 0.25rem;
    width: 1.2rem;
    height: 1.2rem;
    cursor: pointer; }
    .bim-popup-close svg {
      width: 100%;
      height: 100%; }
  .bim-popup-image {
    margin-bottom: 1.5rem; }
    .bim-popup-image:last-child {
      margin-bottom: 0; }
  .bim-popup-title {
    text-align: center;
    font-weight: 600;
    font-size: 1rem;
    margin-bottom: 1rem; }
    .bim-popup-title:last-child {
      margin-bottom: 0; }
  .bim-popup-text {
    text-align: center;
    margin-bottom: 1.5rem; }
    .bim-popup-text:last-child {
      margin-bottom: 0; }
    .bim-popup-text p {
      margin: 0 0 1rem; }
      .bim-popup-text p:last-child {
        margin-bottom: 0; }
  .bim-popup-button {
    text-align: center; }

.bim-slider {
  user-select: none;
  max-width: 920px;
  background: #FDFBFB;
  border: solid 0.25rem #FDFBFB;
  margin: 0 auto; }
  .bim-slider .swiper-image {
    position: relative; }
    .bim-slider .swiper-image:before {
      content: '';
      display: block;
      position: relative;
      z-index: 0;
      padding-bottom: 56.25%; }
    @media screen and (max-width: 765px) {
      .bim-slider .swiper-image:before {
        content: '';
        display: block;
        position: relative;
        z-index: 0;
        padding-bottom: 75%; } }
    .bim-slider .swiper-image img {
      position: absolute;
      left: 0;
      top: 0;
      width: 100%;
      height: 100%; }
    .bim-slider .swiper-image-description {
      position: relative;
      text-overflow: ellipsis;
      overflow: hidden;
      white-space: nowrap;
      position: absolute;
      z-index: 1;
      left: 0;
      bottom: 0;
      width: 100%;
      padding: 0.75rem 3rem 0.75rem 0.75rem;
      line-height: 0.75rem;
      background: #000;
      transition: all 0.35s ease 0.35s;
      color: rgba(253, 251, 251, 0);
      font-size: 0.6rem; }
    .bim-slider .swiper-image.--has-description img {
      height: calc(100% - 2.25rem); }
  .bim-slider .swiper-slide {
    overflow: hidden; }
    .bim-slider .swiper-slide-active .swiper-image {
      transform: none;
      opacity: 1; }
      .bim-slider .swiper-slide-active .swiper-image-description {
        color: #FDFBFB; }
  .bim-slider-main {
    position: relative;
    overflow: hidden; }
    .bim-slider-main:hover .swiper-button {
      transform: translateY(-50%); }
    .bim-slider-main .swiper-pagination {
      z-index: 5;
      position: absolute;
      bottom: 0;
      right: 0;
      background: #FDFBFB;
      font-weight: 600;
      display: flex;
      align-items: center;
      justify-content: center;
      width: 2.25rem;
      height: 2.25rem;
      letter-spacing: 0.1em;
      font-size: 0.7rem; }
    .bim-slider-main .swiper-button {
      z-index: 5;
      position: absolute;
      top: 50%;
      width: 2.25rem;
      height: 2.25rem;
      color: #000;
      display: flex;
      align-items: center;
      justify-content: center;
      cursor: pointer;
      transition: all 0.2s ease; }
      .bim-slider-main .swiper-button:before {
        content: '';
        display: block;
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        background: #FDFBFB;
        transition: all 0.2s ease; }
      .bim-slider-main .swiper-button svg {
        width: 1.2rem;
        height: 1.2rem;
        transition: all 0.2s ease;
        position: relative;
        z-index: 1; }
      .bim-slider-main .swiper-button-prev {
        left: 0;
        transform: translate(-110%, -50%); }
        .bim-slider-main .swiper-button-prev:hover svg {
          transform: translateX(-3px); }
      .bim-slider-main .swiper-button-next {
        right: 0;
        transform: translate(110%, -50%); }
        .bim-slider-main .swiper-button-next:hover svg {
          transform: translateX(3px); }
  .bim-slider-thumbnails {
    margin-top: 5px; }
    .bim-slider-thumbnails .swiper-slide {
      cursor: pointer;
      opacity: 0.25;
      transition: opacity 0.2s ease; }
      .bim-slider-thumbnails .swiper-slide-thumb-active {
        opacity: 1; }
  @media screen and (max-width: 992px) {
    .bim-slider-main .swiper-button {
      display: none; }
    .bim-slider .swiper-image-description {
      font-size: 0.6rem; } }

.gform_wrapper h2 {
  color: var(--primary-color) !important; }

.gform_wrapper .gfield--type-text {
  position: relative; }
  .gform_wrapper .gfield--type-text .gform-field-label {
    position: absolute;
    top: -15px;
    left: 0;
    color: var(--primary-color);
    transition: transform 0.8s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1); }
    @media screen and (max-width: 765px) {
      .gform_wrapper .gfield--type-text .gform-field-label {
        position: relative;
        top: auto;
        left: auto; } }

.gform_wrapper .gfield--type-name {
  padding: 2rem 1.5rem 1rem 1.5rem;
  background-color: var(--primary-color);
  border-radius: 1.5rem; }
  .gform_wrapper .gfield--type-name legend, .gform_wrapper .gfield--type-name label {
    color: var(--primary-color); }
  .gform_wrapper .gfield--type-name legend {
    transform: translateY(1.5rem); }
  .gform_wrapper .gfield--type-name .ginput_complex input {
    box-shadow: none;
    border: none;
    border-radius: 0;
    color: var(--primary-color);
    background-color: transparent !important;
    border-bottom: 2px solid var(--bg-color) !important; }
  .gform_wrapper .gfield--type-name .gform-field-label {
    color: var(--bg-color); }

.gform_wrapper input[type='text'],
.gform_wrapper input[type='email'],
.gform_wrapper input[type='tel'],
.gform_wrapper input[type='number'] {
  box-shadow: none !important;
  border: none !important;
  border-radius: 0 !important;
  background-color: transparent !important;
  color: var(--primary-color);
  border-bottom: 2px solid var(--primary-color) !important; }

.gform_wrapper textarea {
  box-shadow: none !important;
  border: 2px solid var(--primary-color) !important;
  border-radius: 30px !important;
  background-color: transparent !important;
  padding: 1rem !important;
  color: var(--primary-color); }

.gform_wrapper .gfield_radio,
.gform_wrapper .gfield_checkbox {
  display: flex;
  flex-wrap: wrap;
  flex-direction: row !important; }
  .gform_wrapper .gfield_radio .gchoice,
  .gform_wrapper .gfield_checkbox .gchoice {
    position: relative; }
  .gform_wrapper .gfield_radio .gfield-choice-input,
  .gform_wrapper .gfield_checkbox .gfield-choice-input {
    width: 1px;
    height: 1px;
    position: absolute;
    top: 0;
    left: 0;
    visibility: hidden; }
    .gform_wrapper .gfield_radio .gfield-choice-input:checked + label,
    .gform_wrapper .gfield_checkbox .gfield-choice-input:checked + label {
      background-color: #FDFBFB;
      border-color: #FDFBFB;
      color: #000 !important;
      transform: translateY(-2px); }
  .gform_wrapper .gfield_radio .gform-field-label,
  .gform_wrapper .gfield_checkbox .gform-field-label {
    border: 2px solid var(--primary-color);
    padding: .25rem .75rem;
    border-radius: 5rem;
    cursor: pointer;
    color: var(--primary-color);
    transition: all 0.8s cubic-bezier(0.23, 1, 0.32, 1); }

.gform_wrapper input[type=submit],
.gform_wrapper input[type=button] {
  background-color: var(--primary-color) !important;
  color: var(--bg-color) !important;
  text-transform: uppercase !important;
  font-family: "Space Mono", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif !important;
  font-weight: 600 !important;
  padding: 1rem 4rem !important;
  border-radius: 1.5rem !important;
  margin: 1rem auto 0 auto !important;
  outline: none !important; }

.gform_wrapper input[type=button] {
  background-color: #FDFBFB !important;
  color: #000 !important; }

.gform_wrapper .gform_required_legend {
  color: var(--primary-color);
  font-size: .8rem;
  display: none; }

.gform_wrapper .gform_confirmation_message {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  color: #000 !important;
  text-transform: uppercase;
  font-weight: 600;
  font-family: "Space Mono", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
  font-size: 1rem; }
  .gform_wrapper .gform_confirmation_message strong {
    text-transform: uppercase;
    font-size: 2rem; }

.gform_wrapper .gform-field-label {
  color: var(--primary-color); }

.gform_wrapper .gfield--input-type-date ::placeholder {
  color: var(--primary-color);
  opacity: .5; }

.gform_wrapper .gform-loader {
  position: absolute !important;
  top: 50%;
  right: 0;
  transform: translateY(-50%); }

.gform_wrapper .gform_page_footer {
  position: relative !important; }

.main-blob {
  position: fixed;
  top: 15%;
  left: 15%;
  opacity: 0.25;
  width: 800px;
  height: 800px;
  aspect-ratio: 1/1;
  animation: transform_blob 18s ease-in-out infinite both alternate, movement_one 12s ease-in-out infinite both;
  filter: blur(40px);
  z-index: -1;
  background: linear-gradient(47deg, rgba(255, 255, 255, 0.3) 21%, rgba(253, 251, 251, 0.3) 81%); }
  @media screen and (max-width: 765px) {
    .main-blob {
      display: none; } }
  .main-blob.one {
    top: 28%;
    left: 28%;
    animation: transform_blob 8s ease-in-out infinite both alternate, movement_two 20s ease-in-out infinite both; }

@keyframes animate_blobs {
  0% {
    transform: translate(40%, -25%);
    border-radius: 60% 40% 30% 70% / 100% 85% 92% 74%; }
  50% {
    transform: translate(0%, 13%);
    border-radius: 20% 71% 47% 70% / 81% 15% 22% 54%;
    rotate: 41deg;
    scale: 1.15; }
  100% {
    transform: translate(-45%, 39%);
    border-radius: 100% 75% 92% 74% / 60% 80% 30% 70%;
    rotate: -60deg;
    scale: 1.05; } }

@keyframes transform_blob {
  0%,
  100% {
    border-radius: 33% 67% 70% 30% / 30% 40% 70% 70%; }
  20% {
    border-radius: 37% 63% 51% 49% / 37% 35% 35% 63%; }
  40% {
    border-radius: 36% 64% 64% 36% / 64% 48% 52% 26%; }
  60% {
    border-radius: 37% 63% 51% 49% / 30% 30% 70% 73%; }
  80% {
    border-radius: 40% 60% 42% 58% / 51% 51% 49% 59%; } }

@keyframes movement_one {
  0%,
  100% {
    transform: none; }
  50% {
    transform: translate(50%, 20%) rotateY(10deg) scale(1); } }

@keyframes movement_two {
  0%,
  500% {
    transform: none; }
  50% {
    transform: translate(50%, 20%) rotate(-200deg) scale(1.3); } }

.loader {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 300;
  background-color: #000; }
  .--loaded .loader {
    animation: 1.2s cubic-bezier(0.785, 0.135, 0.15, 0.86) 0.5s fade-out forwards; }
  .loader-center {
    width: 300px;
    height: auto;
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 2;
    transform: translate(-50%, -50%); }
    @media screen and (max-width: 765px) {
      .loader-center {
        width: 145px;
        height: 175px; } }
  .loader-logo {
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: -1;
    /* .--loaded &{
            animation: 1.2s cubic-bezier(.785,.135,.15,.86) 1.2s grow-out forwards;
        } */ }

@keyframes fade-in {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }

@keyframes fade-out {
  0% {
    opacity: 1;
    visibility: visible; }
  100% {
    opacity: 0;
    visibility: hidden; } }

@keyframes grow-out {
  0% {
    opacity: 1;
    transform: scale(1);
    filter: blur(0); }
  100% {
    opacity: 0;
    transform: scale(5);
    filter: blur(10px); } }

.menumobile {
  position: fixed;
  top: 0;
  left: 0;
  height: 100dvh;
  width: 100%;
  background-color: #FDFBFB;
  color: #000;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1), visibility 0.8s cubic-bezier(0.23, 1, 0.32, 1), transform 0.8s cubic-bezier(0.23, 1, 0.32, 1);
  z-index: -1;
  display: flex;
  flex-direction: column;
  transform: translateY(-100%); }
  .--menu-active .menumobile {
    opacity: 1;
    visibility: visible;
    transform: translateY(0); }
  .menumobile-menu {
    margin: 8rem 0 0 0;
    padding: 0;
    list-style-type: none;
    display: flex;
    flex-direction: column;
    align-content: center;
    justify-content: center;
    width: 100%; }
    .menumobile-menu > li {
      margin: 0.5rem 0 !important;
      text-align: center; }
      .menumobile-menu > li > a {
        font-size: 1.4rem;
        font-weight: 700;
        color: #000;
        text-align: center;
        font-family: "Space Mono", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; }
  .menumobile-bottom {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: .5rem 2rem;
    margin-top: auto;
    margin-bottom: 1rem; }
    .menumobile-bottom-link {
      justify-self: flex-end;
      font-family: "Space Mono", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
      display: flex;
      flex-wrap: nowrap;
      align-items: center; }
      @media screen and (max-width: 765px) {
        .menumobile-bottom-link {
          font-size: .7rem; } }
      .menumobile-bottom-link svg {
        width: .8rem;
        height: .8rem;
        object-fit: contain;
        margin: 0 0 0 .5rem;
        transform: rotate(-90deg); }
    .menumobile-bottom-tel, .menumobile-bottom-mail {
      font-weight: 500; }
      @media screen and (max-width: 765px) {
        .menumobile-bottom-tel, .menumobile-bottom-mail {
          font-size: .7rem; } }
  .menumobile-lang {
    display: flex;
    align-items: center;
    margin: 0 1em 0 0;
    grid-column: span 2; }
    .menumobile-lang svg {
      width: 1rem;
      height: 1rem; }

.wpml-ls {
  padding: 0 .5rem .25rem 0; }
  .wpml-ls .wpml-ls-item {
    padding: .25em .5em; }
  .wpml-ls .wpml-ls-link {
    color: currentColor;
    font-size: .8em;
    padding: 0 !important;
    position: relative; }
    .wpml-ls .wpml-ls-link::after {
      content: "";
      width: 100%;
      height: 1px;
      background-color: currentColor;
      position: absolute;
      bottom: -6px;
      left: 0;
      transition: bottom 0.8s cubic-bezier(0.23, 1, 0.32, 1); }
    .wpml-ls .wpml-ls-link:hover::after {
      bottom: -3px; }

.otgs-development-site-front-end {
  display: none !important; }

.artists {
  display: flex;
  flex-direction: column; }
  .artists-header {
    max-width: 100vw;
    margin-left: auto !important;
    margin-right: auto !important;
    width: 100%;
    display: grid;
    grid-template-columns: .3fr .7fr;
    gap: 2rem;
    width: 100%; }
    @media screen and (max-width: 765px) {
      .artists-header {
        max-width: 100vw; } }
    @media screen and (max-width: 992px) {
      .artists-header {
        grid-template-columns: 1fr; } }
    .artists-header h1 {
      font-size: 2.2rem;
      margin: 0; }
    .artists-header p {
      max-width: 70%; }
      @media screen and (max-width: 765px) {
        .artists-header p {
          max-width: 100%; } }
  .artists-cards {
    max-width: 100vw;
    margin-left: auto !important;
    margin-right: auto !important;
    width: 100%;
    margin: 4rem 0 0 0; }
    @media screen and (max-width: 765px) {
      .artists-cards {
        max-width: 100vw; } }
    .artists-cards .pin-spacer:nth-of-type(3n+1) .artists-card {
      background-color: #000;
      color: #FDFBFB; }
    .artists-cards .pin-spacer:nth-of-type(3n+2) .artists-card {
      background-color: #C5ACFB; }
    .artists-cards .pin-spacer:nth-of-type(3n+3) .artists-card {
      background-color: #FDFBFB; }
  .artists-card {
    padding: 3rem;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    min-height: 25rem;
    margin: 0 0 4rem 0;
    border-radius: 50px; }
    @media screen and (max-width: 992px) {
      .artists-card {
        align-items: flex-start;
        flex-direction: column;
        border-radius: 1.5rem;
        margin: 0 1.5rem; }
        .artists-card + * {
          margin: 2rem 1.5rem 0 1.5rem; }
        .artists-card:nth-of-type(3n+1) {
          background-color: #000;
          color: #FDFBFB; }
        .artists-card:nth-of-type(3n+2) {
          background-color: #C5ACFB; }
        .artists-card:nth-of-type(3n+3) {
          background-color: #FDFBFB; } }
    @media screen and (max-width: 765px) {
      .artists-card {
        padding: 1rem;
        margin: 0; }
        .artists-card + * {
          margin: 1rem 0 0 0; } }
    .artists-card-title {
      font-weight: 700; }
  .artists-picture {
    width: 50%;
    max-width: 520px;
    max-height: 380px;
    margin-right: 4rem;
    flex-shrink: 0;
    border-radius: 1.5rem;
    overflow: hidden; }
    @media screen and (max-width: 992px) {
      .artists-picture {
        width: 100%; } }
  .artists-image {
    width: 100%;
    object-fit: cover; }
  .artists-spacer {
    height: 50vh; }
  .artists-seo {
    margin: 0 auto 4rem auto;
    padding: 0 1.5rem;
    width: 100%;
    max-width: 30rem; }
  .artists-gallery {
    max-width: 100vw;
    margin-left: auto !important;
    margin-right: auto !important;
    width: 100%;
    margin: 10vh auto;
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    grid-auto-rows: 40vh 45vh 50vh 60vh;
    gap: 1rem; }
    @media screen and (max-width: 765px) {
      .artists-gallery {
        max-width: 100vw; } }
    @media screen and (max-width: 765px) {
      .artists-gallery {
        grid-template-columns: 1fr;
        grid-auto-rows: 300px; } }
    .artists-gallery-picture {
      overflow: hidden;
      border-radius: 1.5rem;
      width: 100%;
      height: 100%;
      grid-column: span 2; }
      @media screen and (max-width: 765px) {
        .artists-gallery-picture {
          grid-column: span 1; } }
      .artists-gallery-picture:is(:nth-child(1), :nth-child(5), :nth-child(7), :nth-child(11),
      :nth-child(13), :nth-child(17), :nth-child(19), :nth-child(23), :nth-child(25)) {
        grid-column: span 3;
        grid-row: span 2; }
        @media screen and (max-width: 765px) {
          .artists-gallery-picture:is(:nth-child(1), :nth-child(5), :nth-child(7), :nth-child(11),
          :nth-child(13), :nth-child(17), :nth-child(19), :nth-child(23), :nth-child(25)) {
            grid-column: span 1; } }
    .artists-gallery-image {
      width: 100%;
      height: 100%;
      object-fit: cover; }
    .artists-gallery-blank {
      grid-column: span 2; }
      @media screen and (max-width: 765px) {
        .artists-gallery-blank {
          display: none; } }

.homepage {
  width: 100%; }
  .homepage-logo {
    height: 80vh;
    display: grid;
    place-items: center; }
    .homepage-logo-svg {
      width: 15%;
      min-width: 10rem;
      height: auto;
      opacity: 0;
      margin: 5em 0 0 0;
      filter: blur(20px);
      animation: appear_blur 1s ease-in-out 1s forwards; }
  .homepage-hero {
    width: 100%;
    height: 200vh;
    overflow: hidden;
    position: relative; }
  .homepage-keywords {
    font-weight: 700;
    text-transform: uppercase;
    font-size: clamp(2rem, 4vw, 6rem);
    position: absolute;
    top: 2rem;
    left: 0;
    transform: translateY(10rem);
    z-index: 2;
    white-space: nowrap; }
  .homepage-wrapper {
    --radius: 7px;
    position: relative;
    height: 100vh;
    clip-path: inset(10% 2rem round var(--radius));
    transition: clip-path 0.8s cubic-bezier(0.23, 1, 0.32, 1);
    overflow: hidden; }
    @media screen and (max-width: 765px) {
      .homepage-wrapper {
        clip-path: inset(10% 1rem 1rem 1rem); } }
  .homepage-intro {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    transition: clip-path 0.8s cubic-bezier(0.23, 1, 0.32, 1); }
    .homepage-intro.first {
      margin: 30vh auto 30vh auto; }
    .homepage-intro.last {
      margin: 10vh auto 0 auto; }
    @media screen and (max-width: 765px) {
      .homepage-intro {
        width: 100%;
        padding: 0 3rem; } }
    .homepage-intro-title {
      font-size: 3rem;
      color: #FDFBFB;
      text-align: center;
      margin: 1rem 0;
      text-shadow: 0 0 10px rgba(0, 0, 0, 0.1); }
      @media screen and (max-width: 765px) {
        .homepage-intro-title {
          font-size: 2rem; } }
      @media screen and (max-width: 572px) {
        .homepage-intro-title {
          font-size: 1.4rem; } }
    .homepage-intro-text {
      color: #FDFBFB;
      text-transform: uppercase;
      font-weight: 700;
      font-size: 1.3rem;
      text-align: center; }
      @media screen and (max-width: 992px) {
        .homepage-intro-text {
          font-size: 1rem; } }
      .homepage-intro-text p {
        text-shadow: 0 0 10px rgba(0, 0, 0, 0.1); }
    .homepage-intro-subtext {
      text-transform: uppercase;
      font-weight: 300;
      text-align: center;
      font-family: "Space Mono", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; }
    .homepage-intro-link {
      margin: 3rem 0 0 0; }
    .homepage-intro-video {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      z-index: -2;
      object-fit: cover;
      background-color: #000;
      border-radius: 7px; }
      @media screen and (max-width: 992px) {
        .homepage-intro-video {
          pointer-events: none; } }
    .homepage-intro-image {
      z-index: 4;
      width: 100%;
      height: 100%;
      object-fit: cover;
      transition: opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1);
      border-radius: 7px; }
      @media screen and (max-width: 992px) {
        .homepage-intro-image {
          pointer-events: none; } }
  .homepage-gallery {
    position: relative;
    height: 100vh;
    margin: 15vh auto; }
    @media screen and (max-width: 992px) {
      .homepage-gallery {
        height: 50vh; } }
    .homepage-gallery-picture {
      position: absolute;
      overflow: hidden;
      border-radius: 20px;
      width: 35rem; }
      @media screen and (max-width: 1920px) {
        .homepage-gallery-picture {
          width: 22rem; } }
      @media screen and (max-width: 992px) {
        .homepage-gallery-picture {
          width: 12rem; } }
      .homepage-gallery-picture:first-of-type {
        position: absolute;
        aspect-ratio: 1/1;
        top: calc(50% - 350px);
        left: calc(50% - 350px);
        width: 35rem; }
        @media screen and (min-width: 1921px) {
          .homepage-gallery-picture:first-of-type {
            top: calc(50% - 500px);
            left: calc(50% - 500px);
            width: 50rem; } }
        @media screen and (max-width: 992px) {
          .homepage-gallery-picture:first-of-type {
            width: 25rem;
            top: calc(50% - 250px);
            left: calc(50% - 250px); } }
        @media screen and (max-width: 572px) {
          .homepage-gallery-picture:first-of-type {
            width: calc(100% - 2rem);
            top: 0;
            left: 1rem; } }
      .homepage-gallery-picture:nth-of-type(3n+2) {
        left: 5%;
        bottom: 35%;
        aspect-ratio: 4/3; }
        @media screen and (max-width: 572px) {
          .homepage-gallery-picture:nth-of-type(3n+2) {
            display: none; } }
      .homepage-gallery-picture:last-of-type {
        position: absolute;
        top: 0;
        right: 5%;
        aspect-ratio: 16/9; }
        @media screen and (min-width: 1921px) {
          .homepage-gallery-picture:last-of-type {
            top: -10%; } }
        @media screen and (max-width: 572px) {
          .homepage-gallery-picture:last-of-type {
            display: none; } }
    .homepage-gallery-image {
      width: 100%;
      height: 100%;
      object-fit: cover; }
  .homepage-spacer {
    height: 250vh; }
  .homepage-paragraphs {
    max-width: 100vw;
    margin-left: auto !important;
    margin-right: auto !important;
    width: 100%;
    position: relative;
    color: var(--font-color);
    display: flex;
    flex-direction: column; }
    @media screen and (max-width: 765px) {
      .homepage-paragraphs {
        max-width: 100vw; } }
    .homepage-paragraphs-first {
      grid-template-columns: 1fr 1fr; }
    @media screen and (min-width: 1281px) {
      .homepage-paragraphs-second {
        margin-bottom: 0 !important; } }
    .homepage-paragraphs-first, .homepage-paragraphs-second {
      display: grid;
      min-height: 80vh;
      gap: 8rem;
      position: relative;
      z-index: 2; }
      @media screen and (min-width: 1921px) {
        .homepage-paragraphs-first, .homepage-paragraphs-second {
          gap: 12rem; } }
      @media screen and (min-width: 1281px) {
        .homepage-paragraphs-first, .homepage-paragraphs-second {
          margin: 20vh 0; } }
      @media screen and (max-width: 992px) {
        .homepage-paragraphs-first, .homepage-paragraphs-second {
          grid-template-columns: 1fr;
          min-height: auto;
          gap: 4rem;
          margin: 4rem 0 0 0; } }
    .homepage-paragraphs-column {
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: flex-start; }
      .homepage-paragraphs-column:first-of-type {
        align-items: flex-end; }
        @media screen and (max-width: 765px) {
          .homepage-paragraphs-column:first-of-type {
            align-items: flex-start; } }
        .homepage-paragraphs-column:first-of-type .homepage-paragraphs-title {
          text-align: right; }
        .homepage-paragraphs-column:first-of-type p {
          text-align: right; }
          @media screen and (max-width: 765px) {
            .homepage-paragraphs-column:first-of-type p {
              text-align: left; } }
    .homepage-paragraphs-title {
      font-weight: 700;
      text-transform: uppercase;
      font-size: 1.3rem;
      margin: 0 0 2rem 0; }
    .homepage-paragraphs-button {
      display: flex;
      justify-content: flex-start;
      align-items: center;
      margin: 2rem 0 0 0; }
      @media screen and (min-width: 1281px) {
        .homepage-paragraphs-button {
          margin: 4rem 0 0 0; } }
      @media screen and (min-width: 1921px) {
        .homepage-paragraphs-button {
          margin: 8rem 0 0 0; } }
  .homepage-prestations {
    height: 350vh;
    position: relative;
    overflow: hidden; }
    @media screen and (max-width: 765px) {
      .homepage-prestations {
        height: 300vh; } }
    .homepage-prestations-wrapper {
      width: 100%;
      height: 100vh;
      position: relative;
      z-index: 2;
      display: flex;
      justify-content: flex-end;
      align-items: flex-start; }
    .homepage-prestations-title {
      font-size: clamp(1.2rem, 6vw, 6rem);
      font-weight: 700;
      text-align: center;
      width: 100%;
      opacity: 0;
      transition: opacity 1.4s cubic-bezier(0.23, 1, 0.32, 1), transform 1.4s cubic-bezier(0.23, 1, 0.32, 1);
      color: var(--font-color);
      position: absolute;
      top: 10%;
      left: 50%;
      transform: translate(-50%) scale(1.2);
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center; }
      .active .homepage-prestations-title {
        transform: translate(-50%, 0) scale(1);
        opacity: 1; }
      .homepage-prestations-title span {
        text-transform: uppercase;
        font-size: 1.2rem; }
    .homepage-prestations-presta {
      position: relative;
      width: 700px;
      display: flex;
      flex-direction: column;
      justify-content: flex-start;
      align-items: flex-start;
      transition: transform 1.4s cubic-bezier(0.23, 1, 0.32, 1); }
      @media screen and (max-width: 992px) {
        .homepage-prestations-presta {
          width: 350px; } }
      .homepage-prestations-presta.active {
        z-index: 4;
        transform: scale(1.2); }
        .homepage-prestations-presta.active .homepage-prestations-picture {
          filter: grayscale(0) brightness(80%); }
        .homepage-prestations-presta.active .homepage-prestations-desc {
          opacity: 1;
          transform: scale(1); }
        .homepage-prestations-presta.active .homepage-prestations-type,
        .homepage-prestations-presta.active .homepage-prestations-location {
          opacity: 1;
          transform: translateY(0); }
    .homepage-prestations-picture {
      display: block;
      overflow: hidden;
      border-radius: 1.5rem;
      width: 100%;
      height: 22rem;
      position: relative;
      transition: opacity 1.4s cubic-bezier(0.23, 1, 0.32, 1), filter 1.4s cubic-bezier(0.23, 1, 0.32, 1);
      filter: grayscale(100%) brightness(0.5); }
      @media screen and (max-width: 992px) {
        .homepage-prestations-picture {
          height: 12rem; } }
    .homepage-prestations-image {
      width: 100%;
      height: 100%;
      object-fit: cover; }
    .homepage-prestations-list {
      width: auto;
      z-index: 2;
      display: flex;
      justify-content: flex-start;
      align-items: flex-start;
      gap: 6rem;
      margin: 0 2rem 0 0;
      padding-right: 20vw; }
    .homepage-prestations-titles {
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      transition: transform 1.4s cubic-bezier(0.23, 1, 0.32, 1);
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center; }
    .homepage-prestations-desc {
      font-size: 2rem;
      font-weight: 700;
      line-height: 1.1;
      text-align: center;
      width: 100%;
      z-index: 2;
      will-change: transform;
      margin: 1rem 0;
      transform: scale(1.2);
      opacity: 0;
      transition: transform 0.8s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1); }
      @media screen and (max-width: 992px) {
        .homepage-prestations-desc {
          font-size: .8rem; } }
      @media screen and (min-width: 1921px) {
        .homepage-prestations-desc {
          font-size: 2rem; } }
    .homepage-prestations-type {
      border: 1px solid #FDFBFB;
      border-radius: 40px;
      padding: .25rem 1rem;
      text-transform: uppercase;
      font-size: .6rem;
      opacity: 0;
      transform: translateY(-1rem);
      transition: transform 0.8s cubic-bezier(0.23, 1, 0.32, 1) 0.4s, opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1) 0.4s;
      text-align: center; }
      @media screen and (max-width: 765px) {
        .homepage-prestations-type {
          font-size: .5rem; } }
    .homepage-prestations-location {
      opacity: 0;
      transform: translateY(1rem);
      transition: transform 0.8s cubic-bezier(0.23, 1, 0.32, 1) 0.4s, opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1) 0.4s;
      text-transform: uppercase; }
      @media screen {
        .homepage-prestations-location {
          font-size: .5rem;
          text-align: center; } }

#canvasContainer {
  z-index: 4;
  width: 100%;
  height: 100%;
  transition: opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1); }
  @media screen and (max-width: 992px) {
    #canvasContainer {
      pointer-events: none; } }

#canvasContainer img {
  visibility: hidden;
  pointer-events: none;
  position: absolute; }

@use "sass:math";
.prestations {
  display: flex;
  flex-direction: column; }
  .prestations-header {
    max-width: 100vw;
    margin-left: auto !important;
    margin-right: auto !important;
    width: 100%; }
    @media screen and (max-width: 765px) {
      .prestations-header {
        max-width: 100vw; } }
  .prestations-container {
    display: flex;
    flex-direction: column;
    max-width: 1920px;
    padding-top: 15vh; }
  .prestations-presta {
    position: relative;
    height: 150vh;
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-template-rows: repeat(16, 1fr); }
    @media screen and (min-width: 1921px) {
      .prestations-presta {
        height: 100vh; } }
    @media screen and (max-width: 765px) {
      .prestations-presta {
        grid-template-columns: 1fr;
        grid-template-rows: auto;
        height: auto;
        gap: 1em; } }
    @media screen and (min-width: 766px) {
      .prestations-presta:nth-of-type(4n+1) {
        margin: 5rem 0 0 0; }
        .prestations-presta:nth-of-type(4n+1) .prestations-presta-main {
          grid-column: 5/span 4;
          grid-row: 1 / span 8; }
        .prestations-presta:nth-of-type(4n+1) .prestations-presta-pic:nth-of-type(4n + 1) {
          grid-column: 1/span 3;
          grid-row: 8 / span 6; }
        .prestations-presta:nth-of-type(4n+1) .prestations-presta-pic:nth-of-type(4n + 2) {
          grid-column: 3/span 3;
          grid-row: 4 / span 6;
          z-index: -1; }
        .prestations-presta:nth-of-type(4n+1) .prestations-presta-pic:nth-of-type(4n + 3) {
          grid-column: 8/span 3;
          grid-row: 2 / span 6; }
        .prestations-presta:nth-of-type(4n+1) .prestations-presta-pic:nth-of-type(4n + 4) {
          grid-column: 10/span 3;
          grid-row: 7 / span 6; }
      .prestations-presta:nth-of-type(4n+2) .prestations-presta-main {
        grid-column: 8/span 4;
        grid-row: 2 / span 8; }
      .prestations-presta:nth-of-type(4n+2) .prestations-presta-pic:nth-of-type(4n + 1) {
        grid-column: 1/span 3;
        grid-row: 10 / span 6; }
      .prestations-presta:nth-of-type(4n+2) .prestations-presta-pic:nth-of-type(4n + 2) {
        grid-column: 3/span 4;
        grid-row: 8 / span 6;
        z-index: -1; }
      .prestations-presta:nth-of-type(4n+2) .prestations-presta-pic:nth-of-type(4n + 3) {
        grid-column: 6/span 3;
        grid-row: 6 / span 6;
        z-index: 0; }
      .prestations-presta:nth-of-type(4n+2) .prestations-presta-pic:nth-of-type(4n + 4) {
        grid-column: 10 / span 3;
        grid-row: 9 / span 6; }
      .prestations-presta:nth-of-type(4n+3) {
        margin: 5rem 0 0 0; }
        .prestations-presta:nth-of-type(4n+3) .prestations-presta-main {
          grid-column: 3/span 4;
          grid-row: 2 / span 8; }
        .prestations-presta:nth-of-type(4n+3) .prestations-presta-pic:nth-of-type(4n + 1) {
          grid-column: 1/span 3;
          grid-row: 6 / span 6;
          z-index: 1; }
        .prestations-presta:nth-of-type(4n+3) .prestations-presta-pic:nth-of-type(4n + 2) {
          grid-column: 6/span 3;
          grid-row: 7 / span 6; }
        .prestations-presta:nth-of-type(4n+3) .prestations-presta-pic:nth-of-type(4n + 3) {
          grid-column: 7/span 3;
          grid-row: 5 / span 6;
          z-index: -1; }
        .prestations-presta:nth-of-type(4n+3) .prestations-presta-pic:nth-of-type(4n + 4) {
          grid-column: 9/span 3;
          grid-row: 4 / span 6;
          z-index: -2; }
      .prestations-presta:nth-of-type(4n+4) .prestations-presta-main {
        grid-column: 8/span 4;
        grid-row: 5 / span 8; }
      .prestations-presta:nth-of-type(4n+4) .prestations-presta-pic:nth-of-type(4n + 1) {
        grid-column: 1/span 3;
        grid-row: 2 / span 6;
        z-index: 2; }
      .prestations-presta:nth-of-type(4n+4) .prestations-presta-pic:nth-of-type(4n + 2) {
        grid-column: 3/span 3;
        grid-row: 4 / span 6;
        z-index: 1; }
      .prestations-presta:nth-of-type(4n+4) .prestations-presta-pic:nth-of-type(4n + 3) {
        grid-column: 5/span 3;
        grid-row: 6 / span 6;
        z-index: 0; }
      .prestations-presta:nth-of-type(4n+4) .prestations-presta-pic:nth-of-type(4n + 4) {
        grid-column: 10/span 3;
        grid-row: 1 / span 6; } }
    .prestations-presta-title {
      font-size: 2rem; }
    .prestations-presta-main {
      position: relative;
      width: 100%;
      height: 100%;
      display: flex;
      flex-direction: column;
      justify-content: flex-end;
      align-items: flex-start;
      border-radius: 7px;
      overflow: hidden;
      padding: 4rem;
      z-index: 2; }
      @media screen and (max-width: 765px) {
        .prestations-presta-main {
          width: 100%;
          height: 500px;
          padding: 2rem 1rem; } }
    .prestations-presta-picture {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      z-index: -1;
      filter: brightness(15%);
      display: block; }
    .prestations-presta-image {
      width: 100%;
      height: 100%;
      object-fit: cover; }
    .prestations-presta-pic {
      position: absolute;
      z-index: 0;
      border-radius: 7px;
      overflow: hidden;
      transition: scale 0.8s cubic-bezier(0.23, 1, 0.32, 1);
      max-width: calc(min(25vw, 30rem));
      max-height: 25rem; }
      @media screen and (min-width: 1921px) {
        .prestations-presta-pic {
          max-height: 30rem; } }
      @media screen and (max-width: 992px) {
        .prestations-presta-pic {
          width: calc(min(40vw, 20rem)); } }
      @media screen and (max-width: 765px) {
        .prestations-presta-pic {
          position: relative;
          width: 100%;
          max-width: 100%;
          max-height: 15em; } }
      @media screen and (max-width: 572px) {
        .prestations-presta-pic {
          display: none; } }
    @media screen and (max-width: 765px) {
      .prestations-presta-text {
        font-size: .8rem; } }
  .prestations-cats {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
    margin: 10vh 0; }
    @media screen and (max-width: 765px) {
      .prestations-cats {
        grid-template-columns: 1fr; } }
  .prestations-cat {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start; }
    .prestations-cat-tile {
      width: 100%;
      display: flex;
      flex-direction: column;
      justify-content: flex-start;
      align-items: flex-start; }
      .prestations-cat-tile:hover {
        color: #FDFBFB; }
        .prestations-cat-tile:hover .prestations-cat-link {
          background-color: #FDFBFB;
          color: #000;
          border-color: #FDFBFB; }
        .prestations-cat-tile:hover .prestations-cat-picture {
          transform: scale(0.9); }
    .prestations-cat-title {
      font-size: 1.2rem;
      margin: 2rem 0 .5rem 0;
      transition: color 1.4s cubic-bezier(0.23, 1, 0.32, 1);
      min-height: 2lh; }
      @media screen and (max-width: 992px) {
        .prestations-cat-title {
          margin: 1rem 0 .5rem 0;
          font-size: 1rem; } }
    .prestations-cat-text {
      font-weight: 300;
      min-height: 12rem;
      transition: color 1.4s cubic-bezier(0.23, 1, 0.32, 1); }
      .prestations-cat-text:empty {
        display: none; }
        .prestations-cat-text:empty + .prestations-cat-link {
          margin: 1.5rem 0 0 0; }
      @media screen and (min-width: 1921px) {
        .prestations-cat-text {
          min-height: 16rem; } }
      @media screen and (max-width: 992px) {
        .prestations-cat-text {
          min-height: auto; } }
    .prestations-cat-picture {
      width: 100%;
      aspect-ratio: 9/10;
      border-radius: 20px;
      overflow: hidden;
      display: block;
      transition: transform 0.8s cubic-bezier(0.175, 0.885, 0.32, 1.275); }
    .prestations-cat-image {
      width: 100%;
      height: 100%;
      object-fit: cover; }
    .prestations-cat-link {
      transition: all 0.8s cubic-bezier(0.23, 1, 0.32, 1);
      margin: auto 0 0 0; }
      @media screen and (max-width: 765px) {
        .prestations-cat-link {
          margin: 0; } }
  .prestations-endtext {
    text-align: center;
    max-width: 45rem;
    margin: 0 auto;
    text-transform: uppercase;
    font-weight: 700;
    font-size: 1.2rem; }
    @media screen and (max-width: 765px) {
      .prestations-endtext {
        font-size: 1rem; } }

.page {
  overflow-x: hidden; }
  .page-banner {
    width: 100%;
    height: 25rem;
    position: relative;
    overflow: hidden;
    display: flex;
    justify-content: flex-start;
    align-items: flex-end;
    margin-bottom: 10vh;
    padding: 4rem 0; }
    .page-banner-picture {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: auto;
      filter: brightness(75%); }
      @media screen and (max-width: 765px) {
        .page-banner-picture {
          height: 100%; } }
    .page-banner-image {
      width: 100%;
      height: 100%;
      object-fit: cover; }
    .page-banner h1 {
      text-align: left; }
  .page-content {
    display: flex;
    flex-direction: column; }
  .page-header {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center; }
  .page-title {
    position: relative;
    z-index: 1;
    line-height: 1;
    text-align: center; }
  .page-intro {
    font-weight: 700;
    text-transform: uppercase;
    font-size: 1.4rem;
    text-align: center; }
    @media screen and (max-width: 765px) {
      .page-intro {
        font-size: 1rem; } }
  .page-texte {
    margin: 2rem 0 0 0;
    max-width: 90%; }
    .page-texte p {
      text-align: center; }
  .page--404 {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    position: relative;
    min-height: 80vh; }
    .page--404-link {
      margin: 1rem 0 0 0; }
    .page--404-number {
      position: absolute;
      font-size: clamp(4rem, 15vw, 15rem);
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      color: #000;
      z-index: -1;
      text-shadow: 0 0 40px #FDFBFB;
      animation: pulsate 1s ease-out infinite; }
      @media screen and (max-width: 992px) {
        .page--404-number {
          top: 20%; } }
    .page--404-text {
      font-family: "Space Mono", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
      text-align: center; }

@keyframes pulsate {
  0% {
    text-shadow: 0 0 25px #FDFBFB; }
  10% {
    text-shadow: 0 0 60px #FDFBFB; }
  100% {
    text-shadow: 0 0 25px #FDFBFB; } }

.realisations-list {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  margin: 4rem 0; }

.realisations-link {
  width: 100%;
  border: 3px solid #FDFBFB;
  font-weight: 700;
  font-size: 3rem;
  font-family: "Space Mono", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
  text-transform: uppercase;
  border-radius: 2.5rem;
  text-align: center;
  transition: background 0.8s cubic-bezier(0.23, 1, 0.32, 1), color 0.8s cubic-bezier(0.23, 1, 0.32, 1), border 0.8s cubic-bezier(0.23, 1, 0.32, 1), box-shadow 0.8s cubic-bezier(0.23, 1, 0.32, 1); }
  .realisations-link:hover {
    background-color: #C5ACFB;
    border-color: #C5ACFB;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.2); }
  .realisations-link:nth-of-type(even):hover {
    background-color: #FDFBFB;
    border-color: #FDFBFB; }
  @media screen and (max-width: 765px) {
    .realisations-link {
      font-size: 2rem; } }
  .realisations-link + * {
    margin: .75rem 0 0 0; }

.realisation-type {
  border: 1px solid #FDFBFB;
  border-radius: 40px;
  padding: .25rem 1rem;
  text-transform: uppercase;
  font-size: .6rem; }

.realisation-header {
  position: relative;
  margin: 0 0 4rem 0; }
  .realisation-header-wrapper {
    width: 75%;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start; }
    @media screen and (max-width: 765px) {
      .realisation-header-wrapper {
        width: 100%; } }
  .realisation-header .page-intro {
    text-align: left; }
  .realisation-header .page-texte {
    width: 50%; }
    @media screen and (max-width: 765px) {
      .realisation-header .page-texte {
        width: 100%; } }
    .realisation-header .page-texte p {
      text-align: left; }

.realisation-picture {
  position: absolute;
  top: 0;
  right: 4rem;
  z-index: -1;
  border-radius: 7px;
  overflow: hidden;
  width: 50%;
  aspect-ratio: 11/7; }
  @media screen and (max-width: 765px) {
    .realisation-picture {
      width: 15rem;
      top: 4rem;
      right: 2rem; } }

.realisation-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center; }

.flex-action {
  margin: 4rem 0;
  color: #000; }
  .flex-action-blocs {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2rem; }
    @media screen and (max-width: 992px) {
      .flex-action-blocs {
        grid-template-columns: 1fr; } }
  .flex-action-bloc {
    background-color: #D9D9D9;
    border-radius: 1.5rem;
    padding: 2rem;
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-start; }
    @media screen and (min-width: 1921px) {
      .flex-action-bloc {
        padding: 2rem 4rem; } }
    .flex-action-bloc-button {
      display: flex;
      justify-content: flex-end;
      align-items: center; }
      .flex-action-bloc-button:hover .flex-action-bloc-link {
        border-color: #9747FF;
        color: #9747FF; }
    .flex-action-bloc-image {
      max-width: 100%; }
    .flex-action-bloc-link {
      color: #000;
      border-color: #000; }
    .flex-action-bloc-bottom {
      display: flex;
      justify-content: space-between;
      align-items: flex-end;
      margin: 1rem 0 0 0;
      width: 100%; }
      @media screen and (max-width: 765px) {
        .flex-action-bloc-bottom {
          flex-direction: column;
          align-items: flex-start; } }
    .flex-action-bloc-title {
      margin: 0 .5rem 0 0;
      max-width: 25rem; }
    @media screen and (max-width: 765px) {
      .flex-action-bloc-button {
        margin: 1rem 0 0 0; } }
    .flex-action-bloc svg {
      fill: #FDFBFB; }
    .flex-action-bloc .flex-action-bloc-button:hover .flex-action-bloc-link {
      border-color: #FDFBFB;
      color: #FDFBFB; }

.flex-text {
  margin: 4rem 0; }
  @media screen and (min-width: 993px) {
    .flex-text.right {
      width: 70%;
      margin: 4rem 0 4rem auto; } }
  @media screen and (min-width: 993px) {
    .flex-text.center {
      width: 60%;
      margin: 4rem auto; } }
  @media screen and (min-width: 993px) {
    .flex-text.left {
      width: 70%;
      margin: 4rem 0 4rem 0; } }
  .flex-text-surtitle {
    font-weight: 300;
    font-family: "Space Mono", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif; }
    .center .flex-text-surtitle {
      text-align: center; }
  .flex-text-title {
    font-weight: 700;
    font-size: 1.4rem;
    text-transform: uppercase; }
    @media screen and (max-width: 765px) {
      .flex-text-title {
        font-size: 1rem; } }
    .center .flex-text-title {
      text-align: center; }
    @media screen and (max-width: 765px) {
      .flex-text-title {
        font-size: 1rem; } }
  .flex-text-wrapper {
    margin: 0 auto; }
    @media screen and (min-width: 1921px) {
      .flex-text-wrapper {
        max-width: 75rem; } }
  .flex-text-2col {
    display: flex;
    gap: 8rem;
    margin: 15vh 0; }
    @media screen and (max-width: 992px) {
      .flex-text-2col {
        flex-direction: column;
        gap: 4rem; } }
    .flex-text-2col-title {
      margin-top: 0;
      display: flex;
      align-items: center;
      justify-content: space-between;
      margin: 0 0 2rem 0;
      text-align: right; }
      @media screen and (max-width: 765px) {
        .flex-text-2col-title {
          flex-direction: column; } }
      .flex-text-2col-right .flex-text-2col-title {
        flex-direction: row-reverse;
        text-align: left; }
      .flex-text-2col-title h2 {
        width: 100%;
        font-size: 1.4rem; }
        @media screen and (max-width: 765px) {
          .flex-text-2col-title h2 {
            font-size: 1rem; } }
    .flex-text-2col-button {
      display: block;
      width: 5rem;
      height: 2.5rem;
      border: 1px solid #FDFBFB;
      border-radius: 40px;
      transition: background 0.8s cubic-bezier(0.23, 1, 0.32, 1), border 0.8s cubic-bezier(0.23, 1, 0.32, 1); }
      .flex-text-2col-button:hover {
        background-color: #FDFBFB;
        border-color: #FDFBFB; }
        .flex-text-2col-button:hover svg {
          fill: #000; }
      .flex-text-2col-button svg {
        width: 100%;
        height: 100%;
        fill: #FDFBFB;
        transition: fill 0.8s cubic-bezier(0.23, 1, 0.32, 1); }
    .flex-text-2col-left .flex-text-2col-text {
      text-align: right; }

.flex-textimages {
  margin: 4rem 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-areas: "portrait text" "portrait paysage" "capleft capright"; }
  .flex-textimages.right {
    grid-template-areas: "text portrait" "paysage portrait" "capleft capright"; }
  @media screen and (max-width: 992px) {
    .flex-textimages {
      margin: 2rem 0;
      grid-template-columns: 1fr;
      grid-template-areas: "text" "portrait" "capleft" "paysage" "capright"; } }
  .flex-textimages-picture-portrait {
    grid-area: portrait;
    height: 100%;
    width: 100%;
    border-radius: 7px;
    overflow: hidden; }
    @media screen and (min-width: 1921px) {
      .flex-textimages-picture-portrait {
        max-height: 80vh; } }
  .flex-textimages-image-portrait {
    height: 100%;
    width: 100%;
    object-fit: cover; }
  .flex-textimages-picture-paysage {
    grid-area: paysage;
    width: 100%;
    border-radius: 1.5rem;
    overflow: hidden; }
  .flex-textimages-image-paysage {
    width: 100%;
    object-fit: cover; }
  .flex-textimages-wrapper {
    grid-area: text;
    padding: 2rem; }
    @media screen and (max-width: 765px) {
      .flex-textimages-wrapper {
        padding: 0 0 2rem 0; } }
  .flex-textimages-surtext {
    text-transform: uppercase; }
  .flex-textimages-bigtext {
    text-transform: uppercase;
    font-size: 1.6rem;
    font-weight: 700;
    line-height: 1.2;
    margin: 1rem 0;
    text-wrap: balance; }
    @media screen and (min-width: 1921px) {
      .flex-textimages-bigtext {
        font-size: 2.2rem; } }
  .flex-textimages-caption-right {
    font-size: .7rem;
    grid-area: capright; }
  .flex-textimages-caption-left {
    font-size: .7rem;
    grid-area: capleft; }

.flex-video {
  margin: 4rem 0;
  position: relative;
  width: 100%;
  aspect-ratio: 16/9; }
  @media screen and (min-width: 1921px) {
    .flex-video {
      aspect-ratio: 16/7; } }
  .flex-video-picture {
    width: 100%;
    height: 100%;
    position: relative;
    z-index: 2;
    border-radius: 7px;
    overflow: hidden;
    display: block; }
  .flex-video-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1); }
  .flex-video-caption {
    font-size: .7rem; }
  .flex-video-in, .flex-video-out {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1;
    background-color: #000;
    aspect-ratio: 16/9;
    border-radius: 7px;
    overflow: hidden; }
    @media screen and (min-width: 1921px) {
      .flex-video-in, .flex-video-out {
        aspect-ratio: 16/7; } }
  .flex-video-iframe {
    width: 100%;
    height: 100%;
    z-index: 0; }
  .flex-video-button {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 2;
    background-color: #000;
    display: grid;
    place-items: center;
    width: 4rem;
    height: 4rem;
    border-radius: 50%;
    transition: opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1); }
    @media screen and (min-width: 993px) {
      .flex-video-button {
        display: none; } }
  .flex-video-icon {
    fill: #FDFBFB; }

.flex-gallery {
  display: grid;
  grid-template-columns: 1fr 1fr;
  margin: 4rem 0; }
  .flex-gallery-picture {
    width: 100%; }
  .flex-gallery-image {
    width: 100%;
    height: 100%;
    object-fit: cover; }

.flex-logos {
  margin: 10vh auto;
  position: relative; }
  .flex-logos-title {
    width: 100%;
    text-align: center;
    margin: 2rem 0; }
  .flex-logos-wrapper {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
    gap: 2rem 3rem;
    justify-items: center; }
  .flex-logos-logo {
    width: auto;
    display: grid;
    place-items: center; }
  .flex-logos-image {
    filter: brightness(0) invert(1);
    height: 5rem;
    max-width: 100%;
    width: auto;
    object-fit: contain; }

.flex-chiffres {
  margin: 10vh auto; }
  .flex-chiffres-title {
    text-align: center;
    font-size: 1.4rem; }
    @media screen and (max-width: 765px) {
      .flex-chiffres-title {
        font-size: 1rem; } }
  .flex-chiffres-numbers {
    max-width: 100vw;
    margin-left: auto !important;
    margin-right: auto !important;
    width: 100%;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem; }
    @media screen and (max-width: 765px) {
      .flex-chiffres-numbers {
        max-width: 100vw; } }
    @media screen and (max-width: 765px) {
      .flex-chiffres-numbers {
        grid-template-columns: 1fr; } }
  .flex-chiffres-number {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center; }
    .flex-chiffres-number-value {
      font-size: 4rem;
      font-weight: 600;
      margin: 1rem 0; }
      @media screen and (max-width: 765px) {
        .flex-chiffres-number-value {
          margin: 0; } }
    .flex-chiffres-number-title, .flex-chiffres-number-subtitle {
      font-size: .7rem;
      text-transform: uppercase;
      font-weight: 700; }
      @media screen and (min-width: 1921px) {
        .flex-chiffres-number-title, .flex-chiffres-number-subtitle {
          font-size: 1rem; } }

@media screen and (max-width: 765px) {
  .flex-slider {
    width: calc(100% + 4rem);
    transform: translateX(-2rem); } }

.flex-slider-container {
  position: relative; }

.flex-slider-wrapper {
  position: relative; }

.flex-slider-presta {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  z-index: 1; }

.flex-slider-picture {
  display: block;
  overflow: hidden;
  border-radius: 1.5rem;
  width: 100%;
  aspect-ratio: 16/9;
  position: relative;
  transition: opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1), filter 0.8s cubic-bezier(0.23, 1, 0.32, 1);
  filter: brightness(85%); }
  @media screen and (max-width: 765px) {
    .flex-slider-picture {
      aspect-ratio: 1/1;
      border-radius: 0; } }

.flex-slider-image {
  width: 100%;
  height: 100%;
  object-fit: cover; }

.flex-slider-list {
  width: auto;
  z-index: 2;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 6rem;
  margin: 0 2rem 0 0;
  padding-right: 15rem; }

.flex-slider-titles {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transition: transform 0.8s cubic-bezier(0.23, 1, 0.32, 1);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center; }
  @media screen and (max-width: 765px) {
    .flex-slider-titles {
      width: calc(100% - 4rem); } }

.flex-slider-desc {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.1;
  text-align: center;
  width: 100%;
  z-index: 2;
  will-change: transform;
  margin: 1rem 0;
  transition: transform 0.8s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1); }
  @media screen and (max-width: 992px) {
    .flex-slider-desc {
      font-size: .8rem; } }
  @media screen and (min-width: 1921px) {
    .flex-slider-desc {
      font-size: 2rem; } }

.flex-slider-type {
  border: 1px solid #FDFBFB;
  border-radius: 40px;
  padding: .25rem 1rem;
  text-transform: uppercase;
  font-size: .6rem;
  opacity: 0;
  transform: translateY(-1rem);
  transition: transform 0.8s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1); }
  .swiper-slide-active .flex-slider-type {
    opacity: 1;
    transform: translateY(0); }

.flex-slider-location {
  transition: transform 0.8s cubic-bezier(0.23, 1, 0.32, 1), opacity 0.8s cubic-bezier(0.23, 1, 0.32, 1);
  text-transform: uppercase;
  opacity: 0;
  transform: translateY(1rem); }
  .swiper-slide-active .flex-slider-location {
    opacity: 1;
    transform: translateY(0); }

.flex-slider-button {
  background-color: #FDFBFB;
  margin: 3rem 0 0 0;
  z-index: 8; }

.flex-slider-next {
  position: absolute;
  top: 0;
  right: 0;
  height: 100%;
  width: 40%;
  z-index: 4; }

.flex-slider-prev {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 40%;
  z-index: 4; }

.flex-images {
  margin: 20vh 0; }

.flex-textdefil {
  margin: 4rem 0;
  position: relative;
  height: 8vh; }
  .flex-textdefil-text {
    font-weight: 700;
    text-transform: uppercase;
    font-size: clamp(2rem, 4vw, 6rem);
    z-index: 2;
    white-space: nowrap;
    overflow: visible;
    position: absolute;
    top: 0;
    left: 0; }

.flex-shortcode {
  max-width: 1440px;
  margin-left: auto !important;
  margin-right: auto !important;
  width: 100%; }
  @media screen and (max-width: 765px) {
    .flex-shortcode {
      max-width: 100vw; } }

