/* -----------------------------------------------
   Blog Post
   ----------------------------------------------- */

.blog-post {
    max-width: 680px;
    margin: 1rem auto;
    padding: 1.5rem;
    background: transparent;
    font-family: Georgia, 'Times New Roman', serif;
}

/* Header */

.blog-post__header {
    margin-bottom: 2.5rem;
}

.blog-post__meta {
    font-family: system-ui, sans-serif;
    font-size: 13px;
    color: #78716c;                                 /* --sz-text-secondary */
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin: 0 0 0.75rem;
}

.blog-post__title {
    font-family: system-ui, sans-serif;
    font-size: 28px;
    font-weight: 500;
    line-height: 1.3;
    margin: 0 0 1rem;
    color: #111;
}

.blog-post__rule {
    height: 2px;
    width: 48px;
    background: var(--sz-primary);                  /* brand accent */
}

/* Body */

.blog-post__body {
    font-size: 17px;
    line-height: 1.8;
    color: #222;
}

.blog-post__body h2 {
    font-family: system-ui, sans-serif;
    font-size: 20px;
    font-weight: 500;
    color: #111;
    margin: 2rem 0 1.25rem;
}

.blog-post__body p {
    margin: 0 0 1.4rem;
}

.blog-post__body p:last-child {
    margin-bottom: 0;
}

.blog-post__body em {
    font-style: italic;
}

.blog-post__body code {
    font-family: 'Courier New', Courier, monospace;
    font-size: 15px;
    color: #555;
}

/* Footer */

.blog-post__footer {
    margin-top: 2.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid #e7e5e4;                 /* --sz-card-border */
}

.blog-post__byline {
    font-family: system-ui, sans-serif;
    font-size: 13px;
    color: #78716c;                                 /* --sz-text-secondary */
    margin: 0;
}
