@charset "UTF-8";
/*
 * Proportional function
 * Help compute proportional size in rem according to the width
*/
/* =========================
 * == Highlighting texts
 ========================= */
mark {
  --_highlighted-color-from: var(--highlighted-color-from, white);
  --_highlighted-color-to: var(--highlighted-color-to, rgba(255, 255, 255, 0));
  padding-left: 0.17ch;
  margin-left: -0.17ch;
  background: linear-gradient(90deg, var(--_highlighted-color-from) 0%, var(--_highlighted-color-to) 100%) no-repeat 0 50%;
  background-size: 0 100%;
  animation: mark-reveal 1.5s ease-out forwards;
  color: inherit;
}

@keyframes mark-reveal {
  to {
    background-size: 100% 100%;
  }
}
/* =================
 * == Over titles
 =================== */
.over-title {
  position: relative;
  text-transform: uppercase;
  font: 400 max(1.125rem, 0.9375dvw)/normal "Fjalla One", sans-serif;
  letter-spacing: -0.05625rem;
}

.technologies {
  display: flex;
  flex-flow: row nowrap;
  gap: max(10px, 0.2604166667dvw);
  width: max-content;
  overflow: scroll;
  scroll-snap-type: x mandatory;
  /* Hide scrollbar for IE, Edge and Firefox */
  -ms-overflow-style: none; /* IE and Edge */
  scrollbar-width: none; /* Firefox */
  position: relative;
  /* Hide scrollbar for Chrome, Safari and Opera */
}
.technologies::-webkit-scrollbar {
  display: none;
}
.technologies-item {
  scroll-snap-align: start;
  padding: 20px 40px;
  display: flex;
  flex-flow: column nowrap;
  align-items: center;
  justify-content: center;
  gap: 1.3888888889dvh;
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(75px);
}
.technologies-item .image {
  height: max(40px, 3.125dvw);
  width: auto;
}
.technologies-item .image picture, .technologies-item .image img {
  width: auto;
  height: 100%;
  object-fit: contain;
}
.technologies-item p {
  color: #fff;
  font: normal max(20px, 1.0416666667dvw)/1.2 "Schibsted Grotesk", sans-serif;
}

.services {
  background: linear-gradient(270deg, rgba(255, 255, 255, 0) 5.77%, rgba(255, 255, 255, 0.4) 71.01%);
  backdrop-filter: blur(30px);
  padding: 7.2916666667dvw;
}
.services-item {
  padding: 5.5555555556dvh 0;
  border-top: 1px solid #fff;
}
@media screen and (max-width: 1024px) {
  .services-item {
    padding: 3.2051282051dvh 0;
  }
}
.services-item:first-child {
  padding-top: 0;
  border-top: 0;
}
.services-item:last-child {
  padding-bottom: 0;
}

.image-text {
  display: flex;
  flex-flow: row nowrap;
  background: #F6F7FF;
  margin: 0 7.2916666667dvw;
}
@media screen and (max-width: 1024px) {
  .image-text {
    flex-flow: column-reverse nowrap;
    padding: 7.2916666667dvw;
    margin: 0;
  }
}
.image-text__image {
  flex: 0 0 50%;
  position: relative;
}
.image-text__image .image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 1024px) {
  .image-text__image .image {
    position: relative;
    --aspect-ratio: 351/537;
  }
}
@media screen and (max-width: 1024px) {
  .image-text__image {
    flex: none;
  }
}
.image-text__content {
  flex: 1;
  padding: 6.9270833333dvw 11.1111111111dvh 6.9270833333dvw 8.8541666667dvw;
  display: flex;
  flex-flow: column nowrap;
  justify-content: center;
}
.image-text__content .over-title {
  margin-bottom: 2.0512820513dvh;
}
.image-text__content-title {
  margin-bottom: 4.1025641026dvh;
}
@media screen and (max-width: 1024px) {
  .image-text__content {
    padding: 0 0 4.358974359dvh;
  }
}

.double-accordion {
  display: flex;
  flex-flow: column nowrap;
}
.double-accordion__item {
  padding: 3.125dvh 0;
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  align-items: center;
  border-bottom: solid 1px #152B46;
}
.double-accordion__item:first-child {
  border-top: solid 1px #152B46;
}
.double-accordion__item-header {
  width: 44.6483180428%;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 1024px) {
  .double-accordion__item-header {
    order: 1;
    width: 92%;
    margin-bottom: 2.7dvh;
  }
}
.double-accordion__item-header .double-accordion__item--number {
  width: 14.2465753425%;
  text-align: center;
  margin-top: 8px;
}
.double-accordion__item-header .double-accordion__item--title {
  width: 81.095890411%;
}
.double-accordion__item-content {
  width: 49.4801223242%;
}
@media screen and (max-width: 1024px) {
  .double-accordion__item-content {
    order: 3;
    width: 100%;
    padding-left: 17.8082191781%;
  }
}
.double-accordion__item-content .p-content {
  max-height: 0;
  transition: max-height 0.3s ease-in-out;
  overflow: hidden;
}
.double-accordion__item--first_sentence {
  transition: font-weight 0.3s ease-in-out;
}
.double-accordion__item-button {
  width: 1.7125382263%;
}
@media screen and (max-width: 1024px) {
  .double-accordion__item-button {
    order: 2;
    width: 8%;
    margin-bottom: 2.7dvh;
  }
}
.double-accordion__item-button .icon {
  display: block;
  width: 100%;
  height: auto;
  position: relative;
  aspect-ratio: 1;
}
.double-accordion__item-button .icon > * {
  height: 3px;
  width: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: #152B46;
  transition: transform 1s cubic-bezier(0.2, 0.9, 0.5, 1);
}
.double-accordion__item-button .icon > *:nth-child(2) {
  transform: translate(-50%, -50%) rotate(90deg);
}
.double-accordion__item.open .double-accordion__item--first_sentence {
  font-weight: 700;
}
.double-accordion__item.open .double-accordion__item-content .p-content {
  max-height: var(--max-height, 1000px);
}
.double-accordion__item.open .double-accordion__item-button .icon > *:nth-child(2) {
  transform: translate(-50%, -50%) rotate(180deg);
}

.button-arrow {
  --_arrow-size: var(--arrow-size, 60px);
  min-height: var(--_arrow-size);
  max-height: var(--_arrow-size);
  aspect-ratio: 1;
  border-radius: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #fff;
}
@media screen and (max-width: 1024px) {
  .button-arrow {
    --_arrow-size: var(--arrow-size, 40px);
  }
}
.button-arrow svg {
  width: min(20px, 33.3333333333%);
}

.carousel.carousel--nav-arrow, .carousel.carousel--nav-arrow-title {
  display: flex;
  flex-flow: column nowrap;
  gap: 45px;
}
@media screen and (max-width: 1024px) {
  .carousel.carousel--nav-arrow, .carousel.carousel--nav-arrow-title {
    gap: 10px;
  }
}
.carousel.carousel--nav-arrow .carousel__navigation, .carousel.carousel--nav-arrow-title .carousel__navigation {
  display: flex;
  gap: 10px;
  flex-flow: row wrap;
  justify-content: var(--_nav-align);
  align-items: center;
}
.carousel.carousel--nav-arrow .carousel__navigation-next, .carousel.carousel--nav-arrow .carousel__navigation-prev, .carousel.carousel--nav-arrow-title .carousel__navigation-next, .carousel.carousel--nav-arrow-title .carousel__navigation-prev {
  --arrow-size: 60px;
  border-radius: 50px;
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #152B46;
  /**
   * DISABLE DEFAULT BUTTON STYLE
   **/
  border: none;
  outline: none;
  cursor: pointer;
  transition: background 0.3s cubic-bezier(0.2, 0.9, 0.5, 1);
}
@media screen and (max-width: 1024px) {
  .carousel.carousel--nav-arrow .carousel__navigation-next, .carousel.carousel--nav-arrow .carousel__navigation-prev, .carousel.carousel--nav-arrow-title .carousel__navigation-next, .carousel.carousel--nav-arrow-title .carousel__navigation-prev {
    --arrow-size: 40px;
  }
}
.carousel.carousel--nav-arrow .carousel__navigation-next[disabled], .carousel.carousel--nav-arrow .carousel__navigation-prev[disabled], .carousel.carousel--nav-arrow-title .carousel__navigation-next[disabled], .carousel.carousel--nav-arrow-title .carousel__navigation-prev[disabled] {
  cursor: not-allowed;
  background: rgba(21, 43, 70, 0.2);
}
.carousel.carousel--nav-arrow .carousel__navigation-next svg, .carousel.carousel--nav-arrow .carousel__navigation-prev svg, .carousel.carousel--nav-arrow-title .carousel__navigation-next svg, .carousel.carousel--nav-arrow-title .carousel__navigation-prev svg {
  color: #fff;
  width: 33.3333333333%;
}
@media screen and (max-width: 1024px) {
  .carousel.carousel--nav-arrow .carousel__navigation-next, .carousel.carousel--nav-arrow .carousel__navigation-prev, .carousel.carousel--nav-arrow-title .carousel__navigation-next, .carousel.carousel--nav-arrow-title .carousel__navigation-prev {
    background: #152B46;
  }
  .carousel.carousel--nav-arrow .carousel__navigation-next[disabled], .carousel.carousel--nav-arrow .carousel__navigation-prev[disabled], .carousel.carousel--nav-arrow-title .carousel__navigation-next[disabled], .carousel.carousel--nav-arrow-title .carousel__navigation-prev[disabled] {
    background: transparent;
  }
  .carousel.carousel--nav-arrow .carousel__navigation-next svg, .carousel.carousel--nav-arrow .carousel__navigation-prev svg, .carousel.carousel--nav-arrow-title .carousel__navigation-next svg, .carousel.carousel--nav-arrow-title .carousel__navigation-prev svg {
    color: #fff;
  }
}
@media screen and (max-width: 1024px) {
  .carousel.carousel--nav-arrow .carousel__navigation-next, .carousel.carousel--nav-arrow .carousel__navigation-prev, .carousel.carousel--nav-arrow-title .carousel__navigation-next, .carousel.carousel--nav-arrow-title .carousel__navigation-prev {
    background: #152B46;
  }
  .carousel.carousel--nav-arrow .carousel__navigation-next[disabled], .carousel.carousel--nav-arrow .carousel__navigation-prev[disabled], .carousel.carousel--nav-arrow-title .carousel__navigation-next[disabled], .carousel.carousel--nav-arrow-title .carousel__navigation-prev[disabled] {
    background: transparent;
  }
  .carousel.carousel--nav-arrow .carousel__navigation-next svg, .carousel.carousel--nav-arrow .carousel__navigation-prev svg, .carousel.carousel--nav-arrow-title .carousel__navigation-next svg, .carousel.carousel--nav-arrow-title .carousel__navigation-prev svg {
    color: #fff;
  }
}
.carousel.carousel--nav-arrow .carousel__navigation-next, .carousel.carousel--nav-arrow-title .carousel__navigation-next {
  transform: rotate(45deg);
}
.carousel.carousel--nav-arrow .carousel__navigation-prev, .carousel.carousel--nav-arrow-title .carousel__navigation-prev {
  transform: rotate(-135deg);
}
.carousel.carousel--nav-arrow.carousel--padding-left .carousel__navigation, .carousel.carousel--nav-arrow-title.carousel--padding-left .carousel__navigation {
  padding-left: 7.2916666667dvw;
}
.carousel.carousel--nav-arrow.carousel--padding-right .carousel__navigation, .carousel.carousel--nav-arrow-title.carousel--padding-right .carousel__navigation {
  padding-right: 7.2916666667dvw;
}
.carousel.carousel--nav-arrow .carousel__navigation__titles-wrapper .carousel__navigation__titles-title, .carousel.carousel--nav-arrow-title .carousel__navigation__titles-wrapper .carousel__navigation__titles-title {
  display: none;
}
.carousel.carousel--nav-arrow .carousel__navigation__titles-wrapper .carousel__navigation__titles-title.active, .carousel.carousel--nav-arrow-title .carousel__navigation__titles-wrapper .carousel__navigation__titles-title.active {
  display: block;
}

.carousel {
  --_card-gap: var(--card-gap, 96px);
  --_nav-align: var(--nav-align, left);
  /* Hide scrollbar for IE, Edge and Firefox */
  -ms-overflow-style: none; /* IE and Edge */
  scrollbar-width: none; /* Firefox */
  position: relative;
  /* Hide scrollbar for Chrome, Safari and Opera */
}
.carousel::-webkit-scrollbar {
  display: none;
}
.carousel__navigation .over-title {
  margin-right: auto;
}
.carousel__navigation--list {
  display: flex;
  flex-flow: column nowrap;
  justify-content: flex-end;
  min-width: 17.96875dvw;
  width: max-content;
  gap: max(12px, 0.9375dvw);
}
@media screen and (max-width: 1024px) {
  .carousel__navigation--list {
    width: 100%;
    overflow: auto;
    flex-flow: row nowrap;
    justify-content: flex-start;
    gap: 10px;
    -ms-overflow-style: none;
    scrollbar-width: none;
  }
  .carousel__navigation--list::-webkit-scrollbar {
    display: none;
  }
}
.carousel__navigation-item {
  opacity: 0.5;
  color: #fff;
  transition: opacity 0.3s cubic-bezier(0.2, 0.9, 0.5, 1);
  cursor: pointer;
}
@media screen and (max-width: 1024px) {
  .carousel__navigation-item {
    flex: 0 0 auto; /* Empêche les items de se rétrécir */
    white-space: nowrap; /* Empêche le texte de passer à la ligne */
  }
}
.carousel__navigation-item.active {
  opacity: 1;
}
.carousel__navigation-item .heading-4 + .taxonomy-list {
  margin-top: max(8px, 0.4166666667dvw);
}
.carousel__header {
  max-width: 38.6979166667dvw;
  margin-right: auto;
}
@media screen and (max-width: 1024px) {
  .carousel__header {
    max-width: 100%;
    margin-bottom: 20px;
  }
}
.carousel__header .over-title {
  margin-bottom: 1.0416666667dvw;
}
.carousel--nav-list {
  display: grid;
  grid-template-columns: max-content 60px 1fr;
  grid-template-areas: "nav . slides";
  max-width: calc(100vw - 14.5833333333dvw);
}
@media screen and (max-width: 1024px) {
  .carousel--nav-list {
    grid-template-columns: 100%;
    grid-template-areas: "nav" "slides";
    gap: 4.3243243243dvh;
  }
}
.carousel--nav-list .carousel__navigation {
  grid-area: nav;
}
.carousel--nav-list .carousel__slides {
  position: relative;
  grid-area: slides;
  width: fit-content;
}
.carousel--nav-list .carousel__slides > *:not(:first-child) {
  position: absolute;
  left: 100%;
  top: 0;
  height: 100%;
  transition: left 0.7s cubic-bezier(0.2, 0.9, 0.5, 1);
}
.carousel--nav-list .carousel__slides > *:not(:first-child).slided {
  left: 0;
}
.carousel:not(.animated):not([data-stackable="1"]) .carousel__slides {
  overflow-x: scroll;
  overflow-y: hidden;
}
.carousel:not(.animated) .carousel__slides {
  /* Hide scrollbar for IE, Edge and Firefox */
  -ms-overflow-style: none; /* IE and Edge */
  scrollbar-width: none; /* Firefox */
  /* Hide scrollbar for Chrome, Safari and Opera */
  position: relative;
  display: flex;
  flex-flow: row nowrap;
  align-items: center;
  scroll-snap-type: x mandatory;
  gap: var(--_card-gap);
}
.carousel:not(.animated) .carousel__slides::-webkit-scrollbar {
  display: none;
}
.carousel:not(.animated) .carousel__slides > * {
  scroll-snap-align: start;
}
.carousel:not(.animated).carousel--padding-left .carousel__slides {
  scroll-padding-left: 7.2916666667dvw;
  padding-left: 7.2916666667dvw;
}
.carousel:not(.animated).carousel--padding-right .carousel__slides {
  scroll-padding-right: 7.2916666667dvw;
  padding-right: 7.2916666667dvw;
}

.realisation-card {
  position: relative;
  display: flex;
  flex-flow: column nowrap;
  align-items: center;
  aspect-ratio: 662/780;
  min-width: 34.4791666667dvw;
  max-width: 34.4791666667dvw;
  padding: 30px;
  text-decoration: none;
}
@media screen and (max-width: 1024px) {
  .realisation-card {
    min-width: 73.5897435897dvw;
    max-width: 73.5897435897dvw;
    aspect-ratio: unset;
    height: auto;
  }
}
.realisation-card .background {
  z-index: -1;
  position: absolute;
  inset: 0;
}
.realisation-card .background .image, .realisation-card .background img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.realisation-card .background::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(21, 43, 70, 0.8) 0%, rgba(21, 43, 70, 0.8) 100%);
}
.realisation-card .header {
  width: 100%;
  flex: 1;
  color: #fff;
}
@media screen and (max-width: 1024px) {
  .realisation-card .header {
    flex: none;
  }
  .realisation-card .header p:nth-child(2) {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
}
.realisation-card .content {
  margin: auto 0;
}
.realisation-card .content .video {
  width: 100%;
  aspect-ratio: 488/316;
  padding: 16px 0;
}
.realisation-card .content .video video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.realisation-card .content .video video.is-loading {
  animation: lbt-video-pulse 1.6s ease-in-out infinite;
}
@keyframes lbt-video-pulse {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0.55;
  }
}
.realisation-card .footer {
  flex: 1;
  width: 100%;
  display: flex;
  flex-flow: row nowrap;
  justify-content: space-between;
  align-items: flex-end;
  color: #fff;
}
@media screen and (max-width: 1024px) {
  .realisation-card .footer {
    flex: none;
  }
}
.realisation-card .footer .categories--list {
  display: flex;
  flex-flow: row wrap;
  gap: 5px;
}
@media screen and (max-width: 1024px) {
  .realisation-card .footer .categories--list {
    align-content: flex-start;
    height: calc(2 * (1.2825rem + 10px + 2px) + 5px);
    overflow: hidden;
  }
}
.realisation-card .footer .categories--list .list-item {
  border: 1px solid #fff;
  padding: 5px;
  color: #FFF;
  font: 500 0.75rem/1.71 "Schibsted Grotesk", sans-serif;
  letter-spacing: -0.28px;
}

.accordion-item:first-child .accordion-item__title {
  padding-top: 0;
}
.accordion-item__title {
  cursor: pointer;
  padding: var(--_accordion__margin) 0;
  display: flex;
  justify-content: space-between;
  gap: 10px;
}
.accordion-item__title > * {
  font-size: max(18px, 1.3541666667dvw);
  letter-spacing: -0.0885416667dvw;
}
.accordion-item__icon {
  display: block;
  flex-shrink: 0;
  width: var(--_accordion__button-size);
  height: var(--_accordion__button-size);
  position: relative;
}
@media screen and (max-width: 1024px) {
  .accordion-item__icon {
    width: 28px;
    height: 28px;
  }
}
.accordion-item__icon > * {
  height: 3px;
  width: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: #152B46;
  transition: transform 1s cubic-bezier(0.2, 0.9, 0.5, 1);
}
@media screen and (max-width: 1024px) {
  .accordion-item__icon > * {
    height: 2px;
  }
}
.accordion-item__icon > *:nth-child(2) {
  transform: translate(-50%, -50%) rotate(90deg);
}
.accordion-item__content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.5s cubic-bezier(0.2, 0.9, 0.5, 1);
}
.accordion-item__content__wrapper {
  padding-bottom: 40px;
}
.accordion-item:not(:last-child) {
  border-bottom: 1px solid var(--_accordion__separator-color);
}
.accordion-item:last-child {
  border-bottom: 1px solid var(--_accordion__last-border);
}
.accordion-item.open .accordion-item__icon > *:nth-child(2) {
  transform: translate(-50%, -50%) rotate(180deg);
}
.accordion-item.open .accordion-item__content {
  max-height: var(--max-height, 1000px);
}

.accordion {
  --_accordion__separator-color: var(--accordion__separator-color, #152B46);
  --_accordion__last-border: var(--accordion__last-border, transparent);
  --_accordion__margin: var(--accordion__margin, 20px);
  --_accordion__button-size: var(--accordion__button-size, 42px);
  display: flex;
  flex-flow: column nowrap;
}

.single-need .background-1 {
  padding-top: calc(var(--header-free, 0dvh) + 7dvh);
  position: relative;
}
.single-need .background-1::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -10;
  background: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="1920" height="2327" viewBox="0 0 1920 2327" fill="none"><path d="M0 -22H1920V3368H0V-22Z" fill="url(%23paint0_linear_2092_2831)"/><defs><linearGradient id="paint0_linear_2092_2831" x1="1349" y1="440" x2="1587.83" y2="3387.95" gradientUnits="userSpaceOnUse"><stop stop-color="white"/><stop offset="0.486956" stop-color="%230095FC"/><stop offset="0.97" stop-color="%23152B46"/></linearGradient></defs></svg>');
  background-size: cover;
}
.single-need .section-1 {
  --left-free: 46.3dvw;
  --right-width: 53.7dvw;
  --accordion__separator-color: #fff;
  --accordion__last-border: #fff;
  --accordion__margin: max(20px, 2.6041666667dvw);
  --accordion__button-size: 28px;
  display: grid;
  grid-template-columns: var(--left-free) minmax(0, 1fr);
  padding-bottom: 11.1111111111dvh;
}
@media screen and (max-width: 1024px) {
  .single-need .section-1 {
    --left-free: 7.2916666667dvw;
    --right-width: 85.4166666667dvw;
    grid-template-columns: minmax(0, 1fr);
    padding-bottom: 1.2820512821dvh;
  }
}
.single-need .section-1__header {
  position: sticky;
  top: var(--header-free-scrolled, 0dvh);
  align-self: start;
}
@media screen and (max-width: 1024px) {
  .single-need .section-1__header {
    display: contents;
  }
}
.single-need .section-1__header .technologies {
  margin-left: 7.2916666667dvw;
  max-width: calc(var(--left-free, 0dvw) - 14.5833333333dvw);
  margin-top: 9.2592592593dvh;
  flex-flow: row wrap;
}
@media screen and (max-width: 1024px) {
  .single-need .section-1__header .technologies {
    order: 2;
    flex-flow: row nowrap;
    max-width: 100%;
    margin-left: 0;
    margin-top: 4dvh;
    padding: 0 7.2916666667dvw 3dvh;
    scroll-padding: 0 7.2916666667dvw;
  }
}
.single-need .section-1__title {
  margin: 0 7.2916666667dvw 4dvh;
  max-width: 50dvw;
}
@media screen and (max-width: 1024px) {
  .single-need .section-1__title {
    max-width: 100%;
    margin-bottom: 0;
  }
  .single-need .section-1__title > * {
    margin-bottom: 2dvh;
  }
}
.single-need .section-1__description {
  margin-left: 7.2916666667dvw;
  max-width: 17.0975dvw;
}
@media screen and (max-width: 1024px) {
  .single-need .section-1__description {
    max-width: 100%;
    margin-bottom: 4dvh;
  }
}
.single-need .section-1 .services {
  margin-top: 12.962962963dvh;
  max-width: var(--right-width, 0dvw);
  width: 100%;
}
@media screen and (max-width: 1024px) {
  .single-need .section-1 .services {
    order: 1;
    margin-top: 0;
    margin-left: var(--left-free, 0dvh);
  }
}
.single-need .section-2 {
  margin: 11.1111111111dvh 0;
}
@media screen and (max-width: 1024px) {
  .single-need .section-2 {
    margin: 0;
  }
}
.single-need .section-3 {
  margin: 11.1111111111dvh 0;
}
.single-need .section-3__title {
  max-width: 52.0833333333dvw;
  margin-bottom: 6.6666666667dvh;
}
.single-need .section-4 {
  --btn-hover-background-color: #fff;
  --btn-hover-color: #152B46;
  color: #fff;
  background-color: #FD5E3E;
  padding: 11.1111111111dvh 9.8958333333dvw;
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
  align-items: flex-end;
  gap: 4.1025641026dvh;
}
@media screen and (max-width: 1024px) {
  .single-need .section-4 {
    padding: 6.4102564103dvh 7.2916666667dvw;
  }
}
.single-need .section-4__header {
  position: relative;
  max-width: 37.03125dvw;
}
@media screen and (max-width: 1024px) {
  .single-need .section-4__header {
    width: 100%;
    max-width: 100%;
  }
  .single-need .section-4__header .over-title {
    display: block;
    width: 100%;
    text-align: center;
    margin-bottom: 10px;
  }
}
.single-need .section-4__title {
  --arrow-size: max(58px, 3.125dvw);
  width: fit-content;
  letter-spacing: -0.2864583333dvw;
}
@media screen and (max-width: 1024px) {
  .single-need .section-4__title {
    text-align: center;
    width: 100%;
  }
  .single-need .section-4__title .button-arrow {
    position: absolute;
    top: 0;
    right: 0;
  }
}
.single-need .section-4__title-link {
  display: block;
  width: fit-content;
  color: inherit;
  text-decoration: none;
}
@media screen and (max-width: 1024px) {
  .single-need .section-4__title-link {
    width: 100%;
  }
}
.single-need .section-4__content {
  max-width: 28.6979166667dvw;
}
@media screen and (max-width: 1024px) {
  .single-need .section-4__content {
    max-width: 100%;
  }
}
.single-need .section-4__content--links {
  display: flex;
  flex-flow: row wrap;
  gap: max(6px, 0.78125dvw);
}
@media screen and (max-width: 1024px) {
  .single-need .section-4__content--links {
    justify-content: center;
  }
}
.single-need .section-4__content .p-content {
  margin-bottom: 4.6296296296dvh;
}
@media screen and (max-width: 1024px) {
  .single-need .section-4__content .p-content {
    margin-bottom: 4.1025641026dvh;
    text-align: center;
  }
}
.single-need .section-5 {
  --card-gap: 1.3541666667dvw;
  margin: 11.1111111111dvh 0;
}
.single-need .section-5__content > .button {
  margin: 4.1666666667dvw auto 0;
}
@media screen and (max-width: 1024px) {
  .single-need .section-5__content > .button {
    margin-left: 0;
    max-width: calc(100% - 60px - 7.2916666667dvw);
  }
}
.single-need .section-5__content > .button .button__content > * {
  text-align: center;
  font: 400 max(3.75rem, 3.125dvw)/1.66 "Schibsted Grotesk", sans-serif;
  letter-spacing: -3px;
}
@media screen and (max-width: 1024px) {
  .single-need .section-5__content > .button .button__content > * {
    text-align: left;
    font-size: 7.1794871795dvw;
    line-height: 1.21;
  }
}
.single-need .section-5 .carousel.carousel--nav-arrow {
  gap: 25px;
}