html{
  box-sizing: border-box;
  height: 100%;
  font-size: medium;
  font-family: "ヒラギノ丸ゴ Pro W4","ヒラギノ丸ゴ Pro","Hiragino Maru Gothic Pro","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","HG丸ｺﾞｼｯｸM-PRO","HGMaruGothicMPRO";
  letter-spacing: .05em;
  word-break: break-all;
}
p, a{
  color: #333;
    line-height: 1.5em;
}
a{
  cursor: pointer;
  text-decoration: none;
}
a:hover{
  opacity: 0.8;
}

img{
    max-width: 100%;
}

*, *:before, *:after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}


.clearfix:after {  
  display: block;
  clear: both;
  content: "";
}  
  
.clear{
	clear:both;
	height:0;
}

/* header */

.header-topline{
    width:100%;
    height:8px;
    background-color: #ff0000;
    margin-bottom: 20px;
}

.header_sp{
  display: none;
}
.header_contents{
  display: flex;
}
.header_logo{
  
}
.header_logo img{
  margin-left: 115px;
    margin-bottom: 10px;
}

.header-contactwrap{
    position: absolute;
    right: 115px;
    top:30px;
    margin-bottom: -10px;
}

.header-contact a{
    display: block;
    width: 100%;
    text-align: center;
    background: #fff;
    border: 2px solid #3850cc;
    border-radius: 5px;
    padding: 5px 0;
    margin-bottom: 5px;
    font-size: 1.3em;
}
.header-contact i{
    color:#3850cc;
}

.orange{
    color:#990000;
}

.header-tel{
    font-size: 1.5em;
}

.header-accesswrap{
    position: absolute;
    right: 350px;
    top: 30px;
}
.header-access{
    font-size: 1.5em;
    line-height: 24px;
    border-bottom: 1px dashed rgb(238, 120, 0);
    padding: 0 0 10px;
    margin-bottom: 10px;
}


.header_link{
  background-color: #990000;
}
header ul{
  font-family:'Hiragino Maru Gothic Pro',Hiragino Kaku Gothic Pro', 'Meiryo', sans-serif;
  text-transform: uppercase;
  display: flex;
  justify-content: space-between;
  width: 700px;
  margin: 0px auto;
}
header ul a {
  color: #fff;
  font-size: 15px;
  padding: 11px 27px 11px 0px;
  display: inline-block;
  text-decoration: none;
}
.header_button{
  text-align: right;
  margin: 20px 76px 0 0;
  width: 200px;
}
.header_button a:first-of-type img{
  margin-bottom: 14px;
}

/* footer */


.footer-info-wrap{
    max-width: 900px;
    margin: 50px auto;
    padding:0;
    display:-webkit-box;
    display:-moz-box;
    display:-ms-box;
    display:-webkit-flexbox;
    display:-moz-flexbox;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:-ms-flex;
    display:flex;
    -webkit-box-lines:multiple;
    -moz-box-lines:multiple;
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    -ms-flex-wrap:wrap;
    flex-wrap:wrap;
}

.footer-info{
    width: 50%;
    padding-bottom: 20px;
}

.padding-left{
    padding-left: 20px;
}

.footer-address{
    font-size: 1.2em;
    padding: 10px 0 20px;
}

.footer-table{
    width:100%;
    margin-bottom: 10px;
    font-size: 0.85em;
}

.footer-table th{
    background-color: #990000;
    color:#fff;
    font-weight: 400;
    padding: 5px;
    text-align: center;
    border: 1px solid #cac8c8;
    vertical-align: middle;
}

.footer-table td{
    font-weight: 400;
    padding: 5px;
    text-align: center;
    border: 1px solid #cac8c8;
    vertical-align: middle;
}

.fontsize-small{
    font-size: 11px;
}

.valign-middle{
    height: 100%;
    padding: 30px 0;
}

.footer-tel{
    font-size: 28px;
}






footer{
  background-color: #990000;
}
footer div:first-of-type{
  border-bottom: 1px solid #fff;
}
footer ul{
  display: flex;
  justify-content: space-between;
  width: 750px;
  margin: 0px auto;
  height: 56px;
}
footer ul li{
  padding: 16px 0;
}
footer a{
  color: #fff;
  padding: 16px 18px;
}
footer p{
  text-align: center;
  color: #fff;
  padding: 20px 0 10px;
}

/* common */
.sp-mode{
  display: none;
}
.tc{
  text-align: center;
}

/* index */
#index{
}
.index_mv{
  position: relative;
    width:100%
}
.index_mv:before{
      content: "";
  display: block;
  padding-top: 40.4%;
}

.index_mv_contents{
    position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
        background:url("../images/top-mainbg1.jpg") no-repeat;
    background-size: cover;
}


.index_mv_textbox{
  position: absolute;
  top: 50%;
  left: 20%;
 height:100%;
  -ms-transform: translate(-50%,-50%);
  -webkit-transform: translate(-50%,-50%);
  transform: translate(-50%,-50%);

  /*以下装飾*/
  margin:0;/*余計な隙間を除く*/
  font-size: 20px;/*文字サイズ*/
  padding: 0 30px;/*文字と線の間の余白*/
  color: white;/*文字色*/
    background:rgba(42, 68, 99, 0.8); 
    display: table;
}
.index_mv_text{
     display:table-cell;
    vertical-align: middle;   
    height: 100%;
}

.index_mv_text h1{
   font-size: 1.3em;
    padding-bottom: 20px;
	font-family:'Hiragino Maru Gothic Pro',Hiragino Kaku Gothic Pro', 'Meiryo', sans-serif;
    width: 100%; /* 幅を最大にして、コンテナいっぱいに広げる */
}

.index_mv_text p{
    color: #fff;
    font-size: 0.8em;
    line-height: 1.0em;
	text-align: center;
	font-family:'Hiragino Maru Gothic Pro',Hiragino Kaku Gothic Pro', 'Meiryo', sans-serif;
		
}

.big-letter{
    font-size: 1.5em;
	text-align: center;
	font-family:'Hiragino Maru Gothic Pro',Hiragino Kaku Gothic Pro', 'Meiryo', sans-serif;
}

.index_mv img{
    width:100%;
}



h2.section_title{
    text-align: center;
    padding: 50px 0;
}

.top-needs-wrap{
    max-width:1062px;
    margin: 0 auto 100px;
    padding:0;
    display:-webkit-box;
    display:-moz-box;
    display:-ms-box;
    display:-webkit-flexbox;
    display:-moz-flexbox;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:-ms-flex;
    display:flex;
    -webkit-box-lines:multiple;
    -moz-box-lines:multiple;
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    -ms-flex-wrap:wrap;
    flex-wrap:wrap;
}

.top-needs{
    width:33.3333%;
    padding: 0 30px;
}

.top-needs p{
    padding: 10px;
      font-family: "ヒラギノ丸ゴ Pro W4","ヒラギノ丸ゴ Pro","Hiragino Maru Gothic Pro","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","HG丸ｺﾞｼｯｸM-PRO","HGMaruGothicMPRO";
    line-height: 1.5em;
}


#top-concept{
    background-image: url(../images/top-conceptbg.jpg);
    background-size: cover;
    background-position: 50% 50%;
    padding-top: 0;
    padding-bottom: 0;
}

#top-concept .site {
    position: relative;
    padding-left: 450px;
    height: 386px;
    max-width: 1040px;
    margin: 0 auto;
}
.site {
    max-width: 1040px;
    margin: 0 auto;
    padding: 0 20px;
}

#top-concept header {
    
}

#top-concept h2 {
    text-align: right;
    padding-top: 60px;
    margin-right: 8px;
}

#top-concept figure {
    position: absolute;
    bottom: -2px;
    left: 65px;
}

#top-concept figure figcaption {
    position: absolute;
    bottom: 30px;
    left: -45px;
}

#top-concept figure figcaption p{
    padding: 0 0 0 100px;
    text-align: right;
}

#top-concept figure figcaption p.prof01{
    color:#333366;
    font-size: 24px;
}

#top-concept figure figcaption p.prof02{
    margin-top: 10px;
    font-size: 18px;
}

#top-concept figure figcaption p.prof03{
    font-size: 30px;
}

#top-concept figure figcaption p.prof04{
    font-size: 14px;
}


#top-concept p {
    line-height: 24px;
    padding: 20px 0;
    font-weight: 400;
}

#top-concept p.more {
    text-align: right;
}

a.btn {
    line-height: 44px;
    width: 230px;
    position: relative;
    display: inline-block;
    background-color: #ffffff;
    font-size: 16px;
    text-align: center;
    border: 2px solid #333333;
    border-radius: 10px;
}

.top-cases-wrap{
    max-width:816px;
    margin: 0 auto 100px;
    padding:0;
    display:-webkit-box;
    display:-moz-box;
    display:-ms-box;
    display:-webkit-flexbox;
    display:-moz-flexbox;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:-ms-flex;
    display:flex;
    -webkit-box-lines:multiple;
    -moz-box-lines:multiple;
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    -ms-flex-wrap:wrap;
    flex-wrap:wrap;
}

.top-cases{
    width:33.3333%;
    padding: 0 15px 30px;
}



#top-price{
  position: relative;
  background-image: url(../images/top-pricebg.jpg);
  background-size: cover;
  padding-top: 454px;
}
#top-price div.top-price{
  position: absolute;
  text-align: center;
  transform: translate(-50%,-50%);
  top: 50%;
  left: 50%;
  background-color: #fff;
  font-size: 24px;
  border-radius: 16px;
  width: 50%;
    border: 4px solid #ff9900;
}

.top-price-text{
    vertical-align: middle;   
    height: 100%;
    width: 100%;
    padding: 30px 100px;
    margin: 0 auto;
}


#top-price p{
    color: #333366;
    font-size: 24px;
    text-align: left;
}

#top-price p span{
    color: #ff9900;
    font-size: 30px;
    padding: 0 25px;
}

#top-price p.right{
    text-align: right;
    margin-top: 10px;
}




/* cases */


.cases-wrap{
    max-width:1080px;
    width: 90%;
    margin: 50px auto 100px;
    padding:0;
    display:-webkit-box;
    display:-moz-box;
    display:-ms-box;
    display:-webkit-flexbox;
    display:-moz-flexbox;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:-ms-flex;
    display:flex;
    -webkit-box-lines:multiple;
    -moz-box-lines:multiple;
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    -ms-flex-wrap:wrap;
    flex-wrap:wrap;
}

.cases-title{
    width:100%;
    padding: 0 0 30px;
    font-size: 24px;
}

.section-title2{
    border-bottom: 2px solid #333366;
    padding-bottom: 5px;
    color: #333366;
    font-size: 24px;
    margin-bottom: 20px;
}

.cases{
    width:33.3333%;
    padding: 0 15px 30px;
}


.case-img{
  position: relative;
}

.case_textbox{
  position: absolute;
  top: 50%;
  right: 10%;
 height:100%;
  -ms-transform: translate(-50%,-50%);
  -webkit-transform: translate(-50%,-50%);
  transform: translate(-50%,-50%);
  /*以下装飾*/
  margin:0;/*余計な隙間を除く*/
  font-size: 20px;/*文字サイズ*/
  padding: 0 30px;/*文字と線の間の余白*/
  color: white;/*文字色*/
    background-color:transparent; 
    display: table;
}
.case_text{
     display:table-cell;
    vertical-align: middle;   
    height: 100%;
}

.case_text p{
   font-size: 1.5em;
    text-align: right;
    line-height: 1.8em;
    color: #fff;
    text-shadow: 3px 3px 5px #000000;
}


.case-img img{
    width:100%;
}


.case-counseling{
    max-width: 950px;
    width: 90%;
    margin: 50px auto;
}


.case-counseling a{
     color: #338fdc;
    text-decoration: underline;
}


.case-counseling2{
  position: relative;
  background-image: url(../images/case-counselingbg.jpg);
  background-size: cover;
    background-position: center;
    width:100%;
    padding: 300px 0;
}
.case-counseling2 div.counseling{
  position: absolute;
  text-align: center;
  transform: translate(-50%,-50%);
  top: 50%;
  left: 50%;
  max-width: 800px;
    width:90%;
}

.counseling-box{
    background-color: #fff;
    padding: 50px 50px;
    text-align: left;
    margin-bottom: 50px;
}

.center{
    text-align: center;
}

a.btn2 {
    line-height: 60px;
    width: 230px;
    position: relative;
    display: inline-block;
    background-color: #fe9927;
    color:#fff;
    font-size: 16px;
    text-align: center;
    border-radius: 10px;
    box-shadow: 0 0px 10px 0 rgba(255, 255, 255, .8);
}

.padding-bottom50{
    padding-bottom: 50px;
}


/* concept */
.concept_pt{
  position: relative;
    width: 100%;
}

.concept_pt:before {
  content: "";
  display: block;
  padding-top: 19%;
}

.concept_pt_contents{
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
    background: url("../images/concept-titlebg .jpg") no-repeat;
    background-size: cover;
    background-position: center;
}

.concept_pt_textbox{
    position: absolute;
    top: 50%;
    left: 50%;
    height: 100%;
    -ms-transform: translate(-50%,-50%);
    -webkit-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%);
    margin: 0;
    padding: 0 30px;
    color: white;
    display: table;
}


.concept_pt_text{
      display: table-cell;
    vertical-align: middle;
    height: 100%;
}

.concept_pt_text h1{
   font-size: 1.5em;
    text-shadow: 5px 5px 10px #000;
    font-weight: 400;
    text-align: center;
    color: #fff;
    display: table-cell;
    vertical-align: middle;
}

.big-letter{
    font-size: 1.5em;
}

.concept_pt img{
    width:100%;
}

.float-left{
    float: left;
    padding-right: 5px;
}

.greeting-wrap{
    max-width: 900px;
    margin: 0 auto 100px;
    padding:0;
    display:-webkit-box;
    display:-moz-box;
    display:-ms-box;
    display:-webkit-flexbox;
    display:-moz-flexbox;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:-ms-flex;
    display:flex;
    -webkit-box-lines:multiple;
    -moz-box-lines:multiple;
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    -ms-flex-wrap:wrap;
    flex-wrap:wrap;
}

.greeting-wrap .greeting-img{
    width: 230px;
}

.greeting-wrap .greeting-img img{
    border: 1px solid #333;
    width: 100%;
}

.greeting-list{
    width: calc(100% - 232px);
    padding-left: 20px;
}

.greeting-wrap dl dt{
    float: left ;
    clear: left ;
    margin-right: 0.5em ;
    width: 60px ;
}

.greeting-wrap dl dd{
    float: left ;
    padding-bottom: 20px;
}

.concept-text{
    max-width: 950px;
    width: 90%;
    margin: 50px auto;
}


.concept-text p{
    padding-bottom: 30px;
}

.concept-text .img-box{
    width:100%;
    margin: 0 auto 30px;
    border-radius: 10px;
    border: 2px solid #333366;
    padding: 20px 5px;
    display:-webkit-box;
    display:-moz-box;
    display:-ms-box;
    display:-webkit-flexbox;
    display:-moz-flexbox;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:-ms-flex;
    display:flex;
    -webkit-box-lines:multiple;
    -moz-box-lines:multiple;
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    -ms-flex-wrap:wrap;
    flex-wrap:wrap;
}

.concept-text .img-box div.box-inner{
    width:50%;
    padding: 0 5px;
    display: table;
}

.concept-text .img-box div.box-inner .illust{
    display: table-cell;
    width: 116px;
    vertical-align: middle;
}

.concept-text .img-box div.box-inner .explanation{
    display: table-cell;
    vertical-align: middle;
}



.concept-text .img-box div.box-inner .explanation h4{
    color: #333366;
    font-size: 1.2em;
    padding-bottom: 10px;
}

.concept-text .img-box div.box-inner .explanation p{
    padding-bottom: 0;
}


.concept2{
    background: url("../images/soudan-bg.jpg") no-repeat;
    background-size:cover;
    background-position: center top;
    padding: 200px 0 50px;
    border-top:1px solid #e5e5e5;
    border-bottom:1px solid #e5e5e5;
}

.concept2 .white-box{
    background-color: rgba(255,255,255,0.7);
    width:80%;
    max-width: 1040px;
    padding: 50px 50px 30px;
    margin: 0 auto;
}

.concept2 .white-box h4{
    color: #333366;
    font-size:24px;
    padding-bottom: 20px;
}

.concept2 .white-box p{
    padding:0 5px 20px;
}


.concept-text2{
    max-width: 950px;
    width: 90%;
    margin: 50px auto;
    padding: 20px 5px;
    display:-webkit-box;
    display:-moz-box;
    display:-ms-box;
    display:-webkit-flexbox;
    display:-moz-flexbox;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:-ms-flex;
    display:flex;
    -webkit-box-lines:multiple;
    -moz-box-lines:multiple;
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    -ms-flex-wrap:wrap;
    flex-wrap:wrap;
}

.concept-text2 .title{
    width: 100%;
}

.concept-text2 .text{
    width: 60%;
}

.concept-text2 .photo{
    width: 40%;
}


.concept-counseling{
  position: relative;
  background-image: url(../images/concept-counselingbg.jpg);
  background-size: cover;
    background-position: center;
    width:100%;
    padding: 300px 0;
}
.concept-counseling div.counseling{
  position: absolute;
  text-align: center;
  transform: translate(-50%,-50%);
  top: 50%;
  left: 50%;
  width: 50%;
}

.counseling-text{
    text-align: left;
    padding-bottom: 50px;
}

.counseling-box{
    background-color: #fff;
    padding: 50px 50px;
    text-align: left;
    margin-bottom: 50px;
}

a.btn3 {
    line-height: 60px;
    width: 230px;
    position: relative;
    display: inline-block;
    background-color: #999999;
    color:#fff;
    font-size: 16px;
    text-align: center;
    border-radius: 10px;
    box-shadow: 0 0px 10px 0 rgba(255, 255, 255, .8);
    text-shadow: -2px -2px 1px #666;
}

.padding-bottom50{
    padding-bottom: 50px;
}


/* price */


.price_pt{
  position: relative;
    width: 100%;
}

.price_pt:before {
  content: "";
  display: block;
  padding-top: 19%;
}

.price_pt_contents{
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
    background: url("../images/price-titlebg.jpg") no-repeat;
    background-size: cover;
    background-position: center;
}

.price_pt_textbox{
    position: absolute;
    top: 50%;
    left: 50%;
    height: 100%;
    -ms-transform: translate(-50%,-50%);
    -webkit-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%);
    margin: 0;
    padding: 0 30px;
    color: white;
    display: table;
}


.price_pt_text{
      display: table-cell;
    vertical-align: middle;
    height: 100%;
}

.price_pt_text h1{
   font-size: 1.5em;
    text-shadow: 5px 5px 10px #000;
    font-weight: 400;
    text-align: center;
    color: #fff;
    display: table-cell;
    vertical-align: middle;
}


.price_pt_text h1 br{
   display:none;
}



.price-text{
    max-width: 950px;
    width: 90%;
    margin: 0 auto 50px;
    padding: 20px 5px;
    display:-webkit-box;
    display:-moz-box;
    display:-ms-box;
    display:-webkit-flexbox;
    display:-moz-flexbox;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:-ms-flex;
    display:flex;
    -webkit-box-lines:multiple;
    -moz-box-lines:multiple;
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    -ms-flex-wrap:wrap;
    flex-wrap:wrap;
}



.price-text .text{
    width: 70%;
}

.price-text .text p{
    padding-bottom: 20px;
}


.price-text .photo{
    width: 30%;
}

.price-text .h3{
    text-align: center;
    width: 100%;
    font-size: 24px;
    color: #000000;
    padding: 20px 0;
}


.price-text2{
    max-width: 950px;
    width: 98%;
    margin: 50px auto 50px;
    padding: 20px 5px;
    display:-webkit-box;
    display:-moz-box;
    display:-ms-box;
    display:-webkit-flexbox;
    display:-moz-flexbox;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:-ms-flex;
    display:flex;
    -webkit-box-lines:multiple;
    -moz-box-lines:multiple;
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    -ms-flex-wrap:wrap;
    flex-wrap:wrap;
}

.price-text2 .title{
    width: 100%;
}


.price-text2 .text{
    width: calc(100% - 217px);
    padding-right: 20px;
}

.price-text2 .text p{
    padding-bottom: 20px;
}


.price-text2 .photo{
    width: 217px;
}


.price-compare{
    background-color: #f5f3f3;
    width:100%;
    padding: 50px 0;
}


.price-compare h2{
    font-size: 22px;
    color: #161743;
    border-bottom: none;
    text-align: center;
    padding-bottom: 30px;
}

.price-compare .whitebox{
    max-width:980px;
    width:90%;
    background-color: #fff;
    margin: 0 auto 50px;
    padding: 30px;
}

table.compare{
    width:100%;
    margin-bottom: 10px;
}

table.compare th{
    padding: 30px 10px;
    text-align: center;
    vertical-align: middle;
    border-bottom: 1px solid #333;
    font-size: 0.9em;
}

table.compare td{
    padding: 30px 10px;
    border-left: 1px solid #333;
    border-bottom: 1px solid #333;
    text-align: center;
    vertical-align: middle;
    font-size: 0.9em;
}

table.compare td .underline{
    border-bottom: 3px solid #ff9900;
}


table.compare .orangebg{
    background-color: #feebc1;
}

.bold{
    font-weight: 700;
}

.price-compare .whitebox p.right{
    font-size: 0.9em;
    text-align: right;
}

.price-compare h3{
    text-align: center;
    font-size: 18px;
    color:#fe7200;
}

.price-text3{
    max-width:950px;
    width: 90%;
    margin: 50px auto;
}

.price-table{
    max-width: 950px;
    width:100%;
}


.price-table th, .price-table td{
    padding: 20px 10px;
    font-size: 0.9em;
    vertical-align: middle;
    text-align: center;
}

.price-table .yellowbg{
    background-color: #fffaef;
    border-left:20px solid #fffaef;
}

.price-table .orangebg{
    background-color: #ffefe5;
    border-right:20px solid #ffefe5;
    white-space: nowrap;
    text-align: center;
    width:230px;
    font-weight: 700;
}

.price-table .border-tb{
    border-bottom:1px solid #333;
    border-top:20px solid #fffaef;
}

.price-table .border-tb2{
    border-bottom:1px solid #333;
    border-top:20px solid #ffefe5;
}

.price-table .border-b{
    border-bottom:1px solid #333;
}

.price-table .border-b-yellow{
    border-bottom:10px solid #fffaef;
}

.price-table .border-b-orange{
    border-bottom:10px solid #ffefe5;
}

.table-td-inner{
    display: table;
    table-layout: fixed;
}

.table-td-box1{
    display: table-cell;
  vertical-align: middle;
    padding: 0;
    width:200px;
    text-align: left;
}

.table-td-box2{
    display: table-cell;
  vertical-align: middle;
    padding: 0;
    text-align: left;
}

.price-table a{
    color:#338fdc;
    text-decoration: underline;
} 

br.hide{
    display: none;
}

.margin-bottom50{
    margin-bottom: 50px;
}


.credit{
    background: url("../images/credit-bg.jpg") no-repeat;
    background-size:cover;
    background-position: center top;
    padding: 200px 0 50px;
    border-top:1px solid #e5e5e5;
    border-bottom:1px solid #e5e5e5;
}

.credit .white-box{
    background-color: rgba(255,255,255,0.7);
    width:80%;
    max-width: 1040px;
    padding: 50px 50px 30px;
    margin: 0 auto;
}

.concept2 .white-box h4{
    color: #333366;
    font-size:24px;
    padding-bottom: 20px;
}

.concept2 .white-box p{
    padding:0 5px 20px;
}


.credit{
  position: relative;
  background-image: url(../images/credit-bg.jpg);
  background-size: cover;
  padding-top: 454px;
}

.credit div.credit-box{
  position: absolute;
  text-align: center;
  transform: translate(-50%,-50%);
  top: 50%;
  left: 50%;
  background-color: #fff;
  width: 50%;
    padding: 30px;
}

.credit p{
    color: #333366;
    text-align: left;
}


.credit p.right{
    text-align: right;
    margin-top: 10px;
}

.price-koujo dt span{
    background-color:#fe9927;
    color:#fff;
    padding: 20px 30px;
    display: inline-block;
    border-radius: 10px;
    font-size: 1.2em;
    margin-bottom: 20px;
}

.price-koujo dd{
    margin-bottom: 50px;
    line-height: 1.5em;
}

.price-koujo dd li{
    list-style-type:decimal;
    margin-left: 1.5em;
    margin-bottom: 20px;
    padding-left: 0.5em;
}

.price-koujo dd li:last-child{
    margin-bottom: 0;
}

.price-koujo dd p{
    margin-bottom: 20px;
    line-height: 1.5em;
}

.koujo-box{
    width: 100%;
    margin: 0 auto 20px;
    padding: 0;
    display:-webkit-box;
    display:-moz-box;
    display:-ms-box;
    display:-webkit-flexbox;
    display:-moz-flexbox;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:-ms-flex;
    display:flex;
    -webkit-box-lines:multiple;
    -moz-box-lines:multiple;
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    -ms-flex-wrap:wrap;
    flex-wrap:wrap; 
    
}

.koujo-text{
    width:50%;
}

.koujo-table{
    width:50%;
    text-align: right;
    padding-left: 20px;
}

.price-koujo a{
    color:#338fdc;
    text-decoration: underline;
} 


/* access */



.access_pt{
  position: relative;
    width: 100%;
}

.access_pt:before {
  content: "";
  display: block;
  padding-top: 19%;
}

.access_pt_contents{
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
    background: url("../images/access-titlebg.jpg") no-repeat;
    background-size: cover;
    background-position: center;
}

.access_pt_textbox{
    position: absolute;
    top: 50%;
    left: 50%;
    height: 100%;
    -ms-transform: translate(-50%,-50%);
    -webkit-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%);
    margin: 0;
    padding: 0 30px;
    color: white;
    display: table;
}


.access_pt_text{
      display: table-cell;
    vertical-align: middle;
    height: 100%;
}

.access_pt_text h1{
   font-size: 1.5em;
    text-shadow: 5px 5px 10px #000;
    font-weight: 400;
    text-align: center;
    color: #fff;
    display: table-cell;
    vertical-align: middle;
}



.access-wrap{
    max-width: 950px;
    width: 90%;
    margin: 50px auto;
    line-height: 1.5em;
}

.access-wrap .img-box{
    width:90%;
    margin: 0 auto 50px;
}


.access-wrap dt{
    margin-bottom: 10px;
}

.access-wrap dt img{
    vertical-align: middle;
}

.access-wrap dd{
    padding-left: 55px;
    margin-bottom: 50px;
}

.ggmap {
position: relative;

padding-top: 30px;
height: 500;
overflow: hidden;
}
 
.ggmap script,
.ggmap iframe,
.ggmap object,
.ggmap embed {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}
.ggmap embedmap {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}


/* menu */


.menu_pt{
  position: relative;
    width: 100%;
}

.menu_pt:before {
  content: "";
  display: block;
  padding-top: 19%;
}

.menu_pt_contents{
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
    background: url("../images/menu-titlebg.jpg") no-repeat;
    background-size: cover;
    background-position: center;
}

.menu_pt_textbox{
    position: absolute;
    top: 50%;
    left: 50%;
    height: 100%;
    -ms-transform: translate(-50%,-50%);
    -webkit-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%);
    margin: 0;
    padding: 0 30px;
    color: white;
    display: table;
}


.menu_pt_text{
      display: table-cell;
    vertical-align: middle;
    height: 100%;
}

.menu_pt_text h1{
   font-size: 1.5em;
    text-shadow: 5px 5px 10px #000;
    font-weight: 400;
    text-align: center;
    color: #fff;
    display: table-cell;
    vertical-align: middle;
}



.page-link{
    margin: 70px auto 100px;
    text-align: center;
}

.page-link a{
    padding: 10px 30px;
    color:#4a627d;
    font-size: 24px;
    font-weight: 700;
}

.page-link a.border{
    border-right: 1px solid #4a627d;
    border-left: 1px solid #4a627d;
}

.menu-wrap{
    max-width: 950px;
    width: 90%;
    margin: 0 auto;
}

.menu-wrap p{
    line-height: 1.5em;
    padding-bottom: 20px;
}

.img-wrap{
    max-width: 688px;
    margin: 50px auto;
    padding: 0;
    display:-webkit-box;
    display:-moz-box;
    display:-ms-box;
    display:-webkit-flexbox;
    display:-moz-flexbox;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:-ms-flex;
    display:flex;
    -webkit-box-lines:multiple;
    -moz-box-lines:multiple;
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    -ms-flex-wrap:wrap;
    flex-wrap:wrap; 
}

.img-wrap .menu-img{
    width: 50%;
    padding: 0;
    text-align: center;
}

.img-wrap .menu-img a span{
    color: #fe9927;
    border-bottom: 2px solid #fe9927;
}


.bracket{
    max-width: 950px;
    width:90%;
    margin: 50px auto;
    display:-webkit-box;
    display:-moz-box;
    display:-ms-box;
    display:-webkit-flexbox;
    display:-moz-flexbox;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:-ms-flex;
    display:flex;
    -webkit-box-lines:multiple;
    -moz-box-lines:multiple;
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    -ms-flex-wrap:wrap;
    flex-wrap:wrap; 
}


.bracket h1{
    margin-bottom: 30px;
}

.bracket h3{
    color:#4a627d;
    font-size:18px;
    margin-bottom: 30px;
}

.bracket p{
    line-height: 1.5em;
    margin-bottom: 20px;
}
.width100per{
    width: 100%;
}

.mienai-text{
    width:50%;
}

.mienai-photo{
    width:50%;
    text-align: right;
    padding-left: 20px;
        margin-bottom: 50px;
}

dl.faq {
	margin: 0;
}
dl.faq dt{
	margin-bottom: 15px;
	padding: 20px 20px 20px 70px;
	border-radius: 40px;
	border:2px solid #fe9927;
    background-image:url("../images/faq-q.jpg");
    background-repeat: no-repeat;
    background-position:  20px;
    width:90%;
}
dl.faq dd{
	margin-bottom: 70px;
	padding: 20px 100px 20px 70px;
	border-radius: 40px;
	border:2px solid #fe9927;
    background-image:url("../images/faq-a.jpg");
    background-repeat: no-repeat;
    background-position:  20px 20px;
    width:90%;
    position: relative;
}

dl.faq dd:after{
	content: url("../images/round-incho.png");
    position:absolute;
    right:-100px;
    bottom:-50px;
}


.bubun{
    background-color: #fff8eb;
}

.bubun-wrap{
    max-width:950px;
    width: 90%;
    margin: 0 auto;
    padding: 50px 0 0;
}

.bubun-wrap .img-box{
    background-color: #fff;
    max-width: 800px;
    width: 100%;
    border-radius: 20px;
    text-align: center;
    margin: 0 auto 50px;
    padding: 50px;
}


dl.merit{
	margin: 50px 0;
}
dl.merit dt{
	margin-bottom: 0;
	padding: 20px 20px 5px 70px;
    color:#fe9927;
    width:90%;
    position: relative;
    font-weight: 700;
    font-size: 1.2em;
}
dl.merit dd{
	margin-bottom: 50px;
    margin-left: 30px;
	padding: 20px 40px;
    background-color: #fff;
}

dl.merit dt.merit01:before{
	content: url("../images/merit1.jpg");
    position:absolute;
    top:-10px;
    left:0px;
}

dl.merit dt.merit02:before{
	content: url("../images/merit2.jpg");
    position:absolute;
    top:-10px;
    left:0px;
}

dl.merit dt.merit03:before{
	content: url("../images/merit3.jpg");
    position:absolute;
    top:-10px;
    left:0px;
}

.non-extraction-bg{
    background: url("../images/hibasshi-bg.png") no-repeat;
    background-position: center;
    background-size: contain;
    text-align: center;
    width:100%;
    margin: 50px auto;
}

.non-extraction-bg h3{
    color: #4a627d;
    font-weight: 700px;
    font-size: 28px;
}

.margin-bottom20{
    margin-bottom: 20px;
}

.non-extraction-bg .orange01{
    color: #fe9927;
    font-size: 2.0em;
}

.non-extraction-bg .orange02{
    color: #fe9927;
    font-size: 1.5em;
}

.non-extraction-bg .yellow01{
    font-size: 1.5em;
    border-bottom: 4px solid #fbef5b;
}

.caption_box{
  position: relative;

  margin-top: 1em;
  padding: 30px;
  border: 3px solid #fe9927;
    border-radius: 20px;
    margin-bottom: 50px;
}

.caption_box .caption{
  position: absolute;
  top: 0;
  left: 0;
  font-size: 1em;
  padding: 0 5px;
  margin: 0 auto;
  background-color: white;
  transform: translateY(-50%) translateX(1em);
}

.caption_box h4{
    color: #fe9927;
    text-align: center;
}

.caption_box .content{
    padding: 0;
    display:-webkit-box;
    display:-moz-box;
    display:-ms-box;
    display:-webkit-flexbox;
    display:-moz-flexbox;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:-ms-flex;
    display:flex;
    -webkit-box-lines:multiple;
    -moz-box-lines:multiple;
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    -ms-flex-wrap:wrap;
    flex-wrap:wrap; 
}

.caption_box .content .text{
    width:calc(100% - 308px);
    padding-right: 20px;
    line-height: 1.5em;
}

.caption_box .content .photo{
    width:308px;
}


.column{
    background-color: #fff8eb;
    border-radius: 20px;
    width: 100%;
    padding: 30px 30px 0;
    margin-bottom: 50px;
}


.column dl{
	margin: 0;
}
.column dl dt{
	margin-bottom: 0;
	padding: 20px 0 5px 100px;
    color:#fe9927;
    width:100%;
    position: relative;
    font-weight: 700;
    font-size: 1.2em;
    border-bottom: 3px solid #fe9927;
}
.column dl dd{
    margin-left: 30px;
	padding: 20px;
    display:-webkit-box;
    display:-moz-box;
    display:-ms-box;
    display:-webkit-flexbox;
    display:-moz-flexbox;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:-ms-flex;
    display:flex;
    -webkit-box-lines:multiple;
    -moz-box-lines:multiple;
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    -ms-flex-wrap:wrap;
    flex-wrap:wrap; 
    width: 100%;
}

.column dl dt:before{
	content: url("../images/column.png");
    position:absolute;
    top:-50px;
    left:-20px;
}


.column-text{
    width: calc(100% - 235px);
}

.column-photo{
    width:235px;
    text-align: right;
    padding-left: 20px;
}



.yugami{
    background-color: #fff8eb;
    padding-bottom: 50px;
}

.yugami-wrap{
    max-width:950px;
    width: 90%;
    margin: 0 auto;
    padding: 50px 0 0;
}

.yugami-wrap .img-box{
    background-color: #fff;
    width: 80%;
    border-radius: 20px;
    text-align: center;
    margin: 0 auto 50px;
    padding: 50px;
}

table.yugami-table{
    background-color: #fff;
    margin: 50px auto 50px;
}
table.yugami-table th{
    background-color: #fff;
    padding: 20px;
    width:280px;
}


table.yugami-table td{
    background-color: #fff;
    padding: 20px;
    vertical-align: top;
}

table.yugami-table td h4 {
    background: #ffc34d;
    color: #fff;
    text-align: center;
    margin-bottom: 10px;
    padding: 5px 0;
}



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

.case-counseling2{
  position: relative;
  background-image: url(../images/case-counselingbg.jpg);
  background-size: cover;
    background-position: center;
    width:100%;
    padding: 300px 0;
}
.case-counseling2 div.counseling{
  position: absolute;
  text-align: center;
  transform: translate(-50%,-50%);
  top: 50%;
  left: 50%;
  width: 80%;
}

.counseling-box{
    background-color: #fff;
    padding: 50px 20px;
    text-align: left;
    margin-bottom: 50px;
}



a.btn2 {
    line-height: 60px;
    width: 230px;
    position: relative;
    display: inline-block;
    background-color: #fe9927;
    color:#fff;
    font-size: 16px;
    text-align: center;
    border-radius: 10px;
    box-shadow: 0 0px 10px 0 rgba(255, 255, 255, .8);
}


.concept-counseling div.counseling {
    position: absolute;
    text-align: center;
    transform: translate(-50%,-50%);
    top: 50%;
    left: 50%;
    width: 80%;
}    
    


}



@media screen and (max-width: 1080px) {
  .header_pc{
    display: none;
  }
  .header_sp{
    display: block;
  }
  .header_logo {
    padding: 0px 0 0px 10px;
}
.header_logo img {
  margin-left: 4%;
  width: 200px;
}

h1{
  display: block;
  margin-left: 8%;
}
  .hamburger {
    display : block;
    position: fixed;
    z-index : 3;
    right : 13px;
    top   : 12px;
    width : 42px;
    height: 42px;
    cursor: pointer;
    text-align: center;
  }
  .hamburger span {
    display : block;
    position: absolute;
    width   : 30px;
    height  : 2px ;
    left    : 6px;
    background : #555;
    -webkit-transition: 0.3s ease-in-out;
    -moz-transition   : 0.3s ease-in-out;
    transition        : 0.3s ease-in-out;
  }
  .hamburger span:nth-child(1) {
    top: 10px;
  }
  .hamburger span:nth-child(2) {
    top: 20px;
  }
  .hamburger span:nth-child(3) {
    top: 30px;
  }
  
  /* ナビ開いてる時のボタン */
  .hamburger.active span:nth-child(1) {
    top : 16px;
    left: 6px;
    background :#fff;
    -webkit-transform: rotate(-45deg);
    -moz-transform   : rotate(-45deg);
    transform        : rotate(-45deg);
  }
  
  .hamburger.active span:nth-child(2),
  .hamburger.active span:nth-child(3) {
    top: 16px;
    background :#fff;
    -webkit-transform: rotate(45deg);
    -moz-transform   : rotate(45deg);
    transform        : rotate(45deg);
  }
  
  nav.globalMenuSp {
    position: fixed;
    z-index : 2;
    top  : 0;
    left : 0;
    color: #fff;
    background: rgba(0,0,0,0.7);
    text-align: center;
    width: 100%;
    display: none;
    transition: opacity .6s ease, visibility .6s ease;
  }
  
  nav.globalMenuSp ul {
    margin: 0 auto;
    padding: 60px 0;
    width: 100%;
    display: block;
  }
  
  nav.globalMenuSp ul li {
    list-style-type: none;
    padding: 0;
    margin-bottom: 10px;
    width: 100%;
    transition: .4s all;
  }
  nav.globalMenuSp ul li:last-child {
    padding-bottom: 0;
  }
  nav.globalMenuSp ul li:hover{
    background :#ddd;
  }
  
  nav.globalMenuSp ul li a {
    display: block;
    color: #fff;
    padding: 1em 0;
    text-decoration :none;
  }
  
  /* このクラスを、jQueryで付与・削除する */
  nav.globalMenuSp.active {
    display: block;
  }


.footer-info-wrap {
    max-width: 450px;
}    
    

.footer-info{
    width: 100%;
    padding-bottom: 20px;
    text-align: center;
}

.padding-left{
    padding-left: 0px;
}

.footer-table {
    width: 100%;
    margin: 0 auto 10px;
}
    
    
    
    
    
.top-needs{
    width:100%;
    padding: 0 30px 30px;
    text-align: center;
}    

#top-concept{
    background-image:none;
}

#top-concept .site {
position: static;
    padding-left: 0;
    height: auto;
}
.site {
    width: auto;
    padding: 0 ;
}

#top-concept header {
    height: 210px;
    width:100%;
    background-image: url(../images/top-conceptbg.jpg);
    background-size: cover;
    background-position: 50% 50%;
    position: relative;
    margin: -15px 0 0;
    padding: 0;    
}
    
#top-concept .inner{
    margin: 0 auto;
    width: 375px;
    height: 100%;
    position: relative;
    box-sizing: border-box;
}

#top-concept h2 {
    text-align: right;
padding-right: 10px;
    padding-left: 160px;
    padding-top: 20px;
    margin-right: 0;
}

#top-concept figure {
    position: static;
}

#top-concept figure img{
    height: 225px;
    bottom: 0;
    left: 0px;
    right: auto;
    position: absolute;
    }    
    
#top-concept figure figcaption {
    position: absolute;
    bottom: 5px;
    right: 10px;
    text-align: right;
}

#top-concept figure figcaption p{
    padding: 0 0 0 40px;
    text-align: right;
}

#top-concept figure figcaption p.prof01{
        font-size: 15px;
    line-height: 20px;
    margin-top: 12px;
    margin-bottom: 12px;
}

#top-concept figure figcaption p.prof02{
    margin-top: 10px;
    font-size: 14px;
}

#top-concept figure figcaption p.prof03{
    font-size: 24px;
}

#top-concept figure figcaption p.prof04{
    font-size: 12px;
}


#top-concept p {
    line-height: 24px;
    padding: 20px 20px 0;
    font-weight: 400;
    max-width: 816px;
    margin: 0 auto;
}

#top-concept p.more {
    text-align: center;
}

a.btn {
    line-height: 44px;
    width: 230px;
    position: relative;
    display: inline-block;
    background-color: #ffffff;
    font-size: 16px;
    text-align: center;
    border: 2px solid #333333;
    border-radius: 10px;
}

#top-price {
    padding-top: 300px;
}    

#top-price div.top-price{
  position: absolute;
  text-align: center;
  transform: translate(-50%,-50%);
  top: 50%;
  left: 50%;
  background-color: #fff;
  font-size: 24px;
  border-radius: 16px;
  width: 90%;
    border: 4px solid #ff9900;
}

.top-price-text{
    vertical-align: middle;   
    height: 100%;
    width: 100%;
    padding: 30px 30px;
    margin: 0 auto;
}


#top-price p{
    color: #333366;
    font-size: 18px;
    text-align: left;
}

#top-price p span{
    color: #ff9900;
    font-size: 24px;
    padding: 0 5px;
}

#top-price p.right{
    text-align: center;
    margin-top: 10px;
}

    
.bracket h1 {
    margin-bottom: 30px;
        margin-left: 0;
}    
    
.caption_box .content .text {
    width: 100%;
    padding-right: 0;
    padding-bottom: 20px;
}   

.caption_box .content .photo {
    width: 100%;
    text-align: center;
}  
    
.column {
    padding: 30px 20px 0;
}    
    
.column dl dd {
    margin-left: 0px;
    }
    
.column-text {
    width: 100%;
    padding-left: 0px;
}    
        
    
.column-photo {
    width: 100%;
    text-align: center;
    padding-left: 0px;
}    
    
.price-text2 .text {
    width: 100%;
    padding-right: 0;
}
    
.price-text2 .photo {
    width: 100%;
    text-align: center;
}    
    
.credit div.credit-box {
    position: absolute;
    text-align: center;
    transform: translate(-50%,-50%);
    top: 50%;
    left: 50%;
    background-color: #fff;
    width: 80%;
    padding: 30px;
}
    
.koujo-text {
    width: 100%;
}
    
.koujo-table {
    width: 100%;
    text-align: center;
    padding-left: 0px;
}
    
.case_textbox {
    position: absolute;
    top: 50%;
    right: -23%;
    height: 100%;
    -ms-transform: translate(-50%,-50%);
    -webkit-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%);
    margin: 0;
    font-size: 20px;
    padding: 0 10px;
    color: white;
    background-color: transparent;
    display: table;
}    
    
.concept-text .img-box div.box-inner {
    width: 100%;
    padding: 0 5px;
    margin-bottom: 10px;
}

   
    
 .concept_pt_text h1 {
    font-size: 1.5em;
    text-shadow: 5px 5px 10px #000;
    font-weight: 400;
     padding: 30px 0;
} 
    
    
.greeting-wrap {
    width: 90%;
}    
    
.greeting-wrap .greeting-img {
    width: 230px;
    margin: 0 auto 30px;
}    

.greeting-list {
    width: 100%;
    padding-left: 0;
} 
    
    
.concept2 .white-box {
    width: 90%;
    padding: 20px 20px 10px;
    margin: 0 auto;
}    

.concept-counseling div.counseling {
    width: 90%;
}    

.counseling-text {
    text-align: left;
    padding-bottom: 20px;
}
    
.counseling-box {
    padding: 20px 20px;
    margin-bottom: 20px;
}    

    
.menu_pt_text h1 {
    font-size: 1.5em;
    text-shadow: 5px 5px 10px #000;
    font-weight: 400;
    padding: 30px 0;
}    
.page-link a {
    padding: 5px 10px;
    color: #4a627d;
    font-size: 20px;
    font-weight: 700;
    display: block;
} 
.page-link a.border {
    border:none;
} 
    
.price_pt_text h1 {
    font-size: 1.5em;
    text-shadow: 5px 5px 10px #000;
    font-weight: 400;
     padding: 30px 0;
} 
    
.price-text2 {    
    padding: 0;
    }
    

.access_pt_text h1 {
    font-size: 1.5em;
    text-shadow: 5px 5px 10px #000;
    font-weight: 400;
     padding: 30px 0;
}     
    
}

@media screen and (max-width: 800px) {
   
.index_mv_textbox {
    left: 30%;
    font-size: 16px;
    padding: 0 10px;
}


    
.index_mv_text h1{
   font-size: 1em;
     margin-left: 0;
     padding-left: 0;
	text-align: center;
 
}

}

.index_mv_text p{
    color: #fff;
    font-size: 0.8em;
    line-height: 0.9em;
}    

h2.section_title {
    text-align: center;
    padding: 50px 10px;
}    
    
.table-td-inner {
    display: block;
    table-layout: fixed;
    width: 100%;
}    
    
.table-td-box1 {
    display: block;
    vertical-align: middle;
    padding: 0 0 20px;
    width: 100%;
    text-align: center;
}

.table-td-box2 {
    display: block;
    vertical-align: middle;
    padding: 0;
    text-align: left;
    width:100%;
}    

.price-compare .whitebox p.right {
    text-align: left;
}    
.price-table .orangebg {
    width: 100px;
    border-right:5px solid #ffefe5;
}    

    

.price-table .yellowbg{
    border-left:5px solid #fffaef;
}



.price-table .border-tb{
    border-bottom:1px solid #333;
    border-top:5px solid #fffaef;
}

.price-table .border-tb2{
    border-bottom:1px solid #333;
    border-top:5px solid #ffefe5;
}



.price-table .border-b-yellow{
    border-bottom:10px solid #fffaef;
}

.price-table .border-b-orange{
    border-bottom:10px solid #ffefe5;
}
    
br.hide{
    display: block;
}
    
    
.footer-info-wrap {
    width:90%;
}    
.footer-address {
    font-size: 1.0em;
    padding: 10px 0 20px;
}
    
.concept2 {
    background: url(../images/soudan-bg2.jpg) no-repeat;
    background-size: cover;
    background-position: left top;
    padding: 50px 0;

}    

.concept-text2 .text{
    width: 100%;
}

.concept-text2 .photo{
    width: 100%;
    text-align: center;
    padding-top: 30px;
}    

.concept-counseling {
    position: relative;
    background-image: url(../images/concept-counselingbg2.jpg);
    background-size: cover;
    background-position: center;
}    

    
.img-wrap .menu-img{
    width: 100%;
    padding: 0 0 30px;
    text-align: center;
}    

.mienai-text{
    width:100%;
}

.mienai-photo{
    width:100%;
    text-align: center;
    padding-left: 0px;
    padding-top: 20px;
        margin-bottom: 50px;
} 
  
    
dl.faq dt {
    width: 100%;
}     
    
dl.faq dd {
    margin-bottom: 100px;
    padding: 20px 20px 20px 70px;
    border-radius: 40px;
    border: 2px solid #fe9927;
    background-image: url(../images/faq-a.jpg);
    background-repeat: no-repeat;
    background-position: 20px 20px;
    width: 100%;
    position: relative;
}    
    
 dl.faq dd:after {
    content: url(../images/round-incho-mini.png);
    position: absolute;
    right: -10px;
    bottom: -70px;
} 
    
.bubun-wrap .img-box{
    padding: 20px;
} 
    
    
    

.non-extraction-bg h3{
    font-size: 24px;
}

.margin-bottom20{
    margin-bottom: 10px;
}

.non-extraction-bg .orange01{
    color: #fe9927;
    font-size: 2.0em;
    display: block;
}

.non-extraction-bg .orange02{
    color: #fe9927;
    font-size: 1.5em;
}
    
.non-extraction-bg p{
    font-size: 0.9em;
}

.non-extraction-bg .yellow01{
    font-size: 1.2em;
    border-bottom: 4px solid #fbef5b;
}
    

    


table.yugami-table th{
    width:100%;
    display: block;
    padding: 20px 20px 0;
}


table.yugami-table td{
    width:100%;
    display: block;
    padding: 10px 20px 20px;
}

.case-counseling2 {
    padding: 200px 0;
}    


.case-counseling2 div.counseling {
    width: 90%;
}    

.case_textbox {
    position: absolute;
    top: 50%;
    left: 50%;
    height: 100%;
    -ms-transform: translate(-50%,-50%);
    -webkit-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%);
    margin: 0;
    font-size: 20px;
    padding: 0 10px;
    color: white;
    background-color: transparent;
    display: table;
    text-align: center;
}    
    
 .case_text p {
    font-size: 1.2em;
    text-align: center;
    line-height: 1.8em;
    color: #fff;
    text-shadow: 3px 3px 5px #000000;
}  
    

.price_pt_text h1 {
    font-size: 1.2em;

}    
    
    
.price_pt_text h1 br{
   display:block;
}
    
.price-text .text {
    width: 100%;
}    

.price-text .photo {
    width: 100%;
    text-align: center;
    padding-top: 20px;
} 
    
.price-compare .whitebox {
    padding: 10px;
}
    
    
}

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

/* common */
.sp-mode{
  display: block;
}
.pc-mode{
  display: none;
}
.header_logo img {
  margin-left: 0%;
  width: 180px;
}
footer ul {
  display: block;
  justify-content: space-between;
  width: 100%;
  margin: 0px auto;
  height: auto;
  text-align: center;
}

/* index */


#index_1 {
    padding: 84px 0 0px;
}
.index_1_content_wrap {
  display: block;
  justify-content: space-between;
  width: 96%;
  margin: 0 auto;
  text-align: center;
}
.index_1_content{
  margin-bottom: 60px;
}
#index_2>div {
  background-color: #E9F0F3;
  width: 96%;
  margin: 0 auto;
  display: block;
  justify-content: center;
  flex-basis: 498px;
  padding: 0;
}
#index_2>div>div:first-of-type {
  margin: 0 auto;
}
#index_2>div>div:last-of-type {
  margin: 0 auto;
}
#index_2 ul li time {
  display: block;
  padding-bottom: 10px;
}
#index_3 {
  padding-top: 270px;
}
#index_3 div {
  width: 90%;
  height: 116px;
  padding-top: 42px;
}
#index_3 div a {
  padding: 0px;
  text-align: center;
  line-height: 1.5;
}
#index_3 div a::before {
  margin-right: 20px;
}

.caption_box {
    padding: 30px 10px;
}
    
.column dl dd {
    padding: 20px 0;
}    

.price_pt{
    margin-bottom: 30px;
}   
.kaisha 
width: 100%;
}

.kaisha th,
.kaisha td {
border: 1px solid #ccc;
padding: 20px;
}

.kaisha th {
font-weight: bold;
background-color: #dedede; 
}

@media screen and (max-width: 1040px) {
.kaisha,
.kaisha tr,
.kaisha td,
.kaisha th {display:block;}
.kaisha th {width:auto;}
}

