/**
 * Archivio CPT Immobili Pubblici (pvip_immobile).
 * Stile ispirato a Gestione Affiti e Vendite.
 *
 * @package Immobili_Pubblici
 */

.pvip-archive-immobili {
	--pvip-archive-max: 1200px;
	--pvip-archive-color: #1a1a2e;
	--pvip-archive-color-light: #4a4a6a;
	--pvip-archive-border: #e2e8f0;
	--pvip-archive-accent: #0d9488;
	--pvip-archive-accent-hover: #0f766e;
	max-width: 100%;
	margin: 0;
	padding: 0 0 3rem;
	box-sizing: border-box;
}

.pvip-archive-header {
	padding: 2rem 1rem 1.5rem;
	border-bottom: 1px solid var(--pvip-archive-border);
	margin-bottom: 2rem;
}

.pvip-archive-header__inner {
	max-width: var(--pvip-archive-max);
	margin: 0 auto;
}

.pvip-archive-title {
	margin: 0 0 0.5rem;
	font-size: clamp(1.5rem, 4vw, 2rem);
	font-weight: 700;
	color: var(--pvip-archive-color);
}

.pvip-archive-description {
	margin: 0;
	font-size: 1rem;
	color: var(--pvip-archive-color-light);
	line-height: 1.5;
}

.pvip-archive__inner {
	max-width: var(--pvip-archive-max);
	margin: 0 auto;
	padding-left: 1rem;
	padding-right: 1rem;
	box-sizing: border-box;
}

/* Barra ricerca - Stile moderno */
.pvip-archive-search-bar {
	margin-bottom: 2rem;
	padding: 1.5rem;
	background: white;
	border: 1px solid var(--pvip-archive-border);
	border-radius: 12px;
	box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04);
}

.pvip-archive-search-bar__form {
	display: grid;
	grid-template-columns: 2fr 1.5fr 1.5fr auto;
	gap: 0.75rem;
	align-items: center;
}

.pvip-archive-filter-group {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

.pvip-archive-search-bar__input,
.pvip-archive-filter-select {
	width: 100%;
	min-height: 48px;
	padding: 0.75rem 1.25rem;
	border: 2px solid var(--pvip-archive-border);
	border-radius: 8px !important;
	font-size: 1rem;
	transition: all 0.2s;
	background: #fafbfc;
	font-family: inherit;
}

.pvip-archive-filter-select {
	cursor: pointer;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%234a4a6a' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 1rem center;
	background-size: 12px;
	padding-right: 2.5rem;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

.pvip-archive-search-bar__input:focus,
.pvip-archive-filter-select:focus {
	outline: none;
	border-color: var(--pvip-archive-accent);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--pvip-archive-accent) 15%, transparent);
	background-color: white;
}

.pvip-archive-search-bar__input::placeholder {
	color: #9ca3af;
}

.pvip-archive-search-bar__submit {
	min-height: 48px;
	padding: 0.75rem 2rem;
	background: var(--pvip-archive-accent);
	color: #fff;
	border: none;
	border-radius: 8px;
	font-size: 1rem;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.2s;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.pvip-archive-search-bar__submit:hover {
	background: var(--pvip-archive-accent-hover);
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(13, 148, 136, 0.3);
}

.pvip-archive-search-bar__submit:active {
	transform: translateY(0);
}

@media (max-width: 900px) {
	.pvip-archive-search-bar__form {
		grid-template-columns: 1fr 1fr;
	}
	
	.pvip-archive-filter-group:first-child {
		grid-column: 1 / -1;
	}
	
	.pvip-archive-search-bar__submit {
		grid-column: 1 / -1;
	}
}

@media (max-width: 640px) {
	.pvip-archive-search-bar {
		padding: 1rem;
	}
	
	.pvip-archive-search-bar__form {
		grid-template-columns: 1fr;
	}
	
	.pvip-archive-filter-group,
	.pvip-archive-search-bar__input,
	.pvip-archive-filter-select,
	.pvip-archive-search-bar__submit {
		width: 100%;
	}
}

/* Griglia card */
.pvip-archive-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 1.5rem;
	margin: 0 0 2rem;
}

.pvip-card {
	margin: 0;
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
	transition: box-shadow 0.2s ease;
	border: 1px solid var(--pvip-archive-border);
	background: #fff;
}

.pvip-card:hover {
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
}

/* Card classica con nuova struttura (come mappa) */
.pvip-archive-card--classica .pvip-archive-card__inner-classica {
	position: relative;
	display: flex;
	flex-direction: column;
}

.pvip-archive-card--classica .pvip-archive-card__badges {
	position: absolute;
	top: 0.75rem;
	left: 0.75rem;
	z-index: 2;
	margin: 0;
}

.pvip-archive-card--classica .pvip-archive-card__media-classica {
	flex: none;
	width: 100%;
	position: relative;
}

.pvip-archive-card--classica .pvip-archive-card__media-link {
	display: block;
	height: 100%;
}

.pvip-archive-card--classica .pvip-archive-card__image {
	width: 100%;
	height: 100%;
	min-height: 220px;
	aspect-ratio: 16/10;
	background-size: cover;
	background-position: center;
	background-color: #e8e8e8;
}

.pvip-archive-card--classica .pvip-archive-card__content-classica {
	padding: 1rem 1.25rem;
}

.pvip-archive-card--classica .pvip-archive-card__title {
	margin: 0 0 0.35rem !important;
	font-size: 1.2rem !important;
	font-weight: 700 !important;
	line-height: 1.25 !important;
}

.pvip-archive-card--classica .pvip-archive-card__title a {
	color: var(--pvip-archive-color);
	text-decoration: none;
	font-size: inherit !important;
}

.pvip-archive-card--classica .pvip-archive-card__title a:hover {
	text-decoration: underline;
}

.pvip-archive-card--classica .pvip-archive-card__meta {
	margin: 0 0 0.4rem;
	font-size: 0.95rem;
	color: var(--pvip-archive-color-light);
	line-height: 1.4;
}

.pvip-archive-card--classica .pvip-archive-card__excerpt {
	margin: 0 0 0.75rem;
	font-size: 0.9rem;
	line-height: 1.45;
	color: var(--pvip-archive-color-light);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.pvip-archive-card--classica .pvip-archive-card__features {
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem 1.25rem;
	margin: 0 0 0.75rem;
	font-size: 0.85rem;
	color: var(--pvip-archive-color);
}

.pvip-archive-card--classica .pvip-archive-card__actions {
	margin-top: auto;
	margin-left: -1.25rem;
	margin-right: -1.25rem;
	margin-bottom: -1rem;
	padding: 0.75rem 1.25rem;
	border-top: 1px solid var(--pvip-archive-border);
	background: #f8fafc;
}

.pvip-archive-card--classica .pvip-archive-card__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	padding: 0.6rem 1rem;
	font-size: 0.9rem;
	font-weight: 600;
	text-decoration: none;
	border-radius: 8px;
	background: var(--pvip-archive-accent);
	color: #fff;
	border: 1px solid var(--pvip-archive-accent);
	transition: color 0.2s, background 0.2s, border-color 0.2s;
}

.pvip-archive-card--classica .pvip-archive-card__btn:hover {
	background: var(--pvip-archive-accent-hover);
	border-color: var(--pvip-archive-accent-hover);
	color: #fff;
}

.pvip-card-link {
	display: block;
	text-decoration: none;
	color: inherit;
}

.pvip-card-image {
	aspect-ratio: 4/3;
	min-height: 160px;
	background-size: cover;
	background-position: center;
	background-color: #e8e8e8;
}

.pvip-card-image-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(145deg, #e8ecf0 0%, #dde2e8 100%);
	border-bottom: 1px solid var(--pvip-archive-border);
}

.pvip-card-image-placeholder__text {
	font-size: 0.9375rem;
	font-weight: 600;
	color: var(--pvip-archive-color-light);
	text-align: center;
	padding: 1rem;
	line-height: 1.35;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
	max-width: 100%;
}

/* Icona placeholder per immobili senza immagine */
.pvip-archive-icon-placeholder {
	width: 80px;
	height: 80px;
	opacity: 0.25;
	filter: grayscale(100%);
	transition: opacity 0.3s, filter 0.3s;
}

.pvip-card-link:hover .pvip-archive-icon-placeholder,
.pvip-archive-card__media-link:hover .pvip-archive-icon-placeholder {
	opacity: 0.35;
	filter: grayscale(80%);
}

.pvip-card-body {
	padding: 1rem 1.25rem;
}

.pvip-archive-card--classica .pvip-archive-card__badges {
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem;
	margin-bottom: 0.5rem;
}

.pvip-archive-card--classica .pvip-archive-card__badge {
	display: inline-block;
	padding: 0.2rem 0.5rem;
	font-size: 0.7rem;
	font-weight: 600;
	border-radius: 6px;
	line-height: 1.3;
}

.pvip-archive-card--classica .pvip-archive-card__badge--natura {
	background: color-mix(in srgb, var(--pvip-archive-accent) 18%, white);
	color: var(--pvip-archive-accent-hover);
}

.pvip-archive-card--classica .pvip-archive-card__badge--stato {
	background: color-mix(in srgb, var(--pvip-archive-color) 12%, white);
	color: var(--pvip-archive-color);
}

.pvip-card-title {
	margin: 0 0 0.5rem;
	font-size: 1.125rem;
	line-height: 1.3;
	color: var(--pvip-archive-color);
	font-weight: 700;
}

.pvip-card-title a,
.pvip-card-link .pvip-card-title {
	color: inherit;
	text-decoration: none;
}

.pvip-card-link:hover .pvip-card-title {
	color: var(--pvip-archive-accent);
}

.pvip-card-meta,
.pvip-card-location,
.pvip-card-stato {
	margin: 0.25rem 0 0;
	font-size: 0.9rem;
	color: var(--pvip-archive-color-light);
	line-height: 1.35;
}

.pvip-archive-card__features {
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem 1rem;
	margin: 0.75rem 0 0;
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--pvip-archive-color);
}

.pvip-archive-card__feature {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	white-space: nowrap;
}

.pvip-archive-card__actions {
	padding: 0.75rem 1.25rem;
	border-top: 1px solid var(--pvip-archive-border);
	background: #f8fafc;
}

.pvip-archive-card__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	padding: 0.6rem 1rem;
	font-size: 0.9rem;
	font-weight: 600;
	text-decoration: none;
	border-radius: 8px;
	transition: color 0.2s, background 0.2s, border-color 0.2s;
	background: var(--pvip-archive-accent);
	color: #fff;
	border: 1px solid var(--pvip-archive-accent);
}

.pvip-archive-card__btn:hover {
	background: var(--pvip-archive-accent-hover);
	border-color: var(--pvip-archive-accent-hover);
	color: #fff;
}

/* Nessun risultato - Grafica migliorata */
.pvip-no-results-wrap {
	margin: 3rem 0;
	padding: 4rem 2rem;
	text-align: center;
	background: white;
	border: 1px solid var(--pvip-archive-border);
	border-radius: 20px;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
}

.pvip-no-results-icon {
	width: 80px;
	height: 80px;
	margin: 0 auto 1.5rem;
	background: var(--pvip-archive-accent);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
}

.pvip-no-results-icon svg {
	width: 40px;
	height: 40px;
	color: white;
	stroke-width: 2.5;
}

.pvip-no-results__title {
	margin: 0 0 1rem;
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--pvip-archive-color);
	line-height: 1.3;
}

.pvip-no-results__message {
	margin: 0 0 2rem auto;
	font-size: 1rem;
	font-weight: 400;
	color: var(--pvip-archive-color-light);
	line-height: 1.6;
	max-width: 500px;
	margin-left: auto;
	margin-right: auto;
}

.pvip-no-results__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.75rem 1.75rem;
	background: var(--pvip-archive-accent);
	color: white;
	text-decoration: none;
	border-radius: 10px;
	font-size: 0.95rem;
	font-weight: 600;
	transition: all 0.2s;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.pvip-no-results__button:hover {
	background: var(--pvip-archive-accent-hover);
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(13, 148, 136, 0.3);
	color: white;
}

@media (max-width: 640px) {
	.pvip-no-results-wrap {
		padding: 2.5rem 1.5rem;
		margin: 2rem 0;
	}
	
	.pvip-no-results-icon {
		width: 64px;
		height: 64px;
	}
	
	.pvip-no-results-icon svg {
		width: 32px;
		height: 32px;
	}
	
	.pvip-no-results__title {
		font-size: 1.25rem;
	}
	
	.pvip-no-results__message {
		font-size: 0.9375rem;
	}
}

/* Paginazione */
.pvip-archive-pagination {
	margin-top: 2rem;
	padding-top: 2rem;
	border-top: 1px solid var(--pvip-archive-border);
	text-align: center;
}

.pvip-archive-pagination a,
.pvip-archive-pagination span {
	display: inline-block;
	margin: 0 0.25rem;
	padding: 0.4rem 0.75rem;
	font-size: 0.95rem;
	text-decoration: none;
	color: var(--pvip-archive-accent);
	border-radius: 6px;
}

.pvip-archive-pagination a:hover {
	background: color-mix(in srgb, var(--pvip-archive-accent) 10%, white);
	color: var(--pvip-archive-accent-hover);
}

.pvip-archive-pagination .current {
	font-weight: 600;
	color: var(--pvip-archive-color);
}

/* Vista Completa: box di ricerca a tutta larghezza sopra */
.pvip-archive--completa .pvip-archive-search-bar {
	margin-bottom: 2rem;
}

/* Vista Completa: due colonne (lista + mappa) */
.pvip-archive--completa .pvip-archive-completa__wrap {
	display: grid;
	grid-template-columns: 1fr  minmax(320px, 420px);
	gap: 2rem;
	align-items: start;
	max-width: 100%;
}

.pvip-archive--completa .pvip-archive-completa__list {
	min-width: 0;
}

.pvip-archive--completa .pvip-archive-completa__map {
	position: sticky;
	top: 1.5rem;
	height: 600px;
	min-height: 500px;
	background: #e8e8e8;
	border-radius: 12px;
	overflow: hidden;
	border: 1px solid var(--pvip-archive-border);
}

/* Vista Completa: griglia a lista (una card per riga) */
.pvip-archive-grid--completa {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
	grid-template-columns: unset;
}

/* Card "ricca" orizzontale (vista completa – stile GAV: wrapper unico, ombra, badge su immagine) */
.pvip-archive-card--completa {
	display: flex;
	flex-direction: row;
	align-items: stretch;
	flex-wrap: wrap;
	position: relative;
}

.pvip-archive-card--completa .pvip-archive-card__inner {
	position: relative;
	display: flex;
	flex-direction: row;
	align-items: stretch;
	flex: 1 1 auto;
	min-width: 0;
	background: #fff;
	border-radius: 8px;
	overflow: hidden;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
	transition: box-shadow 0.2s ease;
	border: 1px solid var(--pvip-archive-border);
}

.pvip-archive-card--completa:hover .pvip-archive-card__inner {
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
}

/* Badge: in classica dentro il body, in completa sopra l'immagine */
.pvip-archive-card__badges {
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem;
	margin-bottom: 0.5rem;
}

.pvip-archive-card--completa .pvip-archive-card__badges {
	position: absolute;
	top: 0.75rem;
	left: 0.75rem;
	z-index: 2;
	margin: 0;
	margin-bottom: 0;
}

/* Badge come GAV: pill sopra immagine, colori solidi blu/verde, bianco */
.pvip-archive-card__badge {
	display: inline-block;
	padding: 0.25rem 0.6rem;
	border-radius: 4px;
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	line-height: 1.3;
}

.pvip-archive-card__badge--natura {
	background: #0ea5e9;
	color: #fff;
}

.pvip-archive-card__badge--stato {
	background: #10b981;
	color: #fff;
}

/* Colonna sinistra: immagine (42% come GAV) */
.pvip-archive-card__media {
	flex: 0 0 42%;
	min-width: 0;
	position: relative;
}

.pvip-archive-card__media-link {
	display: block;
	height: 100%;
	min-height: 200px;
}

.pvip-archive-card__image {
	width: 100%;
	height: 100%;
	min-height: 200px;
	aspect-ratio: 4/3;
	background-size: cover;
	background-position: center;
	background-color: #e8e8e8;
}

.pvip-archive-card__media .pvip-card-image-placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	background: #e8e8e8;
}

.pvip-archive-card__media .pvip-card-image-placeholder__text {
	font-size: 0.875rem;
	font-weight: 600;
	color: var(--pvip-archive-color-light);
	text-align: center;
	padding: 0.75rem;
	line-height: 1.35;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* Colonna destra: contenuto */
.pvip-archive-card__content {
	flex: 1;
	min-width: 0;
	padding: 1.25rem 1.5rem;
	display: flex;
	flex-direction: column;
	position: relative;
	color: var(--pvip-archive-color);
}

.pvip-archive-card__title {
	margin: 0 0 0.35rem;
	font-size: 1.35rem;
	font-weight: 700;
	line-height: 1.25;
	color: var(--pvip-archive-color);
}

.pvip-archive-card__title a {
	color: var(--pvip-archive-color);
	text-decoration: none;
}

.pvip-archive-card__title a:hover {
	text-decoration: underline;
}

.pvip-archive-card__meta {
	margin: 0 0 0.4rem;
	font-size: 0.95rem;
	color: var(--pvip-archive-color-light);
	line-height: 1.4;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	overflow: hidden;
	-webkit-line-clamp: 2;
}

.pvip-archive-card__excerpt {
	margin: 0 0 0.75rem;
	font-size: 0.9rem;
	line-height: 1.45;
	color: var(--pvip-archive-color-light);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	flex: 1;
	min-height: 0;
}

/* Riga caratteristiche con icone (come GAV) */
.pvip-archive-card__features {
	display: flex;
	flex-wrap: wrap;
	gap: 0.6rem 1.25rem;
	margin: 0 0 0.75rem;
	font-size: 0.85rem;
	color: var(--pvip-archive-color);
}

.pvip-archive-card__feature {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	white-space: nowrap;
}

.pvip-archive-card__feature-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 18px;
	height: 18px;
	flex-shrink: 0;
}

.pvip-archive-card__feature-icon svg {
	width: 100%;
	height: 100%;
	fill: currentColor;
	opacity: 0.75;
}

/* Pulsanti: stessa fascia e grandezza della vista classica (sfondo grigio, pulsante full width) */
.pvip-archive-card__content .pvip-archive-card__actions {
	margin-top: auto;
	margin-left: -1.5rem;
	margin-right: -1.5rem;
	margin-bottom: -1.25rem;
	padding: 0.75rem 1.25rem;
	border-top: 1px solid var(--pvip-archive-border);
	background: #f8fafc;
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
}

/* Pulsante "Vedi scheda": stesso ingombro della classica (full width, padding uniforme), stile outlined */
.pvip-archive-card__content .pvip-archive-card__btn--visit {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	padding: 0.6rem 1rem;
	font-size: 0.9rem;
	font-weight: 600;
	text-decoration: none;
	border-radius: 8px;
	background: #fff;
	color: var(--pvip-archive-accent);
	border: 1px solid color-mix(in srgb, var(--pvip-archive-accent) 35%, transparent);
	transition: color 0.2s, background 0.2s, border-color 0.2s;
}

.pvip-archive-card__content .pvip-archive-card__btn--visit:hover {
	background: color-mix(in srgb, var(--pvip-archive-accent) 8%, white);
	color: var(--pvip-archive-accent-hover);
	border-color: color-mix(in srgb, var(--pvip-archive-accent) 55%, transparent);
}

/* Logo comune a destra della card (opzionale) */
.pvip-archive-card__comune-logo {
	flex-shrink: 0;
	align-self: center;
	padding: 0 1rem;
	border-left: 1px solid var(--pvip-archive-border);
}

.pvip-archive-card__comune-logo img {
	display: block;
	max-width: 56px;
	max-height: 56px;
	width: auto;
	height: auto;
	object-fit: contain;
}

@media (max-width: 700px) {
	.pvip-archive-card--completa .pvip-archive-card__inner {
		flex-direction: column;
	}

	.pvip-archive-card__media {
		flex: none;
		width: 100%;
	}

	.pvip-archive-card__media-link {
		min-height: 0;
	}

	.pvip-archive-card__image {
		min-height: 220px;
		aspect-ratio: 16/10;
	}

	.pvip-archive-card__content {
		padding: 1rem 1.25rem;
	}

	.pvip-archive-card__content .pvip-archive-card__actions {
		margin-left: -1.25rem;
		margin-right: -1.25rem;
		margin-bottom: -1rem;
		padding: 0.75rem 1.25rem;
	}

	.pvip-archive-card__title {
		font-size: 1.2rem;
	}

	.pvip-archive-card--completa .pvip-archive-card__comune-logo {
		border-left: none;
		border-top: 1px solid var(--pvip-archive-border);
		padding: 0.5rem 1rem;
	}
}

@media (max-width: 900px) {
	.pvip-archive--completa .pvip-archive-completa__wrap {
		grid-template-columns: 1fr;
	}

	.pvip-archive--completa .pvip-archive-completa__map {
		position: relative;
		top: 0;
		height: 400px;
		order: -1;
	}
}

/* ===================================
   LEAFLET MARKER CLUSTER - Stile personalizzato
   =================================== */
.marker-cluster-small,
.marker-cluster-medium,
.marker-cluster-large {
	background-color: rgba(13, 148, 136, 0.6);
}

.marker-cluster-small div,
.marker-cluster-medium div,
.marker-cluster-large div {
	background-color: var(--pvip-archive-accent);
	width: 40px;
	height: 40px;
	margin-left: 0;
	margin-top: 0;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
}

.marker-cluster div span {
	color: white;
	font-size: 14px;
	font-weight: 700;
	line-height: 1;
}

/* Animazione hover sui cluster */
.marker-cluster {
	cursor: pointer;
	transition: transform 0.2s;
}

.marker-cluster:hover {
	transform: scale(1.1);
}

/* Stili per dimensioni diverse */
.marker-cluster-small div {
	width: 36px;
	height: 36px;
}

.marker-cluster-medium div {
	width: 42px;
	height: 42px;
}

.marker-cluster-large div {
	width: 48px;
	height: 48px;
	box-shadow: 0 3px 12px rgba(0, 0, 0, 0.25);
}

.marker-cluster-large div span {
	font-size: 16px;
}

/* Responsive */
@media (max-width: 640px) {
	.pvip-archive-grid {
		grid-template-columns: 1fr;
		gap: 1.25rem;
		margin-bottom: 1.5rem;
	}

	.pvip-archive__inner {
		padding-left: 0.75rem;
		padding-right: 0.75rem;
	}
}
