@charset "utf-8";

.heroKv-wrap {
  background-image: url(/content/dam/31sumai/mfr/K2201/assets/img/quality/hero01_pc.webp);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  height: 52.5vw;
}
.title-wrap {
  height: 52.5vw;
  display: grid;
  place-content: center;
}
.title-wrap img {
  width: 283px;
}
.hero-wrap {
  position: relative;
}
.hero-wrap .caption {
  position: absolute;
  bottom: 4px;
  right: 4px;
  font-size: 12px;
}
.intro-wrap {
  padding-block: 125px 130px;
  text-align: center;
}
.intro-wrap .catch {
  font-size: 40px;
  line-height: 1.6;
  letter-spacing: 0.05em;
}
.intro-wrap .body {
  margin-top: 48px;
  font-size: 17px;
  line-height: 2.294;
  letter-spacing: 0.05em;
}
@media screen and (max-width:768px) {
  .heroKv-wrap {
    background-image: url(/content/dam/31sumai/mfr/K2201/assets/img/quality/hero01_sp.webp);
    height: 100vh;
    height: 100lvh;
    background-size: cover; /* ←ここをcoverに */
    background-repeat: no-repeat;
    background-position: center;
  }
  .title-wrap {
    height: 100vh;
    height: 100lvh;
  }
  .title-wrap img {
    width: calc((( 387 / var(--media_sp)) * 100) * var(--vw));
  }
  .hero-wrap .caption {
    font-size: calc((( 12 * 2 / var(--media_sp)) * 100) * var(--vw));
    bottom: calc((( 4 / var(--media_sp)) * 100) * var(--vw));
    right: calc((( 4 / var(--media_sp)) * 100) * var(--vw));
  }
  .intro-wrap {
    padding-block: calc((( 100 / var(--media_sp)) * 100) * var(--vw));
    text-align: center;
  }
  .intro-wrap .catch {
    padding-left: 0.5em;
    font-size: calc((( 44 / var(--media_sp)) * 100) * var(--vw));
    line-height: 1.454;
    letter-spacing: 0.05em;
  }
  .intro-wrap .body {
    margin-top: calc((( 26 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 26 / var(--media_sp)) * 100) * var(--vw));
    line-height: 2;
    letter-spacing: 0.05em;
  }
}

.sec-blk {
  position: relative;
}
.sec_hero {
  overflow: hidden;
  position: relative;
  transform-origin: center;
}
.sec_hero .caption {
  position: absolute;
  margin: 5px;
  bottom: 0;
  right: 0;
  line-height: 1;
  color: #000;
}
.hero_img-wrap {
  transform-origin: center;
}
.sec_head {
  padding: 90px 0 80px;
}
.sec_head h3 {
  margin: 0 auto;
}
.sec_head p {
  margin-top: 42px;
  font-size: 33px;
  letter-spacing: 0.05em;
  line-height: 1.636;
  text-align: center;
}
.main_contents .img-wrap {
  position: relative;
}
@media screen and (max-width:768px) {
  .sec_head {
    padding: calc((( 100 / var(--media_sp)) * 100) * var(--vw)) 0;
  }
  .sec_head p {
    margin-top: calc((( 38 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 40 / var(--media_sp)) * 100) * var(--vw));
    letter-spacing: 0.05em;
    line-height: 1.75;
    text-align: center;
  }
}


.eco_head {
  padding: 90px 0 80px;
}
.eco_head h3 {
  width: 185px;
}
.eco_head.sec_head p {
  margin-top: 22px;
}
.eco_fig {
  margin: 0 auto;
  width: min(1200px, calc(100% - 80px));
}

.eco_content {
  padding-bottom: 135px;
}
@media screen and (min-width:751px) {
  .eco_content p.catch,
  .eco_content p.body {
    /* overflow-wrap: anywhere;
    word-break: keep-all; */
    white-space: nowrap;
  }
}
.eco_content p.catch {
  font-size: 27px;
  letter-spacing: 0.05em;
  line-height: 1.777;
  color: #51bcc6;
}
.eco_content p.body {
  margin-top: 7px;
  font-size: 17px;
  letter-spacing: 0.05em;
  line-height: 2.294;
}

.eco_zeh-wrap {
  margin: 33px auto 0;
  width: min(1200px, calc(100% - 80px));
}
.eco_low-wrap {
  margin: 47px auto 0;
  width: min(1200px, calc(100% - 80px));
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 3.333%;
}
.eco_low-wrap .img-wrap {
  width: 41.666%;
  text-align: center;
}
.eco_low-wrap .txt-wrap {
  width: 55.001%;
}
.eco_low-wrap .txt-wrap p {
  white-space: normal;
}
.eco_content_note {
  margin: 55px auto 0;
  width: min(1200px, calc(100% - 80px));
}
.eco_content_note p {
  font-size: 12px;
  line-height: 1.666;
  letter-spacing: 0.05em;
}
.eco_content_note p span {
  display: inline-block;
  text-indent: -1em;
  padding-left: 1em;
}
@media screen and (max-width:768px) {
  .eco_head {
    padding: calc((( 100 / var(--media_sp)) * 100) * var(--vw)) 0 calc((( 83 / var(--media_sp)) * 100) * var(--vw));
  }
  .eco_head h3 {
    width: calc((( 222 / var(--media_sp)) * 100) * var(--vw));
  }
  .eco_head.sec_head p {
    margin-top: calc((( 17 / var(--media_sp)) * 100) * var(--vw));
  }
  .eco_fig {
    width: calc((( 600 / var(--media_sp)) * 100) * var(--vw));
  }
  .eco_content {
    padding-bottom: calc((( 104 / var(--media_sp)) * 100) * var(--vw));
  }
  .eco_content p.catch {
    margin-top: calc((( 26 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 32 / var(--media_sp)) * 100) * var(--vw));
    letter-spacing: 0.05em;
    line-height: 1.6875;
    color: #51bcc6;
  }
  .eco_content p.body {
    margin-top: calc((( 4 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 26 / var(--media_sp)) * 100) * var(--vw));
    letter-spacing: 0.05em;
    line-height: 2;
  }
    
  .eco_zeh-wrap {
    margin: calc((( 25 / var(--media_sp)) * 100) * var(--vw)) auto 0;
    width: calc((( 600 / var(--media_sp)) * 100) * var(--vw));
  }
  .eco_low-wrap {
    margin: calc((( 65 / var(--media_sp)) * 100) * var(--vw)) auto 0;
    width: calc((( 600 / var(--media_sp)) * 100) * var(--vw));
    display: block;
  }
  .eco_low-wrap .img-wrap {
    width: 100%;
    text-align: center;
  }
  .eco_low-wrap .txt-wrap {
    width: 100%;
  }
  .eco_low-wrap .txt-wrap p {
    white-space: normal;
  }
  .eco_content_note {
    margin-top: calc((( 56 / var(--media_sp)) * 100) * var(--vw));
    width: calc((( 600 / var(--media_sp)) * 100) * var(--vw));
  }
  .eco_content_note p {
    font-size: calc((( 20 / var(--media_sp)) * 100) * var(--vw));
    line-height: 1.5;
    letter-spacing: 0.05em;
  }
}

.str-blk {
  background-color: #def3f4;
  padding-bottom: 130px;
}
.str_head {
  padding: 122px 0 80px;
}
.str_head h3 {
  width: 121px;
}
.str_head p {
  margin-top: 32px;
}
.str_content-inner {
  margin: 0 auto;
  width: min(1200px, calc(100% - 80px));
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: start;
}
.str_content_item {
  width: 47.5%;
}
.str_content_item p.ttl {
  margin-top: 23px;
  font-size: 27px;
  line-height: 1.777;
  letter-spacing: 0.05em;
  color: #51bcc6;
}
.str_content_item p.txt {
  margin-top: 7px;
  font-size: 17px;
  line-height: 2.294;
  letter-spacing: 0.05em;
}
.str_content_item p.annot {
  font-size: 12px;
  line-height: 1.666;
  letter-spacing: 0.05em;
}
@media screen and (max-width:768px) {
  .str-blk {
    padding-bottom: calc((( 100 / var(--media_sp)) * 100) * var(--vw));
  }
  .str_head {
    padding: calc((( 110 / var(--media_sp)) * 100) * var(--vw)) 0 calc((( 73 / var(--media_sp)) * 100) * var(--vw));
  }
  .str_head h3 {
    width: calc((( 146 / var(--media_sp)) * 100) * var(--vw));
  }
  .str_head p {
    margin-top: calc((( 30 / var(--media_sp)) * 100) * var(--vw));
  }
  .str_content-inner {
    margin: 0 auto;
    width: calc((( 600 / var(--media_sp)) * 100) * var(--vw));
    display: block;
  }
  .str_content-inner > * + * {
    margin-top: calc((( 78 / var(--media_sp)) * 100) * var(--vw));
  }
  .str_content_item {
    width: 100%;
  }
  .str_content_item p.ttl {
    margin-top: calc((( 25 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 32 / var(--media_sp)) * 100) * var(--vw));
    line-height: 1.6875;
    letter-spacing: 0.05em;
    color: #51bcc6;
  }
  .str_content_item p.txt {
    margin-top: calc((( 3 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 26 / var(--media_sp)) * 100) * var(--vw));
    line-height: 2;
    letter-spacing: 0.05em;
  }
  .str_content_item p.annot {
    font-size: calc((( 20 / var(--media_sp)) * 100) * var(--vw));
    line-height: 1.5;
    letter-spacing: 0.05em;
  }
}


.sac-blk {
  padding-bottom: 60px;
}
.sac_head {
  padding: 140px 0 77px;
}
.sac_head h3 {
  width: 283px;
}
.sac_head p {
  margin-top: 32px;
}
.sac_content-inner {
  margin: 0 auto;
  width: min(1200px, calc(100% - 80px));
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: start;
  row-gap: 60px;
}
.sac_content_item {
  width: 47.5%;
}
.sac_content_item p.ttl {
  margin-top: 21px;
  font-size: 27px;
  line-height: 1.777;
  letter-spacing: 0.05em;
  color: #51bcc6;
}
.sac_content_item p.ttl span {
  font-size: 14px;
}
.sac_content_item p.ttl sup {
  font-size: 0.65em;
}
.sac_content_item p.txt {
  margin-top: 5px;
  font-size: 17px;
  line-height: 2.294;
  letter-spacing: 0.05em;
}
.sac_content_item p.txt span {
  font-size: 12px;
}
.sac_content_item p.annot {
  font-size: 12px;
  line-height: 1.666;
  letter-spacing: 0.05em;
}

.sac_content_item.locker .txt-wrap {
  display: grid;
  justify-content: space-between;
  grid-template-columns: 65% 31.579%;
}
.sac_content_item.locker .txt-wrap p.ttl {
  grid-column: 1 / 3;
}
.sac_content_item.locker .txt-wrap .txt-inner {
  order: 1;
  grid-column: 1 / 2;
  grid-row: 2 / 3;
}
.sac_content_item.locker .txt-wrap p.txt {
  letter-spacing: normal;
}
.sac_content_item.locker .txt_img-wrap {
  order: 2;
  grid-column: 2 / 3;
  grid-row: 2 / 3;
  align-self: end;
}

.sac_content_item.park .img_cap:nth-of-type(1) {
  top: 45.5%;
}
@media screen and (max-width:768px) {
  .sac-blk {
    padding-bottom: calc((( 110 / var(--media_sp)) * 100) * var(--vw));
  }
  .sac_head {
    padding: calc((( 110 / var(--media_sp)) * 100) * var(--vw)) 0 calc((( 64 / var(--media_sp)) * 100) * var(--vw));
  }
  .sac_head h3 {
    width: calc((( 340 / var(--media_sp)) * 100) * var(--vw));
  }
  .sac_head p {
    margin-top: calc((( 28 / var(--media_sp)) * 100) * var(--vw));
  }
  .sac_content-inner {
    margin: 0 auto;
    width: calc((( 600 / var(--media_sp)) * 100) * var(--vw));
    display: block;
  }
  .sac_content-inner > * + * {
    margin-top: calc((( 74 / var(--media_sp)) * 100) * var(--vw));
  }
  .sac_content_item {
    width: 100%;
  }
  .sac_content_item p.ttl {
    margin-top: calc((( 27 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 32 / var(--media_sp)) * 100) * var(--vw));
    line-height: 1.6875;
    letter-spacing: 0.05em;
    color: #51bcc6;
  }
  .sac_content_item p.ttl span {
    /* display: block; */
    margin-top: calc((( 4 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 20 / var(--media_sp)) * 100) * var(--vw));
  }
  .sac_content_item p.ttl sup {
    font-size: 0.65em;
  }
  .sac_content_item p.txt {
    margin-top: calc((( 5 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 26 / var(--media_sp)) * 100) * var(--vw));
    line-height: 2;
    letter-spacing: 0.05em;
  }
  .sac_content_item p.annot {
    margin-top: calc((( 10 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 20 / var(--media_sp)) * 100) * var(--vw));
    line-height: 1.5;
    letter-spacing: 0.05em;
  }
  .sac_content_item.locker .txt-wrap {
    display: block;
  }
  .sac_content_item.locker .txt-wrap::after {
    content: "";
    display: block;
    clear: both;
  }
  .sac_content_item.locker .txt-wrap .txt-inner {
    display: contents;
  }
  .sac_content_item.locker .txt_img-wrap {
    width: calc((( 250 / var(--media_sp)) * 100) * var(--vw));
    float: right;
  }
  .sac_content_item.luup p.ttl {
    letter-spacing: 0.02em;
  }
  .sac_content_item.park .img_cap:nth-of-type(1) {
    top: 44%;
  }
}

.view_desc-section {
  margin-inline: auto;
  padding-block: 64px 60px;
  max-width: 1240px;
  display: flex;
  justify-content: space-between;
  align-items: start;
}
@media screen and (min-width:769px) {
  .view_desc-section {
    width: 100%;
    padding-inline: 20px;
  }
}
.view_desc_txt-wrap {
  width: 50%;
}
.view_desc_balcony-wrap {
  margin-top: 49px;
  padding-top: 61px;
  border-top: 1px solid #ccc;
}
.view_desc_balcony-wrap .view_desc_ttl {
  width: 94px;
}
.view_desc_panorama-wrap .view_desc_ttl {
  width: 183px;
}
.view_desc_catch {
  margin-top: 22px;
  font-size: 27px;
  letter-spacing: 0.08em;
  line-height: 1.555;
  color: #51bcc6;
}
.view_desc_panorama-wrap .view_desc_catch {
  margin-top: 35px;
}
.view_desc_catch sub {
  font-size: 0.6em;
  vertical-align: baseline;
}
.view_desc_catch_notes {
  font-size: 12px;
}
.view_desc_txt {
  margin-top: 22px;
  font-size: 17px;
  letter-spacing: 0.05em;
  line-height: 2;
}
.view_desc_panorama-wrap .view_desc_txt {
  margin-top: 20px;
}
.view_desc_fig-wrap {
  width: 46.666%;
}
@media screen and (max-width:768px) {
  .view_desc-section {
    margin-inline: auto;
    padding-block: calc((( 70 / var(--media_sp)) * 100) * var(--vw)) calc((( 110 / var(--media_sp)) * 100) * var(--vw));
    max-width: 1200px;
    width: 80%;
    display: block;
  }
  .view_desc_txt-wrap {
    width: 100%;
  }
  .view_desc_balcony-wrap {
    margin-top: calc((( 59 / var(--media_sp)) * 100) * var(--vw));
    padding-top: calc((( 70 / var(--media_sp)) * 100) * var(--vw));
    border-top: 1px solid #ccc;
  }
  .view_desc_balcony-wrap .view_desc_ttl {
    width: calc((( 124 / var(--media_sp)) * 100) * var(--vw));
  }
  .view_desc_panorama-wrap .view_desc_ttl {
    width: calc((( 241 / var(--media_sp)) * 100) * var(--vw));
  }
  .view_desc_catch {
    margin-top: calc((( 18 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 32 / var(--media_sp)) * 100) * var(--vw));
    line-height: 1.6875;
    letter-spacing: normal;
  }
  .view_desc_panorama-wrap .view_desc_catch {
    margin-top: calc((( 18 / var(--media_sp)) * 100) * var(--vw));
  }
  .view_desc_catch_notes {
    display: block;
    margin-top: calc((( 6 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 20 / var(--media_sp)) * 100) * var(--vw));
    letter-spacing: 0.08em;
  }
  .view_desc_balcony-wrap .view_desc_catch_notes {
    display: inline-block;
  }
  .view_desc_txt {
    margin-top: 0;
    font-size: calc((( 26 / var(--media_sp)) * 100) * var(--vw));
    line-height: 2;
  }
  .view_desc_panorama-wrap .view_desc_txt {
    margin-top: calc((( 7 / var(--media_sp)) * 100) * var(--vw));
  }
  .view_desc_fig-wrap {
    margin-top: calc((( 35 / var(--media_sp)) * 100) * var(--vw));
    width: calc((( 600 / var(--media_sp)) * 100) * var(--vw));
  }
}

.view_img-section {
  position: relative;
  margin: 0 auto;
  width: min(1200px, 100%);
  overflow: hidden;
}

.sky-blk {
  background-color: #20191f;
  position: relative;
  overflow: hidden;
  margin: 0 auto;
  width: min(1200px, calc(100% - 80px));
  aspect-ratio: 1 / 0.4075;
}
/* .sky-inner {
  position: absolute;
  width: 100%;
  height: 100%;
} */
.sky-blk .img-wrap.sky_img-wrap {
  position: absolute;
  width: 100%;
  height: 100%;
  inset: 0;
  margin: auto;
}
.sky-blk .txt-wrap {
  padding-left: 5.416%;
  width: 54.5%;
  height: fit-content;
  position: absolute;
  top: 50%;
  translate: 0 -50%;
  z-index: 1;
}
.sky-blk .txt-wrap p {
  color: #fff;
}
.sky-blk .txt-wrap p.ttl {
  font-size: min(27px, 2.109vw);
  line-height: 1.555;
  letter-spacing: 0.05em;
}
.sky-blk .txt-wrap p.txt {
  margin-top: min(21px, 1.64vw);
  font-size: min(17px, 1.28vw);
  line-height: 2;
  letter-spacing: 0.05em;
}
.sky-blk .txt-wrap p.annot {
  margin-top: min(12px, 0.938vw);
  font-size: min(12px, 0.938vw);
  line-height: 1.666;
  letter-spacing: 0.05em;
}
@media screen and (max-width:768px) {
  .sky-blk {
    width: calc((( 600 / var(--media_sp)) * 100) * var(--vw));
    aspect-ratio: 1 / 2.36;
  }
  .sky-blk .img-wrap.sky_img-wrap {
    position: absolute;
    width: 100%;
    height: 100%;
    inset: 0;
    margin: auto;
  }
  .sky-blk .txt-wrap {
    padding-left: 0;
    width: calc((( 530 / var(--media_sp)) * 100) * var(--vw));
    height: fit-content;
    position: absolute;
    top: calc((( 63 / var(--media_sp)) * 100) * var(--vw));
    left: 7%;
    translate: 0;
    z-index: 1;
  }
  .sky-blk .txt-wrap p {
    color: #fff;
  }
  .sky-blk .txt-wrap p.ttl {
    font-size: calc((( 36 / var(--media_sp)) * 100) * var(--vw));
    line-height: 1.777;
    letter-spacing: 0.05em;
    white-space: nowrap;
  }
  .sky-blk .txt-wrap p.txt {
    width: 94%;
    margin-top: calc((( 8 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 26 / var(--media_sp)) * 100) * var(--vw));
    line-height: 2;
    letter-spacing: 0.05em;
  }
  .sky-blk .txt-wrap p.annot {
    margin-top: calc((( 20 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 20 / var(--media_sp)) * 100) * var(--vw));
    line-height: 1.5;
    letter-spacing: 0.05em;
  }
}

.main_contents {
  padding-bottom: 110px;
}
@media screen and (max-width:768px) {
  .main_contents {
    padding-bottom: calc((( 75 / var(--media_sp)) * 100) * var(--vw));
  }
}