#sec1 {
  background: url("../img/menu/sec1_deco.png") no-repeat top 20vw right/40%;
  padding: 16vw 0px;
}
#sec1 h2 {
  font-size: 6.5vw;
  line-height: 1.8;
  margin: 0px 0px 10vw;
  position: relative;
  z-index: 1;
}
#sec1 .sec1-img1 {
  margin: 0px -7% 8vw;
}
#sec1 .sec1-img2 {
  margin: 8vw auto 0px;
}
@media only screen and (min-width: 768px) {
  #sec1 {
    background-position: top 393px right;
    background-size: auto;
    padding: 120px 0px 132px;
  }
  #sec1 .sec1-row1 {
    flex-direction: row-reverse;
    margin: 0px 0px 80px;
  }
  #sec1 h2 {
    width: 460px;
    font-size: 40px;
    line-height: 70px;
    margin: 248px -131px 0px -187px;
  }
  #sec1 h2 span {
    color: #fff;
  }
  #sec1 .sec1-img1 {
    width: 1087px;
    margin: 0px 0px 0px -250px;
  }
  #sec1 .sec1-img2 {
    width: 600px;
    margin: 0px -100px 0px 0px;
  }
  #sec1 .sec1-txt {
    width: 430px;
    line-height: 35px;
    margin: 59px 0px 0px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1240px) {
  #sec1 .sec1-img1 {
    margin-left: -320px;
  }
  #sec1 h2 {
    margin-right: -60px;
  }
}

#sec2 {
  position: relative;
  background: rgba(0, 0, 0, 0.05);
  padding: 16vw 0px 20vw;
}
#sec2 h2 {
  text-align: center;
  position: relative;
  margin: 0px auto 6vw;
  width: -moz-fit-content;
  width: fit-content;
  font-size: 6.5vw;
  line-height: 1.6;
}
#sec2 h2::before {
  content: "";
  position: absolute;
  top: -10vw;
  right: -6vw;
  width: 28vw;
  height: 30vw;
  background: url("../img/menu/sec2_deco1.png") center/cover;
}
#sec2 .sec2-txt {
  margin-bottom: 8vw;
}
#sec2 .sec2-img {
  position: relative;
}
#sec2 .sec2-img span {
  display: block;
  position: absolute;
  z-index: 1;
  top: 3vw;
  left: 4vw;
  text-align: center;
  height: 30vw;
  background: #fff;
  line-height: 2.5;
  font-size: 5vw;
}
#sec2::before {
  content: "";
  position: absolute;
  bottom: -16vw;
  left: 0px;
  width: 45vw;
  height: 32vw;
  background: url("../img/menu/sec2_deco2.png") center/cover;
}
@media only screen and (min-width: 768px) {
  #sec2 {
    padding: 98px 0px 129px;
  }
  #sec2::before {
    width: 416px;
    height: 272px;
    bottom: -127px;
  }
  #sec2 h2 {
    font-size: 40px;
    line-height: 70px;
    margin-bottom: 30px;
  }
  #sec2 h2::before {
    width: 262px;
    height: 298px;
    top: -62px;
    right: -195px;
  }
  #sec2 .sec2-txt {
    text-align: center;
    margin-bottom: 50px;
    line-height: 35px;
  }
  #sec2 .sec2-row1 {
    width: 100%;
    max-width: 1300px;
    margin: 0px auto;
  }
  #sec2 .sec2-img {
    width: 50%;
    height: 420px;
  }
  #sec2 .sec2-img img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  #sec2 .sec2-img span {
    font-size: 30px;
    height: 190px;
    line-height: 60px;
    top: 18px;
    left: 26px;
  }
}

#sec3 {
  padding: 24vw 0px 0px;
}
#sec3 .wrap {
  z-index: 1;
}
#sec3 h2 {
  position: relative;
  z-index: 1;
  margin: 0px 20vw 8vw auto;
  height: 55vw;
  font-size: 7.5vw;
  line-height: 1.7;
}
#sec3 h2 span {
  font-size: 5.5vw;
}
#sec3 h2::before, #sec3 h2::after {
  content: "";
  position: absolute;
  top: -10vw;
  right: -17vw;
  width: 100vw;
  height: 100%;
  border-top: 1px solid #000;
  border-right: 1px solid #000;
}
#sec3 h2::after {
  top: calc(-10vw + 8px);
  right: calc(-17vw - 8px);
  width: 60vw;
  height: 70%;
}
#sec3 .sec3-img1 {
  position: relative;
}
#sec3 .sec3-img1::before {
  content: "";
  position: absolute;
  top: -32vw;
  left: 4vw;
  width: 30vw;
  height: 34vw;
  background: url("../img/menu/sec3_deco.png") center/cover;
}
#sec3 .sec3-txt1 {
  margin: 8vw 0px;
}
#sec3 .sec3-btn a {
  margin: 10vw auto 0px;
}
@media only screen and (min-width: 768px) {
  #sec3 {
    padding: 142px 0px 0px;
  }
  #sec3 .sec3-row1 {
    flex-direction: row-reverse;
    margin-bottom: 60px;
  }
  #sec3 h2 {
    line-height: 65px;
    height: 290px;
    font-size: 48px;
    margin: 121px -50px 0px 0px;
  }
  #sec3 h2 span {
    font-size: 30px;
  }
  #sec3 h2::before {
    width: 910px;
    height: 610px;
    top: -82px;
    right: -123px;
  }
  #sec3 h2::after {
    width: 401px;
    height: 440px;
    top: -70px;
    right: -133px;
  }
  #sec3 .sec3-img1 {
    width: 950px;
    margin: 0px 0px 0px -190px;
  }
  #sec3 .sec3-img1::before {
    top: auto;
    left: auto;
    bottom: 66px;
    right: -300px;
    width: 249px;
    height: 264px;
  }
  #sec3 .sec3-row2 {
    flex-direction: row-reverse;
  }
  #sec3 .sec3-txt1 {
    width: 460px;
    margin: 67px 40px 0px 0px;
    line-height: 35px;
  }
  #sec3 .sec3-img2 {
    width: 500px;
    margin: 0px 0px 0px -84px;
  }
  #sec3 .sec3-btn a {
    margin: 80px auto 0px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1200px) {
  #sec3 h2 {
    margin-right: -10px;
  }
}

#sec4 {
  position: relative;
  padding: 16vw 0px;
}
#sec4::before {
  content: "";
  position: absolute;
  bottom: 0px;
  left: 0px;
  width: 100%;
  height: calc(100% + 50vw);
  background: url("../img/menu/sec4_bg_sp.png") no-repeat top center/100% 100%;
}
#sec4 h2 {
  text-align: center;
  font-size: 6.5vw;
  line-height: 1.6;
}
#sec4 .sec4-img {
  margin: 8vw -6%;
}
#sec4 .sec4-btn a {
  margin: 8vw auto 0px;
}
@media only screen and (min-width: 768px) {
  #sec4 {
    padding: 115px 0px 115px;
  }
  #sec4::before {
    height: calc(100% + 292px);
    background-image: url("../img/menu/sec4_bg.png");
  }
  #sec4 h2 {
    font-size: 40px;
  }
  #sec4 .sec4-img {
    width: 1200px;
    margin: 30px -100px 42px;
  }
  #sec4 .sec4-txt {
    text-align: center;
    line-height: 35px;
  }
  #sec4 .sec4-btn a {
    margin-top: 55px;
  }
}

#sec5 {
  padding: 16vw 0px;
  background: url("../img/menu/sec5_deco1.png") no-repeat top 65vw left 4vw/35%, url("../img/menu/sec5_deco2.png") no-repeat bottom 55vw right/30%, url("../img/menu/sec5_line.png") no-repeat bottom left/80%;
}
#sec5 h2 {
  position: relative;
  height: 80vw;
  margin: 0px auto 6vw;
  padding: 0px 5vw;
  font-size: 7vw;
  line-height: 1.6;
}
#sec5 h2::before {
  content: "";
  position: absolute;
  top: -3vw;
  right: 0px;
  width: 2px;
  border-left: 1px solid #000;
  height: 50vw;
}
#sec5 h2::after {
  content: "";
  position: absolute;
  bottom: 0px;
  left: 0px;
  width: 4px;
  height: 55vw;
  background: url("../img/menu/sec5_line1.png") no-repeat top center/100% 100%;
}
#sec5 .sec5-txt {
  margin: 8vw 0px;
}
#sec5 .sec5-btn a {
  margin: 0px auto;
}
#sec5 .sec5-img2 {
  margin: 8vw auto 10vw;
}
#sec5 .sec5-img3 {
  width: 80%;
  margin: 0px auto;
}
@media only screen and (min-width: 768px) {
  #sec5 {
    padding: 133px 0px 120px;
    background-size: auto, auto, auto;
    background-position: top 470px left 12%, bottom 289px right, bottom left;
  }
  #sec5 h2 {
    font-size: 40px;
    line-height: 70px;
    margin: 68px 0px 0px 26px;
    height: 472px;
    padding: 0px 28px;
  }
  #sec5 h2::before {
    height: 370px;
    top: -16px;
  }
  #sec5 h2::after {
    width: 8px;
    height: 387px;
  }
  #sec5 .sec5-img1 {
    width: 800px;
    margin: 0px -176px 0px 0px;
  }
  #sec5 .sec5-row2 {
    flex-direction: row-reverse;
    margin: 80px 0px 0px;
  }
  #sec5 .sec5-img2 {
    width: 600px;
    margin: 0px 0px 0px -170px;
  }
  #sec5 .sec5-txt {
    line-height: 35px;
    margin: 0px 0px 42px;
  }
  #sec5 .sec5-box1 {
    width: 482px;
    margin: -9px 0px 0px;
  }
  #sec5 .sec5-btn a {
    margin: 0px;
  }
  #sec5 .sec5-img3 {
    width: 450px;
    margin: -20px -100px 0px auto;
  }
}
@media screen and (min-width: 768px) and (max-width: 1500px) {
  #sec5 {
    background-position: top 470px left 4%, bottom 289px right, bottom left;
  }
}

#bnr {
  background: url("../img/menu/bnr_bg.jpg") center/cover;
  padding: 32vw 0px;
  color: #fff;
  text-align: center;
}
#bnr h2 {
  font-size: 7vw;
  margin-bottom: 4vw;
  letter-spacing: 0.1em;
}
#bnr .bnr-btn a {
  width: 36%;
  margin: 0px auto;
  line-height: 2.5;
  border-radius: 30px;
  background: rgba(0, 0, 0, 0.6);
  letter-spacing: 0.1em;
}
#bnr .bnr-btn a span {
  font-size: 12px;
}
@media only screen and (min-width: 768px) {
  #bnr {
    padding: 192px 0px 197px;
  }
  #bnr h2 {
    font-size: 36px;
    margin-bottom: 42px;
  }
  #bnr .bnr-btn a {
    width: 150px;
    line-height: 40px;
  }
  #bnr .bnr-btn a:hover {
    opacity: 0.8;
  }
}

.remodal-res .remodal-close {
  width: 50px;
  height: auto;
}
.remodal-res .btn-popupfix {
  width: 50px;
}
@media only screen and (min-width: 768px) {
  .remodal-res .remodal-close, .remodal-res .btn-popupfix {
    width: 70px;
  }
}/*# sourceMappingURL=menu.css.map */