/* ============================================================
   Sub-page shared blocks (사업취지 / 인사말 / 참여병원 / 코디안내 /
   지속관리사업 / 관리프로세스)
   ============================================================ */

/* Centred content title for content bands */
.content-title {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  color: var(--fg1);
  letter-spacing: -0.01em;
  font-size: clamp(26px, 3.4vw, 36px);
  line-height: 1.25;
  margin: 0 0 var(--space-8) 0;
  text-align: center;
}
.content-title--sans { font-family: var(--font-sans); }

.page-title--center { text-align: center; }

/* Short, centred accent divider */
.section-divider {
  border: 0;
  width: 100px;
  height: 4px;
  border-radius: var(--radius-pill);
  background: var(--border-strong);
  margin: 48px auto;
}

.page-lede {
  font-size: 17px;
  line-height: 1.75;
  color: var(--fg2);
  max-width: 64ch;
  margin: var(--space-5) 0 0 0;
  text-wrap: pretty;
}

/* Image figure */
.figure-frame {
  background: var(--surface);
  border: 1px solid var(--border);
  /* 반응형 radius: 모바일에서 자연스럽게 작아지고 데스크톱 32px 상한 */
  border-radius: clamp(14px, 4vw, 32px);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.figure-frame img { width: 100%; height: auto; display: block; }
.figure-frame--plain { background: transparent; border: 0; box-shadow: none; }
.figure-frame--gap { margin-top: var(--space-10); }
.band--white { background: #FFFFFF; }

/* Process page text */
.proc-sub {
  font-family: var(--font-sans);
  font-weight: var(--fw-medium);
  color: var(--fg2);
  text-align: center;
  font-size: clamp(15px, 1.8vw, 18px);
  line-height: 1.7;
  margin: var(--space-4) auto 0;
  max-width: 820px;
}
.proc-sub strong { color: var(--brand-coral-600); font-weight: var(--fw-bold); }
.proc-body {
  font-family: var(--font-sans);
  font-weight: var(--fw-regular);
  color: var(--fg2);
  text-align: center;
  font-size: clamp(15px, 1.7vw, 17px);
  line-height: 1.8;
  margin: var(--space-6) auto 0;
  max-width: 820px;
  text-wrap: pretty;
}
.proc-body--lg { font-size: 20px; }
.proc-body--16 { font-size: 16px; }
.proc-body--wide { max-width: 900px; }
.proc-body--bold { font-weight: var(--fw-semibold); }
.proc-emphasis { font-size: 23px; color: var(--primary); text-decoration: underline; }

/* Care pages subtext */
.care-sub {
  font-family: var(--font-sans);
  font-weight: var(--fw-medium);
  color: var(--fg2);
  text-align: center;
  font-size: clamp(16px, 1.9vw, 19px);
  line-height: 1.7;
  margin: var(--space-4) auto 0;
  max-width: 760px;
  text-wrap: pretty;
}
.figure-caption {
  font-size: 13px;
  color: var(--fg4);
  text-align: center;
  margin-top: var(--space-3);
  letter-spacing: 0.02em;
}

/* Closing message block */
.message {
  max-width: 800px;
  margin: 0 auto;
}
.message p {
  font-family: var(--font-sans);
  font-weight: var(--fw-regular);
  font-size: 17px;
  line-height: 1.85;
  color: var(--fg2);
  margin: 0;
  text-align: justify;
  text-wrap: pretty;
}
/* 사업취지: 모바일에서만 본문 텍스트 좌측 정렬 */
@media (max-width: 720px) {
  .message p { text-align: left; }
}
/* .message p 규칙(0,1,1)을 이기도록 우선순위를 높여 볼드·디스플레이 폰트 적용 */
.message .message__sign {
  margin-top: var(--space-12); /* 본문과 한 단락 띄움 */
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: 18px;
  color: var(--brand-coral-600);
  text-align: right;
}

/* Centred narrow band helper */
.band-narrow { max-width: 1180px; margin: 0 auto; text-align: center; }

/* Greeting (사업단장 인사말) */
.greeting {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-10);
  align-items: start;
}
@media (min-width: 900px) {
  .greeting { grid-template-columns: 0.82fr 1.18fr; gap: var(--space-16); align-items: center; }
}
.greeting__portrait {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  max-width: 360px;
  margin: 0 auto;
  width: 100%;
}
.greeting__portrait img { width: 100%; height: auto; display: block; }
.greeting__name {
  padding: var(--space-5) var(--space-5) var(--space-6);
  text-align: center;
  border-top: 1px solid var(--border);
}
.greeting__name strong {
  display: block;
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: 20px;
  color: var(--fg1);
  letter-spacing: -0.01em;
}
.greeting__name span { display: block; font-size: 14px; color: var(--fg3); margin-top: 6px; }
.greeting__body { max-width: 650px; }
.greeting__body p {
  font-family: var(--font-sans);
  font-weight: var(--fw-regular);
  font-size: 17px;
  line-height: 1.9;
  color: var(--fg2);
  margin: 0 0 var(--space-5) 0;
  text-wrap: pretty;
}
.greeting__body p:last-of-type { margin-bottom: 0; }
/* 400px 이하에서 인사말 본문 텍스트만 15px 로 축소 (lead 24px 유지) */
@media (max-width: 400px) {
  .greeting__body p { font-size: 15px; }
}
/* .greeting__body p 규칙(0,1,1)을 이기도록 우선순위를 높인다 */
.greeting__body .greeting__lead {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: 24px;
  color: var(--fg1);
  line-height: 1.4;
  margin-bottom: var(--space-6);
}

/* Coordinator table (colours matched to source image) */
.coord-table-wrap {
  margin: var(--space-8) auto 0;
  max-width: 800px;
  background: #FFFFFF;
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  padding: var(--space-5) var(--space-8);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.coord-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 640px;
  font-family: var(--font-sans);
}
.coord-table td {
  padding: 16px 12px;
  border-bottom: 1px solid #F7D8D8;
  vertical-align: middle;
  white-space: nowrap;
}
.coord-table tr:first-child td { border-top: 0; }
.coord-table tr:last-child td { border-bottom: 0; }
.ct-num { width: 56px; text-align: center; }
.ct-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 999px;
  background: #F18A8A;
  color: #FFFFFF;
  font-size: 13px;
  font-weight: var(--fw-bold);
  line-height: 1;
}
.ct-region { width: 88px; color: #4A4A4A; font-weight: var(--fw-semibold); font-size: 15px; }
.ct-name { width: 96px; color: #4A4A4A; font-weight: var(--fw-medium); font-size: 15px; }
.ct-phone { width: 150px; color: #6E6E6E; font-size: 15px; letter-spacing: 0.01em; }
.ct-hosp { color: #4A4A4A; font-size: 15px; text-align: center; white-space: normal; line-height: 1.5; }
.coord-notes {
  margin: var(--space-6) auto 0;
  max-width: 800px;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.coord-notes li {
  position: relative;
  padding-left: 16px;
  font-size: 14px;
  color: var(--fg3);
  line-height: 1.6;
}
.coord-notes li::before {
  content: "*";
  position: absolute;
  left: 0;
  color: var(--brand-coral-400);
}

/* Hospitals page figures */
.figure-frame--center { max-width: 800px; margin-left: auto; margin-right: auto; }
.hospitals-fig--gap { margin-top: var(--space-12); }
.hospitals-fig--gap-sm { margin-top: var(--space-10); }
.hospitals-intro {
  margin-top: var(--space-12);
  font-family: var(--font-sans);
  font-weight: var(--fw-medium);
  font-size: 20px;
  line-height: 1.6;
  color: var(--fg1);
  text-align: center;
}
