@-webkit-keyframes fadeInDown {
  0% {
    -webkit-transform: translate3d(0, 50%, 0);
    opacity: 0;
    transform: translate3d(0, 50%, 0);
  }
  to {
    -webkit-transform: translateZ(0);
    opacity: 1;
    transform: translateZ(0);
  }
}
@keyframes fadeInDown {
  0% {
    -webkit-transform: translate3d(0, 50%, 0);
    opacity: 0;
    transform: translate3d(0, 50%, 0);
  }
  to {
    -webkit-transform: translateZ(0);
    opacity: 1;
    transform: translateZ(0);
  }
}
.home_page .key {
  --height: 56vw;
  --min-height: 550px;
  --max-height: 940px;
  height: var(--height);
  min-height: var(--min-height);
  max-height: var(--max-height);
  font-size: 0.5882352941em;
}
.home_page .key .inner {
  position: relative;
  z-index: 1;
  padding: 0;
  width: 100%;
  max-width: 1920px;
}
.home_page .key .mv_slider {
  z-index: 0;
}
.home_page .key .mv_slider:not(.slick-slider) {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  overflow: hidden;
}
.home_page .key .s1 {
  background-image: url(../images/idx_mv01.jpg);
}
.home_page .key .slick-initialized .s2 {
  background-image: url(../images/idx_mv02.jpg);
}
.home_page .key .slick-initialized .s3 {
  background-image: url(../images/idx_mv03.jpg);
}
.home_page .key .key_text {
  position: relative;
  z-index: 0;
  overflow: hidden;
}
.home_page .key .key_text .item {
  height: var(--height);
  min-height: var(--min-height);
  max-height: var(--max-height);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.home_page .key .key_text .item::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 16em;
  background: url(../images/hd_bg.png) repeat-x center bottom;
}
.home_page .key .key_catch {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 100%;
  padding-bottom: 7em;
}
.home_page .key .key_catch::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 80%;
  max-width: 102em;
  height: 100%;
  background: -webkit-gradient(linear, right top, left top, from(rgba(0, 0, 0, 0)), to(rgba(0, 0, 0, 0.34)));
  background: linear-gradient(-90deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.34) 100%);
  z-index: -1;
}
.home_page .key .catch {
  margin-left: 14em;
  -webkit-animation: fadeInDown 1s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
          animation: fadeInDown 1s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}
.home_page .key .catch h2,
.home_page .key .catch p {
  color: #fff;
  font-weight: 500;
}
.home_page .key .catch h2 {
  margin-bottom: 0.5106382979em;
  font-size: 4.7em;
  line-height: 1.55;
  letter-spacing: 0.125em;
}
.home_page .key .catch p {
  font-size: 2.5em;
  line-height: 1.75;
  letter-spacing: 0.1em;
}
.home_page .key .key_banner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  position: absolute;
  bottom: 2em;
  left: 2em;
  width: 100%;
}
.home_page .key .key_banner .bnr_item {
  border-radius: 3em;
  border: 0.4em solid #ffffff;
  position: relative;
  z-index: 0;
  overflow: hidden;
  color: #ffffff;
  height: 12em;
  margin-right: 1em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 2em 3.3em 2em;
  -webkit-box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.16);
          box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.16);
  background-position: center;
  background-size: cover;
  -webkit-animation: fadeInDown 1.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
          animation: fadeInDown 1.5s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}
.home_page .key .key_banner .bnr_item::before, .home_page .key .key_banner .bnr_item::after {
  content: "";
  position: absolute;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}
.home_page .key .key_banner .bnr_item::before {
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.25);
  z-index: -1;
}
.home_page .key .key_banner .bnr_item::after {
  top: 1.1em;
  right: 1.1em;
  background: url(../images/key_ic_arr.svg) no-repeat center/contain;
  width: 2.4em;
  height: 2.4em;
}
.home_page .key .key_banner .bnr_item.bnr01 {
  background-image: url(../images/key_bnr_bg01.jpg);
  max-width: 31em;
  width: 40%;
}
.home_page .key .key_banner .bnr_item.bnr02 {
  background-image: url(../images/key_bnr_bg02.jpg);
  max-width: 40em;
  width: 58%;
}
.home_page .key .key_banner .bnr_tl {
  font-size: 1.5em;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1;
}
.home_page .key .key_banner .bnr_tl .tt_lg {
  font-size: 1.4em;
  letter-spacing: 0.075em;
  display: block;
  margin-top: 0.5714285714em;
}
.home_page .key .key-dots {
  margin-top: 4.8em;
  margin-left: -6px;
}
.home_page .key .key-dots .slick-dots {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 3em;
}
.home_page .key .key-dots .slick-dots li {
  margin: 6px;
}
.home_page .key .key-dots .slick-dots li button {
  border: 0;
  background-color: #ffffff;
  border-radius: 50%;
  width: 8px;
  height: 8px;
  text-indent: -9999px;
  color: transparent;
  cursor: pointer;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}
.home_page .key .key-dots .slick-dots li.slick-active button {
  background-color: var(--main-color);
}
.home_page .idx_scroll {
  position: absolute;
  left: 4.3em;
  top: 3.8em;
  bottom: 0;
  margin: auto;
  display: table;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}
.home_page .idx_scroll a {
  -webkit-writing-mode: sideways-lr;
      -ms-writing-mode: sideways-lr;
          writing-mode: sideways-lr;
  font-family: var(--f-en);
  font-size: 1.6em;
  font-weight: 500;
  letter-spacing: 0.055em;
  color: #ffffff;
  text-decoration: none;
  padding-bottom: 5.125em;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}
.home_page .idx_scroll a::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 0.75em;
  height: 4.3125em;
  background: url(../images/ic_scroll.svg) no-repeat center/contain;
}
.home_page .topic_path {
  display: none;
}

@media only screen and (min-width: 1921px) {
  .home_page .key {
    --max-height: 37vw;
  }
  .home_page .key .key_banner {
    max-width: 1920px;
    margin: auto;
    right: 0;
  }
}
@media only screen and (min-width: 769px) {
  .home_page .idx_scroll a:hover {
    margin-top: 1em;
  }
  .home_page .key .key-dots .slick-dots li:hover button {
    background-color: var(--main-color);
  }
  .home_page .key .key_banner .bnr_item:hover::before {
    background-color: rgba(0, 0, 0, 0.46);
  }
  .home_page .key .key_banner .bnr_item:hover::after {
    top: 1.6em;
  }
  .home_page .key .key_text .item{image-rendering: pixelated;}
}
@media only screen and (max-width: 1560px) and (min-width: 769px) {
  .home_page .key {
    --max-height: calc(100vh - 60px);
  }
}
@media only screen and (max-width: 1560px) and (min-width: 769px) and (max-height: 720px) and (orientation: landscape) {
  .home_page .key {
    font-size: min(10px, 1vmin);
  }
}
@media only screen and (max-width: 1366px) and (min-width: 769px) {
  .home_page .key {
    font-size: min(8px, 0.75vw);
  }
  .home_page .idx_scroll {
    font-size: 1.2vmin;
    left: 2.3em;
  }
  .home_page .key_banner {
    font-size: 1.2em;
  }
}
@media only screen and (max-width: 1200px) and (min-width: 769px) {
  .home_page .key .key_text .item {
    background-position: left 30% center;
  }
}
.h3_tl {
  position: relative;
  text-align: center;
  z-index: 0;
}
.h3_tl h3 {
  font-size: 40px;
  font-weight: 500;
  color: #675330;
  letter-spacing: 0.075em;
}
.h3_tl h3::after {
  content: "";
  display: block;
  position: relative;
  width: 41px;
  height: 5px;
  background: var(--main-color);
  margin: 12px auto 0;
}
.h3_tl .h_en {
  font-size: 123px;
  font-weight: 400;
  text-transform: uppercase;
  line-height: 1;
  letter-spacing: 0.15em;
  color: rgba(255, 255, 255, 0.2);
  position: absolute;
  right: 0;
  left: 0.162601626em;
  top: -0.3739837398em;
  white-space: nowrap;
  z-index: -1;
}
.h3_tl .h_en.white {
  color: #ffffff;
}
.h3_tl.tl_left {
  text-align: left;
}
.h3_tl.tl_left h3::after {
  margin-left: 0;
  margin-right: 0;
}
.h3_tl.tl_left .h_en {
  left: unset;
  right: 136px;
}
.h3_tl.tl_white h3 {
  color: #ffffff;
}
.h3_tl.tl_white h3::after {
  background-color: #ffffff;
  width: 52px;
  height: 3px;
  margin-top: 22px;
}
.h3_tl.tl_white .h_en {
  color: rgba(255, 255, 255, 0.2);
}

.h3_st02 {
  text-align: center;
}
.h3_st02 h3 {
  font-size: 40px;
  font-weight: 500;
  letter-spacing: 0.075em;
  line-height: 1.5;
  text-align: center;
  color: #ffffff;
  margin-bottom: 22px;
}
.h3_st02 h3 .txt_sm {
  font-size: 30px;
}
.h3_st02 .h_en {
  font-size: 18px;
  color: #B9A87B;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.05em;
  display: table;
  padding: 0 104px;
  margin: 0 auto;
  position: relative;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}
.h3_st02 .h_en::before, .h3_st02 .h_en::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 80px;
  height: 1px;
  background-color: #B9A87B;
}
.h3_st02 .h_en::before {
  left: 0;
}
.h3_st02 .h_en::after {
  right: 0;
}

.btn02 {
  display: table;
  margin-top: 35px;
  margin-left: 1px;
}
.btn02 a {
  text-decoration: none;
  color: var(--clr1);
  letter-spacing: 0.05em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
}
.btn02 a::before {
  content: "";
  position: relative;
  top: -1px;
  left: -1px;
  display: block;
  width: 70px;
  height: 70px;
  margin-right: 19px;
  border-radius: 50%;
  background: #B9A87B url(../images/ic_arr02.svg) no-repeat center/6px auto;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}
.btn02 a:hover {
  color: var(--clr1);
}

.idx01 {
  padding: 149px 0 138px;
}
.idx01 .h3_tl h3 {
  font-size: 35px;
}
.idx01 .h3_tl h3::after {
  margin-top: 10px;
}
.idx01 .h3_tl .h_en {
  color: rgba(234, 230, 225, 0.4);
}
.idx01 .tab_btn {
  margin-top: 66px;
}
.idx01 .tab_btn .tab {
  border-radius: 40px;
  padding: 18px 20px 17px;
  background-color: #F9F6F3;
  letter-spacing: 0.075em;
  text-align: center;
  color: #B9AE9E;
  font-weight: 500;
  max-width: 270px;
  width: 100%;
  cursor: pointer;
  margin-top: 10px;
}
.idx01 .tab_btn .tab.active {
  background-color: var(--main-color);
  color: #fff;
}
.idx01 .tab_btn .tab p {
  line-height: 1.5;
}
.idx01 .col_cont > .content {
  position: relative;
  background-color: #ffffff;
}
.idx01 .col_cont > .content > div {
  opacity: 0;
  z-index: -10;
  visibility: hidden;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  background-color: #ffffff;
  padding-bottom: 10px;
}
.idx01 .col_cont > .content > div.active {
  opacity: 1;
  z-index: 1;
  visibility: visible;
}
.idx01 .btn_news {
  display: table;
  margin-left: auto;
}
.idx01 .btn_news a {
  position: relative;
  text-decoration: none;
  color: var(--clr1);
  padding-left: 38px;
  font-weight: 500;
  letter-spacing: 0.075em;
}
.idx01 .btn_news a::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: 28px;
  height: 28px;
  background: var(--clr1) url(../images/ic_btn_list.svg) no-repeat center/100% auto;
  border-radius: 50%;
}
.idx01 .btn_news a:hover {
  opacity: 1;
}
.idx01 .list_post {
  border-bottom: 1px solid #EAE6E1;
  padding-bottom: 14px;
  margin-bottom: 20px;
}
.idx01 .list_post a {
  text-decoration: none;
  color: #675330;
  font-weight: 500;
  padding: 0 5px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  padding-right: 30px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  white-space: nowrap;
  margin-bottom: 35px;
}
.idx01 .list_post a::after {
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 23px;
  height: 23px;
  mask-image: url(../images/ic_arr.svg);
  -webkit-mask-image: url(../images/ic_arr.svg);
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-size: 100% auto;
  -webkit-mask-size: 100% auto;
  mask-position: center;
  -webkit-mask-position: center;
  background-color: #9D8867;
}
.idx01 .list_post .date {
  color: #C7BBA9;
  font-family: var(--f-en);
  letter-spacing: 0.05em;
  width: 101px;
  font-size: 14px;
}
.idx01 .list_post .cate {
  width: 120px;
  line-height: 1;
  padding: 10px 20px 11px;
  text-align: center;
  font-size: 14px;
  color: #ffffff;
  background-color: var(--main-color);
  border-radius: 50px;
  display: block;
}
.idx01 .list_post .cate.column {
  background-color: var(--clr1);
}
.idx01 .list_post .title {
  width: calc(100% - 245px);
  position: relative;
  text-overflow: ellipsis;
  overflow: hidden;
  display: block;
  padding-left: 20px;
  letter-spacing: 0.075em;
}

.idx02 {
  padding: 115px 0 126px;
  position: relative;
  z-index: 0;
  background-color: #F7F7F7;
}
.idx02::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  max-height: 698px;
  background: url(../images/idx02_bg.png) no-repeat center/cover;
  z-index: -1;
}
.idx02 .h3_tl {
  margin-bottom: 84px;
}
.idx02 .idx_logo {
  max-width: 370px;
  margin-bottom: 40px;
}
.idx02 .fblock {
  max-width: 1100px;
  width: 100%;
  margin: 0 auto;
}
.idx02 .block_clinic {
  background-color: #ffffff;
  border-radius: 80px;
  padding: 100px 40px;
}
.idx02 .b_info {
  margin-bottom: 49px;
}
.idx02 .btn-group {
  width: 100%;
  margin-top: 46px;
}
.idx02 .b_traffic {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 10px -10px 0;
}
.idx02 .b_traffic .traffic_item {
  width: calc(50% - 20px);
  max-width: 255px;
  margin: 10px;
  background-color: #F9F6F3;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 24px 26px 24px;
  border-radius: 20px;
}
.idx02 .b_traffic .traffic_ic {
  width: 58px;
  height: 58px;
  background-color: #ffffff;
  border-radius: 8px;
  overflow: hidden;
}
.idx02 .b_traffic .traffic_tl {
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0.075em;
  line-height: 1.4;
  width: calc(100% - 58px);
  padding-left: 20px;
}

.idx_map {
  border-radius: 20px;
  overflow: hidden;
  height: 356px;
}
@-moz-document url-prefix() {
  .idx_map {
    /* Fire Fox */
    height: 375px;
  }
}

.idx03 {
  background-color: #F7F7F7;
  padding-bottom: 94px;
  border-bottom: 6px solid #fff;
}
.idx03 .h3_tl {
  margin-bottom: 59px;
}
.idx03 .btn-group {
  margin-top: 40px;
}
.idx03 .btn-group .btn {
  max-width: 350px;
}
.idx03 .idx_wrap {
  max-width: 1920px;
  width: 100%;
  margin: 0 auto;
  position: relative;
}
.idx03 .block_greeting {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.idx03 .block_greeting .h3_tl {
  width: 100%;
  position: unset;
}
.idx03 .greeting_cont {
  position: relative;
  z-index: 1;
  padding: 105px 120px 104px 0;
}
.idx03 .greeting_cont::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 1090px;
  height: 100%;
  background-color: #ffffff;
  z-index: -1;
  border-radius: 0 80px 80px 0;
}
.idx03 .box_name {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: absolute;
  right: -91px;
  top: -173px;
}
.idx03 .box_name p {
  -webkit-writing-mode: vertical-lr;
      -ms-writing-mode: tb-lr;
          writing-mode: vertical-lr;
}
.idx03 .box_name .pos {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  font-size: 1.1764705882em;
}
.idx03 .box_name .pos span {
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.2em;
  position: relative;
  top: -0.1em;
}
.idx03 .box_name .name {
  border-left: 1px solid var(--clr1);
  padding-left: 1.2941176471em;
  margin-left: 1.3529411765em;
  position: relative;
  top: -0.1176470588em;
  padding-bottom: 3.2352941176em;
}
.idx03 .box_name .name span {
  line-height: 1;
}
.idx03 .box_name .name .jp {
  font-size: 2.3529411765em;
  letter-spacing: 0.22em;
  margin-bottom: 0.425em;
  position: relative;
  top: -0.05em;
}
.idx03 .box_name .name .en {
  font-size: 0.8235294118em;
  letter-spacing: 0.075em;
  font-weight: 400;
}

.idx04 {
  background: url(../images/idx04_bg.jpg) no-repeat right center/cover;
  padding: 182px 0 120px;
}
.idx04 .h3_tl {
  margin-bottom: 96px;
}
.idx04 .feature_slider:not(.slick-slider), .idx04 .feature_thumb:not(.slick-slider) {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  overflow: hidden;
  opacity: 0;
}
.idx04 .feature_slider .feature_item {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  z-index: 0;
}
.idx04 .feature_slider h4 {
  font-size: 30px;
  line-height: 1.5;
  font-weight: 500;
  letter-spacing: 0.075em;
  margin-bottom: 29px;
}
.idx04 .feature_slider .btn {
  max-width: 350px;
  margin-left: auto;
  margin-top: 48px;
}
.idx04 .feature_slider .feature_img img {
  border-radius: 40px;
}
.idx04 .feature_slider .feature_cont {
  padding: 90px 50px 50px 80px;
  position: relative;
}
.idx04 .feature_slider .feature_cont::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: calc(200% - 200px);
  height: 100%;
  background-color: #ffffff;
  border-radius: 40px;
  z-index: -1;
}
.idx04 .feature_slider .p_cont {
  min-height: 6.3529411765em;
}
.idx04 .feature_slider .feature_num {
  font-size: 25px;
  font-weight: 500;
  line-height: 1;
  font-family: var(--f-en);
  letter-spacing: 0.15em;
  color: var(--clr2);
  position: absolute;
  top: -1.48em;
  right: 1.16em;
}
.idx04 .feature_slider .feature_num span {
  font-size: 3.2em;
  line-height: 1;
  font-weight: 400;
  letter-spacing: 0.1em;
  margin-left: 0.1375em;
  position: relative;
  top: 0.05em;
}
.idx04 .feature_thumb {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  max-width: 1120px;
  width: 100%;
  margin: 38px auto 0;
  font-size: 10px;
}
.idx04 .feature_thumb img {
  opacity: 0.5;
}
.idx04 .feature_thumb .slick-track {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100% !important;
}
.idx04 .feature_thumb .thumb_it {
  width: calc(25% - 2em) !important;
  max-width: 26em;
  margin: 1em;
  cursor: pointer;
  position: relative;
  z-index: 0;
}
.idx04 .feature_thumb .thumb_it::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 4em;
  border: 5px solid #ffffff;
  opacity: 1;
  visibility: hidden;
}
.idx04 .feature_thumb .thumb_it.slick-current {
  opacity: 1;
}
.idx04 .feature_thumb .thumb_it.slick-current::before {
  visibility: visible;
  opacity: 1;
}
.idx04 .feature_thumb .thumb_it.slick-current img {
  opacity: 1;
}
.idx04 .feature_thumb .thumb_it.slick-current .point {
  opacity: 1;
}
.idx04 .feature_thumb .thumb_img {
  border-radius: 4em;
  overflow: hidden;
}
.idx04 .feature_thumb .point {
  position: absolute;
  right: 0.48em;
  bottom: 0.4em;
  font-family: var(--f-en);
  font-size: 5em;
  line-height: 1;
  color: #ffffff;
  letter-spacing: 0.1em;
  margin-bottom: 0;
  opacity: 0.7;
  z-index: 1;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}
.idx04 .slick-dots {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: -24px;
  margin-left: -6px;
  position: relative;
  z-index: 2;
}
.idx04 .slick-dots li {
  margin: 6px 7px 5px 6px;
}
.idx04 .slick-dots li button {
  border: 0;
  background-color: #ffffff;
  border-radius: 50%;
  width: 8px;
  height: 8px;
  text-indent: -9999px;
  color: transparent;
  cursor: pointer;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}
.idx04 .slick-dots li.slick-active button {
  background-color: var(--clr2);
}
.idx04 .slick-arrow{
  border-radius: 50%;
  background-color: var(--main-color);
  background-size: 100% auto;
  background-position: center;
  background-repeat: no-repeat;
  top: 50%;
  width: 3em;
  height: 3em;
}
.idx04 .slick-arrow.slick-prev{
  background-image: url(../images/ic_prev.svg);
  left: -10px;
}
.idx04 .slick-arrow.slick-next{
  background-image: url(../images/ic_next.svg);
  right: -10px;
}

.idx05 {
  padding: 176px 0 0;
  background: #F9F6F3 url(../images/idx05_bg.png) no-repeat top left/auto;
}
.idx05 .h3_tl {
  margin-bottom: 77px;
}
.idx05 .h3_tl .h_en {
  top: -0.4634146341em;
}
.idx05 .b_tab {
  position: relative;
}
.idx05 .b_tab::before {
  content: "";
  position: absolute;
  top: -23.3em;
  right: -11.1em;
  background: url(../images/idx05_bf.png) no-repeat center/contain;
  width: 35.4em;
  height: 29.1em;
  font-size: 10px;
}
.idx05 .block_medical .medical_item {
  border: 1px solid #EDE5DD;
  border-radius: 20px;
  text-align: center;
  position: relative;
  padding: 2.9em 2em 2.8em;
  font-size: 10px;
}
.idx05 .block_medical .medical_item::before {
  content: "";
  position: absolute;
  top: 1.4em;
  right: 1.4em;
  width: 2.4em;
  height: 2.4em;
  mask-image: url(../images/ic_arr.svg);
  -webkit-mask-image: url(../images/ic_arr.svg);
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-size: 100% auto;
  -webkit-mask-size: 100% auto;
  mask-position: center;
  -webkit-mask-position: center;
  background-color: var(--clr1);
}
.idx05 .block_medical .medical_img {
  background-color: #F9F6F3;
  width: 10.3em;
  height: 10.3em;
  border-radius: 50%;
  margin: 0 auto 2.1em;
}
.idx05 .block_medical .medical_img img {
  max-width: 10.3em;
}
.idx05 .block_medical .medical_tl {
  font-size: 1.9em;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.075em;
}
.idx05 .block_menu {
  border-radius: 20px;
  margin-bottom: 20px;
  padding: 40px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.idx05 .block_menu:last-child {
  margin-bottom: 0;
}
.idx05 .block_menu.bg_pink {
  background-color: #FFF0F0;
}
.idx05 .block_menu.bg_yellow {
  background-color: #FCF8E5;
}
.idx05 .block_menu.bg_green {
  background-color: #F2FAEC;
}
.idx05 .block_menu .menu_title {
  text-align: center;
}
.idx05 .block_menu .menu_title figure {
  display: table;
  margin: 0 auto 10px;
}
.idx05 .block_menu .menu_title .title {
  font-size: 22px;
  line-height: 1.5;
  margin-top: 14px;
  font-weight: 500;
  letter-spacing: 0.075em;
}
.idx05 .block_menu .btn-group {
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}
.idx05 .block_menu .btn-group .btn {
  max-width: 330px;
  width: calc(33.3333333333% - 10px);
  margin: 5px;
}

.idx06 {
  padding-top: 140px;
  padding-bottom: 110px;
  background-color: #F9F6F3;
}
.idx06 .h3_tl {
  margin-bottom: 79px;
}
.idx06 .h3_tl .h_en {
  top: -0.5853658537em;
}
.idx06 .block_pickup .btn {
  margin: 24px auto 0;
  max-width: 350px;
}
.idx06 .block_pickup .pickup_cont {
  padding: 0 20px;
}
.idx06 .block_pickup .pickup_img {
  position: relative;
  border-radius: 40px;
  overflow: hidden;
  margin-bottom: 35px;
}
.idx06 .block_pickup .pickup_img::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 185px;
  background: url(../images/idx06_img_bf.png) repeat-x top left/auto 100%;
  opacity: 0.3;
}
.idx06 .block_pickup .pickup_img img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}
.idx06 .block_pickup .pickup_tl {
  position: absolute;
  z-index: 1;
  bottom: 0;
  left: 0;
  width: 100%;
  text-align: center;
  padding: 0 20px 29px;
  color: #ffffff;
}
.idx06 .block_pickup .pickup_tl h4 {
  font-size: 27px;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.5;
}
.idx06 .block_pickup .pickup_tl .en {
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1;
  margin-bottom: 7px;
}

@-webkit-keyframes rotate-center {
  0% {
    -webkit-transform: rotate(0);
    transform: rotate(0);
  }
  100% {
    -webkit-transform: rotate(540deg);
    transform: rotate(540deg);
  }
}
@keyframes rotate-center {
  0% {
    -webkit-transform: rotate(0);
    transform: rotate(0);
  }
  100% {
    -webkit-transform: rotate(540deg);
    transform: rotate(540deg);
  }
}
.idx07 {
  background: url(../images/idx07_bg.jpg) no-repeat center/cover;
  padding: 178px 0 189px;
}
.idx07 .h3_st02 {
  margin-bottom: 57px;
}
.idx07 .btn02 {
  margin: 45px auto 0;
}
.idx07 .btn02 a {
  color: #ffffff;
}
.idx07 .btn02 a:hover {
  color: #ffffff;
}
.idx07 .block_artmake .artmake_cont {
  color: #ffffff;
}
.idx07 .block_artmake .artmake_cont p {
  font-weight: 500;
  letter-spacing: 0.05em;
}
.idx07 .block_artmake .artmake_img {
  height: 48.6em;
  max-width: 58.3em;
  position: relative;
  margin-top: -26px;
  left: 2px;
  font-size: 10px;
}
.idx07 .block_artmake .artmake_img .circle {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: absolute;
  z-index: 0;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}
.idx07 .block_artmake .artmake_img .circle::before, .idx07 .block_artmake .artmake_img .circle::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}
.idx07 .block_artmake .artmake_img .circle::before {
  border-radius: 50%;
  border: 1px solid #B9A87B;
}
.idx07 .block_artmake .artmake_img .circle::after {
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}
.idx07 .block_artmake .artmake_img .circle.active {
  z-index: 2;
}
.idx07 .block_artmake .artmake_img .circle.active::before {
  background-color: rgba(255, 255, 255, 0.9);
}
.idx07 .block_artmake .artmake_img .circle.active::after {
  -webkit-animation: rotate-center 18s ease-out infinite forwards;
          animation: rotate-center 18s ease-out infinite forwards;
}
.idx07 .block_artmake .artmake_img .circle.active p {
  color: var(--clr1);
}
.idx07 .block_artmake .artmake_img .circle.active .ic::after {
  background-color: var(--clr1);
}
.idx07 .block_artmake .artmake_img .circle_txt01 {
  margin-bottom: 0.6em;
}
.idx07 .block_artmake .artmake_img .circle_txt01 span {
  display: block;
}
.idx07 .block_artmake .artmake_img .circle_txt01 .ic {
  position: relative;
}
.idx07 .block_artmake .artmake_img .circle_txt01 .ic::after {
  content: "";
  position: relative;
  display: block;
  margin: 0.3125em auto 0.1875em;
  mask-image: url(../images/idx07_ic.svg);
  -webkit-mask-image: url(../images/idx07_ic.svg);
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-size: 100% auto;
  -webkit-mask-size: 100% auto;
  mask-position: center;
  -webkit-mask-position: center;
  background-color: #E2CB8E;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
  width: 1.25em;
  height: 0.9375em;
}
.idx07 .block_artmake .artmake_img p {
  font-size: 1.6em;
  line-height: 1.875;
  color: #E2CB8E;
  font-weight: 500;
  letter-spacing: 0.05em;
  text-align: center;
}
.idx07 .block_artmake .artmake_img .circle01 {
  width: 28.1em;
  height: 28.1em;
  top: 0;
  left: 0;
}
.idx07 .block_artmake .artmake_img .circle01::after {
  background-image: url(../images/circle01.svg);
}
.idx07 .block_artmake .artmake_img .circle02 {
  width: 34.4em;
  height: 34.4em;
  top: 2.2em;
  bottom: 0;
  right: 0;
  margin: auto;
}
.idx07 .block_artmake .artmake_img .circle02::after {
  background-image: url(../images/circle03.svg);
}
.idx07 .block_artmake .artmake_img .circle03 {
  width: 22.6em;
  height: 22.6em;
  bottom: 0;
  left: 5.5em;
  padding-top: 1em;
}
.idx07 .block_artmake .artmake_img .circle03::after {
  background-image: url(../images/circle02.svg);
}

.idx08 {
  background: url(../images/idx08_bg.jpg) no-repeat top center/cover;
  padding-bottom: 100px;
}
.idx08 .idx_wrap {
  max-width: 1920px;
  width: 100%;
  margin: 0 auto;
}
.idx08 .h3_st02 {
  margin-bottom: 61px;
}
.idx08 .h3_st02 h3 {
  color: var(--clr1);
  font-size: 38px;
  margin-bottom: 17px;
}
.idx08 .h3_st02 .h_en {
  padding-left: 100px;
}
.idx08 .concerns_img {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  max-width: 710px;
  margin-top: 72px;
}
.idx08 .concerns_img figure {
  width: calc(50% - 5px);
}
.idx08 .concerns_img figure img {
  -webkit-box-shadow: 20px 20px 0px rgba(199, 187, 169, 0.16);
          box-shadow: 20px 20px 0px rgba(199, 187, 169, 0.16);
}
.idx08 .concerns_img .img01 {
  margin-top: 50px;
}
.idx08 .listcheck {
  max-width: 500px;
  width: 100%;
}
.idx08 .listcheck li {
  position: relative;
  padding-left: 34px;
  line-height: 1.6;
  font-weight: 500;
  letter-spacing: 0.05em;
  margin-bottom: 14px;
  border-bottom: 1px solid #EAE6E1;
  padding-bottom: 13px;
}
.idx08 .listcheck li:last-child {
  border-bottom: 0;
}
.idx08 .listcheck li::before {
  content: "";
  position: absolute;
  top: 9px;
  left: 0px;
  width: 15px;
  height: 12px;
  background: url(../images/ic_checklist.svg) no-repeat center/contain;
}
.idx08 .block_concerns {
  position: relative;
  z-index: 0;
}
.idx08 .block_concerns .concerns_cont {
  padding: 60px 60px 89px 100px;
}
.idx08 .block_concerns .concerns_cont::before {
  content: "";
  position: absolute;
  top: -58px;
  left: -210px;
  max-width: 1163px;
  width: 83%;
  height: calc(100% + 60px);
  background-color: #ffffff;
  z-index: -1;
}
.idx08 .h_tl {
  border-bottom: 1px solid #B9A87B;
  padding-bottom: 23px;
  margin-bottom: 34px;
}
.idx08 .h_tl h4 {
  font-size: 29px;
  font-weight: 500;
  letter-spacing: 0.075em;
  line-height: 1.5;
}
.idx08 .h_tl .en {
  font-size: 17px;
  font-weight: 500;
  letter-spacing: 0.05em;
  color: #B9A87B;
  line-height: 1;
  margin-bottom: 9px;
}
.idx08 .idx_tab {
  margin-top: 185px;
  margin-bottom: 101px;
}
.idx08 .block_tattoo {
  max-width: 590px;
  width: 100%;
}
.idx08 .tab_img {
  position: relative;
  width: calc(50% + 200px);
  max-width: 930px;
  height: 608px;
  margin-right: -200px;
}
.idx08 .tab_img .tb_img {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  opacity: 0;
  visibility: hidden;
}
.idx08 .tab_img .tb_img img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}
.idx08 .tab_img .tb_img.active {
  z-index: 1;
  opacity: 1;
  visibility: visible;
}
.idx08 .tab_content {
  position: relative;
  z-index: 1;
  width: 990px;
  margin-right: -210px;
  margin-left: -100px;
  margin-top: 70px;
}
.idx08 .block_flow .flow_item {
  min-height: 52em;
  position: relative;
  font-size: 10px;
}
.idx08 .block_flow .flow_item a {
  z-index: 2;
  border-radius: 195px 195px 0 0;
}
.idx08 .block_flow .flow_item a::before {
  content: "";
  position: absolute;
  top: 2em;
  right: 0;
  width: 7em;
  height: 7em;
  background: #B9A87B url(../images/ic_arr02.svg) no-repeat center/5px auto;
  border-radius: 50%;
}
.idx08 .block_flow .box_in {
  width: 100%;
  height: 100%;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}
.idx08 .block_flow .flow_img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 195px 195px 0 0;
  overflow: hidden;
  -webkit-filter: drop-shadow(20px 20px 0px rgba(199, 187, 169, 0.16));
          filter: drop-shadow(20px 20px 0px rgba(199, 187, 169, 0.16));
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}
.idx08 .block_flow .flow_img::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(75, 60, 35, 0.7);
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}
.idx08 .block_flow .flow_img img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}
.idx08 .block_flow .flow_tl {
  text-align: center;
}
.idx08 .block_flow .flow_tl .point {
  color: #B9A87B;
  line-height: 1;
  font-size: 5em;
  font-weight: 400;
  letter-spacing: 0.05em;
  margin-bottom: 0.22em;
}
.idx08 .block_flow .flow_tl h4 {
  font-size: 2.5em;
  font-weight: 500;
  letter-spacing: 0.075em;
  line-height: 1.48;
  color: #ffffff;
}
.idx08 .block_flow .flow_cont {
  position: relative;
  z-index: 1;
  color: #ffffff;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  padding: 5.7em 4em 2em;
  border-radius: 195px 195px 0 0;
}
.idx08 .block_flow .flow_cont .cont {
  min-height: 14em;
}
.idx08 .block_flow .flow_cont .cont p {
  font-size: 1.7em;
  line-height: 1.8235;
}
.idx08 .idx_banner {
  margin-top: 70px;
  padding-left: 2.2em;
  font-size: 10px;
}
.idx08 .idx_banner .bnr_it {
  max-width: 610px;
  width: calc((100% - 57px) / 2);
  height: 20em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-right: 5.7em;
  position: relative;
}
.idx08 .idx_banner .bnr_it::before {
  content: "";
  position: absolute;
  inset: 1em;
  border: 1px solid;
}
.idx08 .idx_banner .bnr_it:nth-child(2n+2) {
  margin-right: 0;
}
.idx08 .idx_banner .bnr_it a::before {
  content: "";
  position: absolute;
  top: -2.1em;
  left: -2.3em;
  width: 9em;
  height: 9em;
  border-radius: 50%;
  background-repeat: no-repeat;
  background-position: center;
}
.idx08 .idx_banner .box_cont {
  text-align: center;
}
.idx08 .idx_banner .bnr_line {
  background-color: #675330;
  padding: 2em 2em 2.4em;
}
.idx08 .idx_banner .bnr_line::before {
  border-color: #E2CB8E;
  inset: 1.1em;
}
.idx08 .idx_banner .bnr_line a::before {
  background-image: url(../images/bnr_ic_line.svg);
  background-size: contain;
}
.idx08 .idx_banner .bnr_line .tt01 {
  color: #E2CB8E;
  border: 1px solid #E2CB8E;
  font-size: 1.7em;
  line-height: 1.5;
  font-weight: 500;
  letter-spacing: 0.05em;
  padding: 0.5882352941em 0.8823529412em 0.5882352941em 0.9411764706em;
  display: table;
  margin: 0 auto 0.7058823529em;
}
.idx08 .idx_banner .bnr_line .tt02 {
  font-size: 2.3em;
  font-weight: 500;
  letter-spacing: 0.05em;
  color: #ffffff;
  line-height: 1.5;
  text-align: center;
}
.idx08 .idx_banner .bnr_line .tt02 .f_roto {
  font-size: 1.6086956522em;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1;
  color: #E2CB8E;
  position: relative;
  top: 0.0540540541em;
  margin: 0 0.0810810811em;
}
.idx08 .idx_banner .bnr_payment {
  background-color: #F9F6F3;
  border: 1px solid #675330;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}
.idx08 .idx_banner .bnr_payment::before {
  border-color: #C7BBA9;
}
.idx08 .idx_banner .bnr_payment a::before {
  background-color: #B9A87B;
  background-image: url(../images/bnr_ic_payment.svg);
  background-size: contain;
}
.idx08 .idx_banner .bnr_payment .tt01 {
  color: #B9A87B;
  font-size: 2.1em;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.5;
  margin-bottom: 0;
}
.idx08 .idx_banner .bnr_payment .tt02 {
  font-size: 3.1em;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.5;
  color: var(--clr1);
}

.idx_instagram {
  padding: 99px 0 160px;
}
.idx_instagram .instagram_tl {
  margin-bottom: 26px;
}
.idx_instagram .insta_btn {
  max-width: 265px;
  width: 50%;
}
.idx_instagram .insta_btn a {
  padding: 0.9444444444em 1.333333333em;
  font-family: var(--f-en);
  color: #423D3C;
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 0.075em;
  text-decoration: none;
  border-radius: 10px;
  border: 1px solid #D1D1D1;
  position: relative;
  display: block;
  width: 100%;
  margin-top: -1px;
}
.idx_instagram .insta_btn a::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 14px;
  width: 33px;
  height: 33px;
  background: #00A0E8 url(../images/insta_ic_arr.svg) no-repeat center/9px auto;
  border-radius: 50%;
  margin: auto;
}
.idx_instagram .insta_tt {
  font-size: 30px;
  font-weight: 500;
  letter-spacing: 0.075em;
  color: #423D3C;
  position: relative;
  padding-left: 3.3em;
}
.idx_instagram .insta_tt::before {
  content: "";
  position: absolute;
  top: -0.3em;
  left: 0;
  width: 2.6333333333em;
  height: 2.6333333333em;
  background: url(../images/ic_insta.png) no-repeat center/contain;
}
.idx_instagram .instagram_list .item {
  width: calc((100% - 60px) / 4);
  margin-right: 20px;
}
.idx_instagram .instagram_list .item:last-child {
  margin-right: 0;
}

@media only screen and (min-width: 769px) {
  .h3_st02.tl_left {
    text-align: left;
  }
  .h3_st02.tl_left h3 {
    display: table;
    text-align: left;
  }
  .h3_st02.tl_left .h_en {
    margin-left: 0;
    margin-right: 0;
    padding-right: 0;
  }
  .h3_st02.tl_left .h_en::after {
    display: none;
  }
  .btn02 a:hover::before {
    background-color: #958450;
    left: 6px;
  }
  .idx01 .col_tl {
    width: 28%;
  }
  .idx01 .col_cont {
    width: 69%;
    margin-top: -8px;
  }
  .idx01 .tab_btn .tab:hover {
    background-color: var(--main-color);
    color: #ffffff;
  }
  .idx01 .btn_news a:hover {
    color: #b7a879;
  }
  .idx01 .btn_news a:hover::before {
    background-color: #b7a879;
  }
  .idx02 .block_clinic .col {
    width: 50%;
    max-width: 530px;
  }
  .idx02 .block_clinic .col:nth-of-type(1) {
    width: calc(50% - 40px);
    max-width: 510px;
  }
  .idx03 .h3_tl {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
    z-index: 1;
  }
  .idx03 .h3_tl .h_en {
    right: unset;
    left: -28px;
    top: -0.4959349593em;
  }
  .idx03 .greeting_cont {
    width: 60%;
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
  .idx03 .greeting_img {
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
    width: 40%;
    position: relative;
  }
  .idx03 .greeting_img .img_doctor {
    position: absolute;
    bottom: 69px;
    right: -310px;
    width: 1117px;
  }
  .idx04 .feature_slider:not(.slick-slider) {
    height: 29.8235294118em;
  }
  .idx04 .feature_slider .feature_img, .idx04 .feature_slider .feature_cont {
    width: 50%;
  }
  .idx04 .feature_slider .feature_cont {
    margin-top: 45px;
  }
  .idx04 .feature_thumb:not(.slick-slider) {
    height: 12.1176470588em;
  }
  .idx04 .feature_thumb .thumb_it:hover img {
    opacity: 1;
  }
  .idx04 .feature_thumb .thumb_it:hover .point {
    opacity: 1;
  }
  .idx04 .slick-dots li:hover button {
    background-color: var(--clr2);
  }
  .idx05 .block_medical .medical_item {
    max-width: 310px;
    width: calc(25% - 20px);
    margin: 10px;
    -webkit-transition: 0.3s all;
    transition: 0.3s all;
  }
  .idx05 .block_medical .medical_item:hover {
    background-color: #ede5dd;
  }
  .idx05 .block_menu .menu_title {
    width: 275px;
  }
  .idx05 .block_menu .btn-group {
    width: calc(100% - 293px);
  }
  .idx05 .TabContainer .TabContent .content:not(.ac) {
    height: 36.4117647059em;
  }
  .idx06 .block_pickup .pickup_item {
    width: calc(50% - 20px);
    max-width: 630px;
  }
  .idx07 .block_artmake {
    display: -ms-grid;
    display: grid;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -ms-grid-columns: 48% 48%;
    grid-template-columns: 48% 48%;
  }
  .idx07 .block_artmake .artmake_img {
    -ms-grid-row: 1;
    -ms-grid-row-span: 3;
    grid-row: 1/span 3;
  }
  .idx07 .block_artmake .h3_st02, .idx07 .block_artmake .artmake_cont {
    max-width: 550px;
    margin-right: -3px;
    width: 100%;
    margin-left: auto;
  }
  .idx08 .block_concerns .concerns_img {
    width: 50%;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 1;
  }
  .idx08 .block_concerns .concerns_cont {
    width: 50%;
  }
  .idx08 .TabContainer .TabContent .content:not(.ac) {
    height: 31em;
  }
  .idx08 .block_flow .flow_item {
    width: calc((100% - 150px) / 4);
    margin-right: 50px;
  }
  .idx08 .block_flow .flow_item:nth-child(4n+4) {
    margin-right: 0;
  }
  .idx08 .block_flow .flow_item a:hover {
    opacity: 1;
  }
  .idx08 .block_flow .flow_item:hover .box_in {
    -webkit-transform: translateY(-10px);
            transform: translateY(-10px);
  }
  .idx08 .block_flow .flow_item:hover .flow_img {
    -webkit-filter: drop-shadow(15px 15px 0px rgba(199, 187, 169, 0.16));
            filter: drop-shadow(15px 15px 0px rgba(199, 187, 169, 0.16));
  }
  .idx08 .block_flow .flow_item:hover .flow_img:before {
    background-color: rgba(75, 60, 35, 0.9);
  }
  .idx08 .idx_banner .bnr_payment:hover {
    background-color: #f5eee6;
  }
}
@media only screen and (min-width: 769px) and (max-width: 1600px) {
  .h3_tl.tl_left .h_en {
    right: 1vw;
  }
  .idx01 .col_tl {
    width: 30%;
    padding-left: 40px;
  }
  .idx03 .box_name {
    right: 0;
    font-size: min(17px, 1vw);
  }
  .idx03 .greeting_img .img_doctor {
    right: -265px;
  }
  .idx05 {
    background-size: 38%;
  }
  .idx05 .b_tab::before {
    right: -2.1em;
    font-size: 8px;
  }
  .idx08 .block_concerns .concerns_img {
    width: 46%;
    right: 3%;
  }
  .idx08 .block_flow .flow_cont {
    padding: 5.7em 3.2em 2em;
  }
}
@media only screen and (min-width: 1401px) and (max-width: 1500px) {
  .idx04 .slick-dots {
    margin-top: -57px;
  }
}
@media only screen and (min-width: 769px) and (max-width: 1400px) {
  .h3_tl .h_en {
    font-size: min(123px, 10vw);
  }
  .h3_tl.tl_left .h_en {
    right: unset;
    left: -60px;
  }
  .idx01 .inner_big {
    padding: 0 65px;
  }
  .idx01 .col_tl {
    width: 28%;
    padding-left: 0;
  }
  .idx03 .h3_tl {
    padding-left: 35px;
  }
  .idx03 .h3_tl .h_en {
    left: -20px;
  }
  .idx03 .greeting_cont {
    padding: 65px 70px 65px 35px;
  }
  .idx03 .greeting_img .img_doctor {
    right: -190px;
    width: 1000px;
  }
  .idx03 .box_name {
    right: 40px;
  }
  .idx04 .feature_slider h4 {
    font-size: 26px;
    margin-bottom: 15px;
  }
  .idx04 .feature_slider .feature_num {
    font-size: 20px;
  }
  .idx04 .feature_slider .feature_cont {
    padding: 70px 50px 50px 45px;
  }
  .idx04 .feature_slider .btn {
    margin-top: 35px;
  }
  .idx04 .feature_slider .pc_br {
    display: none;
  }
  .idx04 .feature_thumb {
    font-size: min(10px, 1vw);
  }
  .idx05 .b_tab::before {
    font-size: min(8px, 1vw);
  }
  .idx07 .block_artmake {
    padding: 0 40px;
  }
  .idx07 .block_artmake .artmake_img {
    font-size: min(10px, 0.7vw);
  }
  .idx08 .block_concerns .concerns_cont {
    padding: 50px 60px 44px 60px;
  }
  .idx08 .tab_img {
    width: calc(46% + 160px);
  }
  .idx08 .tab_content {
    margin-right: -270px;
  }
  .idx08 .block_flow .flow_item {
    width: calc((100% - 120px) / 4);
    margin-right: 30px;
  }
  .idx08 .block_flow .flow_cont {
    padding: 5.7em 2.5em 2em;
  }
  .idx_instagram {
    padding: 80px 35px;
  }
}
@media only screen and (min-width: 769px) and (max-width: 1300px) {
  .h3_tl h3 {
    font-size: 30px;
  }
  .h3_tl h3::after {
    margin-top: 10px;
  }
  .h3_tl.tl_white h3:after {
    margin-top: 10px;
  }
  .h3_st02 h3 {
    font-size: 28px;
  }
  .h3_st02 h3 .txt_sm {
    font-size: 22px;
  }
  .h3_st02 .h_en {
    font-size: 16px;
    padding: 0 40px;
  }
  .h3_st02 .h_en::before, .h3_st02 .h_en::after {
    width: 33px;
  }
  .idx01 {
    padding: 100px 0 80px;
  }
  .idx01 .h3_tl h3 {
    font-size: 27px;
  }
  .idx02 .h3_tl {
    margin-bottom: 45px;
  }
  .idx02 .block_clinic {
    padding: 65px 37px;
  }
  .idx02 .block_clinic .col:first-of-type {
    width: calc(50% - 25px);
  }
  .idx02 .b_traffic .traffic_item {
    padding: 18px 15px 18px;
  }
  .idx02 .b_traffic .traffic_ic {
    width: 50px;
    height: 50px;
  }
  .idx02 .b_traffic .traffic_tl {
    width: calc(100% - 50px);
    padding-left: 15px;
    font-size: 13px;
  }
  .idx02 .idx_logo {
    margin-bottom: 23px;
  }
  .idx02 .b_info {
    margin-bottom: 26px;
  }
  .idx02 .btn-group {
    margin-top: 10px;
  }
  .idx04 {
    padding: 100px 0 80px;
  }
  .idx04 .h3_tl {
    margin-bottom: 40px;
  }
  .idx04 .feature_slider .feature_img {
    width: 46%;
  }
  .idx04 .feature_slider .feature_cont {
    width: 54%;
  }
  .idx04 .slick-dots {
    margin-top: 0;
    position: absolute;
    top: 28vw;
    left: 0;
  }
  .idx05 {
    padding: 110px 0 0;
  }
  .idx05 .h3_tl {
    margin-bottom: 40px;
  }
  .idx06 {
    padding-top: 110px;
    padding-bottom: 90px;
  }
  .idx06 .h3_tl {
    margin-bottom: 40px;
  }
  .idx06 .block_pickup .pickup_cont {
    padding: 0 23px;
  }
  .idx07 {
    padding: 80px 0 110px;
  }
  .idx07 .h3_st02 {
    margin-bottom: 30px;
  }
  .idx07 .btn02 {
    margin-top: 30px;
  }
  .idx07 .block_artmake {
    -ms-grid-columns: 47% 50%;
    grid-template-columns: 47% 50%;
  }
  .idx07 .block_artmake .artmake_img {
    margin-top: 0;
  }
  .idx08 .h3_st02 {
    margin-bottom: 35px;
  }
  .idx08 .h3_st02 h3 {
    font-size: 34px;
  }
  .idx08 .h3_st02 .h_en {
    padding-left: 45px;
  }
  .idx08 .h_tl {
    padding-bottom: 14px;
    margin-bottom: 17px;
  }
  .idx08 .h_tl .en {
    font-size: 15px;
  }
  .idx08 .h_tl h4 {
    font-size: 24px;
  }
  .idx08 .block_flow .flow_item {
    font-size: min(10px, 0.7vw);
  }
  .idx_instagram .insta_tt {
    font-size: 26px;
  }
  .idx_instagram .insta_btn a {
    font-size: 16px;
  }
  .idx_instagram .insta_btn a::after {
    width: 28px;
    height: 28px;
  }
}
@media only screen and (max-width: 1200px) and (min-width: 769px) {
  .idx01 .list_post a::after {
    width: 20px;
    height: 20px;
  }
  .idx01 .list_post .date {
    font-size: 12px;
    width: 90px;
  }
  .idx01 .list_post .cate {
    font-size: 12px;
    width: 100px;
  }
  .idx01 .list_post .title {
    width: calc(100% - 190px);
    padding-left: 10px;
  }
  .idx01 .tab_btn {
    margin-top: 35px;
  }
  .idx01 .tab_btn .tab {
    max-width: 200px;
  }
  .idx03 .h3_tl {
    margin-bottom: 35px;
    padding-left: 20px;
  }
  .idx03 .h3_tl .h_en {
    left: -10px;
  }
  .idx03 .greeting_img {
    margin-top: -138px;
    width: 32%;
  }
  .idx03 .greeting_img .img_doctor {
    right: -180px;
    max-width: 1000px;
    width: calc(100% + 400px);
    top: 0;
    bottom: unset;
  }
  .idx03 .greeting_cont {
    padding: 50px 40px 50px 20px;
  }
  .idx03 .box_name {
    font-size: min(17px, 1.4vw);
    top: 20px;
    right: -20px;
  }
  .idx04 .feature_slider .btn {
    max-width: 300px;
    margin-top: 35px;
  }
  .idx04 .feature_slider .feature_cont {
    padding: 50px 50px 38px 35px;
  }
  .idx05 .block_medical .medical_item {
    width: calc(25% - 10px);
    margin: 5px;
  }
  .idx05 .block_medical .medical_item::before {
    width: 20px;
    height: 20px;
  }
  .idx05 .block_medical .medical_img {
    width: 90px;
    height: 90px;
    margin-bottom: 12px;
  }
  .idx05 .block_medical .medical_tl {
    font-size: 16px;
  }
  .idx05 .block_menu {
    padding: 20px;
  }
  .idx05 .block_menu .menu_title {
    width: 145px;
  }
  .idx05 .block_menu .menu_title .title {
    font-size: 18px;
  }
  .idx05 .block_menu .btn-group {
    width: calc(100% - 145px);
  }
  .idx06 .block_pickup .pickup_item {
    width: calc(50% - 10px);
  }
  .idx08 .block_concerns .concerns_cont {
    width: 55%;
    padding-left: 0;
    padding-right: 40px;
  }
  .idx08 .block_concerns .concerns_img {
    width: 45%;
  }
  .idx08 .idx_tab {
    margin-top: 90px;
    margin-bottom: 51px;
  }
  .idx08 .tab_img {
    width: 90%;
    max-width: 700px;
    max-height: 484px;
    height: 50vw;
  }
  .idx08 .tab_content {
    width: 100%;
    max-width: 760px;
    margin-right: -21px;
    margin-left: auto;
    margin-top: -50px;
  }
  .idx08 .idx_banner {
    font-size: min(8px, 0.9vw);
  }
}
@media only screen and (max-width: 992px) and (min-width: 769px) {
  .idx02 .b_traffic .traffic_item {
    display: block;
    margin: 5px;
    padding: 15px 15px 15px;
  }
  .idx02 .b_traffic .traffic_ic {
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 15px;
  }
  .idx02 .b_traffic .traffic_tl {
    width: 100%;
    padding-left: 0;
    text-align: center;
  }
  .idx04 .feature_slider .p_cont {
    min-height: 160px;
  }
  .idx05 .block_menu .btn-group .btn {
    width: calc(50% - 10px);
  }
  .idx07 .block_artmake {
    padding-left: 0;
  }
  .idx08 .block_concerns .concerns_cont {
    padding: 0 40px 45px 0;
  }
  .idx08 .block_concerns .concerns_cont::before {
    width: 94%;
  }
  .idx08 .block_flow .flow_item {
    width: calc((100% - 30px) / 2);
    max-width: 360px;
    min-height: 58em;
    margin-top: 30px;
    font-size: 8px;
  }
  .idx08 .block_flow .flow_item:nth-child(2n+2) {
    margin-right: 0;
  }
}