@charset "utf-8";

/* 一覧ページ */

.view {
  padding-block: 150px 0;
}
.view__enheading {
  --margin-bottom: calc(40 / 150 * -1em);
}
/* .view__heading {
} */
.view__copy {
  --margin-top: 60px;
}
.view__view {
  position: relative;
  z-index: 1;
  margin-top: 150px;
}
.view__view__bg {
  position: relative;
  z-index: 1;
  height: 100lvh;
  overflow: hidden;
}
.view__view__bg::before {
  content: "";
  position: absolute;
  z-index: 1;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 30%;
  background: linear-gradient(0deg, rgba(255, 255, 255, .5) 0%, rgba(255, 255, 255, 0) 100%);
}
.view__view__bg img {
  height: 100%;
  object-fit: cover;
}
.view__view__photo {
  position: absolute;
  z-index: 1;
  bottom: 30px;
  left: 50%;
  translate: -50%;
  width: min(95%, 800px);
  height: calc(100% - 165px - 30px);
}
.view__view__photo .photo {
  height: 100%;
}
.view__view__photo .photo img {
  height: 100%;
  object-fit: contain;
  object-position: top center;
}
@media screen and (max-width: 767px){
  .view {
    padding-block: 60px 0;
  }
  .view__enheading {
    --margin-bottom: 40px;
  }
  .view__copy {
    --margin-top: 40px;
  }
  .view__view {
    margin-top: 65px;
  }
  .view__view__photo {
    bottom: 50%;
    translate: -50% 50%;
    width: calc(300 / 380 * 100%);
    height: auto
  }
}



.plan {
  padding-block: 150px 0;
}
/* .plan__heading {
} */
.plan__copy {
  --margin-top: 60px;
}
.plan__content {
  margin-top: 150px;
}
.plan__content__floor {
  max-width: 1500px;
  grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
  align-items: stretch;
}
.plan__content__floor__item {
  position: relative;
  z-index: 1;
  width: 100%;
  box-sizing: border-box;
  padding: 38px 30px;
  grid-template-columns: repeat(auto-fit, minmax(0, auto));
  justify-content: center;
  align-items: center;
  gap: 22px;
}
.plan__content__floor__item::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: calc(100% + 28px);
  clip-path: polygon(0% 0%, 100% 0%, 100% calc(100% - 28px), 0% calc(100% - 28px));
}
.plan__content__floor__item[data-tab-selected="true"]::before {
  clip-path: polygon(0% 0%, 100% 0%, 100% calc(100% - 28px), calc(50% + 16px) calc(100% - 28px), 50% 100%, calc(50% - 16px) calc(100% - 28px), 0% calc(100% - 28px));
}
.plan__content__floor__item--normal::before {
  background: linear-gradient(135deg, rgba(153, 153, 153, 1) 0%, rgba(51, 51, 51, 1) 100%);
}
.plan__content__floor__item--premium::before {
  background: linear-gradient(135deg, rgba(0, 99, 176, 1) 0%, rgba(var(--color-navy), 1) 100%);
}
.plan__content__floor__item__copy {
  font-size: clamp(14px, calc(24 / 1200 * 100vw), 24px);
}
.plan__content__floor__item__heading {
  font-size: clamp(20px, calc(40 / 1200 * 100vw), 40px);
}
.plan__content__group {
  padding-block: 150px 200px;
}
.plan__content__group__enheading {
  font-size: clamp(16px, calc(26 / 1200 * 100vw), 26px);
  color: #8096B8;
}
.plan__content__group__heading {
  --margin-top: 40px;
  --margin-bottom: 80px;
}
.plan__content__group__filter {
  margin-bottom: 150px;
  grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
  align-items: stretch;
  gap: 40px;
}
.plan__content__group__filter__item {
  width: 100%;
  min-height: calc(80 / 30 * 1em);
  place-items: center;
  box-sizing: border-box;
  padding: .5em;
  font-size: clamp(20px, calc(30 / 1200 * 100vw), 30px);
  background: rgba(var(--color-navy), .5);
  background: color-mix(in srgb, rgb(var(--color-navy)) 50%, #fff 50%);
  cursor: pointer;
  -webkit-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  transition: background .5s ease-out;
}
.plan__content__group__filter__item--active {
  background: rgb(var(--color-navy));
}
.plan__content__group__filter__item em {
  font-size: calc(40 / 30 * 100%);
}
.plan__content__group__filter__item .two {
  display: inline-block;
  width: 0;
  height: 0;
  translate: -.5em -1.25em;
  font-size: 35%;
}
.plan__content__group__list {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: stretch;
  gap: 0 45px;
  margin-bottom: calc(-60px + 40px);
}
.plan__content__group__list__item {
  grid-template-columns: 100%;
  grid-template-rows: subgrid;
  grid-row: span 3;
  align-items: stretch;
  gap: 0;
  margin-bottom: 60px;
  display: none;
}
.plan__content__group__list__item--active {
  display: grid;
  animation: tabFadein 1s;
}
/* .plan__content__group__list__item__status {
} */
.plan__content__group__list__item__status__item {
  flex: 0 1 auto;
  box-sizing: border-box;
  padding: .5em;
  font-size: clamp(11px, calc(14 / 1200 * 100vw), 14px);
  color: #fff;
  background: rgb(var(--color-blue));
}
.plan__content__group__list__item__status__item__copy {
  line-height: 1.2;
}
.plan__content__group__list__item__link {
  grid-template-columns: minmax(0, calc(40 / 24 * 1em)) minmax(0, auto) minmax(0, calc(30 / 24 * 1em)) minmax(0, 1fr) minmax(0, calc(40 / 24 * 1em));
  grid-template-rows: calc(40 / 24 * 1em) auto auto auto 30px 1fr 30px auto;
  box-sizing: border-box;
  /* border: 1px solid rgb(var(--color-darknavy)); */
  font-size: clamp(14px, calc(24 / 1200 * 100vw), 24px);
  /* color: rgb(var(--color-darknavy));
  background: #fff;
  transition: background .5s ease-out; */

  color: #fff;
  background: linear-gradient(135deg, rgba(var(--color-navy2), 1) 0%, rgba(var(--color-darknavy), 1) 100%);
  transition: opacity .5s ease-out;
}
.plan__content__group__list__item__link__type {
  grid-column: 2;
  grid-row: 2 / 5;
  min-width: calc(100 / 24 * 1em);
  box-sizing: border-box;
  border-right: 1px solid currentColor;
  grid-template-columns: auto;
  justify-content: start;
  justify-items: center;
  align-content: center;
  gap: calc(15 / 24 * 1em) 0;
  font-size: calc(24 / 24 * 100%);
}
.plan__content__group__list__item__link__type em {
  font-size: calc(45 / 24 * 100%);
  line-height: 1;
  line-height: 1cap;
}
.plan__content__group__list__item__link__type small {
  font-size: calc(14 / 24 * 100%);
}
.plan__content__group__list__item__link__floor {
  grid-column: 4;
  grid-row: 2;
  font-size: calc(20 / 24 * 100%);
  --margin-top: calc(10 / 20 * 1em);
}
.plan__content__group__list__item__link__layout {
  grid-column: 4;
  grid-row: 3;
  align-items: baseline;
  gap: .25em 0;
  font-size: calc(24 / 24 * 100%);
  margin-top: calc(20 / 24 * 1em);
}
/* .plan__content__group__list__item__link__layout__ldk {
} */
.plan__content__group__list__item__link__layout__ldk em {
  font-size: calc(34 / 24 * 100%);
}
/* .plan__content__group__list__item__link__layout__storage {
} */
.plan__content__group__list__item__link__layout__storage::before {
  content: "+";
  display: inline-block;
  translate: 0 -.1em;
}
.plan__content__group__list__item__link__size {
  grid-column: 4;
  grid-row: 4;
  font-size: calc(12 / 24 * 100%);
  margin-top: calc(15 / 12 * 1em);
  margin-bottom: calc(10 / 12 * 1em);
}
.plan__content__group__list__item__link__size__item {
  align-items: baseline;
  gap: .5em;
}
/* .plan__content__group__list__item__link__size__item__name {
}
.plan__content__group__list__item__link__size__item__data {
} */
.plan__content__group__list__item__link__size__item__data em {
  font-size: calc(24 / 12 * 100%);
  vertical-align: -.02em;
}
.plan__content__group__list__item__link__size__item__data .two {
  display: inline-block;
  width: 0;
  height: 0;
  translate: -.5em -1.25em;
  font-size: 35%;
}
.plan__content__group__list__item__link__madori {
  grid-column: 1 / 6;
  grid-row: 6;
}
.plan__content__group__list__item__link__madori__figure {
  width: 100%;
  height: 100%;
  place-items: center;
}
.plan__content__group__list__item__link__more {
  grid-column: 1 / 6;
  grid-row: 8;
  width: 100%;
  box-sizing: border-box;
  padding: 20px;
  /* background: linear-gradient(135deg, rgba(var(--color-navy2), 1) 0%, rgba(var(--color-darknavy), 1) 100%); */

  background: linear-gradient(135deg, rgba(102, 130, 170, 1) 0%, rgba(0, 46, 114, 1) 100%);
}
/* .plan__content__group__list__item__link__more__name {
}
.plan__content__group__list__item__link__more__icon {
} */
.plan__content__group__caution {
  --margin-top: 40px;
}
.plan__content__group__caution:empty {
  display: none;
}
@media (any-hover: hover) {
  .plan__content__group__filter__item:hover {
    background: rgb(var(--color-navy));
  }
  .plan__content__group__list__item__link:hover {
    /* background: rgba(var(--color-darknavy), .05); */

    opacity: .7;
  }
}
@media screen and (min-width: 768px) and (max-width: 1200px) {
  .plan__content__group__list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media screen and (max-width: 767px){
  .plan {
    padding-block: 60px 0;
  }
  .plan__copy {
    --margin-top: 40px;
  }
  .plan__content {
    margin-top: 40px;
  }
  .plan__content__floor__item {
    padding: 14px 10px;
    grid-template-columns: auto;
    gap: 14px 0;
  }
  .plan__content__floor__item::before {
    height: calc(100% + 18px);
    clip-path: polygon(0% 0%, 100% 0%, 100% calc(100% - 18px), 0% calc(100% - 18px));
  }
  .plan__content__floor__item[data-tab-selected="true"]::before {
    clip-path: polygon(0% 0%, 100% 0%, 100% calc(100% - 18px), calc(50% + 10px) calc(100% - 18px), 50% 100%, calc(50% - 10px) calc(100% - 18px), 0% calc(100% - 18px));
  }
  .plan__content__floor__item__copy {
    font-size: 14px;
  }
  .plan__content__floor__item__heading {
    font-size: 28px;
  }
  .plan__content__group {
    padding-block: 60px;
  }
  .plan__content__group__enheading {
    font-size: 14px;
  }
  .plan__content__group__heading {
    --margin-top: 25px;
    --margin-bottom: 40px;
  }
  .plan__content__group__filter {
    margin-bottom: 40px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }
  .plan__content__group__filter__item {
    min-height: calc(44 / 18 * 1em);
    font-size: 18px;
  }
  .plan__content__group__filter__item em {
    font-size: calc(28 / 18 * 100%);
  }
  .plan__content__group__list {
    grid-template-columns: 100%;
    gap: 0;
    margin-bottom: calc(-30px + 30px);
  }
  .plan__content__group__list__item {
    margin-bottom: 30px;
  }
  .plan__content__group__list__item__status__item {
    font-size: 12px;
  }
  .plan__content__group__list__item__link {
    grid-template-columns: minmax(0, 30px) minmax(0, 1fr) minmax(0, 20px) minmax(0, auto) minmax(0, 30px);
    grid-template-rows: 30px auto auto auto auto auto;
    font-size: 18px;
    align-items: end;
  }
  .plan__content__group__list__item__link__type {
    grid-column: 2;
    grid-row: 2 / 3;
    min-width: 0;
    border-right: none;
    grid-template-columns: auto auto;
    justify-items: start;
    align-content: start;
    align-items: baseline;
    gap: calc(5 / 18 * 1em);
    font-size: calc(18 / 18 * 100%);
  }
  .plan__content__group__list__item__link__type em {
    font-size: calc(32 / 18 * 100%);
  }
  .plan__content__group__list__item__link__type small {
    grid-column: 1 / 3;
    font-size: calc(12 / 18 * 100%);
  }
  .plan__content__group__list__item__link__floor {
    font-size: calc(18 / 18 * 100%);
    --margin-top: 0px;
  }
  .plan__content__group__list__item__link__layout {
    grid-column: 2 / 5;
    font-size: calc(22 / 18 * 100%);
    margin-top: calc(20 / 22 * 1em);
    border-top: 1px solid currentColor;
    padding-top: calc(25 / 22 * 1em);
  }
  .plan__content__group__list__item__link__layout__ldk em {
    font-size: calc(32 / 22 * 100%);
  }
  .plan__content__group__list__item__link__size {
    grid-column: 2 / 5;
    font-size: calc(12 / 18 * 100%);
    margin-bottom: calc(30 / 12 * 1em);
  }
  .plan__content__group__list__item__link__madori {
    grid-row: 5;
  }
  .plan__content__group__list__item__link__more {
    grid-row: 6;
    margin-top: 30px;
    padding: 10px;
  }
  .plan__content__group__caution {
    --margin-top: 30px;
  }
}



/* 詳細ページ */
.detail {
  padding-block: calc(var(--header-height) + 50px) 150px;
}
.detail__heading {
  max-width: 1380px;
  font-size: clamp(40px, calc(140 / 1200 * 100vw), 140px);
}
.detail__heading span {
  color: rgba(71, 92, 129, 1);
  background: linear-gradient(135deg, rgba(71, 92, 129, 1) 0%, rgba(209, 214, 223, 1) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  opacity: .3;
}
.detail__content {
  position: relative;
  z-index: 1;
  max-width: 1380px;
  margin-top: 100px;
  /* box-shadow: 0 0 60px rgba(0, 0, 0, .1); */
  box-sizing: border-box;
  padding: 100px min(calc(80 / 1380 * 100%), 80px) 100px min(calc(100 / 1380 * 100%), 100px);
  grid-template-columns: minmax(0, auto) minmax(0, calc(70 / 1200 * 100%)) minmax(0, 1fr);
  align-items: start;
  /* color: rgb(var(--color-darknavy));
  background: #fff; */

  color: #fff;
  background: linear-gradient(135deg, rgba(var(--color-navy2), 1) 0%, rgba(var(--color-darknavy), 1) 100%);
}
.detail__content__premium {
  position: absolute;
  z-index: 1;
  top: 0;
  right: 0;
  max-width: 100%;
  min-height: calc(40 / 18 * 1em);
  place-items: center;
  box-sizing: border-box;
  padding: .25em calc(45 / 18 * 1em);
  font-size: clamp(12px, calc(18 / 1200 * 100vw), 18px);
  background: linear-gradient(135deg, rgba(0, 99, 176, 1) 0%, rgba(var(--color-navy), 1) 100%);

  display: none;
}
.detail__content__type {
  grid-column: 1;
  grid-row: 1 / 3;
  min-width: calc(150 / 36 * 1em);
  min-height: 100%;
  box-sizing: border-box;
  padding: calc(45 / 36 * 1em) .5em;
  grid-template-columns: auto;
  justify-content: center;
  justify-items: center;
  align-content: center;
  gap: calc(25 / 36 * 1em);
  font-size: clamp(26px, calc(36 / 1200 * 100vw), 36px);
  /* background: linear-gradient(135deg, rgba(var(--color-navy2), 1) 0%, rgba(var(--color-darknavy), 1) 100%); */

  color: rgb(var(--color-darknavy));
  background: #fff;
}
.detail__content__type em {
  font-size: calc(64 / 36 * 100%);
  line-height: 1;
  line-height: 1cap;
  text-indent: .05em;
}
.detail__content__type small {
  font-size: calc(24 / 36 * 100%);
}
.detail__content__group {
  grid-column: 3;
  grid-row: 1;
  align-self: end;
  align-items: baseline;
  gap: 20px;
}
.detail__content__group__layout {
  align-items: baseline;
  font-size: clamp(30px, calc(50 / 1200 * 100vw), 50px);
}
/* .detail__content__group__layout__ldk {
} */
.detail__content__group__layout__ldk em {
  font-size: calc(64 / 50 * 100%);
}
/* .detail__content__group__layout__storage {
} */
.detail__content__group__layout__storage::before {
  content: "+";
  display: inline-block;
  translate: 0 -.1em;
}
.detail__content__group__floor {
  font-size: clamp(30px, calc(50 / 1200 * 100vw), 50px);
}
.detail__content__group2 {
  grid-column: 3;
  grid-row: 2;
  align-self: start;
  margin-top: 30px;
  border-top: 1px solid currentColor;
  padding-top: 30px;
}
.detail__content__group2__size {
  font-size: clamp(11px, calc(16 / 1200 * 100vw), 16px);
  align-items: baseline;
  gap: calc(20 / 16 * 1em);
}
.detail__content__group2__size__item {
  align-items: baseline;
  gap: .5em;
}
/* .detail__content__group2__size__item__name {
} */
.detail__content__group2__size__item--main .detail__content__group2__size__item__name {
  font-size: calc(22 / 16 * 100%);
}
/* .detail__content__group2__size__item__data {
} */
.detail__content__group2__size__item--main .detail__content__group2__size__item__data em {
  font-size: calc(50 / 16 * 100%);
  vertical-align: -.05em;
}
.detail__content__group2__size__item__data .two {
  display: inline-block;
  width: 0;
  height: 0;
  translate: -.5em -1.25em;
  font-size: 35%;
}
.detail__content__group2__size__item__data .unit {
  font-size: calc(32 / 16 * 100%);
  vertical-align: -.05em;
}
.detail__content__madori {
  grid-column: 1 / 4;
  margin-top: 70px;
}
/* .detail__content__madori__figure {
} */
.detail__content__madori__legend {
  margin-top: 30px;
  grid-template-columns: 100%;
  gap: 10px 0;
}
.detail__content__madori__legend__list {
  gap: 10px 15px;
  line-height: 1;
}
.detail__content__madori__legend__list:empty {
  display: none;
}
/* .detail__content__madori__legend__list__item {
} */
/* .detail__content__madori__legend__list__item--windlight::before {
  content: "";
  display: inline-block;
  vertical-align: -.05em;
  width: calc(40 / 12 * 1em);
  height: calc(12 / 12 * 1em);
  margin-right: 5px;
  background: ;
} */
.detail__content__madori__legend__list__item--storage::before {
  content: "";
  display: inline-block;
  vertical-align: -.05em;
  width: calc(40 / 12 * 1em);
  height: calc(12 / 12 * 1em);
  margin-right: 5px;
  background: #e6e7e9;
}
.detail__content__madori__legend__list__item--water::before {
  content: "";
  display: inline-block;
  vertical-align: -.05em;
  width: calc(40 / 12 * 1em);
  height: calc(12 / 12 * 1em);
  margin-right: 5px;
  background: #e2effb;
}
.detail__content__madori__legend__list__item--floor::before {
  content: "";
  display: inline-block;
  vertical-align: -.05em;
  width: calc(40 / 12 * 1em);
  height: calc(12 / 12 * 1em);
  margin-right: 5px;
  background: rgb(255, 225, 204);
}
.detail__content__madori__legend__list__item small {
  font-size: 75%;
}
.detail__btn {
  margin-top: 100px;
  gap: 50px;
}
.detail__btn__item {
  flex: 0 1 400px;
}
/* a.detail__btn__item__link {
} */
a.detail__btn__item__link--back {
  background: linear-gradient(135deg, rgba(102, 130, 170, 1) 0%, rgba(var(--color-navy), 1) 100%);
}
@media screen and (max-width: 767px) {
  .detail {
    padding-block: calc(var(--header-height) + 10px) 60px;
  }
  .detail__heading {
    max-width: 560px;
    font-size: 44px;
  }
  .detail__content {
    width: calc(340 / 380 * 100%);
    max-width: 560px;
    margin-top: 40px;
    /* padding: 40px 20px 20px; */
    padding: 20px;
    grid-template-columns: minmax(0, auto) minmax(0, calc(20 / 340 * 100%)) minmax(0, 1fr);
  }
  .detail__content__premium {
    min-height: calc(20 / 11 * 1em);
    padding: .25em calc(10 / 11 * 1em);
    font-size: 11px;
  }
  .detail__content__type {
    min-width: calc(70 / 16 * 1em);
    min-height: 0;
    padding: calc(20 / 16 * 1em) .5em;
    gap: calc(12 / 16 * 1em);
    font-size: 16px;
  }
  .detail__content__type em {
    font-size: calc(30 / 16 * 100%);
  }
  .detail__content__type small {
    font-size: calc(14 / 16 * 100%);
  }
  .detail__content__group {
    gap: 10px 0;
    padding-top: 10px;
  }
  .detail__content__group__layout {
    font-size: 20px;
    width: 100%;
  }
  .detail__content__group__layout__ldk em {
    font-size: calc(30 / 20 * 100%);
  }
  .detail__content__group__floor {
    font-size: 18px;
    width: 100%;
  }
  .detail__content__group2 {
    margin-top: 10px;
    padding-top: 10px;
  }
  .detail__content__group2__size {
    font-size: 12px;
    gap: calc(8 / 12 * 1em);
  }
  .detail__content__group2__size__item {
    width: 100%;
  }
  .detail__content__group2__size__item--main .detail__content__group2__size__item__name {
    font-size: 100%;
  }
  .detail__content__group2__size__item--main .detail__content__group2__size__item__data em {
    font-size: calc(24 / 12 * 100%);
  }
  .detail__content__group2__size__item__data .unit {
    font-size: 100%;
  }
  .detail__content__madori {
    margin-top: 20px;
  }
  .detail__content__madori__legend {
    margin-top: 20px;
  }
  .detail__btn {
    margin-top: 40px;
    gap: 20px 0;
  }
  .detail__btn__item {
    flex: 0 1 300px;
  }
}