.card--dark {
    --color: var(--blue100);
    --date: var(--green100);
    --border: var(--green100);
    --text: inherit;
}
.card--color {
    --color: #FFF;
    --date: var(--green100);
    --border: var(--green100);
    --text: inherit;
}
.card--light {
    --color: #FFF;
    --date: var(--grey50);
    --border: var(--grey50);
    --text: inherit;
}
.card--circular-light {
    --color: var(--blue100);
    --date: var(--green100);
    --border: var(--green100);
    --text: var(--c-2-c-blue-50);
}

.card--yellow-date {
    --color: #FFF;
    --date: var(--yellow100) !important; // MARK: app/styles/pages/detail.css:180 is overwriting this
    --border: var(--green100);
    --text: inherit;
}

.card { color: var(--color); }

.card__inner {
    transition: 250ms var(--easingPrinciple);
}
.card:hover .card__inner {
    transform: translateY(-5px);
}
.card__image figure {
    margin: 0 0 25px;
    border-radius: 10px;
    overflow: hidden;
    background-color: #F2F2F2;
    position: relative;
}

/* Card small style */
.card--small .card__image--small figure { aspect-ratio: 310/175; }
.card--small .card__image--medium figure { aspect-ratio: 310/310; }
.card--small .card__image--large figure { aspect-ratio: 310/413; }

/* Card large style */
.card--large .card__image--medium figure,
.card--large .card__image--large figure { aspect-ratio: 660/413; }
.card--large .card__image--small figure { aspect-ratio: 660/310; }





.card__image figure img {
    display: block;
    float: left;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.card__body {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
}

.card__body a {
    color: inherit;
    text-decoration: none;
}

.card__date {
    color: var(--date);
    font-weight: bold;
    text-transform: uppercase;
    font-size: 14px;
    line-height: 1.2857142857;
    letter-spacing: .09em;
    margin: 0 0 15px 0;
    display: block;
}

.card__text {
    margin: 1.0666666667em 0 0;
    font-size: 16px;
    line-height: 1.5;
    letter-spacing: .01em;
    color: var(--text);

    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.card--circular-light .card__text {
    text-transform: uppercase;
}

.card__text p { margin: 0; }

.card__tags {
    display: flex;
    flex-wrap: wrap;
    margin: 15px 0 0;
    gap: 10px;
}
.card__tags .tag { transition: 250ms; }

.page--grey .card__date {
    color: var(--grey50);
}

.page--grey .title,
.page--grey .card__text {
    color: white;
}
