/* ============================================================
 * Atlas ER — Landing editorial v2 (anthropic-inspired)
 * Palette: cream primario + Blu CONI istituzionale (#003893) + terra (#c85a3c)
 * Hero cream minimale → Esplora (mappa + panel) → At Atlas (dark)
 * ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --dark: #0E1117;
  --dark-2: #161A21;
  --cream: #FAF8F4;
  --cream-2: #F1ECE3;
  --ink: #1A1A1A;
  --muted: #6B6B6B;
  --hair: rgba(14,17,23,.08);
  --hair-strong: rgba(14,17,23,.16);
  --line: rgba(255,255,255,.12);
  --terra: #c85a3c;
  --terra-hi: #d97757;
  --terra-lo: #a84730;
  --coni-blu: #003893;
  --coni-blu-hi: #1A4FA6;
  --coni-blu-lo: #00286B;
  --coni-oro: #B4A76C;
  --easing: cubic-bezier(.16,1,.3,1);
  --serif: 'Source Serif 4', Georgia, serif;
  --sans: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}

html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  scrollbar-gutter: stable;
  scroll-snap-type: y mandatory;
}
.hero, .explore, .at-atlas {
  scroll-snap-align: start;
  scroll-snap-stop: always;
}
body {
  font-family: var(--sans);
  color: var(--ink);
  background: var(--cream);
  line-height: 1.55;
  font-size: 16px;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; }

.wrap { max-width: 1240px; margin: 0 auto; padding: 0 32px; }
@media (max-width: 640px) { .wrap { padding: 0 20px; } }

/* ============ HEADER ============ */
.site-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 50;
  padding: 18px 0;
  transition: background .3s var(--easing), backdrop-filter .3s, box-shadow .3s;
}
.site-header.scrolled {
  background: rgba(250,248,244,.62);
  backdrop-filter: saturate(140%) blur(10px);
  box-shadow: 0 1px 0 var(--hair);
}
.site-header .wrap { display: flex; align-items: center; gap: 32px; }
.brand {
  font-family: var(--serif); font-weight: 600; font-size: 22px; letter-spacing: -.01em;
  color: var(--ink); display: inline-flex; align-items: center; gap: 11px;
}
.brand-mark {
  width: 36px; height: 36px; display: inline-block; flex-shrink: 0;
}
.site-nav {
  margin-left: auto;
  display: flex; align-items: center; gap: 12px;
}

/* Pair CTA pill: outline (mappa pubblica) + solid (area riservata) — stesse dimensioni */
.nav-cta-outline,
.nav-cta {
  display: inline-flex; align-items: center; justify-content: center;
  line-height: 1; white-space: nowrap;
  font-family: var(--sans); font-weight: 600; font-size: 15px;
  padding: 11px 22px; border-radius: 999px;
  border: 1px solid var(--coni-blu);
  transition: all .25s var(--easing);
}
/* Panel CTA nelle schede comune: dimensione compatta, non cresce con l'header */
.panel-actions > .nav-cta-outline,
.panel-actions > .nav-cta {
  font-size: 14px; padding: 9px 20px;
}
/* Header CTA: forza larghezza uguale indipendente dal testo */
.site-nav > .nav-cta-outline,
.site-nav > .nav-cta { min-width: 160px; }
.nav-cta-outline {
  color: var(--coni-blu); background: transparent;
}
.nav-cta-outline:hover {
  background: var(--coni-blu); color: #fff;
  transform: translateY(-1px);
}

.nav-cta {
  color: #fff; background: var(--coni-blu);
}
.nav-cta:hover {
  background: var(--coni-blu-hi); border-color: var(--coni-blu-hi);
  transform: translateY(-1px);
}

/* ============ HERO cream minimal ============ */
.hero {
  position: relative;
  height: 100vh;
  min-height: 640px;
  padding: 120px 0 96px;
  display: flex; align-items: center;
  background: var(--cream);
  overflow: hidden;
}
.hero::before {
  /* Voronoi background: 330 centroidi comuni ER, linee sottili con fade radiale */
  content: '';
  position: absolute; inset: 0;
  background: url('/assets/voronoi-bg.svg?v=2') center 20% / 165% no-repeat;
  /* Opacità gestite DENTRO il SVG (voronoi g 0.25, capoluoghi g 1.0):
     qui moltiplichiamo per 0.35 → voronoi effettivo ~0.087, capoluoghi 0.35 */
  opacity: .22;
  pointer-events: none;
  z-index: 0;
}
.hero-wrap { width: 100%; text-align: left; position: relative; z-index: 1; }


.hero-title {
  font-family: var(--serif);
  font-weight: 600;
  font-size: clamp(40px, 5.2vw, 78px);
  line-height: 1.04;
  letter-spacing: -.028em;
  color: var(--ink);
  margin: 0 0 40px;
  max-width: 980px;
  text-wrap: balance;
}
.hero-title em {
  font-style: italic; font-weight: 400;
  color: var(--coni-blu);
}
.hero-title .no-break { white-space: nowrap; }
.hero-kpis {
  display: flex; flex-wrap: wrap; gap: 48px;
  margin: 0 0 48px;
  padding: 28px 0 4px;
  max-width: 880px;
}
.hero-kpis .kpi { display: flex; flex-direction: column; gap: 6px; }
.hero-kpis dt {
  font-family: var(--serif); font-weight: 600;
  font-size: clamp(26px, 2.6vw, 38px);
  letter-spacing: -.02em;
  color: var(--coni-blu);
  line-height: 1;
}
.hero-kpis dd {
  font-family: var(--sans); font-weight: 500;
  font-size: 15px; letter-spacing: .02em;
  color: var(--muted);
}
@media (max-width: 540px) { .hero-kpis { gap: 32px; } }

.hero-cta { display: flex; flex-wrap: wrap; gap: 14px; }

/* ============ CONI mention — claim collaborazione (no logo, solo testo) ============ */
.coni-mention {
  font-family: var(--sans);
  font-size: 14px;
  font-weight: 400;
  color: var(--muted);
  letter-spacing: .01em;
}
.coni-mention strong {
  font-weight: 600;
  color: var(--coni-blu);
}
.coni-mention--hero {
  margin: -28px 0 36px;  /* compensa margin-bottom 48px di .hero-kpis → spacing naturale */
}
.coni-mention--footer {
  color: rgba(255,255,255,.7);
}
.footer-bottom-sep {
  color: rgba(255,255,255,.35);
  margin: 0 2px;
}
@media (max-width: 540px) {
  .coni-mention--hero { margin: -20px 0 28px; font-size: 13px; }
}

/* ============ BUTTONS ============ */
.btn {
  display: inline-flex; align-items: center; gap: 12px;
  padding: 16px 30px; border-radius: 999px;
  font-family: var(--sans); font-weight: 600; font-size: 16px;
  transition: all .25s var(--easing);
  border: 1px solid transparent;
}
.btn:active { transform: scale(.98); }
.btn-primary {
  background: var(--coni-blu); color: #fff;
  box-shadow: 0 10px 24px -8px rgba(0, 51, 160, .45);
}
.btn-secondary {
  background: transparent; color: var(--coni-blu);
  border: 1px solid var(--coni-blu);
}
.btn-secondary:hover {
  background: var(--coni-blu); color: #fff;
  transform: translateY(-1px);
}
.btn-secondary svg { transition: transform .25s var(--easing); }
.btn-secondary:hover svg { transform: translateX(3px); }
.btn-primary:hover {
  background: var(--coni-blu-hi);
  box-shadow: 0 14px 32px -10px rgba(0, 51, 160, .55);
  transform: translateY(-2px);
}
.btn-primary svg { transition: transform .25s var(--easing); }
.btn-primary:hover svg { transform: translateY(3px); }

/* ============ ESPLORA ============ */
.explore {
  height: 100vh;
  min-height: 720px;
  padding: 24px 0 0;
  background: var(--cream);
  border-top: 1px solid var(--hair);
  position: relative;
  overflow: hidden;
  display: flex; flex-direction: column; justify-content: flex-start;
}
.explore::before {
  /* Voronoi background: variante (celle stessa mano, flip orizzontale, senza capoluoghi).
     Posizione a top per ricevere il pattern che "esce" dal bordo basso dell'hero. */
  content: '';
  position: absolute; inset: 0;
  background: url('/assets/voronoi-bg-explore.svg?v=2') center top / 165% no-repeat;
  opacity: .18;
  pointer-events: none;
  z-index: 0;
}
.section-kicker {
  font-family: var(--sans); font-size: 12px; font-weight: 500;
  letter-spacing: .14em; text-transform: uppercase; color: var(--coni-blu);
  margin-bottom: 16px;
  display: inline-flex; align-items: center; gap: 10px;
}
.section-kicker::before {
  content: ''; width: 18px; height: 1px; background: var(--coni-blu);
  display: inline-block;
}
.explore-title {
  font-family: var(--serif); font-weight: 600;
  font-size: clamp(36px, 5vw, 56px);
  line-height: 1.05; letter-spacing: -.025em;
  color: var(--ink);
}
.explore-title em { font-style: italic; font-weight: 400; color: var(--coni-blu); }
.explore-lead {
  font-family: var(--serif); font-size: 19px; color: var(--muted);
  margin-top: 20px; max-width: 620px;
}

/* Layout full-bleed: mappa 100vw + panel overlay card */
.explore-map-stage {
  position: relative;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  flex: 1;
  min-height: 420px;
}
.explore-map {
  position: absolute;
  inset: 0;
  background: transparent;
  overflow: hidden;
}
.explore-banner {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 5;
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(6px);
  color: #6b7280;
  font-size: 12px;
  font-weight: 500;
  padding: 6px 12px;
  border-radius: 6px;
  box-shadow: 0 1px 6px rgba(0, 0, 0, 0.1);
  pointer-events: none;
  letter-spacing: 0.02em;
}
.explore-map svg {
  width: 100%; height: 100%; display: block;
  overflow: hidden;
  /* Disabilita gesture browser default (pinch-zoom pagina, pan scroll) →
     JS handlers gestiscono pan/pinch + scroll-snap parent non interferisce. */
  touch-action: none;
}
/* Drag-pan cursor (desktop mouse): grab quando si può panare, grabbing durante drag */
#esplora[data-state="province"] .explore-map svg,
#esplora[data-state="comune"] .explore-map svg { cursor: grab; }
.explore-map svg.is-dragging { cursor: grabbing; }
/* Base blu-hi (cielo notturno): stelline bianche contrasto alto */
.explore-map .province .comune {
  fill: var(--coni-blu-hi);
  stroke: rgba(250, 248, 244, .18);
  stroke-width: .3;
  transition: fill .25s;
}
.explore-map .province.is-hover .comune,
.explore-map .province:hover .comune { fill: var(--coni-blu); }
/* Provincia selezionata: blu CONI */
.explore-map .province.is-active .comune { fill: var(--coni-blu); }
/* Comuni dentro provincia selezionata: cliccabili */
.explore-map .province.is-active .comune { cursor: pointer; }
.explore-map .province.is-active .comune:hover { fill: var(--coni-blu-hi); }
/* Comune selezionato: fill luminoso + bordo cream per staccare */
.explore-map .province.is-active .comune.is-selected-comune {
  fill: var(--coni-blu-hi);
  stroke: #FAF8F4;
  stroke-width: 1.2;
}
.explore-map .province.is-dim { opacity: .42; }
/* Contorno regione: cream invece che nero, visibile su fondo scuro */
.explore-map .region-outer { stroke: rgba(250, 248, 244, .55) !important; }

/* Labels comuni: cream su fondo scuro — alta leggibilità in hover */
.explore-map .comune-label {
  font-family: 'Inter', sans-serif;
  font-size: 6.5px;
  font-weight: 600;
  fill: #FAF8F4;
  paint-order: stroke;
  stroke: rgba(14, 17, 23, .85);
  stroke-width: 1.6;
  stroke-linejoin: round;
  pointer-events: none;
  opacity: 0;
  transition: opacity .25s ease;
}
.explore-map .comune-label.is-hover,
.explore-map .comune-label.is-selected { opacity: 1; }

/* Cap-marker (capoluoghi): cream su fondo scuro */
.explore-map .cap-marker { transition: opacity .3s; }
.explore-map .cap-marker.is-hidden { opacity: 0; pointer-events: none; }
.explore-map .cap-label {
  fill: #FAF8F4 !important;
  stroke: rgba(14, 17, 23, .75) !important;
  stroke-width: 2.4 !important;
}
.explore-map .cap-dot {
  fill: #FAF8F4 !important;
  stroke: #0f1f42 !important;
  stroke-width: 1.2 !important;
}

/* Impianti: puntini bianchi (stelline) sempre visibili sulla regione */
.explore-map .impianto-dot {
  fill: #FFFFFF;
  stroke: none;
  pointer-events: none;
}

.map-loading {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  color: var(--muted); font-size: 14px;
}

/* Breadcrumb overlay in basso a sinistra sopra la mappa */
.explore-breadcrumb {
  position: absolute;
  left: max(32px, calc(50vw - 588px));
  bottom: 28px;
  z-index: 2;
  display: inline-flex; flex-wrap: wrap; align-items: center; gap: 4px;
  font-size: 13px; color: var(--muted);
  padding: 6px 10px;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid var(--hair);
  border-radius: 999px;
  box-shadow: 0 4px 16px -8px rgba(14,17,23,.12);
}
.bc-item {
  font-family: var(--sans); font-weight: 600; font-size: 15px;
  color: #ffffff;
  background: var(--coni-blu);
  padding: 8px 16px; border-radius: 999px;
  line-height: 1;
  transition: background .2s, transform .15s, box-shadow .2s;
  border: 1px solid var(--coni-blu);
}
button.bc-item { cursor: pointer; }
button.bc-item:hover {
  background: var(--coni-blu-lo);
  border-color: var(--coni-blu-lo);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px -4px rgba(0, 51, 160, .45);
}
button.bc-item:active { transform: translateY(0); }
/* Stato corrente (es. comune span finale, non button) — leggermente più chiaro per indicare "qui" */
.bc-item.bc-comune {
  background: var(--coni-blu-hi);
  border-color: var(--coni-blu-hi);
}
.bc-item.is-root[data-active="true"] { font-weight: 700; }
.bc-sep { color: var(--coni-blu); font-weight: 500; font-size: 15px; }

/* ============ PANEL (overlay card sopra la mappa, top+left+width dinamici) ============ */
.explore-panel {
  position: absolute;
  top: 28px;  /* JS aggiorna */
  left: 0;    /* JS aggiorna */
  z-index: 2;
  width: 320px;
  height: min(520px, calc(100% - 56px));
  overflow-y: auto;
  scrollbar-gutter: stable;
  background: rgba(255, 255, 255, 0.94);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--hair);
  border-radius: 12px;
  padding: 20px 20px 22px;
  box-shadow: 0 16px 48px -16px rgba(14, 17, 23, 0.2);
  transition:
    top .6s cubic-bezier(.4, 0, .2, 1),
    left .6s cubic-bezier(.4, 0, .2, 1),
    width .6s cubic-bezier(.4, 0, .2, 1),
    height .6s cubic-bezier(.4, 0, .2, 1),
    padding .6s cubic-bezier(.4, 0, .2, 1);
}

/* Overview: stesso stile e dimensioni di province/comune (ereditate da .explore-panel) */
@media (max-width: 768px) {
  .explore-panel {
    position: static;
    width: calc(100% - 48px);
    margin: 16px auto 0;
    max-height: none;
    right: auto; top: auto;
  }
}
.panel-title {
  font-family: var(--serif); font-weight: 600; font-size: 22px;
  line-height: 1.15; letter-spacing: -.02em;
  color: var(--ink); margin-bottom: 12px;
}
/* Header scheda: titolo sopra + bottoni back sotto (stack verticale) */
.panel-head {
  display: flex; flex-direction: column; align-items: flex-start;
  gap: 8px; margin-bottom: 14px;
}
.panel-head .panel-title { margin-bottom: 0; }
.panel-back-btn {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--sans); font-weight: 600; font-size: 13px;
  color: #ffffff;
  background: var(--coni-blu);
  border: 1px solid var(--coni-blu);
  padding: 6px 14px; border-radius: 999px;
  cursor: pointer; line-height: 1;
  margin-bottom: 14px;
  transition: background .2s, transform .15s, box-shadow .2s, border-color .2s;
}
.panel-back-btn:hover {
  background: var(--coni-blu-lo);
  border-color: var(--coni-blu-lo);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px -4px rgba(0, 51, 160, .45);
}
.panel-back-btn:active { transform: translateY(0); }
.panel-back-btn span[aria-hidden] { font-size: 15px; line-height: 1; }
.panel-sub {
  font-size: 13px; color: var(--muted); font-weight: 500;
  letter-spacing: .04em;
  margin-bottom: 12px;
}
.panel-stats {
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 0; border: 1px solid var(--hair); border-radius: 7px;
  margin-bottom: 12px;
}
.panel-stat {
  padding: 9px 16px;
  border-right: 1px solid var(--hair);
  border-bottom: 1px solid var(--hair);
}
.panel-stat:nth-child(2n) { border-right: 0; }
.panel-stat:nth-last-child(-n+2) { border-bottom: 0; }
.panel-stat strong {
  font-family: var(--serif); font-weight: 600;
  font-size: 23px; color: var(--coni-blu);
  display: block; line-height: 1; letter-spacing: -.02em;
  margin-bottom: 4px;
}
.panel-stat span {
  font-size: 11px; color: var(--muted);
  font-weight: 500; letter-spacing: .02em;
}

.panel-section-title {
  font-family: var(--sans); font-size: 12px; font-weight: 600;
  text-transform: uppercase; letter-spacing: .1em;
  color: var(--muted); margin: 24px 0 12px;
}

.panel-table {
  width: 100%; border-collapse: collapse; font-size: 12px;
}
.panel-table th {
  text-align: left; padding: 8px 6px;
  font-size: 10px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .08em; color: var(--muted);
  border-bottom: 1px solid var(--hair-strong);
}
.panel-table th.num { text-align: right; }
.panel-table td {
  padding: 7px 6px;
  border-bottom: 1px solid var(--hair);
  vertical-align: top;
}
.panel-table td.num {
  text-align: right; font-variant-numeric: tabular-nums;
  font-weight: 500; color: var(--ink);
}
.panel-table tbody tr { transition: background .15s; }
.panel-table tbody tr.is-clickable { cursor: pointer; }
.panel-table tbody tr.is-clickable:hover { background: rgba(0, 51, 160, .035); }
.panel-table tbody tr:last-child td { border-bottom: 0; }

/* Micro-CTA verso mappa pubblica, nell'overview Emilia-Romagna */
.panel-micro-cta {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 14px;
  font-family: var(--sans); font-size: 12px; font-weight: 600;
  color: var(--coni-blu);
  transition: gap .2s var(--easing), color .2s;
}
.panel-micro-cta:hover { color: var(--coni-blu-hi); gap: 10px; }

.panel-actions {
  margin-top: 20px; display: flex; gap: 10px; flex-wrap: wrap;
}
.panel-actions > .nav-cta-outline,
.panel-actions > .nav-cta { flex: 1 1 0; min-width: 0; }
.panel-action {
  font-size: 13px; font-weight: 500;
  padding: 8px 14px; border-radius: 6px;
  border: 1px solid var(--hair-strong);
  color: var(--ink);
  transition: all .2s;
}
.panel-action:hover { background: var(--ink); color: #fff; border-color: var(--ink); }
/* CTA login nel panel: riusa .nav-cta, solo reset del margin-left auto */
.panel-nav-cta { margin-left: 0 !important; }

.panel-empty {
  padding: 60px 10px;
  text-align: center; color: var(--muted);
  font-family: var(--serif); font-size: 18px; line-height: 1.5;
}

/* ============ AT ATLAS (dark) ============ */
.at-atlas {
  min-height: 100vh;
  background: var(--dark) url('/assets/sport-mark-dark.svg') center / cover no-repeat;
  color: #fff;
  padding: 100px 0 0;
  position: relative;
  overflow: hidden;
  display: flex; flex-direction: column;
}
.at-atlas > .wrap {
  flex: 1; display: flex; flex-direction: column; justify-content: center;
  padding-bottom: 60px;
}
.at-atlas::before {
  content: ''; position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 40% at 20% 20%, rgba(0,51,160,.25), transparent 65%),
    radial-gradient(ellipse 55% 40% at 80% 85%, rgba(200,90,60,.18), transparent 65%);
  pointer-events: none;
}
.at-atlas > .wrap { position: relative; z-index: 2; }
.at-head { max-width: 820px; margin: 0 auto 48px; text-align: center; }
.at-head .at-lead { margin-left: auto; margin-right: auto; }
.at-kicker { color: var(--coni-blu-hi); }
.at-kicker::before { background: var(--coni-blu-hi); }
.at-title {
  font-family: var(--serif); font-weight: 600;
  font-size: clamp(36px, 5vw, 56px);
  line-height: 1.05; letter-spacing: -.025em;
  color: #fff;
}
.at-title em { font-style: italic; font-weight: 400; color: var(--coni-blu-hi); }
.at-title { text-wrap: balance; }
.at-lead {
  font-family: var(--serif); font-size: 19px; line-height: 1.6;
  color: rgba(255,255,255,.72);
  margin-top: 20px; max-width: 680px;
  hyphens: none; word-break: keep-all; overflow-wrap: normal;
  text-wrap: pretty;
}

.at-cards {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--line);
}
@media (max-width: 900px) { .at-cards { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .at-cards { grid-template-columns: 1fr; } }

.at-card {
  position: relative;
  padding: 40px 28px 32px;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 12px;
  transition: background .25s var(--easing);
  color: #fff;
}
.at-cards .at-card:nth-child(4n) { border-right: 0; }
@media (max-width: 900px) { .at-cards .at-card:nth-child(4n) { border-right: 1px solid var(--line); } .at-cards .at-card:nth-child(2n) { border-right: 0; } }
@media (max-width: 560px) { .at-cards .at-card:nth-child(2n) { border-right: 1px solid var(--line); } }
.at-card::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0;
  width: 2px; background: var(--coni-blu-hi);
  transform: scaleY(0); transform-origin: top;
  transition: transform .3s var(--easing);
}
.at-card:hover { background: rgba(255,255,255,.04); }
.at-card:hover::before { transform: scaleY(1); }
.at-card.is-wip { opacity: .62; cursor: not-allowed; }
.at-card.is-wip:hover { background: transparent; }
.at-card.is-wip:hover::before { transform: scaleY(0); }
.at-card.is-wip .at-card-link { color: rgba(255,255,255,.45); }
.at-card.is-wip:hover .at-card-link { gap: 6px; }
.at-card-num {
  font-family: var(--serif); font-style: italic;
  font-size: 18px; color: var(--coni-blu-hi);
}
.at-card h3 {
  font-family: var(--serif); font-weight: 600; font-size: 24px;
  letter-spacing: -.015em;
}
.at-card p {
  color: rgba(255,255,255,.7); font-size: 15px;
  line-height: 1.55; flex: 1;
}
.at-card-link {
  font-size: 13px; font-weight: 500; color: var(--coni-blu-hi);
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 8px;
  transition: gap .2s;
}
.at-card:hover .at-card-link { gap: 10px; }

/* ============ MAPPA COMING-SOON (pagina /mappa pre-firma CONI) ============ */
.mappa-coming {
  flex: 1; min-height: 0;
  display: flex; align-items: center;
  background: var(--cream, #faf7f0);
  padding: 100px 0 40px;
}
/* Pagina coming-soon: header + hero + footer in una sola viewport */
body:has(.mappa-coming) {
  min-height: 100vh;
  display: flex; flex-direction: column;
}
.mappa-coming-wrap { max-width: 760px; text-align: left; }
.mappa-coming-kicker {
  font-family: var(--sans); font-size: 12px; font-weight: 600;
  letter-spacing: .18em; text-transform: uppercase;
  color: var(--coni-blu-hi);
  margin-bottom: 24px;
}
.mappa-coming-title {
  font-family: var(--serif); font-weight: 600;
  font-size: clamp(36px, 5.5vw, 64px);
  line-height: 1.08; letter-spacing: -0.015em;
  color: var(--ink, #0a0a0a);
  margin-bottom: 28px;
}
.mappa-coming-title em {
  font-style: italic; color: var(--coni-blu);
}
.mappa-coming-lead {
  font-family: var(--serif); font-size: 19px; line-height: 1.6;
  color: var(--ink-soft, #3a3a3a);
  margin-bottom: 40px; max-width: 620px;
}
.mappa-coming-lead strong { font-weight: 600; color: var(--ink, #0a0a0a); }
.mappa-coming-cta { display: flex; flex-wrap: wrap; gap: 14px; }

/* ============ FOOTER ============ */
.footer {
  background: var(--dark-2); color: rgba(255,255,255,.7);
  padding: 40px 0 20px;
  border-top: 1px solid var(--line);
}
.footer .footer-grid { margin-bottom: 28px; gap: 48px; }
.footer .footer-bottom { padding-top: 16px; margin-top: 10px; }
/* Footer integrato in pagina 3 (at-atlas): trasparente sulla dark della sezione */
.at-atlas > .footer {
  background: transparent;
  position: relative; z-index: 2;
}
.footer .brand { color: #fff; }
.footer-grid {
  display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 64px;
  margin-bottom: 56px;
}
@media (max-width: 760px) { .footer-grid { grid-template-columns: 1fr; gap: 40px; } }
.footer-col h4 {
  font-family: var(--sans); font-size: 12px; font-weight: 600;
  letter-spacing: .14em; text-transform: uppercase;
  color: #fff; margin-bottom: 18px;
}
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.footer-col a { font-size: 14px; transition: color .2s; }
.footer-col a:hover { color: var(--coni-blu-hi); }
.footer-about p {
  font-family: var(--serif); font-size: 16px; line-height: 1.55;
  color: rgba(255,255,255,.65); max-width: 380px;
}
.footer-about .brand { margin-bottom: 20px; }

.compliance {
  padding: 20px 0; border-top: 1px solid var(--line);
  display: flex; flex-wrap: wrap; gap: 12px 24px;
  font-size: 13px; color: rgba(255,255,255,.55);
}
.compliance-item { display: inline-flex; align-items: center; gap: 8px; }
.compliance-item::before {
  content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--coni-blu);
  box-shadow: 0 0 8px rgba(0, 51, 160, .5);
}
.footer-bottom {
  padding-top: 24px; border-top: 1px solid var(--line); margin-top: 20px;
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px;
  font-size: 13px; color: rgba(255,255,255,.5);
}
.footer-bottom .made-for {
  font-size: 12px; letter-spacing: .02em; color: rgba(255,255,255,.55);
}

/* ============ LOGIN / INVITE / ATTESA APPROVAZIONE ============ */
.login-page {
  flex: 1;
  background: var(--cream);
  display: flex; align-items: center; justify-content: center;
  padding: 120px 20px 60px;
  position: relative;
}
.login-page::before {
  /* Sfondo voronoi identico al hero landing (pagina 1): stessa size/posizione/opacità */
  content: '';
  position: absolute; inset: 0;
  background: url('/assets/voronoi-bg.svg?v=2') center 20% / 165% no-repeat;
  opacity: .22;
  pointer-events: none;
  z-index: 0;
}
body:has(.login-page) {
  min-height: 100vh;
  display: flex; flex-direction: column;
  scroll-snap-type: none;
}
body:has(.login-page) > .footer { flex-shrink: 0; }
.login-container {
  width: 100%; max-width: 440px;
  position: relative; z-index: 1;
}
.login-card {
  background: #fff;
  border: 1px solid var(--hair);
  border-radius: 16px;
  padding: 40px 36px 32px;
  box-shadow: 0 16px 48px -18px rgba(14, 17, 23, .12);
}
.login-header {
  text-align: center;
  margin-bottom: 28px;
}
.login-logo {
  width: 52px; height: 52px;
  margin: 0 auto 18px;
  display: inline-flex; align-items: center; justify-content: center;
}
.login-logo img,
.login-logo svg {
  width: 100%; height: 100%; display: block;
}
.login-title {
  font-family: var(--serif); font-weight: 600;
  font-size: 30px; line-height: 1.15;
  letter-spacing: -.018em;
  color: var(--ink);
  margin-bottom: 6px;
}
.login-subtitle {
  font-family: var(--sans); font-size: 14px;
  color: var(--muted);
  line-height: 1.5;
}
.login-body { display: flex; flex-direction: column; gap: 18px; }
.login-footer {
  margin-top: 22px; padding-top: 20px;
  border-top: 1px solid var(--hair);
  text-align: center;
  font-size: 13px; color: var(--muted); line-height: 1.5;
}

/* Alerts */
.login-alert {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 12px 14px;
  border-radius: 8px;
  font-size: 14px; line-height: 1.4;
}
.login-alert svg { flex-shrink: 0; width: 16px; height: 16px; margin-top: 2px; }
.login-alert-error {
  background: rgba(200, 90, 60, .08);
  color: var(--terra-lo);
  border: 1px solid rgba(200, 90, 60, .22);
}

/* Form */
.form-group { display: flex; flex-direction: column; gap: 6px; }
.form-label {
  font-family: var(--sans); font-size: 13px; font-weight: 500;
  color: var(--ink);
  letter-spacing: .005em;
}
.input {
  width: 100%;
  font-family: var(--sans); font-size: 15px;
  padding: 11px 14px;
  border: 1px solid var(--hair-strong);
  border-radius: 8px;
  background: #fff;
  color: var(--ink);
  transition: border-color .2s var(--easing), box-shadow .2s var(--easing);
  -webkit-appearance: none; appearance: none;
}
.input::placeholder { color: rgba(107, 107, 107, .6); }
.input:focus {
  outline: none;
  border-color: var(--coni-blu);
  box-shadow: 0 0 0 3px rgba(0, 51, 160, .12);
}
.input-error { border-color: var(--terra); }
.input-error:focus { box-shadow: 0 0 0 3px rgba(200, 90, 60, .18); }

.password-wrapper { position: relative; }
.password-wrapper .input { padding-right: 44px; }
.password-toggle {
  position: absolute; top: 50%; right: 8px;
  transform: translateY(-50%);
  width: 32px; height: 32px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--muted);
  border-radius: 6px;
  transition: color .15s, background .15s;
}
.password-toggle:hover { color: var(--ink); background: rgba(0, 51, 160, .06); }

/* Password requirements */
.password-requirements {
  background: var(--cream-2);
  border: 1px solid var(--hair);
  border-radius: 8px;
  padding: 12px 14px;
  display: flex; flex-direction: column; gap: 6px;
}
.password-requirements p {
  font-size: 12px; font-weight: 600;
  color: var(--muted);
  text-transform: uppercase; letter-spacing: .08em;
  margin-bottom: 2px;
}
.password-req-item {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px;
  color: var(--muted);
}
.password-req-item svg {
  width: 14px; height: 14px; flex-shrink: 0;
}
.password-req-item.met { color: var(--coni-blu); }
.password-req-item.unmet { color: var(--muted); }

.form-error {
  font-size: 12px; color: var(--terra-lo);
  min-height: 14px;
  opacity: 0;
  transition: opacity .15s;
}
.form-error.visible { opacity: 1; }

/* Checkbox privacy/ToS */
.checkbox-group {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 13px; line-height: 1.5; color: var(--muted);
}
.checkbox-group input[type="checkbox"] {
  margin-top: 3px; flex-shrink: 0;
  width: 16px; height: 16px;
  accent-color: var(--coni-blu);
  cursor: pointer;
}
.checkbox-group label { cursor: pointer; }
.checkbox-group a { color: var(--coni-blu); font-weight: 500; }
.checkbox-group a:hover { text-decoration: underline; }

/* CTA principale login */
.btn-login {
  width: 100%;
  padding: 13px 24px;
  margin-top: 4px;
  justify-content: center;
  font-size: 15px;
}
.btn-login:disabled {
  opacity: .5;
  cursor: not-allowed;
  transform: none !important;
  box-shadow: none !important;
}

/* Spinner */
.spinner {
  width: 16px; height: 16px;
  border: 2px solid rgba(255, 255, 255, .35);
  border-top-color: #fff;
  border-radius: 50%;
  animation: login-spin .7s linear infinite;
  display: inline-block;
}
@keyframes login-spin { to { transform: rotate(360deg); } }

/* View enter animation */
.view-enter {
  animation: login-fade .35s var(--easing);
}
@keyframes login-fade {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Vista attesa approvazione */
.conferma-email-body {
  text-align: center;
  padding: 12px 0;
  display: flex; flex-direction: column; align-items: center; gap: 12px;
}
.conferma-email-body h2 {
  font-family: var(--serif); font-weight: 600;
  font-size: 22px; letter-spacing: -.015em;
  color: var(--ink);
  margin-top: 4px;
}
.conferma-email-body p {
  font-size: 14px; color: var(--muted); line-height: 1.55;
  max-width: 340px;
}
.attesa-icon {
  width: 56px; height: 56px;
  color: var(--coni-blu);
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(0, 51, 160, .08);
  border-radius: 50%;
  margin-bottom: 8px;
}
.attesa-icon svg { width: 28px; height: 28px; }

/* Responsive */
@media (max-width: 768px) {
  .login-page { padding: 100px 20px 48px; }
  /* iOS Safari fa auto-zoom al focus su input con font-size <16px → 16px obbligatorio */
  .login-page .input { font-size: 16px; }
  /* Voronoi login segue lo stesso scaling del hero mobile per coerenza visiva */
  .login-page::before {
    background-size: 380%;
    background-position: center 25%;
  }
}
@media (max-width: 480px) {
  .login-page {
    padding: clamp(72px, 22vw, 96px) clamp(14px, 4.2vw, 20px) clamp(28px, 8.6vw, 40px);
  }
  .login-card {
    padding: clamp(22px, 6.6vw, 30px) clamp(16px, 4.9vw, 22px) clamp(20px, 6vw, 26px);
    border-radius: clamp(12px, 3.6vw, 14px);
  }
  .login-header { margin-bottom: clamp(18px, 5.4vw, 24px); }
  .login-logo {
    width: clamp(40px, 12vw, 50px);
    height: clamp(40px, 12vw, 50px);
    margin-bottom: clamp(12px, 3.6vw, 16px);
  }
  .login-title {
    font-size: clamp(22px, 6.6vw, 28px);
    line-height: 1.12;
  }
  .login-subtitle {
    font-size: clamp(12px, 3.6vw, 13.5px);
    margin-top: clamp(4px, 1.2vw, 6px);
  }
  .login-body { gap: clamp(12px, 3.6vw, 16px); }
  .form-label { font-size: clamp(12px, 3.4vw, 13px); }
  .input {
    font-size: 16px; /* ancora 16px esplicito per impedire auto-zoom iOS */
    padding: clamp(10px, 3vw, 12px) clamp(12px, 3.6vw, 14px);
  }
  .password-requirements {
    padding: clamp(10px, 3vw, 12px) clamp(12px, 3.6vw, 14px);
    gap: clamp(4px, 1.2vw, 6px);
  }
  .password-requirements p { font-size: clamp(10.5px, 3vw, 12px); }
  .password-req-item { font-size: clamp(12px, 3.4vw, 13px); }
  .checkbox-group { font-size: clamp(12px, 3.4vw, 13px); }
  .btn-login {
    font-size: clamp(14px, 4vw, 15.5px);
    padding: clamp(11px, 3.3vw, 13px) clamp(18px, 5.4vw, 24px);
  }
  .login-footer {
    font-size: clamp(11.5px, 3.3vw, 13px);
    margin-top: clamp(16px, 4.8vw, 22px);
    padding-top: clamp(14px, 4.2vw, 20px);
  }
}

/* ============ PAGINE LEGALI (privacy / cookie / ToS) ============ */
.legal-page-wrap {
  flex: 1;
  background: var(--cream);
  padding: 130px 0 80px;
  position: relative;
}
body:has(.legal-page-wrap) {
  min-height: 100vh;
  display: flex; flex-direction: column;
  scroll-snap-type: none;
}
body:has(.legal-page-wrap) > .footer { flex-shrink: 0; }
.legal-page {
  max-width: 760px;
  margin: 0 auto;
  padding: 0 32px;
  font-family: var(--sans);
  color: var(--ink);
}
@media (max-width: 640px) { .legal-page { padding: 0 20px; } }
.legal-page h1 {
  font-family: var(--serif); font-weight: 600;
  font-size: clamp(28px, 4vw, 38px);
  line-height: 1.15; letter-spacing: -.018em;
  color: var(--ink);
  margin-bottom: 10px;
  display: flex; flex-wrap: wrap; align-items: baseline; gap: 12px;
}
.legal-page .version-badge {
  display: inline-block;
  font-family: var(--sans); font-size: 12px; font-weight: 500;
  letter-spacing: .04em;
  color: var(--coni-blu);
  background: rgba(0, 51, 160, .08);
  border: 1px solid rgba(0, 51, 160, .18);
  border-radius: 999px;
  padding: 3px 10px;
  margin-left: 0;
}
.legal-page .subtitle {
  font-family: var(--serif); font-size: 17px;
  color: var(--muted);
  line-height: 1.5;
  margin-bottom: 40px;
}
.legal-page h2 {
  font-family: var(--serif); font-weight: 600;
  font-size: 22px; line-height: 1.25; letter-spacing: -.01em;
  color: var(--ink);
  margin-top: 42px;
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--hair);
}
.legal-page h3 {
  font-family: var(--sans); font-weight: 600;
  font-size: 15px; letter-spacing: .01em;
  color: var(--ink);
  margin-top: 24px;
  margin-bottom: 10px;
}
.legal-page p,
.legal-page li {
  font-family: var(--sans); font-size: 15px;
  line-height: 1.65;
  color: var(--ink);
  margin-bottom: 12px;
}
.legal-page strong { color: var(--ink); font-weight: 600; }
.legal-page a {
  color: var(--coni-blu); font-weight: 500;
  text-decoration: underline; text-underline-offset: 2px;
  text-decoration-color: rgba(0, 51, 160, .35);
  transition: text-decoration-color .15s;
}
.legal-page a:hover { text-decoration-color: var(--coni-blu); }
.legal-page ul {
  padding-left: 22px;
  margin-bottom: 16px;
}
.legal-page ul li { margin-bottom: 6px; }

.legal-page table {
  width: 100%; border-collapse: collapse;
  margin: 16px 0 24px;
  font-size: 14px;
  background: #fff;
  border: 1px solid var(--hair);
  border-radius: 8px;
  overflow: hidden;
}
.legal-page table th,
.legal-page table td {
  padding: 12px 14px;
  border-bottom: 1px solid var(--hair);
  text-align: left;
  vertical-align: top;
  color: var(--ink);
}
.legal-page table th {
  background: var(--cream-2);
  font-family: var(--sans); font-weight: 600;
  font-size: 12px; letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--muted);
}
.legal-page table tr:last-child td { border-bottom: 0; }
.legal-page code {
  font-family: 'SF Mono', 'Menlo', 'Consolas', monospace;
  font-size: 13px;
  background: var(--cream-2);
  border: 1px solid var(--hair);
  border-radius: 4px;
  padding: 1px 6px;
  color: var(--coni-blu-lo);
}

.legal-page .placeholder {
  display: inline-block;
  background: #FFF8E1;
  border: 1px solid #F4C430;
  border-radius: 4px;
  padding: 1px 8px;
  font-family: var(--sans); font-size: 13px; font-weight: 500;
  color: #8A6D1F;
}

/* Cookie policy specifici */
.legal-page .badge {
  display: inline-block;
  border-radius: 999px;
  padding: 2px 10px;
  font-size: 11px; font-weight: 600;
  letter-spacing: .04em;
}
.legal-page .badge-green {
  background: rgba(0, 51, 160, .08);
  color: var(--coni-blu);
  border: 1px solid rgba(0, 51, 160, .2);
}
.legal-page .badge-blue {
  background: rgba(200, 90, 60, .08);
  color: var(--terra-lo);
  border: 1px solid rgba(200, 90, 60, .22);
}
.legal-page .info-box {
  background: #fff;
  border: 1px solid var(--hair);
  border-left: 3px solid var(--coni-blu);
  border-radius: 8px;
  padding: 16px 18px;
  margin: 8px 0 28px;
}
.legal-page .info-box p:last-child { margin-bottom: 0; }

/* Footer doc (hr + dicitura piccola) */
.legal-page hr {
  border: 0;
  border-top: 1px solid var(--hair);
  margin: 48px 0 18px;
}
.legal-page > p:last-child {
  font-size: 13px; color: var(--muted);
}

/* ============ FOCUS / A11Y ============ */
a:focus-visible,
button:focus-visible,
.btn:focus-visible,
.nav-cta:focus-visible {
  outline: 2px solid var(--coni-blu);
  outline-offset: 3px;
  border-radius: 4px;
}
.btn:focus-visible, .nav-cta:focus-visible { border-radius: 999px; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
  }
  html { scroll-behavior: auto; }
}

/* ============================================================
   MOBILE RESPONSIVE — Additive only, zero modifiche desktop
   Breakpoint: ≤768px (tablet), ≤480px (phone)
   ============================================================ */

/* ---------- TABLET (≤768px) ---------- */
@media (max-width: 768px) {
  /* ═══ Freeze Safari toolbar ═══
     Su iOS Safari la toolbar in basso è dinamica: appare/scompare in base
     allo scroll del documento root (html). Quando si nasconde, il viewport
     cresce e la pagina si riposiziona (scatto).
     Fix: html è fisso al viewport, lo scroll avviene DENTRO body.
     Safari non tocca la toolbar se scrolla un container interno. */
  html {
    height: 100vh;
    height: 100lvh;
    overflow: hidden;
    scroll-snap-type: none;
  }
  body {
    height: 100vh;
    height: 100lvh;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: y mandatory;
    overscroll-behavior-y: contain;
  }

  /* Scroll-snap sulle 3 sezioni (ora lo scroll container è body) */
  .hero, .explore, .at-atlas {
    scroll-snap-align: start;
    scroll-snap-stop: always;
  }

  /* ═══ Sezione = viewport MASSIMO (lvh) ═══
     Su Safari iOS la toolbar in basso è semi-trasparente e copre dinamicamente
     parte del viewport. Con 100dvh la sezione si accorcia quando la toolbar
     compare → la sezione successiva sbuca sotto la toolbar.
     Con 100lvh la sezione è sempre alta quanto il viewport massimo:
     la toolbar copre la stessa sezione (non il bordo tra due). */
  .hero,
  .explore,
  .at-atlas {
    height: 100vh;
    height: 100lvh;
    min-height: 100vh;
    min-height: 100lvh;
    max-height: 100vh;
    max-height: 100lvh;
    overflow: hidden;
  }

  /* Header: nav CTA più compatti */
  .site-header { padding: 14px 0; }
  .site-header .wrap { gap: 16px; }
  .brand { font-size: 19px; }
  .brand-mark { width: 32px; height: 32px; }

  /* HERO: padding (height gestito sopra nel blocco viewport) */
  .hero {
    padding: 100px 0 72px;
  }
  .hero::before {
    background-size: 380%;
    background-position: center 25%;
  }
  .hero-title { margin-bottom: 32px; }
  .hero-kpis { gap: 36px; margin-bottom: 36px; padding-top: 20px; }

  /* ESPLORA: una sola viewport, mappa sopra + panel scrollabile sotto */
  .explore {
    padding: 60px 0 16px;
    display: flex; flex-direction: column;
    overflow: hidden;
  }
  .explore::before {
    background-size: cover;
    background-position: center top;
  }
  .explore > .wrap { flex: 0 0 auto; }
  .explore-map-stage {
    flex: 1 1 auto;
    min-height: 0;
    display: flex; flex-direction: column;
  }
  .explore-map {
    position: relative;
    inset: auto;
    flex: 0 0 50%;
    min-height: 0;
    height: auto;
  }
  .explore-breadcrumb {
    left: 20px; bottom: 20px;
    font-size: 13px;
    padding: 5px 9px;
  }
  .explore-breadcrumb .bc-item {
    font-size: 13px;
    padding: 6px 12px;
  }
  .explore-breadcrumb .bc-sep { font-size: 13px; }
  /* Panel: flex-fill con scroll interno, NON fa crescere la sezione */
  .explore-panel {
    position: static;
    flex: 1 1 auto;
    min-height: 0;
    max-height: none;
    width: 100%;
    height: auto;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
    margin: 12px 0 0;
    padding: 14px 18px 20px;
    border-radius: 0;
    border-left: 0;
    border-right: 0;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    background: #fff;
  }
  /* Panel content compatto sui phone */
  .panel-head { margin-bottom: 10px; gap: 6px; }
  .panel-title { font-size: 19px; margin-bottom: 0; }
  .panel-sub { font-size: 12px; margin-bottom: 10px; }
  .panel-stats { margin-bottom: 10px; }
  .panel-stat { padding: 6px 12px; }
  .panel-stat strong { font-size: 20px; }
  .panel-stat span { font-size: 10px; }
  .panel-section-title { font-size: 11px; margin: 16px 0 8px; }
  .panel-table { font-size: 13px; }
  .panel-table th { padding: 6px 4px; font-size: 10px; }
  .panel-table td { padding: 10px 4px; }
  .panel-actions { margin-top: 14px; }
  .panel-action { font-size: 12px; padding: 7px 12px; }

  /* AT ATLAS */
  .at-atlas { padding: 72px 0 0; }
  .at-title { font-size: clamp(32px, 5.5vw, 48px); }
  .at-lead { font-size: 17px; }

  /* MAPPA COMING-SOON */
  .mappa-coming { padding: 80px 0 40px; }
  .mappa-coming-title { margin-bottom: 20px; }
  .mappa-coming-lead { font-size: 17px; margin-bottom: 28px; }

  /* LEGAL PAGES: padding laterale + tabelle scrollabili su x */
  .legal-page-wrap { padding: 110px 0 60px; }
  .legal-page { padding: 0 20px; }
  .legal-page table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    max-width: 100%;
  }
}

/* ---------- MOBILE PHONE (≤480px) — SCALA PROPORZIONALE CON vw ----------
   Ogni size usa clamp(minPx, Xvw, maxPx) dove X = valore_px_@_390px * 100/390.
   Range bloccato ±15% per garantire leggibilità estremi (320-480). */
@media (max-width: 480px) {
  /* Edge-consistent + scrollbar reset */
  .wrap {
    max-width: 100%;
    padding-left: max(20px, env(safe-area-inset-left));
    padding-right: max(20px, env(safe-area-inset-right));
    margin: 0 auto;
  }
  html { scrollbar-gutter: auto; }

  /* Height delle 3 sezioni gestito nel blocco ≤768, qui solo login/mappa-coming */
  body:has(.login-page),
  body:has(.mappa-coming) {
    min-height: 100svh;
    min-height: 100dvh;
  }

  /* Header */
  .site-header { padding: clamp(8px, 2.6vw, 12px) 0; }
  .brand {
    font-size: clamp(13px, 3.85vw, 17px);
    gap: clamp(6px, 2vw, 9px);
    white-space: nowrap; flex-shrink: 0;
  }
  .brand-mark {
    width: clamp(20px, 6.2vw, 28px);
    height: clamp(20px, 6.2vw, 28px);
  }
  .nav-cta-outline,
  .nav-cta {
    font-size: clamp(9px, 2.7vw, 11.5px);
    padding: clamp(8px, 2.4vw, 10px) clamp(8px, 2.4vw, 11px);
  }
  /* Override min-width base (160px): su mobile si adatta al contenuto */
  .site-nav > .nav-cta-outline,
  .site-nav > .nav-cta { min-width: 0; }
  .site-nav { gap: clamp(4px, 1.2vw, 6px); }

  /* HERO */
  .hero {
    padding: clamp(60px, 18.5vw, 82px) 0 clamp(20px, 6vw, 28px);
    display: flex; align-items: center;
    overflow: hidden;
  }
  .hero-title {
    font-size: clamp(26px, 7.7vw, 34px);
    line-height: 1.1;
    margin-bottom: clamp(20px, 6vw, 28px);
    letter-spacing: -.02em;
  }
  .hero-kpis {
    padding-top: clamp(12px, 4vw, 18px);
    margin-bottom: clamp(20px, 6vw, 28px);
    gap: clamp(20px, 6vw, 28px);
  }
  .hero-kpis dt { font-size: clamp(19px, 5.6vw, 25px); }
  .hero-kpis dd { font-size: clamp(11.5px, 3.3vw, 14.5px); }
  .hero-cta { gap: clamp(8px, 2.5vw, 12px); }
  .btn {
    padding: clamp(10px, 3vw, 14px) clamp(16px, 5vw, 22px);
    font-size: clamp(12.5px, 3.6vw, 15.5px);
  }

  /* ESPLORA */
  .explore-title { font-size: clamp(24px, 7.2vw, 32px); line-height: 1.1; }
  .explore-lead { font-size: clamp(14px, 4vw, 17.5px); margin-top: clamp(12px, 3.6vw, 16px); }
  .section-kicker {
    font-size: clamp(10px, 2.8vw, 12px);
    margin-bottom: clamp(10px, 3vw, 13px);
  }
  .explore-breadcrumb {
    left: clamp(14px, 4vw, 18px);
    bottom: clamp(14px, 4vw, 18px);
    padding: clamp(4px, 1.3vw, 6px) clamp(7px, 2vw, 9px);
    font-size: clamp(11px, 3vw, 13px);
  }
  .explore-breadcrumb .bc-item {
    font-size: clamp(11px, 3vw, 13px);
    padding: clamp(5px, 1.6vw, 6px) clamp(10px, 3vw, 12px);
  }
  .explore-breadcrumb .bc-sep { font-size: clamp(11px, 3vw, 13px); }
  .explore-panel {
    padding: clamp(12px, 3.6vw, 16px) clamp(15px, 4.6vw, 20px) clamp(16px, 5vw, 22px);
  }
  .panel-head { margin-bottom: clamp(8px, 2.5vw, 12px); gap: clamp(5px, 1.5vw, 7px); }
  .panel-title { font-size: clamp(17px, 4.9vw, 21px); margin-bottom: 0; }
  .panel-sub { font-size: clamp(11px, 3.1vw, 13px); margin-bottom: clamp(8px, 2.5vw, 12px); }
  .panel-stats { margin-bottom: clamp(8px, 2.5vw, 12px); }
  .panel-stat { padding: clamp(5px, 1.6vw, 7.5px) clamp(10px, 3vw, 13px); }
  .panel-stat strong { font-size: clamp(17px, 5vw, 22px); }
  .panel-stat span { font-size: clamp(9px, 2.6vw, 11px); }
  .panel-section-title {
    font-size: clamp(10px, 2.8vw, 12px);
    margin: clamp(14px, 4vw, 18px) 0 clamp(7px, 2vw, 9px);
  }
  .panel-table { font-size: clamp(11.5px, 3.3vw, 14px); display: block; }
  .panel-table thead, .panel-table tbody { display: block; width: 100%; }
  .panel-table thead tr, .panel-table tbody tr {
    display: table; width: 100%; table-layout: fixed;
  }
  .panel-table tbody {
    max-height: clamp(136px, 40vw, 168px);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain;
  }
  .panel-table th {
    padding: clamp(5px, 1.5vw, 7px) clamp(3px, 1vw, 5px);
    font-size: clamp(9px, 2.6vw, 11px);
  }
  .panel-table td { padding: clamp(8px, 2.5vw, 11px) clamp(3px, 1vw, 5px); }
  .panel-actions { margin-top: clamp(12px, 3.6vw, 16px); }
  .panel-action {
    font-size: clamp(11px, 3.1vw, 13px);
    padding: clamp(6px, 1.8vw, 8px) clamp(10px, 3vw, 13px);
  }

  /* AT ATLAS: compattata al massimo per stare in 100dvh mobile —
     2x2 grid + padding/font ridotti, footer incluso sotto */
  .at-atlas {
    padding: clamp(52px, 15vw, 64px) 0 0;
    display: flex; flex-direction: column;
  }
  .at-atlas > .wrap { flex: 0 0 auto; }
  .at-head { margin-bottom: clamp(10px, 3vw, 14px); }
  .at-title { font-size: clamp(20px, 5.8vw, 26px); line-height: 1.1; }
  .at-lead {
    font-size: clamp(11.5px, 3.3vw, 13.5px);
    line-height: 1.45;
    margin-top: clamp(6px, 1.8vw, 8px);
  }
  /* Forza 2x2 (non 1 colonna) per far stare tutte le 4 card nel viewport */
  .at-cards { grid-template-columns: repeat(2, 1fr); }
  .at-cards .at-card:nth-child(2n) { border-right: 0; }
  .at-cards .at-card:nth-child(odd) { border-right: 1px solid var(--line); }
  .at-card {
    padding: clamp(10px, 3vw, 14px) clamp(10px, 3vw, 14px) clamp(8px, 2.4vw, 12px);
    gap: clamp(4px, 1.2vw, 6px);
  }
  .at-card-num { font-size: clamp(12px, 3.4vw, 14px); }
  .at-card h3 { font-size: clamp(13px, 3.8vw, 16px); letter-spacing: -.01em; }
  .at-card p {
    font-size: clamp(10.5px, 3vw, 12px);
    line-height: 1.35;
  }
  .at-card-link { font-size: clamp(10px, 2.8vw, 12px); margin-top: clamp(2px, .8vw, 4px); }

  /* Footer integrato in at-atlas: compact + ancorato al bottom della sezione */
  .at-atlas > .footer {
    flex: 0 0 auto;
    margin-top: auto;
    padding: clamp(10px, 3vw, 14px) 0 calc(env(safe-area-inset-bottom, 0px) + clamp(8px, 2.4vw, 10px));
  }
  .at-atlas > .footer .footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: clamp(14px, 4vw, 18px);
    margin-bottom: clamp(8px, 2.4vw, 10px);
  }
  .at-atlas > .footer .footer-about { display: none; }
  .at-atlas > .footer .footer-col h4 {
    font-size: clamp(9px, 2.6vw, 10px);
    margin-bottom: clamp(4px, 1.2vw, 6px);
    letter-spacing: .1em;
  }
  .at-atlas > .footer .footer-col ul { gap: clamp(3px, 1vw, 5px); }
  .at-atlas > .footer .footer-col a { font-size: clamp(10.5px, 3vw, 12px); }
  .at-atlas > .footer .footer-bottom {
    padding-top: clamp(6px, 1.8vw, 8px);
    margin-top: clamp(6px, 1.8vw, 8px);
    font-size: clamp(10px, 2.8vw, 11px);
    justify-content: center;
  }

  /* FOOTER compatto su login + mappa-coming (stesse regole di .at-atlas > .footer) */
  body:has(.login-page) > .footer,
  body:has(.mappa-coming) > .footer {
    padding: clamp(10px, 3vw, 14px) 0 calc(env(safe-area-inset-bottom, 0px) + clamp(8px, 2.4vw, 10px));
  }
  body:has(.login-page) > .footer .footer-grid,
  body:has(.mappa-coming) > .footer .footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: clamp(14px, 4vw, 18px);
    margin-bottom: clamp(8px, 2.4vw, 10px);
  }
  body:has(.login-page) > .footer .footer-about,
  body:has(.mappa-coming) > .footer .footer-about { display: none; }
  body:has(.login-page) > .footer .footer-col h4,
  body:has(.mappa-coming) > .footer .footer-col h4 {
    font-size: clamp(9px, 2.6vw, 10px);
    margin-bottom: clamp(4px, 1.2vw, 6px);
    letter-spacing: .1em;
  }
  body:has(.login-page) > .footer .footer-col ul,
  body:has(.mappa-coming) > .footer .footer-col ul { gap: clamp(3px, 1vw, 5px); }
  body:has(.login-page) > .footer .footer-col a,
  body:has(.mappa-coming) > .footer .footer-col a { font-size: clamp(10.5px, 3vw, 12px); }
  body:has(.login-page) > .footer .footer-bottom,
  body:has(.mappa-coming) > .footer .footer-bottom {
    padding-top: clamp(6px, 1.8vw, 8px);
    margin-top: clamp(6px, 1.8vw, 8px);
    font-size: clamp(10px, 2.8vw, 11px);
    justify-content: center;
  }

  /* MAPPA COMING-SOON */
  .mappa-coming { padding: clamp(60px, 18.5vw, 82px) 0 clamp(26px, 8vw, 36px); }
  .mappa-coming-kicker {
    font-size: clamp(10px, 2.8vw, 12px);
    margin-bottom: clamp(14px, 4.2vw, 20px);
    letter-spacing: .16em;
  }
  .mappa-coming-title {
    font-size: clamp(27px, 8.2vw, 37px);
    margin-bottom: clamp(14px, 4.6vw, 20px);
    line-height: 1.1;
  }
  .mappa-coming-lead {
    font-size: clamp(14px, 4vw, 17.5px);
    margin-bottom: clamp(20px, 6vw, 28px);
    line-height: 1.5;
  }
  .mappa-coming-cta {
    gap: clamp(10px, 3vw, 14px);
  }
  .mappa-coming-cta .btn {
    padding: clamp(10px, 3vw, 14px) clamp(14px, 4.2vw, 20px);
    font-size: clamp(12.5px, 3.6vw, 15.5px);
  }

  /* LEGAL PAGES */
  .legal-page-wrap { padding: clamp(80px, 24.6vw, 110px) 0 clamp(40px, 12.3vw, 54px); }
  .legal-page > h1 { font-size: clamp(24px, 7.2vw, 32px); }
  .legal-page h2 {
    font-size: clamp(16px, 4.9vw, 22px);
    margin-top: clamp(22px, 7vw, 32px);
  }
}

/* ---------- TOUCH DEVICES (senza hover reale) ----------
   Il browser mobile sintetizza :hover al tap e lo propaga al <g.province>:
   senza override, TUTTI i comuni della provincia toccata lampeggiano a
   --coni-blu-hi (highlight) perché .province:hover .comune e
   .is-active .comune:hover spingono al colore highlight.
   Soluzione: annulla l'effetto :hover riportando ciascun comune al colore
   del suo stato JS (.is-active, .is-selected-comune). */
@media (hover: none) {
  /* Province NON attive: tap non deve scurire → resta al base --coni-blu-hi */
  .explore-map .province:not(.is-active):hover .comune,
  .explore-map .province:not(.is-active).is-hover .comune {
    fill: var(--coni-blu-hi) !important;
  }
  /* Provincia attiva: tap sul <g> non deve toccare i comuni → restano --coni-blu */
  .explore-map .province.is-active:hover .comune,
  .explore-map .province.is-active.is-hover .comune {
    fill: var(--coni-blu) !important;
  }
  /* Tap su un comune dentro provincia attiva: niente highlight → resta --coni-blu */
  .explore-map .province.is-active .comune:hover {
    fill: var(--coni-blu) !important;
  }
  /* Il comune selezionato resta sempre --coni-blu-hi, anche sotto il dito */
  .explore-map .province.is-active .comune.is-selected-comune,
  .explore-map .province.is-active .comune.is-selected-comune:hover,
  .explore-map .province.is-active:hover .comune.is-selected-comune {
    fill: var(--coni-blu-hi) !important;
  }
  .explore-map .province .comune {
    transition: none !important;
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
  }
  .explore-map .province { -webkit-tap-highlight-color: transparent; }
}
