@charset "UTF-8";



:root{
    --plan-black: #3c3838;
    --plan-gray: #b4b5a4;
    --plan-gray2: #cdcec2;
    --plan-gray3: #e6e5e0;
}

.mv{
    position: relative;
    aspect-ratio: 1920 / 1080;
}
.mv-ttl{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
    font-size: clamp(2.8rem, 4.6vw, 4.6rem);
    font-weight: 400;
    letter-spacing: .8rem;
    text-align: center;
    span{
        padding-bottom: 4px;
        position: relative;
        display: inline-block;
        &::after{
            content: "";
            width: calc(100% + 78px);
            height: 1px;
            background-color: var(--color-white);
            position: absolute;
            bottom: 0;
            left: 50%;
            transform: translateX(-50%);
        }
    }
}
.main-section{
    background: url(../img/plan/bg-plan.webp) no-repeat top center/ cover;
}
.lead{
    margin-bottom: clamp(60px, 12vw, 120px);
    .secondary-heading{
        margin-bottom: 1.2em;
    }
    .note{
        margin: 0;
        font-size: clamp(1.4rem, 2.1vw, 2.1rem);
    }
}
/* .plan-list{
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
}
.plan-item{
    background: url(../img/plan/bg-plan-item.webp) no-repeat center / cover;
    color: var(--color-white);
    box-shadow: 2px 2px 4px rgba(0, 0, 0, .4);
    transition: all .3s ease-out;
    &:hover{
        box-shadow: none;
        transform: translate(2px, 2px);
        filter: brightness(1.2);
    }
}
.plan-link{
    padding: clamp(55px, 7.5vw, 75px) 10px clamp(25px, 4.5vw, 45px);
    width: 100%;
    height: 100%;
    display: block;
    &:hover{
        opacity: 1;
    }
}
.plan-name{
    margin: 0 auto 40px;
    width: 150px;
    height: 150px;
    align-content: center;
    background: url(../img/plan/bg-gold.webp) no-repeat center / cover;
}
.plan-name-in{
    display: flex;
    flex-direction: column;
    font-size: clamp(5.2rem, 5.6vw, 5.6rem);
    font-weight: 400;
    line-height: 1;
    .small-text{
        font-size: 40%;
    }
}
.plan-floor{
    font-size: clamp(3rem, 3.6vw, 3.6rem);
    letter-spacing: .3rem;
    .num{
        font-size: 120%;
    }
    .small-text{
        font-size: 65%;
    }
}
.plan-area{
    font-size: clamp(1.4rem, 1.65vw, 1.65rem);
    letter-spacing: .1rem;
    .middle-text{
        font-size: 2.4rem;
        font-weight: 400;
    }
}
.area-wide{
    font-size:clamp(2.3rem, 2.6vw, 2.6rem);
    .large-text{
        font-size: clamp(3.2rem, 3.6vw, 3.6rem);
    }
}
@media screen and (max-width: 1150px) {
    .plan-list{
        grid-template-columns: repeat(2, 1fr);
    }
}
@media screen and (max-width: 767px) {
    .mv{
        padding-top: 60px;
        aspect-ratio: 750 / 600;
        figure{
            height: 100%;
            img{
                height: inherit;
                object-fit: cover;
            }
        }
    }
    .mv-ttl{
        top: 56%;
        span{
            &::after{
                width: calc(100% + 36px);
            }
        }
    }
    .plan-list{
        grid-template-columns: auto;
    }
    .plan-name{
        width: 130px;
        height: 130px;
    }
} */
.general-section.detail-section{
    background: url(../img/limited/bg-premium.webp) no-repeat top center/ cover;
    @media screen and (max-width: 768px){
        background: url(../img/common/bg-dark.webp) no-repeat top center/ cover;
    }
    &.nomal{
        background: url(../img/plan/bg-plan.webp) no-repeat top center/ cover;
        @media screen and (max-width: 768px){
            background: url(../img/plan/bg-plan.webp) no-repeat top center/ cover;
        }
    }
}

.plan-page-head{
     width: 100vw;
    margin: 120px calc(50% - 50vw);
}
@media screen and (max-width: 768px){
    .plan-page-head{
        margin: 80px calc(50% - 50vw) 120px;
    }
}
.plan-page-head-in{
    padding-bottom: 16px;
    border-bottom: 1px solid #dbb85d;
    color: #dbb85d;
    font-size: clamp(2.8rem, 4.6vw, 4.6rem);
    font-weight: 400;
    letter-spacing: .8rem;
    &.nomal{
        color: #000;
        border-bottom: 1px solid #000
    }
}

/* lead */
.plan-lead{
    margin: 120px 0;
    font-size: clamp(1.8rem,1.3vw,2rem);
    letter-spacing: .06em;
    line-height: 1.8;
    font-weight: 400;
    color: #fff;
     @media screen and (max-width: 768px){
        margin: 80px 0;
     }
     &.nomal{
        color: #000;
     }
}
.detail-contents{
    display: grid;
    grid-template-columns: min(23vw, 376px) auto;
    grid-template-rows: repeat(2, auto);
    gap: 80px;
    @media screen and (max-width: 768px){
        display: flex;
        flex-direction: column;
        gap: 36px;
    }

}
.detail-list{
    grid-column: 1/2;
    grid-row: 1/2;
    display: flex;
    flex-direction: column;
    gap: 12px;
    color: #fff;
    &.nomal{
        color: #000;
    }
}
.detail-image01{
    grid-column: 2/3;
    grid-row: 1/-1;
    position: relative;
    /* &::before{
        content: "間取り図";
        font-size: 1.8rem;
        padding: 8px 20px;
        background: #000;
        position: absolute;
        top: 50%;
        left: 50%;
        translate: -50% -50%;
        color: #fff;
    } */
}
.detail-image02{
    grid-column: 1/2;
    grid-row: 2/3;
}

/* リスト */

.detail-item{
    font-size: clamp(1.6rem,1.8vw,2rem);
    letter-spacing: .08em;
    border-bottom: 1px solid #fff;
    padding-bottom: 8px;
    &:first-child{
        border-top: 1px solid #fff;
    }
    .is-large-gold{
        font-size: 290%;
        color: #a68866;
    }
    .is-small{
        font-size: 150%;
    }
    .is-large{
        font-size: 160%;
    }
    @media screen and (max-width: 768px){
        font-size: 1.6rem;
    }
}
.nomal .detail-item{
    border-bottom: 1px solid #000;
    padding-bottom: 8px;
    &:first-child{
        border-top: 1px solid #000;
    }
}
.detail-item-title{
    position: relative;
    padding-left: 16px;
    font-size: 75%;
    &::before{
        content: "";
        position: absolute;
        top: 5px;
        left: 0;
        width: 10px;
        height: 10px;
        background: #fff;
    }
}
.detail-legend{
}

/* 凡例 */
.detail-legend{
    grid-column: 1/3;
    display: flex;
    flex-direction: column;
    gap: 6px;
    color: #fff;
    letter-spacing: .06em;
    line-height: 1.8;
    font-size: 1.3rem;
    @media screen and (max-width: 768px){
        font-size: 1.2rem;
    }
    &.nomal{
        color: #000;
    }
}
.detail-legend-parts{
    display: flex;
    gap: 16px;
    @media screen and (max-width: 768px){
        flex-direction: column;
        gap: 2px;
    }
}

/* ボタン */
.plan-detail-link-in{
    background: url(../img/plan/bg-plan-btn.webp) no-repeat top center/ cover;
    margin: 1em auto 0;
    padding: 16px 45px;
    width: fit-content;
    display: flex;
    align-items: center;
    justify-content: center;
    background: url(../img/common/footer-bg.webp) center center / cover;
    /* background-color: #a78b41; */
    color: var(--color-white);
    font-size: clamp(1.8rem, 2.4vw, 2.4rem);
    letter-spacing: .3rem;
    position: relative;
    line-height: 1.5;
    @media screen and (max-width: 768px){
        margin: 2em auto 0;
    }
}
.plan-detail-link .arrow{
    width: 0;
    height: 0;
    border-style: solid;
    border-top: 6px solid transparent;
    border-bottom: 6px solid transparent;
    border-left: 10px solid #fff;
    border-right: 0;
    position: absolute;
    top: 53%;
    right: 5%;
    transform: translateY(-50%);
}

.plan .inner{
    padding: clamp(90px, 16vw, 200px) 0 clamp(60px, 8vw, 80px);
}
.plan .l-header {
    background: var(--color-main);
}
.plan .l-header.is-menu-open {
    background: transparent;
}