/* ---------------------------------------------------
	common
------------------------------------------------------ */
#pagetit {
  background: url(../img/onsen/pagetit_bg.jpg) center;
  background-size: cover;
}

@media screen and (max-width: 810px) {
  #pagetit {
    background: url(../img/onsen/pagetit_bg_sp.jpg) center;
    background-size: cover;
  }
}
/* ---------------------------------------------------
	room
------------------------------------------------------ */
#room {
  padding: 64px 0 128px;
}
#room .room_slide {
  margin-bottom: 64px;
}
#room .room_slide .slide_item {
  opacity: 0.5;
  transition: opacity 0.6s;
}
#room .room_slide .slick-active .slide_item {
  opacity: 1;
}
#room .room_col {
  align-items: flex-start;
  width: 92%;
  max-width: 1440px;
  margin: 96px auto 0;
}
#room .room_col .col_img {
  width: 64%;
}
#room .room_col .col_img img {
  width: 100%;
  height: auto;
}
#room .room_col .col_img.flexbox .img {
  position: relative;
  width: 50%;
}
#room .room_col .col_img .img_caption {
  position: absolute;
  left: 0;
  bottom: 0;
  padding: 24px 16px 14px;
  background: linear-gradient(to bottom, rgba(19, 27, 36, 0) 0%, rgba(19, 27, 36, 0.6) 100%);
  line-height: 1.2;
}
#room .room_col .col_txt {
  width: 36%;
  padding: 56px 48px 0;
}
#room .room_col .col_txt .txt_container {
  max-width: 385px;
}
#room .room_col .col_txt .sec_lead {
  margin-bottom: 16px;
}
#room hr {
  width: 92%;
  max-width: 1080px;
  margin: 96px auto 48px;
  border: none;
  border-top: 1px solid #d0d0d0;
}
#room .room_col02 {
  align-items: flex-start;
  margin: 0 auto;
}
#room .room_col02 .col_tit {
  width: 92%;
  max-width: 1080px;
  margin: 0 auto 40px;
  font-size: 2rem;
  letter-spacing: 0.2em;
  line-height: 1.75;
}
#room .room_col02 .col_img {
  width: calc(50% + 102px);
  overflow: hidden;
}
#room .room_col02 .col_img .common_slide {
  margin-bottom: 24px;
}
#room .room_col02 .col_img .slick-list {
  max-width: 662px;
  overflow: visible;
}
#room .room_col02 .col_img .slide_item {
  padding-right: 20px;
}
#room .room_col02 .col_img .slick-dots {
  text-align: left;
}
#room .room_col02 .col_img .img_caption {
  position: absolute;
  left: 0;
  bottom: 0;
  padding: 24px 16px 14px;
  background: linear-gradient(to bottom, rgba(19, 27, 36, 0) 0%, rgba(19, 27, 36, 0.6) 100%);
  line-height: 1.2;
}
#room .room_col02 .col_txt {
  width: calc(50% - 102px);
  padding: 0 48px 0;
}
#room .room_col02 .col_txt .txt_container {
  max-width: 389px;
  margin-left: auto;
}
#room .room_col02 .col_txt .txt_btn {
  margin-top: 88px;
}
@media screen and (max-width: 1280px) {
  #room .room_col .col_txt {
    padding-top: 0;
  }
}
@media screen and (max-width: 810px) {
  #room {
    padding: 40px 0 64px;
  }
  #room .room_slide {
    margin-bottom: 48px;
  }
  #room .room_slide .slide_item {
    opacity: 1;
  }
  #room .room_col {
    width: calc(100% - 48px);
    margin-top: 64px;
  }
  #room .room_col .col_img {
    width: 100%;
  }
  #room .room_col .col_img.flexbox .img {
    width: 50%;
  }
  #room .room_col .col_img .img_caption {
    padding: 24px 10px 8px;
    font-size: 1.3rem;
    line-height: 1.4;
    letter-spacing: 0;
  }
  #room .room_col .col_txt {
    width: 100%;
    padding: 32px 0 0;
  }
  #room .room_col .col_txt .txt_container {
    max-width: 100%;
  }
  #room .room_col .col_txt .sec_lead {
    margin-bottom: 16px;
  }
  #room hr {
    width: 100%;
    margin: 48px auto 48px;
  }
  #room .room_col02 {
    width: 100%;
  }
  #room .room_col02 .col_tit {
    width: calc(100% - 48px);
    margin-bottom: 32px;
    font-size: 2rem;
    letter-spacing: 0.2em;
    line-height: 1.75;
  }
  #room .room_col02 .col_img {
    width: 100%;
    margin-bottom: 24px;
    overflow: hidden;
  }
  #room .room_col02 .col_img .common_slide {
    margin-bottom: 24px;
  }
  #room .room_col02 .col_img .slick-list {
    max-width: 90%;
    margin: 0 auto;
    overflow: visible;
  }
  #room .room_col02 .col_img .slide_item {
    padding: 0 8px;
  }
  #room .room_col02 .col_img .slick-dots {
    text-align: center;
  }
  #room .room_col02 .col_txt {
    width: calc(100% - 48px);
    margin: 0 auto;
    padding: 0 0;
  }
  #room .room_col02 .col_txt .txt_container {
    max-width: 100%;
    margin-left: 0;
  }
  #room .room_col02 .col_txt .txt_btn {
    margin-top: 32px;
    text-align: center;
  }
}
/* ---------------------------------------------------
	family
------------------------------------------------------ */
#family {
  padding: 64px 0 128px;
}
#family .sec_tit .small {
  display: block;
  font-size: 2.2rem;
  letter-spacing: 0.1em;
}
#family .family_col {
  max-width: 1440px;
  margin: 0 auto;
}
#family .family_col .col_img {
  width: calc(50% + 160px);
}
#family .family_col .col_txt {
  width: calc(50% - 160px);
  padding: 40px 48px 0;
}
#family .family_col .col_txt .txt_container {
  max-width: 332px;
}
#family .family_col .col_txt .txt_color {
  padding: 1px 16px;
  background: #b9272d;
}
#family .family_col .col_txt .txt_list {
  font-size: 1.7rem;
  line-height: 2.1;
}
#family .family_col .col_txt .txt_list dt {
  color: #c9b292;
}
#family .family_col .col_txt .txt_list .list_row {
  padding: 16px 8px 16px 48px;
}
#family .family_col .col_txt .txt_list .list_row + .list_row {
  border-top: 1px solid #c9b292;
}
#family .family_col .col_txt .txt_list .list_row:first-of-type {
  padding-top: 0;
}
#family .family_col .col_txt .txt_list .list_row:last-of-type {
  padding-bottom: 0;
}
#family .family_col.reverse .col_txt {
  padding-top: 0;
}
#family .family_col.reverse .col_txt .txt_container {
  margin-left: auto;
}
#family .family_col + .family_col {
  margin-top: 64px;
}

@media screen and (max-width: 1280px) {
  #family .family_col .col_txt .txt_list .list_row {
    padding-left: 16px;
  }
}
@media screen and (max-width: 810px) {
  #family {
    padding: 32px 0 64px;
  }
  #family .sec_tit .small {
    font-size: 2rem;
    letter-spacing: 0.1em;
  }
  #family .family_col .col_img {
    width: 100%;
  }
  #family .family_col .col_txt {
    width: calc(100% - 48px);
    margin: 0 auto;
    padding: 32px 0 0;
  }
  #family .family_col .col_txt .txt_container {
    max-width: 100%;
  }
  #family .family_col .col_txt .txt_color {
    padding: 1px 16px;
  }
  #family .family_col .col_txt .txt_list {
    font-size: 1.6rem;
    line-height: 2.1;
  }
  #family .family_col .col_txt .txt_list .list_row {
    padding: 16px 16px;
  }
  #family .family_col.reverse {
    width: calc(100% - 48px);
  }
  #family .family_col.reverse .col_txt {
    width: 100%;
    padding-top: 24px;
  }
  #family .family_col.reverse .col_txt .txt_container {
    margin-left: 0;
  }
  #family .family_col + .family_col {
    margin-top: 64px;
  }
}
/* ---------------------------------------------------
	info
------------------------------------------------------ */
#info {
  padding: 128px 0 0;
}
#info .bg_box {
  padding-top: 24px;
}

@media screen and (max-width: 810px) {
  #info {
    padding: 48px 0 0;
  }
  #info .bg_box {
    padding-top: 32px;
  }
}
/* ---------------------------------------------------
	beppu
------------------------------------------------------ */
#beppu {
  padding: 128px 0 192px;
}
#beppu .beppu_col .col_img {
  width: 56%;
  max-width: 542px;
}
#beppu .beppu_col .col_txt {
  width: 40%;
}
#beppu .beppu_col .col_txt p {
  line-height: 2.25;
}
#beppu .beppu_col02 {
  margin-top: 48px;
  padding: 48px 0;
  border-top: 1px solid #d0d0d0;
  border-bottom: 1px solid #d0d0d0;
  gap: 32px 0;
  line-height: 1.8;
  justify-content: flex-start;
}
#beppu .beppu_col02 .col_item {
  width: 21.8%;
  max-width: 213px;
  margin-right: 4.2%;
  letter-spacing: 0;
}
#beppu .beppu_col02 .col_item:nth-of-type(4n) {
  margin-right: 0;
}
#beppu .beppu_col02 .col_item p {
  line-height: 1.8;
}
#beppu .beppu_col02 .col_item .item_tit {
  margin-bottom: 8px;
  font-size: 2rem;
  line-height: 1.5;
  letter-spacing: 0.2em;
  text-align: center;
}
#beppu .beppu_col02 .col_item .item_time {
  margin-bottom: 24px;
  color: #bc9f77;
  line-height: 1.5;
  letter-spacing: 0.2em;
  text-align: center;
}
#beppu .beppu_col02 .col_item .item_time.ls {
  letter-spacing: 0.01em;
}
#beppu .beppu_col02 .col_item .item_img {
  margin-bottom: 24px;
}
#beppu .beppu_col02 .col_btn {
  width: 100%;
  text-align: right;
}

@media screen and (max-width: 810px) {
  #beppu {
    padding: 48px 0 96px;
  }
  #beppu .beppu_col .col_img {
    width: 100%;
    max-width: 100%;
  }
  #beppu .beppu_col .col_txt {
    width: 100%;
    margin-top: 32px;
  }
  #beppu .beppu_col .col_txt p {
    line-height: 2;
  }
  #beppu .beppu_col02 {
    margin-top: 48px;
    padding: 48px 0;
    gap: 32px 0;
    line-height: 1.8;
    justify-content: space-between;
  }
  #beppu .beppu_col02 .col_item {
    width: calc(50% - 8px);
    max-width: 100%;
    margin-right: 0;
    letter-spacing: 0;
  }
  #beppu .beppu_col02 .col_item .item_tit {
    margin-bottom: 8px;
    font-size: 2rem;
    letter-spacing: 0.2em;
  }
  #beppu .beppu_col02 .col_item .item_time {
    margin-bottom: 12px;
  }
  #beppu .beppu_col02 .col_item .item_time.ls {
    letter-spacing: 0.01em;
  }
  #beppu .beppu_col02 .col_item .item_img {
    margin-bottom: 16px;
  }
  #beppu .beppu_col02 .col_btn {
    text-align: center;
  }
}