@charset "UTF-8";
/*==============================================================================
1.イントロ
2.バナー
3.フロー
4.お預け入れ・お取り出し方法
5.よくあるご質問
==============================================================================*/


/*============================================================================================================================================================
==============================================================================================================================================================

	1.イントロ

==============================================================================================================================================================
============================================================================================================================================================*/
#intro {
    display: flex;
    justify-content: center;

    & ul {

        & li {
            padding-left: 30px;
            position: relative;
            font-family: var(--font-sub);
            font-weight: var(--weight-bold);
            font-size: 1.4rem;

            &::before {
                content: "";
                width: 21px;
                aspect-ratio: 31 / 27;
                position: absolute;
                top: 0.3em;
                left: 0;
                background: url(../1_img/base/icon-checkbox.svg) no-repeat center / 100% auto;
            }

            &+li {
                margin-top: 15px;
            }
        }
    }

}

/*==============================================================================

	intro PC

==============================================================================*/
@media all and (min-width: 768px) {
    #intro {

        & ul {

            & li {
                padding-left: 50px;
                font-size: 2.2rem;

                &::before {
                    width: 31px;
                }

                &+li {
                    margin-top: 45px;
                }
            }
        }

    }
}


/*============================================================================================================================================================
==============================================================================================================================================================

	2.バナー

==============================================================================================================================================================
============================================================================================================================================================*/
.flow-banner {
    margin-top: 35px;
    text-align: center;

    & .fukidashi-wrap {
        margin-bottom: 20px;
        font-size: 2.2rem;
        font-family: var(--font-sub);
    }

    & img {
        width: 100%;
        height: auto;
    }
}

/*==============================================================================

	バナー PC

==============================================================================*/
@media all and (min-width: 768px) {
    .flow-banner {
        margin-top: 110px;

        & .fukidashi-wrap {
            font-size: 3.4rem;
        }

        & img {
            width: 1000px;
        }
    }
}









/*============================================================================================================================================================
==============================================================================================================================================================

	3.フロー

==============================================================================================================================================================
============================================================================================================================================================*/
#flow {
    margin-top: 50px;
    padding: 80px 0 100px;
    position: relative;
    z-index: 3;
    background-color: var(--color-sub);
    clip-path: polygon(50% 0, 100% 60px, 100% calc(100% - 60px), 50% 100%, 0 calc(100% - 60px), 0 60px);

    & h2 {
        margin-bottom: 40px;
        font-weight: var(--weight-bold);
        font-size: 1.5rem;
        font-family: var(--font-sub);

        & img {
            margin: 0 7px;
            width: 16px;
            vertical-align: text-bottom;
        }

        & em {
            &[lang="ja"] {
                font-size: 2.2rem;
            }

            &[lang="en"] {
                font-size: 2.6rem;
                font-family: var(--font-en);
            }
        }
    }

    /*======== flow =========*/
    & .flow-list {
        position: relative;

        /* flowの横の線 */
        &::before {
            content: "";
            width: 2px;
            height: 100%;
            position: absolute;
            top: 0;
            left: 25px;
            transform: translateX(-50%);
            background-color: var(--color-font);
        }

        & li {
            padding-left: 70px;
            position: relative;
            display: flex;
            flex-direction: column;
            align-items: flex-start;
            gap: 10px 0;

            & .flow-num {
                width: 50px;
                aspect-ratio: 50 / 57;
                display: flex;
                align-items: center;
                justify-content: center;
                position: absolute;
                top: -10px;
                left: 0;
                color: #fff;
                font-family: var(--font-en);
                font-weight: var(--weight-bold);
                font-size: 3.1rem;
                background-color: var(--color-font);
                line-height: 1;
                clip-path: polygon(50% 0, 100% 15px, 100% calc(100% - 15px), 50% 100%, 0 calc(100% - 15px), 0 15px);
            }

            & .flow-title {
                margin-bottom: -5px;
                font-weight: var(--weight-medium);
                font-family: var(--font-sub);
                font-size: 1.8rem;
                letter-spacing: 0.2em;
            }

            /* お申し込みボタン */
            & .apply {
                margin-right: 10px;
                margin-bottom: 5px;
                padding: 3px 10px 3px 35px;
                display: inline-block;
                position: relative;
                background-color: var(--color-accent);
                font-weight: var(--weight-medium);
                border-radius: 5px;

                &::after {
                    content: "";
                    width: 18px;
                    aspect-ratio: 1 / 1;
                    position: absolute;
                    top: 50%;
                    left: 10px;
                    transform: translateY(-50%);
                    background: url(../1_img/base/icon-pen.svg) no-repeat center / 100% auto;
                }
            }
        }

        &.yellow li .flow-num{
            background-color: var(--color-accent);
            color: var(--color-font);
        }

        & li+li {
            margin-top: 35px;
        }

        /* flowの横の線の打ち消し用 */
        & li:last-child::before {
            content: "";
            width: 2px;
            height: calc(100% - 10px);
            position: absolute;
            top: 10px;
            left: 25px;
            transform: translateX(-50%);
            background-color: var(--color-sub);
        }
    }

    /*======== お申し込み & 利用開始 =========*/
    & .complete-start{
        padding: 10px;
        margin-top: 30px;
        background-color: #fff;
        text-align: center;
        border-radius: 2em;
        font-weight: var(--weight-medium);
        font-size: 1.8rem;
    }


    /*======== タブ =========*/
    & .flow-tab_container{
        margin-top: 40px;
    }
    & .flow-tab_tabs {
        display: flex;
        gap: 0 20px;

        & button {
            flex: 1;
            padding: 12px 0;
            text-align: center;
            cursor: pointer;
            border-radius: 15px 15px 0 0;
            background: var(--color-font);
            color: #fff;
            font-weight: bold;
            font-family: var(--font-sub);
            transition: 500ms;

            &:hover {
                opacity: 0.6;
            }

            &.active {
                background: var(--color-accent);
            }
        }
    }

    /*======== タブ コンテンツ =========*/
    & .flow-tab_contents {
        padding-top: 20px;
        border-top: 5px solid var(--color-accent);

        & > div {
            padding: 20px 10px;
            display: none;
            opacity: 0;
            transition: opacity 500ms ease;

            &.active {
                display: block;
                opacity: 1;
            }
        }
    }
}

/*==============================================================================

	フロー PC

==============================================================================*/
@media all and (min-width: 768px) {
    #flow {
        margin-top: 120px;
        padding: 130px 0 160px;
        background-color: var(--color-sub);
        clip-path: polygon(50% 0, 100% 130px, 100% calc(100% - 130px), 50% 100%, 0 calc(100% - 130px), 0 130px);

        & h2 {
            margin-bottom: 100px;
            font-size: 3rem;

            & img {
                margin: 0 10px;
                width: 26px;
            }

            & em {
                &[lang="ja"] {
                    font-size: 3rem;
                }

                &[lang="en"] {
                    font-size: 4rem;
                }
            }
        }

        /*======== flow =========*/
        & .flow-list {
            position: relative;

            /* flowの横の線 */
            &::before {
                width: 5px;
                left: 40px;
            }

            & li {
                padding-left: 150px;

                & .flow-num {
                    width: 80px;
                    top: -10px;
                    font-size: 4.5rem;
                    clip-path: polygon(50% 0, 100% 25px, 100% calc(100% - 25px), 50% 100%, 0 calc(100% - 25px), 0 25px);
                }

                & .flow-title {
                    margin-bottom: 0px;
                    font-size: 2.8rem;
                }

                & .flow-text {
                    font-size: 1.8rem;
                }

                /* お申し込みボタン */
                & .apply {
                    margin-right: 20px;
                    padding: 3px 20px 3px 55px;

                    &::after {
                        content: "";
                        left: 23px;
                        width: 25px;
                    }
                }
            }

            & li+li {
                margin-top: 35px;
            }

            /* flowの横の線の打ち消し用 */
            & li:last-child::before {
                width: 7px;
                height: calc(100%);
                left: 40px;
            }
        }

        /*======== お申し込み完了 =========*/
        & .apply-complete{
            padding: 10px;
            margin-top: 50px;
            font-size: 2.2rem;
        }
    }
}




/*============================================================================================================================================================
==============================================================================================================================================================

	4.お預け入れ・お取り出し方法

==============================================================================================================================================================
============================================================================================================================================================*/
#howto {
    margin-top: -60px;
    padding: 100px 0 90px;
    position: relative;
    z-index: 2;
    background-color: #fff;
    clip-path: polygon(100% 0, 100% calc(100% - 60px), 50% 100%, 0 calc(100% - 60px), 0 0);

    /*======== イントロ =========*/
    & .howto-intro {
        text-align: center;

        & p {
            padding: 0 50px;
            display: inline-block;
            position: relative;
            font-size: 1.8rem;
            font-family: var(--font-sub);
            font-weight: var(--weight-bold);
            letter-spacing: 0.2em;

            &::before,
            &::after {
                content: "";
                margin-bottom: 20px;
                width: 40px;
                height: 3px;
                position: absolute;
                bottom: 0;
                background: url(../1_img/base/border-dotted.svg) repeat-x center left / auto 3px;
            }

            &::before {
                left: -5px;
                transform: rotate(60deg);
            }

            &::after {
                right: -5px;
                transform: rotate(-60deg);
            }
        }
    }

    /*======== 取り出し方法 =========*/
    & .howto-list {
        margin-top: 50px;
        padding: 0 10px;

        & li {
            position: relative;
            display: flex;
            flex-direction: column;
            gap: 20px 0;

            & .howto-num {
                width: 60px;
                aspect-ratio: 50 / 57;
                display: flex;
                align-items: center;
                justify-content: center;
                position: absolute;
                top: -20px;
                left: -10px;
                font-family: var(--font-en);
                font-weight: var(--weight-bold);
                font-size: 3.1rem;
                color: #fff;
                background-color: var(--color-font);
                line-height: 1;
                clip-path: polygon(50% 0, 100% 15px, 100% calc(100% - 15px), 50% 100%, 0 calc(100% - 15px), 0 15px);
            }

            /* テキストのとこ */
            &>div {
                padding: 0 20px;
                text-align: center;

                & h3 {
                    font-family: var(--font-sub);
                    font-weight: var(--weight-bold);
                    font-size: 1.8rem;

                    & span {
                        color: var(--color-accent);
                    }
                }

                & p {
                    margin-top: 10px;
                }
            }

            &>img {
                width: 100%;
            }
        }

        & li+li {
            margin-top: 50px;
        }
    }

    /*======== チェックリスト =========*/
    & .howto-check {
        margin: 40px auto 0;
        padding: 35px 20px 25px;
        width: calc(100% - 20px);
        position: relative;
        border: 2px dotted var(--color-font);
        border-radius: 10px;

        & h4 {
            width: 100%;
            position: absolute;
            top: 0;
            left: 0;
            transform: translateY(-50%);
            text-align: center;

            & span {
                padding: 0 10px;
                display: inline-block;
                background-color: #fff;
                font-size: 1.8rem;
                font-weight: var(--weight-bold);
            }

            & img {
                margin: 0 5px;
                vertical-align: text-bottom;
            }
        }

        & .howto-check_list {

            & li {
                display: flex;
                align-items: start;
                gap: 0 20px;
                font-family: var(--font-sub);
                font-weight: var(--weight-bold);
                line-height: 1.6;

                &:nth-child(1)::before{
                    background-image: url(../1_img/base/num-1.svg);
                }
                &:nth-child(2)::before{
                    background-image: url(../1_img/base/num-2.svg);
                }
                &:nth-child(3)::before{
                    background-image: url(../1_img/base/num-3.svg);
                }

                & + li{
                    margin-top: 15px;
                }
            }

            & li::before {
                content: "";
                width: 20px;
                flex-shrink: 0;
                aspect-ratio: 24 / 43;
                background-size: 100% auto;
                background-position: center;
            }

        }
    }
}

/*==============================================================================

	お預け入れ・お取り出し方法 PC

==============================================================================*/
@media all and (min-width: 768px) {
    #howto {
        margin-top: -130px;
        padding: 260px 0 210px;
        clip-path: polygon(100% 0, 100% calc(100% - 130px), 50% 100%, 0 calc(100% - 130px), 0 0);

        /*======== イントロ =========*/
        & .howto-intro {
            text-align: center;

            & p {
                padding: 0 50px;
                font-size: 2.2rem;

                &::before,
                &::after {
                    margin-bottom: 15px;
                }
            }
        }

        /*======== 取り出し方法 =========*/
        & .howto-list {
            margin-top: 70px;
            padding: 0 20px;

            & li {
                flex-direction: row;
                align-items: center;
                gap: 70px;

                & .howto-num {
                    width: 75px;
                    top: -20px;
                    left: -20px;
                    font-size: 4.8rem;
                }

                /* テキストのとこ */
                &>div {
                    padding: 0 20px;

                    & h3 {
                        text-align: left;
                        font-size: 2.4rem;
                    }

                    & p {
                        margin-top: 10px;
                        font-size: 1.8rem;
                        text-align: left;
                    }
                }

                &>img {
                    width: 380px;
                    flex-shrink: 0;
                }
            }

            & li+li {
                margin-top: 65px;
            }
        }

        /*======== チェックリスト =========*/
        & .howto-check {
            margin: 100px auto 0;
            padding: 70px 20px;
            width: calc(100% - 40px);
            text-align: center;
            border-radius: 20px;

            & h4 {

                & span {
                    padding: 0 30px;
                    font-size: 3rem;
                }

                & img {
                    margin: 0 8px 5px;
                    width: 37px;
                    vertical-align: middle;
                }
            }

            & .howto-check_list {
                display: inline-block;

                & li {
                    font-size: 2.2rem;
                }
            }
        }
    }
}


/*============================================================================================================================================================
==============================================================================================================================================================

	5.よくあるご質問

==============================================================================================================================================================
============================================================================================================================================================*/
#faq {
    margin-top: -60px;
    padding: 100px 0 90px;
    position: relative;
    z-index: 1;
    background-color: var(--color-font);
    clip-path: polygon(100% 0, 100% calc(100% - 60px), 50% 100%, 0 calc(100% - 60px), 0 0);
    color: #fff;

    /*======== qaのカテゴリ =========*/
    & .cate-wrap{

        & h3{
            margin-bottom: 15px;
            font-size: 1.5rem;
            font-family: var(--color-sub);
            font-weight: var(--weight-bold);
        }

        & + .cate-wrap{
            margin-top: 20px;
        }
    }


    /*======== qa =========*/
    & .faq-item {
        line-height: 1.6;
        border-radius: 10px;
        overflow: hidden;

        &+.faq-item {
            margin-top: 10px;
        }

        /* 質問 */
        & .faq-item_q {
            cursor: pointer;
            position: relative;
            padding: 20px 50px;
            transition: background 0.3s;
            background-color: #fff;
            color: var(--color-font);

            &:hover {
                background: var(--color-accent);
            }

            /* Qのアイコン */
            &:before {
                content: "";
                width: 30px;
                aspect-ratio: 1 / 1;
                position: absolute;
                top: calc( 20px );
                left: 10px;
                background: url(../1_img/flow/icon-q.svg) no-repeat center / 100% auto;
            }

            /* +と-アイコン */
            & span {
                width: 18px;
                height: 2px;
                position: absolute;
                top: 50%;
                right: 20px;
                transform: translateY(-50%);
                background-color: var(--color-font);

                &::after {
                    content: "";
                    width: 2px;
                    height: 18px;
                    position: absolute;
                    top: 50%;
                    right: 8px;
                    transform: translateY(-50%);
                    background-color: var(--color-font);
                    transition: 300ms;
                }
            }

            /* open時 */
            &.open {
                background: var(--color-accent);

                & span {

                    &::after {
                        opacity: 0;
                        transform: translateY(-50%) rotate(90deg);
                    }
                }
            }
        }

        /* 回答 */
        & .faq-item_a {
            padding: 20px 20px 20px 50px;
            display: none;
            position: relative;
            background: var(--color-sub);
            color: var(--color-font);

            /* Qのアイコン */
            &:before {
                content: "";
                width: 30px;
                aspect-ratio: 1 / 1;
                position: absolute;
                top: calc( 20px );
                left: 10px;
                background: url(../1_img/flow/icon-a.svg) no-repeat center / 100% auto;
            }
        }
    }

    /*======== 規約 =========*/
    & .faq-rule{
        margin-top: 30px;
        text-align: center;

        & .btn-wrap{
            margin-top: 10px;
        }
    }

}
/*==============================================================================

	よくあるご質問 PC

==============================================================================*/
@media all and (min-width: 768px) {
    #faq {
        margin-top: -130px;
        padding: 260px 0 210px;
        clip-path: polygon(100% 0, 100% calc(100% - 130px), 50% 100%, 0 calc(100% - 130px), 0 0);

        /*======== qaのカテゴリ =========*/
        & .cate-wrap{

            & h3{
                font-size: 1.8rem;
            }

            & + .cate-wrap{
                margin-top: 40px;
            }
        }

        /*======== qa =========*/
        & .faq-item {
            line-height: 1.6;
            border-radius: 10px;
            overflow: hidden;

            &+.faq-item {
                margin-top: 30px;
            }

            /* 質問 */
            & .faq-item_q {
                padding: 25px 100px;
                font-size: 1.8rem;

                /* Qのアイコン */
                &:before {
                    width: 50px;
                    top: calc( 15px );
                    left: 25px;
                }

                /* +と-アイコン */
                & span {
                    width: 36px;
                    height: 5px;
                    right: 35px;

                    &::after {
                        width: 5px;
                        height: 36px;
                        right: 16px;
                    }
                }
            }

            /* 回答 */
            & .faq-item_a {
                padding: 25px 25px 25px 100px;

                /* Qのアイコン */
                &:before {
                    width: 50px;
                    top: calc( 15px );
                    left: 25px;
                }
            }
        }

        /*======== 規約 =========*/
        & .faq-rule{
            margin-top: 60px;

            & p{
                font-size: 1.8rem;
            }

            & .btn-wrap{
                margin-top: 20px;
            }
        }

    }
}