/**
 * Claude Agent Dashboard - 전용 스타일
 */

/* ========== 페이지 공통 ========== */

.page-wrapper {
  padding: var(--content-padding);
}

.page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--spacing-6);
}

.page-title {
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  color: var(--text-primary);
}

.page-subtitle {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin-top: var(--spacing-1);
}

/* ========== 요약 카드 ========== */

.stat-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--spacing-4);
  margin-bottom: var(--spacing-6);
}

.stat-card {
  background: var(--bg-primary);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-xl);
  padding: var(--spacing-5);
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-base);
}

.stat-card:hover { box-shadow: var(--shadow-md); }

.stat-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--spacing-3);
}

.stat-card-label {
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--text-secondary);
}

.stat-card-icon {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
}

.stat-card-icon.blue   { background: var(--color-info-light);    color: var(--color-primary); }
.stat-card-icon.green  { background: var(--color-success-light);  color: var(--color-success); }
.stat-card-icon.yellow { background: var(--color-warning-light);  color: var(--color-warning); }
.stat-card-icon.red    { background: var(--color-error-light);    color: var(--color-error); }
.stat-card-icon.purple { background: #f3e8ff;                    color: #7c3aed; }

.stat-card-value {
  font-size: var(--text-3xl);
  font-weight: var(--font-bold);
  color: var(--text-primary);
  line-height: 1;
  margin-bottom: var(--spacing-1);
}

.stat-card-change {
  font-size: var(--text-xs);
  color: var(--text-tertiary);
}

/* ========== 차트 카드 ========== */

.chart-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: var(--spacing-4);
  margin-bottom: var(--spacing-6);
}

.chart-card {
  background: var(--bg-primary);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-xl);
  padding: var(--spacing-5);
  box-shadow: var(--shadow-sm);
}

.chart-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--spacing-4);
}

.chart-card-title {
  font-size: var(--text-base);
  font-weight: var(--font-semibold);
  color: var(--text-primary);
}

.chart-wrapper {
  position: relative;
  width: 100%;
}

/* ========== 세션 리스트 카드 ========== */

.section-card {
  background: var(--bg-primary);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-xl);
  padding: var(--spacing-5);
  box-shadow: var(--shadow-sm);
  margin-bottom: var(--spacing-4);
}

.section-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--spacing-4);
  padding-bottom: var(--spacing-3);
  border-bottom: 1px solid var(--border-light);
}

.section-card-title {
  font-size: var(--text-base);
  font-weight: var(--font-semibold);
  color: var(--text-primary);
}

/* ========== 프로젝트 카드 ========== */

.project-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--spacing-4);
}

.project-card {
  background: var(--bg-primary);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-xl);
  padding: var(--spacing-5);
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-base);
}

.project-card:hover { box-shadow: var(--shadow-md); }

.project-card-path {
  font-family: monospace;
  font-size: var(--text-xs);
  color: var(--text-secondary);
  background: var(--bg-tertiary);
  padding: var(--spacing-1) var(--spacing-2);
  border-radius: var(--radius-md);
  margin-bottom: var(--spacing-3);
  word-break: break-all;
}

.project-card-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-3);
  margin-top: var(--spacing-3);
}

.project-stat-item { }
.project-stat-label { font-size: var(--text-xs); color: var(--text-tertiary); }
.project-stat-value { font-size: var(--text-sm); font-weight: var(--font-semibold); color: var(--text-primary); }

/* ========== 에이전트 카드 ========== */

.agent-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--spacing-4);
}

.agent-card {
  background: var(--bg-primary);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-xl);
  padding: var(--spacing-5);
  box-shadow: var(--shadow-sm);
}

.agent-card-header {
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-3);
  margin-bottom: var(--spacing-3);
}

.agent-avatar {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-xl);
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 1.5rem;
  flex-shrink: 0;
}

.agent-name {
  font-size: var(--text-base);
  font-weight: var(--font-semibold);
  color: var(--text-primary);
}

.agent-desc {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin-top: var(--spacing-2);
  line-height: 1.6;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ========== 태스크 칸반 ========== */

.kanban-board {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--spacing-4);
  align-items: start;
}

.kanban-column {
  background: var(--bg-secondary);
  border-radius: var(--radius-xl);
  padding: var(--spacing-4);
  min-height: 400px;
}

.kanban-column-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--spacing-4);
  padding-bottom: var(--spacing-3);
  border-bottom: 2px solid var(--border-light);
}

.kanban-column-title {
  font-weight: var(--font-semibold);
  color: var(--text-primary);
  display: flex;
  align-items: center;
  gap: var(--spacing-2);
}

.kanban-count {
  background: var(--bg-tertiary);
  color: var(--text-secondary);
  border-radius: var(--radius-full);
  padding: 2px 8px;
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
}

.kanban-pending   .kanban-column-header { border-bottom-color: var(--color-warning); }
.kanban-progress  .kanban-column-header { border-bottom-color: var(--color-primary); }
.kanban-completed .kanban-column-header { border-bottom-color: var(--color-success); }

.task-card {
  background: var(--bg-primary);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-lg);
  padding: var(--spacing-3) var(--spacing-4);
  margin-bottom: var(--spacing-3);
  box-shadow: var(--shadow-sm);
  cursor: pointer;
  transition: box-shadow var(--transition-base);
}

.task-card:hover { box-shadow: var(--shadow-md); }

.task-subject {
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--text-primary);
  margin-bottom: var(--spacing-2);
}

.task-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: var(--text-xs);
  color: var(--text-tertiary);
}

.task-owner {
  display: flex;
  align-items: center;
  gap: var(--spacing-1);
}

/* ========== 메모리 파일 뷰어 ========== */

.memory-viewer {
  background: var(--bg-primary);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-xl);
  overflow: hidden;
}

.memory-viewer-header {
  padding: var(--spacing-4) var(--spacing-5);
  border-bottom: 1px solid var(--border-light);
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--bg-secondary);
}

.memory-content {
  padding: var(--spacing-5);
  font-size: var(--text-sm);
  line-height: 1.7;
  color: var(--text-primary);
}

.memory-content h1, .memory-content h2, .memory-content h3 {
  margin: var(--spacing-4) 0 var(--spacing-2);
  color: var(--text-primary);
}

.memory-content h1 { font-size: var(--text-xl); border-bottom: 1px solid var(--border-light); padding-bottom: var(--spacing-2); }
.memory-content h2 { font-size: var(--text-lg); }
.memory-content h3 { font-size: var(--text-base); }

.memory-content p { margin-bottom: var(--spacing-3); }
.memory-content ul, .memory-content ol { margin-left: var(--spacing-5); margin-bottom: var(--spacing-3); list-style: disc; }
.memory-content li { margin-bottom: var(--spacing-1); }
.memory-content code {
  background: var(--bg-tertiary);
  padding: 2px 6px;
  border-radius: var(--radius-sm);
  font-family: monospace;
  font-size: 0.9em;
}
.memory-content pre {
  background: var(--bg-tertiary);
  padding: var(--spacing-4);
  border-radius: var(--radius-lg);
  overflow-x: auto;
  margin-bottom: var(--spacing-3);
}
.memory-content pre code { background: none; padding: 0; }
.memory-content blockquote {
  border-left: 3px solid var(--color-primary);
  padding-left: var(--spacing-4);
  color: var(--text-secondary);
  margin-bottom: var(--spacing-3);
}

/* 메모리 에디터 */
.memory-editor {
  width: 100%;
  min-height: 400px;
  font-family: monospace;
  font-size: var(--text-sm);
  padding: var(--spacing-4);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-lg);
  background: var(--bg-primary);
  color: var(--text-primary);
  resize: vertical;
}

/* ========== 애널리틱스 히트맵 ========== */

.heatmap-grid {
  display: grid;
  grid-template-columns: repeat(24, 1fr);
  gap: 4px;
  margin-top: var(--spacing-3);
}

.heatmap-cell {
  aspect-ratio: 1;
  border-radius: 3px;
  background: var(--bg-tertiary);
  cursor: pointer;
  transition: opacity var(--transition-fast);
  min-width: 0;
}

.heatmap-cell:hover { opacity: 0.8; }
.heatmap-cell[data-level="1"] { background: var(--color-info-lighter); }
.heatmap-cell[data-level="2"] { background: var(--color-primary-light); }
.heatmap-cell[data-level="3"] { background: var(--color-primary); }
.heatmap-cell[data-level="4"] { background: var(--color-primary-dark); }

.heatmap-labels {
  display: grid;
  grid-template-columns: repeat(24, 1fr);
  gap: 4px;
  margin-top: var(--spacing-1);
}

.heatmap-label {
  text-align: center;
  font-size: 10px;
  color: var(--text-tertiary);
}

/* ========== 기간 필터 탭 ========== */

.period-tabs {
  display: flex;
  gap: var(--spacing-2);
}

.period-tab {
  padding: var(--spacing-1) var(--spacing-3);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--font-medium);
  cursor: pointer;
  border: 1px solid var(--border-light);
  color: var(--text-secondary);
  background: var(--bg-primary);
  transition: all var(--transition-fast);
}

.period-tab:hover { border-color: var(--color-primary); color: var(--color-primary); }
.period-tab.active { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }

/* ========== 반응형 ========== */

@media (max-width: 1200px) {
  .stat-cards { grid-template-columns: repeat(2, 1fr); }
  .chart-grid { grid-template-columns: 1fr; }
  .kanban-board { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  .page-wrapper { padding: var(--spacing-4); }
  .stat-cards { grid-template-columns: 1fr; }
}

/* ========== 다크모드 ========== */
[data-theme="dark"] .stat-card,
[data-theme="dark"] .chart-card,
[data-theme="dark"] .section-card,
[data-theme="dark"] .project-card,
[data-theme="dark"] .agent-card,
[data-theme="dark"] .task-card,
[data-theme="dark"] .memory-viewer {
  background: var(--bg-primary);
  border-color: var(--border-light);
}

[data-theme="dark"] .kanban-column {
  background: var(--bg-secondary);
}

/* ========== 실시간 모니터링 ========== */

.live-pulse-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  display: inline-block;
  flex-shrink: 0;
}

.live-status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #94a3b8;
  display: inline-block;
  margin-right: 6px;
  vertical-align: middle;
}

.live-loading {
  text-align: center;
  padding: 2rem;
  color: var(--text-tertiary);
  font-size: 0.875rem;
}

.live-empty {
  text-align: center;
  padding: 2rem;
  color: var(--text-tertiary);
  font-size: 0.875rem;
}

.live-task-card {
  background: var(--bg-secondary);
  border: 1px solid var(--border-light);
  border-left: 4px solid var(--color-primary);
  border-radius: 8px;
  padding: 1rem;
  transition: box-shadow 0.2s ease;
}

.live-task-card:hover {
  box-shadow: var(--shadow-md);
}

[data-theme="dark"] .live-task-card {
  background: var(--bg-primary);
}
