/* common  */
.pt0{
    padding-top: 0 !important;
}

/* main */
#main{
    background: url(../img/bg_koushi_bosyu01.jpg);
    background-repeat: repeat;
    padding: 30px 25px;
}
#main h2{
    font-family: 'Roboto', sans-serif;
    font-weight: bold;
    font-size: 1.875rem;
    text-align: center;
    line-height: 1;
    padding: 40px 0;
}
#main .cache{
    text-align: center;
    margin-bottom: 40px;
}

section{
    padding: 0 20px;
}

section h3{
    font-weight: bold;
    font-size: 1.5rem;
    text-align: center;
    padding:40px 0;
}
section h4{
    font-size: 1.25rem;
    margin-bottom: 1rem;
    border-left: 5px solid #cc1424;
    padding-left: 1rem;
    
}
section .column{
    margin-bottom: 30px;
}

/* section01 */
#section01 .theme li{
    margin-bottom: 20px;
    box-sizing: border-box;
    border: 4px solid #cc1424;
}
#section01 .theme li dt{
    font-weight: bold;
    margin-bottom: 0.5rem;
    text-align: center;
    padding: 10px;
    background: #cc1424;
    color: #fff;
}
#section01 .theme li dd{
    text-indent: -1rem;
    margin-left: 1rem;
    padding: 10px;
}

#section02{
    background: #fff url(../img/bg_prof01_sp.png) no-repeat;
    background-size: cover;
    background-position: center bottom;
    padding-bottom: 45px;
}
#section02 li{
    text-indent: -1rem;
    margin-left: 1rem;
    margin-bottom: 1rem;
}
#section02 li:last-child{
    margin-bottom: 0;
}
#section02 .well {
    border: 1px solid #e0e0e0;
    background-color: #fcfcfc;
    min-height: 20px;
    padding: 19px;
    margin: 20px 0 40px;
    border: 1px solid #e3e3e3;
}
#section02 .privacy_policy {
    max-height: 20em;
    overflow: auto;
}
#section02 .note {
    font-size: 0.75em;
    line-height: 1.1em;
}
#section02 .btn01 a{
    width:100%;
    background: #cc1424;
}

section a:link,
section a:visited{
    text-decoration: underline;
    color: #cc1424;
}

#section02 .dlword {
    margin: 1rem .5rem 1.5rem;
}
#section02 .dlword a{
    background: #335a94;
    color: #fff;
    padding: 10px 20px 10px 10px;
    text-decoration: none;
    font-size: 0.875rem;
    white-space: nowrap;
}
#section02 .dlword a img{
    width:24px;
    padding:0 .75rem;
}


/***  PC  ***/
@media all and (min-width: 768px) {

    
    /* main */
    #main{
        padding: 60px 25px;
    }
    #main h2{
        font-size: 3rem;
        padding: 80px 0;
    }
    #main .cache{
        margin-bottom: 80px;
    }

    section{
        padding: 0;
    }

    section h3{
        font-size: 2.25rem;
        padding:80px 0;
    }
    section h4{
        font-size: 1.5rem;
        margin-bottom: 2rem;    
    }
    section .column{
        margin-bottom: 60px;
    }

    /* section01 */
    #section01 .theme{
        display : flex;
        flex-wrap : wrap;
        justify-content:space-between;
    }
    #section01 .theme::after{
        content:"";
        display: block;
        width:32%;
    }
    #section01 .theme li{
        margin-bottom: 2%;
        width: 32%;
        min-height: 280px;
    }

    #section02{
        background: #fff url(../img/bg_prof01_pc.png) no-repeat;
        background-size: cover;
        background-position: center bottom;
        padding-bottom: 90px;
    }
    #section02 .well {
        margin: 40px 0 80px;
    }
    #section02 .btn01 a{
        width:60%;
    }

    #section02 .dlword{
        margin: 1rem 1.5rem 1.5rem;
    }

}

