/* ══════════════════════════════════════════
   CRICKET SCOREBOARD v4 — MOBILE PREMIUM
══════════════════════════════════════════ */

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

:root {
  --bg:     #0b1220; --bg2:    #162033;
  --card:   #172132; --card2:  #1d2a3f;
  --border: #2f3d55;
  --text:   #f8fafc; --text2:  #a6b3c5; --muted: #7b8ba3;
  --cyan:   #22c7f0; --cyan-g: rgba(34,199,240,.20);
  --blue:   #3b82f6; --blue-g: rgba(59,130,246,.3);
  --purple: #a855f7; --pur-g:  rgba(168,85,247,.3);
  --red:    #ef4444; --red-g:  rgba(239,68,68,.3);
  --amber:  #f59e0b; --orange: #f97316;
  --green:  #22c55e; --indigo: #6366f1;
  --r1:6px; --r2:11px; --r3:11px; --r4:11px;
  --sh: 0 18px 48px rgba(2,8,23,.28);
  --ease: cubic-bezier(.4,0,.2,1);
}
body.light-mode {
  --bg:#f5f7fb; --bg2:#ffffff; --card:#ffffff; --card2:#f8fbff;
  --border:#dbe7f3; --text:#172033; --text2:#52627a; --muted:#7f90a7;
  --sh:0 16px 40px rgba(15,23,42,.08);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-tap-highlight-color:transparent}
body{
  font-family:'Inter',sans-serif;
  background:
    radial-gradient(circle at top left, rgba(34,199,240,.08), transparent 24%),
    linear-gradient(180deg,var(--bg) 0%,#0d1526 100%);
  color:var(--text);
  min-height:100dvh;
  overflow-x:hidden;
  transition:background .35s,color .35s
}
body.light-mode{
  background:
    radial-gradient(circle at top left, rgba(34,199,240,.08), transparent 22%),
    linear-gradient(180deg,#f7fbff 0%,var(--bg) 100%);
}
button,input{font-family:inherit}
button{cursor:pointer;border:none;outline:none}
input{outline:none}

/* ── Screens ── */
.screen{display:none;min-height:100dvh;flex-direction:column}
.screen.active{display:flex}

/* ══════════════════════════════════════════
   HOME SCREEN
══════════════════════════════════════════ */
#home-screen{
  background:linear-gradient(160deg,#080f1e 0%,#1e293b 55%,#0a1628 100%);
  align-items:center;justify-content:flex-start;
  padding:48px 20px 40px;gap:20px;
}
body.light-mode #home-screen{
  background:linear-gradient(160deg,#dbeafe 0%,#f0f9ff 55%,#e0f2fe 100%);
}
.home-wrap{width:100%;max-width:440px;display:flex;flex-direction:column;gap:18px}

/* Logo */
.home-logo{text-align:center;animation:fadeDown .6s var(--ease)}
.logo-icon{font-size:60px;display:block;margin-bottom:8px;filter:drop-shadow(0 0 22px rgba(34,211,238,.55))}
.logo-title{font-family:'Rajdhani',sans-serif;font-size:38px;font-weight:700;color:var(--text)}
.logo-title span{color:var(--cyan)}
.logo-sub{color:var(--muted);font-size:13px;margin-top:3px}

/* Home Actions */
.home-actions{display:flex;flex-direction:column;gap:12px}

/* Resume card */
.resume-card{
  background:var(--card);border:1.5px solid rgba(34,211,238,.5);
  border-radius:var(--r3);padding:14px 16px;
  box-shadow:0 0 20px rgba(34,211,238,.12);
  animation:fadeUp .4s var(--ease);
}
.resume-card.hidden{display:none}
.resume-label{font-size:10px;font-weight:700;color:var(--red);text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px;display:flex;align-items:center;gap:4px}
.resume-label::before{content:'';width:6px;height:6px;background:var(--red);border-radius:50%;animation:pulse 1s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.resume-teams{font-size:16px;font-weight:800;color:var(--text);margin-bottom:2px}
.resume-score{font-size:13px;color:var(--text2);margin-bottom:12px}
.btn-resume{
  width:100%;padding:12px;
  background:linear-gradient(135deg,rgba(34,211,238,.15),rgba(34,211,238,.08));
  border:1.5px solid var(--cyan);border-radius:var(--r2);
  color:var(--cyan);font-size:14px;font-weight:700;
  transition:all .2s;
}
.btn-resume:hover{background:var(--cyan);color:#0f172a}
.btn-resume:active{transform:scale(.96)}

/* Primary button */
.btn-primary{
  width:100%;padding:15px;
  background:linear-gradient(135deg,#18c3ea,#1296db);
  border-radius:8px;color:#081423;
  font-size:15px;font-weight:800;
  box-shadow:0 14px 28px rgba(18,150,219,.22);
  transition:transform .15s,box-shadow .15s;
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 18px 34px rgba(18,150,219,.28)}
.btn-primary:active{transform:scale(.96)}

/* Sec button */
.btn-sec{
  flex:1;padding:13px;
  background:var(--card2);border:1.5px solid var(--border);
  border-radius:var(--r2);color:var(--text2);font-size:14px;font-weight:600;
  transition:all .2s;
}
.btn-sec:hover{border-color:var(--cyan);color:var(--cyan)}

/* Recent */
.recent-section{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r3);padding:14px 16px;
  animation:fadeUp .5s var(--ease);
}
.recent-section.hidden{display:none}
.recent-header{display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:700;color:var(--text2);margin-bottom:10px}
.clear-btn{font-size:11px;color:var(--red);background:none;border:1px solid var(--red);border-radius:8px;padding:2px 10px;transition:all .2s}
.clear-btn:hover{background:var(--red);color:#fff}
.hist-item{background:var(--card2);border:1px solid var(--border);border-radius:var(--r1);padding:10px 12px;margin-bottom:7px;transition:border-color .2s}
.hist-item:last-child{margin-bottom:0}
.hist-teams{font-size:13px;font-weight:700;color:var(--text);margin-bottom:2px}
.hist-result{font-size:11px;color:var(--muted)}

/* Home theme btn */
.home-theme-btn{
  position:fixed;top:16px;right:16px;
  width:38px;height:38px;
  background:var(--card2);border:1px solid var(--border);
  border-radius:50%;font-size:18px;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;z-index:5;
}
.home-theme-btn:hover{border-color:var(--cyan);transform:scale(1.1)}

/* ══════════════════════════════════════════
   SCOREBOARD SCREEN
══════════════════════════════════════════ */
#scoreboard-screen{background:var(--bg)}

.top-bar{
  display:flex;align-items:center;gap:8px;
  padding:11px 13px;
  background:var(--bg2);border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:10;
}
.match-title{flex:1;font-size:14px;font-weight:700;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.icon-btn{
  width:35px;height:35px;background:var(--card2);border:1px solid var(--border);
  border-radius:50%;font-size:16px;
  display:flex;align-items:center;justify-content:center;transition:all .2s;
}
.icon-btn:hover{border-color:var(--cyan);transform:scale(1.08)}
.icon-btn:active{transform:scale(.91)}

/* Score Hero */
.score-hero{
  background:linear-gradient(160deg,#0e1f36 0%,#162d47 100%);
  padding:14px 15px 11px;border-bottom:1px solid var(--border);
}
body.light-mode .score-hero{background:linear-gradient(160deg,#dbeafe 0%,#e0f2fe 100%)}

/* Target Bar */
.target-bar{
  display:flex;align-items:center;justify-content:space-between;
  background:linear-gradient(135deg,rgba(168,85,247,.18),rgba(34,211,238,.08));
  border:1.5px solid rgba(168,85,247,.4);
  border-radius:var(--r1);padding:7px 12px;margin-bottom:9px;
  animation:fadeUp .3s var(--ease);
}
.target-bar.hidden{display:none}
#target-lbl{font-family:'Rajdhani',sans-serif;font-size:17px;font-weight:700;color:var(--purple)}
.target-right{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
#target-need{font-size:11px;font-weight:600;color:var(--text2)}
.rrr-text{font-size:10px;color:var(--muted)}

/* Inn badge */
.inn-badge{
  display:inline-block;font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.8px;
  background:var(--cyan);color:#0f172a;border-radius:8px;padding:2px 8px;margin-bottom:3px;
}

.score-display{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px}
.runs-wickets{display:flex;align-items:baseline;gap:3px}
.runs-count{font-family:'Rajdhani',sans-serif;font-size:70px;font-weight:700;color:var(--text);line-height:1}
.runs-count.pop{animation:pop .3s var(--ease)}
.slash{font-family:'Rajdhani',sans-serif;font-size:48px;color:var(--muted);line-height:1}
.wickets-count{font-family:'Rajdhani',sans-serif;font-size:48px;font-weight:700;color:var(--red);line-height:1}
.score-meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.overs-text{font-family:'Rajdhani',sans-serif;font-size:20px;font-weight:700;color:var(--cyan)}
.rr-text{font-size:12px;font-weight:600;color:var(--text2)}
.ov-left-text{font-size:11px;color:var(--muted)}

/* This over */
.this-over-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.over-lbl{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.7px;white-space:nowrap}
.over-balls{display:flex;gap:4px;flex-wrap:wrap}
.ball{
  min-width:27px;height:27px;padding:0 5px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;
  background:var(--card2);color:var(--text2);border:1.5px solid var(--border);
  animation:ballIn .2s var(--ease);
}
.ball.four  {background:var(--blue);  border-color:var(--blue);  color:#fff}
.ball.six   {background:var(--purple);border-color:var(--purple);color:#fff}
.ball.wicket,.ball.runout{background:var(--red);border-color:var(--red);color:#fff}
.ball.wide  {background:var(--amber); border-color:var(--amber); color:#0f172a}
.ball.noball{background:var(--orange);border-color:var(--orange);color:#fff}
.ball.bye,.ball.legbye{background:var(--green);border-color:var(--green);color:#0f172a}
.ball.dot   {color:var(--muted)}

/* Stats row */
.stats-row{display:flex;gap:8px;padding:9px 13px}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r2);padding:10px 11px;box-shadow:var(--sh)}
.bat-card{flex:1.4}.bowl-card{flex:1;display:flex;flex-direction:column}
.card-hdr{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.7px;margin-bottom:7px;display:flex;align-items:center;gap:5px}
.partner-badge{font-size:9px;background:var(--cyan);color:#0f172a;border-radius:8px;padding:1px 6px;font-weight:700}
.bat-row{display:flex;align-items:flex-start;gap:7px;padding:4px 0}
.bat-row+.bat-row{border-top:1px solid var(--border)}
.dot-indicator{width:7px;height:7px;border-radius:50%;margin-top:4px;flex-shrink:0}
.striker-dot{background:var(--cyan);box-shadow:0 0 5px var(--cyan)}
.ns-dot{background:var(--muted)}
.player-name{font-size:12px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:115px}
.player-stat{font-size:10px;color:var(--muted);margin-top:1px}
.bowl-card .player-name{font-size:12px;font-weight:700;color:var(--text)}
.bowl-card .player-stat{font-size:10px;color:var(--muted);margin-top:2px}
.extras-txt{font-size:10px;color:var(--muted);margin-top:auto;padding-top:4px}

/* ── Scoring Pad ── */
.scoring-pad{padding:0 11px 26px;display:flex;flex-direction:column}
.pad-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);margin:9px 2px 5px}

/* Runs */
.run-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}
.run-btn{
  aspect-ratio:1;min-height:52px;
  background:var(--card);border:1.5px solid var(--border);
  border-radius:var(--r2);color:var(--text);
  font-family:'Rajdhani',sans-serif;font-size:26px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 8px rgba(0,0,0,.25);
  transition:transform .12s,opacity .12s;
}
.run-btn:active{transform:scale(.85);opacity:.8}
.dot-btn{background:var(--card2);color:var(--muted);border-color:var(--border)}
.four-btn{background:linear-gradient(135deg,var(--blue),#2563eb);border-color:var(--blue);color:#fff;box-shadow:0 3px 10px var(--blue-g)}
.six-btn {background:linear-gradient(135deg,var(--purple),#9333ea);border-color:var(--purple);color:#fff;box-shadow:0 3px 10px var(--pur-g)}

/* Extras */
.extra-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.xbtn{
  padding:13px 6px;border-radius:var(--r2);border:1.5px solid transparent;
  font-size:13px;font-weight:700;
  display:flex;align-items:center;justify-content:center;gap:5px;
  transition:transform .12s,opacity .12s;
}
.xbtn:active{transform:scale(.89);opacity:.85}
.xbadge{font-size:9px;background:rgba(0,0,0,.2);border-radius:8px;padding:1px 5px}
.wide-btn  {background:linear-gradient(135deg,var(--amber),#d97706);color:#0f172a;box-shadow:0 3px 10px rgba(245,158,11,.3)}
.noball-btn{background:linear-gradient(135deg,var(--orange),#ea580c);color:#fff;box-shadow:0 3px 10px rgba(249,115,22,.3)}
.bye-btn   {background:linear-gradient(135deg,#16a34a,#15803d);color:#fff;box-shadow:0 3px 10px rgba(22,163,74,.3)}
.legbye-btn{background:linear-gradient(135deg,#0d9488,#0f766e);color:#fff;box-shadow:0 3px 10px rgba(13,148,136,.3)}

/* Wickets */
.wkt-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.wbtn{
  padding:14px 6px;border-radius:var(--r2);border:none;
  font-size:14px;font-weight:800;
  display:flex;align-items:center;justify-content:center;gap:5px;
  transition:transform .12s,opacity .12s;
}
.wbtn:active{transform:scale(.88);opacity:.85}
.out-btn   {background:linear-gradient(135deg,var(--red),#dc2626);color:#fff;box-shadow:0 4px 12px var(--red-g)}
.runout-btn{background:linear-gradient(135deg,var(--indigo),#4338ca);color:#fff;box-shadow:0 4px 12px rgba(99,102,241,.3)}

/* Actions */
.act-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:6px}
.abtn{
  padding:12px 6px;background:var(--card);border:1.5px solid var(--border);
  border-radius:var(--r2);color:var(--text2);font-size:13px;font-weight:600;
  display:flex;align-items:center;justify-content:center;gap:5px;
  transition:all .2s;
}
.abtn:hover{border-color:var(--cyan);color:var(--cyan)}
.abtn:active{transform:scale(.94)}
.nbowl-btn{border-color:var(--cyan);color:var(--cyan)}
.end-btn{border-color:var(--amber);color:var(--amber)}
.stop-btn{border-color:var(--red);color:var(--red)}

/* ══════════════════════════════════════════
   MODALS
══════════════════════════════════════════ */
.modal-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.65);backdrop-filter:blur(5px);
  display:flex;align-items:flex-end;justify-content:center;
  z-index:100;animation:fadeIn .2s ease;
}
.modal-overlay.hidden{display:none}
.modal-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:8px 8px 0 0;
  padding:22px 18px 34px;width:100%;max-width:480px;
  animation:slideUp .3s var(--ease);
}
.modal-card h3{font-size:20px;font-weight:800;color:var(--text);margin-bottom:3px}
.modal-card p{font-size:12px;color:var(--muted);margin-bottom:14px}
.modal-card p small{font-size:10px}

/* Setup card taller */
.setup-card{max-height:92dvh;overflow-y:auto;padding-bottom:40px}

/* Form */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.fg{margin-bottom:12px}
.fg label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text2);margin-bottom:5px}
.fg input{
  width:100%;background:var(--card2);border:1.5px solid var(--border);
  border-radius:var(--r1);padding:11px 12px;color:var(--text);font-size:14px;
  transition:border-color .2s,box-shadow .2s;
}
.fg input:focus{border-color:var(--cyan);box-shadow:0 0 0 3px var(--cyan-g)}
.fg input::placeholder{color:var(--muted)}
.inline-note{
  margin-top:8px;padding:10px 12px;
  background:var(--card2);border:1px solid var(--border);border-radius:var(--r1);
  color:var(--text2);font-size:12px;font-weight:600;
}
.choice-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.choice-grid.two-up{grid-template-columns:repeat(2,1fr)}
.choice-btn{
  padding:11px 10px;background:var(--card2);border:1.5px solid var(--border);
  border-radius:var(--r1);color:var(--text2);font-size:13px;font-weight:700;
  transition:all .2s;
}
.choice-btn.active,.choice-btn:hover{border-color:var(--cyan);color:var(--cyan)}
.choice-btn.active{background:rgba(34,211,238,.12);box-shadow:0 0 0 2px rgba(34,211,238,.08) inset}

/* Overs sel */
.overs-sel{display:flex;gap:7px}
.ov-btn{
  flex:1;padding:9px 0;
  background:var(--card2);border:1.5px solid var(--border);border-radius:var(--r1);
  color:var(--text2);font-size:14px;font-weight:700;transition:all .2s;
}
.ov-btn.active{background:var(--cyan);border-color:var(--cyan);color:#0f172a}
.ov-btn:hover:not(.active){border-color:var(--cyan);color:var(--cyan)}

.modal-acts{display:flex;gap:8px;margin-top:12px}
.modal-acts .btn-primary{flex:1}

/* Mini selector */
.mini-sel{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;margin-top:6px}
.mini-btn{
  aspect-ratio:1;min-height:46px;
  background:var(--card2);border:1.5px solid var(--border);
  border-radius:var(--r1);color:var(--text);
  font-family:'Rajdhani',sans-serif;font-size:22px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  transition:all .15s;
}
.mini-btn:hover{border-color:var(--cyan);color:var(--cyan)}
.mini-btn:active,.mini-btn.sel{transform:scale(.86);background:var(--cyan);color:#0f172a;border-color:var(--cyan)}
.four-mini{background:var(--blue);border-color:var(--blue);color:#fff}
.six-mini {background:var(--purple);border-color:var(--purple);color:#fff}

/* Innings card */
.inn-card{border-top:4px solid var(--cyan)}
.inn-icon{font-size:48px;text-align:center;margin-bottom:6px;animation:bounce .7s ease infinite alternate}
.inn-score{
  background:var(--card2);border:1px solid var(--border);border-radius:var(--r2);
  padding:10px 14px;font-family:'Rajdhani',sans-serif;font-size:30px;font-weight:700;
  color:var(--cyan);text-align:center;margin-bottom:8px;
}

/* End card */
.end-card{
  border-radius:var(--r4);margin:18px;
  width:calc(100% - 36px);
  border-top:4px solid var(--amber);text-align:center;
}
#end-modal .modal-overlay{align-items:center}
#end-modal .modal-card{border-radius:var(--r4)}
.end-trophy{font-size:56px;margin-bottom:6px;animation:bounce .6s ease infinite alternate}
.celebration-badge{
  display:inline-flex;align-items:center;justify-content:center;
  padding:5px 12px;margin-bottom:8px;
  border-radius:8px;background:linear-gradient(135deg,var(--amber),#fb7185);
  color:#0f172a;font-size:11px;font-weight:800;letter-spacing:.7px;text-transform:uppercase;
}
.end-scores{background:var(--card2);border:1px solid var(--border);border-radius:var(--r2);padding:12px;margin-top:12px;text-align:left}
.end-inn{font-size:13px;font-weight:600;color:var(--text2);padding:3px 0}
.end-inn2{border-top:1px solid var(--border);padding-top:6px;margin-top:3px}
.end-result{font-family:'Rajdhani',sans-serif;font-size:20px;font-weight:700;color:var(--cyan);margin-top:8px;text-align:center}

/* Toast */
.toast{
  position:fixed;bottom:24px;left:50%;
  transform:translateX(-50%) translateY(0);
  background:var(--card2);border:1px solid var(--border);
  color:var(--text);padding:10px 20px;
  border-radius:8px;font-size:13px;font-weight:600;
  z-index:999;box-shadow:0 6px 22px rgba(0,0,0,.4);
  white-space:nowrap;transition:opacity .3s,transform .3s;
}
.toast.hidden{opacity:0;pointer-events:none;transform:translateX(-50%) translateY(20px)}

/* ══════════════════════════════════════════
   ANIMATIONS
══════════════════════════════════════════ */
@keyframes fadeDown{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeUp  {from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn  {from{opacity:0}to{opacity:1}}
@keyframes slideUp {from{transform:translateY(60px);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes pop     {0%{transform:scale(1)}40%{transform:scale(1.18)}100%{transform:scale(1)}}
@keyframes ballIn  {from{transform:scale(.4) rotate(-25deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}
@keyframes bounce  {from{transform:translateY(0)}to{transform:translateY(-10px)}}
@keyframes shake   {0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}

/* ══════════════════════════════════════════
   FULL SCORECARD PANEL
══════════════════════════════════════════ */
#full-scorecard-panel {
  position: fixed;
  inset: 0;
  z-index: 150;
  background: var(--bg2);
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(.4,0,.2,1);
}
#full-scorecard-panel.open {
  transform: translateX(0);
}
.fs-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px 20px; background: var(--bg2); border-bottom: 1px solid var(--border);
}
.fs-header h2 { font-size: 22px; font-weight: 800; color: var(--cyan); }
.fs-tabs { display: flex; background: var(--bg2); }
.fs-tab { flex: 1; padding: 14px; background: transparent; border: none; color: var(--text2); font-size: 14px; font-weight: 700; border-bottom: 3px solid transparent; transition: all 0.2s; }
.fs-tab.active { color: var(--cyan); border-bottom-color: var(--cyan); }
.fs-tab:hover:not(.active) { color: var(--text); }
.fs-content { flex: 1; overflow-y: auto; padding: 20px; display: flex; flex-direction: column; gap: 24px; background: var(--bg); }
.fs-section { background: var(--card); border: 1px solid var(--border); border-radius: var(--r3); padding: 16px; box-shadow: 0 4px 20px rgba(0,0,0,0.1); }
.fs-sec-title { display:flex; align-items:center; gap:6px; font-size: 13px; font-weight: 800; color: var(--muted); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 16px; }
.fs-table-wrap { overflow-x: auto; }
.fs-table { width: 100%; border-collapse: collapse; font-size: 13px; text-align: right; }
.fs-table th { color: var(--text2); padding: 8px 6px; font-weight: 600; border-bottom: 1px solid var(--border); }
.fs-table td { padding: 12px 6px; border-bottom: 1px dashed var(--border); color: var(--text); }
.fs-table tr:last-child td { border-bottom: none; }
.fs-name-col { text-align: left; max-width: 140px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-weight: 700; color:var(--text); }
.fs-howout { display: block; font-size: 10px; color: var(--muted); margin-top: 3px; font-weight: 500; text-transform: lowercase; }
.fs-fow { font-size: 13px; color: var(--text); line-height: 1.6; }

/* ── Responsive Architecture ── */
@media(min-width:400px){.run-btn{min-height:60px}.mini-btn{min-height:52px}}
@media(min-width:480px){.runs-count{font-size:80px}.run-btn{font-size:30px;min-height:66px}}

@media(min-width:640px){
  body.match-live { display:block; }
  body.match-live .screen.active { width:100%; max-width:560px; min-height:calc(100dvh - 72px); margin:0 auto; border-left:1px solid var(--border); border-right:1px solid var(--border); flex-shrink:0; display:flex; }
  
  /* On desktop, instead of pinning it, we just display it over the centered app */
  #full-scorecard-panel {
    max-width: 560px;
    margin: 0 auto;
    border-left: 1px solid var(--border);
    border-right: 1px solid var(--border);
  }
}

/* ── Export Mode for Sharing ── */
#full-scorecard-panel.export-mode {
  position: absolute !important;
  inset: unset !important;
  top: 0 !important;
  left: 0 !important;
  width: 500px !important;
  max-width: none !important;
  height: auto !important;
  overflow: visible !important;
  display: flex !important;
  transform: none !important;
  z-index: -999 !important;
  margin: 0 !important;
}
#full-scorecard-panel.export-mode .fs-content {
  overflow: visible !important;
  height: auto !important;
}
#full-scorecard-panel.export-mode #share-fs-btn,
#full-scorecard-panel.export-mode #close-fs-btn {
  display: none !important;
}

.site-nav{
  position:sticky;top:0;z-index:40;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 22px;background:rgba(8,15,30,.82);backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(148,163,184,.12);
  box-shadow:0 10px 30px rgba(2,8,23,.16);
}
body.light-mode .site-nav{
  background:rgba(255,255,255,.92);
  border-bottom:1px solid rgba(15,23,42,.06);
  box-shadow:0 12px 30px rgba(15,23,42,.06);
}
.site-nav__brand{
  color:var(--text);text-decoration:none;font-family:'Rajdhani',sans-serif;
  font-size:28px;font-weight:700;
  letter-spacing:.3px;
}
.site-nav__toggle{
  display:none;
  width:44px;
  height:44px;
  border-radius:8px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.04);
  color:var(--text);
  font-size:22px;
  line-height:1;
  align-items:center;
  justify-content:center;
  transition:all .2s;
}
.site-nav__toggle:hover{
  border-color:var(--cyan);
  color:var(--cyan);
}
.site-nav__links{display:flex;flex-wrap:wrap;gap:8px}
.site-nav__links a{
  color:var(--text2);text-decoration:none;font-size:12px;font-weight:700;
  padding:9px 12px;border:1px solid var(--border);border-radius:8px;background:rgba(255,255,255,.03);
}
.site-nav__links a:hover{color:var(--cyan);border-color:var(--cyan)}
.site-nav__theme{
  color:var(--text2);font-size:12px;font-weight:700;
  padding:9px 13px;border:1px solid var(--border);border-radius:8px;
  background:rgba(34,199,240,.10);
  transition:all .2s;
}
.site-nav__theme:hover{color:var(--cyan);border-color:var(--cyan);background:rgba(34,199,240,.14)}
body.light-mode .site-nav__brand{color:#0f172a}
body.light-mode .site-nav__links a{
  background:#f8fbff;
  border-color:#dbe7f3;
  color:#44556f;
}
body.light-mode .site-nav__theme{
  background:#ecfbff;
  border-color:#b8ebf7;
  color:#0c84b2;
}
body.light-mode .site-nav__toggle{
  background:rgba(15,23,42,.03);
  border-color:#cbd5e1;
  color:#334155;
}
.info-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--r3);
  padding:18px 16px;box-shadow:var(--sh);animation:fadeUp .45s var(--ease);
}
.info-eyebrow{
  display:inline-block;margin-bottom:8px;color:var(--cyan);font-size:10px;font-weight:800;
  letter-spacing:1px;text-transform:uppercase;
}
.info-card h2{font-size:22px;line-height:1.2;margin-bottom:10px}
.info-card p{color:var(--text2);font-size:14px;line-height:1.7}
.feature-list{display:grid;gap:10px}
.feature-item{
  background:var(--card2);border:1px solid var(--border);border-radius:var(--r2);padding:12px;
}
.feature-item h3{font-size:15px;margin-bottom:4px}
.feature-item p{font-size:13px}
.content-shell{
  width:100%;max-width:1040px;margin:0 auto;padding:28px 18px 72px;
}
.content-hero{
  background:linear-gradient(160deg,#0f1a2c 0%,#16253a 55%,#112033 100%);
  border:1px solid rgba(148,163,184,.14);border-radius:8px;padding:32px 28px;margin-bottom:22px;
  box-shadow:var(--sh);
}
body.light-mode .content-hero{background:linear-gradient(160deg,#ffffff 0%,#f6fbff 55%,#eef7ff 100%)}
.content-hero h1{font-size:36px;line-height:1.05;margin-bottom:12px}
.content-hero p{font-size:16px;line-height:1.85;color:var(--text2);max-width:760px}
.content-grid{display:grid;gap:16px}
.content-card{
  background:var(--card);border:1px solid var(--border);border-radius:8px;padding:22px;box-shadow:var(--sh);
}
.content-card h2{font-size:24px;margin-bottom:12px}
.content-card h3{font-size:18px;margin:14px 0 6px}
.content-card p,.content-card li{font-size:15px;line-height:1.85;color:var(--text2)}
.content-card ul{padding-left:18px}
.content-card a{color:var(--cyan)}
.article-list{display:grid;gap:12px}
.article-link{
  display:block;text-decoration:none;background:var(--card2);border:1px solid var(--border);
  border-radius:8px;padding:18px;color:var(--text);
}
.article-link:hover{border-color:var(--cyan);transform:translateY(-2px);box-shadow:0 12px 24px rgba(15,23,42,.08)}
.article-link h3{margin-bottom:6px}
.card-meta-row{
  display:flex;
  flex-wrap:wrap;
  gap:8px 14px;
  margin:6px 0 8px;
  color:var(--muted);
  font-size:12px;
  font-weight:600;
}
.article-cover{
  width:100%;
  border-radius:8px;
  border:1px solid var(--border);
  overflow:hidden;
  background:var(--card2);
  box-shadow:var(--sh);
}
.article-cover img{
  display:block;
  width:100%;
  height:auto;
}
.article-cover--preview{
  margin-bottom:14px;
  box-shadow:0 16px 32px rgba(2,8,23,.18);
}
.article-cover--preview img{
  aspect-ratio:16/9;
  object-fit:cover;
}
.cover-caption{
  margin-top:12px;
  font-size:13px !important;
  line-height:1.7 !important;
  color:var(--muted) !important;
}
.article-meta-row{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:10px 0 18px;
}
.article-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:8px 12px;
  border-radius:8px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.04);
  color:var(--text2);
  font-size:12px;
  font-weight:700;
}
.article-body{
  display:grid;
  gap:18px;
}
.article-body h2{
  margin-bottom:8px;
}
.article-body h3{
  margin:10px 0 6px;
}
.article-body strong{
  color:var(--text);
}
.internal-links{
  display:grid;
  gap:12px;
}
.internal-link-card{
  display:block;
  padding:16px;
  border-radius:8px;
  border:1px solid var(--border);
  background:var(--card2);
  color:var(--text);
  text-decoration:none;
}
.internal-link-card:hover{
  border-color:var(--cyan);
  transform:translateY(-1px);
}
.faq-list{
  display:grid;
  gap:12px;
}
.faq-item{
  padding:16px;
  border-radius:8px;
  border:1px solid var(--border);
  background:var(--card2);
}
.faq-item h3{
  margin:0 0 8px;
}
.blog-tools{
  display:grid;
  gap:16px;
}
.blog-page .content-shell{
  max-width:1280px;
}
.blog-layout{
  display:grid;
  gap:20px;
  align-items:start;
}
.blog-page .blog-tools{
  position:sticky;
  top:96px;
}
.blog-page .blog-listing{
  display:grid;
  gap:18px;
}
.blog-page .blog-card{
  height:100%;
}
.blog-page .blog-card h3{
  line-height:1.35;
}
.blog-page .blog-card p{
  margin-bottom:0;
}
.blog-search label{
  display:block;
  margin-bottom:8px;
  color:var(--text);
  font-size:14px;
  font-weight:700;
}
.blog-search input{
  width:100%;
  min-height:48px;
  padding:12px 14px;
  border-radius:8px;
  border:1px solid var(--border);
  background:var(--card2);
  color:var(--text);
}
.blog-filters{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}
.filter-chip{
  padding:10px 14px;
  border-radius:8px;
  border:1px solid var(--border);
  background:var(--card2);
  color:var(--text2);
  font-size:13px;
  font-weight:700;
}
.filter-chip.active{
  background:rgba(34,211,238,.14);
  border-color:var(--cyan);
  color:var(--cyan);
}
.author-box{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:14px;
  align-items:center;
  padding:18px;
  border-radius:8px;
  border:1px solid var(--border);
  background:var(--card2);
}
.author-badge{
  width:56px;
  height:56px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,var(--cyan),#0ea5e9);
  color:#082f49;
  font-size:20px;
  font-weight:900;
}
.author-box h3{
  margin:0 0 4px;
}
.author-box p{
  margin:0;
}
.share-box,
.reaction-box,
.comments-box{
  padding:18px;
  border-radius:8px;
  border:1px solid var(--border);
  background:var(--card2);
}
.share-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:10px;
}
.share-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  padding:10px 14px;
  border-radius:8px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.04);
  color:var(--text);
  text-decoration:none;
  font-size:14px;
  font-weight:700;
}
.share-btn:hover{
  border-color:var(--cyan);
  color:var(--cyan);
}
.reaction-row{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:12px;
  margin-top:10px;
}
.reaction-btn{
  min-height:46px;
  padding:10px 16px;
  border-radius:8px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.04);
  color:var(--text);
  font-size:14px;
  font-weight:800;
}
.reaction-btn.active{
  background:rgba(239,68,68,.14);
  border-color:#ef4444;
  color:#ef4444;
}
.reaction-count{
  color:var(--text2);
  font-size:14px;
  font-weight:700;
}
.comment-form{
  display:grid;
  gap:12px;
  margin-top:10px;
}
.comment-form input,
.comment-form textarea{
  width:100%;
  padding:12px 14px;
  border-radius:8px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.04);
  color:var(--text);
  resize:vertical;
}
.comment-list{
  display:grid;
  gap:12px;
  margin-top:16px;
}
.comment-item{
  padding:14px 16px;
  border-radius:8px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.03);
}
.comment-head{
  display:flex;
  justify-content:space-between;
  gap:12px;
  margin-bottom:8px;
  color:var(--text2);
  font-size:12px;
}
.comment-head strong{
  color:var(--text);
}
.comment-empty{
  color:var(--muted);
}
.article-page .content-shell{
  max-width:1120px;
}
.article-page .content-hero{
  padding:38px 34px;
}
.article-page .article-cover{
  margin-bottom:8px;
}
.article-page .content-grid{
  gap:20px;
}
.article-page .article-body{
  gap:22px;
  padding:30px 28px;
  max-width:none;
  margin:0;
}
.toc-box{
  padding:18px;
  border-radius:8px;
  border:1px solid var(--border);
  background:var(--card2);
}
.toc-links{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:10px;
  margin-top:10px;
}
.toc-links a{
  display:block;
  text-decoration:none;
  color:var(--text);
  padding:10px 12px;
  border-radius:8px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.04);
  font-size:14px;
  font-weight:600;
}
.toc-links a:hover{
  border-color:var(--cyan);
  color:var(--cyan);
}
.article-page .article-body > p:first-child{
  font-size:18px;
  line-height:1.95;
  color:var(--text);
}
.article-page .article-body p{
  font-size:17px;
  line-height:1.95;
}
.article-page .article-body h2{
  margin-top:8px;
  padding-top:18px;
  border-top:1px solid var(--border);
  font-size:32px;
  line-height:1.12;
}
.article-page .article-body h3{
  font-size:23px;
  margin:4px 0 2px;
}
.article-page .article-body ul{
  padding-left:0;
  display:grid;
  gap:10px;
}
.article-page .article-body li{
  list-style:none;
  padding:12px 14px;
  border-radius:8px;
  border:1px solid var(--border);
  background:var(--card2);
  font-size:16px;
  line-height:1.85;
}
.article-page .internal-link-card,
.article-page .faq-item{
  padding:18px;
}
.article-page .content-card{
  border-radius:8px;
}
body.light-mode.article-page .article-body li{
  background:#f8fafc;
}
body.light-mode .blog-search input,
body.light-mode .comment-form input,
body.light-mode .comment-form textarea,
body.light-mode .share-btn,
body.light-mode .reaction-btn{
  background:#fff;
}
.article-meta{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.8px}
#toggle-scorecard-btn,
#full-scorecard-panel{display:none !important;}

/* Global radius override */
.btn-primary,
.clear-btn,
.inn-badge,
.ball,
.partner-badge,
.xbadge,
.celebration-badge,
.toast,
.site-nav__toggle,
.site-nav__links a,
.site-nav__theme,
.content-hero,
.content-card,
.article-link,
.article-cover,
.article-pill,
.internal-link-card,
.faq-item,
.blog-search input,
.filter-chip,
.author-box,
.share-box,
.reaction-box,
.comments-box,
.share-btn,
.reaction-btn,
.comment-form input,
.comment-form textarea,
.comment-item,
.toc-box,
.toc-links a,
.article-page .article-body li,
.article-page .content-card,
.feature-item {
  border-radius:11px !important;
}

.modal-card{
  border-radius:11px 11px 0 0 !important;
}

@media(max-width:720px){
  .site-nav{
    align-items:center;
    justify-content:space-between;
    flex-wrap:wrap;
    gap:12px;
    padding:14px;
  }
  .site-nav__brand{
    text-align:left;
    font-size:24px;
    flex:1 1 auto;
  }
  .site-nav__toggle{
    display:flex;
  }
  .site-nav__links{
    width:100%;
    display:none;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:10px;
    padding-top:4px;
  }
  .site-nav.nav-open .site-nav__links{
    display:grid;
  }
  .site-nav__links a,
  .site-nav__theme{
    width:100%;
    min-height:48px;
    display:flex;
    align-items:center;
    justify-content:center;
    text-align:center;
    padding:10px 8px;
    font-size:12px;
    line-height:1.2;
  }
  #home-screen{
    padding:28px 14px 28px;
  }
  .home-wrap{
    gap:16px;
  }
  .logo-icon{
    font-size:52px;
  }
  .logo-title{
    font-size:34px;
  }
  .content-shell{
    padding:18px 14px 40px;
  }
  .content-hero{
    padding:24px 18px;
    border-radius:8px;
  }
  .content-hero h1{font-size:28px}
  .content-card{
    padding:18px 16px;
    border-radius:8px;
  }
  .article-page .content-hero{
    padding:24px 18px;
  }
  .blog-layout{
    grid-template-columns:1fr;
  }
  .blog-page .blog-tools{
    position:static;
  }
  .blog-page .blog-listing{
    grid-template-columns:1fr;
  }
  .article-page .article-body{
    padding:20px 16px;
    gap:18px;
  }
  .author-box{
    grid-template-columns:1fr;
    text-align:left;
  }
  .toc-box{
    padding:16px 14px;
  }
  .toc-links{
    grid-template-columns:1fr;
    gap:8px;
  }
  .article-page .article-body p{
    font-size:16px;
    line-height:1.9;
  }
  .article-page .article-body > p:first-child{
    font-size:17px;
  }
  .article-page .article-body h2{
    font-size:24px;
    padding-top:14px;
  }
  .article-page .article-body h3{
    font-size:19px;
  }
  .article-page .article-body li{
    font-size:15px;
    padding:11px 12px;
  }
  .share-actions{
    grid-template-columns:1fr;
  }
}

@media(max-width:480px){
  .site-nav__links{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .site-nav__links a,
  .site-nav__theme{
    min-height:46px;
    font-size:13px;
  }
  .home-wrap{
    max-width:100%;
  }
  .info-card h2{
    font-size:19px;
  }
}

@media(min-width:768px){
  #home-screen{
    padding:72px 28px 48px;
  }
  .home-wrap{
    max-width:760px;
    gap:22px;
  }
  .score-hero,
  .stats-row,
  .scoring-pad{
    max-width:760px;
    width:100%;
    margin-left:auto;
    margin-right:auto;
  }
  .top-bar{
    max-width:760px;
    width:100%;
    margin:0 auto;
    border-left:1px solid var(--border);
    border-right:1px solid var(--border);
    border-bottom-left-radius:18px;
    border-bottom-right-radius:18px;
  }
}

@media(min-width:900px){
  .blog-layout{
    grid-template-columns:300px minmax(0,1fr);
  }
  .blog-page .blog-listing{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media(min-width:1100px){
  #home-screen{
    padding:90px 32px 56px;
    justify-content:flex-start;
  }
  .home-wrap{
    max-width:1180px;
    display:grid;
    grid-template-columns:minmax(340px,420px) minmax(0,1fr);
    align-items:start;
    gap:24px;
  }
  .home-logo,
  .home-actions,
  .recent-section{
    grid-column:1;
  }
  .info-card{
    grid-column:2;
  }
  .home-logo{
    text-align:left;
    padding:12px 8px 0;
  }
  body.match-live .screen.active{
    max-width:620px;
  }
  #full-scorecard-panel{
    max-width:620px;
  }
  .logo-icon{margin-bottom:14px}
  .logo-sub{font-size:15px}
  .info-card{
    padding:24px 22px;
  }
  .feature-list{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media(min-width:1280px){
  .content-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
  .content-card:first-child:last-child{
    grid-column:1 / -1;
  }
  .article-page .content-grid{
    grid-template-columns:minmax(0,1.6fr) minmax(300px,.72fr);
    align-items:start;
  }
  .article-page .article-body{
    grid-column:1;
    grid-row:1 / span 2;
  }
  .article-page .toc-box{
    grid-column:2;
    grid-row:1;
    position:sticky;
    top:96px;
  }
  .article-page .author-box{
    grid-column:2;
    grid-row:2;
  }
}
