.p-rooms-detail {
  position: relative;
}
.p-rooms-detail__mv {
  position: relative;
  overflow: hidden;
}
.p-rooms-detail__mv-slider {
  position: relative;
  width: 100%;
  height: 100%;
}
.p-rooms-detail__mv-slide {
  position: relative;
  overflow: hidden;
}
.p-rooms-detail__mv-slide img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.p-rooms-detail__mv-arrows {
  position: absolute;
  z-index: 2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.p-rooms-detail__mv-head {
  width: var(--width-inner);
}
.p-rooms-detail__mv-title-ja {
  font-size: 16px;
  line-height: var(--line-height-ja-title);
  letter-spacing: var(--letter-spacing-ja-title);
}
.p-rooms-detail__mv-title {
  font-size: var(--font-size-en-title);
  line-height: var(--line-height-en-title);
  letter-spacing: var(--letter-spacing-en-title);
  text-transform: uppercase;
}
.p-rooms-detail__mv-thumbnails {
  position: relative;
  z-index: 2;
  width: var(--width-inner);
  margin-inline: auto;
}
.p-rooms-detail__mv-thumbnail {
  position: relative;
  border-radius: 3px;
  overflow: hidden;
  z-index: 2;
  margin-right: 9px;
}
.p-rooms-detail__mv-thumbnail img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 94/52;
  border-radius: 3px;
  position: relative;
  z-index: 1;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
.p-rooms-detail__mv-thumbnail::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  border-radius: 3px;
  border: 1px solid var(--color-red);
  z-index: 2;
  opacity: 0;
}
.p-rooms-detail__mv-thumbnail.is-active::after {
  opacity: 1;
}
.p-rooms-detail__mv-thumbnail.is-active img {
  opacity: 0.3;
}
@media screen and (min-width: 768px) {
  .p-rooms-detail__mv-slide img {
    position: relative;
    z-index: 2;
    aspect-ratio: 16/9;
  }
  .p-rooms-detail__mv-arrows {
    width: 100%;
    left: 0;
    bottom: 0;
    z-index: 1;
  }
  .p-rooms-detail__mv-arrow {
    width: 92px;
    height: 92px;
  }
  .p-rooms-detail__mv-head {
    position: absolute;
    top: calc(100% - 92px - 50px);
    left: 50%;
    -webkit-transform: translate(-50%, -100%);
        -ms-transform: translate(-50%, -100%);
            transform: translate(-50%, -100%);
    z-index: 2;
    text-align: center;
    color: #fff;
  }
  .p-rooms-detail__mv-title {
    margin-top: 30px;
  }
  .p-rooms-detail__mv-thumbnails {
    padding: 20px 0;
    width: calc(100% - 92px - 92px);
    margin-inline: auto;
    visibility: hidden;
  }
  .p-rooms-detail__mv-thumbnails.swiper-initialized {
    visibility: visible;
  }
  .p-rooms-detail__mv-thumbnail {
    width: 94px;
  }
}
@media screen and (max-width: 767px) {
  .p-rooms-detail__mv {
    margin-top: var(--height-header);
  }
  .p-rooms-detail__mv-slide img {
    position: relative;
    z-index: 2;
    aspect-ratio: 4/3;
  }
  .p-rooms-detail__mv-arrows {
    width: 94.9%;
    left: 50%;
    top: 37.5vw;
    -webkit-transform: translateY(-50%) translateX(-50%);
        -ms-transform: translateY(-50%) translateX(-50%);
            transform: translateY(-50%) translateX(-50%);
  }
  .p-rooms-detail__mv-thumbnails {
    margin-top: 16px;
    overflow: visible;
  }
  .p-rooms-detail__mv-thumbnails .swiper-wrapper {
    overflow: visible;
  }
  .p-rooms-detail__mv-thumbnail {
    width: 59px;
  }
  .p-rooms-detail__mv-head {
    margin: 42px auto 0;
    color: var(--color-red);
  }
  .p-rooms-detail__mv-title {
    margin-top: 14px;
  }
}
.p-rooms-detail__main {
  position: relative;
}
.p-rooms-detail__main-title {
  color: var(--color-red);
  font-size: var(--font-size-ja-subtitle);
  line-height: var(--line-height-ja-title);
  letter-spacing: var(--letter-spacing-ja-title);
}
.p-rooms-detail__main-price {
  color: var(--color-red);
  font-size: 20px;
  line-height: var(--line-height-ja-title);
}
.p-rooms-detail__main-price-unit {
  font-size: 14px;
  margin-left: 7px;
}
.p-rooms-detail__main-price-unit::before {
  content: "/";
  display: inline-block;
  margin-right: 7px;
  font-family: var(--font-family-en);
}
.p-rooms-detail__main-info {
  position: relative;
  margin-top: 32px;
  font-size: 13px;
  line-height: var(--line-height-body);
  letter-spacing: var(--letter-spacing-body);
  display: grid;
  grid-template-columns: var(--heading-width) 1fr;
  -webkit-column-gap: var(--gap);
     -moz-column-gap: var(--gap);
          column-gap: var(--gap);
}
.p-rooms-detail__main-info::after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  background: var(--border-dotted-red);
}
.p-rooms-detail__main-info dt, .p-rooms-detail__main-info dd {
  padding: 10px 0;
}
.p-rooms-detail__main-info dd {
  position: relative;
}
.p-rooms-detail__main-info dd::before {
  content: "";
  display: block;
  position: absolute;
  left: calc(-1 * var(--heading-width) - var(--gap));
  top: 0;
  width: calc(100% + var(--heading-width) + var(--gap));
  height: 1px;
  background: var(--border-dotted-red);
}
.p-rooms-detail__main-button {
  margin-top: 32px;
}
.p-rooms-detail__main-content {
  font-size: var(--font-size-body);
  line-height: var(--line-height-body);
  letter-spacing: var(--letter-spacing-body);
}
.p-rooms-detail__main-map {
  margin-top: 32px;
  position: relative;
}
.p-rooms-detail__main-map-tabs {
  position: absolute;
  right: 20px;
  top: 20px;
  z-index: 2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 8px;
}
.p-rooms-detail__main-map-tab {
  position: relative;
  height: 32px;
  padding: 0 14px 1px;
  border-radius: 16px;
  cursor: pointer;
  overflow: hidden;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.p-rooms-detail__main-map-tab span {
  position: relative;
  z-index: 2;
  color: #fff;
  line-height: 1;
  font-size: 14px;
}
.p-rooms-detail__main-map-tab::after {
  content: "";
  display: block;
  background: var(--color-red);
  opacity: 0.6;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  -webkit-transition: opacity 0.15s;
  transition: opacity 0.15s;
}
.p-rooms-detail__main-map-tab.is-active::after {
  opacity: 1;
}
.p-rooms-detail__main-map-images {
  position: relative;
  z-index: 1;
}
.p-rooms-detail__main-map-image {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  opacity: 0;
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
.p-rooms-detail__main-map-image.is-active {
  position: relative;
  opacity: 1;
}
@media screen and (min-width: 768px) {
  .p-rooms-detail__main {
    padding: 80px 0 100px;
  }
  .p-rooms-detail__main-inner {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 8.5%;
  }
  .p-rooms-detail__main-head {
    width: min(32.17%, 386px);
    min-width: 300px;
  }
  .p-rooms-detail__main-price {
    margin-top: 11px;
  }
  .p-rooms-detail__main-button {
    --button-padding-x: 20px;
    --button-min-width: 325px;
  }
  .p-rooms-detail__main-content {
    -webkit-box-flex: 1;
        -ms-flex: 1 1 0%;
            flex: 1 1 0%;
  }
  .p-rooms-detail__main-info {
    --heading-width: 110px;
    --gap: 16px;
  }
}
@media screen and (max-width: 767px) {
  .p-rooms-detail__main {
    padding: 17px 0 100px;
  }
  .p-rooms-detail__main-content {
    margin-top: 27px;
  }
  .p-rooms-detail__main-info {
    --heading-width: 100px;
    --gap: 8px;
  }
}
.p-rooms-detail__others {
  position: relative;
  background: var(--color-beige);
  overflow: hidden;
}
.p-rooms-detail__others-title {
  font-size: var(--font-size-en-title);
  line-height: var(--line-height-en-title);
  letter-spacing: var(--letter-spacing-en-title);
  text-transform: uppercase;
  color: var(--color-red);
}
.p-rooms-detail__others-slider {
  overflow: visible;
}
.p-rooms-detail__others-slider .swiper-wrapper {
  overflow: visible;
}
@media screen and (min-width: 768px) {
  .p-rooms-detail__others {
    padding: 120px 0;
  }
  .p-rooms-detail__others-slider {
    margin-top: 44px;
    --room-content-margin-top: 14px;
    --room-button-font-size: 14px;
  }
  .p-rooms-detail__others-arrows {
    position: absolute;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    z-index: 2;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    top: 45%;
    width: 106%;
  }
  .p-rooms-detail__others-button {
    margin-top: 62px;
  }
}
@media screen and (max-width: 767px) {
  .p-rooms-detail__others {
    padding: 100px 0;
  }
  .p-rooms-detail__others-slider {
    margin-top: 44px;
  }
  .p-rooms-detail__others-button {
    margin-top: 42px;
  }
}
.p-rooms-detail__button {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 100;
  text-transform: uppercase;
  --button-height: 68px;
  --button-min-width: 100%;
  --button-color-bg: var(--color-dark-red);
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
.p-rooms-detail__button.is-hidden {
  opacity: 0;
  pointer-events: none;
}

html[lang=en] .p-rooms-detail__mv-title-ja,
html[lang=fr] .p-rooms-detail__mv-title-ja {
  display: none;
}