/**
 * @file
 * Card component styles
 * Replicating shadcn/ui Card component
 */

/* Base card */
.card {
  background-color: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.card-header {
  padding: var(--spacing-6);
  border-bottom: 1px solid var(--color-border);
}

.card-title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  margin: 0;
}

.card-description {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  margin-top: var(--spacing-1);
}

.card-content {
  padding: var(--spacing-6);
}

.card-footer {
  padding: var(--spacing-6);
  border-top: 1px solid var(--color-border);
  background-color: var(--color-gray-50);
}

/* Stat card (for dashboard) */
.stat-card {
  background-color: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--spacing-6);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-2);
}

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

.stat-card-icon.primary {
  background-color: var(--color-primary-100);
  color: var(--color-primary);
}

.stat-card-icon.success {
  background-color: var(--color-success-bg);
  color: var(--color-success);
}

.stat-card-icon.warning {
  background-color: var(--color-warning-bg);
  color: var(--color-warning);
}

.stat-card-icon.danger {
  background-color: var(--color-danger-bg);
  color: var(--color-danger);
}

.stat-card-icon.info {
  background-color: var(--color-info-bg);
  color: var(--color-info);
}

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

.stat-card-value {
  font-size: var(--font-size-2xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
}

.stat-card-change {
  font-size: var(--font-size-sm);
  display: flex;
  align-items: center;
  gap: var(--spacing-1);
}

.stat-card-change.positive {
  color: var(--color-success);
}

.stat-card-change.negative {
  color: var(--color-danger);
}

/* Card grid */
.card-grid {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: var(--spacing-4);
}

@media (min-width: 640px) {
  .card-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .card-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 1280px) {
  .card-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

/* Clickable card */
.card-clickable {
  cursor: pointer;
  transition: all var(--transition-fast);
}

.card-clickable:hover {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-md);
}

/* Card variants */
.card-primary {
  border-left: 4px solid var(--color-primary);
}

.card-success {
  border-left: 4px solid var(--color-success);
}

.card-warning {
  border-left: 4px solid var(--color-warning);
}

.card-danger {
  border-left: 4px solid var(--color-danger);
}
