html {
}

body {
    padding: 2em 1em;
    font-family: system-ui;
}

.blogPost {
    max-width: 680px;
    margin: 0 auto; 
}

.blogPost h1 {
    font-size: 42px;
}

.blogPost p, .blogPost ul, .blogPost ol {
    letter-spacing: 0.5px;
    font-size: 20px;
    font-weight: 300;
    line-height: 32px;
}

.blogPost a {
    text-decoration: none;
    color: #0070f3;
}

.blogPost .image p.caption {
    font-size: 14px;
    font-style: italic;
    text-align: center;
}

.blogPost img {
    max-width: 100%;
}

.blogPost .author {
    display: flex;
    align-items: center;
    margin: 0;
}
    .blogPost .author img {
        width: 48px;
        height: 48px;
        border-radius: 24px;
    }
    .blogPost .author span {
        margin-left: 12px;
    }

.blogPost hr {
    margin-top: 2em;
    margin-bottom: 2em;
    border: 0;
    border-top: 1px solid #ccc;
}

.blogPost .fromAuthor {
    background: #b7e7ff;
    padding: 0.5em 0.75em;
    border-radius: 4px;
    font-style: italic;
}