

.table-def {
  width: 100%;
  background: #fff;
}

.table-def th {
  text-align: left;

  color: #444;
  padding: 18px 20px;
  width: 30%;
  background: #f7f7f7;
  border: solid 1px #d7d7d7;
}

.table-def td {
  padding: 18px 20px;

  border: solid 1px #d7d7d7;
}


@media (max-width: 500px) {

  .table-def th,
  .table-def td {
    display: block !important;
    width: 100% !important;
    border-top: none !important;
    -webkit-box-sizing: border-box !important;
    -moz-box-sizing: border-box !important;
    box-sizing: border-box !important;
    padding: 6px 12px !important;
    letter-spacing: 0;
  }

  .table-def tr:first-child th {
    border-top: 1px solid #d7d7d7 !important;
  }

  .table-def .haveto,
  .table-def .any {
    font-size: 10px;
  }
}






.table-def-s {
  width: 100%;
  font-size: 14px;
}
/*è¦‹å‡ºã—æ¬„*/
.table-def-s th {
  text-align: left;

  color: #444;
  padding: 8px 10px;
  width: 30%;
  background: #f7f7f7;
  border: solid 1px #d7d7d7;
}
/*é€šå¸¸æ¬„*/
.table-def-s td {
  padding: 8px 10px;

  border: solid 1px #d7d7d7;
}



@media (max-width: 500px) {

  .table-def-s th,
  .table-def-s td {
    display: block !important;
    width: 100% !important;
    border-top: none !important;
    -webkit-box-sizing: border-box !important;
    -moz-box-sizing: border-box !important;
    box-sizing: border-box !important;
      letter-spacing: 0;
  }

  .table-def-s tr:first-child th {
    border-top: 1px solid #d7d7d7 !important;
  }

  .table-def-s .haveto,
  .table-def-s .any {
    font-size: 10px;
  }
}




@media screen and (max-width: 600px) {
  .table-resp th {
    border-bottom: 1px solid #ddd;
    border-top: 2px solid #ddd;
  }

  .table-resp th,
  .table-resp td {
    display: block;
    width: 100%;
  }
}

/*営業時間*/

.hours-table-wrap {
    background: rgba(255,255,255,0.9);
      border: 1px solid #e7e7e7;
    padding:16px;
    border-radius: 8px;

    box-shadow: 0px 1px 1px 0px rgb(0 0 0 / 40%);
    color: #444;
    font-size: 15px;
    margin-bottom: 12px;
}


.hours-table {
  font-size: 15px;
  border: none;

  width: 100%;
  margin-bottom: 8px;
}

.hours-table th {
  text-align: center;
  font-weight: normal;
}

.hours-table thead th {
  padding: 16px;
  text-align: center;
}

.hours-table tbody tr {
  /*background:#eee9d8;*/
  text-align: center;
}

.hours-table .table-line {
  border-top: 1px solid #e0e0e0;
}

.hours-table td {
  padding: 16px;
  text-align: center;
  /*border-left: 1px solid #fff;*/
}

.hours-table .info-color {
  color: #fcae68;
}

.hours-table p {
  margin: 15px 0;
}

@media screen and (max-width: 600px) {
  .hours-table {
    font-size: 14px;
  }
  .hours-table td {
    padding: 2px;
    text-align: center;
    /*border-left: 1px solid #fff;*/
  }
  .hours-memo {
    font-size: 13px;
  }
}
/**/









/*料金表*/


.price-table {
width: 100%;
    border-collapse: collapse;
    box-sizing: border-box;
    border-top: solid 1px #cccccc;
    border-left: solid 1px #cccccc;
    border-right: solid 1px #cccccc;
    background: #fff;
    margin-bottom: 12px;
}


.price-table th{
  /* width: 20%; */
    padding: 20px;
    font-weight: normal;
    text-align: left;
    vertical-align: top;


    color: rgb(8, 32, 108);
    font-size: 110%;
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1.6em;

    border-bottom: solid 1px #cccccc;
}

.price-table th span {
  font-size: 13px;
  display: block;
  font-weight: normal;
  color: #333;
}

.price-table td.price-feature{
    width: 40%;
    background: #fff;
    text-align: left;
    vertical-align: middle;
    padding: 16px;

    color: #333;
    font-size: 100%;
    font-weight: normal;
    letter-spacing: .0em;
    line-height: 1.7em;

    border-bottom: solid 1px #cccccc;
     border-left: solid 1px #ddd;
}

.price-table td.price-feature span {
    font-size: 14px;
      display: block;
      font-weight: normal;
      color: #555;
      margin-top: 5px;;
}



.price-table td.price-feature-blank {
  width: 40%;
  background: #fff;
  text-align: left;
  vertical-align: middle;
  padding: 16px;

  color: #333;
  font-size: 100%;
  font-weight: normal;
  letter-spacing: .0em;
  line-height: 1.6em;

  border-bottom: solid 1px #cccccc;
  border-left: solid 1px #FFF;
}
.price-table td.price-feature ul {

}

.price-table td.price-td{
    width: 25%;
    background: #f5f3f2;
    text-align: center;
    vertical-align: middle;


    color: #b79647;
    font-size: 15px;
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1.5;

    border-bottom: solid 1px #cccccc;
    padding: 16px 8px;
}

.price-table .tax {
  display: block;
  font-size: 14px;
  font-weight: normal;
  margin-top: 4px;
  
}

@media screen and (max-width: 600px) {
.price-table th {
    padding: 6px;
    font-weight: normal;
    text-align: left;
    vertical-align: top;
    color: rgb(8, 32, 108);
    font-size: 14px;
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1.6em;

    border-bottom: solid 1px #cccccc;

    display: block;
    width: 100%;
  }


.price-table td.price-feature{
padding: 6px;
    background: #fff;
    text-align: left;
    vertical-align: middle;

    font-size: 14px;
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1.2em;

    border-bottom: solid 1px #cccccc;
    display: block;
      width: 100%;
}
.price-table td.price-feature-blank {
    display: none;
      width: 100%;

}
.price-table td.price-td{

    background: #f5f3f2;
    text-align: left;
    vertical-align: middle;
padding: 6px;

    color: #555;
    font-size: 14px;
    font-weight: bold;
    letter-spacing: 0;
    line-height: 1.2em;

    border-bottom: solid 1px #cccccc;

    display: block;
      width: 100%;
      height: 100%;
}


.price-zei {
  display: block;
}


}













/*料金表V*/


.price-table-v {
  width: 100%;
  border-collapse: collapse;
  box-sizing: border-box;
  border-top: solid 1px #cccccc;
  border-left: solid 1px #cccccc;
  border-right: solid 1px #cccccc;
  background: #fff;
  margin-bottom: 12px;
}
.price-table-v thead th {
width: 30%;
  padding: 18px;
  font-weight: normal;
  text-align: center;
  vertical-align: center;


  color: #333;
  font-size: 16px;
  font-weight: bold;
  letter-spacing: .1em;
  line-height: 1.6em;
border-left: solid 1px #ddd;
  border-bottom: solid 1px #cccccc;
}
.price-table-v thead.table-td-m th {
  width: 25%;
}


.price-table-v tbody th {
color: rgb(8, 32, 108);
  padding: 18px;
  font-weight: normal;
  text-align: center;
  vertical-align: center;


    font-size: 16px;
  font-weight: bold;
  letter-spacing: .1em;
  line-height: 1.6em;

  border-bottom: solid 1px #cccccc;
}
.price-table-v tbody th.table-th-h {
  width: 25%;
}
.price-table-v td {

background: #f5f3f2;
  text-align: center;
  vertical-align: middle;
  padding: 18px;

  color: #b79647;
  font-size: 100%;
  font-weight: bold;
  letter-spacing: .0em;
  line-height: 1.6em;

  border-bottom: solid 1px #cccccc;
  border-left: solid 1px #ddd;
}

.price-table-v td.price-feature ul {}

.price-table-v .table-th-m {
  background: #9AC62C;
    text-align: center;
    vertical-align: middle;
    padding: 18px;
  
    color: #FFF;
    font-size: 100%;
    font-weight: bold;
    letter-spacing: .0em;
    line-height: 1.6em;
  
    border-bottom: solid 1px #cccccc;
    border-left: solid 1px #ddd;
}

.price-table-v .tax {
  display: block;
  font-size: 14px;
  font-weight: normal;
  margin-top: 4px;

}

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

.price-table-v thead th,
.price-table-v tbody th {

    padding: 6px;
    font-weight: normal;
    text-align: center;
    vertical-align: center;


    font-size: 13px;
    font-weight: bold;
    letter-spacing: .1em;
    line-height: 1.6em;

    border-bottom: solid 1px #cccccc;
  }

.price-table-v td {

  background: #fff;
  text-align: center;
  vertical-align: middle;
  padding: 6px;

  color: #333;
  font-size: 13px;
  font-weight: normal;
  letter-spacing: .0em;
  line-height: 1.6em;

  border-bottom: solid 1px #cccccc;
  border-left: solid 1px #ddd;
}
.price-table-v .table-th-m {
      padding: 6px;
  background: #9AC62C;
  text-align: center;
  vertical-align: middle;


  color: #FFF;
  font-size: 14px;
  font-weight: bold;
  letter-spacing: .0em;
  line-height: 1.6em;

  border-bottom: solid 1px #cccccc;
  border-left: solid 1px #ddd;
}


}








.fee-img {
  text-align: center;
}

.fee-img img {
  width: 60%;
}

.fee-table {
  font-size: 15px;

}

.fee-table th,
.fee-table td{
line-height: 1.9;
padding:16px 10px;
}


.fee-table thead {
  font-size: 15px;
  background: #f4f4f4;
}

.fee-th-01 {width: 30%}
.fee-th-02 {width: 50%}
.fee-th-03 {width: 20%}
/*.fee-th-04 {width: 26%}
.fee-th-05 {width: 26%}
.fee-th-06 {width: 8%}
.fee-th-07 {width: 8%}*/



@media screen and (max-width: 600px) {
  table.fee-table thead {
    display: none;
  }
  table.fee-table tr {
    border-bottom:8px solid #ddd;
    display: block;
  }
  table.fee-table td {
    border-bottom: 1px solid #ddd;
    display: block;
    /*text-align: right;*/
    padding:5px;
  }
  table.fee-table td:before {
    content: attr(aria-label);
    font-weight: bold;
    border-bottom:1px dotted #ccc;
    padding: 3px 5px;
    margin:-5px;
    margin-bottom:3px;
    display: block;
    background: #f4f4f4;
  }
  .fee-img img {
  width: 30%;
}
}








/*いんぷらんと*/


.implant-table-v {
  width: 100%;
  border-collapse: collapse;
  box-sizing: border-box;
  border-top: solid 1px #cccccc;
  border-left: solid 1px #cccccc;
  border-right: solid 1px #cccccc;
  background: #fff;
  margin-bottom: 12px;
}

.implant-table-v thead th {
  width: 30%;
  padding: 18px;
  font-weight: normal;
  text-align: center;
  vertical-align: center;
background: #9493CA;

  color: #FFF;
  font-size: 16px;
  font-weight: bold;
  letter-spacing: .1em;
  line-height: 1.6em;
  border-left: solid 1px #ddd;
  border-bottom: solid 1px #cccccc;
}

.implant-table-v thead.table-td-m th {
  width: 25%;
}


.implant-table-v tbody th {
  color: #FFF;
  padding: 18px;
  font-weight: normal;
  text-align: center;
  vertical-align: center;
background-color: #ED907F;

  font-size: 16px;
  font-weight: bold;
  letter-spacing: .1em;
  line-height: 1.6em;

  border-bottom: solid 1px #cccccc;
}

.implant-table-v tbody th.table-th-h {
  width: 25%;
}

.implant-table-v td {


  text-align: left;
  vertical-align: middle;
  padding: 18px;

  color: #222;
  letter-spacing: .0em;
  line-height: 1.6em;

  border-bottom: solid 1px #cccccc;
  border-left: solid 1px #ddd;
}

.implant-table-v td.implant-feature ul {}

.implant-table-v .table-th-m {
  background: #9AC62C;
  text-align: center;
  vertical-align: middle;
  padding: 18px;

  color: #FFF;
  font-size: 100%;
  font-weight: bold;
  letter-spacing: .0em;
  line-height: 1.6em;

  border-bottom: solid 1px #cccccc;
  border-left: solid 1px #ddd;
}

.implant-table-v .tax {
  display: block;
  font-size: 14px;
  font-weight: normal;
  margin-top: 4px;

}

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

  .implant-table-v thead th,
  .implant-table-v tbody th {

    padding: 6px;
    font-weight: normal;
    text-align: center;
    vertical-align: center;


    font-size: 13px;
    font-weight: bold;
    letter-spacing: .1em;
    line-height: 1.6em;

    border-bottom: solid 1px #cccccc;
  }

  .implant-table-v td {

    background: #fff;
    text-align: center;
    vertical-align: middle;
    padding: 6px;

    color: #333;
    font-size: 13px;
    font-weight: normal;
    letter-spacing: .0em;
    line-height: 1.6em;

    border-bottom: solid 1px #cccccc;
    border-left: solid 1px #ddd;
  }

  .implant-table-v .table-th-m {
    padding: 6px;
    background: #9AC62C;
    text-align: center;
    vertical-align: middle;


    color: #FFF;
    font-size: 14px;
    font-weight: bold;
    letter-spacing: .0em;
    line-height: 1.6em;

    border-bottom: solid 1px #cccccc;
    border-left: solid 1px #ddd;
  }


}









/* 小児矯正 */


.kids-ortho-table-v {
  width: 100%;
  border-collapse: collapse;
  box-sizing: border-box;
  border-top: solid 1px #cccccc;
  border-left: solid 1px #cccccc;
  border-right: solid 1px #cccccc;
  background: #fff;
  margin-bottom: 12px;
  font-size: 15px;
}

.kids-ortho-table-v thead th {

  padding: 18px;
  font-weight: normal;
  text-align: center;
  vertical-align: center;
  background: #999;

  color: #FFF;
  font-size: 16px;
  font-weight: bold;
  letter-spacing: .1em;
  line-height: 1.6em;
  border-left: solid 1px #ddd;
  border-bottom: solid 1px #cccccc;
}

.kids-ortho-table-v thead.table-td-m th {

}
.kids-ortho-table-v .bg-color {
  background:#F5A03C;
  border-bottom: solid 2px #F5A03C;
    border-left: solid 2px #F5A03C;
    border-right: solid 2px #F5A03C;
}
.kids-ortho-table-v .text-color {
  color: #F5A03C;
  font-weight: bold;

    border-left: solid 2px #F5A03C;
    border-right: solid 2px #F5A03C;
}
.kids-ortho-table-v .text-color-btm {


  border-bottom: solid 2px #F5A03C;
}
.kids-ortho-table-v .text-color ul li{
  font-weight: bold;
}


.kids-ortho-table-v tbody th {
  color: #333;
  padding: 18px;
  font-weight: normal;
  text-align: center;
  vertical-align: center;
  background-color: #F4f4f4;

  font-size: 16px;
  font-weight: bold;
  letter-spacing: .1em;
  line-height: 1.6em;

  border-bottom: solid 1px #cccccc;
}

.kids-ortho-table-v tbody th.table-th-h {
  width: 20%;
}

.kids-ortho-table-v td {

width: 40%;
  text-align: left;
  vertical-align: middle;
  padding: 18px;

  color: #222;
  letter-spacing: .0em;
  line-height: 1.6em;

  border-bottom: solid 1px #cccccc;
  border-left: solid 1px #ddd;
}

.kids-ortho-table-v td.kids-ortho-feature ul {}

.kids-ortho-table-v .table-th-m {
  background: #9AC62C;
  text-align: center;
  vertical-align: middle;
  padding: 18px;

  color: #FFF;
  font-size: 100%;
  font-weight: bold;
  letter-spacing: .0em;
  line-height: 1.6em;

  border-bottom: solid 1px #cccccc;
  border-left: solid 1px #ddd;
}

.kids-ortho-table-v .tax {
  display: block;
  font-size: 14px;
  font-weight: normal;
  margin-top: 4px;

}

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

  .kids-ortho-table-v thead th,
  .kids-ortho-table-v tbody th {

    padding: 6px;
    font-weight: normal;
    text-align: center;
    vertical-align: center;


    font-size: 13px;
    font-weight: bold;
    letter-spacing: .1em;
    line-height: 1.6em;

    border-bottom: solid 1px #cccccc;
  }

  .kids-ortho-table-v td {

    background: #fff;
    text-align: center;
    vertical-align: middle;
    padding: 6px;

    color: #333;
    font-size: 13px;
    font-weight: normal;
    letter-spacing: .0em;
    line-height: 1.6em;

    border-bottom: solid 1px #cccccc;
    border-left: solid 1px #ddd;
  }

  .kids-ortho-table-v .table-th-m {
    padding: 6px;
    background: #9AC62C;
    text-align: center;
    vertical-align: middle;


    color: #FFF;
    font-size: 14px;
    font-weight: bold;
    letter-spacing: .0em;
    line-height: 1.6em;

    border-bottom: solid 1px #cccccc;
    border-left: solid 1px #ddd;
  }


}