@charset "UTF-8";

/* MONICA 2026 page-specific styles */
.monica-intro {
  padding-top: 80px;
}
@media only screen and (max-width: 768px) {
  .monica-intro {
    padding-top: 60px;
  }
}

.monica-intro__inner {
  width: min(100% - 50px, 1100px);
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .monica-intro__inner {
    width: min(100% - 30px, 1100px);
  }
}

.monica-intro__heading {
  text-align: center;
}

.monica-intro__brand {
  font-family: "FP-HiraKakuProN-W6";
  font-style: normal;
  font-weight: 400;
  font-size: 2rem;
  color: #222222;
  letter-spacing: 0.02em;
  line-height: 1.6;
  font-size: 1.6rem;
}
@media screen and (min-width: 320px) {
  .monica-intro__brand {
    font-size: calc(0.8928571429vw + 13.1428571429px);
  }
}
@media screen and (min-width: 768px) {
  .monica-intro__brand {
    font-size: 2rem;
  }
}

.monica-intro__catch {
  margin-top: 16px;
  font-family: "FP-HiraKakuProN-W6";
  font-style: normal;
  font-weight: 600;
  font-size: 2.4rem;
  color: #222222;
  letter-spacing: 0.05em;
  line-height: 1.6;
  font-size: 2rem;
}
.monica-intro__catch span {
  display: inline-block;
}
@media screen and (min-width: 320px) {
  .monica-intro__catch {
    font-size: calc(0.8928571429vw + 17.1428571429px);
  }
}
@media screen and (min-width: 768px) {
  .monica-intro__catch {
    font-size: 2.4rem;
  }
}

.monica-intro__figure {
  margin-top: 34px;
}

.monica-intro__image {
  display: block;
  width: 100%;
  height: auto;
}

.monica-intro__text {
  margin-top: 36px;
}

.monica-intro__lead {
  font-family: "FP-HiraKakuProN-W6";
  font-style: normal;
  font-weight: 600;
  font-size: 1.8rem;
  color: #222222;
  letter-spacing: 0.02em;
  line-height: 1.8;
  font-size: 1.6rem;
}
@media screen and (min-width: 320px) {
  .monica-intro__lead {
    font-size: calc(0.8928571429vw + 13.1428571429px);
  }
}
@media screen and (min-width: 768px) {
  .monica-intro__lead {
    font-size: 2rem;
  }
}

.monica-intro__body {
  margin-top: 8px;
  font-style: normal;
  font-weight: 300;
  font-size: 1.6rem;
  color: #222222;
  letter-spacing: 0.04em;
  line-height: 1.9;
  font-size: 1.4rem;
}
@media screen and (min-width: 320px) {
  .monica-intro__body {
    font-size: calc(0.4464285714vw + 12.5714285714px);
  }
}
@media screen and (min-width: 768px) {
  .monica-intro__body {
    font-size: 1.6rem;
  }
}

.monica-stay-showroom {
  padding-top: 90px;
}
@media only screen and (max-width: 768px) {
  .monica-stay-showroom {
    padding-top: 60px;
  }
}

.monica-stay-showroom__inner {
  width: min(100% - 50px, 1100px);
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .monica-stay-showroom__inner {
    width: min(100% - 30px, 1100px);
  }
}

.monica-stay-showroom__figure {
  max-width: 430px;
  margin-inline: auto;
}

.monica-stay-showroom__image {
  display: block;
  width: 100%;
  height: auto;
}

.monica-stay-showroom__text {
  margin-top: 40px;
}

.monica-stay-showroom__title {
  font-family: "FP-HiraKakuProN-W6";
  font-style: normal;
  font-weight: 600;
  font-size: 1.8rem;
  color: #222222;
  letter-spacing: 0.02em;
  line-height: 1.8;
  font-size: 1.6rem;
}
@media screen and (min-width: 320px) {
  .monica-stay-showroom__title {
    font-size: calc(0.8928571429vw + 13.1428571429px);
  }
}
@media screen and (min-width: 768px) {
  .monica-stay-showroom__title {
    font-size: 2rem;
  }
}

.monica-stay-showroom__body {
  margin-top: 12px;
  font-style: normal;
  font-weight: 300;
  font-size: 1.6rem;
  color: #222222;
  letter-spacing: 0.04em;
  line-height: 1.9;
  font-size: 1.4rem;
}
@media screen and (min-width: 320px) {
  .monica-stay-showroom__body {
    font-size: calc(0.4464285714vw + 12.5714285714px);
  }
}
@media screen and (min-width: 768px) {
  .monica-stay-showroom__body {
    font-size: 1.6rem;
  }
}

.monica-feature-heading {
  padding-top: 100px;
}
@media only screen and (max-width: 768px) {
  .monica-feature-heading {
    padding-top: 70px;
  }
}

.monica-feature-heading__inner {
  width: min(100% - 50px, 1100px);
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .monica-feature-heading__inner {
    width: min(100% - 30px, 1100px);
  }
}

.monica-feature-heading__title {
  font-family: "FP-HiraKakuProN-W6";
  font-style: normal;
  font-weight: 600;
  font-size: 2.4rem;
  color: #222222;
  letter-spacing: 0.05em;
  line-height: 1.6;
  text-align: center;
  font-size: 2rem;
}
@media screen and (min-width: 320px) {
  .monica-feature-heading__title {
    font-size: calc(0.8928571429vw + 17.1428571429px);
  }
}
@media screen and (min-width: 768px) {
  .monica-feature-heading__title {
    font-size: 2.4rem;
  }
}

.monica-feature-title {
  font-family: "FP-HiraKakuProN-W6";
  font-style: normal;
  font-weight: 600;
  font-size: 2rem;
  color: #222222;
  letter-spacing: 0.03em;
  line-height: 1.6;
  font-size: 1.6rem;
}
@media screen and (min-width: 320px) {
  .monica-feature-title {
    font-size: calc(0.8928571429vw + 13.1428571429px);
  }
}
@media screen and (min-width: 768px) {
  .monica-feature-title {
    font-size: 2rem;
  }
}

.monica-feature-living {
  padding-top: 60px;
}
@media only screen and (max-width: 768px) {
  .monica-feature-living {
    padding-top: 40px;
  }
}

.monica-feature-living__inner {
  width: min(100% - 50px, 1100px);
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .monica-feature-living__inner {
    width: min(100% - 30px, 1100px);
  }
}

.monica-feature-living__body {
  margin-top: 18px;
  font-style: normal;
  font-weight: 300;
  font-size: 1.6rem;
  color: #222222;
  letter-spacing: 0.04em;
  line-height: 1.9;
  font-size: 1.4rem;
}
@media screen and (min-width: 320px) {
  .monica-feature-living__body {
    font-size: calc(0.4464285714vw + 12.5714285714px);
  }
}
@media screen and (min-width: 768px) {
  .monica-feature-living__body {
    font-size: 1.6rem;
  }
}

.monica-feature-living__images {
  display: flex;
  gap: 25px;
  margin-top: 38px;
}
@media only screen and (max-width: 768px) {
  .monica-feature-living__images {
    flex-direction: column;
    gap: 20px;
    margin-top: 28px;
  }
}

.monica-feature-living__figure {
  flex: 1 1 0;
}

.monica-feature-living__image {
  display: block;
  width: 100%;
  height: auto;
}

.monica-feature-garden {
  padding-top: 80px;
}
@media only screen and (max-width: 768px) {
  .monica-feature-garden {
    padding-top: 60px;
  }
}

.monica-feature-garden__inner {
  width: min(100% - 50px, 1100px);
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .monica-feature-garden__inner {
    width: min(100% - 30px, 1100px);
  }
}

.monica-feature-garden__body {
  margin-top: 18px;
  font-style: normal;
  font-weight: 300;
  font-size: 1.6rem;
  color: #222222;
  letter-spacing: 0.04em;
  line-height: 1.9;
  font-size: 1.4rem;
}
@media screen and (min-width: 320px) {
  .monica-feature-garden__body {
    font-size: calc(0.4464285714vw + 12.5714285714px);
  }
}
@media screen and (min-width: 768px) {
  .monica-feature-garden__body {
    font-size: 1.6rem;
  }
}

.monica-feature-garden__images {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 25px;
  margin-top: 28px;
}
@media only screen and (max-width: 768px) {
  .monica-feature-garden__images {
    flex-direction: column;
    align-items: center;
    gap: 20px;
  }
}

.monica-feature-garden__figure {
  flex: 0 1 auto;
}

.monica-feature-garden__image {
  display: block;
  width: auto;
  max-width: 100%;
  height: min(37vw, 480px);
  object-fit: contain;
}
@media only screen and (max-width: 768px) {
  .monica-feature-garden__image {
    width: 100%;
    height: auto;
  }
}

.monica-feature-bedroom {
  padding-top: 80px;
}
@media only screen and (max-width: 768px) {
  .monica-feature-bedroom {
    padding-top: 60px;
  }
}

.monica-feature-bedroom__inner {
  width: min(100% - 50px, 1100px);
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .monica-feature-bedroom__inner {
    width: min(100% - 30px, 1100px);
  }
}

.monica-feature-bedroom__body {
  margin-top: 18px;
  font-style: normal;
  font-weight: 300;
  font-size: 1.6rem;
  color: #222222;
  letter-spacing: 0.04em;
  line-height: 1.9;
  font-size: 1.4rem;
}
@media screen and (min-width: 320px) {
  .monica-feature-bedroom__body {
    font-size: calc(0.4464285714vw + 12.5714285714px);
  }
}
@media screen and (min-width: 768px) {
  .monica-feature-bedroom__body {
    font-size: 1.6rem;
  }
}

.monica-feature-bedroom__images {
  display: flex;
  justify-content: center;
  gap: 28px;
  margin-top: 28px;
  position: relative;
  z-index: 0;
}
.monica-feature-bedroom__images::before {
  content: "";
  display: block;
  width: 100vw;
  height: 54px;
  background-color: #f2eee8;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
}
@media only screen and (max-width: 768px) {
  .monica-feature-bedroom__images {
    flex-direction: column;
    align-items: center;
    gap: 20px;
  }

  .monica-feature-bedroom__images::before {
    height: 36px;
  }
}

.monica-feature-bedroom__figure {
  flex: 0 1 auto;
  text-align: center;
}

.monica-feature-bedroom__image {
  display: block;
  width: auto;
  max-width: 100%;
  height: 520px;
  margin-inline: auto;
  object-fit: contain;
}
@media only screen and (max-width: 768px) {
  .monica-feature-bedroom__image {
    width: 100%;
    height: auto;
  }
}

.monica-visit-notice {
  padding-top: 100px;
}
@media only screen and (max-width: 768px) {
  .monica-visit-notice {
    padding-top: 70px;
  }
}

.monica-visit-notice__inner {
  width: min(100% - 50px, 1100px);
  margin-inline: auto;
  padding: 56px 60px;
  background-color: #f4f3f0;
  border-radius: 18px;
}
@media only screen and (max-width: 768px) {
  .monica-visit-notice__inner {
    width: min(100% - 30px, 1100px);
    padding: 36px 24px;
    border-radius: 12px;
  }
}

.monica-visit-notice__block {
  padding-bottom: 46px;
  border-bottom: 1px solid #cfcac2;
}

.monica-visit-notice__stay {
  padding-top: 46px;
}

.monica-visit-notice__title {
  font-family: "FP-HiraKakuProN-W6";
  font-style: normal;
  font-weight: 600;
  font-size: 2rem;
  color: #222222;
  letter-spacing: 0.03em;
  line-height: 1.6;
  font-size: 1.6rem;
}
@media screen and (min-width: 320px) {
  .monica-visit-notice__title {
    font-size: calc(0.8928571429vw + 13.1428571429px);
  }
}
@media screen and (min-width: 768px) {
  .monica-visit-notice__title {
    font-size: 2rem;
  }
}

.monica-visit-notice__lead {
  display: inline-block;
  margin-top: 32px;
  background: linear-gradient(transparent 25%, #fff36a 25%);
  font-family: "FP-HiraKakuProN-W6";
  font-style: normal;
  font-weight: 600;
  font-size: 1.8rem;
  color: #222222;
  letter-spacing: 0.03em;
  line-height: 1.7;
  font-size: 1.5rem;
}
@media screen and (min-width: 320px) {
  .monica-visit-notice__lead {
    font-size: calc(0.6696428571vw + 12.8571428571px);
  }
}
@media screen and (min-width: 768px) {
  .monica-visit-notice__lead {
    font-size: 1.8rem;
  }
}

.monica-visit-notice__body,
.monica-visit-notice__note {
  margin-top: 28px;
  font-style: normal;
  font-weight: 300;
  font-size: 1.6rem;
  color: #222222;
  letter-spacing: 0.04em;
  line-height: 1.9;
  font-size: 1.4rem;
}
@media screen and (min-width: 320px) {
  .monica-visit-notice__body,
  .monica-visit-notice__note {
    font-size: calc(0.4464285714vw + 12.5714285714px);
  }
}
@media screen and (min-width: 768px) {
  .monica-visit-notice__body,
  .monica-visit-notice__note {
    font-size: 1.6rem;
  }
}

.monica-visit-notice__time {
  margin-top: 28px;
  font-family: "FP-HiraKakuProN-W6";
  font-style: normal;
  font-weight: 600;
  font-size: 2rem;
  color: #222222;
  letter-spacing: 0.03em;
  line-height: 1.6;
  font-size: 1.6rem;
}
@media screen and (min-width: 320px) {
  .monica-visit-notice__time {
    font-size: calc(0.8928571429vw + 13.1428571429px);
  }
}
@media screen and (min-width: 768px) {
  .monica-visit-notice__time {
    font-size: 2rem;
  }
}

.monica-visit-notice__button-wrap {
  margin-top: 32px;
}

.monica-visit-notice__reserve-buttons {
  display: flex;
  gap: 18px;
  margin-top: 32px;
}
@media only screen and (max-width: 768px) {
  .monica-visit-notice__reserve-buttons {
    flex-direction: column;
  }
}

.monica-visit-notice__button {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-width: 258px;
  min-height: 58px;
  padding: 0.8em 2.2em;
  border: 1px solid #c2a979;
  background-color: #ffffff;
  font-family: "FP-HiraKakuProN-W6";
  font-style: normal;
  font-weight: 600;
  font-size: 1.6rem;
  color: #222222;
  letter-spacing: 0.05em;
  line-height: 1.6;
  text-decoration: none;
  transition:
    background-color 0.3s ease,
    color 0.3s ease;
  font-size: 1.4rem;
}
@media screen and (min-width: 320px) {
  .monica-visit-notice__button {
    font-size: calc(0.4464285714vw + 12.5714285714px);
  }
}
@media screen and (min-width: 768px) {
  .monica-visit-notice__button {
    font-size: 1.6rem;
  }
}
.monica-visit-notice__button:hover {
  background-color: #c2a979;
  color: #ffffff;
}

.monica-night-appeal {
  padding-top: 80px;
}
@media only screen and (max-width: 768px) {
  .monica-night-appeal {
    padding-top: 60px;
  }
}

.monica-night-appeal__inner {
  width: min(100% - 50px, 1100px);
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .monica-night-appeal__inner {
    width: min(100% - 30px, 1100px);
  }
}

.monica-night-appeal__figure {
  margin-inline: auto;
}

.monica-night-appeal__image {
  display: block;
  width: 100%;
  height: auto;
}

.monica-night-appeal__body {
  margin-top: 36px;
  font-style: normal;
  font-weight: 300;
  font-size: 1.6rem;
  color: #222222;
  letter-spacing: 0.04em;
  line-height: 1.9;
  font-size: 1.4rem;
}
@media screen and (min-width: 320px) {
  .monica-night-appeal__body {
    font-size: calc(0.4464285714vw + 12.5714285714px);
  }
}
@media screen and (min-width: 768px) {
  .monica-night-appeal__body {
    font-size: 1.6rem;
  }
}

@media only screen and (max-width: 768px) {
  .monica-intro__catch {
    margin-top: 12px;
  }

  .monica-intro__figure {
    margin-top: 28px;
  }

  .monica-intro__text,
  .monica-stay-showroom__text {
    margin-top: 28px;
  }
}
