/* kpi-dashboard.css — KPI 대시보드 스타일 (overview 패널 상단) */

/* ── 컨테이너 ── */
.kpi-dashboard {
    margin-bottom: var(--s-3);
}

/* ── 헤더 (접기/펼치기 토글) ── */
.kpi-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--s-2) var(--s-3);
    cursor: pointer;
    user-select: none;
    background: transparent;
    border-radius: var(--radius-s);
    transition: background var(--duration-fast) var(--easing-smooth);
}

.kpi-header:hover {
    background: transparent;
}

.kpi-header-left {
    display: flex;
    align-items: center;
    gap: var(--s-2);
}

.kpi-chevron {
    transition: transform var(--duration-base) var(--easing-smooth);
    color: var(--text-sub);
}

.kpi-chevron-open {
    transform: rotate(180deg);
}

.kpi-title {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    font-weight: var(--weight-semibold);
    color: var(--text-sub);
    letter-spacing: 0.5px;
    text-transform: uppercase;
}

/* ── Live 상태 dot ── */
.kpi-live-dot {
    width: var(--s-1-5);
    height: var(--s-1-5);
    border-radius: 50%;
    background: var(--green);
    box-shadow: 0 0 4px rgba(34, 197, 94, 0.5);
    transition: background var(--duration-moderate) var(--easing-smooth), box-shadow var(--duration-moderate) var(--easing-smooth);
}

.kpi-live-dot.offline {
    background: var(--text-faint);
    box-shadow: none;
}

/* ── 헤더 우측 요약 ── */
.kpi-header-right {
    display: flex;
    align-items: center;
    gap: var(--s-1);
    font-size: var(--text-sm);
    color: var(--text-faint);
    font-family: var(--font-mono);
}

.kpi-summary-sep {
    color: var(--text-faint);
    opacity: 0.4;
}

.kpi-summary-health {
    font-weight: var(--weight-semibold);
}

.kpi-summary-warn {
    color: var(--amber);
    font-weight: var(--weight-semibold);
}

.kpi-summary-danger {
    color: var(--red);
    font-weight: var(--weight-semibold);
}

/* ── 본문 (접기/펼치기) ── */
.kpi-body {
    overflow: hidden;
    max-height: 600px;
    transition: max-height var(--duration-moderate) var(--easing-smooth), opacity var(--duration-base) var(--easing-smooth);
    opacity: 1;
    padding-top: var(--s-2);
}

.kpi-body-collapsed {
    max-height: 0;
    opacity: 0;
    padding-top: 0;
}

/* ── 메트릭 카드 6열 그리드 ── */
.kpi-metrics {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: var(--s-3);
    margin-bottom: var(--s-3);
}

.kpi-card {
    background: transparent;
    border-radius: var(--radius);
    padding: var(--s-4);
    display: flex;
    flex-direction: column;
    gap: var(--s-2);
}

.kpi-card-label {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    font-weight: var(--weight-medium);
    letter-spacing: var(--tracking-wide);
    color: var(--text-sub);
    text-transform: uppercase;
    line-height: var(--leading-none);
}

.kpi-card-value {
    font-size: var(--text-xl);
    font-weight: var(--weight-bold);
    letter-spacing: var(--tracking-tighter);
    color: var(--text);
    font-family: var(--font-mono);
    line-height: var(--leading-tight);
    font-variant-numeric: tabular-nums;
}

.kpi-val-good { color: var(--green); }
.kpi-val-warn { color: var(--amber); }
.kpi-val-bad { color: var(--red); }

.kpi-card-sub {
    font-size: var(--text-sm);
    color: var(--text-faint);
    font-family: var(--font-mono);
}

/* ── 트렌드 인디케이터 ── */
.kpi-trend {
    display: flex;
    align-items: center;
    gap: var(--s-1);
    font-size: var(--text-sm);
    font-weight: var(--weight-medium);
    line-height: var(--leading-none);
    font-variant-numeric: tabular-nums;
}
.kpi-trend--up   { color: var(--green); }
.kpi-trend--down { color: var(--red); }
.kpi-trend--flat { color: var(--text-sub); }
/* 역 지표: 하락=긍정, 상승=부정 */
.kpi-trend--inverse.kpi-trend--up   { color: var(--red); }
.kpi-trend--inverse.kpi-trend--down { color: var(--green); }

/* ── SLA 게이지 (donut) ── */
.kpi-card--sla {
    align-items: center;
    padding: var(--s-3);
}
.sla-gauge {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: var(--s-12);
    height: var(--s-12);
}
.sla-gauge__track {
    stroke: var(--surface-w8);
    fill: none;
    stroke-width: 6;
}
.sla-gauge__fill {
    fill: none;
    stroke-width: 6;
    stroke-linecap: round;
    transition: stroke-dashoffset var(--duration-slower) var(--easing-smooth), stroke var(--duration-moderate) var(--easing-smooth);
}
.sla-gauge__fill--good    { stroke: var(--green); }
.sla-gauge__fill--warning { stroke: var(--amber); }
.sla-gauge__fill--danger  { stroke: var(--red); }
.sla-gauge__center {
    position: absolute;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--s-1);
}
.sla-gauge__value {
    font-size: var(--text-reading);
    font-weight: var(--weight-bold);
    color: var(--text);
    letter-spacing: var(--tracking-tightest);
    font-variant-numeric: tabular-nums;
    line-height: var(--leading-none);
}
.sla-gauge__label {
    font-size: var(--text-3xs);
    color: var(--text-sub);
    letter-spacing: var(--tracking-wide);
    text-transform: uppercase;
}

/* ── 탭 네비게이션 ── */
.kpi-tabs {
    display: flex;
    gap: var(--s-1);
    margin-bottom: var(--s-2);
}

.kpi-tab {
    background: none;
    border: none;
    padding: var(--s-1) var(--s-3);
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text-faint);
    cursor: pointer;
    border-radius: var(--radius-s);
    transition: background var(--duration-fast) var(--easing-smooth), color var(--duration-fast) var(--easing-smooth);
    display: flex;
    align-items: center;
    gap: var(--s-1);
}

.kpi-tab:hover { background: var(--surface-w6); color: var(--text-sub); }
.kpi-tab.active { background: transparent; color: var(--text); font-weight: var(--weight-semibold); }

.kpi-tab-badge {
    font-size: var(--text-3xs);
    font-weight: var(--weight-bold);
    background: var(--red);
    color: var(--text);
    border-radius: var(--radius-pill);
    padding: 1px var(--s-1-5);
    line-height: 1.2;
    display: none;
}
.kpi-tab-badge.visible { display: inline; }

/* ── 탭 패널 ── */
.kpi-tab-panels {
    background: transparent;
    border-radius: var(--radius-s);
    padding: var(--s-3);
    max-height: 300px;
    overflow-y: auto;
}

.kpi-tab-panel { display: none; }
.kpi-tab-panel.active { display: block; }

/* ── 패널 상단 도구줄 ── */
.kpi-panel-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--s-2);
    gap: var(--s-2);
}

.kpi-action-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--s-1);
    background: none;
    border: none;
    padding: var(--s-1) var(--s-2);
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--accent);
    cursor: pointer;
    border-radius: var(--radius-s);
    transition: background var(--duration-fast) var(--easing-smooth);
}
.kpi-action-btn:hover { background: var(--surface-w6); }

.kpi-section-label {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text-faint);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: var(--s-2);
}

/* ── 이벤트 아이템 ── */
.kpi-event-item {
    display: flex;
    align-items: center;
    gap: var(--s-2);
    padding: var(--s-1) 0;
}

.kpi-event-item + .kpi-event-item {
    margin-top: var(--s-1);
}

.kpi-event-icon {
    flex-shrink: 0;
    display: flex;
    align-items: center;
}

.kpi-event-info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: var(--s-0);
}

.kpi-event-label {
    font-size: var(--text-sm);
    color: var(--text);
    font-weight: var(--weight-medium);
}

.kpi-event-detail {
    font-size: var(--text-sm);
    color: var(--text-faint);
    font-family: var(--font-mono);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.kpi-event-time {
    font-size: var(--text-sm);
    color: var(--text-faint);
    font-family: var(--font-mono);
    white-space: nowrap;
    flex-shrink: 0;
}

/* ── 스케줄러 ── */
.kpi-sched-summary-stats {
    display: flex;
    gap: var(--s-3);
    align-items: center;
}

.kpi-sched-summary {
    display: flex;
    gap: var(--s-3);
    margin-bottom: var(--s-2);
}

.kpi-sched-stat {
    font-size: var(--text-sm);
    color: var(--text-sub);
    font-family: var(--font-mono);
}

.kpi-sched-fail {
    color: var(--red);
    font-weight: var(--weight-semibold);
}

.kpi-sched-item {
    display: flex;
    align-items: center;
    gap: var(--s-2);
    padding: var(--s-1) 0;
    font-size: var(--text-sm);
}

.kpi-sched-item + .kpi-sched-item {
    margin-top: var(--s-1);
}

.kpi-sched-name {
    flex: 1;
    color: var(--text);
    font-weight: var(--weight-medium);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.kpi-sched-cron {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    color: var(--text-faint);
    flex-shrink: 0;
}

.kpi-sched-next {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    color: var(--accent);
    flex-shrink: 0;
}

/* ── 스케줄 액션 (토글 + 즉시실행) ── */
.kpi-sched-actions,
.kpi-schedule-actions {
    display: flex;
    align-items: center;
    gap: var(--sp-xs);
    flex-shrink: 0;
    margin-left: auto;
}

/* 토글 스위치 — 미니 사이즈 */
.kpi-toggle-label {
    position: relative;
    display: inline-flex;
    align-items: center;
    cursor: pointer;
}

.kpi-toggle-label input {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
}

.kpi-toggle-track {
    width: var(--s-5-5);
    height: var(--s-3-5);
    background: var(--surface-w6);
    border-radius: var(--radius-pill);
    position: relative;
    transition: background var(--duration-base) var(--easing-smooth);
}

.kpi-toggle-track::after {
    content: '';
    position: absolute;
    top: 2px;
    left: 2px;
    width: var(--s-2-5);
    height: var(--s-2-5);
    border-radius: 50%;
    background: var(--text-faint);
    transition: transform var(--duration-base) var(--easing-smooth), background var(--duration-base) var(--easing-smooth);
}

.kpi-toggle-label input:checked + .kpi-toggle-track {
    background: var(--accent-dim, rgba(45, 212, 191, 0.25));
}

.kpi-toggle-label input:checked + .kpi-toggle-track::after {
    transform: translateX(14px);
    background: var(--accent);
}

/* 스케줄 상태 dot — 비활성 */
.kpi-schedule-status.sched-disabled,
.sched-disabled {
    background: var(--text-faint);
    opacity: 0.4;
}

/* agents.js 전용 — 요약 행 */
.kpi-sched-summary-row {
    display: flex;
    gap: var(--sp-lg);
    padding: var(--sp-xs) 0;
}

.kpi-sched-stat-text {
    font-size: var(--text-sm);
    color: var(--text-faint);
    font-family: var(--font-mono);
}

.kpi-sched-fail-text {
    color: var(--red);
    font-weight: var(--weight-semibold);
}

/* ── 실패 스케줄 경고 ── */
.kpi-sched-fail-section {
    margin-top: var(--s-2);
    padding-top: var(--s-2);
}

.kpi-sched-fail-item {
    display: flex;
    align-items: center;
    gap: var(--s-2);
    padding: var(--s-1) 0;
    font-size: var(--text-sm);
    color: var(--red);
}

.kpi-sched-fail-count {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    margin-left: auto;
}

/* ── 에스컬레이션 KPI 요약 ── */
.kpi-esc-kpi {
    display: flex;
    gap: var(--s-3);
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text-sub);
}

.kpi-esc-kpi-stat { white-space: nowrap; }
.kpi-esc-kpi-stat.danger { color: var(--red); font-weight: var(--weight-semibold); }

/* ── 에스컬레이션 아이템 ── */
.kpi-esc-item {
    display: flex;
    align-items: flex-start;
    gap: var(--s-2);
    padding: var(--s-2) 0;
}
.kpi-esc-item + .kpi-esc-item { margin-top: var(--s-1); }

.kpi-esc-priority {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    font-weight: var(--weight-bold);
    padding: 1px var(--s-1-5);
    border-radius: var(--radius-s);
    flex-shrink: 0;
}
.kpi-esc-priority.p0 { background: var(--red-bg); color: var(--red); }
.kpi-esc-priority.p1 { background: var(--amber-bg); color: var(--amber); }
.kpi-esc-priority.p2 { background: var(--surface-w6); color: var(--text-sub); }

.kpi-esc-info { flex: 1; min-width: 0; }
.kpi-esc-error {
    font-size: var(--text-sm);
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.kpi-esc-meta {
    font-size: var(--text-sm);
    color: var(--text-faint);
    font-family: var(--font-mono);
    margin-top: var(--s-0);
}

.kpi-esc-resolve-btn {
    background: none;
    border: none;
    font-size: var(--text-sm);
    color: var(--green);
    font-family: var(--font-mono);
    cursor: pointer;
    padding: var(--s-1);
    border-radius: var(--radius-s);
    flex-shrink: 0;
    transition: background var(--duration-fast) var(--easing-smooth);
}
.kpi-esc-resolve-btn:hover { background: var(--green-bg); }

/* ── 규칙 아이템 ── */
.kpi-rule-item {
    display: flex;
    align-items: center;
    gap: var(--s-2);
    padding: var(--s-2) 0;
    font-size: var(--text-sm);
}
.kpi-rule-item + .kpi-rule-item { margin-top: var(--s-1); }

.kpi-rule-toggle {
    width: var(--s-5-5);
    height: var(--s-3-5);
    background: var(--surface-w6);
    border-radius: var(--radius-pill);
    border: none;
    cursor: pointer;
    position: relative;
    transition: background var(--duration-base) var(--easing-smooth);
    flex-shrink: 0;
}
.kpi-rule-toggle::after {
    content: '';
    position: absolute;
    top: 2px;
    left: 2px;
    width: var(--s-2-5);
    height: var(--s-2-5);
    border-radius: 50%;
    background: var(--text-faint);
    transition: transform var(--duration-base) var(--easing-smooth), background var(--duration-base) var(--easing-smooth);
}
.kpi-rule-toggle.on { background: var(--accent-dim); }
.kpi-rule-toggle.on::after { transform: translateX(14px); background: var(--accent); }

.kpi-rule-info { flex: 1; min-width: 0; }
.kpi-rule-name {
    color: var(--text);
    font-weight: var(--weight-medium);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.kpi-rule-event {
    font-size: var(--text-sm);
    color: var(--text-faint);
    font-family: var(--font-mono);
}

.kpi-rule-actions {
    display: flex;
    gap: var(--s-1);
    flex-shrink: 0;
}

.kpi-rule-del-btn {
    background: none;
    border: none;
    color: var(--text-faint);
    cursor: pointer;
    padding: var(--s-1);
    border-radius: var(--radius-s);
    display: flex;
    align-items: center;
    transition: color var(--duration-fast) var(--easing-smooth), background var(--duration-fast) var(--easing-smooth);
}
.kpi-rule-del-btn:hover { color: var(--red); background: var(--red-bg); }

/* ── Webhook 관리 아이템 ── */
.kpi-wh-item {
    display: flex;
    align-items: center;
    gap: var(--s-2);
    padding: var(--s-2) 0;
    font-size: var(--text-sm);
}
.kpi-wh-item + .kpi-wh-item { margin-top: var(--s-1); }

.kpi-wh-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: var(--s-1); }
.kpi-wh-name {
    color: var(--text);
    font-weight: var(--weight-medium);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.kpi-wh-url {
    font-size: var(--text-sm);
    color: var(--text-sub);
    font-family: var(--font-mono);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.kpi-wh-events {
    font-size: var(--text-sm);
    color: var(--text-faint);
    font-family: var(--font-mono);
}
.kpi-wh-actions {
    display: flex;
    gap: var(--s-1);
    flex-shrink: 0;
}

/* ── 스케줄 관리 아이템 ── */
.kpi-sched-mgmt-item {
    display: flex;
    align-items: center;
    gap: var(--s-2);
    padding: var(--s-2) 0;
    font-size: var(--text-sm);
}
.kpi-sched-mgmt-item + .kpi-sched-mgmt-item { margin-top: var(--s-1); }

.kpi-sched-mgmt-actions {
    display: flex;
    gap: var(--s-1);
    flex-shrink: 0;
}

.kpi-sched-trigger-btn {
    background: none;
    border: none;
    font-size: var(--text-sm);
    color: var(--accent);
    font-family: var(--font-mono);
    cursor: pointer;
    padding: var(--s-1) var(--s-1);
    border-radius: var(--radius-s);
    transition: background var(--duration-fast) var(--easing-smooth);
}
.kpi-sched-trigger-btn:hover { background: var(--surface-w6); }

/* ── 실행 이력 ── */
.kpi-sched-history { margin-top: var(--s-3); }
.kpi-sched-hist-title {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text-faint);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: var(--s-2);
}
.kpi-sched-hist-item {
    display: flex;
    align-items: center;
    gap: var(--s-2);
    padding: var(--s-1) 0;
    font-size: var(--text-sm);
    font-family: var(--font-mono);
}
.kpi-sched-hist-ok { color: var(--green); }
.kpi-sched-hist-fail { color: var(--red); }
.kpi-sched-hist-name { color: var(--text-sub); flex: 1; }
.kpi-sched-hist-time { color: var(--text-faint); flex-shrink: 0; }

/* ── 인라인 폼 (모달 대체) ── */
.kpi-inline-form {
    background: var(--bg);
    border-radius: var(--radius-s);
    padding: var(--s-3);
    margin-bottom: var(--s-2);
}
.kpi-inline-form-title {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    font-weight: var(--weight-semibold);
    color: var(--text);
    margin-bottom: var(--s-2);
}
.kpi-inline-form-row {
    display: flex;
    gap: var(--s-2);
    margin-bottom: var(--s-2);
    align-items: center;
}
.kpi-inline-form-row label {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text-sub);
    min-width: var(--s-8);
    flex-shrink: 0;
}
.kpi-inline-form-row input,
.kpi-inline-form-row select {
    flex: 1;
    background: transparent;
    border: none;
    border-radius: var(--radius-s);
    padding: var(--s-1) var(--s-2);
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text);
    outline: none;
}
.kpi-inline-form-row input:focus,
.kpi-inline-form-row select:focus {
    box-shadow: 0 0 0 1px var(--accent);
}
.kpi-inline-form-actions {
    display: flex;
    gap: var(--s-2);
    justify-content: flex-end;
}
.kpi-form-save-btn {
    background: var(--accent);
    color: var(--accent-on);
    border: none;
    border-radius: var(--radius-s);
    padding: var(--s-1) var(--s-3);
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    font-weight: var(--weight-semibold);
    cursor: pointer;
    transition: opacity var(--duration-fast) var(--easing-smooth);
}
.kpi-form-save-btn:hover { opacity: 0.85; }
.kpi-form-cancel-btn {
    background: none;
    color: var(--text-faint);
    border: none;
    border-radius: var(--radius-s);
    padding: var(--s-1) var(--s-3);
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    cursor: pointer;
    transition: color var(--duration-fast) var(--easing-smooth);
}
.kpi-form-cancel-btn:hover { color: var(--text); }

/* ── 빈 상태 ── */
.kpi-empty {
    font-size: var(--text-sm);
    color: var(--text-faint);
    text-align: center;
    padding: var(--s-4) 0;
}

/* ── 반응형 ── */
@media (max-width: 960px) {
    .kpi-metrics {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 640px) {
    .kpi-metrics {
        grid-template-columns: repeat(2, 1fr);
    }
    .kpi-tabs { flex-wrap: wrap; }
    .kpi-inline-form-row { flex-direction: column; align-items: stretch; }
    .kpi-inline-form-row label { min-width: unset; }
    .sla-gauge { width: var(--s-10); height: var(--s-10); }
    .sla-gauge__value { font-size: var(--text-sm); }
}

@media (max-width: 375px) {
    .kpi-metrics {
        grid-template-columns: 1fr;
        gap: var(--s-2);
    }
    .kpi-card {
        padding: var(--s-3);
    }
}

/* ═══════════════════════════════════════════════════════
   panel-kpi (독립 탭) — .kpip-* 접두사
   ═══════════════════════════════════════════════════════ */

/* ── 헤더 ── */
.kpip-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--s-3) var(--s-4);
    flex-wrap: wrap;
    gap: var(--s-2);
}
.kpip-header-left {
    display: flex;
    align-items: center;
    gap: var(--s-2);
}
.kpip-title {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    font-weight: var(--weight-semibold);
    color: var(--text);
    letter-spacing: 0.5px;
    text-transform: uppercase;
}
.kpip-live-dot {
    width: var(--s-1-5);
    height: var(--s-1-5);
    border-radius: 50%;
    background: var(--green);
    box-shadow: 0 0 6px rgba(34, 197, 94, 0.5);
    animation: kpipPulse 2s ease-in-out infinite;
}
@keyframes kpipPulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.5; }
}
.kpip-header-right {
    display: flex;
    align-items: center;
    gap: var(--s-2);
}

/* ── 기간 필터 ── */
.kpip-period-filter {
    display: flex;
    gap: var(--s-1);
    background: var(--surface-w6);
    border-radius: var(--radius-s);
    padding: var(--s-1);
}
.kpip-period-btn {
    padding: var(--s-1) var(--s-2);
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text-faint);
    background: transparent;
    border: none;
    border-radius: var(--radius-s);
    cursor: pointer;
    transition: color var(--duration-fast), background var(--duration-fast);
}
.kpip-period-btn:hover { color: var(--text-sub); }
.kpip-period-btn.active {
    color: var(--text);
    background: transparent;
}

/* ── 새로고침 버튼 ── */
.kpip-refresh-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: var(--s-5-5);
    height: var(--s-5-5);
    border: none;
    border-radius: var(--radius-s);
    background: var(--surface-w6);
    color: var(--text-sub);
    cursor: pointer;
    transition: color var(--duration-fast), background var(--duration-fast);
}
.kpip-refresh-btn:hover {
    color: var(--text);
    background: transparent;
}

/* ── KPI 카드 그리드 ── */
.kpip-cards-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--s-3);
    padding: 0 var(--s-4) var(--s-3);
}
.kpip-card {
    background: transparent;
    border-radius: var(--radius-s);
    padding: var(--s-3) var(--s-4);
    display: flex;
    flex-direction: column;
    gap: var(--s-1);
}
.kpip-card-label {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text-faint);
    text-transform: uppercase;
    letter-spacing: 0.3px;
}
.kpip-card-value {
    font-size: var(--text-4xl);
    font-weight: var(--weight-bold);
    font-family: var(--font-mono);
    color: var(--text);
    line-height: 1;
}
.kpip-card-sub {
    font-size: var(--text-sm);
    color: var(--text-faint);
}

/* 값 상태별 컬러 */
.kpip-val-good { color: var(--green); }
.kpip-val-warn { color: var(--amber); }
.kpip-val-bad { color: var(--red); }

/* ── 하단 2분할 (이벤트 + 스케줄) ── */
.kpip-bottom {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--s-3);
    padding: 0 var(--s-4) var(--s-3);
}

/* ── 공통 섹션 ── */
.kpip-events,
.kpip-schedules,
.kpip-triggers {
    background: transparent;
    border-radius: var(--radius-s);
    padding: var(--s-3);
    display: flex;
    flex-direction: column;
    gap: var(--s-2);
}
.kpip-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.kpip-section-label {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    font-weight: var(--weight-semibold);
    color: var(--text-sub);
    text-transform: uppercase;
    letter-spacing: 0.3px;
}
.kpip-add-btn {
    font-size: var(--text-sm);
    color: var(--accent);
    background: none;
    border: none;
    cursor: pointer;
    padding: var(--s-1);
    border-radius: var(--radius-s);
    transition: background var(--duration-fast);
}
.kpip-add-btn:hover { background: var(--surface-w6); }

/* ── 이벤트 타임라인 ── */
.kpip-event-list {
    display: flex;
    flex-direction: column;
    gap: var(--s-1);
    max-height: 480px;
    overflow-y: auto;
}
.kpip-event-item {
    display: flex;
    align-items: flex-start;
    gap: var(--s-2);
    padding: var(--s-2);
    border-radius: var(--radius-s);
    transition: background var(--duration-fast);
}
.kpip-event-item:hover { background: var(--surface-w6); }
.kpip-event-icon {
    flex-shrink: 0;
    width: var(--s-5-0);
    text-align: center;
    font-size: var(--text-sm);
    padding-top: var(--s-0);
}
.kpip-event-info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: var(--s-1);
}
.kpip-event-label {
    font-size: var(--text-sm);
    font-weight: var(--weight-medium);
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.kpip-event-detail {
    font-size: var(--text-sm);
    color: var(--text-faint);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.kpip-event-time {
    flex-shrink: 0;
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text-faint);
    padding-top: var(--s-1);
}

/* ── 스케줄 폼 ── */
.kpip-schedule-form {
    display: flex;
    flex-direction: column;
    gap: var(--s-2);
    padding: var(--s-2);
    background: var(--surface-w6);
    border-radius: var(--radius-s);
}
.kpip-input {
    background: var(--bg);
    color: var(--text);
    border: 1px solid var(--surface-w6);
    border-radius: var(--radius-s);
    padding: var(--s-1) var(--s-2);
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    outline: none;
    transition: border-color var(--duration-fast);
}
.kpip-input:focus { border-color: var(--accent); }
.kpip-input::placeholder { color: var(--text-faint); }
.kpip-form-actions {
    display: flex;
    gap: var(--s-2);
    justify-content: flex-end;
}
.kpip-form-cancel,
.kpip-form-submit {
    font-size: var(--text-sm);
    padding: var(--s-1) var(--s-2);
    border: none;
    border-radius: var(--radius-s);
    cursor: pointer;
    transition: background var(--duration-fast);
}
.kpip-form-cancel {
    background: transparent;
    color: var(--text-sub);
}
.kpip-form-cancel:hover { color: var(--text); }
.kpip-form-submit {
    background: var(--accent);
    color: var(--bg);
    font-weight: var(--weight-semibold);
}
.kpip-form-submit:hover { filter: brightness(1.1); }

/* ── 스케줄 목록 ── */
.kpip-schedule-list {
    display: flex;
    flex-direction: column;
    gap: var(--s-1);
    max-height: 480px;
    overflow-y: auto;
}
.kpip-sched-item {
    display: flex;
    align-items: center;
    gap: var(--s-2);
    padding: var(--s-2);
    border-radius: var(--radius-s);
    transition: background var(--duration-fast);
}
.kpip-sched-item:hover { background: var(--surface-w6); }
.kpip-sched-item.kpip-sched-disabled { opacity: 0.5; }
.kpip-sched-toggle {
    flex-shrink: 0;
    cursor: pointer;
    width: var(--s-3-5);
    height: var(--s-3-5);
    accent-color: var(--accent);
}
.kpip-sched-name {
    font-size: var(--text-sm);
    font-weight: var(--weight-medium);
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    flex: 1;
    min-width: 0;
}
.kpip-sched-cron {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text-faint);
    flex-shrink: 0;
}
.kpip-sched-next {
    font-size: var(--text-sm);
    color: var(--text-faint);
    flex-shrink: 0;
}
.kpip-sched-action {
    display: flex;
    gap: var(--s-1);
    flex-shrink: 0;
}
.kpip-sched-action button {
    background: none;
    border: none;
    cursor: pointer;
    font-size: var(--text-sm);
    padding: var(--s-1) var(--s-1);
    border-radius: var(--radius-s);
    transition: background var(--duration-fast), color var(--duration-fast);
}
.kpip-sched-action .kpip-sched-trigger {
    color: var(--accent);
}
.kpip-sched-action .kpip-sched-trigger:hover { background: var(--surface-w6); }
.kpip-sched-action .kpip-sched-delete {
    color: var(--red);
}
.kpip-sched-action .kpip-sched-delete:hover { background: var(--surface-w6); }

/* 실패 횟수 표시 */
.kpip-sched-fail-badge {
    font-size: var(--text-3xs);
    font-family: var(--font-mono);
    color: var(--red);
    background: var(--clr-error-bg);
    padding: 1px var(--s-1);
    border-radius: var(--radius-s);
}

/* ── 이벤트 룰 (읽기 전용) ── */
.kpip-triggers {
    margin: 0 var(--s-4) var(--s-4);
}
.kpip-trigger-list {
    display: flex;
    flex-direction: column;
    gap: var(--s-1);
}
.kpip-trigger-item {
    display: flex;
    align-items: center;
    gap: var(--s-2);
    padding: var(--s-2);
    border-radius: var(--radius-s);
    font-size: var(--text-sm);
}
.kpip-trigger-item:hover { background: var(--surface-w6); }
.kpip-trigger-event {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    color: var(--accent);
    flex-shrink: 0;
}
.kpip-trigger-action {
    color: var(--text);
    flex: 1;
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.kpip-trigger-status {
    font-size: var(--text-sm);
    flex-shrink: 0;
}
.kpip-trigger-status.enabled { color: var(--green); }
.kpip-trigger-status.kpip-trigger-disabled { color: var(--text-faint); }

/* ── 빈 상태 ── */
.kpip-empty {
    font-size: var(--text-sm);
    color: var(--text-faint);
    text-align: center;
    padding: var(--s-4) 0;
}

/* ── CEO 종합 요약 그리드 ── */
.kpip-summary-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: var(--s-2);
    padding: 0 var(--s-4) var(--s-3);
}
.kpip-summary-card {
    background: transparent;
    border-radius: var(--radius-s);
    padding: var(--s-2) var(--s-3);
    display: flex;
    flex-direction: column;
    gap: var(--s-1);
}
.kpip-sum-label {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text-faint);
    text-transform: uppercase;
    letter-spacing: 0.3px;
}
.kpip-sum-value {
    font-size: var(--text-lg);
    font-weight: var(--weight-bold);
    font-family: var(--font-mono);
    color: var(--text);
    line-height: 1.2;
}
.kpip-sum-sub {
    font-size: var(--text-sm);
    color: var(--text-faint);
}
.kpip-sum-healthy { color: var(--green); }
.kpip-sum-warning { color: var(--amber); }
.kpip-sum-critical { color: var(--red); }

/* ── 처리량 히스토그램 ── */
.kpip-throughput-section {
    background: transparent;
    border-radius: var(--radius-s);
    padding: var(--s-3);
    margin: 0 var(--s-4) var(--s-3);
    display: flex;
    flex-direction: column;
    gap: var(--s-2);
}
.kpip-throughput-legend {
    display: flex;
    gap: var(--s-3);
    align-items: center;
}
.kpip-legend-item {
    display: flex;
    align-items: center;
    gap: var(--s-1);
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text-sub);
}
.kpip-legend-dot {
    width: var(--s-2);
    height: var(--s-2);
    border-radius: var(--radius-s);
    display: inline-block;
}
.kpip-legend-completed .kpip-legend-dot { background: var(--green); }
.kpip-legend-failed .kpip-legend-dot { background: var(--red); }

.kpip-histogram {
    display: flex;
    align-items: flex-end;
    gap: var(--s-1);
    height: var(--s-12);
    padding-top: var(--s-1);
}
.kpip-histo-bar {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    height: 100%;
}
.kpip-histo-bar-completed {
    background: var(--green);
    border-radius: var(--radius-s) var(--radius-s) 0 0;
    transition: height var(--duration-moderate) var(--easing-smooth);
}
.kpip-histo-bar-failed {
    background: var(--red);
    border-radius: 0 0 var(--radius-s) var(--radius-s);
    transition: height var(--duration-moderate) var(--easing-smooth);
}
.kpip-histo-label {
    font-size: var(--text-3xs);
    font-family: var(--font-mono);
    color: var(--text-faint);
    text-align: center;
    margin-top: var(--s-1);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.kpip-throughput-footer {
    display: flex;
    gap: var(--s-4);
}
.kpip-tp-teams,
.kpip-tp-agents {
    flex: 1;
    min-width: 0;
}
.kpip-tp-section-label {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text-faint);
    text-transform: uppercase;
    margin-bottom: var(--s-1);
}
.kpip-tp-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--s-1) 0;
    font-size: var(--text-sm);
    color: var(--text-sub);
}
.kpip-tp-row-name {
    font-family: var(--font-mono);
    color: var(--text);
}
.kpip-tp-row-count {
    font-family: var(--font-mono);
    color: var(--text-faint);
}

/* ── 반응형 — panel-kpi ── */
@media (max-width: 960px) {
    .kpip-cards-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    .kpip-summary-grid {
        grid-template-columns: repeat(3, 1fr);
    }
    .kpip-bottom {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .kpip-cards-grid {
        grid-template-columns: 1fr;
    }
    .kpip-summary-grid {
        grid-template-columns: repeat(2, 1fr);
        padding-left: var(--s-3);
        padding-right: var(--s-3);
    }
    .kpip-throughput-section {
        margin-left: var(--s-3);
        margin-right: var(--s-3);
    }
    .kpip-throughput-footer {
        flex-direction: column;
    }
    .kpip-header {
        padding: var(--s-2) var(--s-3);
    }
    .kpip-cards-grid,
    .kpip-bottom {
        padding-left: var(--s-3);
        padding-right: var(--s-3);
    }
    .kpip-triggers {
        margin-left: var(--s-3);
        margin-right: var(--s-3);
    }
    .kpip-card-value {
        font-size: var(--text-xl);
    }
    .kpip-sched-cron,
    .kpip-sched-next {
        display: none;
    }
}

/* ═══════════════════════════════════════════════════
   에이전트 성과 (Agent Performance)
   ═══════════════════════════════════════════════════ */

.kpip-agent-perf {
    background: transparent;
    border-radius: var(--radius-s);
    padding: var(--s-3);
    margin: 0 var(--s-4) var(--s-3);
    display: flex;
    flex-direction: column;
    gap: var(--s-2);
}

/* 요약 배지 */
.kpip-ap-summary {
    display: flex;
    gap: var(--s-2);
    align-items: center;
}
.kpip-ap-badge {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text-sub);
    background: var(--surface-w6);
    padding: var(--s-1) var(--s-2);
    border-radius: var(--radius-s);
}
.kpip-ap-badge--good { color: var(--green); }
.kpip-ap-badge--warn { color: var(--amber); }
.kpip-ap-badge--bad { color: var(--red); }

/* Needs Attention */
.kpip-ap-attention {
    background: var(--clr-error-bg-sm);
    border-radius: var(--radius-s);
    padding: var(--s-2);
    display: flex;
    flex-direction: column;
    gap: var(--s-1);
}
.kpip-ap-att-label {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--red);
    text-transform: uppercase;
    letter-spacing: 0.3px;
    font-weight: var(--weight-semibold);
}
.kpip-ap-att-item {
    display: flex;
    align-items: center;
    gap: var(--s-2);
    font-size: var(--text-sm);
}
.kpip-ap-att-name {
    font-family: var(--font-mono);
    color: var(--text);
    font-weight: var(--weight-medium);
}
.kpip-ap-att-rate {
    color: var(--red);
    font-family: var(--font-mono);
}
.kpip-ap-att-runs {
    color: var(--text-faint);
    font-family: var(--font-mono);
}

/* Top Performers */
.kpip-ap-top-label {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text-faint);
    text-transform: uppercase;
    letter-spacing: 0.3px;
    margin-bottom: var(--s-1);
}
.kpip-ap-top-grid {
    display: flex;
    gap: var(--s-2);
    flex-wrap: wrap;
}
.kpip-ap-top-item {
    display: flex;
    align-items: center;
    gap: var(--s-1);
    font-size: var(--text-sm);
    background: var(--surface-w6);
    padding: var(--s-1) var(--s-2);
    border-radius: var(--radius-s);
}
.kpip-ap-top-rank {
    font-family: var(--font-mono);
    color: var(--text-faint);
    font-size: var(--text-sm);
}
.kpip-ap-top-name {
    font-family: var(--font-mono);
    color: var(--text);
    font-weight: var(--weight-medium);
}
.kpip-ap-top-rate {
    font-family: var(--font-mono);
    color: var(--green);
}

/* 에이전트 테이블 */
.kpip-ap-table-wrap {
    overflow-x: auto;
    max-height: 300px;
    overflow-y: auto;
}
.kpip-ap-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--text-sm);
    font-family: var(--font-mono);
}
.kpip-ap-table th {
    text-align: left;
    font-size: var(--text-sm);
    color: var(--text-faint);
    text-transform: uppercase;
    letter-spacing: 0.3px;
    padding: var(--s-1) var(--s-2);
    position: sticky;
    top: 0;
    background: transparent;
}
.kpip-ap-table td {
    padding: var(--s-1) var(--s-2);
    color: var(--text-sub);
}
.kpip-ap-table tr:hover td {
    background: var(--surface-w6);
}
.kpip-ap-cell-name {
    color: var(--text);
    font-weight: var(--weight-medium);
}

/* ═══════════════════════════════════════════════════
   파이프라인 건강 (Pipeline Health)
   ═══════════════════════════════════════════════════ */

.kpip-pipe-health {
    background: transparent;
    border-radius: var(--radius-s);
    padding: var(--s-3);
    margin: 0 var(--s-4) var(--s-3);
    display: flex;
    flex-direction: column;
    gap: var(--s-2);
}

/* 점수 표시 */
.kpip-ph-score-wrap {
    display: flex;
    align-items: center;
    gap: var(--s-2);
}
.kpip-ph-score {
    font-size: var(--text-xl);
    font-weight: var(--weight-bold);
    font-family: var(--font-mono);
    color: var(--text);
    line-height: 1;
}
.kpip-ph-status {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

/* 이슈 목록 */
.kpip-ph-issues {
    display: flex;
    flex-direction: column;
    gap: var(--s-1);
    background: var(--clr-error-bg-xs);
    border-radius: var(--radius-s);
    padding: var(--s-2);
}
.kpip-ph-issue-item {
    display: flex;
    align-items: center;
    gap: var(--s-1);
    font-size: var(--text-sm);
    color: var(--red);
}
.kpip-ph-issue-item svg {
    flex-shrink: 0;
    color: var(--red);
}

/* 컴포넌트 그리드 */
.kpip-ph-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--s-2);
}
.kpip-ph-card {
    background: var(--surface-w6);
    border-radius: var(--radius-s);
    padding: var(--s-2) var(--s-3);
    display: flex;
    flex-direction: column;
    gap: var(--s-1);
}
.kpip-ph-card-title {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text-faint);
    text-transform: uppercase;
    letter-spacing: 0.3px;
    font-weight: var(--weight-semibold);
}
.kpip-ph-card-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: var(--text-sm);
}
.kpip-ph-card-label {
    color: var(--text-faint);
}
.kpip-ph-card-value {
    font-family: var(--font-mono);
    color: var(--text);
    font-weight: var(--weight-medium);
}

/* 반응형 — Agent Performance + Pipeline Health */
@media (max-width: 960px) {
    .kpip-ph-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}
@media (max-width: 640px) {
    .kpip-agent-perf,
    .kpip-pipe-health {
        margin-left: var(--s-3);
        margin-right: var(--s-3);
    }
    .kpip-ph-grid {
        grid-template-columns: 1fr;
    }
    .kpip-ap-top-grid {
        flex-direction: column;
    }
}

/* ═══════════════════════════════════════════════════
   벤치마크 카드
   ═══════════════════════════════════════════════════ */

.kpi-bench-list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: var(--s-2);
    padding: var(--s-2) 0;
}

.kpi-bench-card {
    background: transparent;
    border-radius: var(--radius-s);
    padding: var(--s-3);
    transition: background var(--duration-fast) var(--easing-smooth);
}

.kpi-bench-card:hover {
    background: var(--surface-w6);
}

.kpi-bench-card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--s-2);
}

.kpi-bench-agent {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    font-weight: var(--weight-semibold);
    color: var(--text);
}

.kpi-bench-executions {
    font-size: var(--text-sm);
    color: var(--text-sub);
}

.kpi-bench-card-body {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--s-1) var(--s-2);
}

.kpi-bench-metric {
    display: flex;
    flex-direction: column;
    gap: var(--s-1);
}

.kpi-bench-metric-label {
    font-size: var(--text-sm);
    color: var(--text-faint);
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.kpi-bench-metric-value {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    font-weight: var(--weight-semibold);
    color: var(--text);
}

.kpi-bench-metric-value.kpi-val-good { color: var(--clr-success); }
.kpi-bench-metric-value.kpi-val-warn { color: var(--clr-warning); }
.kpi-bench-metric-value.kpi-val-bad { color: var(--clr-error); }

.kpi-bench-summary {
    display: flex;
    gap: var(--s-3);
    align-items: center;
}

.kpi-bench-stat {
    font-size: var(--text-sm);
    color: var(--text-sub);
    font-family: var(--font-mono);
}

.kpi-bench-filters {
    display: flex;
    align-items: center;
    gap: var(--s-2);
}

.kpi-bench-team-select {
    background: transparent;
    color: var(--text);
    font-size: var(--text-sm);
    padding: var(--s-1) var(--s-2);
    border-radius: var(--radius-s);
    border: none;
    outline: none;
    cursor: pointer;
}

.kpi-bench-period {
    display: flex;
    gap: var(--s-1);
}

.kpi-bench-period-btn {
    background: transparent;
    color: var(--text-faint);
    font-size: var(--text-sm);
    padding: var(--s-1) var(--s-2);
    border-radius: var(--radius-s);
    border: none;
    cursor: pointer;
    font-family: var(--font-mono);
    transition: color var(--duration-fast), background var(--duration-fast);
}

.kpi-bench-period-btn:hover {
    color: var(--text);
}

.kpi-bench-period-btn.active {
    color: var(--text);
    background: transparent;
}

/* ═══════════════════════════════════════════════════
   SLA 설정 탭
   ═══════════════════════════════════════════════════ */

.kpi-sla-section {
    padding: var(--s-3) 0;
}

.kpi-sla-section + .kpi-sla-section {
    padding-top: var(--s-2);
}

.kpi-sla-title {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    font-weight: var(--weight-semibold);
    color: var(--text-sub);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: var(--s-2);
}

.kpi-sla-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--text-sm);
}

.kpi-sla-table th {
    text-align: left;
    padding: var(--s-1) var(--s-2);
    color: var(--text-faint);
    font-weight: var(--weight-medium);
    font-size: var(--text-sm);
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.kpi-sla-table td {
    padding: var(--s-1) var(--s-2);
    color: var(--text);
}

.kpi-sla-priority-badge {
    display: inline-block;
    padding: var(--s-1) var(--s-1);
    border-radius: var(--radius-s);
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    font-weight: var(--weight-bold);
}

.kpi-sla-priority-badge.p0 {
    background: var(--clr-error-bg-lg);
    color: var(--clr-error);
}

.kpi-sla-priority-badge.p1 {
    background: var(--clr-warning-bg-lg);
    color: var(--clr-warning);
}

.kpi-sla-priority-badge.p2 {
    background: var(--clr-info-bg-lg);
    color: var(--clr-info);
}

.kpi-sla-priority-badge.p3 {
    background: var(--surface-w15);
    color: var(--text-sub);
}

.kpi-sla-form {
    display: flex;
    flex-direction: column;
    gap: var(--s-2);
}

.kpi-sla-row {
    display: flex;
    align-items: center;
    gap: var(--s-3);
}

.kpi-sla-row label {
    font-size: var(--text-sm);
    color: var(--text-sub);
    min-width: var(--s-20);
    flex-shrink: 0;
}

.kpi-sla-row select,
.kpi-sla-row input {
    flex: 1;
    max-width: var(--panel-w-sm);
    background: transparent;
    color: var(--text);
    font-size: var(--text-sm);
    padding: var(--s-1) var(--s-2);
    border-radius: var(--radius-s);
    border: none;
    outline: none;
    font-family: var(--font-mono);
}

.kpi-sla-row input:focus,
.kpi-sla-row select:focus {
    box-shadow: 0 0 0 1px var(--accent);
}

.kpi-sla-actions {
    padding-top: var(--s-1);
}

/* ── 채널 어댑터 설정 (Telegram/Slack) ── */
.kpi-ch-card {
    background: transparent;
    border-radius: var(--radius-s);
    padding: var(--s-2) var(--s-3);
    margin-top: var(--s-2);
}
.kpi-ch-card + .kpi-ch-card {
    margin-top: var(--s-2);
}
.kpi-ch-header {
    display: flex;
    align-items: center;
    gap: var(--s-2);
}
.kpi-ch-name {
    font-size: var(--text-sm);
    font-weight: var(--weight-semibold);
    color: var(--text);
    flex: 1;
}
.kpi-ch-toggle {
    position: relative;
    width: var(--s-6);
    height: var(--s-4-5);
    cursor: pointer;
}
.kpi-ch-toggle input {
    opacity: 0;
    width: 0;
    height: 0;
    position: absolute;
}
.kpi-ch-slider {
    position: absolute;
    inset: 0;
    background: var(--surface-w10);
    border-radius: var(--radius-s);
    transition: background var(--duration-base) var(--easing-smooth);
}
.kpi-ch-slider::before {
    content: '';
    position: absolute;
    width: var(--s-3-5);
    height: var(--s-3-5);
    border-radius: 50%;
    background: var(--text-faint);
    top: 2px;
    left: 2px;
    transition: transform var(--duration-base) var(--easing-smooth), background var(--duration-base) var(--easing-smooth);
}
.kpi-ch-toggle input:checked + .kpi-ch-slider {
    background: var(--accent);
}
.kpi-ch-toggle input:checked + .kpi-ch-slider::before {
    transform: translateX(14px);
    background: var(--bg);
}
.kpi-ch-body {
    margin-top: var(--s-2);
    display: flex;
    flex-direction: column;
    gap: var(--s-2);
}
.kpi-ch-actions {
    display: flex;
    gap: var(--s-2);
    justify-content: flex-end;
    padding-top: var(--s-1);
}
.kpi-ch-test-btn {
    background: none;
    color: var(--text-sub);
    font-size: var(--text-sm);
    padding: var(--s-1) var(--s-2);
    border-radius: var(--radius-s);
    border: none;
    cursor: pointer;
    transition: color var(--duration-fast) var(--easing-smooth);
}
.kpi-ch-test-btn:hover {
    color: var(--accent);
}

/* SLA 이력 추세 차트 */
.kpi-sla-chart-wrap {
    width: 100%;
    margin-top: var(--s-2);
}

.kpi-sla-chart-wrap canvas {
    width: 100%;
    display: block;
}

.kpi-sla-hist-summary {
    display: flex;
    align-items: center;
    gap: var(--s-3);
    flex-wrap: wrap;
    margin-bottom: var(--s-2);
}

.kpi-sla-hist-metric {
    display: flex;
    flex-direction: column;
    gap: var(--s-1);
}

.kpi-sla-hist-label {
    font-family: var(--font-mono);
    font-size: var(--text-3xs);
    color: var(--text-faint);
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.kpi-sla-hist-value {
    font-family: var(--font-mono);
    font-size: var(--text-base);
    font-weight: var(--weight-bold);
    color: var(--text);
}

.kpi-sla-hist-value--danger {
    color: var(--clr-error);
}

.kpi-sla-hist-prios {
    display: flex;
    gap: var(--s-1);
    margin-left: auto;
    flex-wrap: wrap;
}

/* ═══════════════════════════════════════════════════
   파이프라인 실시간 (pipeline_metrics)
   ═══════════════════════════════════════════════════ */

.kpi-pipeline-job {
    display: flex;
    align-items: center;
    gap: var(--s-2);
    padding: var(--s-1) var(--s-2);
    font-size: var(--text-sm);
    color: var(--text);
    background: transparent;
    border-radius: var(--radius-s);
    margin-bottom: var(--s-1);
}

.kpi-pipeline-job-scale {
    font-family: var(--font-mono);
    font-weight: var(--weight-bold);
    font-size: var(--text-sm);
    color: var(--accent);
}

.kpi-pipeline-job-round {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    color: var(--text-sub);
}

.kpi-pipeline-job-elapsed {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    color: var(--text-faint);
}

.kpi-pipeline-job-content {
    flex: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: var(--text-sub);
    font-size: var(--text-sm);
}

@media (max-width: 640px) {
    .kpi-bench-list {
        grid-template-columns: 1fr;
    }
    .kpi-sla-row {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--s-1);
    }
    .kpi-sla-row select,
    .kpi-sla-row input {
        max-width: 100%;
    }
}

/* ═══════════════════════════════════════════════════
   API Keys (Rate Limit 회복 상태) 탭
   ═══════════════════════════════════════════════════ */

.kpi-rl-state-badge {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    font-weight: var(--weight-bold);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wider);
    padding: 1px var(--s-1-5);
    border-radius: var(--radius-s);
}
.kpi-rl-state-badge.state-normal { color: var(--green); background: var(--green-bg); }
.kpi-rl-state-badge.state-degraded { color: var(--amber); background: var(--amber-bg); }
.kpi-rl-state-badge.state-cascade { color: var(--red); background: var(--red-bg); }

.kpi-rl-keys {
    display: flex;
    flex-direction: column;
    gap: 0;
}

.kpi-rl-key-item {
    display: flex;
    align-items: center;
    gap: var(--s-2);
    padding: var(--s-1) 0;
    font-size: var(--text-sm);
}
.kpi-rl-key-item + .kpi-rl-key-item { margin-top: var(--s-1); }

.kpi-rl-key-email {
    flex: 1;
    min-width: 0;
    color: var(--text);
    font-weight: var(--weight-medium);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.kpi-rl-key-bar {
    width: var(--s-9-5);
    height: var(--s-1);
    border-radius: var(--radius-pill);
    background: var(--surface-w6);
    flex-shrink: 0;
    overflow: hidden;
}
.kpi-rl-key-bar span {
    display: block;
    height: 100%;
    border-radius: var(--radius-pill);
    transition: width var(--duration-moderate) var(--easing-smooth);
}

.kpi-rl-key-status {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    padding: 1px var(--s-1-5);
    border-radius: var(--radius-s);
    flex-shrink: 0;
    white-space: nowrap;
}
.kpi-rl-key-status.healthy { color: var(--green); background: var(--green-bg); }
.kpi-rl-key-status.rate_limited { color: var(--red); background: var(--red-bg); }
.kpi-rl-key-status.cooling_down { color: var(--amber); background: var(--amber-bg); }
.kpi-rl-key-status.disabled { color: var(--text-faint); background: var(--surface-w6); }

.kpi-rl-key-stats {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text-faint);
    flex-shrink: 0;
    white-space: nowrap;
}

@media (max-width: 768px) {
    .kpi-rl-key-stats { display: none; }
    .kpi-rl-key-bar { width: var(--s-7-5); }
}

/* ── Rate Limit 요약 바 ── */
.kpi-rl-summary {
    display: flex;
    height: var(--s-1-5);
    border-radius: var(--radius-s);
    overflow: hidden;
    margin-bottom: var(--s-2);
    gap: var(--s-1);
}

.kpi-rl-summary-seg {
    border-radius: var(--radius-s);
    min-width: var(--s-1);
    transition: flex var(--duration-moderate) var(--easing-smooth);
}

.kpi-rl-summary-seg.healthy { background: var(--green); }
.kpi-rl-summary-seg.cooling { background: var(--amber); }
.kpi-rl-summary-seg.limited { background: var(--red); }
.kpi-rl-summary-seg.disabled { background: var(--text-faint); opacity: 0.3; }

.kpi-rl-summary-labels {
    display: flex;
    gap: var(--s-2);
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text-sub);
    margin-bottom: var(--s-2);
}

/* ── Benchmark 리더보드 랭킹 ── */
.kpi-bench-rank {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    font-weight: var(--weight-bold);
    color: var(--text-faint);
    min-width: var(--s-5);
    text-align: center;
    flex-shrink: 0;
}

.kpi-bench-rank-1 { color: var(--amber); }
.kpi-bench-rank-2 { color: var(--gray-light); }
.kpi-bench-rank-3 { color: var(--amber); }

.kpi-bench-top1 {
    background: linear-gradient(135deg, var(--bg-card) 0%, color-mix(in srgb, var(--rank-gold) 6%, transparent) 100%);
}

.kpi-bench-top2 {
    background: linear-gradient(135deg, var(--bg-card) 0%, color-mix(in srgb, var(--rank-silver) 4%, transparent) 100%);
}

.kpi-bench-top3 {
    background: linear-gradient(135deg, var(--bg-card) 0%, color-mix(in srgb, var(--rank-bronze) 4%, transparent) 100%);
}

/* 벤치마크 상세 드릴다운 */
.kpi-bench-detail {
    background: var(--bg-secondary);
    border-radius: var(--radius-s);
    padding: var(--s-4);
    margin-bottom: var(--s-2);
}
.kpi-bench-detail-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--s-3);
}
.kpi-bench-detail-title {
    font-weight: var(--weight-semibold);
    font-size: var(--text-sm);
    color: var(--text);
}
.kpi-bench-detail-close {
    background: none;
    border: none;
    color: var(--text-secondary);
    cursor: pointer;
    padding: var(--s-1);
}
.kpi-bench-detail-close:hover { color: var(--text); }
.kpi-bench-detail-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--s-2);
    margin-bottom: var(--s-3);
}
.kpi-bench-detail-stat {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--s-1);
}
.kpi-bench-detail-stat-val {
    font-size: var(--text-reading);
    font-weight: var(--weight-bold);
    color: var(--text);
}
.kpi-bench-detail-stat-label {
    font-size: var(--text-sm);
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.kpi-bench-detail-meta {
    font-size: var(--text-sm);
    color: var(--text-secondary);
    margin-bottom: var(--s-3);
}
.kpi-bench-detail-runs-title {
    font-size: var(--text-sm);
    font-weight: var(--weight-semibold);
    color: var(--text-secondary);
    margin-bottom: var(--s-1);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.kpi-bench-detail-runs {
    display: flex;
    flex-direction: column;
    gap: var(--s-1);
}
.kpi-bench-run-item {
    display: flex;
    align-items: center;
    gap: var(--s-2);
    font-size: var(--text-sm);
    color: var(--text-secondary);
    padding: var(--s-1) 0;
}
.kpi-bench-run-score { flex: 1; }
.kpi-bench-run-dur { color: var(--text-secondary); }
.kpi-bench-run-time { color: var(--text-secondary); font-size: var(--text-sm); }

/* ═══════════════════════════════════════════════════
   CEO Overview 서브뷰
   ═══════════════════════════════════════════════════ */

/* 헤더 */
.ceo-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--s-3) var(--s-4);
}
.ceo-header-left {
    display: flex;
    align-items: center;
    gap: var(--s-2);
}
.ceo-header-right {
    display: flex;
    align-items: center;
    gap: var(--s-2);
}
.ceo-title {
    font-size: var(--text-reading);
    font-weight: var(--weight-bold);
    color: var(--text);
    margin: 0;
}
.ceo-severity-badge {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    font-weight: var(--weight-bold);
    padding: var(--s-1) var(--s-2);
    border-radius: var(--radius-pill);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.ceo-sev--healthy { background: var(--green-bg); color: var(--green); }
.ceo-sev--warning { background: var(--amber-bg); color: var(--amber); }
.ceo-sev--critical { background: var(--red-bg); color: var(--red); }
.ceo-response-time {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text-faint);
}

/* 경고 배너 */
.ceo-alerts-banner {
    display: flex;
    flex-wrap: wrap;
    gap: var(--s-2);
    padding: var(--s-2) var(--s-4);
    margin: 0 var(--s-4) var(--s-2);
    border-radius: var(--radius-s);
    font-size: var(--text-sm);
    font-family: var(--font-mono);
}
.ceo-banner--warning { background: var(--amber-bg); color: var(--amber); }
.ceo-banner--critical { background: var(--red-bg); color: var(--red); }
.ceo-banner-item { white-space: nowrap; }

/* 메트릭 카드 그리드 */
.ceo-metrics-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: var(--s-2);
    padding: 0 var(--s-4) var(--s-3);
}
.ceo-metric-card {
    background: transparent;
    border-radius: var(--radius-s);
    padding: var(--s-2) var(--s-3);
    display: flex;
    flex-direction: column;
    gap: var(--s-1);
}
.ceo-metric-label {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text-sub);
    text-transform: uppercase;
    letter-spacing: 0.3px;
}
.ceo-metric-value {
    font-size: var(--text-xl);
    font-weight: var(--weight-bold);
    font-family: var(--font-mono);
    color: var(--text);
    line-height: 1.2;
}
.ceo-metric-sub {
    font-size: var(--text-sm);
    color: var(--text-faint);
    font-family: var(--font-mono);
}
.ceo-val--warning { color: var(--amber); }
.ceo-val--critical { color: var(--red); }

/* 하단 2열 */
.ceo-bottom-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--s-3);
    padding: 0 var(--s-4) var(--s-4);
}
.ceo-panel {
    background: transparent;
    border-radius: var(--radius-s);
    padding: var(--s-3);
    display: flex;
    flex-direction: column;
    gap: var(--s-2);
    max-height: 480px;
    overflow-y: auto;
}
.ceo-panel-title {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    font-weight: var(--weight-semibold);
    color: var(--text-sub);
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

/* 파이프라인 Job 아이템 */
.ceo-job-item {
    background: var(--bg);
    border-radius: var(--radius-s);
    padding: var(--s-2);
    display: flex;
    flex-direction: column;
    gap: var(--s-1);
}
.ceo-job-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.ceo-job-id {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text);
    font-weight: var(--weight-semibold);
}
.ceo-job-scale {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    font-weight: var(--weight-bold);
    color: var(--accent);
}
.ceo-job-bottom {
    display: flex;
    gap: var(--s-2);
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text-faint);
}
.ceo-job-content {
    font-size: var(--text-sm);
    color: var(--text-faint);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* 알림 아이템 */
.ceo-alert-item {
    background: var(--bg);
    border-radius: var(--radius-s);
    padding: var(--s-2);
    display: flex;
    flex-direction: column;
    gap: var(--s-1);
}
.ceo-alert--p0 { background: var(--red-bg); }
.ceo-alert--p1 { background: var(--amber-bg); }
.ceo-alert-top {
    display: flex;
    gap: var(--s-2);
    align-items: center;
}
.ceo-alert-prio {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    font-weight: var(--weight-bold);
}
.ceo-alert--p0 .ceo-alert-prio { color: var(--red); }
.ceo-alert--p1 .ceo-alert-prio { color: var(--amber); }
.ceo-alert--p2 .ceo-alert-prio { color: var(--text-faint); }
.ceo-alert-type {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text-sub);
}
.ceo-alert-msg {
    font-size: var(--text-sm);
    color: var(--text);
}
.ceo-alert-agent {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text-faint);
}

/* ── Token Usage 트렌드 ── */
.kpi-token-summary {
    display: flex;
    gap: var(--sp-lg);
    flex-wrap: wrap;
    margin-bottom: var(--sp-xl);
}
.kpi-token-stat {
    flex: 1;
    min-width: var(--s-16);
    padding: var(--sp-lg);
    background: var(--bg-card);
    border-radius: var(--radius-s);
    text-align: center;
}
.kpi-token-stat-label {
    font-size: var(--text-sm);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--text-secondary);
    margin-bottom: var(--sp-xs);
}
.kpi-token-stat-value {
    font-size: var(--text-lg);
    font-weight: var(--weight-semibold);
    font-family: var(--font-mono);
    color: var(--text);
}
.kpi-token-chart {
    margin-bottom: var(--sp-xl);
}
.kpi-token-legend {
    display: flex;
    gap: var(--sp-lg);
    margin-bottom: var(--sp-md);
    font-size: var(--text-sm);
    color: var(--text-secondary);
}
.kpi-token-legend-item {
    display: flex;
    align-items: center;
    gap: var(--sp-xs);
}
.kpi-token-dot {
    display: inline-block;
    width: var(--s-2);
    height: var(--s-2);
    border-radius: var(--radius-s);
}
.kpi-token-dot--input { background: var(--accent); }
.kpi-token-dot--output { background: var(--amber); }
.kpi-token-bars {
    display: flex;
    align-items: flex-end;
    gap: var(--s-1);
    min-height: clamp(100px, 18vw, 160px);
    padding-bottom: var(--sp-xl);
}
.kpi-token-bar-group {
    display: flex;
    flex-direction: column;
    align-items: center;
}
.kpi-token-bar-stack {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    width: 100%;
    max-width: var(--s-6);
    margin: 0 auto;
}
.kpi-token-bar {
    min-height: 1px;
    border-radius: var(--radius-s) var(--radius-s) 0 0;
}
.kpi-token-bar--input { background: var(--accent); }
.kpi-token-bar--output { background: var(--amber); border-radius: var(--radius-s) var(--radius-s) 0 0; }
.kpi-token-bar-label {
    font-size: var(--text-3xs);
    color: var(--text-secondary);
    margin-top: var(--sp-xs);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
    text-align: center;
}
.kpi-token-details-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-xl);
}
.kpi-token-section-title {
    font-size: var(--text-sm);
    font-weight: var(--weight-semibold);
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: var(--sp-md);
}
.kpi-token-table {
    width: 100%;
    border-collapse: collapse;
    font-size: var(--text-sm);
    font-family: var(--font-mono);
}
.kpi-token-table th {
    text-align: left;
    font-size: var(--text-sm);
    text-transform: uppercase;
    color: var(--text-secondary);
    padding: var(--sp-xs) var(--sp-md);
    font-weight: var(--weight-medium);
}
.kpi-token-table td {
    padding: var(--sp-xs) var(--sp-md);
    color: var(--text-secondary);
}
.kpi-token-table tr:hover td {
    color: var(--text);
}
.kpi-select {
    background-color: var(--bg-card);
    color: var(--text-secondary);
    border: none;
    border-radius: var(--radius-s);
    padding: var(--sp-xs) var(--sp-md);
    font-size: var(--text-sm);
    font-family: var(--font);
    cursor: pointer;
}
.kpi-select:hover { color: var(--text); }

/* 반응형 — Token Usage */
@media (max-width: 768px) {
    .kpi-token-details-grid { grid-template-columns: 1fr; }
    .kpi-token-summary { gap: var(--sp-md); }
    .kpi-token-stat { min-width: var(--s-11); }
}

/* 반응형 — CEO Overview */
@media (max-width: 960px) {
    .ceo-metrics-grid { grid-template-columns: repeat(3, 1fr); }
    .ceo-bottom-grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
    .ceo-metrics-grid { grid-template-columns: repeat(2, 1fr); }
}

/* -- 벤치마크 이전기간 요약 -- */
.kpi-bench-stat--prev {
    color: var(--text-faint);
    font-size: var(--text-sm);
    opacity: 0.85;
}

/* -- 벤치마크 delta 비교 표시 -- */
.kpi-delta-up {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--clr-success);
    margin-left: var(--sp-2xs);
}
.kpi-delta-down {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--clr-error);
    margin-left: var(--sp-2xs);
}

/* -- 벤치마크 비교 모드 -- */
.kpi-bench-compare-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--s-1);
    padding: var(--s-1) var(--s-2);
    background: var(--surface);
    border: none;
    border-radius: var(--radius-s);
    color: var(--text-sub);
    font-size: var(--text-sm);
    cursor: pointer;
    transition: background var(--duration-fast) var(--easing-smooth), color var(--duration-fast) var(--easing-smooth);
}
.kpi-bench-compare-btn:hover {
    background: var(--surface-hover);
    color: var(--text);
}
.kpi-bench-compare-btn.active {
    background: var(--accent-dim);
    color: var(--accent);
}
.kpi-bench-compare-bar {
    display: none;
    align-items: center;
    justify-content: space-between;
    padding: var(--s-2) var(--s-3);
    background: transparent;
    border-radius: var(--radius-s);
    margin-bottom: var(--s-2);
}
.kpi-bench-compare-bar--active {
    display: flex;
}
.kpi-bench-compare-names {
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    color: var(--text-sub);
}
.kpi-bench-compare-run {
    padding: var(--s-1) var(--s-3);
    background: var(--accent);
    border: none;
    border-radius: var(--radius-s);
    color: var(--bg);
    font-size: var(--text-sm);
    font-weight: var(--weight-semibold);
    cursor: pointer;
    transition: opacity var(--duration-fast) var(--easing-smooth);
}
.kpi-bench-compare-run:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}
.kpi-bench-compare-run:not(:disabled):hover {
    opacity: 0.85;
}
.kpi-bench-card--selected {
    outline: 2px solid var(--accent);
    outline-offset: -2px;
}
.kpi-bench-card {
    cursor: pointer;
}
.kpi-bench-compare-grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 0;
    background: transparent;
    border-radius: var(--radius-s);
    overflow: hidden;
    margin-bottom: var(--s-3);
}
.kpi-bench-compare-header {
    display: contents;
}
.kpi-bench-compare-header > span {
    padding: var(--s-2) var(--s-3);
    background: var(--surface);
    font-size: var(--text-sm);
    font-weight: var(--weight-semibold);
    font-family: var(--font-mono);
    color: var(--text);
}
.kpi-bench-compare-row {
    display: contents;
}
.kpi-bench-compare-label {
    padding: var(--s-2) var(--s-3);
    font-size: var(--text-sm);
    color: var(--text-sub);
    background: var(--surface);
}
.kpi-bench-compare-val {
    padding: var(--s-2) var(--s-3);
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    font-weight: var(--weight-semibold);
    color: var(--text);
    text-align: center;
}
.kpi-bench-compare-agent {
    text-align: center;
}
