@charset "UTF-8";

.tac{text-align: center;}
.tal{text-align: left;}
.tar{text-align: right;}

.df{display: flex;}

.inner {
    max-width: 1240px;
    margin: 0 auto;
}

.mt0{margin-top: 0!important;}
.mt100{margin-top: 100px!important;}

.fwb {
    font-weight: 600;
    color: #001966;    
}

.fontS{font-size: 1.6rem;}

.moreBtn{
    width: 292px;
    margin: 0 auto;
    font-size: 2.0rem;
    font-weight: 600;
    text-align: center;
}
.moreBtn a{
    padding: 10px 10px 10px;
    background: #FFA54B;
    color: #fff;
    border-radius: 50px;
    box-shadow: 0 9px 0px 0px #FFCC99;
    position: relative;
    display: block;
}
.moreBtn a:after{
    content: '';
    background: url(../img/icon_arrow.png);
    width: 15px;
    height: 22px;
    display: block;
    margin-left: 13px;
    position: absolute;
    right: 27px;
    top: 0;
    bottom: 0;
    margin: auto;
}

@media screen and (max-width: 768px){
    .mt100{margin-top: 15%!important;}
    
    .inner{
        width: 96%;
        margin: 0 auto;
    }
    
    .fontS{font-size: 1.4rem;}

    .moreBtn{
        font-size: 1.6rem;
    }
    .moreBtn a{
        padding: 10px 0 10px;   
        box-shadow: 0 5px 0px 0px #FFCC99;  
    }
}


h1.ttl{
    font-size: 3.8rem;
    font-weight: 600;
    text-align: center;
}

h1.ttl span.fontS{
    width: 216px;
    margin: 0 auto 12px;
    display: block;
}
h1.ttl span.subttl{
    margin-top: 5px;
    font-family: 'Agency FB',"agencyfb";
    font-size: 3.1rem;
    color: #FFA54B;
    display: block;
    line-height: 1;
}

h1.ttl span.subttl span{
    font-size: 2.4rem;
}


@media screen and (max-width:768px) {
    h1.ttl{
        font-size: 2.6rem;
    }
    h1.ttl span.subttl{
        font-size: 2rem;
    }

    h1.ttl span.fontS{
        margin-bottom: 4px;
    }
    h1.ttl span.subttl span{
        font-size: 1.8rem;
    }
}

/********* TOP *********/

/*** service ***/
section#service{
    margin-bottom: 68px;
    padding: 47px 0 61px;
    background-color: #FBECC1;
    background-image: url(../img/service_bg-left.webp), url(../img/service_bg-right.webp);
    background-repeat: no-repeat;
    background-position: bottom right, top left ;
}
.service_wrap {
    max-width: 1136px;
    margin: 45px auto 82px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 56px;
    justify-content: center;
}

.service_block {
    max-width: 540px;
    padding-top: 95px;
    position: relative;
}
.service_block .service_block_inner{
    padding: 54px 0 16px;
    background: #FFFFFF;
    border-radius: 15px;
    box-shadow: 0px 9px #FFCC99;
}

.service_block .point {
    width: 149px;
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    margin: auto;
}

.service_block .img_block {
    height: 222px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.service_block .service_block_inner h2 {
    margin: 15px 0 11px;
    font-size: 2.4rem;
    text-align: center;
    font-weight: 600;
}
.service_block .service_block_inner p {
    padding: 0 26px;
    line-height: 1.6;
}

@media screen and (max-width:768px) {
    section#service{
        margin-bottom: 38px;
        padding: 47px 0 31px;
    }

    .service_wrap{
        width: 96%;
        max-width: 540px;
        margin: 30px auto;
        grid-template-columns: 1fr;
        gap: 30px;
    }

    .service_block{
        padding-top: 65px;
    }
    .service_block .point{
        width: 110px;
    }

    .service_block .img_block{
        width: 60%;
        height: auto;
        margin: 0 auto;
    }

    .service_block .service_block_inner h2{
        font-size: 2rem;
        line-height: 1.4;
    }

}


/*** course ***/
section#course .contents_inner {
    padding-bottom: 22px;
}

section#course ul {
    max-width: 1073px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 9px;
}
section#course ul li {
    max-width: 262px;
    margin-bottom: 28px;
    border: 1px solid #DBE2E8;
    border-radius: 10px;
    box-shadow: 0px 9px #FFBFBF;
}
main#top section#course ul li:nth-child(1){
    max-width: 530px;
    padding: 97px 0 0 77px;
    background: #FF4D4D;
    color: #fff;
    border-radius: 10px;
    grid-column: 1 / 3;
    border: 1px solid #FF4D4D;
    line-height: 1;
}

section#course ul li h1 {
    font-size: 3.8rem;
    font-weight: 600;
}
section#course ul li h1 span{
    margin-top: 10px;
    display: block;
    font-size: 3.1rem;
    font-family: 'Agency FB',"agencyfb";
    color: #F8E9BD;
}

section#course ul li a{
    width: 100%;
    padding: 3px 0 20px;
    display: block;
    text-align: center;
}
section#course ul li span.txt {
    margin-bottom: 8px;
    display: block;
    font-size: 3.1rem;
    font-family: 'Agency FB',"agencyfb";
    font-weight: 600;
    color: #FFA54B;
}
section#course ul li h2 {
    margin-top: 10px;
    font-size: 2.4rem;
    font-weight: 600;
    color: #555;
}

@media screen and (max-width:768px) {
    section#course ul{
        width: 96%;
        padding-left: 9px;
        display: flex;
        flex-wrap: wrap;
    }

    section#course ul li{
        width: 31%;
        margin-bottom: 10px;
        box-shadow: 0px 6px #FFBFBF;
    }
    section#course ul li a{
        padding: 3px 0 0px;
    }

    main#top section#course ul li:nth-child(1){
        max-width: 64%;
        padding: 15px 0 15px 15px;
    }

    section#course ul li h1{
        font-size: 1.8rem;
    }
    section#course ul li h1 span{
        font-size: 1.8rem;
    }

    section#course ul li span.txt{
        font-size: 1.8rem;
    }
    section#course ul li h2{
        font-size: 1.2rem;
    }

    section#course span.icon {
        width: 60%;
        max-width: 162px;
        display: block;
        margin: 0 auto;
    }

}


/*** flow ***/
section#flow{
    margin-bottom: 60px;
    padding: 57px 0 80px;
    background: #F3F3F1;
}

section#flow .contents_inner{
    padding-bottom: 53px;
}

section#flow .flow_block{
    max-width: 1096px;
    margin: 69px auto 60px;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 38px;
    justify-content: center;
}
section#flow .flow_block_box {
    max-width: 340px;
}
section#flow .flow_block_box .txt_block {
    margin: 15px 0 0;
    text-align: center;
    font-size: 2.8rem;
    font-weight: 600;
    color: #ffa54b;
}

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

    section#flow {
        margin-bottom: 30px;
        padding: 27px 0 40px;
    }

    section#flow .flow_block{
        width: 80%;
        max-width: 340px;
        margin: 30px auto;
        grid-template-columns: 1fr;

    }
    section#flow .flow_block_box .txt_block{
        font-size: 2.2rem;
    }
}



/*** faq ***/
section#faq {
    margin-bottom: 94px;
}

.faq_block {
    max-width: 1080px;
    margin: 60px auto 91px;
}

.faq_block span.icon {
    font-family: 'Agency FB',"agencyfb";
    font-size: 4.6rem;
    font-weight: 600;
}

.faq_block dl {
    margin-bottom: 45px;
    background: #F9EBBE;
    border-radius: 8px;
}

.faq_block dt {
    padding: 10px 10px 7px 100px;
    background: #FFA54B;
    color: #fff;
    font-size: 2.4rem;
    font-weight: 600;
    border-radius: 8px;
    position: relative;
}

.faq_block dt span.icon {
    width: 73px;
    height: 79px;
    background: #FFA54B;
    display: block;
    text-align: center;
    position: absolute;
    top: 0;
    left: 0;
    border-radius: 8px;
    line-height: 1.8;
}

.faq_block dd {
    padding: 20px 0 10px;
    display: flex;
    align-items: center;
}
.faq_block dd span.icon{
    width: 103px;
    height: 90px;
    display: block;
    text-align: center;
    line-height: 2.1;
    color: #FFA54B;
}

.faq_block dd span.txt {
    width: 90%;
    padding-right: 10px;
    display: block;
}

@media screen and (max-width:768px) {
    section#faq{
        margin-bottom: 42px;
    }
    .faq_block{
        width: 96%;
        margin: 30px auto 31px;
    }
    .faq_block dl{
        margin-bottom: 25px;
    }
    .faq_block dt{
        padding: 5px 10px 3px 70px;
        font-size: 1.8rem;
        line-height: 1.4;
    }

    .faq_block span.icon{
        font-size: 3.8rem;
    }
    .faq_block dt span.icon{
        width: 63px;
        height: 69px;
        line-height: 1.8;
    }
    .faq_block dt span.txt{
        display: block;
    }

    .faq_block dd{
        padding: 20px 10px 10px 0;
    }

    .faq_block dd span.icon{
        width: 70px;
        height: auto;
    }
    .faq_block dd span.txt {
        display: block;
        width: 80%;
    }
}

/*** topics ***/
section#topics{
    margin-bottom: 99px;
    padding: 55px 0 81px;
}

.news_block{
    max-width: 1079px;
    margin: 75px auto 27px;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 31px;
    justify-content: center;
}

.news_block article {
    margin-bottom: 46px;
    position: relative;
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 7px 0px 0px #FFCC99;
    border: 1px solid #FFCC99;
}

.news_block article span.cate.news {
    position: absolute;
    top: 194px;
    background: #ffa54b;
    padding: 6px 10px 5px 14px;
    line-height: 1;
    border-radius: 0 8px 8px 0;
}
.news_block article span.cate.news a{
    color: #fff;
}

.news_block article .img_block {
    max-width: 339px;
    height: 223px;
    margin-bottom: 11px;
    overflow: hidden;
    border-radius: 10px 10px 0 0;
}

.news_block article .img_block img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.news_block article span.txt {
    padding: 0 15px;
    display: block;
}

.news_block article time{
    margin-bottom: 2px;
    padding: 0 15px;
    color: #FFA54B;
    display: block;
}

@media screen and (max-width:768px) {
    section#topics{
        margin-bottom: 32px;
        padding: 35px 0 31px;
    }

    .news_block{
        max-width: 94%;
        margin: 25px auto 27px;
        grid-template-columns: 1fr 1fr;
        gap: 10px;
    }

    .news_block article{
        margin-bottom: 15px;
        box-shadow: 0 4px 0px 0px #FFCC99;
    }

    .news_block article .img_block{
        width: 100%;
        height: 130px;
    }
    .news_block article span.cate.news{
        top: 108px;
        padding: 3px 9px 3px 6px;
    }

    .news_block article time{
        padding: 0 10px;
    }
    .news_block article span.txt{
        padding: 0 10px 10px;
    }
    
}


/*** coach ***/
section#coach {
    margin-bottom: 120px;
}

section#coach .coach_block {
    max-width: 1176px;
    margin: 75px auto 70px;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 30px;
    justify-content: center;
}
article.profile_block{
    position: relative;
    padding-top: 60px;
}
article.profile_block .profile_inner{
    padding: 133px 18px 20px;
    border-radius: 15px;
    border: 1px solid #FFCC99;
    box-shadow: 0 9px 0px 0px #FFCC99;
}

article.profile_block .img_block {
    width: 160px;
    height: 160px;
    margin: auto;
    position: absolute;
    left: 0;
    right: 0;
    text-align: center;
    top: 0;
    box-shadow: 5px 5px #FFA54B;
    border-radius: 50%;
}
rticle.profile_block p.p_title {
    margin-bottom: 1px;
}
article.profile_block p.p_name {
    font-size: 2.8rem;
    font-weight: 600;
}
article.profile_block p.p_name span{
    font-size: 1.6rem;
    font-weight: normal;
}

article.profile_block h2 {
    margin-bottom: 13px;
    font-size: 2.8rem;
    color: #FFA54B;
    font-weight: 700;
}

article.profile_block ul{
    margin-bottom: 24px;
    display: flex;
    flex-wrap: wrap;
}
article.profile_block ul li {
    margin-right: 7px;
    padding: 1px 5px;
    background: #FFCFBF;
    display: inline-block;
    font-size: 1.6rem;
    border-radius: 5px;
}

article.profile_block h3 {
    padding: 0px 10px;
    display: inline-block;
    border: 1px solid #FFCC99;
    border-radius: 5px;
    color: #FFA54B;
    line-height: 1.5;
}

article.profile_block p.price {
    margin-top: 30px;
    text-align: right;
    font-size: 2.0rem;
    font-weight: 600;
    color: #FFA54B;
}
article.profile_block p.price span{
    font-size: 2.8rem;
}

@media screen and (max-width:768px) {
    section#coach {
        margin-bottom: 50px;
    }

    section#coach .coach_block{
        max-width: 96%;
        grid-template-columns: 1fr;
    }

    article.profile_block .profile_inner{
        padding: 120px 10px 10px;
    }

    article.profile_block p.p_name{
        font-size: 2.4rem;
    }
    article.profile_block h2{
        margin-bottom: 8px;
        font-size: 2.4rem;
    }

    article.profile_block ul{
        margin-bottom: 18px;
    }
    article.profile_block ul li{
        font-size: 1.4rem;
    }

    article.profile_block p.price{
        margin-top: 10px;
        font-size: 1.8rem;
    }
    article.profile_block p.price span{
        font-size: 2.6rem;
    }
    
}


/*** line ***/
section#line {
    width: 1100px;
    max-width: 100%;
    margin: 0 auto;
    padding: 38px 0 37px;
    background: #05C654 url(../img/line_bg.png) no-repeat left bottom;
    border-radius: 20px;
    letter-spacing: 3px;
}

section#line h1 {
    margin-bottom: 34px;
    text-align: center;
    font-size: 3.8rem;
    font-weight: 600;
    color: #fff;
    line-height: 1;
}

section#line .moreBtn2 {
    width: 420px;
    margin: 0 auto;
    text-align: center;
}

section#line .moreBtn2 a{
    width: 100%;
    padding: 9px 0 10px;
    display: block;
    background: #2CCC2E;
    border: 5px solid #fff;
    border-radius: 50px;
    box-shadow: 0 0 #fff;
    color: #fff;
    font-size: 3.3rem;
    font-weight: 600;
    position: relative;
}
section#line .moreBtn2 a:after {
    content: '';
    background: url(../img/icon_arrow.png);
    width: 15px;
    height: 22px;
    display: block;
    margin-left: 13px;
    position: absolute;
    right: 27px;
    top: 0;
    bottom: 0;
    margin: auto;
}

@media screen and (max-width:768px) {
    section#line{
        width: 90%;
        margin-bottom: 34px;
        padding: 18px 0 17px;
        background-size: 100px;
        font-size: 2.2rem;
    }

    section#line h1{
        margin-bottom: 14px;
        font-size: 2.4rem;
        line-height: 1.3;
    }
    
    section#line .moreBtn2{
        width: 240px;
    }
    section#line .moreBtn2 a{
        padding: 6px 0 7px;
        font-size: 1.8rem;
    }
}



/*** recruitment ***/
aside.recruitment {
    margin: 98px 0 115px;
    padding: 36px 0 0;
    position: relative;
}

.recuitment_block {
    background: #FFF0C4;
}

.recruitment_inner{
    max-width: 1150px;
    margin: 0 auto;
    position: relative;
}

.recuitment_block .img_block {
    max-width: 1150px;
    position: relative;
    top: -40px;
}

.recuitment_block .txt_block{
    max-width: 550px;
    top: 86px;
    margin-left: 550px;
    position: absolute;
}

.recuitment_block .txt_block h1{
    padding: 12px 0 13px;
    margin-bottom: 12px;
    background: #FFC926;
    font-size: 3.8rem;
    font-weight: 600;
    color: #fff;
    text-align: center;
    border-radius: 10px;
    line-height: 1;
}

.recuitment_block .txt_block p {
    line-height: 1.5;
    padding: 0px 50px 10px;
    color: #555555;
}

@media screen and (max-width:768px) {
    aside.recruitment{
        margin: 45px 0 35px;
    }

    .recruitment_inner{

        width: 100%;
    }

    .recuitment_block .txt_block{
        width: 90%;
        margin: 0 auto;
        padding-bottom: 10px;
        top: -20px;
        position: relative;
    }

    .recuitment_block .txt_block h1{
        font-size: 2.6rem;
    }
    .recuitment_block .txt_block p{
        padding: 0px 20px 10px;
    }

    

}
