/* -------------------------------------- */
/* 2. SECTION INTRODUCTION ET INDEX GRID  */
/* -------------------------------------- */

.index-container {
    /* CHANGEMENT : 15px 20px = 0.9375rem 1.25rem */
    padding: 0.9375rem 1.25rem;
    background-color: var(--color-index-container-bg);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-z2);
    margin-top: var(--space-sm);
    margin-bottom: var(--space-sm);
}

.lead-text {
    font-style: italic;
}

/* Grille principale des cartes */
.index-step-grid {
    display: grid;
    /* CHANGEMENT : 300px = 18.75rem */
    grid-template-columns: repeat(auto-fit, minmax(18.75rem, 1fr));
    /* CHANGEMENT : 15px = 0.9375rem */
    gap: 0.9375rem;
    /* CHANGEMENT : 1200px = 75rem */
    max-width: 75rem;
    margin: 0 auto; /* Correction de 'o auto' */
}

/* Carte individuelle */
.index-step-item {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    background-color: var(--source-color-white-transparent) !important;
    padding: var(--space-md);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-z2);
    border: 1px solid var(--color-step-item-border);
}

/* Entête : Icône et Titre */
.index-card-header {
    display: flex;
    align-items: center;
    /* CHANGEMENT : 15px = 0.9375rem */
    gap: 0.9375rem;
    margin-bottom: var(--space-md);
}

.index-step-icon {
    flex-shrink: 0;
    display: flex;
    justify-content: center;
    align-items: center;

    /* CHANGEMENT : 50px = 3.125rem */
    width: 3.125rem;
    height: 3.125rem;
    border-radius: 50%;

    background-color: #ffffff;
    border: 2px solid #000000;

    /* CHANGEMENT : 10px = 0.625rem */
    padding: 0.625rem;
    box-sizing: border-box;
    box-shadow: var(--shadow-z2);
}

.index-step-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

.index-card-header h3 {
    margin: 0;
    font-size: 1.4rem;
    color: var(--colore-index-step-h3);
    text-align: left;
}

.index-step-item p {
    color: black;
    text-align: left;
    margin-top: 0;
    margin-bottom: 0;
    flex-grow: 1; /* Pousse le bouton vers le bas */
}

.index-btn-container {
    margin: 0;
    text-align: center;
}

.cta-vegetal-index {
    margin-top: var(--space-md);
    margin-bottom: var(--space-xs);
}

/* --- OPTIMISATION MOBILE (S24 Ultra / Écrans étroits) --- */
@media (max-width: 36.25rem) { /* 580px */
    .index-step-grid {
        /* On s'assure que la carte ne force pas de débordement horizontal */
        grid-template-columns: 1fr;
    }
}