@charset "UTF-8";
/* Scss Document */
.flex_30 {
  width: 30%;
}

.flex_31 {
  width: 31%;
}

.flex_32 {
  width: 32%;
}

.flex_33 {
  width: 33%;
}

.flex_34 {
  width: 34%;
}

.flex_35 {
  width: 35%;
}

.flex_36 {
  width: 36%;
}

.flex_37 {
  width: 37%;
}

.flex_38 {
  width: 38%;
}

.flex_39 {
  width: 39%;
}

.flex_40 {
  width: 40%;
}

.flex_41 {
  width: 41%;
}

.flex_42 {
  width: 42%;
}

.flex_43 {
  width: 43%;
}

.flex_44 {
  width: 44%;
}

.flex_45 {
  width: 45%;
}

.flex_46 {
  width: 46%;
}

.flex_47 {
  width: 47%;
}

.flex_48 {
  width: 48%;
}

.flex_49 {
  width: 49%;
}

.flex_50 {
  width: 50%;
}

.flex_51 {
  width: 51%;
}

.flex_52 {
  width: 52%;
}

.flex_53 {
  width: 53%;
}

.flex_54 {
  width: 54%;
}

.flex_55 {
  width: 55%;
}

.flex_56 {
  width: 56%;
}

.flex_57 {
  width: 57%;
}

.flex_58 {
  width: 58%;
}

.flex_59 {
  width: 59%;
}

.flex_60 {
  width: 60%;
}

.flex_61 {
  width: 61%;
}

.flex_62 {
  width: 62%;
}

.flex_63 {
  width: 63%;
}

.flex_64 {
  width: 64%;
}

.flex_65 {
  width: 65%;
}

.flex_66 {
  width: 66%;
}

.flex_67 {
  width: 67%;
}

.flex_68 {
  width: 68%;
}

.flex_69 {
  width: 69%;
}

.flex_70 {
  width: 70%;
}

.padding100 {
  padding-top: 100px;
  padding-bottom: 100px;
}

.padding110 {
  padding-top: 110px;
  padding-bottom: 110px;
}

.padding120 {
  padding-top: 120px;
  padding-bottom: 120px;
}

.padding130 {
  padding-top: 130px;
  padding-bottom: 130px;
}

.padding140 {
  padding-top: 140px;
  padding-bottom: 140px;
}

.padding150 {
  padding-top: 150px;
  padding-bottom: 150px;
}

.padding160 {
  padding-top: 160px;
  padding-bottom: 160px;
}

.padding170 {
  padding-top: 170px;
  padding-bottom: 170px;
}

.padding180 {
  padding-top: 180px;
  padding-bottom: 180px;
}

.padding190 {
  padding-top: 190px;
  padding-bottom: 190px;
}

.padding200 {
  padding-top: 200px;
  padding-bottom: 200px;
}

.padding210 {
  padding-top: 210px;
  padding-bottom: 210px;
}

.padding220 {
  padding-top: 220px;
  padding-bottom: 220px;
}

.padding230 {
  padding-top: 230px;
  padding-bottom: 230px;
}

.padding240 {
  padding-top: 240px;
  padding-bottom: 240px;
}

.padding250 {
  padding-top: 250px;
  padding-bottom: 250px;
}

.padding260 {
  padding-top: 260px;
  padding-bottom: 260px;
}

.padding270 {
  padding-top: 270px;
  padding-bottom: 270px;
}

.padding280 {
  padding-top: 280px;
  padding-bottom: 280px;
}

.padding290 {
  padding-top: 290px;
  padding-bottom: 290px;
}

.padding300 {
  padding-top: 300px;
  padding-bottom: 300px;
}

.margin100 {
  margin-top: 100px;
  margin-bottom: 100px;
}

.margin110 {
  margin-top: 110px;
  margin-bottom: 110px;
}

.margin120 {
  margin-top: 120px;
  margin-bottom: 120px;
}

.margin130 {
  margin-top: 130px;
  margin-bottom: 130px;
}

.margin140 {
  margin-top: 140px;
  margin-bottom: 140px;
}

.margin150 {
  margin-top: 150px;
  margin-bottom: 150px;
}

.margin160 {
  margin-top: 160px;
  margin-bottom: 160px;
}

.margin170 {
  margin-top: 170px;
  margin-bottom: 170px;
}

.margin180 {
  margin-top: 180px;
  margin-bottom: 180px;
}

.margin190 {
  margin-top: 190px;
  margin-bottom: 190px;
}

.margin200 {
  margin-top: 200px;
  margin-bottom: 200px;
}

.margin210 {
  margin-top: 210px;
  margin-bottom: 210px;
}

.margin220 {
  margin-top: 220px;
  margin-bottom: 220px;
}

.margin230 {
  margin-top: 230px;
  margin-bottom: 230px;
}

.margin240 {
  margin-top: 240px;
  margin-bottom: 240px;
}

.margin250 {
  margin-top: 250px;
  margin-bottom: 250px;
}

.margin260 {
  margin-top: 260px;
  margin-bottom: 260px;
}

.margin270 {
  margin-top: 270px;
  margin-bottom: 270px;
}

.margin280 {
  margin-top: 280px;
  margin-bottom: 280px;
}

.margin290 {
  margin-top: 290px;
  margin-bottom: 290px;
}

.margin300 {
  margin-top: 300px;
  margin-bottom: 300px;
}

.pt-110 {
  padding-top: 110px;
}

.pt-120 {
  padding-top: 120px;
}

.pt-130 {
  padding-top: 130px;
}

.pt-140 {
  padding-top: 140px;
}

.pt-150 {
  padding-top: 150px;
}

.pt-160 {
  padding-top: 160px;
}

.pt-170 {
  padding-top: 170px;
}

.pt-180 {
  padding-top: 180px;
}

.pt-190 {
  padding-top: 190px;
}

.pt-200 {
  padding-top: 200px;
}

.pt-210 {
  padding-top: 210px;
}

.pt-220 {
  padding-top: 220px;
}

.pt-230 {
  padding-top: 230px;
}

.pt-240 {
  padding-top: 240px;
}

.pt-250 {
  padding-top: 250px;
}

.pt-260 {
  padding-top: 260px;
}

.pt-270 {
  padding-top: 270px;
}

.pt-280 {
  padding-top: 280px;
}

.pt-290 {
  padding-top: 290px;
}

.pt-300 {
  padding-top: 300px;
}

.pb-110 {
  padding-bottom: 110px;
}

.pb-120 {
  padding-bottom: 120px;
}

.pb-130 {
  padding-bottom: 130px;
}

.pb-140 {
  padding-bottom: 140px;
}

.pb-150 {
  padding-bottom: 150px;
}

.pb-160 {
  padding-bottom: 160px;
}

.pb-170 {
  padding-bottom: 170px;
}

.pb-180 {
  padding-bottom: 180px;
}

.pb-190 {
  padding-bottom: 190px;
}

.pb-200 {
  padding-bottom: 200px;
}

.pb-210 {
  padding-bottom: 210px;
}

.pb-220 {
  padding-bottom: 220px;
}

.pb-230 {
  padding-bottom: 230px;
}

.pb-240 {
  padding-bottom: 240px;
}

.pb-250 {
  padding-bottom: 250px;
}

.pb-260 {
  padding-bottom: 260px;
}

.pb-270 {
  padding-bottom: 270px;
}

.pb-280 {
  padding-bottom: 280px;
}

.pb-290 {
  padding-bottom: 290px;
}

.pb-300 {
  padding-bottom: 300px;
}

.mt-110 {
  margin-top: 110px;
}

.mt-120 {
  margin-top: 120px;
}

.mt-130 {
  margin-top: 130px;
}

.mt-140 {
  margin-top: 140px;
}

.mt-150 {
  margin-top: 150px;
}

.mt-160 {
  margin-top: 160px;
}

.mt-170 {
  margin-top: 170px;
}

.mt-180 {
  margin-top: 180px;
}

.mt-190 {
  margin-top: 190px;
}

.mt-200 {
  margin-top: 200px;
}

.mt-210 {
  margin-top: 210px;
}

.mt-220 {
  margin-top: 220px;
}

.mt-230 {
  margin-top: 230px;
}

.mt-240 {
  margin-top: 240px;
}

.mt-250 {
  margin-top: 250px;
}

.mt-260 {
  margin-top: 260px;
}

.mt-270 {
  margin-top: 270px;
}

.mt-280 {
  margin-top: 280px;
}

.mt-290 {
  margin-top: 290px;
}

.mt-300 {
  margin-top: 300px;
}

.mb-110 {
  margin-bottom: 110px;
}

.mb-120 {
  margin-bottom: 120px;
}

.mb-130 {
  margin-bottom: 130px;
}

.mb-140 {
  margin-bottom: 140px;
}

.mb-150 {
  margin-bottom: 150px;
}

.mb-160 {
  margin-bottom: 160px;
}

.mb-170 {
  margin-bottom: 170px;
}

.mb-180 {
  margin-bottom: 180px;
}

.mb-190 {
  margin-bottom: 190px;
}

.mb-200 {
  margin-bottom: 200px;
}

.mb-210 {
  margin-bottom: 210px;
}

.mb-220 {
  margin-bottom: 220px;
}

.mb-230 {
  margin-bottom: 230px;
}

.mb-240 {
  margin-bottom: 240px;
}

.mb-250 {
  margin-bottom: 250px;
}

.mb-260 {
  margin-bottom: 260px;
}

.mb-270 {
  margin-bottom: 270px;
}

.mb-280 {
  margin-bottom: 280px;
}

.mb-290 {
  margin-bottom: 290px;
}

.mb-300 {
  margin-bottom: 300px;
}

* {
  text-decoration: none !important;
}

html {
  scroll-behavior: smooth;
}

.fast_banner {
  position: absolute;
  bottom: 4%;
  right: 4%;
  z-index: 11;
  width: 30.9vw;
}

.sp_banner {
  display: none;
}

/*sp menu*/
.menu_link li a {
  font-size: 20px;
  display: flex;
  align-items: center;
  gap: 5px;
}

.menu_link li a .arrow {
  color: #217c48;
}

.menu_link li .sub_menu {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 10px;
  padding-top: 20px;
  padding-left: 15px;
}

.menu_link li .sub_menu a {
  font-family: "NotoSansCJKjp-Regular" !important;
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 15px;
}

.menu_link li:nth-child(n + 2) {
  padding-top: 20px;
}

.menu_link_wrap .font17 {
  line-height: 1.6em;
  letter-spacing: 0.05em;
}

#logo {
  position: absolute;
  top: 40px;
  left: 20px;
  z-index: 1;
}

#logo img {
  width: 30vw;
}

.h_banner {
  position: fixed;
  top: 20px;
  right: 7.3vw;
  z-index: 1;
  display: flex;
}

.h_banner li:nth-child(1) img {
  width: 16vw;
}

.h_banner li:nth-child(2) img {
  width: 9.3vw;
}

.h_bottom {
  position: absolute;
  bottom: 4.5%;
  right: 4%;
  z-index: 1;
  display: flex;
  gap: 25px;
}

.h_bottom img {
  max-width: 15vw;
}

#slider {
  height: 49vw !important;
  background: url(../images/fade01.webp) center/cover;
}

/*TROUBLE*/
section.trouble {
  padding: 80px 0;
}

section.trouble .container1760 {
  background: url(../images/top_trouble_bg.webp) center/cover;
  padding: 100px 0;
}

section.trouble .title01 {
  font-size: 50px;
  color: #fff;
}

section.trouble .title01 span {
  font-size: 70px;
}

.top_trouble_list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2vw;
  width: 88%;
  max-width: 1280px;
  margin: 0 auto;
}

section.trouble02 {
  padding: 40px 0 100px;
  background: url(../images/top_trouble_bg02.webp) center/cover;
}

section.trouble02 .title {
  display: inline-block;
  padding-bottom: 170px;
}

.trouble_doctor {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 28.5vw;
}
/* youtube */
.youtube_view {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 67vh;
  padding: 80px 0 20px;
  box-sizing: border-box;
}
.youtube_view iframe {
  width: 80%;      /* 動画の横幅を80%に設定 */
  max-width: 800px; /* 最大横幅を800pxに設定 */
  height: 450px;   /* 高さを固定 */
}
/*contact*/
section.contact {
  padding: 80px 0;
}

section.contact .container1760 {
  background: url(../images/contact_bg.webp) center/cover;
  padding: 20px;
}

section.contact .container1760 .waku {
  border: 1px solid #fff;
  padding: 80px 0;
}

.banner_wrap {
  width: 90%;
  max-width: 1020px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 3vw;
}

.contact_deco {
  position: absolute;
  top: 11vw;
  right: 16vw;
  width: 4.5vw;
}

/*ABOUT*/
section.about {
  background: url(../images/top_about_bg.webp) center/cover;
}

section.about .midashi45 {
  border-top: 1px solid #333333;
  border-bottom: 1px solid #333333;
  padding: 15px 0;
  display: inline-block;
  margin-top: 50px;
}

/*reason*/
section.reason {
  background: url(../images/top_reason_bg_gray.webp) left top/cover;
  padding: 130px 0 180px;
}

.reason_wrap01 {
  position: relative;
  width: 92%;
  max-width: 1760px;
  margin-left: auto;
  background: url(../images/top_reason01.webp) right/auto no-repeat;
  height: 680px;
}

.reason_wrap01 .text_box {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 90%;
  max-width: 775px;
  background-color: #fff;
  padding: 100px 4vw 80px;
  box-shadow: 0 10px 25px 0 rgba(0, 0, 0, 0.2);
}

.reason_wrap01 .text_box p {
  font-size: 18px;
  padding-top: 30px;
}

.reason_wrap01 .text_box img {
  position: absolute;
  top: -40px;
  left: 50%;
  transform: translateX(-50%);
}

.reason_wrap02 {
  position: relative;
  width: 92%;
  max-width: 1760px;
  margin-right: auto;
  background: url(../images/top_reason02.webp) left/auto no-repeat;
  height: 680px;
}

.reason_wrap02 .text_box {
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 90%;
  max-width: 775px;
  background-color: #fff;
  padding: 100px 4vw 80px;
  box-shadow: 0 10px 25px 0 rgba(0, 0, 0, 0.2);
  z-index: 1;
}

.reason_wrap02 .text_box p {
  font-size: 18px;
  padding-top: 30px;
}

.reason_wrap02 .text_box img {
  position: absolute;
  top: -40px;
  left: 50%;
  transform: translateX(-50%);
}

.reason_wrap02 .deco {
  position: absolute;
  bottom: -50px;
  left: 38%;
}

.reason_wrap04 {
  position: relative;
  width: 92%;
  max-width: 1760px;
  margin-left: auto;
  background: url(../images/top_reason04.webp) right/auto no-repeat;
  height: 680px;
}

.reason_wrap04 .text_box {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 90%;
  max-width: 775px;
  background-color: #fff;
  padding: 100px 4vw 80px;
  box-shadow: 0 10px 25px 0 rgba(0, 0, 0, 0.2);
}

.reason_wrap04 .text_box p {
  font-size: 18px;
  padding-top: 30px;
}

.reason_wrap04 .text_box img {
  position: absolute;
  top: -40px;
  left: 50%;
  transform: translateX(-50%);
}

.reason_wrap05 {
  position: relative;
  width: 92%;
  max-width: 1760px;
  margin-right: auto;
  background: url(../images/top_reason05.webp) left/auto no-repeat;
  height: 680px;
}

.reason_wrap05 .text_box {
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 90%;
  max-width: 775px;
  background-color: #fff;
  padding: 100px 4vw 80px;
  box-shadow: 0 10px 25px 0 rgba(0, 0, 0, 0.2);
  z-index: 1;
}

.reason_wrap05 .text_box p {
  font-size: 18px;
  padding-top: 30px;
}

.reason_wrap05 .text_box img {
  position: absolute;
  top: -40px;
  left: 50%;
  transform: translateX(-50%);
}

.reason_green_wrap {
  border: 1px solid #217c48;
  width: 90%;
  max-width: 1620px;
  margin: 0 auto;
}

.reason_green_box {
  position: relative;
  bottom: 10px;
  right: 10px;
  background: url(../images/top_reason_bg_green.webp) center/cover;
  padding: 5vw;
}

.reason_green_box ul {
  display: grid;
  grid-template-columns: 37% 53%;
  gap: 4.5vw;
  align-items: center;
}

.reason_green_box ul li .midashi45 {
  padding-bottom: 15px;
  border-bottom: 1px solid #fff;
  margin-bottom: 30px;
  display: inline-block;
}

.reason_green_box ul .text {
  padding-top: 15px;
  color: #fff;
}

.reason03 {
  position: absolute;
  top: -45px;
  left: 50%;
  transform: translateX(-50%);
}

.reason03_contents {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2.5vw;
}

section.reason_bottom {
  background: url(../images/top_reason_bg_gray.webp) left bottom/cover;
  padding: 100px 0 100px;
}

/*GREETING*/
.greeting_wrap {
  display: grid;
  grid-template-columns: 45% 45%;
  justify-content: space-between;
  gap: 4vw;
}

.greeting_wrap .right {
  padding-left: 55px;
  padding-bottom: 55px;
}

.docter_name {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  max-width: 21vw;
}

/**/
section.fee_and_case {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}

section.fee_and_case a {
  position: relative;
  display: flex;
  align-items: center;
  height: 380px;
}

section.fee_and_case a:hover .arrow_btn {
   background-color: #2c9559;
}
section.fee_and_case a:hover .arrow_btn i {
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
}

section.fee_and_case a ul {
  display: grid;
  gap: 25px;
  width: 70%;
  margin: 0 auto;
}

section.fee_and_case a ul li {
  line-height: normal;
}

section.fee_and_case a ul li .eng_title {
  font-size: 35px;
  line-height: normal;
}

section.fee_and_case a ul li:nth-child(2) {
  position: relative;
  height: 100%;
  display: flex;
  align-items: center;
  line-height: 1.8em;
}

/* section.fee_and_case a ul li:nth-child(2):after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 7%;
  width: 1px;
  height: 65%;
  background: #fff;
} */

section.fee_and_case .fee {
  background: url(../images/top_fee_bg.webp) left/cover;
}

section.fee_and_case .case {
  background: url(../images/top_case_bg.webp) left/cover;
}

section.fee_and_case .column {
  background: url(../images/top_column_bg.webp) left/cover;
}

section.fee_and_case .arrow_btn {
  position: absolute;
  right: 20px;
  bottom: 20px;
  width: 60px;
  height: 60px;
  padding-right: 5px;
  background-color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: .3s;
}

section.fee_and_case .arrow_btn i {
  display: block;
  border-top: 1px solid #333333;
  border-right: 1px solid #333333;
  width: 11px;
  height: 11px;
  transform: rotateZ(45deg);
  transition: .3s;
}

/*faq*/
section.faq {
  background: url(../images/top_faq_bg.webp) top right/cover;
}

.faq_list li {
  position: relative;
}

.faq_list li p {
  display: inline-block;
}

.faq_list li:nth-child(odd) {
  display: grid;
  grid-template-columns: 80px 1fr;
}

.faq_list .question,
.faq_list .question02,
.faq_list .question03,
.faq_list .question04,
.faq_list .question05,
.faq_list .question06,
.faq_list .question07,
.faq_list .question08,
.faq_list .question09,
.faq_list .question10 {
  margin-top: 40px;
  cursor: pointer;
}

.faq_list .question div,
.faq_list .question02 div,
.faq_list .question03 div,
.faq_list .question04 div,
.faq_list .question05 div,
.faq_list .question06 div,
.faq_list .question07 div,
.faq_list .question08 div,
.faq_list .question09 div,
.faq_list .question10 div {
  display: flex;
  align-items: baseline;
  column-gap: 15px;
}

.faq_list .question div:nth-child(2),
.faq_list .question02 div:nth-child(2),
.faq_list .question03 div:nth-child(2),
.faq_list .question04 div:nth-child(2),
.faq_list .question05 div:nth-child(2),
.faq_list .question06 div:nth-child(2),
.faq_list .question07 div:nth-child(2),
.faq_list .question08 div:nth-child(2),
.faq_list .question09 div:nth-child(2),
.faq_list .question10 div:nth-child(2) {
  height: 80px;
  display: flex;
  align-items: center;
  padding-left: 25px;
  background: #2c9559;
  color: #fff;
  font-size: 25px;
}

.answer {
  display: none;
  background-color: #fff;
  padding: 50px;
}

.answer div {
  display: flex;
  gap: 15px;
}

.answer div span {
  color: #bc2a2a;
  font-family: "ivypresto-display", serif;
  font-weight: 300;
  font-style: normal;
  font-size: 37px;
  display: block;
}

.plus {
  position: absolute;
  top: 50%;
  right: 2%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
}

.plus i:nth-child(1) {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: #fff;
  width: 20px;
  height: 3px;
}

.plus i:nth-child(2) {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  background: #fff;
  width: 3px;
  height: 20px;
}

.block {
  display: block;
}

.delete {
  display: none;
}

/*banner*/
.banner_sec {
  padding: 70px 0;
}

.banner_sec ul {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 4vw;
}

.banner_sec ul a {
  display: block;
}

/*footer*/
.footer {
  position: relative;
}

.footer_wrap {
  background-color: #f6f6f6;
  padding: 130px 0;
}

.footer_contents {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 6.5vw;
}

.footer_contents .left ul {
  display: flex;
}

.footer_contents .right {
  padding-right: 1vw;
}

.f_logo {
  display: block;
  margin: 0 auto;
  width: 90%;
  max-width: 780px;
}

.copy {
  background-color: #ded7cb;
  padding: 35px;
  text-align: center;
  font-size: 15px;
}

.top_scroll {
  position: absolute;
  bottom: 7%;
  right: 1.5%;
}
.parking{
  letter-spacing: 0.06em;
}

/*下層*/
.main {
  position: relative;
  height: 550px;
}

.main_title {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  width: 100%;
}

.main_title span {
  color: #aa945e;
  font-size: 42px;
  letter-spacing: 0.13em;
}

.main_title h2 {
  color: #fff;
  font-size: 55px;
}

.main_title h2 span {
  color: #fff;
  font-size: 30px;
}

/*think-about*/
.main.think-about {
  background: url(../images/main_think-about.webp) 65%/cover;
}

.think-about_list .grid_contents {
  grid-template-columns: 35% 60%;
  justify-content: space-between;
  align-items: center;
  gap: 3vw;
}

.think-about_list .grid_contents .midashi35 {
  position: relative;
  padding-bottom: 20px;
}

.think-about_list .grid_contents .midashi35:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  background: #2c9559;
  width: 45px;
  height: 2px;
}

/*about-implant*/
.main.about-implant {
  background: url(../images/main_about-implant.webp) 50%/cover;
}

.implant_wrap {
  background: url(../images/about-implant_bg01.webp) 100%/cover;
  padding: 7vw 4.3vw;
}

.implant_wrap .text_box {
  position: relative;
  width: 100%;
  max-width: 800px;
  background-color: #fff;
  padding: 65px 4vw 60px;
  margin-left: auto;
}

.implant_wrap .text_box:after {
  content: "";
  position: absolute;
  top: 4%;
  left: 2.5%;
  width: 40px;
  height: 40px;
  border-top: 2px solid #2c9559;
  border-left: 2px solid #2c9559;
}

.implant_wrap .text_box:before {
  content: "";
  position: absolute;
  bottom: 4%;
  right: 2.5%;
  transform: rotateZ(90deg);
  width: 40px;
  height: 40px;
  border-top: 2px solid #2c9559;
  border-right: 2px solid #2c9559;
}

.structure_contents {
  background-color: #fff;
  border: 5px solid #ded7cb;
  padding: 80px 4vw;
}

.structure_contents .img100 {
  text-align: center;
}

.structure_contents .img100 img {
  max-width: 899px;
}

.structure_contents .text {
  background-color: #f6f6f6;
  padding: 25px 4.5vw;
}

.structure_contents .text p {
  line-height: 1.9em;
}

section.implant_merit {
  position: relative;
  background: url(../images/about-implant_bg02.webp) center top/cover;
  padding: 130px 0 160px;
}

section.implant_merit .container1600 {
  padding: 0 2vw;
}

section.implant_merit .title_text {
  position: relative;
  margin: 0 auto;
  padding: 50px 0;
  text-align: center;
  width: 100%;
  max-width: 1060px;
  border-bottom: 2px solid #fff;
}

section.implant_merit .title_text .midashi50 {
  position: relative;
  z-index: 1;
  color: #fff;
}

section.implant_merit .title_text span {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-weight: 400;
  color: rgba(255, 255, 255, 0.13);
  font-size: 130px;
  display: block;
  letter-spacing: 0.06em;
}

.grid_contents_merit {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  padding-top: 130px;
  column-gap: 2.2vw;
  row-gap: 110px;
}

.grid_contents_merit li {
  width: 30%;
}

.grid_contents_merit li .img100 .font1 {
  position: absolute;
  top: -7%;
  left: 5%;
  font-size: 95px;
  color: #2c9559;
  font-weight: 400;
}

.grid_contents_merit li .text_box {
  position: relative;
  z-index: 1;
  background-color: #fff;
  padding: 30px 2.5vw 30px;
  margin: -2.5em auto 0;
  width: 91.5%;
  min-height: 320px;
}

.grid_contents_merit li .text_box .midashi28 {
  padding-bottom: 15px;
  margin-bottom: 20px;
  text-align: center;
}

.grid_contents_merit li .text_box .midashi28:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  background: #2c9559;
  width: 45px;
  height: 2px;
}

.grid_contents_merit li .text_box p {
  display: grid;
}

.grid_contents_demerit {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  padding-top: 130px;
  gap: 2.2vw;
}

.grid_contents_demerit li .img100 .font1 {
  position: absolute;
  top: -7%;
  left: 5%;
  font-size: 95px;
  color: #2c9559;
  font-weight: 400;
}

.grid_contents_demerit li .text_box {
  position: relative;
  z-index: 1;
  background-color: #fff;
  padding: 30px 2.5vw 30px;
  margin: -2.5em auto 0;
  width: 91.5%;
  min-height: 320px;
}

.grid_contents_demerit li .text_box .midashi28 {
  padding-bottom: 15px;
  margin-bottom: 20px;
  text-align: center;
}

.grid_contents_demerit li .text_box .midashi28:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  background: #2c9559;
  width: 45px;
  height: 2px;
}

.grid_contents_demerit li .text_box p {
  display: grid;
}

section.comparison {
  background: url(../images/about-implant_bg03.webp) center top/cover;
}

.comparison_table table {
  width: 100%;
  border: 1px solid #a0a0a0;
}

.comparison_table table tr td {
  padding: 40px 20px;
  border: 1px solid #a0a0a0;
}

.comparison_table table tr td:nth-child(1) {
  background-color: #f3eee5;
  color: #333333;
  font-size: 21px;
  width: 13%;
  text-align: center;
}

.comparison_table table tr td:nth-child(n + 2) {
  font-size: 18px;
  width: 29%;
  vertical-align: baseline;
}

.comparison_table table thead tr td {
  padding: 40px 20px;
}

.comparison_table table thead tr td .midashi28 {
  background-color: #2c9559;
  color: #fff;
  padding: 5px;
  text-align: center;
}

.comparison_table table thead tr td img {
  width: 100%;
  height: auto;
  display: block;
  margin-top: 20px;
}

.comparison_table table tbody tr:nth-child(1) td {
  text-align: center;
}

.comparison_table table tbody tr:nth-child(1) td:nth-child(1) {
  padding: 40px 10px;
}

.comparison_contents {
  display: grid;
  gap: 50px;
}

.comparison_contents ul {
  display: grid;
  grid-template-columns: 64% 32%;
  align-items: center;
  justify-content: space-between;
  gap: 3vw;
  background-color: #fff;
  padding: 50px 3.5vw;
  border-left: 8px solid #ded7cb;
}

.comparison_contents ul li .midashi42 {
  border-bottom: 1px solid #333333;
  padding-bottom: 15px;
}

.comparison_contents ul li span.c-fff {
  display: block;
  padding: 5px 15px;
  margin-bottom: 10px;
  font-size: 18px;
  width: fit-content;
  line-height: normal;
}

.implant_link {
  border-bottom: 1px solid #da3734;
  color: #bc2a2a;
}

.implant_link:hover {
  color: #bc2a2a;
}

/*flow*/
.main.flow {
  background: url(../images/main_flow.webp) 50%/cover;
}

.flow_contents {
  background-color: #fff;
  border-radius: 1px;
  padding: 70px 4vw 70px;
}

.flow_contents .grid01 {
  display: grid;
  grid-template-columns: 62% 33%;
  gap: 3vw;
  justify-content: space-between;
}

.flow_contents .grid01 li .midashi30 {
  display: flex;
  align-items: center;
  gap: 1.5vw;
  border-bottom: 1px solid #333333;
  padding-bottom: 20px;
}

.flow_contents .grid01 li .midashi30 span {
  background-color: #aa945e;
  width: 100%;
  max-width: 50px;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 29px;
  letter-spacing: 0.1em;
  line-height: normal;
}

.flow_contact {
  margin-top: 60px;
  background: url(../images/flow_contact_bg.webp) center/cover;
  padding: 40px 4.5vw 60px;
}

.flow_contact .grid02 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5vw;
}

/*case*/
.main.case {
  background: url(../images/main_case.webp) 40%/cover;
}

.case_midashi {
  border-bottom: 2px solid #aa945e;
  padding-bottom: 25px;
}

.case_contents ul {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  align-items: flex-start;
  column-gap: 80px;
}

.case_contents ul li {
  border-radius: 1px;
  padding: 50px 3vw;
}

.case_contents ul li span {
  color: #fff;
  background-color: #434343;
  font-size: 26px;
  width: 88%;
  max-width: 350px;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 50px;
}

.case_contents ul li:nth-child(1) {
  background-color: #f6f6f6;
  position: relative;
}

.case_contents ul li:nth-child(1):after {
  content: "";
  background: url("../images/case_arrow.webp") 50% 50%/34px 94px no-repeat;
  width: 80px;
  height: 94px;
  position: absolute;
  right: -80px;
  top: 50%;
  transform: translateY(-50%);
}

.case_contents ul li:nth-child(2) {
  background-color: #e8f6ef;
}

.case_list {
  width: 100%;
  border: none;
}

.case_list tr td {
  padding: 30px 25px;
  font-family: "NotoSansCJKjp-Medium";
}

.case_list tr td:nth-child(1) {
  color: #fff;
  border: 1px solid #fff;
  background-color: #aa945e;
  width: 25%;
  font-size: 20px;
}

.case_list tr td:nth-child(2) {
  border: 1px solid #e5e5e5;
}

/*
.case_grid_img {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 5px;
    margin-bottom: 50px;
    img {
        width: 100%;
        height: auto;
    }
}
*/
.case_grid_img {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-bottom: 50px;
  grid-row-gap: 3px;
}

.case_grid_img > div {
  width: calc(33.33% - 3px);
}

.case_grid_img > div:first-child, .case_grid_img > div:last-child {
  width: 100%;
  text-align: center;
}

.case_grid_img > div:first-child img, .case_grid_img > div:last-child img {
  width: calc(33.33% - 3px);
  height: auto;
}

.case_grid_img img {
  width: 100%;
  height: auto;
}

/*fee*/
.main.fee {
  background: url(../images/main_case.webp) 40%/cover;
}

.fee_list {
  width: 100%;
}

.fee_list thead tr td {
  color: #fff;
  font-size: 24px;
  background-color: #7e6b5a;
  padding: 10px;
  text-align: center;
}

.fee_list thead tr td:nth-child(n + 2) {
  border-left: 1px solid #fff;
}

.fee_list tbody tr td {
  padding: 25px 15px;
  text-align: center;
  font-family: "NotoSansCJKjp-Medium";
  line-height: 1.8em;
}

.fee_list tbody tr td:nth-child(1) {
  font-size: 20px;
  color: #fff;
  border-bottom: 1px solid #fff;
  background-color: #aa945e;
  width: 23%;
}

.fee_list tbody tr td:nth-child(2) {
  font-size: 28px;
  background-color: #fcfafa;
  border: 1px solid #e5e5e5;
  width: 27%;
}

.fee_list tbody tr td:nth-child(2) span {
  font-size: 23px;
}

.fee_list tbody tr td:nth-child(2) p {
  line-height: 1.3em;
}

.fee_list tbody tr td:nth-child(3) {
  text-align: left;
  font-size: 17px;
  border: 1px solid #e5e5e5;
  padding: 25px 2.5vw;
}

.fee_list tbody tr td:nth-child(3) p {
  line-height: 1.8em;
}

.payment_box {
  background-color: #fff;
  padding: 60px 4vw;
  border-radius: 5px;
}

.payment_box ul {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3.5vw;
  width: 100%;
  max-width: 820px;
  margin: 0 auto;
}

.payment_box ul li p {
  font-size: 28px;
  text-align: center;
  line-height: 1.2em;
  padding-top: 15px;
}

.expense_box {
  background-color: #fff;
  padding: 60px 5vw;
}

.expense_box ul {
  display: flex;
  justify-content: center;
  align-items: center;
}

.expense_box ul li {
  font-family: "NotoSansCJKjp-Medium";
  border-radius: 5px;
  text-align: center;
  line-height: 1.4em;
  min-height: 140px;
  display: grid;
  align-items: center;
  justify-content: center;
}

.expense_box ul li:nth-child(odd) {
  font-size: 24px;
  border: 2px solid #aa945e;
  padding: 15px 15px;
  width: 25%;
}

.expense_box ul li:nth-child(even) {
  font-size: 35px;
  color: #a0a0a0;
  padding: 0 15px;
}

.expense_box ul li:last-child {
  background-color: #aa945e;
  color: #fff;
  font-size: 30px;
}

.fee_btn:hover {
  opacity: 0.7;
}

.fee_risk {
  border: 2px solid #959595;
  padding: 80px 4vw 75px;
  background-color: #fff;
}

.fee_risk .midashi35 {
  width: 99%;
  max-width: 1000px;
  margin: 0 auto;
  background-color: #2c9559;
  padding: 10px;
  text-align: center;
}

.fee_risk ul {
  width: 100%;
  max-width: 1005px;
  margin: 40px auto 0;
}

.fee_risk ul li {
  display: flex;
  align-items: baseline;
  gap: 10px;
  font-family: "NotoSansCJKjp-Medium";
  line-height: 1.9em;
}

.fee_risk ul li i {
  position: relative;
  bottom: 3px;
  width: 100%;
  max-width: 6px;
  height: 6px;
  border-radius: 50%;
  background-color: #2c9559;
}

.fee_risk ul li:nth-child(n + 2) {
  padding-top: 13px;
}

/*faq*/
.main.faq {
  background: url(../images/main_faq.webp) 80%/cover;
}

/*docter*/
.main.doctor {
  background: url(../images/main_doctor.webp) 50%/cover;
}

.greeting_grid {
  display: grid;
  grid-template-columns: 59% 37%;
  justify-content: space-between;
  gap: 2vw;
}

.greeting_grid .left .name_box {
  border-bottom: 1px solid #e5e5e5;
  padding-bottom: 40px;
  margin-bottom: 35px;
}

.greeting_grid .left .name_box .midashi20 {
  line-height: normal;
  padding-bottom: 5px;
}

.greeting_grid .left .name_box div {
  display: flex;
  align-items: baseline;
  gap: 1.5vw;
}

.greeting_grid .left .name_box div .midashi35 {
  font-weight: 600;
}

.greeting_grid .left .name_box div .font1 {
  position: relative;
  bottom: 5px;
  color: #2c9559;
  letter-spacing: 0.13em;
}

.greeting_list_wrap {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2.5vw;
}

.greeting_list_wrap .box {
  border: 1px solid #7e6b5a;
  padding: 40px;
}

.greeting_list_wrap .box .midashi25 {
  text-align: center;
  padding: 5px 15px;
  background-color: #7e6b5a;
  margin-bottom: 30px;
}

.greeting_list_wrap .box ul li div {
  line-height: 1.7em;
  font-family: "NotoSansCJKjp-Medium";
}

.greeting_list_wrap .box ul li div:nth-child(1) {
  display: flex;
  align-items: center;
  gap: 10px;
}

.greeting_list_wrap .box ul li div:nth-child(1) span {
  background: #2c9559;
  width: 100%;
  max-width: 6px;
  height: 6px;
  border-radius: 50%;
}

.greeting_list_wrap .box ul li:nth-child(n + 2) {
  padding-top: 10px;
}

.greeting_list_wrap .left ul li {
  display: grid;
  grid-template-columns: 135px 1fr;
  gap: 2vw;
  align-items: flex-start;
}

.doctor_sec {
  position: relative;
  background-color: #fbfbfb;
  padding: 130px 0 130px;
  background: url(../images/bg_sankaku.webp) top right/cover;
}

.doctor_grid {
  display: grid;
  grid-template-columns: 27% 68.5%;
  justify-content: space-between;
  gap: 2.5vw;
}

.doctor_grid .right {
  padding-top: 10px;
}

.doctor_grid .right .name_box {
  border-bottom: 1px solid #e5e5e5;
  padding-bottom: 25px;
  margin-bottom: 35px;
}

.doctor_grid .right .name_box div {
  display: flex;
  align-items: baseline;
  gap: 1.5vw;
}

.doctor_grid .right .name_box div .midashi35 {
  font-weight: 600;
}

.doctor_grid .right .name_box div .font1 {
  position: relative;
  bottom: 5px;
  color: #2c9559;
  letter-spacing: 0.13em;
}

.history_wrap {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1.5vw;
}

.history_wrap div {
  background-color: #fff;
  padding: 10px 20px 15px 20px;
}

.history_wrap div p {
  font-size: 22px;
  padding-bottom: 10px;
}

.history_wrap div ul li {
  display: flex;
  align-items: baseline;
  gap: 10px;
  font-size: 17px;
  line-height: 1.5em;
}

.history_wrap div ul li span {
  position: relative;
  bottom: 4px;
  background: #2c9559;
  width: 100%;
  max-width: 6px;
  height: 6px;
  border-radius: 50%;
}

.history_wrap div ul li:nth-child(n + 2) {
  padding-top: 10px;
  letter-spacing: 0.06em;
}

.doctor02 {
  display: grid;
  grid-template-columns: 20% 75%;
  justify-content: space-between;
  gap: 3vw;
  width: 100%;
  max-width: 960px;
  margin: 0 auto;
}

.doctor02 .right .midashi25 {
  display: flex;
  gap: 10px;
  align-items: baseline;
}

.doctor02 .right .midashi25 span {
  font-size: 18px;
  color: #2c9559;
}

.doctor_midashi_box {
  background-color: #2c9559;
  color: #fff;
  padding: 20px 50px;
  width: fit-content;
  margin: 50px auto 0;
  border-radius: 3px;
}

/*about*/
.main.about {
  background: url(../images/main_about.webp) 30%/cover;
}

.about_sec01 {
  background: url(../images/about_bg01.webp) right/cover;
}

.about_grid01 {
  display: grid;
  grid-template-columns: 50% 46%;
  justify-content: space-between;
  gap: 3vw;
}

.about_grid01 .left {
  padding-top: 15px;
}

.about_bg02 {
  background: url(../images/about_bg-top.webp) top right/cover;
}

.about_container {
  position: relative;
  width: 96%;
  max-width: 1840px;
  background-color: #aa945e;
  background-image: url(../images/reason_bg01.webp);
  background-size: cover;
}

.about_container:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  border: 3px solid #fff;
  width: 98.3%;
  height: 95.5%;
}

.reason_box {
  width: 94%;
  max-width: 1560px;
  margin: 0 auto;
  padding-top: 40px;
  display: grid;
  align-items: center;
  grid-template-columns: 53% 44%;
  justify-content: space-between;
  gap: 2vw;
}

.reason_box .img100 {
  height: 585px;
}

.reason_box .img100 img {
  position: relative;
  bottom: 8em;
}

.reason_box .right {
  padding-bottom: 40px;
}

.reason_box .right p {
  font-size: 17px;
}

.reason_box.box02 {
  grid-template-columns: 43% 54%;
}

.con01 {
  padding-top: 20px;
  margin-top: 160px;
}

.con01 .font1.number {
  position: absolute;
  right: 3%;
  bottom: 5%;
  font-size: 230px;
  color: rgba(255, 255, 255, 0.1);
  letter-spacing: 0.13em;
}

.con02 {
  margin-top: 200px;
}

.con02 .font1.number {
  position: absolute;
  left: 28%;
  bottom: 5%;
  font-size: 230px;
  color: rgba(255, 255, 255, 0.1);
  letter-spacing: 0.13em;
}

.con03 {
  margin-top: 260px;
}

.con03 .font1.number {
  position: absolute;
  right: 3%;
  bottom: 5%;
  font-size: 230px;
  color: rgba(255, 255, 255, 0.1);
  letter-spacing: 0.13em;
}

.con05 {
  margin-top: 190px;
}

.con05 .font1.number {
  position: absolute;
  left: 28%;
  bottom: 5%;
  font-size: 230px;
  color: rgba(255, 255, 255, 0.1);
  letter-spacing: 0.13em;
}

.reason_btn {
  position: absolute;
  left: 50%;
  bottom: -11%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 20px;
  background-color: #434343;
  width: 100%;
  max-width: 560px;
  height: 130px;
  z-index: 1;
}

.reason_btn i {
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%) rotateZ(45deg);
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  width: 14px;
  height: 14px;
}

.reason_btn:after {
  content: "";
  position: absolute;
  bottom: 10%;
  left: 0;
  background: #fff;
  width: 100%;
  height: 1px;
}

.reason_btn:hover {
  color: #fff;
  opacity: 0.7;
}

.reason_green_grid {
  width: 90%;
  max-width: 1600px;
  margin: 260px auto 0;
}

.reason_green_grid ul {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 7vw;
}

.reason_green_grid ul li {
  border: 2px solid #2c9559;
  padding: 3vw 0 3vw;
  background-color: #f6f6f6;
}

.reason_green_grid ul li .img100 {
  padding: 0 2.7vw;
}

.reason_green_grid ul li .wrap {
  margin-top: -12em;
}

.reason_green_grid ul li .text_box {
  padding: 0 4vw;
}

.reason_green_grid ul li .midashi37 {
  padding-bottom: 20px;
  font-size: 37px;
  text-align: center;
  padding-top: 20px;
}

.reason_green_grid ul .right .midashi37 {
  padding-top: 10px;
}

.reason04_sec {
  position: relative;
  background: url(../images/reason_bg02.webp) right top/cover;
  padding: 150px 0;
}

.reason04_sec ul {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  column-gap: 4vw;
  row-gap: 3.5vw;
}

.reason04_sec ul li .midashi33 {
  position: relative;
  padding: 25px 0 25px;
  margin-bottom: 25px;
  font-size: 33px;
}

.reason04_sec ul li .midashi33:after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  background: #fff;
  width: 45px;
  height: 2px;
}

.reason04_sec .font1.number {
  position: absolute;
  left: 50%;
  top: 2.5%;
  transform: translateX(-50%);
  font-size: 230px;
  color: rgba(255, 255, 255, 0.1);
  letter-spacing: 0.13em;
}

.reason04_sec:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  border: 3px solid #fff;
  width: 98.3%;
  height: 97.5%;
}

.about_bg03 {
  background: url(../images/about_bg-bottom.webp) top right/cover;
}

#anshin-5 {
  position: absolute;
  bottom: 7%;
  right: 11%;
  max-width: 217px;
}

.about_doctor_grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2vw;
}

.about_doctor_grid li a {
  position: relative;
  display: grid;
  grid-template-columns: 32% 64%;
  justify-content: space-between;
  gap: 2.5vw;
  align-items: center;
  background-color: #626262;
  padding: 1.5vw;
}

.about_doctor_grid li a .right span {
  color: #aa945e;
  display: block;
  line-height: normal;
  padding-bottom: 5px;
  padding-left: 5px;
}

.about_doctor_grid li a .right .midashi28 {
  line-height: 1.5em;
}

.about_doctor_grid li a .arrow_box {
  position: absolute;
  bottom: 11%;
  right: 3.5%;
  width: 50px;
  height: 50px;
  background-color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-right: 8px;
}

.about_doctor_grid li a .arrow_box i {
  width: 12px;
  height: 12px;
  transform: rotateZ(45deg);
  border-top: 1px solid #333333;
  border-right: 1px solid #333333;
  display: block;
  line-height: normal;
  letter-spacing: normal;
}

/*accees*/
.main.access {
  background: url(../images/main_access.webp) 50%/cover;
}

.access_sec {
  background: linear-gradient(180deg, #fff 0%, #fff 56%, #fcfafa 56%, #fcfafa 100%);
}

.access_grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 3.3vw;
}

.access_grid .left {
  padding-top: 10px;
}

.access_grid .text_box {
  border-top: 1px solid #dcdcdc;
  border-bottom: 1px solid #dcdcdc;
  padding: 25px 5px;
}

.access_grid .contact_box {
  display: grid;
  grid-template-columns: 52% 40%;
  justify-content: space-between;
  align-items: center;
  gap: 2vw;
  padding-left: 2vw;
  margin: 30px 0;
}

.access_map iframe {
  width: 100%;
  height: 500px;
}

.access_grid02 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 3vw;
}

.access_grid02 li span {
  position: absolute;
  top: 4.5%;
  left: 3.5%;
  display: block;
  padding: 0 15px;
  border-radius: 1px;
  background-color: #2c9559;
  color: #fff;
}

/*accees*/
.main.column {
  background: url(../images/main_column.webp) 50%/cover;
}

.column_contents {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  column-gap: 4.5vw;
  row-gap: 60px;
}

.column_contents li a {
  display: block;
}

.column_contents li a time {
  color: #aa945e;
  font-size: 14px;
  font-weight: 600;
  padding-top: 25px;
}

.column_contents li a img {
  transition: .3s;
}

.column_contents li a:hover img {
  opacity: 0.6;
}

.column_contents li a:hover .column_title {
  color: #2c9559;
}

.column_title {
  font-size: 19px;
  padding: 0 0 15px;
  color: #333333;
  transition: .3s;
}

.column_text {
  font-size: 15px;
  color: #333333;
}

.page {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2.3vw;
}

.page li {
  font-size: 30px;
  font-family: "ivypresto-display", serif;
  font-weight: 300;
  font-style: normal;
  line-height: normal;
  padding: 0 6px;
}

.page li a {
  font-size: 30px;
  color: #a0a0a0;
  display: block;
}

.page .active {
  color: #aa945e;
  border-bottom: 1px solid #aa945e;
}

.next a {
  position: relative;
  right: 10px;
  top: 1px;
  display: block;
  width: 15px;
  height: 15px;
  border-top: 1px solid #a0a0a0;
  border-right: 1px solid #a0a0a0;
  transform: rotateZ(45deg);
}

/*counseling*/
.main.counseling {
  background: url(../images/main_counseling.webp) 55%/cover;
}

.counseling_sec01 {
  position: relative;
  background: url(../images/counseling_bg.webp) center/cover;
}

.counseling_sec01 .midashi33 {
  font-size: 33px;
  line-height: 1.9em;
}

.counseling_sec01:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  border: 20px solid #fff;
  opacity: 0.2;
  width: 100%;
  height: 100%;
  z-index: 1;
}

.counseling_deco {
  position: absolute;
  bottom: -9.8vw;
  right: 0;
  width: 41vw;
}

.counseling_sec02 {
  background: url(../images/counseling_bg02.webp) bottom center/cover;
}

.counseling_tel_box {
  border: 1px solid #333333;
  text-align: center;
  width: 100%;
  max-width: 1000px;
  height: 320px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 4vw;
}

.counseling_tel_box img {
  max-width: 446px;
}

.contact_form {
  padding: 0 2.5vw;
}

.contact_form li {
  display: grid;
  grid-template-columns: 280px 1fr;
  align-items: center;
  gap: 2vw;
}

.contact_form li .left {
  display: grid;
  grid-template-columns: 1fr 50px;
  gap: 1.5vw;
  align-items: center;
}

.contact_form li .left .bg_2c9559.c-fff {
  font-size: 13px;
  display: block;
  height: 27px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.contact_form li .right.radio {
  display: flex;
  align-items: center;
  gap: 35px;
  font-family: "NotoSansCJKjp-Medium";
}

.contact_form li .right.radio label {
  display: flex;
  gap: 10px;
}

.contact_form li:nth-child(n + 2) {
  padding-top: 40px;
}

.contact_form li:nth-child(n + 9) {
  align-items: flex-start;
}

.contact_form li:nth-child(n + 9) .left {
  padding-top: 15px;
}

.text_input {
  background-color: #fff;
  border: 1px solid #bfbfbf;
  width: 100%;
  height: 60px;
  padding: 15px;
}

.textarea {
  width: 100%;
  height: 200px;
  background-color: #fff;
  border: 1px solid #bfbfbf;
  padding: 15px;
}

.calendar_wrap {
  display: grid;
  gap: 20px;
}

.calendar_wrap .calendar_contents {
  display: grid;
  grid-template-columns: 95px 1fr;
  align-items: center;
}

.calendar_wrap .input_grid {
  display: grid;
  grid-template-columns: 55% 44%;
  gap: 12px;
}

.calendar_wrap .calendar {
  position: relative;
}

.calendar_wrap .calendar:after {
  content: "";
  position: absolute;
  top: 50%;
  right: 4%;
  transform: translateY(-50%);
  width: 18px;
  height: 20px;
  background-image: url(../images/calendar_icon.webp);
  background-size: cover;
}

.pull {
  width: 100%;
  height: 60px;
  background-color: #fff;
  border: 1px solid #bfbfbf;
  padding: 15px;
}

.privacy_box {
  width: 100%;
  max-width: 860px;
  margin: 60px auto 40px;
  height: 260px;
  overflow-y: scroll;
  padding: 50px 4vw;
  border: 1px solid #bfbfbf;
  background-color: #fff;
}

.privacy_box .title_wrap span {
  display: block;
  line-height: normal;
  font-size: 16px;
}

.privacy_box p {
  font-size: 16px;
}

.check_box label {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

.submit {
  width: 100%;
  max-width: 350px;
  height: 80px;
  background-color: #aa945e;
  border: 1px solid #aa945e;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  color: #fff;
  font-size: 20px;
  border-radius: 4px;
  transition: .3s;
}

.submit:hover {
  background-color: #fff;
  color: #aa945e;
}

.ml-auto {
  margin-left: auto;
}

.mr-auto {
  margin-right: auto;
}

/*sedation*/
.main.sedation {
  background: url(../images/main_sedation.webp) 50%/cover;
}

.sedation_sec01 .grid {
  display: grid;
  grid-template-columns: 42% 55%;
  justify-content: space-between;
  align-items: center;
  gap: 2vw;
}

.sedation_sec02 {
  background: url(../images/sedation_bg01.webp) center top/cover;
}

.sedation_sec03 {
  background: url(../images/sedation02.webp) center top/cover;
}

.sedation_sec03 ul {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2vw;
}

.sedation_sec03 ul li {
  background-color: #fff;
}

.sedation_sec03 ul li div {
  padding: 2vw;
  margin: 10px;
  height: 95%;
}

.sedation_sec03 ul li div .midashi35 {
  color: #fff;
  text-align: center;
  padding: 5px;
  margin-bottom: 25px;
}

.sedation_sec03 ul li div p {
  display: flex;
  align-items: baseline;
  gap: 10px;
  line-height: 1.6em;
}

.sedation_sec03 ul li div p span {
  display: block;
  font-weight: 700;
}

.sedation_sec03 ul li div p:nth-child(n + 2) {
  margin-top: 15px;
}

.sedation_sec03 ul li:nth-child(1) div {
  border: 1px solid #aa945e;
}

.sedation_sec03 ul li:nth-child(2) div {
  border: 1px solid #a0a0a0;
}

.sedation_check_list {
  background-color: #fff;
  padding: 50px 40px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2vw;
}

.sedation_check_list li {
  display: flex;
  align-items: center;
  gap: 10px;
  border-bottom: 1px solid #2c9559;
  padding-bottom: 15px;
}

.sedation_check_list li p {
  font-size: 19px;
  line-height: 1.6em;
}

.sedation_border_box {
  border: 5px solid #ded7cb;
  padding: 60px 4vw;
  background-color: #fff;
}

.sedation_border_box .midashi44 {
  background: linear-gradient(transparent 70%, #facd89 70%);
  width: max-content;
  margin: 0 auto;
  font-size: 44px;
}

.sedation_doctor {
  display: grid;
  grid-template-columns: 25% 70%;
  justify-content: space-between;
  gap: 3vw;
  align-items: center;
}

.sedation_doctor .right .midashi20 {
  padding: 0 10px;
  background-color: #2c9559;
  color: #fff;
  width: max-content;
}

/*font-size*/
.midashi65 {
  font-size: 65px;
}

.midashi55 {
  font-size: 55px;
}

.midashi50 {
  font-size: 50px;
}

.midashi45 {
  font-size: 45px;
}

.midashi42 {
  font-size: 42px;
}

.midashi40 {
  font-size: 40px;
}

.midashi35 {
  font-size: 35px;
}

.midashi30 {
  font-size: 30px;
}

.midashi28 {
  font-size: 28px;
}

.midashi25 {
  font-size: 25px;
}

.midashi20 {
  font-size: 20px;
}

.font17 {
  font-size: 17px;
}

/*btn*/
.btn {
  position: relative;
  width: 100%;
  max-width: 330px;
  height: 75px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  color: #333333;
  border: 1px solid #333333;
  background-color: #fff;
}

.btn span {
  position: absolute;
  top: 50%;
  right: 25px;
  display: block;
  width: 11px;
  height: 11px;
  border-top: 1px solid #333333;
  border-right: 1px solid #333333;
  transform: translateY(-50%) rotateZ(45deg);
  transition: .3s;
}

.btn:hover {
  background-color: #333333;
  color: #fff;
}

.btn:hover span {
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
}

.btn-b {
  position: relative;
  width: 100%;
  max-width: 300px;
  height: 65px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  color: #333333;
  border: 1px solid #333333;
  background-color: #fff;
}

.btn-b span {
  position: absolute;
  top: 50%;
  right: 25px;
  display: block;
  width: 11px;
  height: 11px;
  border-top: 1px solid #333333;
  border-right: 1px solid #333333;
  transform: translateY(-50%) rotateZ(45deg);
  transition: .3s;
}

.btn:hover {
  background-color: #333333;
  color: #fff;
}

.btn:hover span {
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
}

/*title*/
.eng_title {
  color: #aa945e;
  font-size: 40px;
  font-family: "ivypresto-display", serif;
  font-weight: 300;
  font-style: normal;
  line-height: normal;
  display: inline-block;
}

/*カラー*/
.text_red {
  color: crimson;
}

.c-015a83 {
  color: #015a83;
}

.c-da3734 {
  color: #da3734;
}

.c-fff {
  color: #fff;
}

.c-aa945e {
  color: #aa945e;
}

.c-aa945e {
  color: #aa945e;
}

.bg_f6f6f6 {
  background-color: #f6f6f6;
}

.bg_faf9f9 {
  background-color: #faf9f9;
}

.bg_707070 {
  background-color: #707070;
}

.bg_2c9559 {
  background-color: #2c9559;
}

.bg_faf8f8 {
  background-color: #faf8f8;
}

.bg_015a83 {
  background-color: #015a83;
}

.bg_da3734 {
  background-color: #da3734;
}

.bg_aa945e {
  background-color: #aa945e;
}

.bg_a0a0a0 {
  background-color: #a0a0a0;
}

/************************/
/* PC用
------------------------------------------------------------*/
@media only screen and (max-width: 1750px) {
  .reason_box .right .midashi45 {
    font-size: 2.6vw;
  }
}

@media only screen and (max-width: 1699px) {
  .grid_contents_merit li .text_box .midashi28 {
    font-size: 1.65vw;
  }
  .grid_contents_merit li .text_box p {
    font-size: 1.1vw;
  }
  .grid_contents_merit li .text_box {
    min-height: 20vw;
  }
  .grid_contents_demerit li .text_box .midashi28 {
    font-size: 1.65vw;
  }
  .grid_contents_demerit li .text_box p {
    font-size: 1.1vw;
  }
  .grid_contents_demerit li .text_box {
    min-height: 20vw;
  }
}

@media only screen and (max-width: 1600px) {
  .reason04_sec ul li .midashi33 {
    font-size: 2vw;
  }
}

@media only screen and (max-width: 1500px) {
  .reason_green_grid ul li .midashi37 {
    font-size: 2.5vw;
  }
}

@media only screen and (max-width: 1400px) {
  .reason_wrap02 .deco {
    bottom: -50px;
    left: 38%;
    z-index: 1;
    width: 200px;
  }
  .about_doctor_grid li a .right .midashi28 {
    font-size: 2vw;
  }
  .comparison_table table tr td:nth-child(1) {
    width: 17%;
  }
}
@media only screen and (max-width: 1376px) {
  .none_1376{
    display: none;
  }
}
@media only screen and (max-width: 1250px) {
  .expense_box ul li:nth-child(odd) {
    font-size: 19px;
  }
  .expense_box ul li:nth-child(even) {
    font-size: 29px;
    padding: 0 10px;
  }
  .expense_box ul li:last-child {
    font-size: 23px;
  }
}

@media only screen and (max-width: 1200px) {
  .greeting_wrap .right {
    padding-left: 25px;
    padding-bottom: 25px;
    height: 46vw;
  }
  /*下層*/
  .main_title span {
    font-size: 34px;
  }
  .main_title h2 {
    font-size: 40px;
  }
  /*counseling*/
  .counseling_sec01 .midashi33 {
    font-size: 27px;
  }
}

@media only screen and (max-width: 1024px) {
  .padding100 {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .padding110 {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .padding120 {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .padding130 {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .padding140 {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .padding150 {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .padding160 {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .padding170 {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .padding180 {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .padding190 {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .padding200 {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .padding210 {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .padding220 {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .padding230 {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .padding240 {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .padding250 {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .padding260 {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .padding270 {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .padding280 {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .padding290 {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .padding300 {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .margin100 {
    margin-top: 80px;
    margin-bottom: 80px;
  }
  .margin110 {
    margin-top: 80px;
    margin-bottom: 80px;
  }
  .margin120 {
    margin-top: 80px;
    margin-bottom: 80px;
  }
  .margin130 {
    margin-top: 80px;
    margin-bottom: 80px;
  }
  .margin140 {
    margin-top: 80px;
    margin-bottom: 80px;
  }
  .margin150 {
    margin-top: 80px;
    margin-bottom: 80px;
  }
  .margin160 {
    margin-top: 80px;
    margin-bottom: 80px;
  }
  .margin170 {
    margin-top: 80px;
    margin-bottom: 80px;
  }
  .margin180 {
    margin-top: 80px;
    margin-bottom: 80px;
  }
  .margin190 {
    margin-top: 80px;
    margin-bottom: 80px;
  }
  .margin200 {
    margin-top: 80px;
    margin-bottom: 80px;
  }
  .margin210 {
    margin-top: 80px;
    margin-bottom: 80px;
  }
  .margin220 {
    margin-top: 80px;
    margin-bottom: 80px;
  }
  .margin230 {
    margin-top: 80px;
    margin-bottom: 80px;
  }
  .margin240 {
    margin-top: 80px;
    margin-bottom: 80px;
  }
  .margin250 {
    margin-top: 80px;
    margin-bottom: 80px;
  }
  .margin260 {
    margin-top: 80px;
    margin-bottom: 80px;
  }
  .margin270 {
    margin-top: 80px;
    margin-bottom: 80px;
  }
  .margin280 {
    margin-top: 80px;
    margin-bottom: 80px;
  }
  .margin290 {
    margin-top: 80px;
    margin-bottom: 80px;
  }
  .margin300 {
    margin-top: 80px;
    margin-bottom: 80px;
  }
  .pt-120 {
    padding-top: 80px;
  }
  .pt-130 {
    padding-top: 80px;
  }
  .pt-140 {
    padding-top: 80px;
  }
  .pt-150 {
    padding-top: 80px;
  }
  .pt-160 {
    padding-top: 80px;
  }
  .pt-170 {
    padding-top: 80px;
  }
  .pt-180 {
    padding-top: 80px;
  }
  .pt-190 {
    padding-top: 80px;
  }
  .pt-200 {
    padding-top: 80px;
  }
  .pt-210 {
    padding-top: 80px;
  }
  .pt-220 {
    padding-top: 80px;
  }
  .pt-230 {
    padding-top: 80px;
  }
  .pt-240 {
    padding-top: 80px;
  }
  .pt-250 {
    padding-top: 80px;
  }
  .pt-260 {
    padding-top: 80px;
  }
  .pt-270 {
    padding-top: 80px;
  }
  .pt-280 {
    padding-top: 80px;
  }
  .pt-290 {
    padding-top: 80px;
  }
  .pt-300 {
    padding-top: 80px;
  }
  .pb-120 {
    padding-bottom: 80px;
  }
  .pb-130 {
    padding-bottom: 80px;
  }
  .pb-140 {
    padding-bottom: 80px;
  }
  .pb-150 {
    padding-bottom: 80px;
  }
  .pb-160 {
    padding-bottom: 80px;
  }
  .pb-170 {
    padding-bottom: 80px;
  }
  .pb-180 {
    padding-bottom: 80px;
  }
  .pb-190 {
    padding-bottom: 80px;
  }
  .pb-200 {
    padding-bottom: 80px;
  }
  .pb-210 {
    padding-bottom: 80px;
  }
  .pb-220 {
    padding-bottom: 80px;
  }
  .pb-230 {
    padding-bottom: 80px;
  }
  .pb-240 {
    padding-bottom: 80px;
  }
  .pb-250 {
    padding-bottom: 80px;
  }
  .pb-260 {
    padding-bottom: 80px;
  }
  .pb-270 {
    padding-bottom: 80px;
  }
  .pb-280 {
    padding-bottom: 80px;
  }
  .pb-290 {
    padding-bottom: 80px;
  }
  .pb-300 {
    padding-bottom: 80px;
  }
  .mt-120 {
    margin-top: 80px;
  }
  .mt-130 {
    margin-top: 80px;
  }
  .mt-140 {
    margin-top: 80px;
  }
  .mt-150 {
    margin-top: 80px;
  }
  .mt-160 {
    margin-top: 80px;
  }
  .mt-170 {
    margin-top: 80px;
  }
  .mt-180 {
    margin-top: 80px;
  }
  .mt-190 {
    margin-top: 80px;
  }
  .mt-200 {
    margin-top: 80px;
  }
  .mt-210 {
    margin-top: 80px;
  }
  .mt-220 {
    margin-top: 80px;
  }
  .mt-230 {
    margin-top: 80px;
  }
  .mt-240 {
    margin-top: 80px;
  }
  .mt-250 {
    margin-top: 80px;
  }
  .mt-260 {
    margin-top: 80px;
  }
  .mt-270 {
    margin-top: 80px;
  }
  .mt-280 {
    margin-top: 80px;
  }
  .mt-290 {
    margin-top: 80px;
  }
  .mt-300 {
    margin-top: 80px;
  }
  .mb-120 {
    margin-bottom: 80px;
  }
  .mb-130 {
    margin-bottom: 80px;
  }
  .mb-140 {
    margin-bottom: 80px;
  }
  .mb-150 {
    margin-bottom: 80px;
  }
  .mb-160 {
    margin-bottom: 80px;
  }
  .mb-170 {
    margin-bottom: 80px;
  }
  .mb-180 {
    margin-bottom: 80px;
  }
  .mb-190 {
    margin-bottom: 80px;
  }
  .mb-200 {
    margin-bottom: 80px;
  }
  .mb-210 {
    margin-bottom: 80px;
  }
  .mb-220 {
    margin-bottom: 80px;
  }
  .mb-230 {
    margin-bottom: 80px;
  }
  .mb-240 {
    margin-bottom: 80px;
  }
  .mb-250 {
    margin-bottom: 80px;
  }
  .mb-260 {
    margin-bottom: 80px;
  }
  .mb-270 {
    margin-bottom: 80px;
  }
  .mb-280 {
    margin-bottom: 80px;
  }
  .mb-290 {
    margin-bottom: 80px;
  }
  .mb-300 {
    margin-bottom: 80px;
  }
  .eng_title {
    font-size: 27px;
  }
  section.trouble .title01 {
    font-size: 30px;
    color: #fff;
  }
  section.trouble .title01 span {
    font-size: 45px;
  }
  section.trouble02 .title {
    padding-bottom: 130px;
    width: 500px;
  }
  section.fee_and_case a ul li .eng_title {
    font-size: 25px;
  }
  section.fee_and_case a ul {
    grid-template-columns: repeat(1, 1fr) !important;
    gap: 25px;
  }
  section.fee_and_case a {
    display: block;
    height: auto;
    padding-left: 0;
    padding: 60px 25px 80px;
  }
  section.fee_and_case .arrow_btn {
    right: 20px;
    bottom: 20px;
    width: 45px;
    height: 45px;
  }
  section.fee_and_case a ul {
    gap: 25px;
    width: 84%;
}

  .faq_list .question div:nth-child(2),
  .faq_list .question02 div:nth-child(2),
  .faq_list .question03 div:nth-child(2),
  .faq_list .question04 div:nth-child(2),
  .faq_list .question05 div:nth-child(2),
  .faq_list .question06 div:nth-child(2),
  .faq_list .question07 div:nth-child(2),
  .faq_list .question08 div:nth-child(2),
  .faq_list .question09 div:nth-child(2),
  .faq_list .question10 div:nth-child(2) {
    font-size: 20px;
  }
  /*下層*/
  .main {
    height: 350px;
  }
  .main_title span {
    font-size: 21px;
  }
  .main_title h2 {
    font-size: 28px;
  }
  /*about-implant*/
  section.implant_merit .title_text span {
    font-size: 90px;
  }
  .grid_contents_merit li .img100 .font1 {
    top: -16%;
    left: 5%;
    font-size: 70px;
  }
  .grid_contents_demerit li .img100 .font1 {
    top: -16%;
    left: 5%;
    font-size: 70px;
  }
  /*fee*/
  .fee_list thead tr td {
    font-size: 19px;
  }
  .fee_list tbody tr td:nth-child(1) {
    font-size: 17px;
    width: 23%;
  }
  .fee_list tbody tr td:nth-child(2) {
    font-size: 20px;
    width: 27%;
  }
  .fee_list tbody tr td:nth-child(2) span {
    font-size: 17px;
  }
  .fee_list tbody tr td:nth-child(3) {
    font-size: 15px;
  }
  .payment_box ul li p {
    font-size: 21px;
    padding-top: 15px;
  }
  /*about*/
  .about_container {
    width: 100%;
  }
  .reason_box {
    width: 100%;
    padding-top: 40px;
    grid-template-columns: repeat(1, 1fr);
    gap: 15px;
  }
  .reason_box.box02 {
    grid-template-columns: repeat(1, 1fr);
  }
  .reason_box.box02 .order2 {
    order: 0;
  }
  .reason_box .img100 {
    height: unset;
    text-align: center;
  }
  .reason_box .img100 img {
    bottom: 0;
    max-width: 600px;
  }
  .reason_box .right {
    padding: 0 6vw 100px;
  }
  .con01 {
    padding-top: 0;
    margin-top: 60px;
  }
  .con02 {
    margin-top: 60px;
  }
  .con03 {
    margin-top: 130px;
  }
  .con05 {
    margin-top: 60px;
  }
  .reason_btn {
    bottom: -7%;
    font-size: 20px;
    max-width: 560px;
    height: 130px;
  }
  .reason_box .right .midashi45 {
    font-size: 31px;
  }
  .reason_green_grid ul {
    grid-template-columns: repeat(1, 1fr);
    gap: 220px;
  }
  .reason_green_grid ul li .midashi37 {
    font-size: 27px;
  }
  .reason_green_grid ul .right .midashi37 {
    padding-top: 0;
  }
  .reason04_sec ul {
    grid-template-columns: repeat(2, 1fr);
    column-gap: 4vw;
    row-gap: 3.5vw;
  }
  .reason04_sec ul li .midashi33 {
    font-size: 3vw;
  }
  .about_doctor_grid {
    grid-template-columns: repeat(1, 1fr);
    gap: 25px;
  }
  .about_doctor_grid li a {
    grid-template-columns: 32% 64%;
    padding: 2.5vw;
  }
  /*counseling*/
  .contact_form li .right.radio {
    display: grid;
    gap: 0;
  }
  /**/
  .sedation_border_box .midashi44 {
    font-size: 34px;
  }
  /*font-size*/
  .midashi65 {
    font-size: 45px;
  }
  .midashi55 {
    font-size: 35px;
  }
  .midashi50 {
    font-size: 33px;
  }
  .midashi45 {
    font-size: 30px;
  }
  .midashi42 {
    font-size: 28px;
  }
  .midashi40 {
    font-size: 27px;
  }
  .midashi35 {
    font-size: 25px;
  }
  .midashi30 {
    font-size: 23px;
  }
  .midashi28 {
    font-size: 21px;
  }
  .midashi20 {
    font-size: 19px;
  }
  /******************/
}

@media only screen and (max-width: 740px) {
  .flex_30 {
    width: 100%;
  }
  .flex_31 {
    width: 100%;
  }
  .flex_32 {
    width: 100%;
  }
  .flex_33 {
    width: 100%;
  }
  .flex_34 {
    width: 100%;
  }
  .flex_35 {
    width: 100%;
  }
  .flex_36 {
    width: 100%;
  }
  .flex_37 {
    width: 100%;
  }
  .flex_38 {
    width: 100%;
  }
  .flex_39 {
    width: 100%;
  }
  .flex_40 {
    width: 100%;
  }
  .flex_41 {
    width: 100%;
  }
  .flex_42 {
    width: 100%;
  }
  .flex_43 {
    width: 100%;
  }
  .flex_44 {
    width: 100%;
  }
  .flex_45 {
    width: 100%;
  }
  .flex_46 {
    width: 100%;
  }
  .flex_47 {
    width: 100%;
  }
  .flex_48 {
    width: 100%;
  }
  .flex_49 {
    width: 100%;
  }
  .flex_50 {
    width: 100%;
  }
  .flex_51 {
    width: 100%;
  }
  .flex_52 {
    width: 100%;
  }
  .flex_53 {
    width: 100%;
  }
  .flex_54 {
    width: 100%;
  }
  .flex_55 {
    width: 100%;
  }
  .flex_56 {
    width: 100%;
  }
  .flex_57 {
    width: 100%;
  }
  .flex_58 {
    width: 100%;
  }
  .flex_59 {
    width: 100%;
  }
  .flex_60 {
    width: 100%;
  }
  .flex_61 {
    width: 100%;
  }
  .flex_62 {
    width: 100%;
  }
  .flex_63 {
    width: 100%;
  }
  .flex_64 {
    width: 100%;
  }
  .flex_65 {
    width: 100%;
  }
  .flex_66 {
    width: 100%;
  }
  .flex_67 {
    width: 100%;
  }
  .flex_68 {
    width: 100%;
  }
  .flex_69 {
    width: 100%;
  }
  .flex_70 {
    width: 100%;
  }
  .padding100 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .padding110 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .padding120 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .padding130 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .padding140 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .padding150 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .padding160 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .padding170 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .padding180 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .padding190 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .padding200 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .padding210 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .padding220 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .padding230 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .padding240 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .padding250 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .padding260 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .padding270 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .padding280 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .padding290 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .padding300 {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  .margin100 {
    margin-top: 60px;
    margin-bottom: 60px;
  }
  .margin110 {
    margin-top: 60px;
    margin-bottom: 60px;
  }
  .margin120 {
    margin-top: 60px;
    margin-bottom: 60px;
  }
  .margin130 {
    margin-top: 60px;
    margin-bottom: 60px;
  }
  .margin140 {
    margin-top: 60px;
    margin-bottom: 60px;
  }
  .margin150 {
    margin-top: 60px;
    margin-bottom: 60px;
  }
  .margin160 {
    margin-top: 60px;
    margin-bottom: 60px;
  }
  .margin170 {
    margin-top: 60px;
    margin-bottom: 60px;
  }
  .margin180 {
    margin-top: 60px;
    margin-bottom: 60px;
  }
  .margin190 {
    margin-top: 60px;
    margin-bottom: 60px;
  }
  .margin200 {
    margin-top: 60px;
    margin-bottom: 60px;
  }
  .margin210 {
    margin-top: 60px;
    margin-bottom: 60px;
  }
  .margin220 {
    margin-top: 60px;
    margin-bottom: 60px;
  }
  .margin230 {
    margin-top: 60px;
    margin-bottom: 60px;
  }
  .margin240 {
    margin-top: 60px;
    margin-bottom: 60px;
  }
  .margin250 {
    margin-top: 60px;
    margin-bottom: 60px;
  }
  .margin260 {
    margin-top: 60px;
    margin-bottom: 60px;
  }
  .margin270 {
    margin-top: 60px;
    margin-bottom: 60px;
  }
  .margin280 {
    margin-top: 60px;
    margin-bottom: 60px;
  }
  .margin290 {
    margin-top: 60px;
    margin-bottom: 60px;
  }
  .margin300 {
    margin-top: 60px;
    margin-bottom: 60px;
  }
  .pt-110 {
    padding-top: 60px;
  }
  .pt-120 {
    padding-top: 60px;
  }
  .pt-130 {
    padding-top: 60px;
  }
  .pt-140 {
    padding-top: 60px;
  }
  .pt-150 {
    padding-top: 60px;
  }
  .pt-160 {
    padding-top: 60px;
  }
  .pt-170 {
    padding-top: 60px;
  }
  .pt-180 {
    padding-top: 60px;
  }
  .pt-190 {
    padding-top: 60px;
  }
  .pt-200 {
    padding-top: 60px;
  }
  .pt-210 {
    padding-top: 60px;
  }
  .pt-220 {
    padding-top: 60px;
  }
  .pt-230 {
    padding-top: 60px;
  }
  .pt-240 {
    padding-top: 60px;
  }
  .pt-250 {
    padding-top: 60px;
  }
  .pt-260 {
    padding-top: 60px;
  }
  .pt-270 {
    padding-top: 60px;
  }
  .pt-280 {
    padding-top: 60px;
  }
  .pt-290 {
    padding-top: 60px;
  }
  .pt-300 {
    padding-top: 60px;
  }
  .pb-110 {
    padding-bottom: 60px;
  }
  .pb-120 {
    padding-bottom: 60px;
  }
  .pb-130 {
    padding-bottom: 60px;
  }
  .pb-140 {
    padding-bottom: 60px;
  }
  .pb-150 {
    padding-bottom: 60px;
  }
  .pb-160 {
    padding-bottom: 60px;
  }
  .pb-170 {
    padding-bottom: 60px;
  }
  .pb-180 {
    padding-bottom: 60px;
  }
  .pb-190 {
    padding-bottom: 60px;
  }
  .pb-200 {
    padding-bottom: 60px;
  }
  .pb-210 {
    padding-bottom: 60px;
  }
  .pb-220 {
    padding-bottom: 60px;
  }
  .pb-230 {
    padding-bottom: 60px;
  }
  .pb-240 {
    padding-bottom: 60px;
  }
  .pb-250 {
    padding-bottom: 60px;
  }
  .pb-260 {
    padding-bottom: 60px;
  }
  .pb-270 {
    padding-bottom: 60px;
  }
  .pb-280 {
    padding-bottom: 60px;
  }
  .pb-290 {
    padding-bottom: 60px;
  }
  .mt-110 {
    margin-top: 60px;
  }
  .mt-120 {
    margin-top: 60px;
  }
  .mt-130 {
    margin-top: 60px;
  }
  .mt-140 {
    margin-top: 60px;
  }
  .mt-150 {
    margin-top: 60px;
  }
  .mt-160 {
    margin-top: 60px;
  }
  .mt-170 {
    margin-top: 60px;
  }
  .mt-180 {
    margin-top: 60px;
  }
  .mt-190 {
    margin-top: 60px;
  }
  .mt-200 {
    margin-top: 60px;
  }
  .mt-210 {
    margin-top: 60px;
  }
  .mt-220 {
    margin-top: 60px;
  }
  .mt-230 {
    margin-top: 60px;
  }
  .mt-240 {
    margin-top: 60px;
  }
  .mt-250 {
    margin-top: 60px;
  }
  .mt-260 {
    margin-top: 60px;
  }
  .mt-270 {
    margin-top: 60px;
  }
  .mt-280 {
    margin-top: 60px;
  }
  .mt-290 {
    margin-top: 60px;
  }
  .mt-300 {
    margin-top: 60px;
  }
  .mb-110 {
    margin-bottom: 60px;
  }
  .mb-120 {
    margin-bottom: 60px;
  }
  .mb-130 {
    margin-bottom: 60px;
  }
  .mb-140 {
    margin-bottom: 60px;
  }
  .mb-150 {
    margin-bottom: 60px;
  }
  .mb-160 {
    margin-bottom: 60px;
  }
  .mb-170 {
    margin-bottom: 60px;
  }
  .mb-180 {
    margin-bottom: 60px;
  }
  .mb-190 {
    margin-bottom: 60px;
  }
  .mb-200 {
    margin-bottom: 60px;
  }
  .mb-210 {
    margin-bottom: 60px;
  }
  .mb-220 {
    margin-bottom: 60px;
  }
  .mb-230 {
    margin-bottom: 60px;
  }
  .mb-240 {
    margin-bottom: 60px;
  }
  .mb-250 {
    margin-bottom: 60px;
  }
  .mb-260 {
    margin-bottom: 60px;
  }
  .mb-270 {
    margin-bottom: 60px;
  }
  .mb-280 {
    margin-bottom: 60px;
  }
  .mb-290 {
    margin-bottom: 60px;
  }
  .mb-300 {
    margin-bottom: 60px;
  }
  body {
    min-width: auto;
  }
  .fast_banner {
    bottom: 5%;
    right: unset;
    left: 50%;
    transform: translateX(-50%);
    width: 86vw;
  }
  .sp_banner {
    position: fixed;
    left: 0;
    bottom: 0;
    width: 100%;
    display: grid;
    grid-template-columns: 47.6% 38% 14.9%;
    z-index: 99;
  }
  .sp_banner a {
    display: block;
  }
  #menu_web_btn img {
    width: 100%;
    max-width: 350px;
  }
  .menu_link li a {
    font-size: 18px;
    gap: 5px;
  }
  .menu_tel img {
    max-width: 250px;
  }
  #slider {
    height: 142vw !important;
    background: url(../images/sp/fade01.webp) center/cover;
  }
  #logo {
    top: 25px;
    left: 15px;
  }
  #logo img {
    width: 330px;
  }
  .h_bottom {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    bottom: -12.5%;
    left: 50%;
    right: unset;
    transform: translateX(-50%);
    gap: 15px;
  }
  .h_bottom img {
    width: 38vw;
    max-width: unset;
  }
  .h_banner {
    display: none;
  }
  section.trouble {
    padding: 60px 0 60px;
  }
  section.trouble02 {
    padding: 40px 0 260px;
    background-image: url(../images/sp/top_trouble_bg02.webp);
    background-position: 47% 0;
    background-size: 160%;
    background-repeat: no-repeat;
    background-color: #c9c9c9;
  }
  .trouble_doctor {
    width: 31.5vw;
    left: 50%;
    transform: translateX(-50%);
  }
  .top_trouble_list {
    grid-template-columns: repeat(2, 1fr);
    width: 91%;
  }
  section.trouble .title01 {
    font-size: 24px;
  }
  section.trouble .title01 span {
    font-size: 31px;
  }
  section.trouble .container1760 {
    padding: 50px 0;
  }
  section.trouble02 .title {
    padding-bottom: 50px;
    width: 400px;
  }
  .reason_wrap02 .deco {
    bottom: -50px;
    left: unset;
    right: 8%;
    transform: unset;
    width: 145px;
  }
  .reason_green_box ul li .midashi45 {
    padding-bottom: 10px;
    margin-bottom: 20px;
  }
  section.reason {
    padding: 130px 0 100px;
  }
  section.reason .midashi65 img {
    width: 40px;
  }
  .reason_green_box ul {
    grid-template-columns: repeat(1, 1fr);
    gap: 35px;
  }
  .reason_wrap01,
  .reason_wrap02,
  .reason_wrap04,
  .reason_wrap05 {
    width: 100%;
    margin-right: auto;
    margin-left: auto;
    padding: 50px 0;
    height: unset;
  }
  .reason_wrap04 {
    background: url(../images/top_reason04.webp) 10%/auto no-repeat;
  }
  .reason_wrap05 {
    background: url(../images/top_reason05.webp) 80%/auto no-repeat;
  }
  section.reason_bottom {
    background: url(../images/top_reason_bg_gray.webp) left bottom/cover;
    padding: 60px 0 60px;
  }
  .reason_wrap01 .text_box img {
    position: unset;
    top: -40px;
    left: 50%;
    transform: unset;
    width: 100px;
    margin: 0 auto 25px;
    display: block;
  }
  .reason_wrap02 .text_box img {
    position: unset;
    top: -40px;
    left: 50%;
    transform: unset;
    width: 100px;
    margin: 0 auto 25px;
    display: block;
  }
  .reason_wrap04 .text_box img {
    position: unset;
    top: -40px;
    left: 50%;
    transform: unset;
    width: 100px;
    margin: 0 auto 25px;
    display: block;
  }
  .reason_wrap05 .text_box img {
    position: unset;
    top: -40px;
    left: 50%;
    transform: unset;
    width: 100px;
    margin: 0 auto 25px;
    display: block;
  }
  .reason_wrap01 .text_box {
    position: unset;
    transform: unset;
    margin: 0 auto;
    padding: 60px 4vw 50px;
  }
  .reason_wrap02 .text_box {
    position: unset;
    transform: unset;
    margin: 0 auto;
    padding: 60px 4vw 50px;
  }
  .reason_wrap04 .text_box {
    position: unset;
    transform: unset;
    margin: 0 auto;
    padding: 60px 4vw 50px;
  }
  .reason_wrap05 .text_box {
    position: unset;
    transform: unset;
    margin: 0 auto;
    padding: 60px 4vw 50px;
  }
  .reason03 {
    width: 100px;
  }
  .reason03_contents {
    grid-template-columns: repeat(1, 1fr);
    gap: 45px;
  }
  .youtube_view{
    height: 47vh;
    padding: 65px 0 20px;
  }
  .youtube_view iframe {
    width: 90%;
    height: 53vw;
  }
  section.contact {
    padding: 50px 0;
  }
  section.contact .container1760 .waku {
    padding: 50px 0;
  }
  .contact_deco {
    top: 21%;
    right: 16vw;
    width: 6.5vw;
  }
  .banner_wrap {
    grid-template-columns: repeat(1, 1fr);
    gap: 25px;
  }
  .greeting_wrap {
    grid-template-columns: repeat(1, 1fr);
    gap: 35px;
  }
  .greeting_wrap .right {
    padding-left: 0;
    padding-bottom: 25px;
    height: auto;
  }
  .docter_name {
    max-width: 240px;
    left: 50%;
    transform: translateX(-50%);
  }
  section.fee_and_case a {
    display: block;
    height: auto;
    padding-left: 0;
    padding: 60px 25px 80px;
  }
  section.fee_and_case {
    grid-template-columns: repeat(1, 1fr);
  }
  .faq_list li:nth-child(odd) {
    grid-template-columns: 60px 1fr;
  }
  .faq_list li:nth-child(odd) img {
    width: 100%;
    height: auto;
  }
  .faq_list li p {
    line-height: 1.5em;
    font-size: 16px;
    width: 86%;
  }
  .answer {
    padding: 30px 25px;
  }
  .faq_list .question div:nth-child(2),
  .faq_list .question02 div:nth-child(2),
  .faq_list .question03 div:nth-child(2),
  .faq_list .question04 div:nth-child(2),
  .faq_list .question05 div:nth-child(2),
  .faq_list .question06 div:nth-child(2),
  .faq_list .question07 div:nth-child(2),
  .faq_list .question08 div:nth-child(2),
  .faq_list .question09 div:nth-child(2),
  .faq_list .question10 div:nth-child(2) {
    height: 60px;
    padding-left: 15px;
    font-size: 17px;
  }
  .faq_list .question,
  .faq_list .question02,
  .faq_list .question03,
  .faq_list .question04,
  .faq_list .question05,
  .faq_list .question06,
  .faq_list .question07,
  .faq_list .question08,
  .faq_list .question09,
  .faq_list .question10 {
    margin-top: 15px;
  }
  .plus {
    right: 4%;
    width: 15px;
    height: 15px;
  }
  .plus i:nth-child(1) {
    width: 15px;
  }
  .plus i:nth-child(2) {
    height: 15px;
  }
  .banner_sec ul {
    grid-template-columns: repeat(1, 1fr);
    gap: 25px;
  }
  .footer {
    padding-bottom: 15vw;
  }
  .footer_wrap {
    padding: 70px 0;
  }
  .footer_contents {
    grid-template-columns: repeat(1, 1fr);
    gap: 35px;
  }
  .top_scroll {
    position: absolute;
    bottom: 5%;
    right: 1.5%;
  }
  .copy {
    padding: 25px;
    font-size: 14px;
  }
  /*think-about*/
  .think-about_list .grid_contents {
    grid-template-columns: repeat(1, 1fr);
    gap: 35px;
  }
  .think-about_list .grid_contents .midashi35 {
    padding-bottom: 15px;
  }
  .think-about_list .grid_contents .midashi35:after {
    width: 35px;
    left: 2px;
  }
  /**/
  .implant_wrap {
    background: url(../images/sp/about-implant_bg01.webp) 20%/cover;
    padding: 35px 4vw 380px;
  }
  .implant_wrap .text_box:after {
    top: 4%;
    left: 2.5%;
    width: 30px;
    height: 30px;
  }
  .implant_wrap .text_box {
    padding: 50px 25px 45px;
  }
  .implant_wrap .text_box:before {
    bottom: 4%;
    right: 2.5%;
    width: 30px;
    height: 30px;
  }
  .structure_contents {
    padding: 40px 4vw;
  }
  section.implant_merit .container1600 {
    padding: 0;
  }
  section.implant_merit .title_text span {
    font-size: 57px;
  }
  section.implant_merit {
    background: url(../images/about-implant_bg02.webp) center top/cover;
    padding: 60px 0 90px;
  }
  section.implant_merit:after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    background-image: url(../images/about-implant_bg-left.webp);
    background-size: cover;
    width: 29vw;
    height: 38vw;
  }
  section.implant_merit::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    background-image: url(../images/about-implant_bg-right.webp);
    background-size: cover;
    width: 29vw;
    height: 38vw;
  }
  .grid_contents_merit li .text_box .midashi28 {
    font-size: 18px;
  }
  .grid_contents_merit li .text_box p {
    font-size: 15px;
  }
  .grid_contents_merit li {
    width: 48%;
  }
  .grid_contents_demerit {
    grid-template-columns: repeat(2, 1fr);
    padding-top: 130px;
    column-gap: 6vw;
    row-gap: 75px;
  }
  .grid_contents_demerit li .text_box .midashi28 {
    font-size: 18px;
  }
  .grid_contents_demerit li .text_box p {
    font-size: 15px;
  }
  section.implant_merit .title_text {
    padding: 30px 0;
  }
  .comparison_contents ul {
    grid-template-columns: repeat(1, 1fr);
    gap: 0;
    padding: 40px 25px;
    border-left: 8px solid #ded7cb;
  }
  .comparison_contents ul li span.c-fff {
    padding: 5px 10px;
    margin-bottom: 10px;
    font-size: 16px;
  }
  .comparison_table {
    overflow-x: scroll;
  }
  .comparison_table table {
    width: 250%;
  }
  .comparison_table table tr td:nth-child(1) {
    width: 14%;
    font-size: 18px;
  }
  .comparison_table table tr td:nth-child(n + 2) {
    font-size: 16px;
    width: 28.6%;
    padding: 25px 20px;
    align-content: center;
  }
  /*flow*/
  .flow_contents .grid01 {
    grid-template-columns: repeat(1, 1fr);
    gap: 35px;
  }
  .flow_contact .grid02 {
    grid-template-columns: repeat(1, 1fr);
    gap: 25px;
  }
  .flow_contents {
    padding: 40px 25px 50px;
  }
  .flow_contact {
    margin-top: 25px;
    padding: 30px 25px 50px;
  }
  .flow_contents .grid01 li .midashi30 span {
    max-width: 40px;
    height: 40px;
    font-size: 24px;
  }
  /*case*/
  .case_midashi {
    padding-bottom: 10px;
  }
  .case_contents ul {
    grid-template-columns: repeat(2, 1fr);
    column-gap: 0;
  }
  .case_contents ul li {
    border-radius: 1px;
    padding: 20px;
  }
  .case_contents ul li span {
    font-size: 20px;
    width: 100%;
    height: 40px;
    margin: 0 auto 20px;
  }
  .case_contents ul li:nth-child(1):after {
    content: "";
    background: url("../images/case_arrow.webp") 50% 50%/100% 100% no-repeat;
    width: 15px;
    height: 41px;
    position: absolute;
    right: -10px;
    top: 20px;
    transform: translateY(0);
  }
  .case_grid_img {
    flex-wrap: wrap;
    margin-bottom: 10px;
    grid-row-gap: 10px;
  }
  .case_grid_img > div {
    width: 100%;
  }
  .case_grid_img > div:first-child img, .case_grid_img > div:last-child img {
    width: 100%;
    height: auto;
  }
  .case_list tr td {
    padding: 20px 12px;
  }
  .case_list tr td:nth-child(1) {
    width: 25%;
    font-size: 16px;
  }
  .case_list tr td:nth-child(2) {
    font-size: 15px;
  }
  /*fee*/
  .fee_list_wrap {
    overflow-x: scroll;
  }
  .fee_list {
    width: 190%;
  }
  .fee_list tbody tr td {
    padding: 20px 15px;
  }
  .fee_list tbody tr td:nth-child(3) {
    font-size: 16px;
    padding: 20px 25px;
  }
  .payment_box ul li p {
    font-size: 18px;
    padding-top: 12px;
  }
  .fee_btn img {
    width: 100%;
    max-width: 360px;
  }
  .expense_box {
    padding: 40px 4vw;
  }
  .expense_box ul {
    flex-wrap: wrap;
  }
  .expense_box ul li {
    min-height: 102px;
  }
  .expense_box ul li:nth-child(odd) {
    font-size: 18px;
    padding: 15px 10px;
    width: 43%;
  }
  .expense_box ul li:nth-child(even) {
    font-size: 24px;
    padding: 0 10px;
  }
  .expense_box ul li:nth-child(4) {
    width: 100%;
    min-height: unset;
    padding: 15px 0;
  }
  .expense_box ul li:nth-child(5) {
    width: 50%;
  }
  .expense_box ul li:nth-child(6) {
    min-height: unset;
    padding: 15px 0;
  }
  .expense_box ul li:nth-child(6) span {
    transform: rotateZ(90deg);
  }
  .expense_box ul li:nth-child(n + 6) {
    width: 100%;
  }
  .expense_box ul li:last-child {
    width: 80%;
    font-size: 21px;
  }
  .fee_risk {
    padding: 40px 25px 45px;
    background-color: #fff;
  }
  /*doctor*/
  .doctor_sec {
    background: url(../images/bg_sankaku.webp) top left/cover;
    padding: 60px 0 60px;
  }
  .doctor_sec:after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    background-image: url(../images/bg_sankaku-top.webp);
    background-size: cover;
    width: 65vw;
    height: 65vw;
  }
  .doctor_sec::before {
    content: "";
    position: absolute;
    bottom: 0;
    right: 0;
    background-image: url(../images/bg_sankaku-bottom.webp);
    background-size: cover;
    width: 65vw;
    height: 65vw;
  }
  .greeting_grid {
    grid-template-columns: repeat(1, 1fr);
    gap: 35px;
  }
  .greeting_grid .left .name_box div .font1 {
    bottom: 0px;
  }
  .greeting_grid .left .name_box {
    padding-bottom: 20px;
    margin-bottom: 20px;
  }
  .greeting_list_wrap {
    grid-template-columns: repeat(1, 1fr);
    gap: 15px;
  }
  .greeting_list_wrap .box {
    padding: 30px 25px;
  }
  .greeting_list_wrap .left ul li {
    grid-template-columns: 120px 1fr;
  }
  .greeting_list_wrap .box ul li div:nth-child(1) {
    align-items: baseline;
    gap: 7px;
  }
  .greeting_list_wrap .box ul li div:nth-child(1) span {
    position: relative;
    bottom: 3px;
  }
  .doctor_grid {
    grid-template-columns: repeat(1, 1fr);
    gap: 35px;
  }
  .doctor_grid .right .name_box {
    padding-bottom: 15px;
    margin-bottom: 25px;
  }
  .doctor_grid .right .name_box div .font1 {
    bottom: 0;
  }
  .history_wrap {
    grid-template-columns: repeat(1, 1fr);
    gap: 15px;
  }
  .history_wrap div {
    padding: 10px 25px 15px 25px;
  }
  .history_wrap div p {
    font-size: 20px;
    padding-bottom: 10px;
  }
  .doctor02 {
    grid-template-columns: repeat(1, 1fr);
    gap: 15px;
    width: 74%;
  }
  .doctor02 .img100 img {
    width: 50%;
  }
  .doctor_midashi_box {
    padding: 25px 20px;
  }
  /*about*/
  .about_grid01 {
    grid-template-columns: repeat(1, 1fr);
    gap: 35px;
  }
  .reason_box .right .midashi45 {
    font-size: 26px;
  }
  .reason_box .img100 {
    padding: 0 4vw;
  }
  .about_container:after {
    width: 96.3%;
    height: 97.5%;
  }
  .con01 .font1.number {
    right: 3%;
    bottom: 0%;
    font-size: 110px;
  }
  .con02 .font1.number {
    left: unset;
    right: 3%;
    bottom: 0%;
    font-size: 110px;
  }
  .con03 .font1.number {
    right: 3%;
    bottom: 0%;
    font-size: 110px;
  }
  .con04 .font1.number {
    right: 3%;
    bottom: 0%;
    font-size: 110px;
  }
  .con05 .font1.number {
    right: 3%;
    left: unset;
    bottom: 0%;
    font-size: 110px;
  }
  .reason_btn {
    bottom: -7%;
    font-size: 18px;
    width: 88%;
    height: 100px;
  }
  .reason_btn i {
    right: 9%;
    width: 12px;
    height: 12px;
  }
  .reason_green_grid {
    margin: 230px auto 0;
  }
  .reason_green_grid ul li .text_box {
    padding: 0 5vw 40px;
  }
  .reason04_sec ul {
    grid-template-columns: repeat(1, 1fr);
    gap: 35px;
  }
  .reason04_sec:after {
    width: 96.3%;
    height: 99.5%;
  }
  .reason04_sec ul li .midashi33 {
    font-size: 23px;
    padding: 15px 0 15px;
  }
  .reason04_sec .font1.number {
    top: 1%;
    font-size: 110px;
  }
  .reason04_sec {
    padding: 60px 0;
  }
  #anshin-5 {
    bottom: 8%;
    right: 10%;
    max-width: 24vw;
  }
  .about_doctor_grid li a .right .midashi28 {
    font-size: 19px;
  }
  .about_doctor_grid li a .arrow_box {
    bottom: 11%;
    right: 3.5%;
    width: 35px;
    height: 35px;
    padding-right: 6px;
  }
  .about_doctor_grid li a .arrow_box i {
    width: 8px;
    height: 8px;
  }
  .about_sec01 {
    background: url(../images/about_bg01.webp) 70%/cover;
  }
  /*accees*/
  .access_grid {
    grid-template-columns: repeat(1, 1fr);
    gap: 35px;
  }
  .access_grid .text_box {
    padding: 15px 5px;
  }
  .access_map iframe {
    height: 320px;
  }
  .access_grid02 {
    grid-template-columns: repeat(1, 1fr);
    gap: 15px;
  }
  /*column*/
  .column_contents {
    grid-template-columns: repeat(2, 1fr);
    column-gap: 4.5vw;
    row-gap: 35px;
  }
  .page {
    gap: 4vw;
  }
  .page li {
    font-size: 26px;
  }
  .page li a {
    font-size: 26px;
  }
  .column_title {
    font-size: 18px;
    padding: 0 0 10px;
  }
  .eng_title {
    color: #aa945e;
    font-size: 26px;
    font-family: "ivypresto-display", serif;
    font-weight: 300;
    font-style: normal;
  }
  /*counseling*/
  .counseling_sec01 .midashi33 {
    font-size: 20px;
  }
  .counseling_sec01:after {
    border: 15px solid #fff;
  }
  .counseling_deco {
    bottom: -40.8vw;
    width: 96vw;
  }
  .counseling_tel_box {
    height: 230px;
    padding: 0 6vw;
  }
  .contact_form li {
    grid-template-columns: repeat(1, 1fr);
    gap: 15px;
  }
  .contact_form li .left {
    display: flex;
    gap: 15px;
  }
  .contact_form li .left .bg_2c9559.c-fff {
    padding: 0 7px;
  }
  .contact_form li:nth-child(n + 2) {
    padding-top: 25px;
  }
  .text_input {
    height: 55px;
    padding: 10px;
  }
  .textarea {
    height: 130px;
    padding: 10px;
  }
  .calendar_wrap .calendar_contents {
    grid-template-columns: 85px 1fr;
  }
  .privacy_box p {
    font-size: 15px;
  }
  .privacy_box {
    margin: 30px auto 25px;
    height: 260px;
    padding: 35px 25px;
  }
  .submit {
    max-width: 300px;
    height: 70px;
    font-size: 19px;
  }
  /**/
  .main_title h2 span {
    color: #fff;
    font-size: 20px;
  }
  .sedation_sec01 .grid {
    grid-template-columns: repeat(1, 1fr);
    gap: 35px;
  }
  .sedation_sec03 ul {
    grid-template-columns: repeat(1, 1fr);
    gap: 25px;
  }
  .sedation_sec03 ul li div {
    padding: 6vw 4vw;
    height: 94%;
  }
  .sedation_sec03 ul li div p {
    gap: 7px;
  }
  .sedation_check_list {
    padding: 35px 25px;
    grid-template-columns: repeat(1, 1fr);
    gap: 15px;
  }
  .sedation_check_list li {
    align-items: flex-start;
  }
  .sedation_check_list li img {
    position: relative;
    top: 5px;
    max-width: 21px;
  }
  .sedation_border_box .midashi44 {
    font-size: 25px;
  }
  .sedation_border_box {
    padding: 35px 25px;
  }
  .sedation_doctor {
    grid-template-columns: repeat(1, 1fr);
    gap: 35px;
  }
  .sedation_doctor .right {
    text-align: center;
  }
  .sedation_doctor .right .midashi20 {
    margin: 0 auto;
  }
  .sedation_doctor .img100 {
    text-align: center;
  }
  .sedation_doctor .img100 img {
    max-width: 250px;
  }
  /*font-size*/
  .midashi65 {
    font-size: 35px;
  }
  .midashi55 {
    font-size: 26px;
  }
  .midashi50 {
    font-size: 25px;
  }
  .midashi45 {
    font-size: 25px;
  }
  .midashi42 {
    font-size: 24px;
  }
  .midashi40 {
    font-size: 24px;
  }
  .midashi35 {
    font-size: 23px;
  }
  .midashi30 {
    font-size: 19px;
  }
  .midashi28 {
    font-size: 19px;
  }
  .midashi25 {
    font-size: 19px;
  }
  .midashi20 {
    font-size: 18px;
  }
  .font17 {
    font-size: 16px;
  }
  .btn {
    max-width: 300px;
    height: 65px;
    font-size: 17px;
  }
  /*****************/
}

/* スマートフォン 縦(ポートレート) */
@media only screen and (max-width: 600px) {
  .grid_contents_merit li .img100 .font1 {
    top: -9%;
    font-size: 70px;
  }
  .grid_contents_demerit li .img100 .font1 {
    top: -9%;
    font-size: 70px;
  }
  .grid_contents_merit {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    padding-top: 90px;
    gap: 75px;
  }
  .grid_contents_merit li {
    width: 100%;
  }
  .grid_contents_demerit {
    grid-template-columns: repeat(1, 1fr);
    padding-top: 90px;
    gap: 75px;
  }
  .grid_contents_merit li .text_box .midashi28 {
    font-size: 22px;
  }
  .grid_contents_demerit li .text_box .midashi28 {
    font-size: 22px;
  }
  .grid_contents_merit li .text_box p {
    font-size: 17px;
  }
  .grid_contents_demerit li .text_box p {
    font-size: 17px;
  }
  .grid_contents_merit li .text_box {
    min-height: unset;
    padding: 30px 25px 30px;
    margin: -2.5em auto 0;
    width: 91.5%;
  }
  .grid_contents_demerit li .text_box {
    min-height: unset;
    padding: 30px 25px 30px;
    margin: -2.5em auto 0;
    width: 91.5%;
  }
  .grid_contents_merit li .text_box .midashi28:after {
    width: 35px;
  }
  .trouble_doctor {
    width: 220px;
  }
}

/* スマートフォン 縦(ポートレート) */
