:root{
  --bg:#060810;--s1:#0c0e1c;--s2:#121428;--s3:#1a1c35;
  --orange:#F96B0A;--orange2:#ffaa44;--gold:#FFD700;
  --t1:#EEF2FF;--t2:#8899cc;--t3:#445577;
  --success:#22cc66;--danger:#ee2244;
}
*,*::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}
.screen{display:none;width:100vw;height:100vh;position:absolute;top:0;left:0}
.screen.active{display:flex}
h1,h2,h3{font-family:'Bebas Neue',sans-serif;letter-spacing:2px}
.bb-title{font-family:'Bebas Neue',sans-serif;font-size:3.5rem;letter-spacing:8px;background:linear-gradient(135deg,var(--orange) 0%,var(--gold) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;filter:drop-shadow(0 0 25px rgba(249,107,10,0.6))}
.bb-sub{font-family:'Barlow Condensed',sans-serif;font-size:0.7rem;letter-spacing:8px;color:var(--t2);text-transform:uppercase;margin-top:0.2rem}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0.65rem 1.8rem;border:none;cursor:pointer;transition:all 0.18s;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:0.85rem;letter-spacing:3px;text-transform:uppercase;clip-path:polygon(6px 0%,100% 0%,calc(100% - 6px) 100%,0% 100%)}
.btn-orange{background:var(--orange);color:#fff;box-shadow:0 0 20px rgba(249,107,10,0.35)}
.btn-orange:hover{box-shadow:0 0 35px rgba(249,107,10,0.7);transform:translateY(-2px)}
.btn-gold{background:linear-gradient(135deg,var(--gold),#e8a000);color:#000}
.btn-gold:hover{box-shadow:0 0 25px rgba(255,215,0,0.6);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--t2);border:1px solid var(--t3)}
.btn-ghost:hover{color:var(--orange);border-color:var(--orange)}
.btn-dark{background:var(--s2);color:var(--t1);border:1px solid var(--s3)}
.btn-dark:hover{border-color:var(--t2)}
.btn-sm{padding:0.35rem 1rem;font-size:0.72rem}
.btn-lg{padding:0.9rem 2.8rem;font-size:1rem}
.btn:disabled{opacity:0.35;cursor:not-allowed;transform:none!important;box-shadow:none!important}
input{width:100%;padding:0.85rem 1.2rem;background:var(--s3);border:1px solid #222244;color:var(--t1);font-family:'Rajdhani',sans-serif;font-size:1rem;outline:none;transition:border-color 0.2s;border-radius:2px}
input:focus{border-color:var(--orange);box-shadow:0 0 0 2px rgba(249,107,10,0.1)}
input::placeholder{color:var(--t3)}
label{font-family:'Barlow Condensed',sans-serif;font-size:0.65rem;letter-spacing:2px;color:var(--t2);display:block;margin-bottom:0.3rem;text-transform:uppercase}
.err{color:var(--danger);font-size:0.82rem;min-height:1.1rem;margin-top:0.3rem}
.oline{height:2px;background:linear-gradient(90deg,transparent,var(--orange),var(--gold),transparent);margin:1.5rem 0}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--s1)}::-webkit-scrollbar-thumb{background:var(--t3)}

/* ── AUTH ── */
#screen-login,#screen-register{align-items:center;justify-content:center;flex-direction:column;background:radial-gradient(ellipse at 30% 50%,rgba(249,107,10,0.09) 0%,transparent 60%),radial-gradient(ellipse at 70% 30%,rgba(30,40,120,0.1) 0%,transparent 55%),var(--bg)}
.auth-card{position:relative;background:var(--s1);width:420px;max-width:95vw;padding:2.8rem 3.2rem;animation:fadeUp 0.4s ease;box-shadow:0 20px 80px rgba(0,0,0,0.7)}
.auth-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--orange) 40%,var(--gold) 60%,transparent)}
.auth-logo{text-align:center;margin-bottom:1.8rem}
.auth-icon{font-size:3rem;display:block;margin-bottom:0.3rem}
.fg{margin-bottom:1rem}
.auth-foot{text-align:center;margin-top:1.2rem;font-size:0.88rem;color:var(--t2)}
.auth-foot a{color:var(--orange);text-decoration:none}
.auth-foot a:hover{color:var(--gold)}
.full-btn{width:100%;margin-top:1.2rem}

/* ── MENU ── */
#screen-menu{flex-direction:row}
.sidebar{width:265px;min-width:240px;background:var(--s1);border-right:1px solid var(--s3);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(--orange) 30%,var(--gold) 70%,transparent)}
.sb-logo{margin-bottom:2rem}
.sb-logo .bb-title{font-size:2.2rem;letter-spacing:6px}
.nav{flex:1;display:flex;flex-direction:column;gap:0.15rem}
.ni{display:flex;align-items:center;gap:0.9rem;padding:0.78rem 1rem;cursor:pointer;transition:all 0.18s;font-family:'Barlow Condensed',sans-serif;font-size:0.8rem;font-weight:700;letter-spacing:3px;color:var(--t2);border-left:3px solid transparent;text-transform:uppercase}
.ni:hover{color:var(--t1);background:rgba(255,255,255,0.02)}
.ni.active{color:var(--orange);border-left-color:var(--orange);background:rgba(249,107,10,0.06)}
.ni-icon{font-size:1.2rem;width:1.5rem;text-align:center}
.ucard{background:var(--s2);padding:1rem;margin-top:0.8rem;border-top:1px solid var(--s3)}
.ucard-name{font-family:'Bebas Neue',sans-serif;font-size:1.1rem;color:var(--orange);letter-spacing:2px}
.ucard-rank{font-family:'Barlow Condensed',sans-serif;font-size:0.65rem;letter-spacing:2px;color:var(--t2);margin-top:0.2rem}
.ucard-pts{font-size:0.82rem;color:var(--t2);margin-top:0.4rem}.ucard-pts span{color:var(--gold);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:720px;animation:fadeUp 0.28s ease;max-height:calc(100vh - 40px);overflow-y:auto}
.panel::-webkit-scrollbar{width:3px}
.panel.active{display:block}
.ptitle{font-family:'Bebas Neue',sans-serif;font-size:1.8rem;letter-spacing:4px;color:var(--t1)}
.psub{color:var(--t2);font-size:0.88rem;margin-top:0.2rem}

/* Team grid */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0.7rem;margin-top:1rem}
.tc{position:relative;padding:0.9rem 0.6rem;cursor:pointer;transition:all 0.2s;text-align:center;border:2px solid transparent;background:var(--s2)}
.tc:hover{border-color:rgba(255,255,255,0.2);transform:translateY(-2px)}
.tc.sel{border-color:var(--gold) !important;box-shadow:0 0 20px rgba(255,215,0,0.25)}
.tc-badge{width:52px;height:52px;border-radius:50%;margin:0 auto 0.5rem;display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:0.85rem;letter-spacing:1px;border:2px solid rgba(255,255,255,0.2)}
.tc-name{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:0.65rem;letter-spacing:1.5px;color:var(--t1);line-height:1.2}
.tc-city{font-size:0.62rem;color:var(--t2);margin-top:0.1rem}
.tc-check{position:absolute;top:4px;right:6px;font-size:0.8rem;color:var(--gold)}

/* Matchup display */
.matchup-bar{display:flex;align-items:center;justify-content:center;gap:1.5rem;padding:1.2rem;background:var(--s2);margin:1rem 0;border-left:3px solid var(--orange)}
.mu-team{text-align:center}
.mu-badge{width:48px;height:48px;border-radius:50%;margin:0 auto 0.3rem;display:flex;align-items:center;justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:0.8rem;border:2px solid rgba(255,255,255,0.2)}
.mu-name{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:0.72rem;letter-spacing:1.5px}
.mu-vs{font-family:'Bebas Neue',sans-serif;font-size:2rem;color:var(--t3);letter-spacing:3px}

/* Diff/Quarter sel */
.sel-row{display:flex;gap:0.5rem;margin-top:0.6rem}
.sb2{flex:1;padding:0.45rem;background:var(--s2);border:1px solid var(--s3);color:var(--t2);font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:0.68rem;letter-spacing:2px;cursor:pointer;text-transform:uppercase;transition:all 0.18s}
.sb2:hover,.sb2.act{border-color:var(--orange);color:var(--orange);background:rgba(249,107,10,0.07)}

/* Rankings table */
.rank-tbl{width:100%;border-collapse:collapse;font-size:0.88rem}
.rank-tbl th{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:0.6rem;letter-spacing:2px;color:var(--t2);padding:0.5rem 0.7rem;border-bottom:1px solid var(--s3);text-align:left;text-transform:uppercase}
.rank-tbl td{padding:0.65rem 0.7rem;border-bottom:1px solid rgba(255,255,255,0.03)}
.rank-tbl tr:hover td{background:var(--s2)}
.rank-tbl tr.me td{background:rgba(249,107,10,0.06);color:var(--orange)}
.rank-badge{display:inline-block;padding:0.1rem 0.5rem;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:0.6rem;letter-spacing:1.5px;text-transform:uppercase}
.rbRookie{background:rgba(120,120,120,0.3);color:#aaa}
.rbAmateur{background:rgba(0,160,220,0.3);color:#60ccff}
.rbPro{background:rgba(0,210,100,0.3);color:#60ffaa}
.rbAllStar{background:rgba(220,150,0,0.3);color:#ffcc50}
.rbMVP{background:rgba(180,0,220,0.3);color:#ee80ff}
.rbChampion{background:rgba(200,180,0,0.3);color:#ffe040}
.rbLegend{background:linear-gradient(135deg,rgba(249,107,10,0.5),rgba(255,215,0,0.4));color:#fff}

/* ── GAME ── */
#screen-game{flex-direction:column;align-items:center;justify-content:center;background:#000}
.scoreboard{display:flex;align-items:center;justify-content:space-between;width:800px;max-width:100%;height:64px;background:var(--s1);position:relative;overflow:hidden;flex-shrink:0}
.scoreboard::before{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--sboard-away,#555),var(--sboard-home,#888))}
.sb-team{display:flex;align-items:center;gap:0.6rem;padding:0 1rem;flex:1}
.sb-team.away{flex-direction:row-reverse;text-align:right}
.sb-abbr{font-family:'Bebas Neue',sans-serif;font-size:1.4rem;letter-spacing:2px}
.sb-score{font-family:'Bebas Neue',sans-serif;font-size:2.4rem;letter-spacing:2px;min-width:2.2ch;text-align:center}
.sb-score.flash{animation:scoreFlash 0.5s ease}
.sb-mid{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 1rem;min-width:120px}
.sb-qtr{font-family:'Barlow Condensed',sans-serif;font-size:0.6rem;letter-spacing:2px;color:var(--t2)}
.sb-time{font-family:'Bebas Neue',sans-serif;font-size:1.5rem;color:var(--t1);letter-spacing:3px}
.sb-shot{font-family:'Bebas Neue',sans-serif;font-size:0.85rem;color:var(--danger);letter-spacing:2px}
.sb-shot.warn{color:#ff8800;animation:pulse 0.5s infinite}
.game-wrap{position:relative;flex-shrink:0}
#gc{display:block}
.ctrl-bar{display:flex;align-items:center;justify-content:center;gap:1.5rem;padding:0.4rem 1rem;font-family:'Barlow Condensed',sans-serif;font-size:0.7rem;letter-spacing:1.5px;color:var(--t3);width:800px;max-width:100%;flex-shrink:0}
.ctrl-bar span{color:var(--t2)}
.g-action-btns{position:absolute;top:6px;right:8px;display:flex;gap:0.4rem;z-index:10}
.score-popup{position:absolute;pointer-events:none;font-family:'Bebas Neue',sans-serif;font-size:2.8rem;letter-spacing:4px;animation:scorePopAnim 1.5s ease forwards;text-shadow:0 0 20px currentColor}
@keyframes scorePopAnim{0%{opacity:1;transform:translateY(0) scale(1.2)}100%{opacity:0;transform:translateY(-80px) scale(0.8)}}

/* ── RESULTS ── */
#screen-results{flex-direction:column;align-items:center;justify-content:center;background:var(--bg)}
.res-card{background:var(--s1);max-width:600px;width:94%;padding:2.5rem;position:relative}
.res-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--orange) 40%,var(--gold) 60%,transparent)}
.res-title{font-family:'Bebas Neue',sans-serif;font-size:2.2rem;letter-spacing:5px;text-align:center;margin-bottom:0.3rem}
.res-score{font-family:'Bebas Neue',sans-serif;font-size:3.5rem;text-align:center;letter-spacing:8px;margin:0.5rem 0}
.res-pts{text-align:center;font-family:'Barlow Condensed',sans-serif;font-size:1.1rem;color:var(--gold);letter-spacing:3px;margin-bottom:1.2rem}
.res-stats{display:grid;grid-template-columns:1fr 1fr;gap:0.5rem;margin:1rem 0}
.res-stat{background:var(--s2);padding:0.6rem 0.9rem;display:flex;justify-content:space-between;font-size:0.85rem}
.res-stat-lbl{color:var(--t2)}
.res-stat-val{color:var(--t1);font-weight:700}
.res-btns{display:flex;gap:0.75rem;justify-content:center;margin-top:1.5rem;flex-wrap:wrap}

/* ── TOURNAMENT ── */
#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.5rem;letter-spacing:6px;color:var(--gold);text-align:center;margin-bottom:0.3rem}
.bracket{display:flex;gap:0;align-items:center;justify-content:center;margin:1.5rem 0;overflow-x:auto;width:100%;padding:0.5rem}
.br-round{display:flex;flex-direction:column;justify-content:space-around;min-width:180px}
.br-round-title{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:0.6rem;letter-spacing:2px;color:var(--t2);text-align:center;text-transform:uppercase;padding-bottom:0.5rem;border-bottom:1px solid var(--s3);margin-bottom:0.5rem}
.br-match{background:var(--s1);margin:0.4rem 0;border-left:2px solid var(--s3);overflow:hidden;transition:all 0.2s}
.br-match.active{border-left-color:var(--gold);box-shadow:0 0 15px rgba(255,215,0,0.15)}
.br-match.done{opacity:0.7}
.br-team{display:flex;align-items:center;gap:0.5rem;padding:0.5rem 0.7rem;font-size:0.82rem;border-bottom:1px solid var(--s3)}
.br-team:last-child{border-bottom:none}
.br-team.winner{color:var(--gold);font-weight:700}
.br-team.loser{color:var(--t3)}
.br-team.tbd{color:var(--t3);font-style:italic}
.br-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.br-conn{width:30px;display:flex;flex-direction:column;align-items:center;justify-content:center}
.br-conn-line{width:100%;height:1px;background:var(--s3)}
.tourn-action{display:flex;gap:0.75rem;justify-content:center;flex-wrap:wrap;margin-top:1rem}
.trophy-box{text-align:center;margin:1rem 0}
.trophy-icon{font-size:4rem;display:block;filter:drop-shadow(0 0 20px rgba(255,215,0,0.7))}
.trophy-text{font-family:'Bebas Neue',sans-serif;font-size:1.8rem;letter-spacing:5px;color:var(--gold)}

/* ── MODALS ── */
.modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.8);z-index:999;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.modal.open{display:flex}
.modal-box{background:var(--s1);padding:2.2rem;max-width:380px;width:90%;position:relative;animation:fadeUp 0.25s ease}
.modal-box::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--orange),transparent)}
.modal-title{font-family:'Bebas Neue',sans-serif;font-size:1.6rem;letter-spacing:3px;margin-bottom:0.5rem}
.modal-sub{color:var(--t2);font-size:0.88rem;line-height:1.5;margin-bottom:1.5rem}
.modal-btns{display:flex;gap:0.75rem;justify-content:center}

@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes scoreFlash{0%{transform:scale(1.4);color:#ffff00}100%{transform:scale(1)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.4}}

@media(max-width:900px){
  .team-grid{grid-template-columns:repeat(3,1fr)}
  .sidebar{width:210px;min-width:190px;padding:1.2rem 0.9rem}
  .sb-logo .bb-title{font-size:1.7rem}
}
@media(max-width:620px){
  #screen-menu{flex-direction:column}
  .sidebar{width:100%;min-width:0;height:auto;border-right:none;border-bottom:1px solid var(--s3);padding:0.75rem;flex-shrink:0}
  .sb-logo,.ucard{display:none}
  .nav{flex-direction:row;flex-wrap:wrap;gap:0.2rem}
  .ni{font-size:0.62rem;padding:0.4rem 0.65rem;border-left:none;border-bottom:2px solid transparent}
  .ni.active{border-left:none;border-bottom-color:var(--orange)}
  .menu-main{padding:0.75rem}
  .team-grid{grid-template-columns:repeat(3,1fr)}
}