/* v1.1.0 */
/* =============================================================
   IDSport Cricket — Scoring Shell
   ============================================================= */

/* -------- Fonts -------- */
@import url('https://fonts.googleapis.com/css2?family=Big+Shoulders+Display:wght@700;800;900&family=Figtree:wght@400;500;600;700&family=JetBrains+Mono:wght@500;700&display=swap');

/* -------- Design tokens -------- */
:root {
  --bg:           #0a0b0d;
  --bg-elev-1:    #15171c;   /* slightly lighter for more visible layering */
  --bg-elev-2:    #1e2129;   /* was #1c1f25 */
  --bg-elev-3:    #2a2e3a;   /* was #252932 — more visible surface */
  --border:       #383d4e;   /* was #2b2f39 — clearer separators */
  --border-soft:  #24283200; /* kept near-invisible for subtle dividers */

  --text:         #f0f1f3;   /* slightly brighter white */
  --text-dim:     #b0b8c6;   /* was #9098a5 — much more readable */
  --text-muted:   #7a8390;   /* was #5c6470 — not quite invisible anymore */

  --accent:       #4a5bb8;        /* brand blue */
  --accent-hi:    #6275d8;
  --positive:     #1fb86b;
  --positive-hi:  #27d47e;
  --negative:     #e24e4e;
  --negative-hi:  #ff6161;
  --warning:      #e8a838;
  --danger:       #ff4d4d;

  --radius-sm: 6px;
  --radius:    10px;
  --radius-lg: 16px;

  --shadow-1: 0 1px 0 rgba(255,255,255,.04) inset, 0 4px 16px rgba(0,0,0,.35);
  --shadow-2: 0 12px 40px rgba(0,0,0,.55);

  --font-display: 'Big Shoulders Display', 'Arial Narrow', sans-serif;
  --font-ui:      'Figtree', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;
}

/* -------- Reset / base -------- */
*, *::before, *::after { box-sizing: border-box; }

html, body {
  margin: 0; padding: 0;
  height: 100%;
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-ui);
  font-size: 16px;
  line-height: 1.45;
  -webkit-font-smoothing: antialiased;
  -webkit-tap-highlight-color: transparent;
}

body {
  background:
    radial-gradient(ellipse 1200px 600px at 50% -100px, rgba(74,91,184,0.12), transparent 60%),
    radial-gradient(ellipse 900px 500px at 100% 100%, rgba(31,184,107,0.05), transparent 60%),
    var(--bg);
  min-height: 100dvh;
}

button, input, select { font-family: inherit; color: inherit; }
button { cursor: pointer; background: none; border: 0; }

h1, h2, h3, h4, h5, h6 { margin: 0; font-weight: 700; }

/* ============================================================
   Top bar
   ============================================================ */
.topbar {
  position: fixed; top: 0; left: 0; right: 0;
  height: 56px;
  /* 3-column grid puts court name dead centre regardless of the widths
     of the brand (left) and settings cog (right). */
  display: grid;
  grid-template-columns: 1fr auto 1.5fr;
  align-items: center;
  padding: 0 18px;
  background: linear-gradient(to bottom, rgba(10,11,13,.95), rgba(10,11,13,.6));
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  z-index: 120;   /* must be > .idle-overlay (100) so the settings menu,
                     which lives inside this stacking context, stays on top */
  border-bottom: 1px solid var(--border-soft);
}
.topbar__brand { justify-self: start;  grid-column: 1; }
.topbar__meta  { justify-self: center; text-align: center; grid-column: 2; }
.topbar > .settings { justify-self: end; grid-column: 3; }
.topbar__actions {
  justify-self: end;
  grid-column: 3;
  display: flex;
  align-items: center;
  gap: 8px;
}

.topbar__brand {
  display: flex; align-items: center; gap: 10px;
  color: var(--text);
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 20px;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.topbar__brand img { height: 22px; }

.topbar__meta {
  color: var(--text-dim);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: .04em;
}
.topbar__meta strong { color: var(--text); font-weight: 600; }

/* Settings cog */
.settings {
  position: relative;
  display: inline-flex;
}
.settings__btn {
  width: 40px; height: 40px;
  display: grid; place-items: center;
  border-radius: var(--radius-sm);
  color: var(--text-dim);
  transition: background .15s, color .15s;
}
.settings__btn:hover { background: var(--bg-elev-2); color: var(--text); }
.settings__btn svg { width: 22px; height: 22px; }

.settings__menu {
  position: absolute; top: calc(100% + 8px); right: 0;
  min-width: 370px;
  padding: 8px;
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-2);
  display: none;
  z-index: 110;   /* above .idle-overlay (z-index:100) so the dropdown
                     stays visible / clickable on the idle screen */
}
.settings__menu.is-open { display: block; }

/* ── Inline umpire selector inside settings menu ── */
.settings-umpire__current {
  cursor: pointer;
  user-select: none;
}
.settings-umpire__current:hover { background: var(--bg-elev-3); }
.settings-umpire__name {
  flex: 1;
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.settings-umpire__chevron {
  font-size: 11px;
  color: var(--text-dim);
  transition: transform .2s;
  flex-shrink: 0;
}
.settings-umpire__chevron.is-open { transform: rotate(180deg); }
.settings-umpire__list {
  padding: 6px 4px 2px;
}
.settings-umpire__filter {
  width: 100%;
  box-sizing: border-box;
  padding: 6px 10px;
  margin-bottom: 5px;
  background: var(--bg-elev-1);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-size: 12px;
}
.settings-umpire__filter:focus { outline: none; border-color: var(--accent); }
.settings-umpire__items {
  max-height: 180px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.settings-umpire__item {
  width: 100%;
  text-align: left;
  padding: 8px 10px;
  border-radius: var(--radius-sm);
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
  background: none;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 8px;
}
.settings-umpire__item:hover { background: var(--bg-elev-3); }
.settings-umpire__item.is-selected {
  background: rgba(74,91,184,.2);
  color: var(--accent-hi);
}
.settings-umpire__badge {
  font-size: 10px;
  color: var(--text-dim);
  margin-left: auto;
}

.menu-item {
  width: 100%;
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px;
  border-radius: var(--radius-sm);
  color: var(--text);
  font-weight: 500;
  font-size: 15px;
  text-align: left;
  transition: background .12s;
}
.menu-item:hover { background: var(--bg-elev-3); }
.menu-item--dev-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: #6b4e00;
  padding: 4px 12px 2px;
}
.menu-item--dev {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  flex-wrap: nowrap;
}
.dev-label {
  font-size: 11px;
  color: var(--text-dim);
  font-weight: 600;
}
.dev-input {
  background: var(--bg-elev-1);
  border: 1px solid #6b4e00;
  color: var(--text);
  border-radius: 5px;
  padding: 3px 5px;
  font-size: 12px;
  font-family: inherit;
}
.dev-btn {
  background: #7d5a00;
  border: none;
  color: #fff;
  border-radius: 5px;
  padding: 4px 10px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  font-family: inherit;
}
.dev-btn:hover { background: #9a6e00; } color: var(--danger); }
.menu-item--danger:hover { background: rgba(255,77,77,.1); }
.menu-item .icon { width: 18px; height: 18px; flex: none; opacity: .85; }

/* Reset buttons — side-by-side row inside settings menu */
.menu-item--reset-row {
  display: flex;
  gap: 8px;
  padding: 4px 14px 6px;
  cursor: default;
}
.menu-item--reset-row:hover { background: none; }
.menu-item--reset-row .btn  { flex: 1; }

.menu-item--toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 14px;
  cursor: default;
}
.menu-item--toggle:hover { background: none; }
.menu-item__label { font-size: 13px; color: var(--text-dim); white-space: nowrap; }

.settings__version {
  margin-top: 8px;
  padding: 8px 12px 4px;
  border-top: 1px solid var(--border);
  font-size: 11px;
  color: var(--text-dim);
  text-align: center;
  letter-spacing: .04em;
  user-select: none;
}

/* ─── Shared version chip + optional refresh button ───
   Used in topbar (version only), picker modal foot, and login card footer.
   Refresh button routes through reset.html — same hard-recovery path as
   the settings menu's Refresh action. */
.app-version {
  font-size: 11px;
  color: var(--text-dim);
  letter-spacing: .04em;
  user-select: none;
  white-space: nowrap;
}
.app-version-row {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.app-version-refresh {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  padding: 0;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text-dim);
  cursor: pointer;
  transition: border-color .15s, color .15s, background .15s;
}
.app-version-refresh:hover {
  color: var(--text);
  border-color: var(--text-dim);
  background: var(--bg-elev-2);
}
.app-version-refresh svg { width: 14px; height: 14px; }

/* Login card variant: dotted divider above so it sits cleanly below the form */
.login-card__version-row {
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

/* ============================================================
   Main board layout — shell container.
   Cricket-specific scoring components will live inside this
   container; for now it just centers the idle placeholder.
   ============================================================ */
.board {
  padding: 64px 16px 24px;
  max-width: 1400px;
  margin: 0 auto;
}

/* ============================================================
   Buttons (generic)
   ============================================================ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 10px 18px;
  border-radius: var(--radius-sm);
  font-family: var(--font-ui);
  font-weight: 600;
  font-size: 15px;
  background: var(--bg-elev-3);
  color: var(--text);
  transition: background .12s, transform .06s, border-color .12s;
  border: 1px solid var(--border);
}
.btn:hover { background: var(--bg-elev-2); border-color: var(--text-muted); }
.btn:active { transform: scale(.98); }

.btn--primary   { background: var(--accent);   border-color: var(--accent); color: #fff; }
.btn--primary:hover   { background: var(--accent-hi); border-color: var(--accent-hi); }
.btn--success   { background: var(--positive); border-color: var(--positive); color: #fff; }
.btn--success:hover   { background: var(--positive-hi); border-color: var(--positive-hi); }
.btn--danger    { background: var(--negative); border-color: var(--negative); color: #fff; }
.btn--danger:hover    { background: var(--negative-hi); border-color: var(--negative-hi); }
.btn--warning   { background: var(--warning);  border-color: var(--warning);  color: #1a1400; }
.btn--ghost     { background: transparent; }
.btn--block     { width: 100%; }
.btn--lg        { padding: 14px 22px; font-size: 16px; }
.btn--sm        { padding: 8px 12px;  font-size: 12px; }

/* ============================================================
   Modal (native <dialog>)
   ============================================================ */
dialog {
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--text);

  /* Fill the viewport and center the inner .modal / .confirm on both axes.
     The dialog itself is transparent; the visible UI is the inner box,
     which has its own width/max-width/max-height below. */
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  max-width: none;
  max-height: none;
  margin: 0;
  overflow: auto;
  display: grid;
  place-items: center;
}
dialog::backdrop {
  background: rgba(0,0,0,.72);
  backdrop-filter: blur(4px);
}
dialog:not([open]) { display: none; }

.modal {
  background: var(--bg-elev-1);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-2);
  display: flex; flex-direction: column;
  width: calc(100vw - 24px);
  max-width: 720px;
  max-height: calc(100dvh - 40px);
}
.modal__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 18px;
  border-bottom: 1px solid var(--border);
  background: var(--bg-elev-2);
}
.modal__title {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  display: flex; align-items: center; gap: 10px;
}
.modal__close {
  width: 32px; height: 32px;
  display: grid; place-items: center;
  border-radius: var(--radius-sm);
  color: var(--text-dim);
  transition: background .12s, color .12s;
}
.modal__close:hover { background: var(--bg-elev-3); color: var(--text); }

.modal__body { padding: 20px; overflow-y: auto; }
.modal__foot {
  display: flex; justify-content: space-between; align-items: center; gap: 10px;
  padding: 14px 18px;
  border-top: 1px solid var(--border);
  background: var(--bg-elev-2);
}

/* Form fields */
.field {
  display: flex; align-items: stretch;
  margin-bottom: 10px;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--border);
}
.field__label {
  flex: none;
  width: 110px;
  padding: 12px 14px;
  background: var(--bg-elev-3);
  font-weight: 600;
  font-size: 14px;
  color: var(--text-dim);
  letter-spacing: .04em;
  text-transform: uppercase;
  display: flex; align-items: center;
}
.field__input {
  flex: 1;
  padding: 12px 14px;
  background: var(--bg-elev-2);
  color: var(--text);
  border: 0;
  font-size: 16px;
  outline: none;
  min-width: 0;
}
.field__input:focus { background: var(--bg-elev-1); }
.field__input[readonly], .field__input:disabled { color: var(--text-dim); }

select.field__input {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path fill='%239098a5' d='M6 8L2 4h8z'/></svg>");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 36px;
}

.pill-group {
  display: flex;
  gap: 6px;
  margin: 14px 0;
  flex-wrap: wrap;
}
.pill {
  padding: 10px 18px;
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: 999px;
  font-weight: 600;
  font-size: 14px;
  color: var(--text-dim);
  letter-spacing: .04em;
  text-transform: uppercase;
  transition: all .15s;
}
.pill:hover { color: var(--text); border-color: var(--text-muted); }
.pill.is-active {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

/* Checkbox row (used in modals) */
.checkbox-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: var(--radius);
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  cursor: pointer;
  font-size: 14px;
  font-weight: 500;
  color: var(--text-dim);
  margin-bottom: 10px;
  transition: border-color .15s, color .15s;
}
.checkbox-row:hover { border-color: var(--text-muted); color: var(--text); }
.checkbox-row input[type=checkbox] {
  width: 18px; height: 18px;
  accent-color: var(--positive);
  cursor: pointer;
  flex: none;
}

/* ============================================================
   Login page
   ============================================================ */
.login-shell {
  min-height: 100dvh;
  display: grid; place-items: center;
  padding: 20px;
}
.login-card {
  width: 100%;
  max-width: 380px;
  background: var(--bg-elev-1);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 36px 28px;
  box-shadow: var(--shadow-2);
  text-align: center;
}
.login-card__logo { height: 70px; margin-bottom: 16px; }
.login-card__title {
  font-family: var(--font-display);
  font-size: 28px;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 4px;
}
.login-card__sub {
  color: var(--text-dim);
  font-size: 14px;
  margin-bottom: 24px;
}
.login-card input {
  width: 100%;
  padding: 14px 16px;
  background: var(--bg-elev-2);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font-size: 18px;
  text-align: center;
  letter-spacing: .3em;
  outline: none;
  margin-bottom: 14px;
  transition: border-color .15s;
}
.login-card input:focus { border-color: var(--accent); }
.login-card .err {
  margin-top: 10px;
  color: var(--danger);
  font-size: 14px;
  min-height: 20px;
}

/* ============================================================
   Toast
   ============================================================ */
.toast-host {
  position: fixed;
  top: 70px; left: 0; right: 0;
  z-index: 999;
  /* Centre children horizontally with flex instead of transform — a
     non-none transform on this element would turn it into a containing
     block for its position:fixed descendants, breaking the bottom-bar
     update toast (which wants to be viewport-relative). */
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  pointer-events: none;
}
.toast {
  min-width: 260px;
  max-width: 90vw;
  padding: 12px 16px;
  border-radius: var(--radius);
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-2);
  color: var(--text);
  font-size: 14px;
  font-weight: 500;
  display: flex; align-items: center; gap: 10px;
  animation: toastIn .28s ease-out;
  pointer-events: auto;
}
.toast--warn    { border-color: var(--warning); color: var(--warning); }
.toast--error   { border-color: var(--danger);  color: var(--danger); }
.toast--success { border-color: var(--positive);color: var(--positive); }
.toast.is-leaving { animation: toastOut .22s ease-in forwards; }
@keyframes toastIn  { from { opacity: 0; transform: translateY(-10px); } to { opacity: 1; transform: translateY(0); } }
@keyframes toastOut { to   { opacity: 0; transform: translateY(-10px); } }

/* Full-width bottom bar — specifically for the "Updated to v…" toast.
   Uses position: fixed to escape the centered toast-host container so
   it spans the viewport edge-to-edge. env(safe-area-inset-bottom) keeps
   it clear of the iOS home indicator. */
.toast[data-toast-key="app-updated"] {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  width: 100%;
  max-width: none;
  min-width: 0;
  margin: 0;
  padding: 14px 18px;
  padding-bottom: max(14px, env(safe-area-inset-bottom));
  border: 0;
  border-top: 1px solid var(--border);
  border-radius: 0;
  background: var(--bg-elev-2);
  color: var(--text);
  justify-content: flex-start;
  font-weight: 500;
  animation: toastUpIn .3s ease-out;
}
.toast[data-toast-key="app-updated"].is-leaving {
  animation: toastDownOut .22s ease-in forwards;
}
@keyframes toastUpIn    { from { opacity: 0; transform: translateY(100%); } to { opacity: 1; transform: translateY(0); } }
@keyframes toastDownOut { to   { opacity: 0; transform: translateY(100%); } }

/* ============================================================
   Confirm dialog (Swal replacement)
   ============================================================ */
.confirm {
  max-width: 420px;
}
.confirm__body {
  padding: 24px 24px 8px;
  text-align: center;
}
.confirm__icon {
  width: 56px; height: 56px;
  margin: 0 auto 14px;
  display: grid; place-items: center;
  border-radius: 50%;
  background: rgba(232,168,56,.15);
  color: var(--warning);
}
.confirm__icon--danger {
  background: rgba(255,77,77,.15);
  color: var(--danger);
}
.confirm__icon svg { width: 32px; height: 32px; }
.confirm__title { font-size: 18px; margin-bottom: 6px; }
.confirm__title--danger { color: var(--danger); }
.confirm__msg   { color: var(--text-dim); font-size: 14px; }
.confirm__counter { opacity: .7; font-size: .85em; margin-left: 4px; }
.confirm__ok--primed { animation: confirm-prime-pulse .2s ease; }
@keyframes confirm-prime-pulse {
  0%   { transform: scale(1); }
  50%  { transform: scale(1.08); }
  100% { transform: scale(1); }
}
.confirm__foot  {
  display: flex; gap: 10px; justify-content: center;
  padding: 16px 24px 22px;
}

/* ============================================================
   Idle overlay — shown when no game is active
   ============================================================ */
.idle-overlay {
  position: fixed;
  top: 56px; left: 0; right: 0; bottom: 0;
  background: var(--bg);
  display: flex; align-items: center; justify-content: center;
  z-index: 100;
}
.idle-overlay.hidden { display: none; }

.idle-overlay__inner {
  text-align: center;
  padding: 40px 30px;
  display: flex; flex-direction: column; align-items: center; gap: 14px;
}
.idle-overlay__label {
  font-family: var(--font-display);
  font-size: clamp(28px, 6vw, 42px);
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--text);
  margin: 0;
}
.idle-overlay__sub {
  color: var(--text-dim);
  font-size: 15px;
  max-width: 320px;
  line-height: 1.55;
  margin: 0;
}

/* ============================================================
   Helpers
   ============================================================ */
.hidden { display: none !important; }
.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* ============================================================
   Game Picker modal
   ============================================================ */
.modal--wide { max-width: 1100px; }

/* Court selector row */
.picker__court-row {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 18px;
}
.picker__court-label {
  padding: 10px 14px;
  background: var(--bg-elev-3);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: .04em;
  text-transform: uppercase;
  white-space: nowrap;
}
.picker__courts {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  flex: 1;
}
.picker__court-btn {
  padding: 10px 16px;
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-weight: 600;
  font-size: 14px;
  transition: background .12s, border-color .12s, color .12s;
}
.picker__court-btn:hover {
  background: var(--bg-elev-3);
  border-color: var(--text-muted);
}
.picker__court-btn.is-active {
  background: var(--positive);
  border-color: var(--positive);
  color: #fff;
}
.picker__court-btn.is-active:hover {
  background: var(--positive-hi);
  border-color: var(--positive-hi);
}

/* Date selector — Yesterday / Today / Tomorrow segmented control. */
.picker__date-row { margin-bottom: 18px; }
.picker__dates {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  flex: 1;
}
.picker__date-btn {
  padding: 10px 16px;
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-weight: 600;
  font-size: 14px;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  line-height: 1.15;
  min-width: 110px;
  transition: background .12s, border-color .12s, color .12s;
  cursor: pointer;
}
.picker__date-btn .picker__date-label  { font-size: 14px; font-weight: 700; }
.picker__date-btn .picker__date-detail { font-size: 11px; opacity: .75; margin-top: 2px; letter-spacing: .02em; }
.picker__date-btn:hover {
  background: var(--bg-elev-3);
  border-color: var(--text-muted);
}
.picker__date-btn.is-active {
  background: var(--positive);
  border-color: var(--positive);
  color: #fff;
}
.picker__date-btn.is-active .picker__date-detail { opacity: .9; }
.picker__date-btn.is-active:hover {
  background: var(--positive-hi);
  border-color: var(--positive-hi);
}

/* Games grid */
.picker__games {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  /* Hold the modal height stable across court switches — roughly one
     game card's worth of vertical room so the placeholder/empty/error
     states and the loaded cards all occupy the same footprint. */
  min-height: 320px;
  /* Stop layout flicker during the dim-in-place loading phase. */
  transition: opacity .15s linear;
}
.picker__games.is-loading {
  opacity: .45;
  pointer-events: none;
}
.picker__loading,
.picker__empty,
.picker__error {
  grid-column: 1 / -1;
  /* Centre the message vertically within the reserved min-height so
     it doesn't sit at the top of an otherwise empty area. */
  align-self: center;
  text-align: center;
  padding: 40px 20px;
  color: var(--text-dim);
  font-size: 15px;
}
.picker__error .btn { margin-left: 10px; }

.picker__foot-spacer { flex: 1; }

/* Individual game card */
.game-card {
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.game-card__head {
  padding: 12px 14px;
  background: var(--bg-elev-3);
  border-bottom: 1px solid var(--border);
  font-size: 13px;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 10px;
}
.game-card__when {
  font-weight: 700;
  color: var(--text);
}
.game-card__court {
  color: var(--text-dim);
  font-size: 12px;
}
.game-card__body {
  padding: 16px 14px 14px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1;
}
.game-card__team {
  display: flex;
  align-items: baseline;
  gap: 8px;
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 800;
  letter-spacing: .02em;
  line-height: 1.15;
}
.game-card__team-name {
  color: var(--text);
  word-break: break-word;
}
.game-card__pc {
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 700;
  flex: none;
  color: var(--text-muted);
}
.game-card__vs {
  color: var(--text-muted);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
}
.game-card__meta {
  margin-top: 8px;
  padding-top: 10px;
  border-top: 1px solid var(--border);
  color: var(--text-dim);
  font-size: 13px;
}
.game-card__meta strong {
  color: var(--text);
  font-weight: 700;
}
.game-card__actions {
  margin-top: 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.game-card__tmp-btn {
  font-size: 13px;
  padding: 8px 14px;
}
.game-card__roster-btn {
  background: #7d5a00;
  border-color: #a07800;
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background .15s;
}
.game-card__roster-btn:hover { background: #9a6e00; }
.game-card__roster-hint {
  font-size: 11px;
  color: var(--text-dim);
  text-align: center;
  padding: 2px 0 0;
}

/* ============================================================
   Team chooser dialog — "Who bats first?"
   ============================================================ */
.teamchoice__body {
  padding: 28px 24px 20px;
}
.teamchoice__sub {
  text-align: center;
  color: var(--text-dim);
  margin: 0 0 20px;
  font-size: 14px;
  letter-spacing: .04em;
}
.teamchoice__overs {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  margin: 0 0 22px;
}
.teamchoice__overs-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--text-muted);
}
.teamchoice__overs-row {
  display: flex;
  gap: 10px;
}
.teamchoice__over-btn {
  min-width: 66px;
  padding: 12px 18px;
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 800;
  letter-spacing: .04em;
  color: var(--text-dim);
  background: var(--bg-elev-2);
  border: 2px solid var(--border);
  border-radius: var(--radius-lg);
  cursor: pointer;
  transition: background .12s, border-color .12s, color .12s, transform .06s;
}
.teamchoice__over-btn:hover  { border-color: var(--positive); }
.teamchoice__over-btn:active { transform: scale(.97); }
.teamchoice__over-btn.is-active {
  color: #fff;
  background: var(--positive);
  border-color: var(--positive);
}
.teamchoice__overs-rules {
  margin: 8px 0 0;
  text-align: center;
  font-size: 14px;
  line-height: 1.55;
  color: var(--text-dim);
  letter-spacing: .02em;
  max-width: 340px;
}
.teamchoice__buttons {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 14px;
  align-items: stretch;
}
.teamchoice__btn {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 6px;
  padding: 28px 16px;
  background: var(--bg-elev-2);
  border: 2px solid var(--border);
  border-radius: var(--radius-lg);
  color: var(--text);
  text-align: center;
  cursor: pointer;
  transition: background .15s, border-color .15s, transform .08s;
}
.teamchoice__btn:hover {
  background: var(--bg-elev-3);
  border-color: var(--positive);
}
.teamchoice__btn:active { transform: scale(.98); }
.teamchoice__team-label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--text-muted);
}
.teamchoice__team-name {
  display: block;
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 800;
  letter-spacing: .04em;
  word-break: break-word;
}
.teamchoice__vs {
  display: grid;
  place-items: center;
  font-family: var(--font-display);
  color: var(--text-muted);
  font-weight: 700;
  letter-spacing: .1em;
  font-size: 18px;
}

/* ============================================================
   Topbar — game info variant
   ============================================================ */
.topbar__meta--game {
  padding: 6px 16px;
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font-size: 14px;
  max-width: min(720px, 60vw);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.topbar__meta--game strong { color: var(--text); font-weight: 700; }
.topbar__when {
  color: var(--text-muted);
  font-weight: 500;
  margin-left: 4px;
}

/* ============================================================
   Scoreboard — pre-match landing (choose bowler + batsmen)
   ============================================================ */
.scoreboard {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.scoreboard.hidden { display: none; }

/* Row 1 — match state + bowler */
.sb-state {
  display: flex;
  gap: 8px;
  align-items: stretch;
  flex-wrap: wrap;
}
.sb-chip {
  display: grid;
  place-items: center;
  padding: 0 18px;
  min-height: 54px;
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text);
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 16px;
  letter-spacing: .04em;
  white-space: nowrap;
}
.sb-chip strong { font-weight: 800; color: var(--text); }

/* Big yellow "Choose X" selector buttons */
.sb-pick {
  display: grid;
  place-items: center;
  padding: 14px 22px;
  min-height: 54px;
  background: var(--warning);
  color: #1a1400;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 18px;
  letter-spacing: .06em;
  text-transform: uppercase;
  border-radius: var(--radius);
  border: 0;
  cursor: pointer;
  transition: filter .12s, transform .08s;
}
.sb-pick:hover  { filter: brightness(1.06); }
.sb-pick:active { transform: scale(.98); }
.sb-pick--grow  { flex: 1; min-width: 220px; }
.sb-pick.is-chosen {
  background: var(--bg-elev-3);
  color: var(--text);
  border: 1px solid var(--border);
}

/* Row 1 right: bowler slot (flex container holding either Choose
   Bowler OR the green bowler pill + red Over Up button).          */
.sb-state__bowler {
  display: flex;
  gap: 8px;
  align-items: stretch;
  flex: 1;
  min-width: 200px;
}

/* Bowler pill — green with a yellow "runs this over" badge */
.sb-bowler-pill {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: stretch;
  gap: 0;
  padding: 0 0 0 16px;
  background: var(--positive);
  color: #fff;
  border-radius: var(--radius);
  border: 0;
  cursor: pointer;
  min-height: 54px;
  flex: 1;
  overflow: hidden;
  transition: filter .12s;
}
.sb-bowler-pill:hover { filter: brightness(1.06); }
.sb-bowler-pill__name {
  display: grid;
  align-items: center;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 18px;
  letter-spacing: .04em;
  text-align: left;
  padding-right: 12px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sb-bowler-pill__total {
  display: grid;
  place-items: center;
  min-width: 60px;
  padding: 0 16px;
  background: var(--warning);
  color: #1a1400;
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 18px;
}

/* Over Up — red call-to-action to close the current over */
.sb-over-up {
  padding: 0 22px;
  min-height: 54px;
  background: var(--negative);
  color: #fff;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 16px;
  letter-spacing: .06em;
  border-radius: var(--radius);
  border: 0;
  cursor: pointer;
  transition: background .12s, filter .08s;
  white-space: nowrap;
}
.sb-over-up:hover  { background: var(--negative-hi); }
.sb-over-up:active { filter: brightness(.95); }

/* Row 2-4 : play panel
   Chooser mode : 2 cols (timer | stacked Choose Batsman buttons)
   Over mode    : 2 cols × 3 rows  (timer | ball headers
                                    bat1  | bat1 cells
                                    bat2  | bat2 cells)             */
.sb-play {
  display: grid;
  gap: 6px;
  align-items: stretch;
}
.sb-play--chooser {
  grid-template-columns: minmax(200px, auto) 1fr;
}
.sb-play--over {
  grid-template-columns: minmax(180px, 220px) 1fr;
  grid-auto-rows: minmax(44px, auto);
}

/* Chooser mode: stacked batsmen buttons occupy col 2 next to timer */
.sb-batsmen {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* Timer */
.sb-timer {
  display: grid;
  grid-template-columns: auto auto;
  gap: 14px;
  align-items: center;
  justify-content: center;
  padding: 14px 28px;
  background: var(--positive);
  color: #fff;
  font-family: var(--font-mono);
  font-size: clamp(28px, 4vw, 36px);
  font-weight: 700;
  letter-spacing: .04em;
  border-radius: var(--radius);
  border: 0;
  cursor: pointer;
  transition: filter .12s;
}
.sb-timer:hover { filter: brightness(1.06); }
.sb-timer[data-state="paused"]  { background: var(--warning); color: #1a1400; }
.sb-timer[data-state="running"] { background: var(--positive); color: #fff; }
.sb-timer__icon { display: grid; place-items: center; }
.sb-timer__icon svg { width: 26px; height: 26px; }

/* Over-mode ball rows — a sub-grid with one column per visible ball.
   --visible-balls is set inline on .sb-play--over; defaults to 6.    */
.sb-play__balls-row {
  display: grid;
  grid-template-columns: repeat(var(--visible-balls, 6), minmax(36px, 1fr));
  gap: 5px;
  align-items: stretch;
}

/* Ball number headers — small green circles centred in each column */
.sb-play__bhead {
  justify-self: center;
  align-self: center;
  width: 32px;
  height: 32px;
  display: grid;
  place-items: center;
  background: var(--positive);
  color: #fff;
  border-radius: 50%;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 13px;
  letter-spacing: 0;
}

/* Batsman name + over-total pill — same green/yellow look as bowler */
.sb-play__batname {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: stretch;
  gap: 0;
  padding: 0 0 0 16px;
  background: var(--positive);
  color: #fff;
  border-radius: var(--radius);
  cursor: pointer;
  overflow: hidden;
  min-height: 44px;
  transition: filter .12s;
}
.sb-play__batname:hover { filter: brightness(1.06); }
.sb-play__batname-text {
  display: grid;
  align-items: center;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 17px;
  letter-spacing: .04em;
  padding-right: 10px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sb-play__batname-total {
  display: grid;
  place-items: center;
  min-width: 50px;
  padding: 0 14px;
  background: var(--warning);
  color: #1a1400;
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 16px;
}

/* Per-ball cell — white with black text, matches the example design.
   Keeps contrast high against the dark board for quick scanning.     */
.sb-play__cell {
  display: grid;
  place-items: center;
  padding: 6px 4px;
  min-height: 44px;
  background: #ffffff;
  color: #0a0b0d;
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 18px;
  letter-spacing: 0;
}
.sb-play__cell:empty::before { content: ''; }

/* Row 3 — action toolbar */
.sb-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: stretch;
}
.btn--icon {
  width: 42px;
  padding: 10px;
  justify-content: center;
}
.btn--icon svg { width: 18px; height: 18px; }

.sb-wf {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 2px;
}
.sb-wf__label {
  font-weight: 600;
  font-size: 13px;
  color: var(--text-dim);
  margin-right: 4px;
  letter-spacing: .02em;
}
.sb-wf__btn {
  padding: 7px 14px;
  min-width: 44px;
  background: transparent;
  color: var(--text-dim);
  font-weight: 700;
  font-size: 13px;
  text-align: center;
  text-transform: uppercase;
  border-radius: var(--radius-sm);
  transition: background .12s, color .12s;
}
.sb-wf__btn.is-active { color: #fff; }
.sb-wf__btn--on.is-active  { background: var(--positive); }
.sb-wf__btn--off.is-active { background: var(--negative); }

/* Strike toggle — mirrors sb-wktruns */
.sb-strike-toggle {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 2px;
}
.sb-strike__btn {
  padding: 7px 14px;
  min-width: 44px;
  background: transparent;
  color: var(--text-dim);
  font-weight: 700;
  font-size: 13px;
  text-align: center;
  border-radius: var(--radius-sm);
  transition: background .12s, color .12s;
}
.sb-strike__btn.is-active {
  background: var(--accent, #4f6df5);
  color: #fff;
}
.sb-wktruns {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 2px;
}
.sb-wktruns__btn {
  padding: 7px 14px;
  min-width: 44px;
  background: transparent;
  color: var(--text-dim);
  font-weight: 700;
  font-size: 13px;
  text-align: center;
  border-radius: var(--radius-sm);
  transition: background .12s, color .12s;
}
.sb-wktruns__btn.is-active {
  background: var(--negative);
  color: #fff;
}

/* ── Unified toggle button sizing — all settings toggles identical ── */
.sb-wf__btn,
.sb-strike__btn,
.sb-wktruns__btn,
.sb-pp-toggle__btn {
  padding: 8px 0;
  width: 56px;
  min-width: 56px;
  text-align: center;
}
/* Unified toggle group width so rows right-align consistently */
.sb-wf,
.sb-strike-toggle,
.sb-wktruns,
.sb-pp-toggle {
  min-width: 122px;
}

/* Powerplay settings toggle — mirrors sb-wktruns */
.sb-pp-toggle {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 2px;
}
.sb-pp-toggle__btn {
  padding: 7px 14px;
  min-width: 40px;
  background: transparent;
  color: var(--text-dim);
  font-weight: 700;
  font-size: 13px;
  text-align: center;
  border-radius: var(--radius-sm);
  transition: background .12s, color .12s;
  cursor: pointer;
  border: none;
}
.sb-pp-toggle__btn.is-active {
  background: #6fe67a;
  color: #111;
}

.sb-game-type {
  display: grid;
  place-items: center;
  padding: 0 14px;
  background: var(--bg-elev-3);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--warning);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: .04em;
}

/* Row 4 — scoresheet */
.sb-scoresheet {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 4px;
}
.sb-ss {
  background: var(--bg-elev-1);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.sb-ss__header {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 6px 14px;
  background: rgba(74,91,184,0.18);   /* blue tint — stands out from cell rows */
  border-bottom: 1px solid rgba(74,91,184,0.35);
}
.sb-ss__label {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 12px;
  letter-spacing: .04em;
}
.sb-ss__team {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 13px;
  color: var(--text);
}
.sb-ss__total {
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 700;
  padding: 2px 12px;
  background: var(--bg-elev-2);
  color: var(--text-dim);
  border-radius: var(--radius-sm);
  min-width: 44px;
  text-align: center;
  border: 1px solid var(--border);
}
.sb-ss--active .sb-ss__total {
  background: var(--positive);
  color: #fff;
  border-color: var(--positive);
}

.sb-ss__rows {
  overflow-x: auto;          /* horizontal scroll on narrow viewports */
}
.sb-ss__row {
  display: grid;
  /* Base row: 80px label + N over cells. N comes from CSS var
     set inline on .sb-ss by the renderer. */
  grid-template-columns: 80px repeat(var(--ss-overs, 16), minmax(36px, 1fr));
  gap: 3px;
  padding: 3px;
  align-items: stretch;
  background: var(--bg-elev-1);
  min-width: 560px;          /* keeps cells readable, enables scroll on mobile */
}
.sb-ss__row--skins {
  grid-template-columns: 80px repeat(var(--ss-skins, 4), minmax(36px, 1fr));
}
.sb-ss__row-label {
  display: grid;
  place-items: center;
  padding: 8px 10px;
  background: var(--bg-elev-3);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--text);
  border-radius: var(--radius-sm);
}
/* Row-type colour coding — OVERS blue, RUNS green, SKINS amber */
.sb-ss__row--overs  .sb-ss__row-label { background: rgba(74,91,184,0.28);  color: #a0adff; border: 1px solid rgba(74,91,184,0.4); }
.sb-ss__row--runs   .sb-ss__row-label { background: rgba(31,184,107,0.22); color: #6fcf8e; border: 1px solid rgba(31,184,107,0.35); }
.sb-ss__row--skins  .sb-ss__row-label { background: rgba(232,168,56,0.22); color: #f0c060; border: 1px solid rgba(232,168,56,0.35); }
.sb-ss__cell {
  display: grid;
  place-items: center;
  padding: 8px 2px;
  min-height: 36px;
  background: var(--bg-elev-2);   /* was --bg-elev-1: now one step lighter for visible grid */
  border: 1px solid var(--border-soft);
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: 13px;
  color: var(--text);
  border-radius: var(--radius-sm);
}
.sb-ss__cell--over { color: var(--text-dim); font-weight: 500; }
.sb-ss__cell--skin { font-size: 14px; color: var(--text-muted); }
.sb-ss__cell--run.sb-ss__cell--scored  { color: var(--text); font-weight: 700; }
.sb-ss__cell--skin.sb-ss__cell--scored { color: var(--text); font-weight: 800; }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 900px) {
  .picker__games { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 680px) {
  .board { padding: 62px 12px 24px; }
  .topbar__meta { display: none; }
  .field__label { width: 90px; font-size: 12px; padding: 10px 12px; }
  .modal__foot .btn { padding: 10px 14px; }
  .picker__games { grid-template-columns: 1fr; }
  .picker__court-row { gap: 8px; }
  .picker__court-label { padding: 8px 12px; font-size: 12px; }
  .picker__court-btn { padding: 8px 12px; font-size: 13px; }
  .picker__date-btn { padding: 8px 12px; min-width: 92px; }
  .picker__date-btn .picker__date-label  { font-size: 13px; }
  .picker__date-btn .picker__date-detail { font-size: 10px; }
  .teamchoice__buttons { grid-template-columns: 1fr; }
  .teamchoice__vs { padding: 4px 0; }

  /* Scoreboard: stack timer above batsmen / ball grid.              */
  .sb-play--chooser { grid-template-columns: 1fr; }
  .sb-play--over    {
    /* Keep two cols but shrink the name column — cells must stay
       legible. Horizontal scroll is acceptable when force_over_no
       pushes the cell grid wider than viewport.                     */
    grid-template-columns: minmax(120px, 160px) 1fr;
  }
  .sb-pick--grow { flex-basis: 100%; min-width: 0; }
  .sb-state { gap: 6px; }
  .sb-chip { padding: 0 12px; min-height: 46px; font-size: 14px; }
  .sb-pick { font-size: 16px; min-height: 48px; padding: 12px 16px; }
  .sb-timer { padding: 12px 20px; font-size: 30px; }
  .sb-actions { gap: 6px; }
  .sb-wf { padding-left: 8px; }
  .sb-wf__label { font-size: 12px; }
  .sb-bowler-pill__name { font-size: 15px; }
  .sb-bowler-pill__total { min-width: 48px; padding: 0 10px; font-size: 15px; }
  .sb-over-up { padding: 0 14px; font-size: 14px; }
  .sb-play__batname-text { font-size: 14px; padding-right: 6px; }
  .sb-play__batname-total { min-width: 40px; padding: 0 10px; font-size: 14px; }
  .sb-play__cell { font-size: 16px; min-height: 38px; }
  .sb-play__bhead { width: 28px; height: 28px; font-size: 12px; }
  .sb-ss__header { grid-template-columns: auto 1fr auto; }
  .sb-ss__header .sb-ss__team { grid-column: 1 / -1; font-size: 14px; }
}

/* ============================================================
   v2 Scoring UI — Player Cards, Grid, Ball Pad, Chooser
   ============================================================ */

/* ── Layout: board gets bottom padding so fixed pad doesn't
      overlap the scoresheet ── */
.board {
  padding-bottom: 20px;   /* sb-pad height is set dynamically via JS */
}

/* ── Scoreboard shell ── */
.scoreboard { display: flex; flex-direction: column; gap: 0; }
.scoreboard.hidden { display: none; }

/* ============================================================
   PLAYER CARDS
   ============================================================ */
.sb-players {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  padding: 12px 0 8px;
}

.sb-player-card {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  padding: 12px 14px 14px;
  border-radius: var(--radius);
  border: 1.5px solid var(--border);
  background: var(--bg-elev-1);
  text-align: left;
  cursor: pointer;
  transition: border-color .15s, background .15s, transform .08s;
  overflow: hidden;
}
.sb-player-card:active { transform: scale(.97); }

.sb-player-card__role {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--text-muted);
  line-height: 1;
}
.sb-player-card__icon { width: 12px; height: 12px; flex: none; }

.sb-player-card__name {
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
  line-height: 1.2;
  word-break: break-word;
}

/* Empty state — amber prompt */
.sb-player-card.is-empty {
  border-color: rgba(232,168,56,.35);
  background: rgba(232,168,56,.07);
}
.sb-player-card.is-empty .sb-player-card__name {
  color: var(--warning);
  font-weight: 600;
  font-size: 13px;
}
.sb-player-card.is-empty .sb-player-card__role { color: rgba(232,168,56,.6); }

/* Set state */
.sb-player-card--bowler.is-set {
  border-color: rgba(74,91,184,.5);
  background: rgba(74,91,184,.1);
}
.sb-player-card--bowler.is-set .sb-player-card__role { color: var(--accent-hi); }

.sb-player-card--bat.is-set {
  border-color: rgba(31,184,107,.45);
  background: rgba(31,184,107,.08);
}
.sb-player-card--bat.is-set .sb-player-card__role { color: var(--positive); }

/* ============================================================
   MATCH STATE BAR
   ============================================================ */
.sb-matchbar {
  display: flex;
  align-items: center;
  gap: 0;
  background: #252932;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0;
  overflow: hidden;
  margin-bottom: 10px;
}

/* ── Game timer — inline in matchbar ───────────────────────── */
.sb-matchbar__val--timer {
  font-variant-numeric: tabular-nums;
  letter-spacing: .03em;
}
.sb-matchbar__stat.is-paused { opacity: .65; }

/* Pace indicator — border on the timer stat block */
.sb-matchbar__stat.pace-ok {
  background: rgba(39,174,96,.07);
}
.sb-matchbar__stat.pace-ok .sb-matchbar__val--timer { color: #6fcf8e; }

.sb-matchbar__stat.pace-warn {
  background: rgba(211,84,0,.1);
  animation: pace-pulse-warn 2s ease-in-out infinite;
}
.sb-matchbar__stat.pace-warn .sb-matchbar__val--timer { color: #f0a06a; }

.sb-matchbar__stat.pace-behind {
  background: rgba(192,57,43,.15);
  animation: pace-pulse-red 1s ease-in-out infinite;
}
.sb-matchbar__stat.pace-behind .sb-matchbar__val--timer { color: #ff6b6b; }

@keyframes pace-pulse-warn {
  0%,100% { background: rgba(211,84,0,.07); }
  50%     { background: rgba(211,84,0,.18); }
}
@keyframes pace-pulse-red {
  0%,100% { background: rgba(192,57,43,.12); }
  50%     { background: rgba(192,57,43,.26); }
}

.sb-timer__inline-btn {
  background: none;
  border: none;
  color: var(--text-dim);
  font-size: 11px;
  cursor: pointer;
  padding: 2px 4px;
  border-radius: 4px;
  line-height: 1;
  margin-top: 2px;
  transition: color .15s;
}
.sb-timer__inline-btn:hover { color: var(--text); }

.sb-timer__val-row {
  display: flex;
  align-items: center;
  gap: 4px;
}

.sb-matchbar__stat {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 10px 8px;
  gap: 2px;
}
.sb-matchbar__stat--runs { flex: 1.4; }

.sb-matchbar__label {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--text-muted);
}
.sb-matchbar__val {
  font-family: var(--font-mono);
  font-size: 20px;
  font-weight: 700;
  color: var(--text);
  line-height: 1;
}
.sb-matchbar__val--big { font-size: 26px; }
.sb-matchbar__sub {
  font-size: 11px;
  color: var(--text-dim);
  font-family: var(--font-mono);
}
.sb-matchbar__div {
  width: 1px;
  align-self: stretch;
  background: var(--border);
}
#sb-legal-balls.is-full { color: var(--positive); }

.sb-matchbar__stat--tv {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text-dim);
  transition: background .15s, color .15s;
}
.sb-matchbar__stat--tv:hover {
  background: rgba(79,109,245,.12);
  color: var(--accent-hi);
}
.sb-matchbar__stat--tv svg { display: block; }

/* Powerplay buttons */
.sb-pp-area { flex-direction: column; gap: 3px; padding: 0 4px; }
.sb-pp-btns { display: flex; gap: 5px; }
.sb-pp-btn {
  padding: 5px 9px;
  border-radius: var(--radius-sm);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .04em;
  cursor: pointer;
  border: 1.5px solid transparent;
  transition: background .12s, border-color .12s, color .12s;
  white-space: nowrap;
}
.sb-pp-btn--bat  { background: rgba(99,230,118,.1); color:#6fe67a; border-color:rgba(99,230,118,.3); }
.sb-pp-btn--bowl { background: rgba(79,109,245,.1); color:#818cf8; border-color:rgba(79,109,245,.3); }
.sb-pp-btn--active.sb-pp-btn--bat  { background: #6fe67a; color:#111; border-color:#6fe67a; }
.sb-pp-btn--active.sb-pp-btn--bowl { background: #818cf8; color:#111; border-color:#818cf8; }
.sb-pp-btn--exhausted { opacity:.35; cursor:not-allowed; }
.sb-pp-btn:disabled   { cursor:not-allowed; }

/* ============================================================
   SCORING GRID
   ============================================================ */
.sb-grid {
  background: var(--bg-elev-1);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 10px 12px;
  margin-bottom: 10px;
  overflow-x: auto;
}

.sb-grid__empty {
  text-align: center;
  color: var(--text-muted);
  font-size: 13px;
  padding: 20px 0;
  margin: 0;
}

/* Header + rows use CSS grid with dynamic --cols */
.sb-grid__header,
.sb-grid__row {
  display: grid;
  grid-template-columns: minmax(200px, 260px) repeat(calc(var(--cols, 8) - 2), 44px) 70px;
  gap: 3px;
  width: fit-content;
}

.sb-grid__header { margin-bottom: 4px; }

/* Shared style for all three player buttons */
.sb-grid__bowler-cell,
.sb-grid__name-cell {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 8px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  background: var(--bg-elev-3);
  border: 1px solid var(--border);
  color: var(--text-dim);
  font-family: inherit;
  font-size: 12px;
  font-weight: 700;
  text-align: left;
  height: 36px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  text-transform: capitalize;
  transition: background .12s, border-color .12s;
  letter-spacing: .01em;
}

/* Batsman — soft green accent */
.sb-grid__name-cell {
  background: rgba(39, 174, 96, 0.12);
  border-color: rgba(39, 174, 96, 0.4);
  color: #6fcf8e;
}
.sb-grid__name-cell:hover:not([disabled]) {
  background: rgba(39, 174, 96, 0.25);
  border-color: #27ae60;
  color: #fff;
}
.is-facing.sb-grid__name-cell {
  border-color: #27ae60;
  background: rgba(39, 174, 96, 0.22);
  color: var(--text);
}

.player-dropdown.is-batsman {
  border-color: rgba(39, 174, 96, 0.6);
  box-shadow: 0 8px 32px rgba(0,0,0,.45), 0 0 0 1px rgba(39,174,96,.25);
}
.player-dropdown.is-batsman .player-dropdown__header {
  background: rgba(39, 174, 96, 0.12);
  border-bottom-color: rgba(39, 174, 96, 0.35);
}
.player-dropdown.is-batsman .player-dropdown__title { color: #6fcf8e; }
.sb-grid__bowler-cell {
  background: rgba(211, 84, 0, 0.18);
  border-color: rgba(211, 84, 0, 0.5);
  color: #f0a06a;
}
.sb-grid__bowler-cell:hover:not([disabled]) {
  background: rgba(211, 84, 0, 0.3);
  border-color: #d35400;
  color: #fff;
}
.sb-grid__bowler-cell:hover:not([disabled]),
.sb-grid__name-cell:hover:not([disabled]) { background: var(--bg-elev-2); border-color: var(--accent); color: var(--text); }
.sb-grid__bowler-cell:focus,
.sb-grid__name-cell:focus { outline: none; }
.sb-grid__bowler-cell.is-locked,
.sb-grid__name-cell.is-locked { opacity: 0.55; cursor: not-allowed; }
.is-facing.sb-grid__name-cell { border-color: var(--positive); color: var(--text); }

.sb-grid__player-icon {
  font-size: 14px;
  flex-shrink: 0;
  line-height: 1;
}

.sb-grid__facing-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: transparent;
  flex: none;
  transition: background .2s;
}
.is-facing .sb-grid__facing-dot,
.is-facing-row .sb-grid__facing-dot { background: var(--positive); }

.sb-grid__name-text {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-dim);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  text-transform: capitalize;
}
.is-facing .sb-grid__name-text,
.is-facing-row .sb-grid__name-text { color: var(--text); }

.sb-grid__head {
  display: grid;
  place-items: center;
  height: 26px;
  font-size: 11px;
  font-weight: 600;
  color: var(--text-muted);
  letter-spacing: .04em;
}

.sb-grid__total-head {
  display: grid;
  place-items: center;
  height: 26px;
  font-size: 10px;
  font-weight: 700;
  color: var(--text-muted);
  letter-spacing: .06em;
  text-transform: uppercase;
}

.sb-grid__cell {
  display: grid;
  place-items: center;
  height: 36px;
  min-width: 36px;
  border-radius: 6px;
  font-family: var(--font-mono);
  font-size: 15px;
  font-weight: 700;
  background: #ffffff;
  border: 1px solid #d0d5dd;
  color: #1a1a2e;
  transition: background .1s, border-color .1s;
}

/* Active bat highlight row */
.is-facing-row .sb-grid__cell {
  border-color: rgba(31,184,107,.35);
}

/* Current ball cursor */
.sb-grid__cell.is-current {
  border-color: var(--accent);
}
.sb-grid__cell:focus { outline: none; }
.sb-grid__cell:focus-visible { outline: none; }
.sb-grid__cell.is-dimmed,
.sb-grid__head.is-dimmed {
  opacity: 0.35;
  cursor: not-allowed;
  pointer-events: none;
}

.sb-grid__cursor {
  display: inline-block;
  width: 2px; height: 18px;
  background: var(--accent-hi);
  border-radius: 2px;
  animation: blink .9s step-end infinite;
}
@keyframes blink { 50% { opacity: 0; } }

/* Ball value colour coding */
.sb-grid__cell.is-four   { background: #ffffff; color: #1a7a4a; border-color: rgba(31,184,107,.5); font-weight: 800; }
.sb-grid__cell.is-six    { background: #ffffff; color: #0d6e38; border-color: var(--positive); font-size: 17px; font-weight: 900; }
.sb-grid__cell.is-wicket { background: #ffffff; color: #c0392b; border-color: rgba(226,78,78,.6); font-weight: 800; }
.sb-grid__cell.is-extra  { background: #ffffff; color: #b87a00; border-color: rgba(232,168,56,.5); font-size: 11px; font-weight: 800; }

.sb-grid__total {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 15px;
  font-weight: 800;
  color: var(--text);
  padding: 0 4px;
  line-height: 1.1;
}
.sb-grid__total-innings {
  font-size: 10px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: .02em;
}

/* Edit mode stripe inside grid */
.sb-grid__edit-stripe {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  background: #1a3a5c;
  border: 1px solid #2e6da4;
  border-radius: 6px;
  color: #7ec8f0;
  font-size: 13px;
  font-weight: 600;
  padding: 8px 10px 8px 14px;
  margin-bottom: 6px;
}
.sb-grid__edit-exit {
  background: #2e6da4;
  color: #fff;
  border: none;
  border-radius: 6px;
  padding: 6px 14px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  transition: background .15s;
}
.sb-grid__edit-exit:hover { background: #3a84c4; }

.sb-grid__row { margin-bottom: 3px; }

/* Banner row — Over Up and/or Extra Ball buttons below the scoring rows */
.sb-grid__banner-row {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  padding: 8px 4px 2px;
}

.sb-grid__over-up-btn {
  background: var(--green, #27ae60);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 10px 24px;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: .04em;
  cursor: pointer;
  transition: opacity .15s, transform .1s;
}
.sb-grid__over-up-btn:active {
  opacity: .8;
  transform: scale(.97);
}

.sb-grid__extra-ball-btn {
  background: var(--amber, #e67e22);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 10px 20px;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: .04em;
  cursor: pointer;
  transition: opacity .15s, transform .1s;
}
.sb-grid__extra-ball-btn:active {
  opacity: .8;
  transform: scale(.97);
}

.sb-grid__strike-banner {
  background: #c0392b;
  color: #fff;
  border-radius: 8px;
  padding: 10px 18px;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: .03em;
  flex: 1;
  user-select: none;
}

/* ============================================================
   EDIT MODE BANNER
   ============================================================ */
.sb-edit-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  background: #1a3a5c;
  border: 1px solid #2e6da4;
  border-radius: var(--radius);
  padding: 10px 16px;
  margin-bottom: 4px;
}
.sb-edit-banner__text {
  font-size: 14px;
  font-weight: 700;
  color: #7ec8f0;
  letter-spacing: .02em;
}
.sb-edit-banner__exit {
  background: #2e6da4;
  color: #fff;
  border: none;
  border-radius: 6px;
  padding: 8px 18px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  transition: background .15s;
}
.sb-edit-banner__exit:hover { background: #3a84c4; }

/* Edit button on over cells (moved from runs row) */
.sb-ss__edit-btn {
  position: absolute;
  top: 1px;
  right: 1px;
  width: 16px;
  height: 16px;
  padding: 0;
  border: none;
  border-radius: 3px;
  background: rgba(46,109,164,.6);
  color: #fff;
  font-size: 10px;
  line-height: 16px;
  text-align: center;
  cursor: pointer;
  transition: background .15s;
}
.sb-ss__edit-btn:hover { background: rgba(46,109,164,1); }

/* Completed skin — green tint on the over number cells */
.sb-ss__cell--over.skin-done {
  background: rgba(39,174,96,.15);
  color: #6fcf8e;
  border-color: rgba(39,174,96,.3);
}

/* Highlight cell being edited */
.sb-ss__cell.is-editing {
  outline: 2px solid #2e6da4;
  outline-offset: -2px;
  border-radius: 3px;
}

/* ============================================================
   INLINE FIELDER PANEL
   ============================================================ */
.sb-fielder-panel {
  margin: 4px 0 0;
  opacity: 0;
  transform: translateY(-6px);
  transition: opacity .35s ease, transform .35s ease;
  pointer-events: none;
}
.sb-fielder-panel.is-visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.sb-fielder-panel.is-hiding {
  opacity: 0;
  transform: translateY(-6px);
  pointer-events: none;
}

.sb-fielder-panel__inner {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 10px 14px;
}

.sb-fielder-panel__label {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-dim);
  white-space: nowrap;
  text-transform: uppercase;
  letter-spacing: .05em;
}

.sb-fielder-panel__list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  flex: 1;
}

.sb-fielder-panel__player {
  background: var(--bg-elev-3);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 5px 12px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s, border-color .15s;
}
.sb-fielder-panel__player:hover,
.sb-fielder-panel__player:focus {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.sb-fielder-panel__dismiss {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text-dim);
  border-radius: 6px;
  padding: 5px 10px;
  font-size: 12px;
  cursor: pointer;
  white-space: nowrap;
  transition: color .15s, border-color .15s;
}
.sb-fielder-panel__dismiss:hover { color: var(--text); border-color: var(--text-dim); }

/* ============================================================
   BALL INPUT PAD (fixed at bottom)
   ============================================================ */
.sb-pad {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 90;
  background: var(--bg-elev-1);
  border-top: 1px solid var(--border);
  padding: 8px 12px 18px;
  display: flex;
  flex-direction: column;
  gap: 7px;
}

/* Bowler pill inside the pad */
.sb-bowler-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 5px 12px;
  border-radius: 99px;
  font-size: 13px;
  font-weight: 700;
  background: rgba(74,91,184,.2);
  border: 1px solid rgba(74,91,184,.4);
  color: var(--text);
  cursor: pointer;
  transition: background .12s;
  align-self: flex-start;
}
.sb-bowler-pill.is-empty {
  background: rgba(232,168,56,.1);
  border-color: rgba(232,168,56,.3);
  color: var(--warning);
}
.sb-bowler-pill__name { font-weight: 600; }
.sb-bowler-pill__runs {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 800;
  background: rgba(74,91,184,.3);
  padding: 1px 8px;
  border-radius: 99px;
}

/* Pad status label */
.sb-pad__label {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-dim);
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 20px;
}
.sb-pad__hint { color: var(--text-muted); font-size: 12px; }
.sb-pad__hint--done strong { color: var(--negative-hi); }
.sb-pad__facing { color: var(--text); font-weight: 700; }
.sb-pad__ball-no {
  background: var(--bg-elev-3);
  padding: 2px 8px;
  border-radius: 99px;
  font-size: 12px;
  font-family: var(--font-mono);
  font-weight: 600;
}
.sb-pad__legal { color: var(--text-muted); font-size: 12px; margin-left: auto; }

/* Button rows */
.sb-pad__row {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 5px;
}

.sb-pad__btn {
  height: 48px;
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  font-size: 18px;
  font-weight: 800;
  background: var(--bg-elev-3);
  border: 1px solid var(--border);
  color: var(--text);
  cursor: pointer;
  transition: background .1s, transform .07s, opacity .15s, border-color .1s;
  display: grid;
  place-items: center;
  padding: 0;
}
.sb-pad__btn:hover:not(:disabled) { background: var(--bg-elev-2); border-color: var(--text-muted); }
.sb-pad__btn:active:not(:disabled) { transform: scale(.93); }
.sb-pad__btn:disabled { opacity: .25; cursor: not-allowed; }

/* Four: green */
.sb-pad__btn--four {
  background: rgba(31,184,107,.18);
  border-color: rgba(31,184,107,.4);
  color: var(--positive-hi);
}
.sb-pad__btn--four:hover:not(:disabled) { background: rgba(31,184,107,.28); }

/* Six: bright green */
.sb-pad__btn--six {
  background: rgba(31,184,107,.3);
  border-color: var(--positive);
  color: #fff;
  font-size: 20px;
}
.sb-pad__btn--six:hover:not(:disabled) { background: rgba(31,184,107,.45); }

/* Wicket: red */
.sb-pad__btn--wicket {
  background: rgba(226,78,78,.2);
  border-color: rgba(226,78,78,.5);
  color: var(--negative-hi);
  font-size: 16px;
}
.sb-pad__btn--wicket:hover:not(:disabled) { background: rgba(226,78,78,.32); }

/* Extras: amber */
.sb-pad__btn--extra {
  background: rgba(232,168,56,.12);
  border-color: rgba(232,168,56,.35);
  color: var(--warning);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .03em;
}
.sb-pad__btn--extra:hover:not(:disabled) { background: rgba(232,168,56,.22); }

/* Delete */
.sb-pad__btn--del {
  background: var(--bg-elev-2);
  border-color: var(--border);
  color: var(--text-dim);
  font-size: 20px;
  font-family: var(--font-ui);
}
.sb-pad__btn--del:hover:not(:disabled) { background: rgba(226,78,78,.15); color: var(--negative-hi); }

.sb-pad__spacer { /* fills 7th slot in extras row */ }

/* Action row */
.sb-pad__action-row {
  display: flex;
  gap: 8px;
}

.sb-pad__swap {
  flex: 1;
  font-size: 13px;
  font-weight: 600;
  background: var(--bg-elev-2);
  border-color: var(--border);
  color: var(--text-dim);
  height: 40px;
  padding: 0 12px;
}
.sb-pad__swap:hover { color: var(--text); background: var(--bg-elev-3); }

.sb-pad__overup {
  flex: 1.8;
  height: 40px;
  font-weight: 700;
  font-size: 14px;
  background: var(--bg-elev-2);
  border-color: var(--border);
  color: var(--text-dim);
  transition: background .15s, border-color .15s, color .15s, transform .07s;
}
.sb-pad__overup.is-ready {
  background: var(--negative);
  border-color: var(--negative);
  color: #fff;
  animation: pulse-overup 1.4s ease-in-out infinite;
}
@keyframes pulse-overup {
  0%, 100% { box-shadow: 0 0 0 0 rgba(226,78,78,.5); }
  50%       { box-shadow: 0 0 0 8px rgba(226,78,78,0); }
}
.sb-pad__overup:disabled { opacity: .25; }

/* ============================================================
   PLAYER CHOOSER DIALOG
   ============================================================ */
.modal--chooser {
  width: min(440px, 96vw);
  max-height: 80vh;
  display: flex;
  flex-direction: column;
}

.chooser__body {
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-height: 0;
  flex: 1;
  overflow: hidden;
  padding-top: 4px;
}

.chooser__search { flex: none; }

.chooser-input {
  width: 100%;
  padding: 10px 14px;
  background: var(--bg-elev-3);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-size: 15px;
  font-family: var(--font-ui);
  outline: none;
  transition: border-color .15s;
}
.chooser-input:focus { border-color: var(--accent-hi); }
.chooser-input::placeholder { color: var(--text-muted); }

.chooser__list {
  flex: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-right: 2px;
}

.chooser-loading {
  color: var(--text-muted);
  font-size: 14px;
  text-align: center;
  padding: 24px 0;
}

/* ============================================================
   INLINE PLAYER DROPDOWN
   ============================================================ */
.player-dropdown {
  position: fixed;
  z-index: 500;
  width: 320px;
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: 0 8px 32px rgba(0,0,0,.45);
  overflow: hidden;
  opacity: 0;
  transform: translateY(-6px) scale(.98);
  pointer-events: none;
  transition: opacity .2s ease, transform .2s ease;
  /* Flex column so the list grows into available space and scrolls
     correctly on small viewports / high zoom — never clipped without a scrollbar */
  display: flex;
  flex-direction: column;
}
.player-dropdown.is-open {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}
.player-dropdown.is-bowler {
  border-color: rgba(211, 84, 0, 0.6);
  box-shadow: 0 8px 32px rgba(0,0,0,.45), 0 0 0 1px rgba(211,84,0,.3);
}

.player-dropdown__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 12px 6px;
  border-bottom: 1px solid var(--border);
  background: var(--bg-elev-2);
  flex-shrink: 0;
}
.player-dropdown.is-bowler .player-dropdown__header {
  background: rgba(211, 84, 0, 0.18);
  border-bottom-color: rgba(211, 84, 0, 0.4);
}
.player-dropdown__title {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--text-dim);
}
.player-dropdown.is-bowler .player-dropdown__title { color: #f0a06a; }
.player-dropdown__close {
  background: none;
  border: none;
  color: var(--text-dim);
  font-size: 14px;
  cursor: pointer;
  padding: 2px 4px;
  border-radius: 4px;
  transition: color .15s;
}
.player-dropdown__close:hover { color: var(--text); }

.player-dropdown__filter {
  width: 100%;
  box-sizing: border-box;
  background: var(--bg-elev-1);
  border: none;
  border-bottom: 1px solid var(--border);
  color: var(--text);
  font-size: 13px;
  padding: 8px 12px;
  outline: none;
  flex-shrink: 0;
}
.player-dropdown__filter::placeholder { color: var(--text-dim); }

.player-dropdown__list {
  /* flex: 1 + min-height: 0 lets this grow into whatever space the
     wrapper has left after the header/filter, and activates overflow-y
     based on the real available height — not a hardcoded 420px cap that
     the parent can silently clip without showing a scrollbar */
  flex: 1;
  min-height: 100px;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding: 4px;
}

.player-dropdown__loading {
  padding: 14px 12px;
  font-size: 13px;
  color: var(--text-dim);
  text-align: center;
}

/* ── Chooser item: locked / excluded / badge states ── */
.chooser-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 12px 14px;
  border-radius: var(--radius-sm);
  background: var(--bg-elev-2);
  border: 1px solid transparent;
  cursor: pointer;
  text-align: left;
  transition: background .1s, border-color .1s;
}
.chooser-item:hover { background: var(--bg-elev-3); border-color: var(--border); }
.chooser-item:active { transform: scale(.99); }

.chooser-item__name {
  flex: 1;
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
}
.chooser-item__team {
  font-size: 12px;
  color: var(--text-muted);
  font-weight: 500;
}

.chooser-fallback__msg {
  color: var(--text-dim);
  font-size: 13px;
  text-align: center;
  margin: 0 0 12px;
}
.chooser-fallback__row {
  display: flex;
  gap: 8px;
}
.chooser-fallback__row .chooser-input { flex: 1; }

/* ============================================================
   Responsive tweaks for small screens
   ============================================================ */
@media (max-width: 480px) {
  .sb-players { gap: 6px; }
  .sb-player-card { padding: 10px 10px 12px; }
  .sb-player-card__name { font-size: 12px; }
  .sb-player-card__role { font-size: 10px; }

  .sb-matchbar__val { font-size: 17px; }
  .sb-matchbar__val--big { font-size: 22px; }

  .sb-pad__btn { height: 44px; font-size: 16px; }
  .sb-pad__btn--six { font-size: 18px; }
  .sb-pad__btn--extra { font-size: 11px; }

  .sb-grid__cell { height: 34px; min-width: 32px; font-size: 14px; }
  .sb-grid__name-text { font-size: 12px; max-width: 200px; }
}

/* Confirmed players section — appears above the toggle bar */
.player-dropdown__confirmed {
  flex-shrink: 0;
  border-bottom: 1px solid var(--border);
  padding: 6px 0 4px;
}
.pd-confirmed__header {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--positive, #27ae60);
  padding: 2px 12px 4px;
}
.pd-confirmed__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  width: 100%;
  font-size: 13px;
  color: var(--text);
  padding: 6px 12px;
  font-weight: 500;
  background: none;
  border: none;
  text-align: left;
  cursor: pointer;
  transition: background .12s;
}
.pd-confirmed__item:hover { background: var(--bg-elev-3); }

.pd-confirmed__item--on-pitch,
.pd-confirmed__item--locked {
  opacity: .45;
  cursor: not-allowed;
  pointer-events: none;
}

/* Roster mode source toggle (Team / Arena) */
.player-dropdown__roster-toggle {
  flex-shrink: 0;
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--border);
}
.roster-toggle__btn {
  flex: 1;
  background: var(--bg-elev-2);
  color: var(--text-dim);
  border: none;
  border-right: 1px solid var(--border);
  padding: 9px 0;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: background .15s, color .15s;
}
.roster-toggle__btn:last-child { border-right: none; }
.roster-toggle__btn.is-active {
  background: var(--accent, #4f6df5);
  color: #fff;
}
.roster-toggle__btn:not(.is-active):hover {
  background: var(--bg-elev-3);
  color: var(--text);
}
.roster-toggle__btn--tmp { color: #f0b429; }
.roster-toggle__btn--tmp.is-active { background: #7d5a00; color: #fff; }

.chooser-fallback__note {
  font-size: 11px;
  color: #f0b429;
  padding: 6px 12px 4px;
  margin: 0;
}

.chooser-section-head {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--text-dim);
  padding: 8px 12px 4px;
  pointer-events: none;
}

.chooser-item__badge--confirmed {
  background: var(--positive, #27ae60);
  color: #fff;
  font-weight: 800;
}

.chooser-item.is-other-team {
  opacity: .4;
  cursor: not-allowed;
  pointer-events: none;
}

.chooser-item__badge--other {
  background: var(--bg-elev-3);
  color: var(--text-dim);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .03em;
}

.chooser-item.is-confirmed {
  background: rgba(39,174,96,.08);
  border-color: rgba(39,174,96,.25);
}

/* Tmp player nudge panel */
.player-dropdown__tmp-nudge {
  flex-shrink: 0;
  background: #2a1f00;
  border-bottom: 1px solid #6b4e00;
  padding: 8px 12px 10px;
}
.tmp-nudge__msg {
  font-size: 12px;
  font-weight: 600;
  color: #f0b429;
  margin-bottom: 7px;
}
.tmp-nudge__actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.tmp-nudge__btn {
  flex: 1;
  background: var(--bg-elev-3);
  color: var(--text);
  border: 1px solid #6b4e00;
  border-radius: 6px;
  padding: 5px 8px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s;
  white-space: nowrap;
}
.tmp-nudge__btn:hover { background: #3a2a00; color: #f0b429; }
.tmp-nudge__btn--rename { flex: none; }

.chooser-item__badge--tmp {
  background: #6b4e00;
  color: #f0b429;
  font-weight: 800;
  font-size: 10px;
  letter-spacing: .04em;
}

.sb-grid__tmp-warn {
  font-size: 11px;
  color: #f0b429;
  margin-left: 4px;
  vertical-align: middle;
}

.sb-grid__lock-icon {
  font-size: 11px;
  margin-left: auto;
  opacity: .55;
  flex-shrink: 0;
}

/* ── Chooser item: locked / excluded / badge states ── */

.chooser-item__team {
  font-size: 10px;
  font-weight: 400;
  color: var(--text-dim);
  margin-left: 2px;
  letter-spacing: .01em;
}
  opacity: .65;
}
.chooser-item.is-locked .chooser-item__name {
  color: var(--text-dim);
}
.chooser-item.is-locked:hover {
  background: rgba(232,168,56,.1);
  border-color: rgba(232,168,56,.3);
}

/* Squad-full (overLimit) players — greyed out, sunk to bottom of list */
.chooser-item[data-over-limit="1"] {
  opacity: 0.4;
  cursor: not-allowed;
}
.chooser-item[data-over-limit="1"]:hover {
  background: var(--bg-elev-1);
  border-color: transparent;
  transform: none;
}

/* Section divider for the "not in squad" group */
.chooser-section-head--dim {
  opacity: 0.5;
  font-style: italic;
}

.chooser-item.is-excluded {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 14px;
  border-radius: var(--radius-sm);
  background: var(--bg-elev-1);
  border: 1px solid transparent;
  cursor: not-allowed;
  opacity: .45;
  pointer-events: none;
}

.chooser-item__badge {
  flex: none;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  padding: 2px 7px;
  border-radius: 99px;
  background: var(--bg-elev-3);
  color: var(--text-muted);
  border: 1px solid var(--border);
}
.chooser-item__badge--locked {
  background: rgba(232,168,56,.15);
  border-color: rgba(232,168,56,.35);
  color: var(--warning);
}
.chooser-item__badge--bowl {
  background: rgba(232,168,56,.15);
  border-color: rgba(232,168,56,.35);
  color: var(--warning);
}
.chooser-item__badge--bat {
  background: rgba(31,184,107,.12);
  border-color: rgba(31,184,107,.3);
  color: var(--positive);
}
.chooser-item__badge--right {
  margin-left: auto;
}
.chooser-item__badge--pitch {
  background: rgba(31,184,107,.12);
  border-color: rgba(31,184,107,.3);
  color: var(--positive);
}

/* ============================================================
   SCORE PICKER POPUP  (sp-*)
   ============================================================ */

/* Backdrop */
.sp-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 200;
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
}
.sp-backdrop.is-open { display: block; }

/* Panel */
.sp-panel {
  display: none;
  position: fixed;
  z-index: 201;
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: 0 20px 60px rgba(0,0,0,.7), 0 0 0 1px rgba(255,255,255,.04) inset;
  overflow: hidden;
  width: min(680px, calc(100vw - 16px));
  /* left / top set by JS */
}
.sp-panel.is-open { display: flex; flex-direction: column; }

/* Quickpick panel — standalone, floats ABOVE the ball row */
.sp-qp-panel {
  display: none;
  position: fixed;
  z-index: 201;
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: 0 8px 32px rgba(0,0,0,.55), 0 0 0 1px rgba(255,255,255,.04) inset;
  align-items: center;
  gap: 10px;
  padding: 9px 14px;
  /* left / top set by JS */
}
.sp-qp-panel.is-open { display: flex; }
.sp-quick-heading {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--text-muted);
  white-space: nowrap;
  padding-right: 10px;
  border-right: 1px solid var(--border);
  flex-shrink: 0;
}
.sp-quick-items {
  display: flex;
  flex-direction: row;
  gap: 6px;
  flex: 1;
}

/* Main scoring area */
.sp-main-col {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 14px;
  min-width: 0;
}

/* Header row */
.sp-header-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.sp-header-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-dim);
  letter-spacing: .04em;
}
.sp-cancel-btn {
  display: grid;
  place-items: center;
  width: 28px; height: 28px;
  border-radius: var(--radius-sm);
  background: var(--bg-elev-3);
  border: 1px solid var(--border);
  color: var(--text-dim);
  font-size: 14px;
  cursor: pointer;
  transition: background .12s, color .12s;
}
.sp-cancel-btn:hover { background: rgba(226,78,78,.2); color: var(--negative-hi); }

/* Sub-options area */
.sp-subs {
  display: flex;
  flex-wrap: wrap;
  align-content: flex-start;
  gap: 8px;
  padding: 12px;
  background: var(--bg-elev-1);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius);
  min-height: 116px;
  height: auto;
  overflow: hidden;
  animation: sp-subs-in .12s ease;
}

.sp-cat:focus-visible,
.sp-sub:focus-visible,
.sp-cancel-btn:focus-visible { outline: none; }

@keyframes sp-subs-in {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: none; }
}

/* Sub buttons */
.sp-sub {
  padding: 10px 16px;
  border-radius: var(--radius-sm);
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  transition: transform .07s, filter .1s;
  border: 1px solid transparent;
}
.sp-sub:active { transform: scale(.93); }
.sp-sub[data-display="__blank__"] {
  visibility: hidden;
  pointer-events: none;
  cursor: default;
}

/* Colour per category */
.sp-sub--wicket { background: rgba(220,53,69,.25);  border-color: rgba(220,53,69,.5);  color: #ff8080; }
.sp-sub--wicket:hover { background: rgba(220,53,69,.45); }

.sp-sub--wide   { background: rgba(13,110,253,.25); border-color: rgba(13,110,253,.5); color: #7db3ff; }
.sp-sub--wide:hover   { background: rgba(13,110,253,.45); }

.sp-sub--runs   { background: rgba(31,184,107,.2);  border-color: rgba(31,184,107,.4); color: var(--positive-hi); }
.sp-sub--runs:hover   { background: rgba(31,184,107,.38); }
.sp-sub--runs[data-code="clear"] { background: var(--bg-elev-3); color: var(--text-muted); border-color: var(--border); }

.sp-sub--noball { background: rgba(255,193,7,.18);  border-color: rgba(255,193,7,.4);  color: var(--warning); }
.sp-sub--noball:hover { background: rgba(255,193,7,.32); }

.sp-sub--penalty { background: rgba(100,100,100,.2); border-color: rgba(200,200,200,.25); color: var(--text-dim); }
.sp-sub--penalty:hover { background: rgba(100,100,100,.35); color: var(--text); }

/* Category row */
.sp-top-row {
  display: flex;
  align-items: center;
  gap: 6px;
}
.sp-top-row .sp-cats {
  flex: 1;
}

/* Quick picks — horizontal top bar buttons */
.sp-quick {
  flex: 1;
  padding: 9px 4px;
  border-radius: var(--radius-sm);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .03em;
  text-transform: uppercase;
  text-align: center;
  cursor: pointer;
  border: 1.5px solid transparent;
  transition: background .1s, border-color .1s;
  white-space: nowrap;
}
.sp-quick--run   { background: rgba(99,230,118,.12); color: #6fe67a; border-color: rgba(99,230,118,.25); }
.sp-quick--run:hover { background: rgba(99,230,118,.25); }
.sp-quick--wkt   { background: rgba(226,78,78,.12);  color: #e24e4e; border-color: rgba(226,78,78,.25); }
.sp-quick--wkt:hover { background: rgba(226,78,78,.25); }
.sp-quick--wide  { background: rgba(79,109,245,.12); color: #818cf8; border-color: rgba(79,109,245,.25); }
.sp-quick--wide:hover { background: rgba(79,109,245,.25); }
.sp-quick--nb    { background: rgba(245,158,11,.12); color: #fbbf24; border-color: rgba(245,158,11,.25); }
.sp-quick--nb:hover { background: rgba(245,158,11,.25); }
.sp-clear-btn {
  flex-shrink: 0;
  padding: 13px 14px;
  border-radius: var(--radius-sm);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  cursor: pointer;
  border: 1.5px solid var(--border);
  background: var(--bg-elev-3);
  color: var(--text-muted);
  transition: background .1s, color .1s, border-color .1s;
  white-space: nowrap;
}
.sp-clear-btn:hover {
  background: rgba(226,78,78,.15);
  border-color: rgba(226,78,78,.5);
  color: var(--negative-hi);
}
.sp-clear-btn:focus { outline: none; }

.sp-cats {
  display: flex;
  gap: 7px;
}

.sp-cat {
  flex: 1;
  padding: 13px 4px;
  border-radius: var(--radius-sm);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  cursor: pointer;
  border: 1.5px solid transparent;
  transition: background .1s, border-color .1s, transform .07s;
  color: var(--text-dim);
  background: var(--bg-elev-3);
}
.sp-cat:active { transform: scale(.95); }

/* Hover / active states per category */
.sp-cat--wicket:hover, .sp-cat--wicket.is-active {
  background: rgba(220,53,69,.2);
  border-color: rgba(220,53,69,.6);
  color: #ff8080;
}
.sp-cat--wide:hover, .sp-cat--wide.is-active {
  background: rgba(13,110,253,.2);
  border-color: rgba(13,110,253,.6);
  color: #7db3ff;
}
.sp-cat--runs:hover, .sp-cat--runs.is-active {
  background: rgba(31,184,107,.2);
  border-color: rgba(31,184,107,.6);
  color: var(--positive-hi);
}
.sp-cat--noball:hover, .sp-cat--noball.is-active {
  background: rgba(255,193,7,.15);
  border-color: rgba(255,193,7,.5);
  color: var(--warning);
}
.sp-cat--penalty:hover, .sp-cat--penalty.is-active {
  background: rgba(150,150,150,.15);
  border-color: rgba(200,200,200,.4);
  color: var(--text);
}

/* ============================================================
   GRID — updated cell colours for all score types
   ============================================================ */
.sb-grid__cell.is-runs    { background: #ffffff; color: #1a1a2e; }
.sb-grid__cell.is-four    { background: #ffffff; color: #1a7a4a; border-color: rgba(31,184,107,.5); font-weight: 800; }
.sb-grid__cell.is-six     { background: #ffffff; color: #0d6e38; border-color: var(--positive); font-size: 14px; font-weight: 900; }
.sb-grid__cell.is-wicket  { background: #ffffff; color: #c0392b; border-color: rgba(220,53,69,.6); font-size: 12px; font-weight: 800; }
.sb-grid__cell.is-wide    { background: #ffffff; color: #1a5fd4; border-color: rgba(13,110,253,.5); font-size: 11px; font-weight: 800; }
.sb-grid__cell.is-noball  { background: #ffffff; color: #b87a00; border-color: rgba(255,193,7,.6); font-size: 11px; font-weight: 800; }
.sb-grid__cell.is-penalty { background: #ffffff; color: #c0392b; border-color: rgba(200,200,200,.4); font-size: 12px; font-weight: 800; }
.sb-grid__cell.is-extra   { background: #ffffff; color: #b87a00; }

.sb-grid__head.is-extra {
  color: var(--negative);
  font-weight: 800;
  position: relative;
}

/* × remove button on extra ball header cells */
.sb-grid__extra-remove {
  position: absolute;
  top: 2px;
  right: 2px;
  width: 14px;
  height: 14px;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: rgba(180, 30, 30, 0.75);
  color: #fff;
  font-size: 10px;
  line-height: 14px;
  text-align: center;
  cursor: pointer;
  opacity: 0;
  transition: opacity .15s;
  display: flex;
  align-items: center;
  justify-content: center;
}
/* show on hover (desktop) or always when touch (touch devices ignore hover) */
.sb-grid__head.is-extra:hover .sb-grid__extra-remove,
.sb-grid__head.is-extra:focus-within .sb-grid__extra-remove {
  opacity: 1;
}
@media (pointer: coarse) {
  .sb-grid__extra-remove { opacity: 0.7; }
}

.sb-grid__val { pointer-events: none; }

/* ============================================================
   PAD — simplified (no run button rows)
   ============================================================ */
.sb-pad {
  padding: 10px 12px 16px;
}

/* Extra ball button */
.sb-pad__extrab {
  flex: 1.2;
  height: 40px;
  font-size: 13px;
  font-weight: 600;
  background: rgba(220,53,69,.12);
  border-color: rgba(220,53,69,.3);
  color: var(--negative-hi);
}
.sb-pad__extrab:hover { background: rgba(220,53,69,.22); }
.sb-pad__extrab:disabled { opacity: .25; }

@media (max-width: 480px) {
  .sp-cat { font-size: 11px; padding: 8px 2px; }
  .sp-sub { font-size: 14px; padding: 5px 10px; }
  .sp-qp-bar  { padding: 7px 10px; gap: 7px; }
  .sp-main-col { padding: 10px; gap: 8px; }
}

/* ============================================================
   Notes button (topbar)
   ============================================================ */
/* Score sync queue indicator */
.sq-indicator {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
  transition: background .3s;
}
.sq-indicator--ok      { background: #27ae60; }
.sq-indicator--sending { background: #f0b429; animation: sq-pulse .8s ease-in-out infinite; }
.sq-indicator--pending { background: #f0b429; }
.sq-indicator--error   { background: #e74c3c; animation: sq-pulse .5s ease-in-out infinite; }
@keyframes sq-pulse {
  0%,100% { opacity: 1; } 50% { opacity: .3; }
}
  background: rgba(79,109,245,.15);
  border: 1px solid rgba(79,109,245,.4);
  color: #a5b4fc;
  border-radius: 6px;
  padding: 4px 8px;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s;
  white-space: nowrap;
}
.notes-topbar-btn:hover { background: rgba(79,109,245,.28); color: #c7d2fe; }

/* Umpire selector */
.umpire-selector { display: flex; align-items: center; }
.umpire-selector.hidden { display: none; }
.umpire-selector__trigger { max-width: 200px; overflow: hidden; text-overflow: ellipsis; }

/* ============================================================
   Notes modal
   ============================================================ */
.notes-modal {
  position: fixed;
  inset: 0;
  z-index: 900;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 64px;
}
.notes-modal.hidden { display: none; }
.notes-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.6);
}
.notes-modal__panel {
  position: relative;
  z-index: 1;
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: 16px;
  width: 100%;
  max-width: 680px;
  max-height: 85vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.notes-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px 10px;
  border-bottom: 1px solid var(--border);
}
.notes-modal__title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
}
.notes-modal__close {
  background: none;
  border: none;
  color: var(--text-dim);
  font-size: 16px;
  cursor: pointer;
  padding: 2px 6px;
  border-radius: 4px;
}
.notes-modal__close:hover { color: var(--text); }
/* ── Player row layout (note btn + penalty btn side by side) ── */
.notes-players-list { display: flex; flex-direction: column; gap: 6px; margin-bottom: 4px; }
.notes-player-row { display: flex; align-items: center; gap: 6px; }
.notes-player-row .notes-player-btn { flex: 1; text-align: left; }
.notes-penalty-btn {
  background: none;
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--amber, #f59e0b);
  font-size: 15px;
  width: 34px;
  height: 34px;
  cursor: pointer;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.notes-penalty-btn:hover { background: rgba(245,158,11,0.12); }
.notes-penalty-btn.has-penalty { background: rgba(245,158,11,0.18); border-color: var(--amber, #f59e0b); }
.player-penalty-badge {
  display: inline-block;
  background: rgba(244,63,94,0.18);
  color: #f43f5e;
  font-size: 11px;
  font-weight: 700;
  border-radius: 4px;
  padding: 1px 5px;
  margin-left: 4px;
}
/* ── Penalty selector (−1 … −5 buttons) ── */
.penalty-selector {
  display: flex;
  gap: 10px;
  justify-content: center;
  padding: 16px 0 8px;
}
.penalty-btn {
  background: var(--bg-elev-3);
  border: 2px solid var(--border);
  border-radius: 12px;
  color: #f43f5e;
  font-size: 18px;
  font-weight: 700;
  width: 52px;
  height: 52px;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}
.penalty-btn:hover { background: rgba(244,63,94,0.15); border-color: #f43f5e; }
/* ── Penalty note-log items ── */
.note-item--penalty { border-left: 3px solid #f59e0b; }
.note-item__text--penalty { color: #f43f5e; font-weight: 600; }
/* ── Scoresheet penalties row ── */
.sb-ss__row--penalties { opacity: 0.9; }
.sb-ss__penalties-badges {
  grid-column: 2 / -1;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 5px 0;
  align-items: center;
}
.pen-badge {
  display: inline-flex;
  align-items: center;
  gap: 0;
  border-radius: 4px;
  overflow: hidden;
  font-size: 11px;
  font-weight: 600;
  line-height: 1;
  border: 1px solid rgba(244,63,94,.35);
}
.pen-badge__name {
  background: rgba(244,63,94,.12);
  color: #f43f5e;
  padding: 3px 7px;
}
.pen-badge__runs {
  background: #f43f5e;
  color: #fff;
  padding: 3px 6px;
  font-weight: 700;
  letter-spacing: .02em;
}
.pen-badge__meta {
  background: rgba(244,63,94,.08);
  color: var(--text-dim);
  padding: 3px 6px;
  font-weight: 400;
  font-size: 10px;
}
.pen-badge__delete {
  background: transparent;
  border: none;
  color: rgba(244,63,94,.5);
  font-size: 13px;
  line-height: 1;
  padding: 0 6px;
  cursor: pointer;
  font-weight: 700;
  transition: color .15s;
  align-self: stretch;
  display: flex;
  align-items: center;
}
.pen-badge__delete:hover { color: #f43f5e; background: rgba(244,63,94,.12); }

/* -- Game Anomalies Panel -------------------------------- */
.game-anomalies {
  margin: 8px 0 16px;
  border: 1px solid var(--border);
  border-radius: 6px;
  overflow: hidden;
  font-size: 12px;
}
.ga__header {
  background: var(--card-header, #1e2533);
  color: var(--text-dim);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 6px 12px;
  border-bottom: 1px solid var(--border);
}
.ga__body {
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.ga__col {
  display: flex;
  flex-direction: column;
}
.ga__col--left {
  border-right: 1px solid var(--border);
}
.ga__section {
  display: flex;
  align-items: flex-start;
  border-bottom: 1px solid var(--border);
}
.ga__section:last-child { border-bottom: none; }
.ga__section-label {
  flex-shrink: 0;
  width: 100px;
  padding: 8px 10px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  border-right: 1px solid var(--border);
  align-self: stretch;
  display: flex;
  align-items: flex-start;
}
.ga__section-label--penalty { color: #f43f5e; }
.ga__section-label--mankad  { color: #f59e0b; }
.ga__section-label--note    { color: var(--text-dim); }
.ga__section-rows {
  flex: 1;
  display: flex;
  flex-direction: column;
}
.ga__item {
  display: flex;
  align-items: baseline;
  gap: 8px;
  padding: 6px 10px;
  border-bottom: 1px solid rgba(255,255,255,.04);
  flex-wrap: wrap;
}
.ga__item:last-child { border-bottom: none; }
.ga__item-name {
  font-weight: 600;
  color: var(--text);
  min-width: 100px;
  flex-shrink: 0;
}
.ga__item-value {
  font-weight: 700;
  font-size: 13px;
  flex-shrink: 0;
  min-width: 30px;
  text-align: right;
}
.ga__item-value--penalty    { color: #f43f5e; }
.ga__item-value--mankad-out { color: #f43f5e; font-weight: 800; }
.ga__item-value--mankad-nb  { color: #f59e0b; font-weight: 800; }
.ga__item-detail {
  color: var(--text-dim);
  font-size: 11px;
  flex: 1;
  white-space: normal;
  line-height: 1.4;
}
.ga__item-del {
  flex-shrink: 0;
  margin-left: 6px;
  padding: 0 5px;
  height: 18px;
  line-height: 18px;
  font-size: 13px;
  font-weight: 700;
  color: var(--text-dim);
  background: transparent;
  border: none;
  border-radius: 3px;
  cursor: pointer;
  opacity: 0.45;
  transition: opacity .15s, color .15s;
}
.ga__item-del:hover { opacity: 1; color: #f43f5e; }

/* ── Innings Break modal ─────────────────────────────────────────────────── */
dialog#dlg-innings-break::backdrop {
  background: rgba(0,0,0,.75);
}
.innings-break {
  background: #0b1c12;
  border: 1px solid #1f4228;
  border-radius: 14px;
  max-width: 360px;
  width: 100%;
  padding: 0;
  text-align: center;
  overflow: hidden;
}
.innings-break__header {
  background: linear-gradient(160deg, #0e2a1a 0%, #081610 100%);
  padding: 28px 24px 22px;
  border-bottom: 1px solid #1f4228;
}
.innings-break__badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--warning);
  background: rgba(232,168,56,.1);
  border: 1px solid rgba(232,168,56,.28);
  border-radius: 20px;
  padding: 3px 12px;
  margin-bottom: 14px;
}
.innings-break__team {
  display: block;
  font-size: 16px;
  font-weight: 600;
  color: rgba(255,255,255,.8);
  margin-bottom: 6px;
}
.innings-break__runs {
  display: block;
  font-size: 64px;
  font-weight: 800;
  line-height: 1;
  color: var(--warning);
  letter-spacing: -.02em;
}
.innings-break__runs-label {
  display: block;
  font-size: 12px;
  color: rgba(255,255,255,.35);
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-top: 4px;
}
.innings-break__body {
  padding: 22px 24px 10px;
}
.innings-break__next {
  font-size: 13px;
  color: rgba(255,255,255,.5);
  margin: 0 0 18px;
}
.innings-break__timer-wrap {
  display: flex;
  justify-content: center;
  margin-bottom: 10px;
}
.innings-break__ring {
  width: 118px;
  height: 118px;
}
.innings-break__ring-bg {
  fill: none;
  stroke: rgba(255,255,255,.07);
  stroke-width: 7;
}
.innings-break__ring-fill {
  fill: none;
  stroke: var(--warning);
  stroke-width: 7;
  stroke-linecap: round;
  stroke-dasharray: 314.16;
  stroke-dashoffset: 0;
  transform: rotate(-90deg);
  transform-origin: center;
  transition: stroke-dashoffset .95s linear, stroke .4s;
}
.innings-break__ring-fill.is-done { stroke: var(--positive); }
.innings-break__ring-num {
  font-size: 30px;
  font-weight: 700;
  fill: #fff;
  text-anchor: middle;
  dominant-baseline: middle;
}
.innings-break__skip {
  background: none;
  border: none;
  color: rgba(255,255,255,.3);
  font-size: 11px;
  cursor: pointer;
  padding: 6px 10px;
  text-decoration: underline;
  text-underline-offset: 3px;
  letter-spacing: .03em;
  margin-bottom: 4px;
}
.innings-break__skip:hover { color: rgba(255,255,255,.65); }
.innings-break__foot {
  display: flex;
  gap: 10px;
  padding: 14px 20px 18px;
  border-top: 1px solid #1a3322;
  background: #080f0a;
}
.innings-break__foot .btn { flex: 1; }
.innings-break__start-btn:disabled {
  opacity: .35;
  cursor: not-allowed;
  pointer-events: none;
}


.notes-modal__body {
  padding: 12px 16px;
  overflow-y: auto;
  flex: 1;
}
.notes-team-section { margin-bottom: 16px; }
.notes-team-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--text-dim);
  margin-bottom: 8px;
}
.notes-players {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.notes-player-btn {
  background: var(--bg-elev-3);
  border: 1px solid var(--border);
  border-radius: 20px;
  color: var(--text);
  font-size: 13px;
  font-weight: 500;
  padding: 6px 14px;
  cursor: pointer;
  transition: background .12s, border-color .12s;
}
.notes-player-btn:hover { background: rgba(79,109,245,.2); border-color: rgba(79,109,245,.5); color: #a5b4fc; }
.notes-player-btn.has-note { border-color: #f0b429; color: #f0b429; background: rgba(240,180,41,.1); }
.notes-modal__log {
  border-top: 1px solid var(--border);
  padding: 10px 16px;
  max-height: 200px;
  overflow-y: auto;
}
.note-item {
  display: flex;
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
  font-size: 12px;
}
.note-item:last-child { border-bottom: none; }
.note-item__meta { color: var(--text-dim); white-space: nowrap; min-width: 80px; }
.note-item__player { font-weight: 700; color: #a5b4fc; margin-bottom: 2px; }
.note-item__text { color: var(--text); }

/* ============================================================
   Note entry panel
   ============================================================ */
/* dialog variant — top-layer, always above other dialogs */
dialog.note-entry {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  margin: 0;
  padding: 0;
  border: none;
  background: rgba(0,0,0,.5);
  display: none;        /* hidden by default (no [open] attribute) */
  align-items: center;
  justify-content: center;
}
dialog.note-entry[open] {
  display: flex;        /* shown when dialog is open */
}
dialog.note-entry::backdrop {
  display: none;        /* we paint our own backdrop via background above */
}
.note-entry__panel {
  background: var(--bg-elev-2);
  border: 1px solid var(--border);
  border-radius: 14px;
  width: 90%;
  max-width: 420px;
  padding: 18px;
}
.note-entry__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
}
.note-entry__title { font-size: 14px; font-weight: 700; color: var(--text); }
.note-entry__time { font-size: 11px; color: var(--text-dim); margin-bottom: 10px; }
.note-entry__textarea {
  width: 100%;
  background: var(--bg-elev-3);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--text);
  font-family: inherit;
  font-size: 14px;
  padding: 10px;
  resize: vertical;
  margin-bottom: 12px;
}
.note-entry__textarea:focus { outline: none; border-color: rgba(79,109,245,.6); }
.note-entry__actions { display: flex; gap: 8px; }
                                                                 


/* ============================================================
   Topbar — v1.1.428
   2-column grid: [meta 1fr] [actions auto].
   Key fix: min-width:0 + justify-self:stretch lets 1fr column
   actually constrain meta content so it never bleeds into actions.
   Game heading is plain inline text — no pill box.
   ============================================================ */

.topbar {
  grid-template-columns: auto 1fr minmax(0, auto);
}

/* brand stays left */
.topbar__brand { grid-column: 1; white-space: nowrap; }

/* meta fills space between brand and actions; min-width:0 lets grid shrink it */
.topbar__meta {
  grid-column: 2;
  justify-self: stretch;
  align-self: center;
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 10px;
  overflow: hidden;
  text-align: left;
}

/* Game + court text — clip at column edge */
#topbar-game,
#topbar-court {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}

/* Version badge — tiny dim text at the end */
.topbar__ver {
  font-size: 10px;
  opacity: 0.45;
  white-space: nowrap;
  flex-shrink: 0;
}

/* Actions stay right — tighter gap so all buttons fit when a long game title is visible */
.topbar__actions {
  grid-column: 3;
  gap: 4px;
}

/* Strip pill/box from game-active state */
.topbar__meta--game {
  background: none;
  border: none;
}

/* ============================================================
   Manage Teams modal
   ============================================================ */
dialog#dlg-manage-teams .modal {
  max-width: 780px;
  width: 95vw;
  height: 82vh;          /* fixed height — prevents modal from growing with content */
}
dialog#dlg-manage-teams .modal__body {
  padding: 0;
  flex: 1;               /* fill remaining space inside .modal flex column */
  overflow: hidden;      /* clip; children control their own scroll */
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.mt-loading {
  padding: 24px;
  color: var(--text-dim);
  font-size: 13px;
}
.mt-search-loading {
  padding: 10px 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  color: var(--text-dim);
  font-size: 12px;
}
@keyframes mt-spin { to { transform: rotate(360deg); } }
.mt-spinner {
  display: inline-block;
  width: 13px; height: 13px;
  border: 2px solid var(--border);
  border-top-color: var(--brand, #6366f1);
  border-radius: 50%;
  animation: mt-spin .55s linear infinite;
  flex-shrink: 0;
}

/* Two-column team grid */
.mt-cols {
  display: grid;
  grid-template-columns: 1fr 1px 1fr;
  gap: 0;
  padding: 0;
  flex: 1;               /* fills available space in the flex modal__body */
  min-height: 0;         /* allows shrink below grid's intrinsic size */
  overflow-y: auto;      /* scrolls when player lists + add panel exceed modal height */
}
.mt-divider {
  background: var(--border);
  margin: 12px 0;
}
.mt-team {
  padding: 14px 16px 10px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.mt-team__head {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 4px;
}
.mt-team__count {
  font-size: 11px;
  font-weight: 500;
  background: var(--bg-elev-2);
  color: var(--text-dim);
  border-radius: 10px;
  padding: 1px 7px;
  margin-left: auto;
}

/* Player rows */
.mt-players-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-bottom: 6px;
}
.mt-player-row {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 5px 6px;
  border-radius: 6px;
  min-width: 0;
}
.mt-player-row:hover { background: var(--bg-elev-1); }
.mt-player-name {
  flex: 1;
  font-size: 12px;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}
.mt-player-name--tmp { color: var(--text-dim); font-style: italic; }
.mt-player-btns {
  display: flex;
  gap: 2px;
  flex-shrink: 0;
}
.mt-btn {
  background: none;
  border: none;
  cursor: pointer;
  border-radius: 5px;
  padding: 3px 5px;
  font-size: 13px;
  line-height: 1;
  opacity: 0.6;
  transition: opacity .15s, background .15s;
}
.mt-btn:hover { opacity: 1; background: var(--bg-elev-2); }
.mt-btn--remove:hover { color: var(--danger); }
.mt-empty {
  font-size: 12px;
  color: var(--text-dim);
  padding: 6px 4px;
}

/* Add player trigger + search panel */
.mt-add-trigger {
  background: none;
  border: 1px dashed var(--border);
  border-radius: 7px;
  color: var(--text-dim);
  font-size: 12px;
  cursor: pointer;
  padding: 6px 10px;
  text-align: left;
  transition: border-color .15s, color .15s;
  margin-top: 4px;
}
.mt-add-trigger:hover {
  border-color: var(--accent);
  color: var(--accent);
}
.mt-add-panel {
  margin-top: 6px;
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  background: var(--bg-elev-1);
}
.mt-add-panel.hidden { display: none; }
.mt-search-input {
  width: 100%;
  box-sizing: border-box;
  border: none;
  border-bottom: 1px solid var(--border);
  background: var(--bg-elev-1);
  color: var(--text);
  font-size: 12px;
  padding: 8px 10px;
  outline: none;
}
.mt-search-input:focus { background: var(--bg-elev-2); }
.mt-search-list {
  max-height: 180px;
  overflow-y: auto;
}
.mt-search-item {
  display: block;
  width: 100%;
  text-align: left;
  background: none;
  border: none;
  border-bottom: 1px solid var(--border);
  color: var(--text);
  font-size: 12px;
  padding: 7px 10px;
  cursor: pointer;
  transition: background .12s;
}
.mt-search-item:last-child { border-bottom: none; }
.mt-search-item:hover { background: var(--bg-elev-2); }
.mt-search-empty {
  padding: 10px;
  font-size: 12px;
  color: var(--text-dim);
}

/* Notes & Penalties log — pinned to the bottom of the modal */
.mt-log-section {
  border-top: 1px solid var(--border);
  padding: 14px 16px;
  flex-shrink: 0;        /* never squish — always visible at the bottom */
  max-height: 200px;
  overflow-y: auto;
}
.mt-log-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 10px;
}
.mt-log-empty {
  font-size: 12px;
  color: var(--text-dim);
  padding: 4px 0;
}

/* Manage Teams add-picker section labels */
.mt-search-section-label {
  padding: 5px 10px 3px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--accent);
  background: var(--bg-elev-1);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 1;
}
.mt-search-section-label--other {
  color: var(--text-dim);
}

/* Squad-full state */
.mt-add-trigger--full {
  border-color: var(--border);
  color: var(--text-muted);
  cursor: not-allowed;
  opacity: 0.6;
}
.mt-add-trigger--full:hover {
  border-color: var(--border);
  color: var(--text-muted);
}
.mt-team__count--full {
  background: rgba(31,184,107,.15);
  color: var(--positive);
}

/* ── Add panel tab toggle (Players | + Tmp) ─────────────────── */
.mt-add-toggle {
  display: flex;
  border-bottom: 1px solid var(--border);
  margin-bottom: 6px;
}
.mt-add-toggle__btn {
  flex: 1;
  background: var(--bg-elev-2);
  border: none;
  border-right: 1px solid var(--border);
  padding: 6px 0;
  font-size: 12px;
  color: var(--text-dim);
  cursor: pointer;
  transition: background .15s, color .15s;
}
.mt-add-toggle__btn:last-child { border-right: none; }
.mt-add-toggle__btn.is-active { background: var(--accent, #4f6df5); color: #fff; }
.mt-add-toggle__btn:not(.is-active):hover { background: var(--bg-elev-3); color: var(--text); }
.mt-add-toggle__btn--tmp { color: #f0b429; }
.mt-add-toggle__btn--tmp.is-active { background: #7d5a00; color: #fff; }

/* Tmp player form */
.mt-tmp-msg {
  color: var(--text-dim);
  font-size: 12px;
  padding: 4px 0 8px;
}
.mt-tmp-row {
  display: flex;
  gap: 6px;
  margin-bottom: 6px;
}
.mt-tmp-row .mt-search-input { flex: 1; }
.mt-tmp-note {
  font-size: 11px;
  color: #f0b429;
  margin: 0;
  padding: 4px 0;
}

/* ── Player status tags ─────────────────────────────────────── */
.mt-status-tag {
  display: inline-block;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .03em;
  padding: 1px 4px;
  border-radius: 3px;
  margin-left: 4px;
  vertical-align: middle;
  line-height: 14px;
  text-transform: uppercase;
}
.mt-status-tag--bat {
  background: rgba(31,184,107,.2);
  color: var(--positive);
}
.mt-status-tag--done {
  background: rgba(255,255,255,.08);
  color: var(--text-dim);
}
.mt-status-tag--bowl {
  background: rgba(82,157,255,.2);
  color: #82b4ff;
}
.mt-status-tag--bowled {
  background: rgba(255,255,255,.07);
  color: var(--text-dim);
}

/* ── Swap button ────────────────────────────────────────────── */
.mt-btn--swap {
  color: var(--accent, #f9a825);
  font-size: 13px;
}
.mt-btn--swap:hover {
  background: rgba(249,168,37,.12);
}

/* ── Swap panel ─────────────────────────────────────────────── */
.mt-swap-panel {
  margin-top: 6px;
  border: 1px solid var(--accent, #f9a825);
  border-radius: 6px;
  overflow: hidden;
  background: var(--bg-elev-1);
}
.mt-swap-panel.hidden { display: none; }
.mt-swap-panel__header {
  padding: 6px 10px;
  font-size: 11px;
  color: var(--text-dim);
  background: rgba(249,168,37,.08);
  border-bottom: 1px solid rgba(249,168,37,.2);
}
.mt-swap-panel__header strong {
  color: var(--text-main, #fff);
}

/* ── Balls remaining popup ──────────────────────────────────────────
   Not used on the scoring side — REM block in topbar pulses instead.
   ─────────────────────────────────────────────────────────────── */
.balls-popup { display: none; }

/* ── REM block pulse — fires after every ball ─────────────────── */
@keyframes rem-pulse {
  0%   { transform: scale(1);    box-shadow: none; }
  8%   { transform: scale(1.14); box-shadow: 0 0 0 4px var(--rem-pulse-color, var(--warning)); }
  18%  { transform: scale(1.05); box-shadow: 0 0 0 3px var(--rem-pulse-color, var(--warning)); }
  65%  { transform: scale(1);    box-shadow: 0 0 0 2px var(--rem-pulse-color, var(--warning)); }
  100% { transform: scale(1);    box-shadow: none; }
}

.sb-matchbar__stat.is-rem-pulsing {
  animation: rem-pulse 3s cubic-bezier(0.34,1.56,0.64,1) both;
  border-radius: var(--radius-sm);
  position: relative;
  z-index: 2;
}
/* Colour the REM value based on urgency */
.sb-matchbar__stat.rem-level--normal  #sb-remaining { color: var(--text); }
.sb-matchbar__stat.rem-level--warn    #sb-remaining { color: var(--warning); }
.sb-matchbar__stat.rem-level--urgent  #sb-remaining { color: var(--negative); }
.sb-matchbar__stat.rem-level--last    #sb-remaining { color: var(--danger); font-weight: 900; }
