/* =============================================================
   クリニック情報ページ — SWELL競合防止のためすべて .cl-page でスコープ
   ============================================================= */

.cl-page {
  --cl-blue-50:  #F0F4FA;
  --cl-blue-100: #DCE5F4;
  --cl-blue-200: #B8CBE8;
  --cl-blue-300: #8AAAD6;
  --cl-blue-400: #5C89C4;
  --cl-blue-500: #3A6DAE;
  --cl-blue-600: #1E4F8E;
  --cl-blue-700: #183F72;
  --cl-blue-800: #123058;
  --cl-blue-900: #0C2240;
  --cl-gold:     #C5A55A;
  --cl-gold-lt:  #DCC88E;
  --cl-g50:  #F5F6F8;
  --cl-g100: #ECEEF2;
  --cl-g200: #DDE0E6;
  --cl-g300: #BFC3CC;
  --cl-g400: #9A9FAB;
  --cl-g500: #787E8A;
  --cl-g600: #5E636E;
  --cl-g700: #464A54;
  --cl-g800: #32363E;
  --cl-g900: #1F2228;
  --cl-white: #FFFFFF;
  --cl-font-d: "游ゴシック Medium","Yu Gothic Medium",YuGothic,"游ゴシック体","Yu Gothic","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro",メイリオ,Meiryo,sans-serif;
  --cl-font-h: "游ゴシック Medium","Yu Gothic Medium",YuGothic,"游ゴシック体","Yu Gothic","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro",メイリオ,Meiryo,sans-serif;
  --cl-font-b: "游ゴシック Medium","Yu Gothic Medium",YuGothic,"游ゴシック体","Yu Gothic","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro",メイリオ,Meiryo,sans-serif;
}

.cl-page {
  font-family: var(--cl-font-b) !important;
  font-weight: 300 !important;
  color: var(--cl-g800) !important;
  line-height: 1.8 !important;
  letter-spacing: 0.03em !important;
  -webkit-font-smoothing: antialiased;
  margin-top: -8em !important;
  margin-bottom: -6em !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.cl-page *,
.cl-page *::before,
.cl-page *::after {
  box-sizing: border-box !important;
}


/* ========== Hero ========== */
.cl-page .cl-hero {
  position: relative !important;
  background: linear-gradient(135deg, var(--cl-blue-800) 0%, var(--cl-blue-600) 50%, var(--cl-blue-500) 100%) !important;
  padding: clamp(5rem, 12vw, 9rem) 2rem clamp(3rem, 8vw, 5rem) !important;
  text-align: center !important;
  overflow: hidden !important;
  margin: 0 !important;
  border: none !important;
  margin-left: calc(-50vw + 50%) !important;
  margin-right: calc(-50vw + 50%) !important;
  width: 100vw !important;
}

.cl-page .cl-hero::before {
  content: '' !important;
  position: absolute !important;
  top: -50% !important;
  right: -20% !important;
  width: 600px !important;
  height: 600px !important;
  border-radius: 50% !important;
  background: radial-gradient(circle, rgba(197, 165, 90, 0.08) 0%, transparent 70%) !important;
  pointer-events: none !important;
}

.cl-page .cl-hero::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 80px !important;
  background: linear-gradient(180deg, transparent, var(--cl-white)) !important;
  pointer-events: none !important;
}

.cl-page .cl-hero__en {
  font-family: var(--cl-font-d) !important;
  font-size: clamp(0.7rem, 1.2vw, 0.82rem) !important;
  font-weight: 400 !important;
  letter-spacing: 0.35em !important;
  text-transform: uppercase !important;
  color: var(--cl-gold-lt) !important;
  margin: 0 0 1rem 0 !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
}

.cl-page .cl-hero__title {
  font-family: var(--cl-font-h) !important;
  font-size: clamp(1.6rem, 4vw, 2.4rem) !important;
  font-weight: 400 !important;
  letter-spacing: 0.15em !important;
  color: var(--cl-white) !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
}

.cl-page .cl-hero__line {
  display: block !important;
  width: 40px !important;
  height: 1px !important;
  background: linear-gradient(90deg, var(--cl-gold), var(--cl-gold-lt)) !important;
  margin: 1.5rem auto 0 !important;
  border: none !important;
}


/* ========== Container / Section ========== */
.cl-page .cl-container {
  max-width: 960px !important;
  margin: 0 auto !important;
  padding: 0 clamp(1.5rem, 4vw, 3rem) !important;
}

.cl-page .cl-section {
  padding: clamp(3rem, 7vw, 5rem) 0 !important;
  margin: 0 !important;
  border: none !important;
  background: none !important;
}


/* ========== Section Label ========== */
.cl-page .cl-label {
  text-align: center !important;
  margin: 0 0 3rem 0 !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
}

.cl-page .cl-label__en {
  font-family: var(--cl-font-d) !important;
  font-size: 0.75rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.35em !important;
  text-transform: uppercase !important;
  color: var(--cl-blue-500) !important;
  margin: 0 0 0.5rem 0 !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
}

.cl-page .cl-label__ja {
  font-family: var(--cl-font-h) !important;
  font-size: clamp(1.2rem, 2.5vw, 1.6rem) !important;
  font-weight: 400 !important;
  letter-spacing: 0.12em !important;
  color: var(--cl-g900) !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  border-left: none !important;
  background: none !important;
  border-radius: 0 !important;
}

.cl-page .cl-label__line {
  display: block !important;
  width: 30px !important;
  height: 1px !important;
  background: linear-gradient(90deg, var(--cl-blue-600), var(--cl-gold)) !important;
  margin: 1rem auto 0 !important;
  border: none !important;
  padding: 0 !important;
}


/* ========== Info Table ========== */
.cl-page .cl-info {
  max-width: 700px !important;
  margin: 0 auto !important;
}

.cl-page .cl-info__row {
  display: flex !important;
  align-items: baseline !important;
  padding: 1.4em 0 !important;
  margin: 0 !important;
  border: none !important;
  border-bottom: 1px solid var(--cl-g100) !important;
  background: none !important;
}

.cl-page .cl-info__row:last-child {
  border-bottom: none !important;
}

.cl-page .cl-info__label {
  font-family: var(--cl-font-h) !important;
  font-size: 0.88rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.06em !important;
  color: var(--cl-g900) !important;
  width: 140px !important;
  flex-shrink: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
  position: relative !important;
  padding-left: 1em !important;
}

.cl-page .cl-info__label::before {
  content: '' !important;
  position: absolute !important;
  left: 0 !important;
  top: 0.15em !important;
  width: 3px !important;
  height: 1em !important;
  background: var(--cl-blue-600) !important;
  border-radius: 2px !important;
}

.cl-page .cl-info__value {
  font-size: 0.92rem !important;
  color: var(--cl-g700) !important;
  line-height: 1.8 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
  flex: 1 !important;
}

.cl-page .cl-info__value a {
  color: var(--cl-blue-600) !important;
  text-decoration: none !important;
  border-bottom: 1px solid rgba(30, 79, 142, 0.2) !important;
  transition: border-color 0.2s ease, color 0.2s ease !important;
}

.cl-page .cl-info__value a:hover {
  color: var(--cl-blue-800) !important;
  border-bottom-color: var(--cl-blue-700) !important;
}

/* 電話番号の大きめ表示 */
.cl-page .cl-info__tel {
  font-family: var(--cl-font-b) !important;
  font-size: 1.2rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.06em !important;
  color: var(--cl-g900) !important;
  text-decoration: none !important;
  border-bottom: none !important;
}

.cl-page .cl-info__tel:hover {
  color: var(--cl-blue-600) !important;
  border-bottom: none !important;
}

/* 小さい補足テキスト */
.cl-page .cl-info__sub {
  display: block !important;
  font-size: 0.78rem !important;
  color: var(--cl-g400) !important;
  margin-top: 0.3em !important;
}


/* ========== Access / Station ========== */
.cl-page .cl-access {
  max-width: 700px !important;
  margin: 0 auto !important;
  display: flex !important;
  align-items: center !important;
  gap: 1.5rem !important;
  padding: 1.5rem !important;
  background: var(--cl-blue-50) !important;
  border: 1px solid var(--cl-blue-100) !important;
  border-radius: 8px !important;
}

.cl-page .cl-access__icon {
  width: 44px !important;
  height: 44px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: var(--cl-white) !important;
  border-radius: 50% !important;
  flex-shrink: 0 !important;
  box-shadow: 0 2px 8px rgba(30, 79, 142, 0.08) !important;
}

.cl-page .cl-access__icon svg {
  width: 20px !important;
  height: 20px !important;
  stroke: var(--cl-blue-600) !important;
  fill: none !important;
  stroke-width: 1.5 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
}

.cl-page .cl-access__body {
  flex: 1 !important;
}

.cl-page .cl-access__station {
  font-family: var(--cl-font-h) !important;
  font-size: 1rem !important;
  font-weight: 500 !important;
  color: var(--cl-g900) !important;
  margin: 0 0 0.3rem 0 !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
}

.cl-page .cl-access__detail {
  font-size: 0.85rem !important;
  color: var(--cl-g500) !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
}

.cl-page .cl-access__badge {
  display: inline-block !important;
  font-size: 0.72rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.04em !important;
  padding: 2px 8px !important;
  border-radius: 3px !important;
  margin-right: 0.4em !important;
  color: var(--cl-white) !important;
}

.cl-page .cl-access__badge--hibiya {
  background: #9CA3AF !important;
}

.cl-page .cl-access__badge--asakusa {
  background: #E8507F !important;
}


/* ========== Divider ========== */
.cl-page .cl-divider {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 1rem !important;
  padding: 0 2rem !important;
  margin: 0 !important;
  border: none !important;
  background: none !important;
}

.cl-page .cl-divider::before,
.cl-page .cl-divider::after {
  content: '' !important;
  flex: 1 !important;
  height: 1px !important;
  max-width: 160px !important;
  border: none !important;
}

.cl-page .cl-divider::before {
  background: linear-gradient(90deg, transparent, var(--cl-blue-200)) !important;
}

.cl-page .cl-divider::after {
  background: linear-gradient(90deg, var(--cl-blue-200), transparent) !important;
}

.cl-page .cl-divider__diamond {
  width: 6px !important;
  height: 6px !important;
  background: var(--cl-gold) !important;
  transform: rotate(45deg) !important;
  flex-shrink: 0 !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
}


/* ========== Google Map ========== */
.cl-page .cl-map {
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
}

.cl-page .cl-map__wrap {
  position: relative !important;
  width: 100% !important;
  padding-bottom: 50% !important;
  border-radius: 8px !important;
  overflow: hidden !important;
  border: 1px solid var(--cl-g100) !important;
  max-width: 700px !important;
  margin: 0 auto !important;
}

.cl-page .cl-map__wrap iframe {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  border: none !important;
}


/* ========== CTA ========== */
.cl-page .cl-cta {
  text-align: center !important;
  padding: clamp(3rem, 7vw, 5rem) 2rem !important;
  margin: 0 !important;
  background: linear-gradient(135deg, var(--cl-blue-50) 0%, var(--cl-blue-100) 100%) !important;
  border: none !important;
  margin-left: calc(-50vw + 50%) !important;
  margin-right: calc(-50vw + 50%) !important;
  width: 100vw !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
}

.cl-page .cl-cta__text {
  font-family: var(--cl-font-h) !important;
  font-size: 1rem !important;
  font-weight: 400 !important;
  color: var(--cl-g700) !important;
  letter-spacing: 0.05em !important;
  margin: 0 0 2rem 0 !important;
  padding: 0 !important;
  line-height: 2 !important;
  border: none !important;
  background: none !important;
}

.cl-page .cl-cta__btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.6rem !important;
  padding: 16px 44px !important;
  font-family: var(--cl-font-b) !important;
  font-size: 0.88rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.15em !important;
  color: var(--cl-white) !important;
  background: linear-gradient(135deg, var(--cl-blue-600), var(--cl-blue-700)) !important;
  border: none !important;
  border-radius: 50px !important;
  text-decoration: none !important;
  box-shadow: 0 4px 20px rgba(30, 79, 142, 0.25) !important;
  transition: all 0.3s ease !important;
  cursor: pointer !important;
}

.cl-page .cl-cta__btn:hover {
  background: linear-gradient(135deg, var(--cl-blue-700), var(--cl-blue-800)) !important;
  box-shadow: 0 8px 32px rgba(30, 79, 142, 0.35) !important;
  transform: translateY(-2px) !important;
  color: var(--cl-white) !important;
}

.cl-page .cl-cta__btn svg {
  width: 16px !important;
  height: 16px !important;
  stroke: currentColor !important;
  fill: none !important;
  stroke-width: 2 !important;
  transition: transform 0.3s ease !important;
}

.cl-page .cl-cta__btn:hover svg {
  transform: translateX(3px) !important;
}


/* ========== Responsive ========== */
@media (max-width: 768px) {
  .cl-page .cl-info__row {
    flex-direction: column !important;
    gap: 0.3rem !important;
  }

  .cl-page .cl-info__label {
    width: auto !important;
  }

  .cl-page .cl-access {
    flex-direction: column !important;
    text-align: center !important;
    gap: 1rem !important;
  }

  .cl-page .cl-map__wrap {
    padding-bottom: 70% !important;
    border-radius: 0 !important;
  }
}
