@charset "utf-8";

/** ▼▼▼ main ▼▼▼ **/
#main {
    width: 100%;
    background: url(../images/bg_offset-main.png) no-repeat center center / cover;
}

@media (max-width: 860px) {
    #main {
        margin: 70px 0 0 0;
    }
}

#main h2 {
    width: 90%;
    max-width: 1000px;
    margin: 0 auto;
    line-height: 0;
}
/** ▲▲▲ main ▲▲▲ **/

/** ▼▼▼ contribution ▼▼▼ **/
#contribution {
    width: 90%;
    max-width: 1000px;
    margin: 53px auto 0 auto;
}

#contribution h3 {
    font-size: 2.25em;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    line-height: 133%;
    color: #0071BC;
}

#contribution ul {
    width: 100%;
    max-width: 1000px;
    list-style: none;
    display: flex;
    justify-content: space-between;
}

#contribution ul li:nth-child(1) {
    width: 50%;
    max-width: 500px;
}

#contribution ul li:nth-child(2) {
    width: 45%;
    max-width: 450px;
}

#contribution ul li ul {
    width: 100%;
    max-width: 450px;
    margin: 16px 0 0 0;
    display: flex;
    justify-content: space-between;
}

#contribution ul li ul li:nth-child(1) {
    width: 33%;
    max-width: 150px;
}

#contribution ul li ul li:nth-child(2) {
    width: 62%;
    max-width: 275px;
}

#contribution ul li ul li h4 {
    font-size: 1.25em;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    line-height: 130%;
}

a.provider {
    width: 225px;
    height: 52px;
    margin: 20px 0 0 0;
    padding: 0 0 0 15px;
    display: flex;
    align-items: center;
    border: 1px solid #0071BC;
    border-radius: 5px;
    font-size: 0.75em;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 500;
    text-align: center;
    color: #0071BC;
    background: url(../../common/images/icn_arrow.svg) #FFFFFF no-repeat center right 8px;
    transition: .3s;
}

a.provider span {
    display: block;
    margin: 5px 0 0 0;
    font-size: 1.33em;
    font-weight: 700;
}

a.provider:hover {
    background: url(../../common/images/icn_arrow-w.svg) #0071BC no-repeat center right 8px;
    color: #FFFFFF;
    transform: translateX(30px);
}
/** ▲▲▲ contribution ▲▲▲ **/

/** ▼▼▼ structure ▼▼▼ **/
#structure {
    width: 90%;
    max-width: 1000px;
    margin: 53px auto 0 auto;
}

#structure h3 {
    font-size: 2.25em;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    line-height: 133%;
    color: #0071BC;
}

#structure ul {
    margin: 20px 0 0 20px;
}

#structure ul li {
    margin: 0 0 10px 0;
}

#structure img {
    margin: 15px 0 0 0;
}

#structure div {
    border: 1px solid #888888;
    margin: 30px 0 0 0;
    padding: 25px 40px;
}

#structure div strong {
    font-size: 1.25em;
    font-weight: 700;
}

#structure div p {
    margin: 14px 0 0 0;
}

#structure p {
    margin: 25px 0 0 0;
}

a.credit {
    width: 190px;
    height: 42px;
    margin: 23px 0 0 0;
    padding: 0 0 0 10px;
    display: flex;
    align-items: center;
    border: 1px solid #0071BC;
    border-radius: 5px;
    font-size: 1.12em;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    text-align: center;
    color: #0071BC;
    background: url(../../common/images/icn_arrow.svg) #FFFFFF no-repeat center right 8px;
    transition: .3s;
}

a.credit:hover {
    background: url(../../common/images/icn_arrow-w.svg) #0071BC no-repeat center right 8px;
    color: #FFFFFF;
    transform: translateX(30px);
}

a.delivery {
    width: 175px;
    height: 42px;
    margin: 12px 0 0 0;
    padding: 0 0 0 25px;
    display: flex;
    align-items: center;
    border: 1px solid #0071BC;
    border-radius: 5px;
    font-size: 1.12em;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    text-align: center;
    color: #0071BC;
    background: url(../../common/images/icn_arrow.svg) #FFFFFF no-repeat center right 8px;
    transition: .3s;
}

a.delivery:hover {
    background: url(../../common/images/icn_arrow-w.svg) #0071BC no-repeat center right 8px;
    color: #FFFFFF;
    transform: translateX(30px);
}
/** ▲▲▲ structure ▲▲▲ **/

@media (max-width: 640px) {
    /** ▼▼▼ main ▼▼▼ **/
    #main {
        margin: 70px 0 0 0;
        background: url(../images/bg_offset-main-sp.png) no-repeat center center / cover;
    }
    /** ▲▲▲ main ▲▲▲ **/

    /** ▼▼▼ contribution ▼▼▼ **/
    #contribution {
        width: 90%;
        max-width: 1000px;
        margin: 53px auto 0 auto;
    }

    #contribution h3 {
        font-size: 1.5em;
        line-height: 116%;
    }

    #contribution ul {
        flex-direction: column;
    }

    #contribution ul li:nth-child(1) {
        width: 100%;
    }

    #contribution ul li:nth-child(2) {
        width: 100%;
        margin: 40px 0 0 0;
        padding: 0 0 20px 0;
        border-top: 1px solid #888888;
        border-bottom: 1px solid #888888;
    }

    #contribution ul li ul {
        margin: 0;
        flex-direction: column;
    }

    #contribution ul li ul li {
        margin: 20px 0 0 0;
    }

    #contribution ul li ul li:nth-child(1) {
        width: 45%;
    }

    #contribution ul li ul li:nth-child(2) {
        width: 100%;
        max-width: 640px;
        margin: 20px 0 0 0;
        padding: 0;
        border: none;
    }

    a.provider span {
        display: block;
        margin: 5px 0 0 0;
        font-size: 1.33em;
        font-weight: 700;
    }

    a.provider:hover {
        background: url(../../common/images/icn_arrow-w.svg) #0071BC no-repeat center right 8px;
        color: #FFFFFF;
        transform: translateX(30px);
    }**/
    /** ▲▲▲ contribution ▲▲▲ **/

    /** ▼▼▼ structure ▼▼▼ **/
    #structure {
        width: 90%;
        max-width: 1000px;
        margin: 53px auto 0 auto;
    }

    #structure h3 {
        font-size: 1.5em;
        line-height: 116%;
    }

    #structure ul li {
        margin: 0;
        line-height: 162%;
    }
    /** ▲▲▲ structure ▲▲▲ **/
}