#main .menu {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
}

#main .menu a {
  cursor: pointer;
  text-decoration: none;
}

#main .menu .menu-logo {
  height: 40px;
  width: auto;
}

#main .menu.burger-enabled {
  position: relative;
  align-items: center;
}

#main .menu.burger-enabled .burger {
  display: none;
}

#main .menu.burger-enabled .menu-links {
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
}

#main.mobile .menu.burger-enabled {
  justify-content: space-between;
}

#main.mobile .menu.burger-enabled .burger {
  display: block;
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
  position: relative;
  width: 36px;
  height: 36px;
  flex-shrink: 0;
}

#main.mobile .menu.burger-enabled .burger::before,
#main.mobile .menu.burger-enabled .burger::after,
#main.mobile .menu.burger-enabled .burger span {
  content: '';
  display: block;
  width: 20px;
  height: 2px;
  background: currentColor;
  position: absolute;
  left: 8px;
  transition: transform 0.3s, opacity 0.3s;
}

#main.mobile .menu.burger-enabled .burger::before { top: 10px; }
#main.mobile .menu.burger-enabled .burger span     { top: 17px; }
#main.mobile .menu.burger-enabled .burger::after   { top: 24px; }

#main.mobile .menu.burger-enabled.open .burger::before { transform: translateY(7px) rotate(45deg); }
#main.mobile .menu.burger-enabled.open .burger span    { opacity: 0; }
#main.mobile .menu.burger-enabled.open .burger::after  { transform: translateY(-7px) rotate(-45deg); }

#main.mobile .menu.burger-enabled .menu-links {
  display: none;
  flex-direction: column;
  width: 100%;
}

#main.mobile .menu.burger-enabled.open .menu-links {
  display: flex;
}

#main.mobile .menu.burger-enabled .menu-links a {
  padding: 10px 0;
}
html #main .spacing.bot-hard {
  margin-bottom: 140px;
}

html #main .spacing.bot-medium {
  margin-bottom: 80px;
}

html #main .spacing.bot-soft {
  margin-bottom: 30px;
}

html #main .spacing.top-hard {
  margin-top: 140px;
}

html #main .spacing.top-medium {
  margin-top: 80px;
}

html #main .spacing.top-soft {
  margin-top: 30px;
}
#main .with-background-module {
  position: relative;
}

#main .with-background-module.ratio-1-1::before {
  content: '';
  display: block;
  padding-top: 100%;
}

#main .with-background-module.ratio-1-1 > * {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}

#main .with-background-module > * {
  /*position: absolute;*/
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
}
#main .with-background-module > *:not(img.image) {
  text-align: center;
/*  top: 50%;
  transform: translateY(-50%);
*/}
#main .with-background-module > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
}#main .sizer {
  max-width: var(--main-max-width);
  width: var(--main-width);

  margin-left: auto;
  margin-right: auto;

  min-height: 150px;
}



#main .sizer.height-fixed.medium {
  height: 600px;
}
#main .sizer.height-fixed.small {
  height: 400px;
}
#main .sizer.height-fixed.large {
  height: 800px;
}



#main .sizer.height-percent.small {
  height: 30vh;
}
#main .sizer.height-percent.medium {
  height: 70vh;
}
#main .sizer.height-percent.large {
  height: 100vh;
}



#main .sizer.height-content.small {
  padding: 0 0;
}
#main .sizer.height-content.medium {
  padding: 70px 0;
}
#main .sizer.height-content.large {
  padding: 140px 0;
}




#main .sizer.full {
  width: 100%;
  max-width: 100%;
}

#main .mosaic {
  display: flex;
  flex-wrap: wrap;
  text-align: center;
  margin: auto;
  height: 100%;
  width: 100%;
}
#main .mosaic.reverse {
  flex-direction: row-reverse;
}

#main .mosaic.justify-start   { justify-content: flex-start; }
#main .mosaic.justify-center  { justify-content: center; }
#main .mosaic.justify-end     { justify-content: flex-end; }
#main .mosaic.justify-between { justify-content: space-between; }
#main .mosaic.justify-around  { justify-content: space-around; }
#main .mosaic.justify-evenly  { justify-content: space-evenly; }

#main .mosaic.align-start   { align-content: flex-start; align-items: flex-start; }
#main .mosaic.align-center  { align-content: center;     align-items: center; }
#main .mosaic.align-end     { align-content: flex-end;   align-items: flex-end; }
#main .mosaic.align-between { align-content: space-between; }
#main .mosaic.align-around  { align-content: space-around; }
#main .mosaic.align-evenly  { align-content: space-evenly; }

#main .mosaic > div {
  max-width: var(--main-max-width);
  display: flex;
  margin: auto;
  flex-wrap: nowrap;
  flex-direction: row;
  justify-content: space-evenly;
}
#main .mosaic.tiny > * {
  box-sizing: border-box;
  padding: 0 10%;
}

#main .mosaic .module {
  margin: initial;
}

#main .mosaic.margin-soft > * {
  box-sizing: border-box;
  padding: 1%;
}

#main .mosaic.margin-medium > * {
  box-sizing: border-box;
  padding: 4%;
}

#main .mosaic.margin-hard > * {
  box-sizing: border-box;
  padding: 12%;
}#main .image-cards {
  border-radius: 4px;
  width: 80%;
  box-sizing: border-box;
  padding: 10px;
}

#main .image-cards img {
  width: 100%;
  max-width: var(--main-max-width);
}

#main .image-cards.horizontal {
  display: flex;
  flex-direction: row;
  align-items: center;
}


#main .image-cards.horizontal.align-top {
  align-items: flex-start;
}

#main .image-cards.horizontal.align-center {
  align-items: center;
}

#main .image-cards.horizontal.align-bottom {
  align-items: flex-end;
}

#main .image-cards.vertical {
  display: flex;
  flex-direction: column;
  align-items: center;
}

#main .image-cards.vertical.reverse {
  flex-direction: column-reverse;
}

#main .image-cards.horizontal > * {
  width: 50%;
  box-sizing: border-box;
}


#main .image-cards.horizontal.reverse {
  flex-direction: row-reverse;
}


#main .image-cards.horizontal.gap-light {
  gap: 15px;
}

#main .image-cards.horizontal.gap-medium {
  gap: 30px;
}

#main .image-cards.horizontal.gap-strong {
  gap: 50px;
}

#main .image-cards.vertical.gap-light {
  gap: 15px;
}

#main .image-cards.vertical.gap-medium {
  gap: 30px;
}

#main .image-cards.vertical.gap-strong {
  gap: 50px;
}


#main .image-cards.image-height-light img {
  height: 250px;
  object-fit: cover;
  object-position: center;
}

#main .image-cards.image-height-medium img {
  height: 400px;
  object-fit: cover;
  object-position: center;
}

#main .image-cards.image-height-strong img {
  height: 600px;
  object-fit: cover;
  object-position: center;
}


@media (max-width: var(--mobile-breakpoint, 760px)) {
  #main .image-cards.horizontal {
    flex-direction: column;
  }

  #main .image-cards.horizontal > * {
    width: 100%;
  }

  #main .image-cards.horizontal.reverse.reverse-horizontal-only {
    flex-direction: column;
  }

  #main .image-cards.horizontal.reverse:not(.reverse-horizontal-only) {
    flex-direction: column-reverse;
  }
}#main .br {
  width: var(--main-max-width);
  background-color: pink;
}#main .bloc-image {
  text-align: center;
  width: 100%;
  font-size: 0;
}

#main .bloc-image img {
  max-width: 100%;
}#main .title {
  text-align: center;
}
#main .bold {
  font-weight: bold;
}#main .image-text {
  display: flex;
  justify-content: center;
  flex-direction: row;
  align-items: flex-start;
}
#main .image-text.reverse {
  flex-direction: row-reverse;
}

#main .image-text-image,
#main .image-text-text {
  width: 50%;
}

#main .image-text-image img {
  width: 100%;
  height: auto;
  object-fit: contain;
}

#main .image-text > .basic-text {
  padding: 0 20px;
}

#main .image-text.gap-soft {
  gap: 15px;
}

#main .image-text.gap-medium {
  gap: 30px;
}

#main .image-text.gap-hard {
  gap: 50px;
}


#main:not(.mobile) .image-text.image-same-height {
  align-items: stretch;
}

#main:not(.mobile) .image-text.image-same-height .image-text-image {
  position: relative;
  height: 100%;
}

#main:not(.mobile) .image-text.image-same-height .image-text-image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}



#main .image-text .title {
  text-align: center;
}
#main .image-text > .basic-text {
  padding: 0 20px;
}

#main.mobile .image-text:not(.mobile-horizontal) .image-text-image,
#main.mobile .image-text:not(.mobile-horizontal) .image-text-text {
  width: 100%;
}

#main.mobile .image-text:not(.mobile-horizontal):not(.text-in-image) {
  flex-direction: column;
}


#main .image-text.text-in-image {
  position: relative;
  width: 100%;
  overflow: hidden;
}

#main .image-text.text-in-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

#main .image-text.text-in-image.ratio-1-1::before {
  content: '';
  display: block;
  padding-top: 100%;
}

#main .image-text.text-in-image .image-text-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  box-sizing: border-box;
}

#main .image-text.text-in-image .image-text-overlay > * {
  width: 100%;
  text-align: center;
}#features .scroll-button-container {
  position: fixed;
  bottom: 20px;
  z-index: 9999;
  padding: 10px;
}

#features .scroll-button-container.placement-right {
  right: 20px;
  left: auto;
}

#features .scroll-button-container.placement-left {
  left: 20px;
  right: auto;
}

#features .scroll-button-container.placement-center {
  left: 50%;
  right: auto;
  transform: translateX(-50%);
}

#features .scroll-button {
  width: 60px;
  height: 60px;
  border: none;
  border-radius: 50%;
  background: #3b82f6;
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: transform 0.2s ease, background 0.2s ease;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

#features .scroll-button:hover {
  transform: scale(1.1);
  background: #2563eb;
}

#features .scroll-button-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}

#features .scroll-button-default {
  color: white;
  font-size: 24px;
}

#features .scroll-button-default.scroll-to-top {
  display: none;
}

#features .scroll-button-container {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease;
}

#features .scroll-button-container.visible {
  opacity: 1;
  visibility: visible;
  animation: scrollButtonFadeIn 0.3s ease forwards;
}

@keyframes scrollButtonFadeIn {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

#features .scroll-button-container.placement-center.visible {
  animation: scrollButtonFadeInCenter 0.3s ease forwards;
}

@keyframes scrollButtonFadeInCenter {
  from {
    opacity: 0;
    transform: translateX(-50%) translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
  }
}