@charset "UTF-8";
/*==================================================================

  LP h1（SEO用テキスト非表示）

==================================================================*/
.top_mainvisual + h1 {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
}
/*==================================================================

  メインビジュアル

==================================================================*/
.top_mainvisual {
  position: relative;
  display: block;
  /*height: 880px;*/
  height: 1154px;
}
.top_mainvisual::before {
  position: absolute;
  content: "";
  background: url(../images/mainvisual_bg.jpg) no-repeat;
  width: 1122px;
  height: 1156px;
  top: 130px;
  left: 0;
  z-index: -1;
}
.mainvisual_wrap {
  position: relative;
  /*height: 880px;*/
  height: 1154px;
  margin-bottom: 150px;
}
.mainvisual_bg_img {
  width: 100%;
  /*height: 880px;*/
  height: 1154px;
  object-fit: cover;
  object-position: center;
}
.mainvisual_overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}
.mainvisual_catch {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  text-align: center;
}
.mainvisual_catch img {
  max-width: 830px;
  width: 100%;
  height: auto;
}
.mainvisual_sub_catch {
  margin-top: 22px;
}
.mainvisual_sub_catch p {
  text-shadow: 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 25px #fff, 0 0 25px #fff, 0 0 25px #fff;
  font-size: 160%;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  font-weight: 600;
}
.mainvisual_sub_catch .title::before, .mainvisual_sub_catch .title::after {
  display: inline-block;
  content: '';
  width: 1px;
  height: 22px;
  background: currentColor;
  transform-origin: left bottom;
  box-shadow: 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 25px #fff, 0 0 25px #fff, 0 0 25px #fff;
}
.mainvisual_sub_catch .title::before {
  transform: rotate(-24deg);
  margin-right: 10px;
}
.mainvisual_sub_catch .title::after {
  transform: rotate(24deg);
  margin-left: 10px;
}
.mainvisual_sub_catch .list08 {
  max-width: 990px;
  margin: 0 auto;
}
.mainvisual_banners {
  position: absolute;
  bottom: 31px;
  left: 0;
  right: 0;
  display: flex;
  gap: 28px;
  padding: 0;
}
.mainvisual_bnr01 {
  position: relative;
  /*top: 36px;*/
}
.mainvisual_bnr01 a:hover {
  opacity: .8;
}
.mainvisual_bnr01, .mainvisual_bnr02 {
  flex-shrink: 0;
}
.mainvisual_bnr01 img, .mainvisual_bnr02 img {
  max-width: 100%;
  height: auto;
  display: block;
}
.mv_catch_list {
  display: flex;
  gap: 0 20px;
  align-items: flex-end;
  position: absolute;
  bottom: 31px;
}
/*==================================================================

  .top_trouble（要注意・症状）

==================================================================*/
/* main 内の #container が狭くても、帯だけウィンドウ幅いっぱいにする */
.top_trouble {
  position: relative;
  margin-top: 276px;
  box-sizing: border-box;
  background: url(../images/top_trouble_01_bg.jpg) no-repeat center / cover;
}
/* 背景：親（main/#container）の全幅に敷く。auto 100% だと画像が狭いと左右に白が出るため cover 必須 */
/*.top_trouble::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: var(--top-trouble-bg-start, 108px);
  width: 100%;
  height: var(--top-trouble-bg-height);
  background-image: url(../images/top_trouble_01_bg.jpg);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  z-index: 0;
  pointer-events: none;
}*/
.top_trouble_inner {
  position: relative;
  z-index: 1;
  box-sizing: border-box;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 0px 104px;
}
.top_trouble_head {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
}
/* 英字タイトル：左→右グラデ（#abd39d → #1da66a） */
.top_trouble_en {
  display: inline-block;
  margin: 0;
  padding: 0;
  font-size: 104px;
  font-family: "trajan-pro-3", serif;
  font-weight: 400;
  font-style: normal;
  line-height: 1.2;
  text-align: left;
  position: relative;
  letter-spacing: 0.05em;
  z-index: 2;
  margin-top: -58px;
  background-image: linear-gradient(to right, #abd39d, #1da66a);
  background-size: 100% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
@supports not (background-clip: text) {
  .top_trouble_en {
    background: none;
    color: #1da66a;
    -webkit-text-fill-color: currentColor;
  }
}
.top_trouble_label_box {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  box-sizing: border-box;
  /* width: 330px; */
  max-width: 100%;
  min-height: 44px;
  padding: 4px 16px;
  margin-top: 12px;
  margin-left: /*79*/ 50px;
  margin-right: 0;
  align-self: flex-start;
  background-image: linear-gradient(-44deg, rgb(179, 144, 95) 0%, rgb(221, 192, 148) 100%);
}
.top_trouble_label {
  font-size: 21px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  color: rgb(255, 255, 255);
  line-height: 1.2;
  text-align: left;
}
.top_trouble_h2 {
  /* margin: 29px 0 0 73px; */
  margin-top: 29px;
  padding: 0;
  max-width: 100%;
  font-size: 24px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  font-weight: 600;
  color: rgb(51, 51, 51);
  line-height: 1.2;
  text-align: left;
  align-self: flex-start;
}
.top_trouble_list {
  margin: 54px 0 0;
  padding: 0;
  list-style: none;
}
.top_trouble_list li {
  position: relative;
  margin: 0 0 22px;
  padding-left: 1.5em;
  font-size: 20px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  color: rgb(51, 51, 51);
  line-height: 1.2;
  text-align: left;
}
.top_trouble_list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.1em;
  width: 1.1em;
  height: 1.1em;
  background: url(../images/icon_check_trouble_brown.png) no-repeat center / contain;
  box-sizing: border-box;
}
.top_trouble_list .list06 {
  margin-top: 10px;
  margin-bottom: 30px;
  max-width: 530px;
  background-color: rgba(255, 255, 255, 0.6);
}
.top_trouble_list .list06 li {
  margin-bottom: 0;
  padding-left: 18px;
  font-size: 90%;
}
.top_trouble_list .list06 li:before {
  background: var(--main-color);
  width: 5px;
  height: 5px;
  top: 8px;
}
/*==================================================================

  .top_colonoscopy_wrap（サブタイトル帯 + メリットの親ラップ：共通背景用）

==================================================================*/
.top_colonoscopy_wrap {
  position: relative;
  max-width: none;
  box-sizing: border-box;
  padding-bottom: 140px;
  background: url(../images/top_trouble_colon_bg.jpg) no-repeat center / cover;
}
/*==================================================================

  .top_colonoscopy_subtitle（サブタイトル帯）

==================================================================*/
.top_colonoscopy_subtitle {
  position: relative;
  box-sizing: border-box;
  padding: 170px 24px 142px;
  text-align: center;
  overflow: hidden;
}
.top_colonoscopy_subtitle::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 1px;
  height: 130px;
  background: #fff;
}
.top_colonoscopy_en {
  position: absolute;
  left: 50%;
  top: 55%;
  transform: translate(-50%, -50%);
  font-size: 150px;
  background: linear-gradient(to right, #abd39d, #1da66a);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  opacity: 0.24;
  line-height: 1.2;
  letter-spacing: 0.04em;
  white-space: nowrap;
  pointer-events: none;
  z-index: 0;
  font-family: "trajan-pro-3", serif;
  font-weight: 400;
  font-style: normal;
}
.top_colonoscopy_text {
  position: relative;
  z-index: 1;
  margin: 0;
  font-size: /*40*/ 32px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  color: rgb(255, 255, 255);
  line-height: /*1.2*/ 1.5;
  text-align: center;
  letter-spacing: 0.1em;
}
.top_colonoscopy_highlight {
  color: #efc17f;
  font-weight: inherit;
}
/*==================================================================

  .top_merit（メリット）

==================================================================*/
.top_merit {
  position: relative;
  width: calc(100% - 80px);
  max-width: none;
  margin-left: auto;
  margin-right: 0;
  box-sizing: border-box;
  overflow: visible;
}
.top_merit_row {
  position: relative;
  min-height: 520px;
  overflow: hidden;
}
/* 左カラム：写真 — absolute で下側ほど右カラムに食い込む */
.top_merit_photo {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  /*width: 63%;*/
  width: 50%;
  overflow: hidden;
  z-index: 2;
}
.top_merit_photo img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: right center;
}
/* 右カラム：白背景＋テキスト。::before で斜めの白カバーを作り、写真の上にかぶせる */
.top_merit_body {
  position: relative;
  /*margin-left: 62%;
  width: calc(((100% - 1200px) / 2) + 560px);*/
  margin-left: 50%;
  width: calc(((100% - 1200px) / 2) + 600px);
  min-height: 520px;
  padding: 0;
  display: flex;
  flex-direction: column;
  /* max-height: 720px; */
  background: #fff;
}
/* 白い斜め背景：上側は左に張り出し、下側は右に引っ込む → 下ほど写真が見える。vw で可変 */
.top_merit_body::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: calc(-8vw);
  background: #fff;
  z-index: -1;
  clip-path: polygon(8vw 0, 100% 0, 100% 100%, 0 100%);
}
.top_merit_head {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  z-index: 2;
  padding-top: 51px;
}
/* MERIT 英字：TROUBLE と同じグリーングラデ */
.top_merit_en {
  display: inline-block;
  margin: 0;
  padding: 0;
  font-size: 104px;
  line-height: 1.2;
  letter-spacing: 0.05em;
  text-align: left;
  background-image: linear-gradient(to right, #abd39d, #1da66a);
  background-size: 100% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  font-family: "trajan-pro-3", serif;
  font-weight: 400;
  font-style: normal;
}
.top_merit_row .tit02 {
  padding: 0;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  font-weight: 600;
  margin-bottom: 15px;
  margin-left: 15px;
}
.top_merit_row .accordion {
  max-width: 490px;
}
.top_merit_row .accordion_tit {
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  font-weight: 600;
}
.top_merit_body_text {
  max-width: 800px;
  margin: 90px auto 0;
}
.top_merit_body_text .tit02 {
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  font-weight: 600;
  text-align: center;
  color: #fff;
  margin-bottom: 10px;
  font-size: 210%;
}
.top_merit_body_text .list08 {
  background-color: rgba(255, 255, 255, 0.6);
}
.top_merit_body_text .list08 li b {
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  font-size: 110%;
}
@supports not (background-clip: text) {
  .top_merit_en {
    background: none;
    color: #1da66a;
    -webkit-text-fill-color: currentColor;
  }
}
.top_merit_h2 {
  padding: 0;
  font-size: /*24*/ 18px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  font-weight: 600;
  color: rgb(51, 51, 51);
  line-height: 1.2;
  /* text-align: center; */
  /* padding-left: 17px; */
  margin-bottom: 20px;
}
/* チェックリスト */
.top_merit_list {
  margin: 0;
  padding: 0;
  list-style: none;
  position: relative;
  z-index: 2;
}
/* リスト背景ラップ：右カラム幅に合わせて伸縮する */
.top_merit_list_wrap {
  position: relative;
  margin-top: 47px;
  padding: 50px 24px 30px 69px;
}
/* 四角：ラップの左端〜ウィンドウ右端まで */
.top_merit_list_wrap::before {
  content: "";
  position: absolute;
  top: 0;
  right: -9999px;
  bottom: 0;
  right: 0;
  background: #f9f4ee;
  z-index: 0;
  width: 93%;
}
/* 三角形：四角の左にくっつける */
.top_merit_list_wrap::after {
  content: "";
  position: absolute;
  top: 1px;
  left: -266px;
  bottom: 0;
  width: 320px;
  background: #f9f4ee;
  z-index: 2;
  clip-path: polygon(100% 0, 100% 84%, 48px 0);
  height: 119%;
}
@media (min-width: 1670px) {
  .top_merit_list_wrap::after {
    left: -256px;
  }
}
@media (min-width: 1200px) and (max-width: 1300px) {
  .top_merit_list_wrap::after {
    height: 122%;
  }
}
.top_merit_list li {
  position: relative;
  margin: 0 0 22px;
  padding-left: 35px;
  font-size: 18px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  color: rgb(51, 51, 51);
  line-height: 1.5;
  text-align: left;
  font-weight: 400;
}
.top_merit_list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.1em;
  width: 24px;
  height: 24px;
  background: url(../images/icon_check_trouble_brown.png) no-repeat center / contain;
  box-sizing: border-box;
}
/*==================================================================

  .top_contact（ご予約・お問い合わせ）

==================================================================*/
.top_contact {
  position: relative;
  box-sizing: border-box;
  overflow: hidden;
  background: url(../images/top_contact_bg.jpg) no-repeat top center / cover;
}
#link_contact02 {
  padding-bottom: 166px;
  background: url(../images/top_feature_bg.jpg) no-repeat center top / cover;
}
.top_contact_bg {
  background: url(../images/top_contact_bg.jpg) no-repeat center center / cover;
}
.top_contact_inner {
  position: relative;
  width: 100%;
  min-width: 1200px;
  margin: 0 auto;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
/* --- ヘッダーセル --- */
.top_contact_head_cell {
  position: relative;
  background: rgba(0, 0, 0, 0.4);
  text-align: center;
  padding: 48px 24px 28px;
}
.top_contact_en {
  margin: 0;
  font-size: 104px;
  font-family: "trajan-pro-3", serif;
  font-weight: 400;
  font-style: normal;
  line-height: 1.2;
  background-image: linear-gradient(to right, #abd39d, #1da66a);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  opacity: 0.26;
}
@supports not (background-clip: text) {
  .top_contact_en {
    color: #1da66a;
    opacity: 0.26;
  }
}
.top_contact_h2 {
  margin: 25px 0 0;
  font-size: 24px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  color: rgb(255, 255, 255);
  line-height: 1.2;
  font-weight: 400;
  letter-spacing: 0.18em;
}
/* --- 3カラムグリッド --- */
.top_contact_grid {
  display: flex;
  gap: 2px;
}
/* --- 各セル --- */
.top_contact_cell {
  flex: 1;
  background: rgba(0, 0, 0, 0.4);
  padding: 80px 24px 61px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.top_contact_cell_content {
  max-width: 360px;
  width: 100%;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
}
.top_contact_cell_tit {
  margin: 0;
  font-size: 26px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  color: rgb(255, 255, 255);
  line-height: 1.2;
  font-weight: 400;
  letter-spacing: 0.1em;
}
.top_contact_cell_desc {
  margin: 40px 0 0;
  font-size: 16px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  color: rgb(255, 255, 255);
  line-height: 1.6;
}
/* --- ボタン群 --- */
.top_contact_cell_btns {
  /*margin-top: auto;*/
  padding-top: 24px;
  width: 100%;
  /*max-width: 320px;*/
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.top_contact_btn {
  /*display: flex;*/
  align-items: center;
  justify-content: space-between;
  width: 100%;
  /*padding: 8px 16px;*/
  padding: 10px 28px 10px 10px;
  background: rgba(0, 0, 0, 0.39);
  color: rgb(255, 255, 255);
  font-size: 16px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  line-height: 1.2;
  text-decoration: none;
  box-sizing: border-box;
  transition: background 0.3s;
}
.top_contact_btn:hover {
  background: rgba(0, 0, 0, 0.6);
}
.top_contact_btn_arrow {
  width: 14px;
  height: auto;
  flex-shrink: 0;
  margin-left: 8px;
  margin-top: 3px;
}
/* --- お問い合わせセル --- */
.top_contact_cell_sub {
  margin: 16px 0 0;
  font-size: 16px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  color: rgb(255, 255, 255);
  line-height: 1.2;
}
.top_contact_tel {
  margin: 12px 0 0;
  font-size: 24px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  color: rgb(255, 255, 255);
  line-height: 1.2;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
.top_contact_tel + .top_contact_btn {
  margin-top: 16px;
}
.top_contact_tel a {
  color: inherit;
  text-decoration: none;
}
.top_contact_tel_icon {
  width: 43px;
  height: auto;
}
.top_contact_hours {
  margin-top: 16px;
  text-align: center;
}
.top_contact_hours_label {
  display: inline-block;
  margin: 0;
  padding: 2px 42px;
  font-size: 16px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  color: rgb(255, 255, 255);
  line-height: 1.4;
  border: 1px solid rgba(255, 255, 255, 0.6);
}
.top_contact_hours_time {
  margin: 12px 0 0;
  font-size: 16px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  color: rgb(255, 255, 255);
  line-height: 1.8;
}
/*==================================================================

  .top_feature（当院の大腸カメラ検査の特徴）

==================================================================*/
.top_feature {
  position: relative;
  background: url(../images/top_feature_bg.jpg) no-repeat center top / cover;
  min-width: 1200px;
  overflow: hidden;
  padding-bottom: 158px;
}
.top_feature::before {
  position: absolute;
  content: "";
  background: #fff;
  width: 50%;
  height: 44%;
  left: 0;
  top: 680px;
  z-index: 0;
}
.top_feature_inner {
  width: 100%;
}
/* --- タイトル --- */
.top_feature_head {
  text-align: center;
  padding: 137px 30px /*103*/ 50px;
}
.top_feature_en {
  display: inline-block;
  margin: 0;
  font-size: 104px;
  font-family: "trajan-pro-3", serif;
  font-weight: 400;
  font-style: normal;
  line-height: 1.2;
  letter-spacing: 0.05em;
  background-image: linear-gradient(to right, #abd39d, #1da66a);
  background-size: 100% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
.top_feature_sub_head {
  max-width: 800px;
  margin: 0 auto 60px;
  text-align: center;
}
.top_feature_sub_head .list08 {
  justify-content: center;
}
.top_feature_sub_head .tit02 {
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  font-weight: 600;
  margin-bottom: 15px;
  text-align: center;
}
.top_feature_sub_head .list08 li {
  font-weight: bold;
}
.top_feature_sub_head p {
  font-size: 115%;
}
@supports not (background-clip: text) {
  .top_feature_en {
    background: none;
    color: #1da66a;
    -webkit-text-fill-color: currentColor;
  }
}
.top_feature_h2 {
  margin: 13px 0 0;
  font-size: 30px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  font-weight: 600;
  color: rgb(51, 51, 51);
  line-height: 1.2;
  letter-spacing: 0.1em;
}
/* --- Feature 共通 --- */
.top_feature_maru {
  display: block;
  width: 117px;
  height: auto;
  flex-shrink: 0;
}
.top_feature_number {
  display: block;
  height: 69px;
  width: auto;
  flex-shrink: 0;
}
.top_feature_item_tit {
  margin: 0;
  font-size: 24px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  color: rgb(51, 51, 51);
  line-height: 1.5;
  font-weight: 500;
  letter-spacing: 0.1em;
}
.top_feature_item_desc {
  margin: 16px 30px 5px 10px;
  font-size: 16px;
  font-family: "YuGoPr6N", "Yu Gothic", "Hiragino Kaku Gothic ProN", sans-serif;
  color: rgb(51, 51, 51);
  line-height: 2;
  letter-spacing: 0.1em;
  padding-left: 40px;
}
/* --- サブタイトルアイコン（白丸） --- */
.top_feature_item_sub_icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 62px;
  height: 62px;
  border-radius: 50%;
  background: #fff;
  vertical-align: middle;
  margin-right: 12px;
}
.top_feature_item_sub_icon img {
  width: 60%;
  height: auto;
  display: block;
}
/* --- サブタイトルバー共通 --- */
.top_feature_item_sub {
  position: relative;
  display: flex;
  align-items: center;
  gap: 12px;
}
.top_feature_item_sub_text {
  margin: 0;
  padding: 0 40px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  font-size: 26px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  color: rgb(255, 255, 255);
  line-height: 1.2;
  background: url(../images/tit_h3_feature.png) no-repeat center right;
  white-space: nowrap;
  width: 710px;
  height: 128px;
}
/* ==========================
   Feature 01（2カラム）
   ========================== */
.top_feature_item--01 {
  position: relative;
  display: flex;
  min-height: 520px;
  min-width: 1200px;
}
.top_feature_item--01 .top_feature_item_photo {
  width: 46%;
  flex-shrink: 0;
  overflow: hidden;
}
.top_feature_item--01 .top_feature_item_photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.top_feature_item--01 .top_feature_item_body {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 40px calc((100% - 1260px) / 2) 0px 0px;
  box-sizing: border-box;
}
.top_feature_item--01 .top_feature_item_titrow {
  display: flex;
  align-items: center;
  gap: 22px;
  padding-left: 40px;
}
.top_feature_item--01 .top_feature_item_sub {
  margin-top: auto;
  padding-top: 0;
}
/* ==========================
   Feature 02 & 03（横並び）
   ========================== */
.top_feature_row {
  position: relative;
  display: flex;
  gap: 60px;
  padding: 115px 23px 69px;
  min-width: 1200px;
}
.top_feature_item--02, .top_feature_item--03 {
  flex: 1;
  min-width: 0;
}
/* 写真エリア */
.top_feature_item--02 .top_feature_item_photo, .top_feature_item--03 .top_feature_item_photo {
  position: relative;
  height: 526px;
  overflow: hidden;
}
.top_feature_item--02 .top_feature_item_photo img, .top_feature_item--03 .top_feature_item_photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* サブタイトルバー：画像の下部に重ねる */
.top_feature_item--02 .top_feature_item_sub, .top_feature_item--03 .top_feature_item_sub {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 2;
}
.top_feature_item--02 .top_feature_item_sub .top_feature_maru, .top_feature_item--03 .top_feature_item_sub .top_feature_maru {
  width: 124px;
  height: auto;
  position: absolute;
  left: 16px;
  bottom: 13px;
  z-index: 3;
}
.top_feature_item--02 .top_feature_item_sub .top_feature_item_sub_text, .top_feature_item--03 .top_feature_item_sub .top_feature_item_sub_text {
  width: auto;
  height: auto;
  padding: 25px 32px 14px 156px;
  font-size: 26px;
  background: url(../images/tit_h3_feature.png) no-repeat center right;
  white-space: nowrap;
  height: 104px;
  width: 82%;
  text-align: center;
  letter-spacing: 0.1em;
}
/* 02/03 サブタイトル帯 中間ブレイクポイント（1850px〜641px） */
@media screen and (max-width: 1850px) and (min-width: 641px) {
  .top_feature_item--02 .top_feature_item_sub .top_feature_maru, .top_feature_item--03 .top_feature_item_sub .top_feature_maru {
    width: 80px;
    left: 10px;
    top: -20px;
  }
  .top_feature_item--02 .top_feature_item_sub .top_feature_item_sub_text, .top_feature_item--03 .top_feature_item_sub .top_feature_item_sub_text {
    padding: 25px max(24px, 2vw) 14px max(85px, 5vw);
    font-size: max(18px, 1.5vw);
    letter-spacing: 0.05em;
  }
}
/* コンテンツ */
.top_feature_item--02 .top_feature_item_body, .top_feature_item--03 .top_feature_item_body {
  padding: 38px 49px 0;
}
.top_feature_item--02 .top_feature_item_titrow, .top_feature_item--03 .top_feature_item_titrow {
  display: flex;
  align-items: center;
  gap: 24px;
}
.top_feature_item--02 .top_feature_number, .top_feature_item--03 .top_feature_number {
  height: 69px;
}
.top_feature_item--02 .top_feature_item_desc, .top_feature_item--03 .top_feature_item_desc {
  margin: 35px 0 0;
  padding-left: 0;
}
/* ==========================
   Feature 04〜09（3×2グリッド）
   ========================== */
.top_feature_grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  /*grid-template-rows: repeat(2, 586px);*/
	grid-template-rows: repeat(2, 660px);
  gap: 2px;
  min-width: 1200px;
}
.top_feature_grid_item {
  position: relative;
  overflow: hidden;
}
.top_feature_grid_bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.top_feature_grid_content {
  position: relative;
  z-index: 2;
  height: 100%;
  padding: 24px 20px 0;
  box-sizing: border-box;
}
.top_feature_grid_content p {
  color: #fff;
}
.top_feature_grid_content .list08 {
  background-color: rgba(255, 255, 255, 0.6);
  font-weight: bold;
  padding: 10px 30px;
}
.top_feature_grid_number {
  position: relative;
  height: 75px;
  width: auto;
  display: block;
  left: 20px;
  top: 20px;
}
.top_feature_grid_text {
  /* position: absolute;
  top: 440px;
  left: 20px;
  right: 20px; */
  margin: 0;
  font-size: 24px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  color: rgb(255, 255, 255);
  line-height: 1.5;
  text-align: center;
  letter-spacing: 0.1em;
  margin-bottom: 10px;
}
.top_feature_grid_number + .top_feature_grid_text {
  margin-top: 50px;
}
@media screen and (max-width: 1380px) and (min-width: 641px) {
  .top_feature_grid_text {
    font-size: 22px;
  }
}
/*==================================================================

  .top_flow（大腸カメラ検査の流れ）

==================================================================*/
.top_flow {
  position: relative;
  padding: 123px 0 180px;
  background: url(../images/top_flpw_bg.jpg) no-repeat top center / cover;
}
.top_flow_inner {
  width: 100%;
}
/* --- タイトル --- */
.top_flow_head {
  text-align: center;
  padding: 0 30px 56px;
}
.top_flow_en {
  display: inline-block;
  margin: 0;
  font-size: 104px;
  font-family: "trajan-pro-3", serif;
  font-weight: 400;
  font-style: normal;
  line-height: 1.2;
  letter-spacing: 0.05em;
  background-image: linear-gradient(to right, #abd39d, #1da66a);
  background-size: 100% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
@supports not (background-clip: text) {
  .top_flow_en {
    background: none;
    color: #1da66a;
    -webkit-text-fill-color: currentColor;
  }
}
.top_flow_h2 {
  margin: 9px 0 0;
  font-size: 24px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  font-weight: 600;
  color: rgb(51, 51, 51);
  line-height: 1.2;
  letter-spacing: 0.1em;
}
.top_flow_sub_head {
  max-width: 800px;
  margin: 0 auto 60px;
  text-align: center;
}
.top_flow_sub_head .tit02 {
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  font-weight: 600;
  margin-bottom: 15px;
  text-align: center;
}
.top_flow_sub_head p {
  font-size: 115%;
}
.top_flow_sub_head .tb02 {
  width: 80%;
  margin: 0 auto;
}
/* --- コンテンツエリア（1200px固定・左白/右青） --- */
.top_flow_content {
  width: 1200px;
  margin: 0 auto;
  background: linear-gradient(to right, #fff 70%, #eaf2fb 70%);
  padding: 73px 0 98px 40px;
  position: relative;
}
/* 1本の縦線：01の丸〜04の丸 */
.top_flow_content::before {
  content: "";
  position: absolute;
  top: 102px;
  bottom: 0;
  left: 179px;
  width: 1px;
  height: calc(100% - 425px);
  background: #9ab0a4;
  z-index: 0;
}
/* 04の丸より下の線を白で覆って消す */
.top_flow_item--last::after {
  content: "";
  position: absolute;
  top: 28px;
  bottom: 0;
  left: 111px;
  width: 3px;
  background: #fff;
  z-index: 0;
}
/* --- 各フローアイテム --- */
.top_flow_item {
  display: flex;
  gap: 51px;
  padding: 0 80px 57px 40px;
  position: relative;
}
.top_flow_item--last {
  padding-bottom: 20px;
}
/* 左カラム */
.top_flow_item_left {
  display: flex;
  gap: 0;
  flex: 1;
  min-width: 0;
}
/* ナンバー＋サークル */
.top_flow_item_num {
  display: flex;
  align-items: flex-start;
  gap: 13px;
  flex-shrink: 0;
  width: 130px;
  box-sizing: border-box;
}
.top_flow_number {
  height: auto;
  width: 74px;
  display: block;
}
.top_flow_circle {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 1;
  border-radius: 50%;
  padding: 20px 0 0;
}
.top_flow_circle img {
  width: 24px;
  height: auto;
  display: block;
}
/* テキスト */
.top_flow_item_text {
  flex: 1;
  min-width: 0;
  padding: 21px 0 0 10px;
}
.top_flow_item_tit {
  margin: 0;
  font-size: 24px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  color: rgb(51, 51, 51);
  line-height: 1.2;
  font-weight: 400;
  letter-spacing: 0.1em;
}
.top_flow_item_subtit {
  margin-top: 30px;
  font-size: 18px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  color: var(--main-color);
  line-height: 1.2;
  font-weight: 600;
  letter-spacing: 0.1em;
}
.top_flow_item_desc {
  margin: 20px 0 0;
  font-size: 15px;
  font-family: "YuGoPr6N", "Yu Gothic", "Hiragino Kaku Gothic ProN", sans-serif;
  color: rgb(51, 51, 51);
  line-height: 2;
  letter-spacing: 0.1em;
}
.box_style01 {
  background-color: var(--bg-color);
  padding: 20px;
  margin-bottom: 30px;
  width: 50%;
}
.box_style01 .top_flow_item_subtit {
  margin-top: 10px;
}
.top_flow_item_desc ul {
  margin-top: 15px;
}
/* 右カラム */
.top_flow_item_right {
  width: 400px;
  flex-shrink: 0;
}
.top_flow_item_img {
  width: 100%;
  height: auto;
  display: block;
}
.top_flow_youtube_wrap {
  position: relative;
  width: 100%;
  padding-bottom: 60%; /* 5:3 aspect ratio (same as flow photos 400x240) */
  overflow: hidden;
}
.top_flow_youtube_wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}
/* YouTube facade（遅延読み込み） */
.youtube-facade {
  cursor: pointer;
}
.youtube-facade_thumb {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.youtube-facade_play {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 68px;
  height: 48px;
  background: rgba(0, 0, 0, 0.7);
  border: none;
  border-radius: 14px;
  cursor: pointer;
  z-index: 1;
  transition: background 0.2s;
}
.youtube-facade_play::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(calc(-50% + 2px), -50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 10px 0 10px 18px;
  border-color: transparent transparent transparent #fff;
}
.youtube-facade:hover .youtube-facade_play {
  background: #f00;
}
/*==================================================================

  .top_price（費用）

==================================================================*/
.top_price {
  position: relative;
  padding: 181px 0;
  background: url(../images/top_price_bg_up.jpg) no-repeat top center, #f7f7f7;
}
.top_price_inner {
  width: 1200px;
  margin: 0 auto;
  padding: 140px 122px 115px;
  background: url(../images/top_price_contents_bg.png) no-repeat center / cover;
}
/* --- タイトル --- */
.top_price_head {
  text-align: center;
  padding: 0 0 32px;
}
.top_price_en {
  display: inline-block;
  margin: 0;
  font-size: 104px;
  font-family: "trajan-pro-3", serif;
  font-weight: 400;
  font-style: normal;
  line-height: 1.2;
  letter-spacing: 0.05em;
  background-image: linear-gradient(to right, #abd39d, #1da66a);
  background-size: 100% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
@supports not (background-clip: text) {
  .top_price_en {
    background: none;
    color: #1da66a;
    -webkit-text-fill-color: currentColor;
  }
}
.top_price_h2 {
  margin: 13px 0 0;
  font-size: 24px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  font-weight: 600;
  color: rgb(51, 51, 51);
  line-height: 1.2;
  letter-spacing: 0.02em;
}
/* --- リード文 --- */
.top_price_lead {
  margin: 0 0 58px;
  font-size: 16px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  color: rgb(51, 51, 51);
  line-height: 1.2;
  text-align: center;
}
/* --- セクション見出し --- */
.top_price_section_tit {
  margin: 0 0 39px;
  font-size: 24px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  font-weight: 400;
  line-height: 1.2;
  text-align: center;
  letter-spacing: 0.1em;
  padding: 7px 0;
  display: inline-block;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}
.top_price_section_tit--blue {
  border-bottom: 1px solid #0e3854;
  border-top: 1px solid #0e3854;
}
.top_price_section_tit--green {
  border-bottom: 1px solid #5bb67c;
  border-top: 1px solid #5bb67c;
}
.top_price_section_tit--blue {
  color: rgb(14, 56, 84);
}
.top_price_section_tit--green {
  color: rgb(74, 129, 97);
}
/* --- テーブル共通 --- */
.top_price_table_wrap {
  margin: 0 0 39px;
}
.top_price_table_wrap--green {
  margin-bottom: 60px;
}
.top_price_table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
  border: 1px solid #e6ebee;
}
.top_price_table th, .top_price_table td {
  vertical-align: middle;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  letter-spacing: 0.1em;
  border-left: 1px solid #e6ebee;
}
.top_price_table--blue th, .top_price_table--blue td {
  padding: 5px 20px;
  line-height: 1.8;
}
.top_price_table--green th, .top_price_table--green td {
  padding: 7px 20px;
  line-height: 1.8;
  border-left-color: #c7f6b7;
}
.top_price_table--green {
  border-color: #c7f6b7;
}
.top_price_table--green tbody tr {
  border-bottom-color: #c7f6b7;
}
.top_price_table th:first-child, .top_price_table td:first-child {
  border-left: none;
}
/* ヘッダー */
.top_price_table thead tr {
  color: rgb(255, 255, 255);
  font-size: 18px;
  line-height: 1.2;
  letter-spacing: 0.08em;
}
.top_price_table--blue thead tr {
  background: url(../images/top_price_table_blue.jpg) no-repeat center center / cover;
}
.top_price_table--green thead tr {
  background: url(../images/top_price_table_green.jpg) no-repeat center center / cover;
}
.top_price_th_sub {
  font-size: 14px;
}
.top_price_th_name {
  width: 22%;
  text-align: center;
}
.top_price_th_amount {
  width: 20%;
  text-align: center;
}
.top_price_th_note {
  width: 58%;
  text-align: center;
}
/* ボディ */
.top_price_table tbody tr {
  border-bottom: 1px solid #e6ebee;
  background: #fff;
}
.top_price_td_name {
  font-size: 16px;
  color: rgb(51, 51, 51);
  line-height: 1.375;
  text-align: center;
}
.top_price_td_amount {
  font-size: 28px;
  color: rgb(108, 87, 58);
  line-height: 1.4;
  text-align: center;
  white-space: nowrap;
}
.top_price_td_amount--green {
  color: rgb(45, 112, 74);
}
.top_price_yen_prefix {
  font-size: 16px;
}
.top_price_yen_suffix {
  font-size: 16px;
}
.top_price_td_note {
  font-size: 15px;
  font-family: "YuGoPr6N", "Yu Gothic", "Hiragino Kaku Gothic ProN", sans-serif;
  color: rgb(51, 51, 51);
  line-height: 2.2;
  text-align: left;
}
.top_price_note_amount {
  font-size: 24px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  font-weight: 400;
  letter-spacing: 0.05em;
}
.top_price_note_amount--green {
  color: rgb(45, 112, 74);
}
.top_price_note_amount .top_price_yen_prefix {
  font-size: 14px;
}
.top_price_note_amount .top_price_yen_suffix {
  font-size: 16px;
}
/* --- 注釈 --- */
.top_price_note {
  margin: 0 0 69px;
  padding: 0 0px;
}
.top_price_note_text {
  margin: 0;
  font-size: 16px;
  font-family: "YuGoPr6N", "Yu Gothic", "Hiragino Kaku Gothic ProN", sans-serif;
  color: rgb(108, 87, 58);
  line-height: 1.75;
  letter-spacing: 0.03em;
}
.top_price_note_title {
  margin: 0 0 8px;
  font-size: 16px;
  color: #6c573a;
  letter-spacing: 0.1em;
  line-height: 1.75;
}
.top_price_note_desc {
  margin: 0 0 16px;
  font-size: 15px;
  color: #333;
  line-height: 1.75;
}
.top_price_note_ref {
  margin: 0;
  font-size: 14px;
  color: #333;
  line-height: 1.75;
}
/* --- クレジットカード --- */
.top_price_card {
  margin-top: 79px;
  text-align: center;
  padding: 50px 0;
  background: #fff;
}
.top_price_card_text {
  margin: 0 0 33px;
  font-size: 16px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  color: rgb(51, 51, 51);
  line-height: 1.2;
  letter-spacing: 0.1em;
}
/*==================================================================

  .top_info

==================================================================*/
/* ↓↓↓見た目確認用↓↓↓ */
.top_info:not(.top_info2) {
  background: #f3f3f3;
}
.top_info:not(.top_info2) .top_info_flex {
  padding: 64px 0;
}
/* ↑↑↑見た目確認用↑↑↑ */
.top_info_flex {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.top_info_item {
  width: 49%;
}
/********************************
  .top_news お知らせ
*********************************/
/* 旧仕様 */
.top_news_frame {
  padding: 35px 33px;
  border: 15px solid #F0F0F0;
}
.top_news_headline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}
.top_info .top_news .top_news_frame {
  border: none;
  background: #fff;
  padding: 20px 12px;
}
/* お知らせの高さ */
.top_info .top_news .scroll_area {
  height: 285px;
  overflow-y: scroll;
}
.top_info .top_news ul {
  padding-right: 24px;
}
.news_list li {
  margin-bottom: 10px;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.news_list li span {
  margin-right: 5px;
}
.news_list li em {
  margin-right: 5px;
  display: inline-block;
  min-width: 75px;
  padding: 1px 6px;
  font-style: normal;
  text-align: center;
}
/*スクロールバーの横幅指定*/
.scroll_area::-webkit-scrollbar {
  width: 5px;
}
/*スクロールバーの背景色・角丸指定*/
.scroll_area::-webkit-scrollbar-track {
  border-radius: 10px;
  background: #fff;
}
/*スクロールバーの色・角丸指定*/
.scroll_area::-webkit-scrollbar-thumb {
  border-radius: 10px;
  background: #ccc;
}
/********************************
  .top_sche 診療時間
*********************************/
.top_sche .sub_info_note li {
  color: var(--main-color);
  text-align: center;
  padding: 10px 5px;
  border: 1px solid var(--main-color);
  margin-bottom: 12px;
}
/* 補足リスト */
.top_sche .sub_info_note li:last-child {
  margin-bottom: 0;
}
.top_info2 .top_sche {
  border-radius: 10px;
  padding: 12px;
  background-color: rgba(192, 171, 154, 0.3);
}
/* 診療科目、お問い合わせリスト */
.top_sche_note {
  margin-top: 10px;
}
.top_sche_note dl {
  display: flex;
  margin-bottom: 12px;
}
.top_sche_note dl:last-child {
  margin-bottom: 0;
}
.top_sche_note dl dt {
  width: 25%;
  text-align: center;
  color: #fff;
  font-weight: 700;
  font-weight: bold;
  padding: 16px 5px;
  background: #C0AB9A;
  border-radius: 10px;
  margin-right: 2%;
}
.top_sche_note dl dd {
  width: 73%;
  display: flex;
  align-items: center;
  padding: 10px;
  background: #fff;
  border-radius: 10px;
}
.top_sche_note dl dd a {
  color: inherit;
}
.top_sche_note dl dd a:hover {
  color: inherit;
}
/********************************
  .top_access アクセス
*********************************/
.top_info2 .top_access {
  border-radius: 10px;
  background-color: rgba(192, 171, 154, 0.3);
}
.top_access {
  padding: 12px;
}
.top_access .map {
  position: relative;
}
.top_access .map .btn01 {
  position: absolute;
  top: auto;
  right: 0;
  bottom: 0;
  margin-bottom: 0;
}
.top_access .map img {
  width: 100%;
  /* 下記はサンプル画像が正方形のため調整用に記載しています */
  height: 320px;
  object-fit: cover;
  object-position: center;
}
.top_access p {
  margin-top: 10px;
}
/*==================================================================

  .top_doctor

==================================================================*/
.top_doctor_flex {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.top_doctor_flex .text {
  position: relative;
  width: 70%;
}
.top_doctor_name {
  color: var(--main-color);
  line-height: 1.4;
  font-weight: bold;
}
.top_doctor_name span {
  font-size: 30px;
}
.top_doctor_img {
  width: 28%;
}
.top_doctor_img img {
  width: 100%;
}
.top_doctor .btn01 {
  float: right;
  width: 240px;
}
.top_doctor .btn01 a {
  display: block;
}
/*==================================================================

  .top_medical

==================================================================*/
.top_medical .text p {
  text-align: center;
}
.top_medical_list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.top_medical_list a {
  display: block;
  width: 22%;
  margin-bottom: 20px;
  text-align: center;
}
.top_medical_list a img {
  width: 100%;
}
.top_medical_list dl {
  width: 100%;
}
.top_medical_list dl dt {
  margin-bottom: 7px;
}
.top_medical_list dl dd {
  font-weight: bold;
}
/*==================================================================

  .top_medical2

==================================================================*/
.top_medical2 .text p {
  text-align: center;
}
.top_medical2_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.top_medical2_list a {
  display: block;
  width: 120px;
  margin-right: 17.14px;
  margin-bottom: 20px;
  text-align: center;
}
.top_medical2_list a:last-child {
  margin-right: 0;
}
.top_medical2_list dl {
  width: 100%;
}
.top_medical2_list dl dt {
  margin-bottom: 7px;
}
.top_medical2_list img {
  width: 100%;
}
.top_medical2_list dl dd {
  font-weight: bold;
}
/*==================================================================

  .top_medical3

==================================================================*/
.top_medical3 .text p {
  text-align: center;
}
.top_medical3_list ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.top_medical3_list li {
  width: 120px;
  margin-right: 17.14px;
  margin-bottom: 20px;
  text-align: center;
}
.top_medical3_list li:last-child {
  margin-right: 0;
}
.top_medical3_list img {
  width: 100%;
}
/*==================================================================

  .top_medical4

==================================================================*/
.top_medical4 {
  padding-top: 80px;
}
.top_medical4_list {
  width: 980px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.top_medical4_list dl {
  position: relative;
  width: 270px;
  text-align: center;
  margin-bottom: 30px;
}
.top_medical4_list a {
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
}
.top_medical4_list dt img {
  width: 100%;
  border-radius: 100%;
}
/*==================================================================

  .loop_slide

==================================================================*/
.loop_slide_wrap .slick-slider div {
  transition: none;
}
.loop_slide_wrap .slick-list {
  overflow: hidden !important;
}
.loop_slide_wrap .slick-initialized .slick-slide {
  height: auto;
}
.loop_slide_wrap .slick-initialized .slick-slide img {
  width: 400px;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}
.loop_slide_wrap .slick-initialized .slick-slide:focus {
  outline: none;
}
/*==================================================================================================================

  スマホ

==================================================================================================================*/
@media screen and (max-width:640px) {
  #wrapper, html, body {
    min-height: 500px;
  }
  /*==================================================================

    メインビジュアル（スマホ）

  ==================================================================*/
  .top_mainvisual {
    /*height: calc(100vh - 108px);*/
    height: 100vh;
  }
  .top_mainvisual::before {
    width: 100%;
    height: 100%;
    top: -130px;
    background-size: cover;
    background-position: center;
  }
  .mainvisual_wrap {
    /*height: calc(100vh - 180px);*/
    height: 100vh;
    margin-bottom: 0;
  }
  .mainvisual_bg_img {
    /*height: calc(100vh - 180px);*/
    height: 100vh;
  }
  .mainvisual_overlay {
    max-width: none;
    padding: 0 5%;
  }
  .mainvisual_catch {
    top: 50%;
    width: 100%;
    text-align: center;
    left: 0;
    right: 0;
    margin: auto;
  }
  .mainvisual_catch img {
    max-width: 90vw;
  }
  .mainvisual_sub_catch p {
    font-size: 90%;
  }
  .mainvisual_sub_catch .title::before, .mainvisual_sub_catch .title::after {
    height: 11px;
  }
  .mainvisual_sub_catch .list08 {
    margin: 8px auto;
    font-size: 90%;
  }
  /* .top_trouble（スマホ） */
  .top_trouble {
    padding-top: 32px;
    margin-top: 0;
    --top-trouble-bg-start: 72px;
    background: #cdd4da;
  }
  .top_trouble_inner {
    padding: 0 16px 48px;
  }
  .top_trouble_head {
    align-items: center;
  }
  .top_trouble_en {
    font-size: clamp(40px, 12vw, 72px);
    margin-top: -0.38em;
  }
  .top_trouble_label_box {
    width: auto;
    min-height: 40px;
    margin-top: 0.5em;
    margin-left: 0;
    margin-right: 0;
    align-self: center;
  }
  .top_trouble_label {
    font-size: clamp(16px, 4.2vw, 21px);
  }
  .top_trouble_h2 {
    font-size: 19px;
    margin: 20px 0 0 0;
    text-align: center;
    align-self: center;
  }
  .top_trouble_list {
    max-width: none;
    margin-top: 28px;
  }
  .top_trouble_list li {
    font-size: clamp(15px, 3.8vw, 20px);
  }
  /* .top_colonoscopy_wrap（スマホ） */
  .top_colonoscopy_wrap {
    width: 100%;
    margin-left: 0;
    margin-right: 0;
  }
  /* .top_colonoscopy_subtitle（スマホ） */
  .top_colonoscopy_subtitle {
    padding: 48px 16px;
  }
  .top_colonoscopy_subtitle::before {
    display: none;
  }
  .top_colonoscopy_en {
    font-size: clamp(36px, 14vw, 80px);
  }
  .top_colonoscopy_text {
    font-size: clamp(18px, 5.5vw, 28px);
    text-align: left;
  }
  /* .top_merit（スマホ） */
  .top_merit {
    width: 100%;
    margin-left: 0;
  }
  .top_merit_row {
    min-height: 0;
    flex-direction: column;
  }
  .top_merit_photo {
    position: relative;
    width: 100%;
    height: 220px;
  }
  .top_merit_body {
    margin-left: 0;
    width: 100%;
    min-height: 0;
    max-height: none;
    padding: 4px 20px 32px;
  }
  .top_merit_body::before {
    left: 0;
    clip-path: none;
  }
  .top_merit_head {
    align-items: center;
  }
  .top_merit_en {
    font-size: clamp(40px, 12vw, 64px);
  }
  .top_merit_h2 {
    /* font-size: 21px;
    text-align: center; */
    padding-left: 0;
  }
  .top_merit_list_wrap {
    margin-top: 20px;
    padding: 24px 16px;
  }
  /* 斜め三角を非表示 */
  .top_merit_list_wrap::after {
    display: none;
  }
  /* 背景を真四角に */
  .top_merit_list_wrap::before {
    width: 100%;
    left: 0;
    right: 0;
  }
  .top_merit_list li {
    font-size: clamp(14px, 3.6vw, 16px);
    margin-bottom: 18px;
    padding-left: 1.8em;
  }
  .top_merit_list li::before {
    width: 18px;
    height: 18px;
  }
  /* .top_contact（スマホ） */
  .top_contact_inner {
    min-width: 0;
    width: 100%;
    gap: 2px;
  }
  .top_contact_head_cell {
    padding: 32px 16px 20px;
  }
  .top_contact_en {
    font-size: clamp(36px, 12vw, 64px);
  }
  .top_contact_h2 {
    font-size: 21px;
    margin-top: 12px;
    text-align: center;
  }
  .top_contact_grid {
    /* flex-direction: column; */
    flex-wrap: wrap;
  }
  .top_contact_cell {
    padding: 24px /*16*/ 10px;
    width: calc(100% / 2 - 2px);
    flex: none;
  }
  .top_contact_cell:last-child {
    width: 100%;
  }
  .top_contact_cell_content {
    max-width: 100%;
  }
  .top_contact_cell_tit {
    font-size: clamp(18px, 5vw, 24px);
  }
  .top_contact_cell_desc {
    font-size: 14px;
    margin-top: 16px;
    line-height: 1.6;
  }
  .top_contact_cell_btns {
    max-width: 100%;
  }
  .top_contact_btn {
    font-size: /*15*/ 14px;
    padding: 10px 7px 10px 10px;
    max-width: 320px;
    margin: 0 auto;
  }
  .top_contact_cell:last-child .top_contact_btn {
    /*padding-left: 80px;*/
  }
  .top_contact_tel {
    font-size: clamp(18px, 5.5vw, 24px);
  }
  .top_contact_tel_icon {
    width: 26px;
    padding-top: 5px;
  }
  .top_contact_hours_label {
    font-size: 14px;
    padding: 2px 20px;
  }
  #link_contact02 {
    padding-bottom: 56px;
  }
  /* .top_feature（スマホ） */
  .top_feature {
    min-width: 0;
    padding-bottom: 40px;
  }
  .top_feature::before {
    display: none;
  }
  .top_feature_head {
    padding: 60px 16px 40px;
  }
  .top_feature_en {
    font-size: clamp(40px, 14vw, 80px);
  }
  .top_feature_h2 {
    font-size: 21px;
    text-align: center;
  }
  /* --- Feature 01（スマホ） --- */
  .top_feature_item--01 {
    flex-direction: column;
    min-width: 0;
    min-height: 0;
  }
  .top_feature_item--01 .top_feature_item_photo {
    width: 100%;
    height: 220px;
  }
  .top_feature_item--01 .top_feature_item_body {
    padding: 20px 16px 24px;
  }
  .top_feature_item--01 .top_feature_item_titrow {
    padding-left: 0;
    gap: 12px;
  }
  .top_feature_item--01 .top_feature_item_sub {
    margin-top: 20px;
  }
  .top_feature_item--01 .top_feature_item_sub_text {
    background: #294b62;
  }
  .top_feature_maru {
    width: 64px;
  }
  .top_feature_number {
    height: 36px;
  }
  .top_feature_item_tit {
    font-size: clamp(16px, 4.2vw, 22px);
  }
  .top_feature_item_tit br {
    display: none;
  }
  .top_feature_item_desc {
    font-size: 14px;
    margin: 12px 0 0;
    padding-left: 0;
    line-height: 1.8;
  }
  .top_feature_item_sub_icon {
    width: 40px;
    height: 40px;
    margin-right: 8px;
  }
  .top_feature_item_sub_icon img {
    width: 60%;
  }
  .top_feature_item_sub_text {
    font-size: clamp(14px, 4vw, 20px);
    padding: 12px 16px;
    width: 100%;
    height: auto;
    background-size: cover;
    white-space: normal;
    box-sizing: border-box;
  }
  /* --- Feature 02 & 03（スマホ） --- */
  .top_feature_row {
    flex-direction: column;
    gap: 30px;
    padding: 30px 16px 40px;
    min-width: 0;
  }
  .top_feature_item--02 .top_feature_item_photo, .top_feature_item--03 .top_feature_item_photo {
    height: 220px;
  }
  .top_feature_item--02 .top_feature_item_sub .top_feature_maru, .top_feature_item--03 .top_feature_item_sub .top_feature_maru {
    width: 64px;
    left: 8px;
    bottom: 8px;
  }
  .top_feature_item--02 .top_feature_item_sub .top_feature_item_sub_text, .top_feature_item--03 .top_feature_item_sub .top_feature_item_sub_text {
    width: 100%;
    height: auto;
    padding: 14px 16px 14px 80px;
    font-size: clamp(14px, 4vw, 20px);
    background-size: cover;
    white-space: normal;
    text-align: left;
  }
  .top_feature_item--02 .top_feature_item_body, .top_feature_item--03 .top_feature_item_body {
    padding: 20px 16px 0;
  }
  .top_feature_item--02 .top_feature_item_titrow, .top_feature_item--03 .top_feature_item_titrow {
    gap: 12px;
  }
  .top_feature_item--02 .top_feature_number, .top_feature_item--03 .top_feature_number {
    height: 36px;
  }
  .top_feature_item--02 .top_feature_item_desc, .top_feature_item--03 .top_feature_item_desc {
    margin: 12px 0 0;
    font-size: 14px;
    line-height: 1.8;
  }
  /* --- Feature 04〜09 グリッド（スマホ：2列） --- */
  .top_feature_grid {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: auto;
    min-width: 0;
  }
  .top_feature_grid_content {
    padding: 16px 12px 16px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }
  .top_feature_grid_content .list08 {
    padding: 10px;
  }
  .top_feature_grid_number {
    height: 32px;
  }
  .top_feature_grid_text {
    position: static;
    margin-top: auto;
    margin-bottom: 20px;
    font-size: clamp(13px, 3.6vw, 18px);
    line-height: 1.5;
  }
  .top_feature_grid_text br {
    display: none;
  }
  .mainvisual_banners {
    /*bottom: 24px;*/
    flex-direction: column;
    gap: 10px;
    padding: 5%;
    align-items: center;
    position: relative;
    bottom: 0;
  }
  .mainvisual_bnr01 {
    top: 0;
  }
  .mainvisual_bnr01 {
    max-width: 200px;
    margin: auto;
  }
  .mainvisual_bnr02 {
    max-width: 300px;
    margin: 10px auto 0;
  }
  .mv_catch_list {
    display: flex !important;
    width: 100%;
    position: static;
    margin-top: 0;
    flex-wrap: wrap;
    gap: 10px 2%;
    justify-content: center;
    padding: 35px 3%;
  }
  .mv_catch_item:nth-child(1), .mv_catch_item:nth-child(2) {
    width: 40%;
  }
  .mv_catch_item {
    width: 32%;
  }
  /*==================================================================

    .top_info（スマホ）

  ==================================================================*/
  .news_list li a {
    display: block;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
  }
  .top_info_item {
    width: 100%;
    margin-top: 40px;
  }
  .top_info_item:first-child {
    margin-top: 0;
  }
  .top_info .top_news .scroll_area {
    height: 200px;
  }
  /*==================================================================

    .top_doctor（スマホ）

  ==================================================================*/
  .top_doctor_flex {
    flex-direction: column-reverse;
  }
  .top_doctor .text {
    width: auto;
  }
  .top_doctor_img {
    width: auto;
    margin-bottom: 15px;
  }
  .top_doctor_img p {
    text-align: center;
  }
  .top_doctor_img p img {
    width: 60%;
    margin: 0 auto 15px;
    display: block;
  }
  /*==================================================================

    .top_medical2（スマホ）

  ==================================================================*/
  .top_medical2_list a {
    width: 46%;
    margin-right: 8%;
  }
  .top_medical2_list a:nth-child(even) {
    margin-right: 0;
  }
  /*==================================================================

    .top_medical3（スマホ）

  ==================================================================*/
  .top_medical3_list li {
    width: 46%;
    margin-right: 8%;
  }
  .top_medical3_list li:nth-child(even) {
    margin-right: 0;
  }
  /*==================================================================

    .top_medical4（スマホ）

  ==================================================================*/
  .top_medical4_list {
    width: auto;
    margin: 0 8%;
  }
  .top_medical4_list dl {
    width: 45%;
    margin-right: 0;
  }
  /*==================================================================

    .top_flow（スマホ）

  ==================================================================*/
  .top_flow {
    padding: 60px 0 60px;
  }
  .top_flow_head {
    padding: 0 16px 32px;
  }
  .top_flow_en {
    font-size: clamp(40px, 14vw, 80px);
  }
  .top_flow_h2 {
    font-size: 21px;
    text-align: center;
  }
  .top_flow_content {
    width: 100%;
    padding: 32px 16px;
    background: #fff;
    box-sizing: border-box;
  }
  .box_style01 {
    width: 100%;
  }
  /* 縦線を非表示 */
  .top_flow_content::before {
    display: none;
  }
  .top_flow_item--last::after {
    display: none;
  }
  /* 各アイテム：縦積み */
  .top_flow_item {
    flex-direction: column;
    gap: 16px;
    padding: 0 0 32px;
  }
  .top_flow_item--last {
    padding-bottom: 0;
  }
  .top_flow_item_left {
    flex-direction: column;
  }
  .top_flow_item_num {
    width: auto;
    gap: 8px;
  }
  .top_flow_number {
    width: 52px;
  }
  /* 丸（サークル）を非表示 */
  .top_flow_circle {
    display: none;
  }
  .top_flow_item_text {
    padding: 8px 0 0 0;
  }
  .top_flow_item_tit {
    font-size: 20px;
  }
  .top_flow_item_desc {
    font-size: 14px;
    margin-top: 12px;
    line-height: 1.8;
  }
  .top_flow_item_right {
    width: 100%;
  }
  .top_flow_youtube_wrap {
    padding-bottom: 60%;
  }
  /*==================================================================

    .top_price（スマホ）

  ==================================================================*/
  .top_price {
    padding: 60px 0;
  }
  .top_price_inner {
    width: 100%;
    padding: 40px 16px;
    box-sizing: border-box;
    background-size: cover;
  }
  .top_price_head {
    padding: 0 0 20px;
  }
  .top_price_en {
    font-size: clamp(40px, 14vw, 80px);
  }
  .top_price_h2 {
    font-size: 21px;
    text-align: center;
  }
  .top_price_lead {
    font-size: 14px;
    margin-bottom: 32px;
    line-height: 1.6;
  }
  .top_price_section_tit {
    font-size: 18px;
    margin-bottom: 20px;
    padding: 6px 12px;
  }
  /* テーブルをカード型に変換 */
  .top_price_table_wrap {
    margin-bottom: 24px;
  }
  .top_price_table {
    table-layout: auto;
  }
  /* theadを非表示 */
  .top_price_table thead {
    display: none;
  }
  .top_price_table, .top_price_table tbody, .top_price_table tr, .top_price_table td {
    display: block;
    width: 100%;
    box-sizing: border-box;
  }
  /* 各行をカードに */
  .top_price_table tbody tr {
    margin-bottom: 16px;
    padding: 0;
    background: #fff;
    border: 1px solid #d5d5d5;
    border-bottom: 1px solid #d5d5d5;
  }
  .top_price_table--blue td, .top_price_table--green td {
    padding: 10px 14px;
    line-height: 1.6;
    border-left: none;
  }
  /* 検査名：カード上部のヘッダー風に */
  .top_price_td_name {
    font-size: 15px;
    font-weight: 600;
    background: #f5f5f5;
    border-bottom: 1px solid #e0e0e0;
    text-align: left;
  }
  .top_price_table--blue .top_price_td_name {
    background: #eaf2f7;
  }
  .top_price_table--green .top_price_td_name {
    background: #edf7f0;
  }
  /* 金額 */
  .top_price_td_amount {
    font-size: 22px;
    text-align: left;
  }
  .top_price_td_amount::before {
    content: "金額：";
    font-size: 13px;
    color: #666;
    vertical-align: middle;
  }
  .top_price_yen_prefix {
    font-size: 14px;
  }
  .top_price_yen_suffix {
    font-size: 14px;
  }
  /* 備考 */
  .top_price_td_note {
    font-size: 13px;
    line-height: 1.7;
    color: #555;
    border-top: 1px solid #eee;
  }
  .top_price_note_amount {
    font-size: 18px;
  }
  .top_price_note {
    margin-bottom: 40px;
  }
  .top_price_note_text {
    font-size: 13px;
    line-height: 1.6;
  }
  .top_price_card {
    margin-top: 40px;
    padding: 24px 16px;
  }
  .top_price_card_text {
    font-size: 14px;
    margin-bottom: 20px;
  }
}
/*==================================================================

  .top_faq（よくあるご質問）

==================================================================*/
.top_faq {
  position: relative;
  padding: 146px 0 159px;
  margin-bottom: 770px;
}
.top_faq::before {
  position: absolute;
  content: "";
  background: url(../images/top_faq_under_img.jpg) no-repeat center / cover;
  width: 100%;
  height: 770px;
  bottom: -770px;
  left: 0;
}
.top_faq_bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  background: linear-gradient(to right, #d7e2d9 0%, #d7e2d9 42%, #e8e8e8 42%, #e8e8e8 100%);
}
.top_faq_inner {
  position: relative;
  z-index: 1;
  width: 1200px;
  margin: 0 auto;
}
/* --- タイトル --- */
.top_faq_head {
  text-align: center;
  padding: 0 0 87px;
}
.top_faq_en {
  display: inline-block;
  margin: 0;
  font-size: 104px;
  font-family: "trajan-pro-3", serif;
  font-weight: 400;
  font-style: normal;
  line-height: 1.2;
  letter-spacing: 0.05em;
  background-image: linear-gradient(to right, #abd39d, #1da66a);
  background-size: 100% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  padding: 0 65px;
}
@supports not (background-clip: text) {
  .top_faq_en {
    background: none;
    color: #1da66a;
    -webkit-text-fill-color: currentColor;
  }
}
.top_faq_h2 {
  margin: 13px 0 0;
  font-size: 24px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  font-weight: 600;
  color: rgb(51, 51, 51);
  line-height: 1.2;
  letter-spacing: 0.02em;
}
/* --- アコーディオン --- */
.top_faq_list {
  display: flex;
  flex-direction: column;
}
.top_faq_item {
  margin-bottom: 40px;
}
.top_faq_item:last-child {
  margin-bottom: 0;
}
.top_faq_q {
  display: flex;
  align-items: center;
  padding: 20px 25px;
  cursor: pointer;
  background: #fff;
  transition: background 0.3s;
  position: relative;
}
.top_faq_item.is-open .top_faq_q {
  background: #1da66a;
}
.top_faq_item.is-open .top_faq_q_icon {
  color: #fff;
}
.top_faq_item.is-open .top_faq_q_text {
  color: #fff;
}
.top_faq_item.is-open .top_faq_toggle::before, .top_faq_item.is-open .top_faq_toggle::after {
  background: #fff;
}
.top_faq_q_icon {
  flex-shrink: 0;
  font-size: 40px;
  font-family: "trajan-pro-3", serif;
  font-weight: 400;
  font-style: normal;
  color: #82c68e;
  line-height: 1;
  margin-right: 20px;
  width: 50px;
  text-align: center;
}
.top_faq_q_text {
  flex: 1;
  font-size: 20px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  color: #333;
  line-height: 1.5;
  margin: 0;
}
.top_faq_toggle {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  position: relative;
  margin-left: 20px;
}
.top_faq_toggle::before, .top_faq_toggle::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  background: #82c68e;
  transition: transform 0.3s, background 0.3s;
}
.top_faq_toggle::before {
  width: 24px;
  height: 2px;
  transform: translate(-50%, -50%);
}
.top_faq_toggle::after {
  width: 2px;
  height: 24px;
  transform: translate(-50%, -50%);
}
.top_faq_item.is-open .top_faq_toggle::after {
  transform: translate(-50%, -50%) rotate(90deg);
}
.top_faq_a {
  display: flex;
  align-items: flex-start;
  padding: 0 25px;
  max-height: 0;
  overflow: hidden;
  background: transparent;
  transition: max-height 0.4s ease, padding 0.4s ease;
}
.top_faq_item.is-open .top_faq_a {
  max-height: 300px;
  padding: 31px 55px 0px;
}
.top_faq_a_icon {
  flex-shrink: 0;
  font-size: 40px;
  font-family: "trajan-pro-3", serif;
  font-weight: 400;
  font-style: normal;
  color: rgb(213, 172, 113);
  line-height: 1;
  margin-right: 20px;
  width: 50px;
  text-align: center;
}
.top_faq_a_text {
  flex: 1;
  font-size: 16px;
  font-family: "YuGoPr6N", "Yu Gothic", "Hiragino Sans", "Hiragino Kaku Gothic ProN", sans-serif;
  color: rgb(51, 51, 51);
  line-height: 1.8;
  margin: 0;
  padding-top: 10px;
}
/*==================================================================

  .top_base（拠点）

==================================================================*/
.top_base {
  padding: 137px 0 172px;
  background: #f8f7f8;
}
.top_base_inner {
  max-width: 1300px;
  min-width: 1200px;
  margin: 0 auto;
}
/* --- タイトル --- */
.top_base_head {
  text-align: center;
  padding: 0 0 27px;
}
.top_base_en {
  display: inline-block;
  margin: 0;
  font-size: 104px;
  font-family: "trajan-pro-3", serif;
  font-weight: 400;
  font-style: normal;
  line-height: 1.2;
  letter-spacing: 0.05em;
  background-image: linear-gradient(to right, #abd39d, #1da66a);
  background-size: 100% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
@supports not (background-clip: text) {
  .top_base_en {
    background: none;
    color: #1da66a;
    -webkit-text-fill-color: currentColor;
  }
}
.top_base_h2 {
  margin: 13px 0 0;
  font-size: 24px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  font-weight: 600;
  color: rgb(51, 51, 51);
  line-height: 1.2;
  letter-spacing: 0.02em;
}
/* --- リード文 --- */
.top_base_lead {
  margin: 0 0 48px;
  font-size: 16px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  color: rgb(51, 51, 51);
  line-height: 2;
  text-align: center;
  letter-spacing: 0.15em;
}
/* --- クリニック一覧 --- */
.top_base_list {
  display: flex;
  flex-direction: column;
  gap: 50px;
  justify-content: center;
}
@media screen and (min-width:641px) {
  .top_base_list {
    flex-direction: unset;
  }
}
.top_base_item {
  display: flex;
  /*align-items: flex-start;*/
  padding: 51px;
  gap: 30px;
  background: #fff;
  flex-direction: column;
  width: 50%;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  font-weight: 400;
}
/* --- ロゴ（SP時のみ表示） --- */
.top_base_logo {
  font-size: 20px;
  letter-spacing: 0.1em;
  line-height: 1.5;
  font-family: "dnp-shuei-mincho-pr6n", sans-serif;
  font-weight: 500;
  font-style: normal;
  text-align: left;
  white-space: nowrap;
  max-width: 400px;
  margin: 0 0 30px;
}
/* --- 動画 --- */
.top_base_movie {
  flex-shrink: 0;
  width: 473px;
  margin: 0 auto;
}
.top_base_movie iframe {
  width: 100%;
  height: 296px;
  display: block;
}
.top_base_movie--placeholder {
  background: #e0e0e0;
  height: 296px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.top_base_movie--placeholder::before {
  content: '';
  width: 60px;
  height: 60px;
  background: rgba(0, 0, 0, 0.45);
  border-radius: 50%;
}
.top_base_movie--placeholder::after {
  content: '';
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(calc(-50% + 3px), -50%);
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 12px 0 12px 20px;
  border-color: transparent transparent transparent #fff;
}
/* --- クリニック情報 --- */
.top_base_info {
  flex: 1;
}
.top_base_name {
  margin: 0 0 20px;
  font-size: 20px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  font-weight: 400;
  color: rgb(0, 0, 0);
  line-height: 1.2;
  height: 53px;
}
.top_base_name span {
  display: block;
  font-size: 85%;
}
.top_base_detail {
  margin-bottom: 23px;
}
.top_base_label {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 10px;
  font-size: 18px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  color: rgb(51, 51, 51);
  line-height: 1.2;
}
.top_base_label img {
  width: 18px;
  height: auto;
}
.top_base_text {
  margin: 0;
  font-size: 16px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  color: rgb(51, 51, 51);
  line-height: 1.8;
}
/* --- 地図・路線図 --- */
.top_base_map {
  flex-shrink: 0;
  width: 410px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.top_base_map img {
  width: 100%;
  height: auto;
}
/*==================================================================

  GREETING（理事長メッセージ）

==================================================================*/
.top_greeting {
  padding: 155px 0 164px;
  background: url(../images/top_greeting_bg.jpg) no-repeat center / cover;
}
.top_greeting_inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
  box-sizing: content-box;
}
.top_greeting .tit02 {
  padding: 0 0 14px 0;
  font-size: 19px;
  margin-bottom: 0;
  font-family: "dnp-shuei-mincho-pr6n", sans-serif;
  font-weight: 500;
  font-style: normal;
}
/* --- タイトル（左寄せ） --- */
.top_greeting_head {
  text-align: left;
  padding: 0 0 65px;
}
.top_greeting_en {
  display: inline-block;
  margin: 0;
  font-size: 104px;
  font-family: "trajan-pro-3", serif;
  font-weight: 400;
  font-style: normal;
  line-height: 1.2;
  letter-spacing: 0.05em;
  background-image: linear-gradient(to right, #abd39d, #1da66a);
  background-size: 100% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
@supports not (background-clip: text) {
  .top_greeting_en {
    background: none;
    color: #1da66a;
    -webkit-text-fill-color: currentColor;
  }
}
.top_greeting_h2 {
  margin: 13px 0 0;
  font-size: 24px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  font-weight: 600;
  color: rgb(51, 51, 51);
  line-height: 1.2;
  letter-spacing: 0.02em;
}
/* --- 2カラムレイアウト --- */
.top_greeting_body {
  /* display: flex;*/
  gap: 60px;
  align-items: flex-start;
  justify-content: space-between;
}
/* 左カラム：本文 */
.top_greeting_text {
  /*width: 54%;*/
  flex-shrink: 0;
  width: 100%;
}
.top_greeting_text p {
  font-size: 16px;
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  color: rgb(51, 51, 51);
  line-height: 2.438;
  text-align: left;
  margin: 0 0 40px;
  letter-spacing: 0.1em;
}
.top_greeting_text p:last-child {
  margin-bottom: 0;
  margin-top: 80px;
}
/* 右カラム：写真＋名前 */
.top_greeting_photo {
  position: relative;
  width: 38%;
  flex-shrink: 0;
  text-align: center;
  top: -56px;
  float: right;
  margin-left: 80px;
}
.top_greeting_img {
  width: 100%;
  height: auto;
}
.top_greeting_name {
  margin-top: 33px;
}
.top_greeting_name_line {
  font-family: "ShueiMinPr6", "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", serif;
  color: rgb(51, 51, 51);
  line-height: 1.6;
  margin: 0;
  display: flex;
  align-items: baseline;
  justify-content: center;
}
.top_greeting_name_line + .top_greeting_name_line {
  margin-top: 1px;
}
.top_greeting_label {
  font-size: 16px;
}
.top_greeting_value {
  font-size: 25px;
}
/*==================================================================

  スマホ追加（FAQ・拠点・理事長メッセージ）

==================================================================*/
@media screen and (max-width: 640px) {
  /*==================================================================

    .top_faq（スマホ）

  ==================================================================*/
  .top_faq {
    padding: 60px 0 40px;
    margin-bottom: 300px;
  }
  /* 下の画像を縮小 */
  .top_faq::before {
    height: 300px;
    bottom: -300px;
  }
  /* 背景グラデを全幅均一に */
  .top_faq_bg {
    background: rgba(130, 198, 142, 0.1);
  }
  .top_faq_inner {
    width: 100%;
    padding: 0 16px;
    box-sizing: border-box;
  }
  .top_faq_head {
    padding: 0 0 32px;
  }
  .top_faq_en {
    font-size: clamp(40px, 14vw, 80px);
  }
  .top_faq_h2 {
    font-size: 21px;
    text-align: center;
  }
  .top_faq_item {
    margin-bottom: 16px;
  }
  .top_faq_q {
    padding: 14px 12px;
  }
  .top_faq_q_icon {
    font-size: 28px;
    width: 32px;
    margin-right: 10px;
  }
  .top_faq_q_text {
    font-size: 15px;
    line-height: 1.5;
  }
  .top_faq_toggle {
    width: 20px;
    height: 20px;
    margin-left: 10px;
  }
  .top_faq_toggle::before {
    width: 20px;
  }
  .top_faq_toggle::after {
    height: 20px;
  }
  .top_faq_a {
    padding: 0 12px;
  }
  .top_faq_item.is-open .top_faq_a {
    padding: 16px 12px 0;
  }
  .top_faq_a_icon {
    font-size: 28px;
    width: 32px;
    margin-right: 10px;
  }
  .top_faq_a_text {
    font-size: 14px;
    line-height: 1.7;
    padding-top: 6px;
  }
  /*==================================================================

    .top_base（スマホ）

  ==================================================================*/
  .top_base {
    padding: 60px 0;
  }
  .top_base_inner {
    min-width: 0;
    max-width: 100%;
    padding: 0 16px;
    box-sizing: border-box;
  }
  .top_base_head {
    padding: 0 0 20px;
  }
  .top_base_en {
    font-size: clamp(40px, 14vw, 80px);
  }
  .top_base_h2 {
    font-size: 21px;
    text-align: center;
  }
  .top_base_lead {
    font-size: 14px;
    line-height: 1.7;
    margin-bottom: 32px;
  }
  .top_base_list {
    gap: 32px;
  }
  /* 各アイテムを縦積み */
  .top_base_item {
    flex-direction: column;
    padding: 20px;
    gap: 20px;
    width: 100%;
  }
  /* ロゴ（SP時のみ表示） */
  .top_base_logo {
    display: block;
    text-align: center;
    margin: 0 auto 8px;
  }
  .top_base_logo img {
    max-width: 100%;
    height: auto;
  }
  /* 動画 */
  .top_base_movie {
    width: 100%;
    max-width: 400px;
    margin: 0 auto;
    aspect-ratio: 473 / 296;
  }
  .top_base_movie iframe {
    width: 100%;
    height: 100%;
  }
  /* クリニック名（SP時はロゴに差し替え） */
  .top_base_name {
    display: none;
  }
  .top_base_label {
    font-size: 16px;
  }
  .top_base_text {
    font-size: 14px;
  }
  /* 地図 */
  .top_base_map {
    width: 100%;
    max-width: 400px;
    margin: 0 auto;
  }
  /*==================================================================

    .top_greeting（スマホ）

  ==================================================================*/
  .top_greeting {
    padding: 60px 0;
  }
  .top_greeting_head {
    text-align: center;
    padding: 0 0 32px;
  }
  .top_greeting_en {
    font-size: clamp(40px, 14vw, 80px);
  }
  .top_greeting_h2 {
    font-size: 21px;
    text-align: center;
  }
  /* 写真を上に */
  .top_greeting_body {
    flex-direction: column-reverse;
    gap: 32px;
    display: flex;
  }
  .top_greeting_text {
    width: 100%;
  }
  .top_greeting_text p {
    font-size: 14px;
    line-height: 2;
    margin-bottom: 24px;
  }
  .top_greeting_text p:last-child {
    margin-top: 40px;
  }
  .top_greeting_photo {
    width: 60%;
    margin: 0 auto;
    top: 0;
    float: none;
  }
  .top_greeting_name_line {
    font-size: 14px;
  }
  .top_greeting_label {
    font-size: 13px;
  }
  .top_greeting_value {
    font-size: 20px;
  }
}