@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&family=Mitr:wght@200&display=swap');

/* Reset CSS
-------------------------------*/

body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,code,form,fieldset,legend,input,textarea,p,blockquote,th,td{
    margin:0;
    padding:0;
}
table{
    border-collapse:collapse;
    border-spacing:0;
}
fieldset,img{
    border:0;
}
address,caption,cite,code,dfn,em,strong,th,var{
    font-style:normal;
    font-weight:normal;
}
ul,ol,li{
    list-style:none;
}
caption,th{
    text-align:left;
}
h1,h2,h3,h4,h5,h6{
    font-size:100%;
    font-weight:normal;
}
q:before,q:after{
    content:'';
}
abbr,acronym {border:0;font-variant:normal;}
sup {vertical-align:text-top;}
sub {vertical-align:text-bottom;}
hr {display:none;}
input,textarea,select{
    font-family:inherit;
    font-size:inherit;
    font-weight:inherit;
    *font-size:100%;
}
*,
*::before,
*::after {
    box-sizing: border-box;
}

img{
    max-width:100%;
    height:auto;
    vertical-align: bottom;
    margin:0;
    padding:0;
}

.clearfix:after {
    content: "."; 
    display: block; 
    height: 0; 
    clear: both; 
    visibility: hidden;
}

html {scroll-behavior: smooth;}

a {
    outline:none;
    color: #2e2e2e;
    -webkit-transition: 0.5s;
    -moz-transition: 0.5s;
    -o-transition: 0.5s;
    transition: 0.5s;
    text-decoration: none;
}

a:hover {
    text-decoration: none;
/*    filter: alpha(opacity=80);*/
/*    -moz-opacity:0.80;*/
/*    opacity:0.80;*/
}
.hov a{
    transition: 0.3s;
}
.hov a:hover{
    filter: alpha(opacity=80);
    -moz-opacity:0.80;
    opacity:0.80;
}

/* PCで電話リンクしない */
@media(min-width: 768px){
    a[href^="tel:"]{
        pointer-events: none;
    }
}

.flex{
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

/* マウスストーカー */
#stalker {
    pointer-events:none;
    position:fixed;
    top:-6px;
    left:-6px;
    width:12px;
    height:12px;
    background:#205dab;
    border-radius:50%;

    -webkit-transition:visibility .5s,top,.5s,left .5s,width .5s,height .5s,background-color .5s,-webkit-transform .5s;
    transition:visibility .5s,top,.5s,left .5s,width .5s,height .5s,background-color .5s,-webkit-transform .5s;
    -o-transition:visibility .5s,top,.5s,left .5s,width .5s,height .5s,background-color .5s,-o-transform .5s;

    transition:visibility .5s,transform 0s,top,.5s,left .5s,width .5s,height .5s,background-color .5s;
    transition:visibility .5s,transform 0s,top,.5s,left .5s,width .5s,height .5s,background-color .5s,-webkit-transform 0s,-o-transform 0s;

    -webkit-transition-timing-function:ease-out;
    -o-transition-timing-function:ease-out;
    transition-timing-function:ease-out;
    z-index:99999;
}
#stalker.hov_ {
    top:-35px;
    left:-35px;
    width:70px;
    height:70px;
    background:rgba(32, 93, 171, 0.4);
}
@media screen and (max-width: 810px){
    #stalker{
        display:none;
    }
}


/* Basic setting
-------------------------------*/

body {
    font-family: 'Noto Sans JP', "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
    font-size: 16px;
    line-height: 1.8em;
    color: #000;
    -webkit-text-size-adjust: 100%;
    background-color: #f5f8fb;
}
#wrapper{
    margin:0 auto;
    padding:0;
    width:100%;
    overflow:hidden;
}


















/* ヘッダー
-------------------------------*/
* html #header{height:1%;}
#header{
    width: 100%;
    padding-top: 60px;
    padding-bottom: 50px;
    position: relative;
    z-index: 9999;
    transition: 0.2s;
}

#header .inner{
    align-items: center;
    width: 95%;
    max-width: 1600px;
    margin: auto;
    background-color: #fff;
    padding: 20px 30px;
}
#header .logo{
    width: 300px;
}
.p-nav{
    width: 90%;
    max-width: 1480px;
    margin: auto;
    text-align: right;
    font-size: 12px;
}
.p-nav a{
    color: #9b9b9b;
}
.p-nav a:hover{
    color: #0861d6;
}

.p-nav.h_fixed{
    margin-top: 190px;
}


@media screen and (min-width:911px){
    #header.fixed{
        padding-top: 0;
        padding-bottom: 0;
        position: fixed;
    }

}

@media (min-width:911px) and (max-width:1300px){
    #header .inner{
        padding-left: 20px;
        padding-right: 20px;
    }
    #header .logo{
        width: 23%;
    }
}
@media screen and (max-width:910px){
    #header{
        padding-top: 10px;
        padding-bottom: 10px;
    }
    #header .inner{
        align-items: center;
        width: 95%;
        padding-left: 12px;
        padding-top: 20px;
        padding-bottom: 15px;
    }
    #header .logo img{
        width: 250px;
        height: auto;
    }
}
@media screen and (max-width:640px){
    .p-nav{
        display: none;
    }
}






/* フッター お問い合わせ
-------------------------------*/
#f_contact{
    width: 100%;
    height: 600px;
    background-color: #fff;
/*    background-image: url(img/common/f_contaact_bg.jpg);
    background-position: center bottom;
    background-repeat: no-repeat;*/
    padding-top: 120px;
    margin-top: 150px;
}
#f_contact ._in{
    width: 90%;
    margin: auto;
    text-align: center;
/*    color: #fff;*/
}
#f_contact .txt1{
    font-size: 15px;
    font-weight: 700;
/*    padding-bottom: 12px;
    background: url(img/common/f_contaact_bar.png) center bottom no-repeat;*/
    margin-bottom: 15px;
}
#f_contact .txt2{
    font-size: 35px;
    line-height: 1.2em;
    font-weight: 500;
    color: #0861d6;
    position: relative;
    margin-bottom: 70px;
}
#f_contact .txt2:after{
    position: absolute;
    left: calc(50% - 60px);
    bottom: -20px;
    width: 120px;
    height: 1px;
    background-color: #0861d6;
    content: "";
}

#f_contact .txt3{
    font-size: 16px;
    font-weight: 700;
    margin-top: 40px;
    margin-bottom: 60px;
}
#f_contact .txt3 span{
    color: #ffff70;
}
#f_contact .txt4{
    font-size: 14px;
    margin-bottom: 20px;
}

.btn a{
    margin: auto;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    width: 260px;
    height: 56px;
    padding: 0 25px 5px;
    background-color: #e6eef6;
    background-image: url(img/common/btn_ya.svg);
    background-size: 16px auto;
    background-position: 90% center;
    background-repeat: no-repeat;
    border-radius: 30px;
    text-align: left;
    position: relative;
}
.btn a:hover{
/*    background-position: 93% center;*/
}

.btn a .btn-txt {
    line-height: 1;
    overflow: hidden;
    display: block;
    padding-right: 10px;
}
.btn a .btn-txt-in{
    display: inline-block;
    font-size: 14px;
}
.btn a .btn-txt-in img{
    width: auto;
    max-width: none;
    height: 10px;
}
.btn a:hover .btn-txt-in {
    -webkit-animation: hover_txt_link 0.5s linear forwards;
    animation: hov_txt_link 0.5s linear forwards;
}

@keyframes hov_txt_link {
    0% {
        transform: translateY(0%);
    }
    50% {
        transform: translateY(-100%);
    }
    50.5% {
        transform: translateY(100%);
    }
    100% {
        transform: translateY(0%);
    }
}

@media (min-width:911px) and (max-width:1300px){
    #f_contact{
        height: 46vw;
        padding-top: 9vw;
    } 
    #f_contact .txt1{
        padding-bottom: 0.09vw;
        margin-bottom: 1.9vw;
    }
    #f_contact .txt2{
        font-size: 2.7vw;
        line-height: 1.2em;
        font-weight: 500;
    }
    
    #f_contact .txt2 img{
        width: 31vw;
        height: auto;
    }
    #f_contact .txt3{
        margin-top: 3vw;
        margin-bottom: 4.6vw;
    }
    #f_contact .txt4{
        margin-bottom: 1.5vw;
    }
}
@media  screen and (max-width:910px){
    #f_contact{
        height: auto;
        padding-top: 80px;
        padding-bottom: 80px;
    }
    #f_contact .txt2{
        font-size: 30px;
        line-height: 1.2em;
    }

    #f_contact .txt2 img{
        width: 300px;
        height: auto;
    }
    #f_contact .txt3{
        margin-top: 30px;
        margin-bottom: 40px;
    }
}
@media  screen and (max-width:640px){
    #f_contact{
        padding-top: 50px;
        padding-bottom: 50px;
        margin-top: 80px;
    }
    #f_contact .txt1{
        padding-bottom: 8px;
        margin-bottom: 20px;
    }
    #f_contact .txt2 img{
        width: 240px;
        height: auto;
    }
    #f_contact .txt3{
        font-size: 15px;
        margin-top: 20px;
        margin-bottom: 30px;
    }
    #f_contact .txt4{
        margin-bottom: 10px;
    }
    .btn a{
        width: 250px;
        height: 50px;
    }
}


.f_cont_btn{
    width: 100%;
    max-width: 1100px;
    margin: auto;
}

.f_cont_btn .btn{
    width: 48%;
}
.f_cont_btn .btn a {
    width: 100%;
    height: 140px;
    justify-content: center;
    color: #0861d6;
    border-radius: 70px;
    background-color: #fff;
    border: solid 1px #0861d6;
    background-size: 25px auto;
}
.f_cont_btn .btn a .btn-txt-in {
    display: inline-block;
    font-size: 30px;
    font-weight: 600;
}

.f_cont_btn .btn.tel a{
    background-color: #0861d6;
    background-image: none;
    
}

@media  screen and (max-width:1200px){
    .f_cont_btn .btn a {
        height: 11vw;
        border-radius: 6vw;
        background-size: 2vw auto;
    }
    .f_cont_btn .btn a .btn-txt-in {
        font-size: 2.5vw;
    }

    .f_cont_btn .btn.tel a img{
        width: 34vw;
        height: auto;
    }


}
@media  screen and (max-width:640px){
    #f_contact .txt2 {
        margin-bottom: 50px;
    }

    .f_cont_btn .btn{
        width: 100%;
        max-width: 300px;
        margin: 0 auto 20px;
    }
    .f_cont_btn .btn a {
        height: 75px;
        border-radius: 40px;
        background-size: 16px auto;
    }
    .f_cont_btn .btn a .btn-txt-in {
        font-size: 19px;
    }

    .f_cont_btn .btn.tel a img{
        width: 210px;
        height: auto;
    }

}























/* フッター
-------------------------------*/
#footer{
    letter-spacing:0.07em;
    background-color: #0861d6;
}
.f_info01{
    width: 100%;
    max-width: 1920px;
    margin: auto;
}

.f_info01 .txt{
    width: 460px;
    text-align: center;
    padding-top: 130px;
}
.f_info01 .txt .f_logo{
}

.f_info01 .txt .add{
    display: inline-block;
    text-align: left;
    font-size: 12px;
    line-height: 1.8em;
    color: #fff;
    margin-top: 40px;
}
.f_info01 .f_nav_box{
    width: calc(100% - 460px);
    justify-content: flex-end;
    background-color: #f0f9fe;
    padding-top: 100px;
    padding-bottom: 100px;
    padding-left: 80px;
}
.f_info01 .f_nav_box ._in{
    width: 95%;
    max-width: 1200px;
}



.f_info01 .f_nav1 ul{
    display: flex;
}
.f_info01 .f_nav1 li{
    margin-right: 2em;
}
.f_info01 .f_nav1 li a{
    display: block;
    color: #666;
    font-size: 16px;
    font-weight: 700;
}
.f_info01 .f_nav1 li .sub{
    display: block;
}
.f_info01 .f_nav1 li .sub li{
    margin-top: 5px;
    margin-left: 1em;
}
.f_info01 .f_nav1 li .sub a{
    font-weight: 400;
    font-size: 13px;
}

.f_info01 .f_nav2{
    width: 100%;
    margin-top: 50px;
}
.f_info01 .f_nav2 ul{
    display: flex;
    justify-content: flex-end;
}
.f_info01 .f_nav2 li{
    margin-left: 2em;
}
.f_info01 .f_nav2 li a{
    font-size: 13px;
    color: #666;
}
.f_info01 .f_nav2 li.rec a{
    font-size: 14px;
    font-weight: 700;
    padding-right: 20px;
    background: url(img/common/wo.png) right center no-repeat;
}

/* hoverアニメーション追加 */
.f_info02{
    width: 100%;
    max-width: 1280px;
    margin: auto;
    border-top: solid 1px #cecece;
    padding-top: 60px;
    margin-top: 60px;
    display: flex;
    justify-content: space-between;
}
.f_info02 .ico ul{
    display: flex;
    justify-content: flex-end;
    align-items: center;
}
.f_info02 .ico li{
    margin-left: 15px;
}

.f_info01 .f_nav1 li a span{
    position: relative;
}
.f_info01 .f_nav1 li a span::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    /*線の形状*/
    width: 100%;
    height: 1px;
    background:#205dab;
    /*アニメーションの指定*/
    transition: all .3s;
    transform: scale(0, 1);/*X方向0、Y方向1*/
    transform-origin: left top;/*左上基点*/
}
.f_info01 .f_nav1 li a:hover  span::after {
    transform: scale(1, 1);/*X方向にスケール拡大*/
}
.f_info01 .f_nav2 li a{
    position: relative;
}
.f_info01 .f_nav2 li a::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    /*線の形状*/
    width: 100%;
    height: 1px;
    background:#205dab;
    /*アニメーションの指定*/
    transition: all .3s;
    transform: scale(0, 1);/*X方向0、Y方向1*/
    transform-origin: left top;/*左上基点*/
}
.f_info01 .f_nav2 li a:hover::after {
    transform: scale(1, 1);/*X方向にスケール拡大*/
}



#footer .copy{
    width: 100%;
    background-color: #0861d6;
    color: #fff;
    text-align:right;
    font-size:13px;
    line-height: 1.3em;
    padding:30px 5%;
}
#footer .copy ._in{
    width: 90%;
    max-width: 1600px;
    margin: auto;
}
#pageTop{
    position:fixed;
    bottom:80px;
    right:20px;
    z-index: 99;
}

@media  screen and (max-width:1300px){
    .f_info01 .txt{
        width: 35%;
        padding-top: 10vw;
        padding-left: 3%;
        padding-right: 3%;
    }
    .f_info01 .f_nav_box{
        width: 65%;
        padding-top: 6vw;
        padding-bottom: 6vw;
        padding-left: 3%;
        padding-right: 3%;
    }
    .f_info01 .f_nav_box ._in{
        width: 100%;
    }
    
    .f_info01 .f_nav1{
        width: 100%;
        margin-top: 50px;
        display: block;
    }
    .f_info01 .f_nav1 ul{
        display: flex;
        justify-content: space-between;
    }
    .f_info01 .f_nav1 li{
        margin-right: 0;
    }
    
    .f_info02 {
        padding-top: 4.6vw;
        margin-top: 4.6vw;
    }
    
    .f_info02 .bnr{
        width: 100%;
        text-align: center;
        margin-bottom: 40px;
    }
    .f_info02 .ico{
        width: 100%;
        text-align: center;
    }
    .f_info02 .ico ul{
        display: flex;
        justify-content: center;
        align-items: center;
    }

    .f_info02 .ico li{
        margin: 0 6px;
    }
    
}

@media  screen and (max-width:910px){
    .f_info01 .txt{
        width: 100%;
        padding: 60px 5%;
    }
    .f_info01 .f_nav_box{
        width: 100%;
        padding: 30px 5%;
    }

    
    .f_info02 .bnr{
        margin-bottom: 20px;
    }
    #footer .copy{
        text-align: center;
    }
}

@media  screen and (max-width:640px){

    #footer{
        padding-top: 0;
        letter-spacing:0; 
    }
    .f_info01 .txt{
        width: 100%;
        text-align: center;
    }
    .f_info01 .txt .f_logo img{
        width: 180px;
        height: auto;
    }
    
    .f_info01 .f_nav1,
    .f_info01 .f_nav2{
        display: none;
    }
    
    .f_info02 {
        border-top: none;
        margin-top:0;
        display: block;
        text-align: center;
        padding: 0;
    }

    #footer .copy{
        font-size:12px;
        line-height: 1.3em;
        padding:20px 2%;
    }
    #footer .copy span{
        display: inline-block;
    }
    #pageTop img{
        display: none;
    }
    #pageTop{
        width: 50px;
        height: 50px;
        background: url(img/common/arrow_top_maru.png) no-repeat;
        background-size: cover;
    }
}




/* ページタイトル
-------------------------------*/
.page-ttl{
    width: 100%;
    max-width: 1600px;
    margin: auto;
    padding: 50px 3%;
    border-bottom: solid 1px #cecece;
    margin-bottom: 80px;
    position: relative;
    z-index: 9;
}
.page-ttl .en{
    min-height: 85px;
}
.page-ttl .ja{
    margin-left: 40px;
    font-size: 16px;
    color: #0861d6;
}
.page-ttl .en.lo2{
    margin-bottom: 20px;
}



.page-sub-nav{
    margin-top: 60px;
}
.page-sub-nav ul{
    width: 100%;
    max-width: 780px;
    justify-content: flex-start;
}
.page-sub-nav li{
    width: 32%;
    margin-right: 1%;
    margin-bottom: 5px;
}
.page-sub-nav .btn a{
    width: 100%;
    margin: 0;
    background-image: url(img/common/btn_ya_maru.png);
    background-color: transparent;
}
.page-sub-nav .btn .stay a,
.page-sub-nav .btn a:hover{
    background-color: #e6eef6;
}

.page-sub-nav.x4 ul{
    max-width: 1080px;
}
.page-sub-nav.x4 li{
    width: 24%;
    margin-right: 1%;
}

@media  screen and (max-width:1300px){
    .page-ttl{
        padding: 30px 3%;
        margin-bottom: 50px;
    }
    .page-ttl .en{
        min-height: 6vw;
    }
    .page-ttl .en img{
        width: auto;
        height: 4.5vw;
    }
    .page-ttl .en.des img{
        width: auto;
        height: 6vw;
    }
    .page-ttl .en.lo2{
        margin-bottom: 10px;
    }
    .page-ttl .en.lo2 img{
        width: auto;
        height: 10.5vw;
    }
    .page-ttl .ja{
        margin-left: 3vw;
    }
}
@media  screen and (max-width:910px){
    .page-sub-nav.x4 li{
        width: 48%;
        margin-right: 2%;
        margin-bottom: 8px;
    }

}
@media  screen and (max-width:640px){

    .page-ttl .en{
        min-height: 34px;
    }
    .page-ttl .en img{
        width: auto;
        height: 27px;
    }
    .page-ttl .en.des img{
        width: auto;
        height: 34px;
    }
    .page-ttl .en.lo2 img{
        width: auto;
        height: 55px;
    }

    .page-ttl .ja{
        font-size: 14px;
    }

    .page-sub-nav{
        margin-top: 20px;
    }
    .page-sub-nav li{
        width: 48%;
        margin-right: 2%;
        margin-bottom: 8px;
    }
    .page-sub-nav .btn a{
        width: 100%;
        height: 30px;
        background-image: url(img/common/btn_ya.png);
    }
    .page-sub-nav.x4 li{
        width: 100%;
        max-width: 260px;
        margin-right: 0;
    }


}
























/* 共通
-------------------------------*/
.w1200{
    width: 90%;
    max-width: 1200px;
    margin: auto;
}
.w1000{
    width: 90%;
    max-width: 1000px;
    margin: auto;
}
.w900{
    width: 90%;
    max-width: 1000px;
    margin: auto;
}


.ttl01{
    margin-bottom: 50px;
}
.ttl01 .ja{
    font-size: 29px;
    line-height: 1.2em;
    color: #0861d6;
    padding-bottom: 35px;
    position: relative;
}
.ttl01 .ja:after{
    position: absolute;
    left: 0;
    bottom:15px;
    width: 20px;
    height: 2px;
    background-color: #cecece;
    content: "";
}
.ttl01 .en{
    line-height: 1em;
}
.ttl01 .en img{
    vertical-align: middle;
}



@media  screen and (max-width:910px){
}
@media  screen and (max-width:640px){
    .ttl01{
        margin-bottom: 30px;
    }
    .ttl01 .ja{
        font-size: 20px;
        line-height: 1.2em;
        padding-bottom: 20px;
    }
    .ttl01 .ja:after{
        bottom: 10px;
    }


}

















/* お問い合わせ
-------------------------------*/

.toi01{
    margin-bottom: 150px;
}
.mailform{
    width: 100%;
    margin-top: 50px;
    margin-bottom: 50px;
    border-collapse: separate;
    border-spacing: 20px 20px; /* 左右、上下 */
}

.mailform th{
    width: 160px;
    color: #0861d6;
}
.mailform td.his{
    width: 35px;
}
.mailform td{
    width: calc(100% - 125px);
}
.mailform td.his span{
    background-color:#0861d6;
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    padding: 1px 4px 2px;
}

.mailform td span.wpcf7-list-item {
    margin-top:5px;
    display: block;
}

.va-top{
    vertical-align: top;
}
.length_l{
    width: 100%;
    padding: 10px;
    background-color: #fff;
    border: solid 1px #dadada;
    border-radius: 3px;
}
.length_m{
    width: 50%;
    padding: 10px;
    background-color: #fff;
    border: solid 1px #dadada;
    border-radius: 3px;
}
.naiyou{
    width: 100%;
    height: 250px;
    padding: 10px;
    background-color: #fff;
    border: solid 1px #dadada;
    border-radius: 3px;
    resize: vertical;
}
.toi_txt2 p{
    margin-bottom: 30px;
}
.toi_txt2 a{
    color: #0861d6;
    font-weight: 700;
}


.toi_sousin_1{
    margin: 80px auto 0;
    text-align: center;
    width: 260px;
    height: 56px;
    position: relative;
}
.toi_sousin_1 .btn{
    position: absolute;
    left: 0;
    top: 0;
    z-index: -1;
}
.toi_sousin_1 .btn a{
    background-color: #fff;
    color: #0861d6;

}
.toi_sousin_1:hover .btn a .btn-txt-in {
    -webkit-animation: hover_txt_link 0.5s linear forwards;
    animation: hov_txt_link 0.5s linear forwards;
}
.btn_sousin_1{
    background-color: transparent;
    width:260px;
    height:56px;
    border:0px solid;
    cursor:pointer;
}

.toi_sousin{
    margin-top: 80px;
    text-align: center;
}
.toi_sousin a{
    display: inline-block;
    padding: 10px;
}
.btn_sousin{
    background:url(img/common/btn_sousin.png);
    width:260px;
    height:56px;
    border:0px solid;
    cursor:pointer;
}
.btn_sousin_back{
    background:url(img/common/btn_back.png);
    width:260px;
    height:56px;
    border:0px solid;
    cursor:pointer;
}



@media  screen and (max-width:910px){
    .mailform{
        margin-top: 10px;
        margin-bottom: 10px;
        border-spacing: 0 20px; /* 左右、上下 */
    }
    .mailform th{
        display: inline-block;
        width: auto;
        margin-right: 20px;
    }
    .mailform td.his{
        display: inline-block;
        width: 35px;
        padding: 0;
    }
    .mailform td{
        display: inline-block;
        width: 100%;
        padding-top: 5px;
    }
    .va-top{
        vertical-align:middle;
    }
    .toi_txt2 p{
        margin-bottom: 20px;
    }
    .toi_sousin{
        margin-top: 40px;
    }
    .btn_sousin_1,
    .btn_sousin{
        background:url(../img/common/btn_sousin.png);
        width:260px;
        height:56px;
        border:0px solid;
        cursor:pointer;
    }
    .toi_sousin_1 .btn{
        display: none;
    }

}
@media  screen and (max-width:640px){
    .toi01{
        margin-bottom: 80px;
    }
}



.toi02 section{
    width: 100%;
    margin-bottom: 60px;
}
.toi02_ttl{
    background-color: #323232;
    border-radius: 3px;
    color: #fff;
    padding: 10px 30px;
    margin-bottom: 25px;
}
.toi02_cont{
    width: 100%;
    padding: 0 30px;
    align-items: center;
}
.toi02_cont dt{
    width: 180px;
    height: 140px;
    border: solid 1px #808080;
    border-radius: 3px;
    padding-top: 20px;
    padding-left: 20px;
    color: #808080;
    font-weight: 700;
}
.toi02_cont dd{
    width: calc(100% - 230px);
}
.toi02_cont dd .tel{
    margin-bottom: 20px;
}
.toi02_cont dd .tel img{
    width: auto;
    height: 32px;
}
.toi02_cont dd .fax img{
    vertical-align: middle;
}

.toi02_txt{
    padding-left: 30px;
}
.toi_waku{
    width: 100%;
    overflow: auto;
}

.toi02_list{
    width: 100%;
    max-width: 800px;
    min-width: 620px;
    margin: 40px auto;
    font-size: 15px;
    line-height: 1.5em;
}
.toi02_list tbody{
    border-left:solid 2px #4d4d4d;
    border-top: solid 2px #4d4d4d;
}
.toi02_list td{
    padding: 10px 15px;
    border-right: solid 1px #fff;
}
.toi02_list td:empty{
    padding: 0;
    border-right: none;

}
.toi02_list tr:nth-child(even){
    background-color: #ebebeb;
}

.toi02_list td:nth-last-child(1),
.toi02_list td:nth-last-child(2){
    text-align: center;
}
.toi02_list td.bg1{
    background-color: #4d4d4d;
    color: #fff;
    vertical-align: top;
}
.toi02_list td.bg2{
    background-color: #808080;
    color: #fff;
    border-bottom: solid 1px #fff;
    vertical-align: top;
}
.toi02_list tr.l-bk td,
.toi02_list td.bg1.l-bk,
.toi02_list td.bg2.l-bk{
    border-bottom:solid 2px #4d4d4d;
}




@media  screen and (max-width:910px){

    .toi02_cont{
        padding: 0;
    }
    .toi02_cont dt{
        width: 140px;
        padding-left: 15px;
    }
    .toi02_cont dd{
        width: calc(100% - 160px);
    }
    .toi02_txt{
        padding-left: 0;
    }





}
@media  screen and (max-width:640px){


    .toi02 section{
        margin-bottom: 40px;
    }
    .toi02_ttl{
        padding: 10px 15px;
        margin-bottom: 10px;
    }
    .toi02_cont dt{
        display: inline-block;
        width: auto;
        height: auto;
        padding: 5px 15px;
        margin-bottom: 10px;
    }
    .toi02_cont dd{
        width: 100%;
    }
    .toi02_cont dd .tel{
        margin-bottom: 10px;
    }
    
    .toi02_list{
        margin-top: 20px;
        margin-bottom: 20px;
    }
    .toi02_list td{
        padding: 10px;
    }



}

@media  screen and (max-width:500px){
    
    .toi02_cont dd .tel img{
        width: auto;
        height: 6.4vw;
    }

}


























/* プライバシーポリシー
-------------------------------*/
.pri01{
    margin-bottom: 130px;
    font-size: 15px;
    line-height: 1.8em;
}
.pri_list dt{
    font-size: 18px;
    line-height: 1.6em;
    font-weight: 700;
    color: #0861d6;
    margin-bottom: 5px;
}
.pri_list dd{
    margin-bottom: 30px;
}
.pri_date{
    text-align: right;
    margin-top: 80px;
}
.pri02_ttl{
    width: 100%;
    height: 80px;
    background-color: #3981de;
    border-radius: 10px 10px 0 0;
    padding: 0 50px;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    font-size: 18px;
    line-height: 1.6em;
    font-weight: 700;
    color: #fff;
}
.pri02_box{
    width: 100%;
    background-color: #0861d6;
    border-radius: 0 0 10px 10px;
    padding: 50px;
    font-size: 14px;
    line-height: 1.8em;
    color: #fff;
}
.pri02_box .txt{
    width: 55%;
    border-right: solid 1px #fff;
}
.pri02_box .txt br.sp{
    display: none;
}
.pri02_box .toi{
    width: 37%;
}
.pri02_box .toi .btn{
    margin-top: 10px;
}
.pri02_box .toi .btn a{
    margin-left: 0;
}

@media  screen and (max-width:910px){
    .pri02_box .txt{
        width: 100%;
        border-right: none;
        margin-bottom: 40px;
    }
    .pri02_box .toi{
        width: 100%;
    }
}
@media  screen and (max-width:640px){

    .pri01{
        margin-bottom: 80px;
    }
    .pri_list dt{
        font-size: 16px;
        line-height: 1.6em;
    }
    .pri_list dd{
        margin-bottom: 20px;
    }
    .pri_date{
        margin-top: 40px;
    }
    .pri02_ttl{
        display: block;
        height: auto;
        padding: 20px;
        font-size: 16px;
        line-height: 1.6em;
        text-align: center;
    }
    .pri02_box{
        padding: 30px;
    }
    .pri02_box .txt{
        margin-bottom: 20px;
    }
    .pri02_box .txt br.sp{
        display: inline-block;
    }

}



















/* layout */
.clear { clear: both; }
.ar { text-align: right; }
.ac { text-align: center; }

@media print{
    #wrapper{
        width:1110px;
        margin:auto;
    }
}






