@charset "utf-8";

/* mv
---------------------------------------------------- */
#mv {
    border-top: 10px solid #39579A;
    overflow: hidden;
    padding-bottom: 90px;
}

.mv_inner {
    max-width: 1600px;
    margin: 0 auto;
    position: relative;
}

.back_dot1 {
    position: absolute;
    left: 27%;
    bottom: -5%;
    z-index: -1;
}

.back_dot2 {
    position: absolute;
    right: 92%;
    top: 46.5%;
    z-index: -1;
}

.back_dot3 {
    position: absolute;
    left: 90%;
    bottom: 40%;
    z-index: -1;
}

.mv_txt {
    float: left;
    width: 30.88%;
    padding: 6% 0 0;
}

.mv_txt_inner {
    width: 70%;
    max-width: 290px;
    margin: 0 auto;
}

.home_logo img {
    width: 184px;
    height: auto;
    display: block;
}

.sp_mv {
    display: none;
}

.home_catch {
    font-family: 'Noto Serif JP', serif;
    font-size: 30px;
    line-height: 1.6;
    margin-top: 15%;
}

.home_mv_txt {
    font-size: 15px;
    line-height: 2;
    margin: 20% 0;
}

.home_navi li {
    font-size: 16px;
    line-height: 1.6;
    margin-top: 6%;
}

.mv_img {
    float: right;
    width: 69.12%;
}

.mv_img img {
    display: block;
    width: 100%;
    height: auto;
}

@media screen and (max-width: 1200px) {
    .home_catch {
        font-size: 24px;
    }

    .home_mv_txt {
        font-size: 14px;
    }

    .home_navi {
        display: none;
    }
}

@media screen and (max-width: 768px) {
    #mv {
        border-top: 4px solid #39579A;
        padding-bottom: 30px;
    }

    .back_dot1,
    .back_dot2,
    .back_dot3 {
        display: none;
    }

    .mv_txt {
        float: none;
        width: auto;
        padding: 0;
    }

    .mv_txt_inner {
        width: auto;
        max-width: initial;
        max-width: auto;
        margin: 0 auto;
    }

    .home_logo {
        padding: 22px 0 22px 20px;
    }

    .home_logo img {
        width: 120px;
        height: auto;
    }

    .sp_mv {
        display: block;
    }

    .sp_mv img {
        display: block;
        width: 100%;
        height: auto;
    }

    .home_catch {
        text-align: center;
        font-size: 18px;
        margin: 20px;
    }

    .home_catch br {
        display: none;
    }

    .home_mv_txt {
        font-size: 14px;
        margin: 20px 20px 0;
    }

    .mv_img {
        display: none;
    }
}

/* home_about
---------------------------------------------------- */
#home_about {
    position: relative;
    background: url(../images/back_dot2.png) repeat-x left bottom;
    padding-bottom: 107px;
}

#home_about::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    max-height: 516px;
    height: 77%;
    background: url(../images/back1.png) no-repeat center top;
    background-size: cover;
    z-index: -1;
}

.home_about_inner {
    max-width: 1600px;
    margin: 0 auto;
    position: relative;
}

#home_about figure {
    padding: 80px 0 0;
    padding: 5% 0 0;
    margin: 0 0 0 6.25%;
    width: 50%;
}

#home_about .home_about_txt {
    background-color: #fff;
    width: 560px;
    width: 35%;
    box-sizing: border-box;
    padding: 40px 50px;
    padding: 2.5% 3.12%;
    position: absolute;
    right: 12.5%;
    top: 80%;
    transform: translate(0, -50%);
}

#home_about h2 {
    font-size: 26px;
    line-height: 1;
    font-family: 'Noto Serif JP', serif;
    position: relative;
}

#home_about h2::after {
    content: '';
    width: 103.5px;
    height: 2px;
    background-color: #27477b;
    position: absolute;
    left: 0;
    bottom: -20px;
}

#home_about p {
    font-size: 15px;
    line-height: 2;
    margin-top: 40px;
}

.btn1 a {
    width: 144px;
    height: 32px;
    border: 1px solid #333;
    display: block;
    font-family: 'Montserrat', sans-serif;
    font-size: 14px;
    letter-spacing: 0.1em;
    line-height: 32px;
    text-align: center;
    margin-top: 30px;
}

@media screen and (max-width: 1200px) {
    #home_about h2 {
        font-size: 22px;
    }

    #home_about p {
        font-size: 14px;
    }

    .btn1 a {
        margin-top: 20px;
    }
}

@media screen and (max-width: 768px) {
    #home_about {
        padding-bottom: 40px;
    }

    #home_about::before {
        height: 30%;
    }

    #home_about figure {
        padding: 40px 20px 0;
        margin: 0;
        width: auto;
    }

    #home_about figure img {
        width: 100%;
        height: auto;
    }

    #home_about .home_about_txt {
        width: auto;
        padding: 30px 20px;
        position: static;
        right: auto;
        top: auto;
        transform: translate(0, 0);
    }

    #home_about h2 {
        font-size: 18px;
        text-align: center;
    }

    #home_about h2::after {
        width: 100px;
        left: 50%;
        transform: translate(-50%, 0);
    }

    .btn1 a {
        margin-right: auto;
        margin-left: auto;
    }
}

/* home_news
---------------------------------------------------- */
#home_news {
    padding: 80px 0 100px;
}

#home_news ul {
    max-width: 885px;
    margin: 60px auto 0;
    border-bottom: 1px dotted #707070;
}

#home_news li {
    display: block;
    border-top: 1px dotted #707070;
    padding: 18px 8px;
}

#home_news dt {
    font-size: 15px;
    line-height: 1.6;
    float: left;
}

#home_news dd {
    font-size: 15px;
    line-height: 1.6;
    margin-left: 115px;
}

@media screen and (max-width: 768px) {
    #home_news {
        padding: 40px 0;
    }

    #home_news ul {
        margin: 30px auto 0;
    }

    #home_news li {
        padding: 15px 20px;
    }

    #home_news dt {
        font-size: 14px;
        line-height: 1.8;
        float: none;
    }

    #home_news dd {
        font-size: 14px;
        line-height: 1.8;
        margin-left: 0;
    }
}

/* home_btn
---------------------------------------------------- */

#home_btn li {
    display: block;
    float: left;
    width: 50%;
    text-align: center;
    background: url(../images/home21.jpg) no-repeat center center;
    background-size: cover;
}

#home_btn li:nth-child(2) {
    background: url(../images/home22.jpg) no-repeat center center;
    background-size: cover;
}

#home_btn a {
    display: block;
    height: 344px;
    background-color: rgba(0, 0, 0, 0.4);
    position: relative;
}

#home_btn a:hover {
    opacity: 1;
    background-color: rgba(0, 0, 0, 0);
}

#home_btn dl {
    max-width: 334px;
    width: 100%;
    min-height: 110px;
    border: 1px solid #999;
    text-align: center;
    margin: auto;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    box-sizing: border-box;
    padding: 28px 0 0;
    transition: all .4s;
}

#home_btn a:hover dl {
    border: 1px solid #fff;
    transition: all .4s;
}

#home_btn dt {
    font-size: 24px;
    line-height: 1;
    text-align: center;
    color: #fff;
    font-family: 'Noto Serif JP', serif;
}

#home_btn dd {
    margin-top: 15px;
    font-size: 15px;
    letter-spacing: 0.05em;
    line-height: 1;
    text-align: center;
    color: #fff;
    font-family: 'Montserrat', sans-serif;
}

@media screen and (max-width: 768px) {
    #home_btn li {
        float: none;
        width: auto;
    }

    #home_btn a {
        height: auto;
        padding: 50px 0;
    }

    #home_btn dl {
        width: 60%;
        min-height: 0px;
        position: static;
        top: auto;
        left: auto;
        transform: translate(0, 0);
        padding: 20px 0;
        border-color: #ccc;
    }

    #home_btn dt {
        font-size: 18px;
    }

    #home_btn dd {
        font-size: 12px;
    }
}

/* gmap
---------------------------------------------------- */
#gmap iframe {
    width: 100%;
}

@media screen and (max-width: 768px) {
    #gmap iframe {
        height: 300px;
    }
}

/* home_policy_btn
---------------------------------------------------- */

.home_policy_btn a {
    max-width: 510px;
    background: transparent;
    border: 1px solid #ccc;
    display: block;
    margin: 60px auto;
    text-align: center;
    box-sizing: border-box;
    padding: 24px 0 28px;
}

.home_policy_btn img {
    width: 21.07px;
    height: auto;
    display: inline-block;
    margin: 0 20px 0 0;
    vertical-align: middle;
}

.home_policy_btn .span1 {
    font-family: 'Noto Serif JP', serif;
    font-size: 22px;
    line-height: 1;
    display: inline-block;
    vertical-align: middle;
    margin: 0 20px 0 0;
}

.home_policy_btn .span2 {
    display: inline-block;
    vertical-align: middle;
    font-family: 'Montserrat', sans-serif;
    font-size: 15px;
    letter-spacing: 0.05em;
    line-height: 1;
    margin: 8px 0 0;
}

@media screen and (max-width: 768px) {
    .home_policy_btn {
        padding: 0 20px;
    }

    .home_policy_btn a {
        margin: 40px auto;
    }

    .home_policy_btn img {
        width: 16px;
        height: auto;
        margin: 0 10px 0 0;
    }

    .home_policy_btn .span1 {
        font-size: 16px;
        margin: 2px 6px 0 0;
    }

    .home_policy_btn .span2 {
        font-size: 11px;
    }
}