/* ==========================================================================
   BLOG PAGE (Blog subpage)
   Sections: intro (topics), articles (reused blog card component).
   Mobile-first layout.
   ========================================================================== */

/* ----- PAGE WRAPPER ----- */

.blog-page {
    background-color: var(--color-pink-accent);
    flex: 1;
}

/* ----- SECTION 1: INTRO ----- */

.blog-intro {
    padding: var(--space-xl) var(--space-md) var(--space-lg) var(--space-md);
}

.blog-intro__title {
    text-align: center;
    margin-bottom: var(--space-xs);
}

.blog-intro__subtitle {
    text-align: center;
    font-size: var(--text-body);
    font-weight: 500;
    margin-bottom: var(--space-xl);
}

.blog-intro__heading {
    font-family: var(--font-body);
    font-size: var(--text-h3);
    font-weight: 700;
    margin-bottom: var(--space-md);
}

.blog-intro__list {
    font-size: var(--text-body-small);
    line-height: var(--lh-body);
    padding-left: var(--space-md);
    list-style: disc;
}

.blog-intro__list li {
    margin-bottom: var(--space-xs);
}

/* ----- SECTION 2: ARTICLES (overrides for blog page) ----- */

.blog--page {
    background-color: var(--color-pink-accent);
    padding: 0 var(--space-md) var(--space-xl) var(--space-md);
}

/* ==========================================================================
   DESKTOP (768px+)
   ========================================================================== */

@media (min-width: 768px) {

    .blog-intro {
        padding: var(--space-2xl) var(--space-md) var(--space-xl) var(--space-md);
    }

    /* Two-column: heading left, topics right */
    .blog-intro__content {
        display: flex;
        gap: var(--space-xl);
        max-width: 1200px;
        margin: 0 auto;
    }

    .blog-intro__left {
        flex: 0 0 300px;
    }

    .blog-intro__right {
        flex: 1;
    }

    .blog--page {
        padding: 0 var(--space-2xl) var(--space-2xl) var(--space-2xl);
    }

    .blog--page .blog__cards {
    flex-wrap: wrap;
    }

    .blog--page .blog__card {
        flex: 0 0 calc((100% - 2 * var(--space-md)) / 3);
    }

    .blog__card {
        text-decoration: none;
        color: inherit;
        display: block;
        transition: box-shadow 0.3s ease;
    }

    .blog__card:hover {
        box-shadow: 0 6px 30px rgba(0, 0, 0, 0.5);
    }

}