/* ==========================================================================
   Case Studies — Serif Editorial
   ========================================================================== */

.case-card {
    background-color: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-8);
    display: flex;
    flex-direction: column;
    box-shadow: var(--shadow-sm);
    transition: all var(--duration) var(--ease-out);
}

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

.case-card__tag {
    font-family: var(--font-mono);
    font-size: var(--text-caption);
    font-weight: 500;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--accent);
    margin-bottom: var(--space-4);
}

.case-card__title {
    font-family: var(--font-display);
    font-size: var(--text-title);
    font-weight: 600;
    color: var(--foreground);
    margin-bottom: var(--space-4);
    line-height: 1.3;
}

.case-card__desc {
    font-size: var(--text-body);
    color: var(--muted-foreground);
    line-height: 1.75;
    margin-bottom: var(--space-6);
    flex-grow: 1;
}

.case-card__outcomes {
    border-top: 1px solid var(--border);
    padding-top: var(--space-5);
}

.case-card__outcomes-title {
    font-family: var(--font-mono);
    font-size: var(--text-caption);
    font-weight: 500;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--muted-foreground);
    margin-bottom: var(--space-3);
}

.case-card__outcome-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.case-card__outcome {
    font-size: var(--text-body);
    color: var(--muted-foreground);
    display: flex;
    align-items: baseline;
    gap: var(--space-2);
}

.case-card__outcome::before {
    content: '—';
    color: var(--accent);
    flex-shrink: 0;
}

.case-card.reveal:nth-child(2) {
    transition-delay: calc(100ms * var(--anim-duration));
}

.case-card.reveal:nth-child(3) {
    transition-delay: calc(200ms * var(--anim-duration));
}