:root {
  --_colors---text-primary: #082b39;
  --_colors---text-secondary: white;
  --_colors---blue-background-dark: #6ec1e3;
  --_colors---white-background-light: white;
  --_colors---blue-background-light: #ace1f7;
  --_colors---black-background-light: #07232e;
  --_colors---black-background-dark: #041015;
  --_colors---white-background-dark: #ebebe7;
  --color-text: var(--_colors---text-primary);
}

h1 {
  filter: none;
  text-shadow: 0 2px 10px #07232e40;
  margin-top: 0;
  margin-bottom: 0;
  font-family: Instrumentserif, Arial, sans-serif;
  font-size: 2.75rem;
  font-weight: 400;
  line-height: 1;
}

h2 {
  filter: drop-shadow(0 2px 5px #00000026);
  margin-top: 0;
  margin-bottom: 0;
  font-family: Instrumentserif, Arial, sans-serif;
  font-size: 2.5rem;
  font-weight: 400;
  line-height: 1;
}

h3 {
  margin-top: 0;
  margin-bottom: 0;
  font-family: Instrumentserif, Arial, sans-serif;
  font-size: 1.3rem;
  font-weight: 400;
  line-height: 1.3;
}

.w-layout-grid {
  grid-row-gap: 16px;
  grid-column-gap: 16px;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  display: grid;
}

.paragraph {
  max-width: 600px;
  color: var(--_colors---text-primary);
  letter-spacing: -.3px;
  overflow-wrap: normal;
  margin-bottom: 0;
  font-size: 1rem;
  font-weight: 300;
  line-height: 1.5;
  display: block;
  position: static;
}

.paragraph.align-center {
  text-align: center;
}

.paragraph.ml {
  max-width: 800px;
}

.paragraph.white {
  color: var(--_colors---text-secondary);
}

.paragraph.white._70--opacity {
  opacity: .7;
  opacity: .7;
  max-width: 600px;
}

.paragraph._70--opacity {
  opacity: .7;
}

.span-heading {
  color: #000;
  margin-top: 0;
  margin-bottom: 0;
  font-family: Instrumentserif, Arial, sans-serif;
  font-size: 6vw;
  font-style: italic;
  font-weight: 400;
  line-height: 1;
}

.span-heading.h4 {
  opacity: .5;
  color: var(--_colors---text-secondary);
  font-size: 1.4rem;
}

.span-heading.contact-h1 {
  opacity: .5;
}

.span-heading.default-h1 {
  opacity: .5;
  font-size: 3vw;
}

.span-heading.expertises-solutions {
  opacity: .5;
  color: var(--_colors---text-secondary);
  font-size: 1.5rem;
  font-weight: 400;
}

.span-heading.h2 {
  opacity: .5;
  font-size: 2.4rem;
}

.span-heading.h2.secondary {
  color: var(--_colors---text-secondary);
  font-weight: 400;
}

.main-wrapper {
  overflow: clip;
}

.body {
  color: var(--_colors---text-primary);
  font-family: Satoshi, Arial, sans-serif;
}

.navbar-container {
  justify-content: space-between;
  align-items: center;
  max-width: 120rem;
  margin-left: auto;
  margin-right: auto;
  padding: .5rem 3rem;
  display: flex;
}

.nav-menu {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  justify-content: flex-end;
  align-items: center;
  display: flex;
}

.logo-wrapper {
  justify-content: center;
  align-items: center;
  display: flex;
}

.nav-link-page-wrapper {
  align-items: center;
  display: flex;
}

.logo {
  height: 2rem;
}

.logo.white-background {
  height: 4rem;
}

.link-page {
  color: #f9f8f6;
  text-transform: uppercase;
  padding-left: 14px;
  padding-right: 14px;
}

.link-page.w--current {
  color: #fff;
}

.link-page._2.white-background, .link-page._1.white-background, .link-page._3.white-background, .link-page._2.white-background, .link-page._1.white-background, .link-page._3.white-background {
  color: var(--_colors---text-primary);
}

.navbar {
  background-color: #ddd0;
  position: fixed;
  inset: 0% 0% auto;
}

.hp-hero-section {
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-end;
  width: 100%;
  min-height: 100vh;
  text-decoration: none;
  display: flex;
  position: sticky;
  top: 0;
  overflow: hidden;
}

.hp-hero-image {
  object-fit: cover;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100vh;
  text-decoration: none;
  display: flex;
  position: absolute;
  left: 0;
}

.hp-hero-content-wrapper {
  z-index: 2;
  justify-content: space-between;
  align-items: flex-end;
  width: 100%;
  max-width: 120rem;
  margin-left: auto;
  margin-right: auto;
  padding-bottom: 3rem;
  padding-left: 3rem;
  padding-right: 3rem;
  text-decoration: none;
  display: flex;
  position: absolute;
  inset: auto 0% 0%;
}

.hp-hero-col-left {
  grid-row-gap: 8px;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-start;
  width: 100%;
  padding-right: 8px;
  text-decoration: none;
  display: flex;
}

.hp-h1 {
  color: #e5e5e5;
  letter-spacing: -1px;
  text-shadow: 0 4px 20px #ffffff26;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 3vw;
  font-weight: 400;
  line-height: 1.3;
  text-decoration: none;
}

.frame-1410132487 {
  grid-row-gap: 20px;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-start;
  width: 100%;
  max-width: 530px;
  text-decoration: none;
  display: flex;
}

.hp-hero-dark-overlay {
  z-index: 1;
  background-image: linear-gradient(0deg, #000, #0000005c 22%, #0000);
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.hp-probl-me-section {
  z-index: 2;
  grid-row-gap: 10px;
  background-image: linear-gradient(#fff, #ebebe7);
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  min-height: 67vh;
  margin-left: auto;
  margin-right: auto;
  padding: 0;
  text-decoration: none;
  display: flex;
  position: relative;
}

.white-ellipse {
  z-index: -1;
  object-fit: cover;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 418px;
  height: 421px;
  text-decoration: none;
  display: flex;
  position: absolute;
  top: 101px;
  left: 120px;
}

.container {
  grid-row-gap: 0px;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  max-width: 120rem;
  padding-left: 3rem;
  padding-right: 3rem;
  text-decoration: none;
  display: flex;
}

.container.grow-if-possible {
  flex: 1;
}

.container.no-max-width {
  max-width: none;
}

.heading-wrapper-vertical {
  grid-row-gap: 10px;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  max-width: 500px;
  text-decoration: none;
  display: flex;
}

.heading-wrapper-vertical.relative {
  z-index: 1;
  position: relative;
}

.hp-solutions-grid {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  margin-top: 1rem;
  text-decoration: none;
  display: grid;
}

.hp-probl-me-block {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  background-color: #fff;
  border-radius: 16px;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  max-width: 430px;
  height: 130px;
  padding: 20px 24px 28px;
  text-decoration: none;
  display: flex;
  box-shadow: 0 4px 20px #0000001a;
}

.hp-probl-me-block.dark-bck {
  background-image: linear-gradient(180deg, var(--_colors---black-background-dark), var(--_colors---black-background-light));
  color: var(--_colors---text-secondary);
  background-image: linear-gradient(180deg, var(--_colors---black-background-dark), var(--_colors---black-background-light));
}

.probl-me-h3 {
  opacity: .7;
  text-align: center;
  letter-spacing: -.015em;
  width: 100%;
  margin-top: 0;
  margin-bottom: 0;
  font-family: Satoshi, Arial, sans-serif;
  font-size: 14px;
  font-weight: 300;
  line-height: 1.4;
  text-decoration: none;
}

.h2 {
  filter: none;
  letter-spacing: -.7px;
  text-shadow: 0 1px 10px #0000001a;
  max-width: 480px;
  line-height: 1.2;
}

.h2.align-center {
  text-align: center;
}

.h2.secondary {
  color: var(--_colors---text-secondary);
  text-shadow: 0 1px 20px #ffffff40;
}

.quote {
  opacity: 1;
  height: 1.3rem;
}

.spacer {
  width: 100%;
}

.spacer.medium {
  height: 4rem;
}

.spacer.high {
  height: 7rem;
}

.spacer.low {
  height: 2.5rem;
}

.hp-solutions-section {
  background-color: #fff;
  background-image: linear-gradient(180deg, var(--_colors---white-background-dark), white);
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-end;
  width: 100%;
  min-height: 80vh;
  padding-bottom: 8rem;
  text-decoration: none;
  display: flex;
  position: relative;
}

.heading-wrapper-horizontal {
  z-index: 1;
  grid-row-gap: 10px;
  flex-flow: row;
  justify-content: space-between;
  align-items: flex-end;
  width: 100%;
  padding: 0;
  text-decoration: none;
  display: flex;
  position: relative;
}

.horizontal-wrapper-col-left {
  grid-row-gap: 8px;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-start;
  width: 100%;
  max-width: 530px;
  padding-right: 8px;
  text-decoration: none;
  display: flex;
}

.horizontal-wrapper-col-right {
  grid-row-gap: 20px;
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-start;
  max-width: 600px;
  text-decoration: none;
  display: flex;
}

.rectangle-112 {
  object-fit: cover;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 418px;
  height: 421px;
  text-decoration: none;
  display: flex;
  position: absolute;
  top: 18px;
  left: 432px;
}

.spacer-line {
  grid-row-gap: 10px;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 140%;
  padding: 60px 55px;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.rectangle-1223 {
  object-fit: cover;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 1px;
  text-decoration: none;
  display: flex;
}

.hp-solutions-dark-block {
  background-image: linear-gradient(#071419, #08232d);
  min-height: 45vh;
  position: absolute;
  inset: auto 0% 0%;
  overflow: hidden;
}

.button-dark {
  background-color: var(--_colors---black-background-light);
  -webkit-backdrop-filter: blur(3px);
  backdrop-filter: blur(3px);
  color: #ffffffd9;
  background-image: linear-gradient(#14272d, #3c5d6b);
  border: 1px solid #ffffff4d;
  border-radius: 12px;
  padding: 8px 14px;
  box-shadow: 0 2px 40px #00000059;
}

.solutions-overlay {
  z-index: 1;
  object-fit: cover;
  background-image: linear-gradient(#fff0 53%, #000c 96%);
  width: 100%;
  height: 100%;
  padding: 1.5rem;
  position: absolute;
  inset: 0%;
}

.button-light {
  background-color: var(--_colors---white-background-light);
  background-image: linear-gradient(180deg, var(--_colors---white-background-light), #bcd0d9);
  -webkit-backdrop-filter: blur(3px);
  backdrop-filter: blur(3px);
  color: var(--_colors---text-primary);
  border: 1px solid #ffffff4d;
  border-radius: 12px;
  padding: 8px 14px;
  box-shadow: 0 2px 40px #00000059;
}

.button-wrapper {
  padding-top: .5rem;
}

.button-wrapper.no-padding {
  padding-top: 0;
}

.button-wrapper.navbar-btn {
  display: none;
}

.hp-ecosysteme-section {
  grid-row-gap: 40px;
  background-image: linear-gradient(0deg, #fff, #ebebe7);
  border: 0 solid #0000000d;
  border-top-width: 1px;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  padding: 0;
  text-decoration: none;
  display: flex;
  position: relative;
}

.rectangle-1225 {
  object-fit: cover;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 418px;
  height: 421px;
  text-decoration: none;
  display: flex;
  position: absolute;
  top: 76px;
  left: 73px;
}

.ecocsyst-me-circle-img {
  z-index: 0;
  height: 70vw;
  position: relative;
}

.ecosyst-me-img-wrapper {
  flex: 1;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  margin-top: -6rem;
  display: flex;
  position: relative;
  overflow: visible;
}

.ecosyst-me-job {
  grid-column-gap: 11.2136px;
  background-color: #fff;
  border-radius: 13.4564px;
  flex: 0 auto;
  justify-content: center;
  align-items: center;
  padding: 8.97091px 15.6991px;
  text-decoration: none;
  display: flex;
  position: absolute;
  inset: 22% auto auto 27%;
  box-shadow: 0 4.48545px 10px #0000001f;
}

.ecosyst-me-job._2 {
  background-image: linear-gradient(180deg, var(--_colors---black-background-dark), var(--_colors---black-background-light));
  color: var(--_colors---text-secondary);
  inset: 23% 25% auto auto;
}

.ecosyst-me-job._3 {
  background-image: linear-gradient(180deg, var(--_colors---black-background-dark), var(--_colors---black-background-light));
  color: var(--_colors---text-secondary);
  inset: auto auto 32% 20%;
}

.ecosyst-me-job._4 {
  background-image: linear-gradient(180deg, var(--_colors---black-background-dark), var(--_colors---black-background-light));
  color: var(--_colors---white-background-light);
  inset: auto 23% 28% auto;
}

.ecosyst-me-job._5 {
  inset: auto 13% 51% auto;
}

.ecosyst-me-job._6 {
  background-image: linear-gradient(180deg, var(--_colors---black-background-dark), var(--_colors---black-background-light));
  color: var(--_colors---text-secondary);
  inset: auto auto 52% 11%;
}

.ecosyst-me-job._7 {
  color: var(--_colors---text-primary);
  background-image: none;
  inset: auto 41% 20% auto;
}

.ecosyst-me-job._8 {
  background-image: linear-gradient(180deg, var(--_colors---black-background-dark), var(--_colors---black-background-light));
  color: var(--_colors---text-secondary);
  inset: 25% auto auto 44%;
}

.ecosyst-me-job._9 {
  inset: 57% auto auto 44%;
}

.ecosyst-me-job-text {
  opacity: .75;
  text-align: center;
  letter-spacing: -.3px;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 1rem;
  font-weight: 400;
  line-height: 26.91px;
  text-decoration: none;
}

.cta-section {
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  max-width: none;
  height: 700px;
  min-height: 90vh;
  text-decoration: none;
  display: flex;
  position: relative;
  overflow: hidden;
}

.cta-section.dark-background {
  background-image: linear-gradient(358deg, #000, #07232e);
}

.cta-content {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
  flex-direction: column;
  justify-content: center;
  align-self: center;
  align-items: center;
  width: 100%;
  max-width: 500px;
  text-decoration: none;
  display: flex;
  position: static;
  inset: 0%;
}

.cta-img {
  object-fit: cover;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.footer {
  grid-row-gap: 10px;
  background-color: #fff;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  padding: 40px 40px 24px;
  text-decoration: none;
  display: flex;
}

.footer-block {
  grid-row-gap: 20px;
  background-image: linear-gradient(#041015 0%, #07232e 100%);
  border: 0 solid #ffffff4d;
  border-top-width: 1px;
  border-radius: 30px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding: 60px 80px;
  text-decoration: none;
  display: flex;
}

.footer-logo {
  object-fit: cover;
  justify-content: center;
  align-items: center;
  width: 118px;
  height: 29px;
  text-decoration: none;
  display: flex;
}

.line-wrapper {
  grid-row-gap: 4px;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  padding-top: 8px;
  padding-bottom: 8px;
  text-decoration: none;
  display: flex;
  overflow: hidden;
}

.frame-1707482150 {
  justify-content: space-between;
  align-items: center;
  width: 100%;
  text-decoration: none;
  display: flex;
}

.frame-464 {
  grid-row-gap: 19px;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  text-decoration: none;
  display: flex;
}

.frame-460 {
  grid-row-gap: 18px;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  max-width: 273px;
  text-decoration: none;
  display: flex;
}

.informations-pratiques {
  opacity: .7;
  color: #fff;
  letter-spacing: .2px;
  width: 100%;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 16px;
  font-weight: 400;
  line-height: 100%;
  text-decoration: none;
}

.frame-341 {
  grid-column-gap: 12px;
  grid-row-gap: .5rem;
  flex-flow: wrap;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  text-decoration: none;
  display: flex;
}

.footer-contact-link {
  grid-column-gap: 8px;
  white-space: nowrap;
  flex: 0 auto;
  justify-content: flex-start;
  align-items: center;
  text-decoration: none;
  display: flex;
}

.footer-logo-img {
  object-fit: fill;
  height: 2rem;
  max-height: 3rem;
  overflow: hidden;
}

.text-25 {
  color: #fff;
  letter-spacing: .2px;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.4;
  text-decoration: none;
}

.frame-1707482151 {
  grid-column-gap: 16px;
  white-space: nowrap;
  flex: 0 auto;
  justify-content: flex-start;
  align-items: flex-start;
  text-decoration: none;
  display: flex;
}

.footer-link {
  color: #fff;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 16px;
  font-weight: 400;
  line-height: 24px;
  text-decoration: none;
}

.frame-666 {
  grid-column-gap: 12px;
  flex: 0 auto;
  justify-content: flex-start;
  align-items: flex-start;
  text-decoration: none;
  display: flex;
}

.legal-link {
  color: #d9d9d9;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 14px;
  font-weight: 400;
  line-height: 20px;
  text-decoration: none;
}

.cta-content-wrapper {
  z-index: 2;
  flex-flow: column;
  justify-content: center;
  align-self: center;
  align-items: center;
  width: 100%;
  height: 100%;
  display: flex;
  position: relative;
}

.button-equipe {
  background-color: var(--_colors---white-background-light);
  -webkit-backdrop-filter: blur(3px);
  backdrop-filter: blur(3px);
  color: var(--_colors---text-primary);
  background-image: none;
  border: 1px solid #00000014;
  border-radius: 12px;
  padding: 8px 14px;
  box-shadow: 0 2px 40px #0003;
}

.marquee_wrapper {
  width: 100%;
  overflow: hidden;
}

.marquee_slider {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  flex-flow: row;
  justify-content: flex-start;
  align-items: center;
  margin-top: 60px;
  margin-bottom: 80px;
  display: flex;
  overflow: hidden;
}

.marquee_slide {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  color: #0500ff;
  border: 1px #0500ff;
  flex-flow: column;
  flex: none;
  justify-content: flex-start;
  align-items: center;
  padding: 16px 10px;
  display: flex;
}

.listitem {
  grid-column-gap: 10px;
  background-color: #faf7f2;
  border-radius: 31.35px;
  flex: 0 auto;
  justify-content: center;
  align-items: center;
  width: 20rem;
  min-height: 27rem;
  text-decoration: none;
  display: flex;
  position: relative;
  overflow: hidden;
  box-shadow: 0 5.225px 26.125px #00000026;
}

._64e21b9e92154a4e1af97b75_via-sana-01-22-vignettes-hd-2-p-500jpg {
  grid-row-gap: 10px;
  object-fit: cover;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  height: 100%;
  padding: 0;
  text-decoration: none;
  display: flex;
  position: absolute;
  inset: 0%;
  overflow: hidden;
}

.benefits_card_content {
  z-index: 2;
  grid-column-gap: 2rem;
  grid-row-gap: 2rem;
  flex-flow: column;
  flex: 1;
  justify-content: flex-end;
  transition: opacity .2s;
  display: flex;
  position: relative;
}

.benefits_wrap {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  display: flex;
  container-type: inline-size;
}

.benefits_card_mask_clip {
  overflow: hidden;
}

.benefits_card_wrap {
  color: #fff;
  background-color: #000;
  border-radius: 18px;
  flex-flow: column;
  width: 100%;
  height: 520px;
  padding: 1.5rem;
  transition: width .3s;
  display: flex;
  position: relative;
  overflow: hidden;
}

.u-container {
  flex-flow: column;
  justify-content: center;
  width: 100%;
  max-width: none;
  margin-left: auto;
  margin-right: auto;
  padding: 0;
  display: flex;
  position: relative;
}

.benefits_card_mask_wrap {
  grid-template-rows: 1fr;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  transition-property: all;
  transition-duration: .3s;
  transition-timing-function: ease;
  display: grid;
}

.benefits_card_img {
  opacity: .8;
  object-fit: cover;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0%;
}

.benefits_card_text {
  letter-spacing: -.3px;
  text-wrap: balance;
  margin-bottom: 1rem;
  padding-top: .7rem;
}

.benefits_card_title {
  letter-spacing: -.3px;
  text-wrap: balance;
  font-family: Satoshi, Arial, sans-serif;
  font-size: 1.3rem;
  font-weight: 300;
}

.benefits_layout {
  grid-column-gap: 1.5rem;
  grid-row-gap: 1.5rem;
  flex-flow: column;
  width: 1150px;
  display: flex;
}

.benefit-span {
  opacity: .6;
  letter-spacing: -.3px;
  font-family: Instrumentserif, Arial, sans-serif;
  font-size: 1.4rem;
  font-style: italic;
  font-weight: 400;
}

.line-dark-background {
  background-color: var(--_colors---white-background-light);
  opacity: .2;
  object-fit: cover;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 1px;
  text-decoration: none;
  display: flex;
}

.navbar-button {
  -webkit-backdrop-filter: blur(3px);
  backdrop-filter: blur(3px);
  color: var(--_colors---text-primary);
  background-color: #ffffff1f;
  border: 1px solid #ffffff1a;
  border-top: 1.2px solid #fff6;
  border-left: .5px solid #fff9;
  border-radius: 12px;
  padding: 8px 12px;
  box-shadow: 0 2px 40px #00000059;
}

.navbar-button.nav-white-background {
  color: var(--_colors---text-primary);
  box-shadow: 0 2px 20px #0003;
}

.navbar-button.home {
  color: var(--_colors---text-secondary);
}

.hero-sticky-spacer {
  height: 100vh;
}

.hp-hero-wrapper {
  margin-bottom: -100vh;
}

.contact-overlay {
  z-index: 1;
  background-color: #0003;
  background-image: radial-gradient(circle, #000000b3, #0000);
  position: absolute;
  inset: 0%;
}

.grid-2 {
  grid-column-gap: 3rem;
  grid-row-gap: 3rem;
  grid-template-rows: auto;
  width: 100%;
}

.hp-pb-hrading-wrapper {
  grid-row-gap: 10px;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  max-width: none;
  text-decoration: none;
  display: flex;
}

.hp-pb-hrading-wrapper.relative {
  z-index: 1;
  position: relative;
}

.image-595 {
  object-fit: cover;
  border-radius: 24px;
  width: 100%;
  height: 100%;
  max-height: 48rem;
}

.cta-certifs-wrapper {
  grid-column-gap: 1rem;
  grid-row-gap: 1rem;
  justify-content: center;
  align-items: center;
  display: flex;
}

.cta-certifs-img {
  border: 1px solid #ffffff4d;
  border-radius: 0;
  height: 6rem;
}

.burger-1 {
  cursor: pointer;
  background-color: #fff;
  border-radius: 4px;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 80px;
  height: 80px;
  display: flex;
  position: relative;
  box-shadow: 6px 6px 25px #28078026;
}

.b1-bar1 {
  background-color: #858eca;
  width: 30px;
  height: 4px;
}

.b1-bar2 {
  background-color: #858eca;
  justify-content: center;
  align-items: center;
  width: 30px;
  height: 4px;
  margin-top: 4px;
  margin-bottom: 4px;
  display: flex;
}

.b1-middle {
  background-color: #858eca;
  width: 4px;
  height: 0;
}

.b1-bar3 {
  background-color: #858eca;
  width: 30px;
  height: 4px;
}

@media screen and (min-width: 1440px) {
  .span-heading {
    font-size: 5.5rem;
  }

  .span-heading.contact-h1 {
    font-size: 3.25rem;
  }

  .span-heading.default-h1, .hp-h1 {
    font-size: 2.8rem;
  }

  .hp-solutions-dark-block {
    min-height: 42vh;
  }

  .ecocsyst-me-circle-img {
    max-height: 65rem;
  }

  .ecosyst-me-job._2 {
    right: 20%;
  }

  .contact-h1 {
    font-size: 3.25rem;
  }

  .esp-col-right-background {
    width: 400px;
  }

  .default-h1 {
    font-size: 2.8rem;
  }
}

@media screen and (min-width: 1920px) {
  .paragraph, .button-primary {
    font-size: 1.15rem;
  }

  .hp-solutions-dark-block {
    min-height: 40vh;
  }

  .ecocsyst-me-circle-img {
    height: 70rem;
  }

  .ecosyst-me-job._2 {
    right: 26%;
  }

  .ecosyst-me-job._3 {
    left: 28%;
  }

  .ecosyst-me-job._5 {
    right: 33%;
  }

  .ecosyst-me-job._6 {
    left: 18%;
  }

  .ecosyst-me-job._8 {
    left: 41%;
  }

  .ecosyst-me-job._9 {
    left: 42%;
  }

  .line {
    max-width: none;
  }

  .contact-para {
    font-size: 1.15rem;
  }

  .line-dark-background {
    max-width: none;
  }

  .esp-col-right-background {
    width: 600px;
  }
}

@media screen and (max-width: 991px) {
  .button-primary {
    white-space: nowrap;
    align-self: flex-start;
  }

  .button-secondary {
    white-space: nowrap;
  }

  .span-heading {
    font-size: 8.5vw;
  }

  .span-heading.default-h1 {
    font-size: 5.5vw;
  }

  .admin-item {
    grid-column-gap: 40px;
    grid-row-gap: 40px;
  }

  .nav-link-page-wrapper {
    background-image: linear-gradient(#fff, #f9f8f6);
    border: 1px solid #00000014;
    border-radius: 0;
    margin: 0;
    padding-top: .5rem;
    padding-bottom: 1.25rem;
    overflow: clip;
    box-shadow: 0 2px 30px #0003;
  }

  .btn-wrapper.none-mobile {
    display: none;
  }

  .menu-button {
    padding: 0;
  }

  .menu-button.w--open {
    color: #fff;
    background-color: #fff0;
  }

  .navbar-btn-wrapper {
    align-items: stretch;
    padding: 10px 2rem 0 20px;
    display: block;
  }

  .navbar-btn-wrapper.none-mobile {
    display: none;
  }

  .link-page {
    color: var(--_colors---text-primary);
    padding: 20px;
    font-family: Satoshi, Arial, sans-serif;
    font-size: 1rem;
  }

  .link-page:lang(en), .link-page._3:lang(en), .link-page._3:lang(en) {
    color: #0b2914;
  }

  .icon {
    color: var(--_colors---white-background-light);
  }

  .icon._2 {
    color: var(--_colors---black-background-light);
  }

  .hp-hero-content-wrapper {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
  }

  .hp-h1 {
    font-size: 6vw;
  }

  .hp-equipe-section {
    margin-top: 6rem;
  }

  .hp-solutions-grid {
    grid-column-gap: 24px;
  }

  .hp-solutions-dark-block {
    min-height: 35vh;
  }

  .button-dark {
    width: 100%;
  }

  .button-wrapper.navbar-btn {
    padding-left: 20px;
    padding-right: 20px;
    display: block;
  }

  .ecocsyst-me-circle-img {
    height: 80vw;
    position: absolute;
    inset: -200% 0% 0%;
  }

  .ecosyst-me-img-wrapper {
    grid-column-gap: .5rem;
    grid-row-gap: .5rem;
    flex-flow: wrap;
    justify-content: center;
    align-items: flex-start;
    margin-top: 4rem;
  }

  .ecosyst-me-job {
    position: static;
  }

  .footer-block {
    padding-left: 48px;
    padding-right: 48px;
  }

  .frame-1707482150 {
    grid-column-gap: 3rem;
    grid-row-gap: 3rem;
  }

  .frame-341 {
    align-items: center;
  }

  .footer-logo-img {
    object-fit: fill;
  }

  .frame-1707482151 {
    flex-flow: wrap;
    align-items: stretch;
  }

  .u-container {
    padding-left: 0;
    padding-right: 0;
  }

  .benefits_layout {
    width: 100%;
  }

  .contact-h1 {
    font-size: 6vw;
  }

  .default-hero {
    height: auto;
    min-height: auto;
  }

  .default-hero-img {
    max-height: 400px;
  }

  .default-hero-container {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
  }

  .esp-col-right-background {
    width: 100%;
    height: 30%;
  }

  .esp-histoire-block {
    flex-flow: column;
    justify-content: space-between;
    align-items: flex-start;
  }

  .default-h1 {
    font-size: 5.5vw;
  }

  .navbar-button.home.mobile-none, .navbar-button.mobile-none, .navbar-button.home.mobile-none, .navbar-button.home.mobile-none, .navbar-button.mobile-none {
    display: none;
  }

  .equipe-fondateurs-img {
    object-position: 30% 0%;
    width: 100%;
  }

  .equipe-fondateurs-img-wrapper {
    width: 100%;
  }

  .c-card-btn-text.focus, .c-card-btn-text.default, .c-card-btn-text.focus, .c-card-btn-text.default {
    transform: translate(0, -100%);
  }

  .collection-list-2 {
    grid-template-columns: 1fr 1fr;
  }

  .expertises-solutions-card {
    grid-row-gap: 3rem;
    flex-flow: column;
    justify-content: center;
    align-items: flex-start;
    max-width: none;
    height: auto;
    padding: 40px;
  }

  .expertises-solutions-card.content-right {
    grid-column-gap: 40px;
    grid-row-gap: 3rem;
    grid-column-gap: 40px;
    grid-row-gap: 3rem;
    grid-template-rows: auto auto;
    grid-template-columns: 1fr;
    grid-auto-columns: 1fr;
    padding: 40px;
    display: grid;
  }

  .expertises-solutions-col-content {
    max-width: none;
  }

  .solutions-img {
    border-radius: 20px;
    height: 13rem;
  }

  .solutions-img.mobile-none {
    display: block;
  }

  .expertises-solutions-col-img {
    width: 100%;
  }

  .frame-1707482183 {
    grid-column-gap: 3rem;
    grid-row-gap: 3rem;
  }

  .image-594 {
    width: 100%;
  }

  .grid-2 {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
    grid-template-columns: 1fr;
  }

  .burger-1 {
    box-shadow: none;
    background-color: #fff0;
    transform: scale(.7);
  }

  .b1-bar1, .b1-bar2, .b1-bar3 {
    background-color: var(--_colors---white-background-light);
  }

  .burger-1-2 {
    box-shadow: none;
    background-color: #fff0;
    transform: scale(.7);
  }

  .b1-bar1-2, .b1-bar2-2, .b1-bar3-2 {
    background-color: var(--_colors---black-background-light);
  }
}

@media screen and (max-width: 767px) {
  .admin-section-links {
    display: none;
  }

  .button-primary {
    justify-content: center;
    align-self: auto;
    align-items: center;
  }

  .admin-section-global {
    padding-left: 20px;
    padding-right: 20px;
  }

  .span-heading {
    font-size: 10.5vw;
  }

  .span-heading.contact-h1 {
    font-size: 6vw;
  }

  .admin-item {
    grid-column-gap: 24px;
    grid-row-gap: 24px;
    grid-template-columns: minmax(200px, max-content);
    place-items: start;
  }

  .navbar-container {
    padding-left: 1.2rem;
    padding-right: 1.2rem;
  }

  .link-page {
    color: #0b2914;
  }

  .hp-hero-content-wrapper {
    flex-flow: column;
  }

  .hp-h1 {
    width: 400px;
    font-size: 9vw;
    line-height: 1.1;
  }

  .frame-1410132487 {
    grid-column-gap: 16px;
    grid-row-gap: 16px;
    grid-template-rows: auto auto;
    grid-template-columns: 1fr;
    grid-auto-columns: 1fr;
    display: grid;
  }

  .hp-equipe-section {
    padding-top: 6rem;
  }

  .hp-solutions-grid {
    grid-row-gap: 1rem;
    flex-flow: column;
    grid-template-columns: 1fr;
    justify-content: center;
    align-items: center;
  }

  .hp-probl-me-block {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
    justify-content: flex-start;
    align-items: flex-start;
    max-width: none;
    min-height: 140px;
  }

  .heading-wrapper-horizontal {
    flex-flow: column;
  }

  .horizontal-wrapper-col-right {
    grid-column-gap: 16px;
    grid-row-gap: 20px;
    grid-template-rows: auto auto;
    grid-template-columns: 1fr;
    grid-auto-columns: 1fr;
    display: grid;
  }

  .segments-section {
    padding-top: 80px;
  }

  .segments-wrapper {
    flex-flow: column;
  }

  .segments-col-right {
    justify-content: flex-start;
    align-items: flex-start;
  }

  .segments-block {
    width: 100%;
  }

  .ecocsyst-me-circle-img {
    top: -50%;
  }

  .ecosyst-me-img-wrapper {
    justify-content: center;
    align-items: center;
    margin-top: 4rem;
  }

  .ecosyst-me-job {
    top: 25%;
    left: 5%;
  }

  .ecosyst-me-job._4, .ecosyst-me-job._5, .ecosyst-me-job._6, .ecosyst-me-job._7 {
    bottom: 15%;
    right: 12%;
  }

  .ecosyst-me-job._2 {
    top: 20%;
    right: 12%;
  }

  .ecosyst-me-job._3 {
    bottom: 20%;
    left: 10%;
  }

  .ecosyst-me-job._4, .ecosyst-me-job._5, .ecosyst-me-job._6, .ecosyst-me-job._7 {
    bottom: 15%;
    right: 12%;
  }

  .frame-1707482150 {
    grid-column-gap: 1rem;
    grid-row-gap: 1rem;
    flex-flow: column;
    justify-content: space-between;
    align-items: flex-start;
  }

  .marquee_slider {
    grid-column-gap: 0px;
    grid-row-gap: 0px;
  }

  .marquee_slide {
    width: auto;
    padding-left: 20px;
    padding-right: 20px;
  }

  .u-container {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .collection-list-2 {
    grid-template-columns: 1fr;
  }
}

@media screen and (max-width: 479px) {
  .paragraph {
    font-size: 1rem;
  }

  .button-primary {
    width: auto;
    max-width: 100%;
  }

  .h3-style {
    font-size: 1.5rem;
  }

  .button-secondary {
    width: auto;
    max-width: 100%;
  }

  .span-heading.contact-h1, .span-heading.default-h1 {
    font-size: 8.5vw;
  }

  .span-heading.h2 {
    font-size: 1.8rem;
  }

  .span-heading.contact-h1, .span-heading.default-h1 {
    font-size: 8.5vw;
  }

  .span-heading.expertises-solutions {
    font-size: 1.4rem;
  }

  .navbar-container {
    padding: 0 1.2rem;
  }

  .nav-link-page-wrapper {
    margin: 0;
  }

  .logo {
    height: 1.8rem;
  }

  .navbar-btn-wrapper.none-mobile {
    display: block;
  }

  .link-page {
    padding-top: 16px;
    padding-bottom: 16px;
  }

  .hp-hero-section {
    min-height: 98vh;
  }

  .hp-hero-image {
    object-position: 50% 50%;
  }

  .hp-hero-content-wrapper {
    padding-bottom: 6rem;
    padding-left: 1.2rem;
    padding-right: 1.2rem;
  }

  .hp-h1 {
    width: auto;
    max-width: 250px;
    font-size: 9vw;
  }

  .frame-1410132487 {
    grid-column-gap: 12px;
    grid-row-gap: 12px;
  }

  .hp-hero-dark-overlay {
    background-image: linear-gradient(0deg, #000, #0000005c 50%, #0000);
  }

  .container {
    padding-left: 1.2rem;
    padding-right: 1.2rem;
  }

  .h2 {
    text-shadow: 0 1px 6px #0000000f;
    max-width: 340px;
    font-size: 1.8rem;
  }

  .h2.secondary.align-center.max-width-300 {
    max-width: 300px;
  }

  .spacer {
    z-index: 1;
    font-size: .9rem;
    inset: auto 0% -3%;
  }

  .spacer.high.mobile-none {
    display: none;
  }

  .heading-wrapper-horizontal {
    justify-content: space-between;
    align-items: flex-start;
  }

  .horizontal-wrapper-col-right {
    grid-template-rows: auto;
  }

  .button-dark {
    width: auto;
  }

  .button-dark.header {
    width: 100%;
  }

  .solutions-overlay {
    background-image: linear-gradient(#0000 1%, #00000080 40%, #000 95%);
  }

  .hp-ecosysteme-section {
    margin-top: 0;
  }

  .ecocsyst-me-circle-img {
    object-fit: cover;
    width: 100vw;
    inset: 0%;
  }

  .ecosyst-me-img-wrapper {
    margin-top: 3rem;
  }

  .ecosyst-me-job {
    padding: 6px 12px;
    top: 22%;
    left: 3%;
  }

  .ecosyst-me-job._2 {
    right: 5%;
  }

  .image-589 {
    height: 1rem;
  }

  .cta-content {
    max-width: 300px;
  }

  .footer {
    padding-left: 1.2rem;
    padding-right: 1.2rem;
  }

  .footer-block {
    padding: 40px 32px;
  }

  .frame-1707482150 {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
  }

  .informations-pratiques {
    font-size: .9rem;
  }

  .frame-341 {
    grid-column-gap: .5rem;
    grid-row-gap: .5rem;
    flex-flow: column;
    justify-content: space-between;
    align-items: flex-start;
  }

  .footer-logo-img {
    width: auto;
    height: 1.5rem;
  }

  .text-25 {
    font-size: .9rem;
  }

  .frame-1707482151 {
    grid-column-gap: .5rem;
    grid-row-gap: .5rem;
    flex-flow: column;
  }

  .footer-link {
    font-size: .9rem;
  }

  .legal-link {
    text-align: center;
    align-self: center;
  }

  .marquee_wrapper {
    white-space: nowrap;
    width: auto;
  }

  .marquee_slider {
    white-space: nowrap;
    margin-top: 40px;
    margin-bottom: 40px;
  }

  .marquee_slide {
    padding-top: 40px;
    padding-bottom: 40px;
  }

  .benefits_card_wrap {
    height: 500px;
    position: sticky;
    top: 4%;
  }

  .u-container {
    z-index: 3;
    padding-left: 0;
    padding-right: 0;
  }

  .benefits_layout {
    position: relative;
  }

  .contact-hero-content {
    grid-column-gap: 2rem;
    grid-row-gap: 2rem;
    flex-flow: column;
  }

  .contact-h1 {
    text-align: center;
    font-size: 8.5vw;
    line-height: 1.2;
  }

  .contact-para {
    font-size: 1rem;
  }

  .default-hero {
    grid-row-gap: 2.5rem;
    height: auto;
    min-height: 80vh;
  }

  .default-hero-col-right {
    grid-column-gap: 8px;
    grid-row-gap: 8px;
    grid-template-rows: auto;
    grid-template-columns: 1fr;
    grid-auto-columns: 1fr;
    place-items: center start;
    height: auto;
    display: grid;
  }

  .default-hero-img {
    flex: 0 auto;
    min-height: 300px;
  }

  .default-hero-container {
    grid-column-gap: 8px;
    grid-row-gap: 8px;
    flex-flow: column;
    justify-content: center;
    padding-top: 6rem;
    padding-left: 1.2rem;
    padding-right: 1.2rem;
  }

  .esp-col-right-background {
    width: 100%;
    height: 350px;
    inset: auto 0% 0%;
  }

  .esp-histoire-block {
    flex-flow: column;
  }

  .default-h1 {
    text-shadow: 0 2px 6px #07232e26;
    font-size: 8.5vw;
    line-height: 1.1;
  }

  .default-h1.max-width-300 {
    text-shadow: 0 2px 8px #07232e26;
    max-width: 300px;
    line-height: 1.1;
  }

  .esp-valeurs-section {
    overflow: visible;
  }

  .esp-valeurs-wrapper {
    position: relative;
  }

  .esp-valeurs-block {
    flex-flow: column;
  }

  .default-hero-img-wrapper {
    justify-content: flex-start;
    align-items: center;
    height: 300px;
  }

  .equipe-fondateurs-img {
    object-position: 50% 0%;
    height: 400px;
  }

  .c-card-back {
    width: 100%;
    max-width: none;
    display: none;
  }

  .c-card-front {
    width: 100%;
    max-width: none;
  }

  .paragraph-2 {
    font-size: 12px;
  }

  .expertises-solutions-card {
    grid-column-gap: 1.5rem;
    grid-row-gap: 1.5rem;
    border: 1px solid #ffffff4d;
    grid-template-rows: auto;
    grid-template-columns: 1fr;
    grid-auto-columns: 1fr;
    padding: 28px;
    display: grid;
    top: 1%;
  }

  .expertises-solutions-card.content-right {
    grid-column-gap: 1.5rem;
    grid-row-gap: 1.5rem;
    grid-column-gap: 1.5rem;
    grid-row-gap: 1.5rem;
    padding: 28px;
  }

  .solutions-text {
    font-size: 13px;
    line-height: 1.3;
  }

  .expertises-solutions-section {
    padding-bottom: 2rem;
  }

  .expertises-solutions-h2 {
    font-size: 1.4rem;
  }

  .expertises-solutions-heading {
    top: -20%;
  }

  .expertises-solutions-wrapper {
    top: 3rem;
  }

  .solutions-img {
    object-fit: cover;
    height: 13rem;
  }

  .image-594 {
    height: 20rem;
  }

  .cta-certifs-wrapper {
    grid-column-gap: .5rem;
    grid-row-gap: .5rem;
  }

  .cta-certifs-img {
    height: 5rem;
  }

  .ml-hero-section {
    padding-top: 6rem;
  }

  .list-2 {
    padding-left: 16px;
  }

  .burger-1, .burger-1-2 {
    transform: scale(.6);
  }
}

#w-node-fe56747c-7cfd-2c8d-11bb-3ad0a34d4864-75c4ab36 {
  grid-area: span 1 / span 1 / span 1 / span 1;
}

@media screen and (max-width: 991px) {
  #w-node-_814ec6d3-870c-df0a-0c34-5f851f511221-75c4ab36 {
    grid-area: 2 / 1 / 3 / 2;
  }
}
