@charset "UTF-8";
/* ===================================================================
CSS information

 file name  : facilities.css
 author     : Ability Consultant
 style info : 館内施設
=================================================================== */
.wrp_intr .con_intr, .box_slider, .con_fac .box_run .list_run, .con_fac .box_bath .box_det, .con_fac .box_welcome, .con_fac .box_shop, .con_fac .box_barr, .con_over .box_over {
  max-width: 1200px;
  margin: auto;
}
@media only screen and (max-width: 1199px) {
  .wrp_intr .con_intr, .box_slider, .con_fac .box_run .list_run, .con_fac .box_bath .box_det, .con_fac .box_welcome, .con_fac .box_shop, .con_fac .box_barr, .con_over .box_over {
    width: 91.66667%;
  }
}

.con_gnav .box_gnav #gnav #g_fac a:before {
  filter: progid:DXImageTransform.Microsoft.Alpha(enabled=false);
  opacity: 1;
}

/* -----------------------------------------------------------
	wrp_intr
----------------------------------------------------------- */
.wrp_intr {
  position: relative;
  padding: 45px 0;
  overflow: hidden;
  background: url(../images/common/bg03.png) repeat 0 0;
}
@media only screen and (max-width: 767px) {
  .wrp_intr {
    padding: 3em 0;
  }
}
.wrp_intr .con_intr {
  position: relative;
}
@media only screen and (max-width: 1199px) {
  .wrp_intr .con_intr {
    width: 100%;
  }
}
.wrp_intr .con_intr .photo {
  background: #000;
}
@media only screen and (min-width: 768px) {
  .wrp_intr .con_intr .photo img {
    filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=50);
    opacity: 0.5;
  }
}
@media print {
  .wrp_intr .con_intr .photo img {
    filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=50);
    opacity: 0.5;
  }
}
.ie8 .wrp_intr .con_intr .photo img {
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=50);
  opacity: 0.5;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .wrp_intr .con_intr .photo {
    overflow: hidden;
  }
  .wrp_intr .con_intr .photo img {
    position: relative;
    width: 130%;
    max-width: none;
    margin-left: -15%;
  }
}
.wrp_intr .con_intr .box_txt {
  width: 100%;
  position: absolute;
  top: 50%;
  left: 0;
  text-align: center;
  color: #fff;
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
@media only screen and (max-width: 767px) {
  .wrp_intr .con_intr .box_txt {
    position: static;
    width: 91.66667%;
    margin: 1em auto 0;
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    -webkit-transform: translateY(0);
    transform: translateY(0);
    color: #2f2f2f;
  }
}
.wrp_intr .con_intr .box_txt .catch {
  margin-bottom: 40px;
  line-height: 1.6;
  letter-spacing: .25em;
  font-size: 179%;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .wrp_intr .con_intr .box_txt .catch {
    margin-bottom: 4%;
    font-size: 158%;
  }
}
@media only screen and (max-width: 767px) {
  .wrp_intr .con_intr .box_txt .catch {
    margin-bottom: 3%;
    line-height: 1.25;
    font-size: 143%;
  }
}
.wrp_intr .con_intr .box_txt .txt {
  font-size: 115%;
  line-height: 2.5;
  letter-spacing: .08em;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .wrp_intr .con_intr .box_txt .txt {
    font-size: 108%;
    line-height: 2;
  }
}
@media only screen and (max-width: 767px) {
  .wrp_intr .con_intr .box_txt .txt {
    font-size: 100%;
    line-height: 1.8;
  }
}
.wrp_intr > p {
  position: absolute;
}
.wrp_intr > p.pho02 {
  top: 45px;
  left: 50%;
  width: 318px;
  margin-left: -960px;
}
.wrp_intr > p.pho03 {
  bottom: 45px;
  left: 50%;
  width: 318px;
  margin-left: -960px;
}
.wrp_intr > p.pho04 {
  top: 45px;
  right: 50%;
  width: 318px;
  margin-right: -960px;
}
.wrp_intr > p.pho05 {
  bottom: 45px;
  right: 50%;
  width: 318px;
  margin-right: -960px;
}

/* -----------------------------------------------------------
	con_pnav
----------------------------------------------------------- */
.con_pnav {
  margin-bottom: 115px;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .con_pnav {
    margin-bottom: 100px;
  }
}
@media only screen and (max-width: 767px) {
  .con_pnav {
    margin-bottom: 3em;
  }
}
@media only screen and (min-width: 768px) {
  .con_pnav .pnav {
    max-width: 970px;
    width: 100%;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .con_pnav .pnav li {
    margin: 0 1.03093% 0 0;
    width: 23.91753%;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }
  .con_pnav .pnav li:nth-child(4n) {
    margin-right: 0;
  }
  .con_pnav .pnav li:nth-child(n+5) {
    margin-top: 10px;
  }
}
@media print {
  .con_pnav .pnav {
    max-width: 970px;
    width: 100%;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .con_pnav .pnav li {
    margin: 0 1.03093% 0 0;
    width: 23.91753%;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }
  .con_pnav .pnav li:nth-child(4n) {
    margin-right: 0;
  }
  .con_pnav .pnav li:nth-child(n+5) {
    margin-top: 10px;
  }
}
.ie8 .con_pnav .pnav {
  max-width: 970px;
  width: 100%;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
}
.ie8 .con_pnav .pnav li {
  margin: 0 1.03093% 0 0;
  width: 23.91753%;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
.ie8 .con_pnav .pnav li:nth-child(4n) {
  margin-right: 0;
}
.ie8 .con_pnav .pnav li:nth-child(n+5) {
  margin-top: 10px;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .con_pnav .pnav {
    margin: auto;
    width: 95%;
  }
  .con_pnav .pnav li {
    white-space: nowrap;
  }
  .con_pnav .pnav li a {
    font-size: 93%;
    letter-spacing: 0;
  }
}

/* -----------------------------------------------------------
	con_fac
----------------------------------------------------------- */
.box_slider .slick-dots {
  bottom: 5%;
}
.box_slider .slick-dots li {
  width: 16px;
  height: 16px;
  margin: 0 .3em;
}
@media only screen and (max-width: 767px) {
  .box_slider .slick-dots li {
    width: 1em;
    height: 1em;
    margin: 0 .5em;
  }
}
.box_slider .slick-dots li button {
  width: 100%;
  height: 100%;
}
.box_slider .slick-dots li button:before {
  content: '';
  width: 100%;
  height: 100%;
  border: 2px solid #fff;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  background: none;
  filter: progid:DXImageTransform.Microsoft.Alpha(enabled=false);
  opacity: 1;
  -moz-transition: background 0.8s, border 0.8s;
  -o-transition: background 0.8s, border 0.8s;
  -webkit-transition: background 0.8s, border 0.8s;
  transition: background 0.8s, border 0.8s;
}
.box_slider .slick-dots li.slick-active button:before {
  background: #b18b15;
  border: 2px solid #b18b15;
}
@media only screen and (max-width: 767px) {
  .box_slider {
    width: 100%;
  }
}
.box_slider .slick-list {
  overflow: visible;
}
.box_slider .photo img {
  opacity: 0.5 !important;
  -moz-transition: opacity 1s;
  -o-transition: opacity 1s;
  -webkit-transition: opacity 1s;
  transition: opacity 1s;
}
.box_slider .photo.slick-active img {
  opacity: 1 !important;
}

.con_fac h3 {
  font-weight: normal;
  text-align: center;
  letter-spacing: .12em;
  margin-bottom: 30px;
  font-size: 193%;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .con_fac h3 {
    font-size: 179%;
  }
}
@media only screen and (max-width: 767px) {
  .con_fac h3 {
    font-size: 129%;
    letter-spacing: .06em;
    margin-bottom: 4%;
  }
}
.con_fac h3:before {
  content: "";
  display: block;
  margin: 0 auto .2em;
  width: 23px;
  height: 23px;
  background: url(../images/common/ic_st.png) no-repeat center;
}
@media only screen and (max-width: 767px) {
  .con_fac h3:before {
    width: .8em;
    height: .8em;
    background-size: contain;
  }
}
.con_fac h3 span {
  color: #b18b15;
}
.con_fac .box_run {
  overflow: hidden;
}
.con_fac .box_run .list_run {
  overflow: hidden;
  margin-top: 40px;
}
@media only screen and (max-width: 767px) {
  .con_fac .box_run .list_run {
    margin-top: 1em;
  }
}
.con_fac .box_run .list_run li {
  float: left;
  width: 47.91667%;
}
@media only screen and (max-width: 767px) {
  .con_fac .box_run .list_run li {
    width: 100%;
  }
}
@media only screen and (max-width: 767px) {
  .con_fac .box_run .list_run li {
    float: none;
  }
}
@media only screen and (min-width: 768px) {
  .con_fac .box_run .list_run li:nth-child(even) {
    float: right;
  }
  .con_fac .box_run .list_run li:nth-child(n+3) {
    clear: both;
    margin-top: 30px;
  }
}
@media print {
  .con_fac .box_run .list_run li:nth-child(even) {
    float: right;
  }
  .con_fac .box_run .list_run li:nth-child(n+3) {
    clear: both;
    margin-top: 30px;
  }
}
.ie8 .con_fac .box_run .list_run li:nth-child(even) {
  float: right;
}
.ie8 .con_fac .box_run .list_run li:nth-child(n+3) {
  clear: both;
  margin-top: 30px;
}
@media only screen and (max-width: 767px) {
  .con_fac .box_run .list_run li:nth-child(n+2) {
    margin-top: 1.5em;
  }
}
.con_fac .box_run .list_run li .box_txt h4 {
  font-weight: normal;
  margin-bottom: 10px;
}
.con_fac .box_run .list_run li .box_txt h4 em {
  display: inline-block;
  vertical-align: middle;
  font-size: 158%;
  letter-spacing: .06em;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .con_fac .box_run .list_run li .box_txt h4 em {
    font-size: 143%;
  }
}
@media only screen and (max-width: 767px) {
  .con_fac .box_run .list_run li .box_txt h4 em {
    font-size: 115%;
  }
}
.con_fac .box_run .list_run li .box_txt h4:before {
  content: "";
  width: .8em;
  height: .8em;
  background: url(../images/common/ic_st.png) no-repeat center/contain;
  display: inline-block;
  vertical-align: middle;
  margin: -.25em .3em 0 0;
}
@media only screen and (max-width: 767px) {
  .con_fac .box_run .list_run li .box_txt h4 {
    margin-bottom: 2%;
  }
}
.con_fac .box_run .list_run li .box_txt table {
  width: 100%;
  margin-top: 30px;
}
@media only screen and (max-width: 767px) {
  .con_fac .box_run .list_run li .box_txt table {
    margin-top: 4%;
  }
}
.con_fac .box_run .list_run li .box_txt table th {
  width: 160px;
}
@media only screen and (max-width: 767px) {
  .con_fac .box_run .list_run li .box_txt table th {
    width: 40%;
  }
}
.con_fac .box_bath {
  overflow: hidden;
}
.con_fac .box_bath .box_det {
  overflow: hidden;
  margin-top: 40px;
}
@media only screen and (max-width: 767px) {
  .con_fac .box_bath .box_det {
    margin-top: 0.8em;
  }
}
.con_fac .box_bath .box_det .txt {
  float: left;
  width: 45.83333%;
}
@media only screen and (max-width: 767px) {
  .con_fac .box_bath .box_det .txt {
    float: none;
    width: 100%;
    margin-bottom: 1%;
  }
}
.con_fac .box_bath .box_det .box_tbl {
  float: right;
  width: 47.91667%;
}
@media only screen and (max-width: 767px) {
  .con_fac .box_bath .box_det .box_tbl {
    margin-top: 1.5em;
    float: none;
    width: 100%;
  }
}
.con_fac .box_bath .box_det .box_tbl table {
  width: 100%;
}
.con_fac .box_bath .box_det .box_tbl table th {
  width: 160px;
}
@media only screen and (max-width: 767px) {
  .con_fac .box_bath .box_det .box_tbl table th {
    width: 30%;
  }
}
.con_fac .box_welcome {
  overflow: hidden;
  margin-top: 120px;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .con_fac .box_welcome {
    margin-top: 100px;
  }
}
@media only screen and (max-width: 767px) {
  .con_fac .box_welcome {
    margin-top: 3em;
  }
}
.con_fac .box_welcome .photo {
  margin-bottom: 30px;
}
@media only screen and (max-width: 767px) {
  .con_fac .box_welcome .photo {
    margin-bottom: 4%;
  }
}
.con_fac .box_welcome .txt {
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .con_fac .box_welcome .txt {
    text-align: left;
    margin-bottom: 1%;
  }
}
.con_fac .box_shop {
  overflow: hidden;
  margin-top: 120px;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .con_fac .box_shop {
    margin-top: 100px;
  }
}
@media only screen and (max-width: 767px) {
  .con_fac .box_shop {
    margin-top: 3em;
  }
}
.con_fac .box_shop .photo {
  margin-bottom: 30px;
}
@media only screen and (max-width: 767px) {
  .con_fac .box_shop .photo {
    margin-bottom: 4%;
  }
}
.con_fac .box_shop .txt {
  float: left;
  width: 45.83333%;
}
@media only screen and (max-width: 767px) {
  .con_fac .box_shop .txt {
    float: none;
    width: 100%;
    margin-bottom: 1%;
  }
}
.con_fac .box_shop .box_tbl {
  float: right;
  width: 47.91667%;
}
@media only screen and (max-width: 767px) {
  .con_fac .box_shop .box_tbl {
    margin-top: 1.5em;
    float: none;
    width: 100%;
  }
}
.con_fac .box_shop .box_tbl table {
  width: 100%;
}
.con_fac .box_shop .box_tbl table th {
  width: 160px;
}
@media only screen and (max-width: 767px) {
  .con_fac .box_shop .box_tbl table th {
    width: 40%;
  }
}
.con_fac .box_barr {
  overflow: hidden;
  margin-top: 120px;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .con_fac .box_barr {
    margin-top: 100px;
  }
}
@media only screen and (max-width: 767px) {
  .con_fac .box_barr {
    margin-top: 3em;
  }
}
.con_fac .box_barr .photo {
  float: left;
  width: 47.91667%;
}
@media only screen and (max-width: 767px) {
  .con_fac .box_barr .photo {
    float: none;
    width: 100%;
    margin-bottom: 4%;
  }
}
.con_fac .box_barr .txt {
  float: right;
  width: 47.91667%;
}
@media only screen and (max-width: 767px) {
  .con_fac .box_barr .txt {
    float: none;
    width: 100%;
  }
}

#run {
  margin-top: 120px;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  #run {
    margin-top: 100px;
  }
}
@media only screen and (max-width: 767px) {
  #run {
    margin-top: 3em;
  }
}

.slick-slider {
  margin-bottom: 0 !important;
}

/* -----------------------------------------------------------
	con_over
----------------------------------------------------------- */
.con_over {
  background: url(../images/common/bg02.png) repeat 0 0;
  padding: 65px 0;
  margin-top: 120px;
}
@media only screen and (max-width: 767px) {
  .con_over {
    padding: 8% 0;
    margin-top: 12%;
  }
}
.con_over h3 {
  font-weight: normal;
  text-align: center;
  letter-spacing: .12em;
  margin-bottom: 30px;
  font-size: 193%;
}
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .con_over h3 {
    font-size: 179%;
  }
}
@media only screen and (max-width: 767px) {
  .con_over h3 {
    font-size: 129%;
    letter-spacing: .06em;
    margin-bottom: 4%;
  }
}
.con_over h3:before {
  content: "";
  display: block;
  margin: 0 auto .2em;
  width: 23px;
  height: 23px;
  background: url(../images/common/ic_st.png) no-repeat center;
}
@media only screen and (max-width: 767px) {
  .con_over h3:before {
    width: .8em;
    height: .8em;
    background-size: contain;
  }
}
.con_over h3 span {
  color: #b18b15;
}
.con_over .box_over table {
  width: 100%;
}
.con_over .box_over table th {
  width: 250px;
}
@media only screen and (max-width: 767px) {
  .con_over .box_over table th {
    width: 100%;
    display: block;
  }
}
@media only screen and (max-width: 767px) {
  .con_over .box_over table td {
    width: 100%;
    display: block;
  }
}
