/* ════════════════════════════════════════════════════════════════════
 * GPX-Tool — Design System "Komoot-style"
 * v1.0 — Apr 2026
 *
 * Filosofia:
 *  • Mobile-first, touch target ≥ 44px
 *  • Card pulite con bordi sottili, ZERO ombre forti
 *  • Tipografia bold per i numeri (statistiche), label MAIUSCOLE piccole
 *  • Bottom nav fissa stile Komoot
 *  • Brand color = arancio Strava #FC4C02 (decisione Paolo: arancio resta primary)
 *  • Palette neutra warm-grey
 *
 * Convenzione classi:
 *   .gx-*     = nuovi componenti del design system
 *   .card etc = ristilizzati in-place per non rompere JS hooks
 * ════════════════════════════════════════════════════════════════════ */

:root{
  /* Brand */
  --gx-brand:        #FC4C02;
  --gx-brand-dark:   #D63F00;
  --gx-brand-light:  #FFEEE5;
  --gx-brand-tint:   rgba(252,76,2,.08);
  --gx-brand-tint2:  rgba(252,76,2,.18);

  /* Neutrals — Komoot warm gray scale */
  --gx-n0:   #FFFFFF;
  --gx-n50:  #FAFAF7;
  --gx-n100: #F4F2EC;
  --gx-n150: #ECEAE3;
  --gx-n200: #E2DFD7;
  --gx-n300: #CDC9BE;
  --gx-n400: #A8A399;
  --gx-n500: #7C786F;
  --gx-n600: #54514A;
  --gx-n700: #2E2B26;
  --gx-n900: #100F0D;

  /* Semantic */
  --gx-ok:    #16A34A;
  --gx-err:   #DC2626;
  --gx-info:  #2563EB;
  --gx-warn:  #D97706;
  --gx-magic: #7C3AED;

  /* Sport colors */
  --gx-sp-bike: #FC4C02;
  --gx-sp-run:  #16A34A;
  --gx-sp-hike: #1A7F64;
  --gx-sp-walk: #06B6D4;

  /* Spacing scale */
  --gx-s1: 4px;
  --gx-s2: 8px;
  --gx-s3: 12px;
  --gx-s4: 16px;
  --gx-s5: 20px;
  --gx-s6: 24px;
  --gx-s7: 32px;

  /* Radius */
  --gx-r1: 8px;
  --gx-r2: 12px;
  --gx-r3: 16px;
  --gx-r-pill: 999px;

  /* Typography */
  --gx-sans: 'DM Sans','Inter',system-ui,sans-serif;
  --gx-disp: 'Outfit','DM Sans',sans-serif;

  /* Layout */
  --gx-hdr-h: 56px;
  --gx-bnav-h: 64px;
  --gx-safe-bot: env(safe-area-inset-bottom, 0px);
}

/* ── HEADER (top, slim) ───────────────────────────────────────────── */
.gx-hdr{
  height:var(--gx-hdr-h);
  background:var(--gx-n0);
  border-bottom:1px solid var(--gx-n200);
  display:flex;align-items:center;gap:10px;
  padding:0 var(--gx-s4);
  position:sticky;top:0;z-index:1000;
  font-family:var(--gx-sans);
}
.gx-hdr-logo{
  display:flex;align-items:center;gap:9px;
  text-decoration:none;cursor:pointer;flex-shrink:0;
  border:none;background:none;padding:0;
  font-family:var(--gx-disp);
}
.gx-hdr-logo svg{display:block;width:32px;height:32px;border-radius:7px}
.gx-hdr-logo .gx-wm{
  font-size:22px;letter-spacing:-.02em;line-height:1;display:flex;align-items:baseline;
}
.gx-hdr-logo .gx-wm-gpx{font-weight:800;color:var(--gx-n900)}
.gx-hdr-logo .gx-wm-sep{font-weight:800;color:var(--gx-brand);margin:0 1px}
.gx-hdr-logo .gx-wm-tool{font-weight:400;color:var(--gx-n500)}
.gx-hdr-actions{display:flex;align-items:center;gap:var(--gx-s2);margin-left:auto;flex-shrink:0}

/* Bike toggle, pill style */
.gx-bike{
  display:inline-flex;align-items:center;gap:6px;
  height:34px;padding:0 12px;
  background:var(--gx-n100);border:none;
  color:var(--gx-n700);
  border-radius:var(--gx-r-pill);
  font-size:13px;font-weight:600;cursor:pointer;
  transition:background .15s,color .15s;
  white-space:nowrap;-webkit-tap-highlight-color:transparent;
  font-family:inherit;
}
.gx-bike:hover{background:var(--gx-n150)}
.gx-bike svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.gx-bike.is-on{background:var(--gx-brand);color:#fff}
.gx-bike.is-on:hover{background:var(--gx-brand-dark)}

/* Generic icon header button (sync, etc.) */
.gx-hdr-ic{
  width:34px;height:34px;border-radius:var(--gx-r-pill);
  background:var(--gx-n100);border:none;color:var(--gx-n700);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:15px;
  transition:background .15s;
  text-decoration:none;flex-shrink:0;
}
.gx-hdr-ic:hover{background:var(--gx-n150)}
.gx-hdr-ic svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.gx-hdr-ic.spin svg{animation:gx-spin 1s linear infinite}

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

/* Avatar */
.gx-hdr-avatar,
.hdr-avatar{
  width:34px;height:34px;border-radius:50%;
  object-fit:cover;cursor:pointer;display:block;
  border:2px solid var(--gx-n200);
  flex-shrink:0;
}

/* Bottone "Esci" — pill style come .gx-bike (alias legacy renderizzato dal JS template
   in 5 pagine: index, activity, archivio, editor, snap) */
.hdr-guide{
  display:inline-flex;align-items:center;gap:6px;
  height:34px;padding:0 12px;
  background:var(--gx-n100);border:none;
  color:var(--gx-n700);
  border-radius:var(--gx-r-pill);
  font-family:var(--gx-sans);
  font-size:13px;font-weight:600;
  cursor:pointer;
  transition:background .15s,color .15s;
  white-space:nowrap;flex-shrink:0;
  -webkit-tap-highlight-color:transparent;
}
.hdr-guide:hover,.hdr-guide:active{
  background:var(--gx-n150);
  color:var(--gx-n900);
}
body.bike-mode .hdr-guide{height:42px;padding:0 16px;font-size:15px}
body.bike-mode .hdr-avatar,body.bike-mode .gx-hdr-avatar{width:40px;height:40px}

/* ── BOTTOM NAV (Komoot-style) ────────────────────────────────────── */
.gx-bnav{
  box-sizing:content-box;
  position:fixed;left:0;right:0;bottom:0;z-index:300;
  /* v324 — Navbar in negativo: sfondo scuro ad alto contrasto contro lo
   * sfondo bianco delle pagine (prima era bianca su bianco → si perdeva).
   * Stesse dimensioni, stesso layout, stesso padding. Solo i colori sono
   * invertiti: bg n900 (quasi nero), label/icone n300 (grigio chiaro)
   * inattive, brand arancione vivido per active. Shadow sopra accentuata
   * per stacco visivo netto. */
  background:var(--gx-n900);
  border-top:1px solid var(--gx-n700);
  box-shadow:0 -4px 16px rgba(0,0,0,.18);
  padding:6px 6px calc(10px + var(--gx-safe-bot));
  display:flex;align-items:stretch;
  font-family:var(--gx-sans);
}
.gx-bnav-item{
  box-sizing:content-box;
  flex:1;min-width:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;padding:6px 4px;
  background:transparent;border:none;
  /* v324 — Inactive su sfondo scuro: grigio chiaro n300, leggibile su n900 */
  color:var(--gx-n300);
  font-family:inherit;font-size:11px;font-weight:600;
  letter-spacing:-.005em;
  cursor:pointer;
  border-radius:var(--gx-r2);
  transition:color .15s;
  text-decoration:none;
  -webkit-tap-highlight-color:transparent;
}
.gx-bnav-item svg{
  width:22px;height:22px;
  stroke:currentColor;fill:none;
  stroke-width:2;stroke-linecap:round;stroke-linejoin:round;
  transition:stroke-width .15s;
}
.gx-bnav-item.is-active{color:var(--gx-brand)}
.gx-bnav-item.is-active svg{stroke-width:2.4}
.gx-bnav-item.is-active .gx-bnav-lbl{font-weight:700}
.gx-bnav-item:active:not(:disabled){transform:scale(.94)}
.gx-bnav-item:disabled{
  cursor:default;
  -webkit-appearance:none;
  appearance:none;
  /* v324 — Su sfondo scuro disabled = grigio più scuro per restare leggibile
   * ma chiaramente disabilitato */
  color:var(--gx-n500);
  opacity:.7;
}
.gx-bnav-item:focus{outline:none}
.gx-bnav-item:focus-visible{outline:2px solid var(--gx-brand);outline-offset:2px;border-radius:8px}

/* Bottom nav clearance: pages with bnav need bottom padding */
body.gx-has-bnav{padding-bottom:calc(var(--gx-bnav-h) + var(--gx-safe-bot))}

/* ── BUTTONS ──────────────────────────────────────────────────────── */
.gx-btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:6px;
  height:44px;padding:0 18px;
  font-family:var(--gx-sans);
  font-size:15px;font-weight:700;letter-spacing:-.005em;
  background:var(--gx-n100);color:var(--gx-n700);
  border:none;border-radius:var(--gx-r2);
  cursor:pointer;
  transition:background .15s,color .15s,transform .08s;
  -webkit-tap-highlight-color:transparent;white-space:nowrap;
  text-decoration:none;
}
.gx-btn:hover{background:var(--gx-n150)}
.gx-btn:active:not(:disabled){transform:scale(.97)}
.gx-btn:disabled{opacity:.45;cursor:not-allowed}
.gx-btn svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}

.gx-btn.is-primary{background:var(--gx-brand);color:#fff}
.gx-btn.is-primary:hover{background:var(--gx-brand-dark)}

.gx-btn.is-dark{background:var(--gx-n900);color:#fff}
.gx-btn.is-dark:hover{background:#000}

.gx-btn.is-ghost{background:transparent;color:var(--gx-n700);border:1px solid var(--gx-n200)}
.gx-btn.is-ghost:hover{background:var(--gx-n100)}

.gx-btn.is-danger{background:var(--gx-err);color:#fff}
.gx-btn.is-danger:hover{background:#B91C1C}

.gx-btn.is-block{width:100%}
.gx-btn.is-sm{height:36px;font-size:13px;padding:0 14px;border-radius:var(--gx-r1)}
.gx-btn.is-lg{height:52px;font-size:16px;padding:0 24px}

/* ── CHIPS (filter pills) ─────────────────────────────────────────── */
.gx-chips{
  display:flex;gap:8px;
  padding:10px var(--gx-s4);
  overflow-x:auto;scrollbar-width:none;
  background:var(--gx-n0);
  border-bottom:1px solid var(--gx-n200);
}
.gx-chips::-webkit-scrollbar{display:none}
.gx-chip{
  display:inline-flex;align-items:center;gap:6px;
  height:32px;padding:0 14px;flex-shrink:0;
  background:var(--gx-n100);color:var(--gx-n600);
  border:none;
  border-radius:var(--gx-r-pill);
  font-family:var(--gx-sans);font-size:13px;font-weight:600;
  cursor:pointer;
  transition:background .12s,color .12s;
  white-space:nowrap;
  -webkit-tap-highlight-color:transparent;
}
.gx-chip:hover{background:var(--gx-n150)}
.gx-chip.is-active{background:var(--gx-n900);color:#fff}
.gx-chip svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}

/* ── STATS GRID ───────────────────────────────────────────────────── */
.gx-stats{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:8px;
  font-variant-numeric:tabular-nums;
}
.gx-stats.is-3col{grid-template-columns:repeat(3, minmax(0,1fr))}
.gx-stats.is-2col{grid-template-columns:repeat(2, minmax(0,1fr))}
.gx-stat{display:flex;flex-direction:column;align-items:flex-start;min-width:0}
.gx-stat-num{
  font-family:var(--gx-disp);
  font-size:18px;font-weight:800;letter-spacing:-.02em;
  color:var(--gx-n900);line-height:1;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  max-width:100%;
}
.gx-stat-lbl{
  font-size:10px;font-weight:600;color:var(--gx-n500);
  text-transform:uppercase;letter-spacing:.04em;
  margin-top:5px;line-height:1;
}
.gx-stat.is-lg .gx-stat-num{font-size:24px}

/* ── CARD (generic surface) ───────────────────────────────────────── */
.gx-card{
  background:var(--gx-n0);
  border:1px solid var(--gx-n200);
  border-radius:var(--gx-r3);
  overflow:hidden;
}
.gx-card-padded{padding:var(--gx-s4)}

/* ── PILL (small overlay tag) ─────────────────────────────────────── */
.gx-tag{
  display:inline-flex;align-items:center;gap:5px;
  height:24px;padding:0 9px;
  background:rgba(255,255,255,.95);
  color:var(--gx-n900);
  border-radius:var(--gx-r-pill);
  font-size:11px;font-weight:700;letter-spacing:.005em;
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
}
.gx-tag svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.gx-tag.is-dark{background:rgba(20,20,18,.85);color:#fff}
.gx-tag.is-snap{background:var(--gx-ok);color:#fff;font-size:10px;letter-spacing:.05em}

/* ── TOAST (top center) ───────────────────────────────────────────── */
.gx-toast{
  position:fixed;
  top:calc(env(safe-area-inset-top,0) + 14px);
  left:50%;transform:translateX(-50%) translateY(-8px);
  z-index:9999;
  background:var(--gx-n900);color:#fff;
  padding:10px 18px;
  border-radius:var(--gx-r-pill);
  font-family:var(--gx-sans);font-weight:600;font-size:13px;
  box-shadow:0 4px 16px rgba(0,0,0,.18);
  opacity:0;transition:opacity .25s,transform .25s;
  pointer-events:none;white-space:nowrap;
}
.gx-toast.is-show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── EMPTY STATE ──────────────────────────────────────────────────── */
.gx-empty{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:60px 24px;text-align:center;color:var(--gx-n500);
  font-family:var(--gx-sans);
}
.gx-empty-ic{
  width:64px;height:64px;border-radius:50%;
  background:var(--gx-n100);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:14px;
  color:var(--gx-n400);
}
.gx-empty-ic svg{width:28px;height:28px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.gx-empty-h{font-size:16px;font-weight:700;color:var(--gx-n700);margin-bottom:6px}
.gx-empty-d{font-size:13px;line-height:1.55;max-width:280px}

/* ── LOADER ───────────────────────────────────────────────────────── */
.gx-loader{
  display:flex;align-items:center;justify-content:center;gap:10px;
  padding:48px 24px;
  color:var(--gx-n500);
  font-family:var(--gx-sans);font-size:13px;font-weight:500;
}
.gx-spin{
  width:18px;height:18px;
  border:2.2px solid var(--gx-n200);
  border-top-color:var(--gx-brand);
  border-radius:50%;
  animation:gx-spin .7s linear infinite;
}

/* ── DIVIDER ──────────────────────────────────────────────────────── */
.gx-hr{height:1px;background:var(--gx-n200);border:none;margin:0}
.gx-hr-soft{height:1px;background:var(--gx-n150);border:none;margin:0}

/* ── BIKE MODE OVERRIDES (touch target ≥ 54px) ────────────────────── */
body.bike-mode .gx-btn{min-height:54px;font-size:17px;padding:0 22px}
body.bike-mode .gx-btn.is-sm{min-height:46px;font-size:15px}
body.bike-mode .gx-chip{height:40px;font-size:15px;padding:0 18px}
body.bike-mode .gx-bnav{padding-top:8px;padding-bottom:calc(10px + var(--gx-safe-bot))}
body.bike-mode .gx-bnav-item svg{width:26px;height:26px}
body.bike-mode .gx-bnav-item{font-size:12px}
body.bike-mode .gx-bnav-item .gx-bnav-lbl{font-weight:700}
body.bike-mode.gx-has-bnav{padding-bottom:calc(var(--gx-bnav-h) + 18px + var(--gx-safe-bot))}
body.bike-mode .gx-stat-num{font-size:22px}
body.bike-mode .gx-stat.is-lg .gx-stat-num{font-size:28px}

/* ── GLOBAL TYPOGRAPHIC RESET (light touch) ───────────────────────── */
.gx-h1{font-family:var(--gx-disp);font-size:28px;font-weight:800;letter-spacing:-.02em;line-height:1.15;color:var(--gx-n900);margin:0}
.gx-h2{font-family:var(--gx-disp);font-size:22px;font-weight:800;letter-spacing:-.015em;line-height:1.2;color:var(--gx-n900);margin:0}
.gx-h3{font-family:var(--gx-sans);font-size:17px;font-weight:700;letter-spacing:-.005em;line-height:1.25;color:var(--gx-n900);margin:0}
.gx-meta{font-size:11px;font-weight:600;color:var(--gx-n500);text-transform:uppercase;letter-spacing:.05em}
.gx-body{font-size:15px;line-height:1.55;color:var(--gx-n700)}
.gx-text-muted{color:var(--gx-n500)}
.gx-text-brand{color:var(--gx-brand)}

/* ── UTILITIES ────────────────────────────────────────────────────── */
.gx-row{display:flex;gap:var(--gx-s3);align-items:center}
.gx-col{display:flex;flex-direction:column;gap:var(--gx-s3)}
.gx-grow{flex:1;min-width:0}
.gx-mb-2{margin-bottom:var(--gx-s2)}
.gx-mb-3{margin-bottom:var(--gx-s3)}
.gx-mb-4{margin-bottom:var(--gx-s4)}
.gx-mt-2{margin-top:var(--gx-s2)}
.gx-mt-3{margin-top:var(--gx-s3)}
.gx-mt-4{margin-top:var(--gx-s4)}
.gx-px-4{padding-left:var(--gx-s4);padding-right:var(--gx-s4)}
.gx-py-3{padding-top:var(--gx-s3);padding-bottom:var(--gx-s3)}

/* ── PAGE BACKDROP ────────────────────────────────────────────────── */
body.gx-page{background:var(--gx-n50);color:var(--gx-n700);font-family:var(--gx-sans)}

/* ══════════════════════════════════════════════════════════════════
 * KOMOOT-STYLE ACTIVITY CARD
 * Layout: thumb mappa GRANDE in alto, body sotto con titolo + stats.
 * ══════════════════════════════════════════════════════════════════ */

.gx-act-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(320px, 1fr));
  gap:14px;
  padding:14px var(--gx-s4) 24px;
}
@media (max-width:520px){
  .gx-act-grid{grid-template-columns:1fr;padding:12px var(--gx-s3) 18px;gap:12px}
}

.gx-act-card{
  background:var(--gx-n0);
  border:1px solid var(--gx-n200);
  border-radius:var(--gx-r3);
  overflow:hidden;
  cursor:pointer;
  position:relative;
  transition:border-color .15s,transform .12s;
  user-select:none;
}
.gx-act-card:hover{border-color:var(--gx-n300)}
.gx-act-card:active{transform:scale(.992)}
.gx-act-card.selected{
  border-color:var(--gx-brand);
  box-shadow:0 0 0 2px var(--gx-brand);
}
.gx-act-card.map-highlight{
  border-color:var(--gx-brand);
  box-shadow:0 0 0 2px var(--gx-brand-tint2);
}

.gx-act-thumb{
  position:relative;
  height:170px;
  background:var(--gx-n100);
  border-bottom:1px solid var(--gx-n200);
  display:block;
  overflow:hidden;
}
.gx-act-thumb svg{width:100%;height:100%;display:block}

.gx-act-thumb-overlay{
  position:absolute;inset:0;
  pointer-events:none;
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  padding:10px;
}
.gx-act-thumb-overlay > *{pointer-events:auto}

.gx-act-tag-row{display:flex;gap:6px;flex-wrap:wrap}

.gx-act-menu{
  width:32px;height:32px;
  border-radius:var(--gx-r-pill);
  background:rgba(255,255,255,.95);
  border:none;
  color:var(--gx-n700);
  font-size:18px;font-weight:700;line-height:0;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background .15s;
  -webkit-tap-highlight-color:transparent;
}
.gx-act-menu:hover{background:#fff}
.gx-act-menu:active{transform:scale(.92)}

/* Selection check overlay */
.gx-act-check{
  position:absolute;top:10px;right:50px;
  width:28px;height:28px;border-radius:50%;
  background:var(--gx-brand);color:#fff;
  display:none;align-items:center;justify-content:center;
  font-size:13px;font-weight:800;
  box-shadow:0 2px 8px rgba(0,0,0,.18);
}
.gx-act-card.selected .gx-act-check{display:flex}

.gx-act-body{padding:12px var(--gx-s4) 14px}
.gx-act-meta{
  font-size:11px;font-weight:600;color:var(--gx-n500);
  text-transform:uppercase;letter-spacing:.05em;
  margin-bottom:4px;line-height:1;
}
.gx-act-name{
  font-family:var(--gx-sans);
  font-size:16px;font-weight:700;color:var(--gx-n900);
  letter-spacing:-.005em;line-height:1.3;
  margin-bottom:12px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.gx-act-stats{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:6px;
  padding-top:12px;
  border-top:1px solid var(--gx-n150);
  font-variant-numeric:tabular-nums;
}
.gx-act-stats.is-3col{grid-template-columns:repeat(3, minmax(0,1fr))}
.gx-act-stat-num{
  font-family:var(--gx-disp);
  font-size:17px;font-weight:800;letter-spacing:-.02em;
  color:var(--gx-n900);line-height:1;
}
.gx-act-stat-lbl{
  font-size:9.5px;font-weight:700;color:var(--gx-n500);
  text-transform:uppercase;letter-spacing:.05em;
  margin-top:4px;line-height:1;
}

body.bike-mode .gx-act-stat-num{font-size:21px}
body.bike-mode .gx-act-stat-lbl{font-size:11px}
body.bike-mode .gx-act-name{font-size:18px}

/* ── BOTTOM SHEET MODAL ───────────────────────────────────────────── */
.gx-sheet-bg{
  position:fixed;inset:0;z-index:500;
  background:rgba(15,14,12,.55);
  display:none;
  -webkit-tap-highlight-color:transparent;
}
.gx-sheet-bg.is-open{display:block;animation:gx-fade .2s ease}
@keyframes gx-fade{from{opacity:0}to{opacity:1}}

.gx-sheet{
  position:fixed;left:0;right:0;bottom:0;z-index:501;
  background:var(--gx-n0);
  border-radius:24px 24px 0 0;
  padding:14px var(--gx-s4) calc(var(--gx-s5) + var(--gx-safe-bot));
  max-height:85vh;overflow-y:auto;
  font-family:var(--gx-sans);
  transform:translateY(100%);
  transition:transform .28s cubic-bezier(.22,1,.36,1);
  box-shadow:0 -8px 32px rgba(0,0,0,.18);
}
.gx-sheet.is-open{transform:translateY(0)}
.gx-sheet-grab{
  width:36px;height:4px;
  background:var(--gx-n300);
  border-radius:2px;
  margin:0 auto 14px;
}
.gx-sheet-h{
  font-family:var(--gx-sans);
  font-size:18px;font-weight:700;
  color:var(--gx-n900);
  margin-bottom:14px;
}

/* Print-only utility */
@media print{
  .gx-bnav, .gx-hdr{display:none!important}
  body.gx-has-bnav{padding-bottom:0!important}
}

/* ══════════════════════════════════════════════════════════════════
 * ACCOUNT BOTTOM SHEET (shared via gpxt-account.js)
 * ══════════════════════════════════════════════════════════════════ */
.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(--gx-n0);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;font-family:var(--gx-sans)}
.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(--gx-n200);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(--gx-n200)}
.acc-avatar{width:64px;height:64px;border-radius:50%;object-fit:cover;border:2px solid var(--gx-n200);flex:none}
.acc-avatar-fallback{width:64px;height:64px;border-radius:50%;background:var(--gx-brand);color:#fff;font-family:var(--gx-disp);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:var(--gx-disp);font-weight:800;font-size:18px;letter-spacing:-.3px;color:var(--gx-n900);line-height:1.2;word-break:break-word}
.acc-meta{font-size:12.5px;color:var(--gx-n400);margin-top:4px;line-height:1.4}
.acc-row{display:flex;align-items:center;gap:12px;width:100%;padding:14px 12px;background:var(--gx-n100);border:none;border-radius:12px;color:var(--gx-n900);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(--gx-n200)}
.acc-row svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex:none;color:var(--gx-n500)}
.acc-row.is-danger{color:#DC2626}
.acc-row.is-danger svg{color:#DC2626}

/* ══════════════════════════════════════════════════════════════════
 * COMPONENT EXTENSIONS — varianti per i componenti esistenti
 * (.gx-sheet, .gx-toast, .gx-spin sono già definiti sopra)
 * ══════════════════════════════════════════════════════════════════ */

/* gx-toast variants: aggiungi una di queste classi a .gx-toast */
.gx-toast-success{background:#16A34A}
.gx-toast-error{background:#DC2626}
.gx-toast-info{background:#2563EB}

/* gx-spin variants */
.gx-spin-lg{width:28px;height:28px;border-width:3px}
.gx-spin-sm{width:12px;height:12px;border-width:1.5px}

/* ══════════════════════════════════════════════════════════════════
 * GX-INPUT — Input testuali coerenti
 *
 * Uso: <input type="text" class="gx-input">
 * Variants: .gx-input-sm (h:32px), .gx-input-lg (h:44px)
 * ══════════════════════════════════════════════════════════════════ */
.gx-input{
  width:100%;
  background:var(--gx-n0);
  border:1.5px solid var(--gx-n200);
  color:var(--gx-n900);
  padding:8px 14px;height:36px;
  border-radius:10px;
  font-size:14px;
  font-family:var(--gx-sans);
  outline:none;
  transition:border-color .15s,box-shadow .15s;
  -webkit-appearance:none;appearance:none;
}
.gx-input::placeholder{color:var(--gx-n500)}
.gx-input:focus{border-color:var(--gx-brand);box-shadow:0 0 0 3px var(--gx-brand-tint)}
.gx-input-sm{height:32px;padding:6px 12px;font-size:13px;border-radius:8px}
.gx-input-lg{height:44px;padding:10px 16px;font-size:15px;border-radius:12px}

/* ════════════════════════════════════════════════════════════════════
 * POPOVER MENU (shared via GPXT_UI.popover)
 * Usato da index, archivio e altre pagine con card che hanno menu ⋯.
 * ════════════════════════════════════════════════════════════════════ */
.card-popover{
  position:fixed;z-index:1500;
  background:var(--bg2);border:1px solid var(--border);
  border-radius:14px;box-shadow:0 12px 32px rgba(0,0,0,.14),0 2px 6px rgba(0,0,0,.06);
  padding:6px;min-width:220px;
  opacity:0;transform:scale(.92) translateY(-4px);transform-origin:top right;
  transition:opacity .15s ease, transform .15s ease;
  pointer-events:none;
}
.card-popover.open{opacity:1;transform:scale(1) translateY(0);pointer-events:auto}
.card-popover.flip-down{transform-origin:bottom right;transform:scale(.92) translateY(4px)}
.card-popover.flip-down.open{transform:scale(1) translateY(0)}
.cp-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 12px;border-radius:10px;
  font-family:var(--sans);font-size:14px;color:var(--text);font-weight:500;
  cursor:pointer;transition:background .12s;
  border:none;background:none;width:100%;text-align:left;line-height:1.2;
}
.cp-item:hover{background:var(--bg3)}
.cp-item:active{background:var(--bg4)}
.cp-item .cp-ic{font-size:16px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;text-align:center;flex-shrink:0}
.cp-item .cp-ic svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.cp-item .cp-lb{flex:1;font-weight:500}
.cp-divider{height:1px;background:var(--border);margin:4px 6px}
.cp-item.act-nav    { color:#2563EB; }
.cp-item.act-nav:hover    { background:rgba(37,99,235,.08); }
.cp-item.act-snap   { color:#16A34A; }
.cp-item.act-snap:hover   { background:rgba(22,163,74,.08); }
.cp-item.act-edit   { color:#7C3AED; }
.cp-item.act-edit:hover   { background:rgba(124,58,237,.08); }
.cp-item.act-alt    { color:#8B5CF6; }
.cp-item.act-alt:hover    { background:rgba(139,92,246,.08); }
.cp-item.act-cross  { color:#0891B2; }
.cp-item.act-cross:hover  { background:rgba(8,145,178,.08); }
.cp-item.act-cmp    { color:#FC4C02; }
.cp-item.act-cmp:hover    { background:rgba(252,76,2,.08); }
.cp-item.act-archive { color:#A16207; }
.cp-item.act-archive:hover { background:rgba(234,179,8,.10); }
.cp-item.danger     { color:var(--red); }
.cp-item.danger:hover { background:rgba(220,38,38,.08); }
.card-popover-backdrop{position:fixed;inset:0;z-index:1499;background:transparent;display:none}
.card-popover-backdrop.open{display:block}

/* ════════════════════════════════════════════════════════════════════
 * ACTIVITY CARD (Komoot-style) — shared
 * Usato da index e archivio. Layout identico, solo le azioni nei
 * popover/menu cambiano in base al contesto.
 * ════════════════════════════════════════════════════════════════════ */
.card{
  background:var(--bg2);border:1px solid var(--border);border-radius:16px;
  cursor:pointer;transition:border-color .15s,transform .12s;
  position:relative;overflow:hidden;user-select:none;
}
.card:hover{border-color:var(--border2)}
.card:active{transform:scale(.992)}
.card.selected{border-color:var(--orange);box-shadow:0 0 0 2px var(--orange)}
.card.map-highlight{border-color:var(--c,var(--orange));box-shadow:0 0 0 2px var(--orm)}
.card-thumb{
  position:relative;height:170px;
  background:#F2EFE8;
  border-bottom:1px solid var(--border);
  display:block;overflow:hidden;
}
.card-thumb .card-tile{position:absolute;width:256px;height:256px;pointer-events:none;image-rendering:auto}
.card-thumb svg.card-trace{position:absolute;pointer-events:none}
.card-thumb-overlay{
  position:absolute;inset:0;pointer-events:none;
  display:flex;justify-content:space-between;align-items:flex-start;
  padding:10px;
}
.card-thumb-overlay > *{pointer-events:auto}
.card-tag-row{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.card-sport{
  display:inline-flex;align-items:center;gap:5px;
  height:26px;padding:0 10px;
  background:rgba(255,255,255,.95);color:var(--text);
  border-radius:999px;
  font-size:11px;font-weight:700;letter-spacing:.005em;white-space:nowrap;
}
.card-sport-ic{display:inline-flex;align-items:center;line-height:1}
.card-sport.has-c{color:var(--c,var(--orange))}
.card-snap-badge{
  background:var(--green);color:#fff;
  height:24px;padding:0 8px;border-radius:999px;
  font-size:9.5px;font-weight:800;letter-spacing:.06em;
  display:inline-flex;align-items:center;
}
.card-menu{
  width:32px;height:32px;border-radius:999px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.95);border:none;color:var(--text);
  font-size:18px;font-weight:700;
  cursor:pointer;transition:background .15s,transform .12s;
  line-height:0;-webkit-tap-highlight-color:transparent;
}
.card-menu:hover{background:#fff}
.card-menu:active{transform:scale(.92)}
.card-menu.is-open{background:#fff;color:var(--orange)}
.card-sel-chk{
  position:absolute;top:10px;right:50px;
  width:28px;height:28px;border-radius:50%;
  background:var(--orange);color:#fff;
  display:none;align-items:center;justify-content:center;
  font-size:13px;font-weight:800;z-index:2;
  box-shadow:0 2px 8px rgba(0,0,0,.18);
}
.card.selected .card-sel-chk{display:flex}
.card-body{padding:12px 16px 14px}
.card-meta{
  font-size:11px;font-weight:600;color:var(--text3);
  text-transform:uppercase;letter-spacing:.05em;
  margin-bottom:4px;line-height:1;
  display:flex;align-items:center;gap:6px;
}
.card-meta .card-meta-dot{color:var(--border2)}
.card-name{
  font-family:var(--sans);
  font-size:16px;font-weight:700;color:var(--text);
  letter-spacing:-.005em;line-height:1.3;
  margin-bottom:12px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.card-stats{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));
  gap:6px;padding-top:12px;
  border-top:1px solid var(--bg4);
  font-variant-numeric:tabular-nums;
}
.card-stats.is-3col{grid-template-columns:repeat(3,minmax(0,1fr))}
.st{display:flex;flex-direction:column;align-items:flex-start;min-width:0}
.st-v{
  font-family:'Outfit',sans-serif;
  font-size:17px;font-weight:800;letter-spacing:-.02em;
  color:var(--text);line-height:1;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;
}
.st-l{
  font-size:9.5px;font-weight:700;color:var(--text3);
  text-transform:uppercase;letter-spacing:.05em;
  margin-top:5px;line-height:1;
}

/* ═══════════════════ MAPPA — CONTROLLI CONDIVISI (gpxt-mapctl.js) ═══════════════════
 * FAB layer cycle (stile studio), slider trasparenza, hint flyover.
 * Posizione standard: layers top-right, slider bottom-left.
 * Variabili attese: --bg2, --border, --text, --text3, --orange, --sh-m. */

.gx-fab{
  position:absolute;width:44px;height:44px;border-radius:22px;
  background:var(--bg2);box-shadow:var(--sh-m,0 4px 12px rgba(0,0,0,.15));
  display:flex;align-items:center;justify-content:center;color:var(--text);
  z-index:600;border:1px solid var(--border);
  transition:transform .12s,background .15s;
  cursor:pointer;
}
.gx-fab:active{transform:scale(.92);background:var(--bg3,var(--bg))}
.gx-fab:hover{background:var(--bg3,var(--bg))}
.gx-fab svg{width:22px;height:22px;fill:none;stroke:currentColor;
  stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* Posizioni standard layer FAB. Le pagine possono aggiungere classi mod
 * per spostarlo su un'altra slot se top-right è occupato. */
.gx-fab-layers{right:12px;top:12px}
.gx-fab-layers.gx-fab-slot-2{top:66px}
.gx-fab-layers.gx-fab-slot-3{top:120px}
.gx-fab-layers.gx-fab-slot-4{top:174px}

/* Hint flyover (toast top-center) usato dal cycle */
.gx-map-hint{
  position:absolute;left:50%;top:18px;transform:translate(-50%,-8px);
  background:rgba(0,0,0,.78);color:#fff;font-size:13px;font-weight:500;
  padding:6px 12px;border-radius:18px;z-index:650;pointer-events:none;
  opacity:0;transition:opacity .2s,transform .2s;
}
.gx-map-hint.show{opacity:1;transform:translate(-50%,0)}

/* Slider trasparenza tracce sfondo (bottom-left) */
.gx-track-opacity{
  position:absolute;left:12px;bottom:12px;z-index:600;
  background:var(--bg2);border:1px solid var(--border);border-radius:22px;
  box-shadow:var(--sh-m,0 4px 12px rgba(0,0,0,.15));
  height:38px;display:flex;align-items:center;gap:8px;padding:0 12px 0 10px;
}
.gx-track-opacity .gx-tro-icon{display:flex;align-items:center;color:var(--text3);}
.gx-track-opacity .gx-tro-icon svg{width:14px;height:14px;fill:none;stroke:currentColor;
  stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.gx-track-opacity .gx-tro-range{
  width:90px;height:4px;background:var(--border);border-radius:2px;
  -webkit-appearance:none;appearance:none;cursor:pointer;outline:none;
}
.gx-track-opacity .gx-tro-range::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;width:16px;height:16px;
  background:var(--orange,#FC4C02);border-radius:8px;border:2px solid var(--bg2);
  box-shadow:0 1px 3px rgba(0,0,0,.2);cursor:pointer;
}
.gx-track-opacity .gx-tro-range::-moz-range-thumb{
  width:16px;height:16px;background:var(--orange,#FC4C02);border-radius:8px;
  border:2px solid var(--bg2);cursor:pointer;
}

/* ══════════════════════════════════════════════════════════════════════
 * MAPPA — FAB layer toggle + slider trasparenza tracce sfondo.
 * Pattern uniforme per index, navigate, archivio, activity, snap, share.
 *
 * Posizionamento standard (coerente tra pagine):
 *   - top-right: FAB layers (cycle pulita/osm/satellite[/dark])
 *   - bottom-left: slider trasparenza sfondo (solo dove ha senso)
 * Le pagine possono aggiungere altri FAB (locate, fullscreen, settings)
 * sotto al layer button verticalmente, sempre con offset 54px (44 + 10).
 * ══════════════════════════════════════════════════════════════════════ */
.gpxt-map-fab{
  position:absolute;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);z-index:600;cursor:pointer;
  -webkit-tap-highlight-color:transparent;
  transition:transform .12s,background .15s;
}
.gpxt-map-fab:active{transform:scale(.92);background:var(--bg3,#f5f3ef)}
.gpxt-map-fab svg{
  width:22px;height:22px;
  fill:none;stroke:currentColor;stroke-width:2;
  stroke-linecap:round;stroke-linejoin:round;
}
.gpxt-map-fab.is-layers{right:12px;top:12px}
.gpxt-map-fab.is-locate{right:12px;top:66px}

/* Slider trasparenza tracce sfondo: VERTICALE a sinistra, centrato in altezza.
 * Posizionato sotto i tool selezione (#draw-tools), prima dell'attribution.
 * Si nasconde automaticamente se non ci sono tracce sfondo (.is-empty). */
.gpxt-bg-slider{
  position:absolute;left:12px;
  /* Centrato verticalmente, ma con offset per non collidere con i FAB
   * superiori (filters + draw-tools = ~ 220px) e attribution Leaflet. */
  top:50%;transform:translateY(-50%);
  z-index:600;
  width:36px;height:160px;
  display:flex;align-items:center;justify-content:center;
  padding:10px 0;
  background:var(--bg2);border:1px solid var(--border);border-radius:18px;
  box-shadow:var(--sh-m,0 4px 12px rgba(0,0,0,.12));
}
.gpxt-bg-slider input[type=range]{
  /* Range verticale via rotation. Width effettiva = altezza disponibile,
   * height = thickness della barra. */
  -webkit-appearance:none;appearance:none;
  width:140px;height:3px;margin:0;padding:0;
  background:var(--border);border-radius:2px;cursor:pointer;
  transform:rotate(-90deg);transform-origin:center center;
}
.gpxt-bg-slider input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;width:16px;height:16px;
  background:var(--text);border-radius:8px;border:2px solid var(--bg2);
  cursor:pointer;
}
.gpxt-bg-slider input[type=range]::-moz-range-thumb{
  width:16px;height:16px;background:var(--text);
  border-radius:8px;border:2px solid var(--bg2);cursor:pointer;
}
.gpxt-bg-slider.is-empty{display:none}

/* ══════════════════════════════════════════════════════════════════════
 * DESKTOP OVERRIDES — applicabili solo su viewport ≥ 900px.
 * Il prodotto è mobile-first; queste regole correggono layout che
 * altrimenti si stirano o appaiono sproporzionati su schermi grandi.
 *
 * Strategia: container max-width centrati, bnav floating rounded,
 * sheet/modal centrati invece che full-width, cursor pointer su elementi
 * cliccabili.
 * ════════════════════════════════════════════════════════════════════ */
@media (min-width:900px) {
  /* Bottom nav: pillola galleggiante centrata invece di barra full-width.
   * Desktop l'utente non ha bisogno del thumb-reach mobile, il design
   * floating è più moderno e libera spazio sui lati per altri controlli. */
  .gx-bnav{
    max-width:560px;
    left:50%;right:auto;
    transform:translateX(-50%);
    bottom:16px;
    border-radius:16px;
    border:1px solid var(--gx-n200);
    box-shadow:0 6px 24px rgba(0,0,0,.10);
    padding:8px 8px;
  }
  /* Bnav-aware page bottom padding: il content non deve finire sotto
   * la pillola, ma servono solo i 16px di margin in più. */
  body.gx-page.gx-has-bnav{
    padding-bottom:calc(var(--gx-bnav-h) + 32px);
  }

  /* Cursor pointer: desktop l'utente clicca col mouse, gli elementi
   * tappabili devono avere il cursor a mano. */
  .chip,.list-chip,.sheet-chip,.sheet-photo,.photo-item,
  .gx-bnav-item,.gx-act,.gpxt-map-fab,.draw-tool-btn,
  .filters-btn,.fab,.nav-fab,.map-back-fab,
  .gx-act-thumb,.fp-sport-grid .chip,.fp-gps-btn,
  .nav-confirm-btn,.nav-modal-btn,.nav-mode-btn{
    cursor:pointer;
  }

  /* Hover feedback più marcato su elementi interattivi */
  .chip:hover,.list-chip:hover,.sheet-chip:hover{
    border-color:var(--text2);
  }
  .photo-item:hover img{
    transform:scale(1.04);
  }
  .photo-item img{
    transition:transform .25s ease;
  }
}

/* Container max-width centrati (sempre, anche su tablet) */
@media (min-width:768px) {
  /* Index: griglia card centrata, max 1200px (era full-width) */
  body.gx-page.view-list .grid{
    max-width:1200px;
    margin:0 auto;
  }

  /* Activity: detail-wrap centrato */
  .detail-wrap{
    max-width:1400px;
    margin:0 auto;
  }

  /* Sheet bottom (archivio): centrato come modal floating su desktop,
   * non più full-width che si stira. La pagina archivio definisce
   * .sheet con transform:translateY(100%) (chiuso) → translateY(0) (aperto):
   * dobbiamo combinare il translateX(-50%) per centrare orizzontalmente. */
  .sheet,.gx-sheet{
    max-width:560px;
    left:50% !important;
    right:auto !important;
    transform:translate(-50%, 100%) !important;
    border-radius:18px 18px 0 0;
    box-shadow:0 -6px 32px rgba(0,0,0,.15);
  }
  .sheet.is-open,.gx-sheet.is-open{
    transform:translate(-50%, 0) !important;
  }
}

/* Mappa globale index: altezza dinamica su schermi grandi */
@media (min-width:900px) {
  #global-map{
    height:60vh;
    min-height:420px;
    max-height:680px;
  }

  /* Studio è full-screen con .app fixed. Con bnav floating (bottom:16, h:58),
   * estendo la mappa fino a 0 così il bnav si sovrappone con la sua ombra/
   * sfondo opaco invece di lasciare un gap visivo brutto. */
  body.gx-page.gx-has-bnav .app{
    bottom:0;
  }

  /* Mappa fullscreen (view-map) su desktop: tutta la larghezza pagina,
   * altezza fino in fondo al viewport. Il bnav è in modalità floating
   * pill e si sovrappone visivamente alla mappa (no fascia bianca). */
  body.view-map #global-map-section{
    max-width:none;
    margin:0;
    height:100vh;
    box-sizing:border-box;
  }
  body.view-map #global-map-wrap,
  body.view-map #global-map{
    height:100% !important;
    max-height:none !important;
    min-height:0 !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
 *  BOX HEADER — pattern unificato per tutti i box informativi
 *  del sito (activity, snap, studio, ecc).
 *
 *  Struttura attesa:
 *    <div class="box-header">
 *      <svg class="bh-icn" style="color:#xxx">...</svg>
 *      <div class="bh-title">Titolo</div>
 *      <div class="bh-sub">sottotitolo · 24 elementi</div>  (opzionale)
 *      <svg class="bh-chevron">...</svg>  (solo se collapsible)
 *    </div>
 *
 *  - Icona 20px, color semantico via inline style
 *  - Title 15px/600
 *  - Sub 12px/500 var(--text3), su seconda riga
 *  - Margin 12px sotto (separazione dal contenuto del box)
 * ═══════════════════════════════════════════════════════════════ */
.box-header{
  display:flex;align-items:center;gap:10px;
  margin-bottom:12px;
  user-select:none;
}
.box-header .bh-icn{
  flex-shrink:0;width:20px;height:20px;
  stroke-width:2;stroke-linecap:round;stroke-linejoin:round;
  fill:none;stroke:currentColor;
}
.box-header .bh-title{
  flex:1;min-width:0;
  font-size:15px;font-weight:700;color:var(--text);
  line-height:1.25;
  /* Allineamento titolo+sub in colonna se .bh-sub presente */
  display:flex;flex-direction:column;gap:2px;
}
.box-header .bh-sub{
  font-size:12px;font-weight:500;color:var(--text3);line-height:1.35;
}
.box-header .bh-chevron{
  flex-shrink:0;width:18px;height:18px;color:var(--text3);
  transition:transform .2s ease;
  stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;
  fill:none;stroke:currentColor;
}
/* Variante per quando il box è collapsible — header diventa cliccabile */
.box-header.is-collapsible{
  cursor:pointer;-webkit-tap-highlight-color:transparent;
  margin:-16px -16px 0 -16px;padding:14px 16px;
  border-radius:11px 11px 0 0;
  transition:background .15s;
}
.box-header.is-collapsible:hover,
.box-header.is-collapsible:active{background:var(--bg3)}
.card-collapse-card.is-open .box-header.is-collapsible{margin-bottom:0}
.card-collapse-card.is-open .bh-chevron{transform:rotate(180deg)}

/* ═══════════════════════════════════════════════════════════════
 * Difficulty badge — usato in:
 *  - actCard / archivio card (size sm, compact)
 *  - hero activity.html (size md)
 *  - result-card Magic studio (size inline)
 * ═══════════════════════════════════════════════════════════════ */
.diff-bdg{
  display:inline-flex;align-items:center;gap:6px;
  border-radius:999px;padding:2px 9px;
  font-size:11px;font-weight:600;
  white-space:nowrap;line-height:1.4;
  background:var(--bg3,#F3F4F6);color:var(--text,#111);
  border:1px solid var(--border,#E5E7EB);
}
.diff-bdg .diff-bdg-st{letter-spacing:0;font-size:10px;line-height:1}
.diff-bdg .diff-bdg-em{opacity:.22;color:currentColor}
.diff-bdg .diff-bdg-l{font-weight:600;letter-spacing:.01em}
/* Color rules: i 5 livelli usano un tinge sul fondo + colore stelle pieno */
.diff-bdg.diff-s1{background:rgba(16,185,129,.10);color:#047857;border-color:rgba(16,185,129,.25)}
.diff-bdg.diff-s2{background:rgba(132,204,22,.12);color:#4D7C0F;border-color:rgba(132,204,22,.30)}
.diff-bdg.diff-s3{background:rgba(245,158,11,.12);color:#B45309;border-color:rgba(245,158,11,.30)}
.diff-bdg.diff-s4{background:rgba(239,68,68,.10);color:#B91C1C;border-color:rgba(239,68,68,.28)}
.diff-bdg.diff-s5{background:rgba(127,29,29,.10);color:#7F1D1D;border-color:rgba(127,29,29,.30)}
/* Size variants */
.diff-bdg.diff-sz-sm{font-size:10px;padding:1px 7px;gap:4px}
.diff-bdg.diff-sz-sm .diff-bdg-st{font-size:9px}
.diff-bdg.diff-sz-md{font-size:12px;padding:3px 11px;gap:7px}
.diff-bdg.diff-sz-md .diff-bdg-st{font-size:11px}
.diff-bdg.diff-sz-inline{font-size:10px;padding:2px 8px;gap:5px}

/* Card-tag-row variant: appoggia il badge a destra del card-sport pill.
 * Lo wrappiamo in .card-diff-wrap così index e archivio possono usarlo. */
.card-tag-row .diff-bdg{box-shadow:0 1px 2px rgba(0,0,0,.06)}

/* ═════════════════════ v330 — CYCLOCOMPUTER MODAL ═════════════════════
 * Modal "Invia al ciclocomputer". Markup creato dinamicamente da
 * gpxt-cyclocomputer.js. Disponibile su tutte le pagine che caricano
 * quel script (archivio, index, activity, studio). */

.cy-no-scroll{overflow:hidden}
.cy-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.55);
  z-index:9999;
  display:none;
  align-items:flex-start;justify-content:center;
  padding:24px 16px;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}
.cy-overlay.is-open{display:flex}
.cy-modal{
  background:var(--bg,#fff);
  border-radius:14px;
  box-shadow:0 16px 48px rgba(0,0,0,.24);
  max-width:420px;width:100%;
  margin:auto;
  overflow:hidden;
  animation:cyIn .18s ease-out;
}
@keyframes cyIn{
  from{opacity:0;transform:translateY(8px)}
  to{opacity:1;transform:translateY(0)}
}
.cy-hdr{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;
  border-bottom:1px solid var(--border,#E2DFD7);
}
.cy-title{
  display:flex;align-items:center;gap:8px;
  font-size:14px;font-weight:700;color:var(--text,#1F1B16);
}
.cy-close{
  width:32px;height:32px;
  border-radius:6px;border:none;background:transparent;
  color:var(--text2,#5A4A38);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .12s;
}
.cy-close:hover{background:var(--bg2,#F4EFE4)}
.cy-body{padding:16px}

/* Stati: loading / ready / error */
.cy-loading{
  display:flex;flex-direction:column;align-items:center;gap:12px;
  padding:36px 16px;color:var(--text3,#7A6A4E);font-size:13px;
}
.cy-spinner{
  width:28px;height:28px;
  border:3px solid var(--border,#E2DFD7);
  border-top-color:var(--orange,#FC4C02);
  border-radius:50%;
  animation:cySpin .8s linear infinite;
}
@keyframes cySpin{to{transform:rotate(360deg)}}

.cy-error{
  display:flex;flex-direction:column;align-items:center;gap:10px;
  padding:24px 16px;color:#DC2626;
  text-align:center;
}
.cy-error-msg{font-size:13px;font-weight:600;color:var(--text,#1F1B16)}
.cy-error-close{
  margin-top:4px;padding:8px 18px;
  border-radius:8px;border:1px solid var(--border,#E2DFD7);
  background:var(--bg2,#F4EFE4);color:var(--text,#1F1B16);
  font-size:13px;font-weight:600;cursor:pointer;
}

/* QR */
.cy-qr-wrap{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:16px;
  background:var(--bg2,#F4EFE4);
  border-radius:10px;
}
.cy-qr-img{
  width:200px;height:200px;
  border-radius:8px;background:#fff;
  display:block;
}
.cy-qr-hint{
  font-size:11.5px;color:var(--text3,#7A6A4E);
  text-align:center;max-width:240px;line-height:1.4;
}

/* Link */
.cy-link{
  display:flex;gap:6px;margin-top:14px;
}
.cy-link-input{
  flex:1;min-width:0;
  padding:9px 10px;
  font-size:12px;font-family:inherit;
  border:1px solid var(--border,#E2DFD7);
  border-radius:8px;
  background:var(--bg2,#F4EFE4);
  color:var(--text2,#5A4A38);
}
.cy-link-copy{
  padding:9px 14px;
  font-size:12px;font-weight:600;
  border:1px solid var(--border,#E2DFD7);
  border-radius:8px;
  background:var(--bg,#fff);color:var(--text,#1F1B16);
  cursor:pointer;
  white-space:nowrap;
}
.cy-link-copy:hover{background:var(--bg2,#F4EFE4)}

/* Piattaforme */
.cy-platforms{margin-top:18px}
.cy-platforms-title{
  font-size:11px;font-weight:700;color:var(--text3,#7A6A4E);
  text-transform:uppercase;letter-spacing:.6px;margin-bottom:8px;
}
.cy-platforms-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:6px;
}
.cy-platform{
  display:flex;flex-direction:column;gap:1px;
  padding:10px 12px;
  border:1px solid var(--border,#E2DFD7);
  border-radius:8px;
  background:var(--bg,#fff);
  text-decoration:none;
  transition:border-color .12s,background .12s;
}
.cy-platform:hover{
  border-color:var(--orange,#FC4C02);
  background:var(--bg2,#F4EFE4);
}
.cy-platform-name{
  font-size:12.5px;font-weight:700;color:var(--text,#1F1B16);
}
.cy-platform-action{
  font-size:10.5px;color:var(--text3,#7A6A4E);
}

/* How-to */
.cy-howto{
  margin-top:16px;
  padding-top:14px;
  border-top:1px solid var(--border,#E2DFD7);
}
.cy-howto summary{
  cursor:pointer;
  font-size:12px;font-weight:600;color:var(--text2,#5A4A38);
  list-style:none;
  padding:4px 0;
}
.cy-howto summary::-webkit-details-marker{display:none}
.cy-howto summary::before{
  content:'▸ ';color:var(--orange,#FC4C02);font-weight:700;
}
.cy-howto[open] summary::before{content:'▾ '}
.cy-howto ol{
  margin:8px 0 0 0;padding-left:20px;
  font-size:12px;color:var(--text2,#5A4A38);line-height:1.55;
}
.cy-howto ol li{margin-bottom:6px}
.cy-note{
  margin-top:10px;padding:8px 10px;
  background:var(--bg2,#F4EFE4);
  border-radius:6px;
  font-size:11px;color:var(--text3,#7A6A4E);line-height:1.5;
}

/* ═════════════════════ v335 — Scale CAI MTB + IMBA pills ═════════════════════
 * Pillole compatte sotto al hero activity per mostrare la difficoltà
 * espressa nelle scale standard di settore (CAI Cicloescursionismo + IMBA).
 * Renderizzate solo quando surface_difficulty o max_grade_pct sono disponibili,
 * altrimenti la riga è omessa. */

.hero-scales{
  margin-top:6px;
  display:flex;flex-wrap:wrap;gap:4px;
}
.diff-scales{
  display:inline-flex;flex-wrap:wrap;gap:4px;align-items:center;
}
.diff-pill{
  display:inline-flex;align-items:center;gap:3px;
  font-size:10.5px;font-weight:700;line-height:1;
  padding:4px 8px;border-radius:10px;
  color:#fff;letter-spacing:.3px;
  text-shadow:0 1px 1px rgba(0,0,0,.2);
  white-space:nowrap;
}
.diff-pill-cai{font-family:var(--font-mono,monospace)}
.diff-pill-imba{}

/* ═════════════════════ v343 — Glossario condiviso ═════════════════════
 * Bottom-sheet overlay riusabile per spiegare CAI MTB, CAI Escursionismo,
 * IMBA, metriche Forma (CTL/ATL/TSB/TSS/FTP). Aperto da elementi con
 * `data-gloss="key"` o direttamente via GPXT_GLOSS.open(key). */

.gx-gloss-overlay{
  position:fixed;inset:0;z-index:10000;
  display:none;pointer-events:none;
}
.gx-gloss-overlay.is-open{display:block;pointer-events:auto}
.gx-gloss-backdrop{
  position:absolute;inset:0;background:rgba(28,26,23,.45);
  opacity:0;transition:opacity .2s;
}
.gx-gloss-overlay.is-open .gx-gloss-backdrop{opacity:1}
.gx-gloss-sheet{
  position:absolute;left:0;right:0;bottom:0;
  max-height:88vh;background:var(--bg);
  border-top-left-radius:18px;border-top-right-radius:18px;
  box-shadow:0 -8px 32px rgba(0,0,0,.18);
  display:flex;flex-direction:column;
  transform:translateY(100%);transition:transform .25s cubic-bezier(.22,.61,.36,1);
}
.gx-gloss-overlay.is-open .gx-gloss-sheet{transform:translateY(0)}
.gx-gloss-hdr{
  position:relative;display:flex;align-items:center;justify-content:center;
  padding:10px 14px 6px;flex-shrink:0;
}
.gx-gloss-handle{
  width:38px;height:4px;border-radius:2px;background:var(--border);
}
.gx-gloss-close{
  position:absolute;right:10px;top:10px;
  width:30px;height:30px;border-radius:999px;
  display:flex;align-items:center;justify-content:center;
  background:var(--bg3);border:none;color:var(--text);
  font-size:20px;line-height:1;cursor:pointer;
  -webkit-tap-highlight-color:transparent;
}
.gx-gloss-close:hover{background:var(--border)}
.gx-gloss-body{
  flex:1;overflow-y:auto;padding:6px 18px 28px;
  -webkit-overflow-scrolling:touch;
}
.gx-gloss-section{padding:14px 0;border-bottom:1px solid var(--border)}
.gx-gloss-section:last-child{border-bottom:none}
.gx-gloss-title{
  font-family:var(--disp,inherit);font-size:18px;font-weight:800;
  color:var(--text);margin:0 0 6px;letter-spacing:-.3px;
}
.gx-gloss-intro{
  font-size:13px;color:var(--text2);margin:0 0 12px;line-height:1.5;
}
.gx-gloss-items{display:flex;flex-direction:column;gap:10px}
.gx-gloss-item{
  display:flex;gap:12px;align-items:flex-start;
}
.gx-gloss-pill{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:54px;padding:6px 10px;border-radius:8px;
  font-size:11.5px;font-weight:700;color:#fff;line-height:1;
  flex-shrink:0;text-align:center;
  text-shadow:0 1px 1px rgba(0,0,0,.2);
  letter-spacing:.3px;
}
.gx-gloss-it-body{flex:1;min-width:0}
.gx-gloss-it-name{font-size:13.5px;font-weight:700;color:var(--text);margin-bottom:2px}
.gx-gloss-it-desc{font-size:12.5px;color:var(--text2);line-height:1.45}
.gx-gloss-footer{
  font-size:11.5px;color:var(--text3);margin:12px 0 0;
  padding:10px 12px;background:var(--bg3);border-radius:8px;line-height:1.45;
  font-style:italic;
}

/* Versione "info button" inline: piccola ⓘ accanto a un termine. */
.gx-gloss-btn{
  display:inline-flex;align-items:center;justify-content:center;
  width:16px;height:16px;border-radius:999px;
  background:transparent;border:1px solid var(--text3);
  color:var(--text3);font-size:10px;font-weight:700;line-height:1;
  cursor:pointer;-webkit-tap-highlight-color:transparent;
  margin-left:4px;vertical-align:middle;
  transition:background .15s,border-color .15s,color .15s;
}
.gx-gloss-btn:hover{background:var(--text3);color:#fff}

/* Pillole CAI/IMBA cliccabili: cursore pointer + leggero feedback hover */
.diff-pill[data-gloss]{cursor:pointer;transition:opacity .15s}
.diff-pill[data-gloss]:hover{opacity:.85}
