.related {
    background-color: #fff;
    margin-bottom: 10px;
    margin-top: 10px;
}
.related-title {
    font-size: 16px;
    display: block;
    margin-bottom: 12px;
}
.related-title:before {
    content: "";
    display: block;
    width: 100%;
    min-width: 30px;
    border-top: 2px solid #ddd;
    margin-bottom: 1em;
}
.related-posts {
    padding-top: 10px;
    display: grid;
    grid-gap: 20px;
    grid-template-columns: repeat(3, 1fr);
}
.related-posts .related-post {
    box-sizing: border-box;
    margin-bottom: 15px;
    opacity: 1;
    height: auto;
}
.related-post:hover {
    opacity: 0.8;
}
.related-post-image {
    vertical-align: top;
    margin-bottom: 10px;
    width: 100%;
    height: 150px;
    object-fit: cover;
    display: block;
}
a.related-post-title {
    line-height: 1.4;
    font-size: 16px;
    display: block;
}
@media only screen and (max-width: 840px) {
    .related-posts {
        grid-template-columns: repeat(2, 1fr);
    }
}
@media only screen and (max-width: 480px) {
    .related-posts {
        grid-template-columns: 1fr;
        grid-gap: 20px;
    }
    .related-post {
        height: auto;
    }
    .related-post-image {
        height: auto;
    }
}