.card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 1.5em;
    margin-top: 1.5em;
}

.card-grid>div {
    padding: 1em;
    display: grid;
    grid-template-columns: 1fr;
    gap: 1em;
}

.card-grid h2 {
    margin-top: 0.1em;
}


.card-grid .cover {
    height: 30em;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    padding: 0;
    align-content: space-between;
}

.card-grid .cover h1 {
    display: block;
    width: 100%;
    text-align: center;
    margin: 0;
    padding: 1.5em 1em 1em 1em;
}

.card-grid .cover p.tagline {
    background-color: var(--color-secondary);
    justify-self:flex-start;
    color: var(--color-background);
    padding: 0.5em 1em;
    text-transform: lowercase;
    letter-spacing: 0.1em;
    font-weight: 200;
    font-size: 1.2em;
    margin-top: 6em;
}

.card-grid .cover p:last-of-type {
    background-color: var(--color-background-transparent);
    color: var(--color-text);
    padding: 1em;
    font-weight: 200;
    font-size: 1.2em;
    backdrop-filter: blur(2px);
    margin: 0;
}