@charset "UTF-8";
.bookModule .tabList li:nth-of-type(2), .bookModule .tabList li:nth-of-type(3) {
  display: none !important;
}

.globalNav .member {
  display: flex;
  justify-content: center;
}
.globalNav .member .reserve_new {
  display: block !important;
  background-color: #751426;
  color: #fff;
  border-radius: 4px;
  font-size: 1.4rem;
  height: 45px;
  display: flex !important;
  align-items: center;
  justify-content: center;
  max-width: 230px;
  min-width: 230px;
  filter: drop-shadow(3px 3px 3px rgba(0, 0, 0, 0.3));
  line-height: 1.2;
}
.globalNav .instaList {
  margin-top: 15px;
  display: flex;
  justify-content: center;
  gap: 25px;
  margin-bottom: 20px;
}
.globalNav .instaList li a {
  display: flex;
  align-items: center;
  font-size: 1.3rem;
}
.globalNav .instaList li a img {
  margin-right: 5px;
}

@media (max-width: 1024px) {
  .kv.kv_slide .swiper-pagination {
    text-align: center;
  }
}
.kv.kv_slide .swiper-button-prev,
.kv.kv_slide .swiper-button-next {
  background: none;
  color: #fff;
  filter: drop-shadow(0 0 1px rgba(0, 0, 0, 0.5));
}
.kv.kv_slide .swiper-button-prev::after,
.kv.kv_slide .swiper-button-next::after {
  font-weight: bold;
  height: 32px;
  font-size: 26px;
}
@media (max-width: 1024px) {
  .kv.kv_slide .swiper-button-prev::after,
  .kv.kv_slide .swiper-button-next::after {
    width: 10px;
    height: 20px;
    font-size: 18px;
  }
}
.kv.kv_slide .swiper-button-prev::before,
.kv.kv_slide .swiper-button-next::before {
  display: none;
}
.kv.kv_slide .swiper-button-prev {
  left: calc(var(--slide-peek) - 40px - var(--spaceBetween) + 2px);
}
@media (max-width: 1024px) {
  .kv.kv_slide .swiper-button-prev {
    left: 0;
  }
}
.kv.kv_slide .swiper-button-next {
  right: calc(var(--slide-peek) - 40px - var(--spaceBetween) + 2px);
}
@media (max-width: 1024px) {
  .kv.kv_slide .swiper-button-next {
    right: 0;
  }
}
.kv .kvSlideWrap {
  max-height: 64vh;
  position: relative;
}
@media (max-width: 1024px) {
  .kv .kvSlideWrap {
    max-height: none;
  }
}
.kv .kvSlideWrap .photo {
  max-height: none;
}
@media (max-width: 1024px) {
  .kv .kvSlideWrap .photo {
    height: 65vh;
  }
}
.kv .textWrap {
  position: absolute;
  right: initial;
  left: calc(var(--slide-peek) + 60px);
  bottom: 50px;
  z-index: 2;
  max-width: calc(100% - (var(--slide-peek) + 60px) * 2);
}
@media (max-width: 1024px) {
  .kv .textWrap {
    bottom: 8%;
    max-width: calc(100% - 40px);
    width: 100%;
    left: 50%;
    transform: translateX(-50%);
    text-align: center;
  }
}
.kv .textWrap .open {
  color: #000;
  font-size: 2.7rem;
  font-weight: bold;
  background: rgba(255, 255, 255, 0.5);
  height: 55px;
  line-height: 55px;
  padding: 0 25px;
  margin-bottom: 15px;
  display: inline-block;
}
@media (max-width: 1024px) {
  .kv .textWrap .open {
    font-size: 1.7rem;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 15px;
    margin-bottom: 5px;
    line-height: 1;
  }
}
.kv .textWrap .hotelName {
  color: #fff;
  font-size: 3.8rem;
  font-weight: bold;
  filter: drop-shadow(0 0 1px rgba(0, 0, 0, 0.5));
  line-height: 1.2;
}
@media (max-width: 1024px) {
  .kv .textWrap .hotelName {
    font-size: 2.4rem;
    line-height: 1.4;
  }
}
.kv .kv_bottom .wrapper {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 5vh 0;
  left: calc(var(--slide-peek) + 60px);
  margin: 0;
  max-width: calc(100% - (var(--slide-peek) + 60px) * 2);
}
@media (max-width: 1024px) {
  .kv .kv_bottom .wrapper {
    flex-direction: column;
    padding: 25px 0;
    gap: 25px;
    left: initial;
    max-width: calc(100% - 40px);
    margin: 0 auto;
  }
}
.kv .kv_bottom .kv_lead {
  font-weight: bold;
  font-size: 2rem;
  color: #000;
  line-height: 1.5;
}
@media (max-width: 1024px) {
  .kv .kv_bottom .kv_lead {
    font-size: 1.4rem;
    text-align: center;
    max-width: 100%;
  }
}
.kv .kv_bottom .bnr {
  margin-top: 0;
  flex-wrap: wrap;
  gap: 3px;
}
@media (max-width: 1024px) {
  .kv .kv_bottom .bnr {
    position: initial;
    gap: 6px;
    justify-content: center;
  }
}
.kv .kv_bottom .bnr a,
.kv .kv_bottom .bnr img {
  height: 95px;
  margin-left: 0;
}
@media (max-width: 1024px) {
  .kv .kv_bottom .bnr a,
  .kv .kv_bottom .bnr img {
    height: 60px;
  }
}

.contents {
  overflow: visible;
}

@media (max-width: 767px) {
  .contents {
    overflow-x: clip;
  }
}
.fixedMenu {
  position: sticky;
  top: 110px;
  right: 0;
  z-index: 2;
  width: 45px;
  margin-left: auto;
  margin-block: 40px -265px;
}
.fixedMenu + .bg_beige .wrapper {
  padding-top: 0;
}

@media (max-width: 767px) {
  .fixedMenu {
    top: 80px;
    width: 35px;
    margin-block: 15px -165px;
  }
}
.fixedMenuList {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}

.fixedMenuList > li + li {
  margin-top: 10px;
}

.fixedMenuList > li > a {
  writing-mode: vertical-rl;
}

.fixedMenuList > li > a,
.fixedMenuList > li button {
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 8px 0 0 8px;
  background: #666666;
  width: 45px;
  height: 150px;
  color: #fff;
  font-size: 1.5rem;
  text-decoration: none;
  cursor: pointer;
  line-height: 1.2;
  padding: 10px 0;
}

.lang_ru .fixedMenuList > li.member > a,
.lang_ru .fixedMenuList > li.member button {
  height: 180px;
}
@media (max-width: 1024px) {
  .lang_ru .fixedMenuList > li.member > a,
  .lang_ru .fixedMenuList > li.member button {
    height: 170px;
  }
}
.lang_ru .fixedMenu {
  margin-block: 40px -295px;
}
@media (max-width: 767px) {
  .lang_ru .fixedMenu {
    margin-block: 15px -235px;
  }
}

@media (max-width: 1024px) {
  .lang_it .fixedMenuList > li.member > a,
  .lang_it .fixedMenuList > li.member button,
  .lang_fr .fixedMenuList > li.member > a,
  .lang_fr .fixedMenuList > li.member button,
  .lang_de .fixedMenuList > li.member > a,
  .lang_de .fixedMenuList > li.member button,
  .lang_es .fixedMenuList > li.member > a,
  .lang_es .fixedMenuList > li.member button,
  .lang_vi .fixedMenuList > li.member > a,
  .lang_vi .fixedMenuList > li.member button {
    height: 140px;
  }
}
@media (max-width: 767px) {
  .lang_it .fixedMenu,
  .lang_fr .fixedMenu,
  .lang_de .fixedMenu,
  .lang_es .fixedMenu,
  .lang_vi .fixedMenu {
    margin-block: 15px -205px;
  }
}

@media (max-width: 767px) {
  .fixedMenuList > li > a,
  .fixedMenuList > li button {
    width: 30px;
    height: 100px;
    font-size: 1.1rem;
    font-weight: 600;
  }
}
.fixedMenuList .member a {
  display: flex !important;
}

@media (max-width: 767px) {
  .fixedMenuList .member a {
    border-width: 1px;
  }
}
.fixedMenuList .insta {
  display: flex;
  flex-direction: row-reverse;
  margin-top: 30px;
}

@media (max-width: 767px) {
  .fixedMenuList .insta {
    margin-top: 10px;
  }
}
.fixedMenuList .insta button {
  border: none;
  height: 45px;
  color: #fff;
}

@media (max-width: 767px) {
  .fixedMenuList .insta button {
    height: 40px;
  }
  .fixedMenuList .insta button img {
    width: 17px;
    height: 17px;
  }
}
.fixedMenuList .insta button.on {
  border-radius: 0;
}

.fixedMenuList .insta .nestList {
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s;
  display: flex;
  gap: 10px;
  align-items: center;
  border-radius: 8px 0 0 8px;
  background: #666;
  padding-left: 20px;
}

@media (max-width: 767px) {
  .fixedMenuList .insta .nestList {
    padding-inline: 15px 10px;
  }
}
.fixedMenuList .insta .nestList a {
  color: #fff;
}

.fixedMenuList .insta:has(button.on) .nestList {
  opacity: 1;
  visibility: visible;
}

/* ROOM 客室スライド画像追加 ----------------------------------------- */
/* スライダーが5枚以下の場合下記のCSSを追加してください（各施設ごと） */
.roomPhotoModal .thumbnail01 .slick-track,
.roomPhotoModal .thumbnail02 .slick-track {
  display: flex;
  justify-content: center;
  width: 100% !important;
  transform: unset !important;
}/*# sourceMappingURL=style.css.map */