#all_wrap {
  width: 100%;
  background-image: url("../images/common/back01.png"), url("../images/common/back01.png"), url("../images/common/back01.png"), url("../images/common/back01.png"), url("../images/common/back01.png"), url("../images/common/back01.png");
  background-repeat: no-repeat;
  background-size: initial;
  background-position: top -54px left -410px, top 803px right -297px, top 1660px left -412px, top 2516px right -300px, top 3623px left -411px, bottom -320px right -300px;
}

#mv {
  padding: 50px 0 0 0;
}
#mv .mv_wrap {
  max-width: 1240px;
  width: 95%;
  margin: 0 auto;
}
#mv .mv_wrap .text_wrap h2 {
  margin: 0 0 33px 0;
}
#mv .mv_wrap .text_wrap h2 p:nth-of-type(1) {
  font-size: 30px;
  font-weight: 500;
  position: relative;
  padding: 0px 0 0 110px;
  margin: 0 0 6px 0;
}
#mv .mv_wrap .text_wrap h2 p:nth-of-type(1):before {
  content: "";
  display: block;
  width: 83px;
  height: 1px;
  position: absolute;
  top: 50%;
  transform: translateY(50%);
  background-color: #000;
  left: 0;
}
#mv .mv_wrap .text_wrap h2 p:nth-of-type(2) {
  font-size: 75px;
  font-weight: 500;
  line-height: 1.386;
  letter-spacing: 0;
}
#mv .mv_wrap .enjoy_wrap dl {
  margin: 1.5rem 0;
}
#mv .mv_wrap .enjoy_wrap dt {
  font-size: 24px;
}
#mv .mv_wrap .image_wrap {
  margin: 0 0 98px 0;
}
#mv .mv_wrap .reservation_link {
  position: relative;
  display: block;
  text-align: center;
  padding: 27px 0;
  margin: 50px auto 100px;
  max-width: 580px;
  width: 95%;
  color: #fff;
  background: #000;
}
#mv .mv_wrap .reservation_link:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  opacity: 0;
  transition: 0.5s;
  background: transparent;
}
#mv .mv_wrap .reservation_link span {
  position: relative;
}
#mv .mv_wrap .reservation_link:hover {
  opacity: 1;
}
#mv .mv_wrap .reservation_link:hover:before {
  background: linear-gradient(-8deg, #006fff -50%, #acb131 47.53%, #f00 150%);
  transition: 0.5s;
  opacity: 1;
}
#mv .mv_wrap h3 {
  font-size: 40px;
  font-weight: 500;
  line-height: 1.35;
  margin: 0 0 38px 0;
}
#mv .mv_wrap h4 {
  position: relative;
  padding: 0 0 0 84px;
  font-size: 24px;
  font-weight: 500;
  margin: 0 0 49px 0;
}
#mv .mv_wrap h4:before {
  content: "";
  display: block;
  width: 64px;
  height: 1px;
  position: absolute;
  top: 50%;
  transform: translateY(50%);
  background-color: #000;
  left: 0;
}
#mv .mv_wrap .mv_content_wrap {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 15px;
}
#mv .mv_wrap .mv_content_wrap .left_box {
  width: 47%;
}
#mv .mv_wrap .mv_content_wrap .left_box .ja {
  margin: 0 0 26px 0;
}
#mv .mv_wrap .mv_content_wrap .right_box {
  width: 49%;
}
#mv .mv_wrap .mv_content_wrap .right_box img {
  width: 100%;
}

.about {
  padding: 156px 0 0 0;
}
.about h2 {
  position: relative;
  padding: 0 0 0 340px;
  margin: 0 0 53px 0;
}
.about h2:before {
  content: "";
  display: block;
  width: 303px;
  height: 1px;
  position: absolute;
  top: 50%;
  transform: translateY(50%);
  background-color: #000;
  left: 0;
}
.about p {
  max-width: 1240px;
  width: 95%;
  margin: 0 auto 23px;
}
.about table {
  max-width: 1240px;
  width: 95%;
  margin: 0 auto 67px;
}
.about table tr {
  border-bottom: 1px dashed #707070;
}
.about table tr th, .about table tr td {
  line-height: 1.818;
  padding: 1em;
}
.about table tr th {
  font-weight: 500;
  text-align: center;
}
.about table tr td {
  text-align: left;
}
.about .btn_wrap {
  display: flex;
  flex-direction: row;
  max-width: 1080px;
  margin: 0 auto;
}
.about .btn_wrap .steps_to_link, .about .btn_wrap .reservation_link {
  position: relative;
  display: block;
  text-align: center;
  padding: 14px 0;
  margin: 0 auto;
  max-width: 380px;
  width: 95%;
  color: #fff;
  background: #000;
}
.about .btn_wrap .steps_to_link:before, .about .btn_wrap .reservation_link:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  opacity: 0;
  transition: 0.5s;
  background: transparent;
}
.about .btn_wrap .steps_to_link span, .about .btn_wrap .reservation_link span {
  position: relative;
}
.about .btn_wrap .steps_to_link:hover, .about .btn_wrap .reservation_link:hover {
  opacity: 1;
}
.about .btn_wrap .steps_to_link:hover:before, .about .btn_wrap .reservation_link:hover:before {
  background: linear-gradient(-8deg, #006fff -50%, #acb131 47.53%, #f00 150%);
  transition: 0.5s;
  opacity: 1;
}

.room_type {
  padding: 231px 0 122px 0;
}
.room_type h2 {
  position: relative;
  padding: 0 0 0 340px;
  margin: 0 0 63px 0;
}
.room_type h2:before {
  content: "";
  display: block;
  width: 303px;
  height: 1px;
  position: absolute;
  top: 50%;
  transform: translateY(50%);
  background-color: #000;
  left: 0;
}
.room_type .type_content_wrap {
  max-width: 1240px;
  width: 95%;
  margin: 0 auto 93px;
}
.room_type .type_content_wrap h3 {
  margin: 0 0 17px 0;
}
.room_type .type_content_wrap h3 span {
  vertical-align: middle;
}
.room_type .type_content_wrap h3 span:nth-of-type(1) {
  font-size: 47px;
  font-weight: 500;
  line-height: 1.382;
}
.room_type .type_content_wrap h3 span:nth-of-type(2) {
  position: relative;
  padding: 0px 0 0 14px;
  font-size: 22px;
  font-weight: 500;
  line-height: 1.272;
}
.room_type .type_content_wrap > span {
  display: block;
  font-weight: 500;
  margin: 0 0 11px 0;
}
.room_type .type_content_wrap > p {
  margin: 0 0 26px 0;
}
.room_type .type_content_wrap .image_box_wrap {
  margin: 0 auto 28px;
}
.room_type .type_content_wrap .image_box_wrap ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
}
.room_type .type_content_wrap .image_box_wrap ul li {
  width: calc((100% - 100px) / 3);
}
.room_type .type_content_wrap .image_box_wrap ul li img {
  width: 100%;
}
.room_type .type_content_wrap .view_details {
  position: relative;
  display: block;
  text-align: center;
  padding: 14px 0;
  margin: 0 auto;
  max-width: 440px;
  width: 95%;
  color: #fff;
  background: #000;
}
.room_type .type_content_wrap .view_details:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  opacity: 0;
  transition: 0.5s;
  background: transparent;
}
.room_type .type_content_wrap .view_details span {
  position: relative;
}
.room_type .type_content_wrap .view_details:hover {
  opacity: 1;
}
.room_type .type_content_wrap .view_details:hover:before {
  background: linear-gradient(-8deg, #006fff -50%, #acb131 47.53%, #f00 150%);
  transition: 0.5s;
  opacity: 1;
}

.cancellation_policy {
  padding: 0 0 102px 0;
}
.cancellation_policy h2 {
  position: relative;
  padding: 0 0 0 340px;
  margin: 0 0 85px 0;
}
.cancellation_policy h2:before {
  content: "";
  display: block;
  width: 303px;
  height: 1px;
  position: absolute;
  top: 50%;
  transform: translateY(50%);
  background-color: #000;
  left: 0;
}
.cancellation_policy .policy_wrap {
  max-width: 1240px;
  width: 95%;
  margin: 0 auto 93px;
}
.cancellation_policy .policy_wrap dl {
  margin: 0 0 34px 0;
}
.cancellation_policy .policy_wrap dl dt {
  font-size: 24px;
  font-weight: 500;
  line-height: 1.66;
}
.cancellation_policy .policy_wrap dl:nth-of-type(2) {
  margin: 0 0 72px 0;
}

@media screen and (max-width: 1024px) and (min-width: 768px) {
  .about table tr th {
    width: 25%;
  }
  .about .btn_wrap .steps_to_link, .about .btn_wrap .reservation_link {
    max-width: 380px;
  }
}
@media screen and (max-width: 767px) {
  #all_wrap {
    background-size: 466px, 466px, 466px, 466px, 466px, 466px;
    background-position: top -19px left -234px, top 697px right -233px, top 1407px left -233px, top 2035px right -233px, top 2663px left -233px, bottom 0px right -233px;
  }
  #mv {
    padding: 25px 0 0 0;
  }
  #mv .mv_wrap .text_wrap h2 {
    margin: 0 0 1em 0;
  }
  #mv .mv_wrap .text_wrap h2 p:nth-of-type(1) {
    font-size: 23px;
  }
  #mv .mv_wrap .text_wrap h2 p:nth-of-type(2) {
    font-size: 45px;
  }
  #mv .mv_wrap .image_wrap {
    margin: 0 0 2em 0;
  }
  #mv .mv_wrap .enjoy_wrap dt {
    font-size: 18px;
  }
  #mv .mv_wrap h3 {
    font-size: 35px;
  }
  #mv .mv_wrap h4 {
    font-size: 17px;
  }
  #mv .mv_wrap .mv_content_wrap {
    flex-wrap: wrap;
  }
  #mv .mv_wrap .mv_content_wrap .left_box {
    width: 100%;
    order: 2;
  }
  #mv .mv_wrap .mv_content_wrap .right_box {
    width: 100%;
  }
  .about {
    padding: 50px 0 0 0;
  }
  .about h2 {
    padding: 0px 0 0 84px;
    margin: 0 0 2em 0;
  }
  .about h2:before {
    width: 64px;
  }
  .about table {
    margin: 0 auto 2em;
  }
  .about table tr th {
    width: 30%;
  }
  .about .btn_wrap {
    flex-direction: column;
  }
  .about .btn_wrap .steps_to_link {
    margin: 0 auto 1.5rem;
  }
  .about .btn_wrap .reservation_link, .about .btn_wrap .steps_to_link {
    max-width: 345px;
    padding: 13px 0;
  }
  .about .btn_wrap .reservation_link span, .about .btn_wrap .steps_to_link span {
    font-size: 16px;
  }
  .room_type {
    padding: 50px 0;
  }
  .room_type h2 {
    padding: 0px 0 0 84px;
    margin: 0 0 2em 0;
  }
  .room_type h2:before {
    width: 64px;
  }
  .room_type .type_content_wrap {
    margin: 0 auto 2em;
  }
  .room_type .type_content_wrap h3 span:nth-of-type(1) {
    font-size: 29px;
  }
  .room_type .type_content_wrap h3 span:nth-of-type(2) {
    font-size: 14px;
  }
  .room_type .type_content_wrap > p {
    margin: 0 0 2em 0;
  }
  .room_type .type_content_wrap .image_box_wrap ul {
    display: block;
  }
  .room_type .type_content_wrap .image_box_wrap ul li {
    width: 300px;
    margin: 0 auto 2em auto;
  }
  .room_type .type_content_wrap .view_details {
    max-width: 345px;
    padding: 13px 0;
  }
  .room_type .type_content_wrap .view_details span {
    font-size: 16px;
  }
  .cancellation_policy {
    padding: 0 0 2em 0;
  }
  .cancellation_policy h2 {
    padding: 0px 0 0 84px;
    margin: 0 0 2em 0;
  }
  .cancellation_policy h2:before {
    width: 64px;
  }
  .cancellation_policy .policy_wrap {
    margin: 0 auto 2em;
  }
  .cancellation_policy .policy_wrap dl {
    margin: 0 0 2em 0;
  }
  .cancellation_policy .policy_wrap dl:nth-of-type(2) {
    margin: 0 0 2em 0;
  }
  .cancellation_policy .policy_wrap dl dt {
    font-size: 18px;
  }
}
/*# sourceMappingURL=how_to_enjoy.css.map */