@media (min-width: 576px) {
        dl, ol, p, ul {
            font-size: 1rem !important;
            line-height: 1.75rem;
        }
    }

:root {
    --bi-required-bg: #fdffa1;
    --bi-required-asterisk: #b30000;
}

.form-control.form_obbligatorio,
.form-select.form_obbligatorio,
textarea.form_obbligatorio,
select.selezionavalobbligatorio,
select.selezionavalobblig,
select[required] {
    background-color: var(--bi-required-bg) !important;
}

select.selezionavalobblig + .select2 .select2-selection,
select.selezionavalobbligatorio + .select2 .select2-selection,
select.form_obbligatorio + .select2 .select2-selection,
select[required] + .select2 .select2-selection,
select.selezionavalobblig + .select2-container .select2-selection,
select.selezionavalobbligatorio + .select2-container .select2-selection,
select.form_obbligatorio + .select2-container .select2-selection,
select[required] + .select2-container .select2-selection,
select.selezionavalobblig ~ .select2-container .select2-selection,
select.selezionavalobbligatorio ~ .select2-container .select2-selection,
select.form_obbligatorio ~ .select2-container .select2-selection,
select[required] ~ .select2-container .select2-selection {
    background-color: var(--bi-required-bg) !important;
}

.asterisco-obbligatorio {
    color: var(--bi-required-asterisk);
    font-weight: 700;
    margin-left: 4px;
}

.camposchedanuovo {
        font-weight:600;
    }

.maxh400 {
    max-height: 400px !important;
}

.card-teaser .card-body {
    display: flex;
    align-items: center;   /* allinea verticalmente al centro */
    justify-content: center; /* opzionale: centra anche orizzontalmente */
    height: 100%;          /* fa sì che occupi tutta l’altezza del contenitore */
}
.card-teaser .card-image {
    display: flex;
    align-items: center !important;     /* centro verticale */
    justify-content: center; /* centro orizzontale */
    height: 100%; /* prende l'altezza del contenitore */
}

/* Ridimensiona e mantiene proporzioni */
.card-teaser .card-image img {
    width: 40%;              /* dimensione immagine */
    height: auto;
    object-fit: contain;     /* mantiene le proporzioni */
    display: block;
    margin-top: 25%;

}

.homegray {
    background: #f5f5f5 !important;
    background-color: #f5f5f5 !important;
}

.it-header-slim-wrapper{
    background: #000000 !important;
}

.overlay-black {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.55); /* nero con trasparenza */
    pointer-events: none; /* non blocca click sull’immagine */
    border-radius: inherit; /* se l'immagine ha angoli arrotondati */
}

/* Applica stile uniforme alle voci del megamenù */
.navbar .nav-link.dropdown-toggle {
  font-weight: 400 !important;
  font-size: 1rem !important;
}

.navbar .navbar-collapsable .navbar-nav li.nav-item a.nav-link{
  font-weight: 400 !important;
  font-size: 1rem !important;
}


@media (max-width: 992px) {

.imgscheda {
  padding:30px !important;
}

.marginetabellatablet{

    padding: 1.5rem !important;
}

.titologrotta{
text-align:center;
}
}


@media (max-width: 575px) {

.imgheroo {
 display:none;
}
}


/* Forza il layout verticale dei controlli Leaflet */
.leaflet-bar a,
.leaflet-bar a:hover {
  display: block !important;
  float: none !important;
}

/* Evita che flex o btn-group esterni influenzino il blocco */
.leaflet-control-zoom.leaflet-bar {
  display: inline-block !important;
}

/* (opzionale) dimensioni coerenti su touch */
.leaflet-touch .leaflet-bar a {
  width: 30px;
  height: 30px;
  line-height: 30px;
}

/* Ripristina radio/checkbox nel controllo layer di Leaflet */
.leaflet-control-layers input[type="radio"],
.leaflet-control-layers input[type="checkbox"] {
  appearance: auto !important;
  -webkit-appearance: auto !important;
  -moz-appearance: auto !important;
  position: static !important;
  opacity: 1 !important;
  display: inline-block !important;
  width: auto !important;
  height: auto !important;
  margin: 0 0.4rem 0 0 !important;
  vertical-align: middle !important;
}

/* Etichette in colonna, peso normale */
.leaflet-control-layers label {
  display: block;
  font-weight: 400;
}

/* (opzionale) Migliora contrasto e click area */
.leaflet-control-layers span {
  cursor: pointer;
}

/* (opzionale) Colora i radio/checkbox con il tema del sito */
.leaflet-control-layers input[type="radio"],
.leaflet-control-layers input[type="checkbox"] {
  accent-color: #21479A; /* colore istituzionale */
}

.search-bar {
    width: 100%;
}

.search-bar .icon {
    width: 1.2em;
    height: 1.2em;
    pointer-events: none;
}

/* Mantieni proporzioni e altezza coerente */
.search-bar .form-control-lg {
    height: calc(3rem + 2px);
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
}

/* Migliora l’allineamento verticale */
.search-bar input {
    font-size: 1.1rem;
}

/* Ombra leggera per separare la barra dallo sfondo */
.search-bar input.form-control {
    box-shadow: 0 0 0.25rem rgba(0, 0, 0, 0.1);
    transition: box-shadow 0.2s ease-in-out;
}

.search-bar input.form-control:focus {
    box-shadow: 0 0 0.4rem rgba(0, 123, 255, 0.25);
}

/* Bottone integrato a destra */
.search-bar button.btn {
    font-weight: 500;
    white-space: nowrap;
}

/* Versione mobile — bottone sotto */
@media (max-width: 576px) {
    .search-bar {
        display: flex;
        flex-direction: column;
        align-items: stretch;
    }

    .search-bar svg {
        position: absolute;
        top: 50%;
        left: 1.25rem;
        transform: translateY(-50%);
    }

    .search-bar button {
        position: static !important;
        transform: none !important;
        margin-top: 0.5rem;
        border-radius: 50rem !important;
    }
}


.img-square {
    width: 100%;
    aspect-ratio: 1 / 1;       /* imposta forma quadrata */
    object-fit: cover;         /* ritaglia il contenuto mantenendo proporzioni */
    object-position: center;   /* centra il ritaglio */
    border-radius: 0.5rem;     /* opzionale, mantiene il bordo arrotondato */
    display: block;
}

/* Se vuoi limitare l’altezza massima */
.maxh400 {
    max-height: 400px;
}

.navbar .navbar-collapsable
 {
 z-index:10000 !important;
 }


.col-contatti {
    padding-bottom: 10px;
}


.allinea {
    height: 6.9em;
    display: table-cell;
    vertical-align: middle;
}

.normative-container h5 {
    margin-top: 0;
}

.links-container h5 {
    margin-top: 10px;
}

.info-field a {
    color: #000;
}

/*********** breadcrumb *************************/

.breadcrumb-container .breadcrumb {
    text-transform: uppercase;
    width: 768px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.breadcrumb-container .breadcrumb li {
    display: inline;
    font-size: 13px;
    color: #777;
}

.breadcrumb-container .breadcrumb {
    padding-left: 10px;
}

/*********** bootstrap no gutter ***************/

/* no-gutters Class Rules */
.row.no-gutters {
    margin-right: 0;
    margin-left: 0;
}
.row.no-gutters > [class^="col-"],
.row.no-gutters > [class*=" col-"] {
    padding-right: 0;
    padding-left: 0;
}



@media (max-width: 990px) {
    .breadcrumb-container .breadcrumb {
        width: 600px;
    }
    .btn-labeled {padding-top: 10px;padding-bottom: 10px;margin-top: 10px;margin-bottom: 10px;}
}



.immagine {
    max-width: 200px;
}




.valign{
    display: inline-block;
    vertical-align: middle;
    float: none;
}

.immagine{
    max-height:160px;
}

.media-list {
    margin-top: 8px;
    margin-right:15px;
}

.media-list .glyphicon {
    top: 2px;
}

.box-link .box-titolo {
    margin-top: 4px;
}

.main-box .list-group .list-group-item:hover {
    border-bottom: 1px solid #ccc;
    background-color: #eee;
}



.nomegrotta{
    padding:0;
    font-size: 50px;
}
.camposcheda{
    margin-bottom: 2px;
    color:#6b6b6b;
}


@media (max-width: 767px){
    .risultatiricerca {
        text-align: center;
    }

    .btn-labeled {padding-top: 10px;padding-bottom: 10px;margin-top: 10px;margin-bottom: 10px;}

}

.hide {
    display: none !important;
}

.progress {

    font-size: .52rem !important;

}

.nav-pills .nav-link.active, .nav-pills .show>.nav-link { background-color: #21479A !important; }

/*
.btn-primary { background-color: #21479A !important; }
*/
.dropdown-item{
    padding-top: 5px !important;
}

[type=search] {
    outline-offset: -2px;
    -webkit-appearance: textfield;
}

.icons-list-tabella{
    list-style-type: none;
    padding-left: 1px;

}
.icons-list-tabella2{
    list-style-type: none;
    padding: 1px;
    width:24px;
    margin-bottom:2px;
    color:#7c69ef;
}

.icons-list-tabella2 p {
font-size:10px !important;
}

.testohome a{

    color:#21479A;
    font-weight: bold;

}

.daticatasto{
    color:#000000;
    margin-left: 5px;
}

.avvisiurgenti{
    background-color:#ffca6b;
}

.verificagreen{
    color:green;
}

.verificared{
    color:red;
}

.ekko-lightbox{
    z-index: 1200;
}

.bibliotitolo{
    font-size: 1.3625rem;

}

.biblioaut{
    font-style: italic;

}

.biblio{
    color:#000000;

}

.biblioriassunto{
    color:#161b1d;
    margin-top: 10px !important;
}

.bibliodiv{
    margin-top:12px;
}


/* bordo del campo inserimento del form */

.borderform{
    border: 1px solid #ccc;
}



.btn-label {position: relative;right: -8px;display: inline-block;padding: 9px 1px;border-radius: 3px 0 0 3px;}
.btn-labeled {padding-top: 0;padding-bottom: 0;}


.custom-select{
    border: 1px solid #000 !important;


}



#intestazione {
    position: fixed;
    right: 0px;
    top: 0px;
    z-index: 1110;
    margin: 0px;
    width: 100%;
    height: 40px;
    background: #21479A;
    border-bottom:1px solid #C0C0C0;
}
#intestazione img {
    border: 0px;
}
.intestazioneSX {
    float: left;
    margin: 0px 0px 0px 0px;
    padding: 0px 0px 0px 0px;

}
.intestazioneCenter {
    float: left;
    margin: 0px 0px 0px 0px;
    padding: 0px 0px 0px 0px;
    border-right: solid 1px white;
}

.icoapp{
    width: 100px;
    padding: 10px;
}

.obbligatorio{
    color:red;
}

@media (min-width: 768px){
    .col-md-3-ricercabutt {
        flex: 0 0 25%;
        max-width: 24% !important;
         min-height: 18% !important;
    }
}

@media (min-width: 769px) and (max-width: 1199px){
    .col-md-3-ricercabutt {

         min-height: 28% !important;
    }
}

@media (max-width: 768px){
    .logoreg {

        height: 28px;
    }
    .barralogoreg{
        margin-top: 28px;
    }
    #intestazione{
        height: 28px !important;
    }

}

@media (min-width: 768px){
    .logoreg {

        height: 40px;
    }
    .barralogoreg{
        margin-top: 40px;
    }

    .nullo{
        height: 0;
        width: 0;

    }
}


.card-body, .card-footer, .card-header, .card-meta, [class*=card-img] {

    width: 100% !important;

}

.marginegalleria{
margin-top: 20px !important;
}

.altezzafotocard
{
  height: 100px;
object-fit: cover;
}

.colorebianco{
  color: #fff !important;
}

.fe-trash-2{
    cursor: pointer;

}

.titoli-bolle-home{
    font-size: 1.1875rem;
        color: #000;
        line-height: 1.45;
        letter-spacing: -.01em;
        margin-bottom: .5rem;
        margin-top: 0;

}

.titolo-home-testo{
    font-family: decima_rgbold,Arial,Helvetica,sans-serif;
    font-size: 1.3125rem;
        color: #000;
        line-height: 1.4;
        letter-spacing: -.01em;
        margin-bottom: .5rem;
        margin-top: 0;


}


.select2-container--default .select2-selection--single{
     background-color: transparent !important;
}

.select2nonobbligatori{
    background-color: #fff !important;
}

.select2nonobbligatoridisabled{

        background-color: #f1f4f8 !important;
    opacity: 1;
}

.bottonemodifica {
    color:#42ba96;
}

.bottonecestino {
    color:#df4759 !important;
}

.nuovatabaggiornacav {
    background-color: #df4759;
    color:white;
}

@media (max-width: 1199px){
.menunascosto {visibility: hidden; display: none;}
}

@media (min-width: 1200px){
.menunascosto {visibility: visible; display: inline;}
}

@media (min-width: 990px){
.nuovasegnstato {visibility: visible; display: inline;}
}
@media (max-width: 989px){
.nuovasegnstato {visibility: hidden; display: none;}
}


.daticatastocrigatop{
    color:#ffffff;

}

.h3criga{
    font-family: decimaregular,Arial,Helvetica,sans-serif;
    color:white !important;
}

/* container select2 sempre largo quanto la colonna bootstrap */
.select2-container {
    width: 100% !important;
}

/* box uniforme (evita differenze tra righe) */
.select2-container--default .select2-selection--single {
    height: 44px;           /* usa la tua altezza standard */
    display: flex;
    align-items: center;
}



/* 1) Spazio a destra per testo: deve lasciare posto a X + freccia */
.select2-container--default .select2-selection--single .select2-selection__rendered {
    padding-right: 4.2rem !important; /* testo non va sotto le icone */
}

/* 2) Spazio totale del box (non obbligatorio ma spesso utile) */
.select2-container--default .select2-selection--single {
    padding-right: 0.25rem !important;
}

/* 3) Freccia più a destra */
.select2-container--default .select2-selection--single .select2-selection__arrow {
    right: 0.8rem !important;
}

/* 4) X tra testo e freccia, centrata verticalmente */
.select2-container--default .select2-selection--single .select2-selection__clear {
    position: absolute !important;
    right: 1rem !important; /* lascia la corsia alla freccia */
    top: 50% !important;
    transform: translateY(-50%) !important;

    margin: 0 !important;
    padding: 0 .15rem !important;

    z-index: 2;
    cursor: pointer;
    line-height: 1;
}

/* 5) Assicura che l'area cliccabile della select non copra la X */
.select2-container--default .select2-selection--single {
    position: relative;
}

.selezionavalnos + .select2-container .select2-selection__rendered { padding-right: 4.2rem !important; }
.selezionavalnos + .select2-container .select2-selection__clear { right: 2.4rem !important; }
.selezionavalnos + .select2-container .select2-selection__arrow { right: 0.8rem !important; }

.btn-secondary {

    background-color: #506690 !important;

}

.btn:hover{
    color:white !important;
    background-color: #004d99 !important;

}

/* Desktop / Large screens */

@media (min-width: 1199.98px) {
    .h-cardcomplesso {
        min-height: 650px !important;
        height: 650px !important;
    }
}

/* Tablet (Bootstrap md/lg breakpoint) */
@media (min-width: 991.99px) and (max-width: 1199.98px) {
    .h-cardcomplesso {
        min-height: 720px !important;
        height: 720px !important;
    }
}

/* Tablet piccoli / landscape */
@media (min-width: 767.99px) and (max-width: 991.98px) {
    .h-cardcomplesso {
        min-height: 780px !important;
        height: 780px !important;

    }

}

/* Mobile */
@media (max-width: 767.98px) {
    .h-cardcomplesso {
        min-height: 880px  !important;
        height: 880px  !important;
    }

}

.segn-divider{
    border: 0;
    border-top: 1px solid #d9e2ef;
    opacity: 1;
}

.segn-progress-wrap{
    width: 100%;
    padding: 10px 0;
}

.segn-progress{
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 24px;
    position: relative;
}

/* linea di collegamento */
.segn-progress::before{
    content: "";
    position: absolute;
    left: 40px;
    right: 40px;
    top: 44px;              /* centrata rispetto al cerchio */
    height: 4px;
    background: #cfd6df;
    border-radius: 999px;
    z-index: 0;
}

.segn-step{
    position: relative;
    z-index: 1;
    flex: 1 1 0;
    min-width: 120px;
    text-align: center;
}

.segn-icon{
    width: 88px;
    height: 88px;
    margin: 0 auto 12px auto;
    border-radius: 50%;
    background: #1f4c9a;     /* blu come screenshot */
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 1px 0 rgba(0,0,0,.04);
}

.segn-icon img{
    width: 54px;
    height: 54px;
    object-fit: contain;
    display: block;
}

/* label sotto */
.segn-label{
    font-size: 22px;
    line-height: 1.2;
    color: #1b1f24;
    font-weight: 500;
}

/* stato: corrente/done/todo (puoi personalizzare) */
.segn-step.is-current .segn-icon{
    background: #1f4c9a;
}

.segn-step.is-done .segn-icon{
    background: #1f4c9a;
    opacity: .95;
}

.segn-step.is-todo .segn-icon{
    background: #1f4c9a;
    opacity: .85;
}

/* responsive: su mobile vanno a capo in modo pulito */
@media (max-width: 992px){
    .segn-progress{
        flex-wrap: wrap;
        justify-content: center;
    }
    .segn-progress::before{
        display:none;
    }
    .segn-step{
        flex: 0 1 45%;
        min-width: 160px;
        margin-bottom: 18px;
    }
}
/* ============================
   Select2 + Bootstrap Italia fix
   ============================ */

/* container a larghezza piena */
.select2-container { width: 100% !important; }

/* Single select: replica form-control-sm */
.select2-container--default .select2-selection--single {
    height: calc(1.5em + .5rem + 2px);       /* come form-control-sm */
    padding: .25rem .5rem;
    border: 1px solid var(--bs-border-color, #ced4da);
    border-radius: .25rem;
    background-color: var(--bs-body-bg, #fff);
    display: flex;
    align-items: center;
}

/* testo */
.select2-container--default .select2-selection--single .select2-selection__rendered {
    padding-left: 0;
    line-height: 1.5;
}

/* freccia */
.select2-container--default .select2-selection--single .select2-selection__arrow {
    height: calc(1.5em + .5rem + 2px);
    right: .5rem;
}

/* focus: usa ring BI/BS */
.select2-container--default.select2-container--focus .select2-selection--single,
.select2-container--default.select2-container--open .select2-selection--single {
    border-color: var(--bs-primary, #0d6efd);
    outline: 0;
    box-shadow: 0 0 0 .2rem rgba(13,110,253,.25);
}

/* dropdown */
.select2-dropdown {
    border: 1px solid var(--bs-border-color, #ced4da);
    border-radius: .25rem;
    overflow: hidden;
}

/* search input dentro dropdown */
.select2-container--default .select2-search--dropdown .select2-search__field {
    height: calc(1.5em + .5rem + 2px);
    padding: .25rem .5rem;
    border: 1px solid var(--bs-border-color, #ced4da);
    border-radius: .25rem;
}

/* disabled */
.select2-container--default.select2-container--disabled .select2-selection--single {
    background-color: var(--bs-secondary-bg, #e9ecef);
    cursor: not-allowed;
    opacity: .7;
}

/* errore/obbligatorio: se tu aggiungi classe is-invalid alla select originale */
select.is-invalid + .select2 .select2-selection--single,
select.is-invalid ~ .select2-container .select2-selection--single {
    border-color: var(--bs-danger, #dc3545);
}
/* Contenitore con ratio orizzontale fisso */
.imgscheda-wrap a{
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;     /* <-- cambia qui se vuoi */
    overflow: hidden;
    border-radius: .5rem;     /* allinea al rounded */
}

/* L'immagine riempie e croppa al centro */
.imgscheda-wrap img.imgscheda{
    width: 100%;
    height: 100%;
    object-fit: cover;        /* crop */
    object-position: center;  /* crop centrale */
    display: block;
}

.bi-editable-box{
    background-color: white;
    border: 1px solid #000 !important;
    padding: .8125rem 1.25rem;
    border-radius: 7px;
    min-height: 120px;
}

.bi-editable-box.selezionavalobbligatorio{
    background-color: var(--bi-required-bg) !important;
    border-color:#000 !important;
}


/* Divisori tra voci (accordion-item) */
.accordion-help .accordion-item {
    border-bottom: 1px solid rgba(0,0,0,.125);
}
.accordion-help .accordion-item:last-child {
    border-bottom: 0;
}

/* Facoltativo: riduci padding e compatta un po' */
.accordion-help .accordion-button {
    padding-top: .85rem;
    padding-bottom: .85rem;
}

/* FIX: ripristina l’icona/chevron dell’accordion (Bootstrap Italia / BS5) */
.accordion-button::after {
    transform: rotate(180deg);
    display: block !important;
    content: "" !important;
    background-image: var(--bs-accordion-btn-icon) !important;
    background-repeat: no-repeat !important;
    background-size: var(--bs-accordion-btn-icon-width) !important;
    width: var(--bs-accordion-btn-icon-width) !important;
    height: var(--bs-accordion-btn-icon-width) !important;
}

.accordion-button:not(.collapsed)::after {
    transform: rotate(0deg);
    background-image: var(--bs-accordion-btn-active-icon) !important;
}

/* Select nella ricerca avanzata */
/* Scope: SOLO select2 dentro i wrapper bi-s2-* */
.bi-s2-wrap .select2-container { width: 100% !important; }

/* Altezza "sm" coerente con Bootstrap 5 (form-select-sm) */
.bi-s2-sm .select2-container--default .select2-selection--single{
    height: calc(1.5em + .5rem + 2px);
    min-height: calc(1.5em + .5rem + 2px);
    display: flex;
    align-items: center;
}

/* Testo centrato verticalmente */
.bi-s2-sm .select2-container--default .select2-selection--single .select2-selection__rendered{
    line-height: 1.5;
    padding-left: .5rem;
    padding-right: .5rem; /* poi lo correggiamo quando togliamo freccia */
}

/* =========================================================
   CLEARONLY:
   - Vuota: freccia visibile (nello spot della X)
   - Selezionata: X visibile (nello spot della freccia), freccia nascosta
   - Click sulla X: torna vuota => torna la freccia
   ========================================================= */

.bi-s2-clearonly .select2-container--default .select2-selection--single{
    position: relative; /* fondamentale per posizionare arrow/clear */
}

/* Definisco una "ancora" unica a destra: uguale per freccia e X */
.bi-s2-clearonly .select2-container--default .select2-selection__arrow,
.bi-s2-clearonly .select2-container--default .select2-selection__clear{
    position: absolute !important;
    right: .6rem !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    margin: 0 !important;
    float: none !important;
}

/* Default (vuota): freccia ON, X OFF */
.bi-s2-clearonly .select2-container--default .select2-selection__arrow{
    display: block !important;
}

.bi-s2-clearonly .select2-container--default .select2-selection__clear{
    display: none !important;
    z-index: 3;
}

/* Quando c'è selezione (Select2 aggiunge .select2-selection--clearable):
   X ON, freccia OFF */
.bi-s2-clearonly .select2-container--default .select2-selection--clearable .select2-selection__clear{
    display: block !important;
}

.bi-s2-clearonly .select2-container--default .select2-selection--clearable .select2-selection__arrow{
    display: none !important;
}

/* Spazio testo a destra per non sovrapporsi a freccia/X */
.bi-s2-clearonly .select2-container--default .select2-selection__rendered{
    padding-right: 1.75rem !important;
}


/* FIX: al clear (click X) Select2 non deve mai restringersi */
.bi-s2-wrap .select2-container{
    width: 100% !important;
    display: block !important;   /* evita shrink in contesti flex */
    min-width: 0;                /* evita overflow strani nei flex */
}

.bi-s2-wrap .select2-container--open{
    width: 100% !important;
}

/* se il parent usa flex, questo aiuta ancora di più */
.bi-s2-wrap{
    width: 100%;
}

/* opzionale: anche la selection non deve “collassare” */
.bi-s2-wrap .select2-selection--single{
    width: 100% !important;
    box-sizing: border-box;
}


/* OPERATOR: la freccia deve restare */
select[data-bi-s2="operator"] + .select2-container .select2-selection__arrow{
    display: block !important;
}

/* OPERATOR: la X deve esistere */
select[data-bi-s2="operator"] + .select2-container .select2-selection__clear{
    display: block !important;
}

/* OPERATOR: la X nella stessa posizione della freccia */
select[data-bi-s2="operator"] + .select2-container .select2-selection--single{
    position: relative;
}

/* freccia: posizione standard a destra */
select[data-bi-s2="operator"] + .select2-container .select2-selection__arrow{
    position: absolute;
    right: .6rem;
    top: 50%;
    transform: translateY(-50%);
}

/* X: stessa identica posizione della freccia */
select[data-bi-s2="operator"] + .select2-container .select2-selection__clear{
    position: absolute !important;
    right: .6rem !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    margin: 0 !important;
    float: none !important;
    z-index: 3;
}

/* quando c’è la X, nascondi la freccia */
select[data-bi-s2="operator"] + .select2-container .select2-selection__clear ~ .select2-selection__arrow{
    display: none !important;
}

/* spazio a destra per non far finire il testo sotto X/freccia */
select[data-bi-s2="operator"] + .select2-container .select2-selection__rendered{
    padding-right: 1.75rem !important;
}

.modal-title{
    font-size: 1.75rem !important;
    padding-bottom: 0.75rem;
}
.modal-body{
    margin-top: 30px !important;
    margin-bottom: 30px !important;
}
