/* =========================
   CARD SYSTEM BASE (FINAL CLEAN)
========================= */

.card {
    background: var(--white);
    border: 1px solid var(--gray-100);
    border-radius: 16px;
    padding: 24px;

    transition: all 0.25s ease;
    box-shadow: 0 6px 18px rgba(0,0,0,0.04);

    position: relative;
}

/* hover global (soft) */
.card:hover {
    transform: translateY(-6px);
    box-shadow: 0 20px 40px rgba(4,44,83,0.08);
    border-color: var(--blue-200);
}

/* =========================
   ACCENT BAR (OPTIONNEL GLOBAL)
   activé seulement si class ajoutée
========================= */

.card--accent::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;

    height: 4px;
    width: 0%;

    background: linear-gradient(90deg, var(--blue-700), var(--blue-500));
    transition: width 0.3s ease;
}

.card--accent:hover::before {
    width: 100%;
}

/* =========================
   VARIANTS
========================= */

.card--service {
    padding: 36px 28px;
}

.card--project {
    padding: 0;
    overflow: hidden;
}

.card--testimonial {
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.12);
    color: white;
    box-shadow: none;
}

/* testimonial hover override */
.card--testimonial:hover {
    transform: translateY(-4px);
    box-shadow: none;
}

.card--testimonial {
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.12);
    color: white;
    box-shadow: none;

    flex: 0 0 320px;
    width: 320px;
}