.intro__inner {
  display: flex;
  flex-direction: column;
}

.intro-slider {
  position: relative;
  height: 334px;
  width: 100%;
}

.intro-slider .swiper-wrapper {
  height: 100%;
}

.intro-slider .swiper-slide {
  height: 100%;
  position: relative;
}

.intro-slider__pagination {
  position: absolute;
  bottom: 12px;
  left: 50%;
  transform: translateX(-50%);
  width: 64px;
  height: 20px;
  overflow: hidden;
  z-index: 10;
}

.slider-pagination__bullet {
  position: absolute;
  left: 50%;
  top: 50%;
  background: var(--color-red);
}

.intro-slider .swiper-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
}

.intro-slide__overlay-link {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.intro-slide__btn-wrap {
  position: absolute;
  bottom: 42px;
  z-index: 2;
  display: flex;
}

.intro-slide__btn-wrap--left {
  left: 32px;
}

.intro-slide__btn-wrap--center {
  left: 50%;
  transform: translateX(-50%);
}

.intro-slide__btn-wrap--right {
  right: 32px;
}

.intro-slider__left,
.intro-slider__right {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
}

.intro-slider__left {
  left: 20px;
}

.intro-slider__right {
  right: 20px;
}

.intro__cards-wrapper {
  position: relative;
  height: 232px;
}

.intro__cards {
  position: absolute;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(0px, 1fr));
  gap: 12px;
  padding-bottom: 12px;
  height: 232px;
  left: 0;
  top: 0;
  width: 100%;
}

.intro__card {
  border: 1px solid #F1F1F1;
  border-radius: 0px 0px 6px 6px;
  height: 220px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  text-align: center;
  padding: 34px 34px 14px;
  transition: all 0.2s ease-in-out;
}

.intro__card:hover {
  height: 240px;
  box-shadow: 0px 4px 4px 0px #00000040;
  background-color: var(--color-red);
  padding-bottom: 22px;
  border-color: var(--color-red);
}

.intro__card-text {
  font-weight: 600;
  font-size: 16px;
  line-height: 120%;
  text-align: center;
  text-transform: uppercase;
  color: var(--color-text);
  transition: 0.2s all ease-in-out;
}

.intro__card:hover .intro__card-text {
  color: var(--color-white);
}

.intro__card-icon {
  width: 86px;
  height: 86px;
  transition: 0.2s all ease-in-out;
}

.intro__card-icon svg,
.intro__card-icon img {
  width: 100%;
  height: auto;
}

.intro__card:hover .intro__card-icon {
  width: 108px;
  height: 108px;
}

.intro__services {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
}

.intro__service {
  border: 1px solid var(--color-white);
  background-color: #4D5154;
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: auto auto;
  gap: 8px 20px;
  padding: 16px 0;
  justify-content: center;
  padding-left: 17px;
  transition: background-color 0.25s ease;
}

.intro__service:hover {
  background-color: #2D2E2F;
}

.intro__service-icon {
  width: 68px;
  flex-shrink: 0;
  height: 68px;
  grid-row: 1 / 3;
}

.intro__service-icon img,
.intro__service-icon svg {
  width: 100%;
  height: auto;
}

.intro__service-title {
  font-weight: 600;
  font-size: 16px;
  line-height: 120%;
  text-transform: uppercase;  
  color: var(--color-white);
}

.intro__service-text {
  font-weight: 400;
  font-size: 12px;
  line-height: 130%;
  color: var(--color-white);
}

.contacts {
  background-color: #EEF2F3;
}

.contacts__inner {
  display: flex;
  gap: 32px;
  align-items: flex-start;
}

.contacts__form {
  background-color: var(--color-red);
  padding: 24px 20px;
  display: flex;
  flex-direction: column;
  box-shadow: 4px 4px 10px 0px #00000026;
  width: 392px;
}

.contacts__title {
  font-weight: 600;
  font-size: 26px;
  line-height: 120%;
  letter-spacing: 0px;
  text-align: center;
  vertical-align: middle;
  text-transform: uppercase;
  color: var(--color-white);
  margin-bottom: 24px;
}

.contacts__form .input-text {
  margin-bottom: 10px;
}

.contacts__form .input-file {
  margin-bottom: 16px;
}

.contacts__form .checkbox {
  margin-bottom: 24px;
}

.contacts__form .btn {
  width: 100%;
}

.portfolio {
  padding: 64px 0 64px 102px;
  position: relative;
  width: calc(100% - 392px - 32px);
}

.portfolio::before {
  display: block;
  content: '';
  position: absolute;
  width: 230px;
  height: 100%;
  left: 0;
  top: 0;
  background-color: var(--color-red);
}

.portfolio__title {
  position: absolute;
  z-index: 2;
  writing-mode: sideways-lr;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  opacity: 0.4;
  font-weight: 600;
  font-size: 60px;
  line-height: 120%;
  letter-spacing: 0px;
  text-align: center;
  text-transform: uppercase;
  color: var(--color-white);
}

.portfolio-wrapper {
  position: relative;
  width: 100%;
}

.portfolio-slider {
  width: 100%;
  height: 393px;
}

.portfolio-slider .swiper-slide a {
  display: block;
  width: 100%;
  height: 100%;
}

.portfolio-slider .swiper-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  transition: scale 0.5s ease;
}

.portfolio-slider .swiper-slide img:hover {
  scale: 1.1;
}

.portfolio-slider__right {
  position: absolute;
  z-index: 10;
  right: -20px;
  top: 50%;
  transform: translateY(-50%);
}

.portfolio-slider__left {
  position: absolute;
  z-index: 10;
  left: -20px;
  top: 50%;
  transform: translateY(-50%);
}

.portfolio__pagination {
  position: absolute;
  left: 50%;
  top: calc(100% + 20px);
  transform: translateX(-50%);
  width: 64px;
  height: 20px;
  overflow: hidden;
  z-index: 10;
}

.portfolio__link {
  font-weight: 600;
  font-size: 14px;
  line-height: 130%;
  letter-spacing: 0px;
  color: var(--color-red);
  display: flex;
  align-items: center;
  gap: 2px;
  position: absolute;
  z-index: 10;
  bottom: 24px;
  right: 0; 
}

.portfolio__link:hover {
  opacity: 0.8;
}

.partners__inner {
  display: flex;
  flex-direction: column;
  gap: 44px;
  padding: 64px 0;
}

.partners__title {
  font-weight: 600;
  font-size: 32px;
  line-height: 120%;
  letter-spacing: 0px;
  text-align: center;
  vertical-align: middle;
  text-transform: uppercase;
  color: #4D5154;
}

.partners__slider {
  height: 100%;
}

.partners-slide {
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: var(--color-white);
  padding: 0 10px;
}

.partners-slide__img {
  width: 100%;
  max-width: 144px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.partners-slide__img img {
  width: 100%;
  height: auto;
  filter: grayscale(1) brightness(1.1);
  transition: filter 0.25s ease;
}

.partners-slide:hover .partners-slide__img img {
  filter: grayscale(0) brightness(1);
}

.partners__wrapper {
  height: 96px;
  width: 100%;
  position: relative;
}

.partners__slider-left {
  position: absolute;
  left: clamp(-54px, calc(5vw * -1), 25px);
  top: 50%;
  transform: translateY(-50%);
}
.partners__slider-right {
  position: absolute;
  right: clamp(-54px, calc(5vw * -1), 25px);
  top: 50%;
  transform: translateY(-50%);
}

@media (max-width: 1340px) {
.partners__slider-left {
    display: none;
  }
  .partners__slider-right {
    display: none;
  }
}

@media (max-width: 1080px) {
  .intro__services {
    grid-template-columns: 1fr 1fr;
  }

  .intro__cards-wrapper {
    height: auto;
  }

  .intro__cards {
    position: initial;
    grid-template-columns: 1fr 1fr 1fr;
    height: auto;
  }

  .intro__card {
    height: 100%;
    padding: 20px 0 10px;
    gap: 32px;
    justify-content: flex-start;
  }

  .intro__card:hover {
    height: 100%;
    padding: 20px 0 10px;
  }

  .intro__card-text {
    font-size: 14px;
  }

  .intro__card-icon {
    width: 86px;
    height: 86px;
  }

  .intro__card:hover .intro__card-icon {
    width: 86px;
    height: 86px;
  }

  .portfolio__title {
    writing-mode: initial;
    opacity: 1;
    transform: none;
    z-index: 10;
    position: relative;
    font-size: 26px;
    margin-bottom: 24px;
    left: initial;
    top: initial;
  }

  .contacts__inner {
    gap: 0;
  }

  .portfolio {
    padding: 24px 24px 86px;
    width: calc(100% - 300px);
  }

  .portfolio::before {
    width: 100%;
    height: 189px;
  }

  .contacts__form {
    width: 300px;
  }

  .portfolio__link {
    right: 24px;
    bottom: 56px;
  }

  .portfolio__pagination {
    top: calc(100% + 10px);
  }

  
}

@media (max-width: 768px) {
  .intro__services {
    grid-template-columns: 1fr;
  }

  .intro__cards {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    padding-bottom: 16px;
  }

  .intro-slider__left {
    left: 0;
  }

  .intro-slider__right {
    right: 0;
  }

  .contacts__inner {
    flex-direction: column;
  }

  .portfolio {
    width: 100%;
    padding: 24px 0 86px;
  }

  .contacts__form {
    width: 100%;
    padding: 24px 12px;
  }

  .portfolio-slider__left {
    left: -5px;
  }

  .portfolio-slider__right {
    right: -5px;
  }

  .portfolio-wrapper {
    padding: 0 10px;
  }

  .portfolio-slider {
    height: 200px;
  }

  .intro-slider {
    height: 210px;
  }

  .partners__slider-left, .partners__slider-right {
    display: none;
}
}