@import url('https://fonts.googleapis.com/css?family=Lato:300,400,700|Noto+Sans+JP:300,400,500,700');

body {
    font-family: 'Noto Sans JP', sans-serif;
}
main {
    background-color: #F1F1F1;
    padding-bottom: 200px;
}
.pc { display:block; }
.sp { display:none; }
h2 {
    font-size: 28px;
    text-align: center;
    font-weight: bold;
}
h3 {
    font-size: 24px!important;
}
h4 {
    font-size: 20px;
    font-weight: bold;
}
p {
    font-size: 15px;
}
/* キービジュアル */
.key-visual-wrap {
    position: relative;
    background: url(/assets/about/images/registration_flow/MV.jpg) center center /cover no-repeat;
    background-position: 50% 14%;
    text-align: center;
    height: 500px;
}
.key-visual-wrap::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-color: #0000004D;
}
.key-visual-wrap img {
    margin: 100px auto auto;
    width: 130px;
    height: auto;
}
.key-visual-wrap h1 {
    color: #FFFFFF;
    font-size: 30px;
    margin-left: 18px;
    margin-right: auto;
}
.key-visual-wrap p {
    color: #fff;
    margin-top: 50px;
    margin-bottom: 136px;
}

/* 事前に準備いただくもの */
.section-title {
    width: 315px;
    /* margin-top: 120px; */
    margin-bottom: 20px;
    text-align: center;
}
.sec01 {
    max-width: 1500px;
    margin: 150px auto 0;
    height: auto;
}
.sec01 .contents-wrap {
    max-width: 1124px;
    padding-left: 120px;
    margin-top: 30px;
    padding-bottom: 65px;
    background: #fff;
    border-radius: 20px;
    padding-right: 120px;
}
.sec01 .left-wrap {
    max-width: 536px;
    margin-top: 100px;
}
.sec01 .left-wrap p {
    margin-top: 20px;
}
.sec01 .left-wrap a {
    margin-top: 50px;
}
.sec01 .right-wrap {
    max-width: 536px;
    margin-top: 65px;
    margin-bottom: auto;
    text-align: center;
}
.sec01 h2 {
    text-align: center;
}

/* 会員登録方法について */
.sec02 {
    margin: 150px auto 0px;
}
.contents-wrap {
    width: 100%;
    height: auto;
    margin-left: auto;
    margin-right: auto;
    padding-bottom: 60px;
    background: #FFFFFF 0% 0% no-repeat padding-box;
    border-radius: 20px;
    opacity: 1;
}
.sec02 .sec02-main {
    padding-left: 60px;
    padding-right: 13px;
}
.sec02 .left-wrap {
    width: 100%;
    padding-left: 0px;
}
.sec02 .left-wrap h3 {
    margin-top: 90px;
}
.sec02 .left-wrap p {
    margin-top: 30px;
}
.sec02 .register-button {
    background: linear-gradient(45deg, #d92933 33%, #ef8224 100%);
    color: #fff;
    margin-top: 21px;
    padding: 10px 0;
    text-align: center;
    width: 13rem;
    font-size: 15px;
    border-radius: 35px;
    border: none;
}
.register-button:hover {
    color: #fff;
}
.annotation-msg {
    color: #B8B8B8;
}
.sec02 .right-wrap img {
    margin-right: auto;
    margin-left: auto;
    margin-top: 26px;
}
.sec02-main-title {
    position: relative;
    padding-top: 120px;
}
.sec02-main-title h3 {
    font: normal normal bold Noto Sans JP;
    letter-spacing: 0px;
    color: #2D2D2D;
    opacity: 1;
}
.sec02-main-title h3::before {
    position: absolute;
    width: 1010px;
    bottom: 0;
    border-bottom: 2px solid #F1F1F1;
    content: '';
}
.register-wrap .sec02-main-title h3::before {
    bottom: 90px;
}

/* 会員情報の登録 */
.sec02-main .description {
    margin-top: 30px;
}
.sec02 .left-wrap .list-group {
    margin-top: 30px;
    font-size: 13px;
}
.sec02 .left-wrap .list-group .list-title {

    font-size: 17px;
    font-weight: 600;
}
.sec02 .left-wrap .list-group .item {
    margin-left: 36px;
    margin-top: 12px;
}
.sec02 .left-wrap .list-group li {
    margin-bottom: 20px;
}
.sec02 .left-wrap .list-group li img{
    vertical-align: top;
    margin-right: auto;
    margin-left: auto;
}

/* Thank you! */
.sec03 {
    margin: 150px auto 0px;
}
.sec03 .sec03-main {
    width: 100%;
    height: auto;
    margin-left: auto;
    margin-right: auto;
    background: #fff;
    border-radius: 20px;
}
.sec03 .main-wrap {
    margin-top: 80px;
}
.sec03 .main-wrap p {
    text-align: center;
    max-width: 920px;
    margin-left: auto;
    margin-right: auto;
}
.sec03 .main-wrap .register-button {
    background: linear-gradient(45deg, #d92933 33%, #ef8224 100%);
    color: #fff;
    display: block;
    margin-top: 50px;
    margin-bottom: 70px;
    padding: 10px 0;
    font-size: 15px;
    border-radius: 35px;
    border: none;
    text-align: center;
    margin-left: auto;
    margin-right: auto;
    width: 300px;
}

/* SP */
@media screen and (max-width: 480px) {
    .pc { display:none; }
    .sp { display:block; }

    h2 {
        font-size: 24px;
    }
    h3 {
        font-size: 20px;
    }
    h4 {
        font-size: 18px;
    }
    p {
        font-size: 15px;
    }
    /* キービジュアル */
    .key-visual-wrap h1 {
        margin-left: 0px;
        font-size: 28px;
    }
    .key-visual-wrap p {
        margin-top: 30px;
        margin-bottom: 0px;
        text-align: left;
    }
    .key-visual-wrap img {
        margin: 60px auto auto;
    }
    /* 事前に準備いただくもの */
    .sec01 .left-wrap {
        margin-top: 65px;
    }
    .sec01 .right-wrap img {
        max-width: 75%;
    }
    .btn-dark {
        margin: auto;
    }
    .sec01 .contents-wrap {
        padding-left: 0px;
        padding-right: 0px;
    }
    /* 会員登録方法について */
    .sec02 {
        width: 100%;
    }
    .sec02 .sec02-main {
        max-width: 370px;
        padding: 0 20px;
    }
    .sec02-main:nth-of-type(n+2) {
        margin-top: 60px;
    }
    .sec02 .sec02-main-title {
        margin-top:  -70px;
    }
    .sec02 .right-wrap {
        padding: 0px;
    }
    .sec02 .right-wrap img {
        padding-top: 0px;
    }
    .sec02 .left-wrap {
        padding: 0px;
    }
    .sec02 .left-wrap h3 {
        margin-top: 90px;
        margin-right: auto;
        margin-left: 60px;
    }
    .sec02 .left-wrap p {
        margin-top: 30px;
    }
    .sec02 .right-wrap img {
        transform: scale(1.0);
        margin-right: auto;
        margin-left: auto;
        margin-top: 30px;
    }
    .sec02 .right-wrap .sp-img-1 {
        margin-top: 10px;
    }
    .sec02-main-title h3 {
        font: normal normal bold Noto Sans JP;
        letter-spacing: 0px;
        color: #2D2D2D;
        opacity: 1;
    }
    .sec02 .left-wrap .list-group {
        margin-left: 10px;
    }
    .sec02 .left-wrap .list-group .item {
        margin-left: auto;
        margin-top: 10px;
    }
    .sec02 .left-wrap .list-group li:nth-of-type(n+2) {
        margin-top: 30px;
    }
    .sec02 .comp-msg {
        margin-left: 10px;
    }
    .sec02 .terms-img {
        margin-top: 20px;
        margin-bottom: 50px;
    }

    /* Thank You! */
    .sec03 .main-wrap {
        margin-right: auto;
        margin-left: 10px;
        margin-top: 60px;
    }
    .sec03 .main-wrap p {
        text-align: left;
    }
    .sec03 .main-wrap .register-button {
        margin-left: auto;
        margin-right: auto;
        width: 240px;
        font-size: 14px;
    }
    .sec02-main-title h3::before {
        position: absolute;
        width: 305px;
        bottom: 0;
        border-bottom: 2px solid #F1F1F1;
        content: '';
    }
    .register-wrap .sec02-main-title h3::before {
        bottom: 115px;
    }
}
