/* Cruna Dev Dashboard — 组件 (浅色) */

/* ── 呼吸动画 ── */
@keyframes dot-pulse {
  0%, 100% { box-shadow: 0 0 0 0 var(--dot-green-glow); }
  50%      { box-shadow: 0 0 0 4px transparent; }
}

@keyframes dot-pulse-red {
  0%, 100% { box-shadow: 0 0 0 0 var(--dot-red-glow); }
  50%      { box-shadow: 0 0 0 4px transparent; }
}

/* ── 卡片 ── */
.card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-base);
  margin-bottom: var(--space-4);
  overflow: hidden;
  transition: box-shadow var(--duration-normal) var(--ease-default),
              transform var(--duration-normal) var(--ease-default);
}

.card:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-1px);
}

.card__head {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-border-light);
}

.card__icon {
  font-size: 15px;
  flex-shrink: 0;
}

.card__title {
  font-weight: var(--weight-semibold);
  font-size: var(--text-md);
  flex: 1;
  color: var(--color-text-primary);
}

.card__badge {
  font-size: var(--text-xs);
  padding: 1px var(--space-2);
  border-radius: var(--radius-pill);
  font-weight: var(--weight-semibold);
  font-family: var(--font-mono);
  background: var(--port-tag-bg);
  color: var(--port-tag-color);
}

.card__body {
  padding: var(--space-3) var(--space-4);
}

/* ── 状态圆点 ── */
.dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-full);
  flex-shrink: 0;
  display: inline-block;
}

.dot--green {
  background: var(--color-success);
  animation: dot-pulse var(--duration-pulse) ease-in-out infinite;
}

.dot--red {
  background: var(--color-danger);
  animation: dot-pulse-red var(--duration-pulse) ease-in-out infinite;
}

.dot--amber {
  background: var(--color-warning);
}

.dot--gray {
  background: var(--color-text-muted);
}

/* ── 数据行 ── */
.row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-1);
  font-size: var(--text-base);
  border-bottom: 1px solid var(--color-border-light);
  border-radius: var(--radius-xs);
  transition: background var(--duration-fast) var(--ease-default);
}

.row:last-child {
  border-bottom: none;
}

.row:hover {
  background: var(--color-primary-ghost);
}

.row__name {
  font-weight: var(--weight-semibold);
  color: var(--color-text-primary);
  white-space: nowrap;
}

.row__meta {
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
  font-family: var(--font-mono);
  white-space: nowrap;
}

.row__spacer {
  flex: 1;
}

.row__value {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--color-text-regular);
  white-space: nowrap;
}

/* ── 端口标签 ── */
.port-tag {
  font-size: var(--text-xs);
  font-family: var(--font-mono);
  color: var(--port-tag-color);
  background: var(--port-tag-bg);
  padding: 1px var(--space-2);
  border-radius: var(--radius-pill);
  white-space: nowrap;
}

/* ── 统计网格 ── */
.stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2);
}

.stat {
  padding: var(--space-2) var(--space-3);
  background: var(--color-bg-inset);
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border-light);
}

.stat__label {
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-1);
  font-weight: var(--weight-medium);
}

.stat__value {
  font-size: var(--text-lg);
  font-weight: var(--weight-bold);
  font-family: var(--font-mono);
  color: var(--color-text-primary);
}

.stat__value--small {
  font-size: var(--text-md);
}

/* ── 表格行 ── */
.table-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-2);
  padding: var(--space-1) 0;
  font-size: var(--text-sm);
  border-bottom: 1px solid var(--color-border-light);
}

.table-row:last-child {
  border-bottom: none;
}

.table-row__key {
  color: var(--color-text-regular);
}

.table-row__val {
  font-family: var(--font-mono);
  color: var(--color-text-primary);
  text-align: right;
}

/* ── 任务条目 ── */
.job {
  padding: var(--space-2) var(--space-3);
  background: var(--color-bg-inset);
  border-radius: var(--radius-sm);
  border: 1px solid var(--color-border-light);
  margin-bottom: var(--space-2);
  font-size: var(--text-sm);
}

.job:last-child {
  margin-bottom: 0;
}

.job__header {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-1);
}

.job__id {
  font-family: var(--font-mono);
  color: var(--color-text-secondary);
  font-size: var(--text-xs);
}

.job__detail {
  color: var(--color-text-secondary);
  font-size: var(--text-xs);
  line-height: var(--leading-tight);
}

/* ── 状态徽章 ── */
.badge {
  display: inline-block;
  font-size: 10px;
  padding: 1px var(--space-2);
  border-radius: var(--radius-pill);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.badge--completed  { background: var(--badge-completed-bg);  color: var(--color-success); }
.badge--processing { background: var(--badge-processing-bg); color: #409eff; }
.badge--pending    { background: var(--badge-pending-bg);    color: var(--color-warning); }
.badge--failed     { background: var(--badge-failed-bg);     color: var(--color-danger); }

/* ── 快捷链接 ── */
.links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-1) var(--space-3);
  background: var(--link-bg);
  border: 1px solid var(--link-border);
  border-radius: var(--radius-pill);
  color: var(--color-primary);
  text-decoration: none;
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  transition: background var(--duration-fast) var(--ease-default);
}

.link:hover {
  background: var(--link-bg-hover);
}

/* ── 进度条 ── */
.progress {
  height: 4px;
  background: var(--color-border-light);
  border-radius: 2px;
  overflow: hidden;
  margin-top: var(--space-1);
}

.progress__bar {
  height: 100%;
  border-radius: 2px;
  transition: width var(--duration-normal) var(--ease-default);
}

.progress__bar--green { background: var(--color-success); }
.progress__bar--amber { background: var(--color-warning); }
.progress__bar--red   { background: var(--color-danger); }

/* ── 空状态 ── */
.empty {
  text-align: center;
  padding: var(--space-4);
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
  font-style: italic;
}
