:root {
  --bg: #0f1419;
  --panel: #1a1f29;
  --panel2: #232936;
  --border: #2d3441;
  --text: #c9d1d9;
  --muted: #6b7684;
  --accent: #4a9eff;
  --error: #ff5c5c;
  --error-bg: #2a1416;
  --warn: #f0b429;
  --warn-bg: #2a2410;
  --info: #56b6c2;
}

* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: -apple-system, "Segoe UI", "Apple SD Gothic Neo", sans-serif;
  background: var(--bg);
  color: var(--text);
  font-size: 14px;
}
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

.topbar {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 22px;
  background: var(--panel);
  border-bottom: 1px solid var(--border);
}
.topbar h1 { font-size: 16px; margin: 0; font-weight: 600; }
.topbar .badge { color: var(--muted); font-size: 13px; }
.wrap { padding: 22px; max-width: 1400px; margin: 0 auto; }

/* 페이지 제목 (회사 로그 목록 등) */
.page-head {
  display: flex; align-items: baseline; gap: 14px;
  padding: 18px 22px 14px;
}
.page-title { font-size: 22px; font-weight: 700; }
.page-sub { color: var(--muted); font-size: 13px; display: flex; align-items: center; gap: 8px; }

/* ── 목록 테이블 ── */
table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: 11px 14px; border-bottom: 1px solid var(--border); }
th { color: var(--muted); font-weight: 600; font-size: 12px; text-transform: uppercase; letter-spacing: .04em; }
tbody tr:hover { background: var(--panel2); }
td.num { text-align: right; font-variant-numeric: tabular-nums; }

.pill { display: inline-block; padding: 2px 9px; border-radius: 11px; font-size: 12px; font-weight: 600; }
.pill.err { background: var(--error-bg); color: var(--error); }
.pill.warn { background: var(--warn-bg); color: var(--warn); }
.pill.ok { background: #14241a; color: #4ec97a; }
.pill.zero { color: var(--muted); }

/* ── 뷰어 ── */
.viewer-head {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  padding: 12px 22px; background: var(--panel); border-bottom: 1px solid var(--border);
}
.viewer-head .meta { color: var(--muted); font-size: 13px; }
.viewer-head .meta b { color: var(--text); }
.spacer { flex: 1; }

.btn {
  background: var(--panel2); color: var(--text); border: 1px solid var(--border);
  padding: 6px 14px; border-radius: 7px; cursor: pointer; font-size: 13px;
}
.btn:hover { border-color: var(--accent); }
.btn.active { background: var(--accent); color: #fff; border-color: var(--accent); }
.btn.danger { color: var(--error); border-color: var(--error-bg); }
.btn.danger:hover { background: var(--error); color: #fff; border-color: var(--error); }
.search { background: var(--panel2); border: 1px solid var(--border); color: var(--text);
  padding: 6px 12px; border-radius: 7px; font-size: 13px; width: 220px; }

/* ── 로그 본문 ── */
.log {
  font-family: "SF Mono", "JetBrains Mono", Menlo, Consolas, monospace;
  font-size: 12.5px; line-height: 1.55;
  padding: 8px 0; white-space: pre-wrap; word-break: break-word;
}
.row { display: flex; padding: 0 22px; }
.row:hover { background: var(--panel2); }
.row .ln {
  flex: 0 0 60px; text-align: right; padding-right: 16px;
  color: var(--muted); user-select: none; opacity: .7;
}
.row .tx { flex: 1; }

.row.lv-ERROR { background: var(--error-bg); }
.row.lv-ERROR .tx { color: var(--error); }
.row.lv-WARN { background: var(--warn-bg); }
.row.lv-WARN .tx { color: var(--warn); }
.row.lv-INFO .tx { color: var(--info); }
.row.lv-DEBUG .tx, .row.lv-TRACE .tx { color: var(--muted); }
.row.cont .tx { padding-left: 18px; opacity: .92; }

/* gap 펼치기 버튼 */
.gap {
  margin: 2px 22px; padding: 5px 14px; border-radius: 6px;
  background: var(--panel2); border: 1px dashed var(--border);
  color: var(--muted); cursor: pointer; font-size: 12.5px; display: inline-block;
}
.gap:hover { border-color: var(--accent); color: var(--accent); }

/* ── 회사 카드 그리드 ── */
.card-grid {
  display: grid; gap: 18px; align-items: stretch;
  grid-template-columns: repeat(auto-fill, minmax(560px, 1fr));
}
.card {
  background: var(--panel); border: 1px solid var(--border);
  border-radius: 12px; padding: 16px 18px 8px; color: var(--text);
  display: flex; flex-direction: column;
  min-height: 300px;            /* 모든 카드 높이 통일 (5행 기준) */
}
.card table.mini { flex: 0 0 auto; }
.card .card-more { margin-top: auto; }   /* 더보기 링크 항상 하단 */
.card .card-empty { margin: auto 0; }     /* '로그 없음' 세로 중앙 */
.card-head { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.card-name { font-size: 17px; font-weight: 700; }
a.card-link { color: var(--text); }
a.card-link:hover { color: var(--accent); text-decoration: none; }

.card-versions {
  display: flex; align-items: center; gap: 7px;
  font-size: 12.5px; color: var(--muted);
  padding: 2px 0 10px; border-bottom: 1px solid var(--border); margin-bottom: 6px;
}
.card-versions b { color: var(--text); font-variant-numeric: tabular-nums; }
.card-versions .vsep { color: var(--muted); opacity: .6; }

/* 카드 안 미니 로그 목록 */
table.mini { width: 100%; border-collapse: collapse; }
table.mini th {
  font-size: 11px; color: var(--muted); font-weight: 600; text-transform: uppercase;
  letter-spacing: .04em; padding: 6px 10px; border-bottom: 1px solid var(--border);
  white-space: nowrap;          /* 컬럼명 세로 줄바꿈 방지 */
}
table.mini td {
  padding: 9px 10px; border-bottom: 1px solid var(--border); font-size: 13px;
  white-space: nowrap;          /* 발생/수신 시각이 한 줄에 표시되도록 */
}
table.mini tbody tr { cursor: pointer; }
table.mini tbody tr:hover { background: var(--panel2); }
table.mini tbody tr:last-child td { border-bottom: none; }
.card-empty { padding: 14px 10px; color: var(--muted); font-size: 13px; }
.card-more {
  display: block; padding: 10px; text-align: center; font-size: 12.5px;
  color: var(--muted); border-top: 1px solid var(--border);
}
.card-more:hover { color: var(--accent); text-decoration: none; }

/* 정렬 가능 헤더 */
th.sortable { cursor: pointer; user-select: none; }
th.sortable:hover { color: var(--text); }
th.sortable.asc::after  { content: " ▲"; font-size: 9px; color: var(--accent); }
th.sortable.desc::after { content: " ▼"; font-size: 9px; color: var(--accent); }

.empty { padding: 40px; text-align: center; color: var(--muted); }

/* 설정 페이지 */
.settings-card {
  background: var(--panel); border: 1px solid var(--border);
  border-radius: 12px; padding: 20px 22px; margin-bottom: 18px; max-width: 560px;
}
.settings-card h2 { font-size: 15px; font-weight: 700; margin: 0 0 6px; }
.settings-card .hint { color: var(--muted); font-size: 13px; margin: 0 0 14px; }
.settings-card .hint b { color: var(--text); }
.form-row { display: flex; gap: 10px; align-items: center; }
.form-row.end { justify-content: flex-end; }
/* 폼 유틸 (반복 인라인 스타일 정리) */
.check-inline { display: flex; align-items: center; gap: 6px; cursor: pointer; }
.check-box { display: block; width: 18px; height: 18px; margin: 6px 0 12px; accent-color: var(--accent); }
.field-label { display: block; margin-top: 14px; }
select.w-auto { width: auto; }
/* 설정 카드 안에서 "저장 묶음"과 "일회성 작업"을 나누는 구분선 */
.card-divider { margin-top: 18px; padding-top: 16px; border-top: 1px solid var(--border); }
.hl { background: #5a4a00; color: #fff; border-radius: 2px; padding: 0 1px; }
