@charset "UTF-8";
/* breakpoint ------------------------------*/
/* abouthead ---------------------------------*/
.abouthead {
  width: 100%;
  height: calc(150px + 30vw);
  max-height: 640px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border-radius: 50px;
  background-image: url(../images/about/img_head.jpg);
  background-position: center;
  background-size: cover;
  overflow: hidden;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

@media screen and (max-width: 1200px) {
  .abouthead {
    border-radius: 25px;
  }
}

@media screen and (max-width: 768px) {
  .abouthead {
    border-radius: 15px;
  }
}

.abouthead__wrap {
  max-width: 50%;
  -ms-flex-preferred-size: 50%;
      flex-basis: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

@media screen and (max-width: 1200px) {
  .abouthead__wrap {
    max-width: 100%;
    -ms-flex-preferred-size: 100%;
        flex-basis: 100%;
    border-radius: 25px;
  }
}

.abouthead__title {
  margin-bottom: 40px;
  font-size: 3.2rem;
  line-height: 1.4;
  color: black;
}

@media screen and (max-width: 992px) {
  .abouthead__title {
    margin-bottom: 20px;
    font-size: 2.8rem;
  }
}

@media screen and (max-width: 576px) {
  .abouthead__title {
    font-size: 2.4rem;
    margin-bottom: 10px;
  }
}

.abouthead__en {
  font-size: 1.2rem;
  line-height: 1.6;
}

/* greeting ----------------------------------*/
.greeting__catch {
  margin-bottom: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-size: 2.4rem;
  line-height: 1.6;
  color: black;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

@media screen and (max-width: 992px) {
  .greeting__catch {
    margin-bottom: 40px;
    font-size: 2rem;
  }
}

@media screen and (max-width: 576px) {
  .greeting__catch {
    margin-bottom: 20px;
    font-size: 1.8rem;
  }
}

.greeting__catch:before, .greeting__catch:after {
  content: "";
  max-width: 13px;
  -ms-flex-preferred-size: 13px;
      flex-basis: 13px;
  height: 50px;
  display: block;
  background-image: url(../images/about/img_catch.png);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100% auto;
}

.greeting__catch:before {
  margin-right: 20px;
}

.greeting__catch:after {
  margin-left: 20px;
}

.greeting__wrap {
  max-width: 800px;
  margin: 0 auto;
}

.greeting__wrap p {
  font-size: 1.4rem;
  line-height: 2;
}

/* doctor ------------------------------------*/
.doctor {
  padding: 100px 6vw;
  background-color: white;
  border-radius: 50px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

@media screen and (max-width: 1200px) {
  .doctor {
    padding: 80px 6vw;
    border-radius: 25px;
  }
}

@media screen and (max-width: 768px) {
  .doctor {
    padding: 40px 6vw;
    border-radius: 15px;
  }
}

.doctor__wrap {
  max-width: 900px;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.doctor__wrap-rev {
	flex-direction: row-reverse;
    margin-top: 50px;
}



@media screen and (max-width: 992px) {
  .doctor__wrap {
    display: block;
  }
}

.doctor-main {
  max-width: 45%;
  -ms-flex-preferred-size: 45%;
      flex-basis: 45%;
}

@media screen and (max-width: 992px) {
  .doctor-main {
    max-width: 500px;
    margin: 0 auto;
    margin-top: 60px;
  }
  .doctor-main:first-child {
    margin-top: 0;
  }
}

.doctor-main__image {
  margin-bottom: 20px;
  border-radius: 10px;
  overflow: hidden;
}

.doctor-main__occ {
  font-size: 1.2rem;
  line-height: 1.6;
}

.doctor-main__name {
  margin: 5px 0;
  font-size: 2.8rem;
  line-height: 1.4;
  color: black;
}

@media screen and (max-width: 992px) {
  .doctor-main__name {
    font-size: 2.4rem;
  }
}

@media screen and (max-width: 768px) {
  .doctor-main__name {
    font-size: 2rem;
  }
}

.doctor-main__en {
  font-size: 1.2rem;
  line-height: 1.6;
}

.doctor-main-list {
  margin-top: 40px;
}

.doctor-main-list__title {
  margin-bottom: 20px;
  display: table;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  font-size: 1.2rem;
  line-height: 1.6;
}
.doctor-main-list__text {
    line-height: 2;
    padding: 20px;
    background: #f1f1f1;
    border-radius: 5px;
}
.doctor-main-list__table {
  width: 100%;
  font-size: 1.3rem;
  line-height: 2.2;/* 1.8 */
}

.doctor-main-list__table th {
  width: 25%;
  padding-right: 10px;
  vertical-align: top;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.doctor-main-list__table th span {
  display: inline-block;
}

.doctor-main-list__table td {
  width: 75%;
}

.doctor-main-list__pos {
  font-size: 1.3rem;
  line-height: 1.8;
}

.doctor-main-list__hobby {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.doctor-main-list__hobby li {
  font-size: 1.3rem;
  line-height: 1.8;
}

.doctor-main-list__hobby li:after {
  content: "、";
}

.doctor-main-list__hobby li:last-child:after {
  display: none;
}

.doctor-sub {
  max-width: 52%;
  -ms-flex-preferred-size: 52%;
      flex-basis: 52%;
}

@media screen and (max-width: 768px) {
  .doctor-sub {
    max-width: none;
  }
}

.doctor-sub__title {
  font-size: 1.8rem;
  line-height: 1.6;
  text-align: center;
  color: black;
}

.doctor-sub-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.doctor-sub-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.doctor-sub-list__item {
  max-width: calc((100% - 40px) / 2);
  -ms-flex-preferred-size: calc((100% - 40px) / 2);
      flex-basis: calc((100% - 40px) / 2);
  margin-top: 40px;
}

@media screen and (max-width: 768px) {
  .doctor-sub-list__item {
    max-width: calc((100% - 20px) / 2);
    -ms-flex-preferred-size: calc((100% - 20px) / 2);
        flex-basis: calc((100% - 20px) / 2);
  }
}

.doctor-sub-list__image {
  margin-bottom: 20px;
  border-radius: 10px;
  overflow: hidden;
}

.doctor-sub-list__occ {
  font-size: 1.2rem;
  line-height: 1.6;
}

.doctor-sub-list__name {
  margin: 5px 0;
  font-size: 2rem;
  line-height: 1.6;
  color: black;
}

@media screen and (max-width: 768px) {
  .doctor-sub-list__name {
    font-size: 1.8rem;
  }
}

.doctor-sub-list__en {
  font-size: 1.2rem;
  line-height: 1.6;
}

.doctor-sub-list-pos {
  margin-top: 20px;
  font-size: 1.3rem;
  line-height: 1.8;
}

/* facility ----------------------------------*/
.facility {
  margin-bottom: 0;
}

.facility-list {
  position: relative;
}

.facility-list:before {
  content: "";
  width: calc(50% + 50px);
  height: 100%;
  display: block;
  background-color: white;
  position: absolute;
  left: 50%;
  top: 0;
  z-index: 0;
}

@media screen and (max-width: 768px) {
  .facility-list:before {
    width: calc(50% + 20px);
  }
}

.facility-list__item {
  max-width: 1200px;
  margin: 0 auto;
  padding: 80px 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
}

@media screen and (max-width: 992px) {
  .facility-list__item {
    padding: 60px 0;
    padding-left: 6vw;
    display: block;
  }
}

.facility-list__item:last-child {
  margin-bottom: 0;
}

.facility-list__item.beige {
  padding-left: 0;
  padding-right: 6vw;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}

.facility-list__item.white:before, .facility-list__item.beige:before {
  content: "";
  width: 80%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  z-index: 0;
}

@media screen and (max-width: 992px) {
  .facility-list__item.white:before, .facility-list__item.beige:before {
    width: 100%;
  }
}

.facility-list__item.white:before {
  border-radius: 50px 0 0 50px;
  background-color: white;
  right: 0;
}

@media screen and (max-width: 992px) {
  .facility-list__item.white:before {
    border-radius: 25px 0 0 25px;
  }
}

@media screen and (max-width: 576px) {
  .facility-list__item.white:before {
    border-radius: 15px 0 0 15px;
  }
}

.facility-list__item.beige:before {
  border-radius: 0 50px 50px 0;
  background-color: #edece5;
  left: 0;
}

@media screen and (max-width: 992px) {
  .facility-list__item.beige:before {
    border-radius: 0 25px 25px 0;
  }
}

@media screen and (max-width: 576px) {
  .facility-list__item.beige:before {
    border-radius: 0 15px 15px 0;
  }
}

.facility-list__image, .facility-list__wrap {
  position: relative;
  z-index: 1;
}

.facility-list__image {
  max-width: calc(50% + 50px);
  -ms-flex-preferred-size: calc(50% + 50px);
      flex-basis: calc(50% + 50px);
  border-radius: 10px;
  overflow: hidden;
}

@media screen and (max-width: 992px) {
  .facility-list__image {
    max-width: none;
    margin-bottom: 30px;
  }
}

.facility-list__wrap {
  max-width: calc(50% - 50px);
  -ms-flex-preferred-size: calc(50% - 50px);
      flex-basis: calc(50% - 50px);
  padding: 0 50px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

@media screen and (max-width: 992px) {
  .facility-list__wrap {
    max-width: none;
    padding: 0;
  }
}

.facility-list__title {
  font-size: 2.4rem;
  line-height: 1.6;
  width: 100%;
  max-width: 400px;
  margin-bottom: 40px;
  color: black;
}

@media screen and (max-width: 768px) {
  .facility-list__title {
    font-size: 2rem;
  }
}

@media screen and (max-width: 992px) {
  .facility-list__title {
    margin-bottom: 20px;
  }
}

.facility-list__text {
  width: 100%;
  max-width: 400px;
  margin: 0 auto;
  font-size: 1.4rem;
  line-height: 2;
}

.facility-list-ui {
  width: 100%;
  max-width: 400px;
  margin: 0 auto;
  margin-top: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 992px) {
  .facility-list-ui {
    margin-top: 40px;
  }
}

.facility-list-ui li {
  max-width: 60px;
  -ms-flex-preferred-size: 60px;
      flex-basis: 60px;
  height: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background-color: rgba(0, 0, 0, 0.05);
  border-radius: 50%;
  position: relative;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  cursor: pointer;
  -webkit-transition: all 250ms ease;
  transition: all 250ms ease;
}

@media screen and (max-width: 768px) {
  .facility-list-ui li {
    max-width: 50px;
    -ms-flex-preferred-size: 50px;
        flex-basis: 50px;
    height: 50px;
  }
}

.facility-list-ui li:before {
  content: "";
  width: 18px;
  height: 4px;
  display: block;
  background-image: url(../images/common/icon_arrow_r.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: 100% auto;
}

.facility-list-ui li.ui-prev {
  margin-right: 20px;
}

.facility-list-ui li.ui-prev:before {
  -webkit-transform: scale(-1, 1);
          transform: scale(-1, 1);
}

.facility-list-ui li:hover {
  background-color: rgba(0, 0, 0, 0.2);
}

/* logo --------------------------------------*/
.logo {
  width: calc(100% + 100px);
  margin: 0;
  padding: 100px 50px;
  background-color: white;
  overflow: hidden;
  position: relative;
  left: -50px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

@media screen and (max-width: 768px) {
  .logo {
    width: calc(100% + 40px);
    padding: 80px 20px;
    left: -20px;
  }
}

.logo__image {
  max-width: 240px;
  margin: 60px auto;
}

@media screen and (max-width: 768px) {
  .logo__image {
    max-width: 180px;
    margin: 40px auto;
  }
}

.designer {
  max-width: 700px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 0 auto;
  margin-top: 60px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.designer__image {
  max-width: 120px;
  -ms-flex-preferred-size: 120px;
      flex-basis: 120px;
  margin-right: 60px;
}

@media screen and (max-width: 576px) {
  .designer__image {
    max-width: 100px;
    -ms-flex-preferred-size: 100px;
        flex-basis: 100px;
    margin-right: 30px;
  }
}

@media screen and (max-width: 576px) {
  .designer__wrap {
    max-width: calc(100% - 130px);
    -ms-flex-preferred-size: calc(100% - 130px);
        flex-basis: calc(100% - 130px);
  }
}

.designer__name {
  font-size: 1.8rem;
  line-height: 2.5;
  line-height: 1.6;
  color: black;
}

@media screen and (max-width: 768px) {
  .designer__name {
    font-size: 1.6rem;
    line-height: 2;
  }
}

.designer__en {
  font-size: 1.2rem;
  line-height: 2.5;
  line-height: 1.6;
}

@media screen and (max-width: 768px) {
  .designer__en {
    font-size: 1.1rem;
    line-height: 2;
  }
}

.designer__text {
  margin-top: 20px;
  font-size: 1.3rem;
  line-height: 1.6;
}

@media screen and (max-width: 576px) {
  .designer__text {
    margin-top: 10px;
  }
}

.designer__text span {
  display: inline-block;
}

/* access ------------------------------------*/
.access-map {
  margin-bottom: 60px;
  overflow: hidden;
  border-radius: 20px;
}

@media screen and (max-width: 576px) {
  .access-map {
    margin-bottom: 40px;
    border-radius: 10px;
  }
}

@media screen and (max-width: 768px) {
  .access-map iframe {
    height: 300px;
  }
}

.access-info {
  max-width: 900px;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

@media screen and (max-width: 576px) {
  .access-info {
    display: block;
  }
}

.access-info dl {
  max-width: calc((100% - 160px) / 3);
  -ms-flex-preferred-size: calc((100% - 160px) / 3);
      flex-basis: calc((100% - 160px) / 3);
}

@media screen and (max-width: 768px) {
  .access-info dl {
    max-width: calc((100% - 80px) / 3);
    -ms-flex-preferred-size: calc((100% - 80px) / 3);
        flex-basis: calc((100% - 80px) / 3);
  }
}

@media screen and (max-width: 576px) {
  .access-info dl {
    max-width: none;
    margin-bottom: 20px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
  .access-info dl:last-child {
    margin-bottom: 0;
  }
}

.access-info dl dt {
  margin-bottom: 20px;
  display: inline-block;
  border-bottom: 1px dotted black;
  font-size: 1.2rem;
  line-height: 1.8;
}

.access-info dl dd {
  font-size: 1.4rem;
  line-height: 1.8;
}

@media screen and (max-width: 576px) {
  .access-info dl dd {
    max-width: calc(100% - 80px);
    -ms-flex-preferred-size: calc(100% - 80px);
        flex-basis: calc(100% - 80px);
  }
}

.access-info dl dd span {
  margin-top: 20px;
  display: block;
  font-weight: bold;
  color: black;
}

.access-info dl dd span:first-child {
  margin-top: 0;
}


/* ---------------------------- */
.doctor-main-msg01 {
    font-size: 2.4rem;
    line-height: 1.6;
    margin: 30px 0;
}
.doctor-main-msg02 {
    font-size: 1.4rem;
    line-height: 2;
}

.doctor__profile {
	display: block;
    margin-top: 100px;
}

