/* ── Engagements / Valeurs — À propos ───────────────────────────────────── */

.eng-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--Spacing-m);
    margin-top: var(--Spacing-m);
}

/* ── Carte base ─────────────────────────────────────────────────────────── */
.eng-card {
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    gap: var(--Spacing-m);
    padding: var(--Spacing-xl);
    border-radius: var(--Radius-m);
}

/* Spotlight : dégradé radial qui suit la souris */
.eng-card::before {
    content: '';
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity 0.4s ease;
    background: radial-gradient(
        500px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),
        var(--eng-spotlight, rgba(255,255,255,0.10)),
        transparent 65%
    );
    pointer-events: none;
    z-index: 0;
}
.eng-card:hover::before {
    opacity: 1;
}

/* Tout le contenu passe au-dessus du spotlight */
.eng-card > * {
    position: relative;
    z-index: 1;
}

/* ── Thème primary (fond vert) ──────────────────────────────────────────── */
.eng-card--primary {
    background: var(--Primary-main);
    --eng-spotlight: rgba(255, 255, 255, 0.18);
}
.eng-card--primary .eng-card__num {
    background: rgba(0, 0, 0, 0.18);
    color: var(--Neutral-950);
}
.eng-card--primary .eng-card__title {
    color: var(--Neutral-950);
}
.eng-card--primary .eng-card__desc {
    color: var(--Neutral-900);
}

/* ── Thème light (fond neutre clair) ────────────────────────────────────── */
.eng-card--light {
    background: var(--Neutral-50);
    border: 1px solid var(--Neutral-200);
    --eng-spotlight: rgba(126, 140, 74, 0.12);
}
.eng-card--light .eng-card__num {
    background: var(--Primary-100);
    color: var(--Primary-800);
}
.eng-card--light .eng-card__title {
    color: var(--Neutral-900);
}
.eng-card--light .eng-card__desc {
    color: var(--Neutral-600);
}

/* ── Thème dark (fond sombre) ───────────────────────────────────────────── */
.eng-card--dark {
    background: var(--Neutral-950);
    --eng-spotlight: rgba(126, 140, 74, 0.20);
}
.eng-card--dark .eng-card__num {
    background: rgba(255, 255, 255, 0.08);
    color: var(--Primary-main);
}
.eng-card--dark .eng-card__title {
    color: var(--Neutral-50);
}
.eng-card--dark .eng-card__desc {
    color: var(--Neutral-400);
}

/* ── Numéro badge ───────────────────────────────────────────────────────── */
.eng-card__num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: var(--Radius-s);
    font-family: var(--font-family-heading);
    font-size: var(--font-size-h6);
    font-weight: 700;
    line-height: 1;
    flex-shrink: 0;
    align-self: flex-start;
}

/* ── Titre ──────────────────────────────────────────────────────────────── */
.eng-card__title {
    font-family: var(--font-family-heading);
    font-size: var(--font-size-h4);
    font-weight: 700;
    line-height: var(--line-height-h4);
    margin: 0;
}

/* ── Description ────────────────────────────────────────────────────────── */
.eng-card__desc {
    font-family: var(--font-family-body);
    font-size: var(--font-size-p);
    font-weight: 400;
    line-height: var(--line-height-p);
    margin: 0;
}

/* ── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width: 980px) {
    .eng-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .eng-grid {
        grid-template-columns: 1fr;
    }
    .eng-card {
        padding: var(--Spacing-l);
    }
    .eng-card__title {
        font-size: var(--font-size-h5);
    }
}
