/* Extra styles for the blog service — complements the landing styles.css.
   Only classes that are NOT already defined on the landing live here. */

/* Category filter pills */
.blog-cats {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 0 0 8px;
}

.blog-cats__item {
    padding: 6px 16px;
    border-radius: var(--radius-full);
    font-size: 14px;
    font-weight: 600;
    color: var(--color-text-secondary);
    background: var(--color-bg-alt);
    border: 1px solid var(--color-border);
    transition: all var(--transition);
}

.blog-cats__item:hover {
    color: var(--color-ink-blue);
    border-color: var(--color-primary-light);
}

.blog-cats__item--active {
    background: var(--color-primary-50);
    color: var(--color-ink-blue);
    border-color: transparent;
}

/* Cover images */
.article-card__cover {
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    border-radius: var(--radius-md);
    margin-bottom: 16px;
    display: block;
}

.article__cover {
    width: 100%;
    border-radius: var(--radius-lg);
    margin-bottom: 32px;
    display: block;
}

/* Images inside article content */
.article__content img {
    max-width: 100%;
    height: auto;
    border-radius: var(--radius-md);
    margin: 24px 0;
    display: block;
}

.article__content figure {
    margin: 24px 0;
}

.article__content figcaption {
    font-size: 14px;
    color: var(--color-text-light);
    text-align: center;
    margin-top: 8px;
}

/* Pagination */
.pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    margin-top: 48px;
}

.pagination__link {
    padding: 10px 20px;
    border-radius: var(--radius-md);
    font-weight: 600;
    color: var(--color-ink-blue);
    background: var(--color-primary-50);
    transition: all var(--transition);
}

.pagination__link:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-sm);
}

.pagination__info {
    font-size: 14px;
    color: var(--color-text-light);
}

/* Misc */
.blog-empty {
    text-align: center;
    color: var(--color-text-light);
    padding: 60px 0;
    font-size: 18px;
}

.section__title--sm {
    font-size: clamp(24px, 3vw, 32px);
    text-align: left;
    margin-bottom: 24px;
}

.container--narrow {
    max-width: 760px;
}
