@charset "UTF-8";

#jumbotron_sub .jumbotron_bg {
    background-position: center left;
}

.btn_link_01 input.btn-block {
    display: inline-block;
    background: #fff;
    border: 2px solid #0f1a57;
    text-align: center;
    padding: 1rem 5rem;
    font-family: 'Montserrat', sans-serif;
    font-weight: 600;
    color: #0f1a57;
    transition: .5s ease all;
}

.btn_link_01 input.btn-block:hover {
    background-color: #0f1a57;
    color: #fff;
    opacity: 1;
    transition: .5s ease all;
}

/*----------------------------------------------------
    Service
----------------------------------------------------*/

/* sec01
---------------------------*/
#sec01 {
    margin-bottom: 6rem;
}

#sec01 .name_block {
    text-align: right;
}

@media screen and (max-width:767px) {
    #sec01 {
        margin-bottom: 4rem;
    }

    #sec01 .name_block img {
        width: 50%;
    }
}

#sec01 {
    margin-bottom: 4rem;
}

#sec01 .list_area {
    border-bottom: 1px solid #c9c9c9;
    padding: 1.6rem 0;
}

#sec01 .list_area h3 {
    font-family: 'Noto Serif JP', serif;
    color: #0f1a57;
    font-size: 24px;
    font-weight: 700;
    margin-top: 1rem;
    margin-bottom: 1rem;
}

@media screen and (max-width:767px) {
    #sec01 .list_area h3 {
        font-size: 20px;
    }
}

.row-blog {
    padding-bottom: 6rem;
}

/* blog */
.post .cont figure, .post .cont figure a {
    display: inline-block;
}

.row-blog .cont .cont-box.border {
    border: 1px solid #343434;
}

.row-blog .blog-info {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    -ms-align-items: center;
    align-items: center;
    margin: -5px;
}

.row-blog .blog-info>div {
    padding: 5px;
}

.row-blog .cont.post h1, .row-blog .cont.post h2, .row-blog .cont.post h3, .row-blog .cont.post h4, .row-blog .cont.post h5, .row-blog .cont.post h6 {}

.row-blog .cont.post .metabox p {
    margin-bottom: 2em;
}

.row-blog .cont.post .metabox p:last-child {
    margin-bottom: 0;
}

.row-blog table {
    width: 100% !important;
}

.row-blog table tr th, .row-blog table tr td {
    padding: 15px;
    border: 1px solid #343434;
}

.row-blog table tr th {
    background: #d6d6d6;
}

#side {
    padding: 30px;
    margin-bottom: 60px;
    background: #fff;
}

.blog-ttl-area {
    display: block;
    margin-bottom: 30px;
}

.blog-ttl-area .date-area {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: center;
    -ms-align-items: center;
    align-items: center;
    text-align: center;
    float: left;
    width: 90px;
    height: 90px;
    padding: 10px;
    margin-right: 15px;
    border: 1px solid #1a51a3;
    position: absolute;
}

.blog-ttl-area .date-area .date-cont {
    margin: 0;
}

.blog-ttl-area .date-area .date-cont span {
    font-size: 1.5rem;
    color: #1a51a3;
    display: block;
}

.blog-ttl-area .title {
    padding-bottom: 0 !important;
    margin-bottom: 0 !important;
    margin-left: 120px;
    border: none !important;
}

.cont figure.eye-catch {
    margin-bottom: 30px;
}

.widget-area {
    margin: 0;
}

.widget-area [id^="custom_html"] {
    margin-bottom: 30px;
}

.widget-area [id^="custom_html"]:last-child {
    margin-bottom: 0;
}

.widget {
    padding: 0;
}

.widget>ul {
    margin: 0;
}

.widget>ul>li {
    padding: 0;
    border-top: 1px solid #343434;
}

.widget>ul>li:last-child {
    border-bottom: 1px solid #343434;
}

.widget>ul>li a {
    display: block;
    padding: 15px 0;
}

.widget>ul>li .date {
    font-size: 14px;
    display: block;
    margin-bottom: 5px;
}

.widget>ul>li .metabox p {
    line-height: 1;
}

.widget>ul>li .metabox p:last-child {
    margin-bottom: 0;
}

.widget-title .ttl {
    color: #0f1a57;
    display: block;
    margin-bottom: 5px;
}

.bg-common.blog.home {
    border-bottom: 1px solid #d6d6d6;
}

@media (min-width: 768px) and (max-width: 991px) {
    .row-post-cont-box {
        padding-right: 30px;
        padding-bottom: 30px;
        padding-left: 30px;
    }
}

@media (min-width: 992px) and (max-width: 1200px) {
    .row-post-cont-box {
        padding-right: 45px;
        padding-bottom: 45px;
        padding-left: 45px;
    }
}

@media (min-width: 1201px) {
    .row-post-cont-box {
        padding-right: 60px;
        padding-bottom: 60px;
        padding-left: 60px;
    }
}

.card-blog .item .bg-cont {
    background-color: #fff;
}

.card-blog .item .ttl {
    font-size: 1rem;
    margin-bottom: .5rem;
}

.card-blog .item .blog-info {
    font-size: 14px;
    margin-bottom: .5rem;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    flex-wrap: wrap;
    margin-right: -3px;
    margin-left: -3px;
}

.card-blog .item .blog-info div {
    padding-right: 3px;
    padding-left: 3px;
}

.card-blog .item .metabox {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
}

.card-blog .item .metabox p {
    font-size: .8rem;
}

@media (max-width: 767px) {
    .carousel-area .carousel-cont>.card-blog>.item {
        display: -webkit-flex;
        display: -moz-flex;
        display: -ms-flex;
        display: -o-flex;
        display: flex;
    }
}

.ellipsis {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.post-area img {
    max-width: 100%;
    height: auto;
}

.widget-area>div {
    margin-bottom: 30px;
}

.widget ul {
    padding-left: 0;
    margin-bottom: 0;
}

.widget ul li {
    display: block;
}

.widget {
    padding: 0;
}

.widget>ul {
    margin: 0;
}

.widget>ul>li {
    padding: 0;
    border-top: 1px solid #d6d6d6;
}

.widget>ul>li:last-child {
    border-bottom: 1px solid #d6d6d6;
}

.widget>ul>li a {
    display: block;
    padding: 15px 0;
}

.widget>ul>li .date {
    font-size: 14px;
    display: block;
    margin-bottom: 5px;
}

.widget>ul>li .metabox p {
    line-height: 1;
}

#searchform .btn {
    min-width: inherit;
}

.nav-below {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: space-between;
    margin: 0;
}

.nav-below .nav-next {
    float: left;
}

.nav-below .nav-previous {
    float: right;
}

.nav-below .nav-next a, .nav-below .nav-previous a {
    position: relative;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    display: inherit;
}

.nav-below a:hover, .nav-below a:active, .nav-below a:focus {
    opacity: .5;
}

.nav-below .nav-next a {
    text-align: left;
}

.nav-below .nav-previous a {
    text-align: right;
}

.nav-below .nav-next a:before, .nav-below .nav-previous a:before {
    font-family: ionicons;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}

.nav-below .nav-next a:before {
    content: '\f3d2';
    left: 1em;
}

.nav-below .nav-previous a:before {
    content: '\f3d3';
    right: 1em;
}

.nav-below span {
    text-align: center;
    width: 33.333333%;
}

.nav-below .nav-next, .nav-below .nav-previous {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.nav-below .nav-next {
    text-align: left;
}

.nav-below .nav-previous {
    text-align: right;
}

.nav-below .nav-next a {
    padding: 1em 1em 1em 2em;
}

.nav-below .archive a {
    padding: 1em;
}

.nav-below .nav-previous a {
    padding: 1em 2em 1em 1em;
}

.nav-below span a {
    display: inline-block;
    border: none;
    background: none;
}

@media (max-width: 767px) {
    .nav-below span {
        font-size: .8em;
    }
}

.bg-common.post.blog .row-blog .item-main.archive>.cont>.cont-main>[class^="block_"] {
    border-bottom: 1px solid #d6d6d6;
}

.bg-common.post.blog .row-blog .item-main.archive>.cont>.cont-main>[class^="block_"]:last-child {
    border-bottom: none;
}

/* pagination */
.pagination {
    clear: both;
    padding: 0;
    position: relative;
    font-size: 14px;
    line-height: 14px;
    width: 100%;
    text-align: center;
    justify-content: center;
    margin-bottom: 60px;
}

.pagination-box {
    display: inline-block;
}

.pagination span, .pagination a {
    display: block;
    float: left;
    margin: 2px 2px 2px 0;
    padding: 10px 15px 10px 15px;
    text-decoration: none;
    width: auto;
    color: #777;
    background: #dedede;
    box-shadow: inset 1px 1px #dedede, inset -1px -1px #dedede;
}

.pagination a:hover, .pagination a:active, .pagination a:focus {
    color: #fff;
    background: #1a51a3;
    box-shadow: inset 1px 1px #003670, inset -1px -1px #003670;
}

.pagination .current {
    padding: 10px 15px 10px 15px;
    background: #003670;
    color: #fff;
    box-shadow: inset 1px 1px #003670, inset -1px -1px #003670;
}

@media only screen and (max-width: 413px) {
    .pagination {
        font-size: 12px;
        line-height: 12px;
    }

    .pagination span, .pagination a {
        padding: 8px 10px 8px 10px;
    }

    .pagination .current {
        padding: 8px 10px 8px 10px;
    }
}
