/**
 * Tom Select per #country-filter: allineato a .filter-group .input-container select (blog.css).
 * Con plugin dropdown_input: nel controllo solo la nazione scelta; la ricerca è nel pannello aperto (sticky in alto).
 */

.filter-group .input-container .ts-wrapper {
	position: relative;
	z-index: 1;
	width: 100%;
}

/*
 * Stacking: i filtri sono in colonna (soprattutto su mobile). Il dropdown ha z-index 50 ma resta
 * nello stacking context del wrapper (z-index 1): il .filter-group successivo (nazione) finiva sopra
 * e copriva il menu continente con “Tutte le nazioni”. Con menu aperto il wrapper sale sopra i vicini.
 */
.filter-group .input-container .ts-wrapper.dropdown-active {
	z-index: 60;
}

.filter-group .input-container .clear-filter {
	z-index: 4;
}

/* X visibile solo con selezione reale (classe da ListingShared.syncGeoClearButtons) */
.filter-group .input-container .clear-filter:not(.clear-filter--active) {
	visibility: hidden;
	opacity: 0;
	pointer-events: none;
}

/* Spazio per icona continente a sinistra; senza selezione solo testo “Tutti i continenti” */
/* #continent-filter è fratello di .ts-wrapper, non figlio: :has sul .input-container */
.filter-group .input-container:has(#continent-filter) .ts-wrapper .ts-control {
	padding-left: 44px;
}

.filter-group .input-container:has(.continent-select-icon--empty):has(#continent-filter) .ts-wrapper .ts-control {
	padding-left: 16px;
}

.filter-group .input-container .continent-select-icon--empty {
	display: none;
}

/* Stesso blocco visivo del select nativo in blog.css */
.filter-group .input-container .ts-wrapper.single .ts-control {
	min-height: 52px;
	padding: 14px 3.25rem 14px 16px;
	border-radius: var(--radius-md);
	border: 1px solid var(--border-subtle);
	background-color: var(--input-bg);
	color: var(--text-primary);
	font-family: inherit;
	font-size: 0.95rem;
	font-weight: 500;
	box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.2);
	cursor: pointer;
	transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' fill='none' viewBox='0 0 24 24' stroke='%2394a3b8'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 2.4rem center;
	background-size: 18px;
	flex-wrap: nowrap;
	align-items: center;
}

.filter-group .input-container .ts-wrapper.single .ts-control::after {
	display: none;
}

.filter-group .input-container .ts-wrapper.single.focus .ts-control,
.filter-group .input-container .ts-wrapper.single.dropdown-active .ts-control {
	border-color: var(--accent-orange);
	background-color: var(--surface);
	box-shadow:
		0 0 0 3px var(--focus-ring),
		inset 0 1px 2px rgba(0, 0, 0, 0.15);
}

.filter-group .input-container .ts-wrapper.single .ts-control:hover {
	background-color: var(--surface);
	border-color: rgba(243, 112, 33, 0.42);
}

/* --- plugin dropdown_input: niente campo ricerca nel controllo quando c’è una selezione --- */
.filter-group .input-container .ts-wrapper.plugin-dropdown_input.single.has-items .ts-control {
	cursor: pointer;
}

.filter-group .input-container .ts-wrapper.plugin-dropdown_input .ts-control > .item {
	flex: 1 1 auto;
	min-width: 0;
	max-width: 100%;
}

.filter-group .input-container .ts-wrapper.plugin-dropdown_input .ts-control > .items-placeholder {
	flex: 1 1 auto;
	min-width: 0 !important;
	width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
	min-height: 0 !important;
	font-size: 0.95rem !important;
	font-weight: 500 !important;
	color: var(--text-muted) !important;
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
	cursor: pointer;
}

/*
 * Tom Select (plugin dropdown_input) nasconde .items-placeholder su .dropdown-active.
 * Senza nazione selezionata vogliamo che resti visibile “Tutte le nazioni” nel controllo mentre il menu è aperto.
 */
.filter-group
	.input-container
	.ts-wrapper.plugin-dropdown_input.dropdown-active:not(.has-items)
	.ts-control
	> .items-placeholder {
	display: block !important;
}

.filter-group .input-container .ts-wrapper .ts-control .country-ts-row {
	display: flex;
	align-items: center;
	gap: 10px;
	min-width: 0;
}

/* flag-icons: .fi.fis dimensiona lo sprite nel controllo e nel dropdown */
.filter-group .input-container .ts-wrapper .country-ts-row__fi.fi {
	flex-shrink: 0;
	line-height: 1;
}

.filter-group .input-container .ts-wrapper .country-ts-row__name {
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

/* Campo ricerca nel dropdown (non nel controllo chiuso) */
.filter-group .input-container .ts-dropdown {
	border-radius: var(--radius-md);
	border: 1px solid var(--border-subtle);
	box-shadow: var(--shadow-md);
	background: var(--surface);
	z-index: 50;
	margin-top: 6px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	max-height: min(420px, 72vh);
}

/* Primo blocco = wrapper aggiunto da dropdown_input (input ricerca), sopra .ts-dropdown-content */
.filter-group .input-container .ts-wrapper.plugin-dropdown_input .ts-dropdown > div:first-child {
	flex-shrink: 0;
	position: sticky;
	top: 0;
	z-index: 2;
	background: var(--surface);
	border-bottom: 1px solid var(--border-subtle);
	padding: 10px 12px;
}

.filter-group .input-container .ts-wrapper.plugin-dropdown_input .ts-dropdown input.dropdown-input {
	display: block !important;
	width: 100% !important;
	margin: 0 !important;
	padding: 12px 14px !important;
	min-height: 44px !important;
	box-sizing: border-box;
	border: 1px solid var(--border-subtle) !important;
	border-radius: var(--radius-md) !important;
	background: var(--input-bg) !important;
	color: var(--text-primary) !important;
	font-family: inherit !important;
	font-size: 0.92rem !important;
	font-weight: 500 !important;
	line-height: 1.35 !important;
	box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.12) !important;
}

.filter-group .input-container .ts-wrapper.plugin-dropdown_input .ts-dropdown input.dropdown-input:focus {
	outline: none !important;
	border-color: var(--accent-orange) !important;
	box-shadow:
		0 0 0 3px var(--focus-ring),
		inset 0 1px 2px rgba(0, 0, 0, 0.12) !important;
	background: var(--surface) !important;
}

.filter-group .input-container .ts-wrapper.plugin-dropdown_input .ts-dropdown input.dropdown-input::placeholder {
	color: var(--text-muted);
	font-weight: 400;
}

.filter-group .input-container .ts-dropdown .ts-dropdown-content {
	flex: 1 1 auto;
	min-height: 0;
	max-height: none;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
}

.filter-group .input-container .ts-dropdown .option {
	padding: 14px 16px;
	font-size: 0.95rem;
	font-weight: 500;
}

.filter-group .input-container .ts-dropdown .option.active {
	background: rgba(243, 112, 33, 0.12);
	color: var(--primary-blue);
}

.filter-group .input-container .ts-dropdown .option:hover,
.filter-group .input-container .ts-dropdown .option.selected {
	background: rgba(0, 51, 102, 0.06);
}

.filter-group .input-container .country-ts-row {
	display: flex;
	align-items: center;
	gap: 10px;
	min-width: 0;
}

.filter-group .input-container .country-ts-row__fi.fi {
	flex-shrink: 0;
	line-height: 1;
}

.filter-group .input-container .country-ts-row__name {
	min-width: 0;
}

.filter-group .input-container select.ts-hidden {
	position: absolute !important;
	left: -9999px !important;
	width: 1px !important;
	height: 1px !important;
	opacity: 0 !important;
	pointer-events: none !important;
}

.filter-group .input-container .continent-select-icon {
	display: flex;
	align-items: center;
	justify-content: center;
}

/* Stato “nessuna selezione”: stesso tono del placeholder Tom Select */
.filter-group .input-container .country-ts-row--default .country-ts-row__name,
.filter-group .input-container .continent-ts-row--default .continent-ts-row__name {
	color: var(--text-muted);
	font-weight: 500;
}

/* Righe Tom Select continente (icona + etichetta) */
.filter-group .input-container .ts-wrapper .continent-ts-row {
	display: flex;
	align-items: center;
	gap: 10px;
	min-width: 0;
}

.filter-group .input-container .ts-wrapper .continent-ts-row__glyph {
	flex-shrink: 0;
	width: 1.15em;
	height: 1.15em;
	object-fit: contain;
	display: block;
}

.filter-group .input-container .ts-wrapper .continent-ts-row__glyph.fas {
	width: auto;
	height: auto;
	font-size: 1.05rem;
	line-height: 1;
}

.filter-group .input-container .ts-wrapper .continent-ts-row__name {
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

/* Item selezionato nel controllo: una sola icona (a sinistra fuori da Tom Select); l’item deve poter restringersi in flex */
.filter-group .input-container:has(#continent-filter) .ts-wrapper.single.has-items .ts-control > .item {
	flex: 1 1 auto;
	min-width: 0;
	max-width: 100%;
}

.filter-group .input-container:has(#continent-filter) .ts-wrapper.single.has-items .ts-control .continent-ts-row--control {
	flex: 1 1 auto;
	min-width: 0;
	width: 100%;
}

.filter-group .input-container .ts-dropdown .continent-ts-row {
	display: flex;
	align-items: center;
	gap: 10px;
	min-width: 0;
}

.filter-group .input-container .ts-dropdown .continent-ts-row__glyph.fas {
	font-size: 1rem;
	flex-shrink: 0;
}

/* Continente senza plugin dropdown_input: controllo cliccabile come select */
.filter-group .input-container:has(#continent-filter) .ts-wrapper:not(.plugin-dropdown_input) .ts-control {
	cursor: pointer;
}

/*
 * Continente: senza selezione il placeholder è sull’input; con .has-items Tom Select usa .input-hidden (non sovrascrivere).
 */
.filter-group .input-container:has(#continent-filter) .ts-wrapper:not(.has-items) .ts-control > input {
	flex: 1 1 auto !important;
	min-width: 0 !important;
	max-width: 100% !important;
	position: relative !important;
	left: auto !important;
	width: auto !important;
	height: auto !important;
	margin: 0 !important;
	padding: 0 !important;
	opacity: 1 !important;
	overflow: visible !important;
	clip: auto !important;
	clip-path: none !important;
	border: 0 !important;
	background: transparent !important;
	box-shadow: none !important;
	font-size: 0.95rem !important;
	font-weight: 500 !important;
	color: var(--text-muted) !important;
	cursor: pointer !important;
	pointer-events: auto !important;
	caret-color: transparent !important;
}

.filter-group .input-container:has(#continent-filter) .ts-wrapper:not(.has-items) .ts-control > input::placeholder {
	color: var(--text-muted) !important;
	opacity: 1 !important;
}

/* Focus aperto: Tom Select imposta bordi di default sul controllo; resta allineato al tema */
.filter-group .input-container .ts-wrapper.plugin-dropdown_input.focus.dropdown-active .ts-control {
	border-color: var(--accent-orange);
	box-shadow:
		0 0 0 3px var(--focus-ring),
		inset 0 1px 2px rgba(0, 0, 0, 0.15);
}
