
    .modal-dialog {
    pointer-events: all;
}
/* ============ desktop view ============ */
@media all and (min-width: 992px) {

	.dropdown-menu li{
		position: relative;
	}
	.dropdown-menu .submenu{ 
		display: none;
		position: absolute;
		left:100%; top:-7px;
	}
	.dropdown-menu .submenu-left{ 
		right:100%; left:auto;
	}

	.dropdown-menu > li:hover{ background-color: #f1f1f1 }
	.dropdown-menu > li:hover > .submenu{
		display: block;
	}
}	
/* ============ desktop view .end// ============ */

/* ============ small devices ============ */
@media (max-width: 991px) {

.dropdown-menu .dropdown-menu{
		margin-left:0.7rem;  margin-bottom: .5rem;
}

}	
/* ============ small devices .end// ============ */


    
        #module {
            width: 100%
        }

            #module div.collapse:not(.show) {
            }

            #module div.collapse[aria-expanded="false"] {
                display: block;
                -webkit-transition: height .01s ease !important;
                -o-transition: height .01s ease !important;
                transition: height .01s ease !important;
            }

            #module a.collapsed:after {
                content: '+ leggi tutto';
                float: right
            }

            #module a[role="button"] {
                color: black;
                font-size: 14px
            }

            #module div.collapse.show {
                /*height: 100% !important;*/
            }

            #module div.collapsing[aria-expanded="false"] {
                /*height: 100% !important;*/
                -webkit-transition: height .01s ease !important;
                -o-transition: height .01s ease !important;
                transition: height .01s ease !important;
            }

            #module a[role="button"]:not(.collapsed):after {
                content: '- chiudi';
                float: right;
            }

        .form-control {
            -webkit-appearance: auto !important;
            -moz-appearance: auto !important;
            appearance: auto !important;
        }

        .annuncio {
            width: 283px;
            aspect-ratio: 283/371;
        }

        .videoslider {
            width: 278px;
            /*height: 208px;*/
            aspect-ratio: 278/208;
            display: block;
        }

        @media (max-width: 1200px) {
            .img_intro {
                min-height: auto !important;
            }
        }

        .splide__track {
            overflow: hidden;
            position: relative;
            z-index: 0;
        }

        .splide__list {
            -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
            display: -ms-flexbox;
            display: flex;
            height: 100%;
            margin: 0 !important;
            padding: 0 !important;
            transform-style: preserve-3d;
        }

        .splide__slide {
            -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
            box-sizing: border-box;
            -ms-flex-negative: 0;
            flex-shrink: 0;
            list-style-type: none !important;
            margin: 0;
            outline: none;
            position: relative;
        }

        .splide__slide {
            -webkit-backface-visibility: hidden;
            backface-visibility: hidden;
            box-sizing: border-box;
            -ms-flex-negative: 0;
            flex-shrink: 0;
            list-style-type: none !important;
            margin: 0;
            outline: none;
            position: relative;
        }

@media (max-width: 575px) {

        .container {
        padding-left:2px !important;
        padding-right:10px !important;
    }

        article {
             padding-left:2px !important;
     padding-right:2px !important;
        }
        body {
            overflow-x: hidden;
        }
}
        @media (max-width: 1199px) {
/*            #module div.collapse:not(.show) {
                height: 4.8em !important;
            }*/

            #module div.collapse[aria-expanded="false"] {
                height: 4.8em;
                overflow: hidden;
            }

            #module div.collapse.show {
                height: 100% !important;
            }

            #module div.collapsing[aria-expanded="false"] {
                height: 100% !important;
  
            }

            #collapseTextPlus {
            display:block;
            }
    
    
        #page-title.page-title-dark h1 {
            font-size: 20px !important;
        }

        #page-title.page-title-dark span {
            font-size: 18px !important;
        }
        }

        @media (max-width: 767px) {
            .portfolio-filter li {
                width: 80% !important;
                margin: 0 0 20px 0 !important;
            }
        }

        @media (max-width: 575px) {
            .portfolio-filter li {
                width: 80% !important;
                margin: 0 0 20px 0 !important;
            }
        }

        .btn-newprimary {
            color: #fff !important;
            background-color: #007bff !important;
            border-color: #007bff !important;
        }

        @media (max-width: 767px) {

            #page-title.page-title-dark  {
                padding-top: 5px !important;
                padding-bottom: 5px !important;
            }

            span.aggiornamento {
                display: none!important;
            }
            #page-title span {
 
    margin-top: 0px !important;
 
}
            #page-title.page-title-bread {
                            padding-top: 5px !important;
                padding-bottom: 5px !important;
            }
            #collapseText {
                margin-top: 0px !important;
            }

        }
    


    .portfolio-item-filtri {
        position: relative;
        width: 100%;   
    }
    
    .portfolio-item-filtri ul{
        position: relative;
        width: 100%;
        list-style-type:none;
        color: #FFF;
        font-size: 1.2em;
        text-align: center; 
        list-style: normal;
        margin: 0px; 
        padding: 0px;
        background: none;
    }
    
    /* non funziona perchè credo che ci sia una impostazione di qualche lista su qualche classe base che sovrascrive anche se viene indicata con nuova classe
    .portfolio-item-filtri li{
        position: relative;
        background: #a32623;
        border: 0px; 
        min-width: 100%; 
        height: 60px; 
        list-style: none;
        border-radius: 0px;
        background: cyan;
        display: inline-block;
    }
    */
    
    .portfolio-item-filtri-list{
        position: relative;
        background: #a32623;
        border: 0px; 
        padding:0px;
        width: 100%; 
        height: 50px; 
        list-style: none;
        border-radius: 0px;
        background: none;
        display: inline-block;
    }
    
    .portfolio-item-filtri a{
        position: absolute;
        background: #a32623;
        width:100%;
        height: 50px;
        margin:0;
        padding: 18px;
        top: 0;
        border-radius: 20px;
        left: 50%;
        transform: translateX(-50%);
    }
    
    .portfolio-item-filtri a span{
        padding: 8px;
    }
    
    @media (min-width: 300px) {
    
    .portfolio-item-filtri ul{
        font-size: 1.5em;
    }
    
    .portfolio-item-filtri-list{
        width: 100%; 
        height: 50px; 
    }
    
    .portfolio-item-filtri a{
        height: 50px;
        margin:0 5px;
        padding: 10px;
    }
    
    }
    
    @media (min-width: 400px) {
    
    .portfolio-item-filtri-list{
        width: 100%; 
        height: 50px; 
    }
    
    .portfolio-item-filtri a{
        height: 50px;
        margin:0 5px;
        padding: 10px;
    }
    
    
    }
    
    @media (min-width: 500px) {
    
    .portfolio-item-filtri ul{
        font-size: 1.3em;
    }
    
    .portfolio-item-filtri-list{
        width: 49%; 
        height: 70px; 
    }
    
    .portfolio-item-filtri a{
        height: 70px;
        margin:0 5px;
        padding: 18px;
        transform: translateX(-53%);
    }
    
    }
    
    @media (min-width: 558px) {
    
    .portfolio-item-filtri ul{
        font-size: 1.4em;
    }
    
    .portfolio-item-filtri-list{
        width: 49%; 
        height: 70px; 
    }
    
    .portfolio-item-filtri a{
        height: 70px;
        margin:0 5px;
        padding: 15px;
    }
    
    }
    
    @media (min-width: 601px) {
    
    .portfolio-item-filtri ul{
        font-size: 1.5em;
    }
    
    }
    
    @media (max-width:767px) {
    
    
    }
    
    @media (max-width:992px) {
    
    
    }

/* =====================================================================
   FILTRI ELENCO ANNUNCI - Nuova grafica 2024
   Stile ridisegnato per la barra filtri (provincia/zona, categoria,
   bottoni filtri/mappa) e il box delle macrozone.
   Indipendente da assets/css/styleguide.css e assets/css/globals.css.
   ===================================================================== */

/* ---- Box macrozone (Tutte le zone / Senza zona / elenco macrozone) ---- */
.box_macrozone {
  display: block !important;
  width: 100%;
  max-width: 100%;
  margin: 12px 0 16px;
  padding: 0 !important;
  background: #fafafa;
  border-top: 1px solid #e0e0e0;
  border-bottom: 1px solid #e0e0e0;
  border-radius: 0;
  box-shadow: none;
  position: relative;
  overflow: visible !important;
}
.macrozone_header {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  width: 100%;
  background: #ececec;
  border-bottom: 1px solid #e0e0e0;
}
.macrozone_header_label {
  display: inline-flex;
  align-items: center;
  padding: 8px 14px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .8px;
  color: #1f1f1f;
}
.box_macrozone .citta-list {
  display: flex !important;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  padding: 8px 10px !important;
  width: 100% !important;
  grid-template-columns: none !important;
  column-count: unset !important;
  line-height: 1.3 !important;
  background: transparent !important;
}
.box_macrozone .citta-list p {
  margin: 0;
}
.box_macrozone .citta-list p a,
.box_macrozone .citta-list p span {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px 4px 12px;
  font-size: 13px;
  font-weight: 600;
  text-align: left;
  color: #1f1f1f !important;
  background: #fff;
  border: 1px solid #d6d6d6;
  border-left: 3px solid #c93241;
  border-radius: 0;
  text-decoration: none;
  line-height: 1.3;
  transition: background .15s, color .15s, border-color .15s;
}
.box_macrozone .citta-list p a:hover {
  background: #ececec;
  color: #c93241 !important;
}
.box_macrozone .citta-list .macrozona_selected {
  background: #c93241;
  border-color: #c93241;
  border-left-color: #8a1f2a;
  color: #fff !important;
}
.box_macrozone .citta-list .reset_macrozone {
  /* default come gli altri pulsanti; quando è anche .macrozona_selected eredita lo stato evidenziato */
}
.macrozone_limit {
  max-height: 60px;
  overflow: hidden;
}
.macrozone_btn_toggle {
  display: inline-flex !important;
  align-items: stretch;
  flex: 0 0 auto;
  width: auto !important;
  margin-left: auto;
  padding: 0;
  border-left: 1px solid #e0e0e0;
  text-align: left !important;
}
.macrozone_btn_toggle .btn_mostra_piu,
.macrozone_btn_toggle .button {
  display: inline-flex;
  align-items: center;
  position: static !important;
  top: auto !important;
  padding: 0 14px !important;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: #c93241 !important;
  background: transparent !important;
  border: 0;
  border-radius: 0;
  cursor: pointer;
}
.macrozone_btn_toggle .btn_mostra_piu:hover,
.macrozone_btn_toggle .button:hover {
  color: #8a1f2a !important;
  background: #ececec;
}
@media (max-width: 600px) {
  .macrozone_btn_toggle {
    border-left: 0;
  }
}

/* ---- Barra filtri principale (form-filters) ---- */
#form-filters .filters {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  max-width: 100%;
  margin: 16px 0;
  padding: 12px 24px;
  background: linear-gradient(135deg, #a90b1c, #cf0215);
  border-radius: 0;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  position: relative;
}

/* Cluster "provincia + zona + quartiere" */
#form-filters .filter {
  display: flex;
  flex: 1 1 280px;
  align-items: center;
  gap: 8px;
  min-height: 38px;
  padding: 4px 12px;
  background: #fff;
  border-radius: 0;
  position: relative;
  flex-wrap: wrap;
}

/* Singolo "input" cliccabile dentro .filter (apre la .select-div) */
#form-filters .filter .input {
  position: relative;
  display: flex;
  flex: 1 1 auto;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  padding: 6px 8px;
  cursor: pointer;
  color: #1f1f1f;
  font-weight: 500;
  font-size: 14px;
  white-space: nowrap;
}
#form-filters .filter .input > .valign-text-middle {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
}
#form-filters .filter .input svg {
  flex: 0 0 auto;
}

/* Dropdown della .input */
#form-filters .filter .select-div {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  z-index: 50;
  max-height: 320px;
  overflow-y: auto;
  background: #fff;
  border: 1px solid #ddd;
  border-radius: 0;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
  padding: 6px 0;
}
#form-filters .filter .select-div.right { left: auto; right: 0; }
#form-filters .filter .select-div.left  { left: 0; right: auto; }
#form-filters .filter .select-div.hidden { display: none; }
#form-filters .filter .select-div ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
#form-filters .filter .select-div li {
  padding: 8px 14px;
  font-size: 14px;
  color: #1f1f1f;
  cursor: pointer;
}
#form-filters .filter .select-div li:hover {
  background: #f3f3f3;
  color: #cf0215;
}

/* Toggle categoria (Tutte / Donne / Trans / Massaggi ...) */
#form-filters .toggle-container {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  height: 30px;
  padding: 0;
  background: rgba(255, 255, 255, 0.18);
  border-radius: 0;
  overflow-x: auto;
  overflow-y: hidden;
}
#form-filters .toggle-button {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 14px;
  font-size: 13px;
  font-weight: 600;
  color: #fff;
  border-radius: 0;
  cursor: pointer;
  white-space: nowrap;
  transition: background .15s, color .15s;
}
#form-filters .toggle-button:hover {
  background: rgba(255, 255, 255, 0.25);
}
#form-filters .toggle-button.active {
  background: rgba(0, 0, 0, 0.35);
  color: #fff;
  cursor: default;
}

/* Pulsanti "Filtri" e "Apri mappa" */
#form-filters .filters_div,
#form-filters .button-send-1 {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 38px;
  padding: 0 16px;
  font-size: 14px;
  font-weight: 600;
  color: #fff;
  background: rgba(0, 0, 0, 0.35);
  border-radius: 0;
  cursor: pointer;
  text-decoration: none;
}
#form-filters .filters_div:hover,
#form-filters .button-send-1:hover {
  background: #1f1f1f;
}
#form-filters .filters_div > div,
#form-filters .button-send-1 .cerca-1 {
  font-size: 14px;
  font-weight: 600;
}

#form-filters .flex-cleaner { flex: 1 1 0; min-width: 0; }

/* Riepilogo filtri attivi sopra l'elenco (pillole "20-25", città, ecc.) */
#filtri_fr_container {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: stretch;
  gap: 0;
  margin: 12px 0 16px;
  padding: 0;
  border-top: 1px solid #e0e0e0;
  border-bottom: 1px solid #e0e0e0;
  background: #fafafa;
}
#filtri_fr_container:empty {
  display: none;
}
#filtri_fr_container::before {
  content: 'Filtri attivi:';
  display: inline-flex;
  align-items: center;
  padding: 8px 14px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .8px;
  color: #1f1f1f;
  background: #ececec;
  border-right: 1px solid #e0e0e0;
}
#filtri_fr_container .button-city,
#filtri_fr_container .button-city-1,
#filtri_fr_container .button-city-2 {
  display: inline-flex !important;
  align-items: center;
  gap: 6px;
  padding: 4px 6px 4px 12px;
  margin: 6px 0 6px 8px;
  font-size: 13px;
  font-weight: 600;
  color: #1f1f1f;
  background: #fff;
  border: 1px solid #d6d6d6;
  border-left: 3px solid #c93241;
  border-radius: 0 !important;
  box-shadow: none;
  text-align: left !important;
  width: auto !important;
  height: auto !important;
}
#filtri_fr_container .button-city .vedi-tutte,
#filtri_fr_container .button-city-1 .vedi-tutte {
  background: transparent !important;
  color: inherit !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 0 !important;
  font-size: 13px;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
}
/* la x di chiusura della singola pillola */
#filtri_fr_container .button-city .vedi-tutte.pointer,
#filtri_fr_container .button-city-1 .vedi-tutte.pointer {
  margin-left: 4px !important;
  padding: 2px 4px !important;
  color: #888;
  cursor: pointer;
  transition: color .15s;
}
#filtri_fr_container .button-city .vedi-tutte.pointer:hover,
#filtri_fr_container .button-city-1 .vedi-tutte.pointer:hover {
  color: #c93241;
}
#filtri_fr_container .button-city .vedi-tutte.pointer img {
  display: block;
  width: 14px;
  height: 14px;
}
/* "Rimuovi filtri" – link, non più pillola nera */
#filtri_fr_container > .button-small.vedi-tutte {
  display: inline-flex !important;
  align-items: center;
  margin-left: auto !important;
  padding: 0 14px !important;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: #c93241 !important;
  background: transparent !important;
  border: 0 !important;
  border-left: 1px solid #e0e0e0 !important;
  border-radius: 0 !important;
  cursor: pointer;
  text-decoration: none;
}
#filtri_fr_container > .button-small.vedi-tutte:hover {
  color: #8a1f2a !important;
  background: #ececec !important;
}
@media (max-width: 600px) {
  #filtri_fr_container::before { width: 100%; border-right: 0; border-bottom: 1px solid #e0e0e0; }
  #filtri_fr_container > .button-small.vedi-tutte {
    margin-left: 0 !important;
    width: 100%;
    border-left: 0 !important;
    border-top: 1px solid #e0e0e0 !important;
    justify-content: center;
    padding: 8px 14px !important;
  }
}
#ricerca_container .button-small {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  font-size: 12px;
  color: #fff;
  background: #1f1f1f;
  border-radius: 14px;
  text-decoration: none;
}

/* Responsive: mostra/nascondi "Filtri" desktop vs mobile */
.hide-sm { display: inline-flex; }
.hide-md, .hide-lg { display: none; }
@media (max-width: 767.98px) {
  .hide-sm { display: none !important; }
  .hide-md, .hide-lg { display: inline-flex !important; }

  #form-filters .filters {
    border-radius: 0;
    padding: 10px;
    gap: 8px;
  }
  #form-filters .filter,
  #form-filters .toggle-container,
  #form-filters .toggle-button,
  #form-filters .filters_div,
  #form-filters .button-send-1 {
    border-radius: 0 !important;
  }
  #form-filters .filter {
    flex: 1 1 100%;
  }
  #form-filters .toggle-container {
    width: 100%;
    justify-content: center;
  }
}

/* Utility presenti nel markup (un tempo definite in globals.css) */
.w100x100 { width: 100%; }
.hidden { display: none !important; }
.pointer { cursor: pointer; }
.padding { padding: 10px; }
.padding-3 { padding: 18px 0; }
.cleaner { display: block; clear: both; width: 100%; }
.cleaner.hh15 { height: 15px; }
.cleaner.hh20 { height: 20px; }
.cleaner.hh40 { height: 40px; }
.flex-cleaner { flex: 1; }
.valign-text-middle { display: inline-flex; align-items: center; }
.text-sexyguidaitalia { color: #cf0215 !important; }
.text-white { color: #fff !important; }
.weight-700 { font-weight: 700; }
.button { display: inline-flex; align-items: center; gap: 4px; }
.button-small { font-size: 12px; }
.banner_avviso_massaggi {
  border: 1px solid #E1021E;
  color: #1f1f1f;
  text-align: center;
  padding: 14px;
  border-radius: 12px;
  background: #fff8e8;
  margin: 14px auto;
  max-width: 1100px;
}

/* Avviso ricerca attiva */
#ricerca_container {
  background: #fff;
  border: 1px solid #eee;
  border-radius: 10px;
  padding: 8px 14px;
  margin: 10px auto;
  max-width: 1100px;
}
#ricerca_container .text-white { color: #1f1f1f !important; }

/* =====================================================================
   POPUP FILTRI / MAPPA (apri_filtri / apri_mappa)
   Ricreati qui perche' globals.css/elenco.css non vengono piu' caricati.
   ===================================================================== */
.intro {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.85);
  z-index: 1080;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow-y: auto;
  padding: 15px;
}
.intro.d-none { display: none !important; }
body.no-scroll { overflow: hidden; }

.overlay-select-div {
  position: absolute;
  inset: 0;
  background: transparent;
  z-index: 1;
}

.popup-filtri {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 760px;
  max-height: calc(100vh - 30px);
  padding: 0;
  gap: 0;
  background: #fff;
  color: #1f1f1f;
  border-radius: 14px;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4);
  overflow: hidden;
}
.popup-filtri .filtri-row {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.popup-filtri #filtri-header {
  background: #cf0215;
  color: #fff;
  padding: 12px 20px;
  border-bottom: none;
  flex: 0 0 auto;
}
.popup-filtri #filtri-header .title { font-weight: 700; font-size: 20px; color: #fff; }
.popup-filtri #filtri-header svg,
.popup-filtri #filtri-header svg * { fill: #fff !important; stroke: #fff; }
.popup-filtri #filtri_content {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: 16px 20px;
  text-align: left;
}
.popup-filtri #filtri_footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  border-top: 1px solid #eee;
  padding: 12px 20px;
  flex: 0 0 auto;
}
.popup-filtri .button-medium {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 8px 18px;
  border-radius: 200px;
  background: #ececec;
  color: #1f1f1f;
  cursor: pointer;
  font-weight: 600;
}
.popup-filtri .button-medium:hover { background: #ddd; }
.popup-filtri #search-elenco-btn.button-send-1 {
  background: #cf0215;
  color: #fff;
  border-radius: 200px;
  padding: 8px 22px;
}

/* Pulsanti dentro filtri (radio "Tutti" / "Donne" / categorie, range eta', ecc.) */
.popup-filtri .btn-filtro {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 14px;
  border-radius: 200px;
  background: #ececec;
  color: #1f1f1f;
  cursor: pointer;
  font-size: 14px;
  margin: 3px;
}
.popup-filtri .btn-filtro.selected,
.popup-filtri .btn-filtro.active {
  background: #cf0215;
  color: #fff;
}

@media (max-width: 767.98px) {
  .popup-filtri {
    max-width: 100%;
    max-height: 100%;
    height: 100%;
    border-radius: 0;
    padding: 0;
  }
  .popup-filtri #filtri-header,
  .popup-filtri #filtri_content,
  .popup-filtri #filtri_footer { padding-left: 16px; padding-right: 16px; }
}

/* ---------------------------------------------------------
   Righe filtro all'interno del popup (ajax_filtri.php)
   Sovrascrive lo stile rosso globale di .button e formatta
   correttamente le dropdown (select-div-filter), le liste
   multiple e i bottoni "Contenuti".
   --------------------------------------------------------- */
/* Layout a griglia: più specifiche sulla stessa riga, raggruppate per sezione */
.popup-filtri #filtri_content {
  display: block;
}
.popup-filtri .filtri-sezione {
  margin: 0 0 14px 0;
}
.popup-filtri .filtri-sezione + .filtri-sezione {
  padding-top: 14px;
  border-top: 1px solid #eee;
}
.popup-filtri .filtri-sezione-titolo {
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: #cf0215;
  margin: 0 0 8px 0;
}
.popup-filtri .filtri-sezione-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 14px;
  align-items: start;
}
@media (min-width: 768px) {
  .popup-filtri .filtri-sezione-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (max-width: 480px) {
  .popup-filtri .filtri-sezione-grid {
    grid-template-columns: 1fr;
  }
}
.popup-filtri .filtri-sezione-grid > .dett-row {
  display: block;
  width: 100%;
  margin: 0;
}
.popup-filtri #filtri_content .dett-row {
  display: block;
  width: 100%;
  margin: 0 0 10px 0;
}
.popup-filtri #filtri_content .dett-filter {
  width: 100%;
  display: block;
}
.popup-filtri .select-2.select-filter {
  position: relative;
  width: 100%;
}
.popup-filtri .filtri-d_,
.popup-filtri [class*="filtri-d_"] {
  position: relative;
  width: 100%;
}
.popup-filtri .select-filter-c {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  width: 100%;
  padding: 10px 14px;
  background: #f5f5f5;
  border: 1px solid #e3e3e3;
  border-radius: 10px;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}
.popup-filtri .select-filter-c:hover {
  background: #ececec;
  border-color: #cf0215;
}
/* annulla lo stile rosso globale di .button dentro la riga filtro */
.popup-filtri .select-filter-c .button {
  display: inline-block;
  position: static;
  margin: 0;
  padding: 0;
  height: auto;
  line-height: 1.3;
  background: transparent;
  color: #1f1f1f;
  font-weight: 600;
  font-size: 15px;
  text-transform: none;
  letter-spacing: normal;
  text-shadow: none;
  border: none;
  white-space: normal;
}
.popup-filtri .select-filter-c > .flex {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #555;
  font-size: 14px;
  white-space: nowrap;
}

/* Dropdown */
.popup-filtri .select-div-filter {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 4px);
  background: #fff;
  border: 1px solid #e3e3e3;
  border-radius: 10px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
  max-height: 280px;
  overflow-y: auto;
  z-index: 10;
}
.popup-filtri .select-div-filter ul {
  list-style: none;
  margin: 0;
  padding: 6px 0;
}
.popup-filtri .select-div-filter li {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  cursor: pointer;
  color: #1f1f1f;
  font-size: 14px;
}
.popup-filtri .select-div-filter li:hover,
.popup-filtri .select-div-filter li.selected {
  background: #f5e7e9;
  color: #cf0215;
}
.popup-filtri .select-multiple-ul > li {
  justify-content: flex-start;
}

/* checkbox custom per filtri multipli */
.popup-filtri .m-checkbox {
  width: 18px;
  height: 18px;
  border: 2px solid #bbb;
  border-radius: 4px;
  flex: 0 0 18px;
  position: relative;
  background: #fff;
}
.popup-filtri .m-checkbox.selected {
  background: #cf0215;
  border-color: #cf0215;
}
.popup-filtri .m-checkbox.selected::after {
  content: "";
  position: absolute;
  left: 4px;
  top: 0;
  width: 5px;
  height: 10px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

/* Sezione "Contenuti" con bottoni */
.popup-filtri #filtri_contenuti {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid #eee;
}
.popup-filtri #filtri_contenuti .title {
  font-weight: 700;
  font-size: 16px;
  color: #1f1f1f;
  margin-bottom: 8px;
}
.popup-filtri .contenuti_btn_container {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

/* Popup mappa */
#popup-map-container .popup-filtri,
#popup-map {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1100px;
  height: calc(100vh - 60px);
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.4);
}
#popup-map .close {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 5;
  background: #fff;
  border-radius: 50%;
  padding: 4px;
  cursor: pointer;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.3);
}
#popup-map #map { width: 100%; height: 100%; }


    
