:root {
  --bg: #ffffff;
  --bg2: #f5f5f5;
  --card: #ffffff;
  --border: #53006c;
  --border-light: #d0bada;
  --text: #53006c;
  --muted: #7a3a8a;
  --accent: #53006c;
  --accent-dark: #35004a;
  --radius: 0px;
  --font: 'Inter', sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; border-radius: 0 !important; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font);
  font-size: 13px;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

/* ─── HEADER ─── */
header {
  padding: 0 32px;
  height: 52px;
  display: flex;
  align-items: center;
  gap: 16px;
  border-bottom: 2px solid var(--border);
  background: var(--bg);
  position: sticky;
  top: 0;
  z-index: 1000;
}

.logo {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text);
}

.logo span {
  font-size: 10px;
  font-weight: 400;
  color: var(--muted);
  display: block;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

header .spacer { flex: 1; }

.badge {
  background: var(--bg);
  border: 1px solid var(--border);
  padding: 4px 12px;
  font-size: 11px;
  color: var(--muted);
  font-weight: 500;
  letter-spacing: 0.05em;
}

/* ─── LAYOUT ─── */
.app-body {
  flex: 1;
  display: grid;
  grid-template-columns: 300px 1fr;
  align-items: stretch;
  min-height: 0;
}

/* ─── SIDEBAR ─── */
.sidebar {
  background: var(--bg);
  border-right: 2px solid var(--border);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  overflow-x: hidden;
  /* Riempie la colonna del grid (altezza = .main-content = 100vh - 52). Resta ferma:
     lo scroll della parte destra non la influenza, perché lo scroll è sulla .main-content. */
  height: calc(100vh - 52px);
}

.sidebar::-webkit-scrollbar { width: 3px; }
.sidebar::-webkit-scrollbar-thumb { background: var(--border-light); }

.sidebar-section {
  padding: 16px;
  border-bottom: 1px solid var(--border-light);
}

.sidebar-section h3 {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 10px;
}

/* City info */
.city-info {
  display: flex;
  align-items: center;
  gap: 12px;
  border: 1px solid var(--border);
  padding: 12px;
  background: var(--bg);
}

.city-name {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: -0.01em;
}
.city-meta { font-size: 10px; color: var(--muted); margin-top: 2px; }

.score-ring-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  margin-left: auto;
}
.score-ring-wrap canvas { width: 64px !important; height: 64px !important; }
.score-val { font-size: 18px; font-weight: 700; color: var(--text); }
.score-label { font-size: 9px; color: var(--muted); text-align: center; letter-spacing: 0.08em; text-transform: uppercase; }

/* Category selector */
.cat-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
  /* ---- PATCH-LUCA: scroll dopo 8 pulsanti (4 righe x 2 colonne) ---- */
  max-height: 999px; /* placeholder, sovrascritto da JS */
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-width: none;
  -ms-overflow-style: none;
  scroll-behavior: smooth;
}
.cat-grid::-webkit-scrollbar { width: 0; height: 0; background: transparent; }

/* Wrapper che contiene .cat-grid + frecce di paginazione */
.cat-grid-wrap {
  position: relative;
}
/* Freccia paginazione su/giu (piccola, discreta) */
.cat-grid-arrow {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: 22px;
  height: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--card);
  border: 1px solid var(--border-light);
  color: var(--accent);
  cursor: pointer;
  font-size: 10px;
  line-height: 1;
  padding: 0;
  z-index: 5;
  opacity: 0.85;
  transition: opacity 120ms ease, background 120ms ease;
  user-select: none;
}
.cat-grid-arrow:hover {
  opacity: 1;
  background: var(--bg2);
}
.cat-grid-arrow.up   { top: -14px; }     /* sopra la griglia - PATCH-LUCA: era -6px */
.cat-grid-arrow.down { bottom: -14px; }  /* sotto la griglia - PATCH-LUCA: era -6px */
.cat-grid-arrow[hidden] { display: none !important; }
/* ---- /PATCH-LUCA ---- */

.cat-btn {
  background: var(--bg);
  border: 1px solid var(--border-light);
  padding: 10px 6px;
  cursor: pointer;
  text-align: center;
  /* PATCH-LUCA cat-btn-v2: transizione piu\u0027 lunga e morbida (era all 0.12s) per
     evitare il \u0022flash\u0022 quando si cambia selezione: c\u0027e\u0027 un breve crossfade
     percepibile tra il pulsante che si spegne e quello che si accende. */
  transition:
    background 0.28s cubic-bezier(0.4, 0, 0.2, 1),
    border-color 0.28s cubic-bezier(0.4, 0, 0.2, 1),
    color 0.28s cubic-bezier(0.4, 0, 0.2, 1),
    box-shadow 0.28s cubic-bezier(0.4, 0, 0.2, 1);
  color: var(--text);
  font-family: var(--font);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.04em;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  /* PATCH-LUCA cat-btn-v2: bordi LEGGERMENTE arrotondati (poco poco).
     Il selettore globale * { border-radius: 0 !important; } azzererebbe tutto,
     quindi serve !important anche qui. */
  border-radius: 4px !important;
}

.cat-btn:hover {
  border-color: var(--border);
  background: var(--bg2);
}

.cat-btn.active {
  /* PATCH-LUCA cat-btn-v2: sfondo selezionato MENO scuro.
     Prima: var(--accent-dark) = #35004a (molto scuro, quasi nero-viola).
     Ora: viola medio #6b2a85 - sta a meta\u0027 strada tra --accent-dark (#35004a)
     e --muted (#7a3a8a): chiaramente \u0022acceso\u0022 ma non aggressivo, ben leggibile
     col testo bianco e coerente con la palette viola della dashboard. */
  border-color: #6b2a85;
  background: #6b2a85;
  color: var(--bg);
  /* Lieve ombra morbida per dare profondita\u0027 al pulsante attivo */
  box-shadow:
    0 1px 2px rgba(83, 0, 108, 0.15),
    0 2px 6px rgba(83, 0, 108, 0.10);
}

.cat-btn.active svg path,
.cat-btn.active svg rect,
.cat-btn.active svg circle,
.cat-btn.active svg line,
.cat-btn.active svg polyline,
.cat-btn.active svg polygon {
  stroke: #ffffff;
  fill: none;
}

.cat-btn.active svg .fill-black {
  fill: #ffffff;
  stroke: none;
}

.cat-icon-svg { width: 22px; height: 22px; display: block; }

/* Legend */
/* PATCH-LUCA legend-bar-v2: colori in trasparenza \u002B finiture liquid glass.
   - I colori del gradient sono ora in rgba con alpha ~0.6: il risultato e\u0027 piu\u0027
     morbido, meno saturo, coerente con il resto della dashboard.
   - Bordo viola sottile in trasparenza (come gli altri controlli).
   - Border-radius pill (999px) per renderla piu\u0027 elegante.
   - Inset shadow per dare profondita\u0027 (\u0022incassata\u0022 nella card) e un riflesso
     bianco superiore che simula vetro lucido.
   - Altezza leggermente maggiore (16 -\u003E 18px) per dare piu\u0027 respiro ai colori. */
.legend-bar {
  height: 18px;
  background: linear-gradient(90deg,
              rgba(34, 197, 94, 0.85) 0%,
              rgba(34, 197, 94, 0.85) 16.66%,
              rgba(253, 224, 71, 0.88) 16.66%,
              rgba(202, 138, 4, 0.85) 33.33%,
              rgba(248, 113, 113, 0.85) 33.33%,
              rgba(127, 29, 29, 0.85) 95%,
              rgba(156, 163, 175, 0.80) 95%,
              rgba(156, 163, 175, 0.80) 100%);
  border: 1px solid rgba(83, 0, 108, 0.18);
  border-radius: 999px !important;
  overflow: hidden;
  position: relative;
  box-shadow:
    inset 0 1px 2px rgba(83, 0, 108, 0.10),         /* incassatura morbida */
    inset 0 -1px 0 rgba(255, 255, 255, 0.35),       /* riflesso bordo inferiore */
    0 1px 2px rgba(83, 0, 108, 0.05);               /* alone esterno tenue */
}
/* Riflesso lucido superiore (effetto vetro) sovrapposto al gradient */
.legend-bar::after {
  content: \u0027\u0027;
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg,
              rgba(255, 255, 255, 0.18) 0%,
              rgba(255, 255, 255, 0.04) 45%,
              rgba(255, 255, 255, 0) 60%,
              rgba(0, 0, 0, 0.04) 100%);
  pointer-events: none;
}
.legend-labels {
  display: flex;
  justify-content: space-between;
  font-size: 10px;
  color: var(--muted);
  margin-top: 6px;
  padding: 0 2px;
}

/* ─── Legend mode toggle ─── */
.legend-toggle {
  display: flex;
  margin-top: 10px;
  border: 1px solid var(--border);
  background: var(--bg);
  user-select: none;
}
.legend-toggle-opt {
  flex: 1;
  text-align: center;
  padding: 5px 6px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  color: var(--muted);
  transition: background 0.12s, color 0.12s;
}
.legend-toggle-opt + .legend-toggle-opt { border-left: 1px solid var(--border-light); }
.legend-toggle-opt:hover { background: var(--bg2); }
.legend-toggle-opt.active {
  background: var(--accent-dark);
  color: #fff;
}

/* ─── Steps pill toggle (segmented control) ─── */
.controls-row {
  margin-top: 18px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  align-items: stretch;
}

.steps-wrap {
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: stretch;
  width: 100%;
}

.opacity-slider-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 4px;
  width: 70%;
  align-self: center;
}
.opacity-slider-wrap input[type="range"] {
  -webkit-appearance: none;
  appearance: none;
  flex: 1;
  height: 4px;
  background: linear-gradient(90deg, transparent 0%, var(--border-light) 50%, var(--accent) 100%);
  outline: none;
  cursor: pointer;
  border: 1px solid var(--border-light);
}
.opacity-slider-wrap input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 12px;
  height: 12px;
  background: var(--accent);
  border: 1px solid var(--accent-dark);
  cursor: pointer;
}
.opacity-slider-wrap input[type="range"]::-moz-range-thumb {
  width: 12px;
  height: 12px;
  background: var(--accent);
  border: 1px solid var(--accent-dark);
  cursor: pointer;
  border-radius: 0;
}
.opacity-val {
  font-size: 11px;
  font-weight: 600;
  color: var(--muted);
  min-width: 32px;
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.steps-label {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--muted);
  text-align: left;
}

.steps-pill {
  /* PATCH-LUCA steps-pill-v3: liquid glass.
     Track con leggero blur + gradient, pillola attiva in vetro viola semi-trasparente
     con riflesso interno superiore (highlight) e ombra morbida sotto. */
  display: flex;
  background: linear-gradient(180deg,
              rgba(83, 0, 108, 0.06) 0%,
              rgba(83, 0, 108, 0.10) 100%);
  border: 1px solid rgba(83, 0, 108, 0.18);
  padding: 2px;
  user-select: none;
  border-radius: 999px !important;
  overflow: hidden;
  width: 70%;
  align-self: center;
  -webkit-backdrop-filter: blur(8px) saturate(140%);
  backdrop-filter: blur(8px) saturate(140%);
  box-shadow:
    inset 0 1px 2px rgba(83, 0, 108, 0.08),     /* incassatura tenue */
    inset 0 -1px 0 rgba(255, 255, 255, 0.5);    /* riflesso bordo inferiore */
  position: relative;
}

/* PATCH-LUCA pill-thumb-v1: lo "thumb" scorrevole.
   E' un ::before del .steps-pill che occupa META' della pillola e si sposta
   da sinistra (default) a destra (data-pos="1") con animazione di transform.
   In questo modo l'utente VEDE il fondo viola che SCIVOLA dalla vecchia
   opzione alla nuova, invece di un cambio istantaneo di background. */
.steps-pill::before {
  content: '';
  position: absolute;
  top: 2px;
  bottom: 2px;
  left: 2px;
  width: calc(50% - 2px);
  background:
    linear-gradient(180deg,
      rgba(140, 80, 175, 0.92) 0%,
      rgba(105, 50, 140, 0.92) 50%,
      rgba(95, 40, 130, 0.94) 100%);
  -webkit-backdrop-filter: blur(6px) saturate(160%);
  backdrop-filter: blur(6px) saturate(160%);
  border-radius: 999px !important;
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.45),
    inset 0 -1px 0 rgba(60, 0, 90, 0.35),
    0 1px 2px rgba(60, 0, 90, 0.18),
    0 3px 8px rgba(83, 0, 108, 0.22);
  transition: transform 0.32s cubic-bezier(0.4, 0, 0.2, 1);
  transform: translateX(0%);
  z-index: 0;
  pointer-events: none;
}
.steps-pill[data-pos="1"]::before {
  transform: translateX(100%);
}

.steps-pill-opt {
  flex: 1;
  padding: 5px 14px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  color: var(--muted);
  background: transparent;
  /* PATCH-LUCA pill-thumb-v1: ora le opt cambiano SOLO colore testo (il viola
     scivola via thumb sotto). Niente piu' cambio di background sulla .opt. */
  transition: color 0.32s cubic-bezier(0.4, 0, 0.2, 1);
  border-radius: 999px !important;
  text-align: center;
  position: relative;
  z-index: 1;
}

.steps-pill-opt:hover:not(.active) {
  color: var(--accent);
}

.steps-pill-opt.active {
  /* PATCH-LUCA pill-thumb-v1: l'effetto viola e' gestito dal ::before scorrevole.
     Qui solo testo bianco + leggera ombra testo per leggibilita' sul vetro. */
  background: transparent;
  color: #fff;
  -webkit-backdrop-filter: none;
  backdrop-filter: none;
  box-shadow: none;
  text-shadow: 0 1px 0 rgba(40, 0, 60, 0.25);
}

/* ───── /PATCH-LUCA pill-thumb-v1 ───── */

/* ─── MAIN ─── */
.main-content {
  display: flex;
  flex-direction: column;
  background: var(--bg);
  --charts-h: 160px;
  /* La main-content è alta esattamente come la viewport (sotto l'header) e
     scrolla internamente: la sidebar resta ferma, scorre solo questa colonna */
  height: calc(100vh - 52px);
  overflow-y: auto;
  overflow-x: hidden;
}
.main-content::-webkit-scrollbar { width: 8px; }
.main-content::-webkit-scrollbar-thumb { background: var(--border-light); }

#map {
  width: 100%;
  height: calc(100vh - 52px - var(--charts-h));
  min-height: 120px;
  flex-shrink: 0;
  position: relative;
}

/* ─── BOTTOM PANEL (tendina: charts + POI insieme) ─── */
.bottom-panel {
  /* Altezza naturale: contiene tutti i grafici + POI.
     L'effetto "tendina" è dato dal cambiare l'altezza della mappa (via --charts-h):
     più la mappa è bassa, più del pannello è visibile prima di dover scrollare. */
  min-height: 60px;
  border-top: 2px solid var(--border);
  background: var(--bg);
  position: relative;
  flex-shrink: 0;
}

/* ─── CHARTS PANEL ─── */
.charts-panel {
  background: var(--bg);
  display: flex;
  flex-direction: column;
}

/* Handle per resize verticale del pannello grafici */
.charts-resize-handle {
  position: absolute;
  top: -6px;
  left: 0;
  right: 0;
  height: 12px;
  cursor: ns-resize;
  z-index: 1005;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
}
.charts-resize-handle::before {
  content: '';
  width: 48px;
  height: 4px;
  background: var(--border);
  border-radius: 2px !important;
  opacity: 0.55;
  transition: opacity 0.15s, background 0.15s;
}
.charts-resize-handle:hover::before,
.charts-resize-handle.dragging::before {
  opacity: 1;
  background: var(--accent-dark);
}
body.charts-resizing {
  cursor: ns-resize !important;
  user-select: none !important;
}
body.charts-resizing * {
  cursor: ns-resize !important;
  user-select: none !important;
}

.charts-header {
  padding: 10px 16px;
  border-bottom: 1px solid var(--border-light);
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
}

.charts-title {
  font-weight: 700;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.charts-subtitle { font-size: 10px; color: var(--muted); }
.spacer { flex: 1; }

/* PATCH-LUCA charts-grid-rows: la riga 2 (Category comparison + Category ranking)
   ha bisogno di piu' altezza per mostrare tutte le ~14 categorie in modo
   leggibile. Diamo a riga1 una quota fissa minima e a riga2 il resto, con
   un'altezza totale calcolata sul numero di categorie (~24px per voce).
   Il resto della dashboard NON viene toccato.
   PATCH-LUCA charts-grid-rows-v2: riga1 piu' alta (240px) per dare piu' spazio
   a Distribution e Accessibility zones; riga2 ridotta del 20% (360 -> 288).
   PATCH-LUCA charts-grid-rows-v3: riga1 ridotta da 240 a 220px su richiesta
   utente, per allineare l'altezza dei grafici "Distribution (minutes)" e
   "Accessibility zones" a quella dei grafici della sezione POI Analysis
   (.poi-grid usa righe da 220px, vedi piu' in basso). Risultato: tutti i
   grafici "tondi/distributivi" della dashboard hanno ora la stessa altezza
   visiva. Altezza totale di .charts-grid: 220 + 288 = 508px (era 528). */
.charts-grid {
  flex: 0 0 auto;
  height: 508px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 220px 288px;
  gap: 0;
  overflow: hidden;
}

/* Wrapper per i grafici - non scrolla autonomamente, lo scroll è sul bottom-panel */
.charts-scroll {
  /* nessuno scroll qui: lo gestisce .bottom-panel */
}

.chart-card {
  padding: 12px 14px;
  border-right: 1px solid var(--border-light);
  border-bottom: 1px solid var(--border-light);
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
  min-height: 0;
}

.chart-card:nth-child(2),
.chart-card:nth-child(4) { border-right: none; }
.chart-card:nth-child(3),
.chart-card:nth-child(4) { border-bottom: none; }

.chart-card-title {
  font-size: 9px;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  flex-shrink: 0;
}

.chart-card canvas {
  flex: 1;
  min-height: 0;
}

.stat-row {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
}

.stat-chip {
  background: var(--bg2);
  border: 1px solid var(--border-light);
  padding: 4px 8px;
  font-size: 10px;
  flex: 1;
  text-align: center;
}

.stat-chip .val {
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
  display: block;
}

.stat-chip .lbl { color: var(--muted); font-size: 9px; letter-spacing: 0.05em; }


.empty-charts {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--muted);
  font-size: 12px;
}

/* Loading */
.loading-overlay {
  position: fixed;
  inset: 0;
  background: rgba(255,255,255,0.92);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  gap: 14px;
}

.loading-overlay.hidden { display: none; }

.spinner {
  width: 36px;
  height: 36px;
  border: 2px solid var(--border-light);
  border-top-color: var(--border);
  animation: spin 0.7s linear infinite;
}

@keyframes spin { to { transform: rotate(360deg); } }
.loading-text { font-size: 12px; color: var(--muted); letter-spacing: 0.05em; }

.leaflet-container { background: #f0f0f0 !important; }

/* ─── VIEWPORT DONUT (canvas + HTML overlay, v4) ─── */
.viewport-donut {
  /* PATCH-LUCA donut-v4:
     - dimensione mantenuta a 110px (come v3)
     - RIPRISTINATO il glass background della v2 (semi-trasparente + blur)
     - RIMOSSA l'ombra direzionale sud-est sia dal canvas sia dal testo
     - mantenuto il nuovo anello con gradiente (disegnato da JS, v3) */
  position: fixed;
  top: 68px;
  right: 18px;
  width: 110px;
  height: 110px;
  z-index: 1001;
  padding: 0;
  margin: 0;
  user-select: none;
  pointer-events: none;
  /* Glassmorphism (come v2): semi-trasparente + blur, capsula tonda */
  background: rgba(255, 255, 255, 0.72);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  backdrop-filter: blur(14px) saturate(140%);
  border: 1px solid rgba(83, 0, 108, 0.18);
  border-radius: 50% !important;
  /* Ombra morbida e SIMMETRICA (non direzionale) per dare profondità senza pesare */
  box-shadow:
    0 1px 2px rgba(15, 0, 30, 0.05),
    0 6px 18px rgba(15, 0, 30, 0.10),
    0 18px 38px rgba(15, 0, 30, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.6);
  transition: opacity 0.15s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Variante "scura" per basemap satellitari: glass scuro, testo bianco */
.viewport-donut--light-text {
  background: rgba(20, 12, 28, 0.42);
  border-color: rgba(255, 255, 255, 0.22);
  box-shadow:
    0 1px 2px rgba(0, 0, 0, 0.18),
    0 6px 18px rgba(0, 0, 0, 0.28),
    0 18px 38px rgba(0, 0, 0, 0.32),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

.viewport-donut-canvas {
  width: 110px !important;
  height: 110px !important;
  display: block;
  background: transparent;
  position: absolute;
  inset: 0;
  /* PATCH-LUCA donut-v4: NIENTE ombra direzionale sul canvas */
  filter: none;
}

/* Numero + label centrati */
.viewport-donut-text {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  gap: 0;
}
.viewport-donut-value {
  font-family: 'Inter', sans-serif;
  font-size: 19px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
  color: #0f0a14;
  transition: color 0.2s ease;
  /* PATCH-LUCA donut-v4: nessuna ombra direzionale, solo un highlight bianco discreto */
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.4);
}
.viewport-donut-label {
  font-family: 'Inter', sans-serif;
  font-size: 8px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: rgba(15, 10, 20, 0.62);
  transition: color 0.2s ease;
  margin-top: 3px;
  /* PATCH-LUCA donut-v4: niente ombra direzionale */
  text-shadow: none;
}
/* Variante per basemap scure: testo bianco, sempre senza ombra direzionale */
.viewport-donut--light-text .viewport-donut-value {
  color: #ffffff;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
}
.viewport-donut--light-text .viewport-donut-label {
  color: rgba(255, 255, 255, 0.78);
  text-shadow: none;
}

/* ─── BASEMAP SWITCHER ─── */
.basemap-switcher {
  position: fixed;      /* FISSO rispetto alla viewport: non si muove con lo scroll */
  top: 194px;           /* PATCH-LUCA donut-v3: sotto il donut 110px (68 + 110 + 16) */
  right: 18px;          /* un po' di margine a destra (piu' interno rispetto al donut) */
  z-index: 1001;
  transition: opacity 0.15s ease;
}
.viewport-donut.hidden-by-scroll,
.basemap-switcher.hidden-by-scroll {
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
}

/* PATCH-LUCA basemap-btn-v4: palette chiaro/scuro MORBIDA (no bianco/nero puri).
   - Tema CHIARO (OSM): sfondo bianco-crema caldo, icona viola scuro (--accent-dark)
   - Tema SCURO (satellitari): sfondo viola-grigio scuro, icona crema chiaro
   Coordinato con la palette viola della dashboard, niente piu' contrasti aggressivi. */
.basemap-btn {
  width: 44px;
  height: 44px;
  border-radius: 50% !important;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  user-select: none;
  padding: 0;
  pointer-events: auto;
  transition:
    background 0.18s ease,
    border-color 0.18s ease,
    box-shadow 0.18s ease,
    transform 0.12s ease,
    color 0.18s ease;
  /* Default = tema CHIARO (OSM/Carto): bianco-crema caldo, icona viola scuro */
  background: rgba(250, 246, 252, 0.82);   /* bianco con velo viola tenue */
  -webkit-backdrop-filter: blur(12px) saturate(140%);
  backdrop-filter: blur(12px) saturate(140%);
  border: 1px solid rgba(83, 0, 108, 0.20);
  color: #3a1a4a;                          /* viola scuro morbido, non nero */
  box-shadow:
    0 1px 2px rgba(40, 0, 60, 0.06),
    0 6px 16px rgba(40, 0, 60, 0.10),
    0 14px 32px rgba(40, 0, 60, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.65);
}

/* Tema SCURO (basemap satellitari/AGEA):
   PATCH-LUCA basemap-btn-v5: lo sfondo riprende ESATTAMENTE i colori del donut
   nella sua variante scura (.viewport-donut--light-text), cosi' i due widget
   formano un set coerente quando si e' su mappe satellitari. */
.basemap-btn--dark {
  background: rgba(20, 12, 28, 0.42);        /* identico al donut scuro */
  border: 1px solid rgba(255, 255, 255, 0.22);
  color: #f3e8f7;                            /* icona crema lilla (invariato, contrasta bene) */
  box-shadow:
    0 1px 2px rgba(0, 0, 0, 0.18),
    0 6px 18px rgba(0, 0, 0, 0.28),
    0 18px 38px rgba(0, 0, 0, 0.32),
    inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

.basemap-btn:hover {
  transform: translateY(-1px);
  background: rgba(250, 246, 252, 0.95);
  border-color: rgba(83, 0, 108, 0.38);
  box-shadow:
    0 2px 4px rgba(40, 0, 60, 0.08),
    0 10px 22px rgba(40, 0, 60, 0.14),
    0 18px 40px rgba(40, 0, 60, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.75);
}
.basemap-btn--dark:hover {
  /* Hover: stessa famiglia del donut scuro, leggermente piu' opaco per feedback */
  background: rgba(20, 12, 28, 0.58);
  border-color: rgba(255, 255, 255, 0.35);
  box-shadow:
    0 2px 4px rgba(0, 0, 0, 0.22),
    0 10px 24px rgba(0, 0, 0, 0.34),
    0 22px 44px rgba(0, 0, 0, 0.38),
    inset 0 1px 0 rgba(255, 255, 255, 0.24);
}

/* SVG: come v3, 28x26 */
.basemap-btn svg {
  width: 28px;
  height: 26px;
  display: block;
}

.basemap-dropdown {
  display: none;
  position: absolute;
  top: 52px;            /* PATCH-LUCA basemap-btn-v2: era 40px, ora che il bottone e' 44px serve piu' spazio */
  right: 0;
  background: #ffffff;
  border: 2px solid var(--border);
  box-shadow: 3px 3px 0 var(--border-light);
  min-width: 160px;
  z-index: 1002;
}

.basemap-dropdown.open { display: block; }

.basemap-option {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  cursor: pointer;
  font-family: var(--font);
  font-size: 11px;
  font-weight: 500;
  color: var(--text);
  border-bottom: 1px solid var(--border-light);
  user-select: none;
  transition: background 0.1s;
}

.basemap-option:last-child { border-bottom: none; }
.basemap-option:hover { background: var(--bg2); }
/* PATCH-LUCA basemap-active-color: il viola "selezionato" del basemap dropdown
   ora coincide con quello dei pulsanti category attivi (.cat-btn.active = #6b2a85),
   invece del viola scuro precedente (var(--accent-dark) = #35004a).
   Motivo: coerenza visiva - tutti i pulsanti "selezionati" della dashboard
   usano lo stesso identico viola medio. */
.basemap-option.active { background: #6b2a85; color: #fff; }
.basemap-option.active .basemap-thumb { border-color: rgba(255,255,255,0.5); }

.basemap-thumb {
  width: 28px;
  height: 20px;
  border: 1px solid var(--border-light);
  flex-shrink: 0;
}

.basemap-thumb-light {
  background: linear-gradient(135deg, #e8e8e8 0%, #f5f5f5 40%, #d0d0d0 100%);
}

.basemap-thumb-ortofoto {
  background: linear-gradient(135deg, #4a6741 0%, #3d5c38 30%, #8a7a5a 55%, #6b6b5a 80%, #a09080 100%);
  position: relative;
  overflow: hidden;
}

.basemap-thumb-agea {
  background: linear-gradient(135deg, #6b8e3d 0%, #8fa84a 25%, #c9a85a 55%, #a8884a 80%, #6b5a3a 100%);
  position: relative;
  overflow: hidden;
}
.basemap-thumb-agea::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    repeating-linear-gradient(0deg, transparent, transparent 3px, rgba(0,0,0,0.08) 3px, rgba(0,0,0,0.08) 4px),
    repeating-linear-gradient(90deg, transparent, transparent 4px, rgba(255,255,255,0.06) 4px, rgba(255,255,255,0.06) 5px);
}
.basemap-thumb-ortofoto::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    repeating-linear-gradient(45deg, transparent, transparent 2px, rgba(255,255,255,0.04) 2px, rgba(255,255,255,0.04) 4px),
    repeating-linear-gradient(-45deg, transparent, transparent 3px, rgba(0,0,0,0.05) 3px, rgba(0,0,0,0.05) 5px);
}

/* ─── POI PANEL nel dropdown basemap ─── */
.basemap-section-title {
  padding: 6px 12px 4px;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
  border-top: 1px solid var(--border-light);
  margin-top: 2px;
  user-select: none;
}

.poi-layer-list {
  max-height: 280px;
  overflow-y: auto;
}

.poi-layer-list::-webkit-scrollbar { width: 3px; }
.poi-layer-list::-webkit-scrollbar-thumb { background: var(--border-light); }

.poi-layer-row {
  display: flex;
  align-items: center;
  gap: 0;
  border-bottom: 1px solid var(--border-light);
  cursor: default;
}

.poi-layer-row:last-child { border-bottom: none; }

.poi-layer-check {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 32px;
  flex-shrink: 0;
  cursor: pointer;
  border-right: 1px solid var(--border-light);
}

.poi-layer-check input[type=checkbox] {
  width: 12px;
  height: 12px;
  accent-color: var(--accent);
  cursor: pointer;
  margin: 0;
  border-radius: 0 !important;
}

.poi-layer-dot {
  width: 8px;
  height: 8px;
  flex-shrink: 0;
  margin: 0 6px 0 8px;
}

.poi-layer-label {
  flex: 1;
  font-size: 11px;
  font-weight: 500;
  color: var(--text);
  padding: 0 4px 0 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 32px;
}

.poi-layer-row.current-cat .poi-layer-label {
  font-weight: 700;
}

.poi-layer-expand {
  width: 28px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  flex-shrink: 0;
  border-left: 1px solid var(--border-light);
  color: var(--muted);
  font-size: 10px;
  transition: transform 0.15s;
  user-select: none;
}

.poi-layer-expand.open { transform: rotate(180deg); }

.poi-subtype-list {
  display: none;
  background: var(--bg2);
  border-bottom: 1px solid var(--border-light);
}

.poi-subtype-list.open { display: block; }

.poi-subtype-row {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px 5px 36px;
  border-bottom: 1px solid rgba(208,186,218,0.4);
  cursor: pointer;
}

.poi-subtype-row:last-child { border-bottom: none; }

.poi-subtype-row:hover { background: rgba(83,0,108,0.06); }

.poi-subtype-row input[type=checkbox] {
  width: 11px;
  height: 11px;
  accent-color: var(--accent);
  cursor: pointer;
  margin: 0;
  flex-shrink: 0;
}

.poi-subtype-label {
  font-size: 10px;
  color: var(--muted);
  flex: 1;
}

/* ─── POI SECTION ─── */
.poi-section {
  border-top: 1px solid var(--border-light);
  margin-top: 0;
  background: var(--bg);
  flex-shrink: 0;
}

.poi-header {
  padding: 10px 16px;
  border-bottom: 1px solid var(--border-light);
  display: flex;
  align-items: center;
}

.poi-info-bar {
  display: flex;
  border-bottom: 1px solid var(--border-light);
}

.poi-stat {
  flex: 1;
  padding: 10px 16px;
  border-right: 1px solid var(--border-light);
}
.poi-stat:last-child { border-right: none; }
.poi-stat .val {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1;
}
.poi-stat .lbl {
  font-size: 9px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-top: 3px;
}

.poi-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 220px 220px;
  border-top: none;
}

/* POI alphabetical list */
.poi-alpha-list {
  overflow-y: auto;
  flex: 1;
  min-height: 0;
  font-size: 10px;
}

.poi-alpha-list::-webkit-scrollbar { width: 3px; }
.poi-alpha-list::-webkit-scrollbar-thumb { background: var(--border-light); }

.poi-alpha-item {
  display: flex;
  align-items: baseline;
  gap: 6px;
  padding: 3px 0;
  border-bottom: 1px solid var(--bg2);
  line-height: 1.3;
}

.poi-alpha-item:last-child { border-bottom: none; }

.poi-alpha-name {
  flex: 1;
  color: var(--text);
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.poi-alpha-type {
  color: var(--muted);
  font-size: 9px;
  flex-shrink: 0;
}

.map-tooltip {
  background: #fff !important;
  border: 1px solid #000 !important;
  color: #000 !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 11px !important;
  padding: 10px 14px !important;
  box-shadow: 2px 2px 0 #000 !important;
}
/* ───────── PATCH-LUCA v5: sidebar sempre interamente visibile ─────────
   Obiettivi:
   1) La sidebar (300px) non deve mai essere compressa o tagliata.
   2) Entrambe le colonne dei bottoni categoria devono mostrare nome + icona
      per intero (niente "..." troncato e niente overflow nascosto).
   3) Se la finestra è davvero più stretta della somma sidebar + contenuto,
      meglio uno scroll orizzontale del contenitore che non un clipping.
   Approccio: solo aggiunte di regole CSS in coda al foglio di stile,
   senza toccare le regole originali. Le regole più specifiche o più in
   basso prevalgono, quindi sovrascrivono in modo controllato. */

/* La sidebar non si comprime mai sotto i 300px */
.sidebar{
  min-width: 300px;       /* assicura larghezza minima anche dentro grid/flex */
  flex-shrink: 0;         /* se mai venisse messa in un flex container */
  box-sizing: border-box;
  overflow: visible;      /* niente clipping del contenuto interno */
}

/* Il grid principale (sidebar + mappa+grafici): se lo schermo è troppo
   stretto, lasciamo scrollare orizzontalmente la pagina/container
   invece di nascondere la sidebar. */
.app-body,
.app-grid,
.app-container,
.layout,
body{
  overflow-x: auto;
}

/* Griglia categorie: 2 colonne uguali che riempiono tutto lo spazio
   disponibile della sidebar, con un minimo garantito. */
.cat-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
  width: 100%;
  box-sizing: border-box;
}

/* I pulsanti categoria: nome SEMPRE per intero.
   - white-space:normal  → può andare a capo su 2 righe se serve
   - word-break:break-word + overflow-wrap:anywhere → spezza anche
     parole lunghe tipo "Climate" se davvero non c'è spazio
   - height:auto         → il pulsante cresce in altezza, non taglia
   - overflow:visible    → niente clipping
   - text-overflow:clip  → annulla eventuali "..." ereditati
   - min-width:0         → permette al pulsante di restringersi senza overflow */
.cat-btn{
  white-space: normal !important;
  word-break: break-word;
  overflow-wrap: anywhere;
  overflow: visible !important;
  text-overflow: clip !important;
  height: auto !important;
  min-height: 36px;
  min-width: 0;
  line-height: 1.15;
  padding: 6px 6px;       /* più "respiro" orizzontale */
  text-align: center;
  display: flex;
  flex-direction: column; /* icona sopra, testo sotto: più spazio in larghezza */
  align-items: center;
  justify-content: center;
  gap: 3px;
  box-sizing: border-box;
  /* PATCH-LUCA cat-btn-v2: ribadisco qui i bordi LEGGERMENTE arrotondati e la
     transizione morbida, altrimenti questa regola (piu\u0027 in basso, stessa
     specificita\u0027) sovrascriverebbe quella sopra. */
  border-radius: 4px !important;
  transition:
    background 0.28s cubic-bezier(0.4, 0, 0.2, 1),
    border-color 0.28s cubic-bezier(0.4, 0, 0.2, 1),
    color 0.28s cubic-bezier(0.4, 0, 0.2, 1),
    box-shadow 0.28s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Sovrascrive la regola della v4 che metteva nowrap+font ridotto sugli
   shelter: ora devono comportarsi come gli altri (testo per intero,
   eventualmente su 2 righe). Manteniamo solo un leggero font-size più
   piccolo per uniformità visiva — ma è opzionale: stesso 10px va bene. */
.cat-btn[data-cat^="shelter_"]{
  white-space: normal !important;
  font-size: 10px;
  letter-spacing: normal;
  padding-left: 6px;
  padding-right: 6px;
}

/* \u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500 PATCH-LUCA map-transition: crossfade colori esagoni \u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500
   Obiettivo: quando l\u0027utente cambia categoria, gradient mode o steps mode,
   gli esagoni della mappa NON devono cambiare colore di scatto, ma fare un
   crossfade morbido (\u0022i vecchi colori si spengono, i nuovi si accendono\u0022).

   Come funziona:
   - Leaflet renderizza ogni esagono come elemento SVG \u003Cpath\u003E dentro
     .leaflet-overlay-pane (renderer SVG di default).
   - Quando chiamiamo geojsonLayer.setStyle(...) (cosa fatta da refreshMapColors()),
     Leaflet aggiorna gli attributi \u0022fill\u0022, \u0022fill-opacity\u0022, \u0022stroke\u0022, \u0022stroke-opacity\u0022.
   - Mettendo una transition CSS su questi attributi, il browser anima
     automaticamente il passaggio tra il colore vecchio e quello nuovo.
   - Niente modifiche al JS: vale per cambio categoria, steps 10/15, gradient on/off,
     opacity slider \u2014 tutto quello che passa per setStyle().

   Durata 0.45s = leggermente piu\u0027 lunga dei pulsanti category (0.28s) perche\u0027
   la mappa ha tanti elementi: serve un po\u0027 di tempo in piu\u0027 per percepire
   l\u0027onda di cambiamento, ma resta veloce e mai \u0022pesante\u0022.

   Easing cubic-bezier(0.4, 0, 0.2, 1) = stessa curva dei pulsanti category,
   per coerenza percettiva (Material Design \u0022standard\u0022). */
#map .leaflet-overlay-pane svg path {
  transition:
    fill 0.45s cubic-bezier(0.4, 0, 0.2, 1),
    fill-opacity 0.45s cubic-bezier(0.4, 0, 0.2, 1),
    stroke 0.45s cubic-bezier(0.4, 0, 0.2, 1),
    stroke-opacity 0.45s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Durante pan/zoom Leaflet ricalcola i path: disabilitiamo la transition in
   quei frame con la classe .leaflet-zoom-anim (gia\u0027 messa da Leaflet) e
   anche quando trasciniamo, cosi\u0027 il movimento mappa resta nitido e fluido
   senza che ogni esagono \u0022strascichi\u0022 il proprio colore. */
.leaflet-zoom-anim .leaflet-overlay-pane svg path,
.leaflet-drag-target .leaflet-overlay-pane svg path {
  transition: none !important;
}
/* \u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500 /PATCH-LUCA map-transition \u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500 */
