@charset "UTF-8";
/* ===================================================================
CSS information

file name  : homepage.css
author     : Abilive
style info : トップページ
=================================================================== */
/* ===================================================================
CSS information

file name  : _settings.scss
author     : Abilive
style info : 汎用設定
=================================================================== */
@keyframes FadeIn {
  0% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    opacity: 1;
  }
}
@keyframes FadeUp {
  0% {
    transform: translateY(-200%);
  }
  50% {
    transform: translateY(0);
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes zoomUp {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.25);
  }
}
.p-home-fv__search {
  background-color: rgba(255, 255, 255, 0.85);
  width: calc(1300 / 1440 * 100%);
  max-width: 78.57rem;
  margin-right: auto;
  margin-left: auto;
  padding: 0.71rem 0;
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-home-fv__search {
    padding: 1.42rem 0;
  }
}
@media only screen and (max-width: 767px) {
  .p-home-fv__search {
    padding: 2rem 0 2.5rem;
    width: calc(388 / 428 * 100%);
  }
}
.p-home-fv__search .inner {
  width: calc(1050 / 1100 * 100%);
  margin-right: auto;
  margin-left: auto;
  display: flex;
  flex-wrap: wrap;
}
@media only screen and (max-width: 767px) {
  .p-home-fv__search .inner {
    flex-direction: column;
    align-items: center;
  }
}
.p-home-fv__search__best {
  width: calc(150 / 1050 * 100%);
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-home-fv__search__best {
    width: calc(150 / 1050 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .p-home-fv__search__best {
    width: calc(180 / 355 * 100%);
  }
}
.p-home-fv__search__best__btn {
  display: block;
  width: 100%;
}
.mouse .p-home-fv__search__best__btn {
  -moz-transition: opacity 0.3s ease-in;
  -o-transition: opacity 0.3s ease-in;
  -webkit-transition: opacity 0.3s ease-in;
  transition: opacity 0.3s ease-in;
}
.mouse .p-home-fv__search__best__btn:hover, .touch .p-home-fv__search__best__btn.touchstart {
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=70);
  opacity: 0.7;
}
.touch .p-home-fv__search__best__btn {
  -webkit-tap-highlight-color: transparent;
}
.touch .p-home-fv__search__best__btn.touchend {
  -moz-transition-delay: 200ms;
  -o-transition-delay: 200ms;
  -webkit-transition-delay: 200ms;
  transition-delay: 200ms;
}
.p-home-fv__search__form {
  width: calc(670 / 1050 * 100%);
  margin-left: calc(20 / 1050 * 100%);
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-home-fv__search__form {
    width: calc(880 / 1050 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .p-home-fv__search__form {
    width: 100%;
    margin-top: 2rem;
    margin-left: 0;
    min-height: 17.85rem;
  }
}
.p-home-fv__search__form .search-widget-search-container-bf1818 {
  width: 100% !important;
  padding: 0 !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  display: flex !important;
  align-items: flex-end;
  background-color: transparent !important;
}
@media only screen and (min-width: 768px) {
  .p-home-fv__search__form .search-widget-search-container-bf1818 {
    max-width: 47.14rem;
  }
}
@media only screen and (max-width: 767px) {
  .p-home-fv__search__form .search-widget-search-container-bf1818 {
    flex-direction: column;
    max-width: 25rem;
  }
}
.p-home-fv__search__form .search-widget-search-container-bf1818 input, .p-home-fv__search__form .search-widget-search-container-bf1818 select, .p-home-fv__search__form .search-widget-search-container-bf1818 button {
  width: 100% !important;
}
@media only screen and (max-width: 767px) {
  .p-home-fv__search__form .search-widget-search-container-bf1818 input, .p-home-fv__search__form .search-widget-search-container-bf1818 select, .p-home-fv__search__form .search-widget-search-container-bf1818 button {
    font-size: 16px;
  }
}
.p-home-fv__search__form .search-widget-search-container-bf1818 .input-container-input-container-da40af {
  margin: 0;
  width: 100% !important;
}
.p-home-fv__search__form .search-widget-search-container-bf1818 .input-container-input-container-da40af .input-container-title-db81ec {
  font-family: "Shippori Mincho B1", serif;
  font-weight: 500;
  font-style: normal;
  line-height: 1.4;
  letter-spacing: 0;
  margin-bottom: 0.35rem;
}
@media only screen and (min-width: 768px) {
  .p-home-fv__search__form .search-widget-search-container-bf1818 .input-container-input-container-da40af .input-container-title-db81ec {
    font-size: 0.86rem;
  }
}
@media only screen and (max-width: 767px) {
  .p-home-fv__search__form .search-widget-search-container-bf1818 .input-container-input-container-da40af .input-container-title-db81ec {
    font-size: 1rem;
  }
}
.p-home-fv__search__form .search-widget-search-container-bf1818 .input-container-input-container-da40af .input-container-width-sm-88e98c {
  margin: 0 !important;
}
.p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-input-34bba0, .p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-select-75fb48 {
  font-family: "Shippori Mincho B1", serif !important;
  font-weight: 500 !important;
  font-style: normal;
  min-height: 3.57rem;
  border-radius: 0 !important;
}
@media only screen and (min-width: 768px) {
  .p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-input-34bba0, .p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-select-75fb48 {
    font-size: 100% !important;
  }
}
.p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-input-wrapper-eaf5bf {
  display: flex !important;
  flex-wrap: wrap;
}
@media only screen and (min-width: 768px) {
  .p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-input-wrapper-eaf5bf {
    width: calc(565 / 660 * 100%) !important;
  }
}
@media only screen and (max-width: 767px) {
  .p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-input-wrapper-eaf5bf {
    width: 100% !important;
  }
}
@media only screen and (min-width: 768px) {
  .p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-input-wrapper-eaf5bf > .input-container-input-container-da40af {
    width: calc(80 / 565 * 100%) !important;
    margin-left: calc(10 / 565 * 100%) !important;
  }
}
@media only screen and (max-width: 767px) {
  .p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-input-wrapper-eaf5bf > .input-container-input-container-da40af {
    margin-top: 1.25rem;
    width: 28% !important;
    margin-left: 2%;
  }
  html:lang(en) .p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-input-wrapper-eaf5bf > .input-container-input-container-da40af {
    margin-left: 0;
    width: 100% !important;
  }
}
.p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-calendar-9fdfc9 {
  width: 100% !important;
  background: url(../images/common/ic_calendar.svg) no-repeat 95% 50%, #fff !important;
}
.p-home-fv__search__form .search-widget-search-container-bf1818 .dropdown-selector-container-ef1ce2 .dropdown-selector-input-6d2b0e,
.p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-select-75fb48 {
  padding: 0 1.5rem 0 0.5rem !important;
  background: url(../images/common/ic_down.svg) no-repeat 100% 50%, #fff !important;
}
@media only screen and (min-width: 768px) {
  .p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-two-picker-wrapper-4ca735 {
    width: calc(235 / 565 * 100%) !important;
  }
}
@media only screen and (max-width: 767px) {
  .p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-two-picker-wrapper-4ca735 {
    width: 100% !important;
  }
}
.p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-two-picker-wrapper-4ca735 + .search-widget-two-picker-wrapper-4ca735 {
  width: calc(230 / 565 * 100%) !important;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
}
@media only screen and (min-width: 768px) {
  .p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-two-picker-wrapper-4ca735 + .search-widget-two-picker-wrapper-4ca735 {
    margin-left: calc(10 / 565 * 100%) !important;
  }
}
@media only screen and (max-width: 767px) {
  .p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-two-picker-wrapper-4ca735 + .search-widget-two-picker-wrapper-4ca735 {
    width: 70% !important;
    margin-top: 1.25rem;
  }
  html:lang(en) .p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-two-picker-wrapper-4ca735 + .search-widget-two-picker-wrapper-4ca735 {
    width: 100% !important;
  }
}
.p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-two-picker-wrapper-4ca735 + .search-widget-two-picker-wrapper-4ca735 .input-container-input-container-da40af {
  width: calc(110 / 230 * 100%) !important;
}
.p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-two-picker-wrapper-4ca735 + .search-widget-two-picker-wrapper-4ca735 .input-container-input-container-da40af:not(.input-container-width-sm-88e98c) {
  margin-left: calc(10 / 230 * 100%);
}
.p-home-fv__search__form .search-widget-search-container-bf1818 .dropdown-selector-container-ef1ce2 .dropdown-selector-input-6d2b0e {
  min-width: 100% !important;
  height: 100% !important;
  width: 100% !important;
}
.p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-button-wrapper-d2b715 {
  width: calc(85 / 660 * 100%) !important;
}
@media only screen and (min-width: 768px) {
  .p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-button-wrapper-d2b715 {
    margin-left: calc(10 / 660 * 100%) !important;
  }
}
@media only screen and (max-width: 767px) {
  .p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-button-wrapper-d2b715 {
    width: 100% !important;
    margin-top: 1.25rem;
  }
}
.p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-button-wrapper-d2b715 button {
  margin-bottom: 0 !important;
  font-family: "Shippori Mincho B1", serif !important;
  font-weight: 500 !important;
  font-style: normal;
  min-height: 3.57rem;
  border-radius: 0 !important;
  padding: 0.25rem !important;
  background-color: var(--color-main) !important;
}
.mouse .p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-button-wrapper-d2b715 button {
  -moz-transition: opacity 0.3s ease-in;
  -o-transition: opacity 0.3s ease-in;
  -webkit-transition: opacity 0.3s ease-in;
  transition: opacity 0.3s ease-in;
}
.mouse .p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-button-wrapper-d2b715 button:hover, .touch .p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-button-wrapper-d2b715 button.touchstart {
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=70);
  opacity: 0.7;
}
.touch .p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-button-wrapper-d2b715 button {
  -webkit-tap-highlight-color: transparent;
}
.touch .p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-button-wrapper-d2b715 button.touchend {
  -moz-transition-delay: 200ms;
  -o-transition-delay: 200ms;
  -webkit-transition-delay: 200ms;
  transition-delay: 200ms;
}
@media only screen and (min-width: 768px) {
  .p-home-fv__search__form .search-widget-search-container-bf1818 .search-widget-button-wrapper-d2b715 button {
    font-size: 100% !important;
  }
}
.p-home-fv__search__about {
  width: 100%;
  text-align: center;
}
@media only screen and (min-width: 1025px) {
  .p-home-fv__search__about {
    padding: 0.35rem 0 0.71rem;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-home-fv__search__about {
    margin-top: 1rem;
  }
}
@media only screen and (max-width: 767px) {
  .p-home-fv__search__about {
    margin-top: 2rem;
  }
}
.p-home-fv__search__btn {
  width: calc(190 / 1050 * 100%);
  margin-left: calc(20 / 1050 * 100%);
  display: flex;
}
@media only screen and (min-width: 1025px) {
  .p-home-fv__search__btn {
    flex-direction: column;
    justify-content: flex-end;
    margin-bottom: 1.42rem;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-home-fv__search__btn {
    justify-content: center;
    margin-top: 0.71rem;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-home-fv__search__btn {
    width: 100%;
  }
}
@media only screen and (max-width: 767px) {
  .p-home-fv__search__btn {
    width: 100%;
    flex-direction: column;
    margin-left: auto;
    margin-right: auto;
    margin-top: 1rem;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-home-fv__search__btn .c-btn:nth-child(n+2) {
    margin-left: 1.42rem;
  }
}
@media only screen and (max-width: 767px) {
  .p-home-fv__search__btn .c-btn {
    max-width: 16rem;
    margin-inline: auto;
  }
  html:lang(en) .p-home-fv__search__btn .c-btn {
    max-width: none;
  }
  .p-home-fv__search__btn .c-btn:nth-child(n+2) {
    margin-top: 1rem;
  }
}
@media only screen and (min-width: 768px) {
  .p-home-fv__search__btn .c-btn .c-btn__link__text {
    padding-right: 0;
  }
}
.p-home-fv__intro {
  margin-top: calc(200 / 1400 * 100%);
  position: relative;
  width: 100%;
}
@media only screen and (max-width: 767px) {
  .p-home-fv__intro {
    margin-top: 6rem;
  }
}
.p-home-fv__intro__text {
  position: relative;
  z-index: 2;
}
@media only screen and (max-width: 767px) {
  .p-home-fv__intro__text .c-text-set__text {
    line-height: 3;
    letter-spacing: .1em;
  }
  html:lang(en) .p-home-fv__intro__text .c-text-set__text {
    letter-spacing: 0;
    line-height: 2.5;
  }
}
.p-home-fv__intro__deer {
  margin: 4.28rem auto 0;
  width: calc(225 / 1440 * 100%);
  width: 16.07rem;
}
.p-home-fv__intro__leaf {
  position: absolute;
}
.p-home-fv__intro__leaf--leaf2 {
  top: 25%;
  right: 0;
  width: calc(409 / 1440 * 100%);
}
@media only screen and (max-width: 767px) {
  .p-home-fv__intro__leaf--leaf2 {
    top: 60%;
    width: 35%;
  }
}
.p-home-fv__intro__leaf--leaf1 {
  top: 32%;
  left: 0;
  width: calc(388 / 1440 * 100%);
}
@media only screen and (max-width: 767px) {
  .p-home-fv__intro__leaf--leaf1 {
    width: 35%;
    top: 58%;
  }
}

.l-modal__tokuten__container {
  background-color: var(--color-bg-1);
  background-image: url(../images/common/bg-noise-1.webp);
  background-repeat: repeat;
  background-position: top;
  background-size: auto;
  overflow-y: scroll;
  height: 100%;
  padding: 4.28rem 0;
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .l-modal__tokuten__container {
    padding: 7.14rem 0;
  }
}
@media only screen and (max-width: 767px) {
  .l-modal__tokuten__container {
    padding: 4rem 0;
  }
}
.l-modal__tokuten .c-modal-btn {
  position: absolute;
  left: 4.64rem;
  top: 3.21rem;
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .l-modal__tokuten .c-modal-btn {
    left: 2.14rem;
    top: 2.14rem;
  }
}
@media only screen and (max-width: 767px) {
  .l-modal__tokuten .c-modal-btn {
    left: 1.5rem;
    top: 1.5rem;
  }
}
.l-modal__tokuten .c-modal-btn__ic > span {
  background-color: transparent !important;
}
.l-modal__tokuten .c-modal-btn__ic > span::before, .l-modal__tokuten .c-modal-btn__ic > span::after {
  transition: transform .2s ease 0.2s, top .2s ease;
}
.l-modal__tokuten .c-modal-btn__ic > span::before {
  transform-origin: center center;
  transform: rotate(40deg);
  top: 50%;
}
.l-modal__tokuten .c-modal-btn__ic > span::after {
  transform-origin: center center;
  transform: rotate(-40deg);
  top: 50%;
  width: 100%;
  max-width: 100%;
}
.l-modal__tokuten__content > .inner {
  margin-right: auto;
  margin-left: auto;
  max-width: 64.28rem;
  width: calc(1200 / 1440 * 100%);
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .l-modal__tokuten__content > .inner {
    width: calc(1200 / 1440 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .l-modal__tokuten__content > .inner {
    width: calc(308 / 428 * 100%);
  }
}
.l-modal__tokuten__content__title .img {
  width: 15.42rem;
  margin-inline: auto;
}
.l-modal__tokuten__content__title .read {
  margin-top: 2.5rem;
}
@media only screen and (max-width: 767px) {
  .l-modal__tokuten__content__title .read {
    margin-top: 1rem;
  }
}
.l-modal__tokuten__content__list {
  margin-top: 2.85rem;
  display: flex;
  flex-wrap: wrap;
}
@media only screen and (max-width: 767px) {
  .l-modal__tokuten__content__list {
    flex-direction: column;
  }
}
.l-modal__tokuten__content__list__li {
  width: calc(272 / 900 * 100%);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  position: relative;
}
@media only screen and (min-width: 768px) {
  .l-modal__tokuten__content__list__li:not(:nth-child(3n+1)) {
    margin-left: calc(42 / 900 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .l-modal__tokuten__content__list__li {
    width: 100%;
  }
  .l-modal__tokuten__content__list__li:nth-child(n+2) {
    margin-top: 2.5rem;
  }
}
.l-modal__tokuten__content__list__li .label {
  position: absolute;
  left: -1.43rem;
  top: -1.08rem;
  z-index: 2;
  width: 5rem;
  height: 5.5rem;
  text-align: center;
  background: url(../images/home/bg_tokuten_title.svg) no-repeat center/99%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  font-weight: normal;
  letter-spacing: 0;
}
.l-modal__tokuten__content__list__li .label .t {
  line-height: 1.4;
  padding-top: .15rem;
  font-size: 0.93rem;
}
.l-modal__tokuten__content__list__li .label .num {
  line-height: 1;
  font-family: "Aboreto", system-ui;
  font-weight: 400;
  font-style: normal;
}
@media only screen and (min-width: 768px) {
  .l-modal__tokuten__content__list__li .label .num {
    font-size: 1.71rem;
  }
}
@media only screen and (max-width: 767px) {
  .l-modal__tokuten__content__list__li .label .num {
    font-size: 1.57rem;
  }
}
.l-modal__tokuten__content__list__li .img {
  order: 1;
  width: 100%;
}
.l-modal__tokuten__content__list__li .st {
  margin-top: 1.07rem;
  order: 2;
  width: 100%;
}
.l-modal__tokuten__content__list__li .st .c-title-sub {
  width: 100%;
  display: block;
  letter-spacing: -.03em;
}
.l-modal__tokuten__content__list__li .txt {
  margin-top: 0.35rem;
  order: 3;
  width: 100%;
}

.p-ryokan-map {
  overflow: hidden;
  position: relative;
  z-index: 2;
}
.p-ryokan-map__map {
  position: relative;
  z-index: 1;
  padding-top: 3.57rem;
  margin-right: auto;
  margin-left: auto;
}
html:lang(ko) .p-ryokan-map__map {
  padding-top: 5.71rem;
}
@media only screen and (min-width: 768px) {
  .p-ryokan-map__map {
    width: 95%;
    aspect-ratio: 1200 / 650;
    max-width: 85.71rem;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-ryokan-map__map {
    padding-top: 4.28rem;
  }
  html:lang(ko) .p-ryokan-map__map {
    padding-top: 7.14rem;
  }
}
@media only screen and (max-width: 767px) {
  .p-ryokan-map__map {
    width: 100%;
    padding-top: 4rem;
    overflow-x: auto;
  }
}
@media only screen and (min-width: 768px) {
  .p-ryokan-map__map__img {
    object-fit: cover;
  }
}
@media only screen and (max-width: 767px) {
  .p-ryokan-map__map__img {
    width: 1000px;
  }
}
.p-ryokan-map__list-wrp {
  position: absolute;
  z-index: 5;
  left: 0;
  right: 0;
  bottom: 0;
  aspect-ratio: 1200 / 650;
  object-fit: cover;
  width: 95%;
  max-width: 85.71rem;
  margin-right: auto;
  margin-left: auto;
}
@media only screen and (min-width: 768px) and (max-width: 896px) {
  .p-ryokan-map__list-wrp {
    width: 100%;
  }
}
@media only screen and (max-width: 767px) {
  .p-ryokan-map__list-wrp {
    min-width: 1000px;
  }
}
.p-ryokan-map__list {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
}
.p-ryokan-map__list__link {
  background-color: #fff;
  text-decoration: none;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-direction: column;
  height: fit-content;
  box-sizing: border-box;
  padding: 1.42rem 0 1.42rem;
  position: relative;
  width: 2.5em;
}
@media only screen and (min-width: 1025px) {
  .p-ryokan-map__list__link {
    font-size: 1.14rem;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-ryokan-map__list__link {
    font-size: 1.07rem;
  }
}
@media only screen and (max-width: 767px) {
  .p-ryokan-map__list__link {
    font-size: 1.07rem;
  }
}
html:lang(en) .p-ryokan-map__list__link {
  padding: 1.28rem 1.07rem 1.07rem;
  flex-direction: row;
  align-items: center;
  width: fit-content;
}
.p-ryokan-map__list__link::before {
  content: "";
  width: 100%;
  height: 5px;
  position: absolute;
  left: 0;
  top: 0;
  background-color: var(--color-cv);
}
.p-ryokan-map__list__link .t {
  letter-spacing: 0;
  line-height: 1;
  color: var(--color-text-main);
  transition: opacity .3s ease;
}
html:not([lang=en]) .p-ryokan-map__list__link .t {
  writing-mode: tb-rl;
  writing-mode: vertical-rl;
  -moz-writing-mode: vertical-rl;
  -o-writing-mode: vertical-rl;
  -webkit-writing-mode: vertical-rl;
  -webkit-text-orientation: upright;
  -moz-text-orientation: upright;
  -ms-text-orientation: upright;
  text-orientation: upright;
  text-align: left;
  display: inline-block;
  font-feature-settings: normal;
}
.p-ryokan-map__list__link .o-arrow {
  transition: opacity .3s ease;
  margin-top: 1.78rem;
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-ryokan-map__list__link .o-arrow {
    margin-top: 1.42rem;
  }
}
html:lang(en) .p-ryokan-map__list__link .o-arrow {
  margin-left: .5rem;
  margin-top: 0;
}
.mouse .p-ryokan-map__list__link:hover .t, .mouse .p-ryokan-map__list__link:hover .o-arrow, .touch .p-ryokan-map__list__link.touchstart .t, .touch .p-ryokan-map__list__link.touchstart .o-arrow {
  opacity: .7;
}
.touch .p-ryokan-map__list__link {
  -webkit-tap-highlight-color: transparent;
}
.touch .p-ryokan-map__list__link.touchend {
  -moz-transition-delay: 200ms;
  -o-transition-delay: 200ms;
  -webkit-transition-delay: 200ms;
  transition-delay: 200ms;
}
.p-ryokan-map__list__link--light::before {
  background-color: var(--color-sub-2);
}
.p-ryokan-map__list__li {
  position: absolute;
}
.p-ryokan-map__list__li::before, .p-ryokan-map__list__li::after {
  content: "";
  position: absolute;
  bottom: -2.5rem;
  left: 0;
  right: 0;
  margin: 0 auto;
  background-color: #fff;
}
@media only screen and (max-width: 1024px) {
  .p-ryokan-map__list__li::before, .p-ryokan-map__list__li::after {
    bottom: -1.79rem;
  }
}
.p-ryokan-map__list__li::before {
  width: 1px;
  height: 2.5rem;
}
@media only screen and (max-width: 1024px) {
  .p-ryokan-map__list__li::before {
    height: 1.78rem;
  }
}
.p-ryokan-map__list__li::after {
  width: 0.42rem;
  height: 0.42rem;
  border-radius: 100px;
}
.p-ryokan-map__list__li--tenpyo {
  top: calc(70 / 1200 * 100%);
  left: calc(150 / 1200 * 100%);
}
html:lang(en) .p-ryokan-map__list__li--tenpyo {
  top: calc(300 / 1200 * 100%);
  left: calc(60 / 1200 * 100%);
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  html:lang(en) .p-ryokan-map__list__li--tenpyo {
    left: calc(30 / 1200 * 100%);
  }
}
html:lang(zh-CN) .p-ryokan-map__list__li--tenpyo {
  top: calc(170 / 1200 * 100%);
}
html:lang(zh-Hant) .p-ryokan-map__list__li--tenpyo {
  top: calc(170 / 1200 * 100%);
}
html:lang(zh-TW) .p-ryokan-map__list__li--tenpyo {
  top: calc(170 / 1200 * 100%);
}
.p-ryokan-map__list__li--manyo {
  top: calc(210 / 1200 * 100%);
  left: calc(265 / 1200 * 100%);
}
html:lang(en) .p-ryokan-map__list__li--manyo {
  top: calc(450 / 1200 * 100%);
  left: calc(200 / 1200 * 100%);
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  html:lang(en) .p-ryokan-map__list__li--manyo {
    top: calc(480 / 1200 * 100%);
  }
}
html:lang(zh-CN) .p-ryokan-map__list__li--manyo {
  top: calc(310 / 1200 * 100%);
}
html:lang(zh-Hant) .p-ryokan-map__list__li--manyo {
  top: calc(310 / 1200 * 100%);
}
html:lang(zh-TW) .p-ryokan-map__list__li--manyo {
  top: calc(310 / 1200 * 100%);
}
html:lang(ko) .p-ryokan-map__list__li--manyo {
  top: calc(230 / 1200 * 100%);
}
.p-ryokan-map__list__li--kaze {
  top: calc(-40 / 1200 * 100%);
  left: calc(400 / 1200 * 100%);
}
html:lang(en) .p-ryokan-map__list__li--kaze {
  top: calc(90 / 1200 * 100%);
  left: calc(350 / 1200 * 100%);
}
html:lang(zh-CN) .p-ryokan-map__list__li--kaze {
  top: 0;
}
html:lang(zh-Hant) .p-ryokan-map__list__li--kaze {
  top: 0;
}
html:lang(zh-TW) .p-ryokan-map__list__li--kaze {
  top: 0;
}
html:lang(ko) .p-ryokan-map__list__li--kaze {
  top: calc(-100 / 1200 * 100%);
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  html:lang(ko) .p-ryokan-map__list__li--kaze {
    top: calc(-130 / 1200 * 100%);
  }
}
.p-ryokan-map__list__li--bath {
  top: calc(270 / 1200 * 100%);
  left: calc(490 / 1200 * 100%);
}
html:lang(en) .p-ryokan-map__list__li--bath {
  top: calc(400 / 1200 * 100%);
  left: calc(460 / 1200 * 100%);
}
html:lang(zh-CN) .p-ryokan-map__list__li--bath {
  top: calc(300 / 1200 * 100%);
}
html:lang(zh-Hant) .p-ryokan-map__list__li--bath {
  top: calc(300 / 1200 * 100%);
}
html:lang(zh-TW) .p-ryokan-map__list__li--bath {
  top: calc(300 / 1200 * 100%);
}
html:lang(ko) .p-ryokan-map__list__li--bath {
  top: calc(320 / 1200 * 100%);
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-ryokan-map__list__li--bath {
    top: calc(250 / 1200 * 100%);
  }
  html:lang(ko) .p-ryokan-map__list__li--bath {
    top: calc(320 / 1200 * 100%);
    left: calc(440 / 1200 * 100%);
  }
  html:lang(zh-CN) .p-ryokan-map__list__li--bath {
    top: calc(290 / 1200 * 100%);
  }
  html:lang(zh-Hant) .p-ryokan-map__list__li--bath {
    top: calc(290 / 1200 * 100%);
  }
  html:lang(zh-TW) .p-ryokan-map__list__li--bath {
    top: calc(290 / 1200 * 100%);
  }
}
.p-ryokan-map__list__li--dining {
  top: calc(75 / 1200 * 100%);
  right: calc(565 / 1200 * 100%);
}
html:lang(en) .p-ryokan-map__list__li--dining {
  top: calc(220 / 1200 * 100%);
  right: calc(545 / 1200 * 100%);
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  html:lang(en) .p-ryokan-map__list__li--dining {
    top: calc(250 / 1200 * 100%);
    right: calc(500 / 1200 * 100%);
  }
}
html:lang(zh-CN) .p-ryokan-map__list__li--dining {
  top: calc(175 / 1200 * 100%);
}
html:lang(zh-Hant) .p-ryokan-map__list__li--dining {
  top: calc(175 / 1200 * 100%);
}
html:lang(zh-TW) .p-ryokan-map__list__li--dining {
  top: calc(175 / 1200 * 100%);
}
html:lang(ko) .p-ryokan-map__list__li--dining {
  top: calc(175 / 1200 * 100%);
}
.p-ryokan-map__list__li--tsuki {
  top: calc(380 / 1200 * 100%);
  right: calc(475 / 1200 * 100%);
}
html:lang(en) .p-ryokan-map__list__li--tsuki {
  top: calc(550 / 1200 * 100%);
  right: calc(450 / 1200 * 100%);
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-ryokan-map__list__li--tsuki {
    top: calc(360 / 1200 * 100%);
  }
  html:lang(en) .p-ryokan-map__list__li--tsuki {
    top: calc(600 / 1200 * 100%);
    right: calc(400 / 1200 * 100%);
  }
}
.p-ryokan-map__list__li--lobby {
  top: calc(200 / 1200 * 100%);
  right: calc(335 / 1200 * 100%);
}
html:lang(en) .p-ryokan-map__list__li--lobby {
  top: calc(420 / 1200 * 100%);
  right: calc(250 / 1200 * 100%);
}
html:lang(zh-CN) .p-ryokan-map__list__li--lobby {
  top: calc(250 / 1200 * 100%);
}
html:lang(zh-Hant) .p-ryokan-map__list__li--lobby {
  top: calc(250 / 1200 * 100%);
}
html:lang(zh-TW) .p-ryokan-map__list__li--lobby {
  top: calc(250 / 1200 * 100%);
}
html:lang(ko) .p-ryokan-map__list__li--lobby {
  top: calc(250 / 1200 * 100%);
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-ryokan-map__list__li--lobby {
    top: calc(170 / 1200 * 100%);
  }
  html:lang(en) .p-ryokan-map__list__li--lobby {
    top: calc(400 / 1200 * 100%);
    right: calc(230 / 1200 * 100%);
  }
  html:lang(zh-CN) .p-ryokan-map__list__li--lobby {
    top: calc(220 / 1200 * 100%);
  }
  html:lang(zh-Hant) .p-ryokan-map__list__li--lobby {
    top: calc(220 / 1200 * 100%);
  }
  html:lang(zh-TW) .p-ryokan-map__list__li--lobby {
    top: calc(220 / 1200 * 100%);
  }
  html:lang(ko) .p-ryokan-map__list__li--lobby {
    top: calc(220 / 1200 * 100%);
  }
}

.p-ryokan-map {
  background-color: #A6C7C6;
  background-position: top;
  background-repeat: no-repeat;
  background-size: cover;
  padding: calc(110 / 1440 * 100%) 0;
}
@media only screen and (max-width: 767px) {
  .p-ryokan-map {
    padding: 8rem 0;
  }
}
.p-ryokan-map:not(.lazyload) {
  background-image: url(../images/home/bg_map-pc.webp);
}
@media only screen and (max-width: 767px) {
  .p-ryokan-map:not(.lazyload) {
    background-image: url(../images/home/bg_map-sp.webp);
  }
}
.p-ryokan-map__title {
  position: relative;
  z-index: 3;
}
@media only screen and (min-width: 768px) {
  .p-ryokan-map__list-wrp {
    bottom: calc(170 / 1440 * 100%);
  }
}
@media only screen and (min-width: 1025px) and (max-width: 1259px) {
  .p-ryokan-map__list-wrp {
    bottom: calc(160 / 1440 * 100%);
  }
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-ryokan-map__list-wrp {
    bottom: calc(150 / 1440 * 100%);
  }
}
@keyframes cloud-top1 {
  0% {
    left: calc(-100 / 1440 * 100%);
    opacity: 0;
  }
  25% {
    left: calc(-80 / 1440 * 100%);
    opacity: 1;
  }
  50% {
    left: calc(-60 / 1440 * 100%);
    opacity: 1;
  }
  75% {
    left: calc(-40 / 1440 * 100%);
    opacity: 1;
  }
  100% {
    left: calc(-20 / 1440 * 100%);
    opacity: 0;
  }
}
@keyframes cloud-top2 {
  0% {
    right: 0;
    opacity: 0;
  }
  25% {
    right: calc(-20 / 1440 * 100%);
    opacity: 1;
  }
  50% {
    right: calc(-40 / 1440 * 100%);
    opacity: 1;
  }
  75% {
    right: calc(-60 / 1440 * 100%);
    opacity: 1;
  }
  100% {
    right: calc(-80 / 1440 * 100%);
    opacity: 0;
  }
}
@keyframes cloud-bottom1 {
  0% {
    left: calc(-200 / 1440 * 100%);
    opacity: 0;
  }
  25% {
    left: calc(-180 / 1440 * 100%);
    opacity: 1;
  }
  50% {
    left: calc(-160 / 1440 * 100%);
    opacity: 1;
  }
  75% {
    left: calc(-140 / 1440 * 100%);
    opacity: 1;
  }
  100% {
    left: calc(-120 / 1440 * 100%);
    opacity: 0;
  }
}
@keyframes cloud-bottom2 {
  0% {
    right: calc(-250 / 1440 * 100%);
    opacity: 0;
  }
  25% {
    right: calc(-270 / 1440 * 100%);
    opacity: 1;
  }
  50% {
    right: calc(-290 / 1440 * 100%);
    opacity: 1;
  }
  75% {
    right: calc(-310 / 1440 * 100%);
    opacity: 1;
  }
  100% {
    right: calc(-320 / 1440 * 100%);
    opacity: 0;
  }
}
.p-ryokan-map__cloud > * {
  position: absolute;
  animation-duration: 9s;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
  z-index: 2;
  transition: left .3s ease, right .3s ease, opacity .3s ease;
}
.p-ryokan-map__cloud__top1 {
  width: calc(648 / 1440 * 100%);
  top: calc(-350 / 1440 * 100%);
  left: calc(-100 / 1440 * 100%);
  animation-name: cloud-top1;
}
@media only screen and (max-width: 767px) {
  .p-ryokan-map__cloud__top1 {
    top: calc(-200 / 1440 * 100%);
    width: calc(1166.4 / 1440 * 100%);
    transform: translateX(-8rem);
  }
}
.p-ryokan-map__cloud__top2 {
  width: calc(570 / 1440 * 100%);
  top: calc(-250 / 1440 * 100%);
  right: 0;
  animation-name: cloud-top2;
  animation-delay: 1s;
}
@media only screen and (max-width: 767px) {
  .p-ryokan-map__cloud__top2 {
    top: calc(50 / 1440 * 100%);
    width: calc(1026 / 1440 * 100%);
  }
}
.p-ryokan-map__cloud__bottom1 {
  width: calc(711 / 1440 * 100%);
  bottom: 0;
  left: calc(-200 / 1440 * 100%);
  animation-delay: 1s;
  animation-name: cloud-bottom1;
}
@media only screen and (max-width: 767px) {
  .p-ryokan-map__cloud__bottom1 {
    bottom: calc(-50 / 1440 * 100%);
    width: calc(888.75 / 1440 * 100%);
  }
}
.p-ryokan-map__cloud__bottom2 {
  width: calc(807 / 1440 * 100%);
  bottom: calc(400 / 1440 * 100%);
  right: calc(-250 / 1440 * 100%);
  animation-name: cloud-bottom2;
}
@media only screen and (max-width: 767px) {
  .p-ryokan-map__cloud__bottom2 {
    width: calc(1008.75 / 1440 * 100%);
    bottom: calc(40 / 1440 * 100%);
  }
}

.p-switch__inner {
  position: relative;
  height: 100vh;
  overflow: hidden;
}
.p-switch__img {
  position: absolute;
  inset: 0;
  top: 0;
  left: 0;
  height: 100vh;
  width: 100%;
  clip-path: inset(100% 0% 0% 0%);
}
.p-switch__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.p-switch__img:first-child {
  clip-path: inset(0% 0% 0% 0%);
}

.p-signature {
  display: flex;
  flex-direction: column;
}
.p-signature__bg {
  order: 1;
  overflow: hidden;
  width: 100%;
  height: 0;
  position: sticky;
  left: 0;
  top: 0;
  z-index: 1;
  padding-bottom: calc(1050 / 1920 * 100%);
}
@media only screen and (max-width: 767px) {
  .p-signature__bg {
    padding-bottom: calc(900 / 642 * 100%);
  }
}
.p-signature__bg::before {
  content: "";
  background-size: 100%;
  background-repeat: no-repeat;
  background-position: top;
  width: 100%;
  height: 0;
  display: block;
  padding-bottom: calc(1050 / 1920 * 100%);
}
@media only screen and (max-width: 767px) {
  .p-signature__bg::before {
    padding-bottom: calc(900 / 642 * 100%);
  }
}
.p-signature:not(.lazyload) .p-signature__bg::before {
  background-image: url(../images/home/bg_signature-pc.webp);
}
@media only screen and (max-width: 767px) {
  .p-signature:not(.lazyload) .p-signature__bg::before {
    background-image: url(../images/home/bg_signature-sp.webp);
  }
}

.p-signature01 {
  position: relative;
  order: 2;
  width: 100%;
  margin-top: calc(-1050 / 1920 * 100%);
}
@media only screen and (max-width: 767px) {
  .p-signature01 {
    margin-top: calc(-900 / 642 * 100%);
  }
}
.p-signature01__service {
  width: calc(1320 / 1440 * 100%);
  margin-right: auto;
  margin-left: auto;
  display: flex;
  align-items: flex-start;
  position: relative;
  z-index: 2;
  padding-top: 14.28rem;
  padding-bottom: 8.57rem;
}
@media only screen and (max-width: 1024px) {
  .p-signature01__service {
    width: 100%;
  }
}
@media only screen and (max-width: 767px) {
  .p-signature01__service {
    padding-top: 7.14rem;
    padding-bottom: 7.14rem;
  }
}
.p-signature01__service__img {
  position: relative;
  z-index: 1;
}
.p-signature01__service__img--left {
  margin-top: calc(70 / 1320 * 100%);
  width: calc(476 / 1320 * 100%);
  order: 1;
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-signature01__service__img--left {
    width: calc(425 / 1320 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .p-signature01__service__img--left {
    width: calc(120 / 428 * 100%);
  }
}
.p-signature01__service__img--left .flex {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  margin-top: calc(100 / 476 * 100%);
}
@media only screen and (min-width: 768px) {
  .p-signature01__service__img--left .flex {
    justify-content: space-between;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-signature01__service__img--left .flex {
    margin-top: calc(150 / 476 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .p-signature01__service__img--left .flex {
    flex-direction: column;
  }
}
.p-signature01__service__img--left .img1 {
  margin-left: calc(50 / 476 * 100%);
  width: calc(260 / 476 * 100%);
}
@media only screen and (max-width: 767px) {
  .p-signature01__service__img--left .img1 {
    margin-left: 0;
    margin-top: calc(130 / 120 * 100%);
    width: calc(78 / 120 * 100%);
  }
}
.p-signature01__service__img--left .img2 {
  width: calc(160 / 476 * 100%);
}
@media only screen and (max-width: 767px) {
  .p-signature01__service__img--left .img2 {
    margin-top: calc(170 / 120 * 100%);
    margin-left: calc(15 / 120 * 100%);
    width: calc(77 / 120 * 100%);
  }
}
.p-signature01__service__img--left .img3 {
  width: calc(264 / 476 * 100%);
  margin-top: calc(70 / 476 * 100%);
}
@media only screen and (max-width: 767px) {
  .p-signature01__service__img--left .img3 {
    margin-top: calc(45 / 120 * 100%);
    width: calc(96 / 120 * 100%);
    margin-right: 0;
    margin-left: auto;
  }
}
.p-signature01__service__img--left .img4 {
  margin-top: calc(-50 / 476 * 100%);
  margin-left: calc(70 / 476 * 100%);
  width: calc(160 / 476 * 100%);
}
@media only screen and (max-width: 767px) {
  .p-signature01__service__img--left .img4 {
    margin-top: calc(30 / 120 * 100%);
    margin-left: 0;
    width: calc(70 / 120 * 100%);
  }
}
.p-signature01__service__img--right {
  width: calc(449 / 1320 * 100%);
  order: 3;
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-signature01__service__img--right {
    width: calc(400 / 1320 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .p-signature01__service__img--right {
    width: calc(110 / 428 * 100%);
    margin-top: calc(120 / 428 * 100%);
  }
}
.p-signature01__service__img--right .img1 {
  margin-top: calc(-10 / 449 * 100%);
  margin-left: calc(80 / 449 * 100%);
  width: calc(220 / 449 * 100%);
  position: relative;
  z-index: 2;
}
@media only screen and (max-width: 767px) {
  .p-signature01__service__img--right .img1 {
    width: calc(72 / 110 * 100%);
  }
}
.p-signature01__service__img--right .img2 {
  width: calc(177 / 449 * 100%);
  margin-top: calc(-30 / 449 * 100%);
  margin-left: auto;
  margin-right: calc(30 / 449 * 100%);
}
@media only screen and (max-width: 767px) {
  .p-signature01__service__img--right .img2 {
    margin-top: 0;
    margin-right: 0;
    width: calc(58 / 110 * 100%);
  }
}
.p-signature01__service__img--right .img3 {
  width: calc(220 / 449 * 100%);
  margin-top: calc(50 / 449 * 100%);
  margin-left: calc(-30 / 449 * 100%);
  position: relative;
  z-index: 2;
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-signature01__service__img--right .img3 {
    margin-top: calc(100 / 449 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .p-signature01__service__img--right .img3 {
    margin-left: 0;
    margin-top: calc(290 / 110 * 100%);
    width: calc(69 / 110 * 100%);
  }
}
.p-signature01__service__img--right .img4 {
  margin-top: calc(-65 / 449 * 100%);
  margin-left: auto;
  margin-right: calc(35 / 449 * 100%);
  width: calc(260 / 449 * 100%);
}
@media only screen and (max-width: 767px) {
  .p-signature01__service__img--right .img4 {
    width: calc(89 / 110 * 100%);
    margin-top: calc(-5 / 110 * 100%);
    margin-right: 0;
  }
}
.p-signature01__service__sticky {
  margin-left: calc(-20 / 1320 * 100%);
  margin-right: calc(-20 / 1320 * 100%);
  width: calc(435 / 1320 * 100%);
  position: sticky;
  z-index: 2;
  top: 20vh;
  order: 2;
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-signature01__service__sticky {
    margin-left: calc(-20 / 1320 * 100%);
    margin-right: calc(-20 / 1320 * 100%);
    width: calc(535 / 1320 * 100%);
  }
}
@media only screen and (min-width: 768px) {
  .p-signature01__service__sticky > * {
    white-space: nowrap;
  }
}
@media only screen and (max-width: 767px) {
  .p-signature01__service__sticky {
    margin-left: calc(-50 / 428 * 100%);
    margin-right: calc(-50 / 428 * 100%);
    width: calc(298 / 428 * 100%);
    top: 14vh;
  }
  .p-signature01__service__sticky .c-text-set__text {
    line-height: 3;
  }
  html:lang(en) .p-signature01__service__sticky .c-text-set__text {
    line-height: 2.5;
  }
}
.p-signature01__night {
  display: flex;
  align-items: center;
  position: relative;
  z-index: 2;
  margin-right: auto;
  margin-left: auto;
}
@media only screen and (min-width: 1025px) {
  .p-signature01__night {
    width: calc(1200 / 1440 * 100%);
    max-width: calc(1200px);
  }
}
@media only screen and (min-width: 1025px) and (min-width: 1441px) {
  .p-signature01__night {
    max-width: calc(1200px * ((16 + 3) / 14));
  }
}
@media only screen and (min-width: 1025px) and (min-width: 1441px) and (max-width: 1600px) {
  .p-signature01__night {
    max-width: calc(1200px * ((16 + 2) / 14));
  }
}

@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-signature01__night {
    width: calc(1200 / 1440 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .p-signature01__night {
    width: calc(388 / 428 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .p-signature01__night {
    flex-direction: column;
  }
}
.p-signature01__night__text {
  width: calc(400 / 1200 * 100%);
  margin-left: calc(100 / 1200 * 100%);
}
@media only screen and (min-width: 1025px) {
  .p-signature01__night__text {
    min-width: 26.42rem;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1259px) {
  .p-signature01__night__text {
    width: calc(480 / 1200 * 100%);
    margin-left: calc(60 / 1200 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .p-signature01__night__text {
    width: 100%;
    margin-left: 0;
  }
}
.p-signature01__night__img {
  width: calc(700 / 1200 * 100%);
}
@media only screen and (min-width: 768px) {
  .p-signature01__night__img {
    order: -1;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1259px) {
  .p-signature01__night__img {
    width: calc(660 / 1200 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .p-signature01__night__img {
    width: 100%;
    margin: 2rem auto 0;
  }
}
.p-signature01__night__img .img1 {
  margin-right: 0;
  margin-left: auto;
  width: calc(500 / 700 * 100%);
}
@media only screen and (max-width: 767px) {
  .p-signature01__night__img .img1 {
    width: 68%;
  }
}
.p-signature01__night__img .img2 {
  margin-left: calc(20 / 700 * 100%);
  margin-top: calc(-55 / 700 * 100%);
  width: calc(300 / 700 * 100%);
}
@media only screen and (max-width: 767px) {
  .p-signature01__night__img .img2 {
    margin-top: -18%;
    width: 40%;
  }
}

.p-signature02 {
  order: 3;
  margin-top: 14.28rem;
  display: flex;
  align-items: flex-start;
  margin-left: auto;
  position: relative;
  z-index: 2;
  width: calc(1360 / 1440 * 100%);
  margin-right: 0;
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-signature02 {
    margin-top: 10.71rem;
  }
}
@media only screen and (max-width: 767px) {
  .p-signature02 {
    flex-direction: column;
    margin-top: 6rem;
    width: 100%;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1365px) {
  .p-signature02 {
    width: calc(1400 / 1440 * 100%);
  }
}
.p-signature02__sticky {
  margin-top: 5rem;
  width: calc(410 / 1360 * 100%);
  position: sticky;
  z-index: 2;
  top: 7.14rem;
}
@media only screen and (min-width: 1025px) and (max-width: 1365px) {
  .p-signature02__sticky {
    width: calc(450 / 1400 * 100%);
  }
}
html:lang(en) .p-signature02__sticky .c-text-set__text {
  padding-right: 1rem;
}
html:lang(en) .p-signature02__sticky .c-text-set__title {
  padding-right: 1rem;
}
html:lang(zh-CN) .p-signature02__sticky .c-text-set__title {
  padding-right: 1rem;
}
html:lang(zh-Hant) .p-signature02__sticky .c-text-set__title {
  padding-right: 1rem;
}
html:lang(zh-TW) .p-signature02__sticky .c-text-set__title {
  padding-right: 1rem;
}
html:lang(ko) .p-signature02__sticky .c-text-set__title {
  padding-right: 1rem;
}
@media only screen and (min-width: 768px) and (max-width: 1150px) {
  .p-signature02__sticky {
    width: calc(500 / 1400 * 100%);
  }
  .p-signature02__sticky .c-text-set__text {
    padding-right: 2.14rem;
  }
}
@media only screen and (max-width: 767px) {
  .p-signature02__sticky {
    width: 100%;
    position: relative;
    top: 0;
    margin-top: 0;
  }
}
.p-signature02__img {
  width: calc(950 / 1360 * 100%);
}
@media only screen and (min-width: 1025px) and (max-width: 1365px) {
  .p-signature02__img {
    width: calc(950 / 1400 * 100%);
  }
}
@media only screen and (min-width: 768px) and (max-width: 1100px) {
  .p-signature02__img {
    width: calc(900 / 1400 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .p-signature02__img {
    width: 100%;
    margin-top: 2rem;
  }
  .p-signature02__img .img + .c-text-set__text {
    margin-top: 1.5rem;
  }
  .p-signature02__img .c-text-set__text + .img {
    margin-top: 2rem;
  }
}

.p-inside {
  width: 100%;
  overflow: hidden;
  margin-top: calc(330 / 1440 * 100%);
}
@media only screen and (max-width: 767px) {
  .p-inside {
    margin-top: 6rem;
  }
}

.p-lower-layer {
  margin-top: 10.71rem;
}
@media only screen and (max-width: 767px) {
  .p-lower-layer {
    margin-top: 5rem;
  }
}
.p-lower-layer__sidebar {
  width: calc(195 / 1440 * 100%);
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-lower-layer__sidebar {
    width: calc(240 / 1440 * 100%);
  }
}
@media only screen and (min-width: 1025px) {
  .p-lower-layer__inner {
    width: calc(1245 / 1440 * 100%);
  }
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-lower-layer__inner {
    width: calc(1200 / 1440 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .p-lower-layer__rooms .js-move-sp {
    order: 3;
    width: 100%;
  }
  .p-lower-layer__rooms .c-text-set__btn {
    margin-top: 2rem;
  }
}
.p-lower-layer__rooms__main {
  display: flex;
  align-items: flex-start;
}
@media only screen and (max-width: 767px) {
  .p-lower-layer__rooms__main {
    flex-direction: column;
  }
}
.p-lower-layer__rooms__main__img {
  width: calc(720 / 1245 * 100%);
  order: 1;
}
@media only screen and (max-width: 767px) {
  .p-lower-layer__rooms__main__img {
    order: 2;
    width: 100%;
    margin-top: 1.5rem;
  }
}
.p-lower-layer__rooms__main__text {
  width: calc(375 / 1245 * 100%);
  margin-left: calc(100 / 1245 * 100%);
  order: 2;
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  html:lang(en) .p-lower-layer__rooms__main__text {
    margin-left: calc(80 / 1245 * 100%);
    width: calc(395 / 1245 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .p-lower-layer__rooms__main__text {
    order: 1;
    margin-right: auto;
    margin-left: auto;
    width: calc(388 / 428 * 100%);
  }
}
@media only screen and (min-width: 768px) {
  .p-lower-layer__rooms__main__text > * {
    max-width: 18.21rem;
  }
}
.p-lower-layer__rooms__type {
  width: calc(1050 / 1245 * 100%);
  margin-left: calc(120 / 1245 * 100%);
  margin-top: calc(-165 / 1245 * 100%);
  display: flex;
}
@media only screen and (min-width: 897px) and (max-width: 1024px) {
  .p-lower-layer__rooms__type {
    margin-top: calc(-140 / 1245 * 100%);
  }
}
@media only screen and (min-width: 768px) and (max-width: 896px) {
  .p-lower-layer__rooms__type {
    margin-top: 2.85rem;
  }
}
@media only screen and (max-width: 767px) {
  .p-lower-layer__rooms__type {
    margin: 5rem auto 0;
    flex-direction: column;
    width: calc(380 / 428 * 100%);
  }
}
.p-lower-layer__rooms__type__item {
  display: flex;
  flex-direction: column;
}
@media only screen and (max-width: 767px) {
  .p-lower-layer__rooms__type__item {
    width: 100%;
  }
}
@media only screen and (min-width: 768px) {
  .p-lower-layer__rooms__type__item--tsuki {
    margin-top: calc(275 / 1245 * 100%);
    width: calc(440 / 1050 * 100%);
    order: -1;
  }
}
@media only screen and (min-width: 768px) and (max-width: 896px) {
  .p-lower-layer__rooms__type__item--tsuki {
    margin-top: calc(200 / 1245 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .p-lower-layer__rooms__type__item--tsuki {
    margin-top: 4rem;
  }
}
@media only screen and (min-width: 768px) {
  .p-lower-layer__rooms__type__item--kaze {
    width: calc(526 / 1050 * 100%);
    margin-left: calc(84 / 1050 * 100%);
  }
}
.p-lower-layer__rooms__type__item__text {
  width: 100%;
  padding: 0 .5rem;
  margin-top: 1.42rem;
}
@media only screen and (max-width: 767px) {
  .p-lower-layer__rooms__type__item__text {
    order: 1;
  }
}
.p-lower-layer__rooms__type__item__text .c-title-sub {
  font-size: 1.71rem;
}
.p-lower-layer__rooms__type__item__text .c-text-set__text {
  margin-top: 0.71rem;
}
.p-lower-layer__rooms__type__item__img {
  width: 100%;
  order: -1;
}
@media only screen and (max-width: 767px) {
  .p-lower-layer__rooms__type__item__img {
    order: 2;
    margin-top: 1.5rem;
  }
}
.p-lower-layer__flex {
  margin-top: 7.14rem;
  display: flex;
  align-items: center;
}
@media only screen and (min-width: 768px) and (max-width: 896px) {
  .p-lower-layer__flex {
    align-items: flex-start;
  }
}
@media only screen and (max-width: 767px) {
  .p-lower-layer__flex {
    align-items: flex-start;
    flex-direction: column;
  }
}
.p-lower-layer__flex__img {
  width: calc(890 / 1245 * 100%);
  order: 1;
}
@media only screen and (min-width: 1025px) and (max-width: 1365px) {
  .p-lower-layer__flex__img {
    width: calc(870 / 1245 * 100%);
  }
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-lower-layer__flex__img {
    width: calc(800 / 1245 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .p-lower-layer__flex__img {
    order: 2;
    width: 100%;
    margin-top: 1.5rem;
  }
  .p-lower-layer__flex__img img {
    aspect-ratio: 428 / 428;
    object-fit: cover;
  }
}
.p-lower-layer__flex__text {
  width: calc(285 / 1245 * 100%);
  margin-left: calc(70 / 1245 * 100%);
  order: 2;
}
@media only screen and (min-width: 1441px) and (max-width: 1600px) {
  .p-lower-layer__flex__text {
    margin-left: calc(50 / 1245 * 100%);
  }
}
@media only screen and (min-width: 1025px) and (max-width: 1365px) {
  .p-lower-layer__flex__text {
    margin-right: auto;
    width: calc(300 / 1245 * 100%);
    margin-left: calc(50 / 1245 * 100%);
  }
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-lower-layer__flex__text {
    width: calc(350 / 1245 * 100%);
    margin-left: calc(50 / 1245 * 100%);
    margin-right: auto;
  }
}
@media only screen and (max-width: 767px) {
  .p-lower-layer__flex__text {
    order: 1;
    width: calc(388 / 428 * 100%);
    margin-right: auto;
    margin-left: auto;
  }
  html:lang(ja) .p-lower-layer__flex__text {
    width: 100%;
  }
}
.p-lower-layer__flex__text .u-view-ctrl {
  display: block;
}
@media only screen and (min-width: 1025px) and (max-width: 1259px) {
  .p-lower-layer__flex__text .u-view-ctrl {
    display: none;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-lower-layer__flex__text .u-view-ctrl {
    display: none;
  }
}
.p-lower-layer__flex .js-move-sp {
  width: 100%;
  order: 3;
  text-align: center;
}

.p-location {
  margin-top: calc(250 / 1440 * 100%);
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.p-location__bg {
  order: -1;
  height: 100vh;
  width: 100%;
  position: sticky;
  top: 0;
  background-size: cover;
  background-position: center;
  z-index: 1;
}
.p-location:not(.lazyload) .p-location__bg {
  background-image: url(../images/home/bg_location-pc.webp);
}
@media only screen and (max-width: 767px) {
  .p-location:not(.lazyload) .p-location__bg {
    background-image: url(../images/home/bg_location-sp.webp);
  }
}
.p-location:not(.lazyload) .p-location__inner {
  background-image: url(../images/common/bg-noise-4.webp);
}
@media only screen and (max-width: 767px) {
  .p-location .js-move-sp {
    width: 100%;
    order: 3;
  }
  .p-location .c-text-set__btn {
    margin-top: 2rem;
    display: flex;
    justify-content: center;
  }
}
.p-location__content {
  margin-top: -95vh;
  position: relative;
  z-index: 2;
  width: 100%;
  margin-bottom: 7.14rem;
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-location__content {
    margin-top: -70vh;
  }
}
@media only screen and (max-width: 767px) {
  .p-location__content {
    margin-top: -100vh;
    margin-bottom: 5rem;
  }
}
.p-location__title {
  padding-top: calc(520 / 1440 * 100%);
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-location__title {
    padding-top: calc(420 / 1440 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .p-location__title {
    padding-top: 28.57rem;
  }
}
.p-location__inner {
  overflow: hidden;
  background-color: #f7f5f0;
  background-repeat: repeat;
  background-position: top;
  background-size: auto;
  width: calc(1300 / 1440 * 100%);
  padding: calc(120 / 1440 * 100%) 0;
  margin: 4.28rem auto 0;
}
@media only screen and (max-width: 767px) {
  .p-location__inner {
    padding: 3rem 0 5rem;
    margin: 2rem auto 0;
    width: calc(388 / 428 * 100%);
  }
}
.p-location__seen {
  width: calc(1100 / 1300 * 100%);
  margin-right: auto;
  margin-left: auto;
  display: flex;
  align-items: center;
  position: relative;
  z-index: 2;
}
@media only screen and (min-width: 1025px) and (max-width: 1259px) {
  .p-location__seen {
    align-items: flex-start;
  }
}
@media only screen and (max-width: 1024px) {
  .p-location__seen {
    align-items: flex-start;
  }
}
@media only screen and (max-width: 767px) {
  .p-location__seen {
    width: calc(327 / 370 * 100%);
    flex-direction: column;
  }
}
.p-location__seen__img {
  width: calc(750 / 1100 * 100%);
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-location__seen__img {
    width: calc(700 / 1100 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .p-location__seen__img {
    width: 100%;
    margin-top: 1.5rem;
  }
}
.p-location__seen__text {
  width: calc(350 / 1100 * 100%);
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-location__seen__text {
    width: calc(400 / 1100 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .p-location__seen__text {
    width: 100%;
  }
}
html:lang(ja) .p-location__seen__text .c-title .c-title__jp {
  word-break: keep-all;
}
.p-location__seen__text .c-text-set__text {
  max-width: 16.07rem;
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-location__seen__text .c-text-set__text {
    width: 90%;
  }
}
@media only screen and (max-width: 767px) {
  .p-location__seen__text .c-text-set__text {
    max-width: 19.28rem;
    margin-right: auto;
    margin-left: auto;
    text-align: left;
  }
}
.p-location__map {
  width: calc(1100 / 1300 * 100%);
  margin: 2.14rem auto 0;
  position: relative;
  z-index: 1;
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
}
@media only screen and (max-width: 767px) {
  .p-location__map {
    margin: 4rem auto 0;
    flex-direction: column;
    width: 100%;
  }
}
.p-location__map__link {
  width: calc(270 / 1100 * 100%);
  margin-left: calc(25 / 1100 * 100%);
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  text-decoration: none;
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-location__map__link {
    width: calc(295 / 1100 * 100%);
    margin-left: 0;
  }
}
@media only screen and (max-width: 767px) {
  .p-location__map__link {
    width: calc(260 / 388 * 100%);
    margin-right: auto;
    margin-left: auto;
  }
}
.p-location__map__link .t {
  margin-top: 1rem;
  line-height: 1.6;
}
@media only screen and (max-width: 767px) {
  .p-location__map__link .t {
    margin-top: .75rem;
    margin-right: -1em;
  }
}
.p-location__map__link .o-arrow {
  margin-top: 1rem;
  margin-right: 0;
  margin-left: auto;
}
.p-location__map__link .img {
  overflow: hidden;
  order: -1;
}
.p-location__map__link .img img {
  transform-origin: center;
  display: block;
  transition: transform .3s ease;
}
.mouse .p-location__map__link:hover .img img, .touch .p-location__map__link.touchstart .img img {
  transform: scale(1.1);
}
.touch .p-location__map__link {
  -webkit-tap-highlight-color: transparent;
}
.touch .p-location__map__link.touchend {
  -moz-transition-delay: 200ms;
  -o-transition-delay: 200ms;
  -webkit-transition-delay: 200ms;
  transition-delay: 200ms;
}
.p-location__map__bg {
  top: calc(-1960 / 1100 * 100%);
  right: calc(-30 / 1100 * 100%);
  width: calc(891 / 1100 * 100%);
  position: absolute;
}
@media only screen and (min-width: 1025px) and (max-width: 1365px) {
  .p-location__map__bg {
    top: calc(-2600 / 1100 * 100%);
    right: calc(-200 / 1100 * 100%);
    width: calc(1200 / 1100 * 100%);
  }
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-location__map__bg {
    top: calc(-3200 / 1100 * 100%);
    right: calc(-250 / 1100 * 100%);
    width: calc(1500 / 1100 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .p-location__map__bg {
    width: 100%;
    margin-top: -5rem;
    top: 0;
    right: 0;
    position: relative;
  }
}
.p-location__map__bg img {
  max-width: 1186px;
}
.p-location__acc {
  width: calc(1100 / 1300 * 100%);
  margin: calc(190 / 1300 * 100%) auto 0;
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-location__acc {
    margin: calc(150 / 1300 * 100%) auto 0;
  }
}
@media only screen and (max-width: 767px) {
  .p-location__acc {
    margin: 3rem auto 0;
    width: calc(327 / 370 * 100%);
    flex-direction: column;
  }
}
.p-location__acc__img {
  width: calc(688 / 1100 * 100%);
  order: -1;
}
@media only screen and (min-width: 1025px) and (max-width: 1259px) {
  .p-location__acc__img {
    width: calc(658 / 1100 * 100%);
  }
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-location__acc__img {
    width: calc(658 / 1100 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .p-location__acc__img {
    width: 100%;
    order: 2;
    margin-top: 1.5rem;
  }
}
.p-location__acc__text {
  width: calc(290 / 1100 * 100%);
  margin-left: calc(80 / 1100 * 100%);
}
@media only screen and (min-width: 1025px) and (max-width: 1259px) {
  .p-location__acc__text {
    width: calc(330 / 1100 * 100%);
  }
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-location__acc__text {
    width: calc(392 / 1100 * 100%);
    margin-left: calc(50 / 1100 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .p-location__acc__text {
    width: 100%;
    margin-left: auto;
    order: 1;
  }
}

.p-news {
  position: relative;
  margin-right: auto;
  margin-left: auto;
  margin-top: 7.85rem;
}
@media only screen and (min-width: 1025px) {
  .p-news {
    width: calc(1100 / 1440 * 100%);
    max-width: calc(1100px);
  }
}
@media only screen and (min-width: 1025px) and (min-width: 1441px) {
  .p-news {
    max-width: calc(1100px * ((16 + 3) / 14));
  }
}
@media only screen and (min-width: 1025px) and (min-width: 1441px) and (max-width: 1600px) {
  .p-news {
    max-width: calc(1100px * ((16 + 2) / 14));
  }
}

@media only screen and (max-width: 767px) {
  .p-news {
    width: calc(388 / 428 * 100%);
  }
}
@media only screen and (min-width: 1025px) and (max-width: 1365px) {
  .p-news {
    width: calc(1200 / 1440 * 100%);
  }
}
@media only screen and (min-width: 768px) and (max-width: 1024px) {
  .p-news {
    width: calc(1300 / 1440 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .p-news {
    margin-top: 4rem;
  }
}
.p-news__list {
  display: flex;
  flex-wrap: wrap;
}
@media only screen and (min-width: 768px) {
  .p-news__list {
    margin-top: 2.5rem;
  }
}
@media only screen and (max-width: 767px) {
  .p-news__list {
    margin-top: 2rem;
  }
}
@media only screen and (min-width: 768px) {
  .p-news__li {
    width: calc(260 / 1100 * 100%);
  }
  .p-news__li:not(:nth-child(4n+1)) {
    margin-left: calc(20 / 1100 * 100%);
  }
}
@media only screen and (max-width: 767px) {
  .p-news__li {
    width: 100%;
  }
  .p-news__li:nth-child(n+2) {
    margin-top: 1rem;
  }
}
.p-news__link {
  width: 100%;
  display: flex;
  text-decoration: none;
  color: #030B11;
}
@media only screen and (min-width: 768px) {
  .p-news__link {
    flex-direction: column;
  }
}
@media only screen and (max-width: 767px) {
  .p-news__link {
    align-items: center;
  }
}
.p-news__link__text {
  padding: .5rem;
}
@media only screen and (max-width: 767px) {
  .p-news__link__text {
    padding: 0;
    width: 58%;
  }
}
.p-news__link__text time {
  letter-spacing: 0;
}
.p-news__link__title {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  line-height: 1.5;
}
.firefox .p-news__link__title, .ie .p-news__link__title {
  max-height: 4.5em;
}
.p-news__link__img {
  overflow: hidden;
  order: -1;
}
@media only screen and (max-width: 767px) {
  .p-news__link__img {
    width: 38%;
    margin-right: 4%;
  }
}
.p-news__link__img img {
  transform-origin: center;
  display: block;
  object-fit: cover;
  transition: transform .3s ease;
  aspect-ratio: 260 / 173;
}
.mouse .p-news__link:hover .p-news__link__img img, .touch .p-news__link.touchstart .p-news__link__img img {
  transform: scale(1.2);
}
.touch .p-news__link {
  -webkit-tap-highlight-color: transparent;
}
.touch .p-news__link.touchend {
  -moz-transition-delay: 200ms;
  -o-transition-delay: 200ms;
  -webkit-transition-delay: 200ms;
  transition-delay: 200ms;
}
.p-news__link .o-arrow {
  margin: .5rem 0 0 auto;
}
.p-news__btn {
  display: flex;
  justify-content: flex-end;
  margin-top: 2.85rem;
}
@media only screen and (max-width: 767px) {
  .p-news__btn {
    margin-top: 2.5rem;
    justify-content: center;
  }
}
