
.ocf-article-hero {
    position: relative;
    display: grid;
    min-height: clamp(18rem, 42vw, 32rem);
    align-items: end;
    overflow: hidden;
    background: var(--ocf-bg-dark);
    color: var(--ocf-body-alt);
}

.ocf-article-hero-img,
.ocf-article-hero-overlay {
    position: absolute;
    inset: 0;
}

.ocf-article-hero-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.ocf-article-hero-overlay {
    background: var(--gradient-media-dark-even);
}

.ocf-article-hero-overlay--no-img {
    background: var(--ocf-bg-dark);
}

.ocf-article-hero-inner {
    position: relative;
    z-index: 1;
    padding-block: clamp(4rem, 10vw, 7rem) clamp(3rem, 6vw, 5rem);
}

.ocf-article-hero .heading-section {
    max-width: min(100%, 58rem);
    color: var(--ocf-heading-alt);
}

.ocf-article-body {
    background: var(--ocf-bg);
    padding-block: clamp(2rem, 4vw, 3.5rem) var(--section-pad);
}

.ocf-article-prose {
    font-size: calc(var(--text-base) + 2px);
    line-height: 1.72;
}

.ocf-article-prose > :first-child {
    margin-top: 0;
}

.ocf-article-more.section-padding {
    padding-top: clamp(2rem, 4vw, 3.5rem);
}

.ocf-post-loop,
.ocf-post-grid,
.post-loop,
.post-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: var(--grid-gap);
}

.ocf-post-card,
.post-card {
    display: grid;
    border: var(--card-border-width) solid var(--card-border-color);
    border-radius: var(--card-radius);
    background: var(--ocf-bg);
    overflow: hidden;
}

.ocf-post-card__media img,
.post-card-bg img {
    width: 100%;
    aspect-ratio: 16 / 10;
    object-fit: cover;
}

.ocf-post-card__body,
.post-card-body {
    display: grid;
    gap: 0.5rem;
    padding: 1rem;
}

.ocf-post-card__title,
.post-card-title {
    margin: 0;
    color: var(--ocf-heading);
    font-size: var(--text-lg);
}

.ocf-post-card__excerpt,
.ocf-post-card__meta,
.post-card-excerpt,
.post-card-meta {
    color: var(--ocf-body);
    font-size: var(--text-sm);
}

@media (max-width: 900px) {
    .ocf-post-loop,
    .ocf-post-grid,
    .post-loop,
    .post-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 640px) {
    .ocf-post-loop,
    .ocf-post-grid,
    .post-loop,
    .post-grid { grid-template-columns: 1fr; }
}
