@charset "UTF-8";
/* ============================================================
   医師別 予約動線セクション（参考画像準拠・後付け）
   元LPのデザインに干渉しないよう .p-docsel 名前空間で完結
   ============================================================ */

.p-docsel {
  background: #fff;
  padding: 8vw 0 10vw;
}
.p-docsel__inner {
  width: 88%;
  max-width: 520px;
  margin: 0 auto;
}
/* 既存「ドクター紹介」(暗背景)セクション内に置く場合の調整 */
.p-docsel__inner--onintro {
  width: 100%;
  max-width: 480px;
  margin: 6vw auto 0;
}

/* 見出し */
.p-docsel__head {
  text-align: center;
  margin-bottom: 7vw;
}
.p-docsel__head-en {
  display: block;
  font-style: italic;
  font-size: 1.3rem;
  letter-spacing: 0.12em;
  color: #aa8e5a;
}
.p-docsel__head-ja {
  display: block;
  font-size: 2.2rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: #222;
  margin-top: 0.4em;
}
.p-docsel__head-lead {
  display: block;
  font-size: 1.3rem;
  color: #575757;
  margin-top: 0.8em;
  line-height: 1.7;
}

/* カード */
.p-docsel__card {
  border: 1px solid #e0d8ca;
  background: #fff;
  border-radius: 4px;
  overflow: hidden;
  margin-bottom: 8vw;
  box-shadow: 0 4px 18px rgba(137, 102, 38, 0.06);
}
.p-docsel__card:last-child { margin-bottom: 0; }

/* 写真 */
.p-docsel__photo {
  position: relative;
  width: 100%;
  aspect-ratio: 3 / 3.4;
  background: #efeae0;
  overflow: hidden;
}
.p-docsel__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.p-docsel__badge {
  position: absolute;
  top: 4vw;
  left: 4vw;
  background: #aa8e5a;
  color: #fff;
  font-size: 1.2rem;
  letter-spacing: 0.08em;
  padding: 0.5em 1.1em;
  border-radius: 2px;
  z-index: 2;
}

/* 本文 */
.p-docsel__body { padding: 6vw 6vw 7vw; }
.p-docsel__en {
  font-style: italic;
  font-size: 1.5rem;
  letter-spacing: 0.08em;
  color: #aa8e5a;
}
.p-docsel__role {
  font-size: 1.4rem;
  color: #222;
  margin-top: 0.4em;
}
.p-docsel__name {
  font-size: 2.8rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: #222;
  margin-top: 0.5em;
}
.p-docsel__tagline {
  font-style: italic;
  font-size: 1.5rem;
  color: #575757;
  margin-top: 0.7em;
}

/* タグ */
.p-docsel__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 2vw;
  margin-top: 4vw;
}
.p-docsel__tags li {
  font-size: 1.3rem;
  color: #896626;
  border: 1px solid #c2ae89;
  border-radius: 2px;
  padding: 0.5em 1em;
  line-height: 1;
}

/* 院選択 */
.p-docsel__select {
  font-size: 1.4rem;
  color: #575757;
  letter-spacing: 0.06em;
  margin-top: 6vw;
  margin-bottom: 3vw;
}

/* 予約ボタン */
.p-docsel__btns {
  display: flex;
  flex-direction: column;
  gap: 3vw;
}
/* 「院をお選びください」が無いカード（単一院）は、タグ直後のボタンに上余白を補う */
.p-docsel__tags + .p-docsel__btns {
  margin-top: 6vw;
}
.p-docsel__btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 100%;
  padding: 1.5em 1.2em;
  background: linear-gradient(132deg, rgb(186, 159, 101) 0%, rgb(146, 114, 56) 100%);
  color: #fff;
  font-size: 1.7rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  border-radius: 3px;
  box-shadow: 0 3px 10px rgba(137, 102, 38, 0.25);
  transition: opacity 0.3s ease, transform 0.3s ease;
}
.p-docsel__btn .p-docsel__arrow {
  position: absolute;
  right: 1.2em;
  font-size: 1.6rem;
  line-height: 1;
}
@media (any-hover: hover) {
  .p-docsel__btn:hover { opacity: 0.88; transform: translateY(-1px); }
}

/* 差し替え用プレースホルダの注記（写真未設定時のみ視認用） */
.p-docsel__photo--placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #b8a987;
  font-size: 1.4rem;
  letter-spacing: 0.05em;
  background: repeating-linear-gradient(45deg, #f2ede2, #f2ede2 12px, #ece5d6 12px, #ece5d6 24px);
}
