/* ============================================================
   Automation Review Hub — Glass / Soft Depth
   프로스티드 글래스 · 그라데이션 메시 · 부드러운 입체감
   네비게이션: 아이콘 레일(접이식)
   ============================================================ */

/* ── 라이트 테마 (기본) — Flat / Light / Blue ── */
:root {
  color-scheme: light;
  /* base */
  --canvas: #f6f7f9;
  --ink: #13182b;
  --ink-muted: #6b7280;
  --ink-subtle: #9ca3af;
  /* surfaces (flat, opaque) */
  --glass: #ffffff;
  --glass-2: #ffffff;
  --glass-3: #f3f4f6;
  --glass-solid: #ffffff;
  --glass-brd: #eef0f2;
  --glass-brd-2: #e5e7eb;
  --blur: none;
  --blur-lg: none;
  /* accent (blue) */
  --accent: #2563eb;
  --accent-2: #2563eb;
  --accent-hover: #1d4ed8;
  --grad: linear-gradient(#2563eb,#2563eb);
  --accent-subtle: rgba(37,99,235,.08);
  --accent-ring: rgba(37,99,235,.25);
  --on-accent: #fff;
  /* semantic */
  --success: #059669; --success-bg: rgba(5,150,105,.10);
  --warn: #d97706;   --warn-bg: rgba(217,119,6,.10);
  --danger: #dc2626; --danger-bg: rgba(220,38,38,.08);
  /* radius */
  --radius: 14px; --radius-sm: 11px; --radius-xl: 16px; --radius-2xl: 18px;
  /* type */
  --sans: 'Pretendard Variable',Pretendard,'Apple SD Gothic Neo','Noto Sans KR',-apple-system,'Segoe UI','Malgun Gothic',sans-serif;
  --mono: ui-monospace,'SF Mono','Cascadia Code',Consolas,monospace;
  /* flat subtle shadows (no blur) */
  --shadow-xs: 0 1px 2px rgba(17,24,39,.04);
  --shadow-sm: 0 1px 2px rgba(17,24,39,.06);
  --shadow-md: 0 6px 16px rgba(17,24,39,.08);
  --shadow-lg: 0 20px 50px rgba(17,24,39,.18);
  --shadow-glow: 0 4px 12px rgba(37,99,235,.22);
  --hl-top: inset 0 0 0 transparent;
  /* nav rail */
  --rail: 74px; --rail-open: 252px;
  /* transitions */
  --t-fast:90ms ease; --t-base:150ms ease; --t-slow:200ms ease;
  /* legacy aliases (JS inline styles + map svg) */
  --hairline: #e5e7eb;
  --hairline-strong: #d1d5db;
  --surface-1: #ffffff; --surface-2: #f9fafb; --surface-3: #f3f4f6;
  --bg: #ffffff; --bg0: #f6f7f9; --bg1: #ffffff; --bg2: #f9fafb; --bg3: #f3f4f6;
  --fg: #13182b; --fg2: #374151; --fg-muted: #6b7280;
  --border: #e5e7eb; --border-strong: #d1d5db;
  /* 맵 노드 타입 — fill(연한 틴트) / stroke(타입 컬러) */
  --ntf-task:#eff6ff; --nts-task:#2563eb;
  --ntf-ellipse:#ecfdf5; --nts-ellipse:#059669;
  --ntf-diamond:#fffbeb; --nts-diamond:#d97706;
  --ntf-terminator:#fef2f2; --nts-terminator:#dc2626;
  --ntf-data:#f5f3ff; --nts-data:#7c3aed;
  --ntf-subprocess:#eff6ff; --nts-subprocess:#2563eb;
  --ntf-document:#ecfeff; --nts-document:#0891b2;
  --ntf-note:#f3f4f6; --nts-note:#6b7280;
}

/* ── 다크 테마 — Flat Dark ── */
html.dark {
  color-scheme: dark;
  --canvas: #0f1420;
  --ink: #f3f4f6;
  --ink-muted: #9ca3af;
  --ink-subtle: #6b7280;
  --glass: #1a2030;
  --glass-2: #1a2030;
  --glass-3: #222a3a;
  --glass-solid: #1a2030;
  --glass-brd: #2a3346;
  --glass-brd-2: #2a3346;
  --accent: #3b82f6;
  --accent-2: #3b82f6;
  --accent-hover: #60a5fa;
  --grad: linear-gradient(#3b82f6,#3b82f6);
  --accent-subtle: rgba(59,130,246,.16);
  --accent-ring: rgba(59,130,246,.40);
  --success: #34d399; --success-bg: rgba(52,211,153,.14);
  --warn: #fbbf24;   --warn-bg: rgba(251,191,36,.14);
  --danger: #f87171; --danger-bg: rgba(248,113,113,.16);
  --shadow-xs: 0 1px 2px rgba(0,0,0,.4);
  --shadow-sm: 0 1px 3px rgba(0,0,0,.45);
  --shadow-md: 0 8px 20px rgba(0,0,0,.5);
  --shadow-lg: 0 20px 50px rgba(0,0,0,.6);
  --shadow-glow: 0 4px 14px rgba(59,130,246,.4);
  --hl-top: inset 0 0 0 transparent;
  --hairline: #2a3346;
  --hairline-strong: #3a4459;
  --surface-1: #1a2030; --surface-2: #222a3a; --surface-3: #222a3a;
  --bg: #1a2030; --bg0: #0f1420; --bg1: #1a2030; --bg2: #222a3a; --bg3: #222a3a;
  --fg: #f3f4f6; --fg2: #cbd2dd; --fg-muted: #9ca3af;
  --border: #2a3346; --border-strong: #3a4459;
  --ntf-task:rgba(59,130,246,.22); --nts-task:#60a5fa;
  --ntf-ellipse:rgba(16,185,129,.22); --nts-ellipse:#34d399;
  --ntf-diamond:rgba(217,119,6,.22); --nts-diamond:#fbbf24;
  --ntf-terminator:rgba(248,113,113,.22); --nts-terminator:#f87171;
  --ntf-data:rgba(124,58,237,.26); --nts-data:#a78bfa;
  --ntf-subprocess:rgba(59,130,246,.22); --nts-subprocess:#60a5fa;
  --ntf-document:rgba(8,145,178,.24); --nts-document:#22d3ee;
  --ntf-note:rgba(148,163,184,.24); --nts-note:#9ca3af;
}

/* ─ Reset ───────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  background: var(--canvas);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 14.5px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: 'kern' 1, 'liga' 1, 'calt' 1;
}
/* 플랫 디자인: 그라데이션 메시 제거(단색 배경) */
h1,h2,h3,h4,h5,h6,p,ul,ol { margin: 0; }
h1 { font-size: 27px; font-weight: 750; letter-spacing: -0.045em; line-height: 1.16; }
h2 { font-size: 20px; font-weight: 700; letter-spacing: -0.035em; line-height: 1.28; }
h3 { font-size: 16px; font-weight: 650; letter-spacing: -0.022em; }
h4 { font-size: 14px; font-weight: 650; letter-spacing: -0.012em; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; cursor: pointer; }
input, select, textarea { font: inherit; }
::selection { background: rgba(37,99,235,.24); }
:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--hairline-strong); border-radius: 999px; }
::-webkit-scrollbar-thumb:hover { background: var(--ink-subtle); }

.mono { font-family: var(--mono); font-variant-numeric: tabular-nums; }

/* 글래스 패널 — backdrop blur */
.card, .panel, .login-card, .modal, .toast, .kpi, .scatter-tip,
.map-toolbar, .map-tabs-bar, .map-node-panel, .map-guide, .add-pop,
.accordion, .exec-item, .step-card {
  -webkit-backdrop-filter: var(--blur);
  backdrop-filter: var(--blur);
}

/* ─ 레이아웃 ─────────────────────────────────────────────── */
#app { display: flex; min-height: 100vh; }

/* ── 사이드바: 아이콘 레일(접이식) ── */
#sidebar {
  position: fixed; inset: 0 auto 0 0; width: var(--rail);
  display: flex; flex-direction: column;
  background: var(--glass);
  -webkit-backdrop-filter: var(--blur-lg);
  backdrop-filter: var(--blur-lg);
  border-right: 1px solid var(--glass-brd-2);
  box-shadow: var(--hl-top);
  padding: 14px 13px 12px;
  z-index: 60; overflow: hidden;
  transition: width var(--t-slow), box-shadow var(--t-slow);
}
/* display:flex 가 hidden 속성을 덮어쓰므로 명시적으로 숨김 (로그아웃/로그인 화면) */
#sidebar[hidden], body.no-chrome #sidebar { display: none !important; }
#sidebar:hover { width: var(--rail-open); box-shadow: var(--shadow-lg); }
html.nav-pinned #sidebar { width: var(--rail-open); }
#main {
  flex: 1; margin-left: var(--rail);
  padding: 42px 50px 84px; min-width: 0;
  transition: margin-left var(--t-slow);
}
html.nav-pinned #main { margin-left: var(--rail-open); }
body.no-chrome #main { margin-left: 0 !important; padding: 0 !important; }
/* 프로세스 맵 = 전체화면 캔버스 편집기: 메인 패딩 제거하고 뷰포트 높이를 채움(여백 갭 제거) */
body.map-view #main { padding: 0; height: 100vh; overflow: hidden; }

/* 레일 라벨 — 접힘 시 숨김, 펼침/고정 시 노출 */
.nav-label { opacity: 0; white-space: nowrap; transition: opacity var(--t-base); }
#sidebar:hover .nav-label, html.nav-pinned .nav-label { opacity: 1; transition-delay: 40ms; }

/* 로고 */
.side-logo {
  display: flex; align-items: center; gap: 12px;
  padding: 4px 6px 18px; min-height: 48px;
}
.logo-mark {
  width: 44px; height: 44px; flex: none; border-radius: 13px;
  background: var(--grad); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; font-weight: 800; letter-spacing: -0.5px;
  box-shadow: var(--shadow-glow), inset 0 1px 0 rgba(255,255,255,.3);
}
.side-logo .logo-text { font-size: 13.5px; font-weight: 750; letter-spacing: -0.028em; line-height: 1.25; min-width: 0; }
.side-logo .logo-sub { display: block; font-size: 10px; font-weight: 500; color: var(--ink-subtle); margin-top: 1px; letter-spacing: 0; }
.nav-pin {
  margin-left: auto; flex: none; opacity: 0;
  background: var(--glass-3); border: 1px solid var(--glass-brd-2); border-radius: 9px;
  color: var(--ink-subtle); padding: 6px; display: flex;
  transition: opacity var(--t-base), color var(--t-fast), background var(--t-fast), transform var(--t-base);
}
#sidebar:hover .nav-pin, html.nav-pinned .nav-pin { opacity: 1; }
.nav-pin:hover { color: var(--accent); background: var(--accent-subtle); }
html.nav-pinned .nav-pin { color: var(--accent); transform: rotate(180deg); }
/* 접힘(레일)에서도 토글 클릭 가능 — 로고 우측 고정, 항상 노출 */
#sidebar .nav-pin { opacity: 1; }

/* 섹션 라벨 — 접힘 시 접기 */
.side-nav-label {
  font-size: 9.5px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase;
  color: var(--ink-subtle); padding: 0 12px; overflow: hidden;
  max-height: 0; opacity: .75; transition: max-height var(--t-base), padding var(--t-base);
}
#sidebar:hover .side-nav-label, html.nav-pinned .side-nav-label { max-height: 28px; padding: 12px 12px 4px; }

.side-nav { display: flex; flex-direction: column; gap: 3px; }
.side-nav a {
  display: flex; align-items: center; gap: 13px;
  padding: 7px 19px; border-radius: var(--radius-sm);
  color: var(--ink-muted); font-size: 13.5px; font-weight: 550;
  position: relative; transition: background var(--t-fast), color var(--t-fast);
}
.side-nav a .nav-ico {
  width: 36px; height: 36px; flex: none;
  display: flex; align-items: center; justify-content: center;
  border-radius: 10px; transition: background var(--t-fast), color var(--t-fast);
}
.side-nav a:hover { color: var(--ink); }
.side-nav a:hover .nav-ico { background: var(--glass-3); }
.side-nav a.active { color: var(--accent); font-weight: 650; }
.side-nav a.active .nav-ico { background: var(--grad); color: #fff; box-shadow: var(--shadow-glow); }
.side-nav a svg { opacity: .9; }
.side-nav-sep { height: 1px; background: var(--glass-brd-2); margin: 8px 14px; }

.side-spacer { flex: 1; }
.side-user-wrap { position: relative; border-top: 1px solid var(--glass-brd-2); margin-top: 8px; padding-top: 8px; }
.side-user {
  width: 100%; text-align: left; font: inherit; cursor: pointer;
  background: none; border: 1px solid transparent; border-radius: 11px;
  padding: 8px 6px; display: flex; align-items: center; gap: 11px; min-height: 52px;
  transition: background var(--t-base), border-color var(--t-base);
}
.side-user:hover { background: var(--glass-3); border-color: var(--glass-brd-2); }
.side-user[aria-expanded="true"] { background: var(--glass-3); border-color: var(--glass-brd-2); }
.side-user .avatar {
  width: 40px; height: 40px; flex: none; border-radius: 12px;
  background: var(--accent-subtle); border: 1px solid var(--glass-brd-2);
  display: flex; align-items: center; justify-content: center;
  font-size: 15px; font-weight: 750; color: var(--accent);
}
.side-user .who { min-width: 0; flex: 1; }
.side-user .who b { display: block; font-size: 13px; font-weight: 650; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.side-user .who span { display: block; font-size: 10.5px; color: var(--ink-subtle); }
.side-user .su-caret { flex: none; color: var(--ink-subtle); display: inline-flex; transform: rotate(-90deg); }
/* 좌하단 사용자 메뉴(관리자·설정·테마·로그아웃) */
.side-user-menu {
  position: fixed; min-width: 188px; z-index: 100;
  background: var(--glass); border: 1px solid var(--glass-brd); border-radius: 12px;
  box-shadow: var(--shadow-md), var(--hl-top); padding: 5px;
  -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
  display: flex; flex-direction: column; gap: 1px;
}
.sum-item {
  display: flex; align-items: center; gap: 10px; width: 100%; text-align: left;
  background: none; border: none; border-radius: 8px; padding: 9px 11px;
  font-size: 13px; font-weight: 550; color: var(--ink); cursor: pointer; white-space: nowrap;
}
.sum-item:hover { background: var(--accent-subtle); color: var(--accent); }
.sum-item#sum-logout:hover { background: var(--danger-bg); color: var(--danger); }
.sum-ico { display: inline-flex; flex: none; color: var(--ink-subtle); }
.sum-item:hover .sum-ico { color: inherit; }
.sum-sep { height: 1px; background: var(--glass-brd-2); margin: 4px 6px; }

/* ─ 버튼 ─────────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 7px;
  padding: 8px 17px; border-radius: var(--radius-sm);
  border: 1px solid var(--glass-brd-2);
  background: var(--glass); color: var(--ink);
  -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
  font-size: 13.5px; font-weight: 600; letter-spacing: -0.01em; white-space: nowrap;
  box-shadow: var(--shadow-xs), var(--hl-top);
  transition: background var(--t-fast), border-color var(--t-fast), box-shadow var(--t-base), transform var(--t-fast), filter var(--t-fast);
}
.btn:hover { box-shadow: var(--shadow-sm), var(--hl-top); transform: translateY(-1px); }
.btn:active { transform: translateY(0) scale(.98); }
.btn:disabled { opacity: .45; pointer-events: none; }
.btn-primary {
  background: var(--grad); border-color: transparent; color: #fff;
  box-shadow: var(--shadow-glow), inset 0 1px 0 rgba(255,255,255,.28);
}
.btn-primary:hover { filter: brightness(1.05); box-shadow: 0 10px 30px rgba(37,99,235,.46), inset 0 1px 0 rgba(255,255,255,.28); transform: translateY(-1px); }
.btn-danger { color: var(--danger); }
.btn-danger:hover { background: var(--danger-bg); border-color: var(--danger); }
.btn-ghost { background: transparent; border-color: transparent; color: var(--ink-muted); box-shadow: none; -webkit-backdrop-filter: none; backdrop-filter: none; }
.btn-ghost:hover { background: var(--glass-3); color: var(--ink); box-shadow: none; transform: none; }
.btn-outline { background: transparent; -webkit-backdrop-filter: none; backdrop-filter: none; }
.btn-sm { padding: 5px 13px; font-size: 12.5px; }
.btn-block { width: 100%; }

/* ─ 입력 ─────────────────────────────────────────────────── */
.input, select.input, textarea.input, .form-input, .input-sm {
  width: 100%;
  background: var(--glass-2);
  -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
  border: 1px solid var(--glass-brd-2);
  border-radius: var(--radius-sm);
  color: var(--ink);
  padding: 9px 13px; font-size: 13.5px; line-height: 1.5;
  transition: border-color var(--t-base), box-shadow var(--t-base), background var(--t-base);
  box-shadow: var(--hl-top);
}
.input::placeholder, .form-input::placeholder { color: var(--ink-subtle); }
.input:focus, .form-input:focus, .input-sm:focus, textarea.input:focus, select.input:focus {
  outline: none; border-color: var(--accent); background: var(--glass);
  box-shadow: 0 0 0 4px var(--accent-ring);
}
select.input, select.form-input {
  appearance: none; -webkit-appearance: none; padding-right: 32px;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238b91a8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 12px center;
}
textarea.input { resize: vertical; min-height: 90px; line-height: 1.55; }
.form-input { padding: 8px 11px; font-size: 13px; }
.form-input.input-error, .input.input-error { border-color: var(--danger); box-shadow: 0 0 0 3px rgba(220,38,38,.12); }
.input-sm { width: auto; padding: 6px 10px; font-size: 12.5px; }
input[type=range] { accent-color: var(--accent); width: 100%; margin: 0; }
input[type=checkbox] { accent-color: var(--accent); }
input[type=color] { padding: 3px; height: 38px; cursor: pointer; }

.field { display: flex; flex-direction: column; gap: 7px; margin-bottom: 17px; }
.field > label {
  font-size: 11px; font-weight: 750; letter-spacing: .05em; text-transform: uppercase;
  color: var(--ink-subtle); display: flex; align-items: baseline; gap: 6px;
}
.field .hint { font-weight: 500; color: var(--ink-subtle); font-size: 11.5px; text-transform: none; letter-spacing: 0; }
.form-label { display: flex; flex-direction: column; gap: 5px; font-size: 11px; font-weight: 750; color: var(--ink-subtle); letter-spacing:.04em; text-transform:uppercase; }
.form-row { margin-bottom: 15px; }
.modal-actions { display: flex; gap: 9px; justify-content: flex-end; margin-top: 6px; }
.form-error {
  color: var(--danger); font-size: 13px; margin: 0 0 16px; line-height: 1.6;
  padding: 12px 15px; border: 1px solid rgba(224,69,94,.3);
  background: var(--danger-bg); border-radius: var(--radius-sm);
}
.form-ok {
  color: var(--success); font-size: 13px; margin: 0 0 16px; line-height: 1.6;
  padding: 12px 15px; border: 1px solid rgba(15,157,110,.3);
  background: var(--success-bg); border-radius: var(--radius-sm);
}

/* ─ 뱃지 / 칩 ────────────────────────────────────────────── */
.badge {
  display: inline-flex; align-items: center;
  padding: 3px 11px; border-radius: 999px;
  font-size: 11px; font-weight: 650; line-height: 1.6; letter-spacing: .01em; white-space: nowrap;
  border: 1px solid transparent;
}
.badge.phase-1, .badge.st-open { background: rgba(37,99,235,.13); color: var(--accent); border-color: rgba(37,99,235,.2); }
.badge.phase-2, .badge.st-review { background: var(--warn-bg); color: var(--warn); border-color: rgba(192,122,0,.22); }
.badge.phase-3, .badge.st-adopted { background: var(--success-bg); color: var(--success); border-color: rgba(15,157,110,.22); }
.badge.st-rejected, .badge.critical { background: var(--danger-bg); color: var(--danger); border-color: rgba(224,69,94,.22); }
.badge.st-closed { background: var(--glass-3); color: var(--ink-subtle); }
.badge.badge-success, .badge-success { background: var(--success-bg); color: var(--success); border-color: rgba(15,157,110,.22); }
.badge.badge-error, .badge-error { background: var(--danger-bg); color: var(--danger); border-color: rgba(224,69,94,.22); }

.chip-row { display: flex; align-items: center; gap: 7px; flex-wrap: wrap; }
.chip {
  background: var(--glass-2); border: 1px solid var(--glass-brd-2);
  -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
  border-radius: 999px; padding: 5px 14px;
  font-size: 12.5px; font-weight: 550; color: var(--ink-muted); cursor: pointer;
  transition: all var(--t-fast); box-shadow: var(--hl-top);
}
.chip:hover { border-color: var(--accent); color: var(--ink); }
.chip.active { background: var(--accent-subtle); border-color: var(--accent); color: var(--accent); font-weight: 650; }
.chip-label { font-size: 11.5px; color: var(--ink-subtle); margin-right: 2px; }

/* ─ 페이지 헤더 / 툴바 ────────────────────────────────────── */
.page-head {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 20px;
  margin-bottom: 22px; padding-bottom: 18px;
  border-bottom: 1px solid var(--glass-brd-2);
  animation: page-in .3s cubic-bezier(.2,.8,.2,1) both;
}
/* 헤더 액션 버튼 — 전 페이지 일관 컴팩트 사이즈 */
.page-actions .btn { padding: 6px 14px; font-size: 12.5px; }
.page-actions .btn-sm { padding: 5px 12px; }
/* 페이지 설명문 — 제목(액센트바 15px)과 좌측 정렬, 가독 폭·줄간격 통일 */
.page-head .page-desc,
.page-head > div > p {
  color: var(--ink-subtle); font-size: 13.5px; margin: 7px 0 0;
  line-height: 1.6; max-width: 64ch; padding-left: 15px;
}
.toolbar {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  padding: 0 0 18px; border-bottom: 1px solid var(--glass-brd-2); margin-bottom: 24px;
}
.toolbar .spacer { flex: 1; }
.toolbar select.input { width: auto; }

/* ─ 카드 (글래스) ────────────────────────────────────────── */
.card {
  background: var(--glass);
  border: 1px solid var(--glass-brd);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm), var(--hl-top);
  transition: box-shadow var(--t-slow), transform var(--t-slow);
}
html.dark .card { border-color: var(--glass-brd-2); }
/* 기본 카드(컨테이너)는 들리지 않음 — 클릭 가능한 카드만 lift(오해 방지) */
.card:hover { box-shadow: var(--shadow-sm), var(--hl-top); transform: none; }
.cand-card:hover, .wf-card:hover, .proj-card:hover, a.card:hover {
  box-shadow: var(--shadow-md), var(--hl-top); transform: translateY(-3px);
}
.card.no-lift:hover { transform: none; box-shadow: var(--shadow-sm), var(--hl-top); }

.cand-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(310px, 1fr)); gap: 18px; }
.cand-card { display: flex; flex-direction: column; gap: 13px; padding: 19px; cursor: pointer; }
.cand-top { display: flex; align-items: center; gap: 8px; }
.cand-cat { font-size: 11px; color: var(--ink-subtle); }
.cand-top .st { margin-left: auto; }
.cand-title { font-size: 15.5px; font-weight: 650; letter-spacing: -0.02em; line-height: 1.4; }
.cand-scores {
  display: flex; gap: 24px; padding: 12px 15px;
  background: var(--glass-3); border-radius: var(--radius-sm);
  border: 1px solid var(--glass-brd-2);
}
.score { display: flex; flex-direction: column; gap: 2px; }
.score-label { font-size: 10px; font-weight: 750; letter-spacing: .07em; color: var(--ink-subtle); text-transform: uppercase; }
.score-val { font-family: var(--mono); font-variant-numeric: tabular-nums; font-size: 16px; font-weight: 700; }
.score-val.dim { color: var(--ink-subtle); font-weight: 400; }
.cand-meta { font-size: 12px; color: var(--ink-subtle); display: flex; gap: 6px; flex-wrap: wrap; }
.cand-meta .sep { opacity: .5; }

/* ─ 빈 상태 / 로딩 ─────────────────────────────────────────── */
.empty {
  display: flex; flex-direction: column; align-items: center; gap: 15px;
  padding: 84px 24px; text-align: center;
  border: 1.5px dashed var(--border-strong); border-radius: var(--radius);
  color: var(--ink-subtle); background: var(--glass-3);
}
.empty .empty-icon {
  width: 56px; height: 56px; border-radius: 16px;
  background: var(--glass); border: 1px solid var(--glass-brd);
  display: flex; align-items: center; justify-content: center;
  font-size: 26px; color: var(--accent); box-shadow: var(--shadow-sm);
}
.empty b { color: var(--ink-muted); font-size: 15px; font-weight: 650; letter-spacing: -0.02em; }
.empty p { font-size: 13px; max-width: 340px; line-height: 1.7; margin: 0 auto; }

.loading {
  padding: 68px 24px; text-align: center; color: var(--ink-subtle); font-size: 13px;
  display: flex; flex-direction: column; align-items: center; gap: 15px;
}
.loading::before {
  content: ''; width: 24px; height: 24px; border-radius: 50%;
  border: 2.5px solid var(--hairline-strong); border-top-color: var(--accent);
  animation: spin .75s linear infinite; display: block;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ─ 후보 상세 ────────────────────────────────────────────── */
.detail-head { margin-bottom: 24px; animation: page-in .3s cubic-bezier(.2,.8,.2,1) both; }
.detail-head .crumb { font-size: 12.5px; color: var(--ink-subtle); margin-bottom: 12px; display: inline-flex; align-items: center; gap: 5px; }
.detail-head .crumb:hover { color: var(--accent); }
.detail-title-row { display: flex; align-items: flex-start; gap: 12px; flex-wrap: wrap; }
.detail-title-row h1 { font-size: 23px; font-weight: 750; letter-spacing: -0.04em; flex: 1; min-width: 0; }
.detail-badges { display: flex; align-items: center; gap: 8px; margin-top: 10px; flex-wrap: wrap; }
.detail-meta { font-size: 12.5px; color: var(--ink-subtle); margin-top: 8px; }
.detail-actions { display: flex; align-items: center; gap: 8px; flex: none; }
.detail-actions select.input { width: auto; padding-top: 6px; padding-bottom: 6px; font-size: 12.5px; }
.detail-cols { display: grid; grid-template-columns: minmax(0,1fr) 350px; gap: 22px; align-items: start; }

/* ─ 패널 ─────────────────────────────────────────────────── */
.panel {
  background: var(--glass); border: 1px solid var(--glass-brd);
  border-radius: var(--radius); padding: 21px; box-shadow: var(--shadow-sm), var(--hl-top);
}
html.dark .panel { border-color: var(--glass-brd-2); }
.panel + .panel { margin-top: 16px; }
.panel-title {
  font-size: 10.5px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase;
  color: var(--ink-subtle); margin-bottom: 16px; display: flex; align-items: center; gap: 8px;
}
.panel-title .count {
  font-family: var(--mono); font-variant-numeric: tabular-nums;
  font-size: 10.5px; color: var(--accent);
  background: var(--accent-subtle); border-radius: 999px; padding: 1px 9px;
  letter-spacing: 0; text-transform: none; font-weight: 700;
}
.panel-title .title-action { margin-left: auto; }
.desc-body { white-space: pre-wrap; color: var(--ink-muted); font-size: 14px; line-height: 1.75; }
.desc-body.empty-desc { color: var(--ink-subtle); font-style: italic; }

/* ─ 투표 폼 ──────────────────────────────────────────────── */
.vote-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0 14px; }
.slider-row { margin-bottom: 15px; }
.slider-row label {
  display: flex; align-items: baseline; justify-content: space-between;
  font-size: 11px; font-weight: 750; letter-spacing: .04em; text-transform: uppercase;
  color: var(--ink-subtle); margin-bottom: 6px;
}
.slider-val { font-family: var(--mono); font-variant-numeric: tabular-nums; font-size: 13px; color: var(--accent); text-transform: none; letter-spacing: 0; font-weight: 700; }
.ice-divider {
  font-size: 10px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase;
  color: var(--ink-subtle); margin: 10px 0 13px; display: flex; align-items: center; gap: 8px;
}
.ice-divider::after { content: ""; flex: 1; height: 1px; background: var(--glass-brd-2); }

.my-scores { display: flex; gap: 11px; margin: 17px 0; }
.my-scores > div {
  flex: 1; background: var(--glass-3); border: 1px solid var(--glass-brd-2);
  border-radius: var(--radius-sm); padding: 13px 15px;
  display: flex; flex-direction: column; gap: 3px;
}
.my-scores .lbl { font-size: 10px; font-weight: 750; letter-spacing: .07em; color: var(--ink-subtle); text-transform: uppercase; }
.my-scores strong {
  font-family: var(--mono); font-variant-numeric: tabular-nums;
  font-size: 21px; font-weight: 750;
  background: var(--grad); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.vote-actions { display: flex; gap: 8px; }
.vote-actions .btn-primary { flex: 1; }
.vote-notice {
  font-size: 13px; color: var(--ink-subtle);
  background: var(--glass-3); border: 1px solid var(--glass-brd-2);
  border-radius: var(--radius-sm); padding: 12px 14px; line-height: 1.6;
}

/* ─ 집계 ─────────────────────────────────────────────────── */
.agg-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 9px; }
.agg-item { background: var(--glass-3); border-radius: var(--radius-sm); padding: 11px 14px; border: 1px solid var(--glass-brd-2); }
.agg-item .lbl { display: block; font-size: 10px; color: var(--ink-subtle); font-weight: 750; letter-spacing: .06em; text-transform: uppercase; }
.agg-item .val { font-family: var(--mono); font-variant-numeric: tabular-nums; font-size: 15px; font-weight: 700; margin-top: 2px; }
.voter-list { list-style: none; margin: 12px 0 0; padding: 0; display: flex; flex-direction: column; }
.voter-list li {
  display: flex; align-items: center; gap: 8px; padding: 9px 2px; font-size: 13px;
  border-top: 1px solid var(--glass-brd-2);
}
.voter-list li b { font-weight: 550; flex: 1; }
.voter-list li .vs { font-family: var(--mono); font-variant-numeric: tabular-nums; color: var(--ink-muted); font-size: 12.5px; }

/* ─ 코멘트 ───────────────────────────────────────────────── */
.comment { padding: 15px 0; border-top: 1px solid var(--glass-brd-2); }
.comment:first-child { border-top: none; padding-top: 2px; }
.comment-head { display: flex; align-items: baseline; gap: 8px; }
.comment-author { font-size: 13.5px; font-weight: 650; }
.comment-date { font-size: 11.5px; color: var(--ink-subtle); }
.comment-head .btn-ghost { margin-left: auto; padding: 2px 7px; font-size: 11.5px; }
.comment-body { margin-top: 5px; font-size: 13.5px; color: var(--ink-muted); white-space: pre-wrap; line-height: 1.7; }
.comment-actions { margin-top: 6px; }
.comment-actions .btn-ghost { padding: 2px 8px; font-size: 12px; }
.comment-children { margin-top: 10px; padding-left: 18px; border-left: 2px solid var(--accent-subtle); }
.comment-children .comment { border-top: none; padding: 10px 0; }
.reply-form { margin-top: 10px; }
.comment-form textarea.input { min-height: 70px; }
.comment-form .form-foot { display: flex; justify-content: flex-end; margin-top: 8px; }

/* ─ 대시보드 ──────────────────────────────────────────────── */
.kpi-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 18px; margin-bottom: 24px; }
.kpi {
  padding: 22px 24px;
  background: var(--glass); border: 1px solid var(--glass-brd); border-radius: var(--radius);
  box-shadow: var(--shadow-sm), var(--hl-top);
}
html.dark .kpi { border-color: var(--glass-brd-2); }
.kpi .kpi-label { font-size: 10.5px; color: var(--ink-subtle); font-weight: 750; text-transform: uppercase; letter-spacing: .07em; }
.kpi .kpi-value {
  font-family: var(--mono); font-variant-numeric: tabular-nums;
  font-size: 36px; font-weight: 750; letter-spacing: -0.04em; margin-top: 8px; line-height: 1;
  background: var(--grad); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}

.scatter-wrap { position: relative; }
.scatter-wrap svg { display: block; width: 100%; height: auto; }
.scatter-axis text { fill: var(--ink-subtle); font-size: 10.5px; font-family: var(--mono); }
.scatter-axis-label { fill: var(--ink-subtle); font-size: 11px; font-family: var(--sans); }
.scatter-grid { stroke: var(--hairline); stroke-width: 1; }
.scatter-guide { stroke: var(--hairline-strong); stroke-width: 1; stroke-dasharray: 4 4; }
.scatter-qw-zone { fill: rgba(37,99,235,.07); }
.scatter-qw-label { fill: var(--accent); font-size: 11px; font-weight: 750; letter-spacing: .04em; }
.scatter-quad-label { fill: var(--ink-subtle); font-size: 10px; opacity: .6; }
circle.dot { fill: rgba(37,99,235,.45); stroke: var(--accent); stroke-width: 1.5; cursor: pointer; transition: fill var(--t-fast); }
circle.dot:hover { fill: rgba(37,99,235,.8); }
.scatter-tip {
  position: absolute; pointer-events: none; z-index: 5;
  background: var(--glass); border: 1px solid var(--glass-brd);
  border-radius: var(--radius-sm); padding: 11px 14px;
  font-size: 12.5px; min-width: 160px; max-width: 260px; box-shadow: var(--shadow-md);
}
.scatter-tip b { display: block; font-size: 13px; margin-bottom: 4px; }
.scatter-tip .row { display: flex; justify-content: space-between; gap: 14px; color: var(--ink-muted); }
.scatter-tip .row .v { font-family: var(--mono); font-variant-numeric: tabular-nums; }

/* ─ 테이블 ───────────────────────────────────────────────── */
.table-wrap { overflow-x: auto; }
table.tbl { width: 100%; border-collapse: collapse; font-size: 13px; }
.tbl thead tr { background: var(--glass-3); }
.tbl th {
  text-align: left; font-size: 11px; font-weight: 700; letter-spacing: .04em;
  color: var(--ink-subtle); text-transform: uppercase; line-height: 1.4;
  padding: 11px 16px; border-bottom: 1px solid var(--border-strong); white-space: nowrap;
}
.tbl td {
  padding: 12px 16px; border-bottom: 1px solid var(--glass-brd-2);
  vertical-align: middle; line-height: 1.5; color: var(--ink-muted);
}
.tbl td b, .tbl td a.row-link { color: var(--ink); }
/* 표 좌우 끝 셀에 여백 추가 (테두리에 글자가 붙지 않게) */
.tbl th:first-child, .tbl td:first-child { padding-left: 20px; }
.tbl th:last-child, .tbl td:last-child { padding-right: 20px; }
.tbl tr:last-child td { border-bottom: none; }
.tbl tbody tr { transition: background var(--t-fast); }
.tbl tbody tr:hover td { background: var(--glass-3); }
.tbl .num { font-family: var(--mono); font-variant-numeric: tabular-nums; }
.tbl .rank { color: var(--ink-subtle); font-family: var(--mono); font-variant-numeric: tabular-nums; width: 44px; }
.tbl a.row-link { font-weight: 550; }
.tbl a.row-link:hover { color: var(--accent); }
.rice-cell { display: flex; align-items: center; gap: 9px; }
.hbar .hbar-bg { fill: var(--glass-3); }
.hbar .hbar-fill { fill: var(--accent); }

/* ─ 로그인 / 인증 ─────────────────────────────────────────── */
.login-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 24px; }
.login-card {
  width: 392px; background: var(--glass);
  border: 1px solid var(--glass-brd); border-radius: var(--radius-2xl);
  padding: 42px 38px 36px; box-shadow: var(--shadow-lg), var(--hl-top);
}
html.dark .login-card { border-color: var(--glass-brd-2); }
.login-card .logo-mark { width: 52px; height: 52px; border-radius: 16px; font-size: 24px; margin: 0 auto 20px; }
.login-card h1 { font-size: 20px; font-weight: 750; text-align: center; letter-spacing: -0.03em; }
.login-card .login-sub { text-align: center; color: var(--ink-subtle); font-size: 13px; margin: 8px 0 28px; line-height: 1.6; }
.auth-alt { text-align: center; color: var(--ink-subtle); font-size: 13px; margin: 18px 0 0; }
.auth-alt a { color: var(--accent); font-weight: 650; }
.auth-alt a:hover { text-decoration: underline; }

/* ─ 모달 ─────────────────────────────────────────────────── */
#modal-root { position: fixed; inset: 0; z-index: 100; display: flex; align-items: flex-start; justify-content: center; }
#modal-root[hidden] { display: none; }
.modal-backdrop {
  position: absolute; inset: 0;
  background: rgba(20,24,40,.34);
  -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  animation: backdrop-in .22s ease;
}
@keyframes backdrop-in { from { opacity: 0; } to { opacity: 1; } }
.modal {
  position: relative; margin-top: 10vh;
  width: 500px; max-width: calc(100vw - 48px); max-height: 80vh; overflow: auto;
  background: var(--glass); border: 1px solid var(--glass-brd);
  border-radius: var(--radius-xl); box-shadow: var(--shadow-lg), var(--hl-top);
  animation: modal-in .26s cubic-bezier(.16,1,.3,1);
}
html.dark .modal { border-color: var(--glass-brd-2); }
@keyframes modal-in { from { opacity: 0; transform: translateY(-16px) scale(.96); } to { opacity: 1; transform: none; } }
.modal-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 22px 16px; border-bottom: 1px solid var(--glass-brd-2);
}
.modal-head h2 { font-size: 16px; font-weight: 750; letter-spacing: -0.03em; }
.modal-close {
  background: var(--glass-3); border: 1px solid var(--glass-brd-2); color: var(--ink-subtle);
  font-size: 16px; line-height: 1; padding: 6px 9px; border-radius: 9px;
  transition: background var(--t-fast), color var(--t-fast);
}
.modal-close:hover { background: var(--danger-bg); color: var(--danger); }
.modal-body { padding: 22px 22px 26px; }
.modal-foot { display: flex; justify-content: flex-end; gap: 9px; margin-top: 12px; }

/* ─ 토스트 ───────────────────────────────────────────────── */
#toast-root { position: fixed; right: 22px; bottom: 22px; z-index: 200; display: flex; flex-direction: column; gap: 9px; align-items: flex-end; }
.toast {
  display: flex; align-items: flex-start; gap: 10px;
  background: var(--glass); border: 1px solid var(--glass-brd);
  border-left: 3px solid var(--danger);
  border-radius: var(--radius); padding: 14px 18px 14px 15px;
  font-size: 13.5px; max-width: 360px; line-height: 1.6;
  box-shadow: var(--shadow-md), var(--hl-top);
  animation: toast-in .26s cubic-bezier(.16,1,.3,1);
}
.toast.success { border-left-color: var(--success); }
.toast.warn { border-left-color: var(--warn); }
.toast.leaving { opacity: 0; transform: translateX(16px); transition: opacity .24s, transform .24s; }
.toast .toast-msg { flex: 1; min-width: 0; }
.toast .toast-close { flex: none; background: none; border: none; color: var(--ink-subtle); cursor: pointer; font-size: 13px; line-height: 1; padding: 2px 4px; margin: -2px -4px 0 4px; border-radius: 6px; }
.toast .toast-close:hover { color: var(--ink); background: var(--glass-3); }
@keyframes toast-in { from { opacity: 0; transform: translateX(20px); } to { opacity: 1; transform: none; } }

/* ─ 설정 ─────────────────────────────────────────────────── */
.narrow-card { max-width: 470px; padding: 26px; }
.settings-desc { font-size: 12.5px; color: var(--ink-subtle); margin: -2px 0 18px; line-height: 1.6; }

/* ─ 반응형 ───────────────────────────────────────────────── */
@media (max-width: 1380px) {
  #main { padding: 34px 34px 68px; }
  .detail-cols { grid-template-columns: minmax(0,1fr) 310px; }
}
@media (max-width: 1180px) {
  .detail-cols { grid-template-columns: 1fr; }
  .kpi-grid { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 900px) {
  #main { padding: 24px 20px 52px; }
}

/* ── 모바일 네비게이션 드로어(햄버거) — 기본은 숨김 ── */
.nav-toggle, .nav-backdrop { display: none; }
@media (max-width: 640px) {
  /* 햄버거 버튼 */
  .nav-toggle {
    display: inline-flex; align-items: center; justify-content: center;
    position: fixed; top: 12px; left: 12px; z-index: 90;
    width: 40px; height: 40px; border-radius: 11px;
    background: var(--glass); border: 1px solid var(--glass-brd); color: var(--ink);
    box-shadow: var(--shadow-sm), var(--hl-top);
    -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
  }
  body.no-chrome .nav-toggle { display: none; }
  /* 사이드바 = 오프캔버스 드로어 */
  #sidebar, #sidebar:hover, html.nav-pinned #sidebar {
    width: var(--rail-open); transform: translateX(-100%);
    transition: transform var(--t-slow); z-index: 95; box-shadow: none;
  }
  body.nav-open #sidebar { transform: translateX(0); box-shadow: var(--shadow-lg); }
  .nav-label { opacity: 1 !important; }  /* 드로어는 라벨 항상 표시 */
  /* 메인 = 전체 폭, 상단에 햄버거 공간 */
  #main, html.nav-pinned #main { margin-left: 0 !important; }
  #main { padding: 64px 16px 44px; }
  body.map-view #main { padding: 0 !important; }
  /* 백드롭 */
  .nav-backdrop {
    display: block; position: fixed; inset: 0; z-index: 92;
    background: rgba(15,20,40,.45); opacity: 0; pointer-events: none;
    transition: opacity var(--t-base);
  }
  body.nav-open .nav-backdrop { opacity: 1; pointer-events: auto; }
  /* 좁은 화면 여백·그리드 정리 */
  .page-head { flex-direction: column; align-items: stretch; gap: 12px; }
  .page-actions { justify-content: flex-start; }
  .pp-stat-grid { grid-template-columns: repeat(2, 1fr); }
  .vote-grid { grid-template-columns: 1fr; }
  /* 2열 그리드(홈 분포/워크로드, 상세 좌우)·빌더는 모바일에서 1열로 스택(인라인 1fr 1fr 덮어쓰기) */
  .pp-2col, .pp-detail-grid, .detail-cols, .builder-cols { grid-template-columns: 1fr !important; }
  .kpi-grid { grid-template-columns: 1fr 1fr !important; }
}

/* ============================================================
   자동화 실행 (워크플로)
   ============================================================ */
.badge.tg-manual { background: var(--glass-3); color: var(--ink-muted); }
.badge.tg-form { background: var(--accent-subtle); color: var(--accent); border-color: rgba(37,99,235,.2); }
.badge.tg-schedule { background: var(--warn-bg); color: var(--warn); border-color: rgba(192,122,0,.22); }

.status-dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; flex: none; background: var(--hairline-strong); }
.status-dot.ok { background: var(--success); box-shadow: 0 0 8px rgba(15,157,110,.6); }
.status-dot.err { background: var(--danger); box-shadow: 0 0 8px rgba(224,69,94,.6); }
.status-dot.run { background: var(--warn); animation: dot-pulse 1.2s ease-in-out infinite; }
@keyframes dot-pulse { 0%,100% { opacity: 1; } 50% { opacity: .35; } }

.switch { position: relative; display: inline-flex; align-items: center; cursor: pointer; flex: none; }
.switch input { position: absolute; opacity: 0; width: 0; height: 0; }
.switch .switch-track {
  width: 38px; height: 21px; border-radius: 999px; position: relative;
  background: var(--glass-3); border: 1px solid var(--glass-brd-2);
  transition: background var(--t-base), border-color var(--t-base);
}
.switch .switch-track::after {
  content: ""; position: absolute; top: 2px; left: 2px;
  width: 15px; height: 15px; border-radius: 50%; background: var(--ink-subtle);
  transition: transform var(--t-base), background var(--t-base);
  box-shadow: 0 1px 3px rgba(0,0,0,.2);
}
.switch input:checked + .switch-track { background: var(--grad); border-color: transparent; }
.switch input:checked + .switch-track::after { transform: translateX(17px); background: #fff; }
.switch input:disabled + .switch-track { opacity: .45; cursor: not-allowed; }
.switch input:focus-visible + .switch-track { box-shadow: 0 0 0 4px var(--accent-ring); }

.wf-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 18px; }
.wf-card { display: flex; flex-direction: column; gap: 12px; padding: 19px; }
.wf-card-top { display: flex; align-items: center; gap: 10px; }
.wf-card-top .switch { margin-left: auto; }
.wf-last { display: inline-flex; align-items: center; gap: 6px; font-size: 11.5px; color: var(--ink-subtle); white-space: nowrap; }
.wf-card-title { font-size: 15.5px; font-weight: 650; letter-spacing: -0.02em; line-height: 1.4; }
.wf-card-title:hover { color: var(--accent); }
.wf-card-meta { font-size: 12.5px; color: var(--ink-subtle); display: flex; gap: 6px; flex-wrap: wrap; }
.wf-card-meta .sep { opacity: .5; }
.wf-card-meta a:hover { color: var(--accent); }
.wf-card-actions { display: flex; gap: 8px; margin-top: auto; flex-wrap: wrap; }

.builder-bar { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; margin-top: 6px; }
.wf-name-input {
  flex: 1; min-width: 200px; max-width: 480px;
  background: transparent; border: 1px solid transparent; border-radius: var(--radius-sm);
  color: var(--ink); font-family: var(--sans);
  font-size: 21px; font-weight: 750; letter-spacing: -0.03em; padding: 6px 10px;
}
.wf-name-input:hover:not(:disabled) { border-color: var(--glass-brd-2); }
.wf-name-input:focus { outline: none; border-color: var(--accent); background: var(--glass-2); box-shadow: 0 0 0 4px var(--accent-ring); }
.builder-cols { display: grid; grid-template-columns: minmax(0,1fr) 400px; gap: 22px; align-items: start; margin-top: 20px; }
.builder-side { min-width: 0; }

.wf-canvas { display: flex; flex-direction: column; align-items: center; padding: 12px 0 52px; }
.step-card {
  width: 100%; max-width: 468px;
  display: flex; align-items: center; gap: 14px;
  background: var(--glass); border: 1px solid var(--glass-brd);
  border-radius: var(--radius); padding: 14px 16px; cursor: pointer; position: relative;
  box-shadow: var(--shadow-xs), var(--hl-top);
  transition: border-color var(--t-fast), box-shadow var(--t-base), transform var(--t-fast);
}
html.dark .step-card { border-color: var(--glass-brd-2); }
.step-card:hover { box-shadow: var(--shadow-sm), var(--hl-top); transform: translateY(-2px); }
.step-card.selected { border-color: var(--accent); box-shadow: 0 0 0 4px var(--accent-ring); transform: none; }
.step-icon {
  width: 38px; height: 38px; flex: none; border-radius: 11px;
  background: var(--glass-3); border: 1px solid var(--glass-brd-2);
  display: flex; align-items: center; justify-content: center; font-size: 16px; color: var(--ink-muted);
}
.trigger-card .step-icon { background: var(--grad); border-color: transparent; color: #fff; box-shadow: var(--shadow-glow); }
.step-info { flex: 1; min-width: 0; }
.step-name { font-size: 13.5px; font-weight: 650; display: flex; align-items: center; gap: 7px; min-width: 0; }
.step-name .step-type, .exec-step-head .step-type {
  font-size: 10.5px; font-weight: 650; color: var(--ink-subtle); flex: none;
  background: var(--glass-3); border: 1px solid var(--glass-brd-2);
  border-radius: 999px; padding: 0 9px; line-height: 1.8;
}
.step-sum { font-size: 12px; color: var(--ink-subtle); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 2px; }
.step-ctl { display: flex; gap: 2px; flex: none; opacity: 0; transition: opacity var(--t-fast); }
.step-card:hover .step-ctl, .step-card.selected .step-ctl { opacity: 1; }
.step-ctl button {
  background: none; border: 1px solid transparent; border-radius: 8px;
  color: var(--ink-subtle); width: 27px; height: 27px; cursor: pointer; font-size: 13px;
  display: flex; align-items: center; justify-content: center;
  transition: background var(--t-fast), color var(--t-fast);
}
.step-ctl button:hover { background: var(--glass-3); color: var(--ink); }
.step-ctl button:disabled { opacity: .3; cursor: default; }
.step-ctl button.del:hover { color: var(--danger); background: var(--danger-bg); }

.wf-connector { width: 2px; height: 28px; background: var(--border-strong); position: relative; flex: none; }
.wf-connector::after {
  content: ""; position: absolute; left: 50%; bottom: -2px; transform: translateX(-50%);
  border: 4px solid transparent; border-top-color: var(--border-strong);
}

.add-step-wrap { position: relative; width: 100%; max-width: 468px; }
.add-step-btn { width: 100%; border-style: dashed; color: var(--ink-muted); }
.add-pop {
  position: absolute; top: calc(100% + 8px); left: 50%; transform: translateX(-50%);
  z-index: 20; width: 272px;
  background: var(--glass); border: 1px solid var(--glass-brd);
  border-radius: var(--radius); box-shadow: var(--shadow-lg), var(--hl-top); padding: 7px;
}
.add-pop[hidden] { display: none; }
.add-pop button {
  display: flex; align-items: center; gap: 11px; width: 100%;
  background: none; border: none; border-radius: var(--radius-sm);
  padding: 9px 11px; cursor: pointer; text-align: left; transition: background var(--t-fast);
}
.add-pop button:hover { background: var(--glass-3); }
.add-pop .step-icon { width: 31px; height: 31px; font-size: 14px; }
.add-pop b { display: block; font-size: 13px; }
.add-pop .d { display: block; font-size: 11.5px; color: var(--ink-subtle); }

.input.invalid { border-color: var(--danger); }
.hint-text { font-size: 12px; color: var(--ink-subtle); margin: 6px 0 0; line-height: 1.6; }
.var-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.var-chip {
  font-family: var(--mono); font-size: 11.5px;
  background: var(--accent-subtle); border: 1px solid rgba(37,99,235,.24);
  color: var(--accent); border-radius: 8px; padding: 3px 9px; cursor: pointer;
  transition: background var(--t-fast);
}
.var-chip:hover { background: rgba(37,99,235,.18); }

.ff-row { border: 1px solid var(--glass-brd-2); border-radius: var(--radius-sm); padding: 12px; margin-bottom: 9px; background: var(--glass-3); }
.ff-grid { display: grid; grid-template-columns: 1fr 1fr 88px 28px; gap: 7px; align-items: center; }
.ff-grid .btn-ghost { padding: 2px; }
.ff-opts { margin-top: 7px; }
.ff-req { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; color: var(--ink-muted); margin-top: 8px; }
.form-url-row { display: flex; align-items: center; gap: 8px; margin-top: 14px; }
.form-url-row code {
  flex: 1; min-width: 0; font-family: var(--mono); font-size: 12px; color: var(--ink-muted);
  background: var(--glass-3); border: 1px solid var(--glass-brd-2); border-radius: var(--radius-sm);
  padding: 8px 11px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

.exec-item { border: 1px solid var(--glass-brd-2); border-radius: var(--radius); margin-bottom: 9px; overflow: hidden; background: var(--glass); box-shadow: var(--shadow-xs); }
.exec-item.ok { border-left: 3px solid var(--success); }
.exec-item.err { border-left: 3px solid var(--danger); }
.exec-item.run { border-left: 3px solid var(--warn); }
.exec-head {
  display: flex; align-items: center; gap: 8px; width: 100%;
  background: none; border: none; padding: 11px 14px; cursor: pointer;
  font-size: 12.5px; color: var(--ink-muted); text-align: left; transition: background var(--t-fast);
}
.exec-head:hover { background: var(--glass-3); }
.exec-head .exec-when { font-family: var(--mono); font-variant-numeric: tabular-nums; }
.exec-head .exec-src { margin-left: auto; font-size: 11.5px; color: var(--ink-subtle); white-space: nowrap; }
.exec-body { border-top: 1px solid var(--glass-brd-2); padding: 9px 14px 13px; }
.exec-step { border: 1px solid var(--glass-brd-2); border-radius: var(--radius-sm); margin-top: 7px; overflow: hidden; }
.exec-step-head {
  display: flex; align-items: center; gap: 7px; width: 100%;
  background: var(--glass-3); border: none; padding: 9px 11px;
  font-size: 12px; cursor: pointer; color: var(--ink-muted); text-align: left; transition: background var(--t-fast);
}
.exec-step-head:hover { background: var(--accent-subtle); }
.exec-step-head b { color: var(--ink); font-weight: 650; }
.exec-step-head .ms { margin-left: auto; font-family: var(--mono); font-variant-numeric: tabular-nums; color: var(--ink-subtle); font-size: 11px; }
.exec-step-body { border-top: 1px solid var(--glass-brd-2); padding: 9px 11px; }
.exec-step-body pre {
  margin: 0; font-family: var(--mono); font-size: 11.5px; line-height: 1.6;
  white-space: pre-wrap; word-break: break-word; color: var(--ink-muted);
  max-height: 220px; overflow: auto;
}
.exec-step-body pre.err-text { color: var(--danger); }
.exec-error { font-size: 12px; color: var(--danger); margin-top: 8px; }
.exec-empty { font-size: 12.5px; color: var(--ink-subtle); padding: 16px 4px; text-align: center; }

#integration-slot { margin-top: 24px; }

@media (max-width: 1380px) { .builder-cols { grid-template-columns: minmax(0,1fr) 360px; } }
@media (max-width: 1180px) { .builder-cols { grid-template-columns: 1fr; } }

/* ============================================================
   관리자 탭
   ============================================================ */
.tabs { display: flex; gap: 0; border-bottom: 1px solid var(--glass-brd-2); margin-bottom: 26px; }
.tab-btn {
  background: none; border: none; padding: 11px 21px; font-size: 13.5px; font-weight: 600;
  color: var(--ink-subtle); border-bottom: 2px solid transparent; margin-bottom: -1px;
  transition: color var(--t-base), border-color var(--t-base); letter-spacing: -0.01em;
}
.tab-btn:hover { color: var(--ink); }
.tab-btn.active { color: var(--accent); font-weight: 700; border-bottom-color: var(--accent); }

/* ============================================================
   업무 플로우 설정 — 아코디언
   ============================================================ */
.accordion { border: 1px solid var(--glass-brd-2); border-radius: var(--radius); margin-bottom: 9px; overflow: hidden; background: var(--glass); box-shadow: var(--shadow-xs); }
.accordion-header {
  width: 100%; background: var(--glass-3); border: none;
  display: flex; align-items: center; gap: 11px; padding: 14px 18px;
  font-size: 13.5px; font-weight: 650; color: var(--ink); transition: background var(--t-fast);
}
.accordion-header:hover { background: var(--accent-subtle); }
.acc-count {
  margin-left: auto; font-size: 10.5px; font-weight: 750; letter-spacing: .04em;
  color: var(--accent); background: var(--accent-subtle); border: 1px solid rgba(37,99,235,.2);
  border-radius: 999px; padding: 1px 10px;
}
.acc-arrow { font-size: 10px; color: var(--ink-subtle); transition: transform var(--t-base); }
.accordion.open .acc-arrow { transform: rotate(90deg); }
.accordion-body { padding: 10px 16px 16px; }

.flow-row { padding: 10px 5px; border-bottom: 1px solid var(--glass-brd-2); }
.flow-row:last-child { border-bottom: none; }
.flow-row-main { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.flow-name { flex: 1; font-size: 13.5px; }
.flow-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.dot-active { background: var(--success); box-shadow: 0 0 8px rgba(15,157,110,.6); }
.dot-inactive { background: var(--hairline-strong); }
.flow-form .field { margin-bottom: 11px; }
.flow-form label { display: block; font-size: 11px; color: var(--ink-subtle); margin-bottom: 5px; font-weight: 750; letter-spacing: .04em; text-transform: uppercase; }

/* ============================================================
   프로세스 맵
   ============================================================ */
.map-wrap { display: flex; flex-direction: column; height: 100%; overflow: hidden; }
.map-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 9px 16px; gap: 8px;
  border-bottom: 1px solid var(--glass-brd-2);
  background: var(--glass); flex-shrink: 0; box-shadow: var(--hl-top);
}
.map-toolbar-left, .map-toolbar-right { display: flex; align-items: center; gap: 7px; flex-wrap: wrap; }
.map-sep { width: 1px; height: 18px; background: var(--glass-brd-2); }
.map-canvas-wrap { flex: 1; position: relative; overflow: hidden; cursor: grab; }
.map-canvas-wrap:active { cursor: grabbing; }
.map-tabs-bar {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 16px; border-top: 1px solid var(--glass-brd-2);
  background: var(--glass); flex-shrink: 0; overflow-x: auto;
}
.map-tab {
  padding: 6px 15px; border-radius: var(--radius-sm); border: 1px solid var(--glass-brd-2);
  background: var(--glass-2); color: var(--ink-muted); font-size: 12.5px; font-weight: 550;
  cursor: pointer; white-space: nowrap; display: flex; align-items: center; gap: 5px;
  transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast); box-shadow: var(--hl-top);
}
.map-tab:hover { color: var(--ink); border-color: var(--accent); }
.map-tab.active { background: var(--grad); color: #fff; border-color: transparent; box-shadow: var(--shadow-glow); }
.map-tab-stage { font-size: 10px; padding: 1px 6px; border-radius: 6px; background: rgba(255,255,255,.22); color: rgba(255,255,255,.9); }
.map-tab:not(.active) .map-tab-stage { background: var(--glass-3); color: var(--ink-subtle); }
.map-node-panel {
  position: absolute; right: 14px; top: 10px; width: 248px;
  max-height: calc(100% - 24px); overflow-y: auto; overscroll-behavior: contain;
  background: var(--glass); border: 1px solid var(--glass-brd);
  border-radius: var(--radius); padding: 15px;
  display: flex; flex-direction: column; gap: 11px;
  box-shadow: var(--shadow-md), var(--hl-top); z-index: 10;
}
/* display:flex 가 hidden 속성을 덮어쓰므로 명시적으로 숨김 */
.map-node-panel[hidden] { display: none !important; }
/* 패널 헤더 — 스크롤 시에도 닫기 버튼 고정 */
.map-node-panel .panel-head {
  position: sticky; top: -15px; margin: -15px -15px 0; padding: 13px 15px 9px;
  background: var(--glass); border-bottom: 1px solid var(--glass-brd-2);
  border-radius: var(--radius) var(--radius) 0 0; z-index: 1;
}
.map-node-panel .form-label { gap: 4px; }
.map-node-panel textarea.form-input { font-size: 12.5px; }
.panel-head { display: flex; align-items: center; justify-content: space-between; font-size: 13.5px; font-weight: 650; }
.panel-row { display: flex; gap: 8px; }
.btn-icon { background: transparent; border: none; color: var(--ink-muted); cursor: pointer; font-size: 15px; padding: 3px 5px; transition: color var(--t-fast); }
.btn-icon:hover { color: var(--ink); }
.map-connect-hint {
  position: absolute; top: 10px; left: 50%; transform: translateX(-50%);
  background: var(--grad); color: #fff; padding: 8px 17px;
  border-radius: 999px; font-size: 12.5px; pointer-events: none; box-shadow: var(--shadow-glow);
}
.map-connect-btn.active, #map-connect-btn.active { background: var(--grad); color: #fff; border-color: transparent; }
.map-page-title { font-size: 13.5px; font-weight: 650; color: var(--ink); white-space: nowrap; max-width: 220px; overflow: hidden; text-overflow: ellipsis; }
.map-zoom-pct { font-size: 11.5px; font-variant-numeric: tabular-nums; color: var(--ink-muted); min-width: 42px; text-align: center; user-select: none; font-weight: 550; }
.map-guide {
  position: absolute; top: 14px; left: 14px; z-index: 8;
  background: var(--glass); border: 1px solid var(--glass-brd);
  border-radius: var(--radius); font-size: 12.5px; box-shadow: var(--shadow-md), var(--hl-top); min-width: 196px;
}
.map-guide-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px; border-bottom: 1px solid var(--glass-brd-2);
  font-weight: 650; font-size: 12.5px; color: var(--ink-muted);
}
.map-guide-body { padding: 12px 14px; display: flex; flex-direction: column; gap: 8px; }
.guide-item { display: flex; align-items: center; gap: 9px; color: var(--ink-muted); font-size: 12px; }
.guide-key {
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--glass-3); border: 1px solid var(--glass-brd-2);
  border-radius: 7px; padding: 2px 8px; font-size: 10.5px; font-weight: 750; white-space: nowrap; color: var(--ink);
}

/* 맵 — 줌/스냅/편집 토글 활성 */
#map-snap-btn.active, #map-edit-btn.active { background: var(--grad); color: #fff; border-color: transparent; box-shadow: var(--shadow-glow); }
.map-edit-toggle { display: inline-flex; align-items: center; gap: 6px; font-size: 12.5px; color: var(--ink-muted); white-space: nowrap; padding-left: 4px; }

/* 미니맵 */
/* 담당자별 진행 오버레이 (좌하단) */
.map-assignee {
  position: absolute; bottom: 14px; left: 14px; z-index: 8;
  width: 234px; max-height: 46%; display: flex; flex-direction: column;
  background: var(--glass); border: 1px solid var(--glass-brd);
  border-radius: var(--radius); font-size: 12.5px; box-shadow: var(--shadow-md), var(--hl-top);
  -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
}
.map-assignee .map-guide-body { overflow-y: auto; overscroll-behavior: contain; gap: 6px; }
.mga-total { color: var(--accent); font-weight: 700; margin-left: 4px; }
.mga-sub { font-size: 10.5px; font-weight: 700; color: var(--ink-subtle); text-transform: uppercase; letter-spacing: .03em; }
.mga-stagechips { display: flex; flex-wrap: wrap; gap: 5px; }
.mga-chip {
  display: inline-flex; align-items: center; gap: 5px; cursor: pointer;
  background: var(--glass-3); border: 1px solid var(--glass-brd-2); border-radius: 999px;
  padding: 2px 9px; font-size: 11px; color: var(--ink); font-weight: 600;
}
.mga-chip:hover { background: var(--glass); }
.mga-chip-dot { width: 7px; height: 7px; border-radius: 50%; }
.mga-chip b { font-weight: 800; }
.mga-row {
  display: flex; align-items: center; gap: 8px; width: 100%; text-align: left;
  background: none; border: 1px solid transparent; border-radius: 8px; padding: 4px 6px; cursor: pointer;
}
.mga-row:hover { background: var(--glass-3); border-color: var(--glass-brd-2); }
.mga-row.mga-hl { background: var(--accent-ring); border-color: var(--accent); }
.mga-name { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--ink); font-weight: 600; }
.mga-open { display: block; margin-top: 8px; font-size: 11.5px; color: var(--accent); text-decoration: none; font-weight: 600; }
.mga-open:hover { text-decoration: underline; }
.mga-stages { display: inline-flex; gap: 3px; flex-shrink: 0; }
.mga-dot {
  display: inline-flex; align-items: center; justify-content: center; min-width: 16px; height: 16px;
  border-radius: 8px; padding: 0 4px; font-size: 10px; font-weight: 700; color: #fff;
}
.mga-count {
  flex-shrink: 0; min-width: 20px; text-align: center; font-weight: 750; color: var(--ink);
  background: var(--glass-3); border: 1px solid var(--glass-brd-2); border-radius: 7px; padding: 1px 7px; font-size: 11px;
}
.map-minimap {
  position: absolute; right: 14px; bottom: 14px; width: 178px; height: 118px;
  background: var(--glass); border: 1px solid var(--glass-brd); border-radius: 13px;
  box-shadow: var(--shadow-md), var(--hl-top); overflow: hidden; z-index: 9;
  -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur); cursor: pointer;
}
.map-minimap svg { width: 100%; height: 100%; display: block; }
.mm-viewport { fill: rgba(37,99,235,.14); stroke: var(--accent); stroke-width: 1.5; }

/* 노드 리사이즈 핸들 */
.map-resize { fill: var(--accent); stroke: #fff; stroke-width: 1.5; cursor: nwse-resize; }

/* 노드 호버 글로우 + 선택 펄스 */
.map-node { transition: opacity var(--t-fast); }
.map-node text { transition: none; }
.map-node:hover { filter: drop-shadow(0 5px 14px rgba(37,99,235,.4)); }
.map-node.selected:hover { filter: none; }
.map-sel-ring { animation: sel-pulse 1.6s ease-in-out infinite; }
@keyframes sel-pulse {
  0%,100% { stroke-opacity: 1; stroke-width: 2; }
  50% { stroke-opacity: .45; stroke-width: 3; }
}

/* 엣지 호버 강조 */
.map-edge { transition: opacity var(--t-fast); }
.map-edge:hover .edge-line { stroke-width: 3.5; }

/* 캔버스 비네팅 (깊이감) — SVG 위, 컨트롤(guide/minimap/menu z≥8) 아래 */
.map-canvas-wrap::after {
  content: ''; position: absolute; inset: 0; pointer-events: none; z-index: 3;
  box-shadow: inset 0 0 90px rgba(40,50,90,.10), inset 0 0 24px rgba(40,50,90,.06);
}
html.dark .map-canvas-wrap::after { box-shadow: inset 0 0 120px rgba(0,0,0,.5); }
.map-connect-hint { z-index: 8; }

/* 노드 패널 — 크기/색상 행 */
.np-size-row { display: grid; grid-template-columns: 1fr 1fr; gap: 9px; }
.np-color-row { display: flex; align-items: center; gap: 8px; }
.np-color-row input[type=color] { flex: 1; }

/* 엣지 색상 칩 */
.ep-colors { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 4px; }
.ep-color-chip {
  width: 26px; height: 26px; border-radius: 8px; border: 2px solid transparent;
  cursor: pointer; font-size: 9px; font-weight: 700; color: #fff;
  display: flex; align-items: center; justify-content: center; padding: 0;
  box-shadow: var(--shadow-xs);
}
.ep-color-chip:first-child { width: auto; padding: 0 10px; background: var(--glass-3) !important; color: var(--ink-muted); border-color: var(--glass-brd-2); }
.ep-color-chip.active { border-color: var(--ink); box-shadow: 0 0 0 3px var(--accent-ring); }

/* 페이지 관리 드롭다운 */
.map-page-menu {
  position: absolute; z-index: 30; min-width: 158px;
  background: var(--glass); border: 1px solid var(--glass-brd);
  border-radius: var(--radius); box-shadow: var(--shadow-lg), var(--hl-top); padding: 6px;
  -webkit-backdrop-filter: var(--blur); backdrop-filter: var(--blur);
}
.map-page-menu button {
  display: flex; align-items: center; gap: 10px; width: 100%;
  background: none; border: none; border-radius: var(--radius-sm);
  padding: 8px 11px; cursor: pointer; text-align: left; font-size: 13px; color: var(--ink);
  transition: background var(--t-fast);
}
.map-page-menu button span { width: 16px; text-align: center; opacity: .7; }
.map-page-menu button:hover { background: var(--glass-3); }
.map-page-menu button.danger { color: var(--danger); }
.map-page-menu button.danger:hover { background: var(--danger-bg); }

/* ============================================================
   유틸리티
   ============================================================ */
@keyframes page-in { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }

code {
  font-family: var(--mono); font-size: .88em;
  background: var(--glass-3); border: 1px solid var(--glass-brd-2);
  border-radius: 6px; padding: 1px 6px; color: var(--ink-muted);
}
.section-head {
  font-size: 10.5px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase;
  color: var(--ink-subtle); margin-bottom: 12px; display: flex; align-items: center; gap: 8px;
}
.section-head::after { content: ''; flex: 1; height: 1px; background: var(--glass-brd-2); }
.tabular { font-family: var(--mono); font-variant-numeric: tabular-nums; }
.link-accent { color: var(--accent); }
.link-accent:hover { text-decoration: underline; }

/* ============================================================
   UX 고도화 — 위계 · 버튼 · 카드 인터랙션
   ============================================================ */
/* 페이지 제목 그라데이션 액센트 바 */
.page-head h1 { position: relative; padding-left: 15px; }
.page-head h1::before {
  content: ''; position: absolute; left: 0; top: 5px; bottom: 5px;
  width: 5px; border-radius: 3px; background: var(--grad);
}

/* 액션 버튼 행 — 인라인 스타일 대체 */
.page-actions { display: flex; justify-content: flex-end; align-items: center; gap: 8px; margin-bottom: 14px; flex-wrap: wrap; }
.row-actions { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }

/* 클릭 불가 카드는 들리지 않음 (오해 방지) */
.card.kpi:hover { transform: none; box-shadow: var(--shadow-sm), var(--hl-top); }

/* 클릭 가능한 KPI 카드 */
a.kpi.kpi-link { display: block; position: relative; cursor: pointer; text-decoration: none; }
a.kpi.kpi-link:hover { transform: translateY(-3px); box-shadow: var(--shadow-md), var(--hl-top); }
a.kpi.kpi-link::after {
  content: '→'; position: absolute; top: 14px; right: 16px;
  font-size: 14px; color: var(--ink-subtle); opacity: 0; transform: translateX(-4px);
  transition: opacity var(--t-base), transform var(--t-base);
}
a.kpi.kpi-link:hover::after { opacity: 1; transform: translateX(0); color: var(--accent); }

/* 카드 안 섹션 제목의 패딩 헬퍼 — 아래 테이블 셀(20px)과 좌측 정렬 */
.card > .panel-title.flush { padding: 18px 20px 4px; }
.signup-actions { display: flex; gap: 6px; align-items: center; }
.signup-actions select.input { width: auto; padding: 4px 8px; }

/* 플로우 편집 폼 박스 (인라인 대체) */
.flow-edit-box {
  margin-top: 10px; padding: 15px; border: 1px solid var(--glass-brd-2);
  border-radius: var(--radius-sm); background: var(--glass-3);
}
.flow-active-row { display: flex; align-items: center; gap: 8px; }
.flow-active-row label { margin: 0; }

/* ============================================================
   포털 — 통계 카드 · 칸반 보드 · 단계 스테퍼 · 카드
   ============================================================ */
/* 통계 카드 그리드 */
.pp-stat-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 14px; margin-bottom: 24px;
}
.pp-stat { padding: 16px 18px; display: flex; flex-direction: column; gap: 6px; position: relative; overflow: hidden; }
.pp-stat::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: var(--stat-c, var(--accent)); opacity: .85;
}
.pp-stat-label { font-size: 12px; font-weight: 600; color: var(--ink-subtle); letter-spacing: -.01em; }
.pp-stat-value {
  font-size: 30px; font-weight: 800; letter-spacing: -.03em; line-height: 1;
  color: var(--stat-c, var(--ink)); font-variant-numeric: tabular-nums;
}

/* 칸반 보드 */
.pp-board { display: flex; gap: 14px; overflow-x: auto; padding-bottom: 20px; align-items: flex-start; }
.pp-col {
  min-width: 236px; max-width: 264px; flex-shrink: 0;
  border-radius: var(--radius); border: 1px solid var(--border);
}
.pp-col-body { padding: 8px 12px 12px; display: flex; flex-direction: column; }
.pp-col-empty {
  text-align: center; padding: 22px 0; font-size: 12.5px; color: var(--ink-subtle);
  border: 1.5px dashed var(--border-strong); border-radius: var(--radius-sm); margin: 4px 0;
}

/* 칸반 컬럼 헤더 — 단계 색 강조 */
.pp-col-h { display: flex; align-items: center; justify-content: space-between; padding: 14px 12px 10px; }
.pp-col-h .lbl { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 800; letter-spacing: -.01em; }
.pp-col-h .lbl .sdot { width: 9px; height: 9px; border-radius: 50%; flex: none; }
.pp-col-h .cnt { font-size: 11.5px; font-weight: 700; padding: 2px 9px; border-radius: 8px; background: var(--surface-1); border: 1px solid var(--border); }

/* 단계 스테퍼 */
.pp-step { display: flex; align-items: center; width: 100%; margin: 10px 0 11px; }
.pp-step .dot { border-radius: 50%; flex: none; transition: all .25s ease; }
.pp-step .seg { flex: 1; height: 2px; border-radius: 2px; transition: all .25s ease; }

.pri-pill { display: inline-flex; align-items: center; gap: 3px; font-size: 11px; font-weight: 700; padding: 2px 10px; border-radius: 999px; white-space: nowrap; }
.pri-pill.high, .pri-pill.urgent { background: var(--danger-bg); color: var(--danger); }
.pri-pill.normal, .pri-pill.low { background: var(--surface-3); color: var(--ink-subtle); }
.pri-pill svg { width: 11px; height: 11px; }

/* 프로젝트 카드 — 내부 여백 정돈 */
.proj-card { margin-bottom: 10px; padding: 13px 14px; cursor: pointer; }
.proj-card:last-child { margin-bottom: 0; }
.proj-card .pc-top { display: flex; align-items: center; justify-content: space-between; gap: 6px; margin-bottom: 9px; }
.proj-card .pc-title {
  font-size: 13.5px; font-weight: 650; color: var(--ink); line-height: 1.45; margin-bottom: 3px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.proj-card .pc-meta {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
  font-size: 12px; color: var(--ink-muted);
  padding-top: 10px; border-top: 1px solid var(--glass-brd-2);
}
.proj-card .pc-meta .dept { font-weight: 600; }
.proj-card .pc-meta .who { display: inline-flex; align-items: center; gap: 4px; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.proj-card .pc-due { display: flex; align-items: center; gap: 5px; font-size: 11.5px; color: var(--ink-subtle); margin-top: 6px; }
.ic { width: 12px; height: 12px; flex: none; vertical-align: -1px; }

/* 포털 상세 — 카드 기본 패딩(인라인 패딩 없는 카드가 가장자리에 붙는 문제 해결) */
.pp-detail-grid .card { padding: 16px 18px; }
/* 상세 카드 섹션 제목 — 카드 패딩과 어울리게 */
.pp-detail-grid .card > div:first-child { margin-top: 1px; }

/* 로드맵 — 요약/단계 카드 패딩(가장자리에 붙는 문제 해결) */
.roadmap-summary { padding: 20px 24px; }
.roadmap-phase-card { padding: 20px 22px; }

/* 포털 — 필터바 */
.pp-filterbar { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 16px; }
.pp-filterbar .input-sm { width: auto; }
.pp-mywork { display: inline-flex; align-items: center; gap: 6px; font-size: 12.5px; font-weight: 600; color: var(--ink-muted); white-space: nowrap; cursor: pointer; padding: 0 4px; }

/* 포털 — 현황 대시보드 */
.pp-sec-title { font-size: 12px; font-weight: 800; letter-spacing: -.01em; color: var(--ink-muted); margin-bottom: 14px; }
.pp-due-row { display: flex; align-items: center; gap: 10px; padding: 8px 6px; border-radius: 9px; text-decoration: none; transition: background var(--t-fast); }
.pp-due-row:hover { background: var(--surface-3); }
.pp-due-badge { flex: none; font-size: 11px; font-weight: 800; padding: 2px 9px; border-radius: 999px; min-width: 3.1rem; text-align: center; }
.pp-due-title { flex: 1; min-width: 0; font-size: 13px; font-weight: 600; color: var(--ink); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.pp-due-meta { flex: none; font-size: 11.5px; color: var(--ink-subtle); white-space: nowrap; }

/* 포털 — 승인함 인박스 */
.apr-row { display: flex; align-items: flex-start; gap: 14px; padding: 15px 18px; border-bottom: 1px solid var(--glass-brd-2); }
.apr-row:last-child { border-bottom: none; }
.apr-main { flex: 1; min-width: 0; }
.apr-top { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 5px; }
.apr-proj { font-size: 12.5px; font-weight: 700; color: var(--accent); text-decoration: none; }
.apr-proj:hover { text-decoration: underline; }
.apr-stage { font-size: 11.5px; font-weight: 700; }
.apr-title { font-size: 14px; font-weight: 650; color: var(--ink); line-height: 1.4; }
.apr-meta { font-size: 12px; color: var(--ink-subtle); margin-top: 4px; }
.apr-desc { font-size: 12.5px; color: var(--ink-muted); margin-top: 6px; line-height: 1.6; }
.apr-actions { flex: none; display: flex; gap: 6px; }

/* 상세 모달 풀 스테퍼 */
.pp-step-full { display: flex; align-items: flex-start; width: 100%; padding: 4px 0 2px; }
.pp-step-full .step { display: flex; flex-direction: column; align-items: center; min-width: 52px; }
.pp-step-full .node { border-radius: 50%; display: flex; align-items: center; justify-content: center; transition: all .25s ease; }
.pp-step-full .lab { margin-top: 6px; font-size: 10.5px; white-space: nowrap; }
.pp-step-full .fseg { flex: 1; height: 3px; border-radius: 2px; margin-top: 9px; }

/* 플로우 — 카드 그리드 / 실행 상태 뱃지 */
.flow-grid { display: flex; flex-direction: column; gap: 10px; }
.badge.badge-running { background: var(--warn-bg); color: var(--warn); border-color: rgba(217,119,6,.22); }
.badge.badge-pending { background: var(--surface-3); color: var(--ink-subtle); }
.flow-card .ic { width: 13px; height: 13px; }

/* ── AI 드롭다운 메뉴 ─────────────────────────────────────── */
.ai-menu-item {
  display: flex; align-items: center; gap: .45rem;
  width: 100%; padding: 7px 11px; border: none; border-radius: 7px;
  background: transparent; color: var(--ink); font-size: 13px; font-weight: 500;
  cursor: pointer; text-align: left; transition: background var(--t-fast), color var(--t-fast);
  white-space: nowrap;
}
.ai-menu-item:hover { background: var(--accent-subtle); color: var(--accent); }

/* ── 칸반 빈 칼럼 상태 ────────────────────────────────────── */
.pp-col-empty {
  padding: .55rem .5rem;
  font-size: .79rem; color: var(--ink-subtle);
  text-align: center; line-height: 1.5;
}

/* ── 스켈레톤 로딩 shimmer ──────────────────────────────────── */
@keyframes shimmer {
  0%   { background-position: -600px 0; }
  100% { background-position:  600px 0; }
}
.skel {
  border-radius: 6px;
  background: linear-gradient(90deg, var(--surface-2) 25%, var(--surface-3) 50%, var(--surface-2) 75%);
  background-size: 600px 100%;
  animation: shimmer 1.4s ease-in-out infinite;
}
.skel-board { padding: 18px 0; }
.skel-board .skel-cols { display: flex; gap: 14px; overflow: hidden; }
.skel-board .skel-col  { flex: 1; min-width: 0; }
.skel-board .skel-col-h { height: 28px; border-radius: 6px; margin-bottom: 10px; }
.skel-board .skel-card  { height: 96px; border-radius: 8px; margin-bottom: 10px; }
.skel-detail { padding: 8px 0; }
.skel-detail .skel-title { height: 28px; width: 55%; border-radius: 6px; margin-bottom: 14px; }
.skel-detail .skel-grid  { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.skel-detail .skel-block { height: 180px; border-radius: 10px; }
.skel-inbox .skel-row { height: 72px; border-radius: 8px; margin-bottom: 10px; }

/* ── 필터 활성 배지 ─────────────────────────────────────────── */
.ppf-active-badge {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 18px; height: 18px; padding: 0 5px;
  border-radius: 9px; background: var(--accent); color: #fff;
  font-size: 11px; font-weight: 700; line-height: 1;
}
#ppf-reset.has-filter {
  color: var(--accent); border-color: var(--accent);
  font-weight: 600;
}
