@charset "UTF-8";
/* コンテンツ最大幅 */
/* color */
/* ============================================ */
/* font-size */
/* ============================================ */
/* font-family */
/* ============================================ */
/* house */
/* ============================================ */
.house-wrapper {
  padding-bottom: 150px;
}
@media all and (max-width: 896px) {
  .house-wrapper {
    padding-bottom: 80px;
  }
}
.house-common__ttl__jp {
  font-family: "Noto Serif JP", serif;
  font-style: normal;
  font-size: clamp(1.625rem, -0.8194rem + 4.3651vw, 3rem);
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.04em;
}
.house-common__ttl__en {
  font-family: "Montserrat", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-size: clamp(0.75rem, 0.0833rem + 1.1905vw, 1.125rem);
  color: #747476;
  letter-spacing: 0.1em;
  margin-top: 16px;
}
@media all and (max-width: 896px) {
  .house-common__ttl__en {
    margin-top: 12px;
  }
}
.house-common__note {
  margin-top: 28px;
  line-height: 1.75;
}
@media all and (max-width: 896px) {
  .house-common__note {
    margin-top: 20px;
  }
}
.house-common__note.--white {
  color: #fff;
}
.house-common__note > li {
  position: relative;
  padding-left: 1.2em;
}
.house-common__note > li::before {
  content: "※";
  position: absolute;
  top: 0;
  left: 0;
}
.house-info {
  padding: 150px 0;
  background: url("../images/common/bg_02.jpg") top left/1026px auto repeat;
}
@media all and (max-width: 896px) {
  .house-info {
    padding: 64px 0 80px;
  }
}
.house-info__container + .house-info__container {
  margin-top: 150px;
}
@media all and (max-width: 896px) {
  .house-info__container + .house-info__container {
    margin-top: 80px;
  }
}
.house-info__inner {
  margin-right: calc(50% - 50vw);
  display: flex;
  gap: 42px 8.57cqw;
}
@media all and (max-width: 896px) {
  .house-info__inner {
    margin-right: 0;
    flex-direction: column;
  }
}
.house-info__inner.--reverse {
  flex-direction: row-reverse;
  margin-right: 0;
  margin-left: calc(50% - 50vw);
}
@media all and (max-width: 896px) {
  .house-info__inner.--reverse {
    margin-left: 0;
    flex-direction: column;
  }
}
.house-info__contents {
  flex-shrink: 0;
  width: 35.21cqw;
  min-width: 400px;
  padding-top: 48px;
}
@media all and (max-width: 896px) {
  .house-info__contents {
    width: 100%;
    min-width: inherit;
    padding-top: 0;
  }
}
.house-info__txt {
  line-height: 1.75;
  font-weight: 500;
  margin-top: 48px;
}
@media all and (max-width: 896px) {
  .house-info__txt {
    margin-top: 24px;
  }
}
.house-info__table {
  margin-top: 80px;
  font-size: clamp(0.9375rem, 0.6042rem + 0.5952vw, 1.125rem);
}
@media all and (max-width: 896px) {
  .house-info__table {
    margin-top: 24px;
  }
}
.house-info__table table {
  width: 100%;
  table-layout: fixed;
}
.house-info__table th, .house-info__table td {
  text-align: center;
  padding: 24px 12px;
  border: 1px solid #DADADA;
  font-weight: 700;
  line-height: 1.4;
}
@media all and (max-width: 896px) {
  .house-info__table th, .house-info__table td {
    padding: 12px 8px;
  }
}
.house-info__table th {
  background: #332727;
  color: #fff;
}
.house-info__table td {
  background: #fff;
}
.house-info__img {
  flex-grow: 1;
}
@media all and (max-width: 896px) {
  .house-info__img {
    margin-inline: calc(50% - 50vw);
  }
}
.house-info__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media all and (max-width: 896px) {
  .house-info__img img {
    aspect-ratio: 2/1;
  }
}
.house-room {
  margin-top: 80px;
}
@media all and (max-width: 896px) {
  .house-room {
    margin-top: 40px;
  }
}
.house-room__ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-style: normal;
  font-size: clamp(1.125rem, 0.4583rem + 1.1905vw, 1.5rem);
  font-weight: 500;
  letter-spacing: 0.04em;
  color: #8A9BCE;
  margin-bottom: 16px;
}
@media all and (max-width: 896px) {
  .house-room__ttl {
    margin-bottom: 12px;
  }
}
.house-room__list {
  border-top: 1px solid #2C2C66;
}
.house-room__list__item {
  display: flex;
  gap: 16px 3.57cqw;
  padding-block: 24px;
  border-bottom: 1px solid #BDBDBD;
}
@media all and (max-width: 896px) {
  .house-room__list__item {
    padding-block: 16px;
  }
}
@media all and (max-width: 480px) {
  .house-room__list__item {
    flex-direction: column;
  }
}
.house-room__list__item > dt {
  flex-shrink: 0;
  width: 10em;
  display: flex;
  align-items: center;
  gap: 1.25em;
  font-weight: 700;
}
@media all and (max-width: 480px) {
  .house-room__list__item > dt {
    width: 100%;
  }
}
.house-room__list__item > dt .icon {
  width: 1.875em;
}
.house-room__list__item > dd {
  word-break: keep-all;
}
@media all and (max-width: 480px) {
  .house-room__list__item > dd {
    width: 100%;
  }
}
.house-facility {
  padding: 150px 0;
  background: #fff;
}
@media all and (max-width: 896px) {
  .house-facility {
    padding: 64px 0 80px;
  }
}
.house-facility__list {
  font-family: "Noto Sans JP", sans-serif;
  font-style: normal;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 64px 40px;
  margin-top: 50px;
}
@media all and (max-width: 896px) {
  .house-facility__list {
    gap: 42px 24px;
    margin-top: 32px;
  }
}
@media all and (max-width: 480px) {
  .house-facility__list {
    grid-template-columns: repeat(1, 1fr);
  }
}
.house-facility__list__img img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 424/265;
}
.house-facility__list__ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-style: normal;
  font-size: clamp(1.125rem, 0.4583rem + 1.1905vw, 1.5rem);
  font-weight: 600;
  letter-spacing: 0.04em;
  color: #8A9BCE;
  margin-top: 16px;
}
@media all and (max-width: 896px) {
  .house-facility__list__ttl {
    margin-top: 12px;
  }
}
.house-facility__list__txt {
  line-height: 1.75;
  margin-top: 12px;
}
@media all and (max-width: 896px) {
  .house-facility__list__txt {
    margin-top: 8px;
  }
}
.house-price {
  background: #332727;
  padding-bottom: 80px;
}
.house-price__img {
  margin-inline: calc(50% - 50vw);
  position: relative;
}
.house-price__img::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, transparent 0%, rgba(0, 0, 0, 0.8));
  mix-blend-mode: multiply;
  position: absolute;
  top: 0;
  left: 0;
}
.house-price__img img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 1920/526;
}
@media all and (max-width: 896px) {
  .house-price__img img {
    aspect-ratio: 2/1;
  }
}
.house-price .house-common__ttl__jp {
  color: #fff;
  margin-top: -0.8em;
}
.house-price__container {
  position: relative;
  z-index: 10;
}
.house-price__inner {
  font-family: "Noto Sans JP", sans-serif;
  font-style: normal;
  display: flex;
  gap: 40px;
  margin-top: 50px;
}
@media all and (max-width: 896px) {
  .house-price__inner {
    flex-direction: column;
    margin-top: 32px;
  }
}
.house-price__ttl {
  display: flex;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 4px 10px;
  color: #fff;
}
.house-price__ttl__jp {
  font-size: clamp(1.125rem, 0.4583rem + 1.1905vw, 1.5rem);
  font-weight: 500;
  line-height: 1.4;
}
.house-price__table {
  margin-top: 20px;
}
@media all and (max-width: 896px) {
  .house-price__table {
    margin-top: 16px;
  }
}
.house-price__table table {
  width: 100%;
  table-layout: fixed;
}
.house-price__table th, .house-price__table td {
  text-align: center;
  vertical-align: middle;
  padding: 12px 8px;
  border: 1px solid #DADADA;
  font-weight: 700;
  line-height: 1.4;
  height: 82px;
}
@media all and (max-width: 896px) {
  .house-price__table th, .house-price__table td {
    height: auto;
  }
}
.house-price__table th {
  background: #000;
  color: #fff;
}
.house-price__table td {
  background: #fff;
  color: #000;
}
.house-price__table__sub {
  font-size: clamp(0.625rem, 0.1806rem + 0.7937vw, 0.875rem);
}
.house-stay {
  margin-top: 64px;
  padding-top: 90px;
  position: relative;
}
@media all and (max-width: 1025px) {
  .house-stay {
    margin-top: 40px;
    padding-top: 64px;
  }
}
@media all and (max-width: 896px) {
  .house-stay {
    padding-top: min(13.09vw, 120px);
  }
}
.house-stay__sub {
  width: min(20vw, 447px);
  position: absolute;
  top: 0;
  right: 0;
  z-index: 5;
}
@media all and (max-width: 896px) {
  .house-stay__sub {
    width: min(36vw, 320px);
  }
}
.house-stay__sub img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 894/650;
}
.house-stay__wrapper {
  max-width: 1620px;
  position: relative;
}
.house-stay__bg {
  margin-right: calc(50% - 50vw);
  width: calc(100% + 50vw - 50%);
  height: calc(100% - 64px);
  background: url("../images/common/bg.jpg") top left/965px auto repeat;
  position: absolute;
  top: 0;
  right: 0;
}
.house-stay__container {
  margin-inline: calc(50% - 50vw);
  padding-top: 150px;
  padding-right: calc(50vw - 50%);
  display: flex;
  flex-direction: row-reverse;
  justify-content: flex-end;
  align-items: center;
  gap: 40px min(7.29vw, 140px);
  position: relative;
  z-index: 10;
}
@media all and (max-width: 1025px) {
  .house-stay__container {
    padding-top: 120px;
    gap: 40px 5.46cqw;
  }
}
@media all and (max-width: 896px) {
  .house-stay__container {
    padding-top: calc(13.09vw + 32px);
    padding-right: 20px;
    flex-direction: column;
    align-items: flex-start;
  }
}
.house-stay__container .common-btn {
  margin-top: 32px;
}
@media all and (max-width: 896px) {
  .house-stay__container .common-btn {
    margin-top: 24px;
  }
}
.house-stay__inner {
  flex-grow: 1;
  max-width: 460px;
}
@media all and (max-width: 896px) {
  .house-stay__inner {
    padding-left: 40px;
    width: 100%;
  }
}
.house-stay__ttl {
  font-family: "Noto Serif JP", serif;
  font-style: normal;
  font-size: clamp(1.375rem, -0.4028rem + 3.1746vw, 2.375rem);
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0.04em;
  color: #8A9BCE;
}
.house-stay__block {
  margin-top: 28px;
}
.house-stay__block__ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-style: normal;
  font-size: clamp(1.25rem, -0.3056rem + 2.7778vw, 2.125rem);
  font-weight: 600;
  line-height: 1.4;
  color: #A7842E;
}
.house-stay__block__txt {
  margin-top: 16px;
}
@media all and (max-width: 896px) {
  .house-stay__block__txt {
    margin-top: 12px;
  }
}
.house-stay__contact {
  padding: 20px 3.14cqw;
  border: 1px solid #A7842E;
  margin-top: 32px;
}
@media all and (max-width: 896px) {
  .house-stay__contact {
    padding: 20px;
    margin-top: 24px;
    max-width: 600px;
  }
}
.house-stay__contact__ttl {
  text-align: center;
  width: 100%;
  padding: 0.6em 1.2em;
  border-radius: 9999px;
  background: #A7842E;
  font-family: "Noto Sans JP", sans-serif;
  font-style: normal;
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: 0.2em;
  color: #fff;
  margin-top: 10px;
}
.house-stay__contact__block {
  margin-inline: auto;
  inline-size: -webkit-fit-content;
  inline-size: -moz-fit-content;
  inline-size: fit-content;
}
.house-stay__contact__detail__item {
  display: flex;
  align-items: flex-end;
  gap: 0.5em;
  font-family: "Montserrat", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 500;
  line-height: 1.4;
}
.house-stay__contact__detail__item dt {
  flex-shrink: 0;
  margin-bottom: 0.4em;
  font-size: clamp(0.875rem, 0.5417rem + 0.5952vw, 1.0625rem);
}
.house-stay__contact__detail__item dd .txt_number {
  font-size: clamp(1.375rem, -0.1806rem + 2.7778vw, 2.25rem);
  font-weight: 500;
  letter-spacing: 0.1em;
}
.house-stay__contact__mail {
  font-family: "Montserrat", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-size: clamp(1rem, 0.1111rem + 1.5873vw, 1.5rem);
  font-weight: 500;
  margin-top: 5px;
  margin-inline: auto;
  inline-size: -webkit-fit-content;
  inline-size: -moz-fit-content;
  inline-size: fit-content;
}
.house-stay__note {
  font-size: clamp(0.75rem, 0.5278rem + 0.3968vw, 0.875rem);
  margin-top: 12px;
}
@media all and (max-width: 896px) {
  .house-stay__note {
    margin-top: 10px;
  }
}
.house-stay__note > li {
  position: relative;
  padding-left: 1.2em;
}
.house-stay__note > li::before {
  content: "※";
  position: absolute;
  top: 0;
  left: 0;
}
.house-stay__img {
  flex-shrink: 0;
  width: 55.36vw;
}
@media all and (max-width: 896px) {
  .house-stay__img {
    width: 100%;
    max-width: 720px;
  }
}
.house-stay__img img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 1063/726;
}