.titleArea {
  background-image: url(../images/mainimg.jpg);
}

#contents {
  margin: 0 5vw;
}

.aboutArea {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  padding: 150px 0;
}
@media screen and (max-width: 960px) {
  .aboutArea {
    padding: 70px 0;
    align-items: flex-start;
  }
}
@media screen and (max-width: 668px) {
  .aboutArea {
    padding: 40px 0;
  }
}
.aboutArea .title {
  width: 30%;
}
@media screen and (max-width: 800px) {
  .aboutArea .title {
    width: 180px;
  }
}
@media screen and (max-width: 668px) and (orientation: portrait) {
  .aboutArea .title {
    width: 100%;
  }
}
.aboutArea .title > section {
  display: table;
  margin: 0 auto;
}
@media screen and (max-width: 800px) {
  .aboutArea .title > section {
    margin: 0 auto 0 0;
  }
}
@media screen and (max-width: 668px) and (orientation: portrait) {
  .aboutArea .title > section {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 20px;
  }
}
.aboutArea .title > section .jp {
  text-align: right;
}
.aboutArea .text {
  width: 70%;
  line-height: 200%;
}
@media screen and (max-width: 800px) {
  .aboutArea .text {
    width: calc(100% - 180px);
  }
}
@media screen and (max-width: 668px) and (orientation: portrait) {
  .aboutArea .text {
    width: 100%;
  }
}

.roomArea {
  max-width: 1200px;
  margin: 0 auto;
}
.roomArea section {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}
.roomArea section:not(:last-child) {
  margin-bottom: 100px;
}
@media screen and (max-width: 960px) {
  .roomArea section:not(:last-child) {
    margin-bottom: 50px;
  }
}
.roomArea section .photo {
  width: 50%;
}
@media screen and (max-width: 668px) and (orientation: portrait) {
  .roomArea section .photo {
    width: 100%;
    margin-bottom: 20px;
  }
}
.roomArea section .text {
  width: 45%;
}
@media screen and (max-width: 668px) and (orientation: portrait) {
  .roomArea section .text {
    width: 100%;
  }
}
.roomArea section .text h3 {
  font-size: clamp(24px, 100vw * 30 / 1200, 30px);
  margin-bottom: 30px;
}
@media screen and (max-width: 668px) {
  .roomArea section .text h3 {
    margin-bottom: 20px;
  }
}
.roomArea section .text table {
  width: 100%;
  border-collapse: collapse;
}
.roomArea section .text table tr th, .roomArea section .text table tr td {
  text-align: left;
  vertical-align: top;
  padding: 15px 0;
  border-bottom: 1px solid rgba(34, 34, 34, 0.4);
}
@media screen and (max-width: 668px) {
  .roomArea section .text table tr th, .roomArea section .text table tr td {
    padding: 10px 0;
  }
}
.roomArea section .text table tr th {
  width: 8em;
}

.amenitiesArea {
  max-width: 1200px;
  margin: 150px auto;
  padding: 80px 60px;
  background: url(../../common/images/bg_pattern.jpg);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
@media screen and (max-width: 960px) {
  .amenitiesArea {
    margin: 70px auto;
    padding: 40px;
    background-size: 300px auto;
  }
}
@media screen and (max-width: 668px) {
  .amenitiesArea {
    padding: 30px;
  }
}
.amenitiesArea > div {
  width: 50%;
}
@media screen and (max-width: 668px) and (orientation: portrait) {
  .amenitiesArea > div {
    width: 100%;
    margin-bottom: 20px;
  }
}
.amenitiesArea > div h2 {
  font-size: clamp(20px, 100vw * 25 / 1200, 25px);
  margin-bottom: 50px;
}
@media screen and (max-width: 960px) {
  .amenitiesArea > div h2 {
    margin-bottom: 20px;
  }
}
.amenitiesArea > div p {
  line-height: 200%;
}
.amenitiesArea > p.photo {
  width: 45%;
}
@media screen and (max-width: 668px) and (orientation: portrait) {
  .amenitiesArea > p.photo {
    width: 100%;
  }
}

.saunaArea {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: 150px;
}
@media screen and (max-width: 960px) {
  .saunaArea {
    margin-bottom: 70px;
  }
}
@media screen and (max-width: 668px) {
  .saunaArea {
    margin-bottom: 10px;
  }
}
.saunaArea > div {
  width: 37%;
}
@media screen and (max-width: 960px) {
  .saunaArea > div {
    width: 46%;
  }
}
@media screen and (max-width: 668px) and (orientation: portrait) {
  .saunaArea > div {
    width: 100%;
  }
}
.saunaArea > div .title {
  display: table;
  margin-bottom: 80px;
}
@media screen and (max-width: 1200px) {
  .saunaArea > div .title {
    margin-bottom: 40px;
  }
}
@media screen and (max-width: 668px) and (orientation: portrait) {
  .saunaArea > div .title {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
  }
}
.saunaArea > div .title .jp {
  text-align: right;
}
.saunaArea > div .text {
  margin-left: 3vw;
}
@media screen and (max-width: 668px) and (orientation: portrait) {
  .saunaArea > div .text {
    margin-left: 0;
  }
}
.saunaArea > div .text p {
  line-height: 200%;
}
.saunaArea > div .text table {
  width: 100%;
  margin-top: 50px;
  border-collapse: collapse;
}
@media screen and (max-width: 960px) {
  .saunaArea > div .text table {
    margin-top: 10px;
  }
}
.saunaArea > div .text table tr th, .saunaArea > div .text table tr td {
  border-bottom: 1px solid rgba(34, 34, 34, 0.4);
  padding: 20px 0;
  text-align: left;
  vertical-align: top;
}
.saunaArea > div .text table tr th {
  width: 8em;
}
.saunaArea > ul {
  width: 58%;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 960px) {
  .saunaArea > ul {
    width: 48%;
  }
}
@media screen and (max-width: 668px) and (orientation: portrait) {
  .saunaArea > ul {
    width: 100%;
    margin-top: 30px;
  }
}
.saunaArea > ul li:nth-child(1) {
  width: 41%;
  margin-top: 190px;
}
@media screen and (max-width: 1200px) {
  .saunaArea > ul li:nth-child(1) {
    margin-top: 100px;
  }
}
.saunaArea > ul li:nth-child(2) {
  width: 52%;
}

.restaurantArea {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  flex-direction: row-reverse;
}
.restaurantArea > div {
  width: 50%;
  padding-left: 5vw;
  margin-top: 80px;
}
@media screen and (max-width: 1367px) {
  .restaurantArea > div {
    padding-left: 2vw;
  }
}
@media screen and (max-width: 1200px) {
  .restaurantArea > div {
    margin-top: 40px;
  }
}
@media screen and (max-width: 668px) and (orientation: portrait) {
  .restaurantArea > div {
    width: 100%;
  }
}
.restaurantArea > div .title {
  display: table;
  margin-bottom: 80px;
}
@media screen and (max-width: 1200px) {
  .restaurantArea > div .title {
    margin-bottom: 40px;
  }
}
@media screen and (max-width: 668px) and (orientation: portrait) {
  .restaurantArea > div .title {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
  }
}
.restaurantArea > div .title .jp {
  text-align: right;
}
.restaurantArea > div .text {
  margin-left: 3vw;
}
@media screen and (max-width: 668px) and (orientation: portrait) {
  .restaurantArea > div .text {
    margin-left: 0;
  }
}
.restaurantArea > div .text p {
  line-height: 200%;
}
.restaurantArea > ul {
  width: 50%;
}
@media screen and (max-width: 668px) and (orientation: portrait) {
  .restaurantArea > ul {
    width: 100%;
    margin-top: 20px;
  }
}
.restaurantArea > ul li:nth-child(1) {
  width: 64%;
  margin-bottom: 80px;
}
@media screen and (max-width: 1200px) {
  .restaurantArea > ul li:nth-child(1) {
    margin-bottom: 40px;
  }
}
.restaurantArea > ul li:nth-child(2) {
  width: 44%;
  margin-left: auto;
}/*# sourceMappingURL=index.css.map */