.flex {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
}
.ob {
    position: relative;
}
.ob img {
    width: 100% !important;
    height: 100%;
    object-fit: cover;
}
.ttl-shared {
    font-weight: 400;
}
.ttl-shared span {
    font-size: 100px;
    display: inline-block;
    border-bottom: 1px solid #fff;
    padding-bottom: 21px;
    margin-bottom: 20px;
}
.ttl-shared small {
    font-size: 21px;
    letter-spacing: 2px;
}
body.home {
    font-weight: 500;
    font-size: 16px;
}
#wrapper{
	padding-top: 0;
}
#header{
	background: none;
}
#mainimage {
    position: relative;
}
#mainimage .main-catch {
    font-weight: 400;
    font-size: 34px;
    position: absolute;
    z-index: 5;
    line-height: 182%;
    left: 6.5%;
    bottom: 48%;
    transform: translateY(50%);
    letter-spacing: 4px;
}
#mainimage .main-catch small {
    font-size: 18px;
    letter-spacing: 2px;
}
#mainimage .img{
	
}
@media only screen and (max-width: 767px) {
    .ttl-shared {
        text-align: center;
    }
    .ttl-shared span {
        font-size: 72px;
        margin: 0 auto;
        text-align: center;
    }
    .ttl-shared small {
        font-size: 18px;
    }
}

/* -------------------------------------
table.timetable
------------------------------------- */
table.timetable {
  width: 100%;
  table-layout: fixed;
  border-collapse: collapse;
  margin-bottom: 7px !important;
}
.timetable th, .timetable td {
  text-align: center;
  vertical-align: middle;
  line-height: 1;
  padding: 7px 0 15px;
  font-size: 15px;
  color: #22201E;
}
.timetable thead th {
  font-weight: normal;
  padding: 11px 0 7px;
  width: 11%;
  color: #6D6660;
  background: #FFEBCB;
}
.timetable.green thead th{
  background: #F0FECF;
}
.timetable thead th:first-child {
  width: 30%;
  text-align: left;
  border-radius: 0px 0 0 0;
  letter-spacing: 0.15em;
  padding-left: 10px;
  color: #6D6660;
}
.timetable thead th:last-child {
  white-space: nowrap;
}
.timetable tbody th {
  word-break: keep-all;
  white-space: nowrap;
  text-align: left;
}
.timetable tbody tr:first-child th, .timetable tbody tr:first-child td {
  padding: 10px 0 10px 0;
}
.table_style {
  font-size: 15px;
  line-height: 1.74;
  letter-spacing: 0.09em;
  color: #696969;
}
table.timetable.child {
  background: #EDFCEA;
  border-bottom: 0;
}
.timetable.child thead th:first-child {
  background: #3AB34B;
  color: #fff;
  font-size: 18px;
}
.timetable.child thead th:first-child {
  padding-left: 10px;
}
.timetable.child tbody tr:first-child th, .timetable.child tbody tr th {
  padding-left: 10px !important;
}
.timetable.child thead th {
  background: #3AB34B;
  color: #fff;
  width: 20%;
}
.timetable.child thead th:last-child {
  border-radius: 0;
}
@media screen and (max-width: 1000px) and (min-width: 768px) {
  .timetable thead th:first-child {
    padding-left: 5px;
    width: 28%;
  }
  .timetable tbody th {}
  .timetable thead th {
    padding: 12px 0 11px;
  }
  .timetable tbody tr:first-child th, .timetable tbody tr:first-child td {
    padding: 17px 0 9px;
  }
  .timetable th, .timetable td {
    font-size: 13px !important;
    letter-spacing: 0 !important;
    padding: 8px 0 17px;
  }
  .table_style {
    font-size: 13px;
    letter-spacing: 0;
  }
}
@media screen and (max-width: 767px) {
  .timetable thead th:first-child {
    width: 31%;
  }
  .timetable tbody th {
    letter-spacing: 0.05em;
  }
  .timetable thead th:first-child {
    padding-left: 10px;
    font-size: 14px;
  }
  .timetable thead th{
    width: 7%;
  }
  .timetable thead th:last-child{
    width: 11%;
  }
  .timetable tbody th {
    padding-left: 0px !important;
    font-size: 14px;
  }
  .timetable th, .timetable td {
    font-size: 14px;
  }
  .under_title_h2 h2:before {
    left: 20px;
  }
  .under_title_h2 h2 {
    padding: 19px 0 21px 63px !important;
    line-height: 30px !important;
  }
  .timetable.child thead th {
    width: 6%;
  }
  .btn_style1 a{
    width: 260px;
    font-size: 13px;
  }
}
@media screen and (max-width: 480px) {
  .timetable th, .timetable td {
    font-size: 15px;
    letter-spacing: 0;
  }
  .timetable thead th:first-child {
    width: 32%;
    font-size: 14px;
    letter-spacing: 0.01em;
  }
  .timetable tbody th {
    padding-left: 0px !important;
    letter-spacing: 0;
  }
}


#news {
    background: #000;
    color: #fff;
    padding: 130px 0 16px;
}
#news .news-col .ttl-shared {
    text-align: right;
    margin-right: 100px;
    margin-left: 42px;
    width: 218px;
}
#news .news-col .ttl-shared span {
    width: 218px;
    text-align: left;
    letter-spacing: 8px;
    margin-bottom: 32px;
}
#news .post-box dl {
    display: flex;
    font-weight: 500;
    align-items: center;
    border-bottom: 1px solid #fff;
    padding: 8px 0 12px;
}
.post-box dl dt .new-label{
	display: none;
}
#news .post-box dl dt {
    margin-bottom: -4px;
    font-size: 14px;
    color: #fff;
    width: 120px;
    letter-spacing: 1px;
    margin-bottom: -5px;
}
#news .post-box dl dd {
    font-size: 16px;
}
#news .post-box dl dd a {
    color: #fff;
    font-size: 16px;
}
#news .post-box dl:first-child {
    border-top: 1px solid #fff;
}
.post-box__header a {
    background: none;
    color: #fff;
    font-size: 16px;
    font-weight: 500;
    font-family: "Zen Old Mincho", serif;
    background: url(../img/top/icon_arrow.svg) no-repeat center bottom;
    margin-right: -10px;
    margin-top: 10px;
}
.post-box__content{
	min-height: 170px;
}
@media only screen and (min-width: 768px) and (max-width: 1200px) {
	.post-box{
		padding-right: 30px;
	}
}
@media only screen and (min-width: 768px) and (max-width: 1100px) {
    #mainimage .main-catch {
        font-size: 28px;
    }
    #mainimage .main-catch small {
        font-size: 16px;
        display: block;
        line-height: 33px;
        margin-top: 20px;
    }
    #mainimage .main-catch small br.sp {
        display: block;
    }
    #news {
        padding-right: 30px;
    }
    #news .post-box {
        padding-left: 80px;
    }
}
@media only screen and (min-width: 768px) and (max-width: 1060px) {
	#news .post-box {
    padding-left: 54px;
	}
}


@media only screen and (max-width: 767px) {
    #mainimage .main-catch {
        font-size: 21px;
        line-height: 182%;
        left: 5%;
        top: -19vw;
        letter-spacing: 3px;
    }
    #mainimage .main-catch small {
        font-size: 11px;
        display: inline-block;
        line-height: 21px;
        margin-top: 17px;
        letter-spacing: 2px;
    }
    #mainimage .img {
        height: 85vw;
    }
    #news {
        padding: 38px 0 9px;
    }
    #news .news-col .ttl-shared {
        margin: 0 auto -1px;
        text-align: center;
    }
    #news .news-col .ttl-shared span {
        text-align: center;
        width: 170px;
        letter-spacing: 8px;
        margin-bottom: 14px;
    }
    #news .post-box {
        width: 90%;
		margin-top: 30px;
    }
    #news .post-box dl {
        flex-direction: column;
        align-items: flex-start;
        padding: 9px 0 14px;
    }
    .post-box__header {
        margin-top: 27px;
        margin-right: -30px;
    }
    .post-box__header a {
        margin-left: auto;
        padding: 4px 12px 10px 0px;
        letter-spacing: 2px;
        background-size: 120px;
    }
	.post-box__content{
		min-height: auto;
	}	
}



#clinic {
    padding: 157px 0 120px;
}
#clinic .ttl-shared {
    width: 170px;
    text-align: right;
    position: absolute;
    right: 33px;
    top: -50px;
}
#clinic .ttl-shared span {
    border-color: #000;
    width: 220px;
    margin-left: -40px;
    text-align: left;
    letter-spacing: 9px;
    margin-bottom: 31px;
}
#clinic .ttl-shared small {
    letter-spacing: 3px;
}
#clinic .row {
    width: 100%;
    justify-content: space-between;
}
#clinic .row .col {
    width: 46.7%;
}
#clinic .row .col .row2 h3 {
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 22px;
    letter-spacing: 4px;
}
#clinic .row .col .row2 .timetable {
    margin-bottom: 3px !important;
}
#clinic .row .col .row2 .timetable thead th:first-child {
    width: 22%;
    border-left-width: 1px;
    letter-spacing: 0;
}
#clinic .row .col .parking {
    text-align: right;
    margin-top: 52px;
}
#clinic .row .col .parking span {
    background: #000;
    color: #fff;
    padding: 5px 7px 5px 10px;
    font-size: 14px;
    font-weight: 500;
}
.timetable thead th {
    font-size: 14px;
    font-weight: 500;
    border: 2px solid #CCCCCC;
}
.timetable tbody th, .timetable tbody td {
    font-weight: 500;
    border: 2px solid #CCCCCC;
    text-align: center;
    line-height: 21px;
    letter-spacing: 0px;
}
.timetable tbody tr:last-child td, .timetable tbody tr:last-child th {
    padding-bottom: 10px;
    border-bottom-width: 1px;
}
#clinic .row .col .row2 .timetable thead th {
    background: #EAEAEA;
    color: #000;
    text-align: center;
    padding: 11px 0 9px;
    border-top-width: 1px;
}
#clinic .row .col .row2 .timetable thead th:last-of-type {
    border-right-width: 1px;
}
.timetable tbody tr th {
    border-left-width: 1px;
	    background: #fff;
}
#clinic .row .col .row2 .timetable tbody td:last-of-type {
    border-right-width: 1px;
    border-bottom-width: 1px;
}
#clinic .row .col .row2 .note {
    line-height: 160%;
    margin-bottom: 61px;
    font-size: 14px;
    letter-spacing: 0;
}
#clinic .row .col .row2 .address {
    line-height: 140%;
    padding-left: 34px;
    position: relative;
    margin-bottom: 13px;
    letter-spacing: 0px;
}
#clinic .row .col .row2 .address::before {
    content: "";
    background: url(../img/top/icon_map.svg) no-repeat;
    width: 20px;
    height: 20px;
    position: absolute;
    top: 10px;
    left: 1px;
}
#clinic .row .col .row2 .tel {
    font-weight: 500;
    font-size: 16px;
    display: flex;
    align-items: center;
    padding-left: 34px;
    position: relative;
    letter-spacing: 0;
}
#clinic .row .col .row2 .tel::before {
    content: "";
    background: url(../img/top/icon_tel.svg) no-repeat;
    width: 16px;
    height: 18px;
    position: absolute;
    top: 8px;
    left: 4px;
}
#clinic .row .map {
    width: 50%;
    position: relative;
    margin-top: 165px;
    padding-top: 130px;
}
#clinic .row .map iframe {
    height: 300px;
    width: 100%;
}
@media only screen and (min-width: 768px) and (max-width: 1100px) {
    #clinic .row .col {
        width: 48%;
    }
    .timetable thead th {
        width: 7%;
    }
    #clinic .row .col .row2 .timetable thead th:last-of-type {
        width: 9%;
    }
    #clinic .row .col .row2 .address {
        font-size: 15px;
    }
}
@media only screen and (max-width: 767px) {
    #clinic {
        padding: 52px 0 0;
    }
    #clinic .ttl-shared {
        position: static;
        margin-left: auto;
        width: 240px;
        margin-right: 10px;
        margin-bottom: 40px;
    }
    #clinic .ttl-shared span {
        text-align: right;
        letter-spacing: 6px;
        margin-left: -8px;
        width: 100%;
        padding-bottom: 13px;
        margin-bottom: 18px;
    }
    #clinic .row {
        flex-direction: column;
        padding: 0 10px;
    }
    #clinic .row .col {
        width: 100%;
        margin-bottom: 27px;
    }
    #clinic .row .col .row2 h3 {
        margin-bottom: 11px;
    }
    #clinic .row .col .parking {
        text-align: left;
        margin-top: 26px;
    }
    #clinic .row .col .parking span {
        letter-spacing: 0px;
    }
    .timetable tbody th, .timetable tbody td {
        font-size: 12px;
        line-height: 18px;
    }
    .timetable tbody tr:last-child th {
        padding-bottom: 0px;
        padding-top: 13px;
    }
    #clinic .row .col .row2 .timetable thead th {
        font-size: 12px !important;
        padding-bottom: 11px;
        padding: 13px 0 13px;
    }
    .timetable tbody tr th {
        font-size: 12px !important;
    }
    #clinic .row .col .row2 .note {
        margin-top: 10px;
        margin-bottom: 37px;
    }
    #clinic .row .col .row2 .address {
        padding-left: 27px;
        margin-top: 20px;
    }
    #clinic .row .col .row2 .address::before {
        top: 13px;
        left: -2px;
    }
    #clinic .row .col .row2 .tel {
        padding-left: 27px;
    }
    #clinic .row .col .row2 .tel::before {
        left: -1px;
    }
    #clinic .row .map {
        width: auto;
        margin-top: 20px;
        margin: 0 -20px;
        padding-top: 240px;
    }
}



#equipment {
    background: url(../img/top/equipment_bg.jpg) no-repeat;
    background-size: cover;
    padding: 105px 0 75px;
}
#equipment .row {
    justify-content: space-between;
}
#equipment .row .ttl-shared {
    margin-bottom: 108px;
    display: flex;
    letter-spacing: 8px;
}
#equipment .row .ttl-shared span {
    border: none;
}
#equipment .row .ttl-shared small {
    margin-left: 53px;
    margin-top: 9px;
    letter-spacing: 3px;
}
#equipment .row .ttl {
    font-size: 26px;
    line-height: 160%;
    color: #fff;
    text-align: right;
    margin-top: -33px;
    letter-spacing: 4px;
	font-weight: 400;
}
#equipment .js .slick-list {
    overflow: visible;
}
#equipment .js .box .img {
    margin-bottom: 0;
}
#equipment .js .box .inner {
    background: #FFFFFF;
    padding: 30px 52px 97px;
    border-bottom: 10px solid #D9D9D9;
    box-sizing: content-box;
}
#equipment .js .box .inner h3 {
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 31px;
    letter-spacing: 4px;
}
#equipment .js .box .inner .txt {
    font-weight: 500;
}
#equipment .js .box .inner .txt li {
    margin-bottom: 20px;
    line-height: 140%;
}
#equipment .js .equipment-slide {
    position: relative;
    z-index: 2;
}
#equipment .js .equipment-slide .box {
    padding-bottom: 13px;
    padding-bottom: 16px;
    transition: all .3s;
    transform: scale(1);
    margin: 0 50px 50px;
    width: 580px;
}
#equipment .js .equipment-slide .img img {
    position: relative;
    z-index: 2;
}
#equipment .js .equipment-slide .slick-arrow {
    position: absolute;
    top: 300px;
    width: 80px;
    height: 80px;
    cursor: pointer;
    font-size: 0;
    color: transparent;
    z-index: 5;
}
#equipment .js .equipment-slide .slick-arrow:hover {
    opacity: 0.8;
}
#equipment .js .equipment-slide .slick-arrow.slick-prev {
    background: url("../img/top/icon_prev.svg") no-repeat center/100% auto;
    left: auto;
    right: calc(50% + 522px);
}
#equipment .js .equipment-slide .slick-arrow.slick-next {
    background: url("../img/top/icon_next.svg") no-repeat center/100% auto;
    right: auto;
    left: calc(50% + 501px);
}
@media only screen and (min-width: 768px) and (max-width: 1400px) {
    #equipment .js .equipment-slide .slick-arrow.slick-prev {
        right: auto;
        left: 30px;
    }
    #equipment .js .equipment-slide .slick-arrow.slick-next {
        left: auto;
        right: 30px;
    }
}
@media only screen and (min-width: 768px) and (max-width: 1100px) {
    #equipment .row {
        flex-wrap: wrap;
    }
    #equipment .row .ttl-shared {
        margin-bottom: 40px;
    }
    #equipment .row .ttl {
        font-size: 22px;
        margin-left: auto;
        margin-bottom: 80px;
    }
    #equipment .js .equipment-slide .slick-arrow.slick-prev {
        right: auto;
    }
    #equipment .js .equipment-slide .slick-arrow.slick-next {
        left: auto;
        right: 0px;
    }
}
@media only screen and (max-width: 767px) {
    #equipment {
        padding: 40px 0 20px;
    }
    #equipment .row {
        flex-direction: column;
        margin-bottom: 70px;
    }
    #equipment .row .ttl-shared {
        flex-direction: column;
        margin-bottom: 18px;
        margin-left: 17px;
    }
    #equipment .row .ttl-shared span {
        margin-left: 0;
        letter-spacing: 6px;
        margin-bottom: -45px;
    }
    #equipment .row .ttl-shared small {
        text-align: right;
        margin-right: 8px;
    }
    #equipment .row .ttl {
        font-size: 21px;
        margin-top: 0;
        letter-spacing: 1.5px;
        margin-right: 10px;
    }

    #equipment .js .box .img {
        margin-bottom: -1px;
    }
    #equipment .js .box .inner {
        padding: 30px 30px 20px;
    }
    #equipment .js .box .inner h3 {
        font-size: 21px;
        margin-bottom: 30px;
    }
    #equipment .js .equipment-slide .box {
        width: calc(100vw - 20px);
        margin-bottom: 20px;
    }

    #equipment .js .equipment-slide .slick-arrow {
        top: 94%;
        width: 40px;
        height: 40px;
    }
}
@media only screen and (max-width: 767px) {
    #equipment .js .equipment-slide .slick-arrow.slick-prev {
        left: 0%;
    }
}
@media only screen and (max-width: 767px) {
    #equipment .js .equipment-slide .slick-arrow.slick-next {
        left: 87%;
    }
}

#equipment .js .equipment-slide .slick-dots {
    display: flex;
    justify-content: center;
    font-size: 0;
    color: transparent;
    gap: 0 14px;
    margin: 45px 0 0;
}
#equipment .js .equipment-slide .slick-dots li {
    border-radius: 50%;
    width: 10px;
    height: 10px;
    background: #CCCCCC;
    cursor: pointer;
}
#equipment .js .equipment-slide .slick-dots li button {
    display: none;
}
#equipment .js .equipment-slide .slick-dots li.slick-active {
    background: #000;
}
#equipment .js .equipment-slide .slick-dots li:hover {
    opacity: 0.8;
}
@media only screen and (max-width: 768px) {
    #equipment .js .equipment-slide .slick-dots {
        margin-top: 0;
        gap: 0 10px;
    }
    #equipment .js .equipment-slide .slick-dots li {
        width: 6px;
        height: 6px;
        margin: 0;
    }
}
#equipment .js .equipment-slide .slick-slide[aria-hidden="true"]:not(.slick-cloned) ~ .slick-cloned[aria-hidden="true"] .box, #equipment .js .equipment-slide .slick-slide .box {
    transform: scale(1);
}
#equipment .js .equipment-slide .slick-slide:not(.slick-center) + .slick-slide[aria-hidden="true"]:not([tabindex="-1"]) + .slick-cloned[aria-hidden="true"] .box, #equipment .js .equipment-slide .slick-center .box {
    transform: scale(1) translateY(-35px);
}



#features {
    background: #000;
    padding: 100px 0 100px;
    color: #fff;
}
#features .ttl-shared {
    text-align: center;
    margin-bottom: 70px;
}
#features .ttl-shared span {
    display: block;
    padding-bottom: 41px;
    margin-bottom: -10px;
}
#features .ttl-shared small {
    font-size: 26px;
    letter-spacing: 5px;
    padding-left: 36px;
}
#features .row {
    justify-content: space-between;
}
#features .row .col {
    background: #fff;
    color: #000;
    width: 362px;
    padding: 30px 20px 40px;
    box-sizing: border-box;
}
#features .row .col h3 {
    font-size: 26px;
    font-weight: bold;
    text-align: center;
    line-height: 32px;
    margin-bottom: 20px;
}
#features .row .col h3 span {
    background: #000;
    color: #fff;
    font-size: 24px;
    font-weight: bold;
    width: 50px;
    display: flex;
    height: 50px;
    text-align: center;
    border-radius: 50%;
    vertical-align: middle;
    align-items: center;
    justify-content: center;
    margin: 0 auto -14px;
}
#features .row .col .img {
    width: 75%;
    margin: 0 auto 18px;
}
#features .row .col .txt {
    padding: 0 9px;
    line-height: 180%;
    font-weight: 500;
    letter-spacing: 0;
}
@media only screen and (min-width: 1100px) and (max-width: 1200px) {
	#features .row .col{
		max-width: 32%;
	}
}
@media only screen and (min-width: 768px) and (max-width: 1100px) {
  
    #features .row {
        flex-direction: column;
    }
    #features .row .col {
        max-width: 100%;
        width: 100%;
        margin-bottom: 20px;
    }
    #features .row .col .img {
		text-align: center;
	}
}
@media only screen and (max-width: 767px) {
    #features {
        padding: 70px 0 60px;
    }
    #features .ttl-shared {
        padding: 0 10px;
        margin-bottom: 55px;
    }
    #features .ttl-shared span {
        margin-bottom: -17px;
    }
    #features .ttl-shared small {
        padding-left: 0;
        font-size: 18px;
    }
    #features .row {
        flex-direction: column;
    }
    #features .row .col {
        width: 100%;
        margin-bottom: 10px;
        min-height: 630px;
    }
    #features .row .col .img {
        margin-bottom: 22px;
    }
}



#treatment {
    padding: 70px 0 110px;
    position: relative;
}
#treatment::after {
    content: "";
    background: #EDEDED;
    background: linear-gradient(180deg, rgba(237, 237, 237, 0) 0%, rgba(237, 237, 237, 0.23) 17%, rgba(237, 237, 237, 1) 100%);
    position: absolute;
    top: 600px;
    left: 0;
    right: 0;
    bottom: 0;
}
#treatment::before {
    content: "";
    position: absolute;
    left: 0;
    top: 181px;
    height: 306px;
    right: calc(50% - 393px);
    background: #D9D9D9;
}
#treatment .container {
    max-width: 1440px;
    position: relative;
}
#treatment .line1 {
    position: absolute;
    left: 84px;
    top: 590px;
    background: #8D8D8D;
    width: 1px;
    bottom: -30px;
}
#treatment .line2 {
    position: absolute;
    right: 84px;
    top: 590px;
    background: #8D8D8D;
    width: 1px;
    bottom: -30px;
}
#treatment .set1 {
    margin-bottom: 120px;
}
#treatment .set1 .catch {
    position: absolute;
    left: calc(50% + 65px);
    top: 140px;
    font-size: 40px;
    line-height: 100%;
    letter-spacing: 4px;
}
#treatment .set1 .list-photo {
    display: flex;
    justify-content: space-between;
}
#treatment .set1 .list-photo .photo1 {
    margin-right: -207px;
    width: 339px;
    position: relative;
    z-index: 4;
    margin-top: 236px;
    margin-left: -27px;
}
#treatment .set1 .list-photo .photo2 {
    width: 518px;
    margin-bottom: 20px;
    margin-left: -60px;
}
#treatment .set1 .list-photo .photo3 {
    width: 261px;
    margin-top: 333px;
    margin-left: -244px;
}
#treatment .set1 .list-photo .photo4 {
    width: 383px;
    margin-top: 93px;
    margin-right: -30px;
    margin-left: 40px;
}
#treatment .set2 .ttl-shared {
    text-align: center;
    margin-bottom: 74px;
}
#treatment .set2 .ttl-shared span {
    border: none;
    letter-spacing: 7px;
    margin-bottom: 13px;
}
#treatment .set2 .ttl-shared small {
    letter-spacing: 4px;
    font-size: 26px;
}
#treatment .set2 .ttl {
    font-size: 24px;
    text-align: center;
    letter-spacing: 3px;
    margin-bottom: 58px;
	font-weight: bold;
}
#treatment .set2 .row {
    display: flex;
}
#treatment .set2 .row .photo {
    width: 683px;
    margin-left: -30px;
    margin-bottom: 0;
}
#treatment .set2 .row .col {
    padding: 43px 40px;
    width: 627px;
    background: rgba(255, 255, 255, 0.8);
    align-self: flex-start;
    margin-left: -82px;
    font-weight: 500;
    position: relative;
    margin-top: 71px;
    min-height: 324px;
}
#treatment .set2 .row .col h3 {
    letter-spacing: 4px;
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 17px;
}
#treatment .set2 .row .col .txt {
    letter-spacing: 0;
    margin-bottom: 8px;
    line-height: 180%;
    margin-bottom: 7px;
    max-width: 504px;
}
#treatment .set2 .row .col .list-check li {
    padding-left: 23px;
    position: relative;
    margin-bottom: -7px;
    letter-spacing: 0;
}
#treatment .set2 .row .col .list-check li::before {
    content: "";
    background: url(../img/top/icon_check.svg) no-repeat;
    width: 20px;
    height: 20px;
    position: absolute;
    top: 10px;
    left: -1px;
}
#treatment .set2 .row .col .btn-link {
    position: absolute;
    bottom: 3px;
    right: 0;
}
#treatment .set2 .row .col .btn-link a {
    font-size: 14px;
    background: #000;
    color: #fff;
    padding: 10px 20px;
    transition: all 0.5s ease;
}
#treatment .set2 .row .col .btn-link a:hover {
    background: #fff;
    color: #000;
    transition: all 0.5s ease;
}
#treatment .set2 .row.row-reverse {
    flex-direction: row-reverse;
}
#treatment .set2 .row.row-reverse .col {
    margin-left: 0;
    margin-right: -90px;
    padding: 58px 41px 48px 80px;
    width: 640px;
    min-height: 322px;
    margin-top: 57px;
}
#treatment .set2 .row.row-reverse .col h3 {
    margin-bottom: 17px;
}
#treatment .set2 .row.row-reverse .col .btn-link {
    left: 88px;
}
@media only screen and (min-width: 768px) and (max-width: 1100px) {
    #treatment::before {
        right: 22%;
    }
    #treatment .line1 {
        left: 30px;
    }
    #treatment .line2 {
        right: 30px;
    }
    #treatment .set1 .catch {
        left: 42%;
        top: 31vw;
        font-size: 30px;
    }
    #treatment .set1 .list-photo .photo1 {
        width: 38%;
        margin-top: 175px;
    }
    #treatment .set1 .list-photo .photo2 {
        width: 60%;
        margin-left: 60px;
    }
    #treatment .set1 .list-photo .photo3 {
        width: 38%;
        margin-left: -120px;
    }
    #treatment .set1 .list-photo .photo4 {
        width: 45%;
        margin-top: 80px;
    }
    #treatment .set2 .row {
        margin-bottom: 50px;
    }
    #treatment .set2 .row .col {
        margin-right: 0;
    }
}
@media only screen and (max-width: 767px) {
    #treatment {
        padding-top: 0;
        padding-bottom: 70px;
    }
    #treatment::before {
        right: 10px;
        top: 14vw;
        height: 102vw;
    }
    #treatment .line1 {
        left: 20px;
        top: 649px;
        bottom: -40px;
    }
    #treatment .line2 {
        right: 20px;
        top: 649px;
        bottom: -40px;
    }
    #treatment .set1 {
        position: relative;
        margin-bottom: 49px;
    }
    #treatment .set1 .catch {
        font-size: 26px;
        left: 21%;
        top: 70vw;
        z-index: 6;
    }
    #treatment .set1 .list-photo {
        flex-direction: column;
        justify-content: flex-start;
    }
    #treatment .set1 .list-photo .photo1 {
        order: 2;
        width: 53%;
        margin-left: -10px;
        margin-top: -113px;
        margin-bottom: -10px;
    }
    #treatment .set1 .list-photo .photo2 {
        width: 85%;
        order: 1;
        margin-left: auto;
        margin-right: -10px;
    }
    #treatment .set1 .list-photo .photo3 {
        order: 4;
        margin-top: -38px;
        margin-left: 16px;
        width: 49%;
    }
    #treatment .set1 .list-photo .photo4 {
        order: 3;
        width: 88%;
        margin-left: auto;
        margin-right: -70px;
    }
    #treatment .set2 .ttl-shared {
        margin-bottom: 42px;
    }
    #treatment .set2 .ttl-shared span {
        margin-bottom: 6px;
    }
    #treatment .set2 .ttl-shared small {
        font-size: 18px;
    }
    #treatment .set2 .ttl {
        font-size: 21px;
        margin-bottom: 68px;
    }
    #treatment .set2 .row {
        flex-direction: column;
        margin-bottom: 32px;
    }
    #treatment .set2 .row .photo {
        width: 84%;
        margin: 0 auto 20px;
    }
    #treatment .set2 .row .col {
        width: 100%;
        margin: 0 auto;
        padding: 47px 47px 64px;
    }
    #treatment .set2 .row .col .list-check li::before {
		top: 8px;
	}
    #treatment .set2 .row .col .btn-link {
        right: 30px;
    }
    #treatment .set2 .row .col .btn-link a {
        padding: 9px 25px;
    }
    #treatment .set2 .row.row-reverse {
        flex-direction: column;
    }
    #treatment .set2 .row.row-reverse .col {
        width: 100%;
        padding: 30px 50px;
        margin-top: 0;
    }
    #treatment .set2 .row.row-reverse .col .btn-link {
		left: 50px;
	}
}


.banner {
    display: flex;
    justify-content: space-between;
    gap: 60px;
    padding: 57px 0 60px;
}
#menu {
    margin-top: 53px;
}
#menu h2 {
    text-align: center;
    font-size: 24px;
    font-weight: bold;
    letter-spacing: 4px;
}
#menu .list-banner {
    justify-content: space-between;
    max-width: 1145px;
    margin: 0 auto;
    padding: 0 20px;
	gap: 10px;
}
#menu .list-banner .banner {
    width: 166px;
    margin: 50px 0;
    padding: 0;
}
@media only screen and (min-width: 768px) and (max-width: 1100px) {
    #menu .list-banner {
        padding: 0;
    }
    #menu .list-banner .banner {
        max-width: 15%;
    }
}
@media only screen and (max-width: 767px) {
    .banner {
        gap: 20px;
        padding: 0 10px 50px;
    }
    #menu h2 {
        font-size: 21px;
        margin-bottom: 30px;
    }
    #menu .list-banner {
        flex-wrap: wrap;
        padding: 0 10px;
    }
    #menu .list-banner .banner {
        width: 48%;
        margin: 0 auto 4px;
    }
}


#doctor .bg {
    height: 300px;
    background: url(../img/top/doctor_bg.jpg) no-repeat;
    background-size: cover;
}
#doctor .set {
    background: url(../img/top/dcotor_bg2.jpg) no-repeat right top;
    background-size: cover;
    padding-bottom: 42px;
}
#doctor .set .ttl-shared {
    width: 396px;
    background: #fff;
    padding: 75px 70px 53px;
    margin-bottom: 48px;
    margin-left: -70px;
    position: relative;
}
#doctor .set .ttl-shared::after {
    content: "";
    background: url(../img/top/doctor_deco01.png) no-repeat;
    position: absolute;
    right: -214px;
    top: 142px;
    width: 272px;
    height: 200px;
    background-size: 100%;
}
#doctor .set .ttl-shared span {
    border-color: #000;
    letter-spacing: 8px;
    padding-bottom: 28px;
    width: 262px;
    margin-bottom: 37px;
}
#doctor .set .ttl-shared small {
    font-size: 26px;
    letter-spacing: 4px;
}
#doctor .set .group h3 {
    font-size: 26px;
    font-weight: bold;
    margin-bottom: 27px;
    letter-spacing: 4px;
}
#doctor .set .group h3 small {
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 3px;
}
#doctor .set .group h3 small u {
    border-bottom: 1px solid;
    text-decoration: none;
}
#doctor .set .txt {
    width: 749px;
    font-weight: 500;
    line-height: 180%;
    letter-spacing: 0;
    margin-bottom: 30px;
}
#doctor .set .box {
    background: #fff;
    padding: 22px 40px 55px;
    width: 550px;
    position: relative;
}
#doctor .set .box dl {
    display: flex;
    font-weight: 500;
    line-height: 180%;
    letter-spacing: 0;
}
#doctor .set .box dl dt {
    width: 123px;
}
#doctor .set .box .btn-link {
    position: absolute;
    bottom: 3px;
    right: 0;
}
#doctor .set .box .btn-link a{
    font-size: 14px;
    background: #000;
    color: #fff;
    padding: 10px 20px;
    transition: all 0.5s ease;
}
#doctor .set .box  .btn-link a:hover {
    background: #fff;
    color: #000;
    transition: all 0.5s ease;
}
@media only screen and (min-width: 768px) and (max-width: 1100px) {
    #doctor .bg {
        height: 250px;
    }
    #doctor .set {
        background-position: right 22% top 0;
    }
    #doctor .set .ttl-shared::after {
        right: 0px;
        top: 230px;
        width: 45%;
    }
    #doctor .set .group {
        position: relative;
    }
    #doctor .set .group h3 small {
        display: block;
        margin-top: 10px;
    }
    #doctor .set .txt {
        max-width: 50%;
    }
}
@media only screen and (max-width: 767px) {

    #doctor .bg {
        height: 197px;
        background-position: right 62% top;
    }
    #doctor .set {
        background: none;
        padding-bottom: 58px;
    }
    #doctor .set .ttl-shared {
        width: calc(100% + 20px);
        margin-left: -10px;
        text-align: left;
        padding: 51px 35px 20px;
        margin-bottom: 0;
    }
    #doctor .set .ttl-shared::after {
        display: none;
    }
    #doctor .set .ttl-shared span {
        text-align: left;
        margin-bottom: 20px;
    }
    #doctor .set .ttl-shared small {
        font-size: 18px;
    }
    #doctor .set .group {
        position: relative;
        margin-bottom: 32px;
    }
    #doctor .set .group::before {
        content: "";
        background: url(../img/top/doctor_deco01_sp.png) no-repeat;
        position: absolute;
        left: -28px;
        top: -40px;
        width: 172px;
        height: 310px;
        background-size: 100%;
    }
    #doctor .set .group h3 {
        position: absolute;
        top: 38px;
        left: 10px;
    }
    #doctor .set .group h3 span {
        font-size: 21px;
    }
    #doctor .set .group h3 small {
        display: block;
        font-size: 12px;
        margin-top: 19px;
        margin-left: -8px;
        letter-spacing: 1px;
    }
    #doctor .set .group .img {
        margin: 0 -10px 0 -10px;
    }
    #doctor .set .txt {
        width: 100%;
        padding: 0 24px;
        margin-bottom: 36px;
    }
    #doctor .set .box {
        width: 86%;
        padding: 22px;
        border: 1px solid #000;
        margin: 0 auto;
        font-size: 14px;
        line-height: 160%;
        padding-bottom: 47px;
    }
    #doctor .set .box h4 {
        font-size: 14px;
    }
    #doctor .set .box dl {
        justify-content: flex-start;
        display: inline-block;
        font-size: 14px;
    }
    #doctor .set .box dl dt {
        width: 110px;
    }
    #doctor .set .box .btn-link {
        bottom: 8px;
    }
    #doctor .set .box .btn-link a {
        padding: 9px 25px;
     }
    #doctor .banner {
        flex-direction: column;
        padding-bottom: 67px;
    }
}



#access {
    background: #1F1F1F;
    color: #fff;
    padding: 107px 0 114px;
}
#access .ttl-shared {
    text-align: center;
    margin-bottom: 48px;
}
#access .ttl-shared span {
    border: 0;
    letter-spacing: 7px;
    margin-bottom: 18px;
}
#access .ttl-shared small {
    font-size: 26px;
}
#access .row {
    width: 100%;
    justify-content: space-between;
}
#access .row .col {
    width: 47%;
}
#access .row .col .row2 h3 {
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 13px;
    letter-spacing: 5px;
}
#access .row .col .row2 .timetable {
    color: #fff;
}
#access .row .col .row2 .timetable thead th:first-child {
    width: 24%;
    border-left-width: 1px;
}
#access .row .col .parking {
    text-align: right;
}
#access .row .col .parking span {
    background: #fff;
    color: #000;
    padding: 4px 10px;
    letter-spacing: 0px;
	    font-size: 14px;
}
#access .timetable thead th {
    font-size: 14px;
    font-weight: 500;
    border: 2px solid #CCCCCC;
}
#access .timetable tbody th, #access .timetable tbody td {
    font-weight: 500;
    border: 2px solid #CCCCCC;
    text-align: center;
    line-height: 21px;
    color: #fff;
    font-size: 14px;
}
#access .row .col .row2 .timetable thead th:last-of-type {
    border-right-width: 1px;
}
#access .timetable tbody td:last-of-type {
    border-right-width: 1px;
}
#access .timetable tbody th {
    border-left-width: 1px;
	background: #1F1F1F;
}
#access .timetable tbody tr:last-child td, .timetable tbody tr:last-child th {
    padding-bottom: 10px;
    border-bottom-width: 1px;
}
#access .row .col .row2 .timetable thead th {
    background: #373737;
    color: #fff;
    text-align: center;
    border-top-width: 1px;
}
#access .timetable tbody tr:last-child th {
    border-bottom-width: 1px;
}
#access .row .col .row2 .note {
    line-height: 160%;
    margin-bottom: 23px;
    font-size: 14px;
}
#access .row .col .row2 .address {
    line-height: 140%;
    padding-left: 40px;
    position: relative;
    letter-spacing: 0px;
    margin-bottom: 1px;
}
#access .row .col .row2 .address::before {
    content: "";
    background: url(../img/top/icon_map_w.svg) no-repeat;
    width: 20px;
    height: 20px;
    position: absolute;
    top: 10px;
    left: 9px;
}
#access .row .col .row2 .tel {
    font-weight: 500;
    font-size: 16px;
    display: flex;
    align-items: center;
    padding-left: 35px;
    position: relative;
    letter-spacing: 0px;
}
#access .row .col .row2 .tel::before {
    content: "";
    background: url(../img/top/icon_tel_w.svg) no-repeat;
    width: 16px;
    height: 18px;
    position: absolute;
    top: 9px;
    left: 12px;
}
#access .row .map {
    width: 50%;
    position: relative;
    padding-top: 310px;
}
#access .row .map iframe {
    height: 300px;
    width: 100%;
}
#access .row .col .row2:nth-child(2) h3 {
    margin-bottom: -35px;
}
#access .row .col .row2 .address::before {
    content: "";
}
#access .row .col .row2 .tel a {
    color: #fff;
}
#access .row .col .row2 .tel::before {
    content: "";
}

@media only screen and (min-width: 768px) and (max-width: 1100px) {

    #access .row .col .row2 .timetable thead th {
        width: 7%;
    }
    #access .row .col .row2 .timetable thead th:last-child {
        width: 11%;
    }

    #access .row .col .row2 .address {
        font-size: 14px;
        padding-left: 35px;
    }
    #access .row .col .row2 .tel {
        font-size: 14px;
    }
}
@media only screen and (max-width: 767px) {
    #access {
        padding-bottom: 50px;
        padding-top: 58px;
    }
    #access .ttl-shared {
        margin-bottom: 35px;
    }
    #access .ttl-shared span {
        margin-bottom: -6px;
    }
    #access .ttl-shared small {
        font-size: 18px;
    }

    #access .row .col .row2 .timetable thead th:first-child {
        padding-left: 0;
        border-top-width: 1px;
        border-left-width: 1px;
    }
    #access .row .col .parking {
        text-align: left;
    }
    #access .row .col .parking span {
        padding: 4px 10px;
        font-size: 14px;
    }
    #access .timetable thead th {
        font-size: 12px;
    }
    #access .timetable tbody th, #access .timetable tbody td {
        border-left-width: 1px;
    }
    #access .timetable tbody td:last-of-type {
        border-right-width: 1px;
    }
    #access .timetable tbody tr:last-child td, .timetable tbody tr:last-child th {
        padding-bottom: 7px;
        border-bottom-width: 1px;
    }
    #access .row .col .row2 .timetable thead th {
        padding-top: 13px;
        padding-bottom: 12px;
        border-top-width: 1px;
    }
    #access .row .col .row2 .timetable thead th:last-of-type {
        border-right-width: 1px;
    }
    #access .timetable tbody tr:last-child th {
        border-left-width: 1px;
        border-bottom-width: 1px;
    }
    #access .row .map {
        padding-top: 246px;
    }
    #access .row {
        flex-direction: column;
        padding: 0 7px;
    }
    #access .row .col {
        width: 100%;
        margin-bottom: -10px;
    }
    #access .row .col .row2 {
        margin-bottom: 37px;
    }
    #access .row .col .row2:nth-child(2) h3 {
        margin-bottom: 20px;
    }
    #access .row .col .row2 .address {
        padding-left: 32px;
        margin-bottom: 15px;
    }
    #access .row .col .row2 .address::before {
        top: 11px;
        left: 0;
    }
    #access .row .col .row2 .tel {
        padding-left: 29px;
    }
    #access .row .col .row2 .tel::before {
        left: 2px;
    }
    #access .row .map {
        width: auto;
        margin: 0px -20px;
    }
    #banner {
        background: url(../img/top/banner_img01_sp.jpg) no-repeat;
        background-size: cover;
        padding-bottom: 93px;
        padding-top: 84px;
    }
    #banner .tel {
        width: 90%;
    }
}