@charset "UTF-8";
/* CSS Document */
/* 全体 */
html {
    scroll-behavior: smooth;
}
body {
    font-family: 'Ubuntu','Hiragino Kaku Gothic ProN','ヒラギノ角ゴ ProN W3','メイリオ', 'Meiryo','ＭＳ ゴシック',sans-serif;
    color: #333;
    margin: 0;
    overflow-wrap: break-word;
    word-wrap: break-word;
}
h1,h2,h3,h4,h5,h6,p{
    margin: 0;
}
ul{
    list-style: none;
    padding: 0;
    margin: 0;
}
a{
    transition: opacity 0.4s ease-in-out;
    text-decoration: none;
}
a:hover{
    transition: opacity 0.4s ease-in-out;
    opacity: 0.8;
}
img{
	vertical-align: top;
    width: 100%;
}
main{
    display: block;
    padding-top: 74px;
}
.main_inner{
    max-width: 1100px;
    padding: 80px 20px 0;
    margin: auto;
    margin-bottom: 130px;
}
section{
    margin-bottom: 100px;
}
section:last-child{
    margin-bottom: 0;
}
@media screen and (max-width:1200px){
    main{
        padding-top: 148px;
    }
}
@media screen and (max-width:767px){
    main{
        padding-top: 74px;
    }
    .main_inner{
        padding-top: 50px;
        margin-bottom: 70px;
    }
    section{
        margin-bottom: 70px;
    }
}

/* flex */
.flex{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}
.flex_wrap{
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
.flex_justify_space_between{
    -webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}
.flex_justify_center{
    -webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}
.flex_align_center{
    -webkit-box-align: center;
	-ms-flex-align: center;
    align-items: center;
}
.flex_left{
    order: 1;
}
.flex_right{
    order: 2;
}

/* テキスト */
p{
    font-size: 16px;
    line-height: 24px;
    margin-bottom: 20px;
}
small{
    display: block;
    font-size: 14px;
    line-height: 22px;
    color: #6e6e6e;
    text-indent: -1em;
    padding-left: 1em;
    margin-bottom: 20px;
}
.small_list small{
    margin-bottom: 0;
}
.small_list{
    margin-bottom: 20px;
}
.text_link{
    color: #005bac;
    text-decoration: underline;
}
.blank::after{
    display: inline-block;
    content: "";
    background: url(../img/blank_blue_icon.svg) no-repeat;
    width: 10px;
    height: 8px;
    margin-left: 4px;
    margin-bottom: 2px;
    margin-right: 4px;
}
p.detail_link {
    line-height: 1em;
}
.detail_link a{
    font-weight: bold;
    position: relative;
    color: #005bac;
}
.detail_link a:hover{
    color: #2f8fe5;
}
.detail_link a::after{
    position: absolute;
    content: url(../img/link_blue_icon.svg);
    width: 8px;
    margin-left: 10px;
}
.detail_link a:hover::after{
    content: url(../img/link_blue_ov_icon.svg);
}
.detail_link a.red::after{
    position: absolute;
    content: url(../img/link_red_icon.svg);
    width: 8px;
    margin-left: 10px;
}
.detail_link a.red:hover::after{
    content: url(../img/link_red_ov_icon.svg);
}
.pdf .text_link::after{
    display: inline-block;
    content: url(../img/pdf_icon.svg);
    width: 14px;
    height: 22px;
    margin-left: 5px;
    vertical-align: middle;
}
@media screen and (max-width:767px){
    .lead_text{
        font-size: 18px;
        line-height: 28px;
        margin-bottom: 50px;
    }
}

/* スクエアリスト */
ul.square_list li{
    font-size: 16px;
    line-height: 24px;
    position: relative;
    padding-left: 1em;
    margin-bottom: 10px;
}
ul.square_list li:last-child{
    margin-bottom: 0;
}
ul.square_list li::before{
    display: block;
    position: absolute;
    width: 7px;
    height: 7px;
    left: 0;
    top: 0;
    margin-top: 8px;
    content: "";
    background: #005bac;
}

/* フリーコール */
.freecall_block{
    text-align: center;
    background: #f4f4f4;
    padding: 50px;
    border-radius: 10px;
    margin-top: 40px;
    margin-bottom: 60px;
}
.freecall_block p{
    margin-bottom: 16px;
}
.freecall_block small{
    font-size: 14px;
    line-height: 1em;
    margin: 0;
}
.freecall_block .freecall_title{
    font-size: 24px;
    line-height: 1em;
    font-weight: bold;
    padding-bottom: 20px;
    border-bottom: 1px solid #fccf00;
    margin-bottom: 26px;
}
.freecall_block .freecall_company{
    font-weight: bold;
    margin-bottom: 10px;
}
.freecall_block .freecall_tel{
    font-size: 70px;
    line-height: 1em;
    font-weight: bold;
    margin-bottom: 10px;
}
.freecall_block .freecall_tel img{
    width: 60px;
    vertical-align: middle;
    margin-right: 20px;
}
@media screen and (max-width: 767px){
    .freecall_block{
        padding: 30px;
        margin-top: 30px;
        margin-bottom: 30px;
    }
    .freecall_block .freecall_title{
        font-size: 20px;
        line-height: 28px;
        padding-bottom: 10px;
        margin-bottom: 20px;
    }
    .freecall_block .freecall_company{
        line-height: 24px;
        margin-bottom: 16px;
    }
    .freecall_block .freecall_tel,
    .freecall_block .freecall_tel a{
        color: #333;
        font-size: 30px;
        text-align: center;
        margin-bottom: 16px;
    }
    .freecall_block .freecall_tel img{
        width: 32px;
        margin-right: 5px;
    }
}

/* そのほか */
.red{
    color: #f00!important;
}
.bold{
    font-weight: bold!important;
}
.text_right{
    text-align: right!important;
}
.text_center{
    text-align: center!important;
}
.text_left{
    text-align: left!important;
}
.image_center{
    display: block;
    margin: auto;
}
.bcg_white{
    background-color: #fff!important;
}


