@charset "utf-8";

/* page-title */
.page-title {
    &.page-topimage {
        background-image: url(../img/topimage_property01.jpg);
        @media (width <= 800px) {
            background-image: url(../img/topimage_property01_sp.jpg);
        }
        .topimage-bottom {
            height: 15.7vw;
            background-image: url(../img/topimage_property02.webp);
            @media (width <= 800px) {
                height: 35.5vw;
                background-image: url(../img/topimage_property02_sp.webp);
            }
        }
    }
}


/* property-top */
.property-top {
    .bikou {
        color: var(--green01);
        font-weight: 700;
        text-align: center;
        margin-bottom: 90px;
        @media (width <= 800px) {
            font-size: 12px;
            line-height: 1.5;
            margin-bottom: 35px;
        }
    }
    .jiten {
        color: var(--green01);
        text-align: center;
        margin: 36px 0 0;
        @media (width <= 800px) {
            font-size: 14px;
            margin-top: 30px;
        }
    }
}
.wave {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    max-width: 712px;
    background-image: url(../img/line_wave.svg);
    background-repeat: no-repeat;
    background-position: left bottom;
    padding-bottom: 40px;
    margin: 0 auto 24px;
    @media (width <= 800px) {
        flex-direction: column;
        max-width: inherit;
        background: none;
        padding: 0;
    }
    p {
        color: var(--green01);
        font-weight: 700;
        margin: 0;
        &.area {
            font-size: 36px;
            text-align: center;
            line-height: 1.28;
            @media (width <= 800px) {
                width: 100%;
                font-size: 20px;
                margin-bottom: 20px;
            }
        }
        &.no {
            position: relative;
            font-size: 111px;
            line-height: 1;
            padding-right: 40px;
            @media (width <= 800px) {
                display: inline-block;
                font-size: 53px;
                text-align: center;
                background-image: url(../img/line_wave_sp.svg);
                background-repeat: no-repeat;
                background-position: left bottom;
                padding: 0 0 25px;
            }
            &::after {
                position: absolute;
                right: 0;
                top: 12px;
                font-family: "Zen Kaku Gothic New", sans-serif;
                font-size: 18px;
                font-weight: 00;
                content: "※1";
                @media (width <= 800px) {
                    right: -22px;
                    top: 30px;
                    font-size: 10px;
                }
            }
        }
    }
}



.circlelist {
    li {
        .cl-img {
            &.cl01 {
                margin-bottom: 25px;
                @media (width <= 800px) {
                    width: 209px;
                }
            }
            &.cl02 {
                margin-bottom: 25px;
                @media (width <= 800px) {
                    width: 203px;
                }
            }
            &.cl03 {
                margin-bottom: 35px;
                @media (width <= 800px) {
                    width: 141px;
                    margin-bottom: 25px;
                }
            }
        }
    }
}


/* feature */
.feature {
    margin-top: 20vw;
    padding-bottom: 22vw;
    background-color: var(--yellowgreen02);
    z-index: 0;
    @media (width <= 800px) {
        margin-top: 59vw;
        padding-bottom: 42.7vw;
    }
    .bg-feature {
        position: absolute;
        left: 0;
        top: -17vw;
        width: 100%;
        z-index: -1;
        @media (width <= 800px) {
            top: -30vw;
        }
        img {
            width: 100%;
        }
    }
    h2 {
        margin-bottom: 16px;
    }
}
.feature-img {
    max-width: 1045px;
    margin: 0 auto 60px;
    @media (width <= 800px) {
        position: relative;
        left: 50%;
        translate: -50% 0;
        width: 108vw;
        max-width: inherit;
        margin: 0 auto 35px;
    }
    img {
        width: 100%;
    }
}
.read-feature {
    color: var(--green01);
    font-size: 36px;
    font-weight: 700;
    line-height: 1.5;
    text-align: center;
    margin-bottom: 0;
    @media (width <= 800px) {
        font-size: 20px;
        line-height: 2.1;
    }
}


/* reason */
.reason {
    background-color: var(--yellowgreen03);
    padding-bottom: 165px;
    z-index: 0;
    @media (width <= 800px) {
        padding-bottom: 50px;
    }
    .bg-reason {
        position: absolute;
        left: 0;
        top: -12vw;
        width: 100%;
        z-index: -1;
        @media (width <= 800px) {
            top: -24.3vw;
        }
        img {
            width: 100%;
        }
    }
    h2 {
        margin-bottom: 64px;
        @media (width <= 800px) {
            margin-bottom: 20px;
        }
    }
}

.reason-content {
    position: relative;
    background-color: var(--white);
    background-repeat: no-repeat;
    background-position: left bottom;
    border-radius: 100px;
    padding: 85px 20px;
    margin-bottom: 105px;
    @media (width <= 800px) {
        border-radius: 30px;
        padding: 56px 20px 40px;
        margin-bottom: 35px;
    }
    &:last-child {
        margin-bottom: 0;
    }
    &.r01 {
        border-radius: 100px 100px 100px 0;
        background-image: url(../img/bg_management.webp);
        background-size: 405px 136px;
        @media (width <= 800px) {
            border-radius: 30px 30px 30px 0;
            background-size: 216px 72px;
            padding-bottom: 100px;
        }
        &::after {
            right: -416px;
            bottom: -169px;
            width: 829px;
            height: 257px;
            background-image: url(../img/reason_cloud01.svg);
        }
    }
    &.r02 {
        &::after {
            left: -614px;
            bottom: 0;
            width: 829px;
            height: 257px;
            background-image: url(../img/reason_cloud02.svg);
        }
        .read-reason {
            margin-bottom: 72px;
        }
    }
    &.r03 {
        border-radius: 100px 100px 100px 0;
        background-image: url(../img/bg_inheritance.webp);
        background-size: 475px 128px;
        @media (width <= 800px) {
            border-radius: 30px 30px 30px 0;
            background-size: 206px 56px;
            padding-bottom: 100px;
        }
        &::after {
            right: -260px;
            bottom: -210px;
            width: 967px;
            height: 314px;
            background-image: url(../img/reason_cloud03.svg);
        }
        .read-reason {
            margin-bottom: 54px;
            @media (width <= 800px) {
                margin-bottom: 35px;
            }
        }
    }
    &.r04 {
        &::after {
            left: -60px;
            bottom: -222px;
            width: 968px;
            height: 315px;
            background-image: url(../img/reason_cloud04.svg);
        }
    }
    &.r05 {
        &::after {
            right: -316px;
            bottom: -220px;
            width: 967px;
            height: 314px;
            background-image: url(../img/reason_cloud05.svg);
        }
        h4 {
            line-height: 2.1;
            margin-bottom: 25px;
        }
        .read-reason {
            margin-bottom: 4px;
        }
        .sansho {
            text-align: center;
            margin-bottom: 64px;
        }
    }
    &.r06 {
        background-image: url(../img/bg_trade.webp);
        background-position: right bottom;
        background-size: 283px 91px;
        border-radius: 100px 100px 0 100px;
        @media (width <= 800px) {
            border-radius: 30px 30px 0 30px;
            background-image: url(../img/bg_trade_sp.webp);
            background-size: 212px 69px;
            padding-bottom: 100px;
        }
        .read-reason {
            margin-bottom: 75px;
            @media (width <= 800px) {
                margin-bottom: 32px;
            }
        }
    }
    &::after {
        position: absolute;
        content: "";
        background-repeat: no-repeat;
        background-position: left top;
        background-size: cover;
        z-index: -1;
        pointer-events: none;
        @media (width <= 800px) {
            display: none;
        }
    }
    h3 {
        position: absolute;
        left: 100px;
        top: -26px;
        display: flex;
        align-items: center;
        justify-content: center;
        width: 191px;
        height: 154px;
        color: var(--white);
        font-size: 36px;
        line-height: 1;
        background-color: var(--green01);
        border-radius: 0 0 30px 30px;
        margin: 0;
        padding-bottom: 10px;
        box-shadow: 10px 10px 0px rgba(209, 209, 209, 0.5);
        &.wide {
            width: 220px;
            @media (width <= 800px) {
                width: 118px;
            }
        }
        @media (width <= 800px) {
            left: 10px;
            top: -14px;
            width: 102px;
            height: 54px;
            font-size: 20px;
            border-radius: 0 0 10px 10px;
            box-shadow: 7px 7px 0px rgba(209, 209, 209, 0.5);
            padding-bottom: 0;
        }
        &::after {
            position: absolute;
            right: -13px;
            top: 0;
            width: 13px;
            height: 26px;
            background-color: var(--green02);
            content: "";
            clip-path: polygon(0 0, 0% 100%, 100% 100%);
            z-index: 1;
            @media (width <= 800px) {
                width: 7px;
                height: 14px;
                right: -7px;
            }
        }
    }
    h4 {
        color: var(--green01);
        font-size: 36px;
        text-align: center;
        margin-bottom: 45px;
        @media (width <= 800px) {
            font-size: 20px;
            line-height: 2;
            margin-bottom: 18px;
        }
    }
    .read-reason {
        color: var(--green01);
        font-size: 20px;
        font-weight: 700;
        line-height: 1.5;
        text-align: center;
        margin-bottom: 85px;
        @media (width <= 800px) {
            font-size: 16px;
            margin-bottom: 48px;
        }
    }
    .management {
        position: relative;
        width: 100%;
        max-width: 864px;
        padding: 56px 32px 0;
        background-color: var(--yellowgreen03);
        border-radius: 40px;
        margin: 0 auto 70px;
        @media (width <= 800px) {
            padding: 10px 0;
            margin-bottom: 45px;
        }
        h5 {
            position: absolute;
            left: 50%;
            top: 0;
            width: 100%;
            text-align: center;
            translate: -50% -50%;
            color: var(--green01);
            font-size: 28px;
            margin: 0;
            @media (width <= 800px) {
                font-size: 16px;
            }
        }
        ul {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 0;
            margin: 0;
            padding: 0;
            @media (width <= 800px) {
                grid-template-columns: repeat(2, 1fr);
            }
            li {
                position: relative;
                display: flex;
                flex-direction: column;
                align-items: flex-end;
                justify-content: center;
                line-height: 1.5;
                padding: 0 24px 24px;
                margin: 0;
                @media (width <= 800px) {
                    align-items: center;
                    padding: 20px;
                }
                &::before,
                &::after {
                    position: absolute;
                    content: "";
                }
                &::before {
                    top: 10px;
                    right: 0;
                    width: 1px;
                    height: calc(100% - 40px);
                    border-right: 2px dotted var(--green01);
                    @media (width <= 800px) {
                        top: 20px;
                    }
                }
                &::after {
                    display: none;
                    left: 50%;
                    bottom: 0;
                    translate: -50% 0;
                    width: calc(100% - 40px);
                    height: 1px;
                    border-bottom: 2px dotted var(--green01);
                    @media (width <= 800px) {
                        display: block;
                    }
                }
                &:nth-child(-n+4) {
                    padding: 0 24px 24px;
                    margin-bottom: 20px;
                    @media (width <= 800px) {
                        padding: 20px;
                        margin-bottom: 0;
                    }
                    &::after {
                        display: block;
                    }
                }
                &:nth-child(4n) {
                    &::before {
                        display: none;
                        @media (width <= 800px) {
                            display: block;
                        }
                    }
                }
                &:nth-child(even) {
                    &::before {
                        @media (width <= 800px) {
                            display: none;
                        }
                    }
                }
                &:nth-last-child(2) {
                    &::after {
                        @media (width <= 800px) {
                            display: none;
                        }
                    }
                }
                &:last-child {
                    &::after {
                        @media (width <= 800px) {
                            display: none;
                        }
                    }
                }
                .m-circle {
                    display: flex;
                    align-items: center;
                    justify-content: flex-end;
                    flex-direction: column;
                    width: 153px;
                    height: 153px;
                    background-color: var(--white);
                    border-radius: 50%;
                    @media (width <= 800px) {
                        width: 107px;
                        height: 107px;
                    }
                    .m-img {
                        display: block;
                        &.mi01 {
                            margin-bottom: 5px;
                            @media (width <= 800px) {
                                width: 49px;
                                margin-bottom: 2px;
                            }
                        }
                        &.mi02 {
                            margin-bottom: 12px;
                            @media (width <= 800px) {
                                width: 61px;
                                margin-bottom: 7px;
                            }
                        }
                        &.mi03 {
                            margin-bottom: 15px;
                            @media (width <= 800px) {
                                width: 67px;
                                margin-bottom: 12px;
                            }
                        }
                        &.mi04 {
                            margin-bottom: 10px;
                            @media (width <= 800px) {
                                width: 60px;
                                margin-bottom: 6px;
                            }
                        }
                        &.mi05 {
                            margin-bottom: 10px;
                            @media (width <= 800px) {
                                width: 61px;
                                margin-bottom: 2px;
                            }
                        }
                        &.mi06 {
                            margin-bottom: 12px;
                            @media (width <= 800px) {
                                width: 88px;
                                margin-bottom: 12px;
                            }
                        }
                        &.mi07 {
                            margin-bottom: 12px;
                            @media (width <= 800px) {
                                width: 87px;
                                margin-bottom: 9px;
                            }
                        }
                        &.mi08 {
                            margin-bottom: 12px;
                            @media (width <= 800px) {
                                width: 67px;
                                margin-bottom: 9px;
                            }
                        }
                    }
                    .m-title {
                        display: block;
                        color: var(--green01);
                        width: 100%;
                        font-weight: 700;
                        text-align: center;
                        padding-bottom: 25px;
                        @media (width <= 800px) {
                            font-size: 14px;
                            line-height: 1.2;
                            padding-bottom: 15px;
                        }
                        &.mt01 {
                            padding-bottom: 15px;
                            @media (width <= 800px) {
                                padding-bottom: 12px;
                            }
                        }
                        &.mt05 {
                            @media (width <= 800px) {
                                padding-bottom: 8px;
                            }
                        }
                    }
                }
            }
        }
    }
    .management-detail {
        display: flex;
        flex-wrap: wrap;
        width: 100%;
        max-width: 864px;
        gap: 50px 0;
        padding: 0;
        margin: 0 auto 70px;
        @media (width <= 800px) {
            gap: 0;
            margin-bottom: 45px;
            padding: 0 10px;
        }
        dt {
            position: relative;
            width: 350px;
            color: var(--green01);
            font-size: 20px;
            line-height: 1.3;
            background-image: url(../img/arrow_r_double.svg);
            background-repeat: no-repeat;
            background-position: 9px 6px;
            padding: 0 0 0 35px;
            margin: 0;
            @media (width <= 800px) {
                width: 100%;
                font-size: 16px;
                line-height: 1.3;
                background-position: left 3px;
                padding: 0 0 12px 26px;
            }
        }
        dd {
            width: calc(100% - 350px);
            line-height: 1.87;
            padding: 0;
            margin: 0;
            @media (width <= 800px) {
                width: 100%;
                font-size: 14px;
                line-height: 1.7;
                padding-bottom: 28px;
                &:last-child {
                    padding-bottom: 0;
                }
            }
        }
    }
    .soudan {
        font-size: 20px;
        font-weight: 700;
        line-height: 1.5;
        text-align: center;
        margin-bottom: 0;
        @media (width <= 800px) {
            font-size: 16px;
            padding: 0 10px;
        }
    }
}


/* tochikatsu */
.tochikatsu {
    position: relative;
    width: 100%;
    max-width: 1066px;
    margin: 0 auto;
    .tochikatsu-content {
        position: relative;
        width: 100%;
        z-index: 1;
        &.wide {
            margin-bottom: 110px;
            @media (width <= 800px) {
                margin-bottom: 72px;
            }
            .tochikatsu-detail {
                max-width: 418px;
                text-align: center;
                box-shadow: 0px 10px 0px var(--green02);
                margin: 0 auto;
                padding-bottom: 45px;
                @media (width <= 800px) {
                    max-width: inherit;
                    padding-bottom: 36px;
                }
                &::after {
                    position: absolute;
                    top: 0;
                    left: -18px;
                    width: calc(100% + 36px);
                    height: 100%;
                    content: "";
                    background-color: var(--white);
                    pointer-events: none;
                    z-index: -1;
                    @media (width <= 800px) {
                        display: none;
                    }
                }
                .logo-vertical {
                    position: relative;
                    top: -60px;
                    max-width: 267px;
                    margin: 0 auto -38px;
                    @media (width <= 800px) {
                        top: -38px;
                        max-width: 158px;
                        margin-bottom: -23px;
                    }
                }
                p {
                    color: var(--green01);
                    font-size: 20px;
                    font-weight: 700;
                    line-height: 1.3;
                    margin-bottom: 0;
                    @media (width <= 800px) {
                        font-size: 14px;
                    }
                    .l-text {
                        display: block;
                        font-size: 28px;
                        margin-top: 5px;
                        @media (width <= 800px) {
                            font-size: 18px;
                        }
                    }
                }
            }
            .arrow-tochikatsu {
                position: absolute;
                left: 50%;
                top: 40%;
                translate: -50% 0;
                width: 100%;
                max-width: 932px;
                z-index: -2;
                @media (width <= 800px) {
                    display: none;
                }
            }
        }
        &.half {
            display: flex;
            position: relative;
            justify-content: space-between;
            @media (width <= 800px) {
                display: block;
            }
            &::before {
                @media (width <= 800px) {
                    position: absolute;
                    left: 7px;
                    top: -56px;
                    width: 15px;
                    height: 100%;
                    content: "";
                    background-color: var(--yellowgreen02);
                    border-radius: 0 0 0 20px;
                }
            }
            .tochikatsu-detail {
                max-width: 483px;
                padding: 0 50px 30px;
                @media (width <= 800px) {
                    width: calc(100% - 64px);
                    max-width: inherit;
                    padding: 0 24px 28px;
                    margin: 0 0 64px auto;
                }
                &:last-child {
                    margin-bottom: 0;
                    @media (width <= 800px) {
                        &::before {
                            background-image: url(../img/arrow_tochikatsu_sp02.webp);
                        }
                        &::after {
                            bottom: 0;
                            left: -57px;
                            width: 15px;
                            height: 50%;
                            background-color: var(--white);
                            z-index: 0;
                        }
                    }
                }
                &::before,
                &::after {
                    position: absolute;
                    content: "";
                }
                &::before {
                    @media (width <= 800px) {
                        top: 50%;
                        translate: 0 -50%;
                        left: -57px;
                        width: 53px;
                        height: 46px;
                        background-image: url(../img/arrow_tochikatsu_sp01.webp);
                        background-repeat: no-repeat;
                        background-position: left top;
                        background-size: cover;
                        z-index: 1;
                    }
                }
                .tochikatsu-img {
                    position: relative;
                    text-align: center;
                    &.ti01 {
                        top: -96px;
                        margin: 0 auto -60px;
                        @media (width <= 800px) {
                            top: -56px;
                            width: 151px;
                            margin: 0 auto -32px;
                        }
                    }
                    &.ti02 {
                        top: -28px;
                        margin: 0 auto 12px;
                        @media (width <= 800px) {
                            width: 150px;
                            margin-bottom: 0;
                        }
                    }
                }
                h5 {
                    color: var(--green01);
                    font-size: 28px;
                    text-align: center;
                    margin-bottom: 32px;
                    @media (width <= 800px) {
                        font-size: 18px;
                        margin-bottom: 24px;
                    }
                    .u-line {
                        text-decoration-thickness: 3px;
                    }
                }
                p {
                    margin-bottom: 10px;
                    @media (width <= 800px) {
                        margin-bottom: 15px;
                    }
                }
                ul {
                    display: flex;
                    flex-wrap: wrap;
                    gap: 8px 10px;
                    border-top: 1px dashed var(--green01);
                    margin: 0;
                    padding: 20px 0 0;
                    li {
                        color: var(--green01);
                        font-weight: 700;
                        background-color: var(--white);
                        border-radius: 9999px;
                        padding: 5px 13px;
                        margin: 0;
                        @media (width <= 800px) {
                            font-size: 14px;
                        }
                    }
                }
            }
        }
        .tochikatsu-detail {
            position: relative;
            width: 100%;
            background-color: var(--yellowgreen02);
            box-shadow: 0px 10px 0px var(--yellowgreen01);
            border-radius: 40px;
            @media (width <= 800px) {
                border-radius: 20px;
            }
        }
    }
}


.aco-content {
    position: relative;
    max-width: 864px;
    background-color: var(--yellowgreen02);
    border-radius: 9999px;
    margin: 0 auto 98px;
    padding: 52px 0 35px;
    @media (width <= 800px) {
        border-radius: 50px;
        padding: 38px 10px;
        margin-bottom: 64px;
    }
    &::after {
        position: absolute;
        left: 50%;
        top: 100%;
        translate: -50% 0;
        width: 190px;
        height: 65px;
        content: "";
        background-color: var(--yellowgreen02);
        clip-path: polygon(50% 100%, 0 0, 100% 0);
        @media (width <= 800px) {
            width: 126px;
            height: 46px;
        }
    }
    .logo-aco {
        max-width: 690px;
        margin: 0 auto 35px;
        @media (width <= 800px) {
            max-width: inherit;
            margin-bottom: 24px;
        }
    }
    ul {
        display: flex;
        justify-content: center;
        gap: 0 25px;
        margin: 0;
        padding: 0;
        @media (width <= 800px) {
            flex-wrap: wrap;
            gap: 12px 0;
            max-width: 275px;
            margin: 0 auto;
        }
        li {
            position: relative;
            min-height: 148px;
            line-height: 1.25;
            margin: 0;
            padding: 0;
            @media (width <= 800px) {
                min-height: 108px;
            }
            &:nth-child(1) {
                @media (width <= 800px) {
                    width: 106px;
                    margin-right: 25px;
                }
            }
            &:nth-child(2) {
                margin-right: 10px;
                @media (width <= 800px) {
                    width: 100px;
                    margin-right: 0px;
                }
            }
            &:nth-child(3) {
                width: 153px;
                @media (width <= 800px) {
                    width: 129px;
                    margin-right: 12px;
                }
            }
            &:nth-child(4) {
                @media (width <= 800px) {
                    width: 108px;
                }
            }
            .aco-img {
                position: relative;
                z-index: 0;
                display: block;
                &.ai01 {
                    @media (width <= 800px) {
                        width: 94px;
                    }
                }
                &.ai02 {
                    @media (width <= 800px) {
                        width: 82px;
                    }
                }
                &.ai03 {
                    @media (width <= 800px) {
                        width: 72px;
                        margin: 0 0 0 20px;
                    }
                }
                &.ai04 {
                    @media (width <= 800px) {
                        width: 88px;
                        margin: 0 0 0 auto;
                    }
                }
            }
            .aco-title {
                position: absolute;
                bottom: 0;
                display: flex;
                justify-content: center;
                align-items: center;
                width: 105px;
                height: 53px;
                color: var(--white);
                font-size: 16px;
                font-weight: 700;
                text-align: center;
                border-radius: 9999px;
                background-color: var(--green01);
                z-index: 1;
                @media (width <= 800px) {
                    width: 105px;
                    height: 45px;
                    font-size: 14px;
                    line-height: 1.28;
                }
                &.at01 {
                    right: 0;
                    @media (width <= 800px) {
                        right: auto;
                        left: 0;
                    }
                }
                &.at02 {
                    right: -5px;
                    @media (width <= 800px) {
                        right: auto;
                        left: 0;
                    }
                }
                &.at03 {
                    left: -5px;
                    width: 153px;
                    @media (width <= 800px) {
                        width: 129px;
                        left: 0;
                    }
                }
                &.at04 {
                    left: -10px;
                    @media (width <= 800px) {
                        left: 0;
                    }
                }
            }
        }
    }
}
.taisaku {
    width: 100%;
    max-width: 813px;
    margin: 0 auto;
    @media (width <= 800px) {
        max-width: 257px;
    }
    ul {
        display: flex;
        gap: 0 48px;
        width: 100%;
        margin: 0 0 40px;
        padding: 0;
        @media (width <= 800px) {
            flex-wrap: wrap;
            gap: 20px 0;
            margin-bottom: 25px;
        }
        li {
            display: flex;
            align-items: center;
            justify-content: center;
            width: 100%;
            height: 82px;
            color: var(--white);
            font-size: 28px;
            font-weight: 700;
            background-color: var(--green01);
            border-radius: 9999px;
            @media (width <= 800px) {
                height: 55px;
                font-size: 18px;
            }
        }
    }
    .read-taisaku {
        color: var(--green01);
        font-size: 28px;
        font-weight: 700;
        text-align: center;
        margin-bottom: 0;
        @media (width <= 800px) {
            font-size: 18px;
            line-height: 1.5;
        }
    }
}


.plan-content {
    h5 {
        color: var(--green01);
        font-size: 28px;
        text-align: center;
        margin-bottom: 54px;
        @media (width <= 800px) {
            font-size: 18px;
            line-height: 1.5;
            margin-bottom: 16px;
        }
    }
    ol {
        display: flex;
        gap: 0 16px;
        width: 100%;
        max-width: 1067px;
        margin: 0 auto 16px;
        padding: 0;
        counter-reset: num;
        @media (width <= 800px) {
            flex-wrap: wrap;
            gap: 10px 0;
            margin-bottom: 40px;
        }
        li {
            position: relative;
            width: 100%;
            height: 146px;
            display: flex;
            align-items: center;
            justify-content: center;
            color: var(--green01);
            font-size: 20px;
            font-weight: 700;
            line-height: 1.3;
            text-align: center;
            background-color: var(--yellowgreen02);
            border: 1px solid var(--green01);
            border-radius: 20px;
            padding-top: 10px;
            @media (width <= 800px) {
                justify-content: flex-start;
                height: 52px;
                font-size: 16px;
                border-radius: 9999px;
                padding: 0 0 0 60px;
            }
            &::after {
                position: absolute;
                left: 50%;
                top: 0;
                translate: -50% 0;
                pointer-events: none;
                top: -1px;
                width: 50px;
                height: 1px;
                content: "";
                background-color: var(--yellowgreen02);
                z-index: 0;
                @media (width <= 800px) {
                    display: none;
                }
            }
            .no {
                position: absolute;
                left: 50%;
                top: -10px;
                translate: -50% 0;
                font-family: "Poppins", sans-serif;
                font-size: 29px;
                font-weight: 700;
                letter-spacing: 0.05em;
                line-height: 1;
                padding-bottom: 6px;
                z-index: 1;
                @media (width <= 800px) {
                    left: 22px;
                    top: 50%;
                    translate: 0 -45%;
                    font-size: 18px;
                    padding-bottom: 3px;
                }
                &::before {
                    counter-increment: num;
                    content: counter(num, decimal-leading-zero);
                }
                &::after {
                    position: absolute;
                    left: 50%;
                    bottom: 0;
                    translate: -50% 0;
                    width: 22px;
                    height: 1px;
                    content: "";
                    background-color: var(--green01);
                    @media (width <= 800px) {
                        width: calc(100% - 6px);
                    }
                }
            }
        }
    }
}

.plus-content {
    display: flex;
    justify-content: center;
    align-items: flex-end;
    gap: 0 20px;
    margin-bottom: 30px;
    @media (width <= 800px) {
        flex-wrap: wrap;
        align-items: center;
        width: calc(100% + 6px);
        max-width: 305px;
        margin: 0 auto 20px;
    }
    .logo-plus {
        max-width: 434px;
        padding-bottom: 24px;
        @media (width <= 800px) {
            width: 233px;
            max-width: inherit;
            padding-bottom: 6px;
            img {
                width: 100%;
            }
        }
    }
    .plus-text {
        font-size: 30px;
        font-weight: 700;
        padding-bottom: 36px;
        @media (width <= 800px) {
            position: relative;
            left: -10px;
            width: 48px;
            font-size: 16px;
            padding-bottom: 5px;
        }
    }
    .plus-img {
        @media (width <= 800px) {
            width: 140px;
            margin-left: 10%;
            img {
                width: 100%;
            }
        }
    }
}

.sublease-content {
    display: flex;
    gap: 0 4%;
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    @media (width <= 800px) {
        flex-wrap: wrap;
        gap: 20px 0;
    }
    .sublease-detail {
        width: 100%;
        background-color: var(--yellowgreen02);
        border-radius: 40px;
        padding: 26px 0 36px;
        @media (width <= 800px) {
            padding: 30px;
        }
        .sublease-img {
            display: flex;
            align-items: center;
            justify-content: center;
            width: 121px;
            height: 121px;
            background-color: var(--white);
            border-radius: 50%;
            margin: 0 auto 12px;
            @media (width <= 800px) {
                width: 106px;
                height: 106px;
                margin-bottom: 20px;
            }
            &.si01 {
                img {
                    @media (width <= 800px) {
                        width: 57px;
                    }
                }
            }
            &.si02 {
                img {
                    @media (width <= 800px) {
                        width: 71px;
                    }
                }
            }
            &.si03 {
                img {
                    @media (width <= 800px) {
                        width: 70px;
                    }
                }
            }
        }
        h5 {
            display: flex;
            align-items: center;
            justify-content: center;
            color: var(--green01);
            min-height: 90px;
            font-size: 20px;
            line-height: 1.5;
            text-align: center;
            margin-bottom: 12px;
            @media (width <= 800px) {
                width: calc(100% + 20px);
                min-height: inherit;
                font-size: 16px;
                margin: 0 0 12px -10px;
            }
        }
        p {
            max-width: 260px;
            margin: 0 auto;
            @media (width <= 800px) {
                max-width: inherit;
                font-size: 14px;
                line-height: 1.7;
            }
        }
    }
}


.awards-content {
    position: relative;
    display: flex;
    align-items: center;
    width: 100%;
    max-width: 826px;
    min-height: 177px;
    background-color: var(--yellowgreen02);
    border-radius: 89px;
    margin: 0 auto 100px;
    @media (width <= 800px) {
        display: block;
        min-height: inherit;
        padding: 34px 30px 43px;
        border-radius: 50px;
        margin-bottom: 40px;
    }
    .awards-img {
        position: absolute;
        top: -45px;
        left: -60px;
        @media (width <= 800px) {
            top: -36px;
            left: 36px;
            width: 76px;
        }
    }
    h5 {
        width: 295px;
        color: var(--green01);
        font-size: 36px;
        text-align: center;
        margin: 0;
        padding: 0 0 0 30px;
        @media (width <= 800px) {
            width: 100%;
            font-size: 20px;
            margin-bottom: 30px;
            padding: 0;
        }
    }
    ul {
        width: calc(100% - 295px);
        margin: 0;
        padding: 0;
        @media (width <= 800px) {
            width: calc(100% + 40px);
            margin-left: -20px;
        }
        li {
            position: relative;
            font-size: 20px;
            font-weight: 700;
            line-height: 1.5;
            margin: 0 0 14px;
            @media (width <= 800px) {
                font-size: 16px;
                text-align: center;
            }
            &:last-child {
                margin-bottom: 0;
            }
            .a-year {
                position: relative;
                display: inline-block;
                padding-left: 16px;
                @media (width <= 800px) {
                    padding-left: 13px;
                }
                &::before {
                    position: absolute;
                    left: 0;
                    top: 50%;
                    translate: 0 -50%;
                    width: 10px;
                    height: 12px;
                    content: "";
                    background-color: var(--yellow01);
                    clip-path: polygon(0 0, 0% 100%, 100% 50%);
                    @media (width <= 800px) {
                        width: 8px;
                        height: 10px;
                    }
                }
            }
            .a-bottom {
                @media (width <= 800px) {
                    display: block;
                }
                .a-text {
                    display: inline-block;
                    padding: 0 1em;
                    @media (width <= 800px) {
                        padding: 0 1em 0 0;
                    }
                }
                .u-line {
                    text-decoration-thickness: 3px;
                    text-underline-offset: 5px;
                }

            }
        }
    }
}


.store-content {
    display: flex;
    gap: 0 5.5%;
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    @media (width <= 800px) {
        flex-wrap: wrap;
        gap: 0;
        padding: 0 10px;
    }
    .store-detail {
        position: relative;
        width: 20.9%;
        @media (width <= 800px) {
            display: flex;
            align-items: flex-start;
            justify-content: center;
            flex-direction: column;
            width: 100%;
            min-height: 80px;
            padding: 0 0 0 120px;
            margin-bottom: 20px;
        }
        &:last-child {
            @media (width <= 800px) {
                margin-bottom: 0;
            }
            &::after {
                display: none;
            }
        }
        &::after {
            position: absolute;
            right: -13%;
            top: 0;
            width: 1px;
            height: 100%;
            content: "";
            background-color: var(--green01);
            @media (width <= 800px) {
                right: auto;
                left: 0;
                top: auto;
                bottom: -10px;
                width: 100%;
                height: 1px;
            }
        }
        .store-img {
            width: 100%;
            margin: 0 auto 15px;
            @media (width <= 800px) {
                position: absolute;
                left: 0;
                top: 0;
                width: 108px;
            }
        }
        h5 {
            font-size: 20px;
            line-height: 1.5;
            text-align: center;
            margin-bottom: 0;
            @media (width <= 800px) {
                font-size: 16px;
            }
        }
        p {
            text-align: center;
            margin: 0;
            @media (width <= 800px) {
                font-size: 14px;
            }
        }
    }
}

.trade-content {
    position: relative;
    display: flex;
    flex-direction: row-reverse;
    width: 100%;
    max-width: 1200px;
    margin: 0 0 0 auto;
    @media (width <= 800px) {
        display: block;
    }
    .l-trade {
        width: 45.8%;
        padding: 0 70px 0 20px;
        @media (width <= 800px) {
            width: 100%;
            padding: 0 10px;
        }
        .trade-detail {
            margin-bottom: 35px;
            @media (width <= 800px) {
                margin-bottom: 24px;
            }
            &:last-child {
                margin-bottom: 0;
            }
            h5 {
                color: var(--green01);
                font-size: 20px;
                line-height: 1.3;
                margin-bottom: 12px;
                @media (width <= 800px) {
                    font-size: 16px;
                    padding-left: 24px;
                    margin-bottom: 6px;
                }
                &::before {
                    position: absolute;
                    left: -24px;
                    top: 7px;
                    width: 19px;
                    height: 14px;
                    content: "";
                    background-image: url(../img/arrow_r_double.svg);
                    background-repeat: no-repeat;
                    background-position: left top;
                    background-size: cover;
                    @media (width <= 800px) {
                        left: 0;
                        top: 4px;
                    }
                }
            }
            p {
                margin-bottom: 0;
                @media (width <= 800px) {
                    font-size: 14px;
                }
            }
        }
    }
    .r-trade {
        width: 54.2%;
        @media (width <= 800px) {
            width: calc(100% + 10px);
            margin-bottom: 35px;
        }
        .trade-img {
            width: 100%;
            img {
                width: 100%;
                border-radius: 30px 0 0 30px;
            }
        }
    }
}


/* serviceflow */
.serviceflow {
    background-color: var(--lightblue);
    padding: 0 0 156px;
    @media (width <= 800px) {
        padding-bottom: 56px;
    }
    .bg-serviceflow {
        position: relative;
        width: 100%;
        background-color: var(--yellowgreen03);
        img {
            width: 100%;
        }
    }
    h2 {
        padding-top: 56px;
        margin-bottom: 20px;
        @media (width <= 800px) {
            padding-top: 48px;
            margin-bottom: 8px;
        }
        .en {
            color: var(--gray02);
        }
    }
    .read-serviceflow {
        text-align: center;
        margin-bottom: 70px;
        @media (width <= 800px) {
            font-size: 16px;
            margin-bottom: 32px;
        }
    }
}

.serviceflow-content {
    display: flex;
    gap: 0 43px;
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
    @media (width <= 800px) {
        flex-wrap: wrap;
        gap: 30px 0;
    }
    .serviceflow-detail {
        position: relative;
        width: 100%;
        background-color: var(--white);
        border-radius: 20px;
        padding-bottom: 26px;
        @media (width <= 800px) {
            display: flex;
            border-radius: 10px;
            padding: 20px 20px 20px 0;
        }
        &:last-child {
            &::after {
                display: none;
            }
        }
        &::after {
            position: absolute;
            right: -24px;
            top: 50%;
            translate: 0 -50%;
            width: 24px;
            height: 46px;
            background-color: var(--white);
            content: "";
            clip-path: polygon(0 0, 0% 100%, 100% 50%);
            @media (width <= 800px) {
                right: auto;
                left: 50%;
                top: 100%;
                translate: -50% 0;
                width: 30px;
                height: 16px;
                clip-path: polygon(50% 100%, 0 0, 100% 0);
            }
        }
        .l-serviceflow {
            position: relative;
            width: 100%;
            padding: 36px 0 10px;
            @media (width <= 800px) {
                display: flex;
                flex-wrap: wrap;
                align-items: center;
                justify-content: center;
                width: 114px;
                border-right: 1px solid var(--green01);
                padding: 0;
            }
            .step {
                position: absolute;
                left: 0;
                top: 0;
                translate: 0 -50%;
                width: 100%;
                color: var(--green01);
                font-family: "Poppins", sans-serif;
                font-size: 35px;
                font-weight: 600;
                text-align: center;
                letter-spacing: 0.05em;
                line-height: 1;
                @media (width <= 800px) {
                    position: relative;
                    left: auto;
                    top: auto;
                    translate: 0 0;
                    display: block;
                    font-size: 20px;
                }
            }
            .serviceflow-img {
                display: flex;
                justify-content: center;
                align-items: center;
                height: 89px;
                margin: 0 auto;
                @media (width <= 800px) {
                    height: auto;
                }
                &.si01 {
                    @media (width <= 800px) {
                        width: 63px;
                    }
                }
                &.si02 {
                    @media (width <= 800px) {
                        width: 59px;
                    }
                }
                &.si03 {
                    @media (width <= 800px) {
                        width: 44px;
                    }
                }
                &.si04 {
                    @media (width <= 800px) {
                        width: 49px;
                    }
                }
            }
        }
        .r-serviceflow {
            width: 100%;
            @media (width <= 800px) {
                display: flex;
                flex-wrap: wrap;
                align-content: center;
                align-items: center;
                width: calc(100% - 113px);
                padding-left: 18px;
            }
            h3 {
                color: var(--green01);
                font-size: 20px;
                line-height: 1.3;
                text-align: center;
                padding: 0 0 10px;
                margin-bottom: 12px;
                @media (width <= 800px) {
                    width: 100%;
                    font-size: 16px;
                    text-align: left;
                    padding: 0;
                    margin-bottom: 3px;
                }
                &::after {
                    position: absolute;
                    left: 50%;
                    bottom: 0;
                    translate: -50% 0;
                    width: calc(100% - 70px);
                    height: 1px;
                    content: "";
                    background-color: var(--green01);
                    @media (width <= 800px) {
                        display: none;
                    }
                }
            }
            p {
                display: flex;
                align-items: center;
                justify-content: center;
                min-height: 84px;
                text-align: center;
                margin-bottom: 0;
                @media (width <= 800px) {
                    display: block;
                    width: 100%;
                    text-align: left;
                    min-height: inherit;
                }
            }
        }
    }
}


/* manshitsu */
.manshitsu {
    padding-bottom: 36vw;
    @media (width <= 800px) {
        padding-bottom: 45.3vw;
    }
    .bg-manshitsu {
        background-color: var(--lightblue);
        pointer-events: none;
        img {
            width: 100%;
        }
    }
    .read-manshitsu {
        font-size: 26px;
        font-weight: 700;
        line-height: 1.5;
        text-align: center;
        margin: -11.3vw 0 44px;
        @media (width <= 800px) {
            font-size: 16px;
            margin: -6.4vw 0 16px;
        }
    }
    h2 {
        margin-bottom: 30px;
        @media (width <= 800px) {
            margin-bottom: 8px;
        }
    }
}
.bn-manshitsu {
    width: 100%;
    max-width: 541px;
    margin: 0 auto 104px;
    @media (width <= 800px) {
        width: calc(100% - 34px);
        max-width: inherit;
        margin: 0 auto 50px;
        img {
            width: 100%;
        }
    }
}
.seminar-content {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    max-width: 1300px;
    background-color: var(--yellowgreen02);
    border-radius: 100px;
    margin: 0 auto;
    padding: 90px 100px 60px;
    @media (width <= 800px) {
        flex-wrap: wrap;
        gap: 24px 0;
        border-radius: 30px;
        padding: 30px 30px 40px;
    }
    &::before {
        position: absolute;
        top: -60px;
        left: 50%;
        translate: -50% 0;
        width: 138px;
        height: 60px;
        background-color: var(--yellowgreen02);
        content: "";
        clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
        @media (width <= 800px) {
            top: -16px;
            width: 40px;
            height: 17px;
        }
    }
    .l-seminar {
        position: relative;
        width: 52%;
        @media (width <= 800px) {
            width: 100%;
        }
        .fukidashi-seminar {
            position: relative;
            left: -60px;
            margin-bottom: 20px;
            @media (width <= 800px) {
                left: -24px;
                width: 181px;
                margin-bottom: 14px;
            }
        }
        h3 {
            color: var(--green01);
            font-size: 26px;
            margin-bottom: 40px;
            @media (width <= 800px) {
                font-size: 16px;
                margin-bottom: 10px;
            }
        }
        p {
            margin-bottom: 32px;
            @media (width <= 800px) {
                margin-bottom: 0;
            }
        }
    }
    .r-seminar {
        width: 42.6%;
        @media (width <= 800px) {
            width: 100%;
        }
        .seminar-img {
            width: 100%;
            @media (width <= 800px) {
                margin: 0 auto 20px;
            }
            img {
                width: 100%;
            }
        }
    }
    .btn {
        color: var(--green01);
        background-color: var(--yellowgreen02);
        border: 1px solid var(--green01);
        @media (width >= 800px) {
            &:hover {
                color: var(--white);
                border: 1px solid var(--darkgray);
                background-color: var(--darkgray);
                &::after {
                    background-color: var(--white);
                }
            }
        }
        &::after {
            position: absolute;
            right: 20px;
            top: 50%;
            translate: 0 -50%;
            width: 18px;
            height: 18px;
            background-color: var(--green01);
            mask-image: url(../img/icon_link.svg);
            mask-position: left top;
            mask-repeat: no-repeat;
            mask-size: cover;
            content: "";
            pointer-events: none;
            transition: all 0.3s ease-out;
        }
    }
}