.img_cap {
  position: absolute;
  bottom: 0;
  right: 0;
  line-height: 1;
  margin: 5px;
}
p.img_cap {
  position: relative;
  text-align: right;
  bottom: 0;
  right: 0;
  margin: 5px;
}
div:has(> img) {
  font-size: 0;
}
@media (min-width:769px) {
  .img_cap {
    font-size: 12px;
  }
}
@media (max-width:768px) {
  .img_cap {
    font-size: calc((( 20 / var(--media_sp)) * 100) * var(--vw));
  }
}

.mv {
  position: relative;
}
.mv_txt-wrap {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin-inline: auto;
  text-align: center;
  color: #fff;
}
.hero_ttl {
  opacity: 0;
  letter-spacing: 0.01em;
  /* mix-blend-mode: multiply; */
}
.hero_ttl span {
  display: inline-block;
  font-family: inherit;
  width: fit-content;
  height: 100%;
  text-shadow: 0 0 25px rgba(27, 46, 90, 0.3);
}
.mv_cap {
  position: absolute;
  bottom: 0;
  right: 0;
  margin: 5px;
  width: fit-content;
  color: #000;
  letter-spacing: 0.1em;
}
@media screen and (min-width:769px) {
  .mv_txt-wrap {
    top: 35%;
    left: 4%;
  }
  .hero_ttl {
    width: fit-content;
    font-size: 5.059vw;
    line-height: 1.176;
    text-align: left;
  }
  .mv_txt {
    font-size: 22px;
    line-height: 1.909;
    letter-spacing: 0.09em;
  }
  .mv_cap {
    font-size: 12px;
  }
.mv_wap-wrap {
  position: absolute;
  top: 12.562%;
  right: 1.785%;
  width: 284px;
  aspect-ratio: 1 / 1;
}
}
@media screen and (min-width:769px) and (max-width:1365px){
  .container {
    min-width: 1366px;
  }
}
@media screen and (max-width:768px) {
  .mv_txt-wrap {
    bottom: 4%;
  }
  .hero_ttl {
    font-size: calc((( 66 / var(--media_sp)) * 100) * var(--vw));
  }
  .mv_txt {
    margin-top: calc((( 6 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 24 / var(--media_sp)) * 100) * var(--vw));
    line-height: 1.75;
    letter-spacing: 0.05em;
  }
  .mv_cap {
    font-size: calc((( 20 / var(--media_sp)) * 100) * var(--vw));
    color: #fff;
  }
  .mv_wap-wrap {
    position: absolute;
    top: calc((( 83 / var(--media_sp)) * 100) * var(--vw));
    right: calc((( 30 / var(--media_sp)) * 100) * var(--vw));
    width: calc((( 230 / var(--media_sp)) * 100) * var(--vw));
    aspect-ratio: 1 / 1;
  }
}

@media screen and (min-width:769px) {
  .lead {
    padding-block: 102px 106px;
  }
  .lead_txt {
    font-size: 17px;
    line-height: 3;
    text-align: center;
    letter-spacing: 0.05em;
  }
}
@media screen and (max-width:768px) {
  .lead_txt {
    margin-inline: auto;
    padding-block: calc((( 63 / var(--media_sp)) * 100) * var(--vw)) calc((( 69 / var(--media_sp)) * 100) * var(--vw));
    width: 89.583%;
    font-size: calc((( 26 / var(--media_sp)) * 100) * var(--vw));
    line-height: 2;
  }
}

.only {
  position: relative;
  width: 100%;
  height: auto;
  box-sizing: border-box;
}
.only_bg {
  position: relative;
}
.only_bg img {
  width: 100%;
  height: 100%;
  object-position: center;
  object-fit: cover;
}
.only_head_txt-wrap {
  width: 100%;
  overflow: hidden;
}
.only_head_txt {
  width: 100%;
  display: flex;
  justify-content: space-between;
  font-family: "TrajanPro-Regular";
  text-align: center;
  color: #ffffff;
}
.only_head_txt span {
  display: block;
}
.only .img_cap {
  color: #fff;
}

.case {
  position: relative;
  margin-inline: auto;
}
.case-wrap {
  width: 100%;
}
.case_head {
  line-height: 1;
  text-align: center;
  font-weight: normal;
}
.case_ttl {
  color: #424e6e;
  font-family: "TrajanPro-Regular";
}
.case_ttl span {
  font: inherit;
}
.case_sub_ttl {
  color: #231815;
  font-weight: normal;
  letter-spacing: 0.05em;
}
.case_txt {
  letter-spacing: 0.05em;
}
.case_img {
  position: relative;
  font-size: 0;
}
.case_feature-wrap {
  margin: 120px auto 0;
  width: 1280px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 10px;
}
.case_feature_item {
  background: linear-gradient(330deg, #3f3d6b 20%, #466098 80%) center / 120% 100% no-repeat;
  width: 420px;
  height: 84px;
  display: grid;
  place-content: center;
}
.case_feature_item_txt {
  font-size: 25px;
  text-align: center;
  color: #fff;
}

.party .img_cap,
.diy .img_cap {
  color: #fff;
}
@media screen and (min-width:769px) {
  .case {
    width: 1280px;
    padding: 120px 0;
  }
  .case_head {
    font-size: 31px;
    letter-spacing: 0.1em;
    text-indent: 0.1em;
  }
  .case-wrap {
    display: grid;
    justify-content: space-between;
    grid-template-rows: 550px;
  }
  .case > * + * {
    margin-top: 119px;
  }
  .case-wrap.case_img-right {
    grid-template-columns: auto 750px;
  }
  .case-wrap.case_img-left {
    grid-template-columns: 750px auto;
  }
  .case_txt-wrap {
    grid-row: 1 / 2;
    align-self: center;
  }
  .case-wrap.case_img-right .case_txt-wrap {
    grid-column: 1 / 2;
  }
  .case-wrap.case_img-left .case_txt-wrap {
    grid-column: 2 / 3;
    justify-self: start;
  }
  .case_ttl {
    font-size: 74px;
  }
  .case_txt-inner {
    margin-top: 45px;
  }
  .case_sub_ttl {
    font-size: 24px;
  }
  .case_sub_ttl.ls-08 {
    letter-spacing: -0.08em;
  }
  .case_txt {
    margin-top: 20px;
    width: 360px;
    font-size: 15px;
    line-height: 1.666;
  }
  .party .case_txt {
    width: 400px;
  }
  .diy .case_txt {
    width: 400px;
  }
  .case_img {
    grid-row: 1 / 2;
    width: 750px;
    height: auto;
    aspect-ratio: 1 / 0.73333;
  }
  .case-wrap.case_img-right {
    grid-column:  2 / 3;
  }
  .case-wrap.case_img-left {
    grid-column:  1 / 2;
  }
  .case_img-right .case_img{
  margin-left: auto;
  }
  .case_img-left .case_img{
    margin-right: auto;
  }
}
@media screen and (max-width:768px) {
  .case {
    width: 100%;
    overflow-x: clip;
    padding-bottom: calc((( 85 / var(--media_sp)) * 100) * var(--vw));
  }
  .case_head {
    margin-top: calc((( 118 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 36 / var(--media_sp)) * 100) * var(--vw));
    letter-spacing: 0.05em;
    text-indent: 0.5em;
  }
  .case-wrap {
    display: grid;
    grid-template-columns: calc((100% - 89.583%) / 2) 89.583% calc((100% - 89.583%) / 2);
  }
  .case > * + * {
    margin-top: calc((( 106 / var(--media_sp)) * 100) * var(--vw));
  }
  .case .second {
    margin-top: calc((( 118 / var(--media_sp)) * 100) * var(--vw));
  }
  .case_txt-wrap {
    display: contents;
  }
  .case_ttl {
    position: relative;
    width: fit-content;
    font-size: calc((( 84 / var(--media_sp)) * 100) * var(--vw));
    line-height: 1.190;
    grid-row: 1 / 2;
    grid-column: 2 / 3;
    z-index: 1;
  }
  .case_img-left .case_ttl {
    justify-self: start;
  }
  .case_img-right .case_ttl {
    justify-self: end;
  }
  .case_txt-inner {
    margin-top: calc((( 30 / var(--media_sp)) * 100) * var(--vw));
    grid-row: 3 / 4;
    grid-column: 2 / 3;
  }
  .case_sub_ttl {
    font-size: calc((( 30 / var(--media_sp)) * 100) * var(--vw));
  }
  .case_txt {
    margin-top: calc((( 14 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 24 / var(--media_sp)) * 100) * var(--vw));
    line-height: 1.666;
  }
  .case_img {
    grid-row: 2 / 3;
    margin-top: calc((( -47 / var(--media_sp)) * 100) * var(--vw));
    width: calc((( 668 / var(--media_sp)) * 100) * var(--vw));
    height: auto;
    aspect-ratio: 1 / 0.73333;
  }
  .case_img-right .case_img {
    grid-column: 1 / 3;
  }
  .case_img-left .case_img {
    margin-left: auto;
    grid-column: 2 / 4;
    justify-self: end;
  }
  .case_feature-wrap {
    margin: calc((( 110 / var(--media_sp)) * 100) * var(--vw)) auto 0;
    width: calc((( 688 / var(--media_sp)) * 100) * var(--vw));
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: calc((( 10 / var(--media_sp)) * 100) * var(--vw));
  }
  .case_feature_item {
    background: linear-gradient(330deg, #3f3d6b 20%, #466098 80%) center / 120% 100% no-repeat;
    width: calc((( 339 / var(--media_sp)) * 100) * var(--vw));
    height: calc((( 90 / var(--media_sp)) * 100) * var(--vw));
    display: grid;
    place-content: center;
  }
  .case_feature_item_txt {
    font-size: calc((( 32 / var(--media_sp)) * 100) * var(--vw));
    text-align: center;
    color: #fff;
  }
}

.lineUp_ttl-wrap {
  width: 100%;
  display: grid;
  place-content: center;
}
.lineUp_ttl-wrap hgroup {
  text-align: center;
  color: #424e6e;
}
.lineUp_ttl {
  font-family: "TrajanPro-Regular";
}
.plan-area {
  background-color: #fff;
}
.plan-area .attn .cap_img {
  display: inline-block;
}
.plan-area .sec_lnk {
  width: fit-content;
  margin-inline: auto;
  position: relative;
}
.plan-area .sec_lnk a {
  display: block;
  border-radius: 100vmax;
  color: #fff;
  line-height: 1;
  text-align: center;
  font-family: YakuHanJP, "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}
@media screen and (min-width:769px) {
  .lineUp {
    padding-bottom: 120px;
    background: url(../img/plan/skyterrace/plan_bg_pc.webp) no-repeat center center/cover;
  }
  .lineUp_ttl-wrap {
    padding: 110px 0 120px;
  }
  .lineUp_ttl {
    font-size: 80px;
  }
  .lineUp_ttl_jp {
    font-size: 24px;
    letter-spacing: 0.06em;
  }
  .plan-area {
    margin-inline: auto;
    padding: 83px 80px 77px;
    width: 1280px;
    box-sizing: border-box;
  }
  .plan-area.typeGr {
    margin-top: 60px;
  }
  .plan-area .ttl_wrap {
    display: flex;
    align-items: center;
    column-gap: 32px;
  }
  .plan-area .sec_ttl {
    font-size: 20px;
  }
  .plan-area .sec_ttl .strong {
    font-size: 40px;
  }
  .plan-area .sec_subTtl {
    font-size: 30px;
    letter-spacing: 0.05em;
  }
  .plan-area .sec_subTtl .strong {
    font-size: 40px;
  }
  .plan-area .txt_wrap {
    border-top: 1px solid #444956;
    margin-top: 10px;
    padding-top: 16px;
    display: flex;
    gap: 38px;
  }
  .plan-area .main_txt {
    padding-left: 3px;
    font-size: 17px;
    letter-spacing: 0.05em;
  }
  .plan-area .main_txt .strong {
    font-size: 40px;
    letter-spacing: 0.05em;
  }
  .plan-area .main_txt .strong2 {
    display: inline-block;
    margin-top: -14px;
    font-size: 55px;
    letter-spacing: 0.03em;
  }
  .plan-area .other_txt {
    padding-top: 2px;
    font-size: 17px;
    letter-spacing: 0.05em;
    line-height: 1.529;
  }
  .plan-area .img {
    width: 937px;
    margin: 35px auto 0;
  }
  .plan-area .attn {
    margin-top: 80px;
    font-size: 12px;
    line-height: 1.8;
    color: #222222;
  }
  .plan-area .sec_lnk {
    margin-top: 70px;
  }
  .plan-area .sec_lnk a {
    background: linear-gradient(270deg, #3f3d6b 20%, #466098 80%) center/120% 100% no-repeat;
    width: 320px;
    height: 60px;
    font-size: 15px;
    line-height: 60px;
  }
  .plan-area .sec_lnk a::after {
    content: "";
    position: absolute;
    top: 48%;
    right: 33px;
    width: 8px;
    height: 8px;
    transform: rotate(45deg) translateY(-50%);
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    user-select: none;
  }
  .plan-area .attn .cap_img {
    width: 448px;
  }
}
@media screen and (max-width:768px) {
  .lineUp {
    margin-top: calc((( 55 / var(--media_sp)) * 100) * var(--vw));
    background: url(../img/plan/skyterrace/plan_bg_sp.webp) no-repeat center center/cover;
  }
  .lineUp_ttl-wrap {
    padding: calc((( 76 / var(--media_sp)) * 100) * var(--vw)) 0;
  }
  .lineUp_ttl {
    font-size: calc((( 80 / var(--media_sp)) * 100) * var(--vw));
  }
  .lineUp_ttl_jp {
    font-size: calc((( 24 / var(--media_sp)) * 100) * var(--vw));
  }
  .plan {
    padding-bottom: calc((( 40 / var(--media_sp)) * 100) * var(--vw));
    box-sizing: border-box;
    margin-inline: auto;
  }
  .plan-area {
    margin-inline: auto;
    padding: calc((( 30 / var(--media_sp)) * 100) * var(--vw));
    padding-top: calc((( 33 / var(--media_sp)) * 100) * var(--vw));
    width: 89.583%;
    box-sizing: border-box;
  }
  .plan-area.typeGr {
    margin-top: calc((( 40 / var(--media_sp)) * 100) * var(--vw));
  }
  /* .plan-area .ttl_wrap {
    display: flex;
    align-items: center;
    column-gap: 32px;
  } */
  .plan-area .sec_ttl {
    font-size: calc((( 30 / var(--media_sp)) * 100) * var(--vw));
  }
  .plan-area .sec_ttl .strong {
    font-size: calc((( 60 / var(--media_sp)) * 100) * var(--vw));
  }
  .plan-area .sec_subTtl {
    margin-top: calc((( 3 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 36 / var(--media_sp)) * 100) * var(--vw));
    letter-spacing: 0.05em;
  }
  .plan-area .sec_subTtl .strong {
    font-size: calc((( 46 / var(--media_sp)) * 100) * var(--vw));
  }
  .plan-area .txt_wrap {
    border-top: 1px solid #444956;
    margin-top: calc((( 28 / var(--media_sp)) * 100) * var(--vw));
    padding-top: calc((( 17 / var(--media_sp)) * 100) * var(--vw));
  }
  .plan-area .main_txt {
    padding-left: calc((( 3 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 20 / var(--media_sp)) * 100) * var(--vw));
    letter-spacing: 0.05em;
  }
  .plan-area .main_txt .strong {
    font-size: calc((( 46 / var(--media_sp)) * 100) * var(--vw));
    letter-spacing: 0.05em;
  }
  .plan-area .main_txt .strong2 {
    display: inline-block;
    margin-top: calc((( -14 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 60 / var(--media_sp)) * 100) * var(--vw));
    letter-spacing: 0.03em;
  }
  .plan-area .other_txt {
    margin-top: calc((( 15 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 24 / var(--media_sp)) * 100) * var(--vw));
    letter-spacing: 0.05em;
    line-height: 1.666;
  }
  .plan-area .img {
    margin: calc((( 42 / var(--media_sp)) * 100) * var(--vw)) auto 0;
  }
  .plan-area .attn {
    margin-top: calc((( 80 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 20 / var(--media_sp)) * 100) * var(--vw));
    line-height: 1.5;
    color: #222222;
  }
  .plan-area .sec_lnk {
    margin-top: calc((( 80 / var(--media_sp)) * 100) * var(--vw));
  }
  .plan-area .sec_lnk a {
    background: linear-gradient(270deg, #3f3d6b 20%, #466098 80%) center/120% 100% no-repeat;
    width: calc((( 540 / var(--media_sp)) * 100) * var(--vw));
    height: calc((( 90 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 28 / var(--media_sp)) * 100) * var(--vw));
    line-height: calc((( 90 / var(--media_sp)) * 100) * var(--vw));
  }
  .plan-area .sec_lnk a::after {
    content: "";
    position: absolute;
    transform: rotate(45deg) translateY(-50%);
    user-select: none;
    top: 47%;
    right: calc((( 78 / var(--media_sp)) * 100) * var(--vw));
    width: calc((( 14 / var(--media_sp)) * 100) * var(--vw));
    height: calc((( 14 / var(--media_sp)) * 100) * var(--vw));
    border-top: calc((( 2 / var(--media_sp)) * 100) * var(--vw)) solid #fff;
    border-right: calc((( 2 / var(--media_sp)) * 100) * var(--vw)) solid #fff;
  }
  .plan-area .attn .cap_img {
    width: 100%;
  }
}


.info_heading {
  font-family: "TrajanPro-Regular";
  text-align: center;
  color: #fff;
}
.info_ttl {
  font-weight: normal;
  text-align: center;
  color: #fff;
}
@media all and (min-width:769px) {
  .information {
    padding: 170px 0; 
    background: url(../img/plan/skyterrace/info_bg_pc.webp) no-repeat center center/cover;
  }
  .info_heading {
    font-size: 21px;
    line-height: 1;
  }
  .info_ttl {
    margin-top: 24px;
    font-size: 56px;
    line-height: 1.25;
  }
}
@media all and (max-width:768px) {
  .information {
    padding: calc((( 138 / var(--media_sp)) * 100) * var(--vw)) 0;
    background: url(../img/plan/skyterrace/info_bg_sp.webp) no-repeat center center/cover;
  }
  .info_heading {
    font-size: calc((( 28 / var(--media_sp)) * 100) * var(--vw));
    line-height: 1;
  }
  .info_ttl {
    margin-top: calc((( 48 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 58 / var(--media_sp)) * 100) * var(--vw));
    line-height: 1.345;
  }
}
.reserve-btn-wrap .btn {
  position: relative;
  display: block;
  margin: 0 auto;
  background: linear-gradient(90deg, #cbae83 20%, #9a7955 80%);
  font-family: YakuHanJP, "Noto Sans JP", "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  font-weight: 400;
  text-align: center;
  border-radius: 100vmax;
}
.reserve-btn-wrap .btn .arrow {
  position: absolute;
  transform: rotate(45deg) translateY(-50%);
  user-select: none;
}
@media all and (min-width:769px) {
  .reserve-btn-wrap {
    margin-top: 42px;
  }
  .reserve-btn-wrap .btn {
    width: 390px;
    height: 60px;
    font-size: 15px;
    letter-spacing: 0.05em;
    line-height: 60px;
  }
  .reserve-btn-wrap .btn .arrow {
    top: 48%;
    right: 26px;
    width: 8px;
    height: 8px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
  }
}
@media all and (max-width:768px) {
  .reserve-btn-wrap {
    margin-top: calc((( 60 / var(--media_sp)) * 100) * var(--vw));
  }
  .reserve-btn-wrap .btn {
    width: calc((( 540 / var(--media_sp)) * 100) * var(--vw));
    height: calc((( 90 / var(--media_sp)) * 100) * var(--vw));
    font-size: calc((( 28 / var(--media_sp)) * 100) * var(--vw));
    line-height: calc((( 90 / var(--media_sp)) * 100) * var(--vw));
  }
  .reserve-btn-wrap .btn .arrow {
    top: 47%;
    right: calc((( 78 / var(--media_sp)) * 100) * var(--vw));
    width: calc((( 14 / var(--media_sp)) * 100) * var(--vw));
    height: calc((( 14 / var(--media_sp)) * 100) * var(--vw));
    border-top: calc((( 2 / var(--media_sp)) * 100) * var(--vw)) solid #fff;
    border-right: calc((( 2 / var(--media_sp)) * 100) * var(--vw)) solid #fff;
  }
}

.lnk-blk {
  background: linear-gradient(270deg, #161e49 20%, #32456f 80%);
}
.lnk_txt {
  color: #fff;
  text-align: center;
}
@media screen and (min-width:769px) {
  .lnk-blk {
    padding: 100px 0 155px;
  }
  .lnk_txt {
    font-size: 29px;
    letter-spacing: 0.03em;
    line-height: 1;
    color: #fff;
    text-align: center;
  }
  .garden-wrap {
    margin: 40px auto 0;
  }
  .garden-wrap a {
    display: block;
    max-width: 1120px;
    margin-inline: auto;
  }
}
@media screen and (max-width:768px) {
  .lnk-blk {
    padding: calc((( 68 / var(--media_sp)) * 100) * var(--vw)) 0 calc((( 80 / var(--media_sp)) * 100) * var(--vw));
  }
  .lnk_txt {
    font-size: calc((( 32 / var(--media_sp)) * 100) * var(--vw));
    letter-spacing: 0.03em;
    line-height: 1.625;
    color: #fff;
    text-align: center;
  }
  .garden-wrap {
    margin: calc((( 32 / var(--media_sp)) * 100) * var(--vw)) auto 0;
  }
  .garden-wrap a {
    display: block;
    width: calc((( 690 / var(--media_sp)) * 100) * var(--vw));
    margin-inline: auto;
  }
}