/* api/static/css/data.css
 *
 * Data tab styles. Extracted from styles.css in #2239 — pure relocation,
 * no behaviour change.
 *
 * Selectors covered: `.data-surface`, `.data-error-banner`,
 * `.single-activity-banner`, `.filter-row`, `.sport-pill`, `.search-wrap`,
 * `.date-range`, `.date-label`, `.export-split`, `.export-dropdown`,
 * `.pagination-*`, `.table-card`, `.act-table`, `.activity-cards`,
 * `.activity-card-*`, `.tss-*`, `.if-*`, `.expand-chevron`, `.detail-row`,
 * `.detail-metrics-*`, `.dm-*`, `.detail-weather`, `.detail-derived-header`,
 * `.detail-cards-row`, `.detail-metrics-card`, `.detail-chart-card`,
 * `.detail-zones-card`, `.chart-legend*`, `.chart-container`, `.chart-svg`,
 * `.chart-y-label`, `.chart-loading`, `.zones-donut-*`, `.zones-legend-*`,
 * `.zones-divider`, `.lap-table-wrap`, `.lap-tbl`, `.lap-effort-tinted`,
 * `.lap-corrected`, `.lap-adj-badge`, `.lap-corrected-note`,
 * `.lap-distance-*`, `.effort-bar`, `.effort-cell`, `.detail-swim-meta`,
 * `.swim-meta-*`, `.detail-activity-actions`, `.detail-loading`,
 * `.detail-loading-label`, `.ember-dot--d*`, `.table-loading-cell`,
 * `.table-error-cell`, `.cell-center`, `.detail-empty`,
 * `.detail-copy-mobile`, `.row-copy-btn`, `.threshold-card*`,
 * `.threshold-label`, `.threshold-value*`, `.threshold-unit`,
 * `.threshold-date`, `.threshold-empty`, `.threshold-edit-*`,
 * `.threshold-history*`, `.threshold-step-chart`, `.threshold-btn-*`,
 * `.threshold-zones-grid`, `.threshold-popup*`,
 * `.threshold-suggestion-*`.
 *
 * Deferred from extraction (stay in styles.css):
 *   - `.sport-icon*` — shared with Profile season stats (see styles.css
 *     comment at the `.sport-icon` definition).
 *   - `.sport-badge*` — shared with Plan and Race surfaces.
 *   - `.view-on-strava-link*` — shared with Home and Plan surfaces.
 *   - `.zone-strip-item` — shared with Plan plan-week phase strips.
 *   - The grouped drawer + sheet shells (`.thresholds-overlay`,
 *     `.thresholds-drawer`, `.thresholds-sheet`, etc.) which share
 *     selectors with `.races-*` and `.pipeline-settings-*`.
 *
 * Modify in place. Bump api/static/sw.js CACHE_NAME on every change.
 */

    /* Activity table row hover shift (desktop only) */
    @media (min-width: 640px) {
      .act-table tbody tr { transition: transform 0.15s ease; }
      .act-table tbody tr:hover { transform: translateX(2px); }
    }

    /* ══════════════════════════════════════════
       DATA SURFACE
       ══════════════════════════════════════════ */
    .data-surface {
      padding: var(--space-4);
      padding-bottom: max(var(--space-4), env(safe-area-inset-bottom));
      overflow-y: auto;
      height: calc(100vh - 44px);
      height: calc(100dvh - 44px);
      margin-top: 44px;
      background: var(--slate-50);
    }

    /* Data tab error / stale-data banner */
    .data-error-banner {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: var(--space-2);
      background: var(--red-50);
      border: 0.5px solid var(--red-400);
      color: var(--red-400);
      font-size: 12px;
      padding: var(--space-2) var(--space-4);
      border-radius: 8px;
      margin-bottom: var(--space-3);
    }
    .data-error-banner.hidden { display: none; }

    /* Single-activity focus banner (#2146) — explains why the listing
       collapsed to one workout after clicking a race-prediction
       Reference chip. Uses the ember palette so it reads as a focused
       status, not an error. */
    .single-activity-banner {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: var(--space-3);
      background: var(--ember-50);
      border-left: 3px solid var(--ember-400);
      border-radius: 0 6px 6px 0;
      color: var(--slate-800);
      font-size: 13px;
      padding: var(--space-2) var(--space-3);
      margin-bottom: var(--space-3);
    }
    .single-activity-banner-text { font-weight: 500; }
    .single-activity-banner-clear {
      background: none;
      border: 0;
      color: var(--ember-600);
      font-size: 12px;
      font-weight: 600;
      cursor: pointer;
      text-decoration: underline;
      padding: var(--space-1) var(--space-2);
      font-family: var(--font-sans);
    }
    .single-activity-banner-clear:hover { color: var(--slate-900); }
    .data-error-banner .retry-link {
      background: none;
      border: none;
      color: var(--red-400);
      font-size: 12px;
      font-weight: 500;
      cursor: pointer;
      text-decoration: underline;
      padding: 0;
      font-family: var(--font-sans);
    }
    .data-error-banner .retry-link::after {
      content: '';
      position: absolute;
      top: 50%; left: 50%;
      transform: translate(-50%, -50%);
      min-width: 44px; min-height: 44px;
    }
    .data-error-banner .retry-link { position: relative; }

    /* Threshold cards (content inside the shared thresholds drawer/sheet) */
    .threshold-card {
      background: var(--slate-50); border: 0.5px solid var(--slate-100);
      border-radius: 8px; padding: var(--space-3) 14px; margin-bottom: 10px;
    }
    .threshold-card-header {
      display: flex; align-items: center; justify-content: space-between;
    }
    .threshold-label { margin: 0; }
    .threshold-value {
      font-size: 18px; font-weight: 500; color: var(--slate-900);
      margin-top: var(--space-1); display: flex; align-items: baseline; gap: var(--space-1);
    }
    .threshold-unit { font-size: 12px; color: var(--slate-600); font-weight: 400; }
    .threshold-date { font-size: 11px; color: var(--slate-600); margin-top: 2px; }
    .threshold-empty { color: var(--slate-600); font-size: 14px; font-style: italic; margin-top: var(--space-1); }
    .threshold-card--wide { /* no special width in drawer */ }
    .threshold-value--sm { font-size: 14px; }
    .threshold-edit-btn {
      background: none; border: none; color: var(--slate-400);
      cursor: pointer; font-size: 16px; padding: 0; margin-left: auto;
      position: relative;
    }
    .threshold-edit-btn::after {
      content: ''; position: absolute;
      top: 50%; left: 50%; transform: translate(-50%, -50%);
      min-width: 44px; min-height: 44px;
    }
    .threshold-edit-btn:hover { color: var(--ember-400); }
    .threshold-value--clickable {
      cursor: pointer;
      border-bottom: 1px dashed var(--slate-400);
      display: inline-flex;
    }
    .threshold-value--clickable:hover { border-bottom-color: var(--ember-400); }
    .threshold-history {
      margin-top: var(--space-3); padding-top: 10px;
      border-top: 0.5px solid var(--slate-100);
    }
    .threshold-step-chart { width: 100%; height: 72px; display: block; }
    .threshold-history-empty {
      font-size: 12px; color: var(--slate-400); font-style: italic;
    }
    .threshold-history-loading {
      font-size: 12px; color: var(--slate-600);
    }
    .threshold-history-error {
      font-size: 12px; color: var(--ember-600);
    }
    .threshold-edit-form {
      margin-top: var(--space-2);
    }
    .threshold-edit-actions {
      display: flex; gap: var(--space-2); margin-top: var(--space-2);
    }
    .threshold-btn-save:disabled {
      opacity: 0.6; cursor: not-allowed;
    }
    .threshold-btn-cancel {
      background: var(--slate-50); color: var(--slate-800);
    }
    .threshold-zones-grid {
      display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-2);
      margin-top: var(--space-2);
    }
    .threshold-zones-grid label { display: block; margin-bottom: var(--space-1); }

    /* Filter row */
    .filter-row {
      display: flex;
      gap: var(--space-2);
      flex-wrap: wrap;
      align-items: center;
      margin-bottom: 32px;
      position: relative;
      z-index: var(--z-raised);
    }
    .sport-pill {
      background: var(--white);
      color: var(--slate-600);
      border: 0.5px solid var(--slate-200);
      border-radius: 20px;
      padding: 6px 14px;
      font-size: 14px;
      min-height: 44px;
      cursor: pointer;
      font-family: var(--font-sans);
      font-weight: 400;
      display: inline-flex;
      align-items: center;
      gap: 6px;
    }
    .sport-pill.active {
      background: var(--slate-900);
      color: var(--ember-400);
      border-color: var(--slate-900);
    }

    .filter-row select {
      height: 36px;
      min-height: 44px;
      border: 0.5px solid var(--slate-200);
      border-radius: 6px;
      padding: 0 var(--space-2);
      font-size: 14px;
      font-family: var(--font-sans);
      color: var(--slate-800);
      background: var(--white);
    }
    .date-range {
      display: inline-flex;
      align-items: center;
      gap: 6px;
    }
    .date-range .date-sep {
      color: var(--slate-200);
      font-size: 14px;
      user-select: none;
    }
    .date-label {
      display: inline-flex;
      align-items: center;
      gap: 0;
      border: 0.5px solid var(--slate-200);
      border-radius: 6px;
      background: var(--white);
      min-height: 44px;
      overflow: hidden;
    }
    .date-label .date-prefix {
      font-size: 14px;
      font-weight: 500;
      color: var(--slate-400);
      letter-spacing: 0.06em;
      text-transform: uppercase;
      padding: 0 0 0 10px;
      white-space: nowrap;
    }
    .date-label input[type="date"] {
      border: none;
      outline: none;
      background: transparent;
      height: 36px;
      padding: 0 var(--space-2);
      font-size: 14px;
      font-family: var(--font-sans);
      color: var(--slate-800);
      min-width: 0;
    }
    .filter-row .action-btns {
      display: flex;
      gap: var(--space-2);
      margin-left: auto;
    }
    .search-wrap {
      position: relative;
      flex: 0 1 200px;
      min-width: 140px;
    }
    .search-wrap .search-icon {
      position: absolute;
      left: 10px;
      top: 50%;
      transform: translateY(-50%);
      font-size: 13px;
      pointer-events: none;
    }
    .search-wrap input[type="search"] {
      width: 100%;
      padding: 6px 10px 6px 30px;
      border: 0.5px solid var(--slate-200);
      border-radius: 20px;
      font-size: 14px;
      font-family: var(--font-sans);
      color: var(--slate-800);
      background: var(--white);
      min-height: 44px;
      box-sizing: border-box;
    }
    .search-wrap input[type="search"]:focus {
      outline: none;
      border-color: var(--ember-400);
    }
    .search-wrap input[type="search"]:focus-visible {
      outline: 2px solid var(--ember-400);
      outline-offset: 2px;
    }
    .pagination-row {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: var(--space-3);
      margin-top: 32px;
    }
    .pagination-btn { border-width: 0.5px; border-color: var(--slate-200); padding: 6px var(--space-3); position: relative; }
    .pagination-btn::after {
      content: '';
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      min-width: 44px;
      min-height: 44px;
    }
    .pagination-btn:disabled {
      color: var(--slate-400);
      cursor: default;
      opacity: 0.5;
    }
    .pagination-info {
      font-size: 12px;
      font-weight: 500;
      color: var(--slate-600);
    }
    .export-split {
      position: relative;
      display: inline-flex;
    }
    .export-split-main, .export-split-caret {
      background: var(--white);
      border: 0.5px solid var(--slate-200);
      color: var(--slate-600);
      font-size: 14px;
      min-height: 44px;
      cursor: pointer;
      font-family: var(--font-sans);
      display: inline-flex;
      align-items: center;
    }
    .export-split-main {
      padding: 10px 14px;
      border-radius: 20px 0 0 20px;
      gap: 5px;
      min-width: 110px;
      justify-content: center;
      border-right: none;
    }
    .export-split-caret {
      padding: 10px 10px;
      border-radius: 0 20px 20px 0;
      border-left: 1px solid var(--slate-200);
    }
    .export-split-main:hover, .export-split-caret:hover { border-color: var(--slate-400); }
    .export-split-main:hover { border-right: none; }
    .export-split-main .btn-icon { font-size: 13px; opacity: 0.6; }
    .export-dropdown {
      display: none;
      position: absolute;
      top: calc(100% + 4px);
      right: 0;
      background: var(--white);
      border: 0.5px solid var(--slate-200);
      border-radius: 12px;
      box-shadow: 0 4px 12px rgba(0,0,0,0.08);
      z-index: var(--z-fixed);
      min-width: 190px;
      overflow: hidden;
    }
    .export-dropdown[data-state="open"] { display: block; }
    .export-dropdown button {
      display: flex;
      align-items: center;
      gap: 6px;
      width: 100%;
      padding: 10px 14px;
      background: none;
      border: none;
      color: var(--slate-600);
      font-size: 14px;
      font-family: var(--font-sans);
      cursor: pointer;
    }
    .export-dropdown button:hover { background: var(--slate-50); }
    .export-dropdown .dropdown-sep {
      height: 1px;
      background: var(--slate-100);
      margin: var(--space-1) 0;
    }
    .export-dropdown .dropdown-toggle {
      justify-content: space-between;
      white-space: nowrap;
    }
    .export-dropdown .dropdown-toggle .toggle-check {
      font-size: 14px;
      color: var(--ember-500);
    }

    /* Activity table */
    .table-card {
      overflow: hidden;
    }
    .activity-cards { display: none; }
    .act-table {
      width: 100%;
      border-collapse: collapse;
    }
    .act-table thead th {
      background: var(--slate-50);
      font-size: 11px;
      font-weight: 500;
      color: var(--slate-600);
      text-transform: uppercase;
      letter-spacing: 0.06em;
      padding: 10px 14px;
      text-align: left;
      cursor: pointer;
    }
    .act-table thead th:last-child,
    .act-table thead th:nth-last-child(2) { text-align: center; width: 40px; }
    .act-table thead th.col-actions-header { text-align: center; cursor: default; }
    .act-table tbody tr { border-bottom: 0.5px solid var(--slate-100); }
    .act-table tbody tr:hover { background: var(--slate-50); }
    .act-table tbody td {
      padding: 10px 14px;
      font-size: 13px;
      color: var(--slate-800);
      vertical-align: middle;
    }
    /* Today-row accent (#2241) — 2px ember left edge on the row dated today
       so the just-synced activity is visually pickable without scanning dates.
       Quiet treatment that doesn't compete with the TSS / sport colour cues. */
    .act-table tbody tr.is-today td:first-child {
      box-shadow: inset 2px 0 0 var(--ember-400);
    }
    .activity-card.is-today {
      border-left: 2px solid var(--ember-400);
    }
    .act-table .cell-date { font-size: 12px; color: var(--slate-400); white-space: nowrap; }
    .act-table .cell-duration { font-size: 12px; color: var(--slate-400); }
    .act-table .cell-method { font-size: 12px; color: var(--slate-400); }

    /* TSS colouring */
    .tss-high { color: var(--ember-500); font-weight: 500; }
    .tss-normal { color: var(--slate-800); font-weight: 400; }
    .tss-easy { color: var(--slate-400); font-weight: 400; }

    /* IF colouring */
    .if-hard { color: var(--ember-500); }
    .if-tempo { color: var(--ember-500); }
    .if-easy { color: var(--slate-800); }

    /* Expand chevron */
    .expand-chevron {
      background: none;
      border: none;
      cursor: pointer;
      color: var(--slate-400);
      font-size: 16px;
      padding: var(--space-1);
      min-width: 44px;
      min-height: 44px;
      display: flex;
      align-items: center;
      justify-content: center;
      line-height: 1;
      transition: transform 0.2s;
    }
    .expand-chevron:hover { color: var(--slate-800); }
    .expand-chevron[data-state="open"] { transform: rotate(90deg); color: var(--slate-800); }

    /* Detail row */
    .detail-row { display: none; }
    .detail-row[data-state="open"] { display: table-row; }
    .detail-row > td {
      background: var(--slate-50);
      border-top: 0.5px solid var(--slate-100);
      padding: var(--space-3) 14px var(--space-3) 28px !important;
      border-bottom: 0.5px solid var(--slate-100);
    }

    /* Detail metrics card */
    .detail-metrics-card {
      border-radius: 8px;
      padding: var(--space-3) var(--space-4);
      margin-bottom: 10px;
    }
    .detail-metrics-row {
      display: flex;
      gap: var(--space-5);
      flex-wrap: wrap;
    }
    .detail-metrics-row + .detail-metrics-row {
      margin-top: 10px;
      align-items: center;
    }
    .dm-item {
      min-width: 60px;
    }
    .dm-label {
      font-size: 10px;
      font-weight: 500;
      color: var(--slate-600);
      text-transform: uppercase;
      letter-spacing: 0.04em;
      margin-bottom: 1px;
    }
    .dm-value {
      font-size: 14px;
      color: var(--slate-800);
    }
    .dm-value.dm-derived {
      font-size: 13px;
    }
    .dm-unit {
      font-size: 11px;
      color: var(--slate-400);
    }
    .dm-value.dm-bold { font-weight: 500; }
    .dm-value.dm-ember { color: var(--ember-500); font-weight: 500; }
    .dm-peaks-sep {
      border-left: 1px solid var(--slate-100);
      padding-left: 20px;
    }
    .detail-weather {
      margin-top: 9px;
      padding-top: var(--space-2);
      border-top: 1px solid var(--slate-100);
      font-size: 11px;
      color: var(--slate-600);
    }
    /* Section label clarifying that the following row is computed by CoachGPT
       rather than sourced directly from Strava (Strava API terms compliance). */
    .detail-derived-header {
      margin-top: var(--space-3);
      margin-bottom: var(--space-1);
      padding-top: var(--space-2);
      border-top: 1px solid var(--slate-100);
      font-size: 10px;
      font-weight: 500;
      color: var(--slate-600);
      text-transform: uppercase;
      letter-spacing: 0.06em;
    }

    /* Zone donut — compact inline version */
    .dm-zones {
      margin-left: auto;
      display: flex;
      align-items: center;
      gap: 10px;
    }
    .dm-donut {
      width: var(--w, 38px);
      height: var(--h, 38px);
      background: var(--bg);
      border-radius: 50%;
      flex-shrink: 0;
      position: relative;
    }
    .dm-donut::after {
      content: '';
      position: absolute;
      top: 24%; left: 24%;
      width: 52%; height: 52%;
      border-radius: 50%;
      background: var(--white);
    }
    .dm-donut-label {
      font-size: 9px;
      color: var(--slate-600);
      font-weight: 500;
      text-transform: uppercase;
      letter-spacing: 0.3px;
    }
    .dm-zone-legend {
      font-size: 9px;
      color: var(--slate-600);
      line-height: 1.6;
    }
    .dm-zone-legend .zl-swatch {
      display: inline-block;
      width: 7px;
      height: 7px;
      border-radius: 1px;
      margin-right: 3px;
      vertical-align: middle;
      background: var(--bg);
    }

    /* Lap table */
    .lap-table-wrap {
      margin-top: 0;
      background: var(--white);
      border: 0.5px solid var(--slate-100);
      border-radius: 8px;
      overflow-x: auto;
      -webkit-overflow-scrolling: touch;
    }
    .lap-tbl {
      border-collapse: collapse;
      width: 100%;
      font-size: 12px;
    }
    .lap-tbl th {
      background: var(--slate-50);
      padding: 7px var(--space-3);
      text-align: left;
      font-size: 11px;
      font-weight: 500;
      color: var(--slate-400);
      text-transform: uppercase;
      letter-spacing: 0.04em;
      white-space: nowrap;
    }
    .lap-tbl td {
      padding: 6px var(--space-3);
      border-bottom: 0.5px solid var(--slate-100);
      text-align: right;
      color: var(--slate-800);
      white-space: nowrap;
    }
    .lap-tbl td:first-child { text-align: left; color: var(--slate-400); }

    /* Effort bar in lap table */
    .effort-bar {
      height: 14px;
      border-radius: 3px;
      min-width: 15%;
      width: var(--w);
    }
    .effort-bar.effort-low { background: var(--slate-200); }
    .effort-bar.effort-high { background: linear-gradient(90deg, var(--ember-400), var(--ember-500)); }
    .lap-tbl .effort-cell { text-align: left; width: 24%; }

    /* Swim lap autocorrection indicator — flags laps whose distance was
       snapped to the inferred pool length so users can see when a value
       differs from Strava's original. */
    .lap-tbl .lap-corrected {
      display: inline-flex;
      align-items: center;
      gap: 5px;
      border-bottom: 1px dotted var(--slate-400);
      cursor: help;
    }
    .lap-adj-badge {
      display: inline-block;
      padding: 1px 5px;
      border-radius: 3px;
      background: var(--ember-50);
      color: var(--ember-600);
      font-size: 9px;
      font-weight: 500;
      text-transform: uppercase;
      letter-spacing: 0.04em;
      line-height: 1.3;
    }
    .lap-corrected-note {
      padding: var(--space-2) var(--space-3);
      border-top: 0.5px solid var(--slate-100);
      font-size: 11px;
      color: var(--slate-600);
      line-height: 1.5;
    }
    .lap-corrected-note .lap-adj-badge {
      vertical-align: baseline;
    }

    /* Per-lap distance editor — mirrors the swim-meta inline editor.
       Button looks like normal cell text; hover/focus hints it's clickable. */
    .lap-tbl .lap-distance-edit-btn {
      background: transparent;
      border: none;
      padding: 0;
      font: inherit;
      color: inherit;
      cursor: pointer;
      border-bottom: 1px dotted transparent;
    }
    .lap-tbl .lap-distance-edit-btn:hover,
    .lap-tbl .lap-distance-edit-btn:focus-visible {
      border-bottom-color: var(--slate-400);
      outline: none;
    }
    .lap-tbl .lap-distance-select {
      font-size: 12px;
      padding: 1px var(--space-1);
      border: 1px solid var(--slate-300);
      border-radius: 3px;
      background: var(--bg-card, #fff);
      max-width: 90px;
    }
    .lap-tbl .lap-distance-save,
    .lap-tbl .lap-distance-cell .btn {
      margin-left: var(--space-1);
    }
    .lap-tbl .lap-distance-msg {
      display: block;
      margin-top: 2px;
      font-size: 10px;
      color: var(--slate-500);
    }

    .detail-swim-meta {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      margin-top: 6px;
      font-size: 12px;
      color: var(--slate-700);
    }
    .detail-swim-meta .swim-meta-label {
      color: var(--slate-500);
      text-transform: uppercase;
      letter-spacing: 0.04em;
      font-size: 10px;
      font-weight: 500;
    }
    .detail-swim-meta .swim-meta-value {
      font-weight: 500;
    }
    .detail-swim-meta .swim-meta-edit-btn {
      background: transparent;
      border: none;
      padding: 0 var(--space-1);
      cursor: pointer;
      color: var(--slate-500);
      font-size: 12px;
      line-height: 1;
    }
    .detail-swim-meta .swim-meta-edit-btn:hover,
    .detail-swim-meta .swim-meta-edit-btn:focus {
      color: var(--ember-600);
    }
    .detail-swim-meta .swim-meta-select {
      font-size: 12px;
      padding: 2px 6px;
      border: 1px solid var(--slate-300);
      border-radius: 4px;
      background: var(--bg-card, #fff);
    }
    .detail-swim-meta .swim-meta-msg {
      color: var(--slate-500);
      font-size: 11px;
    }

    .detail-activity-actions {
      display: flex;
      align-items: center;
      gap: 10px;
      margin-top: var(--space-3);
      padding-top: 10px;
      border-top: 1px solid var(--slate-200);
      flex-wrap: wrap;
    }
    .detail-activity-actions .reprocess-msg {
      color: var(--slate-500);
      font-size: 11px;
    }

    .detail-loading {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      color: var(--slate-400);
      font-size: 13px;
    }
    .detail-loading .ember-dot {
      width: 6px;
      height: 6px;
      border-radius: 50%;
      background: var(--ember-400);
      animation: dotPulse 1.2s infinite ease-in-out;
    }
    .ember-dot--d1 { animation-delay: 0.2s; }
    .ember-dot--d2 { animation-delay: 0.4s; }
    .detail-loading-label { margin-left: var(--space-1); }

    /* Table state cells (used inside <tr><td colspan=...> rows).
       `.table-empty-cell` retired in favour of `.empty-state` (issue #2168). */
    .table-loading-cell { padding: 20px; text-align: center; }
    .table-error-cell {
      padding: 20px;
      text-align: center;
      color: var(--slate-400);
    }
    .cell-center { text-align: center; }
    .detail-empty {
      color: var(--slate-400);
      font-size: 12px;
    }

    /* Zone donut wrappers (renderZoneDonutsHtml + renderZoneDonutsCard) */
    .dm-zones-row {
      display: flex;
      align-items: center;
      gap: 10px;
    }
    .dm-zones-donut-stack {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 2px;
    }
    .zones-donut-wrap {
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 3px;
      flex-shrink: 0;
    }

    /* Lap row tint — effort-scaled warm background */
    .lap-effort-tinted { background: var(--bg); }
    .row-copy-btn {
      background: none;
      border: none;
      cursor: pointer;
      color: var(--slate-400);
      min-width: 44px;
      min-height: 44px;
      display: flex;
      align-items: center;
      justify-content: center;
      padding: 0;
    }
    .row-copy-btn svg { width: 18px; height: 18px; }
    .row-copy-btn:hover { color: var(--slate-800); }
    .row-copy-btn.copied { color: var(--ember-500); }

    .detail-copy-mobile { display: none; }

    /* Tabular figures for the activity table column */
    .act-table td { font-variant-numeric: tabular-nums; }

/* --- Threshold suggestion popup --- */
.threshold-popup {
  position: fixed;
  inset: 0;
  z-index: var(--z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
}
.threshold-popup.hidden { display: none; }
.threshold-popup-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
}
.threshold-popup-content {
  position: relative;
  background: var(--slate-50);
  border: 1px solid var(--slate-200);
  border-radius: 12px;
  padding: var(--space-5);
  max-width: 420px;
  width: calc(100% - 32px);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
}
.threshold-popup-title {
  font-size: 16px;
  font-weight: 600;
  color: var(--slate-900);
  margin: 0 0 var(--space-1);
}
.threshold-popup-subtitle {
  font-size: 13px;
  color: var(--slate-600);
  margin: 0 0 var(--space-4);
}
.threshold-popup-item {
  display: flex;
  align-items: baseline;
  gap: var(--space-2);
  padding: var(--space-2) 0;
  border-bottom: 1px solid var(--slate-100);
  font-size: 14px;
  color: var(--slate-800);
}
.threshold-popup-item:last-child { border-bottom: none; }
.threshold-popup-item strong { font-weight: 600; }
.threshold-popup-arrow {
  color: var(--slate-400);
  font-size: 12px;
}
.threshold-popup-new {
  color: var(--ember-500);
  font-weight: 500;
}
.threshold-popup-count {
  color: var(--slate-400);
  font-size: 12px;
}
.threshold-popup-actions {
  display: flex;
  gap: var(--space-2);
  margin-top: 20px;
  justify-content: center;
}

/* --- Threshold suggestion badge (inline in Thresholds panel) --- */
.threshold-suggestion-badge {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: 6px;
  padding: 6px 10px;
  background: color-mix(in srgb, var(--ember-400) 8%, transparent);
  border: 1px solid color-mix(in srgb, var(--ember-400) 20%, transparent);
  border-radius: 8px;
  font-size: 13px;
}
.threshold-suggestion-label {
  flex: 1;
  color: var(--ember-500);
  font-weight: 500;
}
.threshold-suggestion-accept,
.threshold-suggestion-dismiss {
  border: none;
  background: none;
  cursor: pointer;
  font-size: 16px;
  padding: 0;
  line-height: 1;
  position: relative;
}
.threshold-suggestion-accept::after,
.threshold-suggestion-dismiss::after {
  content: '';
  position: absolute;
  inset: -10px;
  min-width: 44px;
  min-height: 44px;
}
.threshold-suggestion-accept { color: var(--green, #22c55e); }
.threshold-suggestion-dismiss { color: var(--slate-400); }

/* ── Activity detail: three-card layout ───────────────────── */

.detail-cards-row {
  display: flex;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

.detail-metrics-card {
  flex: 3 1 0%;
  min-width: 0;
}

/* When no chart card is present, constrain metrics and push zones right */
.detail-cards-row:not(:has(.detail-chart-card)) .detail-metrics-card {
  max-width: 520px;
}

.detail-cards-row:not(:has(.detail-chart-card)) .detail-zones-card {
  margin-left: auto;
}

.detail-chart-card {
  flex: 5;
  min-width: 0;
  display: flex;
  flex-direction: column;
  padding: 14px var(--space-4);
}

.detail-zones-card {
  flex: 1.2;
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 14px var(--space-3);
  gap: 0;
}

.detail-zones-card.dual-donut {
  flex: 1.5;
}

/* Chart internals */
.chart-legend {
  display: flex;
  justify-content: flex-end;
  gap: var(--space-3);
  margin-bottom: 6px;
  font-size: 10px;
}

.chart-legend-item {
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

.chart-legend-swatch {
  width: 12px;
  height: 2px;
  border-radius: 1px;
  display: inline-block;
  background: var(--bg);
}

.chart-container {
  flex: 1;
  position: relative;
  min-height: 100px;
}

.chart-y-label {
  position: absolute;
  left: 0;
  font-size: 8px;
  color: var(--slate-400);
}

.chart-svg {
  display: block;
  width: 100%;
  height: 100%;
}

/* Zone donut in zones card */
.zones-donut-group {
  display: flex;
  align-items: center;
  gap: 10px;
}

.zones-donut-label {
  font-size: 9px;
  color: var(--slate-600);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.zones-legend {
  font-size: 10px;
  color: var(--slate-800);
  line-height: 1.7;
}

.zones-legend-item {
  display: flex;
  align-items: center;
  gap: 5px;
}

.zones-legend-swatch {
  width: 7px;
  height: 7px;
  border-radius: 2px;
  flex-shrink: 0;
  background: var(--bg);
}

.zones-divider {
  width: 80%;
  border: none;
  border-top: 1px solid var(--slate-100);
  margin: var(--space-3) 0;
}

/* Chart loading state */
.chart-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  gap: var(--space-1);
}

/* ── Responsive: narrow / mobile (800px) for the three-card detail layout ── */

@media (max-width: 800px) {
  .detail-cards-row {
    flex-wrap: wrap;
  }

  .detail-metrics-card {
    flex: 1 1 60%;
    order: 1;
  }

  .detail-zones-card,
  .detail-zones-card.dual-donut {
    flex: 1 1 30%;
    order: 2;
  }

  .detail-chart-card {
    flex: 1 1 100%;
    order: 3;
    min-height: 120px;
  }
}

    /* ── Mobile (≤639px) — Data-tab overrides ──
       Extracted from the shared `@media (max-width: 639px)` block in
       styles.css so the Data tab owns its mobile rules. Chat / notes /
       mobile-status-bar rules in that block remain in styles.css. */
    @media (max-width: 639px) {
      /* Data surface mobile */
      .data-surface { padding: 10px; }
      .table-card { display: none; }
      .activity-cards { display: flex; flex-direction: column; gap: 20px; }
      .activity-card { overflow: hidden; }
      .activity-card-body { padding: var(--space-3) 14px; cursor: pointer; }
      .activity-card-top {
        display: flex;
        align-items: center;
        justify-content: space-between;
      }
      .activity-card-left {
        display: flex;
        align-items: center;
        gap: var(--space-2);
        min-width: 0;
        flex: 1;
      }
      .activity-card-name {
        font-size: 13px;
        font-weight: 500;
        color: var(--slate-900);
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
      }
      .activity-card-actions {
        display: flex;
        align-items: center;
        gap: 2px;
        flex-shrink: 0;
        margin-left: var(--space-2);
      }
      .activity-card-btn {
        background: none;
        border: none;
        color: var(--slate-400);
        padding: var(--space-1);
        min-width: 32px;
        min-height: 32px;
        display: flex;
        align-items: center;
        justify-content: center;
        border-radius: 6px;
        cursor: pointer;
        font-size: 14px;
      }
      .activity-card-btn svg { width: 15px; height: 15px; }
      .activity-card-stats {
        display: flex;
        align-items: baseline;
        gap: var(--space-4);
        margin-top: var(--space-2);
      }
      .activity-card-tss { font-size: 12px; font-weight: 600; margin-right: var(--space-1); }
      .activity-card-date { font-size: 11px; color: var(--slate-400); }
      .activity-card-stat { font-size: 13px; font-weight: 500; color: var(--slate-800); }
      .activity-card-detail { display: none; }
      .activity-card-detail[data-state="open"] {
        display: block;
        background: var(--slate-50);
        border-top: 0.5px solid var(--slate-100);
        padding: 10px 14px;
      }
      .col-copy { display: none; }
      .row-tappable { cursor: pointer; }
      .detail-copy-mobile {
        display: flex;
        justify-content: flex-start;
        padding: var(--space-2) 0 var(--space-1);
      }
      .detail-copy-mobile .row-copy-btn {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        font-size: 13px;
        color: var(--slate-500);
      }
      .detail-copy-mobile .row-copy-btn svg { width: 14px; height: 14px; }
      .act-table thead th,
      .act-table tbody td { padding: var(--space-2) 10px; }
      .detail-row > td { padding: 10px 10px 10px var(--space-4) !important; }
      /* Mobile detail: merge metric rows, stack zones below */
      .detail-metrics-row { gap: var(--space-4); }
      .detail-metrics-row + .detail-metrics-row { margin-top: var(--space-2); }
      /* Stack detail sub-cards vertically on mobile */
      .detail-cards-row { flex-direction: column; }
      .detail-chart-card { min-height: 160px; }
      .dm-peaks-sep { border-left: none; padding-left: 0; }
      .dm-zones { margin-left: 0; margin-top: var(--space-2); width: 100%; }
      .effort-cell { display: none; }
      /* Issue 1: sport pills — prevent short labels becoming circles */
      .sport-pill {
        min-width: 48px;
        padding: 10px var(--space-4);
      }
      /* Mobile: tighter intra-row gap, but per #2237 inter-section rhythm bumps to 24px. */
      .filter-row { gap: 6px; margin-bottom: 24px; }
      .pagination-row { margin-top: 24px; }
      .filter-row select { flex: 1; min-width: 0; }
      .search-wrap { flex: 1 1 100%; min-width: 0; }
      .pagination-info { font-size: 11px; }
      .filter-row .action-btns { width: 100%; justify-content: flex-end; flex-wrap: wrap; gap: 6px; }
      .filter-row .export-split { width: 100%; }
      .filter-row .export-split-main { flex: 1; justify-content: center; }
      /* Date pickers: single row with From/To labels */
      .filter-row .date-range {
        display: flex;
        flex-direction: row;
        gap: 6px;
        width: 100%;
      }
      .filter-row .date-range .date-label {
        flex: 1;
        min-width: 0;
      }
      .filter-row .date-range .date-label .date-prefix {
        font-size: 12px;
        padding: 0 0 0 var(--space-2);
      }
      .filter-row .date-range .date-label input[type="date"] {
        width: 100%;
        height: 44px;
        font-size: 14px;
        padding: 0 var(--space-1);
      }
      .filter-row .date-range .date-sep {
        display: none;
      }
      /* Sticky date column */
      .act-table thead th:first-child,
      .act-table tbody td:first-child {
        position: sticky;
        left: 0;
        z-index: var(--z-sticky);
        box-shadow: 1px 0 0 0 var(--slate-100);
      }
      .act-table thead th:first-child { background: var(--slate-50); }
      .act-table tbody td:first-child { background: var(--white); }
      .act-table tbody tr:hover td:first-child { background: var(--slate-50); }
    }
