@import "../../assets/css/swiper.min.css";
@import "../../assets/css/cases.css";

:root {
  --general-color: #00BEFF;
  --cursor-color: #0064AA;
}

picture {
  img {
    height: 100%;
    width: auto;
  }
}

.case-cover__img {
  height: 100vh;
}

.process__img {
  left: 55.412vh;
  top: 11vh;
  height: 25.647vh;
}

.results__title, .results__item-title, .results__item-value {
  color: var(--black);
}

.results__list {
  margin: 16.353vh 0 0 31.647vh;
  gap: 4.545vh;
}

.results__item {
  grid-template-columns: auto 45.412vh;
}

.challenge {
  padding: 0 15.882vh;
}

.challenge__text + .challenge__text {
  margin-top: 16px;
}

.challenge__content {
  padding: 0;

  .challenge__title {
    font: 600 3.765vh/1.3 var(--font);
  }

  .challenge__text {
    font: 400 2.824vh/1.35 var(--font);
  }

  &:nth-of-type(1) {
    width: 79.412vh;
    margin-top: 35.059vh;

    .challenge__title {
      width: 50.176vh;
    }

    .challenge__text {
      padding-left: 16.235vh;
    }
  }

  &:nth-of-type(2) {
    width: 47.529vh;
    margin: 18.118vh 0 0;
  }

  &:nth-of-type(3) {
    width: 79.412vh;
    margin: 21.412vh 0 0 31.765vh;

    .challenge__title {
      width: 48vh;
    }

    .challenge__text {
      padding-left: 16.235vh;
    }
  }

  &:nth-of-type(4) {
    margin: 26.118vh 0 0 15.882vh;
    width: 79.412vh;

    .challenge__text:first-child {
      padding-right: 15.882vh;
    }

    .challenge__text + .challenge__text {
      padding: 18.588vh 0 0 15.882vh;
    }
  }

  &:nth-of-type(5) {
    margin: 22.588vh 0 0 15.882vh;
    width: 61.529vh;
  }

  &:nth-of-type(6) {
    margin: 22.588vh 0 0 15.882vh;
    width: 61.529vh;
  }
}

.challenge__img-1 {
  height: 79.412vh;
  margin: 15.882vh 0 0 15.882vh;
}

.challenge__img-2 {
  height: 71.176vh;
  margin: auto 0 0;
}

.challenge__img-3 {
  height: 63.529vh;
  margin-left: 15.882vh;
}

.challenge__img-3 {
  height: 63.529vh;
  margin-left: 15.882vh;
}

.challenge__img-4 {
  height: 63.529vh;
  margin: 15.882vh 0 0 15.882vh;
}

.challenge__img-5 {
  height: 79.412vh;
  margin: 15.882vh 0 0 15.882vh;
}

.dev-phases-content__item > p, .dev-phases-content > p, .dev-phases-content__title {
  color: var(--black);
}

.dev-phases {
  background: var(--white);
  padding: 0 23.059vh 0 15.882vh;
}

.dev-phases-content__list {
  display: flex;
}

.dev-phases-content {
  margin-left: 0;
  margin-top: 26.353vh;
}

.dev-phases-content > p {
  padding-left: 0;
}

.dev-phases > img {
  margin-left: 22.273vh;
}

.dev-phases-content__list {
  width: auto;
  padding: 10vh 0 0;
  align-items: flex-end;
}

.dev-phases-content__item {
  grid-template-columns: 27.614vh;
  margin-bottom: 0;
}

.dev-phases-content__item::before {
  background: #E7E7E7;
  height: 1px;
  width: 23.4vh;
  top: 11vh;
  left: 4.49vh;
}

.dev-phases-content__item:last-child::before {
  content: none;
}

.dev-phases-content__item:first-child::before {
  top: 14.5vh;
  width: 25.614vh;
  height: 1px;
}

.dev-phases-content__item:nth-of-type(2) {
  overflow: visible;

  &::before {
    left: 6.92vh;
    width: 21.614vh;
  }
}

.dev-phases-content__item > p {
  font-weight: 600;
}

.delivered-features {
  background: transparent;
  flex-direction: row;
  padding: 0 0 0 5.341vh;
}

.delivered-features__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 3.977vh;
  margin: 0 31.765vh 0 15.882vh;
}

.delivered-features__title, .delivered-features__item {
  color: var(--black);
}

.delivered-features__item {
  font: 400 2.824vh/1.35 var(--font);
  padding-left: 7.647vh;

  &::before {
    background: var(--black);
    width: 4.118vh;
    top: 1.9vh
  }
}

.delivered-features__title-vertical {
  text-transform: uppercase;
}

.delivered-features__list {
  width: 79.412vh;
  gap: 10px;
}

.technology-stack {
  background: var(--general-color);
}

.integration {
  padding: 0 30.471vh 0 15.882vh;
}

.integration__img {
  height: 61.647vh;
  margin-top: 21.412vh;
}

.communication-img {
  height: 61.364vh;
}

.case-img {
  width: auto;

  > picture {
    height: 86.588vh;
    margin: 8.471vh 6.824vh 0;
  }
}

@media (max-width: 1280px) {
  picture {
    img {
      width: 100%;
      height: auto;
    }
  }

  .case-cover__img {
    height: auto;
  }

  .process__img {
    width: 48.397vw;
    height: auto;
    margin: 0 10.156vw 0 auto;
  }

  .results {
    padding-bottom: 25.911vw;
  }

  .results__list {
    margin: 10.156vw 0 0 0;
    gap: 5.208vw;
  }

  .results__item-title {
    font-size: 6.51vw;
  }

  .results__item-value {
    font: 400 3.125vw/1.35 var(--font);
  }

  .results__item {
    grid-template-columns: auto 45.573vw;
  }

  .challenge {
    padding: 10.156vw 6.25vw 10.417vw 10.417vw;
  }

  .challenge__content {
    .challenge__title {
      font: 600 3.125vw/1.3 var(--font);
    }

    .challenge__text {
      font: 400 2.604vw/1.35 var(--font);
    }

    &:nth-of-type(1) {
      width: 100%;
      margin-top: 0;

      .challenge__title {
        width: 41.896vw;
      }

      .challenge__text {
        padding-left: 10.156vw;
      }
    }

    &:nth-of-type(2) {
      width: 52.083vw;
      margin: 26.563vw 0 0;
    }

    &:nth-of-type(3) {
      width: 62.5vw;
      margin: -4vw 0 0;

      .challenge__text {
        padding-left: 10.156vw;
      }
    }

    &:nth-of-type(4) {
      width: 100%;
      margin: 8.594vw 0 0;

      .challenge__text:first-child {
        padding: 0 41.536vw 0 0;
      }

      .challenge__text + .challenge__text {
        padding: 8.594vw 0 0 31.25vw;
        margin: 0;
      }
    }

    &:nth-of-type(5) {
      margin: 10.417vw 0 0 auto;
      width: 50.083vw;
    }
  }

  .challenge__img-1 {
    width: 100%;
    height: auto;
    margin: 7.813vw 0 0;
  }

  .challenge__img-2 {
    width: 41.667vw;
    height: auto;
    margin: -21.094vw 0 0 auto;
  }

  .challenge__img-3 {
    width: 62.5vw;
    height: auto;
    margin: 20.313vw 0 0;
  }

  .challenge__img-4 {
    width: 62.37vw;
    height: auto;
    margin: 10.547vw 0 0;
  }

  .challenge__img-5 {
    width: 22.552vw;
    height: auto;
    margin: -7.453vw 0 0;
  }

  .dev-phases-content {
    padding: 0;
    margin: 0;
  }

  .dev-phases {
    padding: 10.156vw 8.594vw 16.797vw 10.156vw;
  }

  .dev-phases-content__item{
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-start;

    > p {
      font: 600 2.083vw/1.25 var(--font);
    }
  }

  .dev-phases-content__item:first-child::before {
    top: 14.3vw;
    width: 13.802vw;
  }

  .dev-phases-content__item::before {
    top: 14.25vw;
    width: 15.05vh;
  }

  .dev-phases-content__item:nth-of-type(2) {
    &::before {
      left: 4vw;
      width: 12.802vw;
    }

    > p {
      width: 85%;
    }
  }

  .dev-phases-content__list {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    align-items: stretch;
    width: 100%;
  }

  .delivered-features__content {
    margin: 0;
    padding: 0 6.25vw 9.766vw 11.719vw;
  }

  .delivered-features {
    padding: 0;
    align-items: flex-start;
  }

  .delivered-features__item {
    font-size: 2.604vw;
    padding-left: 9.766vw;

    &::before {
      background: var(--black);
      width: 4.557vw;
      top: 1.7vw;
    }
  }

  .delivered-features__list {
    width: 100%;
  }

  .integration {
    padding: 10.156vw 8.073vw
  }

  .integration__img {
    width: 71.6vw;
    height: auto;
    margin: 0 auto;
  }

  .communication-img {
    width: 41.667vw;
    height: auto;
    transform: translateX(calc(50vw - 50%));
  }

  .case-img {
    > picture {
      width: 66.667vw;
      height: auto;
      margin: 5.208vw auto 0;
    }
  }
}

@media (max-width: 600px) {
  .process__img {
    width: 65.333vw;
    margin: 0 0 0 auto;
  }

  .results__item {
    grid-template-columns: 1fr;
    padding-right: 1vw;
  }

  .results__item-value {
    font: 400 4.267vw/1.35 var(--font);
  }

  .challenge {
    padding: 19.733vw 12px 0 15px;
  }

  .challenge__content {
    .challenge__title {
      font-size: 5.333vw;
    }

    .challenge__text {
      font: 400 4.8vw/1.25 var(--font);
    }

    &:nth-of-type(1) {
      .challenge__title {
        width: 71vw;
      }

      .challenge__text {
        padding-left: 15.467vw;
      }
    }

    &:nth-of-type(2) {
      width: 100%;
      margin: 13.867vw 0 0;
      padding: 0 11vw 0 0;


      .challenge__text {
        padding: 0;
      }
    }

    &:nth-of-type(3) {
      width: 100%;
      margin: -2vw 0 0;

      .challenge__title {
        width: 69vw;
      }

      .challenge__text {
        padding-left: 15.467vw;
      }
    }

    &:nth-of-type(4) {
      margin: 10.933vw 0 0;
      padding-right: 9.2vw;

      .challenge__text:first-child {
        padding: 0;
      }

      .challenge__text + .challenge__text {
        padding: 15.733vw 0 0;
      }
    }

    &:nth-of-type(5) {
      margin: 9.333vw auto 0 0;
      width: 85.083vw;

      .challenge__text {
        padding: 0;
      }
    }
  }

  .challenge__img-1 {
    width: 77.067vw;
    margin: 34.4vw auto 0;
  }

  .challenge__img-2 {
    width: 46.4vw;
    margin: 0 15px 0 auto;
  }

  .challenge__img-3 {
    width: 73.333vw;
    margin: 27.2vw 0 0;
  }

  .challenge__img-4 {
    width: 73.067vw;
    margin: 34.667vw 16px 0 auto;
  }

  .challenge__img-5 {
    width: 42.552vw;
    height: auto;
    margin: 9.333vw 0 0 17vw;
  }

  .dev-phases-content__list {
    grid-template-columns: 1fr;
    align-items: flex-start;
  }


  .delivered-features__content {
    padding: 15.467vw 0 0;
  }

  .delivered-features {
    flex-direction: column;
    padding: 0 12px 15.2vw 15px;
  }

  .delivered-features__list {
    width: 100%;
    margin-top: 0;
  }

  .delivered-features__item {
    font-size: 4.8vw;
    padding-left: 10.667vw;

    &::before {
      width: 5.333vw;
      top: 3.2vw;
    }
  }

  .dev-phases {
    padding: 15.467vw 12px 18.933vw 12px;
  }

  .dev-phases-content__item {
    flex-direction: row-reverse;
    align-items: center;
    gap: 5.333vw;
    padding-bottom: 10vw;

    > p {
      width: 100%;
      font-size: 5.333vw;
    }
  }

  .dev-phases-content > p {
    font-size: 5.333vw;
  }

  .dev-phases-content__item::before {
    left: 4.2vw;
    width: 1px;
    height: 13.3vw;
    top: 9.25vw;
  }

  .dev-phases-content__item:first-child::before {
    top: 9vw;
    width: 1px;
    height: 16vw;
  }

  .dev-phases-content__item:nth-of-type(2) {
    &::before {
      left: 4.4vw;
      width: 1px;
      top: 10vw;
      height: 12vw;
    }
  }

  .dev-phases-content__item:nth-last-child(2) {
    &::before {
      height: 14.2vw;
    }
  }

  .case-img {
    > picture {
      width: 88vw;
      margin: 0 auto;
    }
  }

  .technology-stack__item:first-child {
    grid-row: span 2;;
  }

  .integration {
    padding: 15.467vw 12px 15.467vw 15px;
  }

  .integration__img {
    width: 57.87vw;
  }

  .communication-img {
    width: 72vw;
  }
}
