/* Impact Reports listing — pairs with blog.css */
.reports-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
}
.report-card {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: var(--radius-lg);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: transform .3s ease, box-shadow .3s ease;
}
.report-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-accent); }

.report-cover {
    position: relative;
    aspect-ratio: 16 / 10;
    background: var(--accent-soft);
    overflow: hidden;
}
.report-cover img { width: 100%; height: 100%; object-fit: cover; }
.report-cover-icon {
    position: absolute; inset: 0;
    display: grid; place-items: center;
    font-size: 52px; color: var(--accent);
}
.report-year {
    position: absolute; top: 12px; left: 12px;
    background: var(--accent); color: #fff;
    font-weight: 700; font-size: 12px;
    padding: 4px 12px; border-radius: var(--radius-pill);
}

.report-body { padding: 24px; display: flex; flex-direction: column; flex: 1; }
.report-body h2 {
    font-family: var(--font-display);
    font-size: 19px; line-height: 1.3; color: var(--ink); margin: 0 0 10px;
}
.report-body p { font-size: 14.5px; color: var(--muted); line-height: 1.6; margin: 0 0 18px; flex: 1; }

.report-download {
    display: inline-flex; align-items: center; gap: 10px;
    align-self: flex-start;
    background: var(--accent); color: #fff;
    padding: 11px 20px; border-radius: var(--radius-pill);
    font-weight: 600; font-size: 14px; text-decoration: none;
    transition: background .25s ease, transform .25s ease;
}
.report-download:hover { background: var(--accent-deep); transform: translateY(-2px); color: #fff; }
.report-download span { font-weight: 400; font-size: 12px; opacity: .85; }

@media (max-width: 992px) { .reports-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 580px) { .reports-grid { grid-template-columns: 1fr; } }