// ─────────────────────────────────────────────────────────────────────────────
// Component: Cards
// File: src/scss/components/_cards.scss
//
// Variants: .card .card--elevated .card--hover .card--repo .card--stat
// .card--accent-top .card--accent-{color}
// Tokens: --bg-surface, --bg-elevated, --border-default, --border-glow
// Usage:
…
//
// Notes: No drop shadows — in a dark theme, use border-lift instead.
// Active/selected state: 2px left accent bar via --dd-accent.
// ─────────────────────────────────────────────────────────────────────────────
.card {
background: var(--bg-surface);
border: 1px solid var(--border-default);
border-radius: var(--radius-md);
padding: var(--space-4);
transition: border-color var(--transition-base), background var(--transition-base);
}
.card--elevated {
background: var(--bg-elevated);
}
.card--hover {
cursor: pointer;
transition: border-color var(--transition-fast), background var(--transition-fast), transform var(--transition-fast);
&:hover {
border-color: var(--border-glow);
background: var(--bg-elevated);
transform: translateY(-2px);
}
}
// Repo card grid
.card--repo {
position: relative;
background: transparent;
border: 1px solid var(--border-subtle);
border-radius: var(--radius-sm);
padding: var(--space-3);
cursor: pointer;
text-decoration: none;
display: flex;
flex-direction: column;
gap: var(--space-2);
color: inherit;
transition: border-color var(--transition-fast), background var(--transition-fast);
&:hover {
border-color: var(--border-default);
background: color-mix(in srgb, var(--text-primary) 2%, transparent);
text-decoration: none;
color: inherit;
}
}
// Stat card
.card--stat {
background: var(--bg-surface);
border: 1px solid var(--border-default);
border-radius: var(--radius-base);
padding: var(--space-4);
text-align: center;
.stat-value {
font-family: var(--font-mono);
font-size: var(--text-2xl);
font-weight: var(--weight-bold);
color: var(--color-accent);
display: block;
line-height: 1.1;
}
.stat-label {
font-size: var(--text-sm);
color: var(--text-muted);
margin-top: var(--space-1);
}
}
// Top accent bar variants
.card--accent-top { border-top: 3px solid var(--color-accent); }
.card--accent-success { border-top: 3px solid var(--color-success); }
.card--accent-warning { border-top: 3px solid var(--color-warning); }
.card--accent-danger { border-top: 3px solid var(--color-danger); }
.card--accent-purple { border-top: 3px solid var(--color-purple); }
.card--accent-orange { border-top: 3px solid var(--color-orange); }
// Legacy class aliases
.card-accent-top { border-top: 3px solid var(--color-accent); }
.card-accent-success { border-top: 3px solid var(--color-success); }
.card-accent-warning { border-top: 3px solid var(--color-warning); }
.card-accent-danger { border-top: 3px solid var(--color-danger); }
.card-accent-purple { border-top: 3px solid var(--color-purple); }
.card-accent-orange { border-top: 3px solid var(--color-orange); }
.card-accent-harmonic { border-top: 3px solid var(--dim-harmonic); }
.card-accent-rhythmic { border-top: 3px solid var(--dim-rhythmic); }
.card-accent-melodic { border-top: 3px solid var(--dim-melodic); }
.card-accent-structural { border-top: 3px solid var(--dim-structural); }
.card-accent-dynamic { border-top: 3px solid var(--dim-dynamic); }
.card-hover {
transition: transform var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);
&:hover {
transform: translateY(-2px);
box-shadow: var(--shadow-md);
}
}
// Stat pill — number + label display used in hero right column and dashboards
.stat-pill {
display: flex;
align-items: center;
gap: 10px;
border: 1px solid var(--border-subtle);
border-radius: var(--radius-sm);
padding: 9px 14px;
background: transparent;
&__num {
font-family: var(--font-mono);
font-size: 18px;
font-weight: var(--weight-bold);
color: var(--text-primary);
line-height: 1;
}
&__label {
font-size: var(--text-xs);
font-weight: var(--weight-medium);
color: var(--text-muted);
text-transform: uppercase;
letter-spacing: 0.06em;
}
}