/* ══════════════════════════════════════
   SSPL v4 — Dark Stadium (Layout Fixed)
══════════════════════════════════════ */
:root {
  --bg:#070f1e; --bg2:#0a1628; --bg3:#0d1e38; --bg4:#102248;
  --card:#0d1e38; --card2:#102248;
  --border:rgba(74,127,196,0.18); --border2:rgba(74,127,196,0.3);
  --blue:#4a9eff; --blue-d:#1a3a7a; --blue-dim:rgba(74,158,255,0.12);
  --green:#4cd964; --green-d:#1a3a10;
  --red:#ff453a; --red-d:#3a1010;
  --orange:#ff9f0a; --orange-d:#3a2a08;
  --yellow:#ffd60a;
  --t1:#ffffff; --t2:#c8d8f0; --t3:#6a8ab0; --t4:#2a4a6a;
  --sb-bg:#061020; --sb-head:#0d2142; --sb-border:rgba(26,58,122,0.8);
  --nav-h:52px; --tab-h:60px;
  --r-s:8px; --r-m:12px; --r-l:16px; --r-f:9999px;
  --font:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{height:100%;height:-webkit-fill-available}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--t1);
  height:100vh;
  height:-webkit-fill-available;
  overflow:hidden;
  -webkit-font-smoothing:antialiased;
  display:flex;
  flex-direction:column;
}
button{font-family:var(--font);cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:var(--font)}
.hidden{display:none!important}

/* ── SPLASH ── */
.splash{
  position:fixed;inset:0;z-index:9999;
  background:linear-gradient(160deg,#0d2142 0%,#061020 100%);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .4s;
}
.splash-inner{text-align:center;animation:splashIn .5s ease both}
@keyframes splashIn{from{transform:scale(.85) translateY(20px);opacity:0}to{transform:none;opacity:1}}
.splash-icon{font-size:64px;margin-bottom:16px}
.splash-inner h1{font-size:28px;font-weight:800;color:#fff;letter-spacing:-.5px;margin-bottom:6px}
.splash-inner p{font-size:15px;color:var(--t3)}

/* ── SCREENS — flex column children of body ── */
.screen{
  flex:1;
  min-height:0;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}

/* ── LANDING ── */
#landing{
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  align-items:center;
  justify-content:center;
  padding:40px 24px;
}
.landing-logo{text-align:center;margin-bottom:32px}
.landing-icon{font-size:72px;margin-bottom:16px}
.landing-logo h1{font-size:32px;font-weight:800;color:#fff;letter-spacing:-.8px;margin-bottom:6px}
.landing-logo p{font-size:16px;color:var(--t3)}
.landing-actions{width:100%;max-width:380px;display:flex;flex-direction:column;gap:12px}
.landing-divider{display:flex;align-items:center;gap:12px;margin:4px 0}
.landing-divider::before,.landing-divider::after{content:'';flex:1;height:.5px;background:var(--border2)}
.landing-divider span{font-size:12px;color:var(--t4)}
.landing-note{text-align:center;font-size:12px;color:var(--t4);margin-top:-4px}

/* ── BUTTONS ── */
.btn-fill{
  width:100%;padding:14px;border-radius:var(--r-m);
  font-size:16px;font-weight:600;letter-spacing:-.2px;
  transition:opacity .15s,transform .1s;
  display:flex;align-items:center;justify-content:center;gap:8px;
}
.btn-fill:active{opacity:.82;transform:scale(.98)}
.btn-blue{background:var(--blue);color:#fff}
.btn-green{background:var(--green);color:#000}
.btn-red{background:var(--red);color:#fff}
.btn-orange{background:var(--orange);color:#000}
.btn-outline{background:transparent;border:1.5px solid var(--border2);color:var(--t2)}
.btn-ghost{background:rgba(255,255,255,.07);color:var(--t2)}
.btn-sm{padding:9px 18px;font-size:14px;font-weight:700;border-radius:var(--r-s);width:auto}
.btn-pill{padding:7px 16px;font-size:14px;font-weight:600;border-radius:var(--r-f);width:auto}

/* ── AUTH MODAL ── */
#auth-modal{
  position:fixed;inset:0;z-index:1000;
  background:rgba(0,0,0,.65);
  display:flex;align-items:flex-end;
  backdrop-filter:blur(6px);
}
.modal-sheet-auth{
  background:var(--bg2);
  border-radius:20px 20px 0 0;
  width:100%;max-height:92vh;
  overflow-y:auto;
  border-top:.5px solid var(--border2);
  animation:slideUp .28s cubic-bezier(.32,.72,0,1);
  padding-bottom:32px;
}
.auth-head{display:flex;align-items:center;gap:12px;padding:20px 20px 16px;border-bottom:.5px solid var(--border);margin-bottom:4px}
.auth-app-icon{width:44px;height:44px;border-radius:12px;background:var(--blue-d);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.auth-ttl{font-size:20px;font-weight:700;color:var(--t1)}
.auth-sub{font-size:13px;color:var(--t3);margin-top:2px}
.auth-inner{padding:0 20px;display:flex;flex-direction:column;gap:12px;margin-top:16px}
.seg-wrap{background:rgba(255,255,255,.06);border-radius:var(--r-m);padding:2px;display:flex;gap:2px}
.seg-btn{flex:1;padding:8px;font-size:13px;font-weight:600;color:var(--t3);border-radius:calc(var(--r-m) - 2px);transition:all .2s}
.seg-btn.active{background:var(--card2);color:var(--t1);box-shadow:0 1px 3px rgba(0,0,0,.3)}
.input-group{display:flex;flex-direction:column;gap:6px}
.input-group label{font-size:11px;font-weight:700;color:var(--t3);padding-left:4px;text-transform:uppercase;letter-spacing:.5px}
.lbl-hint{font-weight:400;color:var(--t4);text-transform:none;letter-spacing:0}
.input-group input,.input-group select{
  background:var(--bg3);border:1.5px solid var(--border);
  border-radius:var(--r-m);padding:13px 14px;
  font-size:16px;color:var(--t1);outline:none;
  transition:border-color .2s;-webkit-appearance:none;appearance:none
}
.input-group input:focus,.input-group select:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(74,158,255,.12)}
.input-group input::placeholder{color:var(--t4)}
.input-group select option{background:var(--bg3)}
.inline-error{background:rgba(255,69,58,.15);border:.5px solid rgba(255,69,58,.3);border-radius:var(--r-s);padding:10px 14px;font-size:14px;color:var(--red);font-weight:500}

/* ── MAIN APP LAYOUT ── */
#app{
  flex:1;min-height:0;
  display:flex;flex-direction:column;
  overflow:hidden;
}

/* Nav bar — fixed height at top of #app */
.nav-bar{
  flex-shrink:0;
  height:var(--nav-h);
  background:rgba(7,15,30,.96);
  border-bottom:.5px solid var(--border);
  display:flex;align-items:center;
  padding:0 16px;
  z-index:10;
}
.nav-back{display:flex;align-items:center;gap:5px;color:var(--blue);font-size:16px;font-weight:500;padding:8px 0;min-width:72px}
.nav-title{flex:1;text-align:center;font-size:17px;font-weight:700;color:var(--t1);letter-spacing:-.3px}
.nav-right{min-width:72px;display:flex;justify-content:flex-end}
.nav-avatar{width:32px;height:32px;border-radius:var(--r-f);background:var(--blue-d);border:1.5px solid var(--blue);color:var(--blue);font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;text-transform:uppercase}

/* Page container — flex:1 fills remaining space between nav and tab */
.page-container{
  flex:1;
  min-height:0;
  position:relative;
  overflow:hidden;
}

/* Tab bar — fixed height at bottom of #app */
.tab-bar{
  flex-shrink:0;
  height:var(--tab-h);
  background:rgba(7,15,30,.97);
  border-top:.5px solid var(--border);
  display:flex;align-items:center;
  padding:0 4px;
  z-index:10;
}
.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;color:var(--t4);font-size:10px;font-weight:500;letter-spacing:.2px;transition:color .15s}
.tab-item.active{color:var(--blue)}
.tab-item svg{flex-shrink:0}
.tab-fab-btn{position:relative}
.score-fab{width:44px;height:44px;border-radius:var(--r-f);background:var(--blue);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 12px rgba(74,158,255,.5);margin-bottom:2px}

/* Pages — absolute fill inside .page-container */
.page{
  position:absolute;inset:0;
  opacity:0;pointer-events:none;
  transform:translateX(24px);
  transition:opacity .2s ease,transform .2s ease;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}
.page.active{opacity:1;pointer-events:all;transform:none}
#page-scorer{overflow:hidden}
.page-scroll{padding:10px 0 20px}

/* ── GUEST APP ── */
#guest-app{
  flex:1;min-height:0;
  display:flex;flex-direction:column;
  overflow:hidden;
  background:var(--bg);
}
.guest-nav{
  flex-shrink:0;height:var(--nav-h);
  background:var(--sb-head);
  border-bottom:.5px solid var(--sb-border);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 16px;
}
.guest-back{color:var(--red);font-size:14px;font-weight:600;padding:8px 0}
.guest-title{font-size:16px;font-weight:700;color:var(--t2)}

/* ── SECTION ── */
.section{padding:6px 16px}
.section-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.section-lbl{font-size:11px;font-weight:700;color:var(--t4);text-transform:uppercase;letter-spacing:.8px}
.section-action{font-size:14px;font-weight:600;color:var(--blue)}

/* ── GREETING ── */
.greeting-block{padding:20px 20px 8px}
.greeting{font-size:28px;font-weight:800;color:var(--t1);letter-spacing:-.8px}
.greeting-sub{font-size:15px;color:var(--t3);margin-top:3px}

/* ── QUICK GRID ── */
.quick-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.quick-card{background:var(--card);border:.5px solid var(--border);border-radius:var(--r-l);padding:16px 14px;display:flex;flex-direction:column;align-items:flex-start;gap:10px;font-size:14px;font-weight:600;color:var(--t2);text-align:left;transition:transform .1s,background .1s}
.quick-card:active{transform:scale(.97);background:var(--card2)}
.quick-icon{width:40px;height:40px;border-radius:var(--r-m);display:flex;align-items:center;justify-content:center;font-size:20px}

/* ── ASSIGNED SCORER BANNER ── */
.scorer-banner{background:linear-gradient(135deg,var(--blue-d),rgba(26,58,122,.5));border:1px solid rgba(74,158,255,.3);border-radius:var(--r-l);padding:14px 16px;margin:0 16px 8px;display:flex;align-items:center;gap:12px;cursor:pointer}
.scorer-banner-icon{font-size:28px;flex-shrink:0}
.scorer-banner-title{font-size:11px;font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:.5px}
.scorer-banner-match{font-size:16px;font-weight:700;color:var(--t1);margin-top:2px}
.scorer-banner-sub{font-size:12px;color:var(--t3);margin-top:2px}
.scorer-banner-btn{margin-left:auto;background:var(--blue);color:#fff;font-size:13px;font-weight:700;padding:8px 14px;border-radius:var(--r-s);flex-shrink:0}

/* ── CARDS ── */
.card{background:var(--card);border:.5px solid var(--border);border-radius:var(--r-l);overflow:hidden}
.card-row{display:flex;align-items:center;padding:14px 16px;gap:12px;border-bottom:.5px solid var(--border);cursor:pointer;transition:background .1s}
.card-row:last-child{border-bottom:none}
.card-row:active{background:var(--card2)}
.chevron{color:var(--t4)}

/* ── EMPTY ── */
.empty{text-align:center;padding:48px 20px;color:var(--t3)}
.empty-icon{font-size:48px;margin-bottom:12px;opacity:.6}
.empty h3{font-size:17px;font-weight:600;color:var(--t2);margin-bottom:4px}
.empty p{font-size:14px}
.empty-sm{padding:20px;text-align:center;font-size:14px;color:var(--t4)}

/* ── MATCH CARD ── */
.match-card{background:var(--card);border:.5px solid var(--border);border-radius:var(--r-l);overflow:hidden;margin-bottom:10px;cursor:pointer;transition:transform .1s}
.match-card:active{transform:scale(.99)}
.mc-head{padding:9px 14px;display:flex;align-items:center;justify-content:space-between}
.mc-head.live{background:rgba(255,69,58,.18);border-bottom:.5px solid rgba(255,69,58,.3)}
.mc-head.scheduled{background:rgba(74,158,255,.08);border-bottom:.5px solid rgba(74,158,255,.15)}
.mc-head.complete{background:rgba(74,217,100,.07);border-bottom:.5px solid rgba(74,217,100,.12)}
.mc-tag{font-size:11px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.5px}
.mc-date{font-size:11px;color:var(--t4)}
.mc-body{padding:14px}
.mc-teams{display:flex;align-items:center;justify-content:space-between;gap:8px}
.mc-team{flex:1}
.mc-team-name{font-size:13px;font-weight:600;color:var(--t3)}
.mc-score{font-size:24px;font-weight:800;color:var(--t1);letter-spacing:-1px;line-height:1.1}
.mc-ov{font-size:11px;color:var(--t4);margin-top:1px}
.mc-vs{font-size:12px;color:var(--t4);font-weight:600}
.mc-result{font-size:13px;color:var(--t3);margin-top:8px;padding-top:8px;border-top:.5px solid var(--border)}
.live-badge{display:inline-flex;align-items:center;gap:5px;background:var(--red);color:#fff;font-size:11px;font-weight:700;padding:3px 8px;border-radius:var(--r-f);text-transform:uppercase;letter-spacing:.5px}
.live-dot{width:6px;height:6px;border-radius:50%;background:#fff;animation:pulse 1.4s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}

/* ── LEAGUE CARD ── */
.league-card{background:var(--card);border:.5px solid var(--border);border-radius:var(--r-l);overflow:hidden;margin-bottom:10px;cursor:pointer;transition:transform .1s}
.league-card:active{transform:scale(.99)}
.lc-banner{height:88px;position:relative;overflow:hidden;display:flex;align-items:flex-end;padding:14px}
.lc-banner::before{content:'🏆';position:absolute;right:-6px;top:-10px;font-size:64px;opacity:.1;transform:rotate(12deg)}
.lc-name{font-size:20px;font-weight:800;color:#fff;letter-spacing:-.3px}
.lc-body{padding:12px 14px}
.lc-pills{display:flex;gap:6px;flex-wrap:wrap}
.lc-pill{font-size:11px;font-weight:600;background:var(--bg3);color:var(--t3);padding:3px 10px;border-radius:var(--r-f);border:.5px solid var(--border)}
.lc-pill.active{background:var(--blue-dim);color:var(--blue);border-color:rgba(74,158,255,.3)}

/* ── LEAGUE HERO ── */
.ld-hero{padding:20px 20px 24px;position:relative;overflow:hidden}
.ld-hero::before{content:'🏆';position:absolute;right:0;top:-10px;font-size:100px;opacity:.08;transform:rotate(12deg)}
.ld-name{font-size:26px;font-weight:800;color:#fff;letter-spacing:-.5px}
.ld-sub{font-size:14px;color:rgba(255,255,255,.55);margin-top:4px}
.ld-pills{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.ld-pill{background:rgba(255,255,255,.12);color:rgba(255,255,255,.8);font-size:12px;font-weight:600;padding:4px 12px;border-radius:var(--r-f)}

/* ── POINTS TABLE ── */
.pt-wrap{background:var(--card);border:.5px solid var(--border);border-radius:var(--r-l);overflow:hidden;margin:6px 16px}
.pt-head,.pt-row{display:grid;grid-template-columns:3fr 1fr 1fr 1fr 1fr 1.2fr;padding:10px 14px;align-items:center}
.pt-head{background:var(--bg3);border-bottom:.5px solid var(--border)}
.pt-head span{font-size:10px;font-weight:700;color:var(--t4);text-align:center;text-transform:uppercase;letter-spacing:.3px}
.pt-head span:first-child{text-align:left}
.pt-row{border-bottom:.5px solid var(--border)}
.pt-row:last-child{border-bottom:none}
.pt-row span{font-size:14px;text-align:center;color:var(--t3)}
.pt-row span:first-child{text-align:left;font-weight:700;color:var(--t1)}
.pt-pts{font-weight:800!important;color:var(--blue)!important}
.pt-q{color:var(--green)!important}

/* ── FIXTURE CARD ── */
.fx-card{background:var(--card);border:.5px solid var(--border);border-radius:var(--r-m);padding:14px;margin:4px 16px;cursor:pointer;transition:transform .1s}
.fx-card:active{transform:scale(.99)}
.fx-row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.fx-team{font-size:15px;font-weight:700;color:var(--t1);flex:1}
.fx-score{font-size:20px;font-weight:800;letter-spacing:-.3px;color:var(--t1)}
.fx-vs{font-size:12px;color:var(--t4);font-weight:600;flex-shrink:0}
.fx-foot{display:flex;align-items:center;justify-content:space-between;margin-top:8px;padding-top:8px;border-top:.5px solid var(--border)}
.fx-meta{font-size:12px;color:var(--t4)}
.fx-status{font-size:11px;font-weight:700;padding:3px 8px;border-radius:var(--r-f);text-transform:uppercase;letter-spacing:.3px}
.s-sched{background:var(--bg3);color:var(--t4)}
.s-live{background:rgba(255,69,58,.18);color:var(--red)}
.s-done{background:rgba(74,217,100,.1);color:var(--green)}

/* ── TEAM CARD ── */
.team-card{background:var(--card);border:.5px solid var(--border);border-radius:var(--r-l);overflow:hidden;margin-bottom:10px;cursor:pointer;transition:transform .1s}
.team-card:active{transform:scale(.99)}
.tc-head{padding:16px;display:flex;align-items:center;gap:14px}
.tc-badge{width:52px;height:52px;border-radius:var(--r-m);display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0;background:var(--bg3)}
.tc-name{font-size:18px;font-weight:700;color:var(--t1)}
.tc-sub{font-size:13px;color:var(--t3);margin-top:2px}
.tc-foot{padding:10px 16px;background:var(--bg3);display:flex;gap:16px;border-top:.5px solid var(--border)}
.tc-stat{font-size:13px;color:var(--t3)}
.tc-stat strong{color:var(--t2);font-weight:700}

/* ── PLAYER ROW ── */
.pl-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:.5px solid var(--border)}
.pl-row:last-child{border-bottom:none}
.pl-num{width:28px;height:28px;border-radius:var(--r-f);background:var(--bg3);color:var(--t4);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pl-name{flex:1;font-size:15px;font-weight:600;color:var(--t1)}
.pl-role{font-size:12px;color:var(--t4)}
.pl-cap{font-size:11px;font-weight:700;color:var(--orange);background:var(--orange-d);padding:2px 8px;border-radius:var(--r-f)}

/* ── ROLE BADGE ── */
.role-badge{font-size:11px;font-weight:700;padding:3px 10px;border-radius:var(--r-f);text-transform:capitalize}
.rb-superadmin{background:#1a1440;color:#a78bfa;border:.5px solid #4c1d95}
.rb-organiser{background:rgba(74,158,255,.15);color:var(--blue);border:.5px solid rgba(74,158,255,.3)}
.rb-teammanager{background:var(--orange-d);color:var(--orange);border:.5px solid rgba(255,159,10,.3)}
.rb-scorer{background:rgba(74,217,100,.1);color:var(--green);border:.5px solid rgba(74,217,100,.25)}
.rb-player{background:var(--bg3);color:var(--t3);border:.5px solid var(--border)}
.rb-viewer{background:var(--bg3);color:var(--t4);border:.5px solid var(--border)}

/* ── STATS TABLE ── */
.st-wrap{background:var(--card);border:.5px solid var(--border);border-radius:var(--r-l);overflow:hidden;margin:6px 16px}
.st-head,.st-row{display:grid;padding:10px 14px;align-items:center}
.st-head{background:var(--bg3);border-bottom:.5px solid var(--border)}
.st-head span{font-size:10px;font-weight:700;color:var(--t4);text-align:right;text-transform:uppercase;letter-spacing:.3px}
.st-head span:first-child{text-align:left}
.st-row{border-bottom:.5px solid var(--border)}
.st-row:last-child{border-bottom:none}
.st-row span{font-size:14px;text-align:right;color:var(--t3)}
.st-row span:first-child{text-align:left;font-weight:700;color:var(--t1)}
.st-hi{color:var(--blue)!important;font-weight:800!important}
.bat-grid{grid-template-columns:3fr 1fr 1fr 1fr 1fr 1fr}
.bowl-grid{grid-template-columns:3fr 1fr 1fr 1fr 1fr 1.2fr}

/* ── AWARD CARD ── */
.aw-card{background:var(--card);border:.5px solid var(--border);border-radius:var(--r-l);overflow:hidden;margin:6px 16px}
.aw-head{padding:14px 16px;display:flex;align-items:center;gap:10px}
.aw-icon{font-size:22px}
.aw-title{font-size:15px;font-weight:700;color:#fff}
.aw-sub{font-size:12px;color:rgba(255,255,255,.6);margin-top:1px}
.aw-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:.5px solid var(--border)}
.aw-row:last-child{border-bottom:none}
.aw-rank{width:26px;height:26px;border-radius:var(--r-f);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0}
.r-gold{background:#3a2a00;color:#ffd60a}
.r-silver{background:#1a2030;color:#a0b0c8}
.r-bronze{background:#2a1a08;color:#cd7f32}
.r-other{background:var(--bg3);color:var(--t4)}
.aw-player{flex:1;font-size:14px;font-weight:600;color:var(--t1)}
.aw-team{font-size:11px;color:var(--t4)}
.aw-val{font-size:15px;font-weight:800;color:var(--blue)}

/* ══════════════════════════════════════
   LIVE SCORER
══════════════════════════════════════ */
.scorer-wrap{display:flex;flex-direction:column;height:100%;overflow:hidden}
.sb-head{background:var(--sb-head);padding:12px 16px;flex-shrink:0;border-bottom:.5px solid var(--sb-border)}
.sb-inn-tag{font-size:10px;font-weight:700;color:var(--t4);text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between}
.sb-teams{display:flex;align-items:center;justify-content:space-between;gap:8px}
.sb-t{flex:1}
.sb-t-name{font-size:10px;font-weight:600;color:var(--t4);text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px}
.sb-score{font-size:34px;font-weight:800;color:var(--t1);letter-spacing:-1.5px;line-height:1}
.sb-score.dim{color:var(--t4);font-size:24px;margin-top:4px}
.sb-ov{font-size:11px;color:var(--t3);margin-top:3px}
.sb-vs{font-size:13px;color:var(--t4);font-weight:600}
.sb-stats{display:flex;background:var(--sb-bg);border-radius:var(--r-m);overflow:hidden;margin-top:10px;border:.5px solid var(--sb-border)}
.sb-stat{flex:1;padding:7px 4px;text-align:center;border-right:.5px solid var(--sb-border)}
.sb-stat:last-child{border:none}
.sb-stat-v{font-size:15px;font-weight:800;color:var(--t1);line-height:1}
.sb-stat-l{font-size:9px;font-weight:600;color:var(--t4);text-transform:uppercase;letter-spacing:.4px;margin-top:2px}
.chase-bar{background:rgba(255,255,255,.08);border-radius:4px;height:4px;margin-top:10px;overflow:hidden}
.chase-fill{height:100%;background:var(--green);border-radius:4px;transition:width .5s ease}
.bat-section{background:var(--bg3);padding:10px 14px;flex-shrink:0;border-bottom:.5px solid var(--sb-border)}
.bat-cols{display:grid;grid-template-columns:3fr 1fr 1fr 1fr 1fr;gap:4px;margin-bottom:4px}
.bat-col-h{font-size:9px;font-weight:700;color:var(--t4);text-align:center;text-transform:uppercase;letter-spacing:.4px}
.bat-col-h:first-child{text-align:left}
.bat-bat-row{display:grid;grid-template-columns:3fr 1fr 1fr 1fr 1fr;gap:4px;align-items:center;padding:3px 0}
.bat-name{font-size:13px;font-weight:600;color:var(--t2)}
.bat-val{font-size:13px;font-weight:700;text-align:center;color:var(--t2)}
.bat-val.hi{color:var(--blue);font-weight:800;font-size:15px}
.bat-foot{display:flex;align-items:center;justify-content:space-between;margin-top:8px;padding-top:6px;border-top:.5px solid var(--border)}
.bowler-chip{background:var(--blue-dim);color:var(--blue);font-size:11px;font-weight:700;padding:4px 10px;border-radius:var(--r-f);border:.5px solid rgba(74,158,255,.3);cursor:pointer}
.over-section{background:var(--bg3);padding:8px 14px;flex-shrink:0;border-bottom:.5px solid var(--sb-border)}
.over-lbl{font-size:9px;font-weight:700;color:var(--t4);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;display:flex;align-items:center;justify-content:space-between}
.over-chips{display:flex;gap:5px;align-items:center;flex-wrap:wrap}
.bc{width:30px;height:30px;border-radius:var(--r-f);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0}
.bc-0{background:var(--sb-bg);border:.5px solid var(--sb-border);color:var(--t4)}
.bc-1,.bc-2,.bc-3{background:var(--bg3);border:.5px solid var(--border2);color:var(--t2)}
.bc-2{background:rgba(74,158,255,.1);color:#6ab4ff}
.bc-3{background:rgba(74,217,100,.1);color:var(--green)}
.bc-4{background:var(--blue-d);border:.5px solid rgba(74,158,255,.5);color:var(--blue)}
.bc-6{background:rgba(255,214,10,.12);border:.5px solid rgba(255,214,10,.4);color:var(--yellow);font-size:13px}
.bc-W{background:var(--red-d);border:.5px solid rgba(255,69,58,.4);color:var(--red)}
.bc-WD{background:rgba(175,82,222,.12);border:.5px solid rgba(175,82,222,.3);color:#bf5af2;font-size:9px}
.bc-NB{background:rgba(255,159,10,.1);border:.5px solid rgba(255,159,10,.3);color:var(--orange);font-size:9px}
.bc-B,.bc-LB{background:var(--sb-bg);border:.5px solid var(--sb-border);color:var(--t4);font-size:9px}
.pad{flex:1;overflow-y:auto;background:var(--sb-bg);padding:10px 12px 12px;display:flex;flex-direction:column;gap:8px}
.pad-lbl{font-size:10px;font-weight:700;color:var(--t4);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.run-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.rb{aspect-ratio:1;border-radius:var(--r-m);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:800;border:.5px solid var(--border);transition:transform .08s,opacity .1s}
.rb:active{transform:scale(.88);opacity:.85}
.rb-0{background:var(--bg3);color:var(--t4)}
.rb-1{background:var(--bg3);color:var(--t2)}
.rb-2{background:rgba(74,158,255,.1);color:#6ab4ff;border-color:rgba(74,158,255,.25)}
.rb-3{background:rgba(74,217,100,.08);color:var(--green);border-color:rgba(74,217,100,.2)}
.rb-4{background:var(--blue-d);color:var(--blue);border-color:rgba(74,158,255,.5);font-size:22px}
.rb-6{background:rgba(255,214,10,.12);color:var(--yellow);border-color:rgba(255,214,10,.4);font-size:22px}
.rb-W{background:var(--red-d);color:var(--red);border-color:rgba(255,69,58,.4);font-size:17px}
.extra-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}
.eb{padding:11px 4px;border-radius:var(--r-m);font-size:13px;font-weight:700;text-align:center;border:.5px solid var(--border);transition:transform .08s}
.eb:active{transform:scale(.93)}
.eb-wd{background:rgba(175,82,222,.1);color:#bf5af2;border-color:rgba(175,82,222,.25)}
.eb-nb{background:var(--orange-d);color:var(--orange);border-color:rgba(255,159,10,.25)}
.eb-b,.eb-lb{background:var(--bg3);color:var(--t3)}
.act-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px}
.ab{padding:11px 8px;border-radius:var(--r-m);font-size:13px;font-weight:700;text-align:center;border:.5px solid var(--border);transition:transform .08s}
.ab:active{transform:scale(.93)}
.ab-undo{background:var(--bg3);color:var(--t3)}
.ab-over{background:var(--blue-dim);color:var(--blue);border-color:rgba(74,158,255,.3)}
.ab-retire{background:var(--red-d);color:var(--red);border-color:rgba(255,69,58,.25)}
.viewer-banner{padding:20px;text-align:center;color:var(--t3);font-size:14px;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}

/* ── SCORECARD ── */
.sc-section{background:var(--card);border:.5px solid var(--border);border-radius:var(--r-l);overflow:hidden;margin:6px 16px}
.sc-hd{background:var(--bg3);padding:10px 14px;border-bottom:.5px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.sc-hd-title{font-size:14px;font-weight:700;color:var(--t2)}
.sc-hd-score{font-size:14px;font-weight:800;color:var(--blue)}
.sc-col-h{display:grid;grid-template-columns:3fr 1fr 1fr 1fr 1fr;padding:7px 14px;background:var(--bg3);border-bottom:.5px solid var(--border)}
.sc-col-h span{font-size:10px;font-weight:700;color:var(--t4);text-transform:uppercase;text-align:right}
.sc-col-h span:first-child{text-align:left}
.sc-bat-row{padding:10px 14px;border-bottom:.5px solid var(--border)}
.sc-bat-row:last-child{border-bottom:none}
.sc-bat-top{display:grid;grid-template-columns:3fr 1fr 1fr 1fr 1fr;gap:4px}
.sc-bat-top span{font-size:13px;text-align:right;color:var(--t3)}
.sc-bat-top span:first-child{text-align:left;font-weight:600;color:var(--t1)}
.sc-howout{font-size:11px;color:var(--t4);margin-top:2px}
.sc-bowl-row{display:grid;grid-template-columns:3fr 1fr 1fr 1fr 1fr;padding:10px 14px;border-bottom:.5px solid var(--border)}
.sc-bowl-row:last-child{border-bottom:none}
.sc-bowl-row span{font-size:13px;text-align:right;color:var(--t3)}
.sc-bowl-row span:first-child{text-align:left;font-weight:600;color:var(--t1)}

/* MOTM */
.motm-card{border-radius:var(--r-l);margin:6px 16px;padding:16px;display:flex;align-items:center;gap:14px;background:linear-gradient(135deg,#2a1a00,#3a2800);border:.5px solid rgba(255,214,10,.25)}
.motm-trophy{font-size:32px}
.motm-lbl{font-size:10px;font-weight:700;color:var(--orange);text-transform:uppercase;letter-spacing:.5px}
.motm-name{font-size:20px;font-weight:800;color:var(--t1)}
.motm-team{font-size:13px;color:var(--t3)}

/* ── SETUP FORM ── */
.setup-sec{margin-bottom:20px;padding:0 16px}
.setup-sec-title{font-size:11px;font-weight:700;color:var(--t4);text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px;padding-left:4px}
.form-card{background:var(--card);border:.5px solid var(--border);border-radius:var(--r-l);overflow:hidden}
.form-row{display:flex;align-items:center;padding:13px 16px;gap:12px;border-bottom:.5px solid var(--border)}
.form-row:last-child{border-bottom:none}
.form-row label{font-size:15px;flex:1;color:var(--t2)}
.form-row input,.form-row select{text-align:right;background:none;border:none;outline:none;font-size:15px;color:var(--blue);font-weight:500;flex:1;font-family:var(--font);-webkit-appearance:none}
.form-row input::placeholder{color:var(--t4);font-weight:400}
.form-row select option{background:var(--bg3)}
.stepper{display:flex;align-items:center;gap:12px}
.step-btn{width:28px;height:28px;border-radius:var(--r-f);background:var(--blue);color:#fff;font-size:18px;display:flex;align-items:center;justify-content:center;transition:opacity .15s}
.step-btn:disabled{opacity:.3}
.step-val{font-size:16px;font-weight:600;min-width:28px;text-align:center;color:var(--t1)}

/* ── ADMIN ── */
.admin-hero{background:linear-gradient(135deg,#0a0820,#14103a);padding:24px 20px;display:flex;align-items:center;gap:14px;border-bottom:.5px solid rgba(167,139,250,.15)}
.admin-icon{width:52px;height:52px;border-radius:var(--r-m);background:rgba(167,139,250,.1);display:flex;align-items:center;justify-content:center;font-size:26px}
.admin-title{font-size:22px;font-weight:800;color:#fff}
.admin-sub{font-size:13px;color:rgba(255,255,255,.4);margin-top:2px}
.user-row{display:flex;align-items:center;gap:12px;padding:13px 16px;border-bottom:.5px solid var(--border)}
.user-row:last-child{border-bottom:none}
.user-av{width:36px;height:36px;border-radius:var(--r-f);background:var(--blue-d);border:1px solid rgba(74,158,255,.3);color:var(--blue);font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;text-transform:uppercase}
.user-info{flex:1;min-width:0}
.user-name{font-size:15px;font-weight:600;color:var(--t1)}
.user-email{font-size:12px;color:var(--t4);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ── PROFILE ── */
.prof-head{background:var(--card);padding:28px 20px;display:flex;flex-direction:column;align-items:center;gap:10px;border-bottom:.5px solid var(--border)}
.prof-av{width:72px;height:72px;border-radius:var(--r-f);background:var(--blue-d);border:2px solid rgba(74,158,255,.4);color:var(--blue);font-size:28px;font-weight:700;display:flex;align-items:center;justify-content:center}
.prof-name{font-size:20px;font-weight:700;color:var(--t1)}
.list-section{background:var(--card);border:.5px solid var(--border);border-radius:var(--r-l);margin:8px 16px;overflow:hidden}
.list-row{display:flex;align-items:center;padding:14px 16px;border-bottom:.5px solid var(--border);gap:12px;cursor:pointer}
.list-row:last-child{border-bottom:none}
.list-row:active{background:var(--card2)}
.list-icon{font-size:18px;width:28px;text-align:center}
.list-label{flex:1;font-size:16px;color:var(--t2)}
.list-val{font-size:14px;color:var(--t3)}

/* ── MODAL SHEET ── */
.modal-overlay{
  position:fixed;inset:0;z-index:500;
  background:rgba(0,0,0,.65);
  display:flex;align-items:flex-end;
  backdrop-filter:blur(6px);
}
.modal-sheet{
  background:var(--bg2);
  border-radius:20px 20px 0 0;
  width:100%;max-height:90vh;
  overflow-y:auto;
  padding:8px 0 32px;
  border-top:.5px solid var(--border2);
  animation:slideUp .28s cubic-bezier(.32,.72,0,1);
}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:none}}
.sheet-handle{width:36px;height:4px;border-radius:2px;background:var(--border2);margin:0 auto 16px}
.sheet-title{font-size:18px;font-weight:700;color:var(--t1);padding:0 20px 16px;border-bottom:.5px solid var(--border);margin-bottom:16px}
.sheet-body{padding:0 20px;display:flex;flex-direction:column;gap:12px}
.sheet-actions{padding:16px 20px 0;display:flex;flex-direction:column;gap:10px}

/* ── SEGMENTED ── */
.seg-outer{padding:10px 16px 0}

/* ── TOAST ── */
.toast{
  position:fixed;
  bottom:calc(var(--tab-h) + 10px);
  left:50%;
  transform:translateX(-50%) translateY(12px);
  background:rgba(13,30,56,.97);
  border:.5px solid var(--border2);
  color:var(--t1);font-size:14px;font-weight:600;
  padding:10px 20px;border-radius:var(--r-f);
  z-index:600;white-space:nowrap;
  backdrop-filter:blur(12px);
  transition:opacity .25s,transform .25s;
  opacity:0;pointer-events:none;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.guest-mode{bottom:10px}

/* ── FX GEN ── */
.fx-gen-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:.5px solid var(--border)}
.fx-gen-item:last-child{border-bottom:none}
.fx-gen-num{width:24px;height:24px;border-radius:var(--r-f);background:var(--blue-dim);color:var(--blue);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fx-gen-teams{flex:1;font-size:14px;font-weight:600;color:var(--t2)}
.fx-gen-round{font-size:11px;color:var(--t4)}

@media(max-width:380px){
  .run-grid{gap:5px}.extra-grid{gap:5px}.act-grid{gap:5px}
  .rb{font-size:18px}.sb-score{font-size:28px}.sb-score.dim{font-size:20px}
}

/* ══ v5 ADDITIONS ══ */

/* Quick start cards with photo backgrounds */
.quick-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.quick-card {
  border-radius: var(--r-l); overflow: hidden;
  height: 110px; position: relative; cursor: pointer;
  border: .5px solid var(--border);
  transition: transform .1s, opacity .1s;
  display: flex; flex-direction: column;
  justify-content: flex-end; padding: 12px;
  background-size: cover; background-position: center;
}
.quick-card:active { transform: scale(.97); opacity: .9; }
.quick-card::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(7,15,30,.85) 0%, rgba(7,15,30,.2) 100%);
  z-index: 0;
}
.quick-card-icon { font-size: 22px; margin-bottom: 4px; position: relative; z-index: 1; }
.quick-card-label {
  font-size: 14px; font-weight: 700; color: #fff;
  position: relative; z-index: 1; letter-spacing: -.1px;
}
.quick-card-sub { font-size: 11px; color: rgba(255,255,255,.6); position: relative; z-index: 1; margin-top: 1px; }

/* Matches page tabs */
.match-tabs {
  display: flex; gap: 0; border-bottom: .5px solid var(--border);
  background: var(--bg2); padding: 0 16px; overflow-x: auto;
  scrollbar-width: none; flex-shrink: 0;
}
.match-tabs::-webkit-scrollbar { display: none; }
.match-tab {
  padding: 12px 16px; font-size: 13px; font-weight: 600;
  color: var(--t4); border-bottom: 2px solid transparent;
  white-space: nowrap; transition: color .15s;
  margin-bottom: -1px;
}
.match-tab.active { color: var(--blue); border-bottom-color: var(--blue); }

/* Match status chips */
.match-status-row {
  display: flex; gap: 8px; align-items: center;
  padding: 8px 16px; overflow-x: auto;
  scrollbar-width: none; border-bottom: .5px solid var(--border);
}
.match-status-row::-webkit-scrollbar { display: none; }
.msr-chip {
  padding: 6px 14px; border-radius: var(--r-f);
  font-size: 12px; font-weight: 700;
  white-space: nowrap; cursor: pointer;
  border: .5px solid var(--border); transition: all .15s;
  background: var(--bg3); color: var(--t3);
}
.msr-chip.active { background: var(--blue); color: #fff; border-color: var(--blue); }

/* NB mini-pad */
.nb-pad {
  display: grid; grid-template-columns: repeat(6, 1fr);
  gap: 8px; padding: 4px 0;
}
.nb-btn {
  aspect-ratio: 1; border-radius: var(--r-m);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; font-weight: 800;
  border: .5px solid var(--border);
  transition: transform .08s;
}
.nb-btn:active { transform: scale(.88); }
.nb-0 { background: var(--bg3); color: var(--t4); }
.nb-1 { background: var(--bg3); color: var(--t2); }
.nb-2 { background: rgba(74,158,255,.1); color: #6ab4ff; }
.nb-3 { background: rgba(74,217,100,.08); color: var(--green); }
.nb-4 { background: var(--blue-d); color: var(--blue); border-color: rgba(74,158,255,.4); }
.nb-6 { background: rgba(255,214,10,.12); color: var(--yellow); border-color: rgba(255,214,10,.4); }

/* End match / cancel button in scorer */
.end-match-btn {
  background: rgba(255,69,58,.12); color: var(--red);
  border: .5px solid rgba(255,69,58,.3);
  border-radius: var(--r-s); padding: 8px 14px;
  font-size: 13px; font-weight: 700;
  transition: background .15s;
}
.end-match-btn:active { background: rgba(255,69,58,.25); }

/* Cancelled banner */
.cancelled-banner {
  background: rgba(255,69,58,.12);
  border: .5px solid rgba(255,69,58,.25);
  border-radius: var(--r-l); margin: 6px 16px;
  padding: 14px 16px; text-align: center;
}
.cancelled-banner-title { font-size: 16px; font-weight: 700; color: var(--red); margin-bottom: 4px; }
.cancelled-banner-sub { font-size: 13px; color: var(--t3); }

/* Today badge */
.today-badge {
  background: rgba(74,217,100,.12);
  border: .5px solid rgba(74,217,100,.25);
  color: var(--green);
  font-size: 11px; font-weight: 700;
  padding: 2px 8px; border-radius: var(--r-f);
  display: inline-flex; align-items: center; gap: 4px;
}

/* ── QUICK START HERO CARDS ── */
.quick-grid-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto;
  gap: 10px;
}
.qh-card {
  position: relative;
  border-radius: var(--r-l);
  height: 90px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-end;
  padding: 12px 14px;
  cursor: pointer;
  transition: transform .1s;
  border: .5px solid var(--border);
}
.qh-card:active { transform: scale(.97); }
.qh-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(160deg, transparent 30%, rgba(0,0,0,.55) 100%);
  z-index: 0;
}
/* Background images using gradient "paintings" since we can't load external images */
.qh-batting  { background: linear-gradient(135deg, #0d2a4a 0%, #1a3a6a 40%, #0d4a2a 100%); }
.qh-bowling  { background: linear-gradient(135deg, #2a0d3a 0%, #1a1a5a 40%, #3a2a0a 100%); }
.qh-fielding { background: linear-gradient(135deg, #1a2a0a 0%, #0d3a2a 40%, #1a1a3a 100%); }
.qh-upcoming { background: linear-gradient(135deg, #2a1a0a 0%, #3a2a10 40%, #0d1a3a 100%); }
.qh-emoji {
  position: relative; z-index: 1;
  font-size: 26px; line-height: 1;
  margin-bottom: 2px;
}
.qh-label {
  position: relative; z-index: 1;
  font-size: 13px; font-weight: 700;
  color: rgba(255,255,255,.9);
  letter-spacing: -.1px;
}
.qh-lock {
  position: absolute; top: 8px; right: 8px;
  font-size: 14px; z-index: 1; opacity: .6;
}

/* ── MATCH TABS ── */
.match-tabs {
  display: flex;
  gap: 6px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding-bottom: 8px;
  margin-bottom: 4px;
}
.match-tabs::-webkit-scrollbar { display: none; }
.mtab {
  flex-shrink: 0;
  padding: 6px 14px;
  border-radius: var(--r-f);
  font-size: 13px; font-weight: 600;
  color: var(--t4);
  background: var(--bg3);
  border: .5px solid var(--border);
  transition: all .15s;
  white-space: nowrap;
}
.mtab.active {
  background: var(--blue-dim);
  color: var(--blue);
  border-color: rgba(74,158,255,.35);
}
