/* ════════════════════════════════════════════════════════════════════════
   STAGE VIEWER · DESIGN KIT v2.0
   ────────────────────────────────────────────────────────────────────────
   The visual system for stageviewer.com. One stylesheet, no build step.

   Drop in:
     <link rel="stylesheet" href="design_kit/stageviewer-kit.css">

   v2 is a meaningful change from v1.
   What's gone:
     - Print-magazine chrome (running heads, ornament rows, double-rules,
       paper-grain, "MMXXVI" Roman dates, "Set in" colophons).
     - The horizontal table-style stage card.
   What's new:
     - One-stage-per-viewport scroll-snap card (.sv-stage)
     - Hero, footer, home pin, mark, rail, filter pill+sheet
     - Lenis smooth-scroll integration hooks
     - prefers-reduced-motion handling

   PRINCIPLES
   1. Light only. Salmon paper, warm dark ink. No dark mode.
   2. Three voices: Instrument Serif (display), Newsreader (body/deck),
      Archivo Narrow (labels/data). Don't break the assignment.
   3. Italic is rare — title flourishes (Vuelta a España, Giro d'Italia)
      and editorial decks. Not for dates, units, or just "vibes".
   4. One accent per race scope. Apply via [data-race="..."].
   5. Stages live one-per-viewport with scroll-snap. Reading is the UX.
   ════════════════════════════════════════════════════════════════════════ */


/* ─── 1. TOKENS ──────────────────────────────────────────────────────── */

:root {
  color-scheme: light;

  /* Surface */
  --sv-paper:        #FFF1E5;
  --sv-paper-deep:   #F4E1CE;
  --sv-paper-tint:   rgba(51, 48, 46, 0.025);

  /* Ink */
  --sv-ink:          #33302E;
  --sv-ink-soft:     #5C544E;
  --sv-ink-faint:    #9E938A;

  /* House accent (used when no race is scoped) */
  --sv-claret:       #990F3D;
  --sv-claret-deep:  #6D0A2A;

  /* Race accents — applied via [data-race="..."] */
  --sv-giro:         #E0457B;   /* maglia rosa */
  --sv-tour:         #C9A227;   /* deepened jaune (pure yellow fights salmon) */
  --sv-vuelta:       #C8102E;   /* roja */
  --sv-classics:     #2C4A3E;   /* spring monuments */
  --sv-worldtour:    #5C544E;   /* neutral default */

  --sv-accent:       var(--sv-claret);

  /* Type families */
  --sv-serif-display: 'Instrument Serif', 'Times New Roman', Times, serif;
  --sv-serif-text:    'Newsreader', Georgia, 'Times New Roman', serif;
  --sv-sans:          'Archivo Narrow', 'Helvetica Neue', Arial, sans-serif;
  --sv-mono:          'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;

  /* Spacing scale (rem-friendly multiples of 4) */
  --sv-1:  4px;
  --sv-2:  8px;
  --sv-3:  12px;
  --sv-4:  16px;
  --sv-6:  24px;
  --sv-8:  32px;
  --sv-12: 48px;
  --sv-16: 64px;
  --sv-20: 80px;

  /* Page */
  --sv-page-pad-mobile: 24px;
  --sv-page-pad-desktop: 48px;
}

[data-race="giro"]      { --sv-accent: var(--sv-giro); }
[data-race="tour"]      { --sv-accent: var(--sv-tour); }
[data-race="vuelta"]    { --sv-accent: var(--sv-vuelta); }
[data-race="classics"]  { --sv-accent: var(--sv-classics); }
[data-race="worldtour"] { --sv-accent: var(--sv-worldtour); }


/* ─── 2. RESET / BASE ────────────────────────────────────────────────── */

.sv-base *,
.sv-base *::before,
.sv-base *::after { box-sizing: border-box; }

.sv-base html,
.sv-base body { margin: 0; padding: 0; }

html.sv-base {
  scroll-behavior: smooth;
  scroll-snap-type: y mandatory;
}

body.sv-base {
  font-family: var(--sv-serif-text);
  background: var(--sv-paper);
  color: var(--sv-ink);
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  min-height: 100svh;
}


/* ─── 3. LENIS HOOKS ─────────────────────────────────────────────────── */
/* Lenis hijacks scroll on supported browsers. These rules let it coexist
   with native scroll-behaviour and scroll-snap. The kit doesn't load the
   library — the page is responsible for `<script src="…lenis…">`. */

html.lenis,
html.lenis body { height: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }
.lenis.lenis-smooth [data-lenis-prevent] { overscroll-behavior: contain; }
.lenis.lenis-stopped { overflow: hidden; }
.lenis.lenis-scrolling iframe { pointer-events: none; }


/* ─── 4. TYPOGRAPHY UTILITIES ────────────────────────────────────────── */

.sv-display {
  font-family: var(--sv-serif-display);
  font-weight: 400;
  font-size: clamp(56px, 13vw, 132px);
  line-height: 0.92;
  letter-spacing: -0.025em;
}
.sv-display em { font-style: italic; color: var(--sv-accent); }

.sv-headline {
  font-family: var(--sv-serif-display);
  font-weight: 400;
  font-size: clamp(36px, 7vw, 60px);
  line-height: 1.02;
  letter-spacing: -0.02em;
}
.sv-headline em { font-style: italic; }

.sv-title {
  font-family: var(--sv-serif-display);
  font-weight: 400;
  font-size: 30px;
  line-height: 1.1;
  letter-spacing: -0.005em;
}
.sv-title em { font-style: italic; color: var(--sv-accent); }

.sv-deck {
  font-family: var(--sv-serif-text);
  font-style: italic;
  font-size: clamp(15px, 2.1vw, 19px);
  line-height: 1.5;
  color: var(--sv-ink-soft);
}

.sv-body {
  font-family: var(--sv-serif-text);
  font-size: 16px;
  line-height: 1.55;
  color: var(--sv-ink);
}

.sv-caption {
  font-family: var(--sv-serif-text);
  font-size: 14px;
  line-height: 1.4;
  color: var(--sv-ink-soft);
}

/* Labels are condensed sans, uppercase, tracked. Use anywhere the impulse
   is to "italicise something small for emphasis". Don't. Use this. */
.sv-label {
  font-family: var(--sv-sans);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--sv-ink-soft);
}
.sv-label-small {
  font-family: var(--sv-sans);
  font-weight: 600;
  font-size: 9px;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--sv-ink-faint);
}
.sv-kicker {
  font-family: var(--sv-sans);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--sv-accent);
}


/* ─── 5. STATUS TAG ──────────────────────────────────────────────────── */

.sv-status {
  font-family: var(--sv-sans);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--sv-paper);
  background: var(--sv-accent);
  padding: 5px 9px;
  display: inline-block;
}
.sv-status--neutral {
  color: var(--sv-ink-soft);
  background: transparent;
  border: 1px solid var(--sv-ink-faint);
}


/* ════════════════════════════════════════════════════════════════════════
   6. PAGE LAYOUT
   ════════════════════════════════════════════════════════════════════════ */

.sv-page {
  display: block;
  width: 100%;
}


/* ─── 7. HOME PIN ────────────────────────────────────────────────────── */

.sv-home {
  position: fixed;
  top: max(16px, env(safe-area-inset-top));
  left: max(16px, env(safe-area-inset-left));
  z-index: 80;
  width: 38px;
  height: 38px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--sv-ink);
  background: var(--sv-paper);
  color: var(--sv-ink);
  border-radius: 50%;
  text-decoration: none;
  transition: background 0.2s, color 0.2s, transform 0.2s;
  -webkit-tap-highlight-color: transparent;
}
.sv-home svg { width: 18px; height: 18px; }
.sv-home:hover {
  background: var(--sv-ink);
  color: var(--sv-paper);
  transform: scale(1.05);
}


/* ════════════════════════════════════════════════════════════════════════
   8. HERO — first viewport
   ════════════════════════════════════════════════════════════════════════ */

.sv-hero {
  min-height: 100svh;
  scroll-snap-align: start;
  scroll-snap-stop: always;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 96px 24px 64px;
  padding-top: max(96px, env(safe-area-inset-top) + 80px);
  padding-bottom: max(64px, env(safe-area-inset-bottom) + 64px);
}

.sv-hero__inner {
  width: 100%;
  max-width: 880px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.sv-hero__overline {
  font-family: var(--sv-sans);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--sv-ink-faint);
}

.sv-hero__title {
  font-family: var(--sv-serif-display);
  font-weight: 400;
  font-size: clamp(56px, 13vw, 132px);
  line-height: 0.92;
  letter-spacing: -0.025em;
  color: var(--sv-ink);
  margin: 0;
}
.sv-hero__title em { font-style: italic; color: var(--sv-accent); }

.sv-hero__deck {
  font-family: var(--sv-serif-text);
  font-style: italic;
  font-size: clamp(17px, 2.2vw, 21px);
  line-height: 1.45;
  color: var(--sv-ink-soft);
  max-width: 620px;
  margin: 12px 0 0;
}

.sv-hero__stats {
  display: flex;
  flex-wrap: wrap;
  gap: 28px 40px;
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid var(--sv-ink);
}
.sv-hero__stats > div { display: flex; flex-direction: column; gap: 4px; }
.sv-hero__stat-num {
  font-family: var(--sv-serif-display);
  font-size: clamp(28px, 4.5vw, 44px);
  line-height: 1;
  color: var(--sv-ink);
  font-feature-settings: "onum";
}
.sv-hero__stat-unit {
  font-family: var(--sv-sans);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--sv-ink-faint);
  font-weight: 600;
}


/* ════════════════════════════════════════════════════════════════════════
   9. STAGE CARD — one per viewport
   ════════════════════════════════════════════════════════════════════════ */

.sv-stages-list {
  display: block;
  width: 100%;
}

.sv-stage {
  min-height: 100svh;
  scroll-snap-align: start;
  scroll-snap-stop: always;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 64px 24px 96px;
  padding-top: max(64px, env(safe-area-inset-top) + 48px);
  padding-bottom: max(96px, env(safe-area-inset-bottom) + 88px);
  position: relative;
  border-bottom: 1px solid rgba(51, 48, 46, 0.12);
}

.sv-stage__inner {
  width: 100%;
  max-width: 720px;
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.sv-stage__head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 20px;
}

.sv-stage__head-left {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}

.sv-stage__date {
  font-family: var(--sv-sans);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--sv-ink-faint);
  font-weight: 600;
}

.sv-stage__type {
  font-family: var(--sv-sans);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--sv-accent);
  font-weight: 600;
}

.sv-stage__num {
  font-family: var(--sv-serif-display);
  font-style: italic;
  font-size: clamp(56px, 13vw, 88px);
  line-height: 0.85;
  letter-spacing: -0.02em;
  color: var(--sv-ink-faint);
  flex: 0 0 auto;
  transition: color 0.4s ease;
}
.sv-stage.is-active .sv-stage__num { color: var(--sv-accent); }

.sv-stage__route {
  font-family: var(--sv-serif-display);
  font-weight: 400;
  font-size: clamp(36px, 7vw, 60px);
  line-height: 1.02;
  letter-spacing: -0.02em;
  color: var(--sv-ink);
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 10px 16px;
}
.sv-stage__route-from,
.sv-stage__route-to { display: inline-block; }
.sv-stage__route-sep {
  font-family: var(--sv-sans);
  font-size: 0.5em;
  font-weight: 400;
  color: var(--sv-accent);
  letter-spacing: 0;
  transform: translateY(-0.18em);
  display: inline-block;
}

.sv-stage__deck {
  font-family: var(--sv-serif-text);
  font-style: italic;
  font-size: clamp(15px, 2.1vw, 18px);
  line-height: 1.5;
  color: var(--sv-ink-soft);
  max-width: 560px;
  margin: 0;
}

.sv-stage__viewing {
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
  padding: 14px 18px 16px;
  border: 1px solid var(--sv-accent);
  align-self: flex-start;
}
.sv-stage__viewing-label {
  font-family: var(--sv-sans);
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--sv-accent);
  font-weight: 600;
}
.sv-stage__viewing-time {
  font-family: var(--sv-serif-display);
  font-size: clamp(22px, 3.5vw, 30px);
  line-height: 1;
  color: var(--sv-ink);
  font-feature-settings: "onum";
}

.sv-stage__profile {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 4px;
}
.sv-stage__meta {
  display: flex;
  align-items: baseline;
  gap: 12px;
  font-family: var(--sv-sans);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--sv-ink-soft);
  font-weight: 600;
}
.sv-stage__meta strong { font-weight: 700; color: var(--sv-ink); }
.sv-stage__meta-dot { color: var(--sv-ink-faint); font-weight: 400; }

.sv-stage__elev {
  position: relative;
  height: 110px;
  width: 100%;
  cursor: zoom-in;
  background: linear-gradient(to top, rgba(51, 48, 46, 0.04) 0%, transparent 70%);
}
.sv-stage__elev .profile-wrapper { width: 100%; height: 100%; }
.sv-stage__elev .profile-wrapper > svg {
  width: 100%;
  height: 100%;
  display: block;
  overflow: visible;
}
.sv-stage__elev .elevation-grid line { stroke: #9E938A; stroke-opacity: 0.35; }
.sv-stage__elev svg > rect[fill="#ffffff"] { fill: transparent; }
.sv-stage__elev .profile-error {
  font-family: var(--sv-sans);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--sv-ink-faint);
  text-align: center;
  padding: 32px 0;
}

.sv-stage__diff {
  font-family: var(--sv-sans);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--sv-ink-faint);
  font-weight: 600;
}
.sv-stage__diff strong { color: var(--sv-ink); font-weight: 700; }

.sv-stage__foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding-top: 14px;
  border-top: 1px solid rgba(51, 48, 46, 0.12);
}

.sv-stage__winner {
  font-family: var(--sv-sans);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--sv-ink-soft);
  font-weight: 600;
  text-align: right;
}
.sv-stage__winner strong {
  font-family: var(--sv-serif-display);
  font-style: italic;
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
  font-size: 18px;
  color: var(--sv-accent);
  display: block;
  margin-top: 2px;
}

.sv-stage__badge {
  font-family: var(--sv-sans);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--sv-paper);
  background: var(--sv-accent);
  padding: 5px 9px;
  font-weight: 600;
  align-self: flex-start;
  display: inline-block;
}

.sv-stage[hidden] { display: none; }

/* Desktop: split into two columns. Headline spans, copy left, profile right. */
@media (min-width: 960px) {
  .sv-stage__inner {
    max-width: 1120px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-areas:
      "head head"
      "title title"
      "deck profile"
      "viewing profile"
      "foot foot";
    gap: 24px 56px;
    align-items: start;
  }
  .sv-stage__head    { grid-area: head; }
  .sv-stage__route   { grid-area: title; font-size: clamp(48px, 5.4vw, 78px); }
  .sv-stage__deck    { grid-area: deck; }
  .sv-stage__viewing { grid-area: viewing; align-self: end; }
  .sv-stage__profile { grid-area: profile; align-self: end; }
  .sv-stage__foot    { grid-area: foot; padding-top: 24px; }
  .sv-stage__elev    { height: 150px; }
}


/* ─── 10. MARK (round checkbox) ──────────────────────────────────────── */

.sv-mark {
  appearance: none;
  -webkit-appearance: none;
  width: 36px;
  height: 36px;
  border: 1px solid var(--sv-ink);
  border-radius: 50%;
  background: transparent;
  cursor: pointer;
  position: relative;
  transition: background 0.2s, border-color 0.2s;
  margin: 0;
  flex: 0 0 auto;
  -webkit-tap-highlight-color: transparent;
}
.sv-mark::before {
  content: 'Add';
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--sv-sans);
  font-size: 9px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--sv-ink);
}
.sv-mark:hover { border-color: var(--sv-accent); }
.sv-mark:hover::before { color: var(--sv-accent); }
.sv-mark:checked {
  background: var(--sv-accent);
  border-color: var(--sv-accent);
}
.sv-mark:checked::before {
  content: '✓';
  color: var(--sv-paper);
  font-size: 14px;
  letter-spacing: 0;
  font-weight: 400;
}
.sv-mark:focus-visible { outline: 2px solid var(--sv-accent); outline-offset: 3px; }

.sv-mark--done {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: 1px solid var(--sv-ink-faint);
  border-radius: 50%;
  background: var(--sv-paper-deep);
  color: var(--sv-ink-soft);
  font-family: var(--sv-sans);
  font-size: 14px;
  flex: 0 0 auto;
}
.sv-mark--done::before { content: '✓'; }


/* ─── 11. COMPLETED-STAGES TOGGLE ────────────────────────────────────── */

.sv-completed-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 18px 24px;
  border: none;
  border-top: 1px solid rgba(51, 48, 46, 0.18);
  border-bottom: 1px solid rgba(51, 48, 46, 0.18);
  background: var(--sv-paper-deep);
  color: var(--sv-ink-soft);
  font-family: var(--sv-sans);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
  -webkit-tap-highlight-color: transparent;
  scroll-snap-align: none;
}
.sv-completed-toggle:hover { background: var(--sv-ink); color: var(--sv-paper); }
.sv-completed-toggle::before {
  content: '';
  width: 7px;
  height: 7px;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: rotate(45deg);
  transition: transform 0.2s;
}
.sv-completed-toggle::after { content: 'Show completed stages'; }
.sv-completed-toggle[aria-expanded="true"]::before { transform: rotate(225deg); }
.sv-completed-toggle[aria-expanded="true"]::after  { content: 'Hide completed stages'; }


/* ─── 12. REST DAY ───────────────────────────────────────────────────── */

.sv-rest-day {
  min-height: 50svh;
  scroll-snap-align: start;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 48px 24px;
  border-bottom: 1px solid rgba(51, 48, 46, 0.12);
}
.sv-rest-day__content {
  font-family: var(--sv-serif-display);
  font-style: italic;
  font-size: clamp(28px, 5vw, 48px);
  color: var(--sv-ink-soft);
  text-align: center;
  letter-spacing: -0.01em;
}
.sv-rest-day__content::before {
  content: 'Rest';
  display: block;
  font-family: var(--sv-sans);
  font-style: normal;
  font-size: 10px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--sv-accent);
  margin-bottom: 10px;
  font-weight: 600;
}


/* ─── 13. RIGHT RAIL — desktop progress dots ─────────────────────────── */

.sv-rail {
  position: fixed;
  top: 50%;
  right: 24px;
  transform: translateY(-50%);
  z-index: 60;
}
.sv-rail__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.sv-rail__list li {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.sv-rail__dot {
  display: flex;
  align-items: center;
  gap: 10px;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 4px 0;
  font-family: var(--sv-sans);
  font-size: 10px;
  letter-spacing: 0.16em;
  color: var(--sv-ink-faint);
  font-weight: 600;
  text-transform: uppercase;
  transition: color 0.2s;
  -webkit-tap-highlight-color: transparent;
}
.sv-rail__dot::after {
  content: '';
  width: 16px;
  height: 1px;
  background: var(--sv-ink-faint);
  transition: width 0.2s, background 0.2s;
}
.sv-rail__dot-label { opacity: 0; transition: opacity 0.2s; }
.sv-rail__dot:hover { color: var(--sv-ink); }
.sv-rail__dot:hover::after { width: 28px; background: var(--sv-ink); }
.sv-rail__dot:hover .sv-rail__dot-label { opacity: 1; }

.sv-rail__list li.is-active .sv-rail__dot { color: var(--sv-accent); }
.sv-rail__list li.is-active .sv-rail__dot::after {
  width: 28px;
  background: var(--sv-accent);
  height: 1.5px;
}
.sv-rail__list li.is-active .sv-rail__dot-label { opacity: 1; color: var(--sv-accent); }

@media (max-width: 1080px) {
  .sv-rail { display: none; }
}


/* ─── 14. FILTER PILL + SHEET ────────────────────────────────────────── */

.sv-filter-trigger {
  position: fixed;
  left: max(16px, env(safe-area-inset-left));
  bottom: max(16px, env(safe-area-inset-bottom));
  z-index: 90;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px 10px 12px;
  background: var(--sv-ink);
  color: var(--sv-paper);
  border: 1px solid var(--sv-ink);
  border-radius: 999px;
  font-family: var(--sv-sans);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  cursor: pointer;
  box-shadow: 0 6px 18px rgba(51, 48, 46, 0.22);
  transition: transform 0.2s, background 0.2s;
  -webkit-tap-highlight-color: transparent;
}
.sv-filter-trigger:hover { transform: translateY(-2px); }
.sv-filter-trigger svg { width: 16px; height: 16px; }
.sv-filter-trigger__label { white-space: nowrap; }

.sv-filter-sheet {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 95;
  background: var(--sv-paper);
  border-top: 1px solid var(--sv-ink);
  box-shadow: 0 -12px 32px rgba(51, 48, 46, 0.14);
  transform: translateY(100%);
  transition: transform 0.32s cubic-bezier(0.2, 0.8, 0.2, 1);
  padding: 20px 24px max(28px, env(safe-area-inset-bottom));
  max-height: 60vh;
  overflow-y: auto;
}
.sv-filter-sheet.is-open { transform: translateY(0); }

.sv-filter-sheet__title {
  font-family: var(--sv-sans);
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--sv-ink-faint);
  font-weight: 600;
  margin: 0 0 14px;
}
.sv-filter-sheet__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
}
.sv-filter-sheet__btn {
  padding: 14px 16px;
  background: var(--sv-paper);
  border: 1px solid var(--sv-ink);
  font-family: var(--sv-sans);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--sv-ink);
  cursor: pointer;
  text-align: left;
  transition: background 0.18s, color 0.18s;
  -webkit-tap-highlight-color: transparent;
}
.sv-filter-sheet__btn:hover { background: var(--sv-paper-tint); }
.sv-filter-sheet__btn.is-active {
  background: var(--sv-ink);
  color: var(--sv-paper);
}
.sv-filter-sheet__btn[data-mirror="best-stages-btn"].is-active {
  background: var(--sv-accent);
  border-color: var(--sv-accent);
}
.sv-filter-sheet__sep {
  grid-column: 1 / -1;
  border: 0;
  border-top: 1px solid rgba(51, 48, 46, 0.12);
  margin: 8px 0;
}

@media (min-width: 720px) {
  .sv-filter-sheet {
    left: auto;
    right: 24px;
    bottom: 80px;
    max-width: 440px;
    border-radius: 8px;
    border: 1px solid var(--sv-ink);
    transform: translateY(20px) scale(0.96);
    opacity: 0;
    pointer-events: none;
  }
  .sv-filter-sheet.is-open {
    transform: translateY(0) scale(1);
    opacity: 1;
    pointer-events: auto;
  }
}

.sv-filter-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(51, 48, 46, 0.32);
  z-index: 94;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s;
}
.sv-filter-backdrop.is-open { opacity: 1; pointer-events: auto; }


/* ─── 15. FOOTER ─────────────────────────────────────────────────────── */

.sv-footer {
  min-height: 60svh;
  scroll-snap-align: start;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 64px 24px;
}
.sv-footer__inner {
  width: 100%;
  max-width: 720px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  text-align: center;
}
.sv-footer__credits {
  font-family: var(--sv-serif-text);
  font-size: 14px;
  color: var(--sv-ink-soft);
  line-height: 1.5;
  max-width: 540px;
}
.sv-footer__credits a {
  color: var(--sv-ink);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  text-decoration-color: var(--sv-ink-faint);
  transition: color 0.2s, text-decoration-color 0.2s;
}
.sv-footer__credits a:hover {
  color: var(--sv-accent);
  text-decoration-color: var(--sv-accent);
}


/* ─── 16. PROFILE-ZOOM CONTROL (small +) ─────────────────────────────── */

.sv-profile-zoom {
  position: absolute;
  top: 6px;
  right: 6px;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--sv-paper);
  border: 1px solid var(--sv-ink);
  color: var(--sv-ink);
  cursor: pointer;
  font-size: 0;
  z-index: 5;
  padding: 0;
  -webkit-tap-highlight-color: transparent;
  transition: background 0.2s, color 0.2s, transform 0.2s;
}
.sv-profile-zoom::before,
.sv-profile-zoom::after {
  content: '';
  position: absolute;
  background: currentColor;
  left: 50%;
  top: 50%;
}
.sv-profile-zoom::before { width: 11px; height: 1.4px; transform: translate(-50%, -50%); }
.sv-profile-zoom::after  { width: 1.4px; height: 11px; transform: translate(-50%, -50%); }
.sv-profile-zoom:hover {
  background: var(--sv-accent);
  color: var(--sv-paper);
  border-color: var(--sv-accent);
  transform: scale(1.05);
}


/* ─── 17. PROFILE-ZOOM MODAL ─────────────────────────────────────────── */
/* Drop-in modal styling for the StageProfile zoom view. The page is
   responsible for opening/closing it. Targets element class names emitted
   by the existing JS — these are NOT prefixed because they're shared with
   stageProfile.js. */

.profile-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(51, 48, 46, 0.55);
  backdrop-filter: blur(2px);
  z-index: 20005;
  display: none;
}

.profile-modal {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: var(--sv-paper);
  border: 1px solid var(--sv-ink);
  border-radius: 10px;
  box-shadow: 0 24px 56px rgba(51, 48, 46, 0.28);
  width: min(950px, 95vw);
  max-height: 80vh;
  display: none;
  z-index: 20006;
  overflow: hidden;
}
.profile-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px 12px;
  border-bottom: 1px solid var(--sv-ink);
}
.profile-modal-title {
  font-family: var(--sv-serif-display);
  font-size: 22px;
  font-weight: 400;
  color: var(--sv-ink);
}
.profile-modal-title em { font-style: italic; color: var(--sv-accent); }
.profile-modal-close {
  border: none;
  background: transparent;
  color: var(--sv-ink-soft);
  font-family: var(--sv-serif-display);
  font-size: 28px;
  width: 36px;
  height: 36px;
  cursor: pointer;
  line-height: 1;
}
.profile-modal-close:hover { color: var(--sv-accent); }
.profile-modal-controls { display: flex; align-items: center; gap: 6px; }
.profile-ctrl-btn {
  border: 1px solid var(--sv-ink);
  background: var(--sv-paper);
  padding: 6px 10px;
  cursor: pointer;
  color: var(--sv-ink);
  font-family: var(--sv-sans);
  font-size: 11px;
  letter-spacing: 0.16em;
  font-weight: 600;
  text-transform: uppercase;
  border-radius: 4px;
}
.profile-ctrl-btn:hover { background: var(--sv-ink); color: var(--sv-paper); }
.profile-zoom-slider { accent-color: var(--sv-accent); }
.profile-modal-body { padding: 14px 16px 8px; }

.profile-filter-bar { display: flex; justify-content: flex-end; gap: 6px; margin: 0 4px 10px; }
.profile-filter-pill {
  padding: 5px 10px;
  background: var(--sv-paper);
  border: 1px solid var(--sv-ink);
  border-radius: 999px;
  cursor: pointer;
  font-family: var(--sv-sans);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.18em;
  color: var(--sv-ink-soft);
  text-transform: uppercase;
  transition: all 0.18s;
}
.profile-filter-pill:hover { background: var(--sv-paper-tint); color: var(--sv-ink); }
.profile-filter-pill.active { background: var(--sv-accent); border-color: var(--sv-accent); color: var(--sv-paper); }

.profile-modal-canvas {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 420px;
  background: var(--sv-paper);
  display: flex;
  flex-direction: column;
  padding-top: 8px;
}
.profile-modal-canvas::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 14px;
  background: var(--sv-paper);
  pointer-events: none;
  z-index: 19;
}
.profile-modal-logo {
  position: absolute;
  left: 12px;
  bottom: 10px;
  z-index: 21;
  font-family: var(--sv-serif-display);
  font-style: italic;
  font-size: 18px;
  color: var(--sv-ink);
  pointer-events: none;
  user-select: none;
}
.profile-modal-logo .logo-vuelta-e,
.profile-modal-logo .logo-giro-e,
.profile-modal-logo .logo-tour-e { color: var(--sv-accent); }

.profile-modal-canvas .stage-profile-container {
  height: 340px;
  width: 100%;
  overflow: visible;
  position: relative;
  flex: 0 0 auto;
}
.profile-modal-canvas .profile-wrapper { transform-origin: left center; }

.profile-share-btn,
.profile-calendar-btn {
  width: 34px;
  height: 34px;
  border-radius: 4px;
  background: transparent;
  color: var(--sv-ink-soft);
  border: 1px solid transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
.profile-share-btn:hover,
.profile-calendar-btn:hover {
  background: var(--sv-paper-tint);
  color: var(--sv-ink);
  border-color: var(--sv-ink);
}
.profile-share-btn svg,
.profile-calendar-btn svg {
  width: 20px; height: 20px;
  stroke: currentColor; stroke-width: 1.8;
  stroke-linecap: round; stroke-linejoin: round;
  fill: none;
}

.profile-share-toast {
  position: absolute;
  right: 12px;
  top: 56px;
  background: var(--sv-paper);
  border: 1px solid var(--sv-ink);
  color: var(--sv-ink);
  padding: 6px 12px;
  font-family: var(--sv-sans);
  font-size: 11px;
  letter-spacing: 0.14em;
  font-weight: 600;
  box-shadow: 0 6px 20px rgba(51, 48, 46, 0.18);
  z-index: 23;
  border-radius: 4px;
  transition: opacity 0.25s ease;
}
.profile-share-menu {
  position: absolute;
  right: 56px;
  top: 52px;
  background: var(--sv-paper);
  border: 1px solid var(--sv-ink);
  border-radius: 6px;
  box-shadow: 0 12px 28px rgba(51, 48, 46, 0.22);
  overflow: hidden;
  z-index: 24;
  min-width: 200px;
}
.share-menu-item {
  display: block;
  width: 100%;
  text-align: left;
  padding: 10px 14px;
  font-family: var(--sv-serif-text);
  font-size: 14px;
  color: var(--sv-ink);
  background: var(--sv-paper);
  border: none;
  border-bottom: 1px solid var(--sv-ink-faint);
  cursor: pointer;
}
.share-menu-item:last-child { border-bottom: none; }
.share-menu-item:hover { background: var(--sv-paper-tint); color: var(--sv-accent); }

.profile-modal .poi-marker {
  position: absolute;
  width: 16px;
  height: 16px;
  border-radius: 9999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--sv-paper);
  font-family: var(--sv-sans);
  font-size: 10px;
  font-weight: 700;
  border: 2px solid var(--sv-paper);
  box-shadow: 0 2px 6px rgba(51, 48, 46, 0.28);
  pointer-events: auto;
  user-select: none;
  z-index: 20012;
  cursor: pointer;
}
.profile-modal .poi-marker.kom { background: #2C4A3E; }
.profile-modal .poi-marker.sprint { background: #C9A227; color: var(--sv-ink); }
.profile-modal .poi-marker.climb { background: var(--sv-accent); }

.profile-modal-canvas .poi-layer { position: absolute; inset: 0; pointer-events: none; z-index: 20010; }
.profile-modal-canvas .stage-profile-container { overflow: hidden; }
.profile-modal-canvas .stage-profile-container svg { overflow: hidden; display: block; }

.poi-marker-label {
  position: absolute;
  top: -20px;
  transform: translateX(-50%);
  left: 50%;
  background: var(--sv-paper);
  color: var(--sv-ink);
  border: 1px solid var(--sv-ink);
  padding: 2px 6px;
  font-family: var(--sv-sans);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  white-space: nowrap;
  display: none;
  z-index: 12;
  border-radius: 3px;
}
.poi-popover {
  position: absolute;
  min-width: 180px;
  max-width: 260px;
  background: var(--sv-paper);
  border: 1px solid var(--sv-ink);
  box-shadow: 0 10px 26px rgba(51, 48, 46, 0.2);
  padding: 10px 12px;
  color: var(--sv-ink);
  font-family: var(--sv-serif-text);
  font-size: 13px;
  line-height: 1.45;
  z-index: 20;
  border-radius: 6px;
}

.profile-controls {
  padding: 12px 14px;
  border-top: 1px solid var(--sv-ink);
  background: var(--sv-paper-deep);
  flex: 0 0 auto;
  margin-top: auto;
}

.profile-time-display,
.window-time-display {
  position: absolute;
  display: flex;
  flex-direction: column;
  gap: 3px;
  align-items: center;
  justify-content: center;
  font-family: var(--sv-sans);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--sv-paper);
  pointer-events: none;
  user-select: none;
  line-height: 1.2;
  z-index: 10;
  background: var(--sv-ink);
  padding: 6px 10px;
  border-radius: 6px;
  box-shadow: 0 4px 12px rgba(51, 48, 46, 0.22);
  transition: top 0.2s ease-out;
}
.profile-time-display { left: 0; }
.time-value, .distance-value { color: var(--sv-paper); font-variant-numeric: tabular-nums; }
.profile-time-display .distance-value { font-size: 80%; opacity: 0.85; }
.window-time-range, .window-km-range { color: var(--sv-paper); font-variant-numeric: tabular-nums; white-space: nowrap; }
.window-km-range { font-size: 80%; opacity: 0.85; }

.profile-vertical-line {
  position: absolute;
  top: 0; bottom: 0;
  width: 1.5px;
  background: var(--sv-accent);
  opacity: 0.7;
  display: none;
  z-index: 9;
  pointer-events: none;
}
.profile-window-band {
  position: absolute;
  top: 0; left: 0;
  height: 40px;
  width: 100px;
  background: rgba(200, 16, 46, 0.12);
  border: 1px dashed rgba(200, 16, 46, 0.4);
  z-index: 8;
  pointer-events: none;
  border-radius: 3px;
}
.window-time-start,
.window-time-end {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1px;
}
.window-time-end { align-items: flex-end; }
.window-km {
  font-size: 9px;
  color: var(--sv-accent);
  font-weight: 600;
  letter-spacing: 0.08em;
  display: block;
}

.profile-mode-toggle {
  display: flex;
  gap: 0;
  background: var(--sv-paper);
  border: 1px solid var(--sv-ink);
  margin-right: 8px;
  border-radius: 4px;
  overflow: hidden;
}
.mode-toggle-btn {
  padding: 6px 12px;
  font-family: var(--sv-sans);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 600;
  border: none;
  border-right: 1px solid var(--sv-ink);
  background: transparent;
  color: var(--sv-ink-soft);
  cursor: pointer;
}
.mode-toggle-btn:last-child { border-right: none; }
.mode-toggle-btn:hover { color: var(--sv-ink); }
.mode-toggle-btn.active { background: var(--sv-ink); color: var(--sv-paper); }

.profile-window-handle {
  position: absolute;
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--sv-paper);
  border: 2px solid var(--sv-accent);
  box-shadow: 0 2px 6px rgba(51, 48, 46, 0.22);
  z-index: 11;
  cursor: ew-resize;
}
.profile-window-handle::after {
  content: '';
  position: absolute;
  left: -7px; right: -7px; top: -7px; bottom: -7px;
}
.profile-window-pill {
  position: absolute;
  top: -24px;
  left: 0;
  background: var(--sv-paper);
  border: 1px solid var(--sv-ink);
  padding: 2px 8px;
  font-family: var(--sv-sans);
  font-size: 10px;
  letter-spacing: 0.14em;
  color: var(--sv-ink);
  text-transform: uppercase;
  font-weight: 600;
  pointer-events: none;
  border-radius: 999px;
}
.profile-drag-handle {
  position: absolute;
  top: 0;
  width: 20px;
  height: 20px;
  border-radius: 9999px;
  background: var(--sv-accent);
  border: 2px solid var(--sv-paper);
  box-shadow: 0 2px 6px rgba(51, 48, 46, 0.22);
  display: none;
  z-index: 10;
  cursor: grab;
}
.profile-drag-handle.dragging { cursor: grabbing; }

.profile-poi-table {
  background: var(--sv-paper);
  border-top: 1px solid var(--sv-ink);
  max-height: 200px;
  overflow-y: auto;
}
.poi-header {
  padding: 12px 16px;
  background: var(--sv-paper-deep);
  border-bottom: 1px solid var(--sv-ink);
  font-family: var(--sv-sans);
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--sv-ink);
}
.poi-table { width: 100%; border-collapse: collapse; }
.poi-table th {
  background: var(--sv-paper-deep);
  padding: 8px 14px;
  text-align: left;
  font-family: var(--sv-sans);
  font-weight: 600;
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--sv-ink-soft);
  border-bottom: 1px solid var(--sv-ink);
}
.poi-table td {
  padding: 10px 14px;
  border-bottom: 1px solid var(--sv-ink-faint);
  font-family: var(--sv-serif-text);
  font-size: 14px;
  color: var(--sv-ink);
}
.poi-table tr:hover { background: var(--sv-paper-tint); }
.poi-table .location {
  font-weight: 500;
  max-width: 180px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.poi-table .distance {
  color: var(--sv-ink-soft);
  font-family: var(--sv-sans);
  font-size: 13px;
  font-variant-numeric: tabular-nums;
}
.poi-table .time {
  font-family: var(--sv-sans);
  font-weight: 600;
  font-size: 13px;
  color: var(--sv-accent);
  font-variant-numeric: tabular-nums;
}
.no-poi {
  padding: 24px;
  text-align: center;
  color: var(--sv-ink-faint);
  font-family: var(--sv-serif-text);
  font-style: italic;
  font-size: 14px;
}

.profile-error {
  font-family: var(--sv-sans);
  font-size: 11px;
  color: var(--sv-ink-faint);
  text-align: center;
  padding: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

@media (max-width: 900px) {
  .profile-modal {
    width: 94vw;
    max-height: 86vh;
    max-width: calc(100vw - 12px);
    overflow-y: auto;
  }
  .profile-modal-body { height: auto; padding-bottom: 15px; }
  .profile-modal-canvas { height: 320px; padding-top: 8px; overflow: visible; }
  .profile-modal-canvas .stage-profile-container { height: 260px; margin-bottom: 0; }
  .profile-modal-logo { left: auto; right: 12px; bottom: 4px; font-size: 14px; }
  .profile-drag-handle { width: 24px; height: 24px; }
}
@media (max-width: 900px) and (orientation: portrait) {
  .profile-modal-canvas { height: 290px; padding-top: 4px; }
  .profile-modal-body { padding-bottom: 10px; }
  .profile-modal-canvas::after { height: 10px; }
}
@media (max-width: 900px) and (orientation: landscape) {
  .profile-modal { max-height: 95vh; max-width: 90vw; overflow-y: auto; }
  .profile-modal-header { padding: 6px 12px; }
  .profile-modal-body { padding: 8px 12px 14px; }
  .profile-modal-canvas {
    height: calc(100vh - 120px);
    max-height: 240px;
    padding-top: 8px;
    overflow: visible;
  }
  .profile-modal-canvas .stage-profile-container { height: calc(100% - 40px); max-height: 180px; }
  .profile-controls { padding: 10px; }
  .profile-modal-logo { left: 12px; right: auto; bottom: 4px; font-size: 14px; }
  .profile-time-display { font-size: 12px; margin-bottom: 8px; }
}
body.modal-open { overflow: hidden; touch-action: none; overscroll-behavior: none; }
.profile-modal,
.profile-modal-canvas { overscroll-behavior: contain; }
.profile-modal-canvas,
.profile-drag-handle,
.profile-vertical-line { touch-action: none; }


/* ─── 18. CALENDAR MODAL ─────────────────────────────────────────────── */
/* Used by every race page that supports "add to Google Calendar". */

.calendar-modal {
  position: fixed;
  inset: 0;
  background: rgba(51, 48, 46, 0.5);
  z-index: 1000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.calendar-modal[style*="display: block"],
.calendar-modal[style*="display: flex"] { display: flex !important; }

.modal-content {
  background: var(--sv-paper);
  border: 1px solid var(--sv-ink);
  max-width: 540px;
  width: 100%;
  max-height: 88vh;
  overflow-y: auto;
  position: relative;
  padding: 32px 28px;
  border-radius: 8px;
}
.modal-close {
  position: absolute;
  top: 12px;
  right: 16px;
  background: transparent;
  border: none;
  font-family: var(--sv-serif-display);
  font-size: 30px;
  line-height: 1;
  color: var(--sv-ink-soft);
  cursor: pointer;
  width: 36px;
  height: 36px;
}
.modal-close:hover { color: var(--sv-accent); }
.modal-content h3 {
  font-family: var(--sv-serif-display);
  font-size: 28px;
  font-weight: 400;
  margin: 0 0 16px;
  color: var(--sv-ink);
}
.modal-tabs {
  display: flex;
  gap: 0;
  border-top: 1px solid var(--sv-ink);
  border-bottom: 1px solid var(--sv-ink);
  margin-bottom: 18px;
}
.tab-btn {
  flex: 1;
  padding: 12px;
  border: none;
  border-right: 1px solid var(--sv-ink);
  background: transparent;
  font-family: var(--sv-sans);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--sv-ink-soft);
  cursor: pointer;
  font-weight: 600;
}
.tab-btn:last-child { border-right: none; }
.tab-btn.active { background: var(--sv-ink); color: var(--sv-paper); }
.tab-btn:hover:not(.active) { background: var(--sv-paper-tint); }
.tab-content p {
  font-family: var(--sv-serif-text);
  font-size: 14px;
  line-height: 1.5;
  color: var(--sv-ink);
  margin: 0 0 12px;
}
.tab-content ol {
  font-family: var(--sv-serif-text);
  font-size: 13px;
  line-height: 1.5;
  color: var(--sv-ink);
  padding-left: 20px;
  margin: 8px 0 14px;
}
.tab-content ol a { color: var(--sv-accent); text-decoration: underline; text-underline-offset: 3px; }
.download-ics-btn {
  display: inline-block;
  padding: 12px 18px;
  background: var(--sv-ink);
  color: var(--sv-paper);
  border: 1px solid var(--sv-ink);
  font-family: var(--sv-sans);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  cursor: pointer;
  border-radius: 4px;
}
.download-ics-btn:hover { background: var(--sv-accent); border-color: var(--sv-accent); }
#google-calendar-links {
  display: flex;
  flex-direction: column;
  border-top: 1px solid var(--sv-ink-faint);
}
.google-calendar-link,
.gcal-link {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--sv-ink-faint);
  text-decoration: none;
  color: var(--sv-ink);
  font-family: var(--sv-serif-text);
  font-size: 14px;
  transition: color 0.2s, padding 0.2s;
}
.gcal-link:hover { color: var(--sv-accent); padding-left: 6px; }
.gcal-link.added,
.gcal-link.gcal-added { text-decoration: line-through; color: var(--sv-ink-faint); }


/* ─── 19. FLOATING CALENDAR BUTTON (right-bottom) ────────────────────── */

.floating-calendar-btn {
  position: fixed;
  right: max(16px, env(safe-area-inset-right));
  bottom: max(16px, env(safe-area-inset-bottom));
  z-index: 90;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--sv-paper);
  color: var(--sv-ink);
  border: 1px solid var(--sv-ink);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 6px 18px rgba(51, 48, 46, 0.18);
  transition: background 0.2s, color 0.2s, transform 0.2s, opacity 0.2s;
  opacity: 0;
  pointer-events: none;
  -webkit-tap-highlight-color: transparent;
}
.floating-calendar-btn svg {
  width: 20px; height: 20px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.6;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.floating-calendar-btn.has-selected:not(:disabled) {
  background: var(--sv-accent);
  color: var(--sv-paper);
  border-color: var(--sv-accent);
  opacity: 1;
  pointer-events: auto;
}
.floating-calendar-btn.has-selected:not(:disabled):hover { transform: translateY(-2px); }
@keyframes sv-wiggle {
  0%, 100% { transform: rotate(0deg); }
  20% { transform: rotate(-8deg); }
  40% { transform: rotate(8deg); }
  60% { transform: rotate(-4deg); }
  80% { transform: rotate(4deg); }
}
.floating-calendar-btn.wiggle:not(:disabled) {
  animation: sv-wiggle 0.6s ease-in-out;
}


/* ─── 20. TIMEZONE SELECTOR ──────────────────────────────────────────── */

.timezone-selector {
  position: fixed;
  top: max(16px, env(safe-area-inset-top));
  right: max(16px, env(safe-area-inset-right));
  z-index: 80;
}
.timezone-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  background: var(--sv-paper);
  border: 1px solid var(--sv-ink);
  color: var(--sv-ink);
  font-family: var(--sv-sans);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
  cursor: pointer;
  border-radius: 999px;
  transition: background 0.2s, color 0.2s;
}
.timezone-toggle:hover { background: var(--sv-ink); color: var(--sv-paper); }
.clock-icon { display: none; }
.timezone-text { letter-spacing: 0.18em; }
.timezone-dropdown {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  min-width: 220px;
  background: var(--sv-paper);
  border: 1px solid var(--sv-ink);
  box-shadow: 0 8px 28px rgba(51, 48, 46, 0.18);
  display: none;
  max-height: 60vh;
  overflow-y: auto;
  border-radius: 6px;
}
.timezone-dropdown.open,
.timezone-dropdown[style*="display: block"] { display: block; }
.timezone-option {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--sv-ink-faint);
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
.timezone-option:last-child { border-bottom: none; }
.timezone-option:hover { background: var(--sv-paper-tint); }
.timezone-option.active { background: var(--sv-ink); color: var(--sv-paper); }
.tz-name { font-family: var(--sv-serif-text); font-size: 14px; }
.tz-code {
  font-family: var(--sv-sans);
  font-size: 10px;
  letter-spacing: 0.18em;
  color: var(--sv-ink-faint);
  font-weight: 600;
  text-transform: uppercase;
}
.timezone-option.active .tz-code { color: rgba(255, 241, 229, 0.7); }
.timezone-indicator { display: none; }


/* ─── 21. JERSEY LEADERS STRIP ───────────────────────────────────────── */

.jersey-leaders {
  margin-top: 8px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 14px 24px;
  padding: 18px 0 0;
}
.jersey-leaders__heading { display: none; }
.jersey-grid { display: contents; }

.jersey-item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--sv-serif-text);
}
.jersey-icon {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex: 0 0 auto;
  background: var(--sv-ink-faint);
}
.jersey-icon.red    { background: var(--sv-vuelta); }
.jersey-icon.green  { background: #2C4A3E; }
.jersey-icon.pink   { background: var(--sv-giro); }
.jersey-icon.yellow { background: var(--sv-tour); }
.jersey-icon.purple { background: #8B3D8B; } /* maglia ciclamino */
.jersey-icon.azzurra { background: #2D75A6; } /* maglia azzurra (KOM, Giro) */
.jersey-icon.polka  {
  background: var(--sv-paper);
  border: 2px solid var(--sv-vuelta);
  width: 12px;
  height: 12px;
}
.jersey-icon.white  { background: var(--sv-paper); border: 1px solid var(--sv-ink); }

.jersey-text { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.jersey-label {
  font-family: var(--sv-sans);
  font-size: 9px;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--sv-ink-faint);
  font-weight: 600;
}
.leader-name {
  font-family: var(--sv-serif-display);
  font-size: 18px;
  line-height: 1.05;
  color: var(--sv-ink);
}


/* ─── 22. ACCESSIBILITY ──────────────────────────────────────────────── */

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; scroll-snap-type: none; }
  .sv-page, .sv-stage, .sv-hero, .sv-footer, .sv-rest-day {
    scroll-snap-align: none !important;
  }
}


/* ════════════════════════════════════════════════════════════════════════
   END OF KIT v2.0
   ════════════════════════════════════════════════════════════════════════ */
