:root{
  --bg:#04090A;--s1:#081210;--s2:#0C1C18;--s3:#112820;
  --field:#1A4A28;--field2:#153D20;--pitch:#9B845A;--pitch2:#B09870;
  --gold:#C8A030;--gold2:#E8C060;--gold3:#8B6818;
  --cream:#F0ECD8;--t1:#D0ECCB;--t2:#7A9F7A;--t3:#3A5F3A;
  --danger:#E84444;--info:#4488EE;--success:#44CC44;--orange:#FF8844;
  --white:#FFFFFF;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{width:100%;height:100%;overflow:hidden}
body{background:var(--bg);color:var(--t1);font-family:'Rajdhani',sans-serif}
body::after{content:'';position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");pointer-events:none;z-index:9999}
.screen{display:none;width:100vw;height:100vh;position:absolute;top:0;left:0}
.screen.active{display:flex}
::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:var(--s1)}::-webkit-scrollbar-thumb{background:var(--gold3)}
h1,h2,h3{font-family:'Bebas Neue',sans-serif;letter-spacing:2px}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:.65rem 1.6rem;border:none;cursor:pointer;transition:all .2s;font-family:'Oswald',sans-serif;font-size:.75rem;letter-spacing:2px;text-transform:uppercase;clip-path:polygon(6px 0%,100% 0%,calc(100% - 6px) 100%,0% 100%)}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold3));color:#000;box-shadow:0 0 18px rgba(200,160,48,.35)}
.btn-gold:hover{box-shadow:0 0 32px rgba(200,160,48,.7);transform:translateY(-1px)}
.btn-green{background:linear-gradient(135deg,#2a6a2a,#1a4a1a);color:var(--gold2)}
.btn-green:hover{box-shadow:0 0 24px rgba(40,140,40,.4);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--t2);border:1px solid var(--s3)}
.btn-ghost:hover{border-color:var(--gold3);color:var(--gold2)}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover{box-shadow:0 0 18px rgba(232,68,68,.5)}
.btn-info{background:var(--info);color:#fff}
.btn-sm{padding:.35rem .9rem;font-size:.62rem}
.btn-lg{padding:.9rem 2.8rem;font-size:.85rem}
.btn:disabled{opacity:.3;cursor:not-allowed;transform:none!important;box-shadow:none!important}
input{width:100%;padding:.8rem 1.1rem;background:var(--s3);border:1px solid #1A3A28;color:var(--t1);font-family:'Rajdhani',sans-serif;font-size:1rem;outline:none;transition:border-color .2s}
input:focus{border-color:var(--gold3);box-shadow:0 0 0 2px rgba(200,160,48,.1)}
input::placeholder{color:var(--t3)}
label{font-family:'Oswald',sans-serif;font-size:.6rem;letter-spacing:2px;color:var(--t2);display:block;margin-bottom:.35rem;text-transform:uppercase}
.err{color:var(--danger);font-size:.8rem;min-height:1rem;margin-top:.3rem}
.gold-line{height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin:1.2rem 0}

/* ── AUTH SCREENS ── */
#screen-login,#screen-register{align-items:center;justify-content:center;flex-direction:column;background:radial-gradient(ellipse at 30% 50%,rgba(40,140,60,.08) 0%,transparent 60%),radial-gradient(ellipse at 70% 40%,rgba(200,160,48,.07) 0%,transparent 55%),var(--bg)}
.auth-card{position:relative;background:var(--s1);border:1px solid #1A3A28;padding:2.8rem 3.2rem;width:430px;max-width:95vw;animation:fadeUp .4s ease;box-shadow:0 20px 80px rgba(0,0,0,.6)}
.auth-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold),var(--success),transparent)}
.auth-logo{text-align:center;margin-bottom:1.8rem}
.auth-icon{font-size:3rem;display:block;margin-bottom:.3rem}
.auth-title{font-family:'Bebas Neue',sans-serif;font-size:2.5rem;letter-spacing:6px;background:linear-gradient(135deg,var(--gold),var(--success));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.auth-sub{font-family:'Oswald',sans-serif;font-size:.6rem;letter-spacing:4px;color:var(--t2);margin-top:.2rem}
.fg{margin-bottom:1rem}
.auth-foot{text-align:center;margin-top:1.2rem;font-size:.88rem;color:var(--t2)}
.auth-foot a{color:var(--gold2);text-decoration:none}.auth-foot a:hover{color:#fff}
.full-btn{width:100%;margin-top:1.2rem}

/* ── MENU ── */
#screen-menu{flex-direction:row}
.sidebar{width:260px;min-width:230px;background:var(--s1);border-right:1px solid #1A3A28;display:flex;flex-direction:column;padding:1.8rem 1.4rem;flex-shrink:0;position:relative}
.sidebar::after{content:'';position:absolute;right:0;top:0;bottom:0;width:2px;background:linear-gradient(180deg,transparent,var(--gold) 30%,var(--success) 70%,transparent)}
.sb-logo{margin-bottom:2rem;text-align:center}
.logo-big{font-family:'Bebas Neue',sans-serif;font-size:2rem;letter-spacing:6px;background:linear-gradient(135deg,var(--gold),var(--gold2));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.logo-sub{font-family:'Oswald',sans-serif;font-size:.5rem;letter-spacing:4px;color:var(--t3);text-transform:uppercase}
.nav{flex:1;display:flex;flex-direction:column;gap:.15rem}
.ni{display:flex;align-items:center;gap:.9rem;padding:.75rem 1rem;cursor:pointer;transition:all .18s;font-family:'Oswald',sans-serif;font-size:.7rem;letter-spacing:2px;color:var(--t2);border-left:2px solid transparent;text-transform:uppercase}
.ni:hover{color:var(--t1);background:rgba(255,255,255,.02)}
.ni.active{color:var(--gold2);border-left-color:var(--gold);background:rgba(200,160,48,.06)}
.ni-icon{font-size:1.2rem;width:1.4rem;text-align:center}
.ucard{background:var(--s2);border:1px solid #1A3A28;padding:.9rem;margin-top:.8rem}
.ucard::before{content:'';display:block;height:1px;background:linear-gradient(90deg,var(--gold),transparent);margin-bottom:.8rem}
.ucard-name{font-family:'Bebas Neue',sans-serif;font-size:1rem;letter-spacing:2px;color:var(--gold2)}
.ucard-rank{font-family:'Oswald',sans-serif;font-size:.6rem;letter-spacing:2px;color:var(--t2);margin-top:.15rem}
.ucard-pts{font-size:.82rem;color:var(--t2);margin-top:.4rem}.ucard-pts span{color:var(--gold2);font-weight:700}
.menu-main{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;overflow:hidden}
.panel{display:none;width:100%;max-width:740px;animation:fadeUp .28s ease;max-height:calc(100vh - 60px);overflow-y:auto}
.panel::-webkit-scrollbar{width:3px}.panel.active{display:block}
.ptitle{font-family:'Bebas Neue',sans-serif;font-size:2rem;letter-spacing:4px;color:var(--gold2);margin-bottom:.2rem}
.psub{color:var(--t2);font-size:.88rem;margin-bottom:1.2rem;font-family:'Oswald',sans-serif;font-size:.75rem;letter-spacing:1px}

/* TEAM GRID */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.65rem;margin-top:1rem}
.tc{position:relative;padding:.75rem .5rem;cursor:pointer;transition:all .2s;text-align:center;border:2px solid transparent;background:var(--s2)}
.tc:hover{border-color:rgba(255,255,255,.2);transform:translateY(-2px)}
.tc.sel{border-color:var(--gold)!important;box-shadow:0 0 16px rgba(200,160,48,.3)}
.tc-badge{width:48px;height:48px;border-radius:50%;margin:0 auto .45rem;display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:.8rem;letter-spacing:1px;border:2px solid rgba(255,255,255,.2);position:relative;overflow:hidden}
.tc-name{font-family:'Oswald',sans-serif;font-size:.58rem;letter-spacing:1.5px;color:var(--t1);line-height:1.2;text-transform:uppercase}
.tc-city{font-size:.6rem;color:var(--t2);margin-top:.1rem}
.tc-sel-mark{position:absolute;top:3px;right:5px;font-size:.7rem;color:var(--gold)}
.diff-row,.laps-row{display:flex;gap:.5rem;margin-top:.6rem}
.db{flex:1;padding:.45rem;background:var(--s2);border:1px solid #1A3A28;color:var(--t2);font-family:'Oswald',sans-serif;font-size:.6rem;letter-spacing:1.5px;cursor:pointer;transition:all .2s;text-transform:uppercase}
.db:hover,.db.act{border-color:var(--gold3);color:var(--gold2);background:rgba(200,160,48,.08)}

/* MATCHUP PREVIEW */
.matchup-bar{display:flex;align-items:center;justify-content:center;gap:1.5rem;padding:1.2rem;background:var(--s2);border-left:3px solid var(--gold);margin:1rem 0}
.mu-badge{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:.78rem;border:2px solid rgba(255,255,255,.2)}
.mu-name{font-family:'Oswald',sans-serif;font-size:.72rem;letter-spacing:1.5px;margin-top:.3rem;text-align:center}
.mu-vs{font-family:'Bebas Neue',sans-serif;font-size:2.2rem;color:var(--t3);letter-spacing:3px}

/* RANKINGS */
.rank-tbl{width:100%;border-collapse:collapse;font-size:.88rem}
.rank-tbl th{font-family:'Oswald',sans-serif;font-size:.58rem;letter-spacing:2px;color:var(--t2);padding:.5rem .7rem;border-bottom:1px solid #1A3A28;text-align:left;text-transform:uppercase}
.rank-tbl td{padding:.6rem .7rem;border-bottom:1px solid rgba(255,255,255,.03)}
.rank-tbl tr:hover td{background:var(--s2)}
.rank-tbl tr.me td{background:rgba(200,160,48,.06);color:var(--gold2)}
.rbadge{display:inline-block;padding:.1rem .45rem;font-family:'Oswald',sans-serif;font-size:.55rem;letter-spacing:1px;text-transform:uppercase}
.rNewcomer{background:rgba(100,100,100,.3);color:#aaa}
.rClub{background:rgba(0,140,180,.3);color:#60d0ff}
.rDistrict{background:rgba(0,180,100,.3);color:#60ffa0}
.rState{background:rgba(200,100,0,.3);color:#ffb060}
.rNational{background:rgba(160,0,200,.3);color:#dd80ff}
.rInternational{background:rgba(200,180,0,.3);color:#ffee40}
.rLegend{background:linear-gradient(135deg,rgba(200,160,48,.5),rgba(232,192,96,.4));color:#fff}

/* ── GAME SCREEN ── */
#screen-game{flex-direction:column;align-items:center;justify-content:flex-start;background:var(--bg);overflow:hidden}

/* SCOREBOARD */
.scoreboard{width:800px;max-width:100vw;background:var(--s1);border-bottom:2px solid var(--gold3);padding:.6rem 1.2rem;flex-shrink:0;position:relative}
.scoreboard::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--field),var(--gold),var(--field))}
.sb-teams{display:grid;grid-template-columns:1fr auto 1fr;gap:.5rem;align-items:center}
.sb-team{display:flex;align-items:center;gap:.6rem}
.sb-team.away{flex-direction:row-reverse;text-align:right}
.sb-abbr{font-family:'Bebas Neue',sans-serif;font-size:1.2rem;letter-spacing:2px}
.sb-runs{font-family:'Oswald',sans-serif;font-size:1.8rem;font-weight:700;color:var(--white);min-width:3ch;text-align:center}
.sb-ovrs{font-family:'Oswald',sans-serif;font-size:.65rem;color:var(--t2);letter-spacing:1px}
.sb-mid{text-align:center}
.sb-innings-lbl{font-family:'Oswald',sans-serif;font-size:.55rem;letter-spacing:2px;color:var(--t2)}
.sb-vs-txt{font-family:'Bebas Neue',sans-serif;font-size:1.4rem;color:var(--t3)}
.sb-status{font-family:'Oswald',sans-serif;font-size:.65rem;color:var(--gold2);letter-spacing:1px;text-align:center;margin-top:.2rem}
.sb-extra-row{display:flex;align-items:center;justify-content:space-between;margin-top:.4rem;padding-top:.4rem;border-top:1px solid #1A3A28}
.sb-stat{font-family:'Oswald',sans-serif;font-size:.6rem;letter-spacing:1px;color:var(--t2);display:flex;gap:.3rem;align-items:center}
.sb-stat span{color:var(--gold2);font-size:.75rem}
.over-dots{display:flex;gap:.25rem;align-items:center}
.over-dot{width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Oswald',sans-serif;font-size:.6rem;font-weight:700;flex-shrink:0}
.od-0{background:#2a2a2a;color:#888}
.od-1{background:#1a4a1a;color:#88ff88}
.od-2{background:#1a4a1a;color:#44ff44}
.od-3{background:#1a3a5a;color:#44aaff}
.od-4{background:#1a3a5a;color:#00aaff}
.od-6{background:#4a3a00;color:#ffcc00}
.od-W{background:#4a0000;color:#ff4444}
.od-E{background:#3a1a3a;color:#cc88ff}

/* GAME BODY */
.game-body{display:flex;gap:1rem;padding:.6rem 1rem;width:800px;max-width:100vw;flex:1;overflow:hidden;align-items:flex-start}

/* FIELD CANVAS */
.field-wrap{position:relative;flex-shrink:0}
#field-canvas{display:block;border-radius:4px}
.field-overlay{position:absolute;inset:0;pointer-events:none}
.shot-direction{position:absolute;inset:0;pointer-events:none;display:none}
.result-splash{position:absolute;inset:0;display:none;align-items:center;justify-content:center;flex-direction:column;pointer-events:none}
.result-splash.show{display:flex}
.splash-num{font-family:'Bebas Neue',sans-serif;font-size:4rem;letter-spacing:4px;filter:drop-shadow(0 0 20px currentColor);animation:splashIn .4s ease}
.splash-txt{font-family:'Oswald',sans-serif;font-size:.75rem;letter-spacing:3px;opacity:.8;margin-top:-.3rem}

/* RIGHT PANEL */
.right-panel{flex:1;display:flex;flex-direction:column;gap:.6rem;min-width:0}
.bat-info-card,.bowl-info-card{background:var(--s1);border:1px solid #1A3A28;padding:.7rem .9rem}
.bi-title{font-family:'Oswald',sans-serif;font-size:.58rem;letter-spacing:2px;color:var(--t2);text-transform:uppercase;margin-bottom:.5rem}
.bi-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.2rem;font-size:.82rem}
.bi-name{color:var(--t1);font-weight:600}
.bi-stat{font-family:'Oswald',sans-serif;font-size:.72rem;color:var(--gold2)}
.bi-on-strike{color:var(--gold2)}
.comm-card{background:var(--s1);border:1px solid #1A3A28;padding:.7rem .9rem;flex:1;overflow-y:auto;min-height:80px;max-height:130px}
.comm-card::-webkit-scrollbar{width:3px}
.comm-item{font-size:.82rem;line-height:1.5;margin-bottom:.3rem;padding-bottom:.3rem;border-bottom:1px solid rgba(255,255,255,.04)}
.comm-item:last-child{border-bottom:none}
.comm-ball{font-family:'Oswald',sans-serif;color:var(--gold2);margin-right:.4rem;font-size:.75rem}
.comm-text{color:var(--t2)}
.comm-result{font-family:'Oswald',sans-serif;font-weight:600}
.cr-six{color:var(--gold2)}.cr-four{color:var(--info)}.cr-wkt{color:var(--danger)}.cr-dot{color:var(--t3)}.cr-run{color:var(--success)}

/* CONTROLS */
.controls{width:800px;max-width:100vw;background:var(--s1);border-top:2px solid var(--gold3);padding:.7rem 1rem;flex-shrink:0}
.ctrl-phase{display:none}.ctrl-phase.active{display:block}
.ctrl-title{font-family:'Oswald',sans-serif;font-size:.62rem;letter-spacing:3px;color:var(--t2);text-transform:uppercase;margin-bottom:.55rem;display:flex;align-items:center;gap:.6rem}
.ctrl-title::after{content:'';flex:1;height:1px;background:var(--s3)}
.shot-btns{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.55rem}
.shot-btn{flex:1;min-width:80px;padding:.45rem .5rem;background:var(--s2);border:1px solid #1A3A28;color:var(--t2);font-family:'Oswald',sans-serif;font-size:.62rem;letter-spacing:1.5px;cursor:pointer;transition:all .18s;text-transform:uppercase;text-align:center}
.shot-btn:hover{border-color:var(--t3);color:var(--t1)}
.shot-btn.sel{border-color:var(--gold);color:var(--gold2);background:rgba(200,160,48,.12)}

/* TIMING BAR */
.timing-wrap{display:flex;align-items:center;gap:.8rem;margin-top:.5rem}
.timing-bar{flex:1;height:20px;border-radius:2px;position:relative;overflow:hidden;background:linear-gradient(90deg,#992222 0%,#992222 14%,#CC7700 14%,#CC7700 28%,#779900 28%,#779900 42%,#22AA22 42%,#22AA22 58%,#779900 58%,#779900 72%,#CC7700 72%,#CC7700 86%,#992222 86%,#992222 100%);cursor:pointer;box-shadow:inset 0 0 0 1px rgba(255,255,255,.1)}
.timing-cursor{position:absolute;top:-3px;bottom:-3px;width:5px;background:#fff;border-radius:2px;transform:translateX(-50%);box-shadow:0 0 10px rgba(255,255,255,.9),0 0 20px rgba(255,255,255,.5);transition:left 0s linear}
.timing-labels{display:flex;justify-content:space-between;font-family:'Oswald',sans-serif;font-size:.52rem;letter-spacing:1px;color:var(--t3);margin-top:.15rem}
.timing-hint{font-family:'Oswald',sans-serif;font-size:.62rem;letter-spacing:1px;color:var(--t2);white-space:nowrap}
.play-shot-btn{padding:.55rem 1.8rem;background:linear-gradient(135deg,var(--gold),var(--gold3));color:#000;font-family:'Oswald',sans-serif;font-size:.7rem;letter-spacing:2px;border:none;cursor:pointer;clip-path:polygon(6px 0%,100% 0%,calc(100% - 6px) 100%,0% 100%);transition:all .2s;font-weight:600;white-space:nowrap}
.play-shot-btn:hover{box-shadow:0 0 20px rgba(200,160,48,.6)}
.play-shot-btn:disabled{opacity:.3;cursor:not-allowed}

/* BOWLING CONTROLS */
.del-btns{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.55rem}
.del-btn{flex:1;min-width:80px;padding:.45rem .5rem;background:var(--s2);border:1px solid #1A3A28;color:var(--t2);font-family:'Oswald',sans-serif;font-size:.62rem;letter-spacing:1.5px;cursor:pointer;transition:all .18s;text-transform:uppercase;text-align:center}
.del-btn:hover{border-color:var(--t3);color:var(--t1)}
.del-btn.sel{border-color:var(--info);color:#80aaff;background:rgba(64,136,238,.1)}
.line-btns{display:flex;gap:.4rem;margin-bottom:.55rem}
.line-btn{flex:1;padding:.45rem;background:var(--s2);border:1px solid #1A3A28;color:var(--t2);font-family:'Oswald',sans-serif;font-size:.62rem;letter-spacing:2px;cursor:pointer;transition:all .18s;text-transform:uppercase}
.line-btn:hover{border-color:var(--t3);color:var(--t1)}
.line-btn.sel{border-color:var(--success);color:#80ff80;background:rgba(64,204,64,.08)}
.bowl-btn{padding:.55rem 1.8rem;background:linear-gradient(135deg,#1a6a1a,#0a4a0a);color:var(--gold2);font-family:'Oswald',sans-serif;font-size:.7rem;letter-spacing:2px;border:none;cursor:pointer;clip-path:polygon(6px 0%,100% 0%,calc(100% - 6px) 100%,0% 100%);transition:all .2s;font-weight:600}
.bowl-btn:hover{box-shadow:0 0 20px rgba(40,160,40,.4)}
.bowl-btn:disabled{opacity:.3;cursor:not-allowed}
.bowl-action-row{display:flex;align-items:center;gap:.8rem}

/* INNINGS BREAK */
#screen-innings{flex-direction:column;align-items:center;justify-content:center;background:var(--bg)}
.innings-card{background:var(--s1);border:1px solid #1A3A28;padding:2.5rem 3rem;max-width:520px;width:92%;text-align:center;position:relative}
.innings-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.innings-num{font-family:'Bebas Neue',sans-serif;font-size:1.2rem;letter-spacing:5px;color:var(--gold);margin-bottom:.5rem}
.innings-score{font-family:'Oswald',sans-serif;font-size:3rem;font-weight:700;color:var(--white);line-height:1;margin:.5rem 0}
.innings-target{font-family:'Oswald',sans-serif;font-size:1.1rem;color:var(--t2);letter-spacing:2px;margin:.5rem 0 1.5rem}

/* RESULT SCREEN */
#screen-result{flex-direction:column;align-items:center;justify-content:center;background:var(--bg)}
.result-card{background:var(--s1);border:1px solid #1A3A28;padding:2.2rem 2.8rem;max-width:580px;width:94%;position:relative}
.result-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold) 40%,var(--success) 60%,transparent)}
.result-winner{font-family:'Bebas Neue',sans-serif;font-size:2.5rem;letter-spacing:5px;text-align:center;margin-bottom:.3rem}
.result-detail{text-align:center;font-family:'Oswald',sans-serif;font-size:1rem;color:var(--t2);letter-spacing:2px;margin-bottom:1rem}
.result-scorecard{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin:1rem 0}
.rs-col{background:var(--s2);padding:.9rem;border:1px solid #1A3A28}
.rs-team{font-family:'Bebas Neue',sans-serif;font-size:1rem;letter-spacing:2px;margin-bottom:.3rem}
.rs-score{font-family:'Oswald',sans-serif;font-size:1.8rem;font-weight:700;color:var(--white)}
.rs-sub{font-size:.75rem;color:var(--t2);margin-top:.2rem;font-family:'Oswald',sans-serif}
.pts-earned{font-family:'Oswald',sans-serif;font-size:1.1rem;color:var(--gold2);text-align:center;letter-spacing:2px;margin:.8rem 0}
.res-btns{display:flex;gap:.7rem;justify-content:center;margin-top:1.2rem;flex-wrap:wrap}

/* TOURNAMENT SCREEN */
#screen-tournament{flex-direction:column;align-items:center;overflow-y:auto;padding:1.5rem 2rem;background:var(--bg)}
.tourn-title{font-family:'Bebas Neue',sans-serif;font-size:2.2rem;letter-spacing:6px;color:var(--gold2);text-align:center;margin-bottom:.3rem}
.bracket{display:flex;gap:0;align-items:center;justify-content:center;margin:1.2rem 0;overflow-x:auto;width:100%;padding-bottom:.5rem}
.br-round{display:flex;flex-direction:column;justify-content:space-around;min-width:175px}
.br-round-title{font-family:'Oswald',sans-serif;font-weight:700;font-size:.58rem;letter-spacing:2px;color:var(--gold3);text-align:center;text-transform:uppercase;padding-bottom:.4rem;border-bottom:1px solid #1A3A28;margin-bottom:.4rem}
.br-match{background:var(--s1);margin:.35rem 0;border-left:2px solid #1A3A28;overflow:hidden;transition:all .2s}
.br-match.active{border-left-color:var(--gold);box-shadow:0 0 12px rgba(200,160,48,.2)}
.br-match.done{opacity:.7}
.br-team{display:flex;align-items:center;gap:.45rem;padding:.45rem .65rem;font-size:.8rem;border-bottom:1px solid #1A3A28}
.br-team:last-child{border-bottom:none}
.br-team.winner{color:var(--gold2);font-weight:700}
.br-team.loser{color:var(--t3)}
.br-team.tbd{color:var(--t3);font-style:italic}
.br-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.br-conn{width:28px;display:flex;align-items:center}
.br-conn-line{width:100%;height:1px;background:#1A3A28}
.tourn-actions{display:flex;gap:.7rem;justify-content:center;flex-wrap:wrap;margin-top:1rem}
.trophy-box{text-align:center;margin:1rem 0}
.trophy-icon{font-size:3.5rem;display:block;filter:drop-shadow(0 0 15px rgba(200,160,48,.8))}
.trophy-text{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;letter-spacing:5px;color:var(--gold2)}
.cup-stands{width:100%;max-width:460px;margin:.8rem auto}
.cs-title{font-family:'Oswald',sans-serif;font-size:.55rem;letter-spacing:3px;color:var(--t2);text-align:center;margin-bottom:.5rem;text-transform:uppercase}
.cs-row{display:flex;align-items:center;gap:1rem;padding:.5rem .8rem;background:var(--s1);margin-bottom:.2rem;border:1px solid #1A3A28;font-size:.85rem}
.cs-row.pr{border-color:var(--gold);background:rgba(200,160,48,.06);color:var(--gold2)}
.cs-pos{font-family:'Bebas Neue',sans-serif;font-size:.9rem;width:1.8rem;color:var(--t2)}.cs-pos.p1{color:var(--gold2)}
.cs-pts{margin-left:auto;font-family:'Oswald',sans-serif;font-size:.72rem;color:var(--info)}

/* TEAMS PANEL */
.teams-detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem;margin-top:.8rem}
.td-card{background:var(--s2);border:1px solid #1A3A28;padding:.9rem;position:relative;overflow:hidden}
.td-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px}
.td-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.6rem}
.td-badge{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:.72rem;border:2px solid rgba(255,255,255,.2);flex-shrink:0}
.td-name{font-family:'Bebas Neue',sans-serif;font-size:.95rem;letter-spacing:2px;line-height:1.1}
.td-city{font-family:'Oswald',sans-serif;font-size:.58rem;color:var(--t2);letter-spacing:1px;text-transform:uppercase}
.td-stat-row{display:flex;justify-content:space-between;font-size:.78rem;margin-bottom:.2rem}
.td-stat-lbl{color:var(--t2);font-family:'Oswald',sans-serif;font-size:.58rem;letter-spacing:1px}
.td-stat-bar{width:80px;height:4px;background:var(--s3);border-radius:2px;margin-top:4px}
.td-stat-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--gold3),var(--success))}
.td-players{font-size:.72rem;color:var(--t3);margin-top:.5rem;line-height:1.5}

/* MODAL */
.modal-ov{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:999;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.modal-ov.open{display:flex}
.modal-box{background:var(--s1);border:1px solid #1A3A28;padding:2.2rem;max-width:380px;width:90%;position:relative;animation:fadeUp .25s ease}
.modal-box::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.modal-title{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;letter-spacing:3px;margin-bottom:.5rem}
.modal-sub{color:var(--t2);font-size:.88rem;line-height:1.5;margin-bottom:1.3rem;font-family:'Oswald',sans-serif;font-size:.75rem;letter-spacing:1px}
.modal-btns{display:flex;gap:.7rem;justify-content:center}
.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1rem;color:var(--t3);cursor:pointer;width:26px;height:26px;display:flex;align-items:center;justify-content:center}
.modal-close:hover{color:var(--t1)}

/* TOAST */
.toast{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%) translateY(80px);background:var(--s1);border:1px solid var(--gold3);color:var(--t1);padding:.7rem 1.8rem;font-family:'Oswald',sans-serif;font-size:.7rem;letter-spacing:1.5px;z-index:9000;transition:transform .35s cubic-bezier(.4,0,.2,1);white-space:nowrap}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast span{color:var(--gold2)}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes splashIn{0%{transform:scale(2.5);opacity:0}50%{transform:scale(.9);opacity:1}100%{transform:scale(1)}}
@keyframes ripple{0%{transform:scale(0);opacity:.7}100%{transform:scale(3);opacity:0}}

/* USER NAV */
.user-chip{display:none;align-items:center;gap:.4rem;font-family:'Oswald',sans-serif;font-size:.6rem;letter-spacing:1px;color:var(--t2)}
.user-chip.show{display:flex}
.user-dot{width:6px;height:6px;background:#44dd44;border-radius:50%}

/* PHASE INDICATOR */
.phase-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.25rem .7rem;font-family:'Oswald',sans-serif;font-size:.6rem;letter-spacing:2px;text-transform:uppercase}
.phase-batting{background:rgba(200,160,48,.15);color:var(--gold2);border:1px solid var(--gold3)}
.phase-bowling{background:rgba(64,204,64,.1);color:#80ff80;border:1px solid #2a6a2a}
.phase-ai{background:rgba(64,136,238,.1);color:#80aaff;border:1px solid #1a3a6a}

/* TOPBAR */
.game-topbar{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1.2rem;background:var(--s1);border-bottom:1px solid #1A3A28;width:800px;max-width:100vw;flex-shrink:0}
.topbar-logo{font-family:'Bebas Neue',sans-serif;font-size:1rem;letter-spacing:3px;color:var(--gold2)}
.topbar-phase{display:flex;align-items:center;gap:.5rem}
.topbar-btns{display:flex;gap:.4rem}

@media(max-width:820px){
  .scoreboard,.game-body,.controls,.game-topbar{width:100%}
  .game-body{flex-direction:column;gap:.5rem;padding:.4rem .6rem}
  .right-panel{max-height:160px}
  .team-grid{grid-template-columns:repeat(3,1fr)}
  .teams-detail-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  #screen-menu{flex-direction:column}
  .sidebar{width:100%;min-width:0;height:auto;border-right:none;border-bottom:1px solid #1A3A28;padding:.7rem}
  .sb-logo,.ucard{display:none}
  .nav{flex-direction:row;flex-wrap:wrap;gap:.2rem}
  .ni{font-size:.55rem;padding:.4rem .6rem;border-left:none;border-bottom:2px solid transparent}
  .ni.active{border-left:none;border-bottom-color:var(--gold)}
  .menu-main{padding:.7rem}
  .team-grid{grid-template-columns:repeat(3,1fr)}
  .teams-detail-grid{grid-template-columns:1fr 1fr}
  .shot-btns,.del-btns{gap:.25rem}
  .shot-btn,.del-btn{font-size:.55rem;padding:.35rem .3rem}
}