@charset "utf-8";
/*////////////////////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////////////

common

////////////////////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////////////*/
body {
  word-wrap: break-word;
  word-break: break-all;
}
.sec_title {
  font-size: 24px;
  font-weight: bold;
  border-bottom: 1px solid #3C2D1E;
}
main section .sub_title, main section .sub_title:not(.no-style), main section h4:not(.no-style) {
  font-size: 20px;
  font-weight: bold;
  border-left: 2px solid #3C2D1E;
  padding-left: 20px;
  background-color: transparent;
  background: transparent;
  color: #111;
  margin: 0 0 30px;
  line-height: 1.3;
}
@media screen and (max-width: 767px) {
  main section .sub_title, main section .sub_title:not(.no-style), main section h4:not(.no-style) {
    font-size: 2rem;
    padding-left: 2.5rem;
    margin: 0 0 2.5rem;
  }
}

@media screen and (max-width: 767px) {
  body main {
    padding: 0;
    margin-top: 3rem;
  }
}
.case_title {
  margin-top: 50px;
}
@media screen and (max-width: 767px) {
  .case_title {
    margin-top: 6rem;
  }
}
.case_title dt {
  font: 46px/0.9 var(--en-font);
  color: var(--sub-color01);
  text-align: center;
}
@media screen and (max-width: 767px) {
  .case_title dt {
    font-size: 10vw;
  }
}
.case_title dd {
  font-size: 24px;
  font-weight: bold;
  text-align: center;
  margin-top: 10px;
}
@media screen and (max-width: 767px) {
  .case_title dd {
    font-size: 2.2rem;
    margin-top: 2.5rem;
  }
}
.items.before_after .imgs {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  .items.before_after .imgs {
    margin-top: 2.5rem;
  }
}
@media screen and (min-width: 767px), print {
  .items.before_after .imgs > * {
    width: 48%;
  }
}
.items.before_after .imgs .img {
  margin: 0;
  position: relative;
}
@media screen and (max-width: 767px) {
  .items.before_after .imgs .img + .img {
    margin-top: 2.5rem;
  }
}
.items.before_after .img figcaption {
  position: absolute;
  bottom: 0px;
  left: 0;
  background-color: #FFFFFF;
  color: var(--sub-color01);
  text-align: center;
  font: 22px/0.9 var(--en-font);
  width: 90px;
  border-radius: 90px;
  height: 90px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  letter-spacing: -0.04em;
}
@media screen and (max-width: 767px) {
  .items.before_after .img figcaption {
    width: 20vw;
    border-radius: 20vw;
    height: 20vw;
    font-size: 5vw;
  }
}
.items.before_after .img + .img figcaption {
  background-color: #FF2201;
  color: #FFFFFF;
}
.items.before_after .details-items-wrap {
  padding: 40px 60px;
  background-color: #F2F2F2;
  justify-content: space-between;
  align-items: center;
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  .items.before_after .details-items-wrap {
    padding: 1.5rem 2.5rem 1rem;
    margin-top: 2.5rem;
    display: block;
  }
}
.items.before_after .details-items {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  /*align-items: center;*/
}
@media screen and (max-width: 767px) {
  .items.before_after .details-items {
    align-items: flex-start;
  }
}
.items.before_after .details-items dt {
  width: 23.5%;
  color: #FF2201;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  padding: 10px 0;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .items.before_after .details-items dt {
    width: 38%;
  }
}
.items.before_after .details-items dt.price {
  border-top: 1px solid #FFF;
}
.items.before_after .details-items dt:before {
  content: "";
  display: block;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center center;
}
.items.before_after .details-items dt.count:before {
  background-image: url(../../images/treatment/implant/icon_teach01.svg);
  width: 14px;
  height: 20px;
  margin-right: 10px;
}
.items.before_after .details-items dt.price:before {
  background-image: url(../../images/treatment/implant/icon_calculator01.svg);
  width: 18px;
  height: 22px;
  margin-right: 5px;
}
.items.before_after .details-items dt.type:before {
  background-image: url(../../images/treatment/implant/icon_menu01.svg);
  width: 15px;
  height: 20px;
  margin-right: 10px;
}
.items.before_after .details-items dt.age:before {
  background-image: url(../../images/treatment/implant/icon_heart01.svg);
  width: 14px;
  height: 12px;
  margin-right: 10px;
}
.items.before_after .details-items dt.sex:before {
  background-image: url(../../images/treatment/implant/icon_sex01.svg);
  width: 14px;
  height: 20px;
  margin-right: 10px;
}
.items.before_after .details-items dt.background:before {
  background-image: url(../../images/treatment/implant/icon_menu01.svg);
  width: 15px;
  height: 21px;
  margin-right: 10px;
}
.items.before_after .details-items dt.period:before {
  background-image: url(../../images/treatment/implant/icon_calendar01.svg);
  width: 14px;
  height: 16px;
  margin-right: 10px;
}
.items.before_after .details-items dt.risk:before {
  background-image: url(../../images/treatment/implant/icon_risk01.svg);
  width: 14px;
  height: 16px;
  margin-right: 10px;
}
.items.before_after .details-items dd {
  padding: 10px 0;
}
.items.before_after .details-items dt.price + dd {
  border-top: 1px solid #FFF;
}
.items.before_after .details-items dt.type, .items.before_after .details-items dt.type + dd {
  border-top: 1px solid #FFF;
}
.schedule-tbl {
  border: 1px solid #111;
  background-color: #fff;
}
@media screen and (max-width: 767px) {
  .schedule-tbl {
    display: flex;
    flex-wrap: wrap;
  }
}
@media screen and (max-width: 767px) {
  .schedule-tbl tr, .schedule-tbl th, .schedule-tbl td {
    display: block;
  }
}
@media screen and (max-width: 767px) {
  .schedule-tbl thead {
    width: 38%;
  }
}
.schedule-tbl thead th {
  text-align: center;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .schedule-tbl thead th:first-child, .schedule-tbl tbody th:first-child {
    padding: 0;
    height: 22vw;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    font-size: 4vw;
  }
}
.schedule-tbl thead td {
  text-align: center;
  font-weight: bold;
}
.schedule-tbl tbody th, main section table:not(.no-style) tbody th {
  text-align: center;
  border: 1px solid #111;
  padding: .5em 1em;
  color: #111;
}
@media screen and (max-width: 767px) {
  .schedule-tbl tbody {
    width: 62%;
  }
}
main .schedule-tbl tbody td, main section .schedule-tbl tbody td, main section table:not(.no-style) tbody td + td {
  text-align: center;
  color: #FF2201;
  border: 1px solid #111;
}
@media screen and (max-width: 767px) {
  main section .schedule-tbl thead th, main .schedule-tbl tbody td, main section .schedule-tbl tbody td, main section table:not(.no-style) tbody td + td {
    border-top: none;
    height: 20vw;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
  }
  main section .schedule-tbl {
    border-top: 1px solid #111;
    border-bottom: 1px solid #111;
  }
  .schedule-tbl tbody th, main section table:not(.no-style) tbody th {
    border-top: none;
    color: #111;
  }
  main section .schedule-tbl thead th {
    border-right: none;
    border-top: none;
    border-left: none;
  }
  .schedule-tbl thead th:last-child, .schedule-tbl tbody td:last-child {
    border-bottom: none;
  }
  main section .schedule-tbl tbody td {
    border-top: none;
    color: #FF2201;
    border-left: none;
  }
  main section table:not(.no-style) tbody th, main section .schedule-tbl tbody td, main section table:not(.no-style) tbody td + td {
    border-right: none;
  }
  main section .schedule-tbl tbody td, main section table:not(.no-style) tbody td + td {
    border-left: 1px solid #111 !important;
  }
}
main section.schedule ul li + li {
  margin-top: 1rem;
}
/*#######################################################

schedule

#######################################################
*/
body#example section.schedule, body#price section.schedule, body#flow section.schedule, body#facility section.schedule, body#doctor section.schedule {
  padding: 80px 0;
  background-color: #fff;
  margin-top: 80px;
}
body#flow section.schedule, body#facility section.schedule, body#example section.schedule, body#doctor section.schedule {
  margin-top: 0;
}
@media screen and (max-width: 767px) {
  body#example section.schedule, body#price section.schedule, body#flow section.schedule, body#facility section.schedule, body#doctor section.schedule {
    padding: 6rem 2.5rem;
    margin-top: 6rem;
  }
}
body#example section.schedule h2:first-of-type, body#price section.schedule h2:first-of-type, body#flow section.schedule h2:first-of-type, body#facility section.schedule h2:first-of-type, body#doctor section.schedule h2:first-of-type {
  margin-top: 0px;
}
@media screen and (max-width: 767px) {
  body#example section.schedule .wrap, body#price section.schedule .wrap, body#flow section.schedule .wrap, body#facility section.schedule .wrap, body#doctor section.schedule .wrap {
    padding: 0;
  }
}
/*////////////////////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////////////

implant

////////////////////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////////////*/
/*#######################################################

about

#######################################################
*/
body#implant section.about {
  padding-bottom: 80px;
}
@media screen and (max-width: 767px) {
  body#implant section.about {
    padding: 0 2.5rem;
  }
}
@media screen and (max-width: 767px) {
  body#implant section.about .wrap {
    padding: 0;
  }
}
body#implant section.about h2:first-of-type {
  margin-top: 0px;
}
body#implant section.about .items {
  display: flex;
  flex-wrap: wrap;
}
@media screen and (min-width: 767px), print {
  body#implant section.about .items {
    justify-content: space-between;
  }
}
@media screen and (min-width: 767px), print {
  body#implant section.about .items > * {
    width: 48%;
  }
}
@media screen and (max-width: 767px) {
  body#implant main section.about .items p {
    margin-bottom: 2rem;
  }
}
body#implant section.about .desc {
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  body#implant section.about .desc {
    margin: 2rem 0 5rem;
  }
}
body#implant section.about .img {
  margin-bottom: 0px;
}
body#implant section.about .btn-wrap {
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  body#implant section.about .btn-wrap {
    margin-top: 6rem;
  }
}
body#implant section.about .btn-wrap .btn {
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  body#implant section.about .btn-wrap .btn {
    width: auto;
    margin: 0 auto;
  }
}
/*#######################################################

philosophy

#######################################################
*/
body#implant section.philosophy {
  
  background-repeat: no-repeat;
  padding: 80px 0;
  margin: 0;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  body#implant section.philosophy {
    padding: 3rem 0;
    margin-top: 3rem;
  }
}
body#implant section.philosophy h2:first-of-type {
  margin-top: 0px;
}
@media screen and (max-width: 767px) {
  body#implant main section.philosophy h2:first-of-type {
    margin-top: 0px;
    margin-bottom: 2rem;
  }
}
@media screen and (min-width: 767px), print {
  body#implant section.philosophy .text {
    text-align:left;
  }
}
body#implant section.philosophy .btn {
  margin: 50px auto 0;
}
@media screen and (max-width: 767px) {
  body#implant section.philosophy .btn {
    margin: 5rem 0 0;
    width: auto;
  }
}
/*#######################################################

about-implant

#######################################################
*/
@media screen and (max-width: 767px) {
  body#implant main section.about-implant {
    margin-top: 5rem;
    padding: 0 2.5rem;
  }
}
@media screen and (max-width: 767px) {
  body#implant main section.about-implant .wrap {
    padding: 0;
  }
}
@media screen and (max-width: 767px) {
  body#implant main section.about-implant h2:not(.no-style) {
    margin: 0 0 2.5rem;
  }
}
body#implant section.about-implant .items {
  display: flex;
  flex-wrap: wrap;
}
@media screen and (min-width: 767px), print {
  body#implant section.about-implant .items {
    justify-content: space-between;
  }
}
@media screen and (min-width: 767px), print {
  body#implant section.about-implant .items > * {
    width: 48%;
  }
}
body#implant section.about-implant .desc {
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  body#implant section.about-implant .desc {
    margin-top: 2.5rem;
  }
}
body#implant section.about-implant .desc p:last-child {
  margin-bottom: 0;
}
body#implant section.about-implant .items .img {
  margin-bottom: 0;
}
/*#######################################################

reason

#######################################################
*/
body#implant section.reason {
  padding: 80px 0;
  background-color: #FFF;
}
@media screen and (max-width: 767px) {
  body#implant section.reason {
    padding: 5rem 2.5rem;
    margin-top: 5rem;
  }
}
@media screen and (max-width: 767px) {
  body#implant section.reason .wrap {
    padding: 0;
  }
}
@media screen and (max-width: 767px) {
  body#implant main section.reason p:last-child {
    margin-bottom: 0;
  }
}
body#implant section.reason h2:first-of-type {
  margin-top: 0px;
}
@media screen and (max-width: 767px) {
  body#implant section.reason h2:first-of-type {
    margin-bottom: 2.5rem;
  }
}
body#implant section.reason .lead {
  text-align: center;
}
@media screen and (max-width: 767px) {
  body#implant section.reason .lead {
    margin-bottom: 0;
  }
}
body#implant section.reason .items {
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  body#implant section.reason .items {
    margin-top: 5rem;
  }
}
body#implant section.reason .items > li {
  position: relative;
}
body#implant section.reason .items > li + li {
  margin-top: 50px;
}
@media screen and (max-width: 767px) {
  body#implant section.reason .items > li + li {
    margin-top: 2.5rem;
  }
}
body#implant section.reason .items > li:before {
  content: "";
  display: block;
  position: absolute;
  margin: auto;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  width: 46%;
  top: 0;
  bottom: 0;
  right: 0;
  border-top-left-radius: 500px;
  border-bottom-left-radius: 500px;
  height: 100%;
}
@media screen and (max-width: 767px) {
  body#implant section.reason .items > li:before {
    position: relative;
    height: 30rem;
    width: 30rem;
    margin: auto 0px auto auto;
    background-position: center right;
    right: -2.5rem;
  }
}
@media screen and (min-width: 767px), print {
  body#implant section.reason .items > li:nth-child(even):before {
    right: auto;
    left: 0;
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    border-top-right-radius: 500px;
    border-bottom-right-radius: 500px;
  }
}
body#implant section.reason .items > li:nth-child(1):before {
  background-image: url(../../images/treatment/implant/pic_implant03.png);
}
body#implant section.reason .items > li:nth-child(2):before {
  background-image: url(../../images/treatment/implant/pic_implant04.png);
}
body#implant section.reason .items > li:nth-child(3):before {
  background-image: url(../../images/treatment/implant/pic_implant05.png);
}
body#implant section.reason .items > li:nth-child(4):before {
  background-image: url(../../images/treatment/implant/pic_implant06.png);
}
body#implant section.reason .items > li:nth-child(5):before {
  background-image: url(../../images/treatment/implant/pic_implant07.png);
}
@media screen and (min-width: 767px), print {
  body#implant section.reason .items > li .inner {
    margin-right: 50%;
  }
}
@media screen and (min-width: 767px), print {
  body#implant section.reason .items > li:nth-child(even) .inner {
    margin-right: 0;
    margin-left: 50%;
  }
}
body#implant section.reason .title dt {
  font: 90px/0.9 var(--en-font);
  color: var(--sub-color01);
}
@media screen and (max-width: 767px) {
  body#implant section.reason .title dt {
    font-size: 6rem;
    margin-top: 2.5rem;
  }
}
body#implant section.reason .title dd {
  font-size: 24px;
  font-weight: bold;
  border-bottom: 1px solid #111111;
  margin: 30px 0px 20px;
  padding-bottom: 20px;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  body#implant section.reason .title dd {
    font-size: 2.2rem;
    margin: 1rem 0 2.5rem;
    padding-bottom: 1rem;
  }
}
body#implant main section.reason h3:not(.no-style) {
  border: none;
  margin: 0;
  padding: 0;
  font-size: 2.2rem;
}
/*#######################################################

price

#######################################################
*/
body#implant section.price .items {
  display: flex;
  flex-wrap: wrap;
  margin-top: 70px !important;
}
@media screen and (max-width: 767px) {
  body#implant section.price .items {
    margin-top: 2.5rem !important;
  }
}
body#implant section.price .items .img {
  margin-bottom: 30px;
}
@media screen and (max-width: 767px) {
  body#implant section.price .items .img {
    margin-bottom: 2.5rem;
  }
}
body#implant section.price .items > li {
  margin-bottom: 40px;
}
@media screen and (min-width: 767px), print {
  body#implant section.price .items > li {
    width: 48%;
  }
}
@media screen and (max-width: 767px) {
  body#implant section.price .items > li {
    margin-bottom: 6rem;
  }
}
@media screen and (min-width: 767px), print {
  body#implant section.price .items > li:nth-child(odd) {
    margin-right: 4%;
  }
}
body#implant section.price .details-items {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
}
@media screen and (max-width: 767px) {
  body#implant section.price .details-items {
    display: block;
  }
}
body#implant section.price .details-items dt {
  display: flex;
  flex-wrap: wrap;
  color: #FF2201;
  font-weight: bold;
  align-items: center;
  width: 32%;
  border-top: 1px solid #F2F2F2;
  padding: 10px 0;
}
@media screen and (max-width: 767px) {
  body#implant section.price .details-items dt {
    width: auto;
  }
}
body#implant section.price .details-items dt:before {
  content: "";
  display: block;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center center;
  margin-right: 10px;
}
body#implant section.price .details-items dt.menu:before {
  background-image: url(../../images/treatment/implant/icon_menu01.svg);
  width: 15px;
  height: 20px;
}
body#implant section.price .details-items dt.price:before {
  background-image: url(../../images/treatment/implant/icon_calculator01.svg);
  width: 18px;
  height: 22px;
}
body#implant section.price .details-items dd {
  width: 68%;
  border-top: 1px solid #F2F2F2;
  padding: 10px 0;
}
@media screen and (max-width: 767px) {
  body#implant section.price .details-items dd {
    width: auto;
  }
}
body#implant section.price .btn-wrap {
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  body#implant section.price .btn-wrap {
    margin-top: 0;
  }
}
body#implant section.price .btn-wrap .btn {
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  body#implant section.price .btn-wrap .btn {
    width: auto;
    margin: 0 auto;
  }
}
/*#######################################################

case

#######################################################
*/
body#implant section.case .lead {
  text-align: center;
}
@media screen and (max-width: 767px) {
  body#implant main section.case .lead {
    margin-bottom: 0;
  }
}
body#implant section.case h2:first-of-type {
  margin-top: 0px;
}
body#implant section.case .details-items-wrap {
  display: flex;
  flex-wrap: wrap;
}
@media screen and (max-width: 767px) {
  body#implant section.case .details-items-wrap {
    display: block;
  }
}
body#implant section.case .details-items-wrap .desc {
  width: 46%;
}
@media screen and (max-width: 767px) {
  body#implant section.case .details-items-wrap .desc {
    width: auto;
  }
}
body#implant section.case .details-items {
  width: 46%;
}
@media screen and (max-width: 767px) {
  body#implant section.case .details-items {
    width: auto;
    margin-top: 1.5rem;
  }
}
body#implant section.case .details-items dd {
  width: 76.5%;
}
@media screen and (max-width: 767px) {
  body#implant section.case .details-items dd {
    width: 62%;
  }
}
body#implant section.case .btn-wrap {
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  body#implant section.case .btn-wrap {
    margin-top: 6rem;
  }
}
body#implant section.case .btn-wrap .btn {
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  body#implant section.case .btn-wrap .btn {
    width: auto;
  }
}
/*#######################################################

flow

#######################################################
*/
@media screen and (min-width: 767px), print {
  body#implant section.flow .items {
    margin: 0 auto;
    width: 500px;
  }
}
body#implant section.flow .items > li {
  display: flex;
  flex-wrap: wrap;
}
body#implant section.flow .items .step {
  font: 40px/0.9 var(--en-font);
  color: var(--sub-color01);
  width: 36%;
  position: relative;
}
@media screen and (max-width: 767px) {
  body#implant section.flow .items .step {
    font-size: 2rem;
    padding-left: 10vw;
    padding-top: 0.5vw;
  }
}
body#implant section.flow .items .step:before, body#implant section.flow .items .step:after {
  content: "";
  display: block;
  position: absolute;
  background-color: #FF2201;
  top: 0;
}
body#implant section.flow .items .step:before {
  width: 20px;
  border-radius: 20px;
  height: 20px;
  right: 30px;
}
@media screen and (max-width: 767px) {
  body#implant section.flow .items .step:before {
    width: 5vw;
    border-radius: 5vw;
    height: 5vw;
    left: 0;
    right: auto;
  }
}
body#implant section.flow .items .step:after {
  width: 1px;
  height: 100%;
  right: 40px;
}
@media screen and (max-width: 767px) {
  body#implant section.flow .items .step:after {
    right: auto;
    left: 2.5vw;
  }
}
body#implant section.flow .items li:last-child .step:after {
  display: none;
}
body#implant section.flow .items .text-wrap {
  padding-bottom: 40px;
  width: 64%;
}
@media screen and (max-width: 767px) {
  body#implant section.flow .items .text-wrap {
    padding-bottom: 6rem;
  }
}
body#implant section.flow .items .text {
  font-size: 18px;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  body#implant section.flow .items .text {
    font-size: 2.2rem;
    line-height: 1.5;
  }
}
body#implant section.flow .items .data-items {
  display: flex;
  flex-wrap: wrap;
  margin-top: 20px;
}
@media screen and (max-width: 767px) {
  body#implant section.flow .items .data-items {
    margin-top: 2.5rem;
    display: block;
  }
}
body#implant section.flow .items .data-items dt, body#implant section.flow .items .data-items dd {
  padding: 6px 10px 3px 10px;
  border: 1px solid #111111;
  line-height: 1.3;
  font-size: 12px;
}
@media screen and (max-width: 767px) {
  body#implant section.flow .items .data-items dt, body#implant section.flow .items .data-items dd {
    text-align: center;
  }
}
body#implant section.flow .items .data-items dt {
  background-color: #111111;
  color: #FFFFFF;
}
body#implant section.flow .btn-wrap {
  margin-top: 50px;
}
@media screen and (max-width: 767px) {
  body#implant section.flow .btn-wrap {
    margin-top: 0;
  }
}
body#implant section.flow .btn {
  margin: 0 auto;
  width: 29rem;
}
@media screen and (max-width: 767px) {
  body#implant section.flow .btn {
    margin: 0;
    width: auto;
  }
}
/*#######################################################

faq

#######################################################
*/
body#implant section.faq .items {
  padding: 40px;
  background-color: #F9F9F9;
}
@media screen and (max-width: 767px) {
  body#implant section.faq .items {
    padding: 2.5rem;
  }
}
body#implant section.faq .items > li + li {
  margin-top: 40px;
  border-top: 1px solid #111;
  padding-top: 40px;
}
@media screen and (max-width: 767px) {
  body#implant section.faq .items > li + li {
    margin-top: 2.5rem;
    padding-top: 2.5rem;
  }
}
body#implant section.faq .items .title {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
@media screen and (max-width: 767px) {
  body#implant section.faq .items .title {
    display: block;
  }
}
body#implant section.faq .items .icon {
  width: 40px;
  height: 40px;
  background-color: #FFFFFF;
  color: #FF2201;
  font: 30px/0.9 var(--en-font);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
}
body#implant section.faq .items .title .icon {
  background-color: #FF2201;
  color: #FFFFFF;
}
@media screen and (max-width: 767px) {
  body#implant section.faq .items .icon {
    width: 12vw;
    height: 12vw;
    margin: 0 auto;
    font-size: 8vw;
  }
}
body#implant section.faq .items .title dd {
  width: 90%;
  margin-left: auto;
  font-weight: bold;
  font-size: 18px;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  body#implant section.faq .items .title dd {
    font-size: 2.2rem;
    width: auto;
    margin-top: 2.5rem;
  }
}
body#implant section.faq .items .text-wrap {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  margin-top: 20px;
}
@media screen and (max-width: 767px) {
  body#implant section.faq .items .text-wrap {
    display: block;
  }
}
body#implant section.faq .items .text {
  width: 90%;
  margin-left: auto;
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  body#implant section.faq .items .text {
    width: auto;
    margin-top: 2.5rem;
    line-height: 1.5;
  }
}
/*#######################################################

schedule

#######################################################
*/
/*#######################################################

access

#######################################################
*/
body#implant section.access .map {
  height: 500px;
}
@media screen and (max-width: 767px) {
  body#implant section.access .map {
    height: 70vw;
  }
}
body#implant section.access .map iframe {
  width: 100%;
  height: 100%;
  vertical-align: bottom;
}
body#implant section.access .details {
  text-align: center;
  font-size: 18px;
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  body#implant section.access .details {
    font-size: 1.6rem;
    margin-top: 2.5rem;
  }
}
body#implant section.access .details .nearest {
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  body#implant section.access .details .nearest {
    margin-top: 2.5rem;
  }
}
/*#######################################################

cta

#######################################################
*/
div.cta .items {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  text-align: center;
  margin-top: 40px;
}
@media screen and (min-width: 767px), print {
  div.cta .items > * {
    width: 48.75%;
  }
}
@media screen and (max-width: 767px) {
  div.cta .items > * {
    width: 50%;
  }
}
@media screen and (max-width: 767px) {
  div.cta .items {
    margin-top: 2.5rem;
  }
}
div.cta .items > .tel a, div.cta .items > .reserve a {
  color: #FFFFFF;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  width: 100%;
  font-size: 24px;
  font-weight: bold;
  height: 160px;
  flex-direction: column;
}
@media screen and (max-width: 767px) {
  div.cta .items > .tel a, div.cta .items > .reserve a {
    font-size: 1.6rem;
    height: 30vw;
    letter-spacing: -.02em;
  }
}
div.cta .items > .tel a {
  background-color: #111;
}
@media screen and (min-width: 767px), print {
  div.cta .items > .tel a {
    opacity: 1;
    pointer-events: none;
  }
}
div.cta .items > .reserve a {
  background-color: #FF2201;
}
div.cta .items > .tel a:before, div.cta .items > .reserve a:before {
  content: "";
  display: block;
  margin: 0 auto 20px;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center center;
}
@media screen and (max-width: 767px) {
  div.cta .items > .tel a:before, div.cta .items > .reserve a:before {
    margin-bottom: 0.5rem;
  }
}
div.cta .items > .tel a:before {
  width: 30px;
  height: 32px;
  background-image: url(../../images/treatment/implant/icon_tel01.svg);
}
@media screen and (max-width: 767px) {
  div.cta .items > .tel a:before {
    width: 7vw;
    height: 7vw;
  }
}
div.cta .items > .reserve a:before {
  width: 40px;
  height: 38px;
  background-image: url(../../images/treatment/implant/icon_reserve01.svg);
}
@media screen and (max-width: 767px) {
  div.cta .items > .reserve a:before {
    width: 7vw;
    height: 7vw;
  }
}
/*#######################################################

blog

#######################################################
*/
body#implant section.blog {
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  body#implant section.blog {
    margin-top: 6rem;
  }
}
body#implant section.blog ul li {
  border-top: solid 1px;
  border-color: rgba(47, 47, 47, .1);
  padding: 20px 0
}
body#implant section.blog ul li article {
  display: flex;
  flex-wrap: wrap
}
body#implant section.blog ul li figure {
  width: 48%;
  margin: 0 2% 0 0
}
@media screen and (max-width: 767px) {
  body#implant section.blog ul li figure {
    margin: 0;
    width: auto
  }
}
body#implant section.blog ul li figure img {
  border-radius: 10px
}
body#implant section.blog ul li .card_item_body {
  width: 50%
}
@media screen and (max-width: 767px) {
  body#implant section.blog ul li .card_item_body {
    width: auto;
    margin-top: 2.5rem;
  }
}
body#implant section.blog ul li p {
  font-size: 20px;
  font-weight: 700;
  color: #1e1e1e
}
@media screen and (max-width: 767px) {
  body#implant section.blog ul li p {
    font-size: 2.2rem;
    line-height: 1.5;
  }
}
/*////////////////////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////////////

price

////////////////////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////////////*/
/*#######################################################

price-list

#######################################################
*/
body#price section.price-list .items {
  margin-bottom: 60px;
}
@media screen and (max-width: 767px) {
	body#price section.price-list .items {
  margin-bottom: 6rem;
}

}
body#price section.price-list .items_inner + .items_inner {
  margin-top: 10px;
}
body#price section.price-list .title dl {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  border: 1px solid #111;
}
@media screen and (max-width: 767px) {
  body#price section.price-list .title dl {
    display: block;
  }
}
body#price section.price-list .title dt, body#price section.price-list .title dd {
  padding: 20px 0;
}
@media screen and (max-width: 767px) {
  body#price section.price-list .title dt, body#price section.price-list .title dd {
    padding: 0.5rem;
  }
}
body#price section.price-list .title dt {
  background-color: #111111;
  color: #FFFFFF;
  width: 28%;
  font-weight: bold;
  text-align: center;
}
@media screen and (max-width: 767px) {
  body#price section.price-list .title dt {
    width: auto;
    font-size: 2rem;
  }
}
body#price section.price-list .title dd {
  width: calc(72% - 50px)
}
@media screen and (max-width: 767px) {
  body#price section.price-list .title dd {
    padding: 2.5rem;
    width: auto;
    text-align: center;
  }
}
body#price section.price-list .text {
  background-color: #FFF;
  border: 1px solid #111;
  padding: 50px;
  border-top: none;
}
@media screen and (max-width: 767px) {
  body#price section.price-list .text {
    padding: 2.5rem;
  }
}
body#price section.price-list .text ul:last-of-type {
  margin-bottom: 0;
}
/*#######################################################

warranty

#######################################################
*/
body#price section.warranty ul {
  padding: 60px;
  background-color: #F2F2F2;
}
@media screen and (max-width: 767px) {
  body#price section.warranty ul {
    padding: 2.5rem;
  }
}
@media screen and (max-width: 767px) {
  body#price main section.warranty h3:not(.no-style) {
    margin: 6rem 0 2.5rem;
  }
}
/*#######################################################

case

#######################################################
*/
body#price section.case .details-items dt {
  width: 22%;
}
@media screen and (max-width: 767px) {
  body#price section.case .details-items dt {
    width: 38%;
  }
}
body#price section.case .details-items dd {
  width: 78%;
}
@media screen and (max-width: 767px) {
  body#price section.case .details-items dd {
    width: 62%;
  }
}
body#price section.case .btn-wrap .btn {
  margin: 50px auto 0;
}
@media screen and (max-width: 767px) {
  body#price section.case .btn-wrap .btn {
    margin: 6rem auto 0;
    width: auto;
  }
}
/*#######################################################

pay

#######################################################
*/
body#price section.pay .logos {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
body#price section.pay .logos > .logo {
  width: 18.5%;
  text-align: center;
}
body#price section.pay .logos > .logo figure {
  border: 1px solid #F2F2F2;
  height: 110px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  body#price section.pay .logos > .logo figure {
    height: 15vw;
  }
}
body#price section.pay .logos .text {
  font-size: 14px;
  margin-top: 10px;
}
@media screen and (max-width: 767px) {
  body#price section.pay .logos .text {
    font-size: 3vw;
    line-height: 1.1;
    letter-spacing: -0.03em;
    padding-top: 0.5vw;
  }
}
body#price main section.pay .logos img {
  margin: 0 auto;
  border-radius: 0;
}
body#price main section.pay .logos img.visa {
  max-width: 85px;
}
body#price main section.pay .logos img.mastercard {
  max-width: 85px;
}
body#price main section.pay .logos img.american-express {
  max-width: 70px;
}
body#price main section.pay .logos img.diners {
  max-width: 80px;
}
body#price main section.pay .logos img.jcb {
  max-width: 80px;
}
@media screen and (max-width: 767px) {
  body#price main section.pay .logos img.visa {
    max-width: 60%;
  }
  body#price main section.pay .logos img.mastercard {
    max-width: 70%;
  }
  body#price main section.pay .logos img.american-express {
    max-width: 60%;
  }
  body#price main section.pay .logos img.diners {
    max-width: 80%;
  }
  body#price main section.pay .logos img.jcb {
    max-width: 80%;
  }
}
@media screen and (max-width: 767px) {
  body#price section.pay p:last-child {
    margin-bottom: 0px;
  }
}
/*////////////////////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////////////

example

////////////////////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////////////*/
/*#######################################################

achievement

#######################################################
*/
body#example main section.achievement img {
  border-radius: 0;
}
body#example main section.achievement p:last-child {
  margin-bottom: 0;
}
/*#######################################################

case

#######################################################
*/
body#example section.case {
  padding: 80px 0;
  background-color: #FFF;
}
@media screen and (max-width: 767px) {
  body#example section.case {
    padding: 6rem 0;
  }
}
body#example section.case h2:first-of-type {
  margin-top: 0px;
}
body#example section.case .items.before_after .details-items-wrap {
  background-color: #FFF;
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  body#example section.case .items.before_after .details-items-wrap {
    margin-top: 2.5rem;
  }
}
body#example section.case .details-items {
  border-bottom: 1px solid #111;
}
body#example section.case .details-items dt {
  width: 22%;
}
@media screen and (max-width: 767px) {
  body#example section.case .details-items dt {
    width: 100%;
  }
}
body#example section.case .items.before_after .details-items dt.type, body#example section.case .items.before_after .details-items dt.type + dd {
  border-top: 1px solid #111;
}
body#example section.case .details-items dd {
  width: 78%;
}
@media screen and (max-width: 767px) {
  body#example section.case .details-items dd {
    width: 100%;
    border-top: none;
  }
}
body#example section.case .details-items dt.sex, body#example section.case .details-items dt.sex + dd, body#example section.case .details-items dt.background, body#example section.case .details-items dt.background + dd, body#example section.case .details-items dt.count, body#example section.case .details-items dt.count + dd, body#example section.case .details-items dt.price, body#example section.case .details-items dt.price + dd, body#example section.case .details-items dt.period, body#example section.case .details-items dt.period + dd, body#example section.case .details-items dt.risk, body#example section.case .details-items dt.risk + dd {
  border-top: 1px solid #111;
}
@media screen and (max-width: 767px) {
  body#example section.case .details-items dd, body#example section.case .details-items dt.sex + dd, body#example section.case .details-items dt.background + dd, body#example section.case .details-items dt.count + dd, body#example section.case .details-items dt.price + dd, body#example section.case .details-items dt.period + dd, body#example section.case .details-items dt.risk + dd {
    border-top: none;
    padding-top: 0px;
  }
}
body#example section.case .step-items {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  body#example section.case .step-items {
    margin-top: 2.5rem;
  }
}
body#example section.case .step-items.col3 > li:nth-child(1), body#example section.case .step-items.col3 > li:nth-child(2) {
  width: 34.1%;
}
@media screen and (max-width: 767px) {
  body#example section.case .step-items.col3 > li:nth-child(1), body#example section.case .step-items.col3 > li:nth-child(2) {
    width: 33.8%;
  }
}
body#example section.case .step-items.col3 > li:last-child {
  width: 31.8%;
}
@media screen and (max-width: 767px) {
  body#example section.case .step-items.col3 > li:last-child {
    width: 32.3%;
  }
}
body#example section.case .step-items.col2 > li:nth-child(1) {
  width: 51.25%;
}
@media screen and (max-width: 767px) {
  body#example section.case .step-items.col2 > li:nth-child(1) {
    width: 50.5%;
  }
}
body#example section.case .step-items.col2 > li:last-child {
  width: 48.75%;
}
@media screen and (max-width: 767px) {
  body#example section.case .step-items.col2 > li:last-child {
    width: 49%;
  }
}
body#example section.case .step-items figure {
  margin-bottom: 10px;
}
body#example section.case .step-items img {
  border-radius: 0;
}
body#example section.case .step-items.col3 > li:nth-child(1) img, body#example section.case .step-items.col3 > li:nth-child(2) img {
  max-width: calc(100% - 20px);
}
@media screen and (max-width: 767px) {
  body#example section.case .step-items.col3 > li:nth-child(1) img, body#example section.case .step-items.col3 > li:nth-child(2) img {
    max-width: calc(100% - 5px);
  }
}
body#example section.case .step-items.col2 > li:nth-child(1) img {
  max-width: calc(100% - 20px);
}
@media screen and (max-width: 767px) {
  body#example section.case .step-items.col2 > li:nth-child(1) img {
    max-width: calc(100% - 5px);
  }
}
body#example section.case .step-items .text {
  margin-right: 20px;
  background-color: #111;
  color: #FFFFFF;
  text-align: center;
  font-weight: bold;
  position: relative;
  height: 50px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  body#example section.case .step-items .text {
    margin-right: 5px;
    line-height: 1.3;
    font-size: 3vw;
    letter-spacing: -0.03em;
  }
}
body#example section.case .step-items li:last-child .text {
  margin-right: 0px;
}
body#example section.case .step-items .text:after {
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 25px 0 25px 20px;
  border-color: transparent transparent transparent #111111;
  content: "";
  display: block;
  position: absolute;
  margin: auto;
  top: 0;
  right: -20px;
}
@media screen and (max-width: 767px) {
  body#example section.case .step-items .text:after {
    border-width: 25px 0 25px 5px;
    right: -5px;
  }
}
body#example section.case .step-items li:last-child .text:after {
  display: none;
}
body#example section.case .step-items .text.red {
  background-color: #FF2201;
}
body#example section.case .doctor-items {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 60px;
}
@media screen and (max-width: 767px) {
  body#example section.case .doctor-items {
    margin-top: 2.5rem;
  }
}
body#example section.case .doctor-items .img {
  margin: 0;
  width: 200px;
  border-radius: 200px;
  height: 200px;
  background-color: #F2F2F2;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 767px) {
  body#example section.case .doctor-items .img {
    width: 40vw;
    border-radius: 40vw;
    margin: 0 auto;
    height: 40vw;
  }
}
body#example section.case .doctor-items .img img {
  border-radius: 0;
}
@media screen and (max-width: 767px) {
  body#example section.case .doctor-items .img img {
    width: 38%;
  }
}
body#example section.case .doctor-items .text-wrap {
  width: 66.1%;
}
@media screen and (max-width: 767px) {
  body#example section.case .doctor-items .text-wrap {
    width: auto;
    padding-bottom: 1rem;
  }
}
body#example main section.case .doctor-items .text-wrap h3 {
  margin: 0 0 10px;
  border-bottom: none;
}
@media screen and (max-width: 767px) {
  body#example main section.case .doctor-items .text-wrap h3 {
    margin: 2.5rem 0 0.5rem;
    text-align: center;
  }
}
body#example main section.case .btn-wrap {
  margin-top: 50px;
}
@media screen and (max-width: 767px) {
  body#example main section.case .btn-wrap {
    margin-top: 6rem;
  }
}
body#example main section.case .btn-wrap .btn {
  margin: auto;
}
@media screen and (max-width: 767px) {
  body#example main section.case .btn-wrap .btn {
    width: auto;
  }
}
/*#######################################################

schedule

#######################################################
*/
@media screen and (max-width: 767px) {
  body#example section.schedule {
    margin-top: 0;
  }
}
/*////////////////////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////////////

flow

////////////////////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////////////*/
/*#######################################################

menu

#######################################################
*/
body#flow section.menu nav ul {
  display: flex;
  flex-wrap: wrap;
}
@media screen and (max-width: 767px) {
  body#flow section.menu nav ul {
    display: block;
  }
}
@media screen and (min-width: 767px), print {
  body#flow section.menu nav ul {
    justify-content: space-between;
  }
}
body#flow section.menu nav ul > li {
  padding: 0;
  margin-top: 10px;
}
@media screen and (min-width: 767px), print {
  body#flow section.menu nav ul > li {
    width: calc(50% - 5px);
  }
}
body#flow main section.menu ul:not([class]) li + li {
  margin-top: 10px;
}
@media screen and (max-width: 767px) {
  body#flow main section.menu ul:not([class]) li + li {
    margin-top: 1.5rem;
  }
}
body#flow main section.menu ul:not([class]) li:before {
  display: none;
}
body#flow section.menu nav ul > li a {
  display: block;
  padding: 10px;
  background-color: #F2F2F2;
}
@media screen and (max-width: 767px) {
  body#flow section.menu nav ul > li a {
    padding: 0.5rem;
  }
}
body#flow section.menu nav ul > li dl {
  display: flex;
  flex-wrap: wrap;
}
body#flow section.menu nav ul > li dl dt {
  font: 20px/0.9 var(--en-font);
  color: var(--sub-color01);
  margin-right: 20px;
  position: relative;
  height: 50px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  padding-left: 20px;
}
@media screen and (max-width: 767px) {
  body#flow section.menu nav ul > li dl dt {
    font-size: 1.6rem;
    margin-right: 2.5rem;
    height: 6vw;
    padding-left: 2.5rem;
  }
}
body#flow section.menu nav ul > li dl dt:before {
  content: "";
  display: block;
  position: absolute;
  margin: auto;
  background-color: #FF2201;
  width: 2px;
  height: 100%;
  left: 0;
  top: 0;
  bottom: 0;
}
body#flow section.menu nav ul > li dl dd {
  font-weight: bold;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
/*#######################################################

step

#######################################################
*/
body#flow section.step {
  padding: 80px 0;
  background-color: #F9F9F9;
}
@media screen and (max-width: 767px) {
  body#flow section.step {
    padding: 6rem 0;
  }
}
body#flow section.step .items li + li {
  margin-top: 20px;
}
body#flow section.step .title {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  background-color: #111;
}
@media screen and (max-width: 767px) {
  body#flow section.step .title {
    padding: 1.5rem 2.5rem;
    display: block;
  }
}
body#flow section.step .title dt {
  font: 28px/0.9 var(--en-font);
  color: #fff;
  background-color: var(--sub-color01);
  height: 70px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  width: 30%;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  body#flow section.step .title dt {
    font-size: 2rem;
    margin: 0 auto;
    height: auto;
    padding: 1rem 2.5rem;
    min-width: 62%;
  }
}
body#flow section.step .title dd {
  width: calc(70% - 50px);
  color: #FFFFFF;
  font-size: 25px;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  body#flow section.step .title dd {
    font-size: 2.2rem;
    width: auto;
    margin-top: 0.5rem;
    text-align: center;
  }
}
body#flow section.step .eyecatch {
  margin: 0;
}
body#flow section.step .eyecatch img {
  border-radius: 0;
}
body#flow section.step .text {
  padding: 60px;
  background-color: #FFFFFF;
}
@media screen and (max-width: 767px) {
  body#flow section.step .text {
    padding: 2.5rem;
  }
}
body#flow section.step .arrow-wrap {
  position: relative;
  z-index: 0;
  text-align: center;
  font-weight: bold;
  font-size: 25px;
}
body#flow section.step .arrow-wrap:before, body#flow section.step .arrow-wrap:after {
  left: 0;
  right: 0;
  border-style: solid;
  content: "";
  display: block;
  position: absolute;
  margin: 0 auto;
  width: 0;
  height: 0;
  z-index: -1;
}
body#flow section.step .arrow-wrap:before {
  border-width: 100px 400px 0 400px;
  border-color: #ffffff transparent transparent transparent;
  top: 0;
}
@media screen and (max-width: 767px) {
  body#flow section.step .arrow-wrap:before {
    border-width: 25vw 44vw 0 44vw;
    top: 0;
  }
}
body#flow section.step .arrow-wrap:after {
  border-width: 76px 300px 0 300px;
  border-color: #f2f2f2 transparent transparent transparent;
  top: 10px;
}
@media screen and (max-width: 767px) {
  body#flow section.step .arrow-wrap:after {
    border-width: 17vw 30vw 0 30vw;
    top: 10px;
  }
}
body#flow main section.step p:last-child {
  margin-bottom: 0px;
}
body#flow section.step .arrow {
  font-weight: bold;
  font-size: 25px;
  height: 100px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  transform: translate(0, -5px);
  line-height: 1.3;
}
@media screen and (max-width: 767px) {
  body#flow section.step .arrow {
    font-size: 1.8rem;
    height: 20vw;
    transform: translate(0, 2vw);
  }
}
body#flow section.step p + .sub_title {
  margin-top: 50px;
}
@media screen and (max-width: 767px) {
  body#flow section.step p + .sub_title {
    margin-top: 6rem;
  }
}
/*#######################################################

schedule

#######################################################
*/
@media screen and (max-width: 767px) {
  body#flow section.schedule {
    margin-top: 0;
  }
}
/*////////////////////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////////////

facility

////////////////////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////////////*/
/*#######################################################

beginning

#######################################################
*/
body#facility section.beginning .img img, body#facility section.office .img img, body#facility section.detailed .img img, body#facility section.surgery .img img {
  border-radius: 0;
}
/*#######################################################

office

#######################################################
*/
body#facility section.office {
  padding: 80px 0;
  background-color: #F9F9F9;
}
@media screen and (max-width: 767px) {
  body#facility section.office {
    padding: 6rem 0;
  }
}
body#facility section.office h2:first-of-type {
  margin-top: 0px;
}
@media screen and (max-width: 767px) {
  body#facility main section h3:not(.no-style) {
    line-height: 1.5;
    padding-bottom: 1.5rem;
    margin: 6rem 0 2.5rem;
  }
}
body#facility main section figure.img {
  margin-bottom: 0px;
}
body#facility main section figure.img + .text {
  margin-top: 2.5rem;
}
/*#######################################################

surgery

#######################################################
*/
body#facility section.surgery {
  padding: 80px 0;
  background-color: #F9F9F9;
}
@media screen and (max-width: 767px) {
  body#facility section.surgery {
    padding: 6rem 0;
  }
}
body#facility section.surgery h2:first-of-type {
  margin-top: 0px;
}
/*#######################################################

schedule

#######################################################
*/
@media screen and (max-width: 767px) {
  body#facility section.schedule {
    margin-top: 0;
  }
}
/*////////////////////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////////////

doctor

////////////////////////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////////////////////////*/
/*#######################################################

director

#######################################################
*/
body#doctor section.director .img img, body#doctor section.doctors .img img, body#doctor section.staff .img img, body#doctor section.staff-feature .img img {
  border-radius: 0;
}
body#doctor section.director, body#doctor section.staff {
  padding: 80px 0;
  background-color: #F9F9F9;
}
@media screen and (max-width: 767px) {
  body#doctor section.director, body#doctor section.staff {
    padding: 6rem 0;
  }
}
body#doctor section.director h2:first-of-type, body#doctor section.staff h2:first-of-type {
  margin-top: 0px;
}
body#doctor section.director .img img {
  border-radius: 0;
}
body#doctor section.director .position, body#doctor section.doctors .position {
  text-align: center;
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  body#doctor section.director .position, body#doctor section.doctors .position {
    margin-top: 2.5rem;
  }
}
body#doctor section.director .name, body#doctor section.doctors .name {
  text-align: center;
}
body#doctor section.director .name dt, body#doctor section.doctors .name dt {
  font-weight: bold;
  font-size: 35px;
}
@media screen and (max-width: 767px) {
  body#doctor section.director .name dt, body#doctor section.doctors .name dt {
    font-size: 2.5rem;
  }
}
body#doctor section.director .name dd, body#doctor section.doctors .name dd {
  font-size: 20px;
}
@media screen and (max-width: 767px) {
  body#doctor section.director .name dd, body#doctor section.doctors .name dd {
    font-size: 1.6rem;
  }
}
body#doctor .box {
  padding: 0 60px 60px;
  background-color: #FFFFFF;
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  body#doctor .box {
    padding: 0 2.5rem 2.5rem;
    margin-top: 6rem;
  }
}
body#doctor section.doctors .box {
  background-color: #F9F9F9;
}
body#doctor .box h3 {
  border: none;
  display: flex;
  justify-content: center;
  background-color: #111;
  color: #FFFFFF;
  margin: 0 auto;
  max-width: 310px;
  border-radius: 100px;
  position: relative;
  top: -25px;
  height: 50px;
  align-items: center;
}
@media screen and (max-width: 767px) {
  body#doctor .box h3 {
    max-width: none;
    padding: 1rem 0;
    height: auto;
    top: -6vw;
  }
}
body#doctor .box h3:first-of-type {
  margin: 0 auto;
}
body#doctor main section p.text:last-child, body#doctor main section h3:not(.no-style) + p.text {
  margin-bottom: 0;
}
body#doctor .box .items {
  display: flex;
  flex-wrap: wrap;
}
body#doctor .box .text + .items {
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  body#doctor .box .text + .items {
    margin-top: 2.5rem;
  }
}
body#doctor .box .items dt, body#doctor .box .items dd {
  padding: 10px 0;
  border-bottom: 1px solid #111;
}
@media screen and (max-width: 767px) {
  body#doctor .box .items dt, body#doctor .box .items dd {
    padding: 1rem 0;
  }
}
body#doctor .box .items dt {
  width: 23%;
  color: #FF2201;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  body#doctor .box .items dt {
    width: 100%;
    border-bottom: none;
    padding-bottom: 1rem;
  }
}
body#doctor .box .items dd {
  width: 77%;
}
@media screen and (max-width: 767px) {
  body#doctor .box .items dd {
    width: 100%;
    padding-top: 0px;
  }
}
body#doctor main section .box ul:not([class]) {
  margin: 0;
}
body#doctor main section .box ul:not([class]) + h4 {
  margin-top: 30px;
}
body#doctor main section .box ul:not([class]) li + li {
  margin-top: 10px;
}
@media screen and (max-width: 767px) {
  body#doctor main section .box .tbl, body#doctor main section .box .tbl tbody {
    display: block;
  }
}
@media screen and (max-width: 767px) {
  body#doctor main section .box .tbl tbody tr {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
  }
  body#doctor main section .box .tbl tbody tr + tr {
    margin-top: 2.5rem;
  }
}
body#doctor main section .box .tbl th {
  color: #FF2201;
  font-weight: bold;
  text-align: left;
  padding-left: 0px;
  padding-right: 0px;
  background-color: transparent;
  border-left: none !important;
  border-right: none !important;
}
@media screen and (max-width: 767px) {
  body#doctor main section .box .tbl th {
    padding: 1rem 0;
    width: 100%;
    text-align: center;
    font-size: 2rem;
  }
}
body#doctor main section .box .tbl td, body#doctor main section table.tbl tbody td + td {
  font-weight: bold;
  text-align: center;
  color: #111111;
  border-left: none !important;
  border-right: none !important;
}
@media screen and (max-width: 767px) {
  body#doctor main section .box .tbl td {
    padding: 1rem 0;
    width: 100%;
    border-top: none;
    border-bottom: 1px solid #111;
  }
}
body#doctor main section .box .tbl td:last-child {
  font-weight: normal;
  text-align: left;
}
@media screen and (max-width: 767px) {
  body#doctor main section .box .tbl td:last-child, body#doctor main section .box .tbl td + td {
    width: 100%;
    padding: 1rem 0;
    height: auto;
    line-height: 1.3;
  }
}
body#doctor section.staff-feature {
  padding-bottom: 80px;
}
@media screen and (max-width: 767px) {
  body#doctor section.staff-feature {
    padding-bottom: 0;
  }
}
body#doctor main section.staff-feature p:last-child {
  margin-bottom: 0;
}

.treatment-btn {margin: 2.5rem auto !important;}
/*241007追記*/
.add_implant.sec-intro .sec-intro__title { text-align: center; font-size: 30px; margin: 0 0 30px; font-family: var(--sub-font); font-weight: 700; }
.add_implant.sec-intro .sec-intro__sub-title { font-family: var(--sub-font); font-weight: 700; font-size: 3.2rem; text-align: center; color: var(--sub-color01); margin-bottom: .8rem; }
.sec-intro.add_implant .sec-intro__sub-title+p { text-align: center; margin-bottom: 8rem; }
.sec-intro.add_implant .sec-intro__sub-title+.sec-intro__lead, .sec-intro.add_implant .sec-intro__lead { margin: 5rem 0 8rem; }
@media (max-width:768px) {
	.add_implant.sec-intro .sec-intro__title { font-size: 25px; line-height: 1.5; }
	.add_implant.sec-intro .sec-intro__sub-title { font-size: 2rem; line-height: 1.6; margin-bottom: 1.6rem; margin-bottom: 0; }
	.sec-intro.add_implant .sec-intro__sub-title+.sec-intro__lead, .sec-intro.add_implant .sec-intro__lead { text-align: left; margin: 2.5rem 0 5rem; }
}
.sec-intro.add_implant .c-table { width: 100%; border-top: 1px solid #111; }
.sec-intro.add_implant .c-table th, .sec-intro.add_implant .c-table td { padding: 10px; vertical-align: middle; text-align: center;background: #fff; }
@media screen and (max-width:767px) {
	.sec-intro.add_implant .c-table th, .sec-intro.add_implant .c-table td { padding: 1rem .5rem .75rem; }
}
.sec-intro.add_implant .c-table thead td { padding: 20px 10px; font-weight: 700; }
@media screen and (max-width:767px) {
	.sec-intro.add_implant .c-table thead td { padding: 1.5rem .5rem 1.25rem ;}
}
.sec-intro.add_implant .c-table thead th, .sec-intro.add_implant .c-table thead td, .sec-intro.add_implant .c-table tbody th, .sec-intro.add_implant .c-table tbody td { border: 1px solid #111; }
@media screen and (max-width:767px) {
	.sec-intro.add_implant .c-table thead th, .sec-intro.add_implant .c-table thead td, .sec-intro.add_implant .c-table tbody th, .sec-intro.add_implant .c-table tbody td { font-size: 1.2rem; line-height: 1.3; }
	main .sec-intro.add_implant table:not(.no-style) tbody td+td { display: table-cell !important; }
}
.sec-intro.add_implant .c-table tbody th { font-weight: 500; border-left: none; }
.sec-intro.add_implant .c-table tbody td { color: #ff2201; }
.sec-intro.add_implant .c-table thead th:first-child { border-left: none; }
.sec-intro.add_implant .c-table tbody td:last-child, .sec-intro.add_implant .c-table thead td:last-child { border-right: none; }
.sec-intro.add_implant .c-table__closed { margin: 2rem 0 3rem; line-height: 1.5; font-size: 1.4rem; text-align: center; }
@media screen and (max-width:767px) {
.sec-intro.add_implant .c-table__closed { margin: .5rem 0 2.5rem; font-size: 1.2rem; text-align: left; }
}
.sec-intro.add_implant .c-table__closed-title { background-color: #f2f2f2; padding: .2rem 1rem; display: inline-block; font-weight: 700; margin: 0 1rem; }
@media screen and (max-width:767px) {
	.sec-intro.add_implant .c-table__closed-title { margin: .5rem 1rem .5rem 0; }
}
.sec-intro.add_implant .c-map { display: grid; background-color: #f2f2f2; }
@media screen and (min-width:767px), print {
	.sec-intro.add_implant .c-map { grid-template-columns: 49rem, 1fr; }
}
.sec-intro.add_implant .c-map__img { background-color: #fff; }
@media screen and (min-width:767px), print {
	.sec-intro.add_implant .c-map__img { grid-row: 1/2; grid-column: 1/2; height: 29rem; }
}
.sec-intro.add_implant .c-map__img img { object-fit: contain; width: 100%; height: 100%;border-radius: 0; }
@media screen and (min-width:767px), print {
	.sec-intro.add_implant .c-map__info { grid-row: 1/2; grid-column: 2/3; }
}
@media screen and (min-width:767px), print {
	.sec-intro.add_implant .c-map__info-inner { padding: 4rem; }
}
@media screen and (max-width:767px) {
	.sec-intro.add_implant .c-map__info-inner { padding: 2.5rem; }
}
.sec-intro.add_implant .c-map__info-adr { position: relative; }
@media screen and (min-width:767px), print {
	.sec-intro.add_implant .c-map__info-adr { padding-left: 2rem; }
}
@media screen and (max-width:767px) {
	.sec-intro.add_implant .c-map__info-adr { padding-left: 2.5rem; }
}
.sec-intro.add_implant .c-map__info-adr:before { content: ""; display: block; position: absolute; margin: auto; background-repeat: no-repeat; background-size: contain; background-position: center center; background-image: url(//www.sekokai-takashimadaira.com/css/../images/index2023/icon_pin01.svg); width: 1.4rem; height: 1.8rem; top: 0; left: 0; }
.sec-intro.add_implant .c-map__info-sta { position: relative; margin-top: 2rem; }
@media screen and (min-width:767px), print {
	.sec-intro.add_implant .c-map__info-sta { padding-left: 2rem }
}
@media screen and (max-width:767px) {
	.sec-intro.add_implant .c-map__info-sta { padding-left: 2.5rem; margin-top: 2.5rem; }
}
.sec-intro.add_implant .c-map__info-sta:before { content: ""; display: block; position: absolute; margin: auto; background-repeat: no-repeat; background-size: contain; background-position: center center; background-image: url(//www.sekokai-takashimadaira.com/css/../images/index2023/icon_bus01.svg); width: 1.4rem; height: 2rem; top: 0; left: 0; }
@media screen and (max-width:767px) {
	.sec-intro.add_implant .c-map__info-sta:before { top: .1rem; }
}
.sec-intro.add_implant .c-map__btn { margin-top: 2rem; }
.sec-intro.add_implant .sec-intro__note { text-align: center; margin-bottom: 5rem; line-height: 1.5;}
@media screen and (max-width:767px) {
    .sec-intro.add_implant .sec-intro__note { text-align: left; margin-bottom: 2.5rem; }
}
main section.sec-intro.add_implant .btn { margin: 0; }
@media (max-width:768px) {
    main section.sec-intro.add_implant .btn { height: 5rem; background-position: center right 1.4rem; margin-left: auto; margin-right: auto; }
}
main section.faq p.related_post{margin-top:0.5em;margin-bottom:0}
main section.faq p.related_post a{ color: #ff2201;}
/*241007追記end*/