/* ==========================================================================
   Impact Page
   ========================================================================== */

/* --- Introduction --- */
.impact-intro__grid {
    display: grid;
    grid-template-columns: 1.3fr 1fr;
    gap: var(--space-3xl);
    align-items: start;
}

.impact-intro__content h2 {
    margin-bottom: var(--space-lg);
}

.impact-intro__content p {
    color: var(--color-text-light);
    line-height: var(--lh-relaxed);
}

.impact-highlight-card {
    background: var(--gradient-cta);
    color: var(--color-bg-white);
    padding: var(--space-2xl);
    border-radius: var(--radius-xl);
    text-align: center;
    box-shadow: var(--shadow-lg);
}

.impact-highlight-card__icon {
    color: rgba(255, 255, 255, 0.9);
    margin-bottom: var(--space-lg);
}

.impact-highlight-card h3 {
    color: var(--color-bg-white);
    margin-bottom: var(--space-md);
    font-size: var(--fs-xl);
}

.impact-highlight-card p {
    font-size: var(--fs-sm);
    opacity: 0.9;
    line-height: var(--lh-relaxed);
}

.impact-highlight-card strong {
    font-weight: var(--fw-extrabold);
}

@media (max-width: 768px) {
    .impact-intro__grid {
        grid-template-columns: 1fr;
    }
}

/* --- Focus / Impact Areas --- */
.impact-area {
    background: var(--color-bg-white);
    padding: var(--space-xl);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    text-align: center;
    transition: transform var(--transition-base), box-shadow var(--transition-base);
    display: flex;
    flex-direction: column;
}

.impact-area:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.impact-area__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 80px;
    height: 80px;
    border-radius: var(--radius-full);
    background: rgba(31, 78, 121, 0.08);
    color: var(--color-primary);
    margin: 0 auto var(--space-lg);
}

.impact-area h3 {
    font-size: var(--fs-xl);
    margin-bottom: var(--space-sm);
}

.impact-area p {
    font-size: var(--fs-sm);
    color: var(--color-text-light);
    line-height: var(--lh-relaxed);
    flex: 1;
}

.impact-area__stat {
    margin-top: var(--space-lg);
    padding-top: var(--space-md);
    border-top: 1px solid var(--color-border-light);
    font-size: var(--fs-sm);
    color: var(--color-secondary);
}

.impact-area__stat strong {
    font-family: var(--font-heading);
    font-size: var(--fs-xl);
    font-weight: var(--fw-extrabold);
    display: block;
    margin-bottom: 2px;
}

/* --- Impact Stories Grid --- */
.impact-stories-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-xl);
}

.impact-story {
    background: var(--color-bg);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: box-shadow var(--transition-base);
}

.impact-story:hover {
    box-shadow: var(--shadow-md);
}

.impact-story--featured {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: 1.4fr 1fr;
}

.impact-story__image {
    overflow: hidden;
}

.impact-story__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}

.impact-story:hover .impact-story__image img {
    transform: scale(1.03);
}

.impact-story__content {
    padding: var(--space-xl);
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.impact-story__content h3 {
    font-size: var(--fs-xl);
    margin-bottom: var(--space-sm);
}

.impact-story--featured .impact-story__content h3 {
    font-size: var(--fs-2xl);
}

.impact-story__content h3 a {
    color: var(--color-primary);
}

.impact-story__content h3 a:hover {
    color: var(--color-secondary);
}

.impact-story__content p {
    color: var(--color-text-light);
    font-size: var(--fs-sm);
    line-height: var(--lh-relaxed);
    margin-bottom: var(--space-md);
    flex: 1;
}

@media (max-width: 768px) {
    .impact-stories-grid {
        grid-template-columns: 1fr;
    }
    .impact-story--featured {
        grid-template-columns: 1fr;
    }
}

/* --- Milestones Grid --- */
.milestones-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-xl);
}

.milestone {
    text-align: center;
    padding: var(--space-xl);
    background: var(--color-bg-white);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border-light);
    transition: border-color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-base);
}

.milestone:hover {
    border-color: var(--color-primary);
    box-shadow: var(--shadow-md);
    transform: translateY(-2px);
}

.milestone__number {
    font-family: var(--font-heading);
    font-size: var(--fs-3xl);
    font-weight: var(--fw-extrabold);
    color: var(--color-primary);
    line-height: 1;
    margin-bottom: var(--space-xs);
}

.milestone__title {
    font-family: var(--font-heading);
    font-size: var(--fs-sm);
    font-weight: var(--fw-bold);
    color: var(--color-secondary);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: var(--space-sm);
}

.milestone p {
    font-size: var(--fs-xs);
    color: var(--color-text-muted);
    line-height: var(--lh-relaxed);
}

@media (max-width: 1024px) {
    .milestones-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 576px) {
    .milestones-grid {
        grid-template-columns: 1fr;
    }
}

/* --- Annual Reports --- */
.reports-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-lg);
    max-width: 800px;
    margin-inline: auto;
}

.report-item {
    display: flex;
    align-items: center;
    gap: var(--space-xl);
    padding: var(--space-lg) var(--space-xl);
    background: var(--color-bg);
    border-radius: var(--radius-lg);
    border-left: 4px solid var(--color-primary);
    transition: box-shadow var(--transition-base);
}

.report-item:hover {
    box-shadow: var(--shadow-sm);
}

.report-item__year {
    font-family: var(--font-heading);
    font-size: var(--fs-2xl);
    font-weight: var(--fw-bold);
    color: var(--color-primary);
    flex-shrink: 0;
}

.report-item__desc {
    flex: 1;
    color: var(--color-text-light);
}

@media (max-width: 576px) {
    .report-item {
        flex-direction: column;
        text-align: center;
        border-left: none;
        border-top: 4px solid var(--color-primary);
    }
}
