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

file name  : homepage.css
author     : Abilive
style info : トップページ
=================================================================== */
/* ===================================================================
CSS information

file name  : _settings.scss
author     : Abilive
style info : 汎用設定
=================================================================== */
.p-fv {
  position: relative;
  margin-top: 30px;
  padding-top: 20px;
}
.p-fv:before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  z-index: -1;
  width: 1920px;
  height: 332px;
  margin-left: -960px;
  background: url(../images/home/dec_fv.png) no-repeat left top/contain;
}
.p-fv iframe {
  width: 100%;
  height: 560px;
}

#js-mainSlider .slick-dots {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 50px;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0 8px;
}
#js-mainSlider .slick-dots li {
  overflow: hidden;
  width: 15px;
  height: 15px;
  border-radius: 50%;
  background: #fff;
  -webkit-transform: scale(0.53);
          transform: scale(0.53);
  -webkit-transition: background 500ms ease, -webkit-transform 500ms ease;
  transition: background 500ms ease, -webkit-transform 500ms ease;
  transition: background 500ms ease, transform 500ms ease;
  transition: background 500ms ease, transform 500ms ease, -webkit-transform 500ms ease;
}
#js-mainSlider .slick-dots li:hover, #js-mainSlider .slick-dots li.slick-active {
  background: #9C0911;
  -webkit-transform: scale(1);
          transform: scale(1);
}
#js-mainSlider .slick-dots li button {
  cursor: pointer;
  width: 100%;
  height: 100%;
  padding: 0;
  border: none;
  background: none;
  color: transparent;
}

.p-plan {
  position: relative;
  z-index: 1;
  width: 950px;
  margin: 50px auto 0;
}
.p-plan h3 {
  width: 134px;
  margin: 0 auto 20px;
}
.p-plan ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.p-plan ul li {
  width: 290px;
}
.p-plan ul li a {
  display: block;
  text-decoration: none !important;
  -webkit-transition: opacity 0.3s ease-in;
  transition: opacity 0.3s ease-in;
}
.p-plan ul li a:hover {
  opacity: 0.7;
}
.p-plan ul li a .img {
  aspect-ratio: 290/180;
}
.p-plan ul li a .img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.p-plan ul li a .st,
.p-plan ul li a .txt {
  width: 240px;
  margin-inline: auto;
}
.p-plan ul li a .st {
  margin-top: 15px;
  font-family: "Noto Sans JP", "メイリオ", "Meiryo", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "游ゴシック体", "Yu Gothic", YuGothic, "MS Ｐゴシック", "MS PGothic", "Lucida Sans Unicode", "Lucida Grande", Verdana, Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0.02em;
  line-height: 1.6;
  font-size: 100%;
}
.p-plan ul li a .txt {
  margin-top: 10px;
  text-align: right;
  font-family: "Noto Sans JP", "メイリオ", "Meiryo", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "游ゴシック体", "Yu Gothic", YuGothic, "MS Ｐゴシック", "MS PGothic", "Lucida Sans Unicode", "Lucida Grande", Verdana, Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0.02em;
  line-height: 1.6;
  font-size: 86%;
}
.p-plan ul li a .txt em {
  font-size: 117%;
}
.p-plan .btn {
  width: 400px;
  margin: 25px auto 0;
}

.p-concept {
  position: relative;
  margin-top: -70px;
  padding-top: 188px;
}
.p-concept:before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  z-index: -1;
  width: 1920px;
  height: 356px;
  margin-left: -960px;
  background: url(../images/home/dec_cons.png) no-repeat left top/contain;
}
.p-concept img {
  -webkit-box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
          box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
}

.p-facilities {
  position: relative;
  padding-block: 173px;
}
.p-facilities:before, .p-facilities:after {
  content: "";
  position: absolute;
  left: 50%;
  z-index: -1;
  width: 1920px;
  height: 173px;
  margin-left: -960px;
  background: url(../images/home/dec_fac.png) no-repeat left top/contain;
}
.p-facilities:before {
  top: 0;
}
.p-facilities:after {
  bottom: 0;
  -webkit-transform: rotateX(180deg);
          transform: rotateX(180deg);
}
.p-facilities > div h3 {
  width: 106px;
  margin: 0 auto 40px;
}
.p-facilities > div:after {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  z-index: -2;
  width: 1920px;
  height: 100%;
  margin-left: -960px;
  background: #FAFAF1;
}
.p-facilities > div .wrp_roo,
.p-facilities > div .wrp_cui {
  position: relative;
}
.p-facilities > div .wrp_roo [class^=info],
.p-facilities > div .wrp_cui [class^=info] {
  position: absolute;
  font-family: "Noto Sans JP", "メイリオ", "Meiryo", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "游ゴシック体", "Yu Gothic", YuGothic, "MS Ｐゴシック", "MS PGothic", "Lucida Sans Unicode", "Lucida Grande", Verdana, Arial, sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0.02em;
  line-height: 1.6;
  padding-left: 15px;
  font-size: 100%;
}
.p-facilities > div .wrp_roo [class^=info]:before,
.p-facilities > div .wrp_cui [class^=info]:before {
  content: "";
  position: absolute;
  left: 0;
  top: 7px;
  width: 8px;
  height: 8px;
  background: #9C0911;
  border-radius: 50%;
}
.p-facilities > div .wrp_roo {
  background: #fff;
  padding: 0 0 70px 0;
  margin-bottom: 50px;
}
.p-facilities > div .wrp_roo .info1 {
  top: 428px;
  left: 165px;
}
.p-facilities > div .wrp_roo .info2 {
  top: 428px;
  left: 495px;
}
.p-facilities > div .wrp_roo .info3 {
  top: 428px;
  left: 825px;
}
.p-facilities > div .wrp_roo .info4 {
  top: 737px;
  left: 165px;
}
.p-facilities > div .wrp_roo .info5 {
  top: 737px;
  left: 495px;
}
.p-facilities > div .wrp_roo .info6 {
  top: 737px;
  left: 825px;
}
.p-facilities > div .wrp_cui .info1 {
  top: 545px;
  left: 258px;
}
.p-facilities > div .wrp_cui .info2 {
  top: 545px;
  left: 762px;
}
.p-facilities .btn {
  width: 400px;
  margin: 40px auto 0;
}

.p-access {
  position: relative;
  width: 950px;
  margin: -50px auto 0;
}
.p-access .btn {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  width: 400px;
  margin: auto;
}

.p-other {
  width: 950px;
  margin: 70px auto 0;
  padding-block: 24px;
  background: #F7F6E7;
}
.p-other ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0 15px;
}
.p-other ul li a {
  display: block;
  -webkit-transition: opacity 0.3s ease-in;
  transition: opacity 0.3s ease-in;
}
.p-other ul li a:hover {
  opacity: 0.7;
}