/* ───────────────────────────────────────────────
   Zizania — Story Card (reusable component)
   Variants: default | featured | compact
   ─────────────────────────────────────────────── */

.zz-story-card {
    display: block;
    background-color: var(--surface-container-lowest);
    border-radius: 1.75rem;
    overflow: hidden;
    box-shadow: var(--shadow-ambient);
    transition: transform var(--transition-base), box-shadow var(--transition-base);
    height: 100%;
}

.zz-story-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-floating);
}

.zz-story-card__link {
    display: flex;
    flex-direction: column;
    height: 100%;
    text-decoration: none;
    color: inherit;
}

/* Media */
.zz-story-card__media {
    flex: 0 0 auto;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background-color: var(--surface-container-low);
}

.zz-story-card__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 600ms ease-in-out;
}

.zz-story-card:hover .zz-story-card__image {
    transform: scale(1.04);
}

/* Body */
.zz-story-card__body {
    flex: 1 1 auto;
    padding: 1.75rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    justify-content: flex-start;
    background-color: var(--surface-container-lowest);
}

.zz-story-card__badge {
    align-self: flex-start;
}

.zz-story-card__title {
    margin: 0;
    font-size: 1.25rem;
    font-weight: 700;
    line-height: 1.25;
    color: var(--on-surface);
    letter-spacing: -0.01em;
}

.zz-story-card__excerpt {
    margin: 0;
    font-size: 0.9375rem;
    line-height: 1.55;
    color: var(--on-surface-variant, #484837);
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.zz-story-card__read-more {
    margin-top: auto;
    padding-top: 0.5rem;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    color: var(--on-surface);
    text-decoration: underline;
    text-decoration-color: var(--primary);
    text-decoration-thickness: 2px;
    text-underline-offset: 4px;
    align-self: flex-start;
}

.zz-story-card:hover .zz-story-card__read-more {
    text-decoration-thickness: 3px;
}


/* Featured variant */
.zz-story-card--featured .zz-story-card__media { aspect-ratio: 16/10; }
.zz-story-card--featured .zz-story-card__title { font-size: 1.875rem; font-weight: 800; }
.zz-story-card--featured .zz-story-card__excerpt { font-size: 1rem; -webkit-line-clamp: 4; }
.zz-story-card--featured .zz-story-card__body { padding: 2.25rem 2rem; gap: 1.25rem; }

/* Compact variant */
.zz-story-card--compact .zz-story-card__media { aspect-ratio: 3/2; }
.zz-story-card--compact .zz-story-card__title { font-size: 1rem; }
.zz-story-card--compact .zz-story-card__body { padding: 1.25rem 1.5rem; gap: 0.75rem; }
.zz-story-card--compact .zz-story-card__read-more { font-size: 0.6875rem; }
