@charset "UTF-8";
/* CSS Document */

.ttl-sec{
    font-size: 39px;
    color: #153D89;
    font-weight: bold;
    line-height: 1.5em;
    text-align: center;
}

.sec-mv{
    width: 100vw;
    height: 100vh;
    background: url(../img/top/bg_main.jpg) no-repeat center center;
    background-size: cover;
    position: relative;
}
.sec-mv .ttl{
    font-size: 50px;
    color: #ffffff;
    font-family: "游明朝", "Yu Mincho", "YuMincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", serif;
    width: 100%;
    line-height: 1.3em;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%,-50%);
}
.sec-mv .ttl small{
    font-size: 32px;
    font-family: "游明朝", "Yu Mincho", "YuMincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", serif;
}
.sec-mv .ico{
    display: block;
    width: 72px;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 30px;
    margin-left: auto;
    margin-right: auto;
	-webkit-animation: jump .5s cubic-bezier(0.215, 0.61, 0.355, 1) infinite alternate;
	animation: jump .5s cubic-bezier(0.215, 0.61, 0.355, 1) infinite alternate;
}
@-webkit-keyframes jump {
    0% {
        -webkit-transform: translateY(0);
        transform: translateY(0);
    }
    100% {
        -webkit-transform: translateY(-10px);
        transform: translateY(-10px);
    }
}
@keyframes jump {
    0% {
        -webkit-transform: translateY(0);
        transform: translateY(0);
    }
    100% {
        -webkit-transform: translateY(-10px);
        transform: translateY(-10px);
    }
}

.sec-about{
    padding: 100px 0 120px;
}
.sec-about .txt{
    font-size: 21px;
    letter-spacing: 1px;
    margin: 22px 0 55px;
}
.sec-about .inner > div{
    margin: 0 10px;
    width: 319px;
}

.sec-intro{
    padding: 100px 0;
    background: url(../img/top/bg_intro.jpg) no-repeat center center;
    background-size: cover;
}
.sec-intro .inner{
    max-width: 1080px;
    margin: 50px auto 0;
}
.sec-intro .inner > div{
    width: 49%;
}
.sec-intro .inner .txt{
    font-size: 32px;
    color: #153D89;
    font-weight: bold;
    margin: 23px 0;
}

.sec-drawing{
    padding: 100px 0 120px;
}
.sec-drawing .inner{
    max-width: 1080px;
    margin: 50px auto 110px;
}
.sec-drawing .inner .txt{
    width: 52%;
}
.sec-drawing .inner .txt p{
    font-size: 18px;
    line-height: 1.8em;
}
.sec-drawing .inner .img{
    width: 41%;
}
.sec-drawing .name{
    padding: 0 5px;
    margin-bottom: -30px;
}
.sec-drawing .inner02{
    max-width: 100%;
    margin: 0 auto;
}
.sec-drawing .inner02 > div{
    width: 32%;
}
.sec-drawing .inner02 iframe{
    width: 100%;
}

.sec-achievement{
    padding: 100px 0;
    background: url(../img/top/bg_achievement.jpg) no-repeat center center;
    background-size: cover;
}
.sec-achievement .txt{
    font-size: 18px;
    line-height: 1.8em;
    max-width: 944px;
    margin: 0 auto;
    margin: 30px auto 65px;
}
.sec-achievement .inner{
    margin-bottom: 40px;
}
.sec-achievement .inner > div{
    width: 308px;
    margin: 0 13px;
}

.sec-contact{
    padding: 100px 0;
}
.sec-contact .txt{
    font-size: 18px;
    line-height: 1.8em;
    max-width: 944px;
    margin: 30px auto 80px;
}
.sec-contact .box-contact{
    max-width: 805px;
    margin: 0 auto;
}
.sec-contact .box-contact .label{
    font-size: 16px;
    margin-bottom: 5px;
}
.sec-contact .box-contact .inner{
    border-top: 1px solid #232B33;
    border-bottom: 1px solid #232B33;
    padding: 40px 0;
}
.sec-contact .box-contact .inner > div{
    width: 43%;
}
.sec-contact .box-contact .inner .tel a{
    font-size: 38px;
    color: #153D89;
    font-weight: bold;
    display: inline-block;
    padding-left: 10px;
    position: relative;
}
.sec-contact .box-contact .inner .tel a:before{
    content: "";
    background: url(../img/common/ico_tel.png) no-repeat left top;
    background-size: 100%;
    width: 30px;
    height: 42px;
    position: absolute;
    left: -30px;
    top: 0;
}
.sec-contact .box-contact .inner .tel .note{
    font-size: 14px;
    margin-top: 5px;
}
.sec-contact .box-contact .inner .mail a{
    max-width: 313px;
    margin: 0 auto;
    display: block;
    padding: 20px 0;
    background: #153D89;
}
.sec-contact .box-contact .inner .mail a span{
    font-size: 17px;
    color: #ffffff;
    font-weight: bold;
    padding-left: 30px;
    position: relative;
}
.sec-contact .box-contact .inner .mail a span:before{
    content: "";
    background: url(../img/common/ico_mail.png) no-repeat left top;
    background-size: 100%;
    width: 24px;
    height: 17px;
    position: absolute;
    left: -5px;
    top: 0;
}



@media only screen and (min-width: 768px) {
}

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

.ttl-sec{
    font-size: 20px;
}

.sec-mv{
    background: url(../img/top/bg_main_sp.jpg) no-repeat center center;
    background-size: cover;
}
.sec-mv .ttl{
    font-size: 28px;
    letter-spacing: 1px;
}
.sec-mv .ttl small{
    font-size: 16px;
    line-height: 2.5em;
}
.sec-mv .ico{
    width: 57px;
    bottom: 20px;
}

.sec-about{
    padding: 50px 0;
}
.sec-about .txt{
    font-size: 14px;
    margin: 17px 0 35px;
}
.sec-about .inner > div{
    margin: 0 1%;
    width: 48%;
    max-width: 100%;
}
.sec-about .inner > div:first-child{
    margin: 0 5% 10px;
}

.sec-intro{
    padding: 50px 0;
    background: url(../img/top/bg_intro_sp.jpg) no-repeat center center;
    background-size: cover;
}
.sec-intro .inner{
    max-width: 345px;
    margin: 30px auto 0;
}
.sec-intro .inner > div{
    width: 100%;
    margin-bottom: 40px;
}
.sec-intro .inner > div:last-child{
    margin-bottom: 0;
}
.sec-intro .inner .txt{
    font-size: 16px;
    margin: 15px 0;
}

.sec-drawing{
    padding: 50px 0;
}
.sec-drawing .inner{
    margin: 20px auto 40px;
}
.sec-drawing .inner .txt{
    width: 100%;
    margin-bottom: 20px;
}
.sec-drawing .inner .txt p{
    font-size: 14px;
}
.sec-drawing .inner .img{
    width: 100%;
    max-width: 315px;
    margin: 0 auto;
}
.sec-drawing .name{
    margin-bottom: -10px;
}
.sec-drawing .inner02{
    max-width: 345px;
    margin: 0 auto;
}
.sec-drawing .inner02 > div{
    width: 100%;
    margin-bottom: 20px;
}
.sec-drawing .inner02 > div:last-child{
    margin-bottom: 0;
}
.sec-drawing .inner02 iframe{
    height: 205px;
}

.sec-achievement{
    padding: 50px 0;
    background: url(../img/top/bg_achievement_sp.jpg) no-repeat center center;
    background-size: cover;
}
.sec-achievement .txt{
    font-size: 14px;
    margin: 20px auto 30px;
}
.sec-achievement .inner{
    margin-bottom: 30px;
}
.sec-achievement .inner > div{
    width: 100%;
    max-width: 345px;
    margin: 0 auto 20px;
}
.sec-achievement .inner > div:last-child{
    margin-bottom: 0;
}

.sec-contact{
    padding: 50px 0;
}
.sec-contact .txt{
    font-size: 14px;
    margin: 20px auto 40px;
}
.sec-contact .box-contact .inner{
    padding: 30px 0;
}
.sec-contact .box-contact .inner > div{
    width: 100%;
}
.sec-contact .box-contact .inner .tel{
    margin-bottom: 20px;
}
.sec-contact .box-contact .inner .tel a{
    font-size: 30px;
}
.sec-contact .box-contact .inner .tel a:before{
    width: 21px;
    height: 30px;
    left: -20px;
}

}