/* Build: 2026-05-12T04:22:29Z */
:root{
  --bg:#FAFAF7;--bg2:#fff;--bg3:#F4F2EC;--bg4:#ECEAE3;
  --border:#E2DFD7;--border2:#CDC9BE;
  --orange:#FC4C02;--orl:rgba(252,76,2,.08);--orm:rgba(252,76,2,.18);
  --o-mid:rgba(252,76,2,.10);--o-border:rgba(252,76,2,.22);
  --text:#100F0D;--text2:#54514A;--text3:#7C786F;
  --green:#16A34A;--red:#DC2626;
  --sans:'DM Sans',sans-serif;--serif:'DM Serif Display',serif;
  --sh-s:0 1px 2px rgba(0,0,0,.04);--sh-m:0 4px 14px rgba(0,0,0,.06);--sh-l:0 12px 32px rgba(0,0,0,.10);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{min-height:100%;background:var(--bg);color:var(--text);font-family:var(--sans);-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button,input,select{font-family:var(--sans)}

/* Header & top bar usano il design system .gx-hdr (vedi gpxt-design.css) */
/* Bottom navbar ora gestita da .gx-bnav (in fondo al body) */

/* ══ SETUP / LOGIN ══ */
#screen-setup{display:none;justify-content:center;padding:36px 16px}
.setup-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:18px;
  padding:28px;max-width:520px;width:100%;box-shadow:var(--sh-m);
}

/* Hero: logo+brand+tagline */
.login-hero{display:flex;align-items:center;gap:14px;margin-bottom:14px}
.login-logo svg{width:52px;height:52px;display:block;border-radius:11px;box-shadow:var(--sh-s)}
.login-hero-text{flex:1;min-width:0}
.login-brand{
  font-family:'Outfit',sans-serif;font-size:30px;font-weight:800;
  letter-spacing:-.6px;color:var(--orange);line-height:1;margin:0;
}
.login-tag{font-size:13px;color:var(--text3);margin-top:5px;line-height:1.35}

/* Descrizione */
.login-desc{
  font-size:13.5px;color:var(--text2);line-height:1.65;
  margin-bottom:20px;
}

/* Banner contestuale rate-limit / issue */
.login-issue{
  display:flex;gap:12px;align-items:flex-start;
  background:rgba(252,76,2,.06);border:1px solid var(--orm);
  border-radius:12px;padding:14px;margin-bottom:18px;
}
.login-issue .li-icn{
  width:22px;height:22px;color:var(--orange);flex-shrink:0;margin-top:1px;
}
.login-issue .li-title{font-size:13.5px;font-weight:700;color:var(--text);margin-bottom:4px}
.login-issue .li-text{font-size:12.5px;color:var(--text2);line-height:1.5}

/* CTA Strava: bottone arancione protagonista */
.login-cta{
  display:flex;align-items:center;justify-content:center;gap:10px;
  background:var(--orange);color:#fff;
  height:52px;border-radius:12px;font-size:16px;font-weight:700;
  text-decoration:none;letter-spacing:-.1px;
  box-shadow:0 4px 14px rgba(252,76,2,.28);
  transition:transform .15s,box-shadow .15s,filter .15s;
}
.login-cta:hover{filter:brightness(1.06);transform:translateY(-1px);box-shadow:0 6px 18px rgba(252,76,2,.34)}
.login-cta:active{transform:translateY(0);box-shadow:0 2px 8px rgba(252,76,2,.22)}
.login-cta-icn{width:20px;height:20px}

/* Trust micro line sotto il CTA */
.login-trust{
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-size:11.5px;color:var(--green);font-weight:600;
  margin-top:10px;margin-bottom:24px;line-height:1.3;
}
.login-trust svg{width:14px;height:14px;flex-shrink:0}

/* Feature grid: card minimaliste con icona SVG colorata */
.feat-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:18px;
}
.feat{
  background:var(--bg);border:1px solid var(--border);border-radius:12px;
  padding:14px 12px;display:flex;flex-direction:column;gap:6px;
  transition:border-color .15s,background .15s;
}
.feat:hover{border-color:var(--border2);background:var(--bg2)}
.feat-icn{width:22px;height:22px;flex-shrink:0;margin-bottom:2px}
.feat-t{font-size:13px;font-weight:700;color:var(--text);line-height:1.2}
.feat-d{font-size:11.5px;color:var(--text3);line-height:1.45}

/* v325 — Card "Estrai GPX da immagine": evidenziata come feature unica del
 * prodotto. Bordo arancione sottile + badge "Unico" angolo top-right.
 * Stesse dimensioni della card normale, solo styling diverso. */
.feat-unique{
  position:relative;
  border-color:var(--orange,#FC4C02);
  background:linear-gradient(135deg,rgba(252,76,2,.05) 0%,transparent 100%);
}
.feat-unique:hover{
  border-color:var(--orange,#FC4C02);
  background:linear-gradient(135deg,rgba(252,76,2,.08) 0%,rgba(252,76,2,.02) 100%);
}
.feat-badge{
  position:absolute;top:8px;right:8px;
  background:var(--orange,#FC4C02);color:#fff;
  font-size:9px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;
  padding:2px 6px;border-radius:4px;
  line-height:1.2;
}

/* Footer link */
.login-footer{
  display:flex;justify-content:center;padding-top:6px;border-top:1px solid var(--border);
  margin-top:6px;
}
.login-footer-link{
  display:flex;align-items:center;gap:7px;
  font-size:12px;color:var(--text3);font-weight:600;
  padding:10px 14px;border-radius:8px;
  transition:color .15s,background .15s;
}
.login-footer-link:hover{color:var(--orange);background:var(--orl)}
.login-footer-link svg{width:14px;height:14px}

@media(max-width:420px){
  .setup-card{padding:22px 18px;border-radius:14px}
  .login-brand{font-size:26px}
  .feat{padding:12px 10px}
  .feat-t{font-size:12.5px}
  .feat-d{font-size:11px}
}

/* Legacy classes (mantenute per compat con altri elementi) */
.warn{background:#FFF8F5;border:1px solid rgba(252,76,2,.3);border-radius:8px;padding:10px 13px;font-size:12px;color:#B03000;margin-top:10px;line-height:1.6}
.btn-orange{background:var(--orange);color:#fff;border:none;padding:0 20px;height:38px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:filter .15s;width:100%;margin-top:8px}
.btn-orange:hover{filter:brightness(1.08)}
.btn-orange:disabled{opacity:.45;cursor:default;filter:none}
.token-status{font-size:11px;padding:3px 9px;border-radius:20px;font-weight:500}
.token-status.ok{background:rgba(22,163,74,.1);color:var(--green);border:1px solid rgba(22,163,74,.25)}
.token-status.warn{background:rgba(252,76,2,.08);color:var(--orange);border:1px solid var(--orm)}

/* ══ APP ══ */
#screen-app{display:none}
.tabs-bar{background:var(--bg2);border-bottom:1px solid var(--border);display:flex;padding:0 20px}
.tab-btn.active{color:var(--orange);border-bottom-color:var(--orange);font-weight:600}

/* Filter bar */
.filter-bar{padding:7px 20px 7px 12px;display:flex;gap:6px;flex-wrap:wrap;align-items:center;border-bottom:1px solid var(--border);background:var(--bg2)}

/* ── FILTRI DENTRO LA MAPPA (colonna destra + popup esteso) ──────────────
 * La barra filtri tradizionale è stata spostata dentro #global-map-wrap.
 * I chip sport principali stanno in colonna verticale in alto a destra
 * (overlay sulla mappa). Il bottone "···" apre un popup a sinistra della
 * colonna con sport extra, date, geo e GPX. Su mobile il popup diventa
 * un bottom-sheet a tutta larghezza. */
.map-filters-col{
  position:absolute;top:12px;right:12px;z-index:600;
  display:flex;flex-direction:column;gap:6px;
  width:122px;pointer-events:none;
}
.map-filters-col > *{pointer-events:auto}
.map-filters-col .chip-row{
  display:flex;flex-direction:column;gap:6px;width:100%;flex-wrap:nowrap;
}
.map-filters-col .chip{
  flex:0 0 auto;width:100%;min-width:0;text-align:center;
  background:rgba(255,255,255,.94);
  -webkit-backdrop-filter:saturate(160%) blur(8px);
  backdrop-filter:saturate(160%) blur(8px);
  border:1px solid rgba(0,0,0,.06);
  border-radius:999px;
  box-shadow:0 1px 3px rgba(0,0,0,.08);
  font-size:12px;font-weight:600;
  padding:8px 10px;line-height:1.2;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.map-filters-col .chip.on{background:#1C1A17;color:#fff;border-color:#1C1A17}
.map-filters-col .chip-more{font-size:14px;padding:8px 10px;letter-spacing:1px}
.map-filters-col .chip-more.on,.map-filters-col .chip-more.open{
  background:var(--orange);color:#fff;border-color:var(--orange)
}
.map-filters-col .filter-summary,
.map-filters-col .btn-clear-all{display:none!important}

/* Popup esteso — appare a sinistra della colonna */
.map-filters-pop{
  position:absolute;top:12px;right:144px;z-index:610;
  display:none;flex-direction:column;gap:10px;
  width:min(360px,calc(100vw - 168px));
  max-height:calc(100% - 24px);
  overflow-y:auto;
  background:rgba(255,255,255,.98);
  -webkit-backdrop-filter:saturate(160%) blur(10px);
  backdrop-filter:saturate(160%) blur(10px);
  border:1px solid rgba(0,0,0,.08);
  border-radius:14px;
  box-shadow:0 8px 32px rgba(0,0,0,.18);
  padding:12px 14px;
}
.map-filters-pop.open{display:flex}
.map-filters-pop .fe-row{display:flex;flex-wrap:wrap;align-items:center;gap:6px;padding:4px 0}
.map-filters-pop .fe-row + .fe-row{border-top:1px solid var(--border);padding-top:8px;margin-top:2px}
.map-filters-pop #chip-row-extra{flex-wrap:wrap;width:100%}
.map-filters-pop #chip-row-extra .chip{flex:0 1 auto;width:auto;min-width:0;padding:6px 10px;font-size:12px}

/* Mobile: colonna chip più stretta, popup come bottom-sheet */
@media (max-width:560px){
  .map-filters-col{width:104px;top:8px;right:8px;gap:5px}
  .map-filters-col .chip{font-size:11px;padding:7px 9px}
  .map-filters-col .chip-more{font-size:13px;padding:7px 9px}
  .map-filters-pop{
    position:fixed;inset:auto 8px calc(72px + env(safe-area-inset-bottom,0px)) 8px;
    top:auto;right:auto;width:auto;
    max-height:60vh;
    border-radius:16px;
  }
}

/* Print */
@media print{.map-filters-col,.map-filters-pop{display:none!important}}
/* Riga dei chip principali: occupa tutta la larghezza senza andare a capo */
.chip-row{display:flex;gap:6px;flex-wrap:nowrap;width:100%;align-items:center}
.filter-extra{display:none;width:100%;flex-direction:column;gap:0;margin-top:6px;padding-top:6px;border-top:1px solid var(--border)}
.filter-extra.open{display:flex}
.fe-row{display:flex;flex-wrap:wrap;gap:6px;align-items:center;width:100%;padding:5px 0}
.fe-row+.fe-row{border-top:1px solid var(--border);padding-top:8px}
.geo-confirm-banner{display:none;position:fixed;top:0;left:0;right:0;z-index:9999;background:#fff;border-bottom:2px solid var(--orange);padding:10px 18px;align-items:center;gap:10px;box-shadow:0 2px 12px rgba(0,0,0,.15);pointer-events:all}
.geo-confirm-banner.visible{display:flex}
.geo-confirm-msg{font-size:13px;font-weight:600;color:var(--text);flex:1}
.geo-confirm-ok{background:var(--orange);color:#fff;border:none;padding:6px 16px;border-radius:7px;font-size:13px;font-weight:600;cursor:pointer}
.geo-confirm-ok:hover{filter:brightness(1.08)}
.geo-confirm-cancel{background:none;border:1px solid var(--border);color:var(--text3);padding:6px 12px;border-radius:7px;font-size:13px;cursor:pointer}
.geo-confirm-cancel:hover{border-color:var(--border2);color:var(--text2)}
.filter-summary{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text3);flex-wrap:wrap}
.filter-summary-tag{display:inline-flex;align-items:center;gap:4px;background:var(--o-mid);border:1px solid var(--o-border);color:var(--orange);border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600}
.btn-clear-all{background:none;border:1px solid var(--border);color:var(--text3);padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}
.btn-clear-all:hover{border-color:#DC2626;color:#DC2626}
.btn-filter-toggle{background:none;border:1px solid var(--border);color:var(--text3);padding:3px 9px;border-radius:20px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap}
.btn-filter-toggle:hover{border-color:var(--border2);color:var(--text2)}
.btn-filter-toggle.active{background:var(--orange);border-color:var(--orange);color:#fff}
.filter-sep{width:1px;height:22px;background:var(--border);margin:0 2px;flex-shrink:0}
.filter-lbl{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;margin-right:2px}
.chip{background:var(--bg3);border:1px solid var(--border);color:var(--text2);padding:6px 10px;border-radius:20px;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap;text-align:center}
.chip:hover{border-color:var(--border2);background:var(--bg4)}
.chip.on{background:var(--orl);border-color:var(--orm);color:var(--orange);font-weight:600}
/* Nei chip-row ogni chip si espande ugualmente */
.chip-row .chip{flex:1;min-width:0}
.chip-more{font-size:16px;letter-spacing:1px;padding:6px 9px;min-width:38px;text-align:center;flex:0 0 auto!important}
.chip-more.open{background:var(--orl);border-color:var(--orm);color:var(--orange)}
.date-input{height:30px;padding:0 8px;background:var(--bg);border:1px solid var(--border);border-radius:6px;font-size:12px;color:var(--text);outline:none;transition:border-color .15s;cursor:pointer}
.date-input:focus{border-color:var(--orange)}
.btn-filter-clear{background:none;border:none;color:var(--text3);font-size:12px;cursor:pointer;padding:2px 6px;border-radius:4px;transition:all .15s}
.btn-filter-clear:hover{color:var(--red);background:rgba(220,38,38,.06)}

/* ══ GLOBAL MAP ══ */
#global-map-section{background:var(--bg2);border-bottom:1px solid var(--border);position:relative;z-index:1;isolation:isolate}
#global-map-wrap{position:relative;z-index:1;isolation:isolate}
#global-map{height:380px;width:100%;background:var(--bg3);transition:height .3s ease}
/* Collassata: striscia sottile che mostra solo i controlli in basso */
#global-map.collapsed{height:42px;overflow:hidden}
.map-legend{
  position:absolute;bottom:12px;left:12px;z-index:400;
  background:rgba(255,255,255,.92);backdrop-filter:blur(4px);
  border:1px solid var(--border);border-radius:8px;padding:8px 12px;
  display:flex;flex-direction:column;gap:4px;box-shadow:var(--sh-s);
  max-width:200px;
}
.map-legend-title{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}
.legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text2);font-weight:500}
.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.map-controls{position:absolute;top:10px;right:10px;z-index:400;display:flex;gap:4px;align-items:center}
.map-toggle{background:rgba(255,255,255,.92);backdrop-filter:blur(4px);border:1px solid var(--border);border-radius:6px;padding:5px 10px;font-size:11px;font-weight:600;color:var(--text2);cursor:pointer;transition:all .15s;box-shadow:var(--sh-s)}
.map-toggle:hover{background:var(--bg3)}
.map-lyr-btn{background:rgba(255,255,255,.92);backdrop-filter:blur(4px);border:1px solid var(--border);color:var(--text2);padding:4px 9px;font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;box-shadow:var(--sh-s)}
.map-lyr-btn:first-child{border-radius:6px 0 0 6px;border-right:none}
.map-lyr-btn:nth-child(2){border-radius:0 6px 6px 0}
.map-lyr-btn:hover{background:var(--bg3)}
.map-lyr-btn.active{background:var(--orl);border-color:var(--orm);color:var(--orange)}
#global-map.drawing-rect,#global-map.drawing-rect *{cursor:crosshair!important}
#global-map.drawing-lasso,#global-map.drawing-lasso *{cursor:cell!important}
/* Pannello strumenti selezione: sotto al filters-btn-map (che è top:12 left:12).
 * Ogni .draw-tool-btn è un FAB tondo uniforme con il pattern delle altre pagine. */
#draw-tools{
  position:absolute;left:12px;top:66px;z-index:400;
  display:flex;flex-direction:column;gap:8px;
}
.draw-tool-btn{
  width:44px;height:44px;border-radius:22px;
  background:var(--bg2);border:1px solid var(--border);
  box-shadow:var(--sh-m,0 4px 12px rgba(0,0,0,.12));
  display:flex;align-items:center;justify-content:center;
  color:var(--text);cursor:pointer;
  -webkit-tap-highlight-color:transparent;
  transition:transform .12s,background .15s,border-color .15s,color .15s;
}
.draw-tool-btn:active{transform:scale(.92);background:var(--bg3,#f5f3ef)}
.draw-tool-btn svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.draw-tool-btn.draw-active{
  background:#2563EB;border-color:#2563EB;color:#fff;
  box-shadow:0 0 0 3px rgba(37,99,235,.20);
}
/* Compat con vecchio markup (rimossi ma css di legacy potrebbe restare) */
.draw-tool-lbl{display:none}
.map-fs-btn{background:rgba(255,255,255,.92);backdrop-filter:blur(4px);border:1px solid var(--border);border-radius:6px;width:30px;height:28px;font-size:13px;color:var(--text2);cursor:pointer;transition:all .15s;box-shadow:var(--sh-s);display:flex;align-items:center;justify-content:center}
.map-fs-btn:hover{background:var(--bg3);color:var(--text)}
#global-map-wrap:fullscreen,
#global-map-wrap:-webkit-full-screen{position:fixed;inset:0;z-index:9999}
#global-map-wrap:fullscreen #global-map,
#global-map-wrap:-webkit-full-screen #global-map{height:100vh!important}

/* ══ GEO BAR ══ */
.geo-bar{
  display:flex;flex-wrap:wrap;align-items:center;gap:8px;
  padding:10px 20px;background:var(--bg2);
  border-bottom:1px solid var(--border);
}
.geo-search-wrap{display:flex;align-items:center;gap:0;flex:1;min-width:220px;max-width:360px;position:relative}
.geo-input{
  flex:1;height:34px;padding:0 36px 0 11px;background:var(--bg);
  border:1px solid var(--border);border-radius:6px;font-size:13px;color:var(--text);
  outline:none;transition:border-color .15s;
}
.geo-input:focus{border-color:var(--orange)}
.geo-input::placeholder{color:var(--text3)}
.geo-search-btn{
  position:absolute;right:0;top:0;bottom:0;width:34px;
  background:none;border:none;cursor:pointer;font-size:13px;
  color:var(--text3);transition:color .15s;border-radius:0 6px 6px 0;
}
.geo-search-btn:hover{color:var(--orange)}
.geo-radius-wrap{display:flex;align-items:center;gap:5px}
.geo-radius-input{
  width:72px;height:34px;padding:0 8px;background:var(--bg);
  border:1px solid var(--border);border-radius:6px;font-size:13px;
  color:var(--text);outline:none;text-align:right;transition:border-color .15s;
}
.geo-radius-input:focus{border-color:var(--orange)}
.geo-gps-btn{
  display:flex;align-items:center;gap:5px;
  height:34px;padding:0 12px;background:var(--bg2);
  border:1px solid var(--border);border-radius:6px;
  font-size:12px;font-weight:600;color:var(--text2);cursor:pointer;transition:all .15s;
}
.btn-nav-gpx{display:inline-flex;align-items:center;gap:5px;background:var(--blue);border:none;color:#fff;border-radius:6px;padding:4px 10px;font-size:12px;font-weight:600;cursor:pointer;font-family:var(--sans);white-space:nowrap}
.btn-nav-gpx:not(:disabled){background:#2563EB!important;color:#fff!important}
.btn-nav-gpx:disabled{background:var(--border);color:var(--text3);cursor:not-allowed;opacity:.6}
.btn-snap-gpx{display:inline-flex;align-items:center;gap:5px;background:var(--green);border:none;color:#fff;border-radius:6px;padding:4px 10px;font-size:12px;font-weight:600;cursor:pointer;font-family:var(--sans);white-space:nowrap}
.btn-snap-gpx:not(:disabled){background:#16A34A!important;color:#fff!important}
.btn-snap-gpx:disabled{background:var(--border);color:var(--text3);cursor:not-allowed;opacity:.6}
.geo-gps-btn:hover{border-color:var(--orange);color:var(--orange);background:var(--orl)}
.geo-gps-btn.locating{color:var(--orange);border-color:var(--orm);animation:pulse 1s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
.geo-status{font-size:12px;color:var(--text2);display:flex;align-items:center;gap:5px}
.geo-status.ok{color:var(--green)}
.geo-status.err{color:var(--red)}
.geo-clear-btn{
  height:34px;padding:0 12px;background:rgba(252,76,2,.08);
  border:1px solid var(--orm);border-radius:6px;
  font-size:12px;font-weight:600;color:var(--orange);cursor:pointer;transition:all .15s;
}
.geo-clear-btn:hover{background:rgba(252,76,2,.15)}

/* ══ GEO NOTICE ══ */
.geo-notice-box{
  background:#FFFBF0;border:1.5px solid rgba(252,76,2,.28);border-radius:8px;
  padding:11px 14px;display:flex;align-items:center;justify-content:space-between;
  gap:12px;flex-wrap:wrap;
}
.geo-notice-txt{font-size:12px;color:var(--text2);line-height:1.6}
.geo-notice-txt strong{color:var(--text);font-weight:600}
.geo-notice-btn{
  background:var(--orange);color:#fff;border:none;
  padding:9px 18px;border-radius:8px;font-size:13px;font-weight:700;
  cursor:pointer;white-space:nowrap;transition:filter .15s;flex-shrink:0;
}
.geo-notice-btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.geo-notice-btn:hover{filter:brightness(1.08)}
.geo-notice-btn:disabled{opacity:.5;cursor:default;filter:none}
/* Editor banner */
.editor-banner{display:none;align-items:center;justify-content:space-between;gap:12px;
  padding:11px 20px;background:rgba(168,85,247,.07);border-bottom:2px solid rgba(168,85,247,.25);
  flex-wrap:wrap}
.editor-banner.visible{display:flex}
.editor-banner-text{font-size:12px;color:var(--text2);line-height:1.5}
.editor-banner-text strong{color:#7C3AED;font-weight:700}
.editor-banner-text em{color:var(--text3);font-style:normal}
.editor-banner-btn{display:inline-flex;align-items:center;gap:6px;background:#A855F7;color:#fff;
  border:none;padding:9px 18px;border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;
  white-space:nowrap;transition:filter .15s;flex-shrink:0;box-shadow:0 2px 8px rgba(168,85,247,.3)}
.editor-banner-btn:hover{filter:brightness(1.1)}
@media(max-width:767px){
  .editor-banner{flex-direction:column;align-items:stretch;gap:8px;padding:12px 16px}
  .editor-banner-btn{width:100%;justify-content:center;padding:12px;font-size:14px}
}
/* Geo circle on map */
.geo-circle-popup .leaflet-popup-content-wrapper{background:rgba(28,26,23,.85);color:#fff;border:none;border-radius:8px;font-size:12px;padding:0}
.geo-circle-popup .leaflet-popup-tip{background:rgba(28,26,23,.85)}

/* ══ GPX UPLOAD BAR ══ */
.gpx-bar{
  padding:8px 20px;display:flex;flex-wrap:wrap;align-items:center;gap:8px;
  background:#F0F7FF;border-bottom:1px solid rgba(37,99,235,.15);
}
.gpx-bar-label{font-size:11px;font-weight:700;color:#2563EB;text-transform:uppercase;letter-spacing:.5px}
.gpx-intersect-progress{display:none;align-items:center;gap:6px;font-size:12px;color:var(--text3);padding:3px 0}
.gpx-upload-btn{
  display:inline-flex;align-items:center;gap:6px;cursor:pointer;
  height:32px;padding:0 14px;background:#fff;border:1.5px dashed #93C5FD;
  border-radius:6px;font-size:12px;font-weight:600;color:#2563EB;transition:all .15s;
}
.gpx-upload-btn:hover{background:#EFF6FF;border-color:#2563EB}
.gpx-upload-btn input{display:none}
.gpx-status{font-size:12px;color:#1E40AF;display:flex;align-items:center;gap:5px}
.gpx-status.err{color:var(--red)}
.gpx-clear-btn{
  height:32px;padding:0 12px;background:rgba(37,99,235,.08);
  border:1px solid rgba(37,99,235,.25);border-radius:6px;
  font-size:12px;font-weight:600;color:#2563EB;cursor:pointer;transition:all .15s;
}
.gpx-clear-btn:hover{background:rgba(37,99,235,.15)}
.gpx-intersect-toggle{
  display:flex;align-items:center;gap:6px;cursor:pointer;
  font-size:12px;font-weight:500;color:#1E40AF;user-select:none;
}
.gpx-intersect-toggle input{accent-color:#2563EB;width:14px;height:14px;cursor:pointer}
.map-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(247,245,242,.7);z-index:300;font-size:13px;color:var(--text3);gap:8px;pointer-events:none}
.map-loading.hidden{display:none}

/* Grid — Komoot-style: card a tutta larghezza con thumb in alto */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px;padding:14px 16px 100px}
@media (max-width:520px){.grid{grid-template-columns:1fr;padding:12px 12px 100px;gap:12px}}

/* Multi-select bar (raised above bottom nav) */
.sel-bar{position:fixed;bottom:calc(80px + env(safe-area-inset-bottom,0));left:50%;transform:translateX(-50%);background:var(--text);color:#fff;border-radius:14px;padding:10px 16px;display:none;align-items:center;gap:12px;box-shadow:var(--sh-l);z-index:310;white-space:nowrap}
.sel-bar.show{display:flex}
.sel-count{font-size:13px;font-weight:600}
.sel-bar .btn-xs{background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.2);color:#fff;padding:5px 13px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}
.sel-bar .btn-xs:hover{background:rgba(255,255,255,.25)}
.sel-bar .btn-xs.primary{background:var(--orange);border-color:var(--orange)}
.sel-bar .btn-xs.primary:hover{filter:brightness(1.1)}

/* ── ACTIVITY CARD: regole spostate in gpxt-design.css (shared con archivio) ── */
.gx-track-blend{mix-blend-mode:multiply}

body.bike-mode .st-v{font-size:21px}
body.bike-mode .st-l{font-size:11px}
body.bike-mode .card-name{font-size:18px}

/* Popover menu (riusato — minimo restyling) */
/* Popover menu rules ora in gpxt-design.css (shared con archivio) */

/* Toast — top center, Komoot pill */
.toast{position:fixed;top:calc(env(safe-area-inset-top,0) + 14px);left:50%;transform:translateX(-50%) translateY(-8px);background:var(--text);color:#fff;padding:10px 18px;border-radius:999px;font-family:var(--sans);font-weight:600;font-size:13px;box-shadow:0 4px 16px rgba(0,0,0,.18);pointer-events:none;opacity:0;transition:all .25s;z-index:9999}
.toast.visible{opacity:1;transform:translateX(-50%) translateY(0)}

/* Badge "delta vs tua media" sulle card attività concluse */
.eta-delta{display:inline-flex;align-items:center;gap:3px;border-radius:6px;padding:1px 6px;font-size:11px;font-weight:600;white-space:nowrap;border:1px solid;margin-left:4px}
.eta-delta.fast{background:rgba(22,163,74,.10);color:#15803d;border-color:rgba(22,163,74,.30)}
.eta-delta.slow{background:rgba(245,158,11,.10);color:#92400E;border-color:rgba(245,158,11,.30)}
.eta-delta.avg {background:var(--bg3);color:var(--text3);border-color:var(--border)}

.load-more-wrap{text-align:center;padding:6px 20px 24px}
.btn-more{background:var(--bg2);border:1.5px solid var(--border);color:var(--text2);padding:9px 28px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}
.btn-more:hover{border-color:var(--border2);color:var(--text);background:var(--bg3)}

/* ══ SUMMARY ══ */
.summary-totals{
  display:flex;flex-wrap:wrap;gap:8px;
  background:var(--bg2);
  border-radius:10px;padding:14px 18px;margin-bottom:10px;
  box-shadow:var(--sh-s);
}
.sum-kpi{display:flex;flex-direction:column;gap:2px;min-width:90px}
.sum-kpi-v{font-size:18px;font-weight:700;color:var(--text)}
.sum-kpi-l{font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.5px}
.sum-divider{width:1px;background:var(--border);align-self:stretch;margin:0 4px;flex-shrink:0}
.sum-kpi.highlight .sum-kpi-v{color:var(--orange)}
@media(max-width:680px){
  .summary-totals{display:grid;grid-template-columns:1fr 1fr;padding:10px 14px;gap:4px 10px;align-items:center}
  .sum-kpi{flex:none;min-width:0;padding:0;flex-direction:row;align-items:baseline;gap:5px}
  .sum-kpi-v{font-size:18px;letter-spacing:-.3px}
  .sum-kpi-l{font-size:10px;letter-spacing:.2px}
  .sum-divider{display:none}
}

.summary-sports{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:4px}
.sport-pill{
  display:flex;align-items:center;gap:10px;
  background:var(--bg2);border:1px solid var(--border);
  border-radius:8px;padding:10px 14px;flex:1;min-width:200px;
  box-shadow:var(--sh-s);cursor:pointer;
  border-left:4px solid var(--c,var(--border));
  transition:transform .12s, box-shadow .15s, border-color .15s;
  position:relative;
  -webkit-tap-highlight-color:transparent;
}
.sport-pill:hover{box-shadow:var(--sh-m);transform:translateY(-1px)}
.sport-pill:active{transform:scale(.985)}
.sport-pill::after{
  content:"›";position:absolute;right:12px;top:50%;
  transform:translateY(-50%);
  color:var(--text3);font-size:18px;font-weight:300;
  opacity:0;transition:opacity .15s,transform .15s,right .15s;
}
.sport-pill:hover::after{opacity:1}
.sport-pill-icon{display:inline-flex;align-items:center;flex-shrink:0}
.sport-pill-name{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--c,var(--text3));margin-bottom:5px}
.sport-pill-stats{display:flex;gap:12px;flex-wrap:wrap}
.sps{display:flex;flex-direction:column;gap:1px}
.sps-v{font-size:13px;font-weight:700;color:var(--text)}
.sps-l{font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:.4px}

/* ── Sport detail modal (tap su sport-pill) ── */
.spd-ov{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:1800;opacity:0;pointer-events:none;transition:opacity .25s;display:flex;align-items:center;justify-content:center;padding:16px}
.spd-ov.open{opacity:1;pointer-events:auto}
.spd{background:var(--bg2);border-radius:14px;max-width:420px;width:100%;box-shadow:0 12px 40px rgba(0,0,0,.28);overflow:hidden;transform:scale(.92);transition:transform .25s cubic-bezier(.32,.72,0,1);max-height:88vh;display:flex;flex-direction:column}
.spd-ov.open .spd{transform:scale(1)}
.spd-hdr{padding:18px 18px 14px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border);border-left:5px solid var(--c,var(--orange))}
.spd-hdr-ic{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;color:var(--c,var(--orange));flex-shrink:0}
.spd-hdr-tt{flex:1;min-width:0}
.spd-hdr-name{font-size:15px;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.4px;line-height:1.2}
.spd-hdr-sub{font-size:12px;color:var(--text3);margin-top:2px}
.spd-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:transparent;border:none;color:var(--text2);cursor:pointer;flex-shrink:0}
.spd-close:hover{background:var(--bg3)}
.spd-close svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.spd-body{padding:16px 18px;overflow-y:auto;flex:1}
.spd-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:14px}
.spd-stat{background:var(--bg3);border-radius:10px;padding:12px}
.spd-stat-l{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.4px;font-weight:600;margin-bottom:5px}
.spd-stat-v{font-size:18px;font-weight:700;color:var(--text);line-height:1.1}
.spd-stat-x{font-size:11px;color:var(--text2);margin-top:3px}
.spd-section{margin-top:14px}
.spd-section-h{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;font-weight:600;margin-bottom:8px}
.spd-rec{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg3);border-radius:8px;margin-bottom:6px;cursor:pointer;transition:background .15s,transform .12s;-webkit-tap-highlight-color:transparent}
.spd-rec:hover{background:var(--bg4)}
.spd-rec:active{transform:scale(.99)}
.spd-rec-bdg{font-size:10px;font-weight:700;color:#fff;background:var(--c,var(--orange));padding:3px 7px;border-radius:5px;text-transform:uppercase;letter-spacing:.4px;flex-shrink:0}
.spd-rec-n{flex:1;font-size:13px;color:var(--text);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.spd-rec-v{font-size:12px;color:var(--text2);font-weight:600;flex-shrink:0}
.spd-foot{padding:12px 18px 16px;border-top:1px solid var(--border);background:var(--bg3);display:flex;gap:8px}
.spd-foot-btn{flex:1;padding:11px;border-radius:8px;font-size:13px;font-weight:600;border:1px solid var(--border);background:var(--bg2);color:var(--text);cursor:pointer;transition:background .15s;font-family:inherit}
.spd-foot-btn:hover{background:var(--bg3)}
.spd-foot-btn.primary{background:var(--c,var(--orange));color:#fff;border-color:transparent}
.spd-foot-btn.primary:hover{filter:brightness(.95)}
.loader{display:flex;align-items:center;justify-content:center;padding:60px;gap:10px;font-size:13px;color:var(--text3)}
.spin{width:18px;height:18px;border-radius:50%;border:2.5px solid var(--border2);border-top-color:var(--orange);animation:spin .7s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes hdrPfSpin{to{transform:rotate(360deg)}}
#hdr-pf-svg{stroke:#FC4C02;stroke-width:2;fill:none;stroke-linecap:round}
#hdr-pf:active{transform:scale(.95)}
.empty{text-align:center;padding:60px 20px;font-size:13px;color:var(--text3)}
.empty-icon{font-size:32px;margin-bottom:8px}

/* ══ MODAL ══ */
.overlay{display:none;position:fixed;inset:0;background:rgba(20,18,15,.55);backdrop-filter:blur(5px);z-index:500;align-items:center;justify-content:center;padding:16px}
.overlay.open{display:flex}
.modal{background:var(--bg2);border:1px solid var(--border);border-radius:14px;width:100%;max-width:860px;max-height:92vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--sh-l)}
.modal-head{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-start;flex-shrink:0}
.m-title{font-size:17px;font-weight:700;color:var(--text);margin-bottom:2px}
.m-sub{font-size:12px;color:var(--text3)}
.btn-close{background:var(--bg3);border:1px solid var(--border);color:var(--text3);width:28px;height:28px;border-radius:6px;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
.btn-close:hover{color:var(--text);background:var(--bg4)}
.modal-tabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0;padding:0 18px;background:var(--bg2)}
.mtab{background:none;border:none;padding:10px 14px;font-size:13px;font-weight:500;color:var(--text3);border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;transition:all .15s}
.mtab:hover{color:var(--text2)}
.mtab.active{color:var(--orange);border-bottom-color:var(--orange);font-weight:600}
.modal-body{flex:1;overflow-y:auto;padding:16px 18px;display:flex;flex-direction:column;gap:14px}
.modal-pane{display:none}
.modal-pane.active{display:block}

#modal-map{height:300px;border-radius:12px;border:1px solid var(--border);background:var(--bg3)}
.modal-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:7px}
.mst{background:var(--bg3);border-radius:12px;padding:10px 12px;border:1px solid var(--border)}
.mst-v{font-size:16px;font-weight:700;color:var(--text);margin-bottom:2px}
.mst-l{font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:.4px;font-weight:500}

/* Elevation chart — fixed height wrapper prevents infinite resize */
.chart-outer{background:var(--bg3);border:1px solid var(--border);border-radius:12px;padding:14px}
.chart-title{font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}
.chart-inner{position:relative;height:160px;width:100%}
#elev-chart{position:absolute;inset:0}

/* Photo gallery — strip orizzontale (vedi commento dettagliato in
 * gpxt-activity.css). Layout condiviso per coerenza tra le sezioni
 * foto attività (Activity) e route archiviate (Archivio). */
.photo-grid{
  display:flex;
  gap:8px;
  overflow-x:auto;
  overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
  scroll-snap-type:x mandatory;
  scrollbar-width:thin;
  scrollbar-color:var(--border) transparent;
  padding-bottom:4px;
}
.photo-grid::-webkit-scrollbar{height:6px}
.photo-grid::-webkit-scrollbar-track{background:transparent}
.photo-grid::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
.photo-item{
  border-radius:12px;overflow:hidden;aspect-ratio:1;cursor:pointer;
  border:1px solid var(--border);transition:all .18s;position:relative;background:#000;
  flex:0 0 140px;
  scroll-snap-align:start;
}
.photo-item:hover{transform:scale(1.02);box-shadow:var(--sh-m)}
.photo-item img,.photo-item video{width:100%;height:100%;object-fit:cover;display:block}
.photo-item .vid-badge{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;
}
.photo-item .vid-badge span{
  background:rgba(0,0,0,.55);backdrop-filter:blur(2px);
  color:#fff;font-size:22px;width:44px;height:44px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  border:2px solid rgba(255,255,255,.6);
}
.no-content{text-align:center;padding:32px;font-size:13px;color:var(--text3)}

/* Lightbox */
.lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.95);z-index:900;align-items:center;justify-content:center;flex-direction:column}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:85vh;border-radius:8px;object-fit:contain}
.lightbox video{max-width:90vw;max-height:85vh;border-radius:8px;outline:none;background:#000}
.lb-close{position:absolute;top:16px;right:20px;background:none;border:none;color:#fff;font-size:28px;cursor:pointer;opacity:.7;transition:opacity .15s}
.lb-close:hover{opacity:1}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.15);border:none;color:#fff;width:44px;height:44px;border-radius:50%;font-size:22px;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}
.lb-nav:hover{background:rgba(255,255,255,.28)}
.lb-prev{left:16px}
.lb-next{right:16px}
.lb-counter{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.55);font-size:12px;font-family:var(--mono,'monospace')}
.lb-strava-link{
  display:inline-flex;align-items:center;gap:6px;
  background:var(--orange);color:#fff;
  padding:9px 18px;border-radius:8px;font-size:13px;font-weight:600;
  text-decoration:none;box-shadow:0 2px 12px rgba(252,76,2,.4);
  transition:filter .15s;
}
.lb-strava-link:hover{filter:brightness(1.1)}

.modal-foot{padding:10px 18px 14px;border-top:1px solid var(--border);display:flex;gap:7px;flex-shrink:0}
.modal-foot .btn-card{flex:1;padding:9px;font-size:13px;font-weight:600}

::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}
.leaflet-control-attribution{display:none!important}

/* ══ BIKE MODE — polish index.html ══════════════════════════════════════════
 * Quando body.bike-mode è attivo (toggle header 🚴):
 * testi e tap target più grandi, bordi più spessi, spaziature più generose.
 * Pensato per uso con guanti o telefono sul manubrio. */
body.bike-mode .chip          { font-size:15px; padding:10px 14px; }
body.bike-mode .chip-more     { font-size:20px; padding:10px 12px; min-width:46px; }
body.bike-mode .card-name     { font-size:18px; margin-bottom:14px; }
body.bike-mode .card-sport    { height:30px; font-size:13px; padding:0 12px; }
body.bike-mode .card-menu     { width:38px; height:38px; font-size:22px; }
body.bike-mode .card-sel-chk  { width:32px; height:32px; font-size:15px; }
body.bike-mode .cp-item       { font-size:15px; padding:12px 14px; }
body.bike-mode .summary-card,
body.bike-mode .discipline-card { border-width:1.5px; }
/* ─────────────────────────── REDESIGN: TOP BAR + TOGGLE + LIST FILTERS ─────────────────────────── */
/* Nascondi header globale su index */
.gx-hdr{display:none !important}
body.gx-page{padding-top:0 !important}

/* Top bar: icone scrollabili, NON sticky */
.page-top{display:flex;align-items:center;gap:8px;padding:calc(12px + env(safe-area-inset-top)) 16px 4px;max-width:1200px;margin:0 auto;justify-content:flex-end}
.page-top-ic{width:36px;height:36px;border-radius:9px;background:var(--bg2);border:1.5px solid var(--border);color:var(--text);display:flex;align-items:center;justify-content:center;transition:background .12s,transform .12s;flex:none;position:relative}
.page-top-ic:active{transform:scale(.94);background:var(--bg3)}
.page-top-ic svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.page-top-ic.spin svg{animation:gx-spin 1s linear infinite}
.page-top-ic .badge-dot{position:absolute;top:-2px;right:-2px;background:var(--orange);color:#fff;font-size:9px;font-weight:700;border-radius:8px;padding:1px 4px;line-height:1.2;min-width:14px;text-align:center}
.initials-btn{width:36px;height:36px;border-radius:50%;background:var(--orange);color:#fff;font-family:'Outfit',sans-serif;font-weight:800;font-size:12px;letter-spacing:.3px;display:flex;align-items:center;justify-content:center;flex:none;transition:transform .12s,background .12s;border:none;cursor:pointer}
.initials-btn:active{transform:scale(.94);background:#E04400}

/* Indicatore prefetch flottante (sopra la navbar quando attivo) */
.prefetch-pill{position:fixed;left:12px;bottom:calc(72px + env(safe-area-inset-bottom));background:var(--bg2);border:1.5px solid var(--border);border-radius:999px;padding:6px 12px 6px 8px;display:none;align-items:center;gap:6px;color:var(--text2);font-size:12px;font-weight:600;box-shadow:0 4px 12px rgba(0,0,0,.12);z-index:55;cursor:pointer}
.prefetch-pill[style*="flex"],.prefetch-pill[style*="inline-flex"]{display:inline-flex !important}
.prefetch-pill svg{width:16px;height:16px;color:var(--orange)}
.prefetch-pill #hdr-pf-cnt{font-family:'Outfit',sans-serif;font-weight:800;color:var(--orange)}

/* Toggle + filters strip per vista lista */
.list-controls{padding:calc(14px + env(safe-area-inset-top)) 16px 0;max-width:1200px;margin:0 auto}
.list-controls .row1{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.list-controls .search-box{position:relative;flex:1;min-width:0}
.list-controls .search-box input{width:100%;background:var(--bg2);border:1.5px solid var(--border);color:var(--text);padding:8px 14px 8px 36px;border-radius:10px;font-size:14px;outline:none;font-family:'DM Sans',sans-serif;transition:border-color .15s,box-shadow .15s;height:36px}
.list-controls .search-box input::placeholder{color:var(--text3)}
.list-controls .search-box input:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(252,76,2,.09)}
.list-controls .search-box svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--text3);pointer-events:none}
.list-controls .search-box .clear-btn{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:24px;height:24px;border-radius:50%;display:none;align-items:center;justify-content:center;color:var(--text3);background:var(--bg3);border:none;cursor:pointer}
.list-controls .search-box.has-text .clear-btn{display:flex}
.list-controls .search-box .clear-btn svg{position:static;transform:none;width:12px;height:12px}

.map-fab-btn{flex:none;width:36px;height:36px;border-radius:10px;background:var(--bg2);border:1.5px solid var(--border);color:var(--text);display:flex;align-items:center;justify-content:center;transition:background .12s,transform .12s,border-color .12s;cursor:pointer}
.map-fab-btn:active{transform:scale(.93);background:var(--bg3);border-color:var(--border2)}
.map-fab-btn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* Bottone overlay "torna alla lista" — appare solo in view-map */
.map-back-fab{
  position:fixed;top:calc(12px + env(safe-area-inset-top));left:12px;
  width:44px;height:44px;border-radius:22px;
  background:var(--bg2);border:1px solid var(--border);
  box-shadow:var(--sh-m,0 4px 12px rgba(0,0,0,.12));
  display:none;align-items:center;justify-content:center;
  color:var(--text);z-index:601;
  transition:transform .12s,background .15s;cursor:pointer;
}
.map-back-fab:active{transform:scale(.92);background:var(--bg3,#f5f3ef)}
.map-back-fab svg{
  width:22px;height:22px;
  fill:none;stroke:currentColor;stroke-width:2;
  stroke-linecap:round;stroke-linejoin:round;
}
body.view-map .map-back-fab{display:flex}
/* In view-map: cascata top-left → back-fab (12) · filters (66) · draw-tools (120/174) */
body.view-map .filters-btn.map-filters-btn{top:calc(66px + env(safe-area-inset-top)) !important}
body.view-map #draw-tools{top:calc(120px + env(safe-area-inset-top)) !important}

/* Chips orizzontali (sort + range) — stile archivio */
.list-chips{display:flex;gap:8px;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;padding:2px 0 14px;margin:0 -16px;scrollbar-width:none}
.list-chips::-webkit-scrollbar{display:none}
.list-chips::before,.list-chips::after{content:'';flex:none;width:14px}
.list-chip-grp{display:flex;gap:6px;flex:none}
.list-chip{flex:none;background:var(--bg2);border:1.5px solid var(--border);color:var(--text2);padding:7px 13px;border-radius:999px;font-size:13px;font-weight:600;white-space:nowrap;transition:all .12s;cursor:pointer}
.list-chip:active{transform:scale(.96)}
.list-chip.is-on{background:var(--text);border-color:var(--text);color:#fff}
.list-chip-grp+.list-chip-grp{padding-left:6px}

/* Mostra/nascondi pannelli in base alla view */
body.view-list #global-map-section{display:none !important}
body.view-list #summary-section{display:block}
body.view-list #act-grid{display:grid}
body.view-map .page-top{display:none !important}
body.view-map .list-controls{display:none}
body.view-map #summary-section{display:none !important}
body.view-map #act-grid{display:none !important}
body.view-map #pane-act > #global-map-section{display:block !important}

/* Map view fullscreen: mappa occupa tutto fra top viewport e navbar */
body.view-map #global-map-section{margin:0;border:none;border-radius:0;height:calc(100vh - var(--gx-bnav-h, 64px) - env(safe-area-inset-bottom));max-height:none;padding-top:env(safe-area-inset-top);box-sizing:border-box}
body.view-map #global-map-wrap,body.view-map #global-map{height:100%}
body.view-map #map-fs-btn{display:none}

/* ─────────────────────────── ACCOUNT BOTTOM SHEET ─────────────────────────── */
.acc-sheet-back{position:fixed;inset:0;background:rgba(0,0,0,.5);opacity:0;pointer-events:none;transition:opacity .25s;z-index:1100;backdrop-filter:blur(2px)}
.acc-sheet-back.is-open{opacity:1;pointer-events:auto}
.acc-sheet{position:fixed;left:0;right:0;bottom:0;background:var(--bg2);border-radius:20px 20px 0 0;z-index:1101;max-height:88vh;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:env(safe-area-inset-bottom);box-shadow:0 12px 40px rgba(0,0,0,.18);
  transform:translateY(100%);visibility:hidden;
  transition:transform .3s cubic-bezier(.2,.85,.25,1),visibility 0s linear .3s}
.acc-sheet.is-open{transform:translateY(0);visibility:visible;transition:transform .3s cubic-bezier(.2,.85,.25,1),visibility 0s linear 0s}
.acc-sheet-handle{width:40px;height:4px;background:var(--border);border-radius:2px;margin:10px auto 0}
.acc-sheet-inner{padding:14px 18px 24px}
.acc-head{display:flex;align-items:center;gap:14px;margin-bottom:18px;padding:6px 0 14px;border-bottom:1px solid var(--border)}
.acc-avatar{width:64px;height:64px;border-radius:50%;object-fit:cover;border:2px solid var(--border);flex:none}
.acc-avatar-fallback{width:64px;height:64px;border-radius:50%;background:var(--orange);color:#fff;font-family:'Outfit',sans-serif;font-weight:800;font-size:22px;letter-spacing:.5px;display:flex;align-items:center;justify-content:center;flex:none}
.acc-info{flex:1;min-width:0}
.acc-name{font-family:'Outfit',sans-serif;font-weight:800;font-size:18px;letter-spacing:-.3px;color:var(--text);line-height:1.2;word-break:break-word}
.acc-meta{font-size:12.5px;color:var(--text3);margin-top:4px;line-height:1.4}
.acc-row{display:flex;align-items:center;gap:12px;width:100%;padding:14px 12px;background:var(--bg3);border:none;border-radius:12px;color:var(--text);font-size:14px;font-weight:600;text-align:left;text-decoration:none;cursor:pointer;transition:background .12s;margin-bottom:8px;font-family:inherit}
.acc-row:active{background:var(--border)}
.acc-row svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex:none;color:var(--text2)}
.acc-row.is-danger{color:var(--red,#DC2626)}
.acc-row.is-danger svg{color:var(--red,#DC2626)}

@keyframes gx-spin{to{transform:rotate(360deg)}}

/* ══════════════════════════════════════════════════════════════════════
 * FILTRI POPOVER — bottone "⋯" che apre il pannello filtri.
 * Due trigger: accanto al campo di ricerca (.row1) e sulla mappa
 * (top-left, sotto i draw-tools).
 * ════════════════════════════════════════════════════════════════════ */
.filters-btn{
  width:36px;height:36px;flex-shrink:0;
  background:var(--bg2);border:1.5px solid var(--border);border-radius:10px;
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--text);cursor:pointer;
  transition:transform .12s,background .15s,border-color .15s;
  -webkit-tap-highlight-color:transparent;position:relative;
}
.filters-btn svg{width:18px;height:18px}
.filters-btn:hover{background:var(--bg3)}
.filters-btn:active{transform:scale(.92)}
.filters-btn.has-active{border-color:var(--orange);color:var(--orange)}
.filters-btn.has-active::after{
  content:'';position:absolute;top:6px;right:6px;
  width:6px;height:6px;border-radius:50%;background:var(--orange);
}
.filters-btn.is-open{background:var(--bg3);border-color:var(--text2)}

/* Variante FAB per la mappa */
.filters-btn.map-filters-btn{
  position:absolute;top:12px;left:12px;z-index:600;
  width:44px;height:44px;border-radius:22px;
  background:var(--bg2);
  box-shadow:var(--sh-m,0 4px 12px rgba(0,0,0,.12));
}
.filters-btn.map-filters-btn svg{width:22px;height:22px}

/* Popover filtri — pannello dropdown ricco. Posizione top-left calcolata
 * in JS (openFiltersPopover): vicino al trigger, con flip verticale se
 * sotto non c'è spazio. */
.filters-popover{
  position:fixed;z-index:850;display:none;
  background:var(--bg2);border:1px solid var(--border);
  border-radius:14px;box-shadow:0 12px 40px rgba(0,0,0,.18);
  padding:12px;width:320px;max-width:calc(100vw - 24px);
  max-height:calc(100vh - 80px);overflow-y:auto;
  font-family:'DM Sans',sans-serif;
}
.filters-popover.open{display:block}
.fp-section{margin-bottom:12px}
.fp-section:last-of-type{margin-bottom:6px}
.fp-section-title{
  font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;
  color:var(--text3);margin-bottom:8px;
}
.fp-sport-grid{display:flex;flex-wrap:wrap;gap:6px}
.fp-sport-grid .chip{
  border:1px solid var(--border);background:var(--bg);color:var(--text2);
  padding:5px 10px;border-radius:8px;font-size:12px;font-weight:600;
  cursor:pointer;transition:background .15s,border-color .15s,color .15s;
}
.fp-sport-grid .chip.on{
  background:var(--orange);border-color:var(--orange);color:#fff;
}
.fp-row{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.fp-row:last-child{margin-bottom:0}
.fp-lbl{font-size:12px;color:var(--text3);font-weight:600;flex-shrink:0}
.fp-date{
  flex:1;height:32px;padding:0 8px;
  background:var(--bg);border:1px solid var(--border);border-radius:8px;
  color:var(--text);font-size:12px;font-family:inherit;
}
.fp-clear-mini{
  width:28px;height:28px;border-radius:6px;
  background:var(--bg);border:1px solid var(--border);
  color:var(--text3);cursor:pointer;font-size:12px;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
}
.fp-clear-mini:hover{background:var(--bg3);color:var(--text)}
.fp-gps-btn{
  flex:1;height:34px;display:inline-flex;align-items:center;justify-content:center;gap:6px;
  background:var(--bg);border:1px solid var(--border);border-radius:8px;
  color:var(--text);font-size:13px;font-weight:600;cursor:pointer;
  font-family:inherit;
}
.fp-gps-btn:hover{background:var(--bg3);border-color:var(--text2)}
.fp-range{flex:1;-webkit-appearance:none;appearance:none;background:var(--border);height:4px;border-radius:2px;margin:0;cursor:pointer}
.fp-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:var(--orange);border-radius:8px;border:2px solid var(--bg2);cursor:pointer}
.fp-range::-moz-range-thumb{width:16px;height:16px;background:var(--orange);border-radius:8px;border:2px solid var(--bg2);cursor:pointer}
.fp-range-val{font-size:12px;color:var(--text2);font-weight:600;min-width:60px;text-align:right;font-variant-numeric:tabular-nums}
.fp-geo-status{font-size:12px;color:var(--text3);margin-top:6px;padding:4px 8px;background:var(--bg);border-radius:6px}
.fp-summary-row{margin-top:6px;padding-top:10px;border-top:1px solid var(--border)}

/* ═════════════════════ v326 — SHOWCASE LANDING ═════════════════════
 * Sezione "Da immagine a traccia GPX": 3 esempi prima/dopo con SVG
 * inline. Posizionata dopo .feat-grid, prima del login-footer.
 * Su mobile (default) usa layout vertical-stack; da 520px in su
 * passa a 3 colonne (before · arrow · after) per row. */

.showcase{
  margin-top:18px;
  padding-top:18px;
  border-top:1px solid var(--border);
}
.showcase-hdr{margin-bottom:14px;text-align:center}
.showcase-eyebrow{
  font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;
  color:var(--orange,#FC4C02);margin-bottom:4px;
}
.showcase-title{
  font-size:18px;font-weight:800;color:var(--text);margin:0 0 6px 0;line-height:1.2;
}
.showcase-sub{
  font-size:12px;color:var(--text3);line-height:1.5;margin:0;
  max-width:380px;margin-inline:auto;
}

.sc-row{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  gap:8px;align-items:center;
  margin-top:14px;
}
.sc-before,.sc-after{
  display:flex;flex-direction:column;gap:4px;min-width:0;
}
.sc-label{
  font-size:10px;font-weight:600;color:var(--text3);
  text-transform:uppercase;letter-spacing:.5px;text-align:center;
}
.sc-img{
  width:100%;height:auto;display:block;
  border-radius:6px;
  border:1px solid var(--border);
  background:#fff;
}
.sc-arrow{
  display:flex;align-items:center;justify-content:center;
  color:var(--orange,#FC4C02);
  flex-shrink:0;padding:0 2px;
}

/* Modalità */
.sc-modes{
  margin-top:18px;
  display:grid;grid-template-columns:1fr;gap:8px;
}
@media (min-width:520px){
  .sc-modes{grid-template-columns:1fr 1fr}
}
.sc-mode{
  display:flex;align-items:flex-start;gap:8px;
  padding:10px 12px;
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:8px;
}
.sc-mode svg{flex-shrink:0;margin-top:1px}
.sc-mode-t{display:flex;flex-direction:column;gap:2px;min-width:0}
.sc-mode-t strong{font-size:12px;font-weight:700;color:var(--text);line-height:1.2}
.sc-mode-t span{font-size:11px;color:var(--text3);line-height:1.4}

/* ═════════════════════ v328 — DEMO ANIMATA (SVG + CSS keyframes) ═════════════════════
 * Loop di 9 secondi che mostra la pipeline di estrazione in 5 fasi:
 *   0.0-1.5s — Immagine sorgente appare
 *   1.5-3.0s — Cursor si muove e tappa il colore
 *   3.0-4.5s — 4 anchor appaiono in sequenza
 *   4.5-7.0s — Mappa target appare + traccia GPX si disegna
 *   7.0-9.0s — Badge "GPX pronto"
 * Tutto via CSS animations: niente JS, niente SMIL (deprecato in Chrome).
 * Rispetta prefers-reduced-motion. */

.sc-demo{
  margin-top:18px;
  padding:14px;
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:10px;
}
.sc-demo-label{
  font-size:10px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;
  color:var(--orange,#FC4C02);margin-bottom:8px;text-align:center;
}
.sc-demo-viewport{position:relative;width:100%}
.sc-demo-svg{
  width:100%;height:auto;display:block;
  border-radius:8px;background:#fff;
}
.sc-demo-caption{
  position:relative;
  min-height:18px;margin-top:8px;
  text-align:center;font-size:11.5px;font-weight:600;
  color:var(--text2);
}
.d-cap{
  position:absolute;left:0;right:0;
  opacity:0;
  animation:demoCap 9s linear infinite;
}
.d-cap-0{animation-delay:0s}
.d-cap-1{animation-delay:1.5s}
.d-cap-2{animation-delay:3s}
.d-cap-3{animation-delay:4.5s}
.d-cap-4{animation-delay:7s}
@keyframes demoCap{
  /* Visibile per ~1.5s (16.6% del 9s loop), con fade in/out */
  0%   {opacity:0}
  3%   {opacity:1}
  14%  {opacity:1}
  17%  {opacity:0}
  100% {opacity:0}
}

/* ── Animazioni SVG ── */

/* FASE 0-2: immagine sorgente visibile da 0 a ~4.5s, fade out 4.5-7s */
.d-src{
  animation:demoSrc 9s ease-in-out infinite;
}
@keyframes demoSrc{
  0%   {opacity:0}
  6%   {opacity:1}
  50%  {opacity:1}
  60%  {opacity:0}
  100% {opacity:0}
}

/* FASE 3-4: mappa target appare 4.5s, resta fino al loop */
.d-dst{
  opacity:0;
  animation:demoDst 9s ease-in-out infinite;
}
@keyframes demoDst{
  0%   {opacity:0}
  50%  {opacity:0}
  60%  {opacity:1}
  90%  {opacity:1}
  100% {opacity:0}
}

/* FASE 1: cursor visibile 1.0-3.0s, si muove via translate.
 * Visibilità sul gruppo, movimento sul path (per evitare conflitti
 * CSS transform vs attribute transform su nested <g>). */
.d-cursor{
  opacity:0;
  animation:demoCursorOp 9s ease-in-out infinite;
}
@keyframes demoCursorOp{
  0%   {opacity:0}
  11%  {opacity:0}
  14%  {opacity:1}
  40%  {opacity:1}
  44%  {opacity:0}
  100% {opacity:0}
}
.d-pointer{
  animation:demoPointer 9s ease-in-out infinite;
}
@keyframes demoPointer{
  /* Inizio: traslato a destra (entra da fuori frame). Fine: posizione base. */
  0%, 14%  {transform:translate(60px, 12px)}
  28%      {transform:translate(0, 0)}
  100%     {transform:translate(0, 0)}
}
/* Tap ripple alla fine del movimento del cursor (~2.7s) */
.d-tap{
  animation:demoTap 9s ease-out infinite;
}
@keyframes demoTap{
  0%, 30%  {r:0;opacity:0;stroke-width:2}
  31%      {r:4;opacity:1;stroke-width:2}
  38%      {r:14;opacity:0;stroke-width:1}
  100%     {r:14;opacity:0;stroke-width:1}
}

/* FASE 2: anchor pulsanti che appaiono uno per uno (3.0-4.5s) */
.d-anchor{
  animation:demoAnchor 9s ease-out infinite;
  transform-origin:center;
  transform-box:fill-box;
}
.d-a1{animation-delay:0s}
.d-a2{animation-delay:.25s}
.d-a3{animation-delay:.5s}
.d-a4{animation-delay:.75s}
@keyframes demoAnchor{
  0%, 33%  {r:0;opacity:0}
  36%      {r:4.5;opacity:1}
  40%      {r:3;opacity:1}
  60%      {r:3;opacity:1}
  68%      {r:0;opacity:0}
  100%     {r:0;opacity:0}
}

/* FASE 3: traccia GPX si disegna (4.5-7.0s) */
.d-track #demoTrack,
#demoTrack{
  animation:demoStroke 9s ease-in-out infinite;
}
@keyframes demoStroke{
  0%, 50%   {stroke-dashoffset:100}
  72%       {stroke-dashoffset:0}
  90%       {stroke-dashoffset:0}
  100%      {stroke-dashoffset:0}
}
.d-track-start{
  animation:demoStartEnd 9s ease-out infinite;
  animation-delay:0s;
}
.d-track-end{
  animation:demoStartEnd 9s ease-out infinite;
  animation-delay:.25s;
}
@keyframes demoStartEnd{
  0%, 53%  {r:0}
  56%      {r:4}
  60%      {r:3}
  90%      {r:3}
  100%     {r:0}
}

/* FASE 4: badge "GPX pronto" (7.0-9.0s) */
.d-success{
  opacity:0;
  transform:scale(.85);
  transform-origin:140px 70px;
  animation:demoSuccess 9s ease-out infinite;
}
@keyframes demoSuccess{
  0%, 77%  {opacity:0;transform:scale(.85)}
  82%      {opacity:1;transform:scale(1.05)}
  85%      {opacity:1;transform:scale(1)}
  95%      {opacity:1;transform:scale(1)}
  100%     {opacity:0;transform:scale(1)}
}

/* Rispetto preferenza utente: niente animazione, mostra solo lo stato finale
 * (badge "GPX pronto" + mappa). Più accessibile per utenti con vertigini. */
@media (prefers-reduced-motion: reduce){
  .d-src, .d-cursor, .d-pointer, .d-tap, .d-anchor,
  .d-track-start, .d-track-end, .d-cap,
  .sc-demo-svg #demoTrack{
    animation:none;
  }
  .d-src{opacity:0}
  .d-dst{opacity:1;animation:none}
  .d-success{opacity:1;animation:none;transform:scale(1)}
  #demoTrack{stroke-dashoffset:0}
  .d-track-start, .d-track-end{r:3}
  .d-cap-4{opacity:1}
}
