.projet.hero {
  display: flex;
  position: relative;
  gap: 32px;
  width: 100%;
  height: 500px;
  padding-top: 0;
}

.projet.hero .button {
  position: absolute;
  top: 0;
}

.projet.hero .info {
  display: flex;
  flex-direction: column;
  gap: 32px;
  width: 100%;
  justify-content: flex-end;
}

.projet.hero .image {
  width: 100%;
  border-radius: 16px;
  overflow: hidden;
}

.projet.hero .title {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.projet.hero h1 {
  font-family: "Playfair Display", serif;
}

.meta-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 16px;
  background-color: var(--color-200);
  border-radius: 16px;
}

.meta-item {
  display: flex;
  gap: 16px;
}

.meta-item dt {
  font-weight: 700;
  width: 80px;
}

.services {
  display: flex;
  width: 100%;
  gap: 8px;
}

ul.sommaire {
  display: flex;
  position: fixed;
  top: 50%;
  transform: translateY(-50%);
  flex-direction: column;
  align-items: flex-end;
  height: fit-content;
  gap: 8px;
  right: 32px;
}

.sommaire li,
.sommaire a {
  width: 100%;
  display: flex;
  justify-content: flex-end;
  font-weight: 700;
  color: var(--gun-powder-400);
}

.sommaire a span {
  border-bottom: 1px solid var(--white);
}

.sommaire a:hover span {
  border-bottom: 1px solid var(--gun-powder-400);
}

.content {
  display: flex;
  gap: 32px;
  padding-top: 0;
  flex-wrap: wrap;
}

.content .text {
  display: flex;
  flex-direction: column;
  gap: 16px;
  background: var(--color-100);
  border-radius: 16px;
  box-shadow: #3963e02a 0px 4px 8px 2px inset;
  padding: 16px 32px;
  width: 100%;
  min-width: 300px;
  flex: 1 0 0;
  scroll-margin-top: 160px;
}

.content #brief,
.content #concept {
  min-width: 500px;
}

.content #contraintes,
.content #recherche,
.content #livrable {
  min-width: 800px;
}

.research-gallery {
  display: flex;
  gap: 16px;
}

.research-gallery figure {
  position: relative;
  width: 100%;
  height: 400px;
  border-radius: 8px;
  overflow: hidden;
  border: 3px solid var(--color-200);
}

.research-gallery embed {
  width: 100%;
  height: 100%;
}

.research-gallery figcaption {
  position: absolute;
  bottom: 0;
  width: 100%;
  display: flex;
  justify-content: center;
  background-color: var(--color-200);
  padding: 8px;
  font-weight: 700;
}

.cta {
  display: none;
}

.maquette {
  display: flex;
  gap: 16px;
  padding-top: 16px;
  height: 700px;
}

.figma {
  width: 70%;
}

.figma iframe {
  border-radius: 8px;
  overflow: hidden;
  width: 100%;
  height: 100%;
}

.maquette .rendu {
  width: 30%;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.rendu .image,
.rendu iframe {
  border-radius: 8px;
  overflow: hidden;
  width: 100%;
  height: 100%;
}

.video,
.video iframe {
  width: 100%;
  height: 500px;
  border-radius: 8px;
  overflow: hidden;
}

@media screen and (max-width: 1440px) {
  .projet.hero {
    padding-bottom: 32px;
  }

  ul.sommaire {
    display: none;
  }
}

@media screen and (max-width: 1024px) {
  .projet.hero .button {
    left: 0;
  }

  .projet.hero {
    flex-direction: column-reverse;
    gap: 16px;
    padding-top: 40px;
    padding-bottom: 16px;
  }
  .content,
  .research-gallery,
  .maquette {
    flex-wrap: nowrap;
    flex-direction: column;
    height: fit-content;
  }

  .content .text {
    min-width: 100% !important;
  }

  main {
    padding-top: 112px;
  }

  .projet.hero .info,
  .content {
    gap: 16px;
  }

  .content .text {
    padding: 16px;
  }

  .research-gallery figure {
    height: 250px;
  }

  .figma,
  .maquette .rendu {
    width: 100%;
  }

  .figma,
  .figma iframe {
    height: 400px;
  }

  .rendu .image,
  .rendu iframe {
    height: 250px;
  }

  .video,
  .video iframe {
    width: 100%;
    height: 400px;
    border-radius: 8px;
    overflow: hidden;
  }
}
