/* sub-page common/sidebar
------------------------------------------------------*/

#cont-wrapper{
    max-width: 1000px;
    width: 95%;
    margin: 0 auto;
    padding: 50px;
    position: relative;
    margin-top: 20px;
    border: 1px solid #ccc;
    box-sizing: border-box;
}

#contents{
    width: 100%;
    /* float: left; */
    margin: 0;
    /* margin-bottom: 50px; */
}

#sidebar {
  width: 100%;
/* float: right; */
    margin: 0;
    display: flex;
    justify-content: space-between;
}

.sidebnr{
    width: 30%;
    margin: 0;
    text-align: center;
    margin-bottom: 10px;
}

.sidebnr img{
    width: 100%;
    margin: 0 0 10px;
}

.sidebnr02{
    width: 100%;
    margin: 0;
    text-align: center;
    /* margin-bottom: 10px; */
}

.sidebnr02 img{
    width: 49%;
}

/* sub-page content common
------------------------------------------------------*/
.breadcrumb{
    max-width: 1000px;
    width: 100%;
    margin: 0 auto;
    margin-top: 170px;
    font-size: 14px;
}

/* sub-page head高さ res
------------------------------------------------------*/
@media only screen and (max-width: 900px) {
  .breadcrumb{
      margin-top: 150px;
  }
}
@media only screen and (max-width: 760px) {
  .breadcrumb{
      margin-top: 130px;
  }
}
@media only screen and (max-width: 640px) {
  .breadcrumb{
      margin-top: 190px;
  }
}
@media only screen and (max-width: 500px) {
  .breadcrumb{
      margin-top: 180px;
  }
}
@media only screen and (max-width: 375px) {
  .breadcrumb{
      margin-top: 140px;
  }
}
/*---------*/

.breadcrumb li{
       display: inline-block;
}

.breadcrumb li a{
    text-decoration: none;
    color: #666;
}

.breadcrumb li a:hover{
    color: #18BA60;
}

.herelink{
    border-bottom: 1px solid #18BA60;
    color: #18BA60;
}

h1{
    margin-bottom: 20px;
}

article{
    width: 90%;
    margin: 0 auto;
    margin-bottom: 20px;
}

.cont-dis{
    width: 100%;
    margin: 0 auto;
}

.cont-dis img{
    width: 50%;
}

.cont-dis02{
    display: inline-block;
    width: 48%;
    margin: 0;
    padding: 0;
    text-align: center;
    vertical-align: top;
    margin-left: 1%;
}

.cont-dis02 img{
    width: 60%;
    margin: 0 auto;
}

.cont-dis03{
    display: inline-block;
    width: 100%;
    margin: 0 auto;
    padding: 0;
    text-align: center;
    vertical-align: top;
    margin-left: 0;

}

.cont-dis03 img{
    width: 35%;
}
.w20p img {
  width: 20%;
}

.cont-dis04{
    display: block;
    width: 100%;
    margin: 0;
    padding: 0 0 20px;
    text-align: center;
    vertical-align: top;
    margin-left: 0;
    border-bottom: 1px solid #ccc;
}
.cont-dis04_head {
  display: flex;
	align-items: center;
  font-weight: bold;
  letter-spacing: 1em;
  font-size: 18px;
}
.cont-dis04_head::after{
  content: "";
	flex-grow: 1;
	height: 1px;
	background: #ccc;
	display: block;
}

.cont-dis05{
    display: inline-block;
    width: 50%;
    margin: 0;
    margin-right: 2%;
    margin-left: 16%;
    padding: 0;
    vertical-align: bottom;
    margin-bottom: 30px;
}

.cont-dis05 p{
    text-align: left;
}

.cont-dis06{
    display: inline-block;
    width: 28%;
    margin: 0;
    padding: 0;
    text-align: center;
    margin-left: 1%;

}

.cont-dis06 img{
    width: 100%;
}


.cont-dis02 ul{
    width: 85%;
    margin: 0 auto;
    text-align: left;
    margin-top: 10px;
    font-size: 12px;
    line-height: 25px;
    margin-left: 15%;
}
.cont-dis04 ul{
    width: 100%;
    margin: 0 auto;
    text-align: left;
    margin-top: 10px;
    font-size: 12px;
    line-height: 2.5;
    margin-left: 0;

}

.cont-dis02 ul li a{
    text-decoration: none;
    color: #666;
}
.cont-dis04 ul li a {
  text-decoration: none;
  color: #2D7DD2;
  font-size: 18px;
}

.cont-dis02 ul li a:hover{
    border-bottom: 1px solid #666;
}

.cont-dis04 ul li a:hover {
  border-bottom: 1px solid #2D7DD2;
}

#contents article p{
    font-size: 16px !important;
    line-height: 32px !important;
    letter-spacing: 50%;
    margin-bottom: 30px;
    text-align: justify;
}

article img{
    display: block;
    width: 35%;
    margin: 0 auto;
    margin-top: 10px;
    margin-bottom: 30px;
}

.toc {
  margin: 0 0 50px;
  width: 95%;

}

#privacy-p,
#strength,
#greeting,
#souzoku01,
#souzoku02,
#souzoku03,
#souzoku04,
#souzoku05,
#souzoku06,
#shintaku01,
#shintaku02,
#shintaku03,
#shintaku04,
#shintaku05{
    padding-top: 140px;
    margin-top: -140px;
}

.yoyaku{
    display: block;
    margin: 0 auto;
    width: 60%;
    font-size: 18px;
    background-color: #18BA60;
    border-radius: 30px;
    border: 1px solid #18BA60;
    line-height: 54px;
    color: #fff;
    text-decoration: none;
    text-align: center;
}

.yoyaku:hover{
    background-color: #fff;
    color: #18BA60;
}

.tel-cont{
    width: 40%;
    margin: 0 auto;
    text-align: center;
    margin-top: 50px;
}

.tel-cont a img{
    width: 100%;
}


.tel-cont p{
    font-size: 13px;
    text-align: right;
    margin: 0;
}


.pcenter{
    text-align: center !important;
}

.mbottom img{
    margin-bottom: 0;
}

.pict-wrapper{
        width: 100%;
        text-align: center;
        margin: 0 auto;
    }
.pict-wrapper85{
        width: 85%;
        text-align: center;
        margin: 0 auto;
    }

.pict-wrapper80{
        width: 80%;
        text-align: center;
        margin: 0 auto;
    }


.pict-wrapper .pictfull,
.pict-wrapper85 .pictfull,
.pict-wrapper80 .pictfull{
    width: 70%;
    margin-top: 50px;
}

.pict-wrapper .pictfull2,
.pict-wrapper85 .pictfull2,
.pict-wrapper80 .pictfull2{
    width: 100%;
    margin-top: 25px;
    margin-bottom: 25px;
}


.textred{
    color: #e60000;
}

.marg-top{
    margin-top: 50px;
    margin-bottom: 0;
}

.marg-left{
    margin: 0;
    margin-left: 30px;
    margin-bottom: 5px;
}

.texbig{
    font-size: 17px;
    font-weight: bold;
}

.br-dis{
    display: none;
}


/* sub-page sidebar responsive
------------------------------------------------------*/
@media only screen and (max-width: 1020px) {

    #contents{
        width: 95%;
        margin: 0 auto 50px;
        /* margin-left: 1%; */
    }

    #sidebar{
        width: 95%;
        margin: 0 auto;
        margin-right: 1%;
    }

}
@media only screen and (max-width: 760px) {

    #contents{
        width: 100%;
        margin: 0 auto 50px;
    }

    #sidebar{
        width: 100%;
        margin: 0 auto;
        display: block;
    }

    .sidebnr{
        width: 90%;
        margin: 0 auto;
        margin-top: 10px;
    }

    .sidebnr02{
    width: 90%;
    margin: 0 auto;
    margin-top: 10px;
    }

    #twit-news{
        width: 100%;
        margin: 0 auto;
        margin-bottom: 20px;
    }

    h2{
        width: 90%;
        margin: 0 auto;
        margin-bottom: 50px;
        margin-top: 50px;
    }

    .pict-wrapper .pictfull{
        width: 95%;
        margin-top: 30px;
    }


    table.souzoku-t01{
        display: none;
    }

    .cont-dis04_head {
      font-size: 16px;
    }
     .cont-dis04 ul li a {
      font-size: 16px;
    }
    .toc {
      margin: 30px auto;
      width: 95%;
    }
}



/* flow
------------------------------------------------------*/

.flow p{
    width: 80%;
    margin: 0 auto;
    margin-top: 20px;
}

.orange-maru{
    width: 80%;
    margin: 0 auto;
    margin-top: 20px;
    margin-bottom: 20px;
    background-color: #F77C5B;
    border-radius: 20px;
    color: #fff;
    font-size: 16px;
    letter-spacing: 2px;
    line-height: 45px;
    text-align: center;
}

.red-bigtext{
    font-size: 38px;
    color: #EE4443;
    text-decoration: none;
    text-align: center;
    display: block;
    margin: 0 auto;
}

.arrow{
    width: 50%;
    margin: 0 auto;
    margin-top: 30px;
    text-align: center;
}

.arrow img{
    width: 15%;
}

a.text-blue{
    border-bottom: 1px solid #fff;
    font-size: 13px;
    color: #2D7DD2;
    text-decoration: none;
    margin: 0 auto;
}

a.text-blue:hover{
    border-bottom: 1px solid #2D7DD2;
}

.texright{
    text-align: right !important;
}

.text-13p{
    font-size: 13px;
}

hr.kugiri{
    color:
}


/* oyagokoro
------------------------------------------------------*/

.box-wrapper{
    width: 100%;
    margin: 0 auto;
}

.line-box{
    width: 49%;
    margin: 0;
    display: inline-block;
}

.line-box img{
    width: 95%;
}

.line-box p{
    width: 96%;
    margin: 0 auto;
    font-size: 11px;
}

/* access
------------------------------------------------------*/

.map{
    width: 85%;
    margin: 0 auto;
    margin-bottom: 50px;
}

.map p{
    font-size: 12px;
    text-align: left;
    line-height: 16px;
    margin-top: 0;
}


.access-wrapper{
    width: 100%;
    margin: 0;
    padding: 0;
}

.acc-box01{
    display: inline-block;
    width: 45%;
    margin: 0;
    padding: 0;
}
.acc-box02{
    display: inline-block;
    width: 50%;
    margin: 0;
    padding: 0;
    vertical-align: bottom;
}

.acc-box02{
    text-align: center;
}

.acc-box02 img{
    width: 98%;
}

/* contact
------------------------------------------------------*/

#mailformpro{
    width: 90%;
    margin: 0 auto;
}

.contact-add{
    padding-left: 40px;
}

.contact-left{
    font-size: 12px;
    text-align: left;
    margin: 0;
}





/* trouble
------------------------------------------------------*/

dl.check-t,
dl.check-t dt,
dl.check-t dd {
      box-sizing: border-box;
    letter-spacing: 1px;
}

dl.check-t {
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
  border-left: 1px solid #fff;
}

dl.check-t dt,
dl.check-t dd {
  padding: 10px 10px 0 10px;
  border-top: 1px solid #fff;
  font-size: 12px;
}

dl.check-t dt {
  width: 40%;
  float: left;
  padding-bottom: 10px;
}
dl.check-t dd {
  margin-left: 40%;
  border-left: 1px solid #fff;
  padding-bottom: 10px;
}
dl.check-t dd:after {
  content: '';
  display: block;
  clear: both;
}


.check-mark:before{
  content: '';/*何も入れない*/
  display: inline-block;/*忘れずに！*/
  width: 15px;/*画像の幅*/
  height: 15px;/*画像の高さ*/
  background-image: url("../trouble/images/check-mark.png");
  background-size: contain;
  vertical-align: middle;
  background-repeat: no-repeat;
  padding-right: 5px;
}

.check-mark02:before{
  content: '';/*何も入れない*/
  display: inline-block;/*忘れずに！*/
  width: 15px;/*画像の幅*/
  height: 15px;/*画像の高さ*/
  background-image: url("../trouble/images/check-mark02.png");
  background-size: contain;
  vertical-align: middle;
  background-repeat: no-repeat;
  padding-right: 5px;
}

dl.check-t dt.check-title,
dl.check-t dd.check-title {
    color: #fff;
    background-color: #F77C5B;
    font-size: 14px;
    text-align: center;
}

dl.check-t dd.check-title{
    padding-bottom: 0px;
}

.check-t hr{
    margin: 0;
    background-color: #fff;
	border-top: 1px dotted #666;

}

.cont-lefttex{
    display: inline-block;
    width: 60%;
    margin: 0;
    padding: 0;
    text-align: left;
    vertical-align: top;
    margin-left: 1%;

}

.cont-lefttex02{
    display: inline-block;
    width: 50%;
    margin: 0;
    padding: 0;
    text-align: center;
    vertical-align: top;
    margin-left: 1%;

}

.cont-lefttex img,
.cont-righttex img{
    width: 90%;
    margin: 0 auto
}

.cont-lefttex02 img,
.cont-righttex02 img{
    width: 100%;
}

.cont-lefttex p,
.cont-righttex p,
.cont-lefttex02 p,
.cont-righttex02 p{
    margin: 0 !important;
}

.cont-righttex{
    display: inline-block;
    width: 38%;
    margin: 0;
    padding: 0;
    text-align: center;
    vertical-align: top;
}

.cont-righttex02{
    display: inline-block;
    width: 48%;
    margin: 0;
    padding: 0;
    text-align: center;
    vertical-align: top;
}



table.souzoku-t01,
table.souzoku-t01 th,
table.souzoku-t01 td {
    border-collapse: collapse;
    border: 1px solid #ccc;
    line-height: 1.5;
}

table.souzoku-t01 th {
    width: 13%;
    padding: 5px;
    font-size: 13px;
    font-weight: bold;
    vertical-align: top;
    background: #e6f2ff;
    color: #666;
}
table.souzoku-t01 td {
    width: 29%;
    padding: 8px;
    vertical-align: top;
    font-size: 13px;
}

.table-top{
    background-color: #80bfff !important;
    color: #fff !important;
}

.souzoku-t01 ol{
    list-style-type: decimal;
    list-style-position: inside;
}

.souzoku-t01 ol li{
      padding-left: 1em;
      text-indent: -1em;
}

.cont-dis ul{
    list-style-position: inside;
    text-align: left;
}

.cont-dis ul li{
      padding-left: 1em;
      text-indent: -1em;
    line-height: 2.5;
    font-size: 15px;
}


table.souzoku-t02,
table.souzoku-t02 th,
table.souzoku-t02 td {
    border-collapse: collapse;
    border: 1px solid #ccc;
    line-height: 1.5;
}

table.souzoku-t02 th {
    width: 50%;
    padding: 10px;
    font-size: 14px;
    vertical-align: top;
    background: #e6f2ff;
    color: #666;
    text-align: center;
}
table.souzoku-t02 td {
    width: 50%;
    padding: 8px;
    vertical-align: top;
    font-size: 14px;
    text-align: right;
}


.kugiri {
    display: flex;
    align-items: center;
    margin-top: 30px;
}

.kugiri:before,
.kugiri:after {
    border-top: 1px solid;
    content: "";
    flex-grow: 1;
}

.kugiri:before {
    margin-right: 1rem;
}

.kugiri:after {
    margin-left: 1rem;
}

.resp-souzoku04{
    display: none;
    font-size: 13px;
}


.facebook-wrapper {
    max-width: 760px;
    margin: 0 auto;
}
.facebook-wrapper > .fb-page {
    width: 100%;
}
.facebook-wrapper > .fb-page > span,
.facebook-wrapper iframe {
    width: 100% !important;
}

/* Shintaku
------------------------------------------------------*/

table.shintaku-t,
table.shintaku-t th,
table.shintaku-t td {
    border-collapse: collapse;
    border: 1px solid #fff;
    line-height: 1.5;
    font-weight: normal;
    color: #000;
}

.shintaku-t .table-top{
    background: #1a8cff !important;
}

table.shintaku-t th {
    width: 15%;
    padding: 10px;
    font-size: 14px;
    vertical-align: top;
    text-align: center;
}
table.shintaku-t td {
    width: 27%;
    padding: 8px;
    vertical-align: top;
    font-size: 14px;
    text-align: left;
}

table.shintaku-t .td-odd-b,
table.shintaku-t .th-odd-b{
    background: #99caff;
    color: #000;
}

table.shintaku-t .td-even-b,
table.shintaku-t .th-even-b{
    background: #e6f2ff;
    color: #000;
}

.resp-shintaku05{
    display: none;
}

table.shintaku-t02,
table.shintaku-t02 th,
table.shintaku-t02 td {
    border-collapse: collapse;
    line-height: 1.5;
    font-weight: normal;
}

table.shintaku-t02 th {
    width: 33.33%;
    padding: 10px;
    font-size: 14px;
    vertical-align: top;
    color: #fff;
    text-align: center;
}
table.shintaku-t02 td {
    padding: 8px;
    vertical-align: top;
    font-size: 14px;
    text-align: left;
    color: #000;
}

table.shintaku-t02 .ts-title{
    padding: 3px;
    font-size: 13px;
    background-color: #e6f2ff;
    color: #666;
}

.tb-orange{
    background: #F47C5A !important;
    color: #fff !important;
}

.tb-orange-p{
    background: #F6D1CB !important;
}

.tb-green{
    background: #29B45E !important;
    color: #fff !important;
}

.tb-green-p{
    background: #CDE8D3 !important;
}

.tb-blue{
    background: #4A68B1 !important;
    color: #fff !important;
}

.tb-blue-p{
    background: #CCD7EE !important;
}

.b-odd{
    background: rgb(204, 215, 238, 0.5) !important;
}

.o-odd{
    background: rgb(246, 209, 203, 0.5) !important;
}

.g-odd{
    background: rgb(205, 232, 211, 0.5) !important;
}

.tb-odd{
    background: #e6f2ff !important;
}

.tb-even{
    background: #b3d7ff !important;
}

.img-resp{
    display: none;
}
/* sub-page contents responsive
------------------------------------------------------*/

@media only screen and (max-width: 760px) {

  #cont-wrapper{
      padding: 1%;
  }

    .orange-maru{
        width: 90%;
        margin: 0 auto;
        margin-top: 20px;
        margin-bottom: 20px;
        background-color: #F77C5B;
        border-radius: 20px;
        color: #fff;
        font-size: 14px;
        letter-spacing: 1px;
        line-height: 45px;
        text-align: center;
    }

    .flow p{
        width: 90%;
        margin: 0 auto;
        margin-top: 20px;
    }

    .yoyaku{
        width: 80%;
    }

    .map{
        width: 95%;
    }

    .cont-dis03,
    .cont-dis04{
        width: 100%;
    }

    .cont-dis03 img{
        width: 50%
    }

    article p{
        font-size: 14px;
        line-height: 26px;
    }

    .cont-lefttex,
    .cont-righttex,
    .cont-lefttex02,
    .cont-righttex02{
        width: 100%;
    }

    .cont-lefttex p{
        margin-bottom: 20px;
    }

    .resp-souzoku04{
        display: block;
        font-size: 13px;
    }

    .cont-dis05{
    display: inline-block;
    width: 60%;
    margin: 0;
    margin-right: 2%;
    margin-left: 6%;
    padding: 0;
    vertical-align: bottom;
    margin-bottom: 30px;
    }

    .cont-dis05 p{
        text-align: left;
    }

    .br-dis{
    display: inline-block;
    }

    .acc-box01,
    .acc-box02{
        width: 100%;
    }

    .acc-box02 img{
        width: 100%;
    }

    .t-disp{
        display: none;
    }

    .resp-shintaku05{
        display: block;
        width: 95%;
        margin: 0 auto;
    }

    .img-resp{
        display: block;
    }

    .img-disp{
        display: none;
    }

    table.shintaku-t{
        width: 95%;
        margin: 0 auto;
    }


}
