.search__menu {
  margin: -80px 0 0;
  padding: 0 0 0 285px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 25px;
  position: relative;
  z-index: 10;
}
.search__menu li {
  width: 150px;
  text-align: center;
  font-size: 15px;
  position: relative;
}
.search__menu li a {
  text-decoration: none;
  color: #0F1726;
}
.search__menu li figure {
  width: 100%;
  height: 100px;
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
          box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
  margin-bottom: 10px;
  -o-object-fit: cover;
     object-fit: cover;
  overflow: hidden;
  margin-bottom: 8px;
}
.search__menu li figure img {
  width: 100%;
}
.search__menu li::after {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  border-width: 0 1px 1px 0;
  border-style: solid;
  border-color: #231815;
  position: absolute;
  bottom: -8px;
  left: 50%;
  -webkit-transform: translateX(-50%) rotate(45deg);
          transform: translateX(-50%) rotate(45deg);
}

@media all and (max-width: 767px) {
  .search__menu {
    margin-top: 0;
    padding: 0;
    gap: 6.6666666667vw;
  }
  .search__menu li {
    width: calc((100% - 6.6666666667vw) / 2);
    font-size: 4vw;
  }
  .search__menu li figure {
    height: 26.6666666667vw;
    margin-bottom: 2.6666666667vw;
    margin-bottom: 2.1333333333vw;
  }
  .search__menu li::after {
    width: 2.1333333333vw;
    height: 2.1333333333vw;
    bottom: -2.1333333333vw;
  }
}
.search__block {
  margin-top: 50px;
  padding-top: 20px;
}
.search__block h3 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 14px;
  font-size: 36px;
  font-weight: 400;
  color: #1D3A66;
  border: 0;
  margin-bottom: 20px;
}
.search__block h3::before {
  content: "";
  display: block;
  width: 70px;
  height: 70px;
  background-repeat: no-repeat;
  background-position: 0 0;
  background-size: contain;
}
.search__block#process h3::before {
  background-image: url(../../images/products/problems-needs1.png);
}
.search__block#cost-reduction h3::before {
  background-image: url(../../images/products/problems-needs2.png);
}
.search__block#performance h3::before {
  background-image: url(../../images/products/problems-needs3.png);
}
.search__block#eco h3::before {
  background-image: url(../../images/products/problems-needs4.png);
}

@media all and (max-width: 767px) {
  .search__block {
    margin-top: 13.3333333333vw;
    padding-top: 5.3333333333vw;
  }
  .search__block h3 {
    gap: 3.7333333333vw;
    font-size: 6.4vw;
    margin-bottom: 5.3333333333vw;
  }
  .search__block h3::before {
    width: 12vw;
    height: 12vw;
  }
}
.search__box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 30px 40px;
}
.search__box dl {
  max-width: 293px;
  width: calc((100% - 80px) / 3);
  min-height: 160px;
  padding: 16px 20px 16px 18px;
  background-color: #E8ECED;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.search__box dl dt {
  padding-left: 36px;
  font-size: 22px;
  font-weight: 700;
  color: #004EA2;
  margin-bottom: 9px;
  position: relative;
}
.search__box dl dt img {
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.search__box dl dd {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  font-size: 15px;
  color: #333;
  line-height: 1.6;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
.search__box dl dd a {
  color: #004EA2;
  margin-top: auto;
  margin-left: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.search__box dl dd a::before {
  content: "";
  display: block;
  width: 0;
  height: 0;
  margin-right: 6px;
  border-width: 4px 0 4px 6px;
  border-style: solid;
  border-color: transparent #004EA2;
}

@media all and (max-width: 767px) {
  .search__box {
    gap: 8vw;
  }
  .search__box dl {
    width: 100%;
    max-width: 100%;
    min-height: 42.6666666667vw;
    padding: 4.2666666667vw 5.3333333333vw 4.2666666667vw 4.8vw;
  }
  .search__box dl dt {
    padding-left: 9.6vw;
    font-size: 5.8666666667vw;
    margin-bottom: 2.4vw;
  }
  .search__box dl dt img {
    width: 9%;
    max-height: 100%;
  }
  .search__box dl dd {
    font-size: 4vw;
  }
  .search__box dl dd a::before {
    margin-right: 1.6vw;
    border-width: 1.0666666667vw 0 1.0666666667vw 1.6vw;
  }
}
#MainHead {
  height: 150px;
}
#MainHead h1 span {
  margin-bottom: 12px;
}
#MainHead h1 small {
  font-size: 22px;
  font-weight: 500;
  display: block;
  margin-bottom: 2px;
}

@media all and (max-width: 767px) {
  #MainHead {
    height: 32vw;
  }
  #MainHead h1 span {
    margin-bottom: 3.2vw;
  }
  #MainHead h1 small {
    font-size: 4.8vw;
    margin-bottom: 0.5333333333vw;
  }
}
.top__block {
  padding-bottom: 0;
  margin-bottom: 50px;
}

@media all and (max-width: 767px) {
  .top__block {
    margin-bottom: 13.3333333333vw;
  }
}
.top__box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 45px;
}
.top__box figure {
  width: 360px;
}
.top__box figure img {
  width: 100%;
}

@media all and (max-width: 767px) {
  .top__box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 4.2666666667vw;
  }
  .top__box figure {
    width: 100%;
  }
}
.top__box__text {
  width: 555px;
  font-size: 15px;
  color: #333;
  line-height: 1.6;
}
.top__box__text p {
  font-size: 16px;
  font-weight: 700;
}
.top__box__text ul.list--dotted li {
  color: #000;
  font-weight: normal;
}
.top__box__text ul.list--dotted li::before {
  background-color: #000;
}

@media all and (max-width: 767px) {
  .top__box__text {
    width: 100%;
    font-size: 4vw;
  }
  .top__box__text p {
    font-size: 4.2666666667vw;
  }
}
.table__block {
  padding-top: 0;
}