/* Blog index and article layouts — readable long-form, minimal surface area */
.blog-index-hero {
    max-width: var(--content-max-width, 72rem);
    margin: 0 auto;
    padding: 2rem var(--section-padding-x, 1.25rem) 1.5rem;
    text-align: center;
}
.blog-index-hero h1 {
    font-family: 'Space Grotesk', sans-serif;
    font-size: clamp(1.75rem, 4vw, 2.35rem);
    line-height: 1.2;
    margin-bottom: 0.75rem;
}
.blog-index-lead {
    color: var(--text-secondary);
    font-size: 1.05rem;
    line-height: 1.65;
    max-width: 40rem;
    margin-left: auto;
    margin-right: auto;
}
.blog-index-lead a {
    color: var(--primary-gold);
    font-weight: 600;
}
.blog-index-lead a:hover {
    color: var(--primary-gold);
}
.blog-index-lead a:focus-visible {
    outline: 2px solid var(--primary-gold);
    outline-offset: 2px;
    border-radius: 2px;
}
.blog-grid {
    max-width: var(--content-max-width, 72rem);
    margin: 0 auto;
    padding: 0 var(--section-padding-x, 1.25rem) 3rem;
    display: grid;
    gap: 1.25rem;
    grid-template-columns: 1fr;
}
@media (min-width: 720px) {
    .blog-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
    .blog-grid { grid-template-columns: repeat(3, 1fr); }
}
.blog-card {
    background: var(--card-bg, rgba(255, 255, 255, 0.04));
    border: 1px solid var(--border-subtle, rgba(255, 255, 255, 0.08));
    border-radius: 12px;
    padding: 1.35rem 1.25rem;
    display: flex;
    flex-direction: column;
    transition: border-color 0.2s ease, transform 0.2s ease;
}
.blog-card:hover {
    border-color: var(--primary-gold, #c9a227);
    transform: translateY(-2px);
}
.blog-card h2 {
    font-family: 'Space Grotesk', sans-serif;
    font-size: 1.15rem;
    margin: 0 0 0.65rem;
    line-height: 1.35;
}
.blog-card h2 a {
    color: var(--text-primary);
}
.blog-card h2 a:hover { color: var(--primary-gold); }
.blog-card p {
    color: var(--text-secondary);
    font-size: 0.95rem;
    line-height: 1.6;
    flex: 1;
    margin: 0 0 1rem;
}
.blog-card .read-more {
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--primary-gold);
}

.blog-article {
    max-width: var(--content-max-width);
    margin: 0 auto;
    padding: 0 var(--section-padding-x) 3.5rem;
    box-sizing: border-box;
}
.blog-article header {
    padding-top: 0.5rem;
    margin-bottom: 2rem;
    text-align: center;
}
.blog-article .section-tag {
    margin-bottom: 0.75rem;
    display: inline-block;
}
.blog-article h1 {
    font-family: 'Space Grotesk', sans-serif;
    font-size: clamp(1.65rem, 4vw, 2.25rem);
    line-height: 1.2;
    margin: 0 0 0.75rem;
}
.blog-article .byline {
    font-size: 0.9rem;
    color: var(--text-muted);
}
.blog-article .blog-prose {
    color: var(--text-secondary);
    font-size: 1.02rem;
    line-height: 1.75;
    text-align: left;
    max-width: none;
}
.blog-article .blog-prose h2 {
    font-family: 'Space Grotesk', sans-serif;
    color: var(--text-primary);
    font-size: 1.35rem;
    margin: 2.25rem 0 0.85rem;
    line-height: 1.3;
}
.blog-article .blog-prose h3 {
    font-family: 'Space Grotesk', sans-serif;
    color: var(--text-primary);
    font-size: 1.1rem;
    margin: 1.5rem 0 0.6rem;
}
.blog-article .blog-prose p { margin: 0 0 1.1rem; }
.blog-article .blog-prose ul, .blog-article .blog-prose ol {
    margin: 0 0 1.1rem;
    padding-left: 1.35rem;
}
.blog-article .blog-prose li { margin-bottom: 0.45rem; }
.blog-article .blog-prose a {
    color: var(--primary-gold);
}
.blog-article-footer {
    margin-top: 2.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--border-subtle, rgba(255, 255, 255, 0.08));
    font-size: 0.95rem;
    color: var(--text-muted);
    text-align: center;
}
.blog-article-footer p {
    margin: 0;
}
.blog-article-footer a {
    color: var(--primary-gold);
    font-weight: 600;
}
.blog-article-footer a:hover {
    color: var(--primary-gold);
    opacity: 0.92;
}
