/* ============================================================
   수익 자동화 엔진 대시보드 — 외부 의존 0, dark-first
   ============================================================ */

:root {
  /* 배경 elevation */
  --bg-0: #0b0e14;
  --bg-1: #121620;
  --bg-2: #1a1f2b;
  --bg-3: #222838;
  --border: #252b38;
  --border-soft: #1d2330;

  /* 텍스트 (다크 배경 순백 회피) */
  --text-0: #e8eaed;
  --text-1: #a7afbe;
  --text-2: #6b7385;

  /* accent */
  --accent: #4f8cff;
  --accent-soft: rgba(79, 140, 255, .12);

  /* 신호등 (적색=고장 전용) */
  --ok: #3ecf8e;
  --ok-soft: rgba(62, 207, 142, .14);
  --warn: #f5b14c;
  --warn-soft: rgba(245, 177, 76, .14);
  --fail: #f0616d;
  --fail-soft: rgba(240, 97, 109, .14);
  --idle: #5a6275;
  --idle-soft: rgba(90, 98, 117, .16);

  /* 데이터 출처 */
  --src-live: #3ecf8e;
  --src-est: #b48cff;
  --src-off: #6b7385;

  /* 타이포 */
  --font: -apple-system, BlinkMacSystemFont, "Apple SD Gothic Neo", "Pretendard",
    "Malgun Gothic", "Segoe UI", system-ui, sans-serif;
  --font-num: ui-monospace, "SF Mono", "JetBrains Mono", Menlo, monospace;

  /* 간격 (8px 그리드) */
  --sp-1: 4px;  --sp-2: 8px;  --sp-3: 12px;
  --sp-4: 16px; --sp-5: 24px; --sp-6: 32px;

  --radius: 12px;
  --radius-sm: 6px;
  --shadow: 0 1px 2px rgba(0,0,0,.4), 0 4px 16px rgba(0,0,0,.25);
}

/* 라이트 테마 (선택 토글) */
[data-theme="light"] {
  --bg-0: #f4f6fb;
  --bg-1: #ffffff;
  --bg-2: #f0f3f9;
  --bg-3: #e6eaf2;
  --border: #dce1ec;
  --border-soft: #e8ecf3;
  --text-0: #1a1f2b;
  --text-1: #4a5263;
  --text-2: #7b8395;
  --accent-soft: rgba(79, 140, 255, .1);
  --ok-soft: rgba(38, 160, 105, .12);
  --warn-soft: rgba(196, 130, 30, .14);
  --fail-soft: rgba(214, 60, 75, .12);
  --idle-soft: rgba(120, 128, 145, .14);
  --ok: #1e9b63;
  --warn: #b4781e;
  --fail: #d63c4b;
  --shadow: 0 1px 2px rgba(20,30,60,.06), 0 4px 14px rgba(20,30,60,.06);
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  background: var(--bg-0);
  color: var(--text-0);
  font-family: var(--font);
  font-size: 14px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1, h2, h3 { margin: 0; font-weight: 700; }

a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

.num, .tnum { font-variant-numeric: tabular-nums; font-family: var(--font-num); }

.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

.skip-link {
  position: absolute; left: -999px; top: 8px; z-index: 100;
  background: var(--accent); color: #fff; padding: 8px 14px; border-radius: var(--radius-sm);
}
.skip-link:focus { left: 8px; }

:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; border-radius: 4px; }

/* ─────────────── 헤더 ─────────────── */
.topbar {
  position: sticky; top: 0; z-index: 30;
  background: color-mix(in srgb, var(--bg-0) 88%, transparent);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
}
.topbar__inner {
  max-width: 1320px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--sp-4); padding: var(--sp-3) var(--sp-5); flex-wrap: wrap;
}
.brand { display: flex; align-items: center; gap: var(--sp-3); min-width: 0; }
.brand__logo {
  display: grid; place-items: center; width: 34px; height: 34px;
  border-radius: 9px; background: var(--accent-soft); color: var(--accent); flex: none;
}
.brand__text { display: flex; flex-direction: column; line-height: 1.2; min-width: 0; }
.brand__title { font-weight: 700; font-size: 15px; }
.brand__sub { font-size: 12px; color: var(--text-2); font-family: var(--font-num);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 200px; }

/* phase 배지 */
.badge { font-size: 11px; font-weight: 700; padding: 3px 10px; border-radius: 999px;
  display: inline-flex; align-items: center; gap: 5px; white-space: nowrap; flex: none; }
.badge--phase { background: var(--idle-soft); color: var(--text-1); }
.badge--phase.is-approval { background: var(--warn-soft); color: var(--warn); }
.badge--phase.is-revenue { background: var(--ok-soft); color: var(--ok); }
.badge--phase::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }

.topbar__actions { display: flex; align-items: center; gap: var(--sp-3); flex-wrap: wrap; }
.freshness { font-size: 12px; color: var(--text-1); font-variant-numeric: tabular-nums; }

.btn {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--bg-2); color: var(--text-0);
  border: 1px solid var(--border); border-radius: var(--radius-sm);
  padding: 7px 12px; font-size: 13px; font-family: var(--font); cursor: pointer;
  transition: background .15s, border-color .15s;
}
.btn:hover { background: var(--bg-3); border-color: var(--accent); }
.btn:active { transform: translateY(1px); }
.btn--icon { padding: 7px; }
.btn.is-loading svg { animation: spin .8s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

.toggle { display: inline-flex; align-items: center; gap: 8px; cursor: pointer; font-size: 13px; color: var(--text-1); user-select: none; }
.toggle input { position: absolute; opacity: 0; width: 0; height: 0; }
.toggle__track { width: 38px; height: 22px; border-radius: 11px; background: var(--bg-3);
  border: 1px solid var(--border); position: relative; transition: background .15s; flex: none; }
.toggle__thumb { position: absolute; top: 2px; left: 2px; width: 16px; height: 16px; border-radius: 50%;
  background: var(--text-2); transition: transform .15s, background .15s; }
.toggle input:checked + .toggle__track { background: var(--accent-soft); border-color: var(--accent); }
.toggle input:checked + .toggle__track .toggle__thumb { transform: translateX(16px); background: var(--accent); }
.toggle input:focus-visible + .toggle__track { outline: 2px solid var(--accent); outline-offset: 2px; }

/* ─────────────── 레이아웃 ─────────────── */
.wrap { max-width: 1320px; margin: 0 auto; padding: var(--sp-5); display: flex; flex-direction: column; gap: var(--sp-5); }

.statusbar {
  background: var(--warn-soft); border: 1px solid var(--warn);
  color: var(--text-0); border-radius: var(--radius); padding: var(--sp-4) var(--sp-5);
  font-size: 14px; line-height: 1.6;
}
.statusbar strong { color: var(--warn); }
.statusbar code { font-family: var(--font-num); background: var(--bg-2); padding: 2px 6px; border-radius: 4px; font-size: 13px; }
.statusbar--error { background: var(--fail-soft); border-color: var(--fail); }
.statusbar--error strong { color: var(--fail); }

/* 운영 메타바 */
.metabar {
  display: flex; flex-wrap: wrap; align-items: center; gap: var(--sp-2) var(--sp-3);
  font-size: 13px; color: var(--text-1);
  background: var(--bg-1); border: 1px solid var(--border-soft);
  border-radius: var(--radius); padding: var(--sp-3) var(--sp-4);
}
.metabar__k { color: var(--text-2); margin-right: 4px; }
.metabar__v { color: var(--text-0); font-weight: 600; }
.metabar__sep { color: var(--text-2); }

/* ─────────────── KPI 타일 ─────────────── */
.kpi-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: var(--sp-4); }
.kpi {
  background: var(--bg-1); border: 1px solid var(--border-soft);
  border-radius: var(--radius); padding: var(--sp-4); box-shadow: var(--shadow);
  display: flex; flex-direction: column; gap: 6px; position: relative; overflow: hidden;
  border-left: 3px solid var(--idle);
}
.kpi--ok   { border-left-color: var(--ok); }
.kpi--warn { border-left-color: var(--warn); }
.kpi--fail { border-left-color: var(--fail); }
.kpi--idle { border-left-color: var(--idle); }
.kpi__label { font-size: 12px; color: var(--text-1); display: flex; align-items: center; gap: 6px; }
.kpi__value { font-size: 28px; font-weight: 700; font-variant-numeric: tabular-nums;
  font-family: var(--font-num); line-height: 1.1; letter-spacing: -.5px; }
.kpi__value.is-null { color: var(--text-2); font-size: 20px; }
.kpi__unit { font-size: 14px; color: var(--text-1); font-weight: 600; margin-left: 2px; }
.kpi__foot { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-top: 2px; }
.delta { font-size: 12px; font-variant-numeric: tabular-nums; display: inline-flex; align-items: center; gap: 2px; }
.delta--up { color: var(--ok); }
.delta--down { color: var(--fail); }
.delta--flat { color: var(--text-2); }

/* 출처 배지 */
.src { font-size: 10px; font-weight: 700; letter-spacing: .3px; padding: 2px 6px; border-radius: 4px;
  text-transform: none; display: inline-flex; align-items: center; gap: 3px; }
.src--live { background: var(--ok-soft); color: var(--ok); }
.src--est  { background: rgba(180,140,255,.14); color: var(--src-est); }
.src--off  { background: var(--idle-soft); color: var(--src-off); }

/* ─────────────── 카드 공통 ─────────────── */
.card {
  background: var(--bg-1); border: 1px solid var(--border-soft);
  border-radius: var(--radius); padding: var(--sp-5); box-shadow: var(--shadow);
}
.card--full { grid-column: 1 / -1; }
.card__head { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3);
  margin-bottom: var(--sp-4); flex-wrap: wrap; }
.card__title { font-size: 15px; display: flex; align-items: center; gap: 8px; }
.card__meta { font-size: 12px; color: var(--text-2); }
.card__note { font-size: 12px; color: var(--text-2); margin: var(--sp-3) 0 0; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.card__note em { color: var(--text-1); font-style: normal; }

.count-chip { font-size: 12px; font-weight: 700; font-variant-numeric: tabular-nums;
  background: var(--bg-3); color: var(--text-1); border-radius: 999px; padding: 1px 9px; }
.count-chip.has-pending { background: var(--warn-soft); color: var(--warn); }

.two-col { display: grid; grid-template-columns: 1.1fr .9fr; gap: var(--sp-5); }

/* 점 마커 */
.dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; flex: none; background: var(--idle); }
.dot--ok { background: var(--ok); } .dot--warn { background: var(--warn); }
.dot--fail { background: var(--fail); } .dot--idle { background: var(--idle); }

/* ─────────────── 11단계 스테퍼 ─────────────── */
.stepper-scroll { overflow-x: auto; padding-bottom: 4px; }
.stepper { display: flex; align-items: stretch; min-width: max-content; gap: 0; }
.step { display: flex; flex-direction: column; align-items: center; flex: 1 0 auto;
  min-width: 86px; position: relative; padding: 0 4px; }
.step__line { position: absolute; top: 17px; left: -50%; width: 100%; height: 2px; background: var(--border); z-index: 0; }
.step:first-child .step__line { display: none; }
.step__dot { position: relative; z-index: 1; width: 34px; height: 34px; border-radius: 50%;
  display: grid; place-items: center; font-weight: 700; font-size: 12px; font-family: var(--font-num);
  background: var(--bg-2); border: 2px solid var(--idle); color: var(--text-1); }
.step--ok   .step__dot { border-color: var(--ok); background: var(--ok-soft); color: var(--ok); }
.step--warn .step__dot { border-color: var(--warn); background: var(--warn-soft); color: var(--warn); }
.step--fail .step__dot { border-color: var(--fail); background: var(--fail-soft); color: var(--fail); }
.step--idle .step__dot { border-color: var(--idle); background: var(--bg-2); color: var(--text-2); }
.step--ok   .step__line, .step--warn .step__line { background: var(--ok); }
.step--fail .step__line { background: var(--fail); }
.step__name { font-size: 11px; margin-top: 7px; text-align: center; color: var(--text-1); line-height: 1.3; }
.step__count { font-size: 12px; font-weight: 700; font-variant-numeric: tabular-nums; color: var(--text-0); margin-top: 2px; }
.step__count.is-empty { color: var(--text-2); font-weight: 400; }
.step__note { font-size: 10px; color: var(--warn); margin-top: 3px; text-align: center; line-height: 1.25; max-width: 84px; }
.step--ok .step__note { color: var(--text-2); }

/* drip 진행바 */
.drip { margin-top: var(--sp-5); }
.drip__head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 6px; }
.drip__label { font-size: 12px; color: var(--text-1); }
.drip__count { font-size: 13px; font-weight: 700; font-variant-numeric: tabular-nums; }
.drip__bar { display: flex; gap: 6px; }
.drip__slot { flex: 1; height: 10px; border-radius: 999px; background: var(--bg-3); border: 1px solid var(--border); }
.drip__slot.is-used { background: var(--accent); border-color: var(--accent); }

/* ─────────────── 수익 파이프라인 카드 ─────────────── */
.pipe-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--sp-3); }
.pipe {
  background: var(--bg-2); border: 1px solid var(--border-soft); border-radius: var(--radius-sm);
  padding: var(--sp-3) var(--sp-4); display: flex; flex-direction: column; gap: 6px;
  border-left: 3px solid var(--idle);
}
.pipe--ok { border-left-color: var(--ok); }
.pipe--warn { border-left-color: var(--warn); }
.pipe--idle { border-left-color: var(--idle); opacity: .82; }
.pipe__top { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.pipe__name { font-weight: 600; font-size: 13px; }
.pipe__mech { font-size: 12px; color: var(--text-1); line-height: 1.45; }
.pipe__foot { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-top: 2px; }
.pipe__when { font-size: 11px; color: var(--text-2); line-height: 1.4; }

/* status 배지 */
.sbadge { font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 999px;
  display: inline-flex; align-items: center; gap: 4px; }
.sbadge--active { background: var(--ok-soft); color: var(--ok); }
.sbadge--semi   { background: var(--warn-soft); color: var(--warn); }
.sbadge--deferred { background: var(--idle-soft); color: var(--text-1); }

.env { font-size: 11px; font-weight: 600; padding: 2px 7px; border-radius: 4px; display: inline-flex; align-items: center; gap: 4px; }
.env--ready { background: var(--ok-soft); color: var(--ok); }
.env--missing { background: var(--warn-soft); color: var(--warn); }
.env--na { background: var(--idle-soft); color: var(--text-2); }

/* ─────────────── 채널 리스트 ─────────────── */
.channel-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--sp-2); }
.channel {
  display: flex; align-items: center; gap: var(--sp-3); padding: var(--sp-3);
  background: var(--bg-2); border: 1px solid var(--border-soft); border-radius: var(--radius-sm);
}
.channel__name { font-weight: 600; font-size: 13px; min-width: 92px; }
.channel__role { font-size: 11px; padding: 2px 7px; border-radius: 4px; font-weight: 600; }
.role--canonical { background: var(--accent-soft); color: var(--accent); }
.role--differentiated { background: var(--idle-soft); color: var(--text-1); }
.channel__tags { display: flex; gap: 6px; flex-wrap: wrap; margin-left: auto; align-items: center; }
.tag { font-size: 11px; color: var(--text-2); background: var(--bg-3); padding: 2px 7px; border-radius: 4px; }
.channel__ok { font-size: 12px; font-variant-numeric: tabular-nums; color: var(--text-1); display: inline-flex; align-items: center; gap: 4px; }
.channel.is-off { opacity: .58; }

/* ─────────────── 테이블 ─────────────── */
.table-scroll { overflow-x: auto; }
.data-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.data-table th, .data-table td { text-align: left; padding: 10px 12px; border-bottom: 1px solid var(--border-soft); white-space: nowrap; }
.data-table th { color: var(--text-2); font-weight: 600; font-size: 12px; position: sticky; top: 0; }
.data-table td { color: var(--text-0); }
.data-table tbody tr:hover { background: var(--bg-2); }
.data-table .num { text-align: right; font-variant-numeric: tabular-nums; font-family: var(--font-num); }
.data-table .title-cell { white-space: normal; max-width: 360px; font-weight: 500; }
.data-table .muted { color: var(--text-2); }
.row--dry { opacity: .68; }
.row--dry td { border-bottom-style: dashed; }
.row--stale td { background: var(--fail-soft); }
.row--warn-age td { background: var(--warn-soft); }

.cat { font-size: 11px; padding: 2px 8px; border-radius: 4px; font-weight: 600; background: var(--bg-3); color: var(--text-1); }
.cat--life { background: rgba(79,140,255,.14); color: #7fb0ff; }
.cat--money { background: rgba(62,207,142,.14); color: var(--ok); }
.cat--health { background: rgba(240,97,109,.14); color: #ff8a93; }
.cat--it { background: rgba(180,140,255,.14); color: var(--src-est); }

.pill { font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 999px; display: inline-flex; align-items: center; gap: 4px; }
.pill--ok { background: var(--ok-soft); color: var(--ok); }
.pill--warn { background: var(--warn-soft); color: var(--warn); }
.pill--fail { background: var(--fail-soft); color: var(--fail); }
.pill--idle { background: var(--idle-soft); color: var(--text-1); }

.ch-chip { font-size: 11px; background: var(--bg-3); color: var(--text-1); padding: 2px 7px; border-radius: 4px; margin-right: 4px; }
.ch-chip--canonical { background: var(--accent-soft); color: var(--accent); }

.ymyl-y { color: var(--warn); font-weight: 700; }
.ymyl-n { color: var(--text-2); }

.age { font-variant-numeric: tabular-nums; }
.age--stale { color: var(--fail); font-weight: 700; }
.age--warn { color: var(--warn); font-weight: 600; }

.empty-row td { text-align: center; color: var(--text-2); padding: var(--sp-5); }

/* ─────────────── 미니 차트 ─────────────── */
.mini-charts { display: flex; gap: var(--sp-5); align-items: flex-end; flex-wrap: wrap; }
.mini-chart { display: flex; flex-direction: column; gap: 4px; }
.mini-chart__label { font-size: 11px; color: var(--text-2); }
.spark { display: block; }
.spark__line { fill: none; stroke: var(--accent); stroke-width: 2; }
.spark__area { fill: var(--accent-soft); }
.spark__dot { fill: var(--accent); }
.catbar-row { display: flex; align-items: center; gap: 8px; font-size: 11px; margin-bottom: 3px; }
.catbar-row__name { min-width: 44px; color: var(--text-1); }
.catbar-row__track { flex: 1; height: 8px; background: var(--bg-3); border-radius: 999px; overflow: hidden; min-width: 80px; }
.catbar-row__fill { height: 100%; border-radius: 999px; }
.catbar-row__val { font-variant-numeric: tabular-nums; color: var(--text-1); min-width: 16px; text-align: right; }

/* ─────────────── 푸터 ─────────────── */
.foot { max-width: 1320px; margin: 0 auto; padding: var(--sp-5); color: var(--text-2); font-size: 12px;
  display: flex; gap: var(--sp-3); flex-wrap: wrap; align-items: center; border-top: 1px solid var(--border-soft); }
.foot__sep { color: var(--text-2); }

/* ─────────────── 반응형 ─────────────── */
@media (max-width: 1024px) {
  .kpi-grid { grid-template-columns: repeat(3, 1fr); }
  .two-col { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .wrap { padding: var(--sp-4); gap: var(--sp-4); }
  .topbar__inner { padding: var(--sp-3) var(--sp-4); }
  .kpi-grid { grid-template-columns: repeat(2, 1fr); }
  .pipe-grid { grid-template-columns: 1fr; }
  .kpi__value { font-size: 24px; }
  .brand__sub { max-width: 130px; }
  .toggle__label { display: none; }
  .btn span:not(.sr-only) { display: none; }
  .btn { padding: 8px; }
  .mini-charts { gap: var(--sp-4); }
  .card { padding: var(--sp-4); }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}
