.placeholder {
  background-color: #ffffff;
  display: grid;
  justify-items: center;
  align-items: start;
  width: 100%;
}

.placeholder .div {
  background-color: #ffffff;
  overflow: hidden;
  width: 100vw;
  height: 56.3vw;
  position: relative;
}

.placeholder .overlap {
  position: absolute;
  width: 1920px;
  height: 1682px;
  top: 4367px;
  left: 0;
}

.placeholder .rectangle {
  position: absolute;
  width: 1920px;
  height: 1101px;
  top: 0;
  left: 0;
  background-color: #f7fafc;
}

.placeholder .bg {
  height: 400px;
  top: 500px;
  background: linear-gradient(
    1deg,
    rgba(130, 151, 171, 1) 13%,
    rgba(130, 151, 171, 0) 100%
  );
  position: absolute;
  width: 1920px;
  left: 0;
}

.placeholder .mask-group {
  position: absolute;
  width: 1920px;
  height: 400px;
  top: 165px;
  left: -3803px;
}

.placeholder .frame {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 30px;
  position: absolute;
  top: 120px;
  left: 255px;
}

.placeholder .text-wrapper {
  position: relative;
  width: 568px;
  margin-top: -1.00px;
  font-family: "Work Sans", Helvetica;
  font-weight: 400;
  color: #222222;
  font-size: 32px;
  text-align: center;
  letter-spacing: -1.28px;
  line-height: 42px;
}

.placeholder .frame-2 {
  display: inline-flex;
  align-items: flex-start;
  gap: 30px;
  padding: 0px 0px 10px;
  position: relative;
  flex: 0 0 auto;
}

.placeholder .card {
  display: flex;
  flex-direction: column;
  width: 450px;
  align-items: flex-start;
  padding: 10px;
  position: relative;
  background-color: #ffffff;
  border-radius: 10px;
  overflow: hidden;
}

.placeholder .image {
  position: relative;
  align-self: stretch;
  width: 100%;
  height: 260px;
  margin-top: -4394.00px;
  margin-left: -4058.00px;
  object-fit: cover;
}

.placeholder .title-button {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  padding: 16px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.placeholder .text-wrapper-2 {
  position: relative;
  align-self: stretch;
  margin-top: -1.00px;
  font-family: var(--home-h3-font-family);
  font-weight: var(--home-h3-font-weight);
  color: #222222;
  font-size: var(--home-h3-font-size);
  letter-spacing: var(--home-h3-letter-spacing);
  line-height: var(--home-h3-line-height);
  font-style: var(--home-h3-font-style);
}

.placeholder .text-wrapper-3 {
  color: #222222;
  position: relative;
  width: fit-content;
  font-family: "Work Sans", Helvetica;
  font-weight: 400;
  font-size: 18px;
  letter-spacing: -0.36px;
  line-height: 20px;
  white-space: nowrap;
}

.placeholder .img {
  position: relative;
  align-self: stretch;
  width: 100%;
  height: 260px;
  margin-top: -4394.00px;
  margin-left: -4538.00px;
  object-fit: cover;
}

.placeholder .image-2 {
  position: relative;
  align-self: stretch;
  width: 100%;
  height: 260px;
  margin-top: -4394.00px;
  margin-left: -5018.00px;
  object-fit: cover;
}

.placeholder .button {
  all: unset;
  box-sizing: border-box;
  position: relative;
  flex: 0 0 auto;
  background-color: #47596b;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 16px 40px;
  border-radius: 8px;
}

.placeholder .text-wrapper-4 {
  margin-top: -1.00px;
  color: #ffffff;
  position: relative;
  width: fit-content;
  font-family: "Work Sans", Helvetica;
  font-weight: 400;
  font-size: 18px;
  letter-spacing: -0.36px;
  line-height: 20px;
  white-space: nowrap;
}

.placeholder .contact {
  position: absolute;
  width: 1920px;
  height: 782px;
  top: 900px;
  left: 0;
  background-color: #8297ab;
}

.placeholder .frame-3 {
  display: flex;
  flex-direction: column;
  width: 1290px;
  align-items: flex-start;
  gap: 30px;
  position: relative;
  left: 255px;
}

.placeholder .text-wrapper-5 {
  position: relative;
  align-self: stretch;
  margin-top: -1.00px;
  font-family: var(--home-h2-font-family);
  font-weight: var(--home-h2-font-weight);
  color: #ffffff;
  font-size: var(--home-h2-font-size);
  letter-spacing: var(--home-h2-letter-spacing);
  line-height: var(--home-h2-line-height);
  font-style: var(--home-h2-font-style);
}

.placeholder .frame-4 {
  display: flex;
  align-items: flex-start;
  gap: 150px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.placeholder .frame-5 {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 60px;
  position: relative;
  flex: 0 0 auto;
}

.placeholder .frame-6 {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 20px;
  position: relative;
  flex: 0 0 auto;
}

.placeholder .p {
  position: relative;
  width: 570px;
  margin-top: -1.00px;
  font-family: var(--home-body-18-font-family);
  font-weight: var(--home-body-18-font-weight);
  color: #ffffff;
  font-size: var(--home-body-18-font-size);
  letter-spacing: var(--home-body-18-letter-spacing);
  line-height: var(--home-body-18-line-height);
  font-style: var(--home-body-18-font-style);
}

.placeholder .div-2 {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  position: relative;
  flex: 0 0 auto;
}

.placeholder .iconsans-bold-email {
  margin-top: -5278.00px;
  margin-left: -4058.00px;
  position: relative;
  width: 30px;
  height: 30px;
}

.placeholder .text-wrapper-6 {
  position: relative;
  width: fit-content;
  font-family: var(--home-body-18-font-family);
  font-weight: var(--home-body-18-font-weight);
  color: #ffffff;
  font-size: var(--home-body-18-font-size);
  letter-spacing: var(--home-body-18-letter-spacing);
  line-height: var(--home-body-18-line-height);
  white-space: nowrap;
  font-style: var(--home-body-18-font-style);
}

.placeholder .iconsans-bold-call {
  margin-top: -5328.00px;
  margin-left: -4058.00px;
  position: relative;
  width: 30px;
  height: 30px;
}

.placeholder .iconsans-bold-email-2 {
  position: relative;
  width: 30px;
  height: 30px;
  margin-top: -5466.00px;
  margin-left: -4058.00px;
}

.placeholder .iconsans-bold-call-2 {
  position: relative;
  width: 30px;
  height: 30px;
  margin-top: -5516.00px;
  margin-left: -4058.00px;
}

.placeholder .contact-form {
  display: flex;
  flex-direction: column;
  width: 570px;
  align-items: flex-start;
  gap: 50px;
  position: relative;
}

.placeholder .table-wrapper {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 60px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.placeholder .table {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 20px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.placeholder .input {
  align-items: center;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  display: flex;
  padding: 14px;
  position: relative;
  background-color: #e9f3fb;
  border-radius: 10px;
}

.placeholder .text-wrapper-7 {
  position: relative;
  flex: 1;
  height: 24px;
  margin-top: -1.00px;
  font-family: var(--home-body-16-font-family);
  font-weight: var(--home-body-16-font-weight);
  color: #5f788a;
  font-size: var(--home-body-16-font-size);
  letter-spacing: var(--home-body-16-letter-spacing);
  line-height: var(--home-body-16-line-height);
  white-space: nowrap;
  font-style: var(--home-body-16-font-style);
}

.placeholder .row {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.placeholder .div-wrapper {
  align-items: center;
  flex: 1;
  flex-grow: 1;
  display: flex;
  padding: 14px;
  position: relative;
  background-color: #e9f3fb;
  border-radius: 10px;
}

.placeholder .text-wrapper-8 {
  position: relative;
  flex: 1;
  margin-top: -1.00px;
  font-family: var(--home-body-16-font-family);
  font-weight: var(--home-body-16-font-weight);
  color: #5f788a;
  font-size: var(--home-body-16-font-size);
  letter-spacing: var(--home-body-16-letter-spacing);
  line-height: var(--home-body-16-line-height);
  font-style: var(--home-body-16-font-style);
}

.placeholder .input-2 {
  flex-grow: 1;
  padding: 14px;
  position: relative;
  background-color: #e9f3fb;
  border-radius: 10px;
  border: none;
  flex: 1;
  margin-top: -1.00px;
  font-family: var(--home-body-16-font-family);
  font-weight: var(--home-body-16-font-weight);
  color: #5f788a;
  font-size: var(--home-body-16-font-size);
  letter-spacing: var(--home-body-16-letter-spacing);
  line-height: var(--home-body-16-line-height);
  font-style: var(--home-body-16-font-style);
}

.placeholder .input-3 {
  height: 190px;
  align-items: flex-start;
  align-self: stretch;
  width: 100%;
  display: flex;
  padding: 14px;
  position: relative;
  background-color: #e9f3fb;
  border-radius: 10px;
}

.placeholder .checkbox {
  align-items: center;
  display: flex;
  gap: 6px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.placeholder .checkbox-checked {
  position: relative;
  width: 18px;
  height: 18px;
  margin-top: -5528.00px;
  margin-left: -4778.00px;
  background-image: url(./img/icon.png);
  background-size: 100% 100%;
}

.placeholder .label {
  height: 18px;
  white-space: nowrap;
  position: relative;
  flex: 1;
  margin-top: -1.00px;
  font-family: var(--home-body-16-font-family);
  font-weight: var(--home-body-16-font-weight);
  color: #ffffff;
  font-size: var(--home-body-16-font-size);
  letter-spacing: var(--home-body-16-letter-spacing);
  line-height: var(--home-body-16-line-height);
  font-style: var(--home-body-16-font-style);
}

.placeholder .checkbox-2 {
  align-items: flex-start;
  display: flex;
  gap: 6px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.placeholder .icon {
  margin-top: -5566.00px;
  position: relative;
  width: 18px;
  height: 18px;
  margin-left: -4778.00px;
  background-image: url(./img/checked-unchecked-2.svg);
  background-size: 100% 100%;
}

.placeholder .label-2 {
  position: relative;
  flex: 1;
  margin-top: -1.00px;
  font-family: var(--home-body-16-font-family);
  font-weight: var(--home-body-16-font-weight);
  color: #ffffff;
  font-size: var(--home-body-16-font-size);
  letter-spacing: var(--home-body-16-letter-spacing);
  line-height: var(--home-body-16-line-height);
  font-style: var(--home-body-16-font-style);
}

.placeholder .icon-2 {
  margin-top: -5634.00px;
  position: relative;
  width: 18px;
  height: 18px;
  margin-left: -4778.00px;
  background-image: url(./img/checked-unchecked.svg);
  background-size: 100% 100%;
}

.placeholder .d-couvrir-wrapper {
  all: unset;
  box-sizing: border-box;
  position: relative;
  flex: 0 0 auto;
  background-color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 16px 40px;
  border-radius: 8px;
}

.placeholder .d-couvrir {
  margin-top: -1.00px;
  color: #222222;
  position: relative;
  width: fit-content;
  font-family: var(--home-button-font-family);
  font-weight: var(--home-button-font-weight);
  font-size: var(--home-button-font-size);
  letter-spacing: var(--home-button-letter-spacing);
  line-height: var(--home-button-line-height);
  white-space: nowrap;
  font-style: var(--home-button-font-style);
}

.placeholder .frame-7 {
  position: absolute;
  width: 1920px;
  height: 720px;
  top: 1658px;
  left: 0;
}

.placeholder .overlap-group {
  position: absolute;
  width: 1920px;
  height: 720px;
  top: 0;
  left: 0;
}

.placeholder .bg-2 {
  height: 720px;
  top: 0;
  background-color: #708599;
  transform: rotate(180.00deg);
  position: absolute;
  width: 1920px;
  left: 0;
}

.placeholder .play {
  display: inline-flex;
  align-items: flex-start;
  gap: 10px;
  padding: 33px 30px 33px 36px;
  position: absolute;
  top: 309px;
  left: 909px;
  background-color: #d6e9f880;
  border-radius: 50px;
}

.placeholder .polygon {
  position: relative;
  width: 36px;
  height: 36px;
  margin-top: -1802.00px;
  margin-left: -4676.00px;
}

.placeholder .image-3 {
  position: absolute;
  width: 930px;
  height: 520px;
  top: -1393px;
  left: -3308px;
  object-fit: cover;
}

.placeholder .frame-8 {
  position: absolute;
  width: 1410px;
  height: 1129px;
  top: 2498px;
  left: 255px;
}

.placeholder .overlap-2 {
  position: absolute;
  width: 884px;
  height: 883px;
  top: -2179px;
  left: -3810px;
}

.placeholder .subtract {
  position: absolute;
  width: 412px;
  height: 386px;
  top: 0;
  left: 434px;
}

.placeholder .subtract-2 {
  position: absolute;
  width: 292px;
  height: 450px;
  top: 297px;
  left: 592px;
}

.placeholder .subtract-3 {
  position: absolute;
  width: 525px;
  height: 304px;
  top: 579px;
  left: 210px;
}

.placeholder .subtract-4 {
  position: absolute;
  width: 328px;
  height: 480px;
  top: 317px;
  left: 0;
}

.placeholder .subtract-5 {
  position: absolute;
  width: 473px;
  height: 375px;
  top: 0;
  left: 13px;
}

.placeholder .implantodata-logo {
  position: absolute;
  width: 169px;
  height: 166px;
  top: 356px;
  left: 356px;
  aspect-ratio: 1.02;
}

.placeholder .frame-9 {
  display: flex;
  flex-direction: column;
  width: 210px;
  align-items: flex-start;
  gap: 6px;
  position: absolute;
  top: 643px;
  left: 288px;
}

.placeholder .frame-10 {
  display: inline-flex;
  align-items: flex-start;
  gap: 6px;
  position: relative;
  flex: 0 0 auto;
  margin-right: -54.00px;
}

.placeholder .tabler-star-filled-wrapper {
  display: inline-flex;
  align-items: flex-start;
  gap: 10px;
  padding: 5px 0px;
  position: relative;
  flex: 0 0 auto;
}

.placeholder .tabler-star-filled {
  position: relative;
  width: 18px;
  height: 18px;
  overflow: hidden;
}

.placeholder .vector {
  position: absolute;
  width: 16px;
  height: 16px;
  top: -2980px;
  left: -4345px;
}

.placeholder .text-wrapper-9 {
  position: relative;
  align-self: stretch;
  width: 240px;
  margin-top: -1.00px;
  font-family: "Work Sans", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 18px;
  letter-spacing: 0;
  line-height: 28px;
}

.placeholder .vector-2 {
  position: absolute;
  width: 16px;
  height: 16px;
  top: -3014px;
  left: -4345px;
}

.placeholder .text-wrapper-10 {
  position: absolute;
  top: 589px;
  left: 312px;
  font-family: "Work Sans", Helvetica;
  font-weight: 500;
  color: #ffffff;
  font-size: 30px;
  letter-spacing: -1.20px;
  line-height: 34px;
  white-space: nowrap;
}

.placeholder .frame-11 {
  display: flex;
  flex-direction: column;
  width: 210px;
  align-items: flex-start;
  gap: 6px;
  position: absolute;
  top: 301px;
  left: 393px;
}

.placeholder .vector-3 {
  position: absolute;
  width: 16px;
  height: 16px;
  top: -2638px;
  left: -4450px;
}

.placeholder .vector-4 {
  position: absolute;
  width: 16px;
  height: 16px;
  top: -2672px;
  left: -4450px;
}

.placeholder .vector-5 {
  position: absolute;
  width: 16px;
  height: 16px;
  top: -2734px;
  left: -4450px;
}

.placeholder .text-wrapper-11 {
  position: absolute;
  top: 250px;
  left: 445px;
  font-family: "Work Sans", Helvetica;
  font-weight: 500;
  color: #ffffff;
  font-size: 30px;
  letter-spacing: -1.20px;
  line-height: 34px;
  white-space: nowrap;
}

.placeholder .frame-12 {
  display: flex;
  flex-direction: column;
  width: 209px;
  align-items: flex-start;
  gap: 6px;
  position: absolute;
  top: 301px;
  left: 774px;
}

.placeholder .frame-13 {
  display: inline-flex;
  align-items: flex-start;
  gap: 6px;
  position: relative;
  flex: 0 0 auto;
  margin-right: -55.00px;
}

.placeholder .vector-6 {
  position: absolute;
  width: 16px;
  height: 16px;
  top: -2638px;
  left: -4831px;
}

.placeholder .vector-7 {
  position: absolute;
  width: 16px;
  height: 16px;
  top: -2672px;
  left: -4831px;
}

.placeholder .text-wrapper-12 {
  position: absolute;
  top: 250px;
  left: 792px;
  font-family: "Work Sans", Helvetica;
  font-weight: 500;
  color: #ffffff;
  font-size: 30px;
  letter-spacing: -1.20px;
  line-height: 34px;
  white-space: nowrap;
}

.placeholder .frame-14 {
  display: flex;
  flex-direction: column;
  width: 210px;
  align-items: flex-start;
  gap: 6px;
  position: absolute;
  top: 643px;
  left: 901px;
}

.placeholder .frame-15 {
  display: inline-flex;
  align-items: flex-start;
  gap: 6px;
  position: relative;
  flex: 0 0 auto;
  margin-right: -1.00px;
}

.placeholder .vector-8 {
  position: absolute;
  width: 16px;
  height: 16px;
  top: -2980px;
  left: -4958px;
}

.placeholder .un-traitement-plus {
  position: relative;
  align-self: stretch;
  width: 187px;
  margin-top: -1.00px;
  font-family: "Work Sans", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 18px;
  letter-spacing: 0;
  line-height: 28px;
}

.placeholder .vector-9 {
  position: absolute;
  width: 16px;
  height: 16px;
  top: -3042px;
  left: -4958px;
}

.placeholder .text-wrapper-13 {
  position: absolute;
  top: 589px;
  left: 901px;
  font-family: "Work Sans", Helvetica;
  font-weight: 500;
  color: #ffffff;
  font-size: 30px;
  letter-spacing: -1.20px;
  line-height: 34px;
  white-space: nowrap;
}

.placeholder .frame-wrapper {
  display: flex;
  flex-direction: column;
  width: 236px;
  align-items: flex-start;
  gap: 6px;
  position: absolute;
  top: 895px;
  left: 574px;
}

.placeholder .frame-16 {
  display: inline-flex;
  align-items: flex-start;
  gap: 6px;
  position: relative;
  flex: 0 0 auto;
  margin-right: -4.00px;
}

.placeholder .vector-10 {
  position: absolute;
  width: 16px;
  height: 16px;
  top: -3232px;
  left: -4631px;
}

.placeholder .meilleure {
  position: relative;
  width: 216px;
  margin-top: -1.00px;
  font-family: "Work Sans", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 18px;
  letter-spacing: 0;
  line-height: 28px;
}

.placeholder .text-wrapper-14 {
  position: absolute;
  top: 850px;
  left: 617px;
  font-family: "Work Sans", Helvetica;
  font-weight: 500;
  color: #ffffff;
  font-size: 30px;
  letter-spacing: -1.20px;
  line-height: 34px;
  white-space: nowrap;
}

.placeholder .frame-17 {
  display: flex;
  flex-direction: column;
  width: 930px;
  align-items: center;
  gap: 30px;
  position: absolute;
  top: 0;
  left: 240px;
}

.placeholder .text-wrapper-15 {
  position: relative;
  width: 450px;
  margin-top: -1.00px;
  font-family: "Work Sans", Helvetica;
  font-weight: 400;
  color: #222222;
  font-size: 32px;
  text-align: center;
  letter-spacing: -1.28px;
  line-height: 42px;
}

.placeholder .text-wrapper-16 {
  position: relative;
  align-self: stretch;
  font-family: "Work Sans", Helvetica;
  font-weight: 400;
  color: #222222;
  font-size: 16px;
  text-align: center;
  letter-spacing: 0;
  line-height: 24px;
}

.placeholder .button-2 {
  all: unset;
  box-sizing: border-box;
  position: absolute;
  top: 1077px;
  left: 584px;
  background-color: #47596b;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 16px 40px;
  border-radius: 8px;
}

.placeholder .content-wrapper {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100vw;
  height: 56.3vw;
  top: 0;
  left: 0;
  background: linear-gradient(
    182deg,
    rgba(112, 133, 153, 1) 17%,
    rgba(128, 149, 166, 1) 48%,
    rgba(255, 255, 255, 1) 100%
  );
}

.placeholder .content {
  display: inline-flex;
  align-items: center;
  gap: 86px;
  position: relative;
  width: 73.4%;
}

.placeholder .text {
  width: 45%;
  gap: 24px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  position: relative;
}

.placeholder .logo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  position: relative;
}

.placeholder .text-wrapper-17 {
  position: relative;
  width: fit-content;
  font-family: "Work Sans", Helvetica;
  font-weight: 300;
  color: #ffffff;
  font-size: 4.8vw;
  letter-spacing: -0.18vw;
  line-height: 3.8vw;
  white-space: nowrap;
}

.placeholder .frame-18 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 0.3vw 0.5vw 0.3vw 0.3vw;
  position: relative;
  flex: 0 0 auto;
  background-color: #ffffff;
  border-radius: 8px;
}

.placeholder .text-wrapper-18 {
  position: relative;
  width: fit-content;
  font-family: "Work Sans", Helvetica;
  font-weight: 300;
  color: #7c8fa1;
  font-size: 4.8vw;
  letter-spacing: -0.18vw;
  line-height: 3.8vw;
  white-space: nowrap;
}

.placeholder .text-2 {
  gap: 16px;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  position: relative;
}

.placeholder .implantodata-est-un {
  position: relative;
  max-width: 618px;
  margin-top: -1.00px;
  font-family: "Work Sans", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 0.94vw;
  letter-spacing: 0;
  line-height: 1.6;
}

.placeholder .text-wrapper-19 {
  position: relative;
  align-self: stretch;
  font-family: "Work Sans", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 0.95vw;
  letter-spacing: 0;
  line-height: 1.6;
}

.placeholder .contacts {
  display: flex;
  flex-direction: column;
  max-width: 226px;
  align-items: flex-start;
  gap: 16px;
  position: relative;
  flex: 0 0 auto;
}

.placeholder .img-2 {
  position: relative;
  width: 1.7vw;
  height: 1.7vw;
}

.placeholder .text-wrapper-20 {
  position: relative;
  width: fit-content;
  font-family: "Work Sans", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 0.95vw;
  letter-spacing: 0;
  line-height: 1.6;
  white-space: nowrap;
}

.placeholder .phone {
  display: flex;
  align-items: center;
  gap: 12px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.placeholder .chantal-endodata-fr {
  position: relative;
  width: fit-content;
  margin-right: -2.00px;
  font-family: "Work Sans", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 0.95vw;
  letter-spacing: 0;
  line-height: 1.6;
  white-space: nowrap;
  background: transparent;
  border: none;
  padding: 0;
}

.placeholder .implantodata-logo-wrapper {
  position: relative;
  width: 49%;
  border-radius: 10px;
  overflow: hidden;
}

.placeholder .implantodata-logo-1 {
  position: relative;
  z-index: 1;
  width: auto;
  max-width: 100%;
  height: auto;
}

.placeholder .implantodata-logo-2 {
  position: absolute;
  z-index: 2;
  aspect-ratio: 2.58;
  object-fit: cover;
  width: 53.6%;
  height: auto;
  top: 30%;
  left: 36.8%;
}

.placeholder .map {
  position: absolute;
  width: 1920px;
  height: 820px;
  top: 6049px;
  left: 0;
  background-color: #8297ab;
}

.placeholder .overlap-3 {
  position: absolute;
  width: 1410px;
  height: 700px;
  top: 0;
  left: 255px;
  background-color: #ffffff;
  border-radius: 10px;
}

.placeholder .text-wrapper-21 {
  position: absolute;
  width: 568px;
  top: 58px;
  left: 421px;
  font-family: "Work Sans", Helvetica;
  font-weight: 400;
  color: #222222;
  font-size: 32px;
  text-align: center;
  letter-spacing: -1.28px;
  line-height: 42px;
}

.placeholder .text-wrapper-22 {
  position: absolute;
  width: 450px;
  top: 486px;
  left: 840px;
  font-family: "Work Sans", Helvetica;
  font-weight: 400;
  color: #222222;
  font-size: 16px;
  letter-spacing: 0;
  line-height: 24px;
}

.placeholder .map-2 {
  position: absolute;
  width: 509px;
  height: 512px;
  top: -5759px;
  left: -3438px;
}

.placeholder .group {
  position: absolute;
  width: 161px;
  height: 273px;
  top: -5685px;
  left: -2611px;
}

.placeholder .frame-19 {
  position: absolute;
  width: 1920px;
  height: 620px;
  top: 3747px;
  left: 0;
  background-color: #e0e5ea;
}

.placeholder .frame-20 {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 60px;
  position: relative;
  top: 120px;
  left: 255px;
}

.placeholder .frame-21 {
  display: flex;
  flex-direction: column;
  width: 1410px;
  align-items: center;
  gap: 30px;
  position: relative;
  flex: 0 0 auto;
}

.placeholder .frame-22 {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  position: relative;
  flex: 0 0 auto;
}

.placeholder .frame-23 {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  position: relative;
  flex: 0 0 auto;
}

.placeholder .iconsans-bold-insta {
  overflow: hidden;
  position: relative;
  width: 30px;
  height: 30px;
}

.placeholder .subtract-6 {
  position: absolute;
  width: 25px;
  height: 25px;
  top: -3754px;
  left: -4637px;
}

.placeholder .text-wrapper-23 {
  position: relative;
  width: fit-content;
  margin-top: -1.00px;
  font-family: var(--home-h3-font-family);
  font-weight: var(--home-h3-font-weight);
  color: #222222;
  font-size: var(--home-h3-font-size);
  letter-spacing: var(--home-h3-letter-spacing);
  line-height: var(--home-h3-line-height);
  white-space: nowrap;
  font-style: var(--home-h3-font-style);
}

.placeholder .frame-24 {
  display: flex;
  align-items: flex-start;
  gap: 30px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.placeholder .frame-25 {
  display: flex;
  flex-direction: column;
  width: 450px;
  align-items: flex-start;
  gap: 10px;
  padding: 30px;
  position: relative;
  background-color: #ffffff;
  border-radius: 10px;
}

.placeholder .text-wrapper-24 {
  position: relative;
  align-self: stretch;
  font-family: "Work Sans", Helvetica;
  font-weight: 400;
  color: #222222;
  font-size: 18px;
  text-align: justify;
  letter-spacing: 0;
  line-height: 28px;
}

.placeholder .icon-park-outline {
  position: absolute;
  width: 48px;
  height: 48px;
  top: 26px;
  left: 340px;
  overflow: hidden;
  transform: rotate(-180.00deg);
}

.placeholder .vector-11 {
  position: absolute;
  width: 35px;
  height: 29px;
  top: 3854px;
  left: 4405px;
  transform: rotate(180.00deg);
}

.placeholder .vector-12 {
  position: absolute;
  width: 35px;
  height: 29px;
  top: 3854px;
  left: 4885px;
  transform: rotate(180.00deg);
}

.placeholder .frame-26 {
  display: flex;
  flex-direction: column;
  width: 450px;
  height: 216px;
  align-items: flex-start;
  gap: 10px;
  padding: 30px;
  position: relative;
  background-color: #ffffff;
  border-radius: 10px;
}

.placeholder .vector-13 {
  position: absolute;
  width: 35px;
  height: 29px;
  top: 3854px;
  left: 5365px;
  transform: rotate(180.00deg);
}

.placeholder .frame-27 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 40px;
  position: absolute;
  top: 1435px;
  left: 520px;
}

.placeholder .text-wrapper-25 {
  position: relative;
  width: fit-content;
  font-family: "Work Sans", Helvetica;
  font-weight: 400;
  color: #222222;
  font-size: 32px;
  text-align: center;
  letter-spacing: -1.28px;
  line-height: 42px;
  white-space: nowrap;
}

.placeholder .image-4 {
  position: relative;
  width: 380px;
  height: 106px;
  margin-top: -1260.58px;
  margin-left: -3983.00px;
}

.placeholder .image-5 {
  position: relative;
  width: 120px;
  height: 124.83px;
  margin-top: -1270.00px;
  margin-left: -3563.00px;
  object-fit: cover;
}
/* Original CSS code should be injected here */

/* Additional styles for semantic improvements and accessibility */

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Form input improvements */
.input input,
.div-wrapper input,
.input-3 textarea {
  width: 100%;
  border: none;
  background: transparent;
  font-family: var(--home-body-16-font-family);
  font-weight: var(--home-body-16-font-weight);
  color: #5f788a;
  font-size: var(--home-body-16-font-size);
  letter-spacing: var(--home-body-16-letter-spacing);
  line-height: var(--home-body-16-line-height);
  font-style: var(--home-body-16-font-style);
  outline: none;
}

.input-3 textarea {
  resize: vertical;
  min-height: 160px;
}

.input-wrapper {
  flex: 1;
}

/* Checkbox improvements */
.checkbox-input {
  position: absolute;
  opacity: 0;
  width: 18px;
  height: 18px;
  margin: 0;
}

.checkbox .checkbox-input + .label::before,
.checkbox-2 .checkbox-input + .label-2::before {
  content: "";
  display: inline-block;
  width: 18px;
  height: 18px;
  margin-right: 6px;
  background-size: 100% 100%;
  vertical-align: top;
  flex-shrink: 0;
}

.checkbox .checkbox-input + .label::before {
  background-image: url(./img/checked-unchecked-2.svg);
}

.checkbox .checkbox-input:checked + .label::before {
  background-image: url(./img/icon.png);
}

.checkbox-2 .checkbox-input + .label-2::before {
  background-image: url(./img/checked-unchecked.svg);
}

.checkbox-2 .checkbox-input:checked + .label-2::before {
  background-image: url(./img/icon.png);
}

.checkbox .label,
.checkbox-2 .label-2 {
  display: flex;
  align-items: flex-start;
  cursor: pointer;
}

/* Remove old checkbox styling */
.checkbox-checked,
.icon,
.icon-2 {
  display: none;
}

/* Link styling for email */
.chantal-endodata-fr {
  text-decoration: none;
  color: inherit;
}

.chantal-endodata-fr:hover,
.chantal-endodata-fr:focus {
  text-decoration: underline;
}

/* Button focus improvements */
.button:focus-visible,
.button-2:focus-visible,
.d-couvrir-wrapper:focus-visible,
.play:focus-visible {
  outline: 2px solid #ffffff;
  outline-offset: 2px;
}

/* Semantic section grouping */
.stakeholder-group {
  position: absolute;
}

.industriel-group {
  top: 589px;
  left: 288px;
}

.endodontist-group {
  top: 250px;
  left: 393px;
}

.patient-group {
  top: 250px;
  left: 774px;
}

.correspondent-group {
  top: 589px;
  left: 901px;
}

.researcher-group {
  top: 850px;
  left: 574px;
}

/* Improve link accessibility in blog cards */
.card .text-wrapper-3 {
  text-decoration: none;
  color: #222222;
  transition: color 0.2s ease;
}

.card .text-wrapper-3:hover,
.card .text-wrapper-3:focus {
  color: #47596b;
  text-decoration: underline;
}

/* Form validation styles */
.input input:invalid,
.div-wrapper input:invalid,
.input-2:invalid,
.input-3 textarea:invalid {
  border: 1px solid #e74c3c;
}

.input input:valid,
.div-wrapper input:valid,
.input-2:valid,
.input-3 textarea:valid {
  border: 1px solid #27ae60;
}

/* Improve form field focus states */
.input:focus-within,
.div-wrapper:focus-within,
.input-2:focus,
.input-3:focus-within {
  box-shadow: 0 0 0 2px rgba(71, 89, 107, 0.3);
}


@media(max-width: 991.98px) and (min-width: 768px){
  .placeholder .implantodata-est-un {
      font-size: 1.4vw;
  }

  .placeholder .text-wrapper-19 {
      font-size: 1.5vw;
  }

  .placeholder .text-wrapper-20 {
      font-size: 1.5vw;
  }

  .placeholder .img-2 {
      width: 2vw;
      height: 2vw;
  }

  .placeholder .content {
      width: 90%;
  }

  .placeholder .text {
      width: 60%;
  }

  .placeholder .implantodata-logo-wrapper {
      width: 40%;
  }

  .placeholder .chantal-endodata-fr {
      font-size: 1.5vw;
  }
}
@media(max-width: 767.98px) {
  .placeholder .content {
    width: calc(100% - 32px);
    display: flex;
    flex-direction: column;
    padding: 60px 0;
  }

  .placeholder .content-wrapper {
    min-height: 100%;
    height: auto;
    position: static;
  }

  .placeholder .text {
    width: 100%;
    order: 1;
  }

  .placeholder .implantodata-logo-wrapper {
    width: 100%;
    order: 2;
    max-width: 690px;
  } 

  .placeholder {
    display: block;
    min-height: 100%;
  }
  .placeholder .div {
    height: auto;
  }

  .placeholder .text-wrapper-17 {
    font-size: 40px;
    line-height: 35px;
  }

  .placeholder .text-wrapper-18 {
    font-size: 40px;
    line-height: 35px;
  }

  .placeholder .implantodata-est-un {
    font-size: 16px;
  }

  .placeholder .text-wrapper-19 {
      font-size: 18px;
  }

  .placeholder .img-2 {
      width: 32px;
      height: 32px;
  }

  .placeholder .chantal-endodata-fr {
      font-size: 18px;
  }

  .placeholder .text-wrapper-20 {
      font-size: 18px;
  }
}