@charset "UTF-8";

/*-------------------------------------------*/
/*メインイメージ*/
/*-------------------------------------------*/
body {
    overflow-x: hidden;
}

.mainimg {
    position: relative;
    margin-top: 97px;
}

.bgimg img {
    width: 100%;
    object-fit: cover;
    max-height: 252px;
    min-height: 252px;
}

.text_img {
    position: absolute;
    top: 50px;
    right: 0;
    left: 11px;
    bottom: 0;
    display: flex;
    justify-content: center;
    align-items: flex-start;
}

.symbol_wrap {
    position: relative;
}

.symbol {
    position: absolute;
    top: -60px;
    right: 0;
    left: 0;
    bottom: 0;
}

.symbol img {
    margin: 0 auto;
}




@media screen and (max-width: 768px) {

    .mainimg {
        margin-top: 72px;
    }
}

@media screen and (max-width: 480px) {
    .mainimg {
        margin-top: 58px;
    }

    .bgimg img {
        min-height: 200px;
    }

    .text_img img {
        max-height: 80px;
    }

    .symbol img {
        max-width: 80px;
        padding-right: 0;
    }

    .text_img {
        left: 0;
    }

}

/*-------------------------------------------*/
/*入会までの流れ*/
/*-------------------------------------------*/
.flow .maxWid,
.selection_bnr .maxWid {
    max-width: 800px;
}

section.flow {
    margin-bottom: 90px;
}

.flow_subtitle {
    margin-top: 190px;
    margin-bottom: 80px;
}

.flow_subtitle h3 {
    font-size: 3.0rem;
    text-align: center;
    margin-bottom: 29px;
}

.flow_subtitle p {
    font-size: 1.5rem;
    line-height: 1.7;
}


.flow_contents .bg {
    background-color: #f7f7f7;
    border-radius: 10px;
    padding: 35px;
    position: relative;

}

.step.flex {
    justify-content: space-between;
}

.text_area {
    margin-top: 18px;
    margin-right: 33px;
    width: calc(100% - 306px);
}

.image_area {
    width: 100%;
    max-width: 306px;
}

.step .text_area h4 {
    font-size: 2.4rem;
    color: #d01c97;
    margin-bottom: 6px;

}

.step .text_area p {
    font-size: 1.5rem;
}

.btn_area {
    margin-top: 40px;
    max-width: 220px;
}

.step .btn_area a {
    font-size: 1.7rem;
    color: #fff;
    background-color: #d01c97;
    border: 1px solid #d01c97;
    padding: 10px 10px;
    position: relative;
    display: flex;
    align-items: center;
    transition: 0.8s;
}

.step .btn_area a:hover {
    color: #d01c97;
    background-color: initial;
    border: 1px solid #d01c97;
    opacity: 1;

}

.step .btn_area a:after {
    content: "";
    position: absolute;
    right: 10px;
    width: 9px;
    height: 9px;
    border: 2px solid currentColor;
    border-left: 0;
    border-bottom: 0;
    box-sizing: border-box;
    -webkit-transform: translateX(-10%) rotate(45deg);
    transform: translateX(-10%) rotate(45deg);
}



.num {
    position: absolute;
    top: -30px;
}

.arrow {
    margin-top: 20px;
    margin-bottom: 20px;
    text-align: center;
    display: flex;
    justify-content: center;
}

/*-------------------------------------------*/
/*バナーエリア*/
/*-------------------------------------------*/
.selection_bnr .maxWid {
    max-width: 800px;
    margin-bottom: 100px;
}

@media screen and (max-width: 768px) {
    .step .text_area h4 {
        font-size: 2.0rem;
    }

    .step .text_area p {
        font-size: 1.3rem;
    }

    .image_area {
        width: 100%;
        max-width: 40%;
    }

    .text_area {
        margin-right: 10px;
        width: 60%;
    }
}

@media screen and (max-width: 640px) {
    .step.flex {
        flex-direction: column;
    }

    .image_area,
    .text_area {
        width: 100%;
        max-width: 100%;
    }

    .btn_area {
        margin-top: 20px;
    }

    .image_area {
        margin-top: 40px;
    }

    .flow_contents .bg {
        padding: 20px;
    }

    .step .text_area h4 {
        margin-bottom: 10px;
    }

    .arrow {
        margin-top: 30px;
        margin-bottom: 30px;
    }

    .text_area {
        margin-top: 10px;
    }

    .flow_subtitle p {
        font-size: 1.3rem;
    }

    .flow_subtitle h3 {
        font-size: 2.4rem;
        margin-bottom: 20px;
    }

}


@media screen and (max-width: 480px) {
    .image_area img {
        width: 100%;
    }

    .step .btn_area a {
        font-size: 1.3rem;
    }

    .num {
        top: -25px;
    }

    .num img.retina {
        height: 35px;
    }

    .image_area {
        margin-top: 20px;
    }

    .flow_subtitle {
        margin-top: 70px;
    }

    .btn_area {
        max-width: 180px;
    }
}

@media screen and (max-width: 350px) {
    .flow_subtitle h3 {
        font-size: 2.2rem;
    }
}