:root{
  --bg:#0D0A06;--s1:#150F08;--s2:#1E160A;--s3:#26200F;
  --mahogany:#5C2E0A;--mahogany2:#7A3F10;--mahogany3:#A05520;
  --cream:#F5EDD8;--cream2:#E8D9BC;--cream3:#D4C099;
  --gold:#C8960A;--gold2:#E8B020;--gold3:#F0CC50;
  --t1:#F0E8D0;--t2:#A09060;--t3:#5A4A28;
  --red:#CC2020;--green:#2A7A30;--blue:#1A4A8A;
  --shadow:rgba(0,0,0,0.6);
}
*,*::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:'Lora',serif}
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  background:radial-gradient(ellipse at 50% 0%,rgba(200,150,10,.06) 0%,transparent 55%),
             radial-gradient(ellipse at 20% 100%,rgba(90,45,10,.15) 0%,transparent 50%)}
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:9999;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='.028'/%3E%3C/svg%3E")}
.screen{display:none;width:100vw;height:100vh;position:absolute;top:0;left:0;z-index:1}
.screen.active{display:flex}
::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:var(--s1)}::-webkit-scrollbar-thumb{background:var(--gold)}

/* ── TYPOGRAPHY ── */
.cinzel{font-family:'Cinzel',serif}
.playfair{font-family:'Playfair Display',serif}
.logo-txt{font-family:'Cinzel',serif;font-weight:700;font-size:2.8rem;letter-spacing:5px;
  background:linear-gradient(135deg,var(--gold),var(--gold3),var(--gold));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  filter:drop-shadow(0 0 20px rgba(200,150,10,.5))}
.logo-sub{font-family:'Cinzel',serif;font-size:.6rem;letter-spacing:7px;color:var(--t2);margin-top:.2rem;text-transform:uppercase}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:.72rem 1.8rem;border:none;cursor:pointer;transition:all .22s;font-family:'Cinzel',serif;font-size:.7rem;letter-spacing:2px;text-transform:uppercase;position:relative;overflow:hidden}
.btn-gold{background:linear-gradient(135deg,var(--mahogany2),var(--gold),var(--mahogany2));background-size:200% 100%;color:#1A0A00;font-weight:700;box-shadow:0 0 20px rgba(200,150,10,.3),inset 0 1px 0 rgba(255,255,255,.15);clip-path:polygon(8px 0%,100% 0%,calc(100% - 8px) 100%,0% 100%)}
.btn-gold:hover{background-position:100% 0;box-shadow:0 0 35px rgba(200,150,10,.6);transform:translateY(-2px)}
.btn-cream{background:var(--cream);color:var(--bg);font-weight:700;clip-path:polygon(8px 0%,100% 0%,calc(100% - 8px) 100%,0% 100%)}
.btn-cream:hover{background:var(--cream2);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--t2);border:1px solid var(--s3)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-red{background:#6A0A0A;color:#FFD0D0;border:1px solid #AA1A1A}
.btn-red:hover{background:#880A0A}
.btn-sm{padding:.38rem .9rem;font-size:.6rem}
.btn-lg{padding:1rem 2.8rem;font-size:.8rem}
.btn:disabled{opacity:.3;cursor:not-allowed;transform:none!important;box-shadow:none!important}
input{width:100%;padding:.85rem 1.1rem;background:var(--s3);border:1px solid #3A2A10;color:var(--t1);font-family:'Lora',serif;font-size:.95rem;outline:none;transition:border-color .2s;border-radius:2px}
input:focus{border-color:var(--gold)}
input::placeholder{color:var(--t3)}
label{font-family:'Cinzel',serif;font-size:.6rem;letter-spacing:2px;color:var(--t2);display:block;margin-bottom:.35rem;text-transform:uppercase}
.err{color:#FF8080;font-size:.82rem;min-height:1rem;margin-top:.3rem}
.ornament-line{height:1px;background:linear-gradient(90deg,transparent,var(--gold),var(--cream3),var(--gold),transparent);margin:1.4rem 0;position:relative}
.ornament-line::before{content:'◆';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--gold);font-size:.7rem;background:var(--s1);padding:0 .5rem}

/* ── AUTH ── */
#sl,#sr{align-items:center;justify-content:center;flex-direction:column;
  background:radial-gradient(ellipse at 35% 50%,rgba(92,46,10,.2) 0%,transparent 60%),
             radial-gradient(ellipse at 70% 40%,rgba(200,150,10,.06) 0%,transparent 55%),var(--bg)}
.auth-card{position:relative;background:var(--s1);border:1px solid #3A2A10;padding:2.8rem 3.2rem;width:440px;max-width:95vw;animation:fadeUp .4s ease;box-shadow:0 30px 80px rgba(0,0,0,.7),inset 0 1px 0 rgba(200,150,10,.1)}
.auth-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold),var(--gold3),var(--gold),transparent)}
.auth-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--mahogany3),transparent)}
.auth-logo{text-align:center;margin-bottom:1.8rem}
.auth-icon{font-size:3rem;display:block;margin-bottom:.3rem;filter:drop-shadow(0 0 15px rgba(200,150,10,.5))}
.fg{margin-bottom:1rem}
.auth-foot{text-align:center;margin-top:1.2rem;font-size:.9rem;color:var(--t2)}
.auth-foot a{color:var(--gold2);text-decoration:none;font-family:'Cinzel',serif;font-size:.8rem}.auth-foot a:hover{color:var(--gold3)}
.full-btn{width:100%;margin-top:1.3rem}

/* ── MENU ── */
#sm{flex-direction:row}
.sidebar{width:270px;min-width:240px;background:var(--s1);border-right:1px solid #3A2A10;display:flex;flex-direction:column;padding:1.8rem 1.5rem;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(--gold3) 70%,transparent)}
.sb-logo{margin-bottom:2rem;text-align:center}
.sb-logo .logo-txt{font-size:1.8rem;letter-spacing:3px}
.nav{flex:1;display:flex;flex-direction:column;gap:.12rem}
.ni{display:flex;align-items:center;gap:.9rem;padding:.75rem 1rem;cursor:pointer;transition:all .18s;font-family:'Cinzel',serif;font-size:.65rem;letter-spacing:2px;color:var(--t2);border-left:2px solid transparent;text-transform:uppercase}
.ni:hover{color:var(--cream);background:rgba(200,150,10,.04)}
.ni.active{color:var(--gold2);border-left-color:var(--gold);background:rgba(200,150,10,.07)}
.ni-icon{font-size:1.1rem;width:1.4rem;text-align:center}
.ucard{background:var(--s2);padding:.9rem;margin-top:.8rem;border-top:1px solid #3A2A10;position:relative}
.ucard::before{content:'';display:block;height:1px;background:linear-gradient(90deg,var(--gold),transparent);margin-bottom:.8rem}
.ucard-name{font-family:'Cinzel',serif;font-size:1rem;letter-spacing:2px;color:var(--gold2)}
.ucard-rank{font-family:'Cinzel',serif;font-size:.55rem;letter-spacing:2px;color:var(--t2);margin-top:.15rem;text-transform:uppercase}
.ucard-pts{font-size:.88rem;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:720px;animation:fadeUp .3s ease;max-height:calc(100vh - 40px);overflow-y:auto}
.panel::-webkit-scrollbar{width:3px}.panel.active{display:block}
.ptitle{font-family:'Playfair Display',serif;font-size:2rem;font-weight:900;color:var(--cream);margin-bottom:.15rem}
.ptitle em{color:var(--gold2);font-style:italic}
.psub{font-family:'Cinzel',serif;font-size:.6rem;letter-spacing:2px;color:var(--t2);text-transform:uppercase;margin-bottom:1.2rem}

/* TEAM GRID */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.65rem;margin-top:.8rem}
.tc{position:relative;padding:.8rem .5rem;cursor:pointer;transition:all .22s;text-align:center;border:2px solid transparent;background:var(--s2);border-radius:3px}
.tc:hover{border-color:rgba(200,150,10,.4);transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.4)}
.tc.sel{border-color:var(--gold)!important;box-shadow:0 0 18px rgba(200,150,10,.35)}
.tc-piece{width:44px;height:44px;border-radius:50%;margin:0 auto .5rem;display:flex;align-items:center;justify-content:center;position:relative;box-shadow:0 4px 10px rgba(0,0,0,.5)}
.tc-name{font-family:'Cinzel',serif;font-size:.56rem;letter-spacing:1.5px;color:var(--t1);line-height:1.3;text-transform:uppercase}
.tc-sel-mark{position:absolute;top:4px;right:6px;font-size:.75rem;color:var(--gold)}

/* MATCHUP BAR */
.mu-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;border-radius:0 3px 3px 0}
.mu-piece{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 10px rgba(0,0,0,.5)}
.mu-name{font-family:'Cinzel',serif;font-size:.62rem;letter-spacing:1.5px;color:var(--t2);margin-top:.3rem;text-align:center}
.mu-vs{font-family:'Playfair Display',serif;font-size:2rem;color:var(--t3);font-style:italic}

/* DIFF SELECTOR */
.sel-row{display:flex;gap:.5rem;margin-top:.5rem}
.db{flex:1;padding:.48rem;background:var(--s2);border:1px solid #3A2A10;color:var(--t2);font-family:'Cinzel',serif;font-size:.58rem;letter-spacing:2px;cursor:pointer;transition:all .18s;text-transform:uppercase;border-radius:2px}
.db:hover,.db.act{border-color:var(--gold3);color:var(--gold2);background:rgba(200,150,10,.08)}

/* RANKINGS */
.rank-tbl{width:100%;border-collapse:collapse;font-size:.9rem}
.rank-tbl th{font-family:'Cinzel',serif;font-size:.58rem;letter-spacing:2px;color:var(--t2);padding:.5rem .7rem;border-bottom:1px solid #3A2A10;text-align:left;text-transform:uppercase}
.rank-tbl td{padding:.6rem .7rem;border-bottom:1px solid rgba(255,255,255,.03);font-family:'Lora',serif}
.rank-tbl tr:hover td{background:var(--s2)}
.rank-tbl tr.me td{background:rgba(200,150,10,.06);color:var(--gold2)}
.rbadge{display:inline-block;padding:.12rem .5rem;font-family:'Cinzel',serif;font-size:.52rem;letter-spacing:1.5px;text-transform:uppercase;border-radius:2px}
.rbNovice{background:rgba(120,120,120,.3);color:#ccc}
.rbApprentice{background:rgba(0,120,180,.3);color:#80C8FF}
.rbKnight{background:rgba(0,160,80,.3);color:#80FFA0}
.rbChampion{background:rgba(180,80,0,.3);color:#FFA060}
.rbGrandmaster{background:rgba(120,0,180,.3);color:#D080FF}
.rbLegend{background:linear-gradient(135deg,rgba(200,150,10,.5),rgba(240,200,80,.4));color:#FFF}

/* ── GAME SCREEN ── */
#sg{flex-direction:column;align-items:center;justify-content:flex-start;background:var(--bg);overflow:hidden}
.g-topbar{width:100%;max-width:960px;background:var(--s1);border-bottom:1px solid #3A2A10;padding:.55rem 1.5rem;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.g-topbar-logo{font-family:'Cinzel',serif;font-size:.9rem;letter-spacing:3px;color:var(--gold2);filter:drop-shadow(0 0 8px rgba(200,150,10,.4))}
.g-btns{display:flex;gap:.4rem}

/* SCOREBOARD */
.game-scoreboard{width:100%;max-width:960px;background:var(--s1);display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:.5rem 1.5rem;border-bottom:1px solid #3A2A10;flex-shrink:0}
.gs-team{display:flex;align-items:center;gap:.7rem}
.gs-team.away{flex-direction:row-reverse;text-align:right}
.gs-piece{width:32px;height:32px;border-radius:50%;box-shadow:0 2px 8px rgba(0,0,0,.5);flex-shrink:0}
.gs-name{font-family:'Cinzel',serif;font-size:.75rem;letter-spacing:1.5px;text-transform:uppercase}
.gs-pieces-left{font-family:'Lora',serif;font-size:.78rem;color:var(--t2);font-style:italic}
.gs-center{text-align:center}
.gs-score{font-family:'Playfair Display',serif;font-size:1.8rem;font-weight:900;color:var(--cream);letter-spacing:3px;filter:drop-shadow(0 0 8px rgba(200,150,10,.3))}
.gs-turn{font-family:'Cinzel',serif;font-size:.58rem;letter-spacing:2px;color:var(--gold);text-transform:uppercase}

/* GAME LAYOUT */
.game-layout{display:flex;gap:1.2rem;padding:.8rem 1.2rem;width:100%;max-width:960px;flex:1;overflow:hidden;align-items:flex-start}

/* BOARD */
.board-wrap{position:relative;flex-shrink:0}
.board-frame{background:linear-gradient(135deg,var(--mahogany),var(--mahogany2));padding:16px;border-radius:4px;box-shadow:0 20px 60px rgba(0,0,0,.7),inset 0 1px 0 rgba(200,150,10,.2),0 0 0 1px var(--mahogany3)}
.board-frame::before{content:'';position:absolute;inset:4px;border:1px solid var(--gold3);opacity:.3;border-radius:2px;pointer-events:none}
#board-canvas{display:block;border-radius:2px}
/* Coordinate labels */
.coord-row{display:flex;justify-content:space-around;padding:0 16px;flex-shrink:0}
.coord-label{font-family:'Cinzel',serif;font-size:.5rem;letter-spacing:1px;color:rgba(200,150,10,.5);width:1px;text-align:center}
.coord-col{display:flex;flex-direction:column;justify-content:space-around;position:absolute;left:4px;top:16px;height:calc(100% - 32px)}

/* RIGHT PANEL */
.right-panel{flex:1;display:flex;flex-direction:column;gap:.8rem;min-width:0}
.rp-card{background:var(--s1);border:1px solid #3A2A10;padding:.9rem;border-radius:3px;position:relative}
.rp-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold3),transparent)}
.rp-title{font-family:'Cinzel',serif;font-size:.6rem;letter-spacing:2px;color:var(--t2);text-transform:uppercase;margin-bottom:.65rem;display:flex;align-items:center;gap:.5rem}
.rp-title::after{content:'';flex:1;height:1px;background:var(--s3)}
.move-history{max-height:140px;overflow-y:auto;font-family:'Lora',serif;font-size:.78rem}
.move-history::-webkit-scrollbar{width:3px}
.mv-item{display:flex;gap:.5rem;margin-bottom:.25rem;color:var(--t2);line-height:1.5}
.mv-num{color:var(--gold3);min-width:2rem;font-family:'Cinzel',serif;font-size:.68rem}
.mv-txt{color:var(--t2)}
.mv-cap{color:var(--red);font-size:.7rem}
.captured-row{display:flex;flex-wrap:wrap;gap:4px;min-height:28px}
.cap-piece{width:24px;height:24px;border-radius:50%;opacity:.65;box-shadow:0 2px 5px rgba(0,0,0,.5)}
.think-dots{display:none;align-items:center;gap:.35rem;font-family:'Cinzel',serif;font-size:.6rem;color:var(--t2);letter-spacing:1px}
.think-dots.show{display:flex}
.tdot{width:5px;height:5px;border-radius:50%;background:var(--gold);animation:tdot 1.2s ease-in-out infinite}
.tdot:nth-child(2){animation-delay:.2s}.tdot:nth-child(3){animation-delay:.4s}

/* CONTROLS */
.controls{width:100%;max-width:960px;background:var(--s1);border-top:1px solid #3A2A10;padding:.5rem 1.2rem;display:flex;align-items:center;justify-content:center;gap:2rem;flex-shrink:0;flex-wrap:wrap}
.ctrl-item{font-family:'Cinzel',serif;font-size:.6rem;letter-spacing:1.5px;color:var(--t3);display:flex;align-items:center;gap:.35rem}
.ctrl-key{background:var(--s3);color:var(--t2);padding:.1rem .35rem;border:1px solid #3A2A10;border-radius:2px;font-size:.62rem}

/* ── RESULT ── */
#sres{flex-direction:column;align-items:center;justify-content:center;background:var(--bg)}
.res-card{background:var(--s1);border:1px solid #3A2A10;max-width:580px;width:94%;padding:2.5rem;position:relative;border-radius:3px;box-shadow:0 30px 80px rgba(0,0,0,.7)}
.res-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold),var(--gold3),var(--gold),transparent)}
.res-icon{font-size:4rem;display:block;text-align:center;margin-bottom:.5rem;filter:drop-shadow(0 0 20px rgba(200,150,10,.6))}
.res-winner{font-family:'Playfair Display',serif;font-size:2.2rem;font-weight:900;text-align:center;color:var(--gold2);font-style:italic}
.res-detail{text-align:center;font-family:'Cinzel',serif;font-size:.7rem;letter-spacing:3px;color:var(--t2);margin-top:.3rem;text-transform:uppercase}
.res-board{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin:1.2rem 0}
.res-side{background:var(--s2);padding:.9rem;border-radius:3px;text-align:center;border:1px solid #3A2A10}
.res-piece-lg{width:52px;height:52px;border-radius:50%;margin:0 auto .5rem;box-shadow:0 4px 14px rgba(0,0,0,.6)}
.res-side-name{font-family:'Cinzel',serif;font-size:.72rem;letter-spacing:1.5px;text-transform:uppercase}
.res-side-caps{font-family:'Lora',serif;font-size:.82rem;color:var(--t2);margin-top:.3rem;font-style:italic}
.res-pts{text-align:center;font-family:'Cinzel',serif;font-size:1rem;letter-spacing:2px;color:var(--gold2);margin:.8rem 0;text-transform:uppercase}
.res-btns{display:flex;gap:.75rem;justify-content:center;margin-top:1.2rem;flex-wrap:wrap}

/* ── TOURNAMENT ── */
#stourn{flex-direction:column;align-items:center;overflow-y:auto;padding:1.5rem 2rem;background:var(--bg)}
.tourn-title{font-family:'Playfair Display',serif;font-size:2rem;font-weight:900;color:var(--gold2);text-align:center;margin-bottom:.2rem;font-style:italic;filter:drop-shadow(0 0 12px rgba(200,150,10,.4))}
.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-rtitle{font-family:'Cinzel',serif;font-size:.58rem;letter-spacing:2px;color:var(--gold3);text-align:center;text-transform:uppercase;padding-bottom:.4rem;border-bottom:1px solid #3A2A10;margin-bottom:.4rem}
.br-match{background:var(--s1);margin:.35rem 0;border-left:2px solid #3A2A10;overflow:hidden;border-radius:0 2px 2px 0}
.br-match.active{border-left-color:var(--gold);box-shadow:0 0 14px rgba(200,150,10,.2)}
.br-match.done{opacity:.7}
.br-team{display:flex;align-items:center;gap:.5rem;padding:.45rem .68rem;font-family:'Cinzel',serif;font-size:.68rem;border-bottom:1px solid #3A2A10;text-transform:uppercase;letter-spacing:1px}
.br-team:last-child{border-bottom:none}
.br-team.winner{color:var(--gold2)}
.br-team.loser{color:var(--t3)}
.br-team.tbd{color:var(--t3);font-style:italic;font-family:'Lora',serif;font-size:.7rem}
.br-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;box-shadow:0 1px 4px rgba(0,0,0,.5)}
.br-conn{width:26px;display:flex;align-items:center}
.br-conn-line{width:100%;height:1px;background:#3A2A10}
.trophy-box{text-align:center;margin:1rem 0}
.trophy-icon{font-size:4rem;display:block;filter:drop-shadow(0 0 20px rgba(200,150,10,.8))}
.trophy-text{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:900;color:var(--gold2);font-style:italic}
.tourn-actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;margin-top:1rem}
.cup-stands{width:100%;max-width:450px;margin:.8rem auto}
.cs-title{font-family:'Cinzel',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:.9rem;padding:.5rem .8rem;background:var(--s1);margin-bottom:.2rem;border:1px solid #3A2A10;font-family:'Cinzel',serif;font-size:.72rem;letter-spacing:1px;border-radius:2px}
.cs-row.pr{border-color:var(--gold);background:rgba(200,150,10,.07);color:var(--gold2)}
.cs-pos{font-family:'Playfair Display',serif;font-size:.9rem;width:1.8rem;color:var(--t2);font-style:italic}.cs-pos.p1{color:var(--gold2)}
.cs-pts{margin-left:auto;font-size:.68rem;color:var(--t2)}

/* TEAMS PANEL */
.teams-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem;margin-top:.8rem}
.td-card{background:var(--s2);border:1px solid #3A2A10;padding:.9rem;border-radius:3px;position:relative;overflow:hidden}
.td-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px}
.td-header{display:flex;align-items:center;gap:.8rem;margin-bottom:.65rem}
.td-pieces{display:flex;gap:.3rem}
.td-piece-sm{width:28px;height:28px;border-radius:50%;box-shadow:0 2px 6px rgba(0,0,0,.5)}
.td-name{font-family:'Playfair Display',serif;font-size:.95rem;font-weight:700;line-height:1.1}
.td-theme{font-family:'Cinzel',serif;font-size:.5rem;color:var(--t2);letter-spacing:1px;text-transform:uppercase;margin-top:.1rem}
.td-bar-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}
.td-bar-lbl{font-family:'Cinzel',serif;font-size:.5rem;color:var(--t2);width:50px;text-transform:uppercase;letter-spacing:.5px}
.td-bar{flex:1;height:4px;background:var(--s3);border-radius:2px}
.td-bar-fill{height:100%;border-radius:2px}

/* MODAL */
.modal-ov{display:none;position:fixed;inset:0;background:rgba(0,0,0,.8);z-index:999;align-items:center;justify-content:center;backdrop-filter:blur(6px)}
.modal-ov.open{display:flex}
.modal-box{background:var(--s1);border:1px solid #3A2A10;padding:2.2rem;max-width:380px;width:90%;position:relative;animation:fadeUp .25s ease;border-radius:3px;box-shadow:0 30px 80px rgba(0,0,0,.7)}
.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:'Playfair Display',serif;font-size:1.4rem;font-weight:900;color:var(--cream);margin-bottom:.5rem}
.modal-sub{color:var(--t2);font-size:.9rem;line-height:1.5;margin-bottom:1.3rem;font-family:'Lora',serif}
.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}.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 2rem;font-family:'Cinzel',serif;font-size:.65rem;letter-spacing:2px;z-index:9000;transition:transform .35s cubic-bezier(.4,0,.2,1);white-space:nowrap;text-transform:uppercase;border-radius:2px;box-shadow:0 10px 40px rgba(0,0,0,.5)}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast span{color:var(--gold2)}

@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes tdot{0%,100%{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}
@keyframes kingGlow{0%,100%{filter:drop-shadow(0 0 4px currentColor)}50%{filter:drop-shadow(0 0 12px currentColor)}}

@media(max-width:900px){
  .team-grid{grid-template-columns:repeat(3,1fr)}
  .teams-grid{grid-template-columns:repeat(2,1fr)}
  .game-layout{gap:.7rem;padding:.5rem .7rem}
  .sidebar{width:210px;min-width:190px;padding:1.2rem .9rem}
}
@media(max-width:640px){
  #sm{flex-direction:column}
  .sidebar{width:100%;min-width:0;height:auto;border-right:none;border-bottom:1px solid #3A2A10;padding:.7rem;flex-shrink:0}
  .sb-logo,.ucard{display:none}
  .nav{flex-direction:row;flex-wrap:wrap;gap:.2rem}
  .ni{font-size:.55rem;padding:.38rem .6rem;border-left:none;border-bottom:2px solid transparent}
  .ni.active{border-left:none;border-bottom-color:var(--gold)}
  .menu-main{padding:.75rem}
  .team-grid{grid-template-columns:repeat(3,1fr)}
  .right-panel{display:none}
}