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

#lead {
  padding-bottom: 84px;
}
#lead .floormap {
  margin-top: 104px;
}
#lead .page_nav {
  margin-top: 56px;
}

.fac_sec {
  padding: 80px 0 84px;
}
.fac_sec .sec_tit {
  margin-bottom: 40px;
}
.fac_sec .common_slide {
  margin-bottom: 16px;
}
.fac_sec .common_slide.wide_container {
  max-width: none;
}
.fac_sec .common_slide.sp_wide {
  margin-bottom: 48px;
}
.fac_sec .common_slide img {
  width: 100%;
}
.fac_sec .fac_col.wide_container {
  max-width: none;
}
.fac_sec .fac_col .col_img {
  width: 50%;
}
.fac_sec .fac_col .col_img img {
  width: 100%;
}
.fac_sec .fac_col .col_txt {
  width: 44.6%;
}
.fac_sec .fac_img {
  margin-top: 64px;
  justify-content: space-around;
}
.fac_sec .fac_img .img_min {
  margin-top: 172px;
}
.fac_sec .fac_btn {
  margin-top: 32px;
}

@media screen and (max-width: 810px) {
  #lead {
    padding-bottom: 48px;
  }
  #lead .floormap {
    margin-top: 48px;
  }
  #lead .page_nav {
    margin-top: 24px;
  }
  .fac_sec {
    padding: 48px 0 48px;
  }
  .fac_sec .sec_tit {
    margin-bottom: 32px;
  }
  .fac_sec .common_slide {
    width: 100%;
    margin-bottom: 24px;
  }
  .fac_sec .common_slide.sp_wide {
    margin-bottom: 48px;
  }
  .fac_sec .fac_col .col_img {
    width: 100%;
    margin-bottom: 24px;
  }
  .fac_sec .fac_col .col_txt {
    width: 100%;
  }
  .fac_sec .fac_img {
    margin-top: 40px;
  }
  .fac_sec .fac_img .img_wide {
    width: 50%;
  }
  .fac_sec .fac_img .img_min {
    width: 36%;
    margin-top: 20%;
  }
  .fac_sec .fac_btn {
    margin-top: 24px;
  }
}
/* ---------------------------------------------------
		onsen
------------------------------------------------------ */
#onsen .onsen_col {
  margin-top: 64px;
}
#onsen .onsen_col .col_item {
  width: 31.6%;
  max-width: 368px;
}
#onsen .onsen_col .col_item p {
  margin-top: 16px;
  text-align: center;
}

@media screen and (max-width: 810px) {
  #onsen .onsen_col {
    margin-top: 40px;
  }
  #onsen .onsen_col .col_item {
    width: 31.6%;
    max-width: 368px;
  }
  #onsen .onsen_col .col_item p {
    margin-top: 12px;
    line-height: 1.5;
  }
}
/* ---------------------------------------------------
		relaxation
------------------------------------------------------ */
#relaxation .fac_col {
  margin-top: 64px;
}

/* ---------------------------------------------------
	sec_wrap
------------------------------------------------------ */
.sec_wrap section {
  width: 46%;
  max-width: 536px;
  padding: 80px 0 84px;
}
.sec_wrap .common_slide {
  margin-bottom: 60px;
}
.sec_wrap .sec_tit {
  text-align: left;
}
.sec_wrap .sec_tit .en {
  display: inline-block;
  margin: 0 0 0 8px;
}

@media screen and (max-width: 810px) {
  .sec_wrap section {
    width: 100%;
    max-width: 100%;
    padding: 48px 0 48px;
  }
  .sec_wrap .common_slide {
    margin-bottom: 40px;
  }
  .sec_wrap .sec_tit {
    text-align: center;
  }
  .sec_wrap .sec_tit .en {
    display: block;
    margin: 8px 0 0;
  }
}
/* ---------------------------------------------------
	other
------------------------------------------------------ */
#other .flexbox:has(.other_sec) {
  gap: 64px 0;
  justify-content: flex-start;
}
#other .other_sec {
  width: 31.6%;
  max-width: 368px;
  margin-right: 2.6%;
}
#other .other_sec:nth-of-type(3n), #other .other_sec:last-of-type {
  margin-right: 0;
}
#other .other_sec .other_mv {
  margin-bottom: 40px;
}
#other .other_sec .sec_tit {
  margin-bottom: 32px;
  text-align: left;
}
@media screen and (max-width: 810px) {
  #other .flexbox:has(.other_sec) {
    gap: 40px 0;
    justify-content: space-between;
  }
  #other .other_sec {
    width: 100%;
    max-width: 100%;
    margin-right: 0;
  }
  #other .other_sec .other_mv {
    margin-bottom: 20px;
  }
  #other .other_sec .sec_tit {
    margin-bottom: 16px;
    font-size: 2rem;
  }
  #other .other_sec .sec_tit .en {
    display: inline-block;
    margin: 0 0 0 12px;
    font-size: 1.3rem;
  }
}
/* ---------------------------------------------------
	info
------------------------------------------------------ */
#info {
  padding: 80px 0 112px;
}
#info .table {
  margin-top: 40px;
}

@media screen and (max-width: 810px) {
  #info {
    padding: 48px 0 96px;
  }
  #info .table {
    margin-top: 32px;
  }
}