main h3 {
  font-weight: 700;
  font-size: 20px;
  line-height: 1.65;
  letter-spacing: 0.21em;
}
main .business {
  padding: 80px 0;
}
main .business .strong {
  text-align: center;
  font-weight: 700;
  font-size: 24px;
  line-height: 1.875;
  letter-spacing: 0;
}
main .business p {
  margin-top: 78px;
}
main .business figure {
  width: 576px;
  margin: 55px auto 0;
}
main .business dl {
  margin-top: 120px;
}
main .business dl + dl {
  margin-top: 90px;
}
main .business dt {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0.08em;
  padding-left: 20px;
  border-left: solid 4px #0057FF;
}
main .business dd {
  margin-top: 30px;
  padding-left: 24px;
}
main .business li {
  letter-spacing: 0.06em;
}
main .business li + li {
  margin-top: 9px;
}
main .power {
  background: #0057FF;
  padding: 90px 0;
}
main .power .media {
  background: #fff;
  padding: 63px 50px 54px;
  margin-top: 75px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
main .power .media-reverse {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
main .power .media .body {
  width: 52.1681997372%;
}
main .power .media .body p {
  margin-top: 20px;
}
main .power .media .img_wrap {
  width: 40.2102496715%;
}
main .power .media + .media {
  margin-top: 76px;
}
main .service {
  background: #FFEFEF;
  padding: 90px 0;
}
main .service .service_item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  margin-top: 72px;
}
main .service .service_item .heading {
  width: 374px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
main .service .service_item .heading h3 {
  margin-left: 40px;
}
main .service .service_item .heading figure {
  width: 92px;
}
main .service .service_item .detail {
  width: 397px;
}
main .service .service_item .detail .price {
  text-align: center;
  color: #fff;
  background: #2D3B52;
  padding: 15px 0;
  margin-top: 25px;
}
main .service .service_item + .service_item {
  margin-top: 92px;
}
main .tips {
  background: #2D3B52;
  padding: 90px 0 128px;
}
main#single .tips {
  background: #fff;
  padding: 0;

}
main .tips .more {
  text-align: center;
  margin-top: 64px;
}
main .tips .media {
  background: #fff;
  padding: 68px 40px 65px;
  margin-top: 80px;
}
main#single .tips .media {
  margin-top: 0;
}
main .tips .media h3 {
  padding: 0 26px 15px;
  border-bottom: solid 1px #000;
}
main .tips .media figure {
  width: 400px;
  margin: 56px auto 0;
}
main .tips .media p {
  margin-top: 57px;
}
main .tips .media + .media {
  margin-top: 34px;
}
main .flow {
  background: #FFEFEF;
  padding: 90px 0;
}
main .flow-item {
  margin-top: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
}
main .flow-item:after {
  content: '';
  width: 1.6em;
  aspect-ratio: 1 / cos(55deg);
  -webkit-clip-path: polygon(50% 100%, 100% 0, 0 0);
          clip-path: polygon(50% 100%, 100% 0, 0 0);
  position: absolute;
  left: 50%;
  bottom: -37px;
  background: #0057FF;
  margin-left: -0.8em;
}
main .flow-item:last-child:after {
  content: none;
}
main .flow-title {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 14em;
          flex: 0 0 14em;
  padding: 1em;
  background: #0057FF;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
main .flow-title h3 {
  color: #fff;
}
main .flow-detail {
  padding: 1em;
  -ms-flex-item-align: center;
      -ms-grid-row-align: center;
      align-self: center;
  background: #fff;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
main .flow a {
  color: #0057FF;
  display: inline;
}
span.bogo-language-name {
  color: rgba(255, 255, 255, 0.5);
}

@media screen and (max-width: 767px) {
  main h3 {
    font-size: 4.8vw;
    letter-spacing: 0.08em;
  }
  main .business {
    padding: 13.8666666667vw 0 24.8vw;
  }
  main .business .strong {
    font-size: 4.8vw;
    line-height: 1.722;
  }
  main .business p {
    margin-top: 13.3333333333vw;
  }
  main .business figure {
    width: 100vw;
    margin: 10.6666666667vw calc(50% - 50vw) 0;
  }
  main .business dl {
    margin-top: 10.6666666667vw;
  }
  main .business dl + dl {
    margin-top: 5.3333333333vw;
  }
  main .business dt {
    font-size: 4.8vw;
    padding: 4.5333333333vw 0 4.5333333333vw 4vw;
    border-left: solid 1.0666666667vw #0057FF;
  }
  main .business dd {
    margin-top: 2.6666666667vw;
    padding-left: 4vw;
  }
  main .business li + li {
    margin-top: 2.4vw;
  }
  main .power {
    padding: 16.5333333333vw 0 24vw;
  }
  main .power .media {
    padding: 20.8vw 3.2vw 19.2vw;
    display: block;
    width: 100vw;
    margin: 9.0666666667vw calc(50% - 50vw) 0;
  }
  main .power .media .body {
    width: 100%;
  }
  main .power .media .body h3 {
    font-size: 5.3333333333vw;
    letter-spacing: 0.21em;
    padding: 0 4.8vw;
    text-align: center;
  }
  main .power .media .body p {
    margin-top: 12vw;
  }
  main .power .media .body figure {
    width: 100vw;
    margin: 5.8666666667vw calc(50% - 50vw) 0;
  }
  main .power .media .img_wrap {
    width: 100%;
  }
  main .power .media + .media {
    margin-top: 14.9333333333vw;
  }
  main .service {
    padding: 13.8666666667vw 0 19.7333333333vw;
  }
  main .service .service_item {
    display: block;
    margin-top: 13.8666666667vw;
  }
  main .service .service_item .heading {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
  main .service .service_item .heading h3 {
    margin-left: 0;
  }
  main .service .service_item .heading figure {
    margin-top: 3.2vw;
    width: 24.5333333333vw;
  }
  main .service .service_item .detail {
    margin-top: 5.8666666667vw;
    width: 100%;
  }
  main .service .service_item .detail .price {
    padding: 4.2666666667vw 0;
    margin-top: 15.4666666667vw;
  }
  main .service .service_item + .service_item {
    margin-top: 13.8666666667vw;
  }
  main .tips {
    padding: 16.5333333333vw 0 26.6666666667vw;
  }
  main .tips h2 .main::before {
    left: -14.866667vw;
  }
  main .tips h2 .main::after {
    right: -15vw;
  }
  main .tips .more {
    margin-top: 13.3333333333vw;
  }
  main .tips .media {
    padding: 14.1333333333vw 4vw 17.3333333333vw;
    width: 100vw;
    margin: 9.0666666667vw calc(50% - 50vw) 0;
  }
  main .tips .media h3 {
    font-size: 5.3333333333vw;
    letter-spacing: 0.21em;
    padding: 0 0 2.1333333333vw;
  }
  main .tips .media figure {
    width: 100vw;
    margin: 8.5333333333vw calc(50% - 50vw) 0;
  }
  main .tips .media p {
    margin-top: 13.3333333333vw;
  }
  main .tips .media + .media {
    margin-top: 14.9333333333vw;
  }
  main .flow-item {
    flex-direction: column;
  }
  main .flow-title {
    flex-basis: 100%;
  }
}