@layer pages {
    :root {
        --overlap_element_asp_ratio: 18.132;
        --buffer_size: 2px;



    }
}

@layer pages {
    .banner_row {
        display: grid;
        grid-template-columns: 44% 1fr;
        padding-top: 2.5rem;
    }

    .banner_img {
        display: flex;
        align-items: flex-start;
        justify-content: flex-end;
        position: relative;
        /*margin-top: 4.5rem;*/
    }

    .banner_img .img1 {
        max-width: none;
        width: 100%;
    }

    .banner_img .img2 {
        position: absolute;
        width: 60%;
        top: 18.25rem;
        right: 4rem;
        transform: translateY(-100%);
    }

    .grid3 {
        display: grid;
        grid-template-columns: 65% 1fr;
        column-gap: clamp(2rem, 8vw, 9rem);
        row-gap: 3rem;
    }

    .graphic_wrap img {
        display: block;
        margin-left: auto;
        margin-right: auto;
    }

    .graphic_wrap img:first-child {
        width: 12rem;
    }

    .graphic_wrap img:last-child {
        margin-top: -4rem;

    }
}

@layer pages {
    .main_area2 {
        padding-bottom: 3rem;
        margin-top: clamp(-320px, -16.5vw, -300px);
        position: relative;
        z-index: 99;
    }
}


@layer pages {
    .main_area2::after {
        /*content: '';
        display: block;
        width: 100%;
        aspect-ratio: var(--overlap_element_asp_ratio);
        clip-path: shape(from 100% 30.19%, line to 0% 100%, vline to 0%, hline by 100%, vline by 30.19%, close);
        background: #fff;*/
    }
}

@layer pages {
    .main_area3 {
        background: var(--blue_100);
        background: linear-gradient(180deg, rgba(230, 228, 239, 1) 0%, rgba(255, 255, 255, 1) 100%);
        margin-top: -1.3vw;
        /*margin-top: calc(100% / var(--overlap_element_asp_ratio) * -1 + var(--buffer_size));*/
    }

    .main_area3>.inner {
        padding-top: 7rem;
        padding-bottom: 5rem;
    }

    .main_area3 .main_area_inner {
        /*padding-top: calc(100% / var(--overlap_element_asp_ratio) + 3rem + var(--buffer_size));*/
    }
}

@layer pages {
    .main_area5 {
        overflow-x: hidden;
        background: var(--blue_100);
        background: linear-gradient(180deg, #9A84BE, #D8CCE5 50%, #F7EFFF 100%)
    }


    .main_area5 {
        overflow-y: hidden;
        transform: skewY(var(--skew_deg));

        /*margin-top: calc(100% / var(--overlap_element_asp_ratio) * -1 + var(--buffer_size));*/
    }

    .main_area5>.inner {
        transform: skewY(var(--reverse_skew_deg));
        padding-top: 5rem;

    }

    .main_area5 .main_area_inner {
        /*padding-top: calc(100% / var(--overlap_element_asp_ratio) + 3rem + var(--buffer_size));*/
    }

    .overlap_element3 {

        /*display: block;
        width: 100%;
        aspect-ratio: var(--overlap_element_asp_ratio);
        clip-path: shape(from 100% 30.19%, line to 0% 100%, vline to 0%, hline by 100%, vline by 30.19%, close);

        margin-top: -2px;*/
    }

    .grid1 {
        display: grid;
        grid-template-columns: fit-content(35%) 1fr;

    }

    .grid1 .mobile_graphic {
        grid-row: 2 / 2;
        display: flex;
        align-items: flex-end;
        padding-top: 1.3rem;
    }

    .grid1 .mobile_graphic img {
        transform: translateY(1.2vw);
    }

    .grid1 h2 {
        /*grid-column: 1 / 2;*/
        margin-bottom: 0;
    }


    .grid1>*:last-child {
        /*grid-row: 2 / 3;*/
        padding-bottom: 3rem;
    }
}

@layer pages {
    /*.overlap_element3_1 {
        background: linear-gradient(90deg, #9A84BE, #D8CCE5 50%, #F7EFFF 100%);
    }

    .overlap_element3_2 {
        background: #fff;
    }*/
}

@layer pages {
    .main_area4 {
        padding-bottom: 3rem;
        background: linear-gradient(180deg, #D3E8E7 0%, rgba(255, 255, 255, 1) 100%);
        /*margin-top: calc(100% / var(--overlap_element_asp_ratio) * -1 + var(--buffer_size));*/
        overflow-y: hidden;
        transform: skewY(var(--skew_deg));
        margin-top: -1.3vw;
    }

    .main_area4>.inner {
        transform: skewY(var(--reverse_skew_deg));
        padding-top: 5rem;
    }

    .main_area4 .main_area_inner {
        /* padding-top: calc(100% / var(--overlap_element_asp_ratio) + 3rem + var(--buffer_size));*/
    }

    .grid2 {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        row-gap: 4rem;
    }

    .grid2>*:first-child {
        border-right: 2px solid var(--blue_200);
        padding-right: clamp(1.2rem, 1.997vw, 3rem);
    }

    .grid2>*:last-child {
        padding-left: clamp(1.2rem, 1.997vw, 3rem);
    }
}

@layer pages {
    .app_wrapper {
        display: grid;
        grid-template-columns: 8rem 1fr;
        column-gap: 1.5rem;
        row-gap: 1rem;
    }

    .app_wrapper .qr_wrap {
        grid-row: span 2;
    }

    .app_wrapper .e_life_input {
        height: 3.6rem;
    }

    .app_wrapper .e_life_input img {
        width: 100%;
        height: 100%;
        max-width: none;
        object-fit: contain;
        object-position: left;
    }

    .app_row {
        display: flex;
        flex-wrap: wrap;
        column-gap: .5rem;
        row-gap: .5rem;
    }

    .app_row img {
        height: 3rem;
    }
}

@layer pages {
    .index_btn_row {
        display: flex;
        justify-content: center;
        padding-bottom: 1rem;
    }

    .go_down_btn {
        width: 1.7rem;
        height: 1.7rem;
        font-size: 0;
        display: block;
        -webkit-animation: up_down_anim 2s linear infinite;
        animation: up_down_anim 2s linear infinite;
    }

    .go_down_btn::before {
        content: '';
        display: block;
        width: 100%;
        height: 100%;
        background-image: url('../images/icon/icon_arrow.svg');
        background-position: center;
        background-repeat: no-repeat;
        background-size: contain;
        filter: drop-shadow(0 0 .5rem #ff7203);
    }

    @keyframes up_down_anim {
        0% {
            transform: translateY(-1rem);
            opacity: 0;
        }

        50% {
            transform: translateY(0);
            opacity: 1;
        }

        100% {
            transform: translateY(1rem);
            opacity: 0;
        }
    }
}