@media only screen and (min-width: 768px) {
  #key .kv li {
    background: url("../img/english/kv.jpg") no-repeat center/cover;
    height: 950px;
  }
}

header .nav-english {
  position: relative;
}

header .nav-english::before {
  content: "/";
  position: absolute;
  top: 50%;
  left: 42%;
  transform: translate(-50%, -50%);
  font-size: 18px;
}

#sec1 {
  background: url("../img/english/sec1_bg.jpg") no-repeat center top/190%;
  padding: 20vw 0;
}

#sec1 .wrap h2 {
  background: url("../img/english/sec1_deco_h2.png") no-repeat center top/12vw auto;
  text-align: center;
  padding-top: 7vw;
  font-size: 7vw;
  line-height: 1.5;
}

#sec1 .wrap .txt {
  padding: 8vw 0 15vw;
}

#sec1 .wrap .video {
  width: 100%;
  height: 60vw;
  display: block;
}

@media screen and (min-width: 999px) {
  #sec1 {
    background-size: 100%;
    padding: 193px 0 137px;
  }

  #sec1 .wrap h2 {
    background-size: 91px auto;
    padding-top: 61px;
    font-size: 40px;
    line-height: 66px;
  }

  #sec1 .wrap .txt {
    padding: 46px 0 128px;
    text-align: center;
    letter-spacing: 0.07em;
  }

  #sec1 .wrap .video {
    width: 800px;
    height: 446px;
    margin: 0px auto;
  }
}

#sec2 {
  background: url("../img/english/sec2_deco_1.png") no-repeat left top/40%, url("../img/english/sec2_deco_2.png") no-repeat right bottom/75%, url("../img/english/bg02.jpg") repeat center;
  color: #000;
  padding: 20vw 0 30vw;
}

#sec2 .wrap h2 {
  font-size: 8vw;
  text-align: center;
  line-height: 1.5;
}

#sec2 .gr1 {
  padding-bottom: 15vw;
}

#sec2 .gr1 h2 {
  padding: 7vw 0 5vw;
  letter-spacing: 0.04em;
}

#sec2 .gr1 h2 img {
  display: block;
  padding-bottom: 2vw;
}

#sec2 .gr2 h2 {
  padding: 13vw 0 5vw;
}

#sec2 .gr2 .photo {
  padding-left: 8%;
  position: relative;
  z-index: 1;
}

#sec2 .gr2 .photo::after {
  position: absolute;
  content: "";
  background: url("../img/english/deco_img.jpg") no-repeat center/100%;
  width: 50vw;
  height: 25vw;
  bottom: -6vw;
  left: 0;
  z-index: -1;
}

@media screen and (min-width: 999px) {
  #sec2 {
    background-size: 347px auto, 795px auto, auto;
    background-position: left top, right bottom 82px;
    padding: 0;
  }

  #sec2 .wrap {
    max-width: 1500px;
  }

  #sec2 .wrap h2 {
    font-size: 40px;
    text-align: left;
    line-height: 64px;
  }

  #sec2 .gr1 {
    padding-bottom: 197px;
  }

  #sec2 .gr1 h2 {
    padding: 269px 0 0;
  }

  #sec2 .gr1 h2 img {
    padding: 0 0 75px 36px;
  }

  #sec2 .gr1 h2 span {
    padding-left: 79px;
  }

  #sec2 .gr1 .photo {
    position: absolute;
    top: 138px;
    height: 610px;
    right: 0;
    left: 576px;
  }

  #sec2 .gr1 .txt {
    width: 370px;
    padding: 44px 0 0 80px;
  }

  #sec2 .gr2 {
    position: relative;
    padding-bottom: 82px;
    max-width: 1420px;
    margin: 0 auto;
  }

  #sec2 .gr2 .photo {
    padding: 0 0 61px 63px;
    text-align: right;
    margin: 0 calc(50% - 92px) 0 0;
    height: 494px;
  }

  #sec2 .gr2 .photo::after {
    bottom: 0px;
    left: 0px;
    width: 535px;
    height: 260px;
  }

  #sec2 .gr2 .photo img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
  }

  #sec2 .gr2 .inner {
    position: absolute;
    top: 83px;
    left: calc(50% + 162px);
  }

  #sec2 .gr2 h2 {
    padding: 0 0 37px;
  }

  #sec2 .gr2 .txt {
    width: 338px;
  }
}

#sec3 {
  background: #000;
  padding: 20vw 4%;
  color: #fff;
}

#sec3 .wrap {
  background-color: #1a1a1a;
  padding: 17vw 4%;
}

#sec3 .wrap h2 {
  font-size: 8vw;
  text-align: center;
  line-height: 1.5;
}

#sec3 .wrap .txt {
  padding: 7vw 0 9vw;
  text-align: center;
}

#sec3 .wrap .btn-sec {
  margin: 0 auto 10vw;
}

#sec3 .wrap .btn-sec::after {
  content: "";
  position: absolute;
  background: url("../img/english/icon_web.png") no-repeat center/100%;
  width: 6vw;
  height: 7vw;
  top: 50%;
  transform: translateY(-50%);
  left: 5%;
}

#sec3 .wrap .info {
  border: 1px solid #fff;
  text-align: center;
  padding: 10vw 4%;
}

#sec3 .wrap .info h4 {
  font-size: 5.5vw;
  line-height: 1.5;
  margin-bottom: 5vw;
}

@media screen and (min-width: 999px) {
  #sec3 {
    padding: 131px 0 102px;
  }

  #sec3 .wrap {
    padding: 78px 0 99px;
    max-width: 800px;
  }

  #sec3 .wrap h2 {
    font-size: 40px;
    line-height: 64px;
  }

  #sec3 .wrap .txt {
    padding: 27px 0 43px;
  }

  #sec3 .wrap .btn-sec {
    width: 330px;
    margin: 0 auto 60px;
    line-height: 60px;
    letter-spacing: 0.06em;
    padding-left: 4px;
  }

  #sec3 .wrap .btn-sec::after {
    width: 28px;
    height: 31px;
    left: 23px;
    top: 47%;
  }

  #sec3 .wrap .btn-sec::before {
    right: 17px;
  }

  #sec3 .wrap .info {
    padding: 27px 0 37px;
    max-width: 639px;
    box-sizing: border-box;
    margin: 0 auto;
  }

  #sec3 .wrap .info h4 {
    font-size: 25px;
    line-height: 64px;
    margin-bottom: 2px;
  }
}

#sec4 {
  padding-bottom: 30vw;
}

#sec4 .wrap .photo {
  padding-left: 7%;
  position: relative;
  z-index: 1;
}

#sec4 .wrap .photo::after {
  background: url("../img/english/deco_img.jpg") no-repeat center/100%;
  position: absolute;
  content: "";
  width: 50vw;
  height: 25vw;
  top: -6vw;
  left: 0;
  z-index: -1;
}

#sec4 .wrap h2 {
  text-align: center;
  font-size: 8vw;
  line-height: 1.5;
  margin: 7vw 0;
  letter-spacing: 0.04em;
}

#sec4 .wrap .sec4-js {
  margin: 10vw 0;
}

#sec4 .wrap .sec4-js .slick-dots {
  padding-top: 3vw;
  align-items: flex-end;
}

#sec4 .wrap .sec4-js .slick-dots li {
  height: 100%;
  width: 35px;
  margin-right: 7px;
}

#sec4 .wrap .sec4-js .slick-dots li button {
  width: 100%;
  height: 2px;
  background: url("../img/english/bg02.jpg") no-repeat center;
}

#sec4 .wrap .sec4-js .slick-dots li button:hover {
  height: 6px;
}

#sec4 .wrap .sec4-js .slick-dots .slick-active button {
  height: 6px !important;
}

#sec4 .wrap .info {
  background: url("../img/english/bg02.jpg") repeat center;
  color: #000;
  padding: 15vw 4%;
}

#sec4 .wrap .info .lead dl {
  border-bottom: 1px solid #000;
  text-align: center;
  font-size: 6.5vw;
  padding-bottom: 5vw;
  letter-spacing: 0.065em;
}

#sec4 .wrap .info .lead dl dt {
  line-height: 1.5;
}

#sec4 .wrap .info .lead dl dd {
  line-height: 1.5;
}

#sec4 .wrap .info .lead dl dd span {
  font-size: 4.5vw;
}

#sec4 .wrap .info .lead .list-menu {
  padding: 5vw 0;
}

#sec4 .wrap .info .lead .list-menu h4 {
  font-size: 4.2vw;
  text-align: center;
  margin-bottom: 3vw;
  letter-spacing: 0.07em;
}

#sec4 .wrap .info .note {
  border: 1px solid #000;
  text-align: center;
  padding: 10vw 0;
  letter-spacing: 0.07em;
}

@media screen and (min-width: 999px) {
  #sec4 {
    padding-bottom: 109px;
  }

  #sec4 .wrap {
    max-width: 1320px;
  }

  #sec4 .wrap .gr {
    position: relative;
    z-index: 1;
    padding-bottom: 215px;
  }

  #sec4 .wrap .gr::before {
    content: "";
    position: absolute;
    background: url("../img/english/sec4_deco_1.png") no-repeat left top/100%;
    width: 468px;
    height: 607px;
    top: -71px;
    left: -80px;
    z-index: -1;
  }

  #sec4 .wrap .photo {
    position: relative;
    z-index: 2;
    padding: 60px 20px 0 61px;
    max-width: 1200px;
    height: 710px;
  }

  #sec4 .wrap .photo img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
  }

  #sec4 .wrap .photo::after {
    width: 534px;
    height: 260px;
    top: 0;
    left: 0;
  }

  #sec4 .wrap h2 {
    margin: 0;
    font-size: 40px;
    line-height: 64px;
    text-align: left;
    padding: 156px 0 0 155px;
  }

  #sec4 .wrap .sec4-js {
    min-width: 640px;
    margin: 0;
    position: absolute;
    top: 45px;
    left: 658px;
    right: 20px;
  }

  #sec4 .wrap .sec4-js .slick-slide li {
    height: 440px !important;
  }

  #sec4 .wrap .sec4-js .slick-slide li img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
  }

  #sec4 .wrap .sec4-js .slick-dots {
    padding-top: 30px;
  }

  #sec4 .wrap .sec4-js .slick-dots li {
    margin-right: 6px;
  }

  #sec4 .wrap .txt {
    width: 383px;
    padding: 17px 0 0 163px;
  }

  #sec4 .wrap .info {
    padding: 69px 0;
    max-width: 1000px;
    margin: 0 auto;
  }

  #sec4 .wrap .info .lead {
    display: flex;
    padding: 0 58px 51px;
  }

  #sec4 .wrap .info .lead dl {
    text-align: left;
    border-bottom: unset;
    border-right: 1px solid #000;
    padding: 42px 0 33px;
    width: 334px;
    font-size: 35px;
  }

  #sec4 .wrap .info .lead dl dt {
    line-height: 54px;
  }

  #sec4 .wrap .info .lead dl dd {
    line-height: 79px;
  }

  #sec4 .wrap .info .lead dl dd span {
    font-size: 25px;
  }

  #sec4 .wrap .info .lead .list-menu {
    width: calc(100% - 334px);
    padding: 0;
  }

  #sec4 .wrap .info .lead .list-menu h4 {
    font-size: 20px;
    text-align: center;
    margin: -2px 0 0 11px;
  }

  #sec4 .wrap .info .lead .list-menu ul {
    display: flex;
    padding: 32px 0 0 73px;
  }

  #sec4 .wrap .info .lead .list-menu ul li {
    margin-right: 89px;
  }

  #sec4 .wrap .info .lead .list-menu ul li:nth-child(3) {
    margin-right: 0;
  }

  #sec4 .wrap .info .note {
    max-width: 840px;
    margin: 0 auto;
    box-sizing: border-box;
    padding: 40px 0 39px;
    font-size: 22px;
    line-height: 45px;
    padding-left: 15px;
  }
}

@media screen and (min-width: 1099px) and (max-width: 1300px) {
  #sec4 .wrap h2 {
    padding: 156px 0 0 80px;
  }

  #sec4 .wrap .txt {
    padding: 17px 0 0 80px;
  }

  #sec4 .wrap .sec4-js {
    left: 500px;
  }
}

#sec5 {
  padding-bottom: 20vw;
}

#sec5 .wrap h2 {
  position: relative;
  z-index: 1;
  color: #000;
  font-size: 8vw;
  line-height: 1.5;
  padding: 19vw 0 33vw 9%;
  margin: 0 51% 0 0%;
  letter-spacing: 0.04em;
}

#sec5 .wrap h2::before {
  content: "";
  position: absolute;
  background: url("../img/english/deco_img.jpg") no-repeat center;
  width: 26vw;
  height: 26vw;
  top: -5vw;
  left: -5vw;
  z-index: -2;
}

#sec5 .wrap h2::after {
  content: "";
  position: absolute;
  background: url("../img/english/bg02.jpg") repeat center;
  bottom: 0;
  top: 0;
  left: 0;
  right: 0;
  z-index: -1;
}

#sec5 .wrap .photo1 {
  position: absolute;
  top: -16vw;
  right: 0;
  left: 44vw;
  z-index: 1;
}

#sec5 .wrap .photo2 {
  margin: -31vw 39% 5vw 6%;
  position: relative;
  z-index: 1;
}

@media screen and (min-width: 999px) {
  #sec5 {
    padding-bottom: 0;
  }

  #sec5 .wrap {
    max-width: 1336px;
    padding: 250px 0 0 0;
  }

  #sec5 .wrap h2 {
    font-size: 70px;
    line-height: 64px;
    padding: 243px 0 479px 138px;
    margin: 0 0 0 69px;
  }

  #sec5 .wrap h2::before {
    width: 259px;
    height: 259px;
    top: -58px;
    left: -59px;
  }

  #sec5 .wrap h2::after {
    width: 524px;
  }

  #sec5 .wrap .photo1 {
    position: absolute;
    top: 0;
    right: 0;
    left: 537px;
    height: 718px;
  }

  #sec5 .wrap .photo2 {
    margin: -335px calc(50% - 59px) 0 150px;
    text-align: right;
    height: 473px;
  }

  #sec5 .wrap .photo2 img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
  }

  #sec5 .wrap .txt {
    width: 320px;
    position: absolute;
    bottom: 107px;
    left: calc(50% + 134px);
  }
}

@media screen and (min-width: 999px) and (max-width: 1355px) {
  #sec5 .wrap h2 {
    margin-left: 59px;
  }
}

#sec6 h2 {
  width: 60%;
}

@media only screen and (min-width: 768px) {
  #sec6 h2 {
    width: 282px;
  }
}

/*# sourceMappingURL=english.css.map */