/* ============================================================
 * mappa.css — Atlas ER — Mappa gestionale (admin/delegato/fiduciario)
 * Task MAP-RESTYLE (2026-04-22)
 *
 * File centralizzato: carica su admin.html, delegato.html, fiduciario.html.
 * Edit qui = propagato automaticamente alle 3 pagine ruolo.
 *
 * Linguaggio: allineato alla landing (Source Serif 4 per display,
 * Inter per UI, palette cream + blu CONI, easing ease-out-expo,
 * card bianco con shadow soft, pill buttons).
 *
 * Cascata JS: map.js / map-popup.js / map-cluster.js (già condivisi).
 * ============================================================ */

/* --- Token locali (allineati a landing.css) ------------------ */
:root {
  --mappa-cream:        #FAF8F4;
  --mappa-cream-2:      #F1ECE3;
  --mappa-ink:          #1A1A1A;
  --mappa-muted:        #6B6B6B;
  --mappa-hair:         rgba(14,17,23,.08);
  --mappa-hair-strong:  rgba(14,17,23,.16);
  --mappa-blu:          #003893;
  --mappa-blu-hi:       #1A4FA6;
  --mappa-blu-lo:       #00286B;
  --mappa-blu-soft:     rgba(0,56,147,.08);
  --mappa-easing:       cubic-bezier(.16,1,.3,1);
  /* NB: il gestionale è GDPR-compliant con Inter self-hosted (LEGAL-1).
   * No Google Fonts CDN → Source Serif 4 non disponibile qui.
   * Simuliamo il tono editoriale con Inter 600 + tracking negativo. */
  --mappa-display:      'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --mappa-sans:         'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --mappa-radius:       14px;
  --mappa-radius-sm:    10px;
  --mappa-shadow:       0 10px 30px -12px rgba(14,17,23,.18), 0 2px 6px -2px rgba(14,17,23,.08);
  --mappa-shadow-sm:    0 4px 12px -4px rgba(14,17,23,.14);
}

/* ============================================================
 * 1. CONTAINER TAB MAPPA
 * ============================================================ */
.admin-mappa-tab {
  margin: calc(-1 * var(--space-8));
  height: calc(100vh - var(--header-height));
  position: relative;
  overflow: hidden;
  background: var(--mappa-cream);
  font-family: var(--mappa-sans);
}

@media (max-width: 768px) {
  .admin-mappa-tab {
    margin: calc(-1 * var(--space-4));
  }
}

/* Canvas MapLibre: eredita family per label symbol (nessun effetto, paint layer a parte) */
.admin-mappa-tab .maplibregl-canvas-container { background: var(--mappa-cream); }

/* ============================================================
 * 2. LOADING STATE
 * ============================================================ */
.admin-mappa-loading {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--mappa-cream);
  z-index: 5;
  font-family: var(--mappa-sans);
  font-size: 14px;
  font-weight: 500;
  color: var(--mappa-muted);
  gap: 10px;
  letter-spacing: .01em;
  animation: mappa-loading-pulse 1.6s ease-in-out infinite;
}
.admin-mappa-loading svg {
  color: var(--mappa-blu);
  opacity: .75;
}
@keyframes mappa-loading-pulse {
  0%, 100% { opacity: .85; }
  50%      { opacity: .45; }
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ============================================================
 * 3. CONTROLS BAR (top-right) — pill toggles
 * ============================================================ */
.admin-mappa-controls {
  position: absolute;
  top: 20px;
  right: 20px;
  z-index: 10;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
  max-width: calc(100% - 40px);
}

/* Pill buttons — sostituiscono .btn.btn-sm per i controlli mappa */
.admin-mappa-controls .btn,
.admin-mappa-controls .btn.btn-sm {
  font-family: var(--mappa-sans);
  font-size: 13px;
  font-weight: 500;
  line-height: 1;
  letter-spacing: .01em;
  padding: 9px 16px;
  border-radius: 999px;
  border: 1px solid var(--mappa-hair-strong);
  background: rgba(255,255,255,.92);
  color: var(--mappa-ink);
  backdrop-filter: saturate(140%) blur(8px);
  -webkit-backdrop-filter: saturate(140%) blur(8px);
  box-shadow: var(--mappa-shadow-sm);
  transition: all .22s var(--mappa-easing);
  white-space: nowrap;
  cursor: pointer;
}
.admin-mappa-controls .btn:hover {
  border-color: var(--mappa-blu);
  color: var(--mappa-blu);
  transform: translateY(-1px);
}
.admin-mappa-controls .btn.btn-primary,
.admin-mappa-controls .btn.btn-sm.btn-primary {
  background: var(--mappa-blu);
  color: #fff;
  border-color: var(--mappa-blu);
}
.admin-mappa-controls .btn.btn-primary:hover {
  background: var(--mappa-blu-lo);
  border-color: var(--mappa-blu-lo);
  color: #fff;
}
.admin-mappa-controls .btn.btn-secondary,
.admin-mappa-controls .btn.btn-sm.btn-secondary {
  background: rgba(255,255,255,.92);
  color: var(--mappa-ink);
  border-color: var(--mappa-hair-strong);
}

/* Contatore impianti (filtri attivi) */
.admin-mappa-controls > div {
  font-family: var(--mappa-sans) !important;
  font-size: 12px !important;
  color: var(--mappa-muted) !important;
  background: rgba(255,255,255,.92);
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--mappa-hair);
  box-shadow: var(--mappa-shadow-sm);
}

/* ============================================================
 * 4. PANNELLI CARD (filtri, sidebar provincia, stats)
 *    Stile landing: bianco, radius 14, shadow soft
 * ============================================================ */
.mappa-pannello-filtri,
.mappa-pannello-stats {
  position: absolute;
  z-index: 10;
  background: #fff;
  border: 1px solid var(--mappa-hair);
  border-radius: var(--mappa-radius);
  padding: 22px 22px 20px;
  box-shadow: var(--mappa-shadow);
  font-family: var(--mappa-sans);
  color: var(--mappa-ink);
}

.mappa-pannello-filtri {
  top: 20px;
  left: 20px;
  width: 300px;
  max-height: calc(100% - 40px);
  overflow-y: auto;
}

.mappa-pannello-stats {
  bottom: 20px;
  right: 20px;
  width: 320px;
  max-height: 60vh;
  overflow-y: auto;
}

/* Header dei pannelli: titolo serif + close pill */
.mappa-pannello-filtri > div:first-child strong,
.mappa-pannello-stats > div:first-child strong {
  font-family: var(--mappa-display) !important;
  font-size: 17px !important;
  font-weight: 600;
  letter-spacing: -.01em;
  color: var(--mappa-ink);
}

/* Close button nei pannelli: pill minimale */
.mappa-pannello-filtri .btn.btn-sm.btn-secondary,
.mappa-pannello-stats .btn.btn-sm.btn-secondary {
  width: 28px;
  height: 28px;
  padding: 0 !important;
  border-radius: 999px;
  border: 1px solid var(--mappa-hair);
  background: #fff;
  color: var(--mappa-muted);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  line-height: 1;
}
.mappa-pannello-filtri .btn.btn-sm.btn-secondary:hover,
.mappa-pannello-stats .btn.btn-sm.btn-secondary:hover {
  border-color: var(--mappa-blu);
  color: var(--mappa-blu);
}

/* Label sezione nei pannelli (kicker) */
.pannello-section-label {
  font-family: var(--mappa-sans);
  font-size: 11px;
  font-weight: 600;
  color: var(--mappa-muted);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 8px;
}

/* Chip filtri tipologia/proprietà/gestione/parere */
.mappa-pannello-filtri .btn.btn-sm {
  font-family: var(--mappa-sans);
  font-size: 12px;
  font-weight: 500;
  line-height: 1;
  padding: 7px 12px;
  border-radius: 999px;
  border: 1px solid var(--mappa-hair-strong);
  background: var(--mappa-cream);
  color: var(--mappa-ink);
  transition: all .2s var(--mappa-easing);
}
.mappa-pannello-filtri .btn.btn-sm:hover {
  border-color: var(--mappa-blu);
  color: var(--mappa-blu);
}
.mappa-pannello-filtri .btn.btn-sm.btn-primary {
  background: var(--mappa-blu);
  color: #fff;
  border-color: var(--mappa-blu);
}
.mappa-pannello-filtri .btn.btn-sm.btn-primary:hover {
  background: var(--mappa-blu-lo);
  border-color: var(--mappa-blu-lo);
}

/* ============================================================
 * 4-bis. SIDEBAR ENTITÀ (provincia / comune) — BLOCCO 7.3/7.4
 *        Card ricca con hero blu, metric, barre tipologia, chip.
 * ============================================================ */
.mappa-sidebar-entita {
  position: absolute;
  bottom: 20px;
  left: 20px;
  z-index: 10;
  width: 320px;
  max-height: calc(100% - 80px);
  background: #fff;
  border: 1px solid var(--mappa-hair);
  border-radius: var(--mappa-radius);
  box-shadow: var(--mappa-shadow);
  font-family: var(--mappa-sans);
  color: var(--mappa-ink);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

/* Hero blu */
.mappa-sidebar-entita .msb-hero {
  background: var(--mappa-blu);
  color: #fff;
  padding: 16px 20px 18px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.mappa-sidebar-entita .msb-hero-testo { flex: 1; min-width: 0; }
.mappa-sidebar-entita .msb-kicker {
  font-size: 10.5px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .08em;
  opacity: .8;
  margin-bottom: 4px;
}
.mappa-sidebar-entita .msb-nome {
  font-family: var(--mappa-display);
  font-size: 22px;
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: -.015em;
  color: #fff;
  word-break: break-word;
}
.mappa-sidebar-entita .msb-sigla {
  font-size: 12px;
  font-weight: 500;
  opacity: .8;
  margin-top: 4px;
  letter-spacing: .02em;
}
.mappa-sidebar-entita .msb-close {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.3);
  background: rgba(255,255,255,.1);
  color: #fff;
  font-size: 13px;
  line-height: 1;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all .2s var(--mappa-easing);
}
.mappa-sidebar-entita .msb-close:hover {
  background: rgba(255,255,255,.2);
  border-color: rgba(255,255,255,.5);
}

/* Body scrollabile */
.mappa-sidebar-entita .msb-body {
  padding: 18px 20px 18px;
  overflow-y: auto;
}

/* Metric count */
.mappa-sidebar-entita .msb-metric {
  margin-bottom: 18px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--mappa-hair);
}
.mappa-sidebar-entita .msb-metric-valore {
  font-family: var(--mappa-display);
  font-size: 2.4rem;
  font-weight: 600;
  line-height: 1;
  letter-spacing: -.035em;
  color: var(--mappa-blu);
  font-variant-numeric: tabular-nums;
}
.mappa-sidebar-entita .msb-metric-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--mappa-muted);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-top: 4px;
}

/* Section con label */
.mappa-sidebar-entita .msb-section { margin-bottom: 16px; }
.mappa-sidebar-entita .msb-section:last-child { margin-bottom: 0; }

/* Barre tipologia */
.mappa-sidebar-entita .msb-bars {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.mappa-sidebar-entita .msb-bar-row { display: block; }
.mappa-sidebar-entita .msb-bar-label {
  display: flex;
  justify-content: space-between;
  font-size: 12.5px;
  margin-bottom: 4px;
  gap: 10px;
}
.mappa-sidebar-entita .msb-bar-label > span:first-child {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.mappa-sidebar-entita .msb-bar-n {
  color: var(--mappa-muted);
  font-variant-numeric: tabular-nums;
  font-weight: 500;
  flex-shrink: 0;
}
.mappa-sidebar-entita .msb-bar-track {
  height: 4px;
  background: var(--mappa-cream-2);
  border-radius: 999px;
  overflow: hidden;
}
.mappa-sidebar-entita .msb-bar-fill {
  height: 100%;
  background: var(--mappa-blu);
  border-radius: 999px;
  transition: width .5s var(--mappa-easing);
}
.mappa-sidebar-entita .msb-bar-fill-soft {
  background: linear-gradient(90deg, var(--mappa-blu-lo, #5b7ab8), var(--mappa-blu));
  opacity: .75;
}

/* Chip proprietà */
.mappa-sidebar-entita .msb-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.mappa-sidebar-entita .msb-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px 5px 11px;
  border-radius: 999px;
  background: var(--mappa-blu-soft);
  color: var(--mappa-blu);
  font-size: 12px;
  font-weight: 500;
  border: 1px solid rgba(0,56,147,.15);
  line-height: 1.2;
}
.mappa-sidebar-entita .msb-chip-n {
  background: var(--mappa-blu);
  color: #fff;
  font-size: 10.5px;
  font-weight: 600;
  padding: 2px 7px;
  border-radius: 999px;
  font-variant-numeric: tabular-nums;
  min-width: 18px;
  text-align: center;
}

/* Referente */
.mappa-sidebar-entita .msb-referente {
  font-size: 13.5px;
  font-weight: 500;
  color: var(--mappa-ink);
}
.mappa-sidebar-entita .msb-referente-box { line-height: 1.4; }
.mappa-sidebar-entita .msb-referente-meta {
  font-size: 12px;
  color: var(--mappa-muted);
  margin-top: 1px;
}
.mappa-sidebar-entita .msb-referente-vuoto {
  color: var(--mappa-muted);
  font-weight: 400;
  font-style: italic;
}

/* Zoom button */
.mappa-sidebar-entita .msb-zoom-btn {
  width: 100%;
  margin-top: 6px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid var(--mappa-blu);
  background: transparent;
  color: var(--mappa-blu);
  font-family: var(--mappa-sans);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: all .2s var(--mappa-easing);
}
.mappa-sidebar-entita .msb-zoom-btn:hover {
  background: var(--mappa-blu);
  color: #fff;
}
.mappa-sidebar-entita .msb-zoom-icon {
  font-weight: 400;
  transition: transform .2s var(--mappa-easing);
}
.mappa-sidebar-entita .msb-zoom-btn:hover .msb-zoom-icon {
  transform: translateX(2px);
}

/* ============================================================
 * 5. BREADCRUMB (overlay bottom-left sopra mappa)
 * ============================================================ */
.mappa-breadcrumb {
  position: absolute;
  bottom: 20px;
  left: 20px;
  z-index: 9;
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,.92);
  backdrop-filter: saturate(140%) blur(8px);
  -webkit-backdrop-filter: saturate(140%) blur(8px);
  padding: 9px 16px;
  border-radius: 999px;
  border: 1px solid var(--mappa-hair);
  box-shadow: var(--mappa-shadow-sm);
  font-family: var(--mappa-sans);
  font-size: 13px;
  font-weight: 500;
  color: var(--mappa-ink);
  max-width: calc(100% - 40px);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.mappa-breadcrumb .bc-item {
  background: none;
  border: 0;
  padding: 0;
  font: inherit;
  color: inherit;
  cursor: pointer;
  transition: color .2s var(--mappa-easing);
}
.mappa-breadcrumb .bc-item:hover { color: var(--mappa-blu); }
.mappa-breadcrumb .bc-item.is-current {
  color: var(--mappa-blu);
  cursor: default;
  font-weight: 600;
}
.mappa-breadcrumb .bc-sep {
  color: var(--mappa-muted);
  font-weight: 400;
}

/* Se la sidebar provincia è aperta (bottom-left), il breadcrumb si sposta a destra della sidebar */
.admin-mappa-tab:has(.mappa-sidebar-entita:not([style*="display: none"]):not([hidden])) .mappa-breadcrumb {
  left: calc(300px + 40px);
}

/* ============================================================
 * 6. POPUP IMPIANTO (editoriale)
 *    Classe base maplibregl-popup, content = .maplibregl-popup-content
 * ============================================================ */
.admin-mappa-tab .maplibregl-popup-content {
  font-family: var(--mappa-sans);
  padding: 0;
  border-radius: var(--mappa-radius);
  border: 1px solid var(--mappa-hair);
  box-shadow: var(--mappa-shadow);
  overflow: hidden;
  min-width: 260px;
}

.admin-mappa-tab .maplibregl-popup-close-button {
  font-size: 18px;
  color: #fff;
  padding: 2px 10px 4px;
  right: 4px;
  top: 4px;
  border-radius: 999px;
  line-height: 1;
  opacity: .85;
}
.admin-mappa-tab .maplibregl-popup-close-button:hover {
  background: rgba(255,255,255,.2);
  color: #fff;
  opacity: 1;
}

.admin-mappa-tab .maplibregl-popup-tip { border-top-color: #fff; }

/* Layout interno popup (sarà popolato da map-popup.js con queste classi) */
.mappa-popup-header {
  background: var(--mappa-blu);
  color: #fff;
  padding: 14px 18px 12px;
}
.mappa-popup-header h3 {
  font-family: var(--mappa-display);
  font-size: 17px;
  font-weight: 600;
  letter-spacing: -.015em;
  line-height: 1.25;
  margin: 0;
  padding-right: 24px; /* spazio per close */
  color: #fff;
}
.mappa-popup-meta {
  font-family: var(--mappa-sans);
  font-size: 11px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: .08em;
  opacity: .85;
  margin-top: 6px;
  color: rgba(255,255,255,.9);
}

.mappa-popup-body {
  padding: 14px 18px 16px;
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--mappa-ink);
}
.mappa-popup-body .mappa-popup-section {
  padding: 10px 0;
  border-top: 1px solid var(--mappa-hair);
}
.mappa-popup-body .mappa-popup-section:first-child { padding-top: 0; border-top: 0; }
.mappa-popup-body .mappa-popup-section-label {
  font-size: 10.5px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--mappa-muted);
  margin-bottom: 5px;
}
.mappa-popup-body .mappa-popup-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 3px 0;
}
.mappa-popup-body .mappa-popup-row > span:last-child {
  color: var(--mappa-muted);
  text-align: right;
}

.mappa-popup-body .mappa-popup-spazio {
  padding: 6px 0;
  border-bottom: 1px solid var(--mappa-hair);
}
.mappa-popup-body .mappa-popup-spazio:last-child { border-bottom: 0; }
.mappa-popup-body .mappa-popup-spazio-nome {
  font-weight: 600;
  color: var(--mappa-ink);
}
.mappa-popup-body .mappa-popup-spazio-meta {
  font-size: 12px;
  color: var(--mappa-muted);
  font-style: normal;
}
.mappa-popup-body .mappa-popup-spazio-discipline {
  font-size: 12px;
  color: var(--mappa-muted);
  margin-top: 2px;
}

/* Badge modifica in popup */
.mappa-popup-badge {
  display: inline-block;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: 4px 10px;
  border-radius: 999px;
  margin-top: 6px;
}
.mappa-popup-badge.is-propria {
  background: #FFF4CC;
  color: #8A6D00;
}
.mappa-popup-badge.is-altrui {
  background: #E6F0FF;
  color: var(--mappa-blu-lo);
}

/* Bottoni azione popup */
.mappa-popup-actions {
  display: flex;
  gap: 8px;
  padding: 12px 18px 14px;
  background: var(--mappa-cream);
  border-top: 1px solid var(--mappa-hair);
}
.mappa-popup-actions .popup-btn-modifica {
  flex: 1;
  font-family: var(--mappa-sans);
  font-size: 13px;
  font-weight: 600;
  padding: 9px 14px;
  border-radius: 999px;
  border: 1px solid var(--mappa-blu);
  background: var(--mappa-blu);
  color: #fff;
  cursor: pointer;
  transition: all .2s var(--mappa-easing);
}
.mappa-popup-actions .popup-btn-modifica:hover {
  background: var(--mappa-blu-lo);
  border-color: var(--mappa-blu-lo);
}

/* Toggle "Mostra altro" / "Nascondi" */
.mappa-popup-body .popup-toggle-extra {
  font-family: var(--mappa-sans);
  font-size: 12px;
  font-weight: 600;
  color: var(--mappa-blu);
  background: none;
  border: 0;
  padding: 6px 0;
  cursor: pointer;
}
.mappa-popup-body .popup-toggle-extra:hover { text-decoration: underline; }

/* Popup base (loading) */
.mappa-popup-body .popup-loading {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 0;
  color: var(--mappa-muted);
  font-size: 13px;
}
.mappa-popup-body .popup-spinner {
  width: 14px;
  height: 14px;
  border: 2px solid var(--mappa-hair);
  border-top-color: var(--mappa-blu);
  border-radius: 50%;
  animation: spin .8s linear infinite;
}

.mappa-popup-header-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
}

/* ============================================================
 * 7. CLUSTER NATIVO (rendering layer — nessun HTML marker)
 *    I cluster sono circle+symbol layers MapLibre.
 *    Questo blocco è solo placeholder commentato: la paint
 *    è definita in map-layers.js.
 * ============================================================ */
/* Nessuna regola CSS: cluster sono layer MapLibre GPU. */

/* ============================================================
 * 8. RESPONSIVE MOBILE
 * ============================================================ */
@media (max-width: 768px) {
  .admin-mappa-controls {
    top: 12px;
    right: 12px;
    gap: 6px;
    max-width: calc(100% - 24px);
  }
  .admin-mappa-controls .btn,
  .admin-mappa-controls .btn.btn-sm {
    font-size: 12px;
    padding: 7px 12px;
  }
  .mappa-pannello-filtri {
    top: 12px;
    left: 12px;
    right: 12px;
    width: auto;
    max-width: calc(100% - 24px);
    max-height: 50vh;
  }
  .mappa-sidebar-entita {
    bottom: 12px;
    left: 12px;
    right: 12px;
    width: auto;
    max-width: calc(100% - 24px);
  }
  .mappa-pannello-stats {
    bottom: 12px;
    left: 12px;
    right: 12px;
    width: auto;
    max-width: calc(100% - 24px);
  }
  .mappa-breadcrumb {
    bottom: auto;
    top: calc(12px + 40px + 8px); /* sotto la controls bar */
    left: 12px;
    font-size: 12px;
    padding: 7px 14px;
  }
  .admin-mappa-tab:has(.mappa-sidebar-entita:not([style*="display: none"]):not([hidden])) .mappa-breadcrumb {
    left: 12px; /* reset su mobile: pannelli full-width */
  }
}

/* ============================================================================
 * #43 ATLANTE-PORT — Label hover prov/com (pill blu CONI).
 * Pattern identico a mappa-full.html (mappa pubblica), portato sulle mappe
 * gestionale (admin/delegato/fiduciario/srs). Overlay assoluto nel container
 * MapLibre, pointer-events:none così non intercetta interazioni mappa.
 * ============================================================================ */
.atlante-hover-label {
  position: absolute;
  z-index: 11;
  pointer-events: none;
  background: #003893;
  color: #ffffff;
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.01em;
  padding: 5px 12px;
  border-radius: 999px;
  box-shadow: 0 2px 8px rgba(0, 56, 147, 0.25);
  white-space: nowrap;
  transform: translateY(-100%);
  transition: opacity 0.12s ease;
}

@media (max-width: 768px) {
  .atlante-hover-label { font-size: 12px; padding: 4px 10px; }
}
