/* top内共通 */
.bg_green_title{
    position: relative;
    display: inline-block;
    margin-bottom: 20px;
    font-family:'游ゴシック','ヒラギノ角ゴシック', 'Hiragino Sans', 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', 'メイリオ', 'Meiryo', 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
    font-weight: bold;
    font-size: 20px;
    line-height: 1.7;
}
.bg_green_title span{
    display: inline-block;
    padding: 4px 0.15em;
    line-height: 1;
    background: #31AE4B;
    color: #fff;
}


/* gr_link */
.gr_link{
    position: absolute;
    display: inline-block;
    bottom: 60px;
    left: 0;
    right: 0;
    width: 90%;
    margin: auto;
    padding: 0 50px 10px 20px;
    border-bottom: 2px solid #31AE4B;
    font-size: 18px;
    font-weight: bold;
    text-align: center;
    color: #31AE4B;
}
.gr_link:hover{
    opacity: 0.8;
}
.gr_link:after{
    content: "";
    display: inline-block;
    position: absolute;
    top: -4px;
    right: 0;
    width: 24px;
    height: 24px;
    background-color: #31AE4B;
    border-radius: 100%;
}
.gr_link:before{
    content: "";
    display: inline-block;
    position: absolute;
    top: 3px;
    right: 9px;
    width: 10px;
    height: 10px;
    border-right: 3px solid #fff;
    border-bottom: 3px solid #fff;
    transform: rotate(-45deg);
    z-index: 1;
}

/* top_area */
#top_area{
    position: relative;
    margin-bottom: 10px;
}
#top_area:after{
    content: "";
    display: inline-block;
    position: absolute;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: #F0F5E9;
    z-index: -1;
}
#top_area .tp_in{
    position: relative;
    max-width: 1920px;
    margin: 0 auto;
}
#top_area .prides{
    position: relative;
    margin-bottom: 50px;
}
#top_area .prides .m_img{
    max-width: 1440px;
    width: 100%;
    margin-left: auto;
}
#top_area .prides .m_txt{
    position: relative;
    width: 90%;
    margin: -15px auto 0;
}

#top_area .prides .m_txt .name{
    margin-bottom: 20px;
    font-family: arial;
    font-weight: bold;
    font-size: 14px;
    color: #31AE4B;
}
#top_area .prides .m_txt .name span{
    margin-right: 10px;
    font-size: 20px;
    color: #31AE4B;
    vertical-align: -2px;
}
#top_area .prides .m_txt .txt{
    line-height: 2;
}

/* スライダー */
#top_area .prides .slick-dots{
    width: auto;
    right: 10px;
    bottom: 10px;
    z-index: 10;
}
#top_area .prides .slick-dots li{
    width: 10px;
}
#top_area .prides .slick-dots li button:before{
    content: "";
    display: inline-block;
    width: 9px;
    height: 9px;
    border: 1px solid #FFF;
    border-radius: 100%;
    background: #DDD;
    opacity: 1;
}
#top_area .prides .slick-dots li.slick-active button:before{
    background: #31AE4B;
}

/* news */
.news{
    position: relative;
    max-width: 1240px;
    width: 95%;
    padding-bottom: 130px;
    margin: 0 auto;
}
.news .til_area{
    margin-bottom: 20px;
    text-align: center;
}
.news .news_con{
    padding: 10px 10px 7px;
    background: #fff;
    box-shadow: 0px 5px 10px rgba(0, 0, 0, 0.2);
}

.news .news_con .news_list > li{
    border-bottom: 1px solid #CCC;
}
.news .news_con .news_list > li:last-child{
    border: 0;
}
.news .news_con .news_list > li .txt{
    position: relative;
    margin: 0 10px;
    padding: 15px 0px;
}
.news .news_con .news_list > li .day{
    display: inline-block;
    margin-right: 15px;
    font-size: 12px;
    color: #999999;
}
.news .news_con .news_list > li .cate{
    display: inline-block;
    max-width: 100px;
    width: 100%;
    padding: 5px;
    font-size: 12px;
    color: #31AE4B;
    background: #EFF9F1;
    text-align: center;
}
.news .news_con .news_list > li .til{
    display: block;
    margin: 6px 0 0;
    padding-right: 0;
    font-size: 14px;
    line-height: 1.8;
    text-decoration: underline;
}
.news .news_con .news_list > li .til:hover{
    text-decoration: none;
    opacity: 0.8;
}
.news .news_con .news_list > li .img{
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 55px;
    height: 55px;
    margin: auto;
    background: #EEEEEE;
    overflow: hidden;
}
.news .news_con .news_list > li .img img{
    position: absolute;
    top: 50%;
    bottom: auto;
    left: 50%;
    right: auto;
    max-width: none;
    max-height: none;
    margin: auto;
    transform: translate(-50%, -50%);
    visibility: hidden;
}
.news .news_con .news_list > li .img img.imgV{
    visibility: visible;
    max-width: 100%!important;
    max-height: none!important;
}
.news .news_con .news_list > li .img img.imgH{
    visibility: visible;
    max-width: none!important;
    max-height: 100%!important;
}

/* guide_area */
#guide_area{
    margin-bottom: 90px;
}
#guide_area .ga_inner{
    max-width: 1920px;
    margin: 0 auto;
}
#guide_area #company,
#guide_area #business{
    margin-bottom: 10px;
    overflow: hidden;
}
#guide_area #company{
    background: url(/shared/images/img_01_sp.jpg) left top / 100% no-repeat;
}
#guide_area #business{
    background: url(/shared/images/img_02_sp.jpg) right top / 100% no-repeat;
}
#guide_area .txt_area{
    position: relative;
    max-width: 100%;
    padding: 47% 5% 90px;
    margin-left: auto;
}
#guide_area #business .txt_area{
    margin-left: 0;
}
#guide_area .txt_area .en_til{
    position: relative;
    top: 123px;
    left: -70px;
    opacity: 0.3;
}
#guide_area #business .txt_area .en_til{
    right: auto;
    left: -60px;
}
#guide_area .txt_area .en_til span{
    display: none;
}
#guide_area .txt_area .bg_green_title{
    font-size: 20px;
    line-height: 1.7;
}
#guide_area .txt_area .txt{
    width: 100%;
    margin-bottom: 20px;
    line-height: 1.8;
}
#guide_area .txt_area .gr_link{
    width: 85%;
    right: 0;
    bottom: auto;
    margin: auto;
}

/* head_fam */
#head_fam{
    padding: 80px 0 70px;
    margin-bottom: 10px;
    background: url(/shared/images/img_03.jpg) center top / cover no-repeat;
}
#head_fam .inner{
    max-width: 1180px;
    width: 85%;
}
#head_fam .til img{
    display: block;
    margin: 0 auto 20px;
    max-width: 295px;
    width: 80%;
}

#head_fam .flx_box{
    text-align: center;
}
#head_fam .flx_box li{
    width: 80%;
    margin: 10px auto;

}

/* follow us */
#follow_us{
    padding: 70px 0 20px;
    background: #EEEEEE;
}
#follow_us .inner{
    max-width: 940px;
    width: 90%;
}
#follow_us .til{
    position: relative;
    margin-bottom: 60px;
    text-align: center;
}
#follow_us .til:after{
    content: "";
    display: inline-block;
    position: absolute;
    left: 0;
    right: 0;
    bottom: -25px;
    width: 50px;
    height: 5px;
    margin: auto;
    background: #31AE4B;
}
#follow_us .til img{
    max-width: 260px;
    width: 80%;
}
#follow_us .sns_content .sns_box{
    margin: 0 auto 60px;
}
#follow_us .sns_content .sns_box .sns_name{
    margin-bottom: 15px;
    text-align: center;
}
#follow_us .sns_content .sns_box .display{
    max-height: 430px;
    margin-bottom: 40px;
    overflow-y: scroll;
    border: 4px solid;
    box-shadow: 8px 8px 0 #DDD;
}
#follow_us .sns_content #FB_box .display{
    border-color: #1877F2;
}
#follow_us .sns_content #TW_box .display{
    border-color: #1DA1F2;
}
#follow_us .sns_content .sns_box .link{
    display: block;
    max-width: 360px;
    width: 100%;
    margin: 0 auto;
    padding: 14px;
    border-radius: 30px;
    font-weight: bold;
    text-align: center;
}
#follow_us .sns_content .sns_box .link:hover{
    opacity: 0.8;
}
#follow_us .sns_content #FB_box .link{
    background: #D7E1EE;
}
#follow_us .sns_content #FB_box .link span{
    color: #1877F2;
}
#follow_us .sns_content #TW_box .link{
    background: #D9E6EF;
}
#follow_us .sns_content #TW_box .link span{
    color: #1DA1F2;
}
#follow_us .sns_content .sns_box .link svg{
    width: 32px;
    height: 32px;
    margin-right: 15px;
}
#follow_us .sns_content #FB_box .link svg{
    fill: #1877F2;
}
#follow_us .sns_content #TW_box .link svg{
    fill: #1DA1F2;
}



@media screen and (min-width:560px){
    /* top内共通 */
    .bg_green_title{
        margin-bottom: 25px;
        font-size: 30px;
    }
    .bg_green_title span{
        padding: 6px 0.15em;
    }

    .gr_link{
        position: relative;
        width: auto;
        left: auto;
        bottom: -10px;
        margin: 0;
        text-align: left;
    }

    /* prides */
    #top_area .prides{
        margin-bottom: 90px;
    }
    #top_area .prides .m_txt{
        width: 95%;
        margin: 35px auto 0;
    }
    #top_area .prides .m_txt .name{
        margin-bottom: 25px;
        font-size: 18px;
    }
    #top_area .prides .m_txt .name span{
        font-size: 25px;
    }
    /* slide */
    #top_area .prides .slick-dots{
        right: 30px;
        bottom: 30px;
    }
    #top_area .prides .slick-dots li{
        width: 20px;
    }
    #top_area .prides .slick-dots li button:before{
        width: 13px;
        height: 13px;
    }

    /* news */
    #top_area .news{
        padding-bottom: 100px;
    }
    #top_area .news .til_area{
        display: flex;
        justify-content: space-between;
        align-items: flex-end;
        text-align: left;
        margin-bottom: 25px;
    }
    .news .news_con{
        padding: 8px 30px 10px;
    }
    .news .news_con .news_list > li .img{
        width: 60px;
        height: 60px;
    }

    /* guide_area */
    #guide_area{
        margin-bottom: 0;
    }
    #guide_area .txt_area{
        padding: 62% 18px 50px;
    }
    #guide_area .txt_area .en_til span{
        display: block;
        position: absolute;
        top: -190px;
        width: 610px;
        left: 30px;
        margin: auto;
    }
    #guide_area .txt_area .bg_green_title{
        font-size: 24px;
        line-height: 1.85;
    }
    #guide_area .txt_area .txt{
        margin-bottom: 35px;
    }
    #guide_area .txt_area .gr_link{
        max-width: 180px;
        bottom: 0;
        text-align: center;
    }

    /* follow us */
    #follow_us .inner{
        width: 95%;
    }
    #follow_us .sns_content .sns_box{
        max-width: 440px;
        margin: 0 auto 60px;
    }

    /* head_fam */
    #head_fam{
        padding: 100px 0 70px;
    }
}

@media screen and (min-width:960px){
    /* top共通 */
    .bg_green_title{
        margin-bottom: 13px;
        font-size: 2.5vw;
        line-height: 1.85;
    }
    .bg_green_title span{
        padding: 10px 0.15em;
    }
    #guide_area .txt_area .bg_green_title{
        line-height: 2.2;
    }

    /* top_area */
    #top_area{
        margin-bottom: 0;
    }
    #top_area:after{
        width: 90%;
        height: 92%;
    }
    /* prides */
    #top_area .prides{
        margin-bottom: 60px;
    }
    #top_area .prides .m_img{
        width: 60%;
    }
    #top_area .prides .m_txt{
        position: absolute;
        width: auto;
        bottom: -15%;
        left: 5%;
        margin: 0;
    }
    #top_area .prides .m_txt .name{
        margin-bottom: 13px;
    }
    #top_area .prides .m_txt .txt{
        width: 34%;
    }

    /* news */
    #top_area .news{
        padding: 0;
        margin: 11% auto 120px;
    }
    .news .news_con{
        padding: 25px 40px 20px;
    }

    /* guide_area */
    #guide_area #company{
        background: url(/shared/images/img_01.jpg) center left 40% / auto 100% no-repeat;
    }
    #guide_area #business{
        background: url(/shared/images/img_02.jpg) center right 40%/ auto 100% no-repeat;
    }
    #guide_area .txt_area{
        position: relative;
        max-width: 720px;
        width: 50%;
        padding: 200px 80px 160px;
        z-index: 5;
    }
    #guide_area .txt_area:after{
        content: "";
        display: inline-block;
        position: absolute;
        right: 0;
        top: 0;
        width: 100%;
        height: 100%;
        background: #FFF;
        opacity: 0.8;
        z-index: -1;
    }
    #guide_area .txt_area .en_til{
        position: absolute;
    }
    #guide_area #business .txt_area .en_til{
        right: -80px;
        left: auto;
    }
    #guide_area .txt_area .en_til span{
        position: relative;
        top: 0;
        left: 0;
        width: auto;
    }
    #guide_area .txt_area .txt{
        max-width: 560px;
    }

    /* head_fam */
    #head_fam{
        padding: 100px 0 130px;
    }
    #head_fam .flx_box{
        display: flex;
        justify-content: space-between;
    }
    #head_fam .flx_box li{
        flex: 0 0 30%;
        margin: 0 1%;
    }

    /* follow us */
    #follow_us{
        padding: 70px 0 90px;
    }
    #follow_us .sns_content{
        display: flex;
        justify-content: space-between;
    }
    #follow_us .sns_content .sns_box{
        flex: 0 0 440px;
        margin: 0;
    }
}

@media screen and (min-width:1200px){
    /* top内共通 */
    .bg_green_title{
        margin-bottom: 20px;
        line-height: 1.7;
    }
    /* top_area */
    #top_area .prides .m_txt .name{
        margin-bottom: 25px;
    }
    #top_area .prides .m_txt .name span{
        font-size: 32px;
    }
}
@media screen and (min-width:1400px){
    #guide_area #company{
        background: url(/shared/images/img_01.jpg) left center / auto 100% no-repeat;
    }
    #guide_area #business{
        background: url(/shared/images/img_02.jpg) center right/ auto 100% no-repeat;
    }
}
