@charset "UTF-8";
/* ------------------------------
   concept.css
------------------------------ */
.page-ttl .ttl_inner{
    bottom: 25px;
}
@media screen and (max-width: 767px) {
    .page-ttl .ttl_inner{
        bottom:-34px;
        padding: 10px 20px;
    }

}

/*sec01*/
.sec01{
    position: relative;
    padding: 65px 0 50px 0;
    box-sizing: border-box;
}
.sec01.inner{ max-width: 1029px;}
.sec01 h2{
    font-size: 3.5rem;
    line-height: 1.5;
    margin-bottom: 55px;
}
.sec01 p,
.sec01 li{
    position: relative;
    font-size: 1.6rem;
    letter-spacing: -.005em;
    line-height: calc(30 / 16);
}
.sec01 li{
    text-indent: -1rem;
    margin-left: 1rem;
}
.sec01 li:before{
    position: relative;
    top: -3px;
    margin-right: 5px;
    display: inline-block;
    vertical-align: middle;
    content: '●';
    color: #bc121a;
}

.sec01 ul{
    margin: 30px 0;
}
.sec01 li{
    line-height: calc(36 / 16);
}

.sec01 .img{
    text-align: center;
    margin: 60px auto 0 auto;
}


@media screen and (max-width: 767px) {
    .sec01{
        padding: 18% 0 18% 0;
        display: block;
        }
    .sec01.inner{ max-width: inherit;}
    .sec01 h2{
        font-size: 2.4rem;
        margin-bottom: 10%;
    }
    .sec01 p,
    .sec01 li{
        font-size: 1.4rem;
    }
    .sec01 li{
        text-indent: 0;
        margin-left: 0;
        padding-left: 2.2rem;
        box-sizing: border-box;
    }
    .sec01 li:before{
        position: absolute;
        left: 0;
        top: -1px;
        margin-right: 0;
    }

    .sec01 ul{
        margin: 8% 0;
    }
    .sec01 .img{
        margin: 12% auto 0 auto;
    }
}

/*sec02*/
.sec02{
    padding: 65px 0 150px 0;
    box-sizing: border-box;
}

.main_cnts .white-box{
    width: 100%;
    max-width: 1049px;
    padding: 45px 35px 75px 35px;
    margin: 0 auto;
    background: #FFF;
    border: 1px solid #dcdcdc;
    box-sizing: border-box;
}
.main_cnts .white-box+.white-box{ margin-top: 65px;}
.main_cnts .white-box .box-ttl{
    text-align: center;
    font-size: 3.0rem;
    font-weight: 700;
    margin-bottom: 20px;
}
.main_cnts .white-box .box-ttl span{
    position: relative;
}
.main_cnts .white-box .box-ttl span:before{
    position: relative;
    top: -2px;
    display: inline-block;
    vertical-align: middle;
    margin-right: 12px;
    content: '';
    background: url("../img/common/mark_logo.svg") no-repeat center center;
    background-size: 100% auto;
    width: 30px;
    height: 29px;
}

.main_cnts .white-box .subttl{
    text-align: center;
    font-size: 3.0rem;
    letter-spacing: -.001em;
    color: #bc121a;
    margin-bottom: 20px;
}
.main_cnts .white-box .lead{
    text-align: center;
    font-size: 2.4rem;
    line-height: calc(30 / 24);
    letter-spacing: -.001em;
    margin-bottom: 40px;
}

.main_cnts .white-box .flex{
    align-items: center;
}
.main_cnts .white-box .flex.-reverse{
    flex-direction: row-reverse;
}

.main_cnts .white-box .flex .img{
    width: 47%;
    max-width: 453px;
}
.main_cnts .white-box .flex .txt{
    width: 53%;
    padding-left: 22px;
    box-sizing: border-box;
}
.main_cnts .white-box .flex.-reverse .txt{
    padding-right: 22px;
    padding-left: 0;
}
.main_cnts .white-box .flex .txt p{
    font-size: 1.6rem;
    line-height: calc(30 / 16);
}
.main_cnts .white-box .flex .txt p+p{ margin-top: 24px;}


@media screen and (max-width: 767px) {
    .sec02{
        padding: 12% 0 16% 0;
        box-sizing: border-box;
    }

    .main_cnts .white-box{
        max-width: inherit;
        padding: 5% 4%;
    }
    .main_cnts .white-box+.white-box{ margin-top: 10%;}
    .main_cnts .white-box .box-ttl{
        font-size: 2.2rem;
        margin-bottom: 5%;
    }

    .main_cnts .white-box .box-ttl span:before{
        top: -2px;
        margin-right: 8px;
        width: 24px;
        height: 24px;
    }

    .main_cnts .white-box .subttl{
        font-size: 2.4rem;
        margin-bottom: 5%;
    }
    .main_cnts .white-box .lead{
        font-size: 1.8rem;
        margin-bottom: 10%;
    }

    .main_cnts .white-box .flex{
        display: block;
    }
    .main_cnts .white-box .flex .img{
        width: 100%;
        max-width: 453px;
        margin: 0 auto 4% auto;
    }
    .main_cnts .white-box .flex .txt{
        width: 100%;
        padding-left: 0;
    }
    .main_cnts .white-box .flex.-reverse .txt{
        padding-right: 0;
        padding-left: 0;
    }
    .main_cnts .white-box .flex .txt p{
        font-size: 1.4rem;
    }
    .main_cnts .white-box .flex .txt p+p{ margin-top: 5%;}


}














