/* Default Options */
/* Media Query */
/**
 * Media Query Mixin
 * @param {string} $mq  - min | max | min-max
 * @param {string} $bp1 - breakpoint key (e.g. "lg")
 * @param {string} $bp2 - breakpoint key (e.g. "xl") for min-max upper bound
 */
/* Transform Font Size */
/* --------------------------------- */
@media screen and (min-width: 992px) {
  .l-contents.detail {
    display: grid;
    grid-template-columns: var(--grid-column-guide);
    column-gap: var(--grid-gap);
  }
}

/* --------------------------------- */
.p-rooms-map {
  max-width: 960px;
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  row-gap: var(--space-xs);
}
.p-rooms-map .list {
  padding-inline: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  column-gap: var(--space-xxs);
  row-gap: 10px;
}
.p-rooms-map .list li {
  display: grid;
  grid-template-columns: clamp(20px, 2vw, 24px) auto;
  column-gap: 5px;
  align-items: center;
}
.p-rooms-map .list li .number {
  aspect-ratio: 1/1;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: var(--text-color);
  border-radius: 3px;
  font-weight: 500;
  line-height: 1;
  color: var(--bg-color);
}
.p-rooms-list {
  display: flex;
  flex-direction: column;
  row-gap: var(--space-md);
}
.p-rooms-list .item a {
  display: flex;
  flex-direction: column;
  row-gap: var(--space-xxs);
  text-decoration: none;
}
.p-rooms-list .item a .image {
  margin-block-end: var(--space-xxs);
  border-radius: var(--space-xxs);
  overflow: hidden;
  transition: var(--hover-animation-speed);
}
.p-rooms-list .item a .title {
  margin-block-end: 10px;
  display: flex;
  flex-direction: column;
  row-gap: clamp(5px, 0.5vw, 10px);
  line-height: 1.2;
}
.p-rooms-list .item a .spec {
  color: rgba(0, 0, 0, 0.7);
}
.p-rooms-list .item a .c-more {
  margin-block-start: var(--space-xs);
}
.p-rooms-list .item a .c-more .u-txt-size-sm {
  font-weight: 500;
}
.p-rooms-list .item a:hover .image {
  opacity: 0.7;
}
.p-rooms-header {
  margin-block-end: var(--space-md);
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-inline: 10px;
}
.p-rooms-header .inner {
  padding-inline: var(--space-md);
  display: flex;
  flex-direction: column;
  justify-content: center;
  row-gap: var(--space-xxs);
  line-height: 1.4;
}
.p-rooms-header .inner .name {
  font-size: clamp(0.875rem, 0.5681818182rem + 0.8522727273vw, 1.25rem);
  font-weight: 600;
}
.p-rooms-header .inner .type {
  font-size: clamp(1.25rem, 0.2272727273rem + 2.8409090909vw, 2.5rem);
}
.p-rooms-header .image {
  width: 100%;
  aspect-ratio: 1/1;
  border-radius: var(--space-xs);
  overflow: hidden;
}
.p-rooms-header .image picture,
.p-rooms-header .image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.p-rooms-contents {
  display: flex;
  flex-direction: column;
  row-gap: var(--space-sm);
}
.p-rooms-contents .intro {
  font-size: clamp(1.25rem, 0.7386363636rem + 1.4204545455vw, 1.875rem);
  font-weight: 600;
  line-height: 1.6;
}
.p-rooms-contents .intro br {
  display: none;
}
.p-rooms-contents .image {
  border-radius: var(--space-xxs);
  overflow: hidden;
}
.p-rooms-contents .imagelist {
  display: flex;
  flex-direction: column;
  row-gap: var(--space-xxs);
}
.p-rooms-contents .imagelist .item {
  border-radius: var(--space-xxs);
  overflow: hidden;
}
.p-rooms-contents .reserve {
  width: 100%;
  max-width: 700px;
  margin-inline: auto;
}
.p-rooms-contents .reserve a {
  width: 100%;
  height: clamp(100px, 10vw, 120px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  border: 1px solid var(--text-color);
  text-decoration: none;
  border-radius: var(--space-xxs);
  line-height: 1.6;
  transition: var(--hover-animation-speed);
}
.p-rooms-contents .reserve a span {
  font-weight: 600;
}
.p-rooms-contents .reserve a p {
  font-weight: 500;
}
.p-rooms-contents .reserve a:hover {
  background-color: rgba(0, 0, 0, 0.1);
}
.p-rooms-section {
  display: flex;
  flex-direction: column;
  row-gap: var(--space-xxs);
}
.p-rooms-section-title {
  font-weight: 600;
  line-height: 1.6;
}
.p-rooms-textlist {
  padding: 0;
  list-style: none;
  border-block-start: 1px solid rgba(0, 0, 0, 0.15);
}
.p-rooms-textlist li {
  padding-block: var(--space-xs);
  display: flex;
  flex-direction: column;
  row-gap: 10px;
  border-block-end: 1px solid rgba(0, 0, 0, 0.15);
  line-height: 1.6;
}
.p-rooms-textlist li .title {
  font-weight: 600;
}
@media screen and (min-width: 768px) {
  .p-rooms-list {
    max-width: 1600px;
    margin-inline: auto;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: var(--space-md);
    row-gap: 0;
  }
  .p-rooms-list .item:nth-child(2n) {
    padding-block-start: var(--space-xl);
  }
}
@media screen and (min-width: 992px) {
  .p-rooms-header {
    height: 100vh;
    padding-inline: 0;
    padding-block: var(--space-sm);
    box-sizing: border-box;
    position: relative;
  }
  .p-rooms-header .inner {
    padding-inline: 0;
    position: absolute;
    right: var(--space-sm);
    bottom: calc(var(--space-sm) * 2);
    z-index: 1;
    color: var(--bg-color);
  }
  .p-rooms-header .image {
    height: calc(100vh - var(--space-sm) * 2);
    position: relative;
    z-index: 0;
  }
  .p-rooms-contents {
    grid-column: 1/9;
    row-gap: var(--space-md);
  }
  .p-rooms-contents .intro br {
    display: block;
  }
  .p-rooms-contents .imagelist {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: var(--grid-gap);
  }
  .p-rooms-textlist li {
    display: grid;
    grid-template-columns: repeat(8, 1fr);
    column-gap: var(--grid-gap);
  }
  .p-rooms-textlist li .title {
    grid-column: 1/3;
  }
  .p-rooms-textlist li p {
    grid-column: 3/9;
  }
}

/* --------------------------------- */