    
    .form-section {
        padding: 20px;
        background: #f8f9fa; /* Grigio chiaro */
        border-radius: 8px;
        margin-bottom: 20px;
        border: 1px solid #eee;
    }

    .section-title {
        font-size: 14px;
        font-weight: 600;
        color: var(--primary); /* Colore primario */
        text-transform: uppercase;
        letter-spacing: 0.5px;
        margin-bottom: 20px;
        padding-bottom: 10px;
        border-bottom: 1px solid #ddd;
    }
    
    .section-title i {
        margin-right: 8px;
        opacity: 0.8;
    }

    /* --- INPUT TEXT CON EFFETTO FLOATING --- */
    .form-group.form-float {
        position: relative;
        margin-bottom: 25px; /* Spazio sotto */
    }

    .form-group.form-float .form-line {
        width: 100%;
        position: relative;
        border-bottom: 1px solid #ddd;
        background: transparent;
    }

    /* La barra colorata che appare sotto */
    .form-group.form-float .form-line:after {
        content: '';
        position: absolute;
        left: 0;
        bottom: -1px;
        width: 0;
        height: 2px;
        background: var(--primary);
        transition: width 0.3s;
    }

    /* Quando l'input è attivo, la barra si allarga */
    .form-group.form-float .form-line.focused:after {
        width: 100%;
        border-bottom: solid var(--primary);
    }

    /* L'input vero e proprio */
    .form-group.form-float .form-line .form-control {
        border: none;
        box-shadow: none;
        padding: 10px 0 5px 0; /* Spazio per non sovrapporre */
        background: transparent;
        z-index: 10;
        position: relative;
        height: 35px;
    }

    /* L'etichetta che si muove */
    .form-group.form-float .form-line .form-label {
        position: absolute;
        top: 10px;
        left: 0;
        cursor: text;
        transition: 0.2s;
        font-weight: normal;
        color: #999;
        font-size: 14px;
        z-index: 5;
    }

    /* Stato "Sollevato" dell'etichetta (Focus o Valore inserito) */
    .form-group.form-float .form-line.focused .form-label,
    .form-group.form-float .form-line .form-control.has-value + .form-label {
        top: -15px;
        left: 0;
        font-size: 12px;
        color: var(--primary);
        font-weight: 600;
    }

    /* --- STILE SPECIFICO PER LE SELECT (Non floating) --- */
    .form-group-select {
        margin-bottom: 25px;
    }
    
    .form-group-select label {
        display: block;
        font-size: 12px;
        color: var(--primary); /* Le tengo colorate per uniformità */
        font-weight: 600;
        margin-bottom: 5px;
        text-transform: uppercase;
    }

    .form-group-select .form-control {
        border: 1px solid #ddd;
        box-shadow: none;
        border-radius: 4px;
        height: 36px;
    }
    
    .form-group-select .form-control:focus {
        border-color: var(--primary);
    }

    /* Azioni Form (Bottoni) */
    .form-actions {
        display: flex;
        justify-content: flex-end;
        gap: 10px; /* Spazio tra i bottoni */
        padding-top: 15px;
        border-top: 1px solid #eee;
    }
    
    /* Utility margine sinistro bootstrap vecchio fix */
    .ml-2 { margin-left: 10px; }

/* --- STILE ERRORI --- */

.error-msg-field {
    display: block;             
    margin-top: 8px;            
    padding: 8px 12px;          
    font-size: 12px;            
    border-radius:4px; 
    
    color: #8a1f1f;             
    background-color: #fdecea;  
    border-left: 4px solid #d32f2f; 
}
.error-msg-field {
    animation: slideIn 0.3s ease-out;
}

@keyframes slideIn {
    from { opacity: 0; transform: translateY(-5px); }
    to { opacity: 1; transform: translateY(0); }
}




