@charset "UTF-8";
body:has([popover]:popover-open) {
  overflow: hidden;
}

body:not(:has([popover]:popover-open)) {
  overflow: initial;
}

body:has([popover]:popover-open) a,
body:has([popover]:popover-open) .btn-icon,
body:has([popover]:popover-open) .map {
  pointer-events: none;
}

@media not screen and (min-width: 821px) {
  body:has([popover]:popover-open) a,
body:has([popover]:popover-open) .btn-icon,
body:has([popover]:popover-open) .map {
    display: none;
  }
}
.map__item {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  aspect-ratio: 335/280;
}
@media screen and (min-width: 821px) {
  .map__item {
    aspect-ratio: 1296/390;
  }
}

.ttl-icon {
  font-weight: bold;
  font-size: 20px;
  line-height: 2.1;
  letter-spacing: 0.05em;
  display: flex;
  align-items: center;
  gap: 12px;
}
@media screen and (min-width: 821px) {
  .ttl-icon {
    font-size: 30px;
    line-height: 1.4;
    gap: 23px;
  }
}

.ttl-icon__img {
  width: 25px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
}
@media screen and (min-width: 821px) {
  .ttl-icon__img {
    width: 30px;
  }
}

.ttl-icon__img-item {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
  aspect-ratio: 1/1;
}

.btn-icon {
  font-size: 16px;
  line-height: 2.25;
  letter-spacing: 0.05em;
  color: #ce4170;
  text-decoration: underline;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background-color: transparent;
  cursor: pointer;
}
@media screen and (min-width: 821px) {
  .btn-icon {
    font-size: 18px;
    line-height: 2;
    gap: 10px;
  }
}

.btn-icon::before {
  content: "";
  background: url(../img/access/icon-magnifying-glass.svg) no-repeat center/contain;
  width: 18px;
  height: 18px;
}

.txt-lead {
  font-size: 18px;
  line-height: 1.8888888889;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 821px) {
  .txt-lead {
    font-size: 22px;
    line-height: 1.9090909091;
    letter-spacing: 0.05em;
  }
}

.txt-box {
  font-size: 18px;
  line-height: 1.8888888889;
  letter-spacing: 0.1em;
  color: #ce4170;
  border: 1px solid #ce4170;
  padding: 0.5em 1em;
  background-color: #fff;
}
@media screen and (min-width: 821px) {
  .txt-box {
    font-size: 22px;
    line-height: 1.9090909091;
    letter-spacing: 0.05em;
  }
}

.ttl-dot {
  font-size: 18px;
  line-height: 2.3333333333;
  letter-spacing: 0.05em;
  color: #ce4170;
  display: flex;
  align-items: center;
  gap: 0.5em;
}
@media screen and (min-width: 821px) {
  .ttl-dot {
    font-size: 22px;
    line-height: 1.9090909091;
  }
}

.ttl-dot::before {
  content: "●";
  font-size: 10px;
}
@media screen and (min-width: 821px) {
  .ttl-dot::before {
    font-size: 12px;
  }
}

.modal::-webkit-backdrop {
  background-color: rgba(0, 0, 0, 0.5);
}

.modal::backdrop {
  background-color: rgba(0, 0, 0, 0.5);
}

.modal__img {
  display: flex;
  justify-content: center;
}

.modal__img-item {
  width: 100%;
  height: auto;
}

@media screen and (orientation: landscape) and (max-height: 845px) {
  .modal__img-item {
    width: 100%;
  }
}
.modal__btn-close-icon-container {
  position: fixed;
  top: 159px;
  width: 100%;
  max-width: 900px;
  margin-inline: auto;
}
@media screen and (min-width: 821px) {
  .modal__btn-close-icon-container {
    top: 40px;
  }
}

.modal__btn-close {
  display: flex;
  align-items: center;
  gap: 7px;
  margin-left: auto;
  background-color: transparent;
  cursor: pointer;
}
@media screen and (min-width: 821px) {
  .modal__btn-close {
    gap: 14px;
  }
}

.modal__btn-close-txt {
  flex-shrink: 0;
  font-size: 16px;
  line-height: 2.25;
  letter-spacing: 0.05em;
  color: #ffffff;
  text-decoration: underline;
  display: inline-block;
  padding-right: 1em;
}
@media screen and (min-width: 821px) {
  .modal__btn-close-txt {
    font-size: 18px;
    line-height: 2;
    padding-right: initial;
  }
}

.box {
  background-color: #fff;
  border-radius: 10px;
  padding: 10px 18px 20px;
}
@media screen and (min-width: 821px) {
  .box {
    padding: 30px 28px 33px;
  }
}

.box__ttl {
  margin-bottom: 17px;
}
@media screen and (min-width: 821px) {
  .box__ttl {
    justify-content: center;
  }
}

.box__lead {
  margin-bottom: 10px;
}
@media screen and (min-width: 821px) {
  .box__lead {
    text-align: center;
  }
}

.box__txt-container {
  display: flex;
  flex-direction: column;
  gap: 1.75em;
}

.box__txt {
  font-size: 16px;
  line-height: 2;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 821px) {
  .box__txt {
    font-size: 18px;
    line-height: 2;
    letter-spacing: 0.05em;
    text-align: center;
  }
}

.box__map-modal {
  width: 100%;
}
@media screen and (min-width: 821px) {
  .box__map-modal {
    margin-inline: auto;
    max-width: 1100px;
  }
}

.box__map-container {
  margin-bottom: 30px;
  margin-inline: auto;
  text-align: right;
}
@media screen and (min-width: 821px) {
  .box__map-container {
    max-width: 700px;
    margin-bottom: 61px;
  }
}

.box__map-item {
  width: 100%;
  height: auto;
}

.box__map-modal {
  margin-top: 195px;
  max-width: 100%;
  width: 900px;
}
@media screen and (min-width: 821px) {
  .box__map-modal {
    margin-top: 80px;
  }
}

.box-container {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
@media screen and (min-width: 821px) {
  .box-container {
    gap: 28px;
  }
}

.box2 {
  background-color: #fbf7f6;
  border-radius: 10px;
  padding: 10px 20px 30px;
}
@media screen and (min-width: 821px) {
  .box2 {
    padding: 24px 30px 30px;
  }
}

.box2__ttl {
  font-weight: bold;
  font-size: 18px;
  line-height: 2.3333333333;
  letter-spacing: 0.05em;
  margin-bottom: 10px;
}
@media screen and (min-width: 821px) {
  .box2__ttl {
    font-size: 22px;
    line-height: 1.9090909091;
    margin-bottom: initial;
  }
}

.box2__lead {
  margin-bottom: 15px;
}
@media screen and (min-width: 821px) {
  .box2__lead {
    margin-bottom: 22px;
  }
}

.box2__txt-box {
  margin-bottom: 15px;
}
@media screen and (min-width: 821px) {
  .box2__txt-box {
    margin-bottom: 10px;
  }
}

.box2__img-item {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  aspect-ratio: 255/130;
}
@media screen and (min-width: 821px) {
  .box2__img-item {
    aspect-ratio: 579/290;
  }
}

.box2__note {
  font-size: 14px;
  line-height: 1.7142857143;
  letter-spacing: 0.1em;
  margin-bottom: 13px;
}
@media screen and (min-width: 821px) {
  .box2__note {
    font-size: 18px;
    line-height: 2;
    letter-spacing: 0.05em;
  }
}

.box2__list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
@media screen and (min-width: 821px) {
  .box2__list {
    flex-direction: initial;
    gap: 30px;
  }
}

.box2__item-ttl {
  margin-bottom: 5px;
}
@media screen and (min-width: 821px) {
  .box2__item-ttl {
    margin-bottom: 10px;
  }
}

.access {
  background: #faede7;
  padding-bottom: 70px;
  padding-top: 50px;
}
@media screen and (min-width: 821px) {
  .access {
    background: #faede7;
    padding-top: 70px;
    padding-bottom: 57px;
    margin-top: 0;
  }
}

.access__map {
  margin-bottom: 12px;
}
@media screen and (min-width: 821px) {
  .access__map {
    margin-bottom: 15px;
  }
}

.access__txt {
  font-size: 18px;
  line-height: 2.3333333333;
  letter-spacing: 0.05em;
  color: #ce4170;
  margin-bottom: 14px;
}
@media screen and (min-width: 821px) {
  .access__txt {
    font-size: 22px;
    line-height: 1.9090909091;
    margin-bottom: 16px;
  }
}

.modal-container {
  overflow: scroll;
}
/*# sourceMappingURL=access.css.map */