main .col2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
main .col2-reverse {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
main .mv {
  background: #0286DC;
}
main .mv .wrap {
  max-width: 1280px;
  padding: 111px 20px 210px;
  position: relative;
  z-index: 0;
}
main .mv .wrap::before {
  content: "";
  width: 1200px;
  height: 100%;
  background: url("../images/top/mv.png") center center/cover no-repeat;
  position: absolute;
  top: 50%;
  right: -152px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  z-index: -1;
  clip-path: polygon(35% 0%, 100% 0%, 65% 100%, 0% 100%);
}

main.en .mv .wrap::before {
  width: 970px;
  right: -330px;
}
main .mv h1 {
  font-family: "Noto Sans JP";
  font-weight: 900;
  font-size: 46px;
  line-height: 1.45;
  letter-spacing: 0.01em;
  color: #fff;
}
main .mv ul {
  display: -webkit-box;
  display: -ms-flexbox;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  display: flex;
  margin-top: 40px;
  gap: 15px;
  max-width: 50%;
}
main .mv li {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.1875;
  letter-spacing: 0.01em;
  color: #fff;
  /* margin-left: 15px; */
}
main .mv li:first-of-type {
  margin: 0;
}
main .mv p {
  margin-top: 24px;
  line-height: 3;
}
main .mv p span {
  font-weight: 700;
  font-size: 20px;
  letter-spacing: 0.01em;
  line-height: 1.2;
}
main .mv p .marker {
  display: inline-block;
  background: #fff;
  padding: 6px 14px;
}
main .mv p .italic {
  font-style: italic;
  padding-left: 4px;
}
main .mv .col2 {
  margin-top: 38px;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
main .mv .col2 .btn + .btn {
  margin-left: 24px;
}
main .about {
  padding: 95px 0 80px;
  position: relative;
  overflow: hidden;
}
main .about.about02{
  background: #506F8D;
}
main .about.about02::before{
  display: none;
}
main .about.about02 h2 .main{
  color: #fff;
}
main .about.about02 h2 .main::after{
  border-bottom: 12px solid #fff;
}
main .about.about02 h2 .main::before{
  border-bottom: 12px solid #fff;
}
main .about.about02 h2 .sub{
  color: #fff;
}
main .about.about02 .wrap .body p{
  color: #fff;
}
main .about02 .img_wrap .btn a{
  background: #fff;
  color: #000;
}
main .about02 .img_wrap .btn a::before{
  background: #506F8D;
}
main .about .wrap {
  position: relative;
}
main .about::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  transform: translateX(-50%);
  width: 100%;
  height: 230%;
  background-color: #E0EDFF;
  transform: skewY(-50deg);
  z-index: -1;
}
main .about .wrap::before {
  content: "";
  position: absolute;
  top: -90px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 100%;
  height: 694px;
  /* background: url("../images/top/about_bg.png") top center/contain no-repeat; */
  /* background-color: #E0EDFF; */
  transform: skewY(-7deg);
  z-index: -1;
}
main .about .col2 {
  margin-top: 75px;
}
main .about .img_wrap {
  width: 46.776084408%;
}
main .about .img_wrap .btn {
  margin-top: 47px;
}
main .about .img_wrap .btn a {
  width: 100%;
}
main .about .body {
  width: 46.5416178195%;
}
main .about .body p + p {
  margin-top: 15px;
}
main .service {
  background: #0286DC;
  padding: 88px 0 80px;
}
main .service .col2 {
  margin-top: 80px;
}
main .service .img_wrap {
  width: 43.7280187573%;
}
main .service .body {
  width: 49.7069167644%;
}
main .service .body p {
  color: #fff;
}
main .service .btn {
  text-align: center;
  margin-top: 48px;
}
main .service .btn a {
  min-width: 384px;
}
main .news {
  background: #2D3B52;
  padding: 90px 0 80px;
}
main .news .news_list {
  background: #fff;
  margin-top: 75px;
  padding: 35px 43px 48px;
}
main .news dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 16px 0;
  border-bottom: solid 1px #000;
}
main .news dt, main .news a {
  font-weight: 500;
  font-size: 16px;
  line-height: 2;
  letter-spacing: 0.06em;
}
main .news dt {
  margin-right: 13.037809648%;
}
main .news a:hover {
  text-decoration: underline;
}
main .access {
  padding: 90px 0 78px;
}
main .access .col2 {
  margin-top: 80px;
}
main .access .access_img {
  width: 46.4243845252%;
}
main .access .access_info {
  width: 48.0656506448%;
}
main .access .access_info .map {
  width: 100%;
  min-height: 264px;
  position: relative;
  padding-top: 51.2195121951%;
  margin-top: 28px;
}
main .access .access_info iframe {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  right: 0;
}
@media screen and (max-width: 767px) {
  main .col2 {
    display: block;
  }
  main .mv {
    background: url("../images/top/mv_bg.png") center center/cover no-repeat;
  }
  main .mv .wrap {
    padding: 51.4666666667vw 0 21.3333333333vw 2.1333333333vw;
    position: relative;
    z-index: 0;
  }
  main .mv .wrap::before {
    content: none;
  }
  main .mv h1 {
    font-size: 9.0666666667vw;
    letter-spacing: 0;
  }
  main .mv ul {
    margin-top: 3.2vw;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    width: 56vw;
    padding: 0 1.3333333333vw;
    gap: 0.8vw 4vw;
    max-width: unset;
  }
  main .mv li {
    font-size: 4vw;
    letter-spacing: 0;
    /* margin: 0 0 0.8vw 4vw; */
  }
  main .mv li:nth-of-type(4) {
    margin-left: 0;
  }
  main .mv p {
    margin: 5.3333333333vw 0 0 1.3333333333vw;
    line-height: 2;
  }
  main .mv p span {
    font-size: 4vw;
    letter-spacing: 0em;
  }
  main .mv p .marker {
    padding: 1.0666666667vw 2.9333333333vw;
  }
  main .mv p .italic {
    padding-left: 1.0666666667vw;
  }
  main .mv .col2 {
    display: none;
  }
  main .about {
    padding: 14.6666666667vw 0 16.5333333333vw;
  }
  main .about .wrap::before {
    content: none;
  }
  main .about .col2 {
    margin-top: 8.5333333333vw;
    padding-bottom: 26.6666666667vw;
    position: relative;
  }
  main .about .img_wrap {
    width: 100vw;
    margin: 0 calc(50% - 50vw);
  }
  main .about .img_wrap .btn {
    margin-top: 0;
    position: absolute;
    bottom: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  main .about .img_wrap .btn a {
    width: 76.8vw;
  }
  main .about .body {
    width: 100%;
    margin-top: 11.2vw;
  }
  main .about .body p + p {
    margin-top: 4.5333333333vw;
  }
  main .service {
    padding: 16.5333333333vw 0 14.9333333333vw;
  }
  main .service .col2 {
    margin-top: 10.1333333333vw;
  }
  main .service .img_wrap {
    width: 100vw;
    margin: 0 calc(50% - 50vw);
  }
  main .service .body {
    width: 100%;
    margin-top: 9.8666666667vw;
  }
  main .service .body p {
    font-size: 4vw;
  }
  main .service .btn {
    margin-top: 12vw;
  }
  main .service .btn a {
    min-width: auto;
    width: 76.8vw;
  }
  main .news {
    padding: 13.8666666667vw 0 16vw;
  }
  main .news .wrap {
    max-width: 100%;
  }
  main .news .news_list {
    margin-top: 10.1333333333vw;
    padding: 5.3333333333vw 3.4666666667vw 10.6666666667vw;
  }
  main .news dl {
    display: block;
    padding: 3.2vw 2.4vw;
  }
  main .news dt, main .news a {
    font-size: 4vw;
    line-height: 1.666;
  }
  main .news dt {
    margin-right: 13.037809648%;
  }
  main .news a {
    text-align: right;
    margin-top: 1.0666666667vw;
  }
  main .news a:hover {
    text-decoration: none;
  }
  main .access {
    padding: 12.5333333333vw 0 0;
  }
  main .access .col2 {
    margin-top: 10.6666666667vw;
  }
  main .access .access_img {
    width: 100vw;
    margin: 0 calc(50% - 50vw);
  }
  main .access .access_info {
    width: 100%;
    margin-top: 10.9333333333vw;
  }
  main .access .access_info .map {
    width: 100vw;
    margin: 0 calc(50% - 50vw);
    padding-top: 50.6666666667%;
    margin-top: 10.6666666667vw;
  }
}