/*
 * Card styles - Premium feel with subtle depth
 */

@layer components {
  .card {
    background-color: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    overflow: hidden;
  }

  .card-interactive {
    transition: 
      border-color var(--duration-fast) var(--ease-out),
      background-color var(--duration-fast) var(--ease-out);

    &:hover {
      border-color: var(--color-border-strong);
      background-color: var(--color-surface-raised);
    }
  }

  .card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    padding: var(--space-5) var(--space-6);
    border-block-end: 1px solid var(--color-border-muted);

    & h3 {
      font-size: var(--text-base);
      font-weight: var(--font-semibold);
      margin: 0;
      letter-spacing: -0.01em;
    }
  }

  .card-body {
    padding: var(--space-6);
  }

  .card-body-compact {
    padding: var(--space-4) var(--space-6);
  }

  .card-footer {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    padding: var(--space-4) var(--space-6);
    border-block-start: 1px solid var(--color-border-muted);
    background-color: var(--color-surface-muted);
  }

  .card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: var(--space-5);
  }

  /* Flush card - no padding, for custom content */
  .card-flush {
    & .card-body {
      padding: 0;
    }
  }

  /* Stat card variant */
  .card-stat {
    padding: var(--space-5) var(--space-6);
    text-align: center;

    & .stat-value {
      font-size: var(--text-3xl);
      font-weight: var(--font-bold);
      letter-spacing: -0.02em;
      color: var(--color-ink);
      line-height: 1;
    }

    & .stat-label {
      margin-block-start: var(--space-1);
      font-size: var(--text-sm);
      color: var(--color-ink-muted);
    }

    & .stat-trend {
      margin-block-start: var(--space-2);
      font-size: var(--text-xs);
      font-weight: var(--font-medium);
    }

    & .stat-trend-up {
      color: var(--color-positive);
    }

    & .stat-trend-down {
      color: var(--color-negative);
    }
  }

  /* Project card */
  .project-card {
    display: block;
    text-decoration: none;
    color: inherit;

    &:hover {
      text-decoration: none;
    }
  }

  .project-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-3);
    margin-block-end: var(--space-3);
  }

  .project-card-name {
    margin: 0;
    font-size: var(--text-lg);
    font-weight: var(--font-semibold);
    letter-spacing: -0.01em;
    color: var(--color-ink);
  }

  .project-card-meta {
    margin: 0;
    font-size: var(--text-sm);
    color: var(--color-ink-muted);
  }
}
