/*
clinic-top-new (NEW クリニックTOP用の追加スタイル)
既存のclinic-top.scssと併用される
clinic-top-new__で始まるクラス名のみを定義
WordPressの「追加CSS」にそのまま貼り付け可能
*/

/* KVセクション - 画像スライダーレイアウト */
.clinic-top-new__kv {
  position: relative;
  width: 100%;
  height: 90vh;
  min-height: 700px;
  margin-bottom: 250px;
}

/* スライダーコンテナ */
.clinic-top-new__kv__slider {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  border-radius: 0 0 30px 30px;
  overflow: hidden;
  width: 90%;
  left: 5%;
  filter: brightness(0.9);
}

.clinic-top-new__kv__slider:active {
  cursor: grabbing;
}

/* スライド */
.clinic-top-new__kv__slide {
  position: relative;
  width: 100%;
  height: 100%;
}

.clinic-top-new__kv__slide img {
    width: 100%;
    height: 110%;
    object-fit: cover;
    display: block;
    margin: 0 auto;
}

/* PC/SP画像切り替え */
.clinic-top-new__kv__slide img.pc {
  display: block;
}

.clinic-top-new__kv__slide img.sp {
  display: none;
}

/* Slickスライダーのカスタマイズ */
.clinic-top-new__kv__slider .slick-slide {
  opacity: 0;
  transition: opacity 1.5s ease-in-out;
}

.clinic-top-new__kv__slider .slick-slide.slick-active {
  opacity: 1;
}

/* Slickのデフォルトスタイルをリセット */
.clinic-top-new__kv__slider .slick-list,
.clinic-top-new__kv__slider .slick-track {
  height: 100%;
}

.clinic-top-new__kv__slider .slick-slide > div {
  height: 100%;
}

/* ドラッグ/スワイプ中のスタイル */
.clinic-top-new__kv__slider.slick-dragging {
  cursor: grabbing;
}

.clinic-top-new__kv__slider .slick-slide img {
  pointer-events: none;
  user-select: none;
}

@media screen and (max-width: 768px) {
  .clinic-top-new__kv {
    height: 60vh;
    min-height: 500px;
    margin-bottom: 20px;
  }
  
  .clinic-top-new__kv__slide img.pc {
    display: none;
  }

  .clinic-top-new__kv__slide img.sp {
    display: block;
  }
  
  .clinic-top-new__kv__slide img {
    width: 100%;
    height: 70%;
    object-fit: cover;
    display: block;
    border-radius: 0 0 30px 30px;
    margin: 0 auto;
    filter: brightness(80%);
  }
}

/* テキストコンテンツ */
.clinic-top-new__kv__content {
  position: absolute;
  top: 60%;
  left: 5%;
  transform: translateY(-50%);
  z-index: 10;
}

.clinic-top-new__kv__text {
  color: #ffffff;
  font-weight: bold;
  font-size: 85px;
  line-height: 1.4;
  margin-bottom: 20px;
  padding-left: 7%;
  margin-right: -7%;
  text-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);
}

.clinic-top-new__kv__subtext {
  color: #ffffff;
  font-size: 18px;
  font-weight: bold;
  display: inline-block;
  margin-left: 5%;
  padding: 2px 15px;
  text-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);
}

@media screen and (max-width: 768px) {
  .clinic-top-new__kv__content {
    left: 20px;
	top: 50%;
  }
  
  .clinic-top-new__kv__text {
    font-size: 45px;
    margin-bottom: 0px;
    color: #ffffff;
    background: transparent;
	padding-left: 3%;
  }
  
  .clinic-top-new__kv__subtext {
    font-size: 14px;
    padding: 8px 16px;
    color: #ffffff;
    background: transparent;
    margin-left: 0;
  }
}

/* メニュー部分 - 画像の上に被せて配置 */
.clinic-top-new__menu {
  position: absolute;
  bottom: -5vh;
  left: 50%;
  transform: translateX(-50%);
  z-index: 50;
  width: 1200px;
  max-width: 90%;
}

.clinic-top-new__menu ul {
  display: flex;
  flex-direction: row;
  gap: 10px;
  list-style: none;
  margin: 0;
  padding: 0;
  justify-content: center;
}

.clinic-top-new__menu li {
  flex: 1;
  /* max-width: 250px; */
}

/* SP版用分割レイアウト（PC版では非表示） */
.clinic-top-new__menu--sp {
  display: none;
}

.clinic-top-new__menu a {
  display: flex;
  flex-direction: row;
  align-items: center;
  padding: 15px 20px;
  background: #ffffff;
  border: 2px solid #e60012;
  border-radius: 8px;
  text-decoration: none;
  color: #e60012;
  transition: all 0.3s ease;
  box-shadow: 0 4px 10px rgba(0,0,0,0.1);
  text-align: left;
  min-height: 60px;
  justify-content: space-between;
}

.clinic-top-new__menu a:hover {
  background: #e60012;
  color: #ffffff;
}

.clinic-top-new__menu__icon {
  margin-right: 0;
  margin-left: 15px;
  flex-shrink: 0;
  order: 2;
}

.clinic-top-new__menu__icon img {
  width: 50px;
  height: 50px;
  object-fit: contain;
}

.clinic-top-new__menu__text {
  font-size: 16px;
  font-weight: bold;
  line-height: 1.4;
  order: 1;
}

/* スマホ版：上に3つ、下に1つのレイアウト */
@media screen and (max-width: 768px) {
  .clinic-top-new__menu {
    position: absolute;
    bottom: 1vh;
    left: 20px;
    right: 20px;
    width: auto;
    transform: none;
  }
  
  /* PC版のulを非表示 */
  .clinic-top-new__menu ul {
    display: none;
  }
  
  /* SP版の分割レイアウトを表示 */
  .clinic-top-new__menu--sp {
    display: block;
  }
  
  /* 上段3つ */
  .clinic-top-new__menu__row-top {
    display: flex;
    flex-direction: row;
    gap: 10px;
    margin-bottom: 10px;
  }
  
  /* 下段1つ */
  .clinic-top-new__menu__row-bottom {
    display: flex;
    justify-content: center;
  }
  
  .clinic-top-new__menu__item {
    flex: 1;
  }
  
  .clinic-top-new__menu__row-bottom .clinic-top-new__menu__item {
    width: 60%;
  }
  
  .clinic-top-new__menu__item a {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 1px 8px;
    background: #ffffff;
    border: 2px solid #e60012;
    border-radius: 8px;
    text-decoration: none;
    color: #e60012;
    transition: all 0.3s ease;
    box-shadow: 0 4px 10px rgba(0,0,0,0.1);
    text-align: center;
    min-height: 80px;
    justify-content: center;
  }
  
  .clinic-top-new__menu__item a:hover {
    background: #e60012;
    color: #ffffff;
  }
  
  .clinic-top-new__menu__item .clinic-top-new__menu__icon {
    margin-right: 0;
    margin-left: 0;
    margin-bottom: 6px;
    order: 1;
  }
  
  .clinic-top-new__menu__item .clinic-top-new__menu__icon img {
    width: 30px;
    height: 30px;
  }
  
  .clinic-top-new__menu__item .clinic-top-new__menu__text {
    font-size: 12px;
    order: 2;
  }
  
  /* SP版：タッチ操作の最適化 */
  .clinic-top-new__kv__slider {
    touch-action: pan-y pinch-zoom;
	width: 100%;
    left: 0%;
  }
}

/* お知らせ上部画像 */
.clinic-top-new__news-image {
  width: 100%;
  max-width: 1200px;
  margin: -100px auto 200px;
  padding: 0 20px;
}

.clinic-top-new__news-image img {
  width: 100%;
  height: auto;
  display: block;
}

.clinic-top-new__news-image img.pc {
  display: block;
}

.clinic-top-new__news-image img.sp {
  display: none;
}

.clinic-top-new__news-image img:not(:first-child) {
  margin-top: 90px;
}


@media screen and (max-width: 768px) {
  .clinic-top-new__news-image {
    margin: 50px auto 60px;
    padding: 0 20px;
  }
  
  .clinic-top-new__news-image img.pc {
    display: none;
  }
  
  .clinic-top-new__news-image img.sp {
    display: block;
  }

   .clinic-top-new__news-image img:not(:first-child) {
    margin-top: 40px;
   }
}

/* ギャラリーセクションとの間隔調整 */
.clinic-top__gallery {
  margin-top: 0px;
}

@media screen and (max-width: 768px) {
  .clinic-top__gallery {
    margin-top: 0px;
  }
}

/* ------------------------------------------------------------------------- */
/* 診療科目（outpatient guide）用のスタイル                                            */
/* 表示位置：診療科目タイトル（MEDICAL SUBJECT / 診療科目）の上に表示されます。         */
/* PC用は .pc を、SP用は .sp を付与してテンプレートから出力しています。             */
/* ------------------------------------------------------------------------- */

.clinic-top__department__guide {
  margin: 0 0 18px 0;
  padding: 0 20px;
  text-align: center;
  max-width: 980px;
  margin-left: auto;
  margin-right: auto;
}

.clinic-top__department__guide__text {
  color: #333333;
  font-size: 16px;
  line-height: 1.8;
  margin: 0 auto;
}

/* PC は表示、SP は非表示（デフォルト） */
.clinic-top__department__guide__text.pc {
  display: block;
}
.clinic-top__department__guide__text.sp {
  display: none;
}

/* 小さめのアクセント（任意） */
.clinic-top__department__guide__text em {
  font-style: normal;
  color: #e60012;
  font-weight: 700;
}

@media screen and (max-width: 768px) {
  .clinic-top__department__guide {
    padding: 0 14px;
    margin-bottom: 12px;
  }
  .clinic-top__department__guide__text.sp {
    font-size: 10px;
    line-height: 1.6;
  }
  /* SP では SP 用テキストを表示 */
  .clinic-top__department__guide__text.pc {
    display: none;
  }
  .clinic-top__department__guide__text.sp {
    display: block;
  }
}

/* 診療科目テキスト用の中央寄せスタイル */
.clinic-top__department__guide--center {
  text-align: center;
  margin-bottom: 30px;
}

.clinic-top__department__guide--center .clinic-top__department__guide__text {
  text-align: center;
  max-width: 800px;
  white-space: pre-line !important; /* 改行を保持 */
  word-wrap: break-word; /* 長い単語の改行 */
  overflow-wrap: break-word; /* より強力な改行処理 */
  display: block !important; /* ブロック要素として表示 */
}

/* 改行タグ（<br>）のスタイル調整 */
.clinic-top__department__guide--center .clinic-top__department__guide__text br {
  display: block !important;
  content: "";
  margin-top: 0.5em;
  line-height: 0.5em;
}

@media screen and (max-width: 768px) {
  .clinic-top__department__guide--center {
    margin-bottom: 20px;
  }
  
  .clinic-top__department__guide--center .clinic-top__department__guide__text br {
    margin-top: 0.3em;
    line-height: 0.3em;
  }
}

  /* タイトル（英語 / 日本語）の間隔調整 */
  .clinic-title-section__en {
    display: block; /* 英語見出しをブロックにして下マージンを効かせる */
    font-size: 14px;
    letter-spacing: 2px;
    margin-bottom: 0.8em; /* 英語と日本語の間のスペースを広げる */
  }

  .clinic-title-section__jp {
    display: block; /* 日本語見出しもブロック表示 */
    margin-top: 0; /* 英語側のマージンで制御するため上マージンはリセット */
  }

  @media screen and (max-width: 768px) {
    /* SP は文字サイズを小さくして間隔を適度に調整 */
    .clinic-title-section__en { margin-bottom: 0.5em; font-size: 12px; }
    .clinic-title-section__jp { font-size: 20px; }
  }
