.input-container {
    position: relative;
    width: 100%;
}

    /* Stile del campo input */
    .input-container input,
    .input-container select {
        /*width: var(--modal-input-width);*/
        padding: 9px;
        border-radius: 15px;
        font-size: 13px;
    }

    .input-container.no-icon .select2-container .select2-selection--single,
    .custom-width button.no-icon {
        border-radius: 15px;
    }

    .input-container.has-icon .select2-container .select2-selection--single,
    .custom-width button.has-icon {
        border-radius: 15px 0px 0px 15px;
    }

    .custom-width .input-group-text {
        border-radius: 0px 15px 15px 0px;
    }

    /* Stile della label flottante */
    .input-container label {
        position: absolute;
        left: var(--modal-label-font-size);
        top: 50%;
        transform: translateY(-50%);
        font-size: var(--modal-label-font-size);
        pointer-events: none;
        width: auto;
    }

    /* Il trucco: taglia il bordo creando una "finta interruzione" */
    .input-container input:focus + label,
    .input-container input:not(:placeholder-shown) + label,
    .input-container select:focus + label,
    .input-container select:not([value=""]) + label,
    .input-container select:focus + span + label,
    .input-container select:not([value=""]) + span + label,
    .input-container textarea:focus + label,
    .input-container textarea:not(:placeholder-shown) + label {
        top: -8px; /* Spostiamo esattamente dentro il bordo */
        font-size: var(--modal-label-font-size);
        padding: 0 2px;
    }


.custom-modal-dialog {
    position: fixed !important;
    left: calc(3%); /* o altro valore adatto */
    width: 95%;
    max-width: 95%; /* Imposta la larghezza massima desiderata */
    max-height: 85%; /* Imposta l'altezza massima desiderata */
}

@media (min-width: 300px) {
    .custom-modal-dialog-ripartizione-pasti {
        max-width: 500px;
        margin-right: auto;
        margin-left: auto;
    }
}

.validation-message {
    color: red;
}

.radius-style {
    border-radius: 15px;
    overflow: hidden; /* Evita bordi tagliati */
}

.custom-width {
    width: 100%;
    margin-top: -18px;
}

.col-sm-2-custom {
    width: 20% !important;
    font-size: var(--modal-label-font-size);
}

.multi-select-label-property {
    font-size: var(--modal-label-font-size);
    position: relative;
    margin-bottom: 1px;
    left: var(--modal-label-font-size);
    top: 3px
}

.choices[data-type*=select-multiple] .choices__inner, .choices[data-type*=text] .choices__inner {
    border-radius: 15px !important;
}

.choices[data-type="select-multiple"] .choices__inner::after {
    content: '';
    position: absolute;
    right: 1rem;
    top: 50%;
    width: 0.6rem;
    height: 0.6rem;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-size: contain;
    transform: translateY(-50%);
    pointer-events: none;
}

.custom-logo-style {
    height: 60px !important;
    width: 60px !important;
}

.custom-logo-style-login {
    height: 80px !important;
    width: 80px !important;
}

.custom-logo-scritta-style {
    height: 35px !important;
    width: 105px !important;
    margin-top: 7px !important;
}

.custom-logo-scritta-style-login {
    height: 45px !important;
    width: 135px !important;
    margin-top: 7px !important;
}

.custom-logo-sm-style {
    height: 55px !important;
    width: 60px !important;
}

.custom-scroll-bar {
    overflow-y: auto;
    resize: vertical;
    scrollbar-width: thin;
}

.custom-image-style {
    width: 35px;
    height: 35px;
}

.custom-progressi-modal-style {
    height: 35px;
    color: indianred
}

.truncate-text {
    display: inline-block;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* ########################################### INIZIO - LAYOUT NOTIFICHE ########################################### */
.notification-container {
    position: fixed;
    right: 20px;
    display: flex;
    flex-direction: column-reverse;
    gap: 10px;
    z-index: 2000;
    margin-right: 5px;
}

.notification {
    width: 300px;
    max-width: 400px;
    padding: 10px 15px;
    border-radius: 15px;
    color: #fff;
    font-weight: 400;
    box-shadow: 0 0px 0px rgba(0,0,0,0.2);
    animation: fadein 0.3s, fadeout 0.3s ease-in-out forwards;
    animation-delay: 0s, var(--duration); /* la seconda animazione aspetta */
}

    .notification.closing {
        opacity: 0;
        transform: translateY(-10px);
    }

    .notification.success {
        background: #28a745;
    }

    .notification.error {
        background: #dc3545;
    }

    .notification.warning {
        background: #ffc107;
        color: #212529;
    }

    .notification.info {
        background: #17a2b8;
    }
    
    .notification.persistent {
        animation: none !important;
    }

@keyframes fadein {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes fadeout {
    to {
        opacity: 0;
        transform: translateY(-10px);
    }
}

.dt-scroll-body {
    max-height: calc(100vh - 450px) !important;
}

/* ########################################### FINE - LAYOUT NOTIFICHE ########################################### */
/* ########################################### INIZIO - MODIFICHE CUSTOM CALENDARIO ########################################### */
#mini-calendar .fc-daygrid-day-frame {
    padding: 0px; /* meno spazio interno */
    font-size: 0rem; /* numeri più piccoli */
}
#mini-calendar .fc-scroller {
    overflow: hidden !important;   /* niente scroll verticale */
}

/* Target del mini calendario */
#mini-calendar .fc-toolbar button {
    padding: 2px 4px; /* meno spazio interno */
    font-size: 0.7rem; /* testo/freccia più piccolo */
    min-width: 20px; /* larghezza minima */
    height: 20px; /* altezza bottone */
}

/* Opzionale: togli bordo arrotondato e sfondo eccessivo */
#mini-calendar .fc-toolbar button {
    border-radius: 3px;
    background-color: transparent; /* colore più chiaro */
}
#mini-calendar .fc-toolbar-chunk {
    margin: 0;
    gap: 2px;
}
.fc-daygrid-day-selected {
    background-color: #1976d2; /* colore del pallino */
    border-radius: 50%;
}


/* Eventi nel calendario */
.fc-event-title,
.fc-event-time {
    font-size: 0.65rem; /* prova 0.7 / 0.65 se vuoi più piccolo */
}
.fc-event {
    padding: 2px;
}

.fc-event-title {
    font-weight: 500;
    white-space: normal; /* va a capo invece di tagliare */
}

/* Riduce l’altezza degli eventi */
.fc-event {
    padding: 0 3px !important;
    font-size: 0.65rem;
    line-height: 1;
    border-radius: 3px;
}

.fc-event-title {
    white-space: initial;
    overflow: hidden;
    text-overflow: ellipsis;
}


/* ########################################### FINE - MODIFICHE CUSTOM CALENDARIO ########################################### */

.divisor-bar {
    border: 1px solid #ccc;
    margin: 40px 0;
}

.me-01rem {
    margin-right: 0.1rem;
}

.ml-0 {
    margin-left: 0;
}

.client-status {
    color: #fff;
    padding-right: 0.6em;
    padding-left: 0.6em;
    border-radius: 1rem;
    display: inline-block;
    padding: 0.7em;
    font-size: 88%;
    line-height: 1;
}

.table-fixed-header {
    border-collapse: collapse;
    width: 100%;
}

    .table-fixed-header thead th {
        position: sticky;
        top: 0;
        background: #fff;
        z-index: 2;
    }

.table-wrapper {
    max-height: 32vh; /* Altezza scrollabile */
    overflow-y: auto;
}

.disabled-div {
    pointer-events: none;
    opacity: 0.5;
}

.w-5-perc {
    width: 5%;
}

.w-10-perc {
    width: 10%;
}

.w-20-perc {
    width: 20%;
}

.w-30-perc {
    width: 30%;
}

.gap-1rem {
    gap: 1rem !important;
}

.table-scroll-body tbody {
    display: block;
    max-height: 53vh;
    overflow-y: auto;
}

    .table-scroll-body thead,
    .table-scroll-body tbody tr {
        display: table;
        width: 100%;
        table-layout: fixed;
    }

/* ######################### Inizio gestione Flat pickers #########################*/

.flatpickr-calendar {
    z-index: 1056 !important;
}

.flatpickr-calendar {
    background: var(--ins-secondary-bg) !important;
    -webkit-box-shadow: var(--ins-box-shadow) !important;
    box-shadow: var(--ins-box-shadow) !important;
    border: 1px solid var(--ins-border-color);
    font-size: 0.813rem;
}

    .flatpickr-calendar.arrowTop:before {
        border-bottom-color: var(--ins-secondary-bg) !important;
    }

    .flatpickr-calendar.arrowTop:after {
        border-bottom-color: var(--ins-secondary-bg) !important;
    }

    .flatpickr-calendar.arrowBottom:before, .flatpickr-calendar.arrowBottom:after {
        border-top-color: var(--ins-secondary-bg) !important;
    }

.flatpickr-current-month {
    font-size: 100% !important;
}

.flatpickr-day.selected, .flatpickr-day.startRange, .flatpickr-day.endRange, .flatpickr-day.selected.inRange, .flatpickr-day.startRange.inRange, .flatpickr-day.endRange.inRange, .flatpickr-day.selected:focus, .flatpickr-day.startRange:focus, .flatpickr-day.endRange:focus, .flatpickr-day.selected:hover, .flatpickr-day.startRange:hover, .flatpickr-day.endRange:hover, .flatpickr-day.selected.prevMonthDay, .flatpickr-day.startRange.prevMonthDay, .flatpickr-day.endRange.prevMonthDay, .flatpickr-day.selected.nextMonthDay, .flatpickr-day.startRange.nextMonthDay, .flatpickr-day.endRange.nextMonthDay {
    background: var(--ins-primary) !important;
    border-color: var(--ins-primary) !important;
}

    .flatpickr-day.selected.startRange + .endRange:not(:nth-child(7n+1)), .flatpickr-day.startRange.startRange + .endRange:not(:nth-child(7n+1)), .flatpickr-day.endRange.startRange + .endRange:not(:nth-child(7n+1)) {
        -webkit-box-shadow: -10px 0 0 var(--ins-primary) !important;
        box-shadow: -10px 0 0 var(--ins-primary) !important;
    }

.flatpickr-time input:hover,
.flatpickr-time .flatpickr-am-pm:hover,
.flatpickr-time input:focus,
.flatpickr-time .flatpickr-am-pm:focus {
    background: var(--ins-secondary-bg) !important;
    color: var(--ins-body-color) !important;
}

.flatpickr-months .flatpickr-month {
    height: 40px !important;
}

.flatpickr-months .flatpickr-prev-month,
.flatpickr-months .flatpickr-next-month,
.flatpickr-months .flatpickr-month {
    color: var(--ins-body-color) !important;
    fill: var(--ins-gray-500) !important;
    line-height: 16px !important;
}

.flatpickr-weekdays {
    background-color: var(--ins-tertiary-bg) !important;
}

span.flatpickr-weekday,
.flatpickr-day,
.flatpickr-current-month input.cur-year[disabled],
.flatpickr-current-month input.cur-year[disabled]:hover,
.flatpickr-time input,
.flatpickr-time .flatpickr-time-separator,
.flatpickr-time .flatpickr-am-pm {
    color: var(--ins-body-color) !important;
    fill: var(--ins-body-color) !important;
    font-weight: var(--ins-font-weight-semibold) !important;
}

.flatpickr-current-month input.cur-year {
    font-weight: var(--ins-font-weight-semibold) !important;
}

.flatpickr-day.disabled, .flatpickr-day.disabled:hover, .flatpickr-day.prevMonthDay, .flatpickr-day.nextMonthDay, .flatpickr-day.notAllowed, .flatpickr-day.notAllowed.prevMonthDay, .flatpickr-day.notAllowed.nextMonthDay {
    color: var(--ins-secondary-color) !important;
}

    .flatpickr-day.inRange, .flatpickr-day.prevMonthDay.inRange, .flatpickr-day.nextMonthDay.inRange, .flatpickr-day.today.inRange, .flatpickr-day.prevMonthDay.today.inRange, .flatpickr-day.nextMonthDay.today.inRange, .flatpickr-day:hover, .flatpickr-day.prevMonthDay:hover, .flatpickr-day.nextMonthDay:hover, .flatpickr-day:focus, .flatpickr-day.prevMonthDay:focus, .flatpickr-day.nextMonthDay:focus {
        background: var(--ins-tertiary-bg) !important;
        border-color: var(--ins-tertiary-bg) !important;
    }

.flatpickr-calendar.showTimeInput.hasTime .flatpickr-time {
    border-top: 1px solid var(--ins-secondary-bg) !important;
}

.numInputWrapper:hover,
.flatpickr-current-month .flatpickr-monthDropdown-months:hover {
    background-color: transparent !important;
    color: var(--ins-body-color) !important;
}

.flatpickr-current-month .numInputWrapper {
    width: 8ch !important;
    display: inline-block !important;
    margin-left: 10px !important;
}

.flatpickr-current-month .flatpickr-monthDropdown-months,
.flatpickr-current-month .numInputWrapper {
    border: 1px solid var(--ins-border-color) !important;
    border-radius: 4px !important;
    padding: 2px 8px !important;
    font-weight: normal !important;
}

.flatpickr-day.inRange {
    -webkit-box-shadow: -5px 0 0 var(--ins-tertiary-bg), 5px 0 0 var(--ins-tertiary-bg) !important;
    box-shadow: -5px 0 0 var(--ins-tertiary-bg), 5px 0 0 var(--ins-tertiary-bg) !important;
}

.flatpickr-day.flatpickr-disabled,
.flatpickr-day.flatpickr-disabled:hover {
    color: var(--ins-secondary-color) !important;
    text-decoration: line-through !important;
    opacity: 0.5 !important;
}

.flatpickr-calendar.hasTime .flatpickr-time {
    border-top: var(--ins-border-color) !important;
}

.flatpickr-weekwrapper .flatpickr-weeks {
    -webkit-box-shadow: none !important;
    box-shadow: none !important;
}

.flatpickr-weekwrapper span.flatpickr-day,
.flatpickr-weekwrapper span.flatpickr-day:hover {
    color: var(--ins-secondary-color) !important;
}

/* ######################### Fine gestione Flat pickers #########################*/

.slot {
    position: relative;
    width: 5rem;
    height: 2rem;
    pointer-events: auto;
}

    .slot.disabled {
        pointer-events: none;
        opacity: 0.6;
    }

        .slot.disabled::after {
            content: "";
            position: absolute;
            top: 48%;
            left: -3%;
            width: 105%;
            height: 2px;
            background-color: red; /* rosso bootstrap */
            transform: rotate(-20deg);
        }

.avatart-custom-size {
    height: 3.5rem;
    width: 3.5rem;
}


/* Quando si fa il check sulla checkbox viene messa una linea sul descrizione*/
/* From Uiverse.io by MattiaCode-IT */
.checkbox-container {
    display: inline-block;
    margin: 50px auto;
    user-select: none;
}

.task-checkbox {
    display: none;
}

.checkbox-label {
    display: flex;
    align-items: center;
    cursor: pointer;
    font-size: 12px;
    font-weight: 500;
    transition: all 0.2s ease;
    padding: 8px;
    border-radius: 8px;
}

    .checkbox-label:hover {
        background: rgba(16, 185, 129, 0.05);
        color: #111827;
    }

.checkbox-box {
    position: relative;
    width: 20px;
    height: 20px;
    border: 2px solid #d1d5db;
    border-radius: 6px;
    margin-right: 12px;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: visible;
}

.checkbox-fill {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, #10b981 0%, #059669 100%);
    transform: scale(0);
    transition: all 0.4s cubic-bezier(0.68, -0.55, 0.265, 1.55);
    border-radius: 4px;
    opacity: 0;
}

.checkmark {
    position: relative;
    z-index: 2;
    opacity: 0;
    transform: scale(0.3) rotate(20deg);
    transition: all 0.5s cubic-bezier(0.68, -0.55, 0.265, 1.55);
}

.check-icon {
    width: 14px;
    height: 14px;
    fill: white;
    filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.2));
}

.success-ripple {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0;
    height: 0;
    background: rgba(16, 185, 129, 0.4);
    border-radius: 50%;
    transform: translate(-50%, -50%);
    opacity: 0;
    pointer-events: none;
}

.checkbox-text {
    transition: all 0.3s ease;
    position: relative;
}

    .checkbox-text::after {
        content: "";
        position: absolute;
        top: 50%;
        left: 0;
        width: 0;
        height: 2px;
        background: #6b7280;
        transition: width 0.4s ease;
        transform: translateY(-50%);
    }

.checkbox-label:hover .checkbox-box {
    border-color: #10b981;
    box-shadow: 0 0 0 2px rgba(16, 185, 129, 0.1);
}

.task-checkbox:checked + .checkbox-label .checkbox-box {
    border-color: #10b981;
    background: #10b981;
    box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3), 0 0 0 2px rgba(16, 185, 129, 0.2);
}

.task-checkbox:checked + .checkbox-label .checkbox-fill {
    transform: scale(1);
    opacity: 1;
}

.task-checkbox:checked + .checkbox-label .checkmark {
    opacity: 1;
    transform: scale(1) rotate(0deg);
    animation: checkPop 0.3s ease-out 0.2s;
}

.task-checkbox:checked + .checkbox-label .success-ripple {
    animation: rippleSuccess 0.6s ease-out;
}

.task-checkbox:checked + .checkbox-label .checkbox-text {
    color: #6b7280;
}

    .task-checkbox:checked + .checkbox-label .checkbox-text::after {
        width: 100%;
    }

.checkbox-label:active .checkbox-box {
    transform: scale(0.95);
}

@keyframes checkPop {
    0% {
        transform: scale(1) rotate(0deg);
    }

    50% {
        transform: scale(1.2) rotate(-5deg);
    }

    100% {
        transform: scale(1) rotate(0deg);
    }
}

@keyframes rippleSuccess {
    0% {
        width: 0;
        height: 0;
        opacity: 0.6;
    }

    70% {
        width: 50px;
        height: 50px;
        opacity: 0.3;
    }

    100% {
        width: 60px;
        height: 60px;
        opacity: 0;
    }
}

/**************************/
.choice {
    margin: 10px 0 10px 0;
    display: flex;
    align-items: center;
}

    .choice > div {
        position: relative;
        width: 20px;
        height: 20px;
        margin-right: 15px;
        z-index: 0;
    }

.choice-circle {
    appearance: none;
    height: 100%;
    width: 100%;
    border-radius: 100%;
    border-width: 5px;
    border-style: solid;
    border-color: rgba(245, 245, 245, 0.45);
    cursor: pointer;
    box-shadow: 0px 0px 20px -13px gray, 0px 0px 20px -14px gray inset;
}

.ball {
    z-index: 1;
    position: absolute;
    inset: 0px;
    transform: translateX(-95px);
    box-shadow: rgba(0, 0, 0, 0.17) 0px -10px 10px 0px inset, rgba(0, 0, 0, 0.15) 0px -15px 15px 0px inset, rgba(0, 0, 0, 0.1) 0px -40px 20px 0px inset, rgba(0, 0, 0, 0.06) 0px 2px 1px, rgba(0, 0, 0, 0.09) 0px 4px 2px, rgba(0, 0, 0, 0.09) 0px 8px 4px, rgba(0, 0, 0, 0.09) 0px 16px 8px, rgba(0, 0, 0, 0.09) 0px 32px 16px, 0px -1px 15px -8px rgba(0, 0, 0, 0.09);
    border-radius: 100%;
    transition: 1000ms cubic-bezier(1, -0.4, 0, 1.4);
    background-color: rgb(232, 232, 232, 1);
    opacity: 0;
    filter: blur(10px);
}

.choice-circle:checked + .ball {
    transform: translateX(0px);
    opacity: 1;
    filter: blur(0);
}

.choice-name {
    font-size: 0.8rem;
}
