/* ============================================================
   Show Jumping Timer — Bromont 2026
   ============================================================ */

* { box-sizing: border-box; }
html, body, #root { margin: 0; height: 100%; }
body {
  background: var(--bromont-night);
  color: var(--air-fg-on-dark);
  font-family: var(--font-body);
  -webkit-font-smoothing: antialiased;
  overscroll-behavior: none;
  user-select: none;
  -webkit-user-select: none;
}
button { font-family: inherit; }

/* ------------------------------------------------------------
   Shell — portrait-first, centered on wider viewports
   ------------------------------------------------------------ */
.app {
  position: relative;
  margin: 0 auto;
  max-width: 520px;
  min-height: 100vh;
  min-height: 100dvh;
  display: grid;
  grid-template-rows: auto 1fr auto;
  padding: env(safe-area-inset-top) 0 env(safe-area-inset-bottom);
  background:
    radial-gradient(ellipse 80% 50% at 50% 0%, rgba(43, 50, 141, 0.18), transparent 60%),
    var(--bromont-night);
  overflow: hidden;
}

/* ------------------------------------------------------------
   Top bar — class label, venue lockup, persistent context
   ------------------------------------------------------------ */
.top {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 18px 22px 14px;
  gap: 16px;
}
.top .venue {
  display: flex; align-items: center; gap: 8px;
  font: 700 11px/1 var(--font-display);
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--air-fg-on-dark);
}
.top .venue .bug {
  width: 14px; height: 14px;
  background: var(--bromont-teal);
  -webkit-mask: url('ds/horse-bug.svg') center/contain no-repeat;
          mask: url('ds/horse-bug.svg') center/contain no-repeat;
}
.top .class-tag {
  font: 700 10px/1 var(--font-headline);
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--bromont-teal);
  padding: 6px 10px;
  border: 1px solid color-mix(in srgb, var(--bromont-teal) 35%, transparent);
  justify-self: end;
  white-space: nowrap;
}
.top .discipline {
  justify-self: end;
  font: 700 11px/1 var(--font-display);
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--air-fg-on-dark-mute);
}

/* ------------------------------------------------------------
   Rider context strip
   ------------------------------------------------------------ */
.rider-strip {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 14px;
  padding: 14px 22px;
  margin: 0 16px;
  border-top: 1px solid color-mix(in srgb, var(--bromont-paper) 9%, transparent);
  border-bottom: 1px solid color-mix(in srgb, var(--bromont-paper) 9%, transparent);
}
.rider-strip .order {
  font: 500 28px/1 var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--bromont-paper);
  min-width: 88px;
  white-space: nowrap;
}
.rider-strip .order .lbl {
  color: var(--air-fg-on-dark-mute);
  font: 600 10px/1 var(--font-headline);
  letter-spacing: .14em;
  display: block;
  margin-bottom: 6px;
  text-transform: uppercase;
}
.rider-strip .order .of {
  font: 500 13px/1 var(--font-mono);
  color: var(--air-fg-on-dark-mute);
  margin-left: 2px;
}
.rider-strip .who {
  display: flex; flex-direction: column; gap: 4px; min-width: 0;
}
.rider-strip .who .name {
  font: 700 19px/1.15 var(--font-display);
  letter-spacing: -.005em;
  color: var(--bromont-paper);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.rider-strip .who .horse {
  font: 400 14px/1.2 var(--font-body);
  color: var(--air-fg-on-dark-mute);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.rider-strip .flag {
  display: inline-flex; align-items: center; justify-content: center;
  height: 28px; padding: 0 8px;
  background: var(--bromont-teal);
  color: var(--bromont-ink-text);
  font: 800 12px/1 var(--font-display);
  letter-spacing: .08em;
}

/* ------------------------------------------------------------
   Stage — the area that swaps PRE / LIVE / PAUSED / DONE
   ------------------------------------------------------------ */
.stage {
  position: relative;
  display: grid;
  align-content: stretch;
  padding: 24px 22px 16px;
  min-height: 0;
}

/* ============================================================
   PRE-RIDE — big START button
   ============================================================ */
.pre {
  display: grid;
  grid-template-rows: 1fr auto;
  gap: 32px;
  min-height: 100%;
}
.pre .cue {
  align-self: stretch;
  display: grid;
  grid-template-rows: 1fr auto auto;
  align-content: center;
  text-align: center;
  gap: 18px;
}
.pre .countdown-label {
  font: 600 11px/1 var(--font-headline);
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--air-fg-on-dark-mute);
  align-self: end;
}

/* Massive teal START button — the only large clickable in this state */
.start-btn {
  position: relative;
  appearance: none;
  display: grid;
  place-items: center;
  width: 100%;
  aspect-ratio: 1 / 1;
  max-height: 60vh;
  padding: 0;
  background: transparent;
  border: 2px solid var(--bromont-teal);
  color: var(--bromont-teal);
  cursor: pointer;
  transition: background 120ms linear, transform 120ms linear;
}
.start-btn::before {
  content: "";
  position: absolute; inset: 6px;
  border: 1px solid color-mix(in srgb, var(--bromont-teal) 30%, transparent);
  pointer-events: none;
}
.start-btn:hover { background: color-mix(in srgb, var(--bromont-teal) 8%, transparent); }
.start-btn:active { background: color-mix(in srgb, var(--bromont-teal) 16%, transparent); }
.start-btn .word {
  font: 800 92px/.95 var(--font-display);
  letter-spacing: -.02em;
  text-transform: uppercase;
}
.start-btn .hint {
  position: absolute; bottom: 18px; left: 0; right: 0;
  font: 600 10px/1 var(--font-headline);
  letter-spacing: .22em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--bromont-teal) 75%, transparent);
}

.pre .helper {
  text-align: center;
  font: 500 14px/1.4 var(--font-body);
  color: var(--air-fg-on-dark-mute);
  padding: 0 12px;
}

/* Pre-ride info row — time allowed (editable) + time limit */
.pre-info {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  margin: 0 -22px -16px;
  background: color-mix(in srgb, var(--bromont-paper) 10%, transparent);
  border-top: 1px solid color-mix(in srgb, var(--bromont-paper) 10%, transparent);
}
.pre-info .cell {
  background: var(--bromont-night);
  padding: 16px 22px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.pre-info .cell .lbl {
  font: 600 10px/1.2 var(--font-headline);
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--air-fg-on-dark-mute);
}
.pre-info .cell .val {
  font: 500 26px/1 var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--bromont-paper);
  min-width: 64px;
  text-align: center;
}
.pre-info .cell .val .unit {
  font: 500 12px/1 var(--font-mono);
  color: var(--air-fg-on-dark-mute);
  margin-left: 2px;
}
.pre-info .ta-controls {
  display: flex;
  align-items: center;
  gap: 4px;
}
.pre-info .ta-step {
  appearance: none;
  background: transparent;
  border: 1px solid color-mix(in srgb, var(--bromont-paper) 22%, transparent);
  color: var(--bromont-paper);
  width: 40px;
  height: 40px;
  font: 500 22px/1 var(--font-display);
  cursor: pointer;
  display: grid;
  place-items: center;
  user-select: none;
  -webkit-user-select: none;
  transition: background 120ms linear, border-color 120ms linear;
}
.pre-info .ta-step:hover {
  background: color-mix(in srgb, var(--bromont-teal) 12%, transparent);
  border-color: var(--bromont-teal);
  color: var(--bromont-teal);
}
.pre-info .ta-step:active {
  background: color-mix(in srgb, var(--bromont-teal) 22%, transparent);
}

/* ============================================================
   LIVE — clock + faults + actions
   ============================================================ */
.live {
  display: grid;
  grid-template-rows: auto auto 1fr;
  gap: 14px;
}

/* Big clock band */
.clock-band {
  position: relative;
  border: 1px solid color-mix(in srgb, var(--bromont-paper) 12%, transparent);
  background: color-mix(in srgb, var(--bromont-night) 60%, #14182B 40%);
  padding: 18px 20px 14px;
}
.clock-band .row1 {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 8px;
}
.clock-band .live-tag {
  display: inline-flex; align-items: center; gap: 8px;
  font: 700 11px/1 var(--font-headline);
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--bromont-leaf);
}
.clock-band .live-tag .dot {
  width: 9px; height: 9px;
  background: var(--bromont-leaf);
  border-radius: 50%;
  animation: liveDot 1.2s ease-in-out infinite;
}
.clock-band[data-paused="true"] .live-tag { color: var(--bromont-flag); }
.clock-band[data-paused="true"] .live-tag .dot { background: var(--bromont-flag); animation: none; }
.clock-band .allowed {
  font: 600 11px/1 var(--font-headline);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--air-fg-on-dark-mute);
}
.clock-band .allowed b {
  color: var(--bromont-paper);
  font-weight: 600;
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}

.clock-band .row2 {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: 18px;
}
.clock {
  font: 700 76px/.92 var(--font-mono);
  font-variant-numeric: tabular-nums;
  letter-spacing: -.02em;
  color: var(--bromont-paper);
}
.clock .min { }
.clock .sep { color: var(--air-fg-on-dark-mute); }
.clock .sec { }
.clock .ms { color: var(--air-fg-on-dark-mute); font-size: 48px; }

.clock-band[data-over="true"] .clock,
.clock-band[data-over="true"] .clock .sep,
.clock-band[data-over="true"] .clock .ms { color: var(--bromont-flag); }
.clock-band[data-near-limit="true"] .allowed b { color: var(--bromont-flag); }
.clock-band[data-paused="true"] { animation: pausePulse 1.4s ease-in-out infinite; }
.clock-band .correction-strip {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed color-mix(in srgb, var(--bromont-paper) 14%, transparent);
  display: flex; justify-content: space-between; align-items: center;
  font: 600 11px/1 var(--font-headline);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--air-fg-on-dark-mute);
}
.clock-band .correction-strip b {
  color: var(--bromont-paper);
  font: 600 14px/1 var(--font-mono);
  font-variant-numeric: tabular-nums;
}

.faults {
  text-align: right;
  display: grid;
  gap: 4px;
}
.faults .v {
  font: 700 56px/.9 var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--bromont-paper);
}
.faults .l {
  font: 600 10px/1 var(--font-headline);
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--air-fg-on-dark-mute);
}
.clock-band[data-faults="true"] .faults .v { color: var(--bromont-flag); }

/* Penalty + control buttons */
.actions {
  display: grid;
  grid-template-rows: 1fr auto auto;
  gap: 10px;
  min-height: 0;
}

.action {
  position: relative;
  appearance: none;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  padding: 0 22px;
  min-height: 84px;
  border: 1px solid;
  background: transparent;
  color: var(--bromont-paper);
  cursor: pointer;
  text-align: left;
  transition: background 120ms linear, border-color 120ms linear;
}
.action::before {
  content: "";
  position: absolute; inset: 5px;
  border: 1px solid transparent;
  pointer-events: none;
}
.action .label {
  font: 800 30px/1 var(--font-display);
  letter-spacing: -.005em;
  text-transform: uppercase;
}
.action .right {
  display: flex; flex-direction: column; align-items: flex-end; gap: 4px;
  font: 600 10px/1 var(--font-headline);
  letter-spacing: .18em;
  text-transform: uppercase;
}
.action .pts {
  font: 700 22px/1 var(--font-mono);
  font-variant-numeric: tabular-nums;
  letter-spacing: 0;
}
.action:active { transform: translateY(1px); }

/* Fault button (combined tap=rail, hold=refusal) */
.action.fault-btn {
  position: relative;
  min-height: 168px; /* spans the height of what was 2 separate buttons */
  overflow: hidden;
}
.action.fault-btn .fill {
  position: absolute;
  inset: 0;
  background: color-mix(in srgb, var(--bromont-flag) 35%, transparent);
  transform-origin: left center;
  transform: scaleX(0);
  transition: transform 80ms linear;
  z-index: 0;
}
.action.fault-btn[data-holding="true"] .fill {
  transform: scaleX(1);
  transition: transform 500ms linear;
}
.action.fault-btn .label,
.action.fault-btn .right {
  position: relative;
  z-index: 1;
}
.action.fault-btn .label {
  font-size: 38px;
}
.action.fault-btn .right .hint {
  display: grid;
  gap: 6px;
  font: 600 10px/1 var(--font-headline);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--bromont-flag) 70%, transparent);
  text-align: right;
}
.action.fault-btn .right .hint .hold {
  color: color-mix(in srgb, var(--bromont-flag) 90%, white);
}
.action.fault-btn[data-holding="true"] .label,
.action.fault-btn[data-holding="true"] .right .pts,
.action.fault-btn[data-holding="true"] .right .hint .hold {
  color: var(--bromont-paper);
}

/* Grid variant compactness */
.app[data-variant="grid"] .action.fault-btn {
  min-height: 0;
  grid-column: 1 / -1;
}
.app[data-variant="grid"] .action.fault-btn .label { font-size: 22px; }
.action.penalty {
  border-color: color-mix(in srgb, var(--bromont-flag) 65%, transparent);
  background: color-mix(in srgb, var(--bromont-flag) 8%, transparent);
  color: var(--bromont-flag);
}
.action.penalty:hover { background: color-mix(in srgb, var(--bromont-flag) 14%, transparent); }
.action.penalty:active { background: color-mix(in srgb, var(--bromont-flag) 22%, transparent); }
.action.penalty .right { color: color-mix(in srgb, var(--bromont-flag) 80%, transparent); }

/* Pause — indigo */
.action.pause {
  border-color: color-mix(in srgb, var(--bromont-indigo-300) 60%, transparent);
  background: color-mix(in srgb, var(--bromont-indigo) 22%, transparent);
  color: var(--bromont-paper);
}
.action.pause:hover { background: color-mix(in srgb, var(--bromont-indigo) 32%, transparent); }
.action.pause .right { color: color-mix(in srgb, var(--bromont-paper) 60%, transparent); }
.action.pause[data-active="true"] {
  background: var(--bromont-indigo);
  border-color: var(--bromont-indigo-300);
}

/* Stop — bold flag red, hold-to-confirm */
.action.stop {
  border-color: var(--bromont-flag);
  background: color-mix(in srgb, var(--bromont-flag) 18%, transparent);
  color: var(--bromont-flag);
  overflow: hidden;
}
.action.stop:hover { background: color-mix(in srgb, var(--bromont-flag) 28%, transparent); }
.action.stop .label, .action.stop .right { position: relative; z-index: 2; }
.action.stop .fill {
  position: absolute; inset: 0;
  background: var(--bromont-flag);
  transform-origin: left center;
  transform: scaleX(0);
  transition: transform 80ms linear;
  z-index: 1;
}
.action.stop[data-holding="true"] .fill { transform: scaleX(1); transition: transform 700ms linear; }
.action.stop[data-holding="true"] .label,
.action.stop[data-holding="true"] .right { color: var(--bromont-paper); }
.action.stop[data-holding="true"] .right { color: color-mix(in srgb, var(--bromont-paper) 75%, transparent); }

/* Footer chip row */
.foot {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 18px 6px 8px;
}
.chip {
  appearance: none;
  background: transparent;
  border: 0;
  color: var(--air-fg-on-dark-mute);
  padding: 8px 14px;
  font: 600 11px/1 var(--font-headline);
  letter-spacing: .14em;
  text-transform: uppercase;
  cursor: pointer;
}
.chip:hover { color: var(--bromont-paper); }
.chip:disabled { color: color-mix(in srgb, var(--bromont-paper) 22%, transparent); cursor: not-allowed; }
.chip .arrow { display: inline-block; transform: scaleX(-1); margin-right: 4px; }
.chip.danger { color: color-mix(in srgb, var(--bromont-flag) 80%, transparent); }
.chip.danger:hover { color: var(--bromont-flag); }
.foot-sep { width: 1px; height: 14px; background: color-mix(in srgb, var(--bromont-paper) 14%, transparent); }

/* ============================================================
   SYNC SLIDER — press/hold under the clock to nudge speed to
   match the official stopwatch. Snaps back to 1× on release.
   ============================================================ */
.sync {
  display: grid;
  gap: 6px;
  padding: 12px 4px 0;
}
.sync-meta {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 0 2px;
}
.sync-meta .lbl {
  font: 600 10px/1 var(--font-headline);
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--air-fg-on-dark-mute);
}
.sync-meta .readout {
  font: 500 14px/1 var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--bromont-paper);
  letter-spacing: -.005em;
}
.sync[data-dir="fast"] .sync-meta .readout { color: var(--bromont-teal); }
.sync[data-dir="slow"] .sync-meta .readout { color: var(--bromont-flag); }

.sync-track {
  position: relative;
  height: 56px;
  touch-action: none;
  cursor: ew-resize;
  user-select: none;
}
.sync-rail {
  position: absolute;
  left: 0; right: 0; top: 50%;
  height: 4px;
  transform: translateY(-50%);
  background: color-mix(in srgb, var(--bromont-paper) 12%, transparent);
}
.sync-center {
  position: absolute;
  left: 50%; top: 50%;
  width: 2px; height: 14px;
  background: color-mix(in srgb, var(--bromont-paper) 28%, transparent);
  transform: translate(-50%, -50%);
}
.sync-fill {
  position: absolute;
  top: 50%;
  height: 4px;
  transform: translateY(-50%);
  background: var(--bromont-paper);
  pointer-events: none;
}
.sync[data-dir="fast"] .sync-fill { background: var(--bromont-teal); }
.sync[data-dir="slow"] .sync-fill { background: var(--bromont-flag); }

.sync-thumb {
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 72px;
  height: 44px;
  background: var(--bromont-paper);
  color: var(--bromont-ink-text);
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  padding: 0 10px;
  gap: 8px;
  box-shadow: 0 6px 16px rgba(0,0,0,.35);
  pointer-events: none;
}
.sync[data-dragging="false"] .sync-thumb {
  transition: left 180ms cubic-bezier(.16,1,.3,1);
}
.sync[data-dragging="false"] .sync-fill {
  transition: left 180ms cubic-bezier(.16,1,.3,1), width 180ms cubic-bezier(.16,1,.3,1);
}
.sync[data-dir="fast"] .sync-thumb { background: var(--bromont-teal); }
.sync[data-dir="slow"] .sync-thumb { background: var(--bromont-flag); color: var(--bromont-paper); }

.sync-arrow {
  font: 800 18px/1 var(--font-display);
  color: color-mix(in srgb, var(--bromont-ink-text) 50%, transparent);
}
.sync[data-dir="slow"] .sync-arrow {
  color: color-mix(in srgb, var(--bromont-paper) 60%, transparent);
}
.sync[data-dir="fast"] .sync-arrow.right,
.sync[data-dir="slow"] .sync-arrow.left {
  color: currentColor;
}
.sync-grip {
  display: block;
  height: 16px;
  width: 100%;
  background-image: repeating-linear-gradient(
    90deg,
    currentColor 0 1px,
    transparent 1px 4px
  );
  opacity: .35;
}

.sync-end {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  font: 700 9px/1 var(--font-headline);
  letter-spacing: .22em;
  color: var(--air-fg-on-dark-mute);
  pointer-events: none;
}
.sync-end.slow { left: 8px; }
.sync-end.fast { right: 8px; }
.sync[data-dir="slow"] .sync-end.slow { color: var(--bromont-flag); }
.sync[data-dir="fast"] .sync-end.fast { color: var(--bromont-teal); }
.paused-card {
  position: absolute; inset: 0;
  background: color-mix(in srgb, var(--bromont-night) 88%, transparent);
  backdrop-filter: blur(4px);
  display: grid;
  place-content: center;
  text-align: center;
  z-index: 5;
  padding: 24px;
}
.paused-inner {
  display: grid;
  gap: 18px;
  width: min(100%, 380px);
}
.paused-card .badge {
  font: 800 14px/1 var(--font-headline);
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--bromont-flag);
}
.paused-card .why {
  font: 500 14px/1.4 var(--font-body);
  color: var(--air-fg-on-dark-mute);
}
.paused-card .paused-action {
  appearance: none;
  background: transparent;
  border: 1px solid color-mix(in srgb, var(--bromont-flag) 55%, transparent);
  color: var(--bromont-paper);
  padding: 16px 18px;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 10px;
  text-align: left;
  cursor: pointer;
  transition: background 120ms linear;
}
.paused-card .paused-action:hover {
  background: color-mix(in srgb, var(--bromont-flag) 14%, transparent);
}
.paused-card .pa-l {
  font: 700 16px/1.15 var(--font-display);
  letter-spacing: -.005em;
}
.paused-card .pa-r {
  font: 700 12px/1 var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--bromont-flag);
}
.paused-card .tc-row {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border: 1px solid color-mix(in srgb, var(--bromont-paper) 14%, transparent);
}
.paused-card .tc-l {
  font: 600 11px/1 var(--font-headline);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--air-fg-on-dark-mute);
  text-align: left;
}
.paused-card .tc-controls {
  display: flex; align-items: center; gap: 6px;
}
.paused-card .tc-btn {
  appearance: none;
  background: transparent;
  border: 1px solid color-mix(in srgb, var(--bromont-paper) 20%, transparent);
  color: var(--bromont-paper);
  padding: 6px 10px;
  font: 600 11px/1 var(--font-mono);
  cursor: pointer;
}
.paused-card .tc-btn:hover:not(:disabled) {
  background: color-mix(in srgb, var(--bromont-teal) 14%, transparent);
  border-color: var(--bromont-teal);
  color: var(--bromont-teal);
}
.paused-card .tc-btn:disabled { opacity: .35; cursor: not-allowed; }
.paused-card .tc-v {
  font: 600 14px/1 var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--bromont-paper);
  min-width: 40px;
  text-align: center;
}
.paused-card .resume {
  appearance: none;
  background: var(--bromont-teal);
  color: var(--bromont-ink-text);
  border: 0;
  padding: 18px 34px;
  font: 800 16px/1 var(--font-display);
  letter-spacing: .12em;
  text-transform: uppercase;
  cursor: pointer;
}
.paused-card .resume:hover { background: color-mix(in srgb, var(--bromont-teal) 88%, white); }

/* ============================================================
   SUMMARY — final result card
   ============================================================ */
.summary {
  display: grid;
  grid-template-rows: auto auto 1fr auto;
  gap: 14px;
}
.summary .result-head {
  display: grid;
  gap: 6px;
  padding: 8px 0 6px;
}
.summary .result-head .stamp {
  font: 700 10px/1 var(--font-headline);
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--bromont-teal);
}
.summary .result-head .verdict {
  font: 800 44px/1 var(--font-display);
  letter-spacing: -.015em;
  color: var(--bromont-paper);
}
.summary[data-elim="true"] .result-head .stamp { color: var(--bromont-flag); }
.summary[data-elim="true"] .result-head .verdict { color: var(--bromont-flag); }

.summary .totalcard {
  border: 1px solid color-mix(in srgb, var(--bromont-paper) 12%, transparent);
  background: color-mix(in srgb, var(--bromont-night) 60%, #14182B 40%);
  padding: 18px 20px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 14px;
  align-items: end;
}
.summary .totalcard .l {
  font: 600 10px/1 var(--font-headline);
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--air-fg-on-dark-mute);
  margin-bottom: 8px;
}
.summary .totalcard .sub-time {
  font: 500 11px/1.3 var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--air-fg-on-dark-mute);
  margin-top: 6px;
  letter-spacing: .04em;
}
.summary .totalcard .time {
  font: 700 56px/.92 var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--bromont-paper);
  letter-spacing: -.02em;
}
.summary .totalcard .penalty-total {
  text-align: right;
}
.summary .totalcard .penalty-total .n {
  font: 700 56px/.92 var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--bromont-paper);
}
.summary[data-faults="true"] .totalcard .penalty-total .n { color: var(--bromont-flag); }
.summary[data-elim="true"] .totalcard .penalty-total .n { color: var(--bromont-flag); font-size: 36px; font-family: var(--font-display); font-weight: 800; letter-spacing: .04em;}

.bd {
  border: 1px solid color-mix(in srgb, var(--bromont-paper) 10%, transparent);
}
.bd-row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  border-bottom: 1px solid color-mix(in srgb, var(--bromont-paper) 7%, transparent);
}
.bd-row:last-child { border-bottom: 0; }
.bd-row .name {
  font: 600 14px/1.2 var(--font-body);
  color: var(--bromont-paper);
}
.bd-row .name small {
  display: block;
  font: 400 11px/1.2 var(--font-body);
  color: var(--air-fg-on-dark-mute);
  margin-top: 3px;
}
.bd-row .count {
  font: 500 14px/1 var(--font-mono);
  color: var(--air-fg-on-dark-mute);
  font-variant-numeric: tabular-nums;
  min-width: 32px; text-align: right;
}
.bd-row .pts {
  font: 700 18px/1 var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--bromont-paper);
  min-width: 44px; text-align: right;
}
.bd-row[data-zero="true"] .name, .bd-row[data-zero="true"] .count, .bd-row[data-zero="true"] .pts { color: var(--air-fg-on-dark-mute); }
.bd-row[data-zero="true"] .name { color: color-mix(in srgb, var(--bromont-paper) 50%, transparent); }
.bd-row[data-faulted="true"] .pts { color: var(--bromont-flag); }

.summary .cta-row {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  padding-top: 4px;
}
.cta {
  appearance: none;
  background: transparent;
  border: 1px solid color-mix(in srgb, var(--bromont-paper) 20%, transparent);
  color: var(--bromont-paper);
  padding: 16px 18px;
  font: 700 13px/1 var(--font-headline);
  letter-spacing: .18em;
  text-transform: uppercase;
  cursor: pointer;
}
.cta:hover { background: color-mix(in srgb, var(--bromont-paper) 8%, transparent); }
.cta.primary {
  background: var(--bromont-teal);
  color: var(--bromont-ink-text);
  border-color: var(--bromont-teal);
}
.cta.primary:hover {
  background: color-mix(in srgb, var(--bromont-teal) 88%, white);
}

/* ============================================================
   Toast — undo / faulted notifier
   ============================================================ */
.toast-wrap {
  position: absolute;
  left: 22px; right: 22px;
  bottom: 24px;
  z-index: 6;
  pointer-events: none;
}
.toast {
  background: var(--bromont-paper);
  color: var(--bromont-ink-text);
  padding: 12px 16px;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 14px;
  pointer-events: auto;
  animation: toastIn 240ms cubic-bezier(.16,1,.3,1);
}
.toast .what {
  font: 600 13px/1.3 var(--font-body);
}
.toast .what small {
  display: block;
  font: 500 11px/1.2 var(--font-body);
  color: color-mix(in srgb, var(--bromont-ink-text) 55%, transparent);
  margin-top: 2px;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.toast button {
  appearance: none;
  background: transparent;
  border: 1px solid color-mix(in srgb, var(--bromont-ink-text) 30%, transparent);
  color: var(--bromont-ink-text);
  padding: 8px 12px;
  font: 700 11px/1 var(--font-headline);
  letter-spacing: .18em;
  text-transform: uppercase;
  cursor: pointer;
}
.toast button:hover { background: var(--bromont-ink-text); color: var(--bromont-paper); }

/* ============================================================
   Layout variants (Tweaks)
   ============================================================ */
/* Variant: ergonomic — stack penalties for one-handed at bottom */
.app[data-variant="ergo"] .stage { padding-top: 12px; }
.app[data-variant="ergo"] .clock-band {
  background: transparent;
  border: 0;
  border-bottom: 1px solid color-mix(in srgb, var(--bromont-paper) 12%, transparent);
  padding: 4px 0 18px;
}
.app[data-variant="ergo"] .clock { font-size: 96px; }
.app[data-variant="ergo"] .actions { padding-top: 8px; }

/* Variant: grid — 2x2 penalty grid (more buttons accessible) */
.app[data-variant="grid"] .actions {
  grid-template-rows: 1fr 1fr;
  grid-template-columns: 1fr 1fr;
  grid-template-areas:
    "fault fault"
    "pause stop";
}
.app[data-variant="grid"] .action.fault-btn { grid-area: fault; }
.app[data-variant="grid"] .action.pause { grid-area: pause; }
.app[data-variant="grid"] .action.stop { grid-area: stop; }
.app[data-variant="grid"] .action {
  grid-template-columns: 1fr;
  text-align: center;
  padding: 16px;
  align-content: center;
  display: grid; gap: 8px;
}
.app[data-variant="grid"] .action .label { font-size: 22px; text-align: center; }
.app[data-variant="grid"] .action .right { align-items: center; flex-direction: row; gap: 6px; justify-self: center; }

/* ============================================================
   Animations
   ============================================================ */
@keyframes liveDot {
  0%, 100% { opacity: 1; }
  50% { opacity: .35; }
}
@keyframes pausePulse {
  0%, 100% { opacity: 1; }
  50% { opacity: .7; }
}
@keyframes toastIn {
  from { transform: translateY(20px); opacity: 0; }
  to   { transform: translateY(0); opacity: 1; }
}
@keyframes faultFlash {
  0% { background: color-mix(in srgb, var(--bromont-flag) 0%, transparent); }
  20% { background: color-mix(in srgb, var(--bromont-flag) 30%, transparent); }
  100% { background: color-mix(in srgb, var(--bromont-flag) 0%, transparent); }
}
.flash { animation: faultFlash 700ms ease-out; }

/* ============================================================
   Tiny screens
   ============================================================ */
@media (max-height: 720px) {
  .start-btn .word { font-size: 72px; }
  .clock { font-size: 60px; }
  .clock .ms { font-size: 38px; }
  .action { min-height: 68px; }
  .action .label { font-size: 24px; }
}
@media (max-height: 620px) {
  .rider-strip { padding: 10px 22px; }
  .top { padding: 12px 22px 8px; }
  .start-btn .word { font-size: 60px; }
  .clock { font-size: 52px; }
  .clock .ms { font-size: 32px; }
  .action { min-height: 56px; }
  .action .label { font-size: 20px; }
  .pre-info .cell { padding: 12px 22px; }
}
