/* ═══════════════════════════════════════════════════════════
   CRICKET OVERLAY — Design System
   Clean light theme following Butler UI/UX guidelines.
   ═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

/* ── Design Tokens ─────────────────────────────────────────── */
:root {
  --white:     #ffffff;
  --gray-50:   #f9fafb;
  --gray-100:  #f3f4f6;
  --gray-200:  #e5e7eb;
  --gray-300:  #d1d5db;
  --gray-400:  #9ca3af;
  --gray-500:  #6b7280;
  --gray-600:  #4b5563;
  --gray-700:  #374151;
  --gray-800:  #1f2937;
  --gray-900:  #111827;
  --black:     #000000;

  --green-50:  #f0fdf4;
  --green-100: #dcfce7;
  --green-500: #22c55e;
  --green-600: #16a34a;
  --green-700: #15803d;

  --red-50:   #fef2f2;
  --red-100:  #fee2e2;
  --red-200:  #fecaca;
  --red-500:  #ef4444;
  --red-600:  #dc2626;
  --red-700:  #b91c1c;

  --amber-50:  #fffbeb;
  --amber-100: #fef3c7;
  --amber-500: #f59e0b;
  --amber-700: #b45309;

  --blue-50:  #eff6ff;
  --blue-500: #3b82f6;
  --blue-700: #1d4ed8;

  /* Semantic */
  --bg:       var(--white);
  --surface:  var(--white);
  --surface2: var(--gray-50);
  --surface3: var(--gray-100);
  --border:   var(--gray-200);
  --border2:  var(--gray-300);

  --text:       var(--gray-900);
  --text-sub:   var(--gray-700);
  --text-muted: var(--gray-500);

  --accent:      var(--gray-900);
  --accent-dark: var(--black);
  --accent-bg:   var(--green-50);

  /* cricket-specific */
  --ub-black:      var(--gray-900);
  --ub-green:      var(--green-500);
  --ub-green-dark: var(--green-600);
  --ub-green-bg:   var(--green-50);
  --ub-red:        var(--red-600);
  --ub-red-bg:     var(--red-50);
  --ub-amber:      var(--amber-500);
  --ub-amber-bg:   var(--amber-50);
  --ub-blue:       var(--blue-500);
  --ub-blue-bg:    var(--blue-50);

  --font: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --mono: 'SF Mono', 'Fira Code', monospace;

  --sp-1: 4px;  --sp-2: 8px;  --sp-3: 12px; --sp-4: 16px;
  --sp-5: 20px; --sp-6: 24px; --sp-8: 32px; --sp-10: 40px;
  --sp-12: 48px; --sp-16: 64px;

  --r-sm:   4px;
  --r-md:   8px;
  --r-lg:   12px;
  --r-xl:   16px;
  --r-pill: 999px;

  --shadow-sm: 0 1px 2px rgba(0,0,0,.05);
  --shadow-md: 0 4px 12px rgba(0,0,0,.08);
  --shadow-lg: 0 8px 32px rgba(0,0,0,.12);
}

/* ── Reset ──────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { -webkit-text-size-adjust:100%; }
body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; }

/* ── Typography ────────────────────────────────────────────── */
.ub-display { font-size:40px;font-weight:800;line-height:1.05;letter-spacing:-0.02em; }
.ub-h1      { font-size:28px;font-weight:700;line-height:1.15;letter-spacing:-0.01em; }
.ub-h2      { font-size:22px;font-weight:700;line-height:1.2; }
.ub-h3      { font-size:17px;font-weight:600;line-height:1.3; }
.ub-body    { font-size:15px;font-weight:400;line-height:1.5; }
.ub-body-sm { font-size:13px;font-weight:400;line-height:1.5; }
.ub-label   { font-size:11px;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--text-muted); }
.ub-mono    { font-family:var(--mono);font-variant-numeric:tabular-nums; }

/* ── Layout ─────────────────────────────────────────────────── */
.ub-container    { max-width:1100px;margin:0 auto;padding:0 var(--sp-6); }
.ub-container-sm { max-width:540px;margin:0 auto;padding:0 var(--sp-5); }
.ub-page-pad     { padding-top:var(--sp-8);padding-bottom:var(--sp-16); }

/* ── Nav ────────────────────────────────────────────────────── */
.ub-nav {
  display:flex;align-items:center;justify-content:space-between;
  padding: var(--sp-4) var(--sp-6);
  border-bottom: 1px solid var(--border);
  position:sticky;top:0;z-index:50;
  background: rgba(255,255,255,.95);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
}
.ub-nav-logo {
  display:flex;align-items:center;gap:var(--sp-3);
  font-size:15px;font-weight:700;letter-spacing:-0.01em;
  text-decoration:none;color:var(--text);
}
.ub-nav-logo .logo-dot {
  width:9px;height:9px;border-radius:50%;background:var(--green-500);
}
.ub-back-link {
  display:inline-flex;align-items:center;gap:var(--sp-2);
  font-size:13px;font-weight:500;color:var(--text-muted);
  text-decoration:none;transition:color .15s;
}
.ub-back-link:hover { color:var(--text); }

/* ── Dividers ───────────────────────────────────────────────── */
.ub-divider { border:none;border-top:1px solid var(--border);margin:var(--sp-6) 0; }
.ub-section-label {
  font-size:11px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--text-muted);margin-bottom:var(--sp-4);
}

/* ── Cards ──────────────────────────────────────────────────── */
.ub-card {
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden;
}
.ub-card-body { padding:var(--sp-5); }
.ub-card-body + .ub-card-body { border-top:1px solid var(--border); }

/* ── Buttons ────────────────────────────────────────────────── */
.ub-btn {
  display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);
  font-family:var(--font);font-size:14px;font-weight:600;line-height:1;
  padding:11px 20px;border-radius:var(--r-lg);
  border:1.5px solid transparent;cursor:pointer;
  text-decoration:none;white-space:nowrap;
  transition:background .15s,border-color .15s,transform .1s,box-shadow .15s;
  user-select:none;-webkit-tap-highlight-color:transparent;
}
.ub-btn:active { transform:scale(0.97); }

.ub-btn-primary   { background:var(--gray-900);color:var(--white);border-color:var(--gray-900); }
.ub-btn-primary:hover { background:var(--black);border-color:var(--black); }

.ub-btn-secondary { background:var(--white);color:var(--gray-900);border-color:var(--gray-300); }
.ub-btn-secondary:hover { border-color:var(--gray-400);background:var(--gray-50); }

.ub-btn-invert { background:var(--gray-900);color:var(--white);border-color:var(--gray-900); }
.ub-btn-invert:hover { background:var(--black); }

.ub-btn-ghost { background:transparent;color:var(--gray-700);border-color:var(--gray-200); }
.ub-btn-ghost:hover { background:var(--gray-50);border-color:var(--gray-300); }

.ub-btn-danger { background:transparent;color:var(--red-600);border-color:var(--red-200); }
.ub-btn-danger:hover { background:var(--red-50);border-color:var(--red-500); }

.ub-btn-sm   { font-size:12px;padding:7px 14px;border-radius:var(--r-md); }
.ub-btn-lg   { font-size:16px;padding:14px 28px; }
.ub-btn-xl   { font-size:18px;padding:17px 36px;border-radius:var(--r-xl); }
.ub-btn-full { width:100%; }
.ub-btn-icon { padding:10px;border-radius:var(--r-md); }

/* ── Form ───────────────────────────────────────────────────── */
.ub-label-text {
  display:block;font-size:11px;font-weight:600;letter-spacing:0.09em;
  text-transform:uppercase;color:var(--text-muted);margin-bottom:6px;
}
.ub-input {
  width:100%;background:var(--white);border:1.5px solid var(--gray-200);
  color:var(--text);border-radius:var(--r-md);padding:10px 14px;
  font-family:var(--font);font-size:14px;font-weight:500;outline:none;
  transition:border-color .2s,box-shadow .2s;-webkit-appearance:none;
}
.ub-input::placeholder { color:var(--gray-400); }
.ub-input:focus { border-color:var(--gray-900);box-shadow:0 0 0 3px rgba(17,24,39,.08); }
.ub-input:disabled { opacity:.4;cursor:not-allowed; }
.ub-textarea { resize:vertical;min-height:72px;line-height:1.5; }

/* ── Chips ──────────────────────────────────────────────────── */
.ub-chip {
  display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;
  letter-spacing:0.06em;padding:4px 10px;border-radius:var(--r-pill);
  background:var(--gray-100);border:1px solid var(--gray-200);color:var(--gray-600);
  cursor:default;user-select:none;
}
.ub-chip-sel   { background:var(--green-50);border-color:var(--green-500);color:var(--green-700); }
.ub-chip-live  { background:var(--red-50);border-color:var(--red-200);color:var(--red-600); }
.ub-chip-amber { background:var(--amber-50);border-color:var(--amber-100);color:var(--amber-700); }

/* ── Badge ──────────────────────────────────────────────────── */
.ub-badge       { display:inline-block;font-size:10px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;padding:3px 8px;border-radius:var(--r-pill);background:var(--gray-100);color:var(--gray-600); }
.ub-badge-green { background:var(--green-50);color:var(--green-700); }

/* ── Status dot ─────────────────────────────────────────────── */
.ub-status { display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:var(--text-muted); }
.ub-status-dot { width:8px;height:8px;border-radius:50%;background:var(--gray-300);transition:background .3s;flex-shrink:0; }
.ub-status.connected .ub-status-dot { background:var(--green-500);box-shadow:0 0 6px rgba(34,197,94,.5);animation:ub-pulse 2s infinite; }
.ub-status.connected { color:var(--green-600); }
@keyframes ub-pulse { 0%,100%{opacity:1} 50%{opacity:.5} }

/* ── List items ─────────────────────────────────────────────── */
.ub-list-item { display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-radius:var(--r-md);cursor:pointer;transition:background .12s; }
.ub-list-item:hover    { background:var(--gray-50); }
.ub-list-item.selected { background:var(--green-50);border:1px solid var(--green-100); }
.ub-list-item.disabled { opacity:.3;pointer-events:none; }

/* ── Ball bubbles ───────────────────────────────────────────── */
.ub-ball { width:32px;height:32px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0;border:2px solid transparent; }
.ub-ball-dot { background:var(--gray-100);color:var(--gray-500);border-color:var(--gray-200); }
.ub-ball-run { background:var(--gray-100);color:var(--gray-700);border-color:var(--gray-200); }
.ub-ball-4   { background:var(--amber-50);color:var(--amber-700);border-color:var(--amber-100); }
.ub-ball-6   { background:var(--green-50);color:var(--green-700);border-color:var(--green-100); }
.ub-ball-W   { background:var(--red-50);color:var(--red-600);border-color:var(--red-200); }
.ub-ball-Wd  { background:var(--blue-50);color:var(--blue-700);border-color:#bfdbfe;font-size:10px; }
.ub-ball-Nb  { background:var(--amber-50);color:var(--amber-700);border-color:var(--amber-100);font-size:10px; }
.ub-ball-Lb  { background:var(--gray-100);color:var(--gray-600);border-color:var(--gray-200);font-size:10px; }
.ub-ball-B   { background:var(--gray-100);color:var(--gray-600);border-color:var(--gray-200);font-size:10px; }
.ub-ball-empty { background:transparent;border:2px dashed var(--gray-200); }

/* ── Score pad ──────────────────────────────────────────────── */
.ub-pad-btn { height:58px;border-radius:var(--r-md);border:1.5px solid transparent;cursor:pointer;font-family:var(--font);font-weight:800;font-size:18px;user-select:none;-webkit-tap-highlight-color:transparent;transition:transform .1s,opacity .1s; }
.ub-pad-btn:active { transform:scale(0.91); }
.ub-pad-dot { background:var(--gray-100);color:var(--gray-500);border-color:var(--gray-200); }
.ub-pad-run { background:var(--gray-100);color:var(--gray-800);border-color:var(--gray-200); }
.ub-pad-4   { background:var(--amber-50);color:var(--amber-700);border-color:var(--amber-100); }
.ub-pad-6   { background:var(--green-50);color:var(--green-700);border-color:var(--green-100); }
.ub-pad-W   { background:var(--red-50);color:var(--red-600);border-color:var(--red-200); }
.ub-pad-Wd  { background:var(--blue-50);color:var(--blue-700);border-color:#bfdbfe;font-size:13px; }
.ub-pad-Nb  { background:var(--amber-50);color:var(--amber-700);border-color:var(--amber-100);font-size:13px; }
.ub-pad-Lb  { background:var(--gray-100);color:var(--gray-600);border-color:var(--gray-200);font-size:13px; }
.ub-pad-By  { background:var(--gray-100);color:var(--gray-600);border-color:var(--gray-200);font-size:13px; }
.ub-pad-undo { background:var(--gray-100);color:var(--gray-500);border-color:var(--gray-200);font-size:16px; }

/* ── Toast ──────────────────────────────────────────────────── */
.ub-toast { position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(16px);background:var(--gray-900);color:var(--white);padding:10px 20px;border-radius:var(--r-md);font-size:13px;font-weight:500;opacity:0;transition:opacity .22s,transform .22s;z-index:9999;white-space:nowrap;pointer-events:none;box-shadow:var(--shadow-md); }
.ub-toast.show { opacity:1;transform:translateX(-50%) translateY(0); }

/* ── Score display ──────────────────────────────────────────── */
.ub-score-big { font-size:52px;font-weight:800;line-height:1;letter-spacing:-0.03em;font-variant-numeric:tabular-nums;color:var(--gray-900); }
.ub-score-overs { font-size:14px;font-weight:400;color:var(--text-muted);margin-top:2px; }

/* ── Table ──────────────────────────────────────────────────── */
.ub-table { width:100%;border-collapse:collapse;font-size:13px; }
.ub-table th { text-align:left;font-size:10px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--text-muted);padding:8px 10px;border-bottom:1px solid var(--border);background:var(--gray-50); }
.ub-table td { padding:9px 10px;border-bottom:1px solid var(--border);color:var(--text); }
.ub-table tbody tr:last-child td { border-bottom:none; }
.ub-table tbody tr:hover td { background:var(--gray-50); }

/* ── Mode cards ─────────────────────────────────────────────── */
.ub-mode-card { background:var(--white);border:1.5px solid var(--gray-200);border-radius:var(--r-lg);padding:16px;cursor:pointer;transition:border-color .15s,box-shadow .15s;box-shadow:var(--shadow-sm); }
.ub-mode-card:hover { border-color:var(--gray-400);box-shadow:var(--shadow-md); }
.ub-mode-card.sel { border-color:var(--green-500);background:var(--green-50); }

/* ── Over / bat rows ────────────────────────────────────────── */
.ub-over-row { display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:var(--sp-3) var(--sp-4);background:var(--gray-50);border-bottom:1px solid var(--border);min-height:52px; }
.ub-bat-row  { display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-bottom:1px solid var(--border); }
.ub-bat-name { flex:1;font-size:15px;font-weight:600;color:var(--text); }
.ub-bat-name.on-strike { color:var(--amber-700); }
.ub-bat-stats { font-size:12px;color:var(--text-muted);font-variant-numeric:tabular-nums;white-space:nowrap; }
.ub-bat-stats b { color:var(--text);font-weight:600; }
.ub-bwl-bar { display:flex;justify-content:space-between;align-items:center;padding:var(--sp-2) var(--sp-4) var(--sp-3);background:var(--gray-50);border-bottom:1px solid var(--border); }

/* ── Modal ──────────────────────────────────────────────────── */
.ub-modal-backdrop { display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:100;align-items:flex-end;justify-content:center; }
.ub-modal-backdrop.open { display:flex; }
.ub-modal { background:var(--white);border:1px solid var(--gray-200);border-radius:var(--r-xl) var(--r-xl) 0 0;padding:24px 20px 32px;width:100%;max-width:460px;max-height:88vh;overflow-y:auto;animation:ub-slide-up .22s ease-out;box-shadow:var(--shadow-lg); }
@keyframes ub-slide-up { from{transform:translateY(40px);opacity:0} to{transform:translateY(0);opacity:1} }
.ub-modal-handle { width:36px;height:4px;border-radius:2px;background:var(--gray-300);margin:0 auto 20px; }
.ub-modal h2 { font-size:18px;font-weight:700;margin-bottom:16px;color:var(--gray-900); }

/* ── Dismissal grid ─────────────────────────────────────────── */
.ub-dis-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px; }
.ub-dis-btn { padding:11px 6px;border-radius:var(--r-md);border:1.5px solid var(--gray-200);background:var(--white);color:var(--gray-700);cursor:pointer;font-size:12px;font-weight:600;font-family:var(--font);transition:border-color .15s,background .15s;text-align:center;box-shadow:var(--shadow-sm); }
.ub-dis-btn:hover { border-color:var(--gray-400);background:var(--gray-50); }
.ub-dis-btn.sel { border-color:var(--red-500);background:var(--red-50);color:var(--red-700); }

/* ── Runs row ───────────────────────────────────────────────── */
.ub-runs-row { display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:12px; }
.ub-runs-btn { padding:16px;border-radius:var(--r-md);background:var(--white);border:1.5px solid var(--gray-200);color:var(--gray-800);font-size:17px;font-weight:700;cursor:pointer;font-family:var(--font);transition:border-color .15s,background .15s;text-align:center;box-shadow:var(--shadow-sm); }
.ub-runs-btn:hover { border-color:var(--gray-400);background:var(--gray-50); }
.ub-runs-btn.sel   { border-color:var(--green-500);background:var(--green-50);color:var(--green-700); }

/* ── Player input ───────────────────────────────────────────── */
.ub-pinput-row { display:flex;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-2); }
.ub-pnum { width:22px;font-size:12px;color:var(--text-muted);flex-shrink:0;text-align:right; }

/* ── Tabs ───────────────────────────────────────────────────── */
.ub-tabs { display:flex;gap:0;background:var(--gray-100);border:1px solid var(--gray-200);border-radius:var(--r-md);padding:3px;margin-bottom:var(--sp-4); }
.ub-tab { flex:1;padding:8px 12px;border-radius:6px;border:none;background:transparent;color:var(--gray-600);cursor:pointer;font-size:13px;font-weight:600;font-family:var(--font);transition:background .15s,color .15s;text-align:center; }
.ub-tab.sel { background:var(--white);color:var(--gray-900);box-shadow:var(--shadow-sm); }

/* ── Innings summary ────────────────────────────────────────── */
.ub-inn-summary { background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--r-lg);padding:var(--sp-4);margin-bottom:var(--sp-4);line-height:1.7;font-size:14px; }

/* ── Empty state ────────────────────────────────────────────── */
.ub-empty { text-align:center;padding:64px 24px;color:var(--text-muted); }
.ub-empty .ub-empty-icon { font-size:48px;margin-bottom:var(--sp-4);line-height:1; }
.ub-empty h3 { font-size:18px;font-weight:700;color:var(--gray-700);margin-bottom:var(--sp-2); }
.ub-empty p  { font-size:14px;color:var(--gray-500); }

/* ── Match card ─────────────────────────────────────────────── */
.ub-match-card { background:var(--white);border:1px solid var(--gray-200);border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-sm);transition:border-color .2s,box-shadow .2s,transform .15s; }
.ub-match-card:hover { border-color:var(--gray-300);box-shadow:var(--shadow-md);transform:translateY(-2px); }
.ub-match-card-stripe { height:3px;background:var(--gray-900); }
.ub-match-card-body { padding:var(--sp-5); }

/* ── Utility ────────────────────────────────────────────────── */
.ub-flex { display:flex; }
.ub-flex-col { display:flex;flex-direction:column; }
.ub-items-center { align-items:center; }
.ub-justify-between { justify-content:space-between; }
.ub-gap-2 { gap:var(--sp-2); } .ub-gap-3 { gap:var(--sp-3); } .ub-gap-4 { gap:var(--sp-4); }
.ub-w-full { width:100%; }
.ub-mt-4 { margin-top:var(--sp-4); } .ub-mt-6 { margin-top:var(--sp-6); }
.ub-mb-4 { margin-bottom:var(--sp-4); }
.ub-text-muted { color:var(--text-muted); }
.ub-text-green { color:var(--green-600); }
.ub-text-red   { color:var(--red-600); }
.ub-text-amber { color:var(--amber-700); }
.ub-fw-bold  { font-weight:700; }
.ub-fw-black { font-weight:800; }
