/* ── Hero ─────────────────────────────────────────── */
.app-hero {
  border-bottom: 1px solid var(--color-border);
  padding: 1.25rem 1.5rem 1.1rem;
}
.app-hero--sky {
  background: var(--c-sky-bg);
  border-bottom-color: var(--c-sky-border);
}
.app-hero__inner { margin: 0 auto; }
.app-hero__title {
  font-size: clamp(1.4rem, 3vw, 2rem); font-weight: 800;
  color: var(--c-sky-text); letter-spacing: -.02em;
  margin: 0 0 .5rem; line-height: 1.2;
}
.app-hero__desc {
  font-size: .9rem; color: var(--color-text-secondary);
  max-width: 660px; line-height: 1.6; margin: 0 0 .85rem;
}
.app-hero__chips { display: flex; flex-wrap: wrap; gap: .35rem; }
.hero-chip {
  display: inline-flex; align-items: center;
  padding: .22rem .65rem; font-size: .72rem; font-weight: 700;
  background: var(--color-surface); border: 1.5px solid var(--c-sky-border);
  border-radius: var(--radius-full); color: var(--c-sky-text); white-space: nowrap;
}

/* ── Tool shell ─────────────────────────────────────────── */
.tool-wrap {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  margin-bottom: var(--space-10);
}

/* ── Drop zone ──────────────────────────────────────────── */
.drop-zone {
  padding: 3.5rem var(--space-8);
  background: var(--c-sky-bg);
  border: 2.5px dashed var(--c-sky-border);
  border-radius: var(--radius-xl);
  text-align: center;
  cursor: pointer;
  transition: background .15s, border-color .15s;
  outline: none;
}
.drop-zone:focus-visible { box-shadow: 0 0 0 3px rgb(24 88 144 / 0.2); }
.drop-zone.drag-over { background: #cce4fa; border-color: #5a9cd8; }
.drop-zone.drag-over .dz-icon { transform: translateY(-4px) scale(1.05); }
.dz-icon  { font-size: 2.5rem; display: block; margin-bottom: var(--space-3); transition: transform .15s; }
.dz-title { font-size: var(--text-lg); font-weight: var(--weight-semibold); color: var(--c-sky-text); margin: 0 0 var(--space-2); }
.dz-sub   { font-size: var(--text-sm); color: var(--color-text-muted); margin: 0 0 var(--space-3); }
.dz-browse { background: none; border: none; color: var(--color-accent); font: inherit; cursor: pointer; padding: 0; text-decoration: underline; }
.dz-limit  { font-size: var(--text-xs); color: var(--color-text-muted); margin: 0; }
#file-input { display: none; }

/* ── Work area ──────────────────────────────────────────── */
#work-area { padding: var(--space-6); }

/* ── File bar ───────────────────────────────────────────── */
.file-bar {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-3); margin-bottom: var(--space-5);
  padding: var(--space-3) var(--space-4);
  background: var(--color-surface-alt); border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}
.file-bar__name { font-size: var(--text-sm); font-weight: var(--weight-medium); color: var(--color-text-primary); }
.btn-link { background: none; border: none; cursor: pointer; padding: 0; font: inherit; font-size: var(--text-sm); color: var(--color-text-muted); }
.btn-link:hover { color: var(--color-text-primary); }

/* ── Score card ─────────────────────────────────────────── */
.scorecard {
  background: var(--c-sky-bg);
  border: 1px solid var(--c-sky-border);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  margin-bottom: var(--space-5);
  position: relative;
  overflow: hidden;
}
.scorecard::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, #b0d4f8, #5a9cd8, #1565c0);
  border-radius: var(--radius-xl) var(--radius-xl) 0 0;
}
.scorecard__head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: var(--space-5);
}
.scorecard__sport {
  display: flex; align-items: center; gap: var(--space-2);
  font-size: var(--text-sm); font-weight: var(--weight-semibold);
  color: var(--c-sky-text);
}
.scorecard__date { font-size: var(--text-sm); color: var(--color-text-muted); }
.scorecard__hero { text-align: center; padding: var(--space-2) 0 var(--space-5); }
.scorecard__hero-val {
  font-size: clamp(2.5rem, 8vw, 4rem);
  font-weight: var(--weight-bold);
  color: var(--color-text-primary);
  line-height: 1;
  letter-spacing: -0.03em;
  display: block;
}
.scorecard__hero-unit {
  font-size: var(--text-sm); color: var(--color-text-muted);
  margin-top: var(--space-1); display: block;
  letter-spacing: 0.04em; text-transform: uppercase;
}
.scorecard__divider { height: 1px; background: var(--c-sky-border); margin-bottom: var(--space-5); }
.scorecard__secondary { display: flex; gap: var(--space-2); flex-wrap: wrap; }
.scorecard__stat { flex: 1; min-width: 5.5rem; text-align: center; }
.scorecard__stat-val {
  font-size: var(--text-xl); font-weight: var(--weight-bold);
  color: var(--color-text-primary); display: block;
}
.scorecard__stat-label { font-size: var(--text-xs); color: var(--color-text-muted); }

/* ── HR zone bar ────────────────────────────────────────── */
.zone-section { margin-bottom: var(--space-5); }
.zone-section__label {
  font-size: var(--text-xs); font-weight: var(--weight-semibold);
  color: var(--color-text-muted); text-transform: uppercase;
  letter-spacing: 0.05em; margin-bottom: var(--space-2);
}
.zone-bar {
  display: flex; height: 10px; border-radius: var(--radius-full);
  overflow: hidden; margin-bottom: var(--space-3); gap: 2px;
}
.zone-bar__seg { transition: flex .6s cubic-bezier(0.16,1,0.3,1); border-radius: 3px; }
.zone-pills { display: flex; gap: var(--space-3); flex-wrap: wrap; }
.zone-pill { display: flex; align-items: center; gap: var(--space-1); font-size: var(--text-xs); color: var(--color-text-muted); }
.zone-pill__dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.zone-pill__pct { font-weight: var(--weight-semibold); color: var(--color-text-secondary); }

/* ── Map section ────────────────────────────────────────── */
.map-section { margin-bottom: var(--space-4); }
.map-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: var(--space-2);
}
.map-header__title {
  font-size: var(--text-xs); font-weight: var(--weight-semibold);
  color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.05em;
}
.seg-control {
  display: inline-flex;
  border: 1.5px solid var(--c-sky-border);
  border-radius: var(--radius-full);
  overflow: hidden;
  background: var(--color-surface);
}
.seg-btn {
  padding: 3px var(--space-3);
  font-size: var(--text-xs); font-weight: var(--weight-medium);
  background: none; border: none; cursor: pointer;
  color: var(--c-sky-text); transition: background .15s, color .15s;
  line-height: 1.6;
}
.seg-btn.active { background: var(--c-sky-text); color: #fff; }
.map-box {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: #eef5eb;
  overflow: hidden;
  position: relative;
}
.map-box canvas { display: block; width: 100%; }
.map-legend {
  position: absolute; bottom: var(--space-3); right: var(--space-3);
  background: rgb(255 255 255 / 0.92);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-xs); color: var(--color-text-muted);
  display: flex; gap: var(--space-2); align-items: center;
  backdrop-filter: blur(4px);
}
.map-legend__grad {
  width: 48px; height: 6px; border-radius: 3px;
  background: linear-gradient(to right, #2196f3, #4caf50, #ff9800, #f44336);
}

/* ── Charts grid ────────────────────────────────────────── */
.charts-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: var(--space-4); margin-bottom: var(--space-4);
}
@media (max-width: 600px) { .charts-grid { grid-template-columns: 1fr; } }

.chart-box {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-surface-alt);
  overflow: hidden;
}
.chart-box__label {
  font-size: var(--text-xs); font-weight: var(--weight-semibold);
  color: var(--color-text-muted); text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: var(--space-2) var(--space-3);
  border-bottom: 1px solid var(--color-border);
}
.chart-canvas-wrap { position: relative; }
.chart-canvas-wrap canvas { display: block; width: 100%; }
.chart-canvas-wrap .c-overlay {
  position: absolute; inset: 0; pointer-events: none;
}

/* ── Power histogram ────────────────────────────────────── */
.histo-box {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-surface-alt);
  overflow: hidden;
  margin-bottom: var(--space-4);
}
.histo-box__label {
  font-size: var(--text-xs); font-weight: var(--weight-semibold);
  color: var(--color-text-muted); text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: var(--space-2) var(--space-3);
  border-bottom: 1px solid var(--color-border);
}
.histo-box canvas { display: block; width: 100%; }

/* ── Crosshair tooltip ──────────────────────────────────── */
.crosshair-tip {
  position: fixed;
  pointer-events: none;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: 0 4px 12px -1px rgb(200 72 120 / 0.14), 0 2px 6px -2px rgb(200 72 120 / 0.10);
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-xs);
  line-height: var(--leading-relaxed);
  color: var(--color-text-primary);
  min-width: 120px;
  z-index: 100;
  display: none;
}
.crosshair-tip__time {
  font-weight: var(--weight-semibold); color: var(--c-sky-text);
  margin-bottom: 3px; padding-bottom: 3px;
  border-bottom: 1px solid var(--color-border);
}
.crosshair-tip__row {
  display: flex; justify-content: space-between; gap: var(--space-4);
}
.crosshair-tip__label { color: var(--color-text-muted); }
.crosshair-tip__val   { font-weight: var(--weight-medium); }

/* ── PR badge ───────────────────────────────────────────── */
.pr-badge {
  display: inline-block;
  background: #f9a825;
  color: #fff;
  font-size: 0.65em;
  font-weight: var(--weight-bold);
  padding: 1px 5px;
  border-radius: var(--radius-full);
  margin-left: 4px;
  vertical-align: middle;
  letter-spacing: 0.03em;
}

/* ── Training Load ──────────────────────────────────────── */
.tl-section {
  background: var(--color-surface-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-4) var(--space-5);
  margin-bottom: var(--space-5);
}
.tl-head {
  display: flex; gap: var(--space-4); align-items: center; flex-wrap: wrap;
  margin-bottom: var(--space-3);
}
.tl-label {
  font-size: var(--text-xs); font-weight: var(--weight-semibold);
  color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.05em;
  flex: none;
}
.tl-tss {
  font-size: var(--text-xl); font-weight: var(--weight-bold); color: var(--color-text-primary);
}
.tl-method { font-size: var(--text-xs); color: var(--color-text-muted); }
.tl-effort { font-size: var(--text-sm); font-weight: var(--weight-semibold); }
.tl-body { display: flex; flex-direction: column; gap: var(--space-2); }
.tl-row { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); }
.tl-row-label { font-size: var(--text-xs); color: var(--color-text-muted); font-weight: var(--weight-semibold); }
.tl-input {
  width: 5rem;
  padding: var(--space-1) var(--space-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  color: var(--color-text-primary);
  font-size: var(--text-sm);
  font-family: inherit;
}

/* ── Lap section ────────────────────────────────────────── */
.laps-section { margin-bottom: var(--space-5); }
.laps-section__label {
  font-size: var(--text-xs); font-weight: var(--weight-semibold);
  color: var(--color-text-muted); text-transform: uppercase;
  letter-spacing: 0.05em; margin-bottom: var(--space-2);
}

/* ── PR section ─────────────────────────────────────────── */
.pr-section { margin-bottom: var(--space-5); }
.pr-section__label {
  font-size: var(--text-xs); font-weight: var(--weight-semibold);
  color: var(--color-text-muted); text-transform: uppercase;
  letter-spacing: 0.05em; margin-bottom: var(--space-2);
}

/* ── Compare section ────────────────────────────────────── */
.compare-section { margin-bottom: var(--space-5); }
.compare-section__head {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: var(--space-3); margin-bottom: var(--space-4);
}
.compare-section__label {
  font-size: var(--text-xs); font-weight: var(--weight-semibold);
  color: var(--color-text-muted); text-transform: uppercase; letter-spacing: 0.05em;
}
.compare-align-ctrl { display: flex; align-items: center; gap: var(--space-1); }
.compare-align-btn {
  padding: 3px var(--space-3);
  font-size: var(--text-xs); font-weight: var(--weight-medium);
  background: none; border: 1.5px solid var(--color-border);
  border-radius: var(--radius-full); cursor: pointer;
  color: var(--color-text-secondary); transition: background .15s, color .15s;
}
.compare-align-btn.active {
  background: var(--color-text-secondary); color: #fff;
  border-color: var(--color-text-secondary);
}
.compare-scorecards { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); margin-bottom: var(--space-4); }
@media (max-width: 600px) { .compare-scorecards { grid-template-columns: 1fr; } }
.compare-sc {
  background: var(--color-surface-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
}
.compare-sc__file { font-size: var(--text-xs); color: var(--color-text-muted); margin-bottom: var(--space-2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.compare-sc__dist { font-size: var(--text-2xl); font-weight: var(--weight-bold); color: var(--color-text-primary); margin-bottom: var(--space-3); }
.compare-sc__stats { display: flex; gap: var(--space-3); flex-wrap: wrap; }
.compare-sc__stat { text-align: center; }
.compare-sc__val { display: block; font-size: var(--text-sm); font-weight: var(--weight-semibold); color: var(--color-text-primary); }
.compare-sc__label { font-size: var(--text-xs); color: var(--color-text-muted); }
.drop-zone--compact { padding: 1.5rem var(--space-8); }

/* ── Button variants ────────────────────────────────────── */
.btn { padding: var(--space-2) var(--space-4); border-radius: var(--radius-full); font-size: var(--text-sm); font-weight: var(--weight-semibold); border: none; cursor: pointer; transition: opacity .15s; }
.btn:hover { opacity: 0.88; }
.btn-primary { background: var(--color-accent); color: #fff; }
.btn-outline { background: transparent; border: 1.5px solid var(--color-border); color: var(--color-text-secondary); }
.btn-outline:hover { background: var(--color-surface-alt); }

/* ── Action row ─────────────────────────────────────────── */
.action-wrap { display: flex; gap: var(--space-3); align-items: center; flex-wrap: wrap; margin-bottom: var(--space-4); }

/* ── Table ──────────────────────────────────────────────── */
.table-wrap {
  border: 1px solid var(--color-border); border-radius: var(--radius-lg);
  overflow: auto; max-height: 320px; font-size: var(--text-xs);
}
.data-table { width: 100%; border-collapse: collapse; white-space: nowrap; }
.data-table thead th {
  position: sticky; top: 0; z-index: 1;
  background: var(--color-surface-alt); border-bottom: 1px solid var(--color-border);
  padding: var(--space-2) var(--space-3);
  font-weight: var(--weight-semibold); color: var(--color-text-secondary); text-align: left;
}
.data-table tbody tr:nth-child(even) { background: var(--color-surface-alt); }
.data-table tbody td { padding: var(--space-2) var(--space-3); color: var(--color-text-primary); border-bottom: 1px solid var(--color-border); }
.data-table tbody tr:last-child td { border-bottom: none; }
.table-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-3) var(--space-4); font-size: var(--text-xs);
  color: var(--color-text-muted); border-top: 1px solid var(--color-border);
}
.learn-more{margin-top:var(--space-10);padding:var(--space-8) 0 0;border-top:1px solid var(--color-border)}.learn-more .lm-inner{max-width:48rem;margin:0 auto}.learn-more h2{font-size:var(--text-lg);font-weight:700;color:var(--color-text-primary);margin:0 0 var(--space-6)}.learn-more .lm-section{margin-bottom:var(--space-5)}.learn-more h3{font-size:var(--text-base);font-weight:600;color:var(--color-text-primary);margin:0 0 var(--space-2)}.learn-more p{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:var(--leading-relaxed);margin:0}
