/* =====================================================
   OCI CRM — 핑거세일즈 레이아웃 기반
   Brand: OCI Red (#E63329) / Black / Pure White
   ===================================================== */

:root {
  /* OCI 브랜드 컬러 */
  --oci-red: #E63329;
  --oci-red-dark: #B5261E;
  --oci-red-light: #FCE9E8;
  --oci-black: #1A1A1A;

  /* 핑거세일즈 스타일 컬러 */
  --primary: #E63329;
  --primary-dark: #B5261E;
  --primary-light: #FCE9E8;

  --bg: #F5F6F8;
  --surface: #FFFFFF;
  --surface-2: #FAFBFC;
  --surface-3: #F1F3F5;

  --border: #E4E7EB;
  --border-2: #D5D9DF;

  --text-1: #1F2329;
  --text-2: #4E5969;
  --text-3: #86909C;
  --text-4: #B0B6BF;

  --blue: #1664E5;
  --blue-light: #E6F0FE;
  --green: #00A86B;
  --green-light: #E6F7EF;
  --amber: #F59C00;
  --amber-light: #FFF6E5;
  --red: #E63329;
  --red-light: #FCE9E8;
  --purple: #7C4DFF;
  --purple-light: #F0EBFF;
  --gray: #6B7280;
  --gray-light: #F3F4F6;

  --sidebar-w: 220px;
  --topbar-h: 56px;
  --radius-sm: 4px;
  --radius: 6px;
  --radius-lg: 8px;
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.04);
  --shadow: 0 1px 3px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.08);
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html {
  height: 100%;
  /* ★ 핵심: html 레벨 viewport 스크롤 완전 차단
     body만 overflow:hidden 하면 Chrome은 html 레벨에서 스크롤을 허용하기 때문에
     content 행이 topbar 위로 올라오는 현상 발생 */
  overflow: hidden;
}
html, body {
  font-family: 'Noto Sans KR', -apple-system, sans-serif;
  font-size: 13px;
  background: var(--bg);
  color: var(--text-1);
}
body {
  height: 100%;          /* 100vh 대신 100% 사용 — zoom 시 vh 단위 오차 방지 */
  overflow: hidden;
  display: flex;
}
button { font-family: inherit; cursor: pointer; }
input, select, textarea { font-family: inherit; }
a { text-decoration: none; color: inherit; }

/* ============== SIDEBAR ============== */
.sidebar {
  width: var(--sidebar-w);
  background: #FFFFFF;
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  /* height: 100% — flex 컨테이너(body)에서 stretch로 자동 채움.
     100vh 사용 시 zoom 적용 시 body 높이 초과로 이격 발생 */
  align-self: stretch;
}

.sidebar-logo {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
  height: var(--topbar-h);
  cursor: pointer;
  flex-shrink: 0;
  transition: background 0.12s;
}
.sidebar-logo:hover { background: var(--surface-2); }
.logo-img {
  height: 22px;
  width: auto;
  display: block;
}
.logo-divider {
  width: 1px;
  height: 16px;
  background: var(--border-2);
}
.logo-sub {
  font-size: 11px;
  color: var(--text-3);
  font-weight: 500;
  letter-spacing: 0.5px;
}

.sidebar-nav {
  flex: 1;
  overflow-y: auto;
  padding: 8px 0;
}
.nav-section { padding: 6px 0; }
.nav-section-title {
  font-size: 10px;
  color: var(--text-4);
  font-weight: 500;
  padding: 6px 16px;
  letter-spacing: 0.6px;
  text-transform: uppercase;
}
.nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 16px;
  font-size: 13px;
  color: var(--text-2);
  cursor: pointer;
  position: relative;
  transition: background 0.12s;
}
.nav-item svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  opacity: 0.7;
}
.nav-item:hover {
  background: var(--surface-3);
  color: var(--text-1);
}
.nav-item.active {
  background: var(--red-light);
  color: var(--oci-red);
  font-weight: 500;
}
.nav-item.active::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--oci-red);
}
.nav-item.active svg { opacity: 1; }
.nav-badge {
  margin-left: auto;
  background: var(--oci-red);
  color: #FFF;
  font-size: 10px;
  font-weight: 500;
  padding: 1px 6px;
  border-radius: 10px;
  min-width: 18px;
  text-align: center;
}

.sidebar-footer {
  border-top: 1px solid var(--border);
  padding: 10px 12px;
}
.ubadge {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.ubadge-info {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.ubadge-name {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-1);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ubadge-role {
  font-size: 10px;
  color: var(--text-3);
  margin-top: 1px;
}
.btn-logout {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: transparent;
  color: var(--text-2);
  font-size: 11px;
  font-weight: 500;
  cursor: pointer;
  white-space: nowrap;
  transition: all 0.15s;
  flex-shrink: 0;
}
.btn-logout:hover {
  background: #fee2e2;
  border-color: #fca5a5;
  color: #dc2626;
}
[data-theme="dark"] .btn-logout:hover {
  background: rgba(220,38,38,.15);
  border-color: rgba(220,38,38,.4);
  color: #f87171;
}
/* 구버전 user-card/user-avatar 호환 */
.user-name { font-size: 12px; font-weight: 500; color: var(--text-1); }
.user-role { font-size: 10px; color: var(--text-3); }

/* ============== MAIN ============== */
.main {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;      /* content 영역 외부로 스크롤 불가 */
  min-width: 0;
  min-height: 0;
}

.topbar {
  height: var(--topbar-h);
  background: #FFF;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 24px;
  flex-shrink: 0;
  /* topbar는 flex flow 안에서 고정 — content가 어떻게 스크롤되어도 절대 겹치지 않음
     position: relative + z-index로 stacking context 생성해 content보다 위에 렌더링 */
  position: relative;
  z-index: 100;
}
.topbar-left {
  display: flex;
  align-items: center;
  gap: 12px;
}
.page-title {
  font-size: 16px;
  font-weight: 600;
  color: var(--text-1);
}
.page-breadcrumb {
  font-size: 12px;
  color: var(--text-3);
  padding-left: 12px;
  border-left: 1px solid var(--border);
}
.topbar-right {
  display: flex;
  align-items: center;
  gap: 8px;
}
.topbar-date {
  font-size: 12px;
  color: var(--text-3);
  margin-right: 8px;
}
.icon-btn {
  width: 32px; height: 32px;
  border: 1px solid var(--border);
  background: #FFF;
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  color: var(--text-2);
  transition: all 0.12s;
}
.icon-btn:hover {
  background: var(--surface-3);
  color: var(--text-1);
}
.icon-btn svg { width: 16px; height: 16px; }
.badge-dot {
  position: absolute;
  top: 6px; right: 6px;
  width: 6px; height: 6px;
  background: var(--oci-red);
  border-radius: 50%;
}

/* ============== CONTENT ============== */
.content {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 0 24px 20px;  /* ★ 상단 padding 제거 — filter-bar가 top:0에서 sticky 되려면
                             negative margin-top 없애야 하고, 그러면 padding-top도 0이어야 함
                             padding-top이 있으면 filter-bar가 아래에서 sticky가 돼야 하는데
                             padding-top 안에서는 sticky가 작동 안 함 */
  min-height: 0;         /* flex-item 높이 축소 허용 → content 안에서만 스크롤 */
  position: relative;    /* stacking context 생성 */
  z-index: 1;            /* topbar(z-index:100) < content(z-index:1) 항상 topbar가 위 */
}

/* filter-bar 없는 페이지의 첫 번째 자식에 상단 여백 보충 */
.content > :not(.filter-bar):first-child {
  margin-top: 20px;
}
.loading {
  text-align: center;
  padding: 80px 0;
  color: var(--text-3);
  font-size: 13px;
}

/* ============== BUTTONS ============== */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 7px 14px;
  border: none;
  border-radius: var(--radius);
  font-size: 12px;
  font-weight: 500;
  transition: all 0.12s;
  cursor: pointer;
  white-space: nowrap;
}
.btn-primary {
  background: var(--oci-red);
  color: #FFF;
}
.btn-primary:hover { background: var(--oci-red-dark); }
.btn-ghost {
  background: #FFF;
  color: var(--text-2);
  border: 1px solid var(--border-2);
}
.btn-ghost:hover {
  background: var(--surface-3);
  color: var(--text-1);
}
.btn-danger {
  background: var(--red-light);
  color: var(--red);
  border: 1px solid var(--red);
}
.btn-danger:hover {
  background: var(--red);
  color: #FFF;
}
.btn-sm { padding: 4px 10px; font-size: 11px; }
.btn-lg { padding: 10px 18px; font-size: 13px; }

/* ============== METRIC CARDS ============== */
.metrics-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  margin-bottom: 16px;
}
.metric-card {
  background: #FFF;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 14px 16px;
  position: relative;
  overflow: hidden;
}
.metric-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--metric-color, var(--oci-red));
}
.metric-label {
  font-size: 11px;
  color: var(--text-3);
  margin-bottom: 4px;
}
.metric-value {
  font-size: 22px;
  font-weight: 700;
  color: var(--text-1);
  line-height: 1.1;
}
.metric-value-suffix {
  font-size: 13px;
  color: var(--text-3);
  font-weight: 400;
  margin-left: 2px;
}
.metric-sub {
  font-size: 11px;
  color: var(--text-3);
  margin-top: 4px;
}
.metric-change {
  font-size: 11px;
  font-weight: 500;
}
.metric-change.up { color: var(--green); }
.metric-change.dn { color: var(--red); }

/* ============== CARDS ============== */
.card {
  background: #FFF;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.card-header {
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: #FFF;
}
.card-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-1);
}
.card-body { padding: 16px; }
.card-body.no-pad { padding: 0; }

.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; }
.grid-65 { display: grid; grid-template-columns: 2fr 1fr; gap: 12px; }

/* ============== TABLE ============== */
.data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}
.data-table th {
  background: var(--surface-2);
  text-align: left;
  font-size: 11px;
  font-weight: 600;
  color: var(--text-3);
  padding: 9px 12px;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
  letter-spacing: 0.2px;
}
.data-table td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
  color: var(--text-1);
  vertical-align: middle;
}
.data-table tr:last-child td { border-bottom: none; }
.data-table tr:hover td { background: var(--surface-2); }
.data-table tr.clickable { cursor: pointer; }

.mono { font-family: 'IBM Plex Mono', monospace; }

/* ============== BADGES ============== */
.badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 500;
  white-space: nowrap;
}
.badge-blue { background: var(--blue-light); color: var(--blue); }
.badge-amber { background: var(--amber-light); color: #B87200; }
.badge-green { background: var(--green-light); color: #0F7A3F; }
.badge-red { background: var(--red-light); color: var(--red); }
.badge-purple { background: var(--purple-light); color: var(--purple); }
.badge-gray { background: var(--gray-light); color: var(--gray); }

/* ============== FILTER BAR ============== */
.filter-bar {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;

  /* sticky — .content(overflow-y:auto) 안에서 상단 고정
     ★ 핵심: margin-top 음수값 제거. 음수 margin-top이 있으면 margin edge가
        border edge(실제 화면 상단)보다 아래에 있어 sticky top:0이 오작동함.
        (margin edge가 0에 걸릴 때 border edge는 이미 뷰포트 위로 숨어버림)
     .content { padding-top: 0 }으로 맞추고 filter-bar가 y=0에서 시작하게 함 */
  position: sticky;
  top: 0;
  z-index: 10;
  background: var(--bg);
  margin: 0 -24px 14px;  /* ★ 음수 top margin 제거 — 좌우만 -24px 유지 */
  padding: 20px 24px 14px; /* 상단 padding 20px로 content padding-top 보충 */
  border-bottom: 1px solid transparent;
  transition: border-color 0.15s, box-shadow 0.15s;
}
/* 스크롤 후 밀착되면 구분선 + 그림자 */
.filter-bar.is-stuck {
  border-bottom-color: var(--border);
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
[data-theme="dark"] .filter-bar.is-stuck {
  box-shadow: 0 2px 8px rgba(0,0,0,.25);
}
.search-input {
  padding: 7px 12px 7px 32px;
  border: 1px solid var(--border-2);
  border-radius: var(--radius);
  font-size: 12px;
  background: #FFF url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%23a0a0a0'%3E%3Cpath fill-rule='evenodd' d='M8 4a4 4 0 100 8 4 4 0 000-8zM2 8a6 6 0 1110.89 3.476l4.817 4.817a1 1 0 01-1.414 1.414l-4.816-4.816A6 6 0 012 8z' clip-rule='evenodd'/%3E%3C/svg%3E") no-repeat 10px center;
  background-size: 14px;
  color: var(--text-1);
  width: 240px;
  outline: none;
  transition: border-color 0.12s;
}
.search-input:focus { border-color: var(--oci-red); }
.filter-select {
  padding: 7px 26px 7px 10px;
  border: 1px solid var(--border-2);
  border-radius: var(--radius);
  font-size: 12px;
  background: #FFF url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%23a0a0a0'%3E%3Cpath fill-rule='evenodd' d='M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z' clip-rule='evenodd'/%3E%3C/svg%3E") no-repeat right 8px center;
  background-size: 12px;
  color: var(--text-2);
  outline: none;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
}
.filter-select:focus { border-color: var(--oci-red); }
.filter-bar > .btn { margin-left: auto; }

/* ── 파이프라인 기간 필터 바 ────────────────────────────────── */
.pipe-date-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  padding: 8px 14px;
  margin-bottom: 12px;
  background: var(--bg-2, #f8f9fa);
  border: 1px solid var(--border-2);
  border-radius: var(--radius);
  transition: border-color .15s, background .15s;
}
.pipe-date-bar.active {
  border-color: var(--oci-blue, #1a73e8);
  background: rgba(26,115,232,.04);
}
[data-theme="dark"] .pipe-date-bar {
  background: #0e0e1e;
  border-color: #2a2a4a;
}
[data-theme="dark"] .pipe-date-bar.active {
  border-color: #3a6fd8;
  background: rgba(58,111,216,.08);
}
.pipe-date-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-3, #6b7280);
  white-space: nowrap;
  letter-spacing: .2px;
}
/* 기준 토글 버튼 그룹 */
.pipe-date-mode-wrap {
  display: flex;
  border: 1px solid var(--border-2);
  border-radius: 6px;
  overflow: hidden;
}
.pipe-date-mode-btn {
  padding: 5px 12px;
  font-size: 11px;
  font-weight: 500;
  border: none;
  background: transparent;
  color: var(--text-3, #6b7280);
  cursor: pointer;
  transition: background .12s, color .12s;
  white-space: nowrap;
}
.pipe-date-mode-btn + .pipe-date-mode-btn {
  border-left: 1px solid var(--border-2);
}
.pipe-date-mode-btn.active {
  background: var(--oci-blue, #1a73e8);
  color: #fff;
}
.pipe-date-mode-btn:not(.active):hover {
  background: var(--bg-hover, rgba(0,0,0,.05));
}
/* 날짜 범위 입력 */
.pipe-date-range {
  display: flex;
  align-items: center;
  gap: 4px;
}
.pipe-date-input {
  padding: 5px 8px;
  font-size: 12px;
  border: 1px solid var(--border-2);
  border-radius: 6px;
  background: var(--bg);
  color: var(--text-1);
  outline: none;
  transition: border-color .12s;
  width: 130px;
}
.pipe-date-input:focus { border-color: var(--oci-blue, #1a73e8); }
[data-theme="dark"] .pipe-date-input {
  background: #13132a;
  border-color: #2a2a4a;
  color: #d0d0e8;
  color-scheme: dark;
}
.pipe-date-sep {
  font-size: 12px;
  color: var(--text-3, #9ca3af);
  padding: 0 2px;
}
.pipe-date-clear-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 1px solid var(--border-2);
  background: transparent;
  color: var(--text-3, #9ca3af);
  font-size: 11px;
  cursor: pointer;
  transition: background .12s, color .12s, border-color .12s;
}
.pipe-date-clear-btn:hover {
  background: #fee2e2;
  border-color: #f87171;
  color: #dc2626;
}
[data-theme="dark"] .pipe-date-clear-btn:hover {
  background: rgba(220,38,38,.15);
  border-color: #dc2626;
  color: #f87171;
}
/* 필터 적용 힌트 텍스트 */
.pipe-date-hint {
  font-size: 10.5px;
  color: var(--oci-blue, #1a73e8);
  font-weight: 500;
  display: none;
}

/* 날짜 range 그룹 */
.filter-date-group {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-wrap: nowrap;
}
.filter-date {
  padding: 6px 8px;
  border: 1px solid var(--border-2);
  border-radius: var(--radius);
  font-size: 12px;
  color: var(--text-2);
  background: var(--surface-1);
  outline: none;
  width: 130px;
}
.filter-date:focus { border-color: var(--oci-red); }

/* 활성 필터 칩 */
.filter-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  background: var(--blue-light);
  color: var(--blue);
  border-radius: 999px;
  font-size: 11px;
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.15s;
}
.filter-chip:hover { background: #dbeafe; }
.filter-chip strong { font-weight: 600; }

/* 다크모드 */
[data-theme="dark"] .filter-date {
  background: var(--surface-2);
  color: var(--text-1);
  border-color: var(--border-2);
  color-scheme: dark;
}
[data-theme="dark"] .filter-chip {
  background: rgba(59,130,246,.2);
  color: #93c5fd;
}

/* ============== KANBAN ============== */
.kanban-board {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 8px;
}
.kanban-col {
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  min-height: 500px;
  display: flex;
  flex-direction: column;
}
.kanban-col-header {
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 3px solid var(--col-color, var(--oci-red));
  border-radius: var(--radius) var(--radius) 0 0;
}
.kanban-col-title { font-size: 11px; font-weight: 600; color: var(--text-2); }
.kanban-count {
  font-size: 10px;
  font-weight: 600;
  background: #FFF;
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 1px 7px;
  color: var(--text-3);
}
.kanban-cards {
  flex: 1;
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  overflow-y: auto;
}
.kanban-card {
  background: #FFF;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 10px;
  cursor: pointer;
  border-left: 3px solid var(--card-accent, var(--oci-red));
  transition: all 0.12s;
}
.kanban-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}
.kanban-card.dragging {
  opacity: 0.5;
  cursor: grabbing;
}
.kc-company { font-size: 12px; font-weight: 600; color: var(--text-1); margin-bottom: 3px; }
.kc-project { font-size: 11px; color: var(--text-2); margin-bottom: 6px; line-height: 1.4; }
.kc-meta { display: flex; align-items: center; justify-content: space-between; }
.kc-amount {
  font-size: 11px;
  font-weight: 600;
  font-family: 'IBM Plex Mono', monospace;
  color: var(--text-1);
}
.kc-date { font-size: 10px; color: var(--text-3); }
.kc-tags { display: flex; gap: 4px; flex-wrap: wrap; margin-top: 5px; }
.kc-tag {
  font-size: 9px;
  padding: 1px 5px;
  border-radius: 3px;
  background: var(--surface-2);
  color: var(--text-3);
  border: 1px solid var(--border);
}
.kc-tag.urgent { background: #FFF8E0; color: #B87200; border-color: #F5D070; }

/* ============== PROGRESS / FUNNEL ============== */
.progress-bar {
  background: var(--border);
  border-radius: 4px;
  height: 6px;
  overflow: hidden;
}
.progress-fill {
  height: 100%;
  background: var(--oci-red);
  transition: width 0.4s;
}

/* ============== INSIGHT / ACTIVITY ============== */
.insight-item {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 11px 16px;
  border-bottom: 1px solid var(--border);
}
.insight-item:last-child { border-bottom: none; }
.insight-icon {
  width: 28px; height: 28px;
  border-radius: var(--radius);
  display: flex; align-items: center; justify-content: center;
  font-size: 13px;
  flex-shrink: 0;
}
.insight-text { flex: 1; font-size: 11px; color: var(--text-2); line-height: 1.5; }
.insight-title { font-weight: 600; color: var(--text-1); font-size: 12px; margin-bottom: 2px; }

/* ============== TABS ============== */
.tab-bar {
  display: flex;
  gap: 2px;
  background: var(--surface-2);
  border-radius: 8px;
  padding: 3px;
  margin-bottom: 16px;
  border: 1px solid var(--border);
  width: fit-content;
}
.tab-btn {
  padding: 6px 14px;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 500;
  border: none;
  background: transparent;
  color: var(--text-3);
  cursor: pointer;
}
.tab-btn.active {
  background: #FFF;
  color: var(--text-1);
  box-shadow: var(--shadow);
}

/* ============================================================
   MODAL — 전면 재설계 (세련된 UX)
   ============================================================ */
.modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(10, 10, 20, 0.55);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: 1000;
  align-items: center;
  justify-content: center;
  padding: 24px 16px;
}
.modal-overlay.active {
  display: flex;
  animation: modalBgIn 0.2s ease both;
}
@keyframes modalBgIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.modal {
  background: var(--surface, #fff);
  border-radius: 16px;
  width: 100%;
  max-width: 560px;
  max-height: 88vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow:
    0 0 0 1px rgba(0,0,0,.06),
    0 8px 24px rgba(0,0,0,.12),
    0 24px 48px rgba(0,0,0,.10);
  animation: modalSlideIn 0.22s cubic-bezier(0.34, 1.2, 0.64, 1) both;
}
@keyframes modalSlideIn {
  from { transform: translateY(24px) scale(0.97); opacity: 0; }
  to   { transform: translateY(0) scale(1); opacity: 1; }
}

/* 헤더 — 좌측 컬러 액센트 바 */
.modal-header {
  padding: 20px 24px 18px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  position: relative;
  background: linear-gradient(135deg, var(--surface) 0%, color-mix(in srgb, var(--oci-red) 4%, var(--surface)) 100%);
}
.modal-header::before {
  content: '';
  position: absolute;
  left: 0; top: 16px; bottom: 16px;
  width: 3px;
  background: var(--oci-red);
  border-radius: 0 3px 3px 0;
}
.modal-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-1);
  line-height: 1.4;
  flex: 1;
}
.modal-close {
  width: 32px; height: 32px;
  border-radius: 50%;
  border: none;
  background: transparent;
  color: var(--text-3);
  font-size: 20px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: background 0.15s, color 0.15s, transform 0.15s;
  line-height: 1;
}
.modal-close:hover {
  background: rgba(230, 57, 70, 0.1);
  color: var(--oci-red);
  transform: rotate(90deg);
}

/* 바디 */
.modal-body {
  padding: 24px;
  overflow-y: auto;
  flex: 1;
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
}
.modal-body::-webkit-scrollbar { width: 5px; }
.modal-body::-webkit-scrollbar-track { background: transparent; }
.modal-body::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }

/* 푸터 */
.modal-footer {
  padding: 16px 24px;
  border-top: 1px solid var(--border);
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  align-items: center;
  background: var(--surface-2);
}
.modal-footer .btn-ghost:first-child:not(:last-child) {
  margin-right: auto;
}

/* ============================================================
   FORM — 통합 디자인 시스템 (모든 모달에서 공유)
   ============================================================ */
.form-grid {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.form-row {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;       /* grid 안에서 input이 컨테이너를 넘치지 않도록 */
}
.form-row-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  align-items: start;
}
.form-row-3 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 14px;
  align-items: start;
}
.form-row .full,
.form-grid .full { grid-column: 1 / -1; }

.form-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-2);
  letter-spacing: 0.2px;
  text-transform: none;
  display: block;
  line-height: 1.3;
}
.form-label.required::after { content: ' *'; color: var(--oci-red); font-weight: 700; }

.form-input,
.form-control {
  width: 100%;
  height: 38px;
  padding: 0 12px;
  font-size: 13px;
  font-family: inherit;
  border: 1px solid var(--border-2);
  border-radius: 6px;
  background: #fff;
  color: var(--text-1);
  outline: none;
  box-sizing: border-box;
  transition: border-color 0.12s, box-shadow 0.12s;
  appearance: none;
  -webkit-appearance: none;
}
.form-input:hover,
.form-control:hover { border-color: var(--text-3); }
.form-input:focus,
.form-control:focus {
  border-color: var(--oci-red);
  box-shadow: 0 0 0 3px rgba(230, 57, 70, 0.12);
}
.form-input::placeholder,
.form-control::placeholder { color: var(--text-4); }
.form-input[readonly],
.form-control[readonly] { background: var(--surface-2); color: var(--text-3); }

textarea.form-input,
textarea.form-control {
  height: auto;
  min-height: 80px;
  padding: 10px 12px;
  resize: vertical;
  line-height: 1.5;
}

/* SELECT — 화살표 아이콘 통일 */
select.form-input,
select.form-control {
  cursor: pointer;
  padding-right: 32px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%2386909C' d='M5 6L0 0h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
}

/* INPUT[type=color] / [type=date] / [type=datetime-local] 정렬 */
input[type="color"].form-input { padding: 3px; height: 38px; cursor: pointer; }
input[type="date"].form-input,
input[type="datetime-local"].form-input { padding-right: 8px; }

/* 체크박스 정렬 */
.form-check {
  display: flex;
  align-items: center;
  gap: 8px;
  height: 38px;
  font-size: 13px;
  color: var(--text-1);
  cursor: pointer;
  user-select: none;
}
.form-check input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--oci-red);
  cursor: pointer;
}

/* 인라인 그룹 (체크박스 + 색상 픽커 등) */
.form-inline {
  display: flex;
  align-items: center;
  gap: 10px;
  height: 38px;
}
.form-inline > input[type="color"] { width: 38px; height: 38px; padding: 3px; border: 1px solid var(--border-2); border-radius: 6px; cursor: pointer; }

/* 반응형 */
@media (max-width: 720px) {
  .form-row-2,
  .form-row-3 { grid-template-columns: 1fr; }
}

/* 섹션 구분선 */
.form-section-title {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 4px 0 8px;
  border-bottom: 1px solid var(--border);
  margin: 4px 0 12px;
}

/* KV 그리드 (상세보기) */
.kv-grid { display: flex; flex-direction: column; gap: 1px; }
.kv-row {
  display: flex;
  gap: 12px;
  padding: 9px 12px;
  border-radius: 8px;
  transition: background 0.1s;
}
.kv-row:hover { background: var(--surface-2); }
.kv-key {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-3);
  min-width: 80px;
  flex-shrink: 0;
}
.kv-val {
  font-size: 13px;
  color: var(--text-1);
  flex: 1;
  word-break: break-word;
}

/* 확인 모달 */
.confirm-icon {
  width: 52px; height: 52px;
  border-radius: 50%;
  background: rgba(230, 57, 70, 0.1);
  display: flex; align-items: center; justify-content: center;
  font-size: 24px;
  margin: 0 auto 16px;
}
.confirm-message {
  text-align: center;
  font-size: 14px;
  color: var(--text-2);
  line-height: 1.6;
  padding: 0 8px;
}

/* (구 .form-grid / .form-control 정의는 통합 form 시스템으로 대체됨) */
.form-field { display: flex; flex-direction: column; gap: 6px; min-width: 0; }

/* ============== TOAST ============== */
.toast-container {
  position: fixed;
  top: 70px;
  right: 24px;
  z-index: 2000;
  display: flex;
  flex-direction: column;
  gap: 8px;
  pointer-events: none;  /* 컨테이너 자체는 클릭 통과 */
}
.toast {
  pointer-events: auto;  /* 실제 토스트 메시지는 클릭 가능 */
  padding: 10px 14px;
  background: #FFF;
  border-left: 3px solid var(--oci-red);
  border-radius: var(--radius);
  box-shadow: var(--shadow-md);
  font-size: 12px;
  color: var(--text-1);
  min-width: 240px;
  animation: slideIn 0.2s;
}
.toast.success { border-color: var(--green); }
.toast.error   { border-color: var(--red); }
.toast.info    { border-color: var(--blue); }
/* 클릭 가능 토스트 */
.toast.toast-action {
  cursor: pointer;
  user-select: none;
}
.toast.toast-action:hover {
  filter: brightness(0.96);
  transform: translateX(-2px);
  transition: filter .1s, transform .1s;
}
.toast-action-hint {
  display: block;
  font-size: 10px;
  opacity: .6;
  margin-top: 2px;
}
@keyframes slideIn { from { transform: translateX(20px); opacity: 0; } to { transform: translateX(0); opacity: 1; } }

/* ============== CHART WRAP ============== */
.chart-wrap { position: relative; height: 220px; }

/* ============== COPY & PASTE (그리드 복붙) ============== */
/* 체크박스 컬럼 */
.cp-check-col { width: 36px !important; padding: 6px 8px !important; }
.cp-checkbox  { width: 15px; height: 15px; cursor: pointer; accent-color: var(--oci-blue, #1a73e8); }

/* 선택된 행 하이라이트 */
tr.cp-selected td { background: rgba(26,115,232,.06) !important; }
[data-theme="dark"] tr.cp-selected td { background: rgba(26,115,232,.12) !important; }

/* 복사/선택 툴바 */
.cp-toolbar {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 3px 6px;
  background: var(--oci-blue, #1a73e8);
  color: #fff;
  border-radius: 6px;
  font-size: 12px;
  animation: slideIn .15s ease;
}
.cp-toolbar .btn {
  background: rgba(255,255,255,.18);
  color: #fff;
  border: 1px solid rgba(255,255,255,.4);
  font-size: 11px;
  padding: 2px 10px;
  border-radius: 4px;
  transition: background .12s;
}
.cp-toolbar .btn:hover  { background: rgba(255,255,255,.32); }
.cp-toolbar .btn:active { background: rgba(255,255,255,.45); }
.cp-sel-count {
  font-weight: 600;
  white-space: nowrap;
  padding: 2px 6px;
}

/* 고객 모달 — 통계 미니 카드 */
.stat-mini {
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 8px 10px;
  text-align: center;
}

/* 고객 멤버 chip hover */
.cust-member-chip:hover {
  background: var(--oci-blue) !important;
  color: #fff !important;
  border-color: var(--oci-blue) !important;
  transition: all .12s;
}

/* 리드 모달 내 클릭 가능 링크 hover */
[data-cust-link]:hover,
[data-contact-link]:hover,
[data-assignee-link]:hover {
  text-decoration: underline !important;
  opacity: .85;
}

/* 칸반 카드 — KRW 환산 보조 표시 */
.kc-krw-sub {
  font-size: 10px;
  color: var(--text-3);
  margin-top: 3px;
  font-family: 'SF Mono', Consolas, monospace;
  font-weight: 500;
  opacity: 0.85;
}

/* 리드 폼 — KRW 환산 미리보기 */
.lf-krw-preview {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: -8px 0 16px;
  padding: 9px 14px;
  background: linear-gradient(135deg, rgba(22,100,229,.08) 0%, rgba(124,77,255,.05) 100%);
  border-left: 3px solid var(--oci-blue);
  border-radius: 6px;
  font-size: 12px;
}
.lf-krw-label { color: var(--text-3); font-weight: 500; }
.lf-krw-value {
  font-weight: 700;
  color: var(--text-1);
  font-feature-settings: 'tnum';
  flex: 1;
}
.lf-krw-rate {
  font-family: 'SF Mono', Consolas, monospace;
  font-size: 11px;
  color: var(--text-3);
}

/* ═══════════════════════════════════════════════════════════════
   파이프라인 헬스체크 — 세련된 cubic bezier 스트림
   ─────────────────────────────────────────────────────────────── */
.pipe-funnel-card {
  background: linear-gradient(180deg, #fbfcfe 0%, #ffffff 100%);
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 1px 3px rgba(0,0,0,.04), 0 8px 24px -12px rgba(0,0,0,.06);
}
.pipe-funnel-card .card-body { overflow: visible; }

.pipe-funnel-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 16px;
}
.pipe-funnel-title {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -0.2px;
  color: var(--text-1);
}
.pipe-funnel-subtitle {
  font-size: 11px;
  color: var(--text-3);
  margin-top: 2px;
}
.pipe-funnel-legend {
  display: flex;
  gap: 14px;
  font-size: 11px;
  color: var(--text-3);
}
.lgd-item { display: inline-flex; align-items: center; gap: 5px; }
.lgd-dot {
  display: inline-block;
  width: 7px; height: 7px;
  border-radius: 50%;
  box-shadow: 0 0 0 2px rgba(255,255,255,.9);
}

/* ── SVG 컨테이너 + 카드 오버레이 ───────────────────────────── */
.pf-wrap {
  position: relative;
  padding-top: 32px;  /* 전환율 캡슐 공간 */
  padding-bottom: 4px;
}
.pf-overlay {
  position: absolute;
  inset: 32px 0 4px 0;
  pointer-events: none;
}

.pf-stream { transition: opacity .2s; }
.pf-stream:hover { opacity: .92; }
.pf-hit:hover { fill: rgba(255,255,255,.04); }

/* ── 단계 카드 (SVG 위 오버레이) ─────────────────────────────── */
.pf-card {
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  pointer-events: auto;
  cursor: pointer;
  min-width: 88px;
  padding: 4px 8px;
  border-radius: 8px;
  transition: all .18s cubic-bezier(.4,0,.2,1);
  user-select: none;
}
.pf-card:hover {
  background: rgba(255,255,255,.7);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transform: translate(-50%, -50%) scale(1.06);
  box-shadow: 0 10px 30px -8px rgba(0,0,0,.18);
}
.pf-card-head {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin-bottom: 2px;
}
.pf-card-name {
  font-size: 11px;
  font-weight: 600;
  color: var(--accent);
  letter-spacing: -0.1px;
  text-shadow: 0 1px 2px rgba(255,255,255,.8);
}
.pf-card-health {
  display: inline-block;
  width: 7px; height: 7px;
  border-radius: 50%;
  box-shadow: 0 0 0 2px rgba(255,255,255,.85);
}
.pf-card-cnt {
  font-size: 30px;
  font-weight: 800;
  line-height: 1;
  color: rgba(20,30,50,.92);
  letter-spacing: -1px;
  text-shadow: 0 1px 2px rgba(255,255,255,.7);
  font-feature-settings: 'tnum';
}
.pf-card-sum {
  font-family: 'SF Mono', 'Consolas', monospace;
  font-size: 11px;
  color: rgba(20,30,50,.6);
  margin-top: 3px;
  letter-spacing: -0.3px;
}
.pf-card-age {
  font-size: 10px;
  color: rgba(20,30,50,.5);
  margin-top: 2px;
  font-weight: 500;
}

/* ── 전환율 캡슐 (단계 사이) ─────────────────────────────────── */
.pf-rate {
  position: absolute;
  top: -32px;
  transform: translateX(-50%);
  padding: 4px 12px 5px;
  background: #fff;
  border-radius: 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  min-width: 64px;
  box-shadow: 0 2px 8px rgba(0,0,0,.06), 0 0 0 1px var(--rate-clr, rgba(0,0,0,.1));
  transition: transform .15s;
  pointer-events: auto;
}
.pf-rate:hover { transform: translateX(-50%) translateY(-2px); }
.pf-rate-label {
  font-size: 9px;
  font-weight: 500;
  color: rgba(0,0,0,.5);
  letter-spacing: 0.4px;
  text-transform: uppercase;
  line-height: 1.2;
}
.pf-rate-pct {
  font-size: 14px;
  font-weight: 800;
  line-height: 1.1;
  letter-spacing: -0.3px;
  font-feature-settings: 'tnum';
}
.pf-rate-low   { --rate-clr: rgba(230,51,41,.4); }
.pf-rate-low   .pf-rate-pct { color: #E63329; }
.pf-rate-mid   { --rate-clr: rgba(245,156,0,.4); }
.pf-rate-mid   .pf-rate-pct { color: #B97500; }
.pf-rate-high  { --rate-clr: rgba(23,168,90,.4); }
.pf-rate-high  .pf-rate-pct { color: #0F7A3F; }
.pf-rate-super { --rate-clr: rgba(33,150,243,.5); background: linear-gradient(135deg, #fff 0%, #E3F2FD 100%); }
.pf-rate-super .pf-rate-pct { color: #1565C0; }

/* ── 결과 (수주/드롭) — 세련된 디자인 ───────────────────────── */
.pf-result {
  display: flex;
  gap: 12px;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(0,0,0,.06);
}
.pf-result-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 16px;
  border-radius: 10px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--clr) 8%, transparent) 0%, transparent 100%);
  border: 1px solid color-mix(in srgb, var(--clr) 20%, transparent);
  flex: 1;
  transition: transform .15s, box-shadow .15s;
}
.pf-result-item:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 16px -6px color-mix(in srgb, var(--clr) 30%, transparent);
}
.pf-result-icon {
  font-size: 20px;
  filter: drop-shadow(0 2px 3px rgba(0,0,0,.1));
}
.pf-result-text { flex: 1; }
.pf-result-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--clr);
  letter-spacing: -0.1px;
}
.pf-result-meta {
  font-size: 13px;
  color: var(--text-1);
  margin-top: 2px;
}
.pf-result-meta strong {
  font-weight: 800;
  font-feature-settings: 'tnum';
}

/* ── 다크 테마 ──────────────────────────────────────────────── */
[data-theme="dark"] .pipe-funnel-card {
  background: linear-gradient(180deg, #1a1d23 0%, #14171c 100%);
  border-color: rgba(255,255,255,.06);
}
[data-theme="dark"] .pf-card-cnt   { color: rgba(255,255,255,.95); text-shadow: 0 1px 2px rgba(0,0,0,.6); }
[data-theme="dark"] .pf-card-sum   { color: rgba(255,255,255,.65); }
[data-theme="dark"] .pf-card-age   { color: rgba(255,255,255,.5); }
[data-theme="dark"] .pf-card-name  { text-shadow: 0 1px 2px rgba(0,0,0,.6); }
[data-theme="dark"] .pf-card-health { box-shadow: 0 0 0 2px rgba(0,0,0,.6); }
[data-theme="dark"] .pf-card:hover { background: rgba(255,255,255,.06); }
[data-theme="dark"] .pf-rate       { background: #25282e; }
[data-theme="dark"] .pf-rate-label { color: rgba(255,255,255,.55); }
[data-theme="dark"] .pf-rate-super { background: linear-gradient(135deg, #25282e 0%, #1e3a5f 100%); }
[data-theme="dark"] .pf-result-item { background: rgba(255,255,255,.03); }
[data-theme="dark"] .pf-result      { border-top-color: rgba(255,255,255,.08); }

/* ═══════════════════════════════════════════════════════════════
   AI 단계 헬스 코칭 모달 (stage-coach)
   ─────────────────────────────────────────────────────────────── */
.stage-coach { font-size: 13px; line-height: 1.6; }

.sc-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: rgba(0,0,0,.06);
  padding: 1px;
  border-radius: 8px;
  margin-bottom: 16px;
  overflow: hidden;
}
.sc-stat {
  background: var(--surface);
  padding: 10px 12px;
  text-align: left;
}
.sc-stat-label {
  font-size: 10px;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: 0.3px;
  font-weight: 500;
  margin-bottom: 4px;
}
.sc-stat-val {
  font-size: 18px;
  font-weight: 700;
  color: var(--text-1);
  font-feature-settings: 'tnum';
}

.sc-status {
  padding: 14px 16px;
  border-radius: 8px;
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.sc-status-badge {
  padding: 4px 12px;
  border-radius: 12px;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.3px;
  white-space: nowrap;
}
.sc-headline {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-1);
  line-height: 1.4;
}

.sc-section {
  background: var(--surface-2);
  padding: 12px 14px;
  border-radius: 8px;
  margin-bottom: 10px;
}
.sc-section-warn   { background: rgba(245,156,0,.06); }
.sc-section-urgent { background: rgba(230,51,41,.06); border-left: 3px solid #E63329; }
.sc-section-action { background: rgba(22,100,229,.06); border-left: 3px solid var(--oci-blue); }
.sc-section-title {
  font-size: 12px;
  font-weight: 700;
  margin-bottom: 6px;
  color: var(--text-1);
}
.sc-list {
  margin: 0;
  padding-left: 22px;
  font-size: 12.5px;
  color: var(--text-2);
}
.sc-list li { margin-bottom: 3px; line-height: 1.55; }

.sc-spinner {
  width: 16px; height: 16px;
  border: 2px solid rgba(0,0,0,.1);
  border-top-color: var(--oci-blue);
  border-radius: 50%;
  animation: sc-spin 0.8s linear infinite;
}
@keyframes sc-spin { to { transform: rotate(360deg); } }

[data-theme="dark"] .sc-stats { background: rgba(255,255,255,.08); }
[data-theme="dark"] .sc-stat  { background: var(--surface); }
[data-theme="dark"] .sc-section-warn   { background: rgba(245,156,0,.1); }
[data-theme="dark"] .sc-section-urgent { background: rgba(230,51,41,.1); }
[data-theme="dark"] .sc-section-action { background: rgba(22,100,229,.1); }

/* 붙여넣기 textarea */
.cp-paste-textarea {
  width: 100%;
  box-sizing: border-box;
  padding: 10px 12px;
  font-size: 12px;
  font-family: var(--font-mono, monospace);
  border: 1.5px solid var(--border);
  border-radius: 6px;
  background: var(--surface-1);
  color: var(--text-1);
  resize: vertical;
  outline: none;
  transition: border-color .15s;
}
.cp-paste-textarea:focus { border-color: var(--oci-blue, #1a73e8); }

/* 미리보기 경고 행 */
tr.cp-row-warn td { background: rgba(230,51,41,.05) !important; }

/* ============== AI 브리핑 완료 배지 ============== */
.brief-done-badge {
  display: inline-flex; align-items: center; gap: 3px;
  font-size: 11px; font-weight: 500;
  border-radius: 10px; padding: 2px 8px; white-space: nowrap;
  border: 1px solid; line-height: 1.5;
  transition: opacity .2s;
}
.brief-badge-fresh {
  color: #1565c0; background: #e3f2fd; border-color: #90caf9;
}
.brief-badge-today {
  color: #2e7d32; background: #e8f5e9; border-color: #a5d6a7;
}
.brief-badge-old {
  color: #6a737d; background: var(--surface-2); border-color: var(--border);
}
/* 카드 뷰 - 버튼 위 한 줄 상태 표시 */
.brief-done-chip {
  font-size: 11px; font-weight: 500; text-align: center;
  padding: 3px 0 5px; color: #2e7d32;
  border-bottom: 1px dashed var(--border); margin-bottom: 6px;
}
[data-theme="dark"] .brief-badge-fresh { color:#90caf9; background:rgba(33,150,243,.12); border-color:#1565c0; }
[data-theme="dark"] .brief-badge-today { color:#81c784; background:rgba(76,175,80,.12);  border-color:#2e7d32; }
[data-theme="dark"] .brief-done-chip   { color:#81c784; }

/* ============== FUNNEL ============== */
.funnel-row {
  margin-bottom: 10px;
}
.funnel-label {
  display: flex;
  justify-content: space-between;
  margin-bottom: 4px;
  font-size: 12px;
  color: var(--text-2);
}
.funnel-label strong { color: var(--text-1); font-weight: 600; }

/* ============== EMPTY STATE ============== */
.empty {
  text-align: center;
  padding: 60px 20px;
  color: var(--text-3);
  font-size: 13px;
}
.empty-icon {
  font-size: 32px;
  opacity: 0.4;
  margin-bottom: 12px;
}

/* ============== SCROLLBAR ============== */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border-2); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--text-4); }

/* ============== UTILITIES ============== */
.flex { display: flex; }
.flex-1 { flex: 1; }
.flex-between { display: flex; justify-content: space-between; align-items: center; }
.gap-1 { gap: 4px; } .gap-2 { gap: 8px; } .gap-3 { gap: 12px; } .gap-4 { gap: 16px; }
.mb-1 { margin-bottom: 8px; } .mb-2 { margin-bottom: 12px; } .mb-3 { margin-bottom: 16px; } .mb-4 { margin-bottom: 20px; }
.mt-1 { margin-top: 8px; } .mt-2 { margin-top: 12px; } .mt-3 { margin-top: 16px; } .mt-4 { margin-top: 20px; }
.text-right { text-align: right; }
.text-center { text-align: center; }
.text-success { color: var(--green); }
.text-danger { color: var(--red); }
.text-warning { color: var(--amber); }
.text-muted { color: var(--text-3); }
.fw-bold { font-weight: 600; }
.fs-11 { font-size: 11px; } .fs-12 { font-size: 12px; } .fs-13 { font-size: 13px; }

/* ============== TEAM PAGE ============== */
.team-member-list { display: flex; flex-direction: column; gap: 8px; }
.member-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px; border-radius: 6px;
}
.member-row:hover { background: var(--bg-2); }
.member-avatar {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--text-3); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-weight: 600; font-size: 13px;
}
.member-avatar.sm { width: 26px; height: 26px; font-size: 11px; }
.member-info { flex: 1; min-width: 0; }
.member-name { font-size: 13px; font-weight: 500; color: var(--text-1); }
.member-role { font-size: 11px; color: var(--text-3); margin-top: 1px; }
.ai-center { align-items: center; }

/* ============== REPORTS - FUNNEL ============== */
.funnel-row {
  display: flex; align-items: center; gap: 10px;
  padding: 6px 0;
}
.funnel-label {
  width: 100px; font-size: 12px; color: var(--text-2); flex-shrink: 0;
}
.funnel-bar-wrap {
  flex: 1; height: 22px; background: var(--bg-2); border-radius: 4px; overflow: hidden;
}
.funnel-bar {
  height: 100%; border-radius: 4px;
  transition: width 0.4s ease;
}
.funnel-count {
  width: 50px; text-align: right; font-size: 12px;
  font-weight: 600; color: var(--text-1); flex-shrink: 0;
  font-family: 'IBM Plex Mono', monospace;
}

.progress-bar {
  width: 100%; height: 6px; background: var(--bg-2);
  border-radius: 3px; margin-top: 8px; overflow: hidden;
}
.progress-fill {
  height: 100%; background: var(--red);
  border-radius: 3px; transition: width 0.4s;
}

/* ============== SETTINGS - INTEGRATION ============== */
.integration-card {
  border: 1px solid var(--border-1);
  border-radius: 8px;
  padding: 16px;
  background: var(--bg-1);
}
.integration-header {
  display: flex; justify-content: space-between; align-items: flex-start;
  margin-bottom: 12px;
}
.integration-name {
  font-size: 15px; font-weight: 600; color: var(--text-1);
}
.integration-desc {
  font-size: 12px; color: var(--text-3); margin-top: 2px;
}
.integration-body { margin: 12px 0; }

.kv-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px 24px;
}
.kv-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 6px 0;
  border-bottom: 1px dashed var(--border-1);
  font-size: 12px;
}
.kv-row:last-child { border-bottom: none; }
.kv-key { color: var(--text-3); }
.kv-val { color: var(--text-1); font-weight: 500; }

.setting-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 0;
  border-bottom: 1px solid var(--border-1);
}
.setting-row:last-child { border-bottom: none; }
.setting-name {
  font-size: 13px; font-weight: 500; color: var(--text-1);
}
.setting-desc {
  font-size: 11px; color: var(--text-3); margin-top: 2px;
}

.switch {
  position: relative; display: inline-block;
  width: 38px; height: 22px; flex-shrink: 0;
}
.switch input { opacity: 0; width: 0; height: 0; }
.slider {
  position: absolute; cursor: pointer;
  top: 0; left: 0; right: 0; bottom: 0;
  background-color: var(--border-2);
  transition: .3s; border-radius: 22px;
}
.slider:before {
  position: absolute; content: "";
  height: 16px; width: 16px;
  left: 3px; bottom: 3px;
  background-color: white;
  transition: .3s; border-radius: 50%;
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
}
.switch input:checked + .slider { background-color: var(--red); }
.switch input:checked + .slider:before { transform: translateX(16px); }

.db-stat {
  text-align: center; padding: 16px;
  border: 1px solid var(--border-1); border-radius: 8px;
}
.db-stat-label { font-size: 12px; color: var(--text-3); }
.db-stat-value {
  font-size: 28px; font-weight: 700; color: var(--text-1);
  margin-top: 4px;
}

.alert {
  padding: 10px 14px; border-radius: 6px;
  font-size: 12px; line-height: 1.5;
}
.alert-success { background: #E6F8EE; color: #0F7A3F; border: 1px solid #B5E5C8; }
.alert-error { background: #FDECEC; color: #B82424; border: 1px solid #F5BABA; }
.alert-info { background: #EAF1FE; color: #2357E8; border: 1px solid #B9CDFB; }

/* ============== LEAD DETAIL MODAL ============== */
.detail-header {
  display: flex; justify-content: space-between; align-items: flex-start;
  padding-bottom: 12px; margin-bottom: 16px;
  border-bottom: 1px solid var(--border-1);
}
.detail-stage { display: flex; gap: 6px; flex-wrap: wrap; }
.detail-amount { text-align: right; }
.amount-big {
  font-size: 22px; font-weight: 700;
  color: var(--text-1); margin-top: 2px;
  font-family: 'IBM Plex Mono', monospace;
}

.activity-list {
  display: flex; flex-direction: column;
}
.activity-item {
  display: flex; gap: 12px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border-1);
  transition: background 0.12s;
}
.activity-item:last-child { border-bottom: none; }
.activity-item.has-calendar:hover {
  background: var(--bg-2);
}
.activity-cal-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 500;
  color: #1a73e8;
  background: #e8f0fe;
  border-radius: 4px;
  padding: 1px 6px;
  margin-left: 6px;
  vertical-align: middle;
  cursor: pointer;
}
.activity-icon {
  width: 28px; height: 28px;
  border-radius: 50%; background: var(--bg-2);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; font-size: 14px;
}
.activity-body { flex: 1; min-width: 0; }
.activity-title {
  font-size: 13px; font-weight: 500; color: var(--text-1);
}
.activity-content {
  font-size: 12px; color: var(--text-2);
  margin-top: 4px; line-height: 1.5;
  white-space: pre-line;
}
.activity-meta {
  font-size: 11px; color: var(--text-3); margin-top: 6px;
}

/* (구 .form-row-2 / .form-row-3 정의는 통합 form 시스템으로 대체됨) */
.grid-3 {
  display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px;
}
@media (max-width: 1100px) {
  .grid-3 { grid-template-columns: 1fr 1fr; }
  .form-row-3 { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 720px) {
  .grid-3, .grid-2, .grid-65 { grid-template-columns: 1fr; }
  .kv-grid { grid-template-columns: 1fr; }
}

/* ============== BADGE - RED ============== */
.badge-red {
  background: #FDECEC; color: #B82424;
}

/* 알림 배지 펄스 애니메이션 */
@keyframes notif-pulse {
  0%   { transform: scale(1);   box-shadow: 0 0 0 0 rgba(184,36,36,.5); }
  50%  { transform: scale(1.25); box-shadow: 0 0 0 6px rgba(184,36,36,0); }
  100% { transform: scale(1);   box-shadow: 0 0 0 0 rgba(184,36,36,0); }
}
.pulse-anim {
  animation: notif-pulse 0.6s ease-out 2;
}

/* ============================================================
   AI 어시스턴트 패널
   ============================================================ */
.btn-ai {
  background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
  color: #E8D5FF;
  border: 1px solid #3d2b6e;
  font-size: 12px;
  gap: 6px;
  padding: 6px 12px;
  border-radius: var(--radius);
  transition: all 0.15s;
}
.btn-ai:hover {
  background: linear-gradient(135deg, #16213e 0%, #0f3460 100%);
  color: #fff;
  box-shadow: 0 0 0 3px rgba(124,77,255,0.15);
}
.ai-badge {
  background: linear-gradient(135deg, #7C4DFF, #5c35cc);
  color: #fff !important;
  font-size: 9px;
  padding: 1px 5px;
}
.nav-badge.ai-badge { font-weight: 700; letter-spacing: 0.3px; }

/* 오버레이 */
.ai-overlay {
  display: none;
  position: fixed; inset: 0; z-index: 1090;
  background: rgba(0,0,0,0.18);
}
.ai-overlay.show { display: block; }

/* 슬라이드 패널 */
.ai-panel {
  position: fixed;
  top: 0; right: 0; bottom: 0;
  width: 420px;
  background: #0d0d1a;
  border-left: 1px solid #1e1e3a;
  z-index: 1100;
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.28s cubic-bezier(.4,0,.2,1);
}
.ai-panel.open { transform: translateX(0); }

/* 패널 헤더 */
.ai-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  border-bottom: 1px solid #1e1e3a;
  background: #0a0a16;
  flex-shrink: 0;
}
.ai-panel-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 600;
  color: #E8D5FF;
}
.ai-status-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #4ade80;
  box-shadow: 0 0 6px #4ade8066;
  animation: pulse-green 2s infinite;
}
@keyframes pulse-green {
  0%, 100% { opacity: 1; } 50% { opacity: 0.5; }
}
.ai-panel-actions { display: flex; gap: 4px; }
.ai-icon-btn {
  width: 28px; height: 28px;
  border: 1px solid #1e1e3a;
  background: #161628;
  border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  color: #8888bb;
  cursor: pointer;
  transition: all 0.12s;
}
.ai-icon-btn:hover { background: #1e1e3a; color: #E8D5FF; }
.ai-icon-btn svg { width: 14px; height: 14px; }

/* 퀵 액션 */
.ai-quick-actions {
  display: flex;
  gap: 6px;
  padding: 10px 12px;
  border-bottom: 1px solid #1e1e3a;
  flex-wrap: wrap;
  flex-shrink: 0;
  background: #0a0a16;
}
.ai-quick-btn {
  padding: 5px 10px;
  border: 1px solid #2a2a4a;
  background: #161628;
  color: #9999cc;
  border-radius: 14px;
  font-size: 11px;
  cursor: pointer;
  transition: all 0.12s;
  white-space: nowrap;
}
.ai-quick-btn:hover {
  border-color: #7C4DFF;
  color: #E8D5FF;
  background: #1e1040;
}

/* 메시지 목록 */
.ai-message-list {
  flex: 1;
  overflow-y: auto;
  padding: 14px 12px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  scroll-behavior: smooth;
}
.ai-message-list::-webkit-scrollbar { width: 4px; }
.ai-message-list::-webkit-scrollbar-thumb { background: #2a2a4a; border-radius: 2px; }

/* 메시지 버블 */
.ai-msg { display: flex; gap: 8px; max-width: 100%; }
.ai-msg-user {
  margin-left: auto;
  background: linear-gradient(135deg, #7C4DFF, #5c35cc);
  color: #fff;
  padding: 9px 13px;
  border-radius: 14px 14px 2px 14px;
  font-size: 12px;
  line-height: 1.5;
  max-width: 85%;
  word-break: break-word;
}
.ai-msg-bot {
  align-items: flex-start;
  max-width: 100%;
}
.ai-bot-icon {
  width: 26px; height: 26px;
  border-radius: 8px;
  background: linear-gradient(135deg, #1a1040, #2d1b69);
  border: 1px solid #3d2b6e;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  margin-top: 2px;
}
.ai-bot-icon svg { width: 14px; height: 14px; color: #C4A0FF; }
.ai-msg-content {
  background: #13132a;
  border: 1px solid #1e1e3a;
  color: #d4d4f0;
  padding: 10px 13px;
  border-radius: 2px 14px 14px 14px;
  font-size: 12px;
  line-height: 1.6;
  word-break: break-word;
  flex: 1;
}
.ai-msg-content p { margin: 4px 0; }
.ai-msg-content ul { padding-left: 16px; margin: 4px 0; }
.ai-msg-content li { margin: 2px 0; }
.ai-msg-content h4.ai-h4 {
  font-size: 12px; font-weight: 700;
  color: #C4A0FF; margin: 10px 0 5px;
  border-bottom: 1px solid #2a2a4a;
  padding-bottom: 3px;
}
.ai-msg-content h5.ai-h5 {
  font-size: 11px; font-weight: 600;
  color: #9999cc; margin: 8px 0 4px;
}
.ai-msg-content strong { color: #E8D5FF; }
.ai-cursor {
  display: inline-block;
  color: #7C4DFF;
  animation: blink 0.8s step-end infinite;
  margin-left: 1px;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0} }

/* ── AI 보고서 다운로드 바 (파일 아이콘 스타일) ─────────────── */
.ai-dl-bar {
  margin: 10px 0 6px 44px;   /* 메시지 내용과 좌측 정렬 */
  padding: 0;
  background: transparent;
  border: none;
}
.ai-dl-label {
  font-size: 11px;
  color: #7c7caa;
  font-weight: 600;
  letter-spacing: .3px;
  margin-bottom: 8px;
  display: block;
}
.ai-dl-files {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: flex-start;
}
.ai-dl-file {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  width: 80px;
  padding: 10px 6px 8px;
  background: #14142a;
  border: 1px solid #2a2a4a;
  border-radius: 10px;
  cursor: pointer;
  transition: background .15s, border-color .15s, transform .12s, box-shadow .15s;
  text-align: center;
}
.ai-dl-file:hover:not(:disabled) {
  background: #1e1e3a;
  border-color: #5050b0;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(80,80,180,.25);
}
.ai-dl-file:active:not(:disabled) {
  transform: translateY(0);
  box-shadow: none;
}
.ai-dl-file:disabled {
  opacity: .5;
  cursor: default;
}
.ai-dl-file[data-fmt="docx"]:hover:not(:disabled) { border-color: #2b5fcc; box-shadow: 0 4px 12px rgba(43,95,204,.3); }
.ai-dl-file[data-fmt="pptx"]:hover:not(:disabled) { border-color: #cc4a2b; box-shadow: 0 4px 12px rgba(204,74,43,.3); }
.ai-dl-file-svg {
  display: block;
  flex-shrink: 0;
}
.ai-dl-file-name {
  font-size: 9.5px;
  color: #a0a0c0;
  line-height: 1.3;
  word-break: break-all;
  max-width: 72px;
}

/* 입력창 */
.ai-input-area {
  display: flex;
  gap: 8px;
  padding: 10px 12px;
  border-top: 1px solid #1e1e3a;
  background: #0a0a16;
  flex-shrink: 0;
  align-items: flex-end;
}
.ai-textarea {
  flex: 1;
  background: #13132a;
  border: 1px solid #2a2a4a;
  border-radius: 10px;
  color: #d4d4f0;
  font-size: 12px;
  padding: 8px 12px;
  resize: none;
  outline: none;
  line-height: 1.5;
  font-family: inherit;
  transition: border-color 0.12s;
  min-height: 36px;
  max-height: 120px;
}
.ai-textarea:focus { border-color: #7C4DFF; }
.ai-textarea::placeholder { color: #44445a; }
.ai-send-btn {
  width: 36px; height: 36px;
  border-radius: 10px;
  background: linear-gradient(135deg, #7C4DFF, #5c35cc);
  border: none;
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  flex-shrink: 0;
  transition: all 0.12s;
}
.ai-send-btn:hover { background: linear-gradient(135deg, #9060FF, #7C4DFF); }
.ai-send-btn svg { width: 16px; height: 16px; }

/* ============================================================
   알림 패널
   ============================================================ */
.notif-wrap { position: relative; }
.notif-panel {
  display: none;
  position: absolute;
  top: calc(100% + 8px); right: 0;
  width: 360px;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  z-index: 500;
  overflow: hidden;
}
.notif-panel.show { display: block; animation: fadeIn 0.15s; }
.notif-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 11px 14px;
  border-bottom: 1px solid var(--border);
  font-size: 12px;
  font-weight: 600;
  color: var(--text-1);
}
.notif-list { max-height: 440px; overflow-y: auto; }
.notif-item {
  display: flex;
  gap: 10px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: background 0.1s;
}
.notif-item:hover { background: var(--surface-2); }
.notif-item:last-child { border-bottom: none; }
.notif-icon {
  width: 32px; height: 32px;
  border-radius: var(--radius);
  display: flex; align-items: center; justify-content: center;
  font-size: 14px;
  flex-shrink: 0;
}
.notif-icon.red    { background: var(--red-light); }
.notif-icon.amber  { background: var(--amber-light); }
.notif-icon.blue   { background: #EEF3FD; }
.notif-icon.green  { background: #E8F8EF; }
.notif-icon.purple { background: #F3EEFB; }
.notif-icon.gray   { background: var(--surface-2); }
.notif-body { flex: 1; min-width: 0; }
.notif-title { font-size: 12px; font-weight: 600; color: var(--text-1); line-height: 1.4; }
.notif-desc  { font-size: 11px; color: var(--text-2); margin-top: 1px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.notif-date  { font-size: 10px; color: var(--text-3); margin-top: 2px; display:flex; align-items:center; gap:4px; }

/* 알림 전체 목록 페이지 */
.notif-icon-sm {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; border-radius: 50%; font-size: 14px;
}
.notif-icon-sm.red    { background: var(--red-light); }
.notif-icon-sm.amber  { background: var(--amber-light); }
.notif-icon-sm.blue   { background: #EEF3FD; }
.notif-icon-sm.green  { background: #E8F8EF; }
.notif-icon-sm.purple { background: #F3EEFB; }
.notif-icon-sm.gray   { background: var(--surface-2); }
.notif-row:hover td   { background: var(--surface-2); }

/* ============================================================
   회의록 페이지
   ============================================================ */
.meeting-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  height: calc(100vh - var(--topbar-h) - 40px);
}
.meeting-input-area {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  display: flex;
  flex-direction: column;
}
.meeting-textarea {
  flex: 1;
  border: none;
  outline: none;
  padding: 16px;
  font-size: 13px;
  line-height: 1.7;
  resize: none;
  color: var(--text-1);
  font-family: inherit;
  border-radius: var(--radius);
}
.meeting-output {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.meeting-output-body {
  flex: 1;
  padding: 16px;
  overflow-y: auto;
  font-size: 13px;
  line-height: 1.7;
  color: var(--text-1);
}
.meeting-output-body h4 {
  font-size: 13px; font-weight: 700;
  color: var(--oci-red);
  margin: 14px 0 6px;
  border-bottom: 1px solid var(--border);
  padding-bottom: 4px;
}
.meeting-output-body ul { padding-left: 18px; margin: 4px 0; }
.meeting-output-body li { margin: 3px 0; }

/* ============================================================
   AI 인사이트 위젯 (대시보드)
   ============================================================ */
.ai-insight-item {
  display: flex;
  gap: 10px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  align-items: flex-start;
}
.ai-insight-item:last-child { border-bottom: none; }
.ai-insight-item .insight-icon { font-size: 16px; }
.ai-insight-body { flex: 1; }
.ai-insight-text { font-size: 12px; color: var(--text-2); line-height: 1.5; }
.ai-insight-tag {
  display: inline-block;
  font-size: 10px;
  font-weight: 600;
  padding: 1px 6px;
  border-radius: 3px;
  margin-bottom: 3px;
}
.ai-insight-tag.urgent { background: var(--red-light); color: var(--red); }
.ai-insight-tag.warning { background: var(--amber-light); color: #B87200; }
.ai-insight-tag.info { background: var(--blue-light); color: var(--blue); }

.ai-gen-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 11px;
  background: linear-gradient(135deg, #1a1040, #2d1b69);
  color: #C4A0FF;
  border: 1px solid #3d2b6e;
  border-radius: var(--radius);
  font-size: 11px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.12s;
}
.ai-gen-btn:hover {
  background: linear-gradient(135deg, #2d1b69, #4a2d99);
  color: #E8D5FF;
}

/* ============================================================
   명함 OCR 드롭존
   ============================================================ */
#card-dropzone {
  border: 2px dashed var(--border);
  border-radius: 8px;
  padding: 32px;
  text-align: center;
  cursor: pointer;
  transition: all 0.2s;
  background: var(--surface-2);
}
#card-dropzone:hover,
#card-dropzone.drag-over {
  border-color: var(--oci-red);
  background: rgba(230,57,70,.06);
  transform: scale(1.01);
}
.ocr-result-card {
  border: 1px solid var(--border);
  border-radius: 6px;
  margin-bottom: 10px;
  overflow: hidden;
}
.ocr-result-header {
  background: var(--surface-2);
  padding: 8px 12px;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-2);
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.ocr-result-body {
  padding: 12px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

/* ============================================================
   캘린더 — Google Calendar 스타일
   ============================================================ */
.cal-page {
  background: #fff;
  border-radius: 8px;
  border: 1px solid #dadce0;
  box-shadow: 0 1px 2px rgba(60,64,67,.08);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  height: calc(100vh - 110px);
}
.cal-toolbar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 20px;
  border-bottom: 1px solid #e0e0e0;
  background: #fff;
  flex-wrap: wrap;
}
.cal-nav-group { display: flex; gap: 2px; align-items: center; }
.cal-view-group {
  display: flex;
  background: #f1f3f4;
  border-radius: 18px;
  padding: 2px;
}
.cal-title {
  font-size: 22px;
  font-weight: 400;
  color: #3c4043;
  min-width: 200px;
  letter-spacing: -0.2px;
}
.cal-today-btn {
  padding: 6px 14px;
  border: 1px solid #dadce0;
  background: #fff;
  border-radius: 4px;
  font-size: 13px;
  font-weight: 500;
  color: #3c4043;
  cursor: pointer;
  transition: background 0.1s;
}
.cal-today-btn:hover { background: #f1f3f4; }
.cal-arrow-btn {
  width: 36px;
  height: 36px;
  border: none;
  background: transparent;
  border-radius: 50%;
  cursor: pointer;
  font-size: 18px;
  color: #5f6368;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.1s;
}
.cal-arrow-btn:hover { background: #f1f3f4; }
.cal-view-btn {
  padding: 6px 14px;
  border: none;
  background: transparent;
  font-size: 13px;
  font-weight: 500;
  color: #5f6368;
  cursor: pointer;
  border-radius: 16px;
  transition: all 0.15s;
}
.cal-view-btn:hover { color: #1a73e8; }
.cal-view-btn.active {
  background: #fff;
  color: #1a73e8;
  box-shadow: 0 1px 2px rgba(60,64,67,.12);
}
.cal-add-btn {
  padding: 8px 18px;
  background: #1a73e8;
  color: #fff;
  border: none;
  border-radius: 18px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  box-shadow: 0 1px 3px rgba(60,64,67,.15);
  transition: all 0.15s;
}
.cal-add-btn:hover {
  background: #1765cc;
  box-shadow: 0 2px 6px rgba(60,64,67,.25);
}
.cal-team-filter {
  padding: 6px 12px;
  border: 1px solid #dadce0;
  border-radius: 4px;
  font-size: 13px;
  color: #3c4043;
  background: #fff;
  outline: none;
}
.cal-wrap {
  flex: 1;
  overflow: hidden;
  background: #fff;
}
#cal-calendar { height: 100%; }

/* === FullCalendar 내부 스타일 — Google Calendar 스타일 === */
.fc { font-family: 'Roboto', 'Noto Sans KR', sans-serif; }
.fc .fc-toolbar { display: none !important; }

/* 헤더 (요일) */
.fc .fc-col-header-cell {
  background: #fff;
  border-bottom: 1px solid #e0e0e0;
  border-left: 1px solid #e0e0e0;
  padding: 8px 0 4px;
}
.fc .fc-col-header-cell:first-child { border-left: none; }
.fc .fc-col-header-cell-cushion {
  font-size: 11px;
  font-weight: 500;
  color: #70757a;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
/* 일요일 빨강, 토요일 파랑 (Google Calendar Korean style) */
.fc .fc-day-sun .fc-col-header-cell-cushion,
.fc .fc-day-sun .fc-daygrid-day-number { color: #d93025 !important; }
.fc .fc-day-sat .fc-col-header-cell-cushion,
.fc .fc-day-sat .fc-daygrid-day-number { color: #1a73e8 !important; }

/* 그리드 셀 */
.fc-theme-standard td,
.fc-theme-standard th { border-color: #e0e0e0 !important; }
.fc-theme-standard .fc-scrollgrid { border-color: #e0e0e0 !important; }
.fc .fc-daygrid-day-frame { padding: 0; min-height: 100px; }
.fc .fc-daygrid-day-top {
  flex-direction: row;
  justify-content: flex-start;
  padding: 4px 6px 2px;
}
.fc .fc-daygrid-day-number {
  font-size: 12px;
  font-weight: 500;
  color: #3c4043;
  padding: 0;
  text-decoration: none;
  line-height: 1;
}
.cal-day-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 22px;
  padding: 0 6px;
  border-radius: 11px;
  font-size: 12px;
  font-weight: 500;
  line-height: 1;
}

/* 오늘 강조 — Google 식 파란 원 (오늘만!) */
.fc .fc-day-today { background: #fff !important; }
.fc .fc-day-today .cal-day-num {
  background: #1a73e8;
  color: #fff !important;
  font-weight: 600;
}

/* 다른 달 날짜 */
.fc .fc-day-other .cal-day-num { color: #bdc1c6; }

/* 이벤트 — 둥근 색상 막대 (eventDisplay: 'block' 모드 기준) */
.fc-h-event,
.fc-v-event,
.fc-daygrid-block-event,
.fc-daygrid-dot-event,
.fc .fc-daygrid-event {
  border: none !important;
  border-radius: 4px !important;
  cursor: pointer;
  transition: filter 0.1s;
  display: block !important;
}
.fc-h-event:hover,
.fc .fc-daygrid-event:hover { filter: brightness(0.92); }

.fc .fc-daygrid-event {
  margin: 1px 4px !important;
  padding: 0 !important;
  overflow: hidden;
}
.fc .fc-daygrid-event .fc-event-main {
  padding: 2px 6px !important;
  font-size: 11px !important;
  line-height: 1.4 !important;
  color: #fff !important;
  display: flex;
  align-items: center;
  gap: 4px;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.fc .fc-daygrid-event .fc-event-main-frame {
  display: flex !important;
  align-items: center;
  gap: 4px;
  width: 100%;
  overflow: hidden;
}
.fc .fc-daygrid-event .fc-event-title,
.fc .fc-daygrid-event .fc-event-title-container {
  font-weight: 500 !important;
  color: #fff !important;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
  min-width: 0;
}
.fc .fc-daygrid-event .fc-event-time {
  font-weight: 500 !important;
  margin-right: 0 !important;
  opacity: 0.9;
  color: #fff !important;
  flex-shrink: 0;
}
.fc-daygrid-event-dot { display: none !important; }

/* 완료된 이벤트 — 흐리게 + 취소선 */
.fc .fc-daygrid-event.cal-event-completed { opacity: 0.55; }
.fc .fc-daygrid-event.cal-event-completed .fc-event-title { text-decoration: line-through; }

/* ============================================================
   뷰 토글 (목록 / 카드)
   ============================================================ */
.view-toggle {
  display: inline-flex;
  border: 1px solid var(--border-2);
  border-radius: 6px;
  background: var(--surface-2);
  padding: 2px;
}
.view-toggle-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 12px;
  border: none;
  background: transparent;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-3);
  cursor: pointer;
  border-radius: 4px;
  transition: all 0.12s;
}
.view-toggle-btn:hover { color: var(--text-1); }
.view-toggle-btn.active {
  background: #fff;
  color: var(--oci-red);
  box-shadow: 0 1px 2px rgba(0,0,0,.06);
}

/* ============================================================
   고객사 카드 그리드
   ============================================================ */
.cust-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 14px;
}
.cust-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  cursor: pointer;
  transition: all 0.15s;
  display: flex;
  flex-direction: column;
}
.cust-card:hover {
  border-color: var(--text-3);
  box-shadow: 0 4px 12px rgba(0,0,0,0.08);
  transform: translateY(-2px);
}
.cust-card-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px;
  border-bottom: 1px solid var(--border);
}
.cust-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 16px;
  font-weight: 600;
  flex-shrink: 0;
}
.cust-card-title {
  flex: 1;
  min-width: 0;
}
.cust-card-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-1);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.cust-card-sub {
  font-size: 11px;
  color: var(--text-3);
  margin-top: 2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.cust-card-body {
  padding: 12px 14px;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.cust-card-row {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: var(--text-2);
  overflow: hidden;
}
.cust-card-row > span:last-child {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
}
.cust-card-icon {
  width: 16px;
  flex-shrink: 0;
  text-align: center;
  font-size: 12px;
  opacity: 0.7;
}
.cust-card-footer {
  padding: 10px 14px 14px;
}

/* ============================================================
   상단 공통 위젯 (세션 / 토큰 / 테마 / 폰트)
   ============================================================ */
.topbar-widgets {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 0 12px;
  height: 32px;
  border-radius: 16px;
  background: var(--surface-2);
  border: 1px solid var(--border);
  margin-right: 4px;
}
.widget-item {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  font-weight: 500;
  color: var(--text-2);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.widget-item svg { opacity: 0.7; }
.widget-divider {
  width: 1px;
  height: 14px;
  background: var(--border-2);
  display: inline-block;
}
.widget-btn {
  width: 28px;
  height: 24px;
  padding: 0;
  border: none;
  background: transparent;
  border-radius: 6px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 600;
  color: var(--text-2);
  transition: all 0.12s;
}
.widget-btn:hover { background: rgba(0,0,0,.06); color: var(--text-1); }
.font-size-group {
  display: inline-flex;
  gap: 1px;
  border-left: 1px solid var(--border-2);
  padding-left: 6px;
  margin-left: 2px;
}

/* ============================================================
   부드러운 테마 전환 트랜지션
   ============================================================ */
body,
.sidebar, .topbar, .card, .modal, .modal-header, .modal-footer,
.cust-card, .nav-item, .data-table, .data-table thead,
.form-input, .form-control, .search-input, .filter-select,
.topbar-widgets, .widget-btn, .cal-page, .cal-toolbar,
.cal-today-btn, .cal-team-filter, .cal-view-btn,
.btn, .badge, .stat-card, .ai-panel {
  transition: background-color 0.25s ease, color 0.2s ease,
              border-color 0.2s ease, box-shadow 0.2s ease;
}

/* ============================================================
   다크 테마 — 따뜻한 차콜 톤 (포근한 색감)
   ============================================================ */
[data-theme="dark"] {
  --bg:        #1c1a1d;   /* 따뜻한 차콜 */
  --surface:   #25232a;   /* 살짝 보라 기운의 어두운 그레이 */
  --surface-2: #2d2b32;
  --surface-3: #36333c;
  --border:    #3d3a44;
  --border-2:  #4b4853;
  --text-1:    #ece8e6;   /* 약간 따뜻한 화이트 */
  --text-2:    #b8b3b1;
  --text-3:    #8a8583;
  --text-4:    #5d5856;

  --primary-light: rgba(230,57,70,.18);
  --blue-light:    rgba(22,100,229,.20);
  --green-light:   rgba(0,168,107,.18);
  --amber-light:   rgba(245,156,0,.18);
  --red-light:     rgba(230,57,70,.20);
  --purple-light:  rgba(124,77,255,.20);
  --gray-light:    rgba(180,180,180,.10);

  --shadow-sm:  0 1px 2px rgba(0,0,0,0.3);
  --shadow:     0 2px 8px rgba(0,0,0,0.35), 0 1px 3px rgba(0,0,0,0.25);
}
[data-theme="dark"] body { background: var(--bg); color: var(--text-1); }
[data-theme="dark"] .sidebar,
[data-theme="dark"] .topbar,
[data-theme="dark"] .card,
[data-theme="dark"] .modal,
[data-theme="dark"] .cust-card,
[data-theme="dark"] .stat-card { background: var(--surface); border-color: var(--border); }
[data-theme="dark"] .modal-header,
[data-theme="dark"] .modal-footer,
[data-theme="dark"] .data-table thead { background: var(--surface-2); }
[data-theme="dark"] .data-table tbody tr:hover,
[data-theme="dark"] .clickable:hover { background: var(--surface-3); }
[data-theme="dark"] .data-table td { border-color: var(--border); }
[data-theme="dark"] .form-input,
[data-theme="dark"] .form-control,
[data-theme="dark"] .search-input,
[data-theme="dark"] .filter-select {
  background: var(--surface-2);
  color: var(--text-1);
  border-color: var(--border-2);
}
[data-theme="dark"] .form-input::placeholder,
[data-theme="dark"] .search-input::placeholder { color: var(--text-3); }
[data-theme="dark"] .nav-item { color: var(--text-2); }
[data-theme="dark"] .nav-item:hover { background: var(--surface-3); color: var(--text-1); }
[data-theme="dark"] .nav-item.active {
  background: linear-gradient(135deg, rgba(230,57,70,.25), rgba(230,57,70,.12));
  color: #fff;
}
[data-theme="dark"] .topbar-widgets { background: var(--surface-2); border-color: var(--border-2); }
[data-theme="dark"] .widget-btn { color: var(--text-2); }
[data-theme="dark"] .widget-btn:hover { background: rgba(255,255,255,.06); color: var(--text-1); }
[data-theme="dark"] .btn-ghost { color: var(--text-2); }
[data-theme="dark"] .btn-ghost:hover { background: var(--surface-3); color: var(--text-1); }
[data-theme="dark"] .badge { color: var(--text-1); }
[data-theme="dark"] .modal-overlay { background: rgba(0,0,0,0.65); }

/* ──────────────────────────────────────────────────────────────
   모달 닫기 컨펌 (Discard Changes Dialog)
   사용자가 입력 중인 모달을 바깥 클릭/×로 닫으려 할 때 표시
   modal-overlay(z-index:1000) 위에 떠야 하므로 z-index 1100 사용
   ────────────────────────────────────────────────────────────── */
.modal-discard-overlay {
  position: fixed;
  inset: 0;
  background: rgba(10, 10, 20, 0.45);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  z-index: 1100;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px 16px;
  animation: discardBgIn 0.15s ease both;
}
@keyframes discardBgIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.modal-discard-box {
  background: var(--surface, #fff);
  border-radius: 12px;
  width: 100%;
  max-width: 400px;
  padding: 24px;
  box-shadow:
    0 0 0 1px rgba(0,0,0,.08),
    0 12px 32px rgba(0,0,0,.18),
    0 24px 48px rgba(0,0,0,.12);
  animation: discardSlideIn 0.18s cubic-bezier(0.34, 1.2, 0.64, 1) both;
}
@keyframes discardSlideIn {
  from { transform: translateY(12px) scale(0.96); opacity: 0; }
  to   { transform: translateY(0) scale(1); opacity: 1; }
}
.modal-discard-title {
  font-size: 15px;
  font-weight: 600;
  color: var(--text-1, #111);
  margin-bottom: 10px;
}
.modal-discard-body {
  font-size: 13px;
  line-height: 1.6;
  color: var(--text-2, #555);
  margin-bottom: 20px;
}
.modal-discard-hint {
  display: block;
  margin-top: 6px;
  font-size: 12px;
  color: var(--text-3, #999);
}
.modal-discard-footer {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}
[data-theme="dark"] .modal-discard-overlay { background: rgba(0,0,0,0.55); }
[data-theme="dark"] .modal-discard-box { background: var(--surface, #1c1c24); }

/* 다크 — Google Calendar */
[data-theme="dark"] .cal-page { background: var(--surface); border-color: var(--border-2); }
[data-theme="dark"] .cal-toolbar { background: var(--surface); border-color: var(--border); }
[data-theme="dark"] .cal-title,
[data-theme="dark"] .cal-today-btn,
[data-theme="dark"] .cal-team-filter { color: var(--text-1); }
[data-theme="dark"] .cal-today-btn,
[data-theme="dark"] .cal-team-filter { background: var(--surface-2); border-color: var(--border-2); }
[data-theme="dark"] .cal-today-btn:hover,
[data-theme="dark"] .cal-arrow-btn:hover { background: var(--surface-3); }
[data-theme="dark"] .cal-view-group { background: var(--surface-3); }
[data-theme="dark"] .cal-view-btn.active { background: var(--surface); color: #6ba3f5; }
[data-theme="dark"] .fc { background: var(--surface); }
[data-theme="dark"] .fc-theme-standard td,
[data-theme="dark"] .fc-theme-standard th,
[data-theme="dark"] .fc-theme-standard .fc-scrollgrid { border-color: var(--border) !important; }
[data-theme="dark"] .fc .fc-col-header-cell { background: var(--surface); border-color: var(--border); }
[data-theme="dark"] .fc .fc-col-header-cell-cushion { color: var(--text-2); }
[data-theme="dark"] .fc .fc-day-today { background: var(--surface-2) !important; }
[data-theme="dark"] .fc .fc-daygrid-day-number,
[data-theme="dark"] .cal-day-num { color: var(--text-1); }
[data-theme="dark"] .fc .fc-day-other .cal-day-num { color: var(--text-4); }

/* 폰트 크기 - / + 컨트롤 */
.font-size-ctrl {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  background: var(--surface-2);
  border-radius: 8px;
  padding: 2px 4px;
  height: 26px;
}
.font-size-ctrl #font-scale-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-2);
  min-width: 32px;
  text-align: center;
  font-variant-numeric: tabular-nums;
}
.font-size-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border: none;
  background: transparent;
  border-radius: 5px;
  cursor: pointer;
  font-size: 15px;
  font-weight: 500;
  line-height: 1;
  color: var(--text-2);
  transition: all 0.12s;
  flex-shrink: 0;
}
.font-size-btn:hover:not(:disabled) { background: var(--surface-3); color: var(--text-1); }
.font-size-btn:disabled { opacity: 0.35; cursor: not-allowed; }
[data-theme="dark"] .font-size-btn:hover:not(:disabled) { background: rgba(255,255,255,.08); }

/* ============================================================
   회의록 AI — 녹음 시각화
   ============================================================ */
.rec-visual {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: var(--surface-2);
  margin: 0 auto 14px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.rec-visual::before {
  content: '🎤';
  font-size: 28px;
  z-index: 1;
}
.rec-visual.recording {
  background: rgba(217, 48, 37, 0.12);
  animation: rec-pulse 1.5s ease-in-out infinite;
}
.rec-visual.recording::after {
  content: '';
  position: absolute;
  inset: -8px;
  border-radius: 50%;
  border: 3px solid #d93025;
  animation: rec-ring 1.5s ease-out infinite;
}
@keyframes rec-pulse {
  0%, 100% { background: rgba(217, 48, 37, 0.12); }
  50%      { background: rgba(217, 48, 37, 0.25); }
}
@keyframes rec-ring {
  0%   { opacity: 1; transform: scale(0.95); }
  100% { opacity: 0; transform: scale(1.25); }
}
.rec-time {
  font-size: 24px;
  font-weight: 600;
  color: var(--text-1);
  font-variant-numeric: tabular-nums;
  margin-bottom: 4px;
}

/* ── Google Meet 연동 UI ─────────────────────────────── */
.gmeet-setup-guide {
  text-align: center;
  padding: 24px;
  color: var(--text-2);
}
.gmeet-connect-panel {
  padding: 4px 0;
}
.gmeet-google-btn {
  display: inline-flex;
  align-items: center;
  background: #1a73e8;
  border: none;
  padding: 8px 16px;
  border-radius: 6px;
  font-size: 13px;
}
.gmeet-google-btn:hover { background: #1558b0; }

.gmeet-link-card {
  border: 1.5px solid #00832d;
  border-radius: 8px;
  padding: 12px;
  background: #f0faf3;
}
.dark .gmeet-link-card { background: rgba(0,131,45,.1); border-color: #00a539; }

.gmeet-link-url {
  font-size: 11px;
  font-family: monospace;
  color: #1a73e8;
  background: var(--surface-1);
  padding: 6px 8px;
  border-radius: 4px;
  word-break: break-all;
  border: 1px solid var(--border);
}

.gmeet-session-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 6px;
  border: 1px solid var(--border);
  background: var(--surface-1);
}
.gmeet-session-row:hover { background: var(--surface-2); }

.btn-xs {
  padding: 3px 10px !important;
  font-size: 11px !important;
  border-radius: 4px !important;
  height: 26px;
  line-height: 1;
}

/* ── 상단 바 녹음 인디케이터 ─────────────────────────── */
.btn-rec-indicator {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  background: rgba(217, 48, 37, 0.08);
  border: 1.5px solid rgba(217, 48, 37, 0.45);
  border-radius: 20px;
  color: #d93025;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s;
  font-variant-numeric: tabular-nums;
}
.btn-rec-indicator:hover {
  background: rgba(217, 48, 37, 0.15);
}
.rec-dot-blink {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #d93025;
  animation: rec-dot-blink 1.2s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes rec-dot-blink {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.2; }
}

#audio-dropzone {
  border: 2px dashed var(--border-2);
  border-radius: 8px;
  padding: 28px 16px;
  text-align: center;
  cursor: pointer;
  transition: all 0.2s;
  background: var(--surface-2);
}
#audio-dropzone:hover,
#audio-dropzone.drag-over {
  border-color: var(--oci-red);
  background: rgba(230,57,70,.06);
}

/* 회의록 목록 */
.ml-item {
  padding: 14px;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: background 0.12s;
}
.ml-item:hover { background: var(--surface-2); }
.ml-item.active {
  background: var(--primary-light);
  border-left: 3px solid var(--oci-red);
}
.ml-item-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-1);
  margin-bottom: 6px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.ml-item-meta { margin-bottom: 6px; }
.ml-item-preview {
  font-size: 12px;
  color: var(--text-3);
  line-height: 1.5;
  margin-bottom: 6px;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.ml-item-date {
  font-size: 11px;
  color: var(--text-4);
}

/* 마크다운 본문 */
.markdown-body h2 {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-1);
  margin: 18px 0 10px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--border);
}
.markdown-body h2:first-child { margin-top: 0; }
.markdown-body ul,
.markdown-body ol { padding-left: 22px; margin: 8px 0; }
.markdown-body li { margin: 4px 0; }
.markdown-body strong { color: var(--text-1); }

/* 세션 만료 모달 */
.session-expired-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(6px);
  z-index: 99999;
  display: flex; align-items: center; justify-content: center;
}
.session-expired-box {
  background: var(--surface);
  border-radius: 12px;
  padding: 32px;
  max-width: 380px;
  text-align: center;
  box-shadow: 0 20px 60px rgba(0,0,0,0.4);
}
.session-expired-icon {
  font-size: 36px;
  margin-bottom: 14px;
}
.session-expired-title {
  font-size: 17px;
  font-weight: 600;
  color: var(--text-1);
  margin-bottom: 8px;
}
.session-expired-msg {
  font-size: 13px;
  color: var(--text-2);
  margin-bottom: 18px;
  line-height: 1.6;
}

/* 상태 뱃지 (모달 상세보기용) */
/* 캘린더 색상 구분 표시 */
.cal-color-indicator {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 5px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--surface-2);
  min-width: 140px;
}
.cal-color-dot {
  width: 12px;
  height: 12px;
  border-radius: 3px;
  flex-shrink: 0;
  transition: background 0.2s;
}
.cal-color-text {
  font-size: 12px;
  font-weight: 500;
  transition: color 0.2s;
}

.status-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 12px;
  font-size: 11px;
  font-weight: 600;
}
.status-badge.planned { background: #e6f0fe; color: #1664E5; }
.status-badge.completed { background: #e6f7ef; color: #00A86B; }

/* "+N more" 링크 */
.fc .fc-daygrid-more-link {
  font-size: 11px;
  font-weight: 500;
  color: #5f6368;
  margin-left: 8px;
  text-decoration: none;
}
.fc .fc-daygrid-more-link:hover { color: #1a73e8; text-decoration: underline; }

/* 주간/일간 뷰 시간 슬롯 */
.fc .fc-timegrid-slot { border-color: #e0e0e0 !important; height: 32px; }
.fc .fc-timegrid-slot-label { font-size: 10px; color: #70757a; }
.fc .fc-timegrid-axis { font-size: 10px; }
.fc .fc-timegrid-now-indicator-line { border-color: #d93025; }
.fc .fc-timegrid-now-indicator-arrow { border-color: #d93025; color: #d93025; }

/* 리스트 뷰 */
.fc .fc-list { border: none; }
.fc .fc-list-day-cushion {
  background: #f1f3f4 !important;
  font-size: 12px;
  font-weight: 500;
}
.fc-list-event-title a { color: #3c4043 !important; font-weight: 500; }
.fc .fc-list-event:hover td { background: #f8f9fa; }
.fc .fc-list-event-dot { border-color: var(--ev-color, #1a73e8) !important; }

/* ============================================================
   게시판
   ============================================================ */
.tab-bar {
  display: flex;
  gap: 2px;
  border-bottom: 2px solid var(--border);
  margin-bottom: 16px;
}
.tab-btn {
  padding: 8px 20px;
  font-size: 13px;
  font-weight: 500;
  border: none;
  background: none;
  color: var(--text-3);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  transition: all 0.15s;
}
.tab-btn:hover { color: var(--text-1); }
.tab-btn.active { color: var(--oci-red); border-bottom-color: var(--oci-red); }

.announce-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
  transition: background 0.1s;
}
.announce-row:hover { background: var(--surface-2); }
.announce-title { flex: 1; font-size: 13px; font-weight: 500; }
.announce-meta { font-size: 11px; color: var(--text-3); }

.faq-group-title {
  padding: 8px 16px;
  background: var(--surface-2);
  font-size: 11px;
  font-weight: 700;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-bottom: 1px solid var(--border);
}
.faq-item { border-bottom: 1px solid var(--border); }
.faq-question {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  cursor: pointer;
  font-size: 13px;
  font-weight: 500;
  transition: background 0.1s;
}
.faq-question:hover { background: var(--surface-2); }
.faq-answer {
  display: none;
  padding: 12px 16px 16px 42px;
  font-size: 13px;
  color: var(--text-2);
  line-height: 1.6;
  background: var(--surface-2);
}
.faq-answer.open { display: block; }
.faq-chevron { margin-left: auto; transition: transform 0.2s; font-size: 12px; }
.faq-chevron.open { transform: rotate(180deg); }

.comment-item {
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
  font-size: 13px;
}
.comment-meta { font-size: 11px; color: var(--text-3); margin-top: 4px; }

/* Quill snow theme overrides */
.ql-toolbar { border-color: var(--border) !important; background: var(--surface-2); }
.ql-container { border-color: var(--border) !important; background: var(--surface); min-height: 140px; }
.ql-editor { color: var(--text-1); font-size: 13px; }

/* ============================================================
   관리자
   ============================================================ */
.stat-grid-4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 16px;
}
.stat-card-admin {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px;
  text-align: center;
}
.stat-card-admin .stat-val { font-size: 24px; font-weight: 700; color: var(--text-1); }
.stat-card-admin .stat-lbl { font-size: 11px; color: var(--text-3); margin-top: 4px; }
.health-row {
  display: flex;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
  font-size: 13px;
  gap: 12px;
}
.health-name { flex: 1; }
.log-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.log-table th, .log-table td {
  padding: 7px 10px;
  text-align: left;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}
.log-table th { background: var(--surface-2); font-weight: 600; color: var(--text-2); }
.log-table tr:hover td { background: var(--surface-2); }
.badge-2xx { background: #d1fae5; color: #065f46; }
.badge-4xx { background: #fef3c7; color: #92400e; }
.badge-5xx { background: #fee2e2; color: #991b1b; }

/* ============================================================
   반응형 — 모바일 / 태블릿 최적화
   ============================================================ */

/* ── 태블릿 (1024px 이하) ─────────────────────────────── */
@media (max-width: 1200px) {
  .ai-panel { width: 360px; }
  .stat-grid-4 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 1024px) {
  :root { --sidebar-w: 180px; }
  .topbar { padding: 0 16px; }
  .content { padding: 0 16px 16px; }
  .filter-bar { margin: 0 -16px 14px; padding: 14px 16px; }
  .stat-grid-4 { grid-template-columns: repeat(2, 1fr); }
  .kanban-board { grid-template-columns: repeat(4, 1fr); }
}

/* ── 모바일 (768px 이하) ─────────────────────────────── */
@media (max-width: 768px) {
  /* ── 레이아웃: 사이드바 오버레이로 전환 ── */
  body { position: relative; }

  .sidebar {
    position: fixed;
    left: 0; top: 0;
    height: 100%;
    z-index: 300;
    transform: translateX(-100%);
    transition: transform 0.25s ease;
    box-shadow: 4px 0 20px rgba(0,0,0,0.15);
    width: 240px !important;
  }
  .sidebar.mobile-open { transform: translateX(0); }

  /* 사이드바 열렸을 때 뒤 오버레이
     ※ 사이드바 영역(0~240px)은 제외하고 오른쪽 영역만 덮어
        터치 이벤트가 nav-item에 정상 전달되도록 함 */
  .sidebar-overlay {
    display: none;
    position: fixed;
    top: 0; bottom: 0;
    left: 240px;   /* 사이드바 너비 이후부터 */
    right: 0;
    background: rgba(0,0,0,0.45);
    z-index: 299;
    cursor: pointer;
  }
  .sidebar-overlay.active { display: block; }

  .main { width: 100%; }

  /* ── 상단 바 ── */
  .topbar { padding: 0 12px; gap: 8px; }
  .page-breadcrumb { display: none; }
  .topbar-widgets { gap: 4px; }
  .topbar-date { display: none; }
  .topbar-widgets .widget-divider { display: none; }
  /* 토큰 위젯 숨김 (모바일에서 공간 절약) */
  #token-widget { display: none; }

  /* 햄버거 버튼 표시 */
  .mobile-menu-btn { display: flex !important; }

  /* ── 컨텐츠 ── */
  .content { padding: 0 12px 12px; }
  .filter-bar {
    margin: 0 -12px 12px;
    padding: 12px;
    flex-wrap: wrap;
    gap: 6px;
  }
  .search-input { width: 100%; }
  .filter-bar > .btn { width: 100%; justify-content: center; }
  .filter-date-group { width: 100%; flex-wrap: wrap; }
  .filter-date { width: calc(50% - 20px); flex: 1; min-width: 110px; }
  .filter-chip { font-size: 10px; padding: 2px 6px; }

  /* ── 카드/그리드 ── */
  .stat-grid-4 { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .metrics-grid { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .card { border-radius: var(--radius); }
  .card-header { padding: 12px; flex-wrap: wrap; gap: 6px; }

  /* ── 테이블: 가로 스크롤 ── */
  .card-body.no-pad { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .data-table { min-width: 640px; }
  .data-table th, .data-table td { padding: 8px 10px; font-size: 11px; }

  /* ── 칸반 ── */
  .kanban-board { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .kanban-col { min-width: 0; }

  /* ── 모달 ── */
  .modal { width: 95vw !important; max-width: 95vw !important; margin: 16px; }
  .modal-body { max-height: 65vh; }

  /* ── AI 패널 ── */
  .ai-panel { width: 100%; right: 0; bottom: 0; top: auto; height: 75vh; border-radius: var(--radius-lg) var(--radius-lg) 0 0; }
  .ai-overlay { display: none; } /* 모바일에서 패널이 슬라이드업이므로 오버레이 불필요 */

  /* ── 회의록 ── */
  .meeting-layout { grid-template-columns: 1fr; }

  /* ── 캘린더 ── */
  .cal-toolbar { flex-wrap: wrap; gap: 6px; }
  .cal-team-filter { width: 100%; }

  /* ── 토스트 위치 ── */
  .toast-container { bottom: 12px; right: 12px; left: 12px; width: auto; }

  /* ── 폰트 크기 조절 숨김 (모바일에서 공간 절약) ── */
  .font-size-ctrl { display: none; }

  /* ── OMS 모듈 ── */
  .oms-cs-features { grid-template-columns: 1fr; }
  .oms-form-grid { grid-template-columns: 1fr; }
  .oms-tab { padding: 8px 12px; font-size: 11px; }
}

/* ── 소형 모바일 (480px 이하) ─────────────────────────── */
@media (max-width: 480px) {
  .stat-grid-4 { grid-template-columns: 1fr 1fr; }
  .kanban-board { grid-template-columns: 1fr; }
  .topbar { padding: 0 10px; }
  .page-title { font-size: 14px; }
  .btn-ai span { display: none; } /* AI 어시스턴트 텍스트 숨김 */
  .btn-ai::after { content: 'AI'; font-size: 11px; }
}

/* ============================================================
   OMS (주문관리) 모듈 스타일
   ============================================================ */

/* 탭 바 */
.oms-tab-bar {
  display: flex;
  gap: 4px;
  margin-bottom: 16px;
  border-bottom: 2px solid var(--border);
  padding-bottom: 0;
  margin-top: 20px;
}
.oms-tab {
  padding: 10px 20px;
  border: none;
  background: none;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-3);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  border-radius: var(--radius) var(--radius) 0 0;
  transition: color 0.15s, border-color 0.15s, background 0.15s;
}
.oms-tab:hover { background: var(--surface-3); color: var(--text-1); }
.oms-tab.active {
  color: var(--oci-red);
  border-bottom-color: var(--oci-red);
  font-weight: 600;
}

/* 준비중 안내 박스 */
.oms-coming-soon {
  background: var(--surface);
  border: 2px dashed var(--border-2);
  border-radius: var(--radius-lg);
  padding: 32px 28px;
  text-align: center;
}
.oms-cs-icon { font-size: 40px; margin-bottom: 12px; }
.oms-cs-title {
  font-size: 18px;
  font-weight: 700;
  color: var(--text-1);
  margin-bottom: 6px;
}
.oms-cs-desc {
  font-size: 13px;
  color: var(--text-3);
  margin-bottom: 20px;
}
.oms-cs-features {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  text-align: left;
  max-width: 700px;
  margin: 0 auto 20px;
}
.oms-feature-group {
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 14px 16px;
}
.oms-feature-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-2);
  margin-bottom: 8px;
}
.oms-feature-group ul {
  padding-left: 16px;
  margin: 0;
}
.oms-feature-group li {
  font-size: 12px;
  color: var(--text-2);
  margin-bottom: 4px;
  line-height: 1.5;
}
.oms-cs-badge {
  display: inline-block;
  background: var(--amber-light);
  color: var(--amber);
  border: 1px solid var(--amber);
  border-radius: 20px;
  padding: 5px 16px;
  font-size: 12px;
  font-weight: 600;
}

/* 프로토타입 폼 */
.oms-proto-form { opacity: 0.55; pointer-events: none; }
.oms-form-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.oms-form-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 12px;
}

/* 비활성 테이블 */
.oms-disabled-table { opacity: 0.6; }

/* mt 유틸 */
.mt-2 { margin-top: 8px; }
.mt-3 { margin-top: 16px; }

[data-theme="dark"] .oms-coming-soon {
  border-color: var(--border);
  background: var(--surface);
}
[data-theme="dark"] .oms-feature-group { background: var(--surface-2); }
@media (max-width: 768px) {
  .oms-cs-features { grid-template-columns: 1fr; }
  .oms-form-grid { grid-template-columns: 1fr 1fr; }
  .oms-tab { padding: 8px 12px; font-size: 12px; }
}

/* ================================================================
   DEVELOPER OPTIONS PAGE
   ================================================================ */

/* ── 전체 레이아웃 ────────────────────────────────────────────── */
.dev-options-wrap {
  max-width: 1400px;
  margin: 0 auto;
}

.dev-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
  padding: 20px 24px;
  background: linear-gradient(135deg, var(--surface) 0%, var(--surface-2) 100%);
  border: 1px solid var(--border);
  border-radius: 12px;
  border-left: 4px solid #8B5CF6;
}

.dev-title {
  font-size: 22px;
  font-weight: 700;
  color: var(--text-1);
  margin-bottom: 4px;
}

.dev-subtitle {
  font-size: 12px;
  color: var(--text-3);
}

.dev-badge {
  background: #8B5CF6;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 12px;
  letter-spacing: 0.5px;
}

/* ── 탭 바 ───────────────────────────────────────────────────── */
.dev-tabs {
  display: flex;
  gap: 4px;
  margin-bottom: 20px;
  background: var(--surface);
  padding: 6px;
  border-radius: 10px;
  border: 1px solid var(--border);
  overflow-x: auto;
}

.dev-tab {
  padding: 8px 18px;
  border: none;
  background: transparent;
  color: var(--text-2);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  border-radius: 7px;
  transition: all 0.15s;
  white-space: nowrap;
}

.dev-tab:hover {
  background: var(--surface-2);
  color: var(--text-1);
}

.dev-tab.active {
  background: #8B5CF6;
  color: #fff;
  font-weight: 600;
}

/* ── 섹션 헤더 ───────────────────────────────────────────────── */
.dev-section-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}

/* ── 기능 플래그 그리드 ──────────────────────────────────────── */
.dev-feature-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(380px, 1fr));
  gap: 16px;
}

.dev-cat-block {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
}

.dev-cat-title {
  padding: 10px 16px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-1);
  background: var(--surface-2);
  margin-bottom: 0;
  letter-spacing: 0.2px;
}

.dev-feature-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  border-top: 1px solid var(--border);
  transition: background 0.15s;
}

.dev-feature-row:hover {
  background: var(--surface-2);
}

.dev-feature-row.disabled {
  opacity: 0.55;
}

.dev-feature-info {
  flex: 1;
  min-width: 0;
}

.dev-feature-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-1);
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 2px;
}

.dev-feature-desc {
  font-size: 11px;
  color: var(--text-3);
  line-height: 1.4;
  margin-bottom: 4px;
}

.dev-feature-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.dev-chip {
  font-size: 10px;
  padding: 2px 7px;
  border-radius: 4px;
  background: var(--surface-3, var(--surface-2));
  color: var(--text-2);
  border: 1px solid var(--border);
}

.dev-chip.blue {
  background: rgba(22, 100, 229, 0.1);
  color: #1664E5;
  border-color: rgba(22, 100, 229, 0.25);
}

.dev-chip.green {
  background: rgba(23, 168, 90, 0.1);
  color: #17A85A;
  border-color: rgba(23, 168, 90, 0.25);
}

.dev-badge-exp {
  font-size: 9px;
  background: #F59C00;
  color: #fff;
  padding: 1px 5px;
  border-radius: 4px;
  font-weight: 600;
  vertical-align: middle;
}

/* ── 토글 스위치 ─────────────────────────────────────────────── */
.dev-toggle {
  position: relative;
  display: inline-block;
  width: 44px;
  height: 24px;
  flex-shrink: 0;
  cursor: pointer;
}

.dev-toggle input {
  opacity: 0;
  width: 0;
  height: 0;
}

.dev-toggle-slider {
  position: absolute;
  inset: 0;
  background: var(--border);
  border-radius: 24px;
  transition: background 0.2s;
}

.dev-toggle-slider::before {
  content: '';
  position: absolute;
  height: 18px;
  width: 18px;
  left: 3px;
  top: 3px;
  background: #fff;
  border-radius: 50%;
  transition: transform 0.2s;
  box-shadow: 0 1px 3px rgba(0,0,0,.3);
}

.dev-toggle input:checked + .dev-toggle-slider {
  background: #17A85A;
}

.dev-toggle input:checked + .dev-toggle-slider::before {
  transform: translateX(20px);
}

.dev-toggle input:disabled + .dev-toggle-slider {
  opacity: 0.5;
}

/* ── DFD 시각화 ──────────────────────────────────────────────── */
.dfd-container {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.dfd-board {
  position: relative;
  /* 헤더 + 컬럼 2행 × 4열 그리드 (페이지/API/테이블/외부) */
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  grid-template-rows: auto 1fr;
  column-gap: 70px;  /* 4열로 늘어남 — 간격 축소 */
  row-gap: 10px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 14px 16px 20px;
  overflow: visible;
}

/* 헤더는 그리드 1행, 컬럼은 그리드 2행으로 자동 배치 */
.dfd-col-hdr {
  text-align: center;
  font-size: 12px;
  font-weight: 700;
  padding: 7px 12px;
  border-radius: 6px;
  color: #fff;
  letter-spacing: 0.2px;
}

.dfd-hdr-page  { background: #1664E5; }
.dfd-hdr-api   { background: #17A85A; }
.dfd-hdr-table { background: #7C4DFF; }

.dfd-svg {
  /* 그리드 전체 영역을 덮도록 절대 위치 */
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
  overflow: visible;
}

.dfd-col {
  display: flex;
  flex-direction: column;
  gap: 5px;
  position: relative;
  z-index: 1;
  align-self: start;  /* 내용 높이에만 맞춤 */
}

.dfd-node {
  padding: 6px 11px;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  border: 1.5px solid var(--border);
  transition: transform 0.12s, border-color 0.12s, background 0.12s, box-shadow 0.12s, opacity 0.15s, filter 0.15s;
  background: var(--surface-2);
  color: var(--text-1);
  user-select: none;
  position: relative;
  z-index: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.dfd-node:hover:not(.dfd-dimmed) {
  border-color: #8B5CF6;
  background: var(--surface);
  box-shadow: 0 2px 8px rgba(0,0,0,.1);
  transform: translateY(-1px);
}

.dfd-node-page  { border-left: 3px solid #1664E5; }
.dfd-node-api   { border-left: 3px solid #17A85A; }
.dfd-node-table { border-left: 3px solid #7C4DFF; }

.dfd-node.dfd-active {
  border-color: #F59C00 !important;
  background: rgba(245,156,0,.15) !important;
  font-weight: 700;
  box-shadow: 0 0 0 3px rgba(245,156,0,.3), 0 4px 12px rgba(245,156,0,.2);
  transform: scale(1.02);
  z-index: 2;
}

.dfd-node.dfd-related {
  border-color: #17A85A !important;
  background: rgba(23,168,90,.12) !important;
  font-weight: 600;
  box-shadow: 0 0 0 2px rgba(23,168,90,.25);
}

.dfd-node.dfd-dimmed {
  opacity: 0.18;
  filter: grayscale(0.5);
}

.dfd-method {
  font-size: 9px;
  font-weight: 700;
  padding: 1px 4px;
  border-radius: 3px;
  color: #fff;
  text-transform: uppercase;
  margin-right: 4px;
}

.dfd-method.crud { background: #1664E5; }
.dfd-method.get  { background: #17A85A; }
.dfd-method.post { background: #F59C00; }

.dfd-table-icon { margin-right: 4px; }

.dfd-cols-preview {
  font-size: 10px;
  color: var(--text-3);
  margin-top: 2px;
  font-family: monospace;
}

/* SVG 엣지 */
.dfd-edge {
  fill: none;
  stroke: rgba(140, 145, 180, 0.18);
  stroke-width: 1;
  transition: stroke 0.15s, stroke-width 0.15s, opacity 0.15s;
}

.dfd-edge.dfd-active {
  stroke: #F59C00;
  stroke-width: 2;
  opacity: 1;
  filter: drop-shadow(0 0 3px rgba(245,156,0,0.6));
}

.dfd-edge.dfd-related-edge {
  stroke: rgba(23, 168, 90, 0.55);
  stroke-width: 1.4;
  opacity: 1;
}

.dfd-edge.dfd-dimmed {
  opacity: 0;
  pointer-events: none;
}

/* 영향도 패널 */
.dfd-impact-panel {
  margin-top: 12px;
  padding: 16px 20px;
  background: var(--surface);
  border: 1px solid #F59C00;
  border-radius: 10px;
  border-left: 4px solid #F59C00;
}

.dfd-impact-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-1);
  margin-bottom: 12px;
}

.impact-section {
  margin-bottom: 12px;
}

.impact-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-3);
  margin-bottom: 6px;
}

.impact-label.impact-page { color: #1664E5; }
.impact-label.impact-api  { color: #17A85A; }
.impact-label.impact-table { color: #7C4DFF; }

.impact-item {
  font-size: 12px;
  padding: 4px 10px;
  background: var(--surface-2);
  border-radius: 5px;
  margin-bottom: 3px;
  color: var(--text-1);
}

/* ── DB 스키마 ───────────────────────────────────────────────── */
.schema-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 14px;
}

.schema-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
}

.schema-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  background: var(--surface-2);
  border-bottom: 1px solid var(--border);
}

.schema-table-name {
  font-size: 13px;
  font-weight: 700;
  color: var(--text-1);
}

.schema-meta {
  font-size: 11px;
  color: var(--text-3);
}

.schema-cols {
  padding: 8px 0;
  max-height: 200px;
  overflow-y: auto;
}

.schema-col {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 14px;
  font-size: 11px;
  border-bottom: 1px solid var(--border);
}

.schema-col:last-child { border-bottom: none; }
.schema-col.pk { background: rgba(245,156,0,.05); }
.schema-col.fk { background: rgba(22,100,229,.05); }

.schema-col-name {
  flex: 1;
  font-family: monospace;
  color: var(--text-1);
  font-size: 11px;
}

.schema-col-type {
  color: var(--text-3);
  font-family: monospace;
  font-size: 10px;
}

.schema-col-null {
  color: #F59C00;
  font-weight: 700;
  font-size: 12px;
  width: 12px;
  text-align: center;
}

/* ══════════════════════════════════════════════════════════════
   Schema Map (연관도 인터랙티브 맵)
   ══════════════════════════════════════════════════════════════ */
.schema-map-viewport {
  position: relative;
  width: 100%;
  height: calc(100vh - 210px);
  min-height: 560px;
  overflow: hidden;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 10px;
  cursor: grab;
  user-select: none;
}
.schema-map-viewport.panning { cursor: grabbing; }
.schema-map-viewport.edit-mode { cursor: default; }
.schema-map-canvas {
  position: absolute;
  top: 0; left: 0;
  transform-origin: 0 0;
  will-change: transform;
}
.schema-map-svg {
  position: absolute;
  top: 0; left: 0;
  pointer-events: none;
  overflow: visible;
}

/* ── 노드 ── */
.schema-map-node {
  position: absolute;
  width: 230px;
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: 9px;
  box-shadow: 0 2px 8px rgba(0,0,0,.07);
  cursor: move;
  transition: box-shadow .15s, border-color .15s;
  z-index: 2;
}
.schema-map-node:hover      { border-color: var(--primary); box-shadow: 0 4px 18px rgba(22,100,229,.18); }
.schema-map-node.selected   { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(22,100,229,.18); }
.schema-map-node.dragging   { box-shadow: 0 8px 28px rgba(0,0,0,.18); z-index: 10; opacity:.92; }

.schema-map-node-header {
  padding: 8px 10px;
  background: var(--surface-2);
  border-bottom: 1px solid var(--border);
  border-radius: 8px 8px 0 0;
  display: flex; align-items: flex-start; justify-content: space-between;
  cursor: pointer;
}
.schema-map-node-header:hover { background: rgba(22,100,229,.06); }
.schema-map-node-name  { font-size: 11px; font-weight: 700; color: var(--text-1); }
.schema-map-node-ko    { font-size: 10px; color: var(--primary); margin-top: 1px; }
.schema-map-node-badge { font-size: 9px; color: var(--text-3); padding: 1px 5px; background: var(--bg); border-radius: 4px; white-space: nowrap; }

.schema-map-node-cols { padding: 4px 0; }
.schema-map-col {
  display: flex; gap: 5px; align-items: center;
  padding: 2px 10px; font-size: 10px;
  border-bottom: 1px solid rgba(0,0,0,.04);
}
.schema-map-col:last-child { border-bottom: none; }
.schema-map-col.pk { background: rgba(245,156,0,.07); }
.schema-map-col.fk { background: rgba(22,100,229,.06); }
.schema-map-col-icon { font-size: 9px; width: 12px; flex-shrink: 0; }
.schema-map-col-name { flex: 1; font-family: monospace; color: var(--text-1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.schema-map-col-type { color: var(--text-3); font-size: 9px; font-family: monospace; white-space: nowrap; }
.schema-map-node-more {
  text-align: center; padding: 4px; font-size: 10px;
  color: var(--text-3); border-top: 1px solid var(--border);
  border-radius: 0 0 8px 8px; cursor: pointer;
}
.schema-map-node-more:hover { color: var(--primary); background: rgba(22,100,229,.04); }

/* 스키마 내보내기 드롭다운 */
.schema-export-item {
  display: block; width: 100%; text-align: left;
  padding: 8px 14px; border: none; background: none; cursor: pointer;
  font-size: 12px; color: var(--text-1);
  transition: background .12s;
}
.schema-export-item:hover { background: rgba(22,100,229,.08); }

/* colored header override (JS sets inline background) */
.schema-map-node-header[style] { color: #fff; }
.schema-map-node-header[style] .schema-map-node-name { color: #fff; font-size: 11px; font-weight: 700; }
.schema-map-node-header[style] .schema-map-node-ko   { color: rgba(255,255,255,.8); font-size: 10px; }
.schema-map-node-header[style] .schema-map-node-badge{ background:rgba(255,255,255,.25); color:#fff; }

/* edit-mode col edit button */
.smap-col-edit-btn {
  margin-left: auto; flex-shrink: 0;
  background: none; border: 1px solid var(--border); border-radius: 3px;
  cursor: pointer; font-size: 10px; padding: 1px 4px; color: var(--text-3);
  line-height: 1; display: none;
}
.schema-map-node.edit-mode .smap-col-edit-btn { display: inline-flex; }
.smap-col-edit-btn:hover { background: var(--primary); color: #fff; border-color: var(--primary); }

/* ── 컨트롤 패널 ── */
.schema-map-controls {
  position: absolute; bottom: 14px; right: 14px;
  display: flex; flex-direction: column; gap: 5px; z-index: 20;
}
.schema-map-ctrl { display: flex; gap: 5px; }
.schema-map-btn {
  width: 32px; height: 32px; border-radius: 7px;
  border: 1px solid var(--border); background: var(--surface);
  cursor: pointer; font-size: 14px;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 6px rgba(0,0,0,.09);
  color: var(--text-1);
}
.schema-map-btn:hover { background: var(--surface-2); color: var(--primary); }
.schema-map-zoom-label {
  position: absolute; bottom: 60px; right: 14px;
  font-size: 10px; color: var(--text-3); z-index: 20;
  background: var(--surface); padding: 2px 6px; border-radius: 4px;
  border: 1px solid var(--border);
}

/* ── 범례 ── */
.schema-map-legend {
  position: absolute; top: 12px; left: 12px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 8px; padding: 8px 12px;
  font-size: 10px; z-index: 20; display: flex; flex-direction: column; gap: 5px;
}
.schema-legend-item { display: flex; align-items: center; gap: 6px; color: var(--text-2); }

/* ── 편집 툴바 (edit mode) ── */
.schema-edit-toolbar {
  position: absolute; top: 12px; right: 12px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 8px; padding: 8px 12px;
  display: flex; gap: 8px; align-items: center;
  font-size: 12px; z-index: 20;
  box-shadow: 0 2px 10px rgba(0,0,0,.1);
}

/* ══════════════════════════════════════════════════════════════
   Schema Detail Popup (노드 클릭 상세)
   ══════════════════════════════════════════════════════════════ */
.schema-detail-overlay {
  position: fixed; inset: 0; z-index: 9100;
  background: rgba(0,0,0,.6); backdrop-filter: blur(3px);
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
}
.schema-detail-modal {
  background: var(--surface) !important;
  border-radius: 14px;
  width: min(880px, 95vw); max-height: 88vh;
  display: flex; flex-direction: column;
  box-shadow: 0 24px 80px rgba(0,0,0,.4);
  overflow: hidden;
  isolation: isolate;
}
.schema-detail-head {
  padding: 14px 18px; border-bottom: 1px solid var(--border);
  background: var(--surface-2);
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
}
.schema-detail-title { font-size: 15px; font-weight: 700; color: var(--text-1); }
.schema-detail-subtitle { font-size: 12px; color: var(--primary); margin-top: 2px; }
.schema-detail-stats { display: flex; gap: 12px; font-size: 11px; color: var(--text-3); }
.schema-detail-stat { display: flex; flex-direction: column; align-items: center; }
.schema-detail-stat strong { font-size: 16px; font-weight: 700; color: var(--text-1); }
.schema-detail-body { flex: 1; overflow-y: auto; padding: 0; }
.schema-detail-section { padding: 14px 18px; border-bottom: 1px solid var(--border); }
.schema-detail-section:last-child { border-bottom: none; }
.schema-detail-section-title {
  font-size: 11px; font-weight: 700; color: var(--text-2);
  text-transform: uppercase; letter-spacing: .06em; margin-bottom: 10px;
  display: flex; align-items: center; gap: 6px;
}
.schema-detail-table {
  width: 100%; border-collapse: collapse; font-size: 12px;
}
.schema-detail-table th {
  background: var(--surface-2); padding: 7px 10px; text-align: left;
  font-size: 11px; font-weight: 600; color: var(--text-2);
  border-bottom: 2px solid var(--border);
  position: sticky; top: 0; z-index: 2;
}
.schema-detail-table td {
  padding: 6px 10px; border-bottom: 1px solid var(--border);
  color: var(--text-1); font-size: 11px; vertical-align: middle;
}
.schema-detail-table tr:last-child td { border-bottom: none; }
.schema-detail-table tr.pk-row  td { background: rgba(245,156,0,.06); }
.schema-detail-table tr.fk-row  td { background: rgba(22,100,229,.06); }
.schema-detail-table tr.idx-row td { background: rgba(23,168,90,.04); }
.schema-col-badge {
  display: inline-block; padding: 1px 5px; border-radius: 3px;
  font-size: 9px; font-weight: 700;
}
.schema-col-badge.pk   { background: rgba(245,156,0,.2); color: #b97500; }
.schema-col-badge.fk   { background: rgba(22,100,229,.15); color: var(--primary); }
.schema-col-badge.idx  { background: rgba(23,168,90,.15); color: #17a85a; }
.schema-col-badge.uni  { background: rgba(124,77,255,.15); color: #7c4dff; }
.schema-col-badge.nn   { background: rgba(220,53,69,.12); color: #dc3545; }
.schema-col-badge.null { background: rgba(0,0,0,.06); color: var(--text-3); }
.schema-type-pill {
  font-family: monospace; font-size: 10px; padding: 1px 6px;
  background: var(--surface-2); border-radius: 4px; color: var(--text-2);
}
.schema-detail-fk-arrow { color: var(--primary); font-weight: 700; }
.schema-detail-foot {
  padding: 12px 18px; border-top: 1px solid var(--border);
  background: var(--surface-2);
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
}

/* ══════════════════════════════════════════════════════════════
   Schema Drift — 변경 감지 시 노드·카드 하이라이트
   ══════════════════════════════════════════════════════════════ */

/* 리스트 카드 drift */
.schema-card.schema-drift {
  border-color: rgba(220,53,69,.5) !important;
  background: rgba(220,53,69,.04) !important;
  animation: driftPulse 2s ease infinite;
}
@keyframes driftPulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(220,53,69,0); }
  50%      { box-shadow: 0 0 0 4px rgba(220,53,69,.12); }
}
/* 연관도 노드 drift */
.schema-map-node.schema-drift {
  border-color: rgba(220,53,69,.6) !important;
  background: rgba(220,53,69,.05) !important;
  animation: driftPulse 2s ease infinite;
}
.schema-map-node.schema-drift .schema-map-node-header {
  background: rgba(220,53,69,.12) !important;
}
/* drift 배지 (카드 헤더 안) */
.schema-drift-badge {
  font-size: 9px; font-weight: 700; padding: 1px 6px; border-radius: 4px;
  background: rgba(220,53,69,.15); color: #dc3545;
  border: 1px solid rgba(220,53,69,.3);
  animation: driftPulse 2s ease infinite;
}

/* ══════════════════════════════════════════════════════════════
   Schema Sync Button — 상태별 스타일
   ══════════════════════════════════════════════════════════════ */
.schema-sync-btn {
  position: relative; gap: 5px;
  transition: all .2s;
}
.schema-sync-btn.has-changes {
  background: rgba(245,156,0,.12) !important;
  border-color: rgba(245,156,0,.5) !important;
  color: #b97500 !important;
  font-weight: 600;
}
.schema-sync-btn.has-changes:hover {
  background: rgba(245,156,0,.2) !important;
}
.schema-sync-btn.syncing {
  opacity: .7; cursor: not-allowed;
}
.schema-sync-btn.just-changed {
  background: rgba(23,168,90,.1) !important;
  border-color: rgba(23,168,90,.4) !important;
  color: #17a85a !important;
}
.schema-sync-btn.just-clean {
  background: rgba(22,100,229,.08) !important;
  border-color: rgba(22,100,229,.3) !important;
  color: var(--primary) !important;
}
/* 버튼 안 변경 건수 뱃지 */
.sync-badge {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 16px; height: 16px; padding: 0 4px;
  background: #f59c00; color: #fff;
  border-radius: 8px; font-size: 10px; font-weight: 700;
  line-height: 1;
}
/* 버튼 안 스피너 */
.sync-spinner {
  display: inline-block; width: 12px; height: 12px;
  border: 2px solid var(--border); border-top-color: var(--primary);
  border-radius: 50%; animation: spin .7s linear infinite;
  vertical-align: middle;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ══════════════════════════════════════════════════════════════
   WS 연결 상태 표시
   ══════════════════════════════════════════════════════════════ */
.schema-ws-dot {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 11px; color: var(--text-3);
  padding: 3px 8px; border-radius: 20px;
  background: var(--surface-2); border: 1px solid var(--border);
  user-select: none;
}
.schema-ws-indicator {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--border); flex-shrink: 0;
  transition: background .3s;
}
.schema-ws-dot.connected .schema-ws-indicator  { background: #17a85a; box-shadow: 0 0 0 2px rgba(23,168,90,.25); }
.schema-ws-dot.connected .schema-ws-label      { color: #17a85a; font-weight: 600; }
.schema-ws-dot.disconnected .schema-ws-indicator { background: #dc3545; }
.schema-ws-dot.disconnected .schema-ws-label    { color: #dc3545; }

/* ══════════════════════════════════════════════════════════════
   Schema Impact Panel (자동 변경감지 + 위험 분석)
   ══════════════════════════════════════════════════════════════ */
.schema-impact-wrap {
  margin-top: 12px; border-radius: 10px;
  border: 1px solid var(--border); overflow: hidden;
  animation: impactSlideIn .3s ease;
}
@keyframes impactSlideIn { from { opacity:0; transform:translateY(-8px); } to { opacity:1; transform:translateY(0); } }
.schema-impact-head {
  padding: 10px 16px; display: flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 700; cursor: pointer;
}
.schema-impact-head.risk-high   { background: rgba(220,53,69,.13); color: #dc3545; }
.schema-impact-head.risk-medium { background: rgba(245,156,0,.13); color: #c47800; }
.schema-impact-head.risk-low    { background: rgba(23,168,90,.13); color: #17a85a; }
.schema-impact-head.risk-none   { background: rgba(22,100,229,.08); color: var(--primary); }
.schema-impact-body { padding: 12px 16px; background: var(--surface); }
.schema-impact-item {
  display: flex; gap: 10px; align-items: flex-start;
  padding: 7px 0; border-bottom: 1px solid var(--border); font-size: 12px;
}
.schema-impact-item:last-child { border-bottom: none; }
.schema-impact-badge {
  flex-shrink: 0; padding: 2px 7px; border-radius: 4px;
  font-size: 10px; font-weight: 700; margin-top: 1px;
}
.schema-impact-badge.add    { background: rgba(23,168,90,.15); color: #17a85a; }
.schema-impact-badge.drop   { background: rgba(220,53,69,.15); color: #dc3545; }
.schema-impact-badge.modify { background: rgba(245,156,0,.15); color: #c47800; }
.schema-impact-badge.new    { background: rgba(22,100,229,.12); color: var(--primary); }
.schema-impact-risks { margin-top: 10px; padding: 10px; background: rgba(220,53,69,.05); border-radius: 6px; }
.schema-impact-risks ul { margin: 4px 0 0 16px; padding: 0; font-size: 11px; color: var(--text-2); }
.schema-impact-risks li { margin-bottom: 3px; }
.schema-impact-strategies { margin-top: 8px; padding: 10px; background: rgba(23,168,90,.05); border-radius: 6px; }
.schema-impact-strategies ul { margin: 4px 0 0 16px; padding: 0; font-size: 11px; color: var(--text-2); }
.schema-impact-strategies li { margin-bottom: 3px; }
.schema-edit-sql-preview {
  font-family: monospace; font-size: 11px; padding: 10px; background: var(--bg);
  border: 1px solid var(--border); border-radius: 6px; white-space: pre-wrap;
  color: var(--text-1); max-height: 120px; overflow-y: auto;
}

/* ── 성능 모니터 ─────────────────────────────────────────────── */
.perf-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 20px;
}

.perf-summary-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 16px;
  text-align: center;
}

.perf-summary-card.err { border-color: var(--oci-red); }

.psv {
  font-size: 24px;
  font-weight: 700;
  color: var(--text-1);
  font-family: 'IBM Plex Mono', monospace;
  margin-bottom: 4px;
}

.psl {
  font-size: 11px;
  color: var(--text-3);
}

.perf-legend {
  font-size: 11px;
  color: var(--text-3);
  margin-bottom: 12px;
  display: flex;
  gap: 12px;
}

.perf-bar-chart {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.perf-bar-row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.perf-hour {
  font-size: 11px;
  color: var(--text-3);
  font-family: monospace;
  width: 80px;
  flex-shrink: 0;
}

.perf-bar-wrap {
  flex: 1;
  background: var(--surface-2);
  border-radius: 3px;
  height: 14px;
  overflow: hidden;
}

.perf-bar {
  height: 100%;
  border-radius: 3px;
  min-width: 2px;
  transition: width 0.3s;
}

.perf-req-count {
  font-size: 11px;
  color: var(--text-2);
  width: 50px;
  text-align: right;
  font-family: monospace;
}

.perf-avg {
  font-size: 11px;
  font-family: monospace;
  width: 50px;
  text-align: right;
}

.perf-err {
  font-size: 10px;
  color: var(--oci-red);
  font-weight: 600;
}

/* ══════════════════════════════════════════════════════════════
   에러 로그 뷰어 모달
   ══════════════════════════════════════════════════════════════ */
.errlog-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  z-index: 2100;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  animation: fadeIn .15s ease;
}

.errlog-modal {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  width: 100%;
  max-width: 1080px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 24px 64px rgba(0,0,0,.3);
}

.errlog-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 20px 24px 16px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

.errlog-filters {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 24px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  flex-wrap: wrap;
}

.errlog-tab-group {
  display: flex;
  gap: 4px;
  background: var(--surface-2);
  border-radius: 8px;
  padding: 3px;
}

.errlog-tab {
  background: none;
  border: none;
  cursor: pointer;
  padding: 5px 14px;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-3);
  transition: all .15s;
}
.errlog-tab:hover { color: var(--text-1); background: var(--surface-3); }
.errlog-tab.active { background: var(--surface); color: var(--text-1); box-shadow: 0 1px 4px rgba(0,0,0,.12); }

.errlog-filter-right {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-left: auto;
  flex-wrap: wrap;
}

.form-input-sm {
  padding: 5px 10px;
  font-size: 12px;
  height: 32px;
  border-radius: 6px;
}

/* errlog-dist-row 정의는 아래 "상단 배지 — 클릭 필터" 섹션에 통합 */

.errlog-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 12px;
  font-family: 'IBM Plex Mono', monospace;
}
.errlog-badge strong { font-size: 13px; }
.errlog-badge-5xx { background: rgba(230,51,41,.12); color: #E63329; border: 1px solid rgba(230,51,41,.25); }
.errlog-badge-401 { background: rgba(245,156,0,.12); color: #B87300; border: 1px solid rgba(245,156,0,.3); }
.errlog-badge-404 { background: rgba(138,110,255,.12); color: #6B4FE0; border: 1px solid rgba(138,110,255,.25); }
.errlog-badge-4xx { background: rgba(0,120,212,.1); color: #0078D4; border: 1px solid rgba(0,120,212,.25); }

.errlog-table-wrap {
  overflow-y: auto;
  flex: 1;
  min-height: 0;
}

.errlog-table {
  width: 100%;
  font-size: 12px;
}
.errlog-table tbody tr:hover { background: var(--surface-2); }

.errlog-path {
  max-width: 280px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.errlog-sc {
  display: inline-block;
  padding: 2px 7px;
  border-radius: 5px;
  font-size: 11px;
  font-weight: 700;
  font-family: monospace;
}
.errlog-sc-5xx { background: rgba(230,51,41,.12); color: #E63329; }
.errlog-sc-401 { background: rgba(245,156,0,.12); color: #B87300; }
.errlog-sc-404 { background: rgba(138,110,255,.12); color: #6B4FE0; }
.errlog-sc-4xx { background: rgba(0,120,212,.1); color: #0078D4; }

.errlog-loading,
.errlog-empty {
  padding: 48px;
  text-align: center;
  color: var(--text-3);
  font-size: 14px;
}

.errlog-pagination {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 24px;
  border-top: 1px solid var(--border);
  flex-shrink: 0;
}

.errlog-total {
  font-size: 12px;
  color: var(--text-3);
  margin-right: auto;
}

.errlog-page-group { display: flex; gap: 4px; flex-wrap: wrap; }

.errlog-page-btn {
  min-width: 32px;
  height: 32px;
  padding: 0 8px;
  border: 1px solid var(--border);
  background: var(--surface);
  border-radius: 6px;
  font-size: 12px;
  cursor: pointer;
  color: var(--text-2);
  transition: all .15s;
}
.errlog-page-btn:hover:not([disabled]) { background: var(--surface-2); color: var(--text-1); }
.errlog-page-btn.active { background: var(--oci-blue); color: #fff; border-color: var(--oci-blue); font-weight: 600; }
.errlog-page-btn[disabled] { opacity: .35; cursor: not-allowed; }

.errlog-page-ellipsis {
  display: flex;
  align-items: center;
  padding: 0 4px;
  color: var(--text-3);
  font-size: 13px;
}

/* 성능 모니터 에러 카드 hover */
.perf-summary-card.perf-err-card {
  transition: all .2s ease;
}
.perf-summary-card.perf-err-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(230,51,41,.2);
}

/* ── 등급 배지 (severity) ───────────────────────────────────── */
.errsev-pill {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 20px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .3px;
  white-space: nowrap;
}
.errsev-critical { background: rgba(230,51,41,.13); color: #C0211A; border: 1px solid rgba(230,51,41,.3); }
.errsev-major    { background: rgba(245,156,0,.13);  color: #9A6000; border: 1px solid rgba(245,156,0,.3); }
.errsev-minor    { background: rgba(0,120,212,.1);   color: #005EA6; border: 1px solid rgba(0,120,212,.22); }

/* ── 유형 배지 (error type) ─────────────────────────────────── */
.errtype-pill {
  display: inline-block;
  padding: 2px 7px;
  border-radius: 4px;
  font-size: 10px;
  font-weight: 600;
  white-space: nowrap;
}
.errtype-logic    { background: rgba(230,51,41,.1);   color: #C0211A; }
.errtype-auth     { background: rgba(245,156,0,.1);   color: #9A6000; }
.errtype-notfound { background: rgba(138,110,255,.1); color: #5B3EC0; }
.errtype-conflict { background: rgba(50,180,80,.1);   color: #1A6E30; }
.errtype-ratelimit{ background: rgba(0,0,0,.07);      color: var(--text-2); }
.errtype-client   { background: rgba(0,120,212,.08);  color: #005EA6; }
.errtype-other    { background: var(--surface-2);     color: var(--text-3); }

/* ── 분포 배지 내 유형 레이블 ────────────────────────────────── */
.errlog-badge-type {
  font-size: 10px;
  opacity: .75;
  margin-left: 3px;
  font-weight: 400;
}

/* ── 등급 요약 (dist 행 오른쪽) ──────────────────────────────── */
.errlog-sev-summary {
  display: flex;
  gap: 6px;
  align-items: center;
  margin-left: auto;
}

/* ── 행 클릭 활성화 + 분석 패널 ─────────────────────────────── */
.errlog-row-active td { background: rgba(0,120,212,.06); }
.errlog-row:hover td  { background: var(--surface-2); }

.errlog-detail-cell {
  padding: 0 !important;
  background: var(--surface-2) !important;
  border-top: none !important;
}

.errlog-analysis {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  padding: 14px 20px;
  border-top: 2px solid var(--oci-blue);
}

.errlog-analysis-cause strong,
.errlog-analysis-guide strong {
  display: block;
  font-size: 12px;
  color: var(--text-1);
  margin-bottom: 6px;
}

.errlog-analysis-cause p {
  margin: 0;
  font-size: 12px;
  color: var(--text-2);
  line-height: 1.6;
}

.errlog-analysis-guide ol {
  margin: 0;
  padding-left: 18px;
}
.errlog-analysis-guide ol li {
  font-size: 12px;
  color: var(--text-2);
  margin-bottom: 4px;
  line-height: 1.5;
}

/* 다크모드 */
[data-theme="dark"] .errsev-critical { color: #FF6B65; }
[data-theme="dark"] .errsev-major    { color: #F5A623; }
[data-theme="dark"] .errsev-minor    { color: #4AACFF; }
[data-theme="dark"] .errtype-logic   { color: #FF6B65; }
[data-theme="dark"] .errtype-auth    { color: #F5A623; }
[data-theme="dark"] .errtype-notfound{ color: #9B85FF; }
[data-theme="dark"] .errtype-conflict{ color: #4CAF72; }
[data-theme="dark"] .errtype-client  { color: #4AACFF; }

/* ── 상단 배지 — 클릭 필터 ─────────────────────────────────── */
.errlog-dist-row {
  display: flex;
  flex-direction: column;
  align-items: flex-start;          /* 좌측 정렬 통일 */
  gap: 10px;                         /* 행 간격 균등 */
  padding: 12px 20px;
  background: var(--surface-2);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

.errlog-dist-badges,
.errlog-resolved-pills {
  display: flex;
  gap: 7px;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;       /* 좌측 시작점 동기화 */
  width: 100%;
  margin: 0;                         /* 행간 gap에 통제권 위임 */
}

.errlog-dist-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 11px;
  border-radius: 20px;
  font-size: 12px;
  cursor: pointer;
  transition: all .15s;
  user-select: none;
}
.errlog-dist-badge:hover { opacity: .8; transform: translateY(-1px); }
.errlog-dist-badge.active {
  box-shadow: 0 0 0 2px currentColor;
  font-weight: 700;
}

.errlog-badge-sc   { font-weight: 700; font-family: monospace; }
.errlog-badge-type { opacity: .75; font-size: 10px; }
.errlog-badge-cnt  { font-weight: 600; margin-left: 2px; }
.errlog-badge-resolved-mini {
  font-size: 9px;
  opacity: .6;
  margin-left: 2px;
  background: rgba(23,168,90,.15);
  color: #17A85A;
  padding: 1px 4px;
  border-radius: 8px;
}

.errlog-loading-mini {
  font-size: 12px;
  color: var(--text-4);
  padding: 4px 0;
}

/* ── 잔여/조치완료 알약 ─────────────────────────────────────── */
/* (.errlog-resolved-pills 는 .errlog-dist-badges 와 함께 위쪽에 통합 정의) */

.errlog-resolved-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 11px;                 /* dist-badge 와 동일한 패딩 */
  border-radius: 20px;
  font-size: 12px;
  cursor: pointer;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text-2);
  transition: all .15s;
  user-select: none;
}
.errlog-resolved-pill:hover { background: var(--surface-3); }
.errlog-resolved-pill.active[data-resolved="all"]      { background: var(--oci-blue); color: #fff; border-color: var(--oci-blue); }
.errlog-resolved-pill.active[data-resolved="pending"]  { background: rgba(230,51,41,.1); color: #C0211A; border-color: rgba(230,51,41,.35); font-weight: 600; }
.errlog-resolved-pill.active[data-resolved="resolved"] { background: rgba(23,168,90,.1); color: #17A85A; border-color: rgba(23,168,90,.35); font-weight: 600; }
.errlog-resolved-pill strong { font-size: 13px; }

/* ── 조치 상태 컬럼 ─────────────────────────────────────────── */
.errlog-status-cell {
  display: flex;
  justify-content: center;
  cursor: pointer;
}
.errlog-status-cell:hover .errlog-status-badge { opacity: .75; }

.errlog-status-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 9px;
  border-radius: 12px;
  font-size: 10px;
  font-weight: 600;
  white-space: nowrap;
  transition: opacity .15s;
}
.errlog-status-badge.resolved {
  background: rgba(23,168,90,.12);
  color: #17A85A;
  border: 1px solid rgba(23,168,90,.28);
}
.errlog-status-badge.pending {
  background: rgba(230,51,41,.08);
  color: #C0211A;
  border: 1px solid rgba(230,51,41,.22);
}

/* 조치완료 행 — 흐리게 */
.errlog-row-resolved td { opacity: .55; }
.errlog-row-resolved:hover td { opacity: .85; }

/* ── 분석 패널 빠른 조치 영역 ──────────────────────────────── */
.errlog-analysis {
  display: grid;
  grid-template-columns: 1fr 1fr auto;
  gap: 16px;
  padding: 14px 20px;
  border-top: 2px solid var(--oci-blue);
}

.errlog-analysis-actions strong {
  display: block;
  font-size: 12px;
  color: var(--text-1);
  margin-bottom: 6px;
}

.errlog-action-btn {
  font-size: 11px;
  padding: 4px 10px;
  white-space: nowrap;
}

/* ── 토스트 알림 ────────────────────────────────────────────── */
.errlog-toast {
  position: fixed;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%);
  background: #1A1A1A;
  color: #fff;
  padding: 10px 20px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 500;
  z-index: 9999;
  animation: fadeInUp .2s ease, fadeOut .3s ease 2.5s forwards;
  box-shadow: 0 4px 16px rgba(0,0,0,.3);
  pointer-events: none;
}
.errlog-toast-err { background: #C0211A; }
@keyframes fadeInUp {
  from { opacity:0; transform: translateX(-50%) translateY(12px); }
  to   { opacity:1; transform: translateX(-50%) translateY(0); }
}
@keyframes fadeOut {
  to { opacity: 0; }
}

/* 다크모드 에러 로그 */
[data-theme="dark"] .errlog-badge-401 { color: #F59C00; }
[data-theme="dark"] .errlog-badge-404 { color: #9B85FF; }
[data-theme="dark"] .errlog-badge-4xx { color: #4AACFF; }
[data-theme="dark"] .errlog-sc-401    { color: #F59C00; }
[data-theme="dark"] .errlog-sc-404    { color: #9B85FF; }
[data-theme="dark"] .errlog-sc-4xx    { color: #4AACFF; }
[data-theme="dark"] .errlog-status-badge.resolved { color: #4CAF72; }
[data-theme="dark"] .errlog-status-badge.pending  { color: #FF6B65; }
[data-theme="dark"] .errlog-resolved-pill.active[data-resolved="pending"]  { color: #FF6B65; }
[data-theme="dark"] .errlog-resolved-pill.active[data-resolved="resolved"] { color: #4CAF72; }

/* ── 스마트 자동 분류 버튼 ─────────────────────────────────── */
.errlog-auto-btn {
  background: rgba(0,120,212,.1);
  color: var(--oci-blue);
  border: 1px solid rgba(0,120,212,.25);
  font-size: 12px;
}
.errlog-auto-btn:hover { background: rgba(0,120,212,.18); }

/* ── 자동 분류 패널 (모달 위에 뜨는 서브 모달) ──────────────── */
.errlog-auto-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.4);
  z-index: 2200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  animation: fadeIn .15s ease;
}

.errlog-auto-modal {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  width: 100%;
  max-width: 600px;
  box-shadow: 0 24px 64px rgba(0,0,0,.35);
  overflow: hidden;
}

.errlog-auto-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: 18px 20px 14px;
  border-bottom: 1px solid var(--border);
}

.errlog-auto-body {
  padding: 16px 20px;
}

.errlog-auto-empty {
  text-align: center;
  padding: 32px;
  color: var(--text-3);
  font-size: 13px;
}

.errlog-auto-summary {
  font-size: 13px;
  color: var(--text-2);
  margin-bottom: 14px;
  padding: 10px 14px;
  background: rgba(0,120,212,.07);
  border-radius: 8px;
  border-left: 3px solid var(--oci-blue);
}
.errlog-auto-summary strong { color: var(--text-1); font-size: 15px; }

.errlog-auto-rules {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 16px;
}

.errlog-auto-rule {
  padding: 10px 14px;
  border-radius: 8px;
  border: 1px solid var(--border);
}
.errlog-auto-rule.has-items { border-color: rgba(23,168,90,.3); background: rgba(23,168,90,.04); }
.errlog-auto-rule.no-items  { opacity: .5; }

.errlog-auto-rule-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.errlog-auto-rule-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-1);
}

.errlog-auto-rule-cnt {
  font-size: 11px;
  font-family: monospace;
  padding: 2px 8px;
  border-radius: 10px;
  background: var(--surface-2);
  color: var(--text-3);
  white-space: nowrap;
}
.errlog-auto-rule-cnt.has-cnt {
  background: rgba(23,168,90,.12);
  color: #17A85A;
  font-weight: 700;
}

.errlog-auto-rule-note {
  font-size: 11px;
  color: var(--text-3);
  margin-top: 5px;
}

.errlog-auto-actions {
  border-top: 1px solid var(--border);
  padding-top: 14px;
  margin-top: 4px;
}

/* ── JWT 인스펙터 ────────────────────────────────────────────── */
.jwt-status {
  padding: 10px 16px;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 600;
  margin-bottom: 16px;
}

.jwt-status.valid   { background: rgba(23,168,90,.12); color: #17A85A; border: 1px solid rgba(23,168,90,.3); }
.jwt-status.expired { background: rgba(230,51,41,.1);  color: var(--oci-red); border: 1px solid rgba(230,51,41,.3); }

.jwt-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 14px;
}

.jwt-section {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
}

.jwt-section-title {
  padding: 8px 14px;
  font-size: 12px;
  font-weight: 700;
  background: var(--surface-2);
  border-bottom: 1px solid var(--border);
  color: var(--text-2);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.jwt-pre {
  margin: 0;
  padding: 12px 14px;
  font-size: 11px;
  font-family: 'IBM Plex Mono', monospace;
  background: transparent;
  color: var(--text-1);
  white-space: pre-wrap;
  word-break: break-all;
  overflow: auto;
  max-height: 260px;
}

.jwt-meta {
  padding: 8px 14px;
  font-size: 11px;
  color: var(--text-2);
  border-top: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 2px;
}

/* ── 소스 모니터 ─────────────────────────────────────────────── */
.src-stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
  margin-top: 8px;
}

.src-stat-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  transition: transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease;
}
.src-stat-card:hover {
  transform: translateY(-1px);
  border-color: var(--border-2);
  box-shadow: 0 2px 8px rgba(0,0,0,.04);
}
.src-stat-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: 0.4px;
}
.src-stat-value {
  font-size: 24px;
  font-weight: 700;
  color: var(--text-1);
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
}
.src-stat-sub {
  font-size: 11px;
  color: var(--text-3);
}

/* 카테고리 막대 */
.src-cat-bars {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.src-cat-row {
  display: grid;
  grid-template-columns: 180px 1fr 320px;
  align-items: center;
  gap: 10px;
  padding: 7px 10px;
  border-radius: 6px;
  cursor: pointer;
  transition: background 120ms ease;
}
.src-cat-row:hover { background: var(--surface-2); }
.src-cat-name {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-1);
}
.src-cat-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.src-cat-key {
  font-size: 10px;
  color: var(--text-3);
  font-family: 'IBM Plex Mono', monospace;
  font-weight: 400;
}
.src-cat-bar-track {
  height: 8px;
  background: var(--surface-3);
  border-radius: 4px;
  overflow: hidden;
}
.src-cat-bar-fill {
  height: 100%;
  border-radius: 4px;
  transition: width 250ms ease;
}
.src-cat-stat {
  display: flex;
  gap: 12px;
  font-size: 11px;
  color: var(--text-2);
  font-variant-numeric: tabular-nums;
  justify-content: flex-end;
}
.src-cat-stat .src-cat-loc {
  font-weight: 700;
  color: var(--text-1);
}
.src-cat-stat .src-cat-size {
  color: var(--text-3);
}

/* Metro Treemap — CSS grid 기반 */
.src-treemap {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: 56px;
  grid-auto-flow: dense;
  gap: 6px;
}
.src-tile {
  background: var(--tile-color, #94a3b8);
  border-radius: 6px;
  padding: 8px 10px;
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  cursor: pointer;
  overflow: hidden;
  transition: transform 120ms ease, box-shadow 120ms ease, filter 120ms ease;
  position: relative;
}
.src-tile:hover {
  transform: translateY(-1px) scale(1.01);
  filter: brightness(1.08);
  box-shadow: 0 4px 12px rgba(0,0,0,.18);
  z-index: 1;
}
.src-tile-name {
  font-size: 11px;
  font-weight: 700;
  line-height: 1.2;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.src-tile-loc {
  font-size: 18px;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  line-height: 1;
}
.src-tile-cat {
  font-size: 9px;
  opacity: 0.85;
  text-transform: uppercase;
  letter-spacing: 0.4px;
}

/* 타일 크기 단계 — Metro 스타일 */
.src-tile-xl { grid-column: span 4; grid-row: span 3; }
.src-tile-lg { grid-column: span 3; grid-row: span 2; }
.src-tile-md { grid-column: span 2; grid-row: span 2; }
.src-tile-sm { grid-column: span 2; grid-row: span 1; }
.src-tile-xs { grid-column: span 1; grid-row: span 1; }

.src-tile-xl .src-tile-loc { font-size: 32px; }
.src-tile-lg .src-tile-loc { font-size: 24px; }
.src-tile-md .src-tile-loc { font-size: 18px; }
.src-tile-sm .src-tile-loc { font-size: 14px; }
.src-tile-xs .src-tile-loc { font-size: 11px; }
.src-tile-xs .src-tile-cat { display: none; }

/* 파일 목록 */
.src-file-filters {
  display: flex;
  gap: 8px;
  align-items: center;
}
.src-file-table {
  font-size: 12px;
}
.src-file-table th {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  color: var(--text-3);
  background: var(--surface-2);
}
.src-file-table td {
  vertical-align: middle;
  padding: 8px 12px;
}
.src-cat-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 600;
  white-space: nowrap;
}

/* 다크 테마 — Metro 카테고리 색 조정 (배경 대비 유지) */
[data-theme='dark'] .src-stat-card { background: var(--surface); }
[data-theme='dark'] .src-cat-row:hover { background: rgba(255,255,255,.04); }

/* Source Monitor 서브 탭 */
.src-shell { display: flex; flex-direction: column; gap: 12px; }
.src-subtabs {
  display: flex;
  gap: 4px;
  border-bottom: 1px solid var(--border);
  padding-bottom: 0;
}
.src-subtab {
  background: transparent;
  border: 0;
  padding: 8px 14px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-3);
  cursor: pointer;
  border-radius: 6px 6px 0 0;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color 120ms, border-color 120ms, background 120ms;
}
.src-subtab:hover { color: var(--text-1); background: var(--surface-2); }
.src-subtab.active {
  color: var(--oci-red, #e63329);
  border-bottom-color: var(--oci-red, #e63329);
  background: var(--surface);
}

/* Quality — 규칙별 막대 */
.src-rule-list { display: flex; flex-direction: column; gap: 4px; }
.src-rule-row {
  display: grid;
  grid-template-columns: 260px 1fr 180px;
  align-items: center;
  gap: 12px;
  padding: 6px 10px;
  border-radius: 6px;
}
.src-rule-row:hover { background: var(--surface-2); }
.src-rule-name {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
}
.src-rule-name code {
  background: var(--surface-3);
  padding: 2px 6px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
}
.src-rule-files {
  font-size: 10px;
  color: var(--text-3);
  white-space: nowrap;
}
.src-rule-bar-track {
  height: 8px;
  background: var(--surface-3);
  border-radius: 4px;
  overflow: hidden;
}
.src-rule-bar-fill {
  height: 100%;
  border-radius: 4px;
  transition: width 250ms ease;
}
.src-rule-counts {
  display: flex;
  gap: 6px;
  justify-content: flex-end;
}
.src-rule-pill {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 11px;
  font-weight: 600;
  white-space: nowrap;
}

/* Security — 심각도 카드 활성 상태 */
.src-sev-card {
  transition: transform 120ms ease, box-shadow 120ms ease;
}
.src-sev-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
.src-sev-card.is-active {
  outline: 2px solid currentColor;
  outline-offset: -2px;
}

/* Complexity 카드 — 동일한 호버 효과 */
.src-cx-card {
  transition: transform 120ms ease, box-shadow 120ms ease;
}
.src-cx-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}

/* Trend — 스파크라인 카드 */
.src-spark-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 12px;
  margin-top: 8px;
}
.src-spark-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.src-spark-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: 0.4px;
}
.src-spark-value {
  font-size: 22px;
  font-weight: 700;
  color: var(--text-1);
  font-variant-numeric: tabular-nums;
  line-height: 1;
}
.src-spark {
  display: block;
  width: 100%;
  height: auto;
  margin-top: 2px;
}
.src-spark-delta {
  font-size: 11px;
  font-variant-numeric: tabular-nums;
  margin-top: 2px;
}

/* Trend 표의 작은 삭제 버튼 */
.src-snap-del.btn-xs {
  padding: 2px 8px;
  font-size: 11px;
  border-radius: 4px;
}

/* 반응형 */
@media (max-width: 900px) {
  .src-cat-row {
    grid-template-columns: 1fr;
    gap: 4px;
  }
  .src-cat-stat { justify-content: flex-start; }
  .src-treemap { grid-template-columns: repeat(6, 1fr); }
  .src-tile-xl { grid-column: span 6; grid-row: span 2; }
  .src-tile-lg { grid-column: span 4; grid-row: span 2; }
  .src-tile-md { grid-column: span 3; }
  .src-file-filters { flex-wrap: wrap; }
  .src-rule-row { grid-template-columns: 1fr; gap: 4px; }
  .src-subtabs { overflow-x: auto; }
  .src-subtab { white-space: nowrap; }
}

/* ── 개발 로드맵 ─────────────────────────────────────────────── */
.roadmap-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 14px;
  margin-bottom: 24px;
}

.roadmap-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 16px;
  transition: box-shadow 0.15s;
}

.roadmap-card:hover {
  box-shadow: 0 4px 12px rgba(0,0,0,.1);
}

.roadmap-card.done {
  border-left: 4px solid #17A85A;
}

.roadmap-card.planned {
  border-left: 4px solid var(--border);
}

.roadmap-card-header {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 8px;
}

.roadmap-icon {
  font-size: 20px;
  flex-shrink: 0;
}

.roadmap-title {
  flex: 1;
  font-size: 13px;
  font-weight: 700;
  color: var(--text-1);
  line-height: 1.3;
}

.roadmap-status-badge {
  font-size: 10px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 10px;
  flex-shrink: 0;
}

.roadmap-status-badge.done    { background: rgba(23,168,90,.15); color: #17A85A; }
.roadmap-status-badge.planned { background: var(--surface-2);    color: var(--text-3); }

.roadmap-desc {
  font-size: 12px;
  color: var(--text-2);
  line-height: 1.5;
  margin-bottom: 12px;
}

.roadmap-meta {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.roadmap-chip {
  font-size: 11px;
  padding: 3px 9px;
  border-radius: 5px;
}

.roadmap-chip.impact { background: rgba(22,100,229,.1); color: #1664E5; }
.roadmap-chip.effort { background: rgba(245,156,0,.1);  color: #b57800; }

.roadmap-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
}

.roadmap-dot.done    { background: #17A85A; }
.roadmap-dot.planned { background: var(--border); }

/* ── 커스텀 개발 가이드 ──────────────────────────────────────── */
.dev-guide-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
}

.dev-guide-item {
  background: var(--surface-2);
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid var(--border);
}

.dev-guide-title {
  padding: 10px 14px;
  font-size: 12px;
  font-weight: 700;
  color: var(--text-1);
  background: var(--surface);
  border-bottom: 1px solid var(--border);
}

.dev-guide-code {
  margin: 0;
  padding: 12px 14px;
  font-size: 11px;
  font-family: 'IBM Plex Mono', monospace;
  color: var(--text-1);
  background: transparent;
  white-space: pre;
  overflow-x: auto;
  line-height: 1.5;
}

/* ── 다크 모드 오버라이드 ────────────────────────────────────── */
[data-theme="dark"] .dev-toggle-slider::before {
  box-shadow: 0 1px 3px rgba(0,0,0,.6);
}

[data-theme="dark"] .dfd-node {
  background: var(--surface-2);
}

[data-theme="dark"] .dev-guide-code,
[data-theme="dark"] .jwt-pre {
  color: #e2e8f0;
}

/* 다크 테마 — schema drift / sync */
[data-theme="dark"] .schema-card.schema-drift {
  border-color: rgba(248,113,113,.5) !important;
  background: rgba(220,53,69,.08) !important;
}
[data-theme="dark"] .schema-map-node.schema-drift {
  border-color: rgba(248,113,113,.6) !important;
  background: rgba(220,53,69,.1) !important;
}
[data-theme="dark"] .schema-sync-btn.has-changes {
  background: rgba(245,156,0,.18) !important;
  border-color: rgba(245,156,0,.6) !important;
}
[data-theme="dark"] .schema-ws-dot {
  background: var(--surface-3);
}

/* ── 반응형 ──────────────────────────────────────────────────── */
@media (max-width: 900px) {
  .dev-feature-grid   { grid-template-columns: 1fr; }
  .jwt-grid           { grid-template-columns: 1fr; }
  .perf-summary-grid  { grid-template-columns: repeat(2, 1fr); }
  .dfd-board          { grid-template-columns: 1fr; grid-template-rows: none; }
  .dfd-svg            { display: none; }
  .dfd-col-hdr        { display: none; }
  .schema-grid        { grid-template-columns: 1fr; }
  .roadmap-grid       { grid-template-columns: 1fr; }
  .dev-guide-grid     { grid-template-columns: 1fr; }
}

/* ──────────────────────────────────────────────────────────────
   관리자 > 메뉴 구조 설정 (사이드바 커스터마이즈 UI)
   ────────────────────────────────────────────────────────────── */
.mc-toolbar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 0 14px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 14px;
}
.mc-changes {
  margin-left: auto;
  margin-right: 4px;
  font-size: 12px;
  color: var(--text-3, #999);
}
.mc-changes.is-dirty {
  color: #d97706;
  font-weight: 600;
}
.mc-hint {
  background: var(--bg-2, #f8f9fb);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 10px 14px;
  font-size: 12px;
  color: var(--text-2, #555);
  line-height: 1.7;
  margin-bottom: 16px;
}
.mc-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.mc-section {
  background: var(--surface, #fff);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
  transition: opacity .15s, border-color .15s;
}
.mc-section.is-hidden {
  opacity: 0.55;
}
.mc-section.is-system {
  background: var(--bg-2, #f5f7fa);
  border-color: var(--border-2, #d8dde5);
}
.mc-section-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, var(--surface) 0%, var(--bg-2, #f8f9fb) 100%);
}
.mc-section.is-system .mc-section-header {
  background: var(--bg-2, #f5f7fa);
}
.mc-handle {
  cursor: grab;
  user-select: none;
  color: var(--text-3, #999);
  font-size: 16px;
  padding: 2px 6px;
  border-radius: 4px;
}
.mc-handle:hover:not(.is-disabled) {
  background: var(--bg-2);
  color: var(--text-1);
}
.mc-handle.is-disabled {
  cursor: not-allowed;
  opacity: 0.3;
}
.mc-handle:active { cursor: grabbing; }
.mc-section-handle { font-weight: 700; }
.mc-icon {
  font-size: 16px;
  width: 22px;
  text-align: center;
  flex-shrink: 0;
}
.mc-section-input, .mc-item-input {
  flex: 1;
  border: 1px solid transparent;
  background: transparent;
  padding: 4px 8px;
  border-radius: 6px;
  font-size: 13px;
  font-family: inherit;
  color: var(--text-1);
  min-width: 0;
}
.mc-section-input { font-weight: 600; font-size: 14px; }
.mc-section-input:hover, .mc-item-input:hover {
  background: var(--bg-2, #f5f7fa);
}
.mc-section-input:focus, .mc-item-input:focus {
  outline: none;
  background: var(--surface);
  border-color: var(--primary, #1664E5);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary, #1664E5) 12%, transparent);
}
.mc-section-label, .mc-item-label {
  flex: 1;
  font-size: 13px;
  color: var(--text-2);
  padding: 4px 8px;
}
.mc-section-label { font-weight: 600; font-size: 14px; color: var(--text-1); }
.mc-lock {
  font-size: 13px;
  opacity: 0.6;
  margin-left: 4px;
}
.mc-vis-btn {
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 4px 8px;
  cursor: pointer;
  font-size: 14px;
  line-height: 1;
  transition: background .12s, border-color .12s;
}
.mc-vis-btn:hover {
  background: var(--bg-2);
  border-color: var(--text-3);
}
.mc-items {
  padding: 6px 8px 8px 28px;
  min-height: 36px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.mc-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border: 1px solid transparent;
  border-radius: 8px;
  background: var(--surface);
  transition: background .12s, border-color .12s, opacity .15s;
}
.mc-item:hover {
  background: var(--bg-2, #f8f9fb);
  border-color: var(--border);
}
.mc-item.is-hidden {
  opacity: 0.5;
}
.mc-item.is-system {
  background: color-mix(in srgb, var(--bg-2, #f5f7fa) 60%, transparent);
}
.mc-empty {
  font-size: 12px;
  color: var(--text-3);
  font-style: italic;
  padding: 8px 10px;
}
.mc-drag-ghost {
  opacity: 0.4;
  background: color-mix(in srgb, var(--primary, #1664E5) 12%, var(--surface));
  border: 1px dashed var(--primary, #1664E5);
}
[data-theme="dark"] .mc-section { background: var(--surface, #1c1c24); }
[data-theme="dark"] .mc-section.is-system { background: var(--surface-2, #1a1a22); }
[data-theme="dark"] .mc-hint { background: var(--surface-2, #1a1a22); }

/* 메뉴 구조 — 역할 권한 안내 뱃지 */
.mc-role-badge {
  display: inline-flex;
  align-items: center;
  font-size: 10px;
  font-weight: 600;
  color: var(--text-3, #777);
  background: var(--bg-2, #f5f7fa);
  border: 1px solid var(--border);
  padding: 1px 6px;
  border-radius: 8px;
  margin-left: 4px;
  letter-spacing: 0.2px;
}
[data-theme="dark"] .mc-role-badge {
  color: var(--text-2, #999);
  background: var(--surface-2, #2a2a32);
}

/* ──────────────────────────────────────────────────────────────
   DFD 시각화 — 미매핑/Stale 경고 배너 + 미분류 노드 표시
   ────────────────────────────────────────────────────────────── */
.dfd-warn {
  margin: 8px 0 12px;
  padding: 10px 14px;
  border-radius: 8px;
  border: 1px solid;
  font-size: 12px;
  line-height: 1.6;
}
.dfd-warn-info {
  background: color-mix(in srgb, #f59e0b 8%, var(--surface));
  border-color: color-mix(in srgb, #f59e0b 35%, transparent);
  color: var(--text-1);
}
.dfd-warn-error {
  background: color-mix(in srgb, #ef4444 8%, var(--surface));
  border-color: color-mix(in srgb, #ef4444 35%, transparent);
  color: var(--text-1);
  font-weight: 500;
}
.dfd-warn summary {
  cursor: pointer;
  font-weight: 500;
  user-select: none;
}
.dfd-warn-hint {
  margin-left: 6px;
  font-size: 11px;
  color: var(--text-3);
  font-weight: normal;
}
.dfd-warn-body {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed color-mix(in srgb, #f59e0b 30%, transparent);
}
.dfd-warn-row {
  margin-bottom: 10px;
}
.dfd-warn-row:last-child { margin-bottom: 0; }
.dfd-warn-row > code {
  display: block;
  margin: 4px 0 6px;
  padding: 6px 10px;
  background: var(--bg-2, #f5f7fa);
  border-radius: 6px;
  font-size: 11.5px;
  word-break: break-all;
  font-family: 'Consolas', 'Monaco', monospace;
}
.dfd-warn-tip {
  font-size: 11px;
  color: var(--text-2);
}
.dfd-warn-tip code {
  background: var(--bg-2);
  padding: 1px 5px;
  border-radius: 3px;
  font-family: 'Consolas', 'Monaco', monospace;
}

/* 미분류 테이블 노드 — 카탈로그 매핑이 없는 자동 감지 항목 */
.dfd-node-uncategorized {
  border-left: 3px solid #f59e0b !important;
  background: color-mix(in srgb, #f59e0b 4%, var(--surface)) !important;
}
.dfd-node-uncategorized .dfd-cols-preview {
  color: var(--text-3);
  font-style: italic;
}
.dfd-uncat-badge {
  display: inline-block;
  font-size: 9px;
  font-weight: 700;
  color: #b45309;
  background: color-mix(in srgb, #f59e0b 18%, transparent);
  border: 1px solid color-mix(in srgb, #f59e0b 40%, transparent);
  padding: 1px 5px;
  border-radius: 6px;
  margin-left: 4px;
  letter-spacing: 0.3px;
}
[data-theme="dark"] .dfd-warn-info {
  background: color-mix(in srgb, #f59e0b 12%, var(--surface));
}
[data-theme="dark"] .dfd-warn-error {
  background: color-mix(in srgb, #ef4444 14%, var(--surface));
}
[data-theme="dark"] .dfd-node-uncategorized {
  background: color-mix(in srgb, #f59e0b 8%, var(--surface)) !important;
}
[data-theme="dark"] .dfd-uncat-badge {
  color: #fbbf24;
}

/* 연관도 — 미분류 테이블 노드 시각 (DFD 와 동일 톤) */
.schema-map-node.is-uncategorized {
  border: 2px solid #f59e0b !important;
  box-shadow: 0 0 0 1px color-mix(in srgb, #f59e0b 30%, transparent),
              0 4px 12px rgba(0,0,0,.08);
}
.schema-map-node.is-uncategorized::before {
  content: '미분류';
  position: absolute;
  top: -8px;
  right: 8px;
  font-size: 9px;
  font-weight: 700;
  color: #fff;
  background: #f59e0b;
  padding: 1px 6px;
  border-radius: 8px;
  letter-spacing: 0.3px;
  z-index: 2;
}
[data-theme="dark"] .schema-map-node.is-uncategorized {
  box-shadow: 0 0 0 1px color-mix(in srgb, #f59e0b 40%, transparent),
              0 4px 12px rgba(0,0,0,.4);
}

/* ──────────────────────────────────────────────────────────────
   DFD 매핑 — 컨텍스트 메뉴 + 모달 + 동적 매핑 노드
   ────────────────────────────────────────────────────────────── */
.dfd-ctxmenu {
  position: fixed;
  z-index: 2000;
  min-width: 220px;
  background: var(--surface, #fff);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,.15), 0 0 0 1px rgba(0,0,0,.04);
  padding: 4px;
  animation: ctxmenuIn .12s ease-out;
}
@keyframes ctxmenuIn {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.dfd-ctxmenu-item {
  padding: 8px 12px;
  font-size: 13px;
  border-radius: 6px;
  cursor: pointer;
  user-select: none;
}
.dfd-ctxmenu-item:hover {
  background: var(--bg-2, #f5f7fa);
}
.dfd-ctxmenu-danger {
  color: #b45309;
}
.dfd-ctxmenu-danger:hover {
  background: color-mix(in srgb, #ef4444 8%, transparent);
  color: #991b1b;
}

/* 동적 매핑된 테이블 (사용자가 우클릭으로 추가) */
.dfd-node-dynamic-mapped {
  border-left: 3px solid #0ea5e9 !important;
  background: color-mix(in srgb, #0ea5e9 4%, var(--surface)) !important;
}
.dfd-mapped-badge {
  display: inline-block;
  font-size: 9px;
  font-weight: 700;
  color: #0c4a6e;
  background: color-mix(in srgb, #0ea5e9 18%, transparent);
  border: 1px solid color-mix(in srgb, #0ea5e9 40%, transparent);
  padding: 1px 5px;
  border-radius: 6px;
  margin-left: 4px;
  letter-spacing: 0.3px;
}
[data-theme="dark"] .dfd-node-dynamic-mapped {
  background: color-mix(in srgb, #0ea5e9 10%, var(--surface)) !important;
}
[data-theme="dark"] .dfd-mapped-badge {
  color: #7dd3fc;
}

/* 매핑 모달 */
.dfd-map-body {
  padding: 4px 0;
}
.dfd-map-search-wrap {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}
.dfd-map-search {
  flex: 1;
  padding: 6px 10px;
  font-size: 12px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--surface);
  color: var(--text-1);
}
.dfd-map-search:focus {
  outline: none;
  border-color: var(--primary, #1664E5);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary,#1664E5) 12%, transparent);
}
.dfd-map-count {
  font-size: 11px;
  color: var(--text-3);
  white-space: nowrap;
}
.dfd-map-api-list {
  max-height: 360px;
  overflow-y: auto;
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 4px;
}
.dfd-map-api-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 4px;
  cursor: pointer;
  transition: background .1s;
  font-size: 13px;
}
.dfd-map-api-item:hover {
  background: var(--bg-2, #f5f7fa);
}
.dfd-map-api-item input[type="checkbox"] {
  margin: 0;
  cursor: pointer;
}
.dfd-map-api-method {
  display: inline-block;
  font-family: 'Consolas', 'Monaco', monospace;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 4px;
  letter-spacing: 0.3px;
  min-width: 42px;
  text-align: center;
}
.dfd-map-api-method.crud { background: #ddd6fe; color: #5b21b6; }
.dfd-map-api-method.get  { background: #d1fae5; color: #065f46; }
.dfd-map-api-method.post { background: #fef3c7; color: #92400e; }
.dfd-map-api-label {
  flex: 1;
  font-family: 'Consolas', 'Monaco', monospace;
  font-size: 12px;
  color: var(--text-1);
}
[data-theme="dark"] .dfd-map-api-method.crud { background: rgba(139,92,246,.25); color: #c4b5fd; }
[data-theme="dark"] .dfd-map-api-method.get  { background: rgba(16,185,129,.25); color: #6ee7b7; }
[data-theme="dark"] .dfd-map-api-method.post { background: rgba(245,158,11,.25); color: #fcd34d; }

/* DFD 무시됨 상태 (확인했지만 매핑 안 함) — 회색 톤으로 덜 강조 */
.dfd-node-dismissed {
  border-left: 3px solid #9ca3af !important;
  background: color-mix(in srgb, #9ca3af 6%, var(--surface)) !important;
  opacity: 0.7;
}
.dfd-dismissed-badge {
  display: inline-block;
  font-size: 9px;
  font-weight: 700;
  color: #4b5563;
  background: color-mix(in srgb, #9ca3af 22%, transparent);
  border: 1px solid color-mix(in srgb, #9ca3af 40%, transparent);
  padding: 1px 5px;
  border-radius: 6px;
  margin-left: 4px;
  letter-spacing: 0.3px;
}

/* 신규 미매핑 — 보더에 부드러운 펄스 */
.dfd-node-new {
  animation: dfdNewPulse 2.2s ease-in-out infinite;
}
@keyframes dfdNewPulse {
  0%, 100% { box-shadow: 0 0 0 0 color-mix(in srgb, #f59e0b 30%, transparent); }
  50%      { box-shadow: 0 0 0 5px color-mix(in srgb, #f59e0b 0%, transparent); }
}

/* 모든 미분류 처리 완료 시 (신규 0, 매핑 안 됨 0) — 차분한 톤 */
.dfd-warn-muted {
  background: var(--bg-2, #f5f7fa);
  border-color: var(--border);
  color: var(--text-2, #555);
}
[data-theme="dark"] .dfd-node-dismissed {
  background: color-mix(in srgb, #9ca3af 8%, var(--surface)) !important;
}
[data-theme="dark"] .dfd-dismissed-badge {
  color: #d1d5db;
}

/* DFD 자동 추론 모달 */
.dfd-infer-body { padding: 4px 0; }
.dfd-infer-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px dashed var(--border);
}
.dfd-infer-counter {
  margin-left: auto;
  font-size: 11px;
  color: var(--text-3);
}
.dfd-infer-list {
  max-height: 480px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.dfd-infer-card {
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 10px 12px;
  background: var(--surface);
  transition: border-color .12s;
}
.dfd-infer-card:hover { border-color: var(--primary, #1664E5); }
.dfd-infer-card-head {
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.dfd-infer-table-name {
  font-weight: 600;
  font-size: 13px;
  color: var(--text-1);
}
.dfd-infer-count {
  font-size: 11px;
  color: var(--text-3);
  background: var(--bg-2, #f5f7fa);
  padding: 1px 6px;
  border-radius: 8px;
}
.dfd-infer-apis {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-left: 24px;
}
.dfd-infer-api {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 8px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 12px;
}
.dfd-infer-api:hover { background: var(--bg-2, #f5f7fa); }
.dfd-infer-api input[type="checkbox"] { cursor: pointer; }
.dfd-infer-evidence {
  margin-left: auto;
  font-size: 10px;
  font-style: italic;
  color: var(--text-3);
  font-family: 'Consolas', 'Monaco', monospace;
}

/* 자동 추론 모달 — 섹션 헤더 (테이블/API 구분) */
.dfd-infer-section-header {
  font-size: 12px;
  font-weight: 700;
  color: var(--text-2);
  padding: 6px 0 6px;
  margin-bottom: 4px;
  border-bottom: 1px solid var(--border);
  letter-spacing: 0.3px;
}

/* DFD 4번째 컬럼 — 외부 서비스 */
.dfd-hdr-external {
  background: linear-gradient(135deg, #0891b2 0%, #06b6d4 100%);
  color: #fff;
}
.dfd-node-external {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 3px solid #06b6d4;
  border-radius: 6px;
  font-size: 12px;
  cursor: pointer;
  transition: background .12s, border-color .12s, transform .12s;
}
.dfd-node-external:hover {
  background: color-mix(in srgb, #06b6d4 5%, var(--surface));
  border-color: #06b6d4;
  transform: translateX(-1px);
}
.dfd-ext-icon {
  font-size: 14px;
  flex-shrink: 0;
}
.dfd-ext-label {
  flex: 1;
  font-weight: 500;
  color: var(--text-1);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dfd-ext-cat {
  font-size: 9px;
  font-weight: 700;
  color: #0c4a6e;
  background: color-mix(in srgb, #06b6d4 18%, transparent);
  padding: 1px 6px;
  border-radius: 6px;
  letter-spacing: 0.3px;
  text-transform: uppercase;
}

/* 카테고리별 보더 색상 (선택적 시각 구분) */
.dfd-ext-cat-map     { border-left-color: #f59e0b; }
.dfd-ext-cat-fx      { border-left-color: #10b981; }
.dfd-ext-cat-ai      { border-left-color: #8b5cf6; }
.dfd-ext-cat-auth    { border-left-color: #ef4444; }
.dfd-ext-cat-calendar{ border-left-color: #3b82f6; }
.dfd-ext-cat-meeting { border-left-color: #ec4899; }
.dfd-ext-cat-cdn     { border-left-color: #6b7280; }

/* 영향도 패널 — 외부 라벨 */
.impact-label.impact-external {
  color: #0c4a6e;
}
[data-theme="dark"] .dfd-node-external {
  background: color-mix(in srgb, #06b6d4 6%, var(--surface));
}
[data-theme="dark"] .dfd-ext-cat {
  color: #67e8f9;
}

/* DFD 외부 서비스 자동 발견 상태 표시 */
.dfd-node-external.is-detected {
  opacity: 1;
}
.dfd-node-external.is-undetected {
  opacity: 0.55;
  border-style: dashed;
}
.dfd-ext-detected {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  font-size: 9px;
  font-weight: 700;
  color: #fff;
  background: #10b981;
  border-radius: 50%;
  margin-left: 2px;
}
.dfd-ext-undetected {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  font-size: 10px;
  font-weight: 700;
  color: var(--text-3);
  background: var(--bg-2, #e5e7eb);
  border: 1px solid var(--border);
  border-radius: 50%;
  margin-left: 2px;
}
[data-theme="dark"] .dfd-ext-undetected {
  background: var(--surface-2);
  color: var(--text-3);
}

/* ──────────────────────────────────────────────────────────────
   개발자 옵션 > API 관리 (OpenAPI 통합 뷰)
   ────────────────────────────────────────────────────────────── */
.apidoc-coverage-pill {
  display: inline-block;
  padding: 1px 8px;
  margin-left: 6px;
  font-size: 10px;
  font-weight: 700;
  border: 1px solid;
  border-radius: 10px;
}
.apidoc-download-group {
  display: flex;
  gap: 4px;
}
.apidoc-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin: 12px 0 16px;
}
.apidoc-stat {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px 14px;
}
.apidoc-stat-label { font-size: 11px; color: var(--text-3); margin-bottom: 4px; }
.apidoc-stat-value { font-size: 22px; font-weight: 700; color: var(--text-1); }

.apidoc-list { display: flex; flex-direction: column; gap: 8px; }
.apidoc-tag-section {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
}
.apidoc-tag-section > summary {
  list-style: none;
  cursor: pointer;
  user-select: none;
  padding: 10px 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  background: linear-gradient(180deg, var(--surface) 0%, var(--bg-2,#f8f9fb) 100%);
  border-bottom: 1px solid var(--border);
}
.apidoc-tag-section[open] > summary { border-bottom-color: var(--border); }
.apidoc-tag-section > summary::-webkit-details-marker { display: none; }
.apidoc-tag-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-1);
  flex: 0 0 auto;
}
.apidoc-tag-count {
  font-size: 11px;
  color: var(--text-3);
  background: var(--bg-2);
  padding: 1px 7px;
  border-radius: 8px;
}
.apidoc-tag-doc {
  margin-left: auto;
  font-size: 11px;
  color: var(--text-3);
}

.apidoc-op-list { display: flex; flex-direction: column; }
.apidoc-op {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 14px;
  border-top: 1px solid var(--border);
  cursor: pointer;
  font-size: 12px;
  transition: background .1s;
}
.apidoc-op:first-child { border-top: none; }
.apidoc-op:hover { background: var(--bg-2, #f8f9fb); }
.apidoc-op.is-stub { background: color-mix(in srgb, #f59e0b 5%, transparent); }
.apidoc-op.is-stub:hover { background: color-mix(in srgb, #f59e0b 10%, transparent); }

.apidoc-method {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 56px;
  padding: 3px 8px;
  font-family: 'Consolas', 'Monaco', monospace;
  font-size: 10px;
  font-weight: 700;
  color: #fff;
  border-radius: 4px;
  text-align: center;
  letter-spacing: 0.5px;
}
.apidoc-method.get    { background: #10b981; }
.apidoc-method.post   { background: #3b82f6; }
.apidoc-method.put    { background: #f59e0b; }
.apidoc-method.patch  { background: #8b5cf6; }
.apidoc-method.delete { background: #ef4444; }
.apidoc-method.crud   { background: #6366f1; }

.apidoc-path {
  font-family: 'Consolas', 'Monaco', monospace;
  font-size: 12px;
  color: var(--text-1);
  font-weight: 500;
  min-width: 200px;
  word-break: break-all;
}
.apidoc-summary {
  flex: 1;
  color: var(--text-2);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.apidoc-doc-badge {
  font-size: 11px;
  color: #10b981;
  flex-shrink: 0;
}
.apidoc-stub-badge {
  font-size: 11px;
  color: #f59e0b;
  flex-shrink: 0;
}

/* Operation 상세 모달 */
.apidoc-detail { padding: 4px 0; }
.apidoc-detail-meta {
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
  padding: 10px 12px;
  background: var(--bg-2);
  border-radius: 6px;
  margin-bottom: 12px;
  font-size: 12px;
  color: var(--text-2);
}
.apidoc-detail-section { margin-bottom: 12px; }
.apidoc-section-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-3);
  letter-spacing: 0.3px;
  text-transform: uppercase;
  margin-bottom: 4px;
}
.apidoc-section-content {
  font-size: 13px;
  color: var(--text-1);
  line-height: 1.6;
}
.apidoc-code-example {
  background: var(--bg-2);
  padding: 10px 12px;
  border-radius: 6px;
  font-family: 'Consolas', 'Monaco', monospace;
  font-size: 11px;
  margin-top: 6px;
  overflow-x: auto;
  border: 1px solid var(--border);
}

@media (max-width: 1100px) {
  .apidoc-stats-grid { grid-template-columns: 1fr 1fr; }
}

/* API 관리 — DFD 연관 배지 + Sync 배너 */
.apidoc-dfd-badge {
  display: inline-block;
  font-size: 9px;
  font-weight: 700;
  color: #0c4a6e;
  background: color-mix(in srgb, #06b6d4 14%, transparent);
  border: 1px solid color-mix(in srgb, #06b6d4 35%, transparent);
  padding: 1px 6px;
  border-radius: 8px;
  letter-spacing: 0.3px;
  flex-shrink: 0;
}
.apidoc-sync-banner {
  background: color-mix(in srgb, #f59e0b 8%, var(--surface));
  border: 1px solid color-mix(in srgb, #f59e0b 35%, transparent);
  border-radius: 8px;
  padding: 10px 14px;
  margin: 12px 0;
  font-size: 12px;
}
.apidoc-sync-banner summary {
  cursor: pointer;
  font-weight: 500;
  user-select: none;
  list-style: none;
}
.apidoc-sync-banner summary::-webkit-details-marker { display: none; }
.apidoc-sync-body {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed color-mix(in srgb, #f59e0b 30%, transparent);
}
.apidoc-sync-row { margin-bottom: 10px; }
.apidoc-sync-row:last-child { margin-bottom: 0; }
.apidoc-sync-row code {
  display: block;
  margin: 4px 0 6px;
  padding: 6px 10px;
  background: var(--bg-2, #f5f7fa);
  border-radius: 6px;
  font-size: 11.5px;
  word-break: break-all;
  font-family: 'Consolas', 'Monaco', monospace;
}
.apidoc-sync-tip {
  font-size: 11px;
  color: var(--text-2);
}
[data-theme="dark"] .apidoc-sync-banner {
  background: color-mix(in srgb, #f59e0b 12%, var(--surface));
}

/* DFD 컬럼 헤더 — 노드 수 카운트 배지 */
.dfd-hdr-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 18px;
  padding: 0 7px;
  margin-left: 6px;
  font-size: 10px;
  font-weight: 800;
  color: var(--text-1, #111);
  background: rgba(255, 255, 255, 0.95);
  border-radius: 10px;
  letter-spacing: 0.2px;
  box-shadow: 0 1px 3px rgba(0,0,0,.15);
}
[data-theme="dark"] .dfd-hdr-count {
  background: rgba(255, 255, 255, 0.85);
  color: #1a1a22;
}
