@charset "UTF-8";

/* ===================================================================
FileName	:	style.scss
Generator	:	Sass
Date : 18.10.30

↓レスポンシブ対応時に入れるタグ
@include mq(tab) {
  // タブレット時css
}
@include mq {
  // スマホ時css
}
=================================================================== */
/* ===================================================================
Layout Index
=================================================================== */
/* Main Img
--------------------------------------------------------------------*/
.ind_slider {
  padding-bottom: 40px;
}

.ind_slider .inner {
  position: relative;
  border-radius: 10px;
  overflow: hidden;
}

.ind_slider .caption {
  position: absolute;
}

.ind_slider .caption.type_01 {
  top: 9.5%;
  right: 3.8%;
}

.ind_slider .caption.type_01 .ttl {
  align-items: flex-end;
}

.ind_slider .caption.type_01 .ttl span {
  background: #72B639;
}

.ind_slider .caption.type_01 .ttl span:not(:first-child) {
  font-size: 2.2rem;
}

.ind_slider .caption.type_02 {
  bottom: 13.5%;
  left: 3.8%;
}

.ind_slider .caption.type_02 .ttl {
  align-items: flex-start;
}

.ind_slider .caption.type_02 .ttl span {
  background: #72B639;
}

.ind_slider .caption.type_03 {
  top: 9.5%;
  right: 3.8%;
}

.ind_slider .caption.type_03 .ttl {
  align-items: flex-end;
}

.ind_slider .caption.type_03 .ttl span {
  background: #FFB100;
}

.ind_slider .caption.type_04 {
  bottom: 13.5%;
  left: 3.8%;
}

.ind_slider .caption.type_04 .ttl {
  align-items: flex-start;
}

.ind_slider .caption.type_04 .ttl span {
  background: #EBA200;
}

.ind_slider .caption.type_05 {
  top: 9.5%;
  left: 3.8%;
}

.ind_slider .caption.type_05 .ttl {
  align-items: flex-start;
}

.ind_slider .caption.type_05 .ttl span {
  background: #72B639;
}

.ind_slider .ttl {
  position: static;
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  flex-direction: column;
  max-width: none;
  width: auto;
  margin-bottom: 0;
}

.ind_slider .ttl span {
  padding: .1em .4em;
  font-size: 1.8rem;
  color: white;
  text-shadow: 0 0 9px rgba(0, 0, 0, 0.2);
}

.ind_slider .ttl span:not(:last-child) {
  margin-bottom: 1em;
}

@media screen and (max-width: 960px) {
  .ind_slider .ttl span {
    font-size: 1.9vw;
  }

  .ind_slider .caption.type_01 .ttl span:not(:first-child) {
    font-size: 2.3vw;
  }
}

@media screen and (max-width: 600px) {
  .ind_slider {
    padding-bottom: 20px;
  }

  .ind_slider .ttl span {
    font-size: 2.4vw;
  }

  .ind_slider .caption.type_01 .ttl span:not(:first-child) {
    font-size: 3.6vw;
  }
}

.bx-wrapper {
  margin-bottom: 40px;
  box-shadow: none;
  border: none;
  background: none;
}

.bx-wrapper .bx-pager {
  bottom: 15px;
}

.bx-wrapper .bx-pager.bx-default-pager a {
  background: #F5F1E5;
}

.bx-wrapper .bx-controls-direction a {
  width: 20px;
}

.bx-wrapper .bx-prev {
  background-image: url(../img/index/ico_chevron-left.svg);
  background-position: 0 0;
}

.bx-wrapper .bx-next {
  background-image: url(../img/index/ico_chevron-right.svg);
  background-position: 0 0;
}

@media screen and (max-width: 600px) {
  .bx-wrapper {
    margin-bottom: 20px;
  }

  .bx-wrapper .bx-pager {
    bottom: 10px;
  }

  .bx-wrapper .bx-prev,
  .bx-wrapper .bx-next {
    display: none;
  }
}

/* Section Information
--------------------------------------------------------------------*/
.ind_sec_info {
  padding-bottom: 40px;
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
}

.ind_sec_info .layout_inner {
  max-width: 430px;
  width: 100%;
  padding-left: 2%;
}

.ind_sec_info .ttl {
  padding-bottom: 1em;
  font-size: 1.8rem;
  color: #72B639;
}

.ind_sec_info .btn {
  text-align: right;
}

.ind_sec_info .sec_news {
  border-radius: 10px;
  background: white;
  max-width: 335px;
  width: 100%;
  padding: 25px;
}

.ind_sec_info .sec_news .ttl:before {
  content: '\f044';
  padding-right: .4em;
  font-family: FontAwesome;
}

.ind_sec_info .sec_news .list {
  padding-bottom: 20px;
  font-size: 1.4rem;
}

.ind_sec_info .sec_news .list li:not(:last-child) {
  padding-bottom: 20px;
}

.ind_sec_info .sec_news .summary .cat a {
  padding: 0;
  font-size: 1.2rem;
  color: #46392E;
  text-decoration: underline;
  background: none;
}

.ind_sec_info .sec_news .summary .cat a:before {
  content: '#';
}

.ind_sec_info .sec_news .summary .cat a:hover {
  text-decoration: none;
}

.ind_sec_info .medical_time {
  border-radius: 10px;
  background: white;
  margin-bottom: 40px;
  padding: 25px;
}

.ind_sec_info .medical_time .ttl:before {
  content: '\f017';
  padding-right: .4em;
  font-family: FontAwesome;
}

.ind_sec_info .medical_time .tbl {
  border: none;
}

.ind_sec_info .medical_time .tbl th {
  display: table-cell;
  padding: 0;
  font-size: 1.8rem;
  border: none;
  background: none;
}

.ind_sec_info .medical_time .tbl td {
  display: table-cell;
  padding: 0;
  font-size: 1.8rem;
  font-weight: bold;
  text-align: right;
  border: none;
}

.ind_sec_info .medical_time .annotation {
  font-size: 1.6rem;
  color: #D36100;
}

.ind_sec_info .access {
  border-radius: 10px;
  background: white;
  padding: 25px;
}

.ind_sec_info .access a {
  text-decoration: none;
}

.ind_sec_info .access .ttl:before {
  content: '\f124';
  padding-right: .4em;
  font-family: FontAwesome;
}

.ind_sec_info .access .tel {
  font-size: 3rem;
  text-align: center;
  line-height: 1;
}

.ind_sec_info .access .tel a {
  color: #72B639;
}

.ind_sec_info .access .address {
  padding-bottom: 20px;
}

.ind_sec_info .access .txt_01 {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  align-items: center;
}

.ind_sec_info .access .txt_01 .zip {
  padding-right: 1.2em;
  font-size: 1.6rem;
}

.ind_sec_info .access .txt_01 .residence {
  font-size: 1.8rem;
}

.ind_sec_info .access .txt_02 {
  display: inline-block;
  width: 100%;
  text-align: right;
}

@media screen and (max-width: 960px) {
  .ind_sec_info {
    flex-direction: column;
  }

  .ind_sec_info .layout_inner {
    max-width: none;
    padding-left: 0;
  }

  .ind_sec_info .sec_news {
    max-width: none;
    margin-bottom: 40px;
  }
}

@media screen and (max-width: 600px) {
  .ind_sec_info {
    padding-bottom: 20px;
  }

  .ind_sec_info .ttl {
    font-size: 1.6rem;
  }

  .ind_sec_info .sec_news {
    padding-right: 4%;
    padding-left: 4%;
    margin-bottom: 20px;
  }

  .ind_sec_info .medical_time {
    padding-right: 4%;
    padding-left: 4%;
    margin-bottom: 20px;
  }

  .ind_sec_info .medical_time .annotation {
    text-align: right;
  }

  .ind_sec_info .access {
    padding-right: 4%;
    padding-left: 4%;
  }

  .ind_sec_info .access .txt_01 {
    align-items: flex-start;
    flex-direction: column;
  }
}

/* Section Aims
--------------------------------------------------------------------*/
.ind_sec_aims {
  border-radius: 10px;
  background: white;
  margin-bottom: 40px;
  padding: 25px;
}

.ind_sec_aims .inner {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
  flex-direction: row-reverse;
}

.ind_sec_aims .img {
  max-width: 285px;
  width: 100%;
  margin-left: 3.4%;
}

.ind_sec_aims .img .img_01 {
  padding-bottom: 25px;
}

.ind_sec_aims .img .img_01 img {
  width: 100%;
  height: 270px;
  object-fit: cover;
  object-position: 85% center;
  font-family: 'object-fit: cover; object-position: 85% center;';
}

.ind_sec_aims .img .img_02 {
  padding-bottom: 25px;
}

.ind_sec_aims .description {
  max-width: 430px;
  width: 100%;
}

.ind_sec_aims .lst_concept .ttl {
  margin-bottom: .6em;
  padding-bottom: .6em;
  font-size: 1.3rem;
  border-bottom: 1px solid #46392E;
}

.ind_sec_aims .lst_concept .txt {
  padding-bottom: .6em;
}

.ind_sec_aims .btn {
  text-align: right;
}

@media screen and (max-width: 960px) {
  .ind_sec_aims .inner {
    flex-direction: column;
  }

  .ind_sec_aims .img {
    max-width: none;
    margin-left: 0;
  }

  .ind_sec_aims .img .img_01 {
    padding-bottom: 20px;
  }

  .ind_sec_aims .img .img_01 img {
    height: 22vw;
    object-position: center 36%;
    font-family: 'object-position: center 36%;';
  }

  .ind_sec_aims .img .img_02,
  .ind_sec_aims .img .img_03 {
    display: none;
  }

  .ind_sec_aims .description {
    max-width: none;
  }
}

@media screen and (max-width: 600px) {
  .ind_sec_aims {
    padding-right: 4%;
    padding-left: 4%;
    margin-bottom: 20px;
  }

  .ind_sec_aims .img {
    max-width: none;
    margin-left: 0;
  }

  .ind_sec_aims .img .img_01 img {
    height: 32vw;
  }
}

/* Section Menu
--------------------------------------------------------------------*/
.ind_sec_menu .lst_menu {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

.ind_sec_menu .lst_menu li {
  border-radius: 10px;
  background: white;
}

.ind_sec_menu .lst_menu li:nth-of-type(-n+3) {
  max-width: 240px;
  width: 100%;
}

.ind_sec_menu .lst_menu li:nth-of-type(4),
.ind_sec_menu .lst_menu li:nth-of-type(5),
.ind_sec_menu .lst_menu li:nth-of-type(6),
.ind_sec_menu .lst_menu li:nth-of-type(7) {
  max-width: 180px;
  width: 100%;
}

.ind_sec_menu .lst_menu li:nth-of-type(5) .small br,
.ind_sec_menu .lst_menu li:nth-of-type(7) .small br {
  display: none;
}

.ind_sec_menu .lst_menu li>a {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  align-items: center;
  flex-direction: column;
  height: 100%;
  padding: 35px 0;
  text-decoration: none;
}

.ind_sec_menu .lst_menu li>a:hover .txt,
.ind_sec_menu .lst_menu li>a:hover .btn {
  transition: .3s ease-in-out;
  opacity: .7;
  filter: alpha(opacity=30);
}

.ind_sec_menu .lst_menu li:not(:last-child) {
  margin-bottom: 40px;
}

.ind_sec_menu .lst_menu li:not(.layout_house_call) .btn {
  margin-top: auto;
  padding: .4em 1.4em;
  color: white;
  border-radius: 14px;
  background: #72B639;
}

.ind_sec_menu .lst_menu li:not(.layout_house_call) .btn:before {
  content: '\f105';
  font-family: FontAwesome;
  padding-right: .6em;
}

.ind_sec_menu .lst_menu .ico {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 40px;
  height: 40px;
  margin-bottom: 25px;
}

.ind_sec_menu .lst_menu .txt {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  align-items: center;
  flex-direction: column;
  text-align: center;
  width: 100%;
}

.ind_sec_menu .lst_menu .txt span {
  display: inline-block;
}

.ind_sec_menu .lst_menu .txt .large {
  padding-bottom: 10px;
  font-size: 1.8rem;
}

.ind_sec_menu .lst_menu .txt .small {
  width: 100%;
  padding: 0 16px;
}

.ind_sec_menu .lst_menu .layout_house_call {
  max-width: none;
  width: 100%;
  padding: 35px 25px;
}

.ind_sec_menu .lst_menu .layout_house_call .inner {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between;
}

.ind_sec_menu .lst_menu .layout_house_call .img {
  max-width: 310px;
  width: 100%;
  margin-left: 2%;
}

.ind_sec_menu .lst_menu .layout_house_call .img img {
  width: 100%;
  height: 180px;
  object-fit: cover;
  object-position: 0 100%;
  font-family: 'object-fit: cover; object-position: 0 100%;';
}

.ind_sec_menu .lst_menu .layout_house_call .description {
  max-width: 410px;
  width: 100%;
}

.ind_sec_menu .lst_menu .layout_house_call .ttl {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  align-items: center;
  font-size: 2rem;
  border: none;
}

.ind_sec_menu .lst_menu .layout_house_call .ttl img {
  width: 40px;
  margin-right: .6em;
}

.ind_sec_menu .lst_menu .layout_house_call .txt {
  align-items: flex-start;
  text-align: left;
}

.ind_sec_menu .lst_menu .layout_house_call .txt_orange {
  color: #D36100;
}

.ind_sec_menu .lst_menu .layout_house_call .btn {
  text-align: right;
}

@media screen and (max-width: 960px) {
  .ind_sec_menu .lst_menu li:not(.layout_house_call) {
    max-width: none;
    width: 48%;
  }

  .ind_sec_menu .lst_menu li:nth-of-type(5) .small br,
  .ind_sec_menu .lst_menu li:nth-of-type(7) .small br {
    display: block;
  }
}

@media screen and (max-width: 600px) {
  .ind_sec_menu .lst_menu li>a {
    flex-direction: row;
    padding: 6% 5%;
  }

  .ind_sec_menu .lst_menu li>a:after {
    content: '\f105';
    font-family: FontAwesome;
    margin-left: auto;
    font-size: 1.6rem;
  }

  .ind_sec_menu .lst_menu li:not(:last-child) {
    margin-bottom: 20px;
  }

  .ind_sec_menu .lst_menu .ico {
    width: 23px;
    height: 23px;
    margin-right: 10px;
    margin-bottom: 0;
  }

  .ind_sec_menu .lst_menu .txt {
    padding-bottom: 0;
    align-items: flex-start;
  }

  .ind_sec_menu .lst_menu .txt .large {
    padding-bottom: 0;
    font-size: 3vw;
  }

  .ind_sec_menu .lst_menu .txt .small {
    display: none;
  }

  .ind_sec_menu .lst_menu .btn {
    display: none;
  }

  .ind_sec_menu .lst_menu .layout_house_call {
    max-width: none;
    padding: 4% 3%;
  }

  .ind_sec_menu .lst_menu .layout_house_call .inner {
    position: relative;
    flex-direction: column;
  }

  .ind_sec_menu .lst_menu .layout_house_call .img {
    position: absolute;
    top: 14%;
    max-width: none;
    margin-left: 0;
  }

  .ind_sec_menu .lst_menu .layout_house_call .img img {
    height: 32vw;
    object-position: 0 70%;
    font-family: 'object-position: 0 70%;';
  }

  .ind_sec_menu .lst_menu .layout_house_call .description {
    max-width: none;
  }

  .ind_sec_menu .lst_menu .layout_house_call .ttl {
    font-size: 3vw;
  }

  .ind_sec_menu .lst_menu .layout_house_call .ttl img {
    width: 24px;
    margin-right: 10px;
  }

  .ind_sec_menu .lst_menu .layout_house_call .txt {
    padding-top: 22%;
  }

  .ind_sec_menu .lst_menu .layout_house_call .btn {
    display: block;
  }
}

/* ===================================================================
Layout Clinic Introduction
=================================================================== */
/* Section Clinic About
--------------------------------------------------------------------*/
.sec_clinic_about {
  border-radius: 10px;
  background: white;
  margin-bottom: 40px;
  padding: 25px;
}

@media screen and (max-width: 600px) {
  .sec_clinic_about {
    margin-bottom: 20px;
    padding-right: 4%;
    padding-left: 4%;
  }
}

.layout_about {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
  flex-direction: row-reverse;
  padding-bottom: 25px;
}

.layout_about .img {
  max-width: 285px;
  width: 100%;
}

.layout_about .description {
  max-width: 430px;
  width: 100%;
}

.layout_about .img {
  margin-left: 2%;
}

.layout_about .img img {
  width: 100%;
  height: 194px;
  object-fit: cover;
  font-family: 'object-fit: cover;';
}

@media screen and (max-width: 960px) {
  .layout_about {
    flex-direction: column;
    flex-direction: column;
  }

  .layout_about .img {
    max-width: none;
    margin: 0;
    padding-bottom: 25px;
  }

  .layout_about .img img {
    width: 100%;
    height: 27vw;
    object-fit: cover;
    font-family: 'object-fit: cover;';
  }

  .layout_about .description {
    max-width: none;
  }

  .layout_about .img {
    margin-left: 0;
  }

  .layout_about .img img {
    height: 22vw;
    object-position: 0% 32%;
    font-family: 'object-position: 0% 32%;';
  }
}

@media screen and (max-width: 600px) {
  .layout_about .img img {
    height: 32vw;
    object-position: 0% 36%;
    font-family: 'object-position: 0% 36%;';
  }
}

/* Section Clinic Feature
--------------------------------------------------------------------*/
.sec_clinic_feature {
  border-radius: 10px;
  background: white;
  margin-bottom: 40px;
  padding: 25px;
}

@media screen and (max-width: 600px) {
  .sec_clinic_feature {
    margin-bottom: 20px;
    padding-right: 4%;
    padding-left: 4%;
  }
}

.img_figure_feature {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
  padding-bottom: 25px;
}

.img_figure_feature figure:not(:last-child) {
  padding-right: 1%;
}

.sub_sec_feature_01 {
  padding-bottom: 25px;
}

.sub_sec_feature_01 .txt {
  padding-bottom: 25px;
}

.sub_sec_feature_01 .layout_inner {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
  flex-direction: row-reverse;
}

.sub_sec_feature_01 .layout_inner .img {
  max-width: 285px;
  width: 100%;
}

.sub_sec_feature_01 .layout_inner .description {
  max-width: 430px;
  width: 100%;
}

.sub_sec_feature_01 .layout_inner .img {
  margin-left: 2%;
}

.sub_sec_feature_01 .lst_cherish {
  padding-bottom: 25px;
  font-size: 1.4rem;
  color: #72B639;
}

.sub_sec_feature_01 .lst_cherish li:before {
  content: '\f058';
  padding-right: .4em;
  font-family: FontAwesome;
}

.sub_sec_feature_01 .lst_cherish li:not(:last-child) {
  padding-bottom: .8em;
}

@media screen and (max-width: 960px) {
  .sub_sec_feature_01 .layout_inner {
    flex-direction: column;
  }

  .sub_sec_feature_01 .layout_inner .img {
    max-width: none;
    margin: 0;
    padding-bottom: 25px;
  }

  .sub_sec_feature_01 .layout_inner .img img {
    width: 100%;
    height: 27vw;
    object-fit: cover;
    font-family: 'object-fit: cover;';
  }

  .sub_sec_feature_01 .layout_inner .description {
    max-width: none;
  }

  .sub_sec_feature_01 .layout_inner .img img {
    object-position: 0% 24%;
    font-family: 'object-position: 0% 24%;';
  }
}

@media screen and (max-width: 600px) {
  .sub_sec_feature_01 .layout_inner .img img {
    height: 30vw;
  }

  .sub_sec_feature_01 .layout_inner .img img {
    object-position: 0% 24%;
    font-family: 'object-position: 0% 24%;';
  }
}

.sub_sec_feature_02 {
  padding-bottom: 25px;
}

/* Section Clinic Intro
--------------------------------------------------------------------*/
.sec_clinic_intro {
  border-radius: 10px;
  background: white;
  padding: 25px;
}

.sec_clinic_intro h4 {
  margin-bottom: 0;
  font-size: 1.4rem;
  line-height: 1;
  border: none;
}

.sec_clinic_intro .greeting {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
}

.sec_clinic_intro .greeting .img {
  max-width: 285px;
  width: 100%;
}

.sec_clinic_intro .greeting .description {
  max-width: 430px;
  width: 100%;
}

@media screen and (max-width: 960px) {
  .sec_clinic_intro .greeting {
    flex-direction: column;
  }

  .sec_clinic_intro .greeting .img {
    max-width: none;
    margin: 0;
    padding-bottom: 25px;
  }

  .sec_clinic_intro .greeting .img img {
    width: 100%;
    height: 27vw;
    object-fit: cover;
    font-family: 'object-fit: cover;';
  }

  .sec_clinic_intro .greeting .description {
    max-width: none;
  }
}

@media screen and (max-width: 600px) {
  .sec_clinic_intro {
    padding-right: 4%;
    padding-left: 4%;
  }

  .sec_clinic_intro .greeting .img img {
    height: 30vw;
  }
}

.sub_sec_director {
  padding-bottom: 25px;
}

.sub_sec_director .greeting {
  flex-direction: row-reverse;
  padding-bottom: 25px;
}

.sub_sec_director .greeting .img {
  margin-left: 2%;
}

.sub_sec_director .career {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
}

.sub_sec_director .career .img {
  max-width: 285px;
  width: 100%;
}

.sub_sec_director .career .description {
  max-width: 430px;
  width: 100%;
}

.sub_sec_director .career .img {
  margin-right: 2%;
}

.sub_sec_director .lst_career {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  flex-wrap: wrap;
}

.sub_sec_director .lst_career .date {
  width: 25%;
  padding: .6em 0;
  border-bottom: 1px dashed #46392E;
}

.sub_sec_director .lst_career .summary {
  width: 74%;
  margin-left: 2px;
  padding: .6em 0;
  border-bottom: 1px dashed #46392E;
}

@media screen and (max-width: 960px) {
  .sub_sec_director .greeting {
    flex-direction: column;
  }

  .sub_sec_director .greeting .img {
    margin-left: 0;
  }

  .sub_sec_director .greeting .img img {
    object-position: 0% 50%;
    font-family: 'object-position: 0% 50%;';
  }

  .sub_sec_director .career {
    flex-direction: column;
  }

  .sub_sec_director .career .img {
    max-width: none;
    margin: 0;
    padding-bottom: 25px;
  }

  .sub_sec_director .career .img img {
    width: 100%;
    height: 27vw;
    object-fit: cover;
    font-family: 'object-fit: cover;';
  }

  .sub_sec_director .career .description {
    max-width: none;
  }

  .sub_sec_director .career .img img {
    object-position: 0% 66%;
    font-family: 'object-position: 0% 66%;';
  }
}

@media screen and (max-width: 600px) {
  .sub_sec_director .career .img img {
    height: 30vw;
  }

  .sub_sec_director .career .img img {
    object-position: 0% 63%;
    font-family: 'object-position: 0% 63%;';
  }
}

.sub_sec_doctor {
  padding-bottom: 25px;
}

.sub_sec_doctor .greeting {
  flex-direction: row-reverse;
}

.sub_sec_doctor .greeting .img {
  margin-left: 2%;
}

.sub_sec_doctor .lst_career {
  padding-bottom: 15px;
}

.sub_sec_doctor .lst_career li {
  padding: .6em 0;
  border-bottom: 1px dashed #46392E;
}

.sub_sec_doctor .btn {
  font-size: 1.2rem;
  text-align: right;
}

@media screen and (max-width: 960px) {
  .sub_sec_doctor .greeting {
    flex-direction: column;
  }

  .sub_sec_doctor .greeting .img {
    margin-left: 0;
  }

  .sub_sec_doctor .greeting .img img {
    object-position: 0% 34%;
    font-family: 'object-position: 0% 34%;';
  }
}

.sub_sec_staff .greeting .img {
  margin-right: 2%;
}

/* ===================================================================
Layout Medical
=================================================================== */
/* Section Clinical Course
--------------------------------------------------------------------*/
.sec_clinical_course {
  border-radius: 10px;
  background: white;
  padding: 25px;
}

.sec_clinical_course .txt {
  padding-bottom: 30px;
}

@media screen and (max-width: 600px) {
  .sec_clinical_course {
    padding-right: 4%;
    padding-left: 4%;
  }
}

.lst_clinical_course li {
  padding: 30px 25px;
  border-top: 1px dashed #E0DEDC;
}

.lst_clinical_course li:nth-of-type(odd) .inner {
  flex-direction: row-reverse;
}

.lst_clinical_course li:nth-of-type(odd) .inner .img {
  margin-left: 2%;
}

.lst_clinical_course li:nth-of-type(even) .inner .img {
  margin-right: 2%;
}

.lst_clinical_course .inner {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
}

.lst_clinical_course .inner .img {
  max-width: 285px;
  width: 100%;
}

.lst_clinical_course .inner .description {
  max-width: 430px;
  width: 100%;
}

.lst_clinical_course .description h4 {
  margin: 0;
  font-size: 2.2rem;
  font-weight: normal;
  color: #D36100;
  border: none;
}

.lst_clinical_course .btn {
  text-align: right;
}

@media screen and (max-width: 960px) {
  .lst_clinical_course li {
    padding: 25px 0;
  }

  .lst_clinical_course li:nth-of-type(odd) .inner {
    flex-direction: column;
  }

  .lst_clinical_course li:nth-of-type(odd) .inner .img {
    margin-left: 0;
  }

  .lst_clinical_course li:nth-of-type(even) .inner .img {
    margin-right: 0;
  }

  .lst_clinical_course .inner {
    flex-direction: column;
  }

  .lst_clinical_course .inner .img {
    max-width: none;
    margin: 0;
    padding-bottom: 25px;
  }

  .lst_clinical_course .inner .img img {
    width: 100%;
    height: 27vw;
    object-fit: cover;
    font-family: 'object-fit: cover;';
  }

  .lst_clinical_course .inner .description {
    max-width: none;
  }
}

@media screen and (max-width: 600px) {
  .lst_clinical_course .inner .img img {
    height: 30vw;
  }

  .lst_clinical_course .description h4 {
    font-size: 1.6rem;
  }
}

/* ===================================================================
Layout Child Dentistry
=================================================================== */
/* Section Child Dentistry
--------------------------------------------------------------------*/
.sec_child_dentistry {
  border-radius: 10px;
  background: white;
  margin-bottom: 40px;
  padding: 25px;
}

@media screen and (max-width: 600px) {
  .sec_child_dentistry {
    margin-bottom: 20px;
    padding-right: 4%;
    padding-left: 4%;
  }
}

.layout_child_dentistry {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
  margin-bottom: 40px;
  padding-bottom: 40px;
  border-bottom: 1px dashed #E0DEDC;
}

.layout_child_dentistry .img {
  max-width: 285px;
  width: 100%;
}

.layout_child_dentistry .description {
  max-width: 430px;
  width: 100%;
}

@media screen and (max-width: 600px) {
  .layout_child_dentistry {
    margin-bottom: 20px;
    padding-bottom: 20px;
  }
}

.layout_child_dentistry.img_right {
  flex-direction: row-reverse;
}

.layout_child_dentistry.img_right .img {
  margin-right: 0;
  margin-left: 2%;
}

.layout_child_dentistry .img {
  margin-right: 2%;
}

@media screen and (max-width: 960px) {
  .layout_child_dentistry {
    flex-direction: column;
  }

  .layout_child_dentistry .img {
    max-width: none;
    margin: 0;
    padding-bottom: 25px;
  }

  .layout_child_dentistry .img img {
    width: 100%;
    height: 27vw;
    object-fit: cover;
    font-family: 'object-fit: cover;';
  }

  .layout_child_dentistry .description {
    max-width: none;
  }

  .layout_child_dentistry.img_right {
    flex-direction: column;
  }

  .layout_child_dentistry.img_right .img {
    margin-left: 0;
  }

  .layout_child_dentistry .img img {
    object-position: 0% 30%;
    font-family: 'object-position: 0% 30%;';
  }
}

@media screen and (max-width: 600px) {
  .layout_child_dentistry .img img {
    height: 30vw;
  }
}

.lst_child_dentistry_guide {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
}

.lst_child_dentistry_guide li:last-child {
  margin-left: 2%;
}

.lst_child_dentistry_guide .inner {
  max-width: 360px;
  width: 100%;
}

.lst_child_dentistry_guide .img {
  padding-bottom: 20px;
}

/* 2025特設ページリンク設置
--------------------------------------------------------------------*/
.sec_child_dentistry .special-link {
  text-align: center;
}

.sec_child_dentistry .special-link p,
.sec_child_dentistry .special-link a {
  font-weight: bold;
  text-align: center;
  text-decoration: none !important;
}

.sec_child_dentistry .special-link a:hover {
  text-decoration: underline !important;
}

.sec_child_dentistry .special-link p {
  font-size: 2.0rem;
  color: #D36100;
}

.sec_child_dentistry .publicity-text {
  font-size: 1.2rem !important;
  font-weight: normal !important;
  color: #46392E !important;
}

/* Section Child Remediation
--------------------------------------------------------------------*/
.sec_child_remediation {
  border-radius: 10px;
  background: white;
  padding: 25px;
}

@media screen and (max-width: 600px) {
  .sec_child_remediation {
    padding-right: 4%;
    padding-left: 4%;
  }
}

.sub_sec_tooth_align_type {
  padding-bottom: 40px;
}

.sub_sec_tooth_align_type .layout_inner {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  flex-wrap: wrap;
  padding: 20px;
  border: 1px solid #46392E;
}

.sub_sec_tooth_align_type .layout_inner>.txt {
  width: 100%;
  padding-top: 25px;
}

@media screen and (max-width: 600px) {
  .sub_sec_tooth_align_type {
    padding-bottom: 20px;
  }

  .sub_sec_tooth_align_type .layout_inner {
    padding-right: 4%;
    padding-left: 4%;
    flex-direction: column;
  }
}

.tooth_align_normal {
  width: 25%;
  padding: 20px;
  border: 4px solid #FFE3A2;
}

.tooth_align_normal .ttl {
  padding-bottom: 20px;
  font-size: 1.4rem;
  color: #D36100;
  text-align: center;
}

.tooth_align_normal .img {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  align-items: center;
  flex-direction: column;
}

.tooth_align_normal .img figure {
  max-width: 110px;
  width: 100%;
  height: 100%;
}

.tooth_align_normal .img figure+figure {
  padding-top: 20px;
}

@media screen and (max-width: 960px) {
  .tooth_align_normal {
    width: 100%;
    margin-bottom: 20px;
  }

  .tooth_align_normal .img {
    justify-content: center;
    flex-direction: row;
  }

  .tooth_align_normal .img figure {
    max-width: 110px;
    width: 100%;
  }

  .tooth_align_normal .img figure+figure {
    margin-left: 2%;
    padding-top: 0;
  }
}

.tooth_align_fault {
  width: 73%;
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  flex-wrap: wrap;
  margin-left: 2%;
  padding: 20px;
  border: 4px solid #CAE8FA;
}

.tooth_align_fault li {
  width: 33.33333%;
}

.tooth_align_fault li:nth-of-type(-n+3) {
  padding-bottom: 15px;
}

.tooth_align_fault .inner {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-direction: column-reverse;
}

.tooth_align_fault .img {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: center;
  align-items: center;
}

.tooth_align_fault .img img {
  width: 94px;
}

.tooth_align_fault .caption {
  padding-bottom: 15px;
  font-size: 1.4rem;
}

@media screen and (max-width: 960px) {
  .tooth_align_fault {
    width: 100%;
    margin-left: 0;
  }

  .tooth_align_fault li {
    width: 50%;
  }

  .tooth_align_fault li:nth-of-type(-n+3) {
    padding-bottom: 15px;
  }

  .tooth_align_fault .img img {
    width: 80px;
  }

  .tooth_align_fault .caption {
    font-size: 1rem;
  }
}

@media screen and (max-width: 600px) {
  .tooth_align_fault {
    padding: 10px;
  }
}

.sub_sec_child_dent_treatment_type {
  padding-bottom: 40px;
}

@media screen and (max-width: 600px) {
  .sub_sec_child_dent_treatment_type {
    padding-bottom: 20px;
  }
}

.tbl_child_dent_treatment_type th {
  width: 20%;
}

.tbl_child_dent_treatment_type td {
  width: 40%;
}

@media screen and (max-width: 600px) {
  .tbl_child_dent_treatment_type th {
    width: 100%;
  }

  .tbl_child_dent_treatment_type td {
    width: 100%;
  }

  .tbl_child_dent_treatment_type td:not(:last-child) {
    border-bottom-style: dashed;
  }
}

.tbl_remediation_consultant {
  margin-bottom: 40px;
}

.tbl_remediation_consultant th {
  width: 20%;
}

.tbl_remediation_consultant td {
  width: 40%;
}

@media screen and (max-width: 600px) {
  .tbl_remediation_consultant {
    margin-bottom: 20px;
  }

  .tbl_remediation_consultant th {
    width: 100%;
  }

  .tbl_remediation_consultant td {
    width: 100%;
  }

  .tbl_remediation_consultant td:not(:last-child) {
    border-bottom-style: dashed;
  }
}

/* ===================================================================
Layout Esthetic
=================================================================== */
/* Section Esthetic About
--------------------------------------------------------------------*/
.sec_esthetic_about {
  border-radius: 10px;
  background: white;
  padding: 25px;
}

@media screen and (max-width: 600px) {
  .sec_esthetic_about {
    padding-right: 4%;
    padding-left: 4%;
  }
}

.sub_sec_esthetic_description {
  margin-bottom: 40px;
  padding-bottom: 40px;
  border-bottom: 1px dashed #E0DEDC;
}

@media screen and (max-width: 600px) {
  .sub_sec_esthetic_description {
    margin-bottom: 20px;
    padding-bottom: 20px;
  }
}

.sub_sec_esthetic_description .layout_inner .img {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
  padding-bottom: 20px;
}

.sub_sec_esthetic_description .layout_inner .img figure {
  width: 49%;
}

.sub_sec_esthetic_description .layout_inner .img figure:last-child {
  margin-left: 2%;
}

.sub_sec_esthetic_treatment_type {
  margin-bottom: 40px;
  padding-bottom: 40px;
  border-bottom: 1px dashed #E0DEDC;
}

@media screen and (max-width: 600px) {
  .sub_sec_esthetic_treatment_type {
    margin-bottom: 20px;
    padding-bottom: 20px;
  }
}

.tbl_esthetic_treatment_type thead th:nth-of-type(1),
.tbl_esthetic_treatment_type thead th:nth-of-type(3) {
  width: 20%;
}

.tbl_esthetic_treatment_type thead th:nth-of-type(2) {
  width: 60%;
}

@media screen and (max-width: 600px) {
  .tbl_esthetic_treatment_type thead {
    display: none;
  }

  .tbl_esthetic_treatment_type td:not(:last-child) {
    border-bottom-style: dashed;
  }
}

.tbl_esthetic_whitening_type thead th:nth-of-type(1),
.tbl_esthetic_whitening_type thead th:nth-of-type(3) {
  width: 20%;
}

.tbl_esthetic_whitening_type thead th:nth-of-type(2) {
  width: 60%;
}

.tbl_esthetic_whitening_type .txt_small {
  display: block;
  font-size: 1rem;
}

@media screen and (max-width: 600px) {
  .tbl_esthetic_whitening_type thead {
    display: none;
  }

  .tbl_esthetic_whitening_type td:not(:last-child) {
    border-bottom-style: dashed;
  }
}

/* ===================================================================
Layout renewal Child Dentistry,
=================================================================== */
/* Section renewalChild Dentistry 20260220
--------------------------------------------------------------------*/

/* ==========================================================
   box1: くすやま歯科クリニック小児歯科（トップ）
   ========================================================== */
.renewal_child_dentistry .sec_child_dentistry.box1 {
  background-color: #fff;
  padding: 40px;
  border-radius: 8px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
}

.renewal_child_dentistry .sec_child_dentistry.box1 .sec_title {
  text-align: center;
  color: #6db54a;
  margin-bottom: 40px;
}

.renewal_child_dentistry .sec_child_dentistry.box1 .sec_title .sub {
  font-size: 1.1rem;
  font-weight: bold;
  margin-bottom: 5px;
  display: block;
}

.renewal_child_dentistry .sec_child_dentistry.box1 .sec_title .main {
  font-size: 1.4rem;
  font-weight: bold;
}

.renewal_child_dentistry .sec_child_dentistry.box1 .layout_child_dentistry {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 40px;
  gap: 30px;
}

.renewal_child_dentistry .sec_child_dentistry.box1 .layout_child_dentistry .description {
  flex: 1;
  min-width: 320px;
}

.renewal_child_dentistry .sec_child_dentistry.box1 .layout_child_dentistry .description h3 {
  color: #d36417;
  font-size: 1.1rem;
  margin-top: 0;
  margin-bottom: 25px;
  font-weight: bold;
}

.renewal_child_dentistry .sec_child_dentistry.box1 .layout_child_dentistry .description p {
  font-size: 0.95rem;
  line-height: 1.8;
  color: #444;
}

.renewal_child_dentistry .sec_child_dentistry.box1 .layout_child_dentistry .img {
  width: 40%;
  min-width: 300px;
}

.renewal_child_dentistry .sec_child_dentistry.box1 .lst_child_dentistry_guide {
  display: flex;
  margin-bottom: 30px;
  gap: 15px;
  /* 画像の間に少し隙間を入れる */
  padding: 0;
  list-style: none;
}

.renewal_child_dentistry .sec_child_dentistry.box1 .lst_child_dentistry_guide li {
  flex: 1;
}

.renewal_child_dentistry .sec_child_dentistry.box1 .lst_child_dentistry_guide .img {
  margin: 0;
  height: 100%;
}

.renewal_child_dentistry .sec_child_dentistry.box1 .lst_child_dentistry_guide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.renewal_child_dentistry .sec_child_dentistry.box1 .box_bottom_txt {
  text-align: center;
  color: #d36417;
  font-weight: bold;
  font-size: 1.1rem;
  line-height: 1.8;
}

/* ==========================================================
   box2: お困りごと
   ========================================================== */
.renewal_child_dentistry .sec_child_dentistry.box2 {
  background-color: #fbfaf6;
  border-radius: 12px;
  padding: 40px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
}

.renewal_child_dentistry .sec_child_dentistry.box2 .trouble-title {
  font-size: 1.5rem;
  font-weight: bold;
  margin-bottom: 20px;
}

.renewal_child_dentistry .sec_child_dentistry.box2 .trouble-subtitle {
  font-size: 1.1rem;
  color: #e26120;
  font-weight: bold;
  margin-bottom: 30px;
}

.renewal_child_dentistry .sec_child_dentistry.box2 .trouble-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-bottom: 40px;
}

.renewal_child_dentistry .sec_child_dentistry.box2 .trouble-item {
  text-align: center;
  background: #fff;
  padding-bottom: 10px;
  border-radius: 4px;
  overflow: hidden;
}

.renewal_child_dentistry .sec_child_dentistry.box2 .trouble-item img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  margin-bottom: 10px;
  display: block;
}

.trouble-item-text {
  font-size: 0.9rem;
  font-weight: bold;
  padding: 0 5px;
}

.renewal_child_dentistry .sec_child_dentistry.box2 .trouble-footer {
  text-align: center;
  font-size: 1.1rem;
  color: #e26120;
  font-weight: bold;
}

/* ==========================================================
   box3: 小児矯正
   ========================================================== */


.renewal_child_dentistry .sec_child_dentistry.box3 .ortho-content {
  display: flex;
  align-items: flex-start;
  gap: 30px;
  margin-bottom: 25px;
}

.renewal_child_dentistry .sec_child_dentistry.box3 .ortho-image {
  flex-shrink: 0;
  width: 250px;
}

.renewal_child_dentistry .sec_child_dentistry.box3 .ortho-image img {
  width: 100%;
  border-radius: 4px;
  display: block;
}

.renewal_child_dentistry .sec_child_dentistry.box3 .ortho-text {
  flex: 1;
}

.renewal_child_dentistry .sec_child_dentistry.box3 .ortho-title {
  font-size: 1.3rem;
  font-weight: bold;
  color: #4c3f36;
  margin-bottom: 15px;
  margin-top: 0;
}

.renewal_child_dentistry .sec_child_dentistry.box3 .ortho-description {
  font-size: 0.95rem;
  line-height: 1.8;
  color: #555;
}

.renewal_child_dentistry .sec_child_dentistry.box3 .ortho-button-container {
  text-align: center;
}

.renewal_child_dentistry .sec_child_dentistry.box3 .ortho-button {
  display: inline-block;
  background-color: #7ab93c;
  color: #fff;
  text-decoration: none;
  font-weight: bold;
  padding: 12px 40px;
  border-radius: 30px;
  font-size: 1rem;
  transition: background-color 0.3s;
}

.renewal_child_dentistry .sec_child_dentistry.box3 .ortho-button:hover {
  background-color: #6da634;
}

/* ==========================================================
   box4: 診療・治療方針
   ========================================================== */
.renewal_child_dentistry .sec_child_dentistry.box4 {
  background-color: #fff;
  padding: 40px;
  border-left: 8px solid #f8f5eb;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
}

.renewal_child_dentistry .sec_child_dentistry.box4 .policy-main-title {
  font-size: 1.5rem;
  font-weight: bold;
  margin-bottom: 30px;
  border-bottom: 1px solid #eee;
  padding-bottom: 10px;
}

.renewal_child_dentistry .sec_child_dentistry.box4 .policy-section-top {
  display: flex;
  align-items: flex-start;
  gap: 30px;
  margin-bottom: 40px;
}

.renewal_child_dentistry .sec_child_dentistry.box4 .policy-text-area {
  flex: 1;
}

.renewal_child_dentistry .sec_child_dentistry.box4 .policy-subtitle {
  font-size: 1.2rem;
  color: #e26120;
  font-weight: bold;
  margin-bottom: 20px;
}

.renewal_child_dentistry .sec_child_dentistry.box4 .policy-text {
  font-size: 0.95rem;
  line-height: 1.8;
  color: #555;
  margin-bottom: 15px;
}

.renewal_child_dentistry .sec_child_dentistry.box4 .policy-text.highlight {
  font-weight: bold;
  text-decoration: underline;
  text-decoration-color: #555;
}

.renewal_child_dentistry .sec_child_dentistry.box4 .policy-image-area {
  width: 45%;
  min-width: 300px;
  flex-shrink: 0;
}

.renewal_child_dentistry .sec_child_dentistry.box4 .policy-image-area img {
  border-radius: 4px;
}

.renewal_child_dentistry .sec_child_dentistry.box4 .policy-section-bottom {
  margin-top: 20px;
}

/* ==========================================================
   box6: 診察から治療・予防ケア（※box5は欠番想定）
   ========================================================== */
.renewal_child_dentistry .sec_child_dentistry.box5 {
  background-color: #fff;
  padding: 40px;
  border-radius: 8px;
  border: 1px solid #f8f5eb;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
}

.renewal_child_dentistry .sec_child_dentistry.box5 .process-title {
  text-align: center;
  font-size: 1.3rem;
  font-weight: bold;
  color: #4a3e35;
  margin-bottom: 50px;
}

.renewal_child_dentistry .sec_child_dentistry.box5 .process-steps {
  display: flex;
  justify-content: space-between;
  gap: 30px;
}

.renewal_child_dentistry .sec_child_dentistry.box5 .process-step {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.renewal_child_dentistry .sec_child_dentistry.box5 .process-icon-area {
  background-color: #f3f8d6;
  width: 100%;
  padding-top: 100%;
  position: relative;
  border-radius: 50% 50% 0 0;
  margin-bottom: 25px;
  overflow: hidden;
}

.renewal_child_dentistry .sec_child_dentistry.box5 .process-icon-inner {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding-bottom: 10%;
}

.renewal_child_dentistry .sec_child_dentistry.box5 .process-icon-inner img {
  width: 50px;
  /* アイコンを少し大きめに */
  height: auto;
  margin-bottom: 10px;
}

.renewal_child_dentistry .sec_child_dentistry.box5 .process-step-title {
  color: #6db54a;
  font-size: 1.2rem;
  font-weight: bold;
  text-align: center;
  line-height: 1.4;
}

.renewal_child_dentistry .sec_child_dentistry.box5 .process-step-text {
  font-size: 0.9rem;
  color: #555;
  line-height: 1.8;
}

/* ==========================================================
   box7: 予防ケア（家庭・医院）
   ========================================================== */
.renewal_child_dentistry .sec_child_dentistry.box6 {
  background-color: #fbfaf6;
  border-radius: 8px;
  padding: 40px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
}

.renewal_child_dentistry .sec_child_dentistry.box6 .preventive-title {
  font-size: 1.4rem;
  font-weight: bold;
  color: #4a3e35;
  margin-bottom: 20px;
}

.renewal_child_dentistry .sec_child_dentistry.box6 .preventive-subtitle {
  font-size: 1.1rem;
  color: #d36417;
  font-weight: bold;
  margin-bottom: 30px;
}

.renewal_child_dentistry .sec_child_dentistry.box6 .preventive-images {
  display: flex;
  margin-bottom: 30px;
}

.renewal_child_dentistry .sec_child_dentistry.box6 .preventive-intro-text {
  font-size: 0.95rem;
  line-height: 1.8;
  color: #555;
  margin-bottom: 40px;
}

.renewal_child_dentistry .sec_child_dentistry.box6 .care-columns {
  display: flex;
  gap: 30px;
  margin-bottom: 40px;
}

.renewal_child_dentistry .sec_child_dentistry.box6 .care-column {
  flex: 1;
}

.renewal_child_dentistry .sec_child_dentistry.box6 .care-title-box {
  background-color: #df9c36;
  color: #fff;
  padding: 15px 20px;
  display: flex;
  align-items: center;
  gap: 15px;
  margin-bottom: 20px;
}

.renewal_child_dentistry .sec_child_dentistry.box6 .care-icon {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.renewal_child_dentistry .sec_child_dentistry.box6 .care-icon img {
  width: 100%;
  filter: brightness(0) invert(1);
}

.renewal_child_dentistry .sec_child_dentistry.box6 .care-title-text {
  display: flex;
  flex-direction: column;
}

.renewal_child_dentistry .sec_child_dentistry.box6 .care-title-main {
  font-size: 1.2rem;
  font-weight: bold;
}

.renewal_child_dentistry .sec_child_dentistry.box6 .care-title-sub {
  font-size: 0.8rem;
}

.renewal_child_dentistry .sec_child_dentistry.box6 .care-description {
  font-size: 0.95rem;
  line-height: 1.8;
  color: #555;
}

.renewal_child_dentistry .sec_child_dentistry.box6 .preventive-footer {
  text-align: center;
  font-size: 1.1rem;
  color: #d36417;
  font-weight: bold;
}

/* ==========================================================
   box8: キッズクラブ
   ========================================================== */
.renewal_child_dentistry .sec_child_dentistry.box7 {
  background-color: #fff;
  padding: 40px;
  border-radius: 8px;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
  text-align: center;
}

.renewal_child_dentistry .sec_child_dentistry.box7 .kids-club-title {
  color: #6db54a;
  font-size: 1.6rem;
  font-weight: bold;
  margin-bottom: 15px;
}

.renewal_child_dentistry .sec_child_dentistry.box7 .kids-club-subtitle {
  color: #d36417;
  font-size: 1.2rem;
  font-weight: bold;
  margin-bottom: 30px;
}

.renewal_child_dentistry .sec_child_dentistry.box7 .kids-club-description {
  font-size: 0.95rem;
  color: #555;
  line-height: 1.8;
  margin-bottom: 30px;
}

.renewal_child_dentistry .sec_child_dentistry.box7 .pdf-notice {
  color: #d36417;
  font-size: 0.9rem;
  margin-bottom: 20px;
}

.renewal_child_dentistry .sec_child_dentistry.box7 .kids-club-flyers {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 40px;
}

.renewal_child_dentistry .sec_child_dentistry.box7 .flyer-item {
  flex: 1;
}

.renewal_child_dentistry .sec_child_dentistry.box7 .flyer-item a {
  display: block;
  text-decoration: none;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.renewal_child_dentistry .sec_child_dentistry.box7 .flyer-item a:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 15px rgba(0, 0, 0, 0.1);
}

.renewal_child_dentistry .sec_child_dentistry.box7 .flyer-item img {
  border: 1px solid #eee;
  display: block;
}

.renewal_child_dentistry .sec_child_dentistry.box7 .kids-club-footer {
  font-size: 1.1rem;
  font-weight: bold;
  color: #4a3e35;
  margin-top: 20px;
}

/* ==========================================================
   box9: 予約・相談
   ========================================================== */
.renewal_child_dentistry .sec_child_dentistry.box8 {
  background-color: #fff;
  padding: 30px;
  border: 1px solid #c8e0ad;
  border-top: 3px solid #b3d48d;
}

.renewal_child_dentistry .sec_child_dentistry.box8 .contact-actions {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 25px;
  padding-bottom: 25px;
  border-bottom: 1px solid transparent;
  position: relative;
}

.renewal_child_dentistry .sec_child_dentistry.box8 .contact-actions::after {
  content: '';
  position: absolute;
  top: 10%;
  bottom: 10%;
  left: 50%;
  width: 1px;
  background-color: #d1e5bd;
  transform: translateX(-50%);
}

.renewal_child_dentistry .sec_child_dentistry.box8 .contact-box {
  flex: 1;
  text-align: center;
  padding: 0 20px;
}

.renewal_child_dentistry .sec_child_dentistry.box8 .contact-label {
  font-size: 0.9rem;
  color: #4a3e35;
  font-weight: bold;
  margin-bottom: 15px;
}

.renewal_child_dentistry .sec_child_dentistry.box8 .contact-phone-number {
  font-size: 2rem;
  font-weight: bold;
  color: #6fb633;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  line-height: 1;
}

.renewal_child_dentistry .sec_child_dentistry.box8 .contact-phone-number i {
  font-size: 1.5rem;
  background-color: #6fb633;
  color: #fff;
  padding: 8px 10px;
  border-radius: 8px;
}

.renewal_child_dentistry .sec_child_dentistry.box8 .contact-line-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  background-color: #06c755;
  color: #fff;
  text-decoration: none;
  padding: 12px 30px;
  border-radius: 5px;
  font-size: 1.1rem;
  font-weight: bold;
  transition: opacity 0.3s ease;
}

.renewal_child_dentistry .sec_child_dentistry.box8 .contact-line-btn:hover {
  opacity: 0.8;
}

.renewal_child_dentistry .sec_child_dentistry.box8 .contact-line-btn i {
  font-size: 1.6rem;
}

.renewal_child_dentistry .sec_child_dentistry.box8 .contact-notes {
  font-size: 0.85rem;
  color: #555;
  line-height: 1.8;
}

.renewal_child_dentistry .sec_child_dentistry.box8 .contact-notes p {
  margin: 0;
  padding-left: 1em;
  text-indent: -1em;
}

/* ==========================================================
   レスポンシブ (スマホ表示) 全セクション一括
   ========================================================== */
@media (max-width: 768px) {

  /* box1 */
  .renewal_child_dentistry .sec_child_dentistry.box1 .layout_child_dentistry {
    flex-direction: column;
  }

  .renewal_child_dentistry .sec_child_dentistry.box1 .layout_child_dentistry .img {
    width: 100%;
  }

  .renewal_child_dentistry .sec_child_dentistry.box1 .lst_child_dentistry_guide {
    flex-direction: column;
  }

  /* box2 */
  .renewal_child_dentistry .sec_child_dentistry.box2 .trouble-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .renewal_child_dentistry .sec_child_dentistry.box2 {
    padding: 20px;
  }

  /* box4 */
  .renewal_child_dentistry .sec_child_dentistry.box4 {
    padding: 20px;
  }

  .renewal_child_dentistry .sec_child_dentistry.box4 .policy-section-top {
    flex-direction: column;
  }

  .renewal_child_dentistry .sec_child_dentistry.box4 .policy-image-area {
    width: 100%;
    margin-top: 20px;
  }

  /* box6 */
  .renewal_child_dentistry .sec_child_dentistry.box5 .process-steps {
    flex-direction: column;
    gap: 40px;
  }

  .renewal_child_dentistry .sec_child_dentistry.box5 .process-icon-area {
    width: 200px;
    padding-top: 200px;
    margin: 0 auto 20px;
  }

  .renewal_child_dentistry .sec_child_dentistry.box5 .process-step-text {
    width: 100%;
    max-width: 400px;
    margin: 0 auto;
  }

  /* box7 */
  .renewal_child_dentistry .sec_child_dentistry.box6 {
    padding: 20px;
  }

  .renewal_child_dentistry .sec_child_dentistry.box6 .preventive-images {
    flex-direction: column;
    gap: 10px;
  }

  .renewal_child_dentistry .sec_child_dentistry.box6 .care-columns {
    flex-direction: column;
    gap: 40px;
  }

  /* box8 */
  .renewal_child_dentistry .sec_child_dentistry.box7 {
    padding: 20px;
  }

  .renewal_child_dentistry .sec_child_dentistry.box7 .kids-club-flyers {
    flex-direction: column;
    gap: 30px;
  }
}


/* ===================================================================
Layout Implant
=================================================================== */
/* Section Implant About
--------------------------------------------------------------------*/
.sec_implant_about {
  border-radius: 10px;
  background: white;
  padding: 25px;
}

@media screen and (max-width: 600px) {
  .sec_implant_about {
    padding-right: 4%;
    padding-left: 4%;
  }
}

.layout_implant_about {
  margin-bottom: 40px;
  padding-bottom: 40px;
  border-bottom: 1px dashed #E0DEDC;
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
  flex-direction: row-reverse;
}

@media screen and (max-width: 600px) {
  .layout_implant_about {
    margin-bottom: 20px;
    padding-bottom: 20px;
  }
}

.layout_implant_about .img {
  max-width: 285px;
  width: 100%;
}

.layout_implant_about .description {
  max-width: 430px;
  width: 100%;
}

.layout_implant_about .img {
  margin-left: 2%;
}

@media screen and (max-width: 960px) {
  .layout_implant_about {
    flex-direction: column;
    flex-direction: column;
  }

  .layout_implant_about .img {
    max-width: none;
    margin: 0;
    padding-bottom: 25px;
  }

  .layout_implant_about .img img {
    width: 100%;
    height: 27vw;
    object-fit: cover;
    font-family: 'object-fit: cover;';
  }

  .layout_implant_about .description {
    max-width: none;
  }
}

@media screen and (max-width: 600px) {
  .layout_implant_about .img img {
    height: 30vw;
  }
}

.sub_sec_implant_treatment_type {
  margin-bottom: 40px;
  padding-bottom: 40px;
  border-bottom: 1px dashed #E0DEDC;
}

@media screen and (max-width: 600px) {
  .sub_sec_implant_treatment_type {
    margin-bottom: 20px;
    padding-bottom: 20px;
  }
}

.tbl_implant_treatment_type {
  margin-bottom: 40px;
}

.tbl_implant_treatment_type th {
  width: 20%;
}

.tbl_implant_treatment_type td:nth-of-type(1) {
  width: 40%;
}

.tbl_implant_treatment_type td:nth-of-type(2) {
  width: 20%;
}

@media screen and (max-width: 600px) {
  .tbl_implant_treatment_type {
    margin-bottom: 20px;
  }

  .tbl_implant_treatment_type th {
    width: 100%;
  }

  .tbl_implant_treatment_type td:nth-of-type(1),
  .tbl_implant_treatment_type td:nth-of-type(2) {
    width: 100%;
  }

  .tbl_implant_treatment_type td:not(:last-child) {
    border-bottom-style: dashed;
  }
}

.sub_sec_implant_maintenance {
  margin-bottom: 40px;
  padding-bottom: 40px;
  border-bottom: 1px dashed #E0DEDC;
}

@media screen and (max-width: 600px) {
  .sub_sec_implant_maintenance {
    margin-bottom: 20px;
    padding-bottom: 20px;
  }
}

.tbl_implant_consultation th {
  width: 20%;
}

.tbl_implant_consultation td {
  width: 80%;
}

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

  .tbl_implant_consultation th,
  .tbl_implant_consultation td {
    width: 100%;
  }

  .tbl_implant_consultation .pc_on {
    display: none;
  }
}

/* ===================================================================
Layout Preventive Dentistry
=================================================================== */
/* Section Preventive Dentistry About
--------------------------------------------------------------------*/
.sec_preventive_dentistry_about {
  border-radius: 10px;
  background: white;
  margin-bottom: 40px;
  padding: 25px;
}

@media screen and (max-width: 600px) {
  .sec_preventive_dentistry_about {
    margin-bottom: 20px;
    padding-right: 4%;
    padding-left: 4%;
  }
}

.layout_preventive_dentistry {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
  padding-bottom: 40px;
}

.layout_preventive_dentistry .img {
  max-width: 285px;
  width: 100%;
}

.layout_preventive_dentistry .description {
  max-width: 430px;
  width: 100%;
}

.layout_preventive_dentistry:nth-of-type(2) {
  margin-bottom: 40px;
  padding-bottom: 40px;
  border-bottom: 1px dashed #E0DEDC;
}

@media screen and (max-width: 600px) {
  .layout_preventive_dentistry:nth-of-type(2) {
    margin-bottom: 20px;
    padding-bottom: 20px;
  }
}

.layout_preventive_dentistry.img_right {
  flex-direction: row-reverse;
}

.layout_preventive_dentistry.img_right .img {
  margin-right: 0;
  margin-left: 2%;
}

.layout_preventive_dentistry .img {
  margin-right: 2%;
}

@media screen and (max-width: 960px) {
  .layout_preventive_dentistry {
    flex-direction: column;
  }

  .layout_preventive_dentistry .img {
    max-width: none;
    margin: 0;
    padding-bottom: 25px;
  }

  .layout_preventive_dentistry .img img {
    width: 100%;
    height: 27vw;
    object-fit: cover;
    font-family: 'object-fit: cover;';
  }

  .layout_preventive_dentistry .description {
    max-width: none;
  }

  .layout_preventive_dentistry.img_right {
    flex-direction: column;
  }

  .layout_preventive_dentistry.img_right .img {
    margin-left: 0;
  }

  .layout_preventive_dentistry .img img {
    object-position: 0% 30%;
    font-family: 'object-position: 0% 30%;';
  }
}

@media screen and (max-width: 600px) {
  .layout_preventive_dentistry {
    padding-bottom: 20px;
  }

  .layout_preventive_dentistry .img img {
    height: 30vw;
  }
}

.lst_preventive_cleaning_guide {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
}

.lst_preventive_cleaning_guide>li:last-child {
  margin-left: 2%;
}

.lst_preventive_cleaning_guide .inner {
  max-width: 360px;
  width: 100%;
}

.lst_preventive_cleaning_guide .img {
  padding-bottom: 20px;
}

.lst_preventive_cleaning_guide .lst_cleaning li:before {
  content: '\f058';
  padding-right: .4em;
  font-family: FontAwesome;
}

.lst_preventive_cleaning_guide .lst_cleaning .txt_small {
  font-size: 1rem;
}

/* Section Preventive Dentistry Thinking
--------------------------------------------------------------------*/
.sec_preventive_dentistry_thinking {
  border-radius: 10px;
  background: white;
  padding: 25px;
}

@media screen and (max-width: 600px) {
  .sec_preventive_dentistry_thinking {
    padding-right: 4%;
    padding-left: 4%;
  }
}

.sub_sec_preventive_lead {
  padding-bottom: 40px;
}

@media screen and (max-width: 600px) {
  .sub_sec_preventive_lead {
    padding-bottom: 20px;
  }
}

.layout_preventive_thinking {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
}

.layout_preventive_thinking .img {
  max-width: 285px;
  width: 100%;
}

.layout_preventive_thinking .description {
  max-width: 430px;
  width: 100%;
}

.layout_preventive_thinking+.layout_preventive_thinking {
  padding-top: 30px;
}

.layout_preventive_thinking.img_right {
  flex-direction: row-reverse;
}

.layout_preventive_thinking.img_right .img {
  margin-right: 0;
  margin-left: 2%;
}

.layout_preventive_thinking .img {
  margin-right: 2%;
}

@media screen and (max-width: 960px) {
  .layout_preventive_thinking {
    flex-direction: column;
  }

  .layout_preventive_thinking .img {
    max-width: none;
    margin: 0;
    padding-bottom: 25px;
  }

  .layout_preventive_thinking .img img {
    width: 100%;
    height: 27vw;
    object-fit: cover;
    font-family: 'object-fit: cover;';
  }

  .layout_preventive_thinking .description {
    max-width: none;
  }

  .layout_preventive_thinking.img_right {
    flex-direction: column;
  }

  .layout_preventive_thinking.img_right .img {
    margin-left: 0;
  }

  .layout_preventive_thinking .img img {
    object-position: 0% 30%;
    font-family: 'object-position: 0% 30%;';
  }
}

@media screen and (max-width: 600px) {
  .layout_preventive_thinking .img img {
    height: 30vw;
  }

  .layout_preventive_thinking+.layout_preventive_thinking {
    padding-top: 20px;
  }
}

/* ===================================================================
Layout Oral Surgery
=================================================================== */
/* Section Oral Surgery About
--------------------------------------------------------------------*/
.sec_oral_surgery_about {
  border-radius: 10px;
  background: white;
  margin-bottom: 40px;
  padding: 25px;
}

@media screen and (max-width: 600px) {
  .sec_oral_surgery_about {
    margin-bottom: 20px;
    padding-right: 4%;
    padding-left: 4%;
  }
}

.tbl_oral_surgery_guide {
  margin-bottom: 40px;
}

@media screen and (max-width: 600px) {
  .tbl_oral_surgery_guide {
    margin-bottom: 20px;
  }

  .tbl_oral_surgery_guide td:not(:last-child) {
    border-bottom: 1px dashed #46392E;
  }
}

.lst_medical_contents {
  max-width: 720px;
  width: 100%;
  margin: 0 auto;
  padding-left: 1.7em;
}

.lst_medical_contents li {
  position: relative;
}

.lst_medical_contents li:not(:last-child) {
  padding-bottom: 25px;
}

.lst_medical_contents li:before {
  content: '\f058';
  padding-right: .4em;
  font-family: FontAwesome;
  position: absolute;
  top: -2px;
  bottom: 0;
  left: -1.4em;
  margin: auto 0;
  font-size: 1.4rem;
}

.lst_medical_contents .txt {
  padding-top: .4em;
}

@media screen and (max-width: 960px) {
  .lst_medical_contents {
    max-width: none;
  }
}

@media screen and (max-width: 600px) {
  .lst_medical_contents li:not(:last-child) {
    padding-bottom: 1em;
  }
}

/* Section Oral Surgery Doctor
--------------------------------------------------------------------*/
.sec_oral_surgery_doctor {
  border-radius: 10px;
  background: white;
  padding: 25px;
}

.sec_oral_surgery_doctor .greeting {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
  flex-direction: row-reverse;
}

.sec_oral_surgery_doctor .greeting .img {
  max-width: 285px;
  width: 100%;
}

.sec_oral_surgery_doctor .greeting .description {
  max-width: 430px;
  width: 100%;
}

.sec_oral_surgery_doctor .greeting .img {
  margin-left: 2%;
}

.sec_oral_surgery_doctor .ttl {
  margin-bottom: 0;
  border: none;
}

.sec_oral_surgery_doctor .lst_career {
  padding-bottom: 15px;
}

.sec_oral_surgery_doctor .lst_career li {
  padding: .6em 0;
  border-bottom: 1px dashed #46392E;
}

@media screen and (max-width: 960px) {
  .sec_oral_surgery_doctor .greeting {
    flex-direction: column;
    flex-direction: column;
  }

  .sec_oral_surgery_doctor .greeting .img {
    max-width: none;
    margin: 0;
    padding-bottom: 25px;
  }

  .sec_oral_surgery_doctor .greeting .img img {
    width: 100%;
    height: 27vw;
    object-fit: cover;
    font-family: 'object-fit: cover;';
  }

  .sec_oral_surgery_doctor .greeting .description {
    max-width: none;
  }

  .sec_oral_surgery_doctor .greeting .img {
    margin-left: 0;
  }

  .sec_oral_surgery_doctor .greeting .img img {
    object-position: 0% 34%;
    font-family: 'object-position: 0% 34%;';
  }
}

@media screen and (max-width: 600px) {
  .sec_oral_surgery_doctor {
    padding-right: 4%;
    padding-left: 4%;
  }

  .sec_oral_surgery_doctor .greeting .img img {
    height: 30vw;
  }
}

/* ===================================================================
Layout House Call
=================================================================== */
/* Section House Call Oral Care
--------------------------------------------------------------------*/
.sec_house_call_oral_care {
  border-radius: 10px;
  background: white;
  margin-bottom: 40px;
  padding: 25px;
}

@media screen and (max-width: 600px) {
  .sec_house_call_oral_care {
    margin-bottom: 20px;
    padding-right: 4%;
    padding-left: 4%;
  }
}

.layout_house_call_oral_care {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
  padding-bottom: 40px;
  flex-direction: row-reverse;
}

.layout_house_call_oral_care .img {
  max-width: 285px;
  width: 100%;
}

.layout_house_call_oral_care .description {
  max-width: 430px;
  width: 100%;
}

.layout_house_call_oral_care .img {
  margin-left: 2%;
}

@media screen and (max-width: 960px) {
  .layout_house_call_oral_care {
    flex-direction: column;
    flex-direction: column;
  }

  .layout_house_call_oral_care .img {
    max-width: none;
    margin: 0;
    padding-bottom: 25px;
  }

  .layout_house_call_oral_care .img img {
    width: 100%;
    height: 27vw;
    object-fit: cover;
    font-family: 'object-fit: cover;';
  }

  .layout_house_call_oral_care .description {
    max-width: none;
  }
}

@media screen and (max-width: 600px) {
  .layout_house_call_oral_care {
    padding-bottom: 20px;
  }

  .layout_house_call_oral_care .img img {
    height: 30vw;
  }
}

/* Section House Call About
--------------------------------------------------------------------*/
.sec_house_call_about {
  border-radius: 10px;
  background: white;
  padding: 25px;
}

@media screen and (max-width: 600px) {
  .sec_house_call_about {
    padding-right: 4%;
    padding-left: 4%;
  }
}

.sub_sec_house_call_about_area {
  padding-bottom: 40px;
}

@media screen and (max-width: 600px) {
  .sub_sec_house_call_about_area {
    padding-bottom: 20px;
  }
}

.sub_sec_house_call_service_guide {
  padding-bottom: 40px;
}

@media screen and (max-width: 600px) {
  .sub_sec_house_call_service_guide {
    padding-bottom: 20px;
  }
}

.lst_house_call_service_guide {
  max-width: 720px;
  width: 100%;
  margin: 0 auto;
  padding-left: 1.7em;
}

.lst_house_call_service_guide>li {
  position: relative;
}

.lst_house_call_service_guide>li:not(:last-child) {
  padding-bottom: 25px;
}

.lst_house_call_service_guide>li:before {
  content: '\f058';
  padding-right: .4em;
  font-family: FontAwesome;
  position: absolute;
  top: 0;
  bottom: 0;
  left: -1.4em;
  margin: auto 0;
  font-size: 1.4rem;
}

.lst_house_call_service_guide .ttl {
  font-size: 1.4rem;
}

.lst_house_call_service_guide .ttl+p {
  padding-top: .4em;
}

.lst_house_call_service_guide .txt_orange {
  color: #D36100;
}

.lst_house_call_service_guide .lst_inner {
  padding-bottom: 1em;
  padding-left: 1.6em;
  list-style: disc;
}

@media screen and (max-width: 960px) {
  .lst_house_call_service_guide {
    max-width: none;
  }
}

@media screen and (max-width: 600px) {
  .lst_house_call_service_guide>li:not(:last-child) {
    padding-bottom: 1em;
  }
}

.tbl_house_call_cost {
  margin-bottom: 25px;
}

.tbl_house_call_cost th,
.tbl_house_call_cost td {
  width: 50%;
}

@media screen and (max-width: 600px) {
  .tbl_house_call_cost {
    margin-bottom: 1em;
  }

  .tbl_house_call_cost th,
  .tbl_house_call_cost td {
    width: 100%;
  }
}

.sub_sec_house_call_document>p {
  max-width: 720px;
  width: 100%;
  margin: 0 auto;
  padding-bottom: 25px;
}

.sub_sec_house_call_document .dl {
  padding-top: 25px;
}

.sub_sec_house_call_document .response_devise {
  max-width: 650px;
  width: 100%;
  margin: 0 auto;
  padding: 25px 5%;
  flex-wrap: wrap;
}

.sub_sec_house_call_document .response_devise .tel {
  line-height: 1;
}

.sub_sec_house_call_document .response_devise .summary {
  padding-top: 1em;
}

@media screen and (max-width: 960px) {
  .sub_sec_house_call_document>p {
    max-width: none;
  }
}

@media screen and (max-width: 600px) {
  .sub_sec_house_call_document>p {
    padding-bottom: 1em;
  }

  .sub_sec_house_call_document .dl {
    padding: 1em 0;
  }

  .sub_sec_house_call_document .response_devise {
    max-width: none;
    width: 90%;
    margin: 0 auto;
    padding: 10px 5%;
  }

  .sub_sec_house_call_document .response_devise .summary {
    padding-top: 0;
    font-size: 2.8vw;
  }
}

.lst_document_guide {
  max-width: 720px;
  width: 100%;
  margin: 0 auto;
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  padding-bottom: 25px;
}

.lst_document_guide li:not(:last-child):after {
  content: '/';
  padding: 0 10px;
}

@media screen and (max-width: 960px) {
  .lst_document_guide {
    flex-direction: column;
    max-width: none;
    padding-bottom: 1em;
    padding-left: 1em;
  }

  .lst_document_guide li:not(:last-child):after {
    content: none;
  }
}

/* ===================================================================
Layout Denture
=================================================================== */
/* Section Denture About
--------------------------------------------------------------------*/
.sec_denture_about {
  border-radius: 10px;
  background: white;
  margin-bottom: 40px;
  padding: 25px;
}

.sec_denture_about .layout_inner .img {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
  padding-bottom: 20px;
}

.sec_denture_about .layout_inner .img figure {
  width: 49%;
}

.sec_denture_about .layout_inner .img figure:last-child {
  margin-left: 2%;
}

.sec_denture_about .tbl {
  margin-bottom: 40px;
}

.sec_denture_about .tbl th {
  width: 40%;
}

.sec_denture_about .tbl td {
  width: 30%;
}

@media screen and (max-width: 600px) {
  .sec_denture_about {
    margin-bottom: 20px;
    padding-right: 4%;
    padding-left: 4%;
  }

  .sec_denture_about .tbl {
    margin-bottom: 20px;
  }

  .sec_denture_about .tbl th,
  .sec_denture_about .tbl td {
    width: 100%;
  }
}

.sub_sec_denture_other .lst {
  padding-left: 1.7em;
}

.sub_sec_denture_other .lst li {
  position: relative;
}

.sub_sec_denture_other .lst li:not(:last-child) {
  padding-bottom: 25px;
}

.sub_sec_denture_other .lst li:before {
  content: '\f058';
  padding-right: .4em;
  font-family: FontAwesome;
  position: absolute;
  top: 0;
  bottom: 0;
  left: -1.4em;
  margin: auto 0;
  font-size: 1.4rem;
}

.sub_sec_denture_other .lst p {
  padding-top: .4em;
}

@media screen and (max-width: 600px) {
  .sub_sec_denture_other .lst li:not(:last-child) {
    padding-bottom: 1em;
  }
}

/* ===================================================================
Layout Device
=================================================================== */
/* Section Device About
--------------------------------------------------------------------*/
.sec_device_about {
  border-radius: 10px;
  background: white;
  margin-bottom: 40px;
  padding: 25px;
}

.sec_device_about .layout_inner .img {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
  padding-bottom: 20px;
}

.sec_device_about .layout_inner .img figure {
  width: 49%;
}

.sec_device_about .layout_inner .img figure:last-child {
  margin-left: 2%;
}

@media screen and (max-width: 600px) {
  .sec_device_about {
    margin-bottom: 20px;
    padding-right: 4%;
    padding-left: 4%;
  }
}

/* Section Hospital Landscape
--------------------------------------------------------------------*/
.sec_hospital_landscape {
  border-radius: 10px;
  background: white;
  margin-bottom: 40px;
  padding: 25px;
}

@media screen and (max-width: 600px) {
  .sec_hospital_landscape {
    margin-bottom: 20px;
    padding-right: 4%;
    padding-left: 4%;
  }
}

.sub_sec_hospital_landscape .img {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  padding-bottom: 25px;
}

.sub_sec_hospital_landscape .img figure {
  width: 32%;
}

.sub_sec_hospital_landscape .img figure:not(:nth-child(3n)) {
  margin-right: 2%;
}

.sub_sec_hospital_landscape .img figure:not(:nth-of-type(n+3)) {
  padding-bottom: 20px;
}

@media screen and (max-width: 600px) {
  .sub_sec_hospital_landscape .img figure:not(:nth-of-type(n+3)) {
    padding-bottom: 1em;
  }
}

/* Section Facility Introduction
--------------------------------------------------------------------*/
.sec_facility_intro {
  border-radius: 10px;
  background: white;
  padding: 25px;
}

.sec_facility_intro .lst_commitment:not(:last-child) {
  padding-bottom: 25px;
}

.sec_facility_intro .lst_commitment.img_right .inner {
  flex-direction: row-reverse;
}

@media screen and (max-width: 600px) {
  .sec_facility_intro {
    padding-right: 4%;
    padding-left: 4%;
  }
}

.layout_facility_intro {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
  padding-bottom: 40px;
  flex-direction: row-reverse;
}

.layout_facility_intro .img {
  max-width: 285px;
  width: 100%;
}

.layout_facility_intro .description {
  max-width: 430px;
  width: 100%;
}

.layout_facility_intro .img {
  margin-left: 2%;
}

.layout_facility_intro .img img {
  width: 100%;
  height: 194px;
  object-fit: cover;
  font-family: 'object-fit: cover;';
}

@media screen and (max-width: 960px) {
  .layout_facility_intro {
    flex-direction: column;
    flex-direction: column;
  }

  .layout_facility_intro .img {
    max-width: none;
    margin: 0;
    padding-bottom: 25px;
  }

  .layout_facility_intro .img img {
    width: 100%;
    height: 27vw;
    object-fit: cover;
    font-family: 'object-fit: cover;';
  }

  .layout_facility_intro .description {
    max-width: none;
  }

  .layout_facility_intro .img {
    margin-left: 0;
  }

  .layout_facility_intro .img img {
    height: 22vw;
    object-position: 0% 32%;
    font-family: 'object-position: 0% 32%;';
  }
}

@media screen and (max-width: 600px) {
  .layout_facility_intro {
    padding-bottom: 20px;
  }

  .layout_facility_intro .img img {
    height: 32vw;
    object-position: 0% 36%;
    font-family: 'object-position: 0% 36%;';
  }
}

/* ===================================================================
Layout Access
=================================================================== */
/* Section Medical Time Reserv
--------------------------------------------------------------------*/
.sec_medical_time_reserv {
  border-radius: 10px;
  background: white;
  margin-bottom: 40px;
  padding: 25px;
}

.sec_medical_time_reserv .medical_time {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  flex-direction: column;
  padding-bottom: 30px;
}

.sec_medical_time_reserv .medical_time .tbl_green {
  margin-bottom: 15px;
  font-size: 1.6rem;
}

.sec_medical_time_reserv .medical_time .annotation {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
}

.sec_medical_time_reserv .medical_time .annotation.no-flex {
  display: block;
}

.sec_medical_time_reserv .medical_time .annotation.type_a {
  padding-bottom: 1em;
  font-size: 1.2rem;
}

.sec_medical_time_reserv .medical_time .annotation.type_a li:not(:last-child) {
  padding-right: 1.6em;
}

.sec_medical_time_reserv .medical_time .annotation.type_b,
.sec_medical_time_reserv .medical_time .annotation.type_c {
  font-size: 1.6rem;
  color: #D36100;
}

.sec_medical_time_reserv .medical_time .annotation.type_b li:last-child {
  padding-left: 1em;
}

.sec_medical_time_reserv .medical_time .annotation.type_b li:last-child:before {
  content: none;
}


.sec_medical_time_reserv .response_devise .txt span {
  display: block;
}

.sec_medical_time_reserv .response_devise .txt .type_b {
  font-size: 1.2rem;
}

@media screen and (max-width: 960px) {
  .sec_medical_time_reserv .medical_time .tbl_green {
    font-size: 1rem;
  }

  .sec_medical_time_reserv .medical_time .annotation {
    flex-direction: column;
  }

  .sec_medical_time_reserv .medical_time .annotation.type_b li:last-child {
    padding-left: 0;
  }

  .sec_medical_time_reserv .medical_time .annotation.type_b li:last-child:before {
    content: '※';
  }

  .sec_medical_time_reserv .response_devise .txt .type_b {
    font-size: 1rem;
  }
}

@media screen and (max-width: 600px) {
  .sec_medical_time_reserv {
    margin-bottom: 20px;
    padding-right: 4%;
    padding-left: 4%;
  }

  .sec_medical_time_reserv .medical_time {
    padding-bottom: 1em;
  }

  .sec_medical_time_reserv .medical_time .tbl_green {
    order: 1;
  }

  .sec_medical_time_reserv .medical_time .annotation.type_a {
    order: 3;
  }

  .sec_medical_time_reserv .medical_time .annotation.type_b,
  .sec_medical_time_reserv .medical_time .annotation.type_c {
    order: 2;
    font-size: 1.2rem;
  }

  .sec_medical_time_reserv .response_devise .txt .type_b {
    font-size: 2.8vw;
  }
}

/* Section Access
--------------------------------------------------------------------*/
.sec_access {
  border-radius: 10px;
  background: white;
  padding: 25px;
}

.sec_access .map {
  padding: 30px;
  border: 1px solid #46392E;
}

@media screen and (max-width: 600px) {
  .sec_access {
    padding-right: 4%;
    padding-left: 4%;
  }

  .sec_access .map {
    padding: 1em;
  }
}

.layout_access {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  justify-content: space-between;
  flex-direction: row-reverse;
  padding-bottom: 25px;
}

.layout_access .img {
  max-width: 285px;
  width: 100%;
}

.layout_access .description {
  max-width: 430px;
  width: 100%;
}

.layout_access .img {
  margin-left: 2%;
}

.layout_access .txt_orange {
  color: #D36100;
}

.layout_access .address {
  display: -webkit-flex;
  display: -ms-flex;
  display: flex;
  flex-direction: column;
  padding-bottom: 1em;
}

.layout_access .txt_01 {
  font-size: 2rem;
}

.layout_access .txt_02 {
  margin-left: auto;
  font-size: 1.2rem;
  text-align: right;
}

.layout_access .txt_02 a:before {
  content: '>';
}

@media screen and (max-width: 960px) {
  .layout_access {
    flex-direction: column;
    flex-direction: column;
  }

  .layout_access .img {
    max-width: none;
    margin: 0;
    padding-bottom: 25px;
  }

  .layout_access .img img {
    width: 100%;
    height: 27vw;
    object-fit: cover;
    font-family: 'object-fit: cover;';
  }

  .layout_access .description {
    max-width: none;
  }

  .layout_access .img {
    margin-left: 0;
  }

  .layout_access .txt_01 {
    font-size: 2.4vw;
  }
}

@media screen and (max-width: 600px) {
  .layout_access {
    padding-bottom: 1em;
  }

  .layout_access .img img {
    height: 30vw;
  }

  .layout_access .address {
    padding-bottom: 0;
  }

  .layout_access .txt_01 {
    font-size: 1.4rem;
  }
}

/* ===================================================================
Layout 404
=================================================================== */
.sec_404 {
  border-radius: 10px;
  background: white;
  padding: 25px;
}

@media screen and (max-width: 600px) {
  .sec_404 {
    padding-right: 4%;
    padding-left: 4%;
  }
}

/* ===================================================================
Layout Archive/Category
=================================================================== */
.lst_archive_category li {
  margin-bottom: 40px;
  padding-bottom: 40px;
  border-bottom: 1px dashed #E0DEDC;
}

@media screen and (max-width: 600px) {
  .lst_archive_category li {
    margin-bottom: 20px;
    padding-bottom: 20px;
  }
}

.lst_archive_category h2 a {
  color: #72B639;
  text-decoration: none;
}

.lst_archive_category h2 a:hover {
  text-decoration: underline;
}

/* ===================================================================
Layout Single
=================================================================== */
.single .summary {
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px dashed #E0DEDC;
}

.article_content {
  margin-bottom: 40px;
  padding-bottom: 40px;
  border-bottom: 1px dashed #E0DEDC;
}

@media screen and (max-width: 600px) {
  .article_content {
    margin-bottom: 20px;
    padding-bottom: 20px;
  }
}

.article_content img {
  margin-bottom: 1em;
}

.article_content ul {
  padding-left: 1.8em;
}

.article_content ul li {
  position: relative;
}

.article_content ul li:not(:last-child) {
  padding-bottom: 1em;
}

.article_content ul li:before {
  content: '\f058';
  padding-right: .4em;
  font-family: FontAwesome;
  position: absolute;
  top: -2px;
  bottom: 0;
  left: -1.4em;
  margin: auto 0;
  font-size: 1.4rem;
}

.article_content ul:not(:last-child) {
  padding-bottom: 1em;
}

.article_content ol {
  padding-left: 2em;
  list-style: decimal;
}

.article_content ol:not(:last-child) {
  padding-bottom: 1em;
}

.article_content table:not(:last-child) {
  margin-bottom: 1em;
}

/* ===================================================================
Layout Sidebar List
=================================================================== */
.sidebar section:not(:last-child) {
  margin-bottom: 25px;
  padding-bottom: 25px;
  border-bottom: 1px dashed #E0DEDC;
}

.side_lst_news li:not(:last-child) {
  margin-bottom: 1em;
  padding-bottom: 1em;
  border-bottom: 1px solid #E0DEDC;
}