/* ============================================================
   사회적협동조합 엘 — 공식 홈페이지
   site.css — Wanted Design System 토큰 위에 구축한 사이트 레이어
   (색·타입·간격은 DS 토큰을 그대로 사용, 새 색 발명 금지)
   ============================================================ */

* { box-sizing: border-box; }

:root {
  /* 콘텐츠 폭(명세서 권장 1,200px) */
  --site-max: 1200px;
  --site-pad: var(--space-32);

  /* 떠다니는 도형(리플) 색 — 기본: 블루 & 골드, 모두 Wanted 램프 */
  --shape-1: var(--color-primary-normal);   /* #0066FF */
  --shape-2: var(--c-lightBlue-50);          /* #00AEFF */
  --shape-3: var(--c-orange-55);             /* #FFA938 따뜻한 포인트 */
  --shape-opacity: 1;

  /* 헤더 높이 */
  --header-h: 72px;
}

html { scroll-behavior: smooth; }
html, body {
  margin: 0;
  padding: 0;
  background: var(--color-background-normal);
  color: var(--color-label-normal);
  font: var(--type-body-1);
  letter-spacing: 0.0057em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  word-break: keep-all;
}

a { color: var(--color-primary-normal); text-decoration: none; }
a:hover { text-decoration: underline; }
img { max-width: 100%; display: block; }

h1, h2, h3, h4, p, ul, ol, figure { margin: 0; }
ul, ol { padding: 0; list-style: none; }

:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
  border-radius: var(--radius-4);
}

/* ── Skip link ──────────────────────────────────────────────── */
.skip-link {
  position: absolute;
  left: var(--space-16);
  top: -120px;
  z-index: 1000;
  background: var(--color-primary-normal);
  color: var(--color-primary-on);
  padding: var(--space-12) var(--space-20);
  border-radius: var(--radius-8);
  font: var(--type-label-1);
  transition: top .2s ease;
}
.skip-link:focus { top: var(--space-16); text-decoration: none; }

/* ── 컨테이너 ───────────────────────────────────────────────── */
.wrap {
  width: 100%;
  max-width: var(--site-max);
  margin-inline: auto;
  padding-inline: var(--site-pad);
}

/* ============================================================
   헤더 / GNB
   ============================================================ */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgb(255 255 255 / 0.82);
  backdrop-filter: saturate(1.4) blur(12px);
  -webkit-backdrop-filter: saturate(1.4) blur(12px);
  border-bottom: 1px solid var(--color-line-neutral);
}
.site-header__inner {
  height: var(--header-h);
  display: flex;
  align-items: center;
  gap: var(--space-24);
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-12);
  flex: none;
}
.brand:hover { text-decoration: none; }
.brand__mark {
  width: 34px; height: 34px;
  flex: none;
  display: grid; place-items: center;
}
.brand__mark svg { width: 34px; height: 34px; display: block; }
.brand__text {
  display: flex; flex-direction: column; line-height: 1;
}
.brand__name {
  font: var(--type-headline-1);
  letter-spacing: -0.01em;
  color: var(--color-label-strong);
}
.brand__sub {
  white-space: nowrap;
  font: var(--type-caption-2);
  letter-spacing: 0.04em;
  color: var(--color-label-alternative);
  margin-top: 3px;
}

.gnb { margin-left: auto; }
.gnb__list { display: flex; gap: var(--space-4); align-items: stretch; }
.gnb__item { position: relative; }
.gnb__top {
  display: inline-flex;
  align-items: center;
  height: var(--header-h);
  padding-inline: var(--space-16);
  font: var(--type-label-1);
  font-weight: var(--w-semibold);
  letter-spacing: 0.0145em;
  color: var(--color-label-normal);
  white-space: nowrap;
  border: 0; background: none; cursor: pointer;
}
.gnb__top:hover { color: var(--color-primary-normal); text-decoration: none; }
.gnb__item[aria-current="page"] > .gnb__top,
.gnb__item.is-active > .gnb__top { color: var(--color-primary-normal); }
.gnb__item.is-active > .gnb__top::after {
  content: ""; position: absolute; left: var(--space-16); right: var(--space-16);
  bottom: 0; height: 3px; border-radius: 3px 3px 0 0;
  background: var(--color-primary-normal);
}
.gnb__panel {
  position: absolute;
  top: calc(var(--header-h) - 8px);
  left: 50%;
  transform: translateX(-50%) translateY(6px);
  min-width: 184px;
  background: var(--color-background-elevated);
  border: 1px solid var(--color-line-normal);
  border-radius: var(--radius-12);
  box-shadow: var(--shadow-strong);
  padding: var(--space-8);
  display: flex; flex-direction: column; gap: 2px;
  opacity: 0; visibility: hidden;
  transition: opacity .16s ease, transform .16s ease;
  z-index: 50;
}
.gnb__item:hover .gnb__panel,
.gnb__item:focus-within .gnb__panel {
  opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0);
}
.gnb__sub {
  display: block;
  padding: var(--space-12);
  border-radius: var(--radius-8);
  font: var(--type-label-1);
  color: var(--color-label-normal);
  white-space: nowrap;
}
.gnb__sub:hover { background: var(--color-fill-normal); color: var(--color-label-strong); text-decoration: none; }
.gnb__sub[aria-current="page"] { color: var(--color-primary-normal); background: var(--color-primary-light); }

.header-cta { flex: none; margin-left: var(--space-8); }

/* 모바일 토글 */
.nav-toggle {
  display: none;
  margin-left: auto;
  width: 44px; height: 44px;
  border: 1px solid var(--color-line-normal);
  border-radius: var(--radius-8);
  background: var(--color-background-normal);
  color: var(--color-label-strong);
  cursor: pointer;
  place-items: center;
}
.nav-toggle .ic { width: 22px; height: 22px; }

/* ============================================================
   떠다니는 리플 도형
   ============================================================ */
.bg-shapes {
  position: fixed;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
}
.bg-shapes .ripple { position: absolute; opacity: calc(0.3 * var(--shape-opacity)); }
.ripple svg { display: block; width: 100%; height: 100%; overflow: visible; }
.ripple circle { fill: none; }

/* 사이트 전체 배경 도형은 은은하게 */
.bg-shapes .ripple { will-change: transform; }

@media (prefers-reduced-motion: no-preference) {
  .ripple { animation: floatY var(--dur, 18s) ease-in-out infinite alternate; }
  .ripple.alt { animation-name: floatYX; }
}
@keyframes floatY {
  from { transform: translateY(0) rotate(0deg); }
  to   { transform: translateY(-26px) rotate(8deg); }
}
@keyframes floatYX {
  from { transform: translate(0,0) rotate(0deg); }
  to   { transform: translate(18px,-20px) rotate(-6deg); }
}

/* 도형 끄기 */
body[data-shapes="off"] .bg-shapes,
body[data-shapes="off"] .hero__shapes { display: none; }

/* main 콘텐츠는 도형 위로 */
.site-main { position: relative; z-index: 1; }

/* ============================================================
   메인 히어로
   ============================================================ */
.hero {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(120% 140% at 85% -10%, var(--c-blue-99) 0%, rgba(255,255,255,0) 55%),
    radial-gradient(110% 120% at 0% 110%, var(--c-coolNeutral-99) 0%, rgba(255,255,255,0) 50%),
    var(--color-background-normal);
  border-bottom: 1px solid var(--color-line-neutral);
}
.hero__inner {
  position: relative; z-index: 2;
  padding-block: clamp(56px, 9vw, 116px);
  max-width: 760px;
}
.hero__eyebrow {
  display: inline-flex; align-items: center; gap: var(--space-8);
  padding: 7px var(--space-12);
  border-radius: var(--radius-full);
  background: var(--color-primary-light);
  color: var(--color-primary-strong);
  font: var(--type-label-2);
  font-weight: var(--w-semibold);
  letter-spacing: 0.0194em;
  margin-bottom: var(--space-24);
}
.hero__eyebrow .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--shape-3); }
.hero h1 {
  font: var(--type-display-2);
  letter-spacing: -0.0282em;
  color: var(--color-label-strong);
  text-wrap: balance;
}
.hero h1 .accent {
  color: var(--color-primary-normal);
  position: relative; white-space: nowrap;
}
.hero__lead {
  margin-top: var(--space-24);
  font: var(--type-body-1-read);
  font-size: 18px; line-height: 30px;
  color: var(--color-label-neutral);
  max-width: 60ch;
  text-wrap: pretty;
}
.hero__actions { margin-top: var(--space-32); display: flex; gap: var(--space-12); flex-wrap: wrap; }
.hero__shapes { position: absolute; inset: 0; z-index: 1; pointer-events: none; }
.hero__shapes .ripple { opacity: calc(0.55 * var(--shape-opacity)); }
.hero__badge {
  position: absolute; right: clamp(16px, 5vw, 64px); top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  display: none;
}

@media (min-width: 1040px) {
  .hero__badge { display: block; }
}

/* ============================================================
   공통 버튼 보강 (DS .btn 위)
   ============================================================ */
.btn .ic { width: 18px; height: 18px; flex: none; }
.btn--xl .ic { width: 20px; height: 20px; }

/* ============================================================
   섹션 공통
   ============================================================ */
.section { padding-block: var(--space-64); position: relative; }
.section--tint { background: var(--color-background-alternative); }
.section__head { margin-bottom: var(--space-40); max-width: 720px; }
.section__head.row {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: var(--space-24); max-width: none;
}
.eyebrow {
  display: block;
  font: var(--type-label-2);
  font-weight: var(--w-semibold);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-primary-normal);
  margin-bottom: var(--space-12);
}
.section__head h2 {
  font: var(--type-title-2);
  letter-spacing: -0.0236em;
  color: var(--color-label-strong);
  text-wrap: balance;
}
.section__head p {
  margin-top: var(--space-12);
  font: var(--type-body-1-read);
  color: var(--color-label-neutral);
  text-wrap: pretty;
}
.link-more {
  display: inline-flex; align-items: center; gap: 6px;
  white-space: nowrap;
  font: var(--type-label-1); font-weight: var(--w-semibold);
  color: var(--color-label-normal);
  flex: none;
}
.link-more:hover { color: var(--color-primary-normal); text-decoration: none; }
.link-more .ic { width: 16px; height: 16px; }

/* ── 핵심 안내 카드 3개 ─────────────────────────────────────── */
.feature-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-24); }
.feature-card {
  position: relative;
  display: flex; flex-direction: column;
  gap: var(--space-16);
  padding: var(--space-32);
  background: var(--color-background-normal);
  border: 1px solid var(--color-line-normal);
  border-radius: var(--radius-20);
  overflow: hidden;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.feature-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-strong);
  border-color: transparent;
  text-decoration: none;
}
.feature-card__ic {
  width: 52px; height: 52px; border-radius: var(--radius-16);
  display: grid; place-items: center; flex: none;
  background: var(--color-primary-light);
  color: var(--color-primary-strong);
}
.feature-card__ic .ic { width: 26px; height: 26px; }
.feature-card:nth-child(2) .feature-card__ic { background: rgb(255 169 56 / 0.16); color: var(--c-orange-45); }
.feature-card:nth-child(3) .feature-card__ic { background: rgb(0 174 255 / 0.14); color: var(--c-lightBlue-40); }
.feature-card h3 { font: var(--type-heading-1); letter-spacing: -0.0194em; color: var(--color-label-strong); }
.feature-card p { font: var(--type-body-2-read); color: var(--color-label-neutral); }
.feature-card__go {
  margin-top: auto;
  display: inline-flex; align-items: center; gap: 6px;
  font: var(--type-label-1); font-weight: var(--w-semibold);
  color: var(--color-primary-normal);
}
.feature-card__go .ic { width: 16px; height: 16px; }
.feature-card__deco {
  position: absolute; right: -40px; bottom: -40px; width: 140px; height: 140px;
  opacity: 0.5; pointer-events: none;
}

/* ── 최신 소식 ──────────────────────────────────────────────── */
.notice-list { display: flex; flex-direction: column; }
.notice-row {
  display: flex; align-items: center; gap: var(--space-20);
  padding: var(--space-20) var(--space-8);
  border-bottom: 1px solid var(--color-line-neutral);
  color: var(--color-label-normal);
}
.notice-row:first-child { border-top: 1px solid var(--color-line-neutral); }
.notice-row:hover { color: var(--color-primary-normal); text-decoration: none; background: var(--color-fill-normal); border-radius: var(--radius-8); }
.notice-row__tag {
  flex: none;
}
.notice-row__title {
  font: var(--type-body-1); font-weight: var(--w-medium);
  color: inherit;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.notice-row__date { margin-left: auto; flex: none; font: var(--type-label-1); color: var(--color-label-assistive); }

/* ── 공공기관 배너존 ────────────────────────────────────────── */
.gov-zone { background: var(--color-background-inverse); }
.gov-zone .wrap { padding-block: var(--space-48); }
.gov-zone__label {
  font: var(--type-label-1); color: rgb(247 247 248 / 0.6);
  margin-bottom: var(--space-20);
  display: flex; align-items: center; gap: var(--space-8);
}
.gov-banners { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-16); }
.gov-banner {
  display: flex; align-items: center; gap: var(--space-16);
  padding: var(--space-16) var(--space-20);
  background: #fff;
  border: 1px solid #e4e6ea;
  border-radius: var(--radius-12);
  color: #1a1d27;
  box-shadow: 0 2px 8px rgb(0 0 0 / 0.06);
  transition: box-shadow .18s ease, border-color .18s ease, transform .18s ease;
}
.gov-banner:hover {
  box-shadow: 0 6px 20px rgb(0 0 0 / 0.12);
  border-color: #c8ccd4;
  transform: translateY(-2px);
  text-decoration: none;
}
.gov-banner__slot {
  width: 100px; height: 44px; flex: none;
  display: grid; place-items: center;
  border-right: 1px solid #e4e6ea;
  padding-right: var(--space-16);
}
.gov-banner__slot img {
  max-width: 100%; max-height: 100%;
  object-fit: contain;
  display: block;
}
.gov-banner__txt { display: flex; flex-direction: column; gap: 3px; min-width: 0; }
.gov-banner__name { font: var(--type-headline-2); font-weight: var(--w-semibold); color: #1a1d27; }
.gov-banner__url {
  font: var(--type-caption-1); color: #888ea0;
  display: inline-flex; align-items: center; gap: 5px;
}
.gov-banner__url .ic { width: 13px; height: 13px; color: #888ea0; }

/* ============================================================
   서브페이지 — 페이지 히어로 + 브레드크럼 + 탭
   ============================================================ */
.page-hero {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(100% 160% at 90% -30%, var(--c-blue-99) 0%, rgba(255,255,255,0) 60%),
    var(--color-background-alternative);
  border-bottom: 1px solid var(--color-line-neutral);
}
.page-hero__inner { padding-block: var(--space-48) var(--space-40); position: relative; z-index: 2; }
.page-hero__shapes { position: absolute; inset: 0; z-index: 1; pointer-events: none; }
.page-hero__shapes .ripple { opacity: calc(0.5 * var(--shape-opacity)); }
.breadcrumb {
  display: flex; align-items: center; gap: var(--space-8);
  font: var(--type-label-1); color: var(--color-label-alternative);
  margin-bottom: var(--space-20); flex-wrap: wrap;
}
.breadcrumb a { color: var(--color-label-alternative); }
.breadcrumb a:hover { color: var(--color-label-strong); }
.breadcrumb a, .breadcrumb .cur, .breadcrumb > span { white-space: nowrap; }
.breadcrumb .sep { color: var(--color-label-assistive); }
.breadcrumb .cur { color: var(--color-label-strong); font-weight: var(--w-semibold); }
.page-hero h1 {
  font: var(--type-title-1);
  letter-spacing: -0.0253em;
  color: var(--color-label-strong);
  text-wrap: balance;
}
.page-hero__desc {
  margin-top: var(--space-16);
  font: var(--type-body-1-read);
  color: var(--color-label-neutral);
  max-width: 64ch; text-wrap: pretty;
}

/* 섹션 탭(같은 대메뉴 형제 페이지) */
.subtabs { border-bottom: 1px solid var(--color-line-normal); background: var(--color-background-normal); position: relative; z-index: 2;}
.subtabs__list {
  display: flex; gap: var(--space-4); overflow-x: auto; scrollbar-width: none;
}
.subtabs__list::-webkit-scrollbar { display: none; }
.subtabs__tab {
  position: relative;
  padding: var(--space-16) var(--space-16);
  font: var(--type-label-1); font-weight: var(--w-medium);
  color: var(--color-label-neutral);
  white-space: nowrap;
}
.subtabs__tab:hover { color: var(--color-label-strong); text-decoration: none; }
.subtabs__tab[aria-current="page"] { color: var(--color-primary-normal); font-weight: var(--w-semibold); }
.subtabs__tab[aria-current="page"]::after {
  content: ""; position: absolute; left: var(--space-16); right: var(--space-16); bottom: -1px;
  height: 2px; background: var(--color-primary-normal);
}

/* ── 본문 영역 ──────────────────────────────────────────────── */
.page-body { padding-block: var(--space-64) var(--space-80); position: relative; z-index: 1; }
.prose { max-width: 820px; }
.prose > * + * { margin-top: var(--space-20); }
.prose h2 {
  font: var(--type-title-3); letter-spacing: -0.023em; color: var(--color-label-strong);
  margin-top: var(--space-48);
}
.prose h2:first-child { margin-top: 0; }
.prose h3 { font: var(--type-heading-2); color: var(--color-label-strong); margin-top: var(--space-32); }
.prose p { font: var(--type-body-1-read); color: var(--color-label-normal); text-wrap: pretty; }
.prose strong { color: var(--color-label-strong); font-weight: var(--w-semibold); }
.prose ul.bullets { display: flex; flex-direction: column; gap: var(--space-12); }
.prose ul.bullets li {
  position: relative; padding-left: var(--space-24);
  font: var(--type-body-1-read); color: var(--color-label-normal);
}
.prose ul.bullets li::before {
  content: ""; position: absolute; left: 4px; top: 10px;
  width: 7px; height: 7px; border-radius: 50%; background: var(--color-primary-normal);
}

.section-title {
  font: var(--type-title-3); letter-spacing: -0.023em; color: var(--color-label-strong);
  margin-bottom: var(--space-24);
  display: flex; align-items: center; gap: var(--space-12);
}
.section-title .num {
  width: 30px; height: 30px; flex: none; border-radius: var(--radius-8);
  display: grid; place-items: center;
  background: var(--color-primary-light); color: var(--color-primary-strong);
  font: var(--type-label-1); font-weight: var(--w-bold);
}
.block { margin-top: var(--space-48); }
.block:first-child { margin-top: 0; }

/* 인용형 콘텐츠 초안 박스(명세서의 '노란 박스') */
.draft {
  border-left: 3px solid var(--shape-3);
  background: rgb(255 169 56 / 0.08);
  border-radius: 0 var(--radius-12) var(--radius-12) 0;
  padding: var(--space-24) var(--space-28);
  font: var(--type-body-1-read);
  color: var(--color-label-normal);
}
.draft p + p { margin-top: var(--space-16); }
.draft .sign { display: block; margin-top: var(--space-20); font-weight: var(--w-semibold); color: var(--color-label-strong); }

/* 인사말 레이아웃 */
.greeting-wrap {
  display: flex;
  gap: 52px;
  align-items: flex-start;
  max-width: 900px;
}
.greeting-figure {
  flex: 0 0 220px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
}
.greeting-figure img {
  width: 220px;
  height: 290px;
  object-fit: cover;
  object-position: center top;
  border-radius: 28px;
  box-shadow: 0 8px 24px rgb(0 0 0 / 0.15);
  display: block;
}
.greeting-figure figcaption {
  width: 220px;
  background: var(--color-primary-normal, #0066ff);
  border-radius: 0 0 16px 16px;
  padding: 14px 20px;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.greeting-figure__role {
  font-size: 12px;
  font-weight: 500;
  color: rgb(255 255 255 / 0.75);
  letter-spacing: 0.08em;
}
.greeting-figure__name {
  font-size: 18px;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0.14em;
}
.greeting-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding-top: 4px;
}
.greeting-body__lead {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--color-label-strong);
  line-height: 1.65;
  border-left: 3px solid var(--color-primary-normal, #0066ff);
  padding-left: 16px;
}
.greeting-body p {
  font-size: 1rem;
  line-height: 1.9;
  color: var(--color-label-normal);
}
.greeting-body__sig {
  margin-top: 8px;
  padding-top: 20px;
  border-top: 1px solid var(--color-line-neutral);
  text-align: right;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.greeting-body__sig-org {
  font-size: 13px;
  color: var(--color-label-alternative);
}
.greeting-body__sig-name {
  font-size: 20px;
  font-weight: 700;
  color: var(--color-label-strong);
  letter-spacing: 0.12em;
}
@media (max-width: 700px) {
  .greeting-wrap { flex-direction: column; gap: 32px; align-items: center; }
  .greeting-body__lead { font-size: 1rem; }
}

/* 정보 카드 그리드 */
.card-grid { display: grid; gap: var(--space-20); }
.card-grid.cols-2 { grid-template-columns: repeat(2, 1fr); }
.card-grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
.info-card {
  padding: var(--space-28);
  background: var(--color-background-normal);
  border: 1px solid var(--color-line-normal);
  border-radius: var(--radius-16);
  display: flex; flex-direction: column; gap: var(--space-12);
}
.info-card__ic {
  width: 44px; height: 44px; border-radius: var(--radius-12); flex: none;
  display: grid; place-items: center;
  background: var(--color-primary-light); color: var(--color-primary-strong);
}
.info-card__ic .ic { width: 22px; height: 22px; }
.info-card h3 { font: var(--type-headline-1); color: var(--color-label-strong); }
.info-card p { font: var(--type-body-2-read); color: var(--color-label-neutral); }

/* ── 주요 사업 소개 페이지 전용 ──────────────────────────────── */
.biz-page { display: flex; flex-direction: column; gap: 72px; }

/* 사업 개요 배너 */
.biz-overview {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1px;
  border: 1px solid var(--color-line-neutral);
  border-radius: 16px; overflow: hidden;
  background: var(--color-line-neutral);
}
.biz-overview__main {
  background: var(--color-primary-normal);
  padding: 40px 44px;
  display: flex; flex-direction: column; gap: 16px;
}
.biz-overview__main-label {
  font-size: 11px; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase;
  color: rgb(255 255 255 / 0.6);
}
.biz-overview__main-text {
  font-size: 1.05rem; line-height: 1.85;
  color: rgb(255 255 255 / 0.9); font-weight: 400;
}
.biz-overview__main-text strong { color: #fff; font-weight: 700; }
.biz-overview__stats {
  background: var(--color-background-normal);
  padding: 40px 44px;
  display: flex; flex-direction: column; justify-content: center; gap: 24px;
}
.biz-stat-row {
  display: flex; flex-direction: column; gap: 5px;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--color-line-neutral);
}
.biz-stat-row:last-child { border-bottom: 0; padding-bottom: 0; }
.biz-stat-row__num {
  font-size: 2rem; font-weight: 800; letter-spacing: -0.03em;
  color: var(--color-primary-normal); line-height: 1;
}
.biz-stat-row__num span { font-size: 1rem; font-weight: 500; margin-left: 2px; }
.biz-stat-row__label {
  font-size: 13px; color: var(--color-label-alternative); line-height: 1.5;
}

/* 서비스 카드 (가로형) */
.svc-list { display: flex; flex-direction: column; gap: 16px; }
.svc-card {
  display: grid; grid-template-columns: 72px 1fr;
  border: 1px solid var(--color-line-neutral);
  border-radius: 16px; overflow: hidden;
  background: var(--color-background-normal);
  transition: box-shadow .18s ease, border-color .18s ease;
}
.svc-card:hover {
  box-shadow: 0 6px 24px rgb(0 0 0 / 0.07);
  border-color: var(--color-line-strong);
}
.svc-card__aside {
  background: var(--color-primary-normal);
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; gap: 10px; padding: 28px 12px;
}
.svc-card__num {
  font-size: 11px; font-weight: 800; letter-spacing: 0.08em;
  color: rgb(255 255 255 / 0.5); text-transform: uppercase;
}
.svc-card__aside .ic { width: 26px; height: 26px; color: #fff; }
.svc-card__body {
  padding: 28px 36px;
  display: flex; flex-direction: column; gap: 10px;
}
.svc-card__head {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
}
.svc-card__title {
  font-size: 1.2rem; font-weight: 700;
  color: var(--color-label-strong); letter-spacing: -0.01em;
}
.svc-card__tag {
  display: inline-flex; align-items: center;
  padding: 3px 10px; border-radius: 4px;
  font-size: 11px; font-weight: 600; letter-spacing: 0.04em;
  background: var(--color-fill-normal);
  color: var(--color-label-alternative);
  border: 1px solid var(--color-line-neutral);
}
.svc-card__desc {
  font-size: 14px; line-height: 1.8;
  color: var(--color-label-normal);
}
.svc-card__points {
  display: flex; flex-direction: column; gap: 5px;
  padding-top: 10px; margin-top: 2px;
  border-top: 1px solid var(--color-line-neutral);
}
.svc-card__point {
  display: flex; align-items: baseline; gap: 8px;
  font-size: 13px; color: var(--color-label-normal); line-height: 1.6;
}
.svc-card__point::before {
  content: ""; display: block; flex: none;
  width: 4px; height: 4px; border-radius: 50%;
  background: var(--color-primary-normal); margin-top: 7px;
}

/* 하단 안내 */
.biz-notice {
  display: flex; align-items: flex-start; gap: 14px;
  padding: 20px 28px;
  border: 1px solid var(--color-line-neutral);
  border-radius: 10px;
  background: var(--color-fill-normal);
}
.biz-notice .ic { width: 16px; height: 16px; flex: none; margin-top: 2px; color: var(--color-label-assistive); }
.biz-notice p { font-size: 13px; line-height: 1.7; color: var(--color-label-alternative); }

@media (max-width: 680px) {
  .biz-overview { grid-template-columns: 1fr; }
  .svc-card { grid-template-columns: 56px 1fr; }
  .svc-card__body { padding: 20px 20px; }
}

/* ── 표 ─────────────────────────────────────────────────────── */
.table-wrap { overflow-x: auto; border: 1px solid var(--color-line-normal); border-radius: var(--radius-16); }
table.data {
  width: 100%; border-collapse: collapse; min-width: 460px;
  font: var(--type-body-2); background: var(--color-background-normal);
}
table.data caption {
  text-align: left; padding: var(--space-16) var(--space-20);
  font: var(--type-label-1); color: var(--color-label-alternative);
  border-bottom: 1px solid var(--color-line-neutral);
}
table.data th, table.data td {
  padding: var(--space-16) var(--space-20); text-align: left;
  border-bottom: 1px solid var(--color-line-neutral);
  vertical-align: top;
}
table.data thead th {
  background: var(--color-background-alternative);
  font-weight: var(--w-semibold); color: var(--color-label-strong);
  white-space: nowrap;
}
table.data tbody th { font-weight: var(--w-semibold); color: var(--color-label-strong); }
table.data tr:last-child td, table.data tr:last-child th { border-bottom: 0; }
table.data td.num { font-variant-numeric: tabular-nums; }
.row-total { background: var(--color-primary-light); }
.row-total th, .row-total td { color: var(--color-primary-heavy); font-weight: var(--w-bold); }

/* ── 타임라인(연혁) ─────────────────────────────────────────── */
.timeline { display: flex; flex-direction: column; gap: 0; position: relative; }
.tl-item {
  display: grid; grid-template-columns: 132px 1fr; gap: var(--space-24);
  padding-bottom: var(--space-32); position: relative;
}
.tl-item::before {
  content: ""; position: absolute; left: 140px; top: 8px; bottom: -8px;
  width: 2px; background: var(--color-line-normal);
}
.tl-item:last-child::before { display: none; }
.tl-date { font: var(--type-label-1); font-weight: var(--w-bold); color: var(--color-primary-normal); text-align: right; padding-top: 1px; }
.tl-body { position: relative; padding-left: var(--space-24); }
.tl-body::before {
  content: ""; position: absolute; left: -7px; top: 5px; width: 14px; height: 14px;
  border-radius: 50%; background: var(--color-background-normal);
  border: 3px solid var(--color-primary-normal);
}
.tl-item.future .tl-date { color: var(--color-label-assistive); }
.tl-item.future .tl-body::before { border-color: var(--color-line-strong); }
.tl-title { font: var(--type-body-1); font-weight: var(--w-semibold); color: var(--color-label-strong); }
.tl-note { font: var(--type-body-2); color: var(--color-label-neutral); margin-top: 4px; }

/* ── 설립목적·연혁 페이지 전용 ─────────────────────────────── */
.purpose-page { display: flex; flex-direction: column; gap: 72px; max-width: 840px; }

.purpose-section__eyebrow {
  font-size: 11px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--color-label-assistive); margin-bottom: 10px; display: block;
}
.purpose-section__heading {
  font-size: 1.75rem; font-weight: 700;
  color: var(--color-label-strong);
  letter-spacing: -0.025em; line-height: 1.25;
  margin-bottom: 32px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--color-line-neutral);
}

/* 설립 목적 callout */
.purpose-callout {
  border-left: 3px solid #1a1d27;
  padding: 4px 0 4px 28px;
}
.purpose-callout p {
  font-size: 1.1rem; line-height: 2;
  color: var(--color-label-normal); font-weight: 400;
}

/* 주 사업 유형 */
.biz-type-wrap {
  display: grid; grid-template-columns: 1fr auto; gap: 48px; align-items: center;
}
.biz-type-wrap p {
  font-size: 1rem; line-height: 1.95; color: var(--color-label-normal);
}
.biz-stat {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  width: 160px; height: 160px;
  border: 2px solid var(--color-label-strong);
  border-radius: 50%;
  text-align: center;
  flex-shrink: 0;
}
.biz-stat__num {
  font-size: 2.4rem; font-weight: 800; color: var(--color-label-strong); line-height: 1;
  letter-spacing: -0.03em;
}
.biz-stat__label {
  font-size: 11px; color: var(--color-label-alternative); margin-top: 8px;
  line-height: 1.5; letter-spacing: 0.04em;
}

/* 새 타임라인 */
.ptl { display: flex; flex-direction: column; gap: 0; }
.ptl-item {
  display: grid; grid-template-columns: 120px 1fr;
  gap: 0; position: relative; padding-bottom: 40px;
}
.ptl-item:last-child { padding-bottom: 0; }
.ptl-item::after {
  content: ""; position: absolute;
  left: 119px; top: 22px; bottom: 0;
  width: 1px; background: var(--color-line-neutral);
}
.ptl-item:last-child::after { display: none; }
.ptl-left {
  padding-right: 32px; padding-top: 2px; text-align: right;
}
.ptl-date {
  font-size: 12px; font-weight: 600; color: var(--color-label-assistive);
  letter-spacing: 0.02em; line-height: 1.6;
}
.ptl-right {
  padding-left: 32px; position: relative;
}
.ptl-right::before {
  content: ""; position: absolute; left: -5px; top: 7px;
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--color-label-strong);
}
.ptl-item.highlight .ptl-right::before {
  width: 12px; height: 12px; left: -6px; top: 6px;
  background: var(--color-primary-normal);
}
.ptl-title {
  font-size: 1rem; font-weight: 600; color: var(--color-label-strong);
  line-height: 1.5; padding-top: 0;
}
.ptl-item.highlight .ptl-title { color: var(--color-primary-normal); }
.ptl-note {
  font-size: 13px; color: var(--color-label-alternative); margin-top: 5px;
}
@media (max-width: 640px) {
  .biz-type-wrap { grid-template-columns: 1fr; justify-items: start; }
  .biz-stat { width: 140px; height: 140px; }
  .ptl-item { grid-template-columns: 90px 1fr; }
  .ptl-item::after { left: 89px; }
  .purpose-callout { padding-left: 20px; }
}

/* ── 조직도 ─────────────────────────────────────────────────── */
.orgchart { display: flex; flex-direction: column; align-items: center; gap: 0; }
.org-node {
  padding: var(--space-12) var(--space-24); border-radius: var(--radius-full);
  font: var(--type-label-1); font-weight: var(--w-semibold);
  background: var(--color-background-normal); border: 1.5px solid var(--color-line-strong);
  color: var(--color-label-strong); text-align: center;
}
.org-node.primary { background: var(--color-primary-normal); color: var(--color-primary-on); border-color: var(--color-primary-normal); }
.org-node.accent { border-color: var(--shape-3); color: var(--c-orange-45); }
.org-connector { width: 2px; height: 22px; background: var(--color-line-strong); }
.org-row { display: flex; gap: var(--space-24); align-items: flex-start; }

/* ── 폼 보강 ────────────────────────────────────────────────── */
.form-card {
  background: var(--color-background-normal);
  border: 1px solid var(--color-line-normal);
  border-radius: var(--radius-20);
  padding: var(--space-40);
  max-width: 640px;
}
.form-grid { display: flex; flex-direction: column; gap: var(--space-20); }
.form-note {
  font: var(--type-caption-1); color: var(--color-label-alternative);
  display: flex; align-items: flex-start; gap: 6px; margin-top: var(--space-8);
}

/* ── 오시는 길 페이지 전용 ──────────────────────────────────── */
.location-page { display: flex; flex-direction: column; gap: 0; max-width: 960px; }

.location-map {
  width: 100%; aspect-ratio: 16/7; min-height: 280px;
  border-radius: 16px; overflow: hidden;
  background: var(--color-fill-normal);
  border: 1px solid var(--color-line-neutral);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 40px;
}
.location-map iframe { width: 100%; height: 100%; border: 0; display: block; }
.location-map__placeholder {
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  color: var(--color-label-assistive);
  font-size: 13px; text-align: center;
}
.location-map__placeholder .ic { width: 32px; height: 32px; opacity: 0.4; }

.location-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1px;
  border: 1px solid var(--color-line-neutral);
  border-radius: 12px; overflow: hidden;
  background: var(--color-line-neutral);
  margin-bottom: 40px;
}
.location-item {
  background: var(--color-background-normal);
  padding: 28px 32px;
  display: flex; flex-direction: column; gap: 10px;
}
.location-item__head {
  display: flex; align-items: center; gap: 10px;
}
.location-item__icon {
  width: 36px; height: 36px; border-radius: 8px; flex: none;
  background: var(--color-fill-normal);
  display: grid; place-items: center;
}
.location-item__icon .ic { width: 18px; height: 18px; color: var(--color-label-strong); }
.location-item__label {
  font-size: 11px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--color-label-assistive);
}
.location-item__value {
  font-size: 1rem; font-weight: 500; color: var(--color-label-strong);
  line-height: 1.65;
}
.location-item__sub {
  font-size: 13px; color: var(--color-label-alternative); line-height: 1.6;
}

.transport-section { display: flex; flex-direction: column; gap: 20px; }
.transport-row {
  display: grid; grid-template-columns: 100px 1fr;
  gap: 0; border-bottom: 1px solid var(--color-line-neutral); padding-bottom: 20px;
}
.transport-row:last-child { border-bottom: 0; padding-bottom: 0; }
.transport-type {
  display: flex; align-items: flex-start; gap: 8px; padding-top: 2px;
}
.transport-badge {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 3px 10px; border-radius: 4px;
  font-size: 12px; font-weight: 700; letter-spacing: 0.04em;
  white-space: nowrap;
}
.transport-badge.subway { background: #3d5afe; color: #fff; }
.transport-badge.bus    { background: #00897b; color: #fff; }
.transport-badge.car    { background: var(--color-fill-normal); color: var(--color-label-normal); border: 1px solid var(--color-line-neutral); }
.transport-desc {
  font-size: 14px; line-height: 1.75; color: var(--color-label-normal); padding-top: 3px;
}

@media (max-width: 680px) {
  .location-grid { grid-template-columns: 1fr; }
  .transport-row { grid-template-columns: 80px 1fr; }
  .location-map { aspect-ratio: 4/3; }
}

/* ── 게시판 목록/카드/갤러리 ────────────────────────────────── */
.bbs-toolbar { display: flex; align-items: center; justify-content: space-between; gap: var(--space-16); margin-bottom: var(--space-20); flex-wrap: wrap; }
.bbs-search { display: flex; align-items: center; gap: var(--space-8); max-width: 320px; width: 100%; }
.bbs-list { border-top: 2px solid var(--color-label-strong); }
.bbs-row {
  display: grid; grid-template-columns: 64px 1fr auto; gap: var(--space-20); align-items: center;
  padding: var(--space-20) var(--space-12);
  border-bottom: 1px solid var(--color-line-neutral);
  color: var(--color-label-normal);
}
.bbs-row:hover { background: var(--color-fill-normal); text-decoration: none; }
.bbs-num { font: var(--type-label-1); color: var(--color-label-assistive); text-align: center; }
.bbs-row__title { font: var(--type-body-1); font-weight: var(--w-medium); color: var(--color-label-strong); }
.bbs-meta { display: flex; gap: var(--space-16); font: var(--type-caption-1); color: var(--color-label-alternative); white-space: nowrap; }

.press-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-24); }
.press-card {
  border: 1px solid var(--color-line-normal); border-radius: var(--radius-16);
  overflow: hidden; background: var(--color-background-normal);
  display: flex; flex-direction: column;
  transition: transform .2s ease, box-shadow .2s ease;
}
.press-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-normal); text-decoration: none; }
.media-slot {
  aspect-ratio: 16 / 10; background: var(--color-background-alternative);
  display: grid; place-items: center; color: var(--color-label-assistive);
  border-bottom: 1px solid var(--color-line-neutral);
  position: relative; overflow: hidden;
}
.media-slot__hint { font: var(--type-caption-1); display: flex; flex-direction: column; align-items: center; gap: 6px; }
.media-slot__hint .ic { width: 24px; height: 24px; opacity: 0.6; }
.press-card__body { padding: var(--space-20) var(--space-24) var(--space-24); display: flex; flex-direction: column; gap: var(--space-8); }
.press-card__date { font: var(--type-caption-1); color: var(--color-label-alternative); }
.press-card h3 { font: var(--type-headline-1); color: var(--color-label-strong); }
.press-card p { font: var(--type-body-2-read); color: var(--color-label-neutral); }

.gallery-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-16); }
.gallery-grid .media-slot { aspect-ratio: 4 / 3; border-radius: var(--radius-12); border: 1px solid var(--color-line-neutral); }

/* ── 알림/안내 박스 ─────────────────────────────────────────── */
.callout {
  display: flex; gap: var(--space-16); align-items: flex-start;
  padding: var(--space-20) var(--space-24);
  background: var(--color-primary-light);
  border-radius: var(--radius-12);
  color: var(--color-primary-heavy);
}
.callout .ic { width: 22px; height: 22px; flex: none; margin-top: 1px; }
.callout p { font: var(--type-body-2-read); color: var(--color-primary-heavy); }
.callout--neutral { background: var(--color-background-alternative); color: var(--color-label-normal); }
.callout--neutral p { color: var(--color-label-normal); }

/* ── 임원·조직·조합원 페이지 전용 ─────────────────────────── */
.people-page { display: flex; flex-direction: column; gap: 72px; max-width: 860px; }

.people-notice {
  display: flex; align-items: flex-start; gap: 14px;
  padding: 20px 24px;
  border: 1px solid var(--color-line-neutral);
  border-left: 3px solid var(--color-label-strong);
  border-radius: 0 10px 10px 0;
  background: var(--color-fill-normal);
}
.people-notice .ic { width: 18px; height: 18px; flex: none; margin-top: 2px; color: var(--color-label-strong); }
.people-notice p { font-size: 14px; line-height: 1.7; color: var(--color-label-normal); }
.people-notice strong { color: var(--color-label-strong); }

/* 임원 카드 그리드 */
.officer-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 1px;
  border: 1px solid var(--color-line-neutral);
  border-radius: 12px;
  overflow: hidden;
  background: var(--color-line-neutral);
}
.officer-card {
  display: flex; flex-direction: column; gap: 6px;
  padding: 24px 24px 22px;
  background: var(--color-background-normal);
}
.officer-card__role {
  font-size: 11px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--color-label-assistive);
}
.officer-card__name {
  font-size: 1.2rem; font-weight: 700;
  color: var(--color-label-strong); letter-spacing: 0.02em;
}
.officer-card__career {
  font-size: 13px; line-height: 1.6;
  color: var(--color-label-alternative);
  margin-top: 2px;
}
.officer-card.is-head { background: var(--color-fill-normal); }
.officer-card.is-head .officer-card__role { color: var(--color-primary-normal); }
.officer-card.is-head .officer-card__name { font-size: 1.35rem; }

/* 조합원 현황 통계 */
.member-stats {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 1px;
  border: 1px solid var(--color-line-neutral);
  border-radius: 12px;
  overflow: hidden;
  background: var(--color-line-neutral);
}
.member-stat {
  display: flex; flex-direction: column; align-items: center;
  padding: 24px 12px;
  background: var(--color-background-normal);
  text-align: center;
}
.member-stat__label {
  font-size: 11px; font-weight: 600; letter-spacing: 0.08em;
  color: var(--color-label-assistive); margin-bottom: 10px;
}
.member-stat__num {
  font-size: 1.8rem; font-weight: 800;
  color: var(--color-label-strong); letter-spacing: -0.02em; line-height: 1;
}
.member-stat__unit {
  font-size: 12px; font-weight: 400; color: var(--color-label-alternative);
  margin-top: 4px;
}
.member-stat.is-total {
  background: var(--color-label-strong);
}
.member-stat.is-total .member-stat__label { color: rgb(255 255 255 / 0.55); }
.member-stat.is-total .member-stat__num { color: #fff; }
.member-stat.is-total .member-stat__unit { color: rgb(255 255 255 / 0.7); }

/* 조직도 */
.org2 { display: flex; flex-direction: column; align-items: center; gap: 0; max-width: 480px; }
.org2-top { width: 100%; }
.org2-node {
  padding: 14px 28px;
  border: 1.5px solid var(--color-line-strong);
  border-radius: 8px;
  font-size: 14px; font-weight: 600;
  color: var(--color-label-strong);
  text-align: center;
  background: var(--color-background-normal);
}
.org2-node.top {
  background: var(--color-label-strong); color: #fff;
  border-color: var(--color-label-strong);
  padding: 16px 28px; font-size: 15px;
}
.org2-vline {
  width: 1.5px; height: 28px;
  background: var(--color-line-strong);
}
.org2-mid {
  display: flex; align-items: flex-start; gap: 0; width: 100%;
}
.org2-mid-left { flex: 1; display: flex; flex-direction: column; align-items: center; }
.org2-mid-right { display: flex; flex-direction: column; align-items: center; padding-top: 0; }
.org2-hline {
  height: 1.5px; background: var(--color-line-strong);
  flex: 1; margin-top: 27px;
}
.org2-bottom { display: flex; flex-direction: column; align-items: center; }

@media (max-width: 640px) {
  .officer-grid { grid-template-columns: 1fr 1fr; }
  .member-stats { grid-template-columns: repeat(3, 1fr); }
}

/* 외부 바로가기 버튼(공시/신고 등) */
.ext-links { display: flex; flex-wrap: wrap; gap: var(--space-12); }

/* ── 경영공시 공통 안내 (개선) ──────────────────────────────── */
.disc-notice {
  font-size: 13px; color: var(--color-label-alternative);
  line-height: 1.7;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--color-line-neutral);
  max-width: 760px;
}

/* ── 문서 다운로드 리스트 ────────────────────────────────────── */
.doc-list {
  border: 1px solid var(--color-line-neutral);
  border-radius: 12px;
  overflow: hidden;
}
.doc-row {
  display: flex; align-items: center; gap: 20px;
  padding: 18px 24px;
  background: var(--color-background-normal);
  border-bottom: 1px solid var(--color-line-neutral);
  transition: background .14s ease;
}
.doc-row:last-child { border-bottom: 0; }
.doc-row:hover { background: var(--color-fill-normal); }
.doc-row__icon {
  width: 36px; height: 36px; flex: none;
  display: grid; place-items: center;
  color: var(--color-primary-normal);
}
.doc-row__icon .ic { width: 20px; height: 20px; }
.doc-row__info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 3px; }
.doc-row__name {
  font-size: 15px; font-weight: 600;
  color: var(--color-label-strong); line-height: 1.4;
}
.doc-row__meta {
  font-size: 12px; color: var(--color-label-assistive); letter-spacing: 0.02em;
}
.doc-row__action {
  flex: none;
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 14px; border-radius: 6px;
  font-size: 13px; font-weight: 600; letter-spacing: 0.03em;
  border: 1px solid var(--color-line-neutral);
  color: var(--color-label-normal);
  background: var(--color-background-normal);
  text-decoration: none;
  transition: border-color .14s, background .14s, color .14s;
}
.doc-row__action:hover {
  border-color: var(--color-primary-normal);
  color: var(--color-primary-normal);
  background: var(--color-primary-light, #eff3ff);
  text-decoration: none;
}
.doc-row__action .ic { width: 14px; height: 14px; }

/* 총회·이사회 결과 카드 */
.meeting-card {
  border: 1px solid var(--color-line-neutral);
  border-radius: 12px;
  overflow: hidden;
}
.meeting-card__head {
  display: flex; align-items: center; gap: 12px;
  padding: 16px 24px;
  background: var(--color-fill-normal);
  border-bottom: 1px solid var(--color-line-neutral);
}
.meeting-card__head h3 {
  font-size: 15px; font-weight: 700;
  color: var(--color-label-strong); flex: 1;
}
.meeting-card__head time {
  font-size: 12px; color: var(--color-label-assistive);
  font-weight: 500;
}
.meeting-card__body { padding: 20px 24px; }
.meeting-card__body ul {
  display: flex; flex-direction: column; gap: 10px;
  list-style: none; margin: 0; padding: 0;
}
.meeting-card__body li {
  display: flex; align-items: baseline; gap: 10px;
  font-size: 14px; color: var(--color-label-normal); line-height: 1.6;
}
.meeting-card__body li::before {
  content: ""; flex: none; width: 4px; height: 4px;
  border-radius: 50%; background: var(--color-primary-normal);
  margin-top: 8px;
}

/* ── 프로세스 스텝 플로우 ────────────────────────────────────── */
.step-flow {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  position: relative;
  gap: 0;
}
.step-flow::before {
  content: "";
  position: absolute;
  top: 28px; left: calc(12.5% + 0px); right: calc(12.5% + 0px);
  height: 1px; background: var(--color-line-neutral);
  z-index: 0;
}
.step-item {
  display: flex; flex-direction: column; align-items: center;
  gap: 16px; padding: 0 16px; text-align: center;
  position: relative; z-index: 1;
}
.step-item__num {
  width: 56px; height: 56px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: var(--color-background-normal);
  border: 1.5px solid var(--color-line-neutral);
  font-size: 13px; font-weight: 700;
  color: var(--color-label-alternative);
  letter-spacing: 0.04em;
  transition: background .2s, border-color .2s, color .2s;
}
.step-item.is-active .step-item__num {
  background: var(--color-primary-normal);
  border-color: var(--color-primary-normal);
  color: #fff;
  box-shadow: 0 4px 12px rgb(0 102 255 / 0.25);
}
.step-item__title {
  font-size: 15px; font-weight: 700;
  color: var(--color-label-strong); line-height: 1.35;
}
.step-item__desc {
  font-size: 13px; color: var(--color-label-alternative);
  line-height: 1.65;
}
.step-action {
  display: flex; align-items: center; gap: 16px;
  margin-top: 40px; padding-top: 32px;
  border-top: 1px solid var(--color-line-neutral);
}
.step-action p {
  font-size: 13px; color: var(--color-label-alternative);
  line-height: 1.6; flex: 1;
}
@media (max-width: 640px) {
  .step-flow { grid-template-columns: 1fr 1fr; gap: 32px 0; }
  .step-flow::before { display: none; }
}

/* ── 문의하기 페이지 전용 ────────────────────────────────────── */
.contact-layout {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 64px;
  align-items: start;
}
.contact-form { display: flex; flex-direction: column; gap: 24px; }
.contact-form .field { display: flex; flex-direction: column; gap: 7px; }
.contact-form .field-label {
  font-size: 13px; font-weight: 600;
  color: var(--color-label-normal); letter-spacing: 0.02em;
}
.contact-form .req { color: var(--color-primary-normal); }
.contact-form .input,
.contact-form .textarea {
  width: 100%;
  padding: 11px 14px;
  border: 1px solid var(--color-line-neutral);
  border-radius: 8px;
  font-size: 14px;
  color: var(--color-label-strong);
  background: var(--color-background-normal);
  transition: border-color .15s;
}
.contact-form .input:focus,
.contact-form .textarea:focus {
  outline: none;
  border-color: var(--color-primary-normal);
  box-shadow: 0 0 0 3px rgb(0 102 255 / 0.1);
}
.contact-form .textarea { min-height: 140px; resize: vertical; }
.contact-form .check {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 13px; color: var(--color-label-alternative); cursor: pointer;
}
.contact-form .check input { margin-top: 2px; flex: none; }
.contact-form .btn--submit {
  align-self: flex-start;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 28px;
  background: var(--color-primary-normal);
  color: #fff; font-size: 14px; font-weight: 700;
  border: none; border-radius: 8px; cursor: pointer;
  transition: background .15s, box-shadow .15s;
}
.contact-form .btn--submit:hover {
  background: var(--color-primary-heavy, #0047cc);
  box-shadow: 0 4px 12px rgb(0 102 255 / 0.3);
}
.contact-form .btn--submit .ic { width: 16px; height: 16px; }

.contact-sidebar { display: flex; flex-direction: column; gap: 1px; }
.contact-info-item {
  display: flex; flex-direction: column; gap: 6px;
  padding: 24px 0;
  border-bottom: 1px solid var(--color-line-neutral);
}
.contact-info-item:first-child { padding-top: 0; }
.contact-info-item:last-child { border-bottom: 0; }
.contact-info-item__label {
  font-size: 11px; font-weight: 700; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--color-label-assistive);
  display: flex; align-items: center; gap: 7px;
}
.contact-info-item__label .ic { width: 14px; height: 14px; }
.contact-info-item__value {
  font-size: 1rem; font-weight: 600;
  color: var(--color-label-strong); line-height: 1.4;
}
.contact-info-item__sub {
  font-size: 13px; color: var(--color-label-alternative);
}
@media (max-width: 700px) {
  .contact-layout { grid-template-columns: 1fr; gap: 40px; }
}

/* ── 페이지 안내(placeholder) 강조 ──────────────────────────── */
.ph {
  background: rgb(255 169 56 / 0.18);
  color: var(--c-orange-45);
  border-radius: var(--radius-4);
  padding: 0 5px; font-weight: var(--w-semibold);
  white-space: nowrap;
}

/* ============================================================
   푸터
   ============================================================ */
.site-footer { background: var(--color-background-inverse); color: rgb(247 247 248 / 0.7); margin-top: var(--space-80); position: relative; z-index: 1; }
.footer-banners { border-bottom: 1px solid rgb(247 247 248 / 0.1); }
.footer-banners .wrap { padding-block: var(--space-32); }
.footer-banners__label { font: var(--type-label-2); letter-spacing: 0.06em; text-transform: uppercase; color: rgb(247 247 248 / 0.45); margin-bottom: var(--space-16); }
.footer-info .wrap { padding-block: var(--space-40) var(--space-48); display: grid; grid-template-columns: 1.2fr 1fr; gap: var(--space-40); }
.footer-brand__name { font: var(--type-headline-1); color: var(--color-static-white); margin-bottom: var(--space-16); }
.footer-info dl { display: grid; grid-template-columns: auto 1fr; gap: 6px var(--space-16); font: var(--type-body-2); }
.footer-info dt { color: rgb(247 247 248 / 0.45); white-space: nowrap; }
.footer-info dd { margin: 0; color: rgb(247 247 248 / 0.8); }
.footer-links { display: flex; flex-direction: column; gap: var(--space-12); align-items: flex-start; }
.footer-links a { color: rgb(247 247 248 / 0.8); font: var(--type-body-2); }
.footer-links a:hover { color: var(--color-static-white); }
.footer-bottom { border-top: 1px solid rgb(247 247 248 / 0.1); }
.footer-bottom .wrap { padding-block: var(--space-20); display: flex; justify-content: space-between; gap: var(--space-16); flex-wrap: wrap; font: var(--type-caption-1); color: rgb(247 247 248 / 0.4); }

/* ============================================================
   아이콘 헬퍼
   ============================================================ */
.ic { display: inline-flex; align-items: center; justify-content: center; }
.ic svg { width: 100%; height: 100%; display: block; }

/* ============================================================
   모바일 메뉴 시트
   ============================================================ */
.mobile-nav {
  position: fixed; inset: 0; z-index: 200;
  background: var(--color-material-dimmer);
  opacity: 0; visibility: hidden; transition: opacity .2s ease;
}
.mobile-nav.open { opacity: 1; visibility: visible; }
.mobile-nav__sheet {
  position: absolute; right: 0; top: 0; bottom: 0; width: min(86vw, 360px);
  background: var(--color-background-normal);
  transform: translateX(100%); transition: transform .25s ease;
  display: flex; flex-direction: column;
  overflow-y: auto;
}
.mobile-nav.open .mobile-nav__sheet { transform: none; }
.mobile-nav__head { display: flex; align-items: center; justify-content: space-between; padding: var(--space-16) var(--space-20); border-bottom: 1px solid var(--color-line-neutral); }
.mobile-nav__close { width: 44px; height: 44px; border: 0; background: none; cursor: pointer; color: var(--color-label-strong); display: grid; place-items: center; }
.mobile-nav__close .ic { width: 22px; height: 22px; }
.mnav-group { border-bottom: 1px solid var(--color-line-neutral); padding: var(--space-12) var(--space-12); }
.mnav-group__title { font: var(--type-label-1); font-weight: var(--w-bold); color: var(--color-label-strong); padding: var(--space-12); }
.mnav-sub { display: block; padding: var(--space-12) var(--space-16); border-radius: var(--radius-8); color: var(--color-label-normal); font: var(--type-body-2); }
.mnav-sub:hover, .mnav-sub[aria-current="page"] { background: var(--color-fill-normal); text-decoration: none; }

/* ============================================================
   Tweaks 패널 (호스트 토글로만 표시)
   ============================================================ */
#tweaks {
  position: fixed; right: 20px; bottom: 20px; z-index: 500;
  width: 280px;
  background: var(--color-background-elevated);
  border: 1px solid var(--color-line-normal);
  border-radius: var(--radius-16);
  box-shadow: var(--shadow-heavy);
  padding: var(--space-20);
  display: none;
  font: var(--type-body-2);
}
#tweaks.show { display: block; }
#tweaks h4 { font: var(--type-headline-2); color: var(--color-label-strong); display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--space-16); }
#tweaks .tw-close { border: 0; background: none; cursor: pointer; color: var(--color-label-alternative); font-size: 18px; line-height: 1; }
.tw-field { margin-bottom: var(--space-16); }
.tw-field > label { display: block; font: var(--type-label-2); font-weight: var(--w-semibold); color: var(--color-label-neutral); margin-bottom: var(--space-8); }
.tw-seg { display: flex; gap: 4px; background: var(--color-fill-normal); padding: 4px; border-radius: var(--radius-8); }
.tw-seg button {
  flex: 1; border: 0; background: none; cursor: pointer; padding: 7px 4px;
  border-radius: var(--radius-6); font: var(--type-label-2); color: var(--color-label-neutral);
}
.tw-seg button[aria-pressed="true"] { background: var(--color-background-normal); color: var(--color-label-strong); box-shadow: var(--shadow-emphasize); }
.tw-swatches { display: flex; gap: var(--space-8); }
.tw-swatch {
  width: 40px; height: 28px; border-radius: var(--radius-8); cursor: pointer;
  border: 2px solid transparent; padding: 0; position: relative; overflow: hidden;
  display: flex;
}
.tw-swatch span { flex: 1; }
.tw-swatch[aria-pressed="true"] { border-color: var(--color-label-strong); }

/* ============================================================
   반응형
   ============================================================ */
@media (max-width: 980px) {
  .feature-grid, .press-grid, .gallery-grid { grid-template-columns: repeat(2, 1fr); }
  .card-grid.cols-3 { grid-template-columns: repeat(2, 1fr); }
  .gov-banners { grid-template-columns: 1fr; }
  .footer-info .wrap { grid-template-columns: 1fr; gap: var(--space-32); }
}
@media (max-width: 860px) {
  .gnb, .header-cta { display: none; }
  .nav-toggle { display: grid; }
}
@media (max-width: 680px) {
  :root { --site-pad: var(--space-20); }
  .feature-grid, .press-grid, .gallery-grid, .card-grid.cols-2, .card-grid.cols-3 { grid-template-columns: 1fr; }
  .hero h1 { font: var(--type-title-1); letter-spacing: -0.0253em; }
  .section__head.row { flex-direction: column; align-items: flex-start; }
  .tl-item { grid-template-columns: 96px 1fr; gap: var(--space-12); }
  .tl-item::before { left: 104px; }
  .bbs-row { grid-template-columns: 1fr; gap: 6px; }
  .bbs-num { display: none; }
  .bbs-meta { gap: var(--space-12); }
  .form-card { padding: var(--space-24); }
  .brand__sub { display: none; }
}
