@charset "UTF-8";
/* ROOMS
*****************************************************************/
/* mixin
*********************************************************************/
/* カラー */
/* media query */
/* SP縦から */
/* SP横から */
/* タブレット縦から */
/* 1280 */
/* フルワイド */
@import url("https://fonts.googleapis.com/css2?family=Shippori+Mincho+B1&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Cinzel&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Russo+One&display=swap");
.area_rooms {
  padding: 0 8vw 80px;
}
@media all and (max-width: 896px) {
  .area_rooms {
    padding: 0 20px 50px;
  }
}
.area_rooms .block_category {
  padding: 80px 0 0;
  text-align: center;
}
@media all and (max-width: 896px) {
  .area_rooms .block_category {
    padding: 30px 0 0;
  }
}
.area_rooms .block_category .ttl_category {
  max-width: 800px;
  margin: auto;
}
.area_rooms .block_category .ttl_category img {
  width: 100%;
  height: auto;
}
.area_rooms .block_category .ttl_category h2 {
  font-size: 2.2rem;
  line-height: 1.3em;
  padding: 14px 0;
}
@media all and (max-width: 896px) {
  .area_rooms .block_category .ttl_category h2 {
    font-size: 1.7rem;
    padding: 10px 0;
  }
}
.area_rooms .block_category .list_pict {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  padding: 20px 0 0;
}
@media all and (max-width: 896px) {
  .area_rooms .block_category .list_pict {
    padding: 10px 0 0;
  }
}
.area_rooms .block_category .list_pict dl {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 15px;
}
@media all and (max-width: 896px) {
  .area_rooms .block_category .list_pict dl {
    width: 50%;
    box-sizing: border-box;
    padding: 5px;
    justify-content: flex-start;
  }
}
.area_rooms .block_category .list_pict dl dt {
  padding: 5px;
  width: 7vw;
}
@media all and (max-width: 480px) {
  .area_rooms .block_category .list_pict dl dt {
    width: 40px;
    padding: 2px;
  }
}
.area_rooms .block_category .list_pict dl dt img {
  width: 100%;
  height: auto;
}
.area_rooms .block_category .list_pict dl dd {
  padding: 5px;
  font-size: 1.6rem;
  text-align: left;
  line-height: 1.3em;
}
@media all and (max-width: 480px) {
  .area_rooms .block_category .list_pict dl dd {
    padding: 2px;
    font-size: 1.5rem;
  }
}
@media all and (max-width: 896px) {
  .area_rooms .block_category .list_pict dl dd .newline_o {
    display: inline-block;
  }
}
.area_rooms .block_category .box_txt {
  padding: 40px 0 0;
}
@media all and (max-width: 896px) {
  .area_rooms .block_category .box_txt {
    padding: 10px 0 0;
  }
}
.area_rooms .block_category .box_txt p {
  font-size: 1.8rem;
  line-height: 2em;
}
@media all and (max-width: 896px) {
  .area_rooms .block_category .box_txt p {
    font-size: 1.5rem;
    line-height: 1.8em;
    text-align: left;
  }
}

.list_rooms {
  padding: 20px 0 0;
}
@media all and (max-width: 896px) {
  .list_rooms {
    padding: 10px 0 0;
  }
}
.list_rooms ul {
  margin: 0 -20px;
  padding: 20px 0 0;
  display: flex;
  flex-wrap: wrap;
}
@media all and (max-width: 896px) {
  .list_rooms ul {
    padding: 5px 0 0;
    margin: 0 -5px;
  }
}
.list_rooms ul li {
  width: 50%;
  box-sizing: border-box;
  padding: 20px;
}
@media all and (max-width: 896px) {
  .list_rooms ul li {
    padding: 5px;
  }
}
@media all and (max-width: 480px) {
  .list_rooms ul li {
    width: 100%;
  }
}
.list_rooms ul li .box_img {
  line-height: 0em;
  position: relative;
}
.list_rooms ul li .box_img::after {
  position: absolute;
  content: "";
  display: block;
  width: 10px;
  height: 100%;
  background-color: #2E318D;
  top: 140px;
  left: 20px;
}
@media all and (max-width: 896px) {
  .list_rooms ul li .box_img::after {
    width: 5px;
    left: 10px;
    top: 70px;
  }
}
.list_rooms ul li .box_img img {
  width: 100%;
  height: auto;
}
.list_rooms ul li .box_name {
  display: flex;
  justify-content: space-between;
  padding: 20px 0 30px 50px;
}
@media all and (max-width: 896px) {
  .list_rooms ul li .box_name {
    padding: 10px 0 20px 25px;
  }
}
.list_rooms ul li .box_name .room_name {
  width: 8vw;
  min-width: 70px;
}
.list_rooms ul li .box_name .room_name img {
  width: 100%;
  height: auto;
}

.visual_detail {
  width: 100%;
  height: 100vh;
  position: relative;
  overflow: hidden;
}
@media all and (max-width: 480px) {
  .visual_detail {
    height: calc(50vh - 50px);
  }
}
.visual_detail img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}

.block_title_detail {
  text-align: center;
  position: absolute;
  width: 100%;
  top: 45%;
}
@media all and (max-width: 896px) {
  .block_title_detail {
    height: 60vh;
  }
}
@media all and (max-width: 480px) {
  .block_title_detail {
    height: 180px;
  }
}
.block_title_detail .box_title {
  display: inline-block;
  background-color: rgba(32, 0, 0, 0.7);
  color: #FFF;
  padding: 16px 3em 16px 3.7em;
}
.block_title_detail .box_title h1 {
  font-size: 4rem;
  line-height: 1em;
  font-weight: 400;
  letter-spacing: 0.2em;
  box-sizing: border-box;
  text-align: center;
}
@media all and (max-width: 896px) {
  .block_title_detail .box_title h1 {
    font-size: 3rem;
  }
}
@media all and (max-width: 480px) {
  .block_title_detail .box_title h1 {
    height: 130px;
    letter-spacing: 0.4em;
  }
}
.block_title_detail .box_title .en {
  font-size: 1.8rem;
  line-height: 1em;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 14vh;
}
@media all and (max-width: 896px) {
  .block_title_detail .box_title .en {
    font-size: 1.2rem;
  }
}
@media all and (max-width: 480px) {
  .block_title_detail .box_title .en {
    height: 50px;
  }
}

.block_detail {
  padding: 5px 0 0;
}
.block_detail .single_img {
  padding: 20px 0 0;
  line-height: 0em;
}
@media all and (max-width: 896px) {
  .block_detail .single_img {
    padding: 15px 0 0;
  }
}
.block_detail .single_img img {
  width: 100%;
  height: auto;
}
.block_detail .caption_txt {
  padding: 5px 0 0;
}
.block_detail .caption_txt p {
  font-size: 1.4rem;
  line-height: 1.4em;
}
.block_detail .double_img {
  padding: 10px 0 0;
  margin: 0 -10px;
  display: flex;
}
@media all and (max-width: 896px) {
  .block_detail .double_img {
    padding: 5px 0 0;
    margin: 0 -5px;
  }
}
.block_detail .double_img .thumb_img {
  width: 50%;
  line-height: 0em;
  box-sizing: border-box;
  padding: 10px;
}
@media all and (max-width: 896px) {
  .block_detail .double_img .thumb_img {
    padding: 5px;
  }
}
.block_detail .double_img .thumb_img .inner {
  width: 100%;
  aspect-ratio: 5/4;
  overflow: hidden;
}
.block_detail .double_img .thumb_img .inner img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}
.block_detail .box_concept .ttl_concept {
  display: flex;
  flex-wrap: wrap;
  font-size: 1.8rem;
  line-height: 1.2em;
  padding: 8px 0 0;
}
@media all and (max-width: 896px) {
  .block_detail .box_concept .ttl_concept {
    font-size: 1.6rem;
  }
}
.block_detail .box_concept .ttl_concept h2 {
  font-family: "Noto Sans JP", "游ゴシック", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, sans-serif;
  font-weight: 700;
  position: relative;
  padding: 2px 8vw 2px 0;
  margin: 0 0 0 -0.6em;
}
.block_detail .box_concept .ttl_concept h2::after {
  content: "";
  display: block;
  border-top: #666 solid 1px;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0px;
  width: 7.5vw;
}
.block_detail .box_concept .ttl_concept > div {
  padding: 2px 0 2px 0.8vw;
}
.block_detail .box_concept p {
  padding: 8px 0 0;
  font-size: 1.5rem;
  line-height: 1.6em;
}
.block_detail .box_spec .part_ttl {
  position: relative;
  padding: 40px 0 0;
}
@media all and (max-width: 896px) {
  .block_detail .box_spec .part_ttl {
    padding: 20px 0 0;
  }
}
.block_detail .box_spec .part_ttl h2 {
  font-size: 2.2rem;
  line-height: 1.1em;
  padding: 0 0 10px;
  border-bottom: #000 solid 1px;
  text-align: center;
  font-weight: 400;
}
@media all and (max-width: 896px) {
  .block_detail .box_spec .part_ttl h2 {
    font-size: 2rem;
    text-align: left;
    padding: 0 0 5px;
  }
}
.block_detail .box_spec .part_ttl .tab_reserve {
  position: absolute;
  right: 0px;
  bottom: 0px;
  width: 14vw;
  min-width: 140px;
}
.block_detail .box_spec .part_ttl .tab_reserve img {
  width: 100%;
  height: auto;
}
.block_detail .box_spec .column_spec {
  display: flex;
  flex-wrap: wrap;
  padding: 10px 0 0;
  margin: 0 -15px;
}
@media all and (max-width: 896px) {
  .block_detail .box_spec .column_spec {
    margin: 0 -10px;
  }
}
.block_detail .box_spec .column_spec .side_txt {
  width: 65%;
  padding: 15px;
  box-sizing: border-box;
}
@media all and (max-width: 896px) {
  .block_detail .box_spec .column_spec .side_txt {
    width: 100%;
    padding: 10px;
  }
}
.block_detail .box_spec .column_spec .side_txt dl {
  font-size: 1.6rem;
  line-height: 1.6em;
  display: flex;
  flex-wrap: wrap;
}
@media all and (max-width: 480px) {
  .block_detail .box_spec .column_spec .side_txt dl {
    font-size: 1.4rem;
  }
}
.block_detail .box_spec .column_spec .side_txt dl dt {
  width: 8em;
  padding: 3px 0;
}
.block_detail .box_spec .column_spec .side_txt dl dd {
  width: calc(100% - 8em);
  padding: 3px 0;
}
.block_detail .box_spec .column_spec .side_map {
  width: 35%;
  padding: 15px;
  box-sizing: border-box;
  text-align: center;
}
@media all and (max-width: 896px) {
  .block_detail .box_spec .column_spec .side_map {
    width: 100%;
    padding: 10px;
  }
}
.block_detail .box_spec .column_spec .side_map img {
  width: 100%;
  height: auto;
}
@media all and (max-width: 896px) {
  .block_detail .box_spec .column_spec .side_map img {
    max-width: 320px;
  }
}

.nav_room {
  background-color: #ECE7E8;
  padding: 60px 20px;
}
@media all and (max-width: 896px) {
  .nav_room {
    padding: 30px 20px;
  }
}
.nav_room h2 {
  text-align: center;
  font-size: 2.2rem;
  line-height: 1.1em;
}
@media all and (max-width: 896px) {
  .nav_room h2 {
    font-size: 2rem;
  }
}
.nav_room nav {
  max-width: 1200px;
  margin: auto;
  padding: 40px 0 0;
}
@media all and (max-width: 896px) {
  .nav_room nav {
    padding: 20px 0 0;
  }
}
.nav_room nav ul {
  display: flex;
  flex-wrap: wrap;
}
.nav_room nav ul li {
  padding: 5px;
  width: 10%;
  box-sizing: border-box;
}
@media all and (max-width: 896px) {
  .nav_room nav ul li {
    width: 20%;
  }
}
.nav_room nav ul li a {
  display: block;
  background-color: rgba(32, 0, 0, 0.7);
  color: #FFF;
  text-align: center;
  padding: 40px 0 30px;
}
.nav_room nav ul li a:hover {
  background-color: #d1803a;
}
.nav_room nav ul li a .name {
  writing-mode: vertical-rl;
  font-size: 2.6rem;
  margin: auto;
}
.nav_room nav ul li a .en {
  font-size: 1.3rem;
  line-height: 1.4em;
  padding: 30px 0 0;
}
@media all and (max-width: 896px) {
  .nav_room nav ul li a .en {
    font-size: 1.2rem;
  }
}
@media all and (max-width: 480px) {
  .nav_room nav ul li a .en {
    font-size: 1rem;
  }
}

.kakuun {
  color: #3C603B;
}

.keiun {
  color: #2E318D;
}

.koun {
  color: #3C603B;
}

.saiun {
  color: #2E318D;
}

.hakuun {
  color: #3C603B;
}

.ryuun {
  color: #2E318D;
}

.shiun {
  color: #3C603B;
}