/* ==========================================================================
   Single Article Template
   ========================================================================== */

/* --- Article Banner --- */
.article-banner {
    position: relative;
    width: 100%;
    aspect-ratio: 21 / 9;
    max-height: 500px;
    overflow: hidden;
    background: var(--color-bg-dark);
}

.article-banner__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.6;
}

.article-banner__overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: flex-end;
    padding-bottom: var(--space-10);
    background: linear-gradient(to top, rgba(0, 0, 0, 0.7) 0%, transparent 60%);
}

.article-banner__category {
    display: inline-block;
    padding: var(--space-1) var(--space-3);
    margin-bottom: var(--space-4);
    font-size: var(--text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    background: var(--color-bg);
    color: var(--color-text);
    border-radius: var(--radius-sm);
}

.article-banner__title {
    font-size: var(--text-5xl);
    color: var(--color-text-inverse);
    margin-bottom: var(--space-4);
    max-width: 800px;
}

.article-banner__meta {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    font-size: var(--text-sm);
    color: rgba(255, 255, 255, 0.8);
}

.article-banner__meta > *:not(:last-child)::after {
    content: '\00b7';
    margin-left: var(--space-4);
}

/* --- Article Layout --- */
.article-content {
    padding-top: var(--space-10);
}

/* --- Scroll Margin for Anchor Links --- */
.article-content__body h2[id],
.article-content__body h3[id],
.article-content__body h4[id] {
    scroll-margin-top: calc(var(--header-height) + var(--space-6));
}

/* --- Article Footer --- */
.article-footer {
    margin-top: var(--space-12);
    padding-top: var(--space-8);
    border-top: 1px solid var(--color-border);
}

/* --- Tags --- */
.article-tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    margin-top: var(--space-6);
}

.article-tags__label {
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--color-text-light);
    margin-right: var(--space-2);
}

.article-tags a {
    display: inline-block;
    padding: var(--space-1) var(--space-3);
    font-size: var(--text-xs);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    color: var(--color-text-light);
    transition: all var(--transition-fast);
}

.article-tags a:hover {
    border-color: var(--color-accent);
    color: var(--color-accent);
}
