﻿/* Stili per input non validi dentro input-container */
.input-container:has(.input-validation-error) {
    background-color: rgba(220, 53, 69, 0.1) !important;
    border-color: #dc3545 !important;
    position: relative;
}

    .input-container:has(.input-validation-error) .input-icon,
    .input-container:has(.input-validation-error) .password-toggle-button {
        display: none;
    }

    .input-container:has(.input-validation-error)::after {
        content: '!';
        position: absolute;
        right: 8px;
        top: 50%;
        transform: translateY(-50%);
        color: #dc3545;
        font-weight: bold;
        font-size: 16px;
        line-height: 1;
    }

/* Stili per input e select non validi standalone */
.form-control.input-validation-error:not(.borderless):not(.input-container *),
select.form-control.input-validation-error {
    background-color: rgba(220, 53, 69, 0.1) !important;
    border-color: #dc3545 !important;
    padding-right: 30px !important;
}

    /* Stili specifici per input standalone */
    .form-control.input-validation-error:not(.borderless):not(.input-container *):not(select) {
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16'%3E%3Ctext x='5' y='13' fill='%23dc3545' font-size='16' font-weight='bold'%3E!%3C/text%3E%3C/svg%3E") !important;
        background-position: calc(100% - 8px) center !important;
        background-repeat: no-repeat !important;
    }

/* Stili specifici per select */
select.form-control.input-validation-error {
    background-image: url('/images/chevron-down.svg') !important;
    background-position: calc(100% - 8px) center !important;
    background-repeat: no-repeat !important;
    background-color: rgba(220, 53, 69, 0.1) !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    appearance: none !important;
}

    /* Override del background bianco predefinito delle select */
    select.form-control.input-validation-error option {
        background-color: white !important;
    }

/* Stili per input (non select) dentro container */
.input-container .form-control.input-validation-error:not(select) {
    background-color: transparent !important;
    border-color: transparent !important;
}

/* Messaggi di errore */
.field-validation-error {
    display: block;
    margin-top: 0.25rem;
    color: #dc3545;
    font-size: 0.875rem;
}

/* Modifica della label quando c'è un errore */
.input-container:has(.input-validation-error) + .field-validation-error {
    margin-top: 4px;
}
