/* 卡片 */
.card {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-card);
  transition:
    border-color var(--dur-base) var(--ease-out),
    transform var(--dur-base) var(--ease-out),
    box-shadow var(--dur-base) var(--ease-out);
  position: relative;
}

.card-hoverable:hover {
  border-color: var(--border-emphasis);
  transform: translateY(-3px);
  box-shadow: var(--shadow-card-hover);
}

.card-glass {
  background: var(--bg-glass);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
}

.card-elevated {
  background: var(--bg-elevated);
  box-shadow: 0 24px 60px rgba(0, 0, 0, .5), var(--shadow-glow);
}

.card-bordered {
  background: transparent;
  border: 1px solid var(--border-emphasis);
}

.card-glow {
  position: relative;
}
.card-glow::before {
  content: '';
  position: absolute;
  inset: -1px;
  background: var(--grad-primary);
  border-radius: inherit;
  z-index: -1;
  opacity: 0;
  transition: opacity var(--dur-base) var(--ease-out);
}
.card-glow:hover::before { opacity: .7; filter: blur(8px); }

/* 子结构 */
.card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}
.card-title {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0;
}
.card-subtitle {
  font-size: 13px;
  color: var(--text-secondary);
  margin-top: 4px;
}
.card-body { color: var(--text-secondary); }
.card-body > * + * { margin-top: var(--space-3); }

.card-footer {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-3);
  margin-top: var(--space-5);
  padding-top: var(--space-4);
  border-top: 1px solid var(--border-subtle);
}

/* 紧凑卡片 */
.card-compact {
  padding: var(--space-4);
}
