main {
    #posts {
        display: grid;
        grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
        gap: 1rem;
        grid-template-rows: auto;
    }

    article.post {
        display: grid;
        grid-template-rows: 150px 1fr;
        gap: 1rem;
        background-color: var(--post-background-color);
        padding: 1rem;
        border-radius: 8px;
        box-shadow: rgba(0, 0, 0, 0.1) 0px 2px 4px;
        transition: transform 0.3s ease;

        &:hover {
            transform: translateY(-5px);
        }

        h2 {
            margin: 0;
            font-size: 1.5rem;
        }

        p {
            margin: 0;
        }

        img.post-image { 
            width: 100%;
            height: 150px;
            border-radius: 8px;
            object-fit: cover;
            object-position: center;
        }

        .post-title {
            color: var(--primary-color);
            text-decoration: none;

            &:hover {
                text-decoration: underline;
            }
        }
    }
}