.banner-wrap img {
  height: unset;
  object-fit: contain;
}

.parts-wrap .rw {
  display: flex;
  justify-content: space-between;
  padding: 60px 0;
}
.parts-wrap .rw .cover {
  padding-top: 100px;
}
.parts-wrap .rw .cover img {
  display: block;
  max-width: 100%;
}
.parts-wrap .rw .right {
  margin-left: 30px;
}
.parts-wrap .rw ul {
  max-width: 628px;
  margin: -10px;
}
.parts-wrap .rw ul li {
  padding: 10px;
  text-align: center;
}
.parts-wrap .rw ul li .wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  background: #F7F8FC;
  border-radius: 6px 6px 6px 6px;
  height: 175px;
  overflow: hidden;
  position: relative;
}
.parts-wrap .rw ul li .wrap::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(to bottom, transparent, rgba(19, 53, 134, 0.2), rgba(19, 53, 134, 0.8));
  opacity: .9;
  transform: scale(3);
  opacity: 0;
  transition: all .3s ease;
}
.parts-wrap .rw ul li .wrap:hover p {
  color: #fff;
}
.parts-wrap .rw ul li .wrap:hover::after {
  transform: scale(1);
  opacity: 1;
}
.parts-wrap .rw ul li .icon {
  height: 120px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.parts-wrap .rw ul li p {
  margin: unset;
  transition: color .3s ease;
  position: relative;
  z-index: 1;
}


@media screen and (max-width: 640px) {
  .parts-wrap .rw {
    display: block;
    padding: 50px 0;
  }
  .parts-wrap .rw .cover {
    padding: unset;
    margin-bottom: 30px;
  }
  .parts-wrap .rw .right {
    margin-left: unset;
  }
  .parts-wrap .rw ul {
    width: unset;
  }
}
