@charset "UTF-8";
/* 色の変数 */
/* 色の変数 */
:root {
  --text_jp: #333;
  --accent-blue: #007BC7;
  --accent-yellow: #FFF466;
}

/* フォントの変数 */
/* トランジションの変数 */
:root {
  --base-duration: 0.4s;
  --base-easing: cubic-bezier(0.785, 0.135, 0.15, 0.86);
  --base-delay: 1s;
}

.page-facilities .facilities-map-area {
  background: url(../img/facilities/img_facilities_map--pc@2x.png) no-repeat center 62%/cover;
  height: 55.5555vw;
  margin-inline: auto;
  margin-inline: auto;
  max-height: 800px;
  max-width: 1440px;
  position: relative;
  width: 100%;
  z-index: 1;
}
@media screen and (max-width: 767.9px) {
  .page-facilities .facilities-map-area {
    background: url(../img/img_map--sp@2x.png) no-repeat center 62%/contain;
    height: 114vw;
    max-height: 880px;
  }
}
.page-facilities .map-point {
  align-items: center;
  cursor: pointer;
  display: flex;
  height: clamp(0.875rem, -0.1222139673rem + 2.0802377415vw, 1.75rem);
  justify-content: center;
  position: absolute;
  transition: opacity var(--base-duration) var(--base-easing);
  width: clamp(0.875rem, -0.1222139673rem + 2.0802377415vw, 1.75rem);
  z-index: 2;
}
@media screen and (max-width: 767.9px) {
  .page-facilities .map-point {
    height: clamp(0.875rem, 0.0379464286rem + 3.5714285714vw, 1.75rem);
    width: clamp(0.875rem, 0.0379464286rem + 3.5714285714vw, 1.75rem);
  }
}
.page-facilities .map-point:hover, .page-facilities .map-point:focus {
  opacity: 0.8;
}
.page-facilities .map-point--1 {
  background: url(../img/number_round-black--01.svg) no-repeat center center/cover;
  left: 30.58%;
  top: 27.7%;
}
@media screen and (max-width: 767.9px) {
  .page-facilities .map-point--1 {
    left: 30.55%;
    top: 33.7%;
  }
}
.page-facilities .map-point--2 {
  background: url(../img/number_round-black--02.svg) no-repeat center center/cover;
  left: 25.85%;
  top: 19.2%;
}
@media screen and (max-width: 767.9px) {
  .page-facilities .map-point--2 {
    left: 22.1%;
    top: 26.25%;
  }
}
.page-facilities .map-point--3 {
  background: url(../img/number_round-black--03.svg) no-repeat center center/cover;
  left: 29.4%;
  top: 24.2%;
}
@media screen and (max-width: 767.9px) {
  .page-facilities .map-point--3 {
    left: 28.5%;
    top: 30.63%;
  }
}
.page-facilities .map-point--4 {
  background: url(../img/number_round-black--04.svg) no-repeat center center/cover;
  left: 25.95%;
  top: 14.1%;
}
@media screen and (max-width: 767.9px) {
  .page-facilities .map-point--4 {
    left: 22.29%;
    top: 21.85%;
  }
}
.page-facilities .map-point--5 {
  background: url(../img/number_round-black--05.svg) no-repeat center center/cover;
  left: 42.19%;
  top: 5.35%;
}
@media screen and (max-width: 767.9px) {
  .page-facilities .map-point--5 {
    left: 51.4%;
    top: 14.1%;
  }
}
.page-facilities .map-point--6 {
  background: url(../img/number_round-black--06.svg) no-repeat center center/cover;
  left: 32.7%;
  top: 5.8%;
}
@media screen and (max-width: 767.9px) {
  .page-facilities .map-point--6 {
    left: 34.5%;
    top: 14.5%;
  }
}
.page-facilities .map-point--7 {
  background: url(../img/number_round-black--07.svg) no-repeat center center/cover;
  left: 28.3%;
  top: 55.6%;
}
@media screen and (max-width: 767.9px) {
  .page-facilities .map-point--7 {
    left: 26.45%;
    top: 58%;
  }
}
.page-facilities .map-point--8 {
  background: url(../img/number_round-black--08.svg) no-repeat center center/cover;
  left: 41.1%;
  top: 50.7%;
}
@media screen and (max-width: 767.9px) {
  .page-facilities .map-point--8 {
    left: 49.45%;
    top: 53.8%;
  }
}
.page-facilities .map-point--9 {
  background: url(../img/number_round-black--09.svg) no-repeat center center/cover;
  left: 20.55%;
  top: 58.8%;
}
@media screen and (max-width: 767.9px) {
  .page-facilities .map-point--9 {
    left: 12.45%;
    top: 60.9%;
  }
}
.page-facilities .map-point--10 {
  background: url(../img/number_round-black--10.svg) no-repeat center center/cover;
  left: 22.6%;
  top: 25.2%;
}
@media screen and (max-width: 767.9px) {
  .page-facilities .map-point--10 {
    left: 16.3%;
    top: 31.7%;
  }
}
.page-facilities .map-point--11 {
  background: url(../img/number_round-black--11.svg) no-repeat center center/cover;
  left: 14.8%;
  top: 53.8%;
}
@media screen and (max-width: 767.9px) {
  .page-facilities .map-point--11 {
    left: 2.2%;
    top: 56.4%;
  }
}
.page-facilities .map-point--12 {
  background: url(../img/number_round-black--12.svg) no-repeat center center/cover;
  left: 34.68%;
  top: 90.1%;
}
@media screen and (max-width: 767.9px) {
  .page-facilities .map-point--12 {
    left: 37.8%;
    top: 88.2%;
  }
}
.page-facilities .facilities-map-desc {
  font-size: clamp(0.9375rem, 0.0115156018rem + 1.9316493314vw, 1.75rem);
  font-weight: 700;
  left: 55.8%;
  line-height: 1.71;
  position: absolute;
  top: 14%;
}
@media screen and (max-width: 767.9px) {
  .page-facilities .facilities-map-desc {
    font-size: clamp(0.9375rem, 0.1602359694rem + 3.3163265306vw, 1.75rem);
    left: auto;
    right: 5%;
    text-align: right;
  }
}

.page-facilities .facilities-list {
  margin-inline: auto;
  margin-top: 0.625rem;
  max-width: 1376px;
  padding-bottom: 5rem;
  padding-inline: 40px;
  width: 100%;
}
@media screen and (max-width: 767.9px) {
  .page-facilities .facilities-list {
    max-width: 640px;
    padding-inline: 20px;
  }
}
.page-facilities .facilities-list__container {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  margin-top: 3.125rem;
  -moz-column-gap: 3rem;
       column-gap: 3rem;
  row-gap: 4.875rem;
}
@media screen and (max-width: 767.9px) {
  .page-facilities .facilities-list__container {
    grid-template-columns: repeat(auto-fill, minmax(276px, 1fr));
  }
}
.page-facilities .facilities-list__note {
  font-size: 0.875rem;
  font-weight: 400;
  line-height: 1.5;
  text-align: right;
}
.page-facilities .facility-card {
  background: #fff;
}
.page-facilities .facility-card-img {
  aspect-ratio: 5/3;
  border-radius: 5px;
  overflow: hidden;
}
.page-facilities .facility-card-img img {
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.page-facilities .facility-card-body {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  margin-top: 1.5rem;
}
.page-facilities .facility-card-title {
  align-items: center;
  display: flex;
  font-size: clamp(1rem, 0.4301634473rem + 1.1887072808vw, 1.5rem);
  font-weight: 700;
  gap: 0.625rem;
}
.page-facilities .facility-card-num {
  align-items: center;
  display: flex;
  height: clamp(1.25rem, 0.1103268945rem + 2.3774145617vw, 2.25rem);
  width: clamp(1.25rem, 0.1103268945rem + 2.3774145617vw, 2.25rem);
}
.page-facilities .facility-card-num img {
  height: 100%;
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.page-facilities .facility-card-desc {
  font-size: 1rem;
  line-height: 1.7;
}
.page-facilities .facility-card-info {
  background: #eff4f7;
  border-radius: 5px;
  padding: 0.5rem;
}
.page-facilities .facility-card-info dl:not(:first-child) {
  margin-top: -0.1875rem;
}
.page-facilities .facility-card-info dt {
  display: inline;
  font-size: 0.875rem;
  line-height: 1;
  position: relative;
}
.page-facilities .facility-card-info dt::before {
  content: "【";
}
.page-facilities .facility-card-info dt::after {
  content: "】";
}
.page-facilities .facility-card-info dd {
  display: inline;
  font-size: 0.875rem;
  line-height: 1;
}

/* モーダル関連のCSS */
.modal {
  display: flex;
  height: 100%;
  left: 0;
  opacity: 0;
  pointer-events: none;
  position: fixed;
  top: 0;
  transition: opacity var(--base-duration) var(--base-easing);
  width: 100%;
  z-index: 100;
}

.modal.is-active {
  opacity: 1;
  pointer-events: auto;
}

.modal__bg {
  background-color: rgba(217, 217, 217, 0.8);
  cursor: pointer;
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
}

.modal__content {
  align-items: center;
  display: flex;
  justify-content: center;
  margin-inline: auto;
  max-width: 1376px;
  padding-inline: 40px;
  position: relative;
  transform: translateY(-20px);
  transition: transform var(--base-duration) var(--base-easing);
  width: 100%;
}
@media screen and (max-width: 767.9px) {
  .modal__content {
    max-width: 640px;
    padding-inline: 20px;
  }
}

.modal__content-inner {
  background: #fff;
  border-radius: 30px;
  overflow: hidden;
  position: relative;
}

.modal.is-active .modal__content {
  transform: translateY(0);
}

.modal__close {
  background: url(../img/facilities/icon_close.svg) no-repeat center center/cover;
  cursor: pointer;
  height: 54px;
  position: absolute;
  right: 32px;
  top: 32px;
  width: 54px;
  z-index: 100;
}
@media screen and (max-width: 767.9px) {
  .modal__close {
    height: 27px;
    right: 16px;
    top: 16px;
    width: 27px;
  }
}

.modal__body {
  max-height: 90vh;
  overflow-y: auto;
}

.modal__body .facility-card {
  align-items: start;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(400px, 1fr));
  padding: 2rem 6.75rem 2rem 2rem;
  -moz-column-gap: 3.125rem;
       column-gap: 3.125rem;
}
@media screen and (max-width: 767.9px) {
  .modal__body .facility-card {
    flex-direction: column;
    gap: 1.25rem;
    grid-template-columns: 1fr;
    padding: 3.625rem 2.5rem;
  }
}
.modal__body .facility-card-body {
  margin-top: 0;
}
.modal__body .facility-card-title {
  font-size: clamp(1.25rem, 0.3952451709rem + 1.7830609212vw, 2rem);
  margin-top: clamp(0.625rem, -1.9392644874rem + 5.3491827637vw, 2.875rem);
}
@media screen and (max-width: 767.9px) {
  .modal__body .facility-card-title {
    margin-top: 0;
  }
}
.modal__body .facility-card-num {
  height: clamp(1.3125rem, -0.183320951rem + 3.1203566122vw, 2.625rem);
  width: clamp(1.25rem, -0.1745913819rem + 2.9717682021vw, 2.5rem);
}