@charset "utf-8";


/* ----------↓ #MAIN ↓---------- */

/* ----------↓ COMMON ↓---------- */
#main .last {
  margin-bottom: 4em;
}

#main .mid {
  margin-bottom: 2em !important;
}

#main .lit {
  margin-bottom: 1em !important;
}

#main .bld {
  font-weight: bold;
}

#main .red {
  color: #DD0000;
}

#main td.nowrap {
  white-space: nowrap;
}

#main .mgn-B00 { margin-bottom: 0 !important; }
#main .mgn-B05 { margin-bottom: 05px !important; }
#main .mgn-B10 { margin-bottom: 10px !important; }
#main .mgn-B15 { margin-bottom: 15px !important; }
#main .mgn-B20 { margin-bottom: 20px !important; }
#main .mgn-B30 { margin-bottom: 30px !important; }
#main .mgn-B40 { margin-bottom: 40px !important; }
#main .mgn-B50 { margin-bottom: 50px !important; }
#main .mgn-B1em { margin-bottom: 1em !important; }
#main .mgn-B2em { margin-bottom: 2em !important; }


/* ----------↓ IMG(float) ↓---------- */
div.pic {
  float: right;
  width: 200px;
  margin-left: 16px;
  margin-bottom: 1.6em;
}

div.pic-250 {
  float: right;
  width: 250px;
  margin-left: 16px;
  margin-bottom: 1.6em;
}

div.txt {
  float: left;
  width: 447px;
  margin-bottom: 1.6em;
}

div.cnt {
  text-align: center;
  width: 80%;
}

div.cnt-at {
  text-align: center;
  width: 80%;
  margin: 0 auto;
}

div.cnt-at95 {
  width: 95%;
  margin: 0 auto;
}

div.cnt-at100 {
  width: 100%;
  margin: 0 auto;
}

img.pht {
  display: block;
  margin-bottom: 0.5em;
}

img.flft {
  float: left;
}

img.frgt {
  float: right;
}


/* ----------↓ span ↓---------- */
span.sml {
  font-size: 90%;
}

/* ----------↓ #ANC ↓---------- */
#anc {
  padding-top: 1em;
  margin-bottom: 4em;
}

#anc ul, #anc li {
  list-style-type: none;
}

#anc ul:after {
  content: "";
  clear: both;
  display: block;
}

#anc ul {
  margin-bottom: 8px !important;
}

#anc ul li {
  margin-bottom: 0.3em;
  width: 28.5%;
}

#anc ul li a {
  padding-left: 18px;
  background: url("../image/arw_anchor.gif") no-repeat left 2px;
}

#anc ul li a:hover {
  background: url("../image/arw_anchor-on.gif") no-repeat left 2px;
}

/* ----------↓ #OVERVIEW ↓---------- */
#overview {
  margin-bottom: 4em;
}


/* ----------↓ LIST ↓---------- */
#overview ul {
  margin-left: 1em;
  margin-bottom: 2em;
}

#overview ol {
  margin-left: 1em;
  margin-bottom: 2em;
}

#overview ul.dec {
  list-style-type: decimal;
}

#overview ul.dec li {
  margin-bottom: 1em;
}

#overview ul li {
  margin-bottom: 0.3em;
}

#overview ol li {
  margin-bottom: 0.3em;
}

/*----- S-TAG -----*/
#overview ol.s-tag {
  position: relative;
  margin: 0 0 1em 1em;
  padding: 0;
}

#overview ol.s-tag li  {
  list-style: none;
  list-style-position: outside;
  margin: 0;
  padding-left: 1.25em;
  text-indent:-1.0em;
  margin-bottom: 1em;
}

#overview ol.s-tag li span {
  position: absolute;
  left: 0;
  margin: 0;
}

#overview ol.maru li  {
  list-style: none;
  list-style-position: inside;
  margin: 0;
  padding-left: 1.25em;
  text-indent: -0.5em;
  margin-bottom: 1em;
}


/* ----------↓ TABLE ↓---------- */
#overview table.treat {
  width: 100%;
  margin-bottom: 2em;
}

#overview table.treat th:first-child {
  width: 29%;
}

#overview table.treat tr {
  border-top: 1px solid #CCCCCC;
  border-left: 1px solid #CCCCCC;
}

#overview table.treat th {
  border-bottom: 1px solid #CCCCCC;
  border-right: 1px solid #FFFFFF;
}

#overview table.treat th:last-child {
  border-right: 1px solid #CCCCCC;
}

#overview table.treat td {
  border-bottom: 1px solid #CCCCCC;
  border-right: 1px solid #CCCCCC;
}


#overview table.treat th {
  background-color: #A1AFDD;
  padding: 8px 0;
  color: #FFFFFF;
  vertical-align: middle;
  white-space: nowrap;
}

#overview table.treat td.cp {
  text-align: left;
  padding: 8px 8px 8px 15px;
  background-color: #EEEEEE;
}

#overview table.treat td.ope {
  text-align: left;
  padding: 8px 8px 8px 15px;
  background-color: #FFFFFF;
}

#overview table.treat td {
  text-align: center;
  vertical-align: middle;
  padding: 9px 7px 7px 7px;
  line-height: 1.3em;
  border-top: none;
}


/* ----------↓ TABLE.chara ↓---------- */

#overview table.chara {
  width: 100%;
  margin-bottom: 0;
}

#overview table.chara tr {
  border-top: 1px solid #CCCCCC;
  border-left: 1px solid #CCCCCC;
}

#overview table.chara th, #overview table.chara td {
  border-bottom: 1px solid #CCCCCC;
  border-right: 1px solid #CCCCCC;
  vertical-align: middle;
  padding: 9px 7px 7px 7px;
  line-height: 1.3em;
  border-top: none;
}

#overview table.chara th {
  width: 20%;
  background-color: #EEEEEE;
  text-align: left;
  font-weight: normal;
  white-space: nowrap;
}

/* ----------↓ TABLE.oral_surgery01 ↓---------- */

#overview table.oral_surgery01 {
  width: 100%;
  margin-bottom: 0;
}

#overview table.oral_surgery01 tr {
  border-top: 1px solid #CCCCCC;
  border-left: 1px solid #CCCCCC;
}

#overview table.chara th, #overview table.oral_surgery01 td {
  border-bottom: 1px solid #CCCCCC;
  border-right: 1px solid #CCCCCC;
  vertical-align: middle;
  padding: 10px;
  line-height: 1.3em;
  border-top: none;
}

#overview table.oral_surgery01 td:first-child {
  width: 20%;
  background-color: #EEEEEE;
  text-align: left;
  font-weight: normal;
  white-space: nowrap;
}

#overview table.oral_surgery01 ul{
  margin: 5px 0;
}

/* ----------↓ TABLE.oral_surgery02 ↓---------- */

#overview table.oral_surgery02 {
  border: 1px solid #CCC;
  width: 100%;
  margin-bottom: 0;
  font-size: 120%;
}

#overview table.oral_surgery02 tr td{
  text-align: center;
  border: 1px solid #CCC;
  padding: 5px;
}

.gray {
  background-color: #BBB;
}


/* ----------↓ #SCHEDULE ↓---------- */
#schedule {
  margin-bottom: 4em;
}

/* ----------↓ TABLE ↓---------- */
#schedule table {
  width: 100%;
  margin-bottom: 0.5em;
}

#schedule tr {
  border-top: 1px solid #CCCCCC;
  border-left: 1px solid #CCCCCC;
}

#schedule th {
  border-bottom: 1px solid #CCCCCC;
  border-right: 1px solid #FFFFFF;
}

#schedule th:last-child {
  border-right: 1px solid #CCCCCC;
}

#schedule td {
  border-bottom: 1px solid #CCCCCC;
  border-right: 1px solid #CCCCCC;
}

#schedule th:first-child {
  width: 20%;
}

#schedule th {
  background-color: #A1AFDD;
  padding: 8px 0;
  color: #FFFFFF;
  vertical-align: middle;
  white-space: nowrap;
}

#schedule td:first-child {
  text-align: center;
  padding: 8px 8px 8px 15px;
  background-color: #EEEEEE;
}

#schedule td {
  text-align: center;
  vertical-align: middle;
  padding: 9px 7px 7px 7px;
  line-height: 1.3em;
  border-top: none;
}

#schedule td.circle {
  background: url("../image/icon_circle.gif") no-repeat 50% center;
}

#schedule td.cross {
  background: url("../image/icon_cross.gif") no-repeat 50% center;
}

#schedule td.check {
  background: url("../image/icon_check.gif") no-repeat 50% center;
}

#schedule td.check_sp {
  background: url("../image/icon_check_sp.gif") no-repeat 50% center;
}

#schedule td.tri {
  background: url("../image/icon_tri.gif") no-repeat 50% center;
}

#schedule td.attention {
  background: url("../image/icon_attention.gif") no-repeat 50% center;
}

#schedule td.check_dbl {
  background: url("../image/icon_check_dbl.gif") no-repeat 50% center;
}

#schedule td.check_stm {
  background: url("../image/icon_check_cln.gif") no-repeat 50% center;
}


/* ----------↓ DL/DT/DD ↓---------- */
#schedule dl, dt, dd {
  box-sizing: border-box;
}

#schedule dl {
  border-bottom: 1px solid #CCCCCC;
}

#schedule dt, dd {
  border-top: 1px solid #CCCCCC;
  line-height: 1.3em;
  vertical-align: middle;
  padding: 13px;
}

#schedule dd {
  padding-left: 50px;
}

#schedule dt {
  white-space: nowrap;
  font-weight: normal;
  background-color: #F6F6F6;
  punctuation-trim: adjacent;
  text-align: left;
  width: 30%;
  float: left;
}




/* ----------↓ LIST ↓---------- */
#main ul, #main ol {
  margin-bottom: 2em;
}

#main ul li, #main ol li {
  margin-left: 16px;
}

#main ol.dec li {
  margin-bottom: 1em;
}


/* ----------↓ #SCHEDULE ↓---------- */
#schedule ul li {
  list-style-type: none;
  text-indent: 18px;
  margin-left: 10px;
}

#schedule ul li.dbl {
  text-indent: 30px;
}

#schedule ul li.circle {
  background: url("../image/icon_circle.gif") left 3px no-repeat;
}

#schedule ul li.cross {
  background: url("../image/icon_cross.gif") left 3px no-repeat;
}

#schedule ul li.check {
  background: url("../image/icon_check.gif") left 3px no-repeat;
}

#schedule ul li.check_sp {
  background: url("../image/icon_check_sp.gif") left 3px no-repeat;
}

#schedule ul li.tri {
  background: url("../image/icon_tri.gif") left 3px no-repeat;
}

#schedule ul li.attention {
  background: url("../image/icon_attention.gif") left 3px no-repeat;
}

#schedule ul li.check_dbl {
  background: url("../image/icon_check_dbl.gif") left 3px no-repeat;
}

#schedule ul li.check_stm {
  background: url("../image/icon_check_cln.gif") no-repeat 50% center;
}





/* ----------↓ #DOCTOR ↓---------- */
#doctor {
  margin-bottom: 4em;
}

#doctor ul li {
  list-style-type: none;
  margin-left: 10px;
}

/* ----------↓ TABLE ↓---------- */
#doctor table {
  width: 100%;
  margin-bottom: 0.5em;
}

#doctor tr {
  border-top: 1px solid #CCCCCC;
  border-left: 1px solid #CCCCCC;
}

#doctor th {
  border-bottom: 1px solid #CCCCCC;
  border-right: 1px solid #FFFFFF;
}

#doctor th:last-child {
  border-right: 1px solid #CCCCCC;
}

#doctor td {
  border-bottom: 1px solid #CCCCCC;
  border-right: 1px solid #CCCCCC;
}

#doctor th {
  background-color: #A1AFDD;
  padding: 8px 0;
  color: #FFFFFF;
  vertical-align: middle;
  white-space: nowrap;
}

#doctor td {
  text-align: center;
  vertical-align: middle;
  padding: 9px 7px 7px 7px;
  line-height: 1.3em;
}

#doctor th:first-child {
  width: auto;
}

#doctor td:first-child {
  text-align: center;
  padding: 9px 7px 7px 7px;
  background-color: #FFFFFF;
}

#doctor td.cp {
  background-color: #EEEEEE;
}

#doctor td.nm {
  width: 13.5% !important;
  white-space: nowrap;
}


/* ----------↓ #CONTACT ↓---------- */
#contact {
  margin-bottom: 4em;
}

/* ----------↓ TABLE ↓---------- */
#contact table {
  width: 100%;
  margin-bottom: 4em;
}

#contact table tr {
  border-top: 1px solid #CCCCCC;
}

#contact table tr:last-child {
  border-bottom: 1px solid #CCCCCC;
}

#contact table th, table td {
  line-height: 1.3em;
  vertical-align: middle;
  padding: 13px;
}

#contact table th {
  white-space: nowrap;
  font-weight: normal;
  background-color: #F6F6F6;
  punctuation-trim: adjacent;
  text-align: left;
  width: 30%;
}


/* ----------↓ #COST ↓---------- */
#cost {
  margin-bottom: 4em;
}

/* ----------↓ TABLE ↓---------- */
#cost table {
  width: 100%;
  margin-bottom: 4em;
}

#cost table tr {
  border-top: 1px solid #CCCCCC;
}

#cost table tr:last-child {
  border-bottom: 1px solid #CCCCCC;
}

#cost table th, table td {
  line-height: 1.3em;
  vertical-align: middle;
  padding: 13px;
}

#cost table th {
  white-space: nowrap;
  font-weight: normal;
  background-color: #F6F6F6;
  punctuation-trim: adjacent;
  text-align: left;
  width: 30%;
}

#cost table tr.sub th, table tr.sub td {
  border-top: 2px solid #FFFFFF;
  line-height: 1.3em;
}

#cost table .list{
  width: 50%;
}

/* ----------↓ SPAN ↓---------- */
#cost span.cost-lft {
  width: 300px;
  float: left;
}


/* ----------↓ #STAFF ↓---------- */
#staff {
  margin-bottom: 4em;
}

/* ----------↓ TABLE ↓---------- */
#staff table {
  width: 100%;
  margin-bottom: 4em;
}

#staff table.mid {
  margin-bottom: 2em;
}

#staff th:first-child {
  width: 15%;
}

#staff th:last-child {
  width: 70%;
}

#staff tr {
  border-top: 1px solid #CCCCCC;
  border-left: 1px solid #CCCCCC;
}

#staff th {
  border-bottom: 1px solid #CCCCCC;
  border-right: 1px solid #FFFFFF;
}

#staff th:last-child {
  border-right: 1px solid #CCCCCC;
}

#staff td {
  border-bottom: 1px solid #CCCCCC;
  border-right: 1px solid #CCCCCC;
}

#staff th {
  background-color: #A1AFDD;
  padding: 8px 0;
  color: #FFFFFF;
  vertical-align: middle;
  white-space: nowrap;
}

#staff td {
  text-align: center;
  vertical-align: middle;
  padding: 9px 7px 7px 7px;
  line-height: 1.3em;
  border-top: none;
}

#staff td:first-child {
  background-color: #EEEEEE;
  white-space: nowrap;
}

#staff td:last-child {
  text-align: left;
  padding: 8px 8px 8px 15px;
}

#staff td.wt {
  background-color: #FFFFFF;
}


/* ----------↓ #STAFF2 ↓---------- */
#staff2 {
  margin-bottom: 4em;
}

/* ----------↓ TABLE ↓---------- */
#staff2 table {
  width: 100%;
}

#staff2 td {
  text-align: left;
  vertical-align: top;
  padding: 1px;
  line-height: 1.7em;
}

#staff2 .box{
  border: 2px solid #CCCCCC;
  padding: 20px 15px;
}

#staff2 .title {
    text-align: right;
    width: 12%;
    white-space: nowrap;
    padding: 0 10px;
}

#staff2 .title2 {
    text-align: right;
    white-space: nowrap;
    padding: 0 10px;
    font-size: 85%;
    line-height:110%;
}



/* ----------↓ #STAFF-C4 ↓---------- */
#staff-c4 {
  margin-bottom: 4em;
}

/* ----------↓ TABLE ↓---------- */
#staff-c4 table {
  width: 100%;
  margin-bottom: 4em;
}

#staff-c4 th:first-child {
  width: 15%;
}

#staff-c4 th:last-child {
  width: 60%;
}

#staff-c4 tr {
  border-top: 1px solid #CCCCCC;
  border-left: 1px solid #CCCCCC;
}

#staff-c4 th {
  border-bottom: 1px solid #CCCCCC;
  border-right: 1px solid #FFFFFF;
}

#staff-c4 th:last-child {
  border-right: 1px solid #CCCCCC;
}

#staff-c4 td {
  border-bottom: 1px solid #CCCCCC;
  border-right: 1px solid #CCCCCC;
}

#staff-c4 th {
  background-color: #A1AFDD;
  padding: 8px 0;
  color: #FFFFFF;
  vertical-align: middle;
  white-space: nowrap;
}

#staff-c4 td {
  text-align: center;
  vertical-align: middle;
  padding: 9px 7px 7px 7px;
  line-height: 1.3em;
  border-top: none;
}

#staff-c4 td:first-child {
  background-color: #EEEEEE;
}

#staff-c4 td:last-child {
  text-align: left;
  padding: 8px 8px 8px 15px;
}

#staff-c4 td.wt {
  background-color: #FFFFFF;
}

#staff-c4 td.w-15 {
  width: 15%;
}


/* ----------↓ #MAP ↓---------- */
#map {
  text-align: center;
  margin: 0 auto 4em auto;
  width: 75%;
}

#map p.floor {
  text-align: left;
  font-size: 150%;
}

/* ----------↓ #SELF_MEDICATION↓---------- */
#self_medication{
  margin-bottom: 4em;
}

/* ----------↓ LIST ↓---------- */
#self_medication ul {
  margin-left: 1em;
  margin-bottom: 2em;
}

/* ----------↓ #RESEARCH ↓---------- */
#research {
  margin-bottom: 4em;
}

/* ----------↓ TABLE ↓---------- */
#research table {
  width: 100%;
  margin-bottom: 4em;
}

#research table tr {
  border-top: 1px solid #CCCCCC;
}

#research table tr:last-child {
  border-bottom: 1px solid #CCCCCC;
}

#research table th, table td {
  line-height: 1.3em;
  vertical-align: middle;
  padding: 13px;
}

#research table th {
  white-space: nowrap;
  font-weight: normal;
  background-color: #F6F6F6;
  punctuation-trim: adjacent;
  text-align: left;
  width: 30%;
}


/* ----------↓ TABLE ↓---------- */
#main table.ins {
  width: 100%;
  margin-bottom: 2em;
}

#main table.last {
  margin-bottom: 4em !important;
}

#main table.ins tr {
  border-top: 1px solid #CCCCCC;
  border-left: 1px solid #CCCCCC;
}

#main table.ins th {
  border-bottom: 1px solid #CCCCCC;
  border-right: 1px solid #FFFFFF;
}

#main table.ins th:last-child {
  border-right: 1px solid #CCCCCC;
}

#main table.ins td {
  border-bottom: 1px solid #CCCCCC;
  border-right: 1px solid #CCCCCC;
}

#main table.ins th {
  background-color: #A1AFDD;
  padding: 8px 0;
  color: #FFFFFF;
  vertical-align: middle;
  white-space: nowrap;
}

#main table.ins td {
  vertical-align: middle;
  padding: 9px 7px 7px 7px;
  line-height: 1.3em;
  border-top: none;
}

#main table.ins td.cp {
  text-align: center;
  background-color: #EEEEEE;
}

#main table.ins td.cntr {
  text-align: center;
}

#main table.ins td.circle {
  background: url("../image/icon_circle.gif") no-repeat 50% center;
}

#main table.ins td.cross {
  background: url("../image/icon_cross.gif") no-repeat 50% center;
}

#main table.ins td.check {
  background: url("../image/icon_check.gif") no-repeat 50% center;
}

#main table.ins td.check_sp {
  background: url("../image/icon_check_sp.gif") no-repeat 50% center;
}

#main table.ins td.tri {
  background: url("../image/icon_tri.gif") no-repeat 50% center;
}

#main table.ins td.attention {
  background: url("../image/icon_attention.gif") no-repeat 50% center;
}

/* ----------↓ TABLE ↓---------- */
#main table.col2 {
  width: 100%;
  margin-bottom: 4em;
}

#main table.col2 tr {
  border-top: 1px solid #CCCCCC;
}

#main table.col2 tr:last-child {
  border-bottom: 1px solid #CCCCCC;
}

#main table.col2 th, table td {
  line-height: 1.3em;
  vertical-align: middle;
  padding: 13px;
}

#main table.col2 th {
  white-space: nowrap;
  font-weight: normal;
  background-color: #F6F6F6;
  punctuation-trim: adjacent;
  text-align: left;
  width: 30%;
}


/* ----------↓ LIST ↓---------- */

#main ul.lnk, #main ul.lnk li {
  list-style-type: none;
  margin-bottom: 0;
}

#main ul.lnk li {
  background: url("../image/icon_lkbox.gif") no-repeat 10px 6px;
  margin-left: 1em;
  padding-left: 2em;
}
