/* ================================================================
   eFOOTBALL UNIVERSE v5 — Pitch Green Theme
   Matches the eFootball grass aesthetic from screenshot
================================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}

:root{
  /* Pitch greens */
  --g1:#071a07; --g2:#0d2e0d; --g3:#124012; --g4:#1a5c1a; --g5:#227022;
  /* Card — white on green like the screenshot */
  --card:#ffffff; --card2:#f4f9f4; --card-dark:rgba(7,26,7,0.88);
  /* Accents */
  --gold:#f5a623; --gold2:#e6941a; --gold-glow:rgba(245,166,35,0.35);
  --white:#ffffff; --off-white:#f0f5f0;
  --red:#e53535; --blue:#1e88e5; --teal:#00bfa5;
  /* Text */
  --t1:#111111; --t2:#333333; --t3:#666666; --tw:rgba(255,255,255,0.9);
  --tdim:rgba(255,255,255,0.45); --tdim2:rgba(255,255,255,0.22);
  /* Borders */
  --b1:rgba(255,255,255,0.18); --b2:rgba(255,255,255,0.08); --bc:rgba(0,0,0,0.08);
  /* Shadows */
  --sh1:0 2px 12px rgba(0,0,0,0.28); --sh2:0 6px 28px rgba(0,0,0,0.38);
  --sh3:0 12px 48px rgba(0,0,0,0.5);
  /* Sizes */
  --nav:56px; --bot:64px; --safe:env(safe-area-inset-bottom,0px);
  --r1:10px; --r2:14px; --r3:20px; --r4:28px;
  /* Fonts */
  --f1:'Oswald',sans-serif; --f2:'Nunito',sans-serif;
}

body{
  background:var(--g2);
  background-image:
    /* Pitch stripes */
    repeating-linear-gradient(180deg,
      transparent 0px, transparent 38px,
      rgba(255,255,255,0.028) 38px, rgba(255,255,255,0.028) 76px
    ),
    /* Base gradient */
    linear-gradient(180deg, var(--g1) 0%, var(--g3) 30%, var(--g4) 60%, var(--g2) 100%);
  min-height:100dvh;
  font-family:var(--f2);
  font-size:15px;
  color:var(--tw);
  overflow-x:hidden;
  -webkit-tap-highlight-color:transparent;
}

/* ── LOADER ── */
#loader{position:fixed;inset:0;z-index:9999;background:var(--g1);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.4rem;transition:opacity .4s}
.ld-ball{width:68px;height:68px;border-radius:50%;background:var(--white);display:flex;align-items:center;justify-content:center;font-size:2.2rem;box-shadow:0 0 40px rgba(255,255,255,.25);animation:ldBounce .85s ease-in-out infinite alternate}
@keyframes ldBounce{from{transform:translateY(0) scale(1)}to{transform:translateY(-16px) scale(0.96)}}
.ld-bar{width:120px;height:3px;background:rgba(255,255,255,.12);border-radius:3px;overflow:hidden}
.ld-fill{height:100%;background:var(--white);border-radius:3px;animation:ldFill 1.2s ease-in-out infinite}
@keyframes ldFill{0%{width:0;opacity:1}70%{width:100%}100%{width:100%;opacity:0}}
.ld-text{font-family:var(--f1);font-size:.62rem;color:var(--tdim);letter-spacing:.3em}

/* ── INSTALL POPUP ── */
#install-popup{
  position:fixed;bottom:calc(var(--bot) + var(--safe) + 14px);
  left:50%;transform:translateX(-50%) translateY(16px);
  background:linear-gradient(135deg,#0d2e0d,#1a5c1a);
  border:1px solid rgba(255,255,255,.2);border-radius:var(--r2);
  padding:.8rem 1rem;max-width:310px;width:calc(100vw - 2rem);
  display:none;align-items:center;gap:.75rem;
  box-shadow:var(--sh3);z-index:600;
  animation:popUp .4s cubic-bezier(.34,1.56,.64,1) forwards;
}
#install-popup.show{display:flex}
@keyframes popUp{from{transform:translateX(-50%) translateY(16px);opacity:0}to{transform:translateX(-50%) translateY(0);opacity:1}}
.ip-icon{width:42px;height:42px;border-radius:10px;background:var(--white);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}
.ip-text{flex:1}.ip-title{font-family:var(--f1);font-size:.82rem;color:var(--white);font-weight:500}
.ip-sub{font-size:.66rem;color:var(--tdim);margin-top:2px}
.ip-install{background:var(--gold);border:none;border-radius:8px;color:var(--white);font-family:var(--f1);font-size:.72rem;padding:.38rem .8rem;cursor:pointer;flex-shrink:0;transition:all .2s}
.ip-install:hover{background:var(--gold2)}
.ip-close{background:none;border:none;color:var(--tdim);cursor:pointer;font-size:1.1rem;flex-shrink:0;padding:.2rem;line-height:1}

/* ── TOAST ── */
#toast{position:fixed;bottom:calc(var(--bot)+var(--safe)+12px);left:50%;transform:translateX(-50%) translateY(8px);background:rgba(7,26,7,.95);color:var(--white);padding:.52rem 1.3rem;border-radius:99px;font-size:.78rem;font-weight:700;font-family:var(--f1);letter-spacing:.04em;z-index:8000;opacity:0;transition:all .28s;pointer-events:none;white-space:nowrap;box-shadow:var(--sh2);border:1px solid var(--b1);max-width:calc(100vw - 2rem);white-space:normal;text-align:center}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#toast.error{background:rgba(229,53,53,.92);border-color:rgba(255,100,100,.3)}
#toast.success{background:rgba(34,112,34,.95)}

/* ── TOPBAR ── */
#topbar{position:fixed;top:0;left:0;right:0;z-index:500;height:var(--nav);background:rgba(7,26,7,.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--b1);display:flex;align-items:center;padding:0 .9rem;gap:.5rem;box-shadow:0 2px 16px rgba(0,0,0,.5)}
.tb-ham{width:36px;height:36px;background:rgba(255,255,255,.08);border:1px solid var(--b1);border-radius:8px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;gap:5px;padding:7px;flex-shrink:0;transition:background .2s}
.tb-ham span{display:block;height:2px;background:var(--white);border-radius:2px;transition:all .25s}
.tb-ham.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.tb-ham.open span:nth-child(2){opacity:0}
.tb-ham.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.tb-logo{position:absolute;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:.4rem;cursor:pointer}
.tb-ball{width:26px;height:26px;border-radius:50%;background:var(--white);display:flex;align-items:center;justify-content:center;font-size:.95rem;box-shadow:0 0 10px rgba(255,255,255,.3)}
.tb-name{font-family:var(--f1);font-size:.8rem;font-weight:600;color:var(--white);letter-spacing:.06em}
#nav-right{margin-left:auto;display:flex;align-items:center;gap:.35rem}

/* ── BOTTOM NAV ── */
#botnav{position:fixed;bottom:0;left:0;right:0;z-index:500;height:calc(var(--bot) + var(--safe));padding-bottom:var(--safe);background:rgba(7,26,7,.97);border-top:1px solid var(--b1);display:flex;align-items:center;box-shadow:0 -2px 16px rgba(0,0,0,.4)}
.nb{flex:1;height:100%;background:none;border:none;color:var(--tdim);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-family:var(--f1);font-size:.48rem;letter-spacing:.07em;text-transform:uppercase;transition:color .2s;position:relative}
.nb svg{width:21px;height:21px;stroke:currentColor;fill:none;stroke-width:1.8;transition:all .2s}
.nb.active{color:var(--white)}.nb.active svg{filter:drop-shadow(0 0 5px rgba(255,255,255,.5))}
.nb-center-ring{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold2));display:flex;align-items:center;justify-content:center;box-shadow:0 4px 18px var(--gold-glow);transition:transform .2s,box-shadow .2s}
.nb-center-ring:active{transform:scale(.93)}
.nb-center-ring svg{stroke:var(--white);stroke-width:2.2}
.nb-badge{position:absolute;top:6px;right:calc(50% - 18px);background:var(--red);color:var(--white);font-size:.5rem;font-weight:800;border-radius:8px;padding:1px 4px;min-width:14px;text-align:center;display:none}
.nb-badge.show{display:block}

/* ── DRAWER ── */
#drawer-overlay{position:fixed;inset:0;z-index:600;background:rgba(0,0,0,.6);display:none}
#drawer-overlay.active{display:block}
#drawer{position:fixed;top:0;bottom:0;left:0;z-index:700;width:275px;background:linear-gradient(180deg,var(--g1) 0%,var(--g2) 100%);border-right:1px solid var(--b1);transform:translateX(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);padding-top:var(--nav);overflow-y:auto;box-shadow:6px 0 40px rgba(0,0,0,.8)}
#drawer.open{transform:translateX(0)}
.dr-profile{padding:1.1rem 1rem;display:flex;align-items:center;gap:.75rem;border-bottom:1px solid var(--b2)}
.dr-av{width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.1);border:2px solid var(--b1);display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:800;color:var(--white);overflow:hidden;flex-shrink:0}
.dr-av img{width:100%;height:100%;object-fit:cover;border-radius:50%}
.dr-name{font-weight:800;font-size:.9rem;color:var(--white)}
.dr-meta{font-size:.64rem;color:var(--tdim);margin-top:2px}
.dr-item{display:flex;align-items:center;gap:.7rem;padding:.7rem 1rem;border:none;background:none;width:100%;text-align:left;color:rgba(255,255,255,.72);font-size:.84rem;font-family:var(--f2);cursor:pointer;transition:all .15s}
.dr-item:hover{background:rgba(255,255,255,.06);color:var(--white)}
.dr-item.danger{color:rgba(255,100,100,.8)}.dr-item.danger:hover{background:rgba(229,53,53,.1);color:#ff8080}
.dr-ico{width:20px;text-align:center;font-size:.95rem;flex-shrink:0}
.dr-sep{height:1px;background:var(--b2);margin:.25rem 0}
.dr-badge{margin-left:auto;background:var(--red);color:var(--white);font-size:.52rem;font-weight:800;border-radius:8px;padding:1px 5px;min-width:16px;text-align:center;display:none}
.dr-badge.show{display:block}

/* ── APP WRAPPER ── */
#app{padding-top:var(--nav);padding-bottom:calc(var(--bot) + var(--safe));min-height:100dvh}
.page{display:none;padding:.75rem .85rem 1rem;animation:pgFade .2s ease-out}
.page.active{display:block}
@keyframes pgFade{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}

/* ── LANDING ── */
#landing{position:fixed;inset:0;z-index:800;background:var(--g1);background-image:repeating-linear-gradient(180deg,transparent 0,transparent 38px,rgba(255,255,255,.025) 38px,rgba(255,255,255,.025) 76px),linear-gradient(180deg,var(--g1) 0%,var(--g3) 60%,var(--g1) 100%);display:none;align-items:center;justify-content:center;overflow-y:auto;opacity:1;transition:opacity .3s ease}
#landing.open{display:flex;opacity:1}
#landing.hiding{opacity:0;pointer-events:none}
.land-wrap{width:100%;max-width:400px;padding:2rem 1.4rem calc(4rem + var(--safe));display:flex;flex-direction:column;align-items:center;gap:.85rem}
.land-ball{width:74px;height:74px;border-radius:50%;background:var(--white);display:flex;align-items:center;justify-content:center;font-size:2.6rem;box-shadow:0 8px 32px rgba(255,255,255,.22);animation:landIn .5s cubic-bezier(.34,1.56,.64,1)}
@keyframes landIn{from{transform:scale(.3) rotate(-20deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}
.land-title{font-family:var(--f1);font-size:2rem;font-weight:700;color:var(--white);text-align:center;line-height:1;letter-spacing:.06em}
.land-sub{font-family:var(--f1);font-size:.72rem;color:var(--tdim);letter-spacing:.28em}
.land-tabs{display:flex;gap:.4rem;width:100%}
.ltab{flex:1;padding:.58rem 1rem;border-radius:99px;border:1.5px solid var(--b1);background:transparent;color:var(--tdim);font-family:var(--f1);font-size:.78rem;cursor:pointer;letter-spacing:.05em;transition:all .2s}
.ltab:hover{border-color:var(--b1);color:var(--white)}
.ltab.active{background:var(--white);color:var(--g1);border-color:var(--white);box-shadow:0 4px 16px rgba(255,255,255,.2)}
.lpanel{display:none;width:100%;flex-direction:column;gap:.65rem}.lpanel.active{display:flex}
.lbl{font-family:var(--f1);font-size:.6rem;font-weight:500;letter-spacing:.09em;text-transform:uppercase;color:var(--tdim);display:block;margin-bottom:4px}
.inp{width:100%;padding:.62rem .88rem;border-radius:10px;background:rgba(255,255,255,.08);border:1.5px solid var(--b1);color:var(--white);font-family:var(--f2);font-size:.88rem;outline:none;transition:all .2s}
.inp:focus{border-color:rgba(255,255,255,.5);background:rgba(255,255,255,.12)}
.inp::placeholder{color:var(--tdim2)}
select.inp option{background:var(--g2);color:var(--white)}
textarea.inp{resize:vertical;min-height:68px}
.errmsg{font-size:.72rem;color:#ff9999;min-height:.9rem}
.btn-primary{width:100%;padding:.68rem;border-radius:10px;border:none;background:var(--white);color:var(--g1);font-family:var(--f1);font-size:.8rem;font-weight:500;cursor:pointer;letter-spacing:.04em;transition:all .2s}
.btn-primary:hover{background:var(--off-white)}.btn-primary:disabled{opacity:.45;cursor:not-allowed}
.btn-google{width:100%;padding:.62rem;border-radius:10px;border:1.5px solid var(--b1);background:rgba(255,255,255,.06);color:var(--white);font-size:.82rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.6rem;transition:all .2s;font-family:var(--f2)}
.btn-google:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.3)}
.or-line{text-align:center;color:var(--tdim);font-size:.72rem;position:relative}
.or-line::before,.or-line::after{content:'';position:absolute;top:50%;width:43%;height:1px;background:var(--b2)}
.or-line::before{left:0}.or-line::after{right:0}
.land-guest{font-size:.76rem;color:var(--tdim);cursor:pointer;transition:color .2s;margin-top:.3rem}
.land-guest:hover{color:rgba(255,255,255,.75)}
.club-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.45rem;max-height:270px;overflow-y:auto}
.club-opt{background:rgba(255,255,255,.06);border:1.5px solid var(--b2);border-radius:var(--r1);padding:.65rem .5rem;text-align:center;cursor:pointer;transition:all .2s}
.club-opt:hover,.club-opt.selected{border-color:var(--gold);background:rgba(245,166,35,.1)}
.club-opt.taken{opacity:.3;cursor:not-allowed}
.club-opt img{width:36px;height:36px;object-fit:contain}
.club-opt-name{font-size:.68rem;font-weight:700;margin-top:.3rem;color:var(--white)}
.club-opt-status{font-size:.58rem;color:var(--tdim);margin-top:2px}
.club-opt.taken .club-opt-status{color:#ff8080}
.club-opt.selected .club-opt-status{color:var(--gold)}
.league-pick-grid{display:grid;grid-template-columns:1fr 1fr;gap:.45rem}
.league-pick-opt{display:flex;align-items:center;gap:.45rem;padding:.6rem .7rem;border:1.5px solid var(--b1);border-radius:var(--r1);cursor:pointer;transition:all .2s}
.league-pick-opt:hover,.league-pick-opt.selected{border-color:var(--gold);background:rgba(245,166,35,.08)}
.league-pick-opt img{width:26px;height:26px;object-fit:contain}
.league-pick-opt span{font-size:.74rem;font-weight:700;color:var(--white)}

/* ── BUTTONS ── */
.btn-sm{padding:.38rem .8rem;border-radius:8px;font-size:.72rem;font-weight:700;font-family:var(--f2);cursor:pointer;border:none;transition:all .2s}
.btn-outline{background:transparent;border:1.5px solid var(--b1);color:rgba(255,255,255,.8)}
.btn-outline:hover{border-color:rgba(255,255,255,.4);color:var(--white)}
.btn-accent{background:linear-gradient(135deg,var(--gold),var(--gold2));color:var(--white)}
.btn-accent:hover{box-shadow:0 4px 16px var(--gold-glow)}
.btn-danger{background:rgba(229,53,53,.15);border:1px solid rgba(229,53,53,.3);color:#ff8080}
.btn-xs{padding:.28rem .6rem;border-radius:7px;font-size:.66rem;font-weight:700;background:transparent;border:1px solid var(--b1);color:var(--tdim);cursor:pointer;font-family:var(--f2)}
.btn-xs:hover{border-color:rgba(255,255,255,.35);color:var(--white)}
.btn-xs.active{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.35);color:var(--white)}
.full-width{width:100%}
.btn-secondary{flex:1;padding:.65rem;border-radius:10px;border:1.5px solid var(--b1);background:transparent;color:var(--white);font-size:.82rem;cursor:pointer;transition:.2s;font-family:var(--f2)}
.btn-secondary:hover{border-color:rgba(255,255,255,.35)}
.topbar-club-btn{width:32px;height:32px;border-radius:50%;border:2px solid var(--b1);background:rgba(255,255,255,.1);cursor:pointer;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:800;color:var(--white);transition:.2s;padding:2px}
.topbar-club-btn img{width:100%;height:100%;object-fit:contain}

/* ── WHITE CARDS (like the screenshot) ── */
.wcard{background:var(--card);border-radius:var(--r2);box-shadow:var(--sh1);overflow:hidden;border:1px solid rgba(255,255,255,.5)}
.wcard-head{padding:.7rem .85rem;border-bottom:1px solid var(--bc)}
.wcard-body{padding:.7rem .85rem}
.wcard-title{font-family:var(--f1);font-size:.82rem;font-weight:600;color:var(--t1);letter-spacing:.02em}

/* ── DARK CARDS ── */
.dcard{background:var(--card-dark);border:1px solid var(--b1);border-radius:var(--r2);box-shadow:var(--sh1);backdrop-filter:blur(8px)}
.dcard-body{padding:.8rem .9rem}

/* ── SECTION HEADERS ── */
.sec-hd{display:flex;align-items:center;gap:.55rem;margin:.8rem 0 .5rem}
.sec-title{font-family:var(--f1);font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.75);text-shadow:0 1px 4px rgba(0,0,0,.5)}
.sec-line{flex:1;height:1.5px;background:linear-gradient(90deg,rgba(255,255,255,.2),transparent);border-radius:1px}
.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}

/* ── STATS GRID ── */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.4rem;margin:.7rem 0}
.stat-box{background:rgba(255,255,255,.1);backdrop-filter:blur(6px);border:1px solid var(--b1);border-radius:var(--r1);padding:.65rem .3rem;text-align:center}
.stat-val{font-family:var(--f1);font-size:1.05rem;font-weight:600;color:var(--white)}
.stat-lbl{font-family:var(--f1);font-size:.48rem;color:var(--tdim);letter-spacing:.07em;text-transform:uppercase;margin-top:2px}

/* ── 3-PANEL OVERVIEW (EXACTLY LIKE SCREENSHOT) ── */
.panels-row{display:flex;gap:.5rem;margin:.3rem 0}
.panel{background:var(--white);border-radius:var(--r2);box-shadow:var(--sh2);padding:.8rem .7rem;flex:1;min-width:0;border:1px solid rgba(255,255,255,.6)}
.panel-title{font-family:var(--f1);font-weight:600;font-size:.78rem;color:var(--t1);margin-bottom:.65rem;letter-spacing:.01em}
.panel-row{display:flex;align-items:center;gap:.38rem;padding:.35rem 0;border-bottom:1px solid rgba(0,0,0,.06);cursor:pointer;border-radius:6px;padding-left:2px;padding-right:2px;transition:background .15s}
.panel-row:last-child{border-bottom:none}
.panel-row:hover{background:rgba(0,0,0,.04)}
.panel-pos{font-family:var(--f1);font-weight:700;font-size:.72rem;min-width:14px;text-align:center;color:var(--t3)}
.panel-pos.p1{color:var(--gold2)}
.panel-name{flex:1;font-size:.7rem;font-weight:800;color:var(--t1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.panel-val{font-family:var(--f1);font-weight:700;font-size:.78rem;color:var(--t1)}
.panel-val.goals{color:var(--gold2)}
.panel-val.cs{color:var(--blue)}
.panel-empty{font-size:.68rem;color:var(--t3);padding:.4rem 0;text-align:center}

/* ── LEAGUE FULL TABLE (after tap) ── */
.lg-full-wrap{background:var(--white);border-radius:var(--r2);box-shadow:var(--sh2);overflow:hidden;border:1px solid rgba(255,255,255,.5)}
.lg-back-bar{display:flex;align-items:center;gap:.6rem;padding:.65rem .85rem;border-bottom:1px solid var(--bc);background:var(--card2)}
.lg-back-btn{background:none;border:none;color:var(--t2);font-size:1rem;cursor:pointer;padding:.2rem .3rem;display:flex;align-items:center;gap:.25rem;font-family:var(--f1);font-size:.72rem}
.lg-tbl{width:100%;border-collapse:collapse;font-size:.7rem}
.lg-tbl th{padding:.42rem .25rem;text-align:center;font-family:var(--f1);font-size:.5rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--t3);border-bottom:1.5px solid rgba(0,0,0,.08)}
.lg-tbl th:nth-child(2){text-align:left}
.lg-tbl td{padding:.42rem .25rem;text-align:center;color:var(--t2);border-bottom:1px solid rgba(0,0,0,.05)}
.lg-tbl td:nth-child(2){text-align:left}
.lg-tbl tr:hover td{background:rgba(0,0,0,.03)}
.lg-tbl tr:last-child td{border-bottom:none}
.lg-tbl .name-cell{display:flex;align-items:center;gap:.3rem;cursor:pointer}
.lg-tbl .pos-num{font-family:var(--f1);font-weight:700;font-size:.7rem}
.fd{display:inline-block;width:8px;height:8px;border-radius:50%;margin:0 1.5px}
.fd.w{background:#16a34a}.fd.d{background:#ca8a04}.fd.l{background:#dc2626}
.deduct-badge{font-size:.5rem;color:#ef4444;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25);border-radius:4px;padding:1px 4px;margin-left:3px}

/* ── FIXTURE CARDS ── */
.fx-date-lbl{font-family:var(--f1);font-size:.58rem;font-weight:600;letter-spacing:.1em;color:rgba(255,255,255,.55);text-transform:uppercase;padding:.5rem 0 .28rem;display:flex;align-items:center;gap:.4rem}
.fx-card{background:var(--white);border-radius:var(--r1);box-shadow:var(--sh1);margin-bottom:.42rem;overflow:hidden;border:1px solid rgba(255,255,255,.45)}
.fx-card.mine{border-left:3px solid var(--gold)}
.fx-card.postponed{border-left:3px solid orange}
.fx-top{display:flex;align-items:center;justify-content:space-between;padding:.38rem .75rem;background:rgba(0,0,0,.04);border-bottom:1px solid rgba(0,0,0,.06);flex-wrap:wrap;gap:.25rem}
.fx-body{display:flex;align-items:center;justify-content:space-between;padding:.6rem .75rem;gap:.4rem}
.fx-team{flex:1;text-align:center;cursor:pointer}
.fx-club-name{font-size:.68rem;font-weight:800;color:var(--t1);margin-top:3px}
.fx-score-box{background:var(--g1);border-radius:9px;padding:5px 10px;text-align:center;min-width:52px}
.fx-score-num{font-family:var(--f1);font-size:.95rem;color:var(--white);letter-spacing:.06em}
.fx-vs{font-family:var(--f1);font-size:.75rem;color:var(--t3)}
.fx-bottom{display:flex;gap:.3rem;padding:.38rem .75rem;flex-wrap:wrap;border-top:1px solid rgba(0,0,0,.06)}
.fx-badge{font-size:.52rem;font-weight:700;border-radius:6px;padding:1px 6px;border:1px solid}
.fx-badge.mine{color:var(--gold2);background:rgba(245,166,35,.1);border-color:rgba(245,166,35,.3)}
.fx-badge.warn{color:#d97706;background:rgba(217,119,6,.08);border-color:rgba(217,119,6,.25)}
.fx-badge.info{color:var(--blue);background:rgba(30,136,229,.08);border-color:rgba(30,136,229,.25)}
.fx-badge.danger{color:var(--red);background:rgba(229,53,53,.08);border-color:rgba(229,53,53,.25)}

/* ── RECENT RESULTS ── */
.res-card{background:var(--white);border-radius:var(--r1);padding:.7rem .8rem;margin-bottom:.42rem;box-shadow:var(--sh1);border:1px solid rgba(255,255,255,.45)}
.res-teams{display:flex;align-items:center;justify-content:space-between;gap:.4rem}
.res-team{flex:1;text-align:center;cursor:pointer}
.res-name{font-size:.68rem;font-weight:800;color:var(--t1);margin-top:3px}
.res-scorebox{background:var(--g1);border-radius:8px;padding:4px 10px;text-align:center;min-width:50px}
.res-score{font-family:var(--f1);font-size:.9rem;color:var(--white);letter-spacing:.06em}
.res-ft{font-size:.5rem;color:rgba(255,255,255,.45)}
.res-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:.38rem}

/* ── MATCH PREP ── */
.mcard{background:var(--card-dark);border:1px solid var(--b1);border-radius:var(--r2);padding:.75rem .85rem;margin-bottom:.48rem}
.mcard-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem;font-size:.82rem}
.mcard-btns{display:flex;gap:.3rem;margin-top:.48rem;flex-wrap:wrap}
.mcard-btns .btn-sm{font-size:.67rem;padding:.33rem .62rem;white-space:nowrap}
.mcode{font-family:var(--f1);font-size:.72rem;letter-spacing:.1em;background:rgba(255,255,255,.08);border:1px solid var(--b1);border-radius:7px;padding:3px 8px;cursor:pointer;display:inline-block;color:var(--white)}
.mstatus{font-size:.6rem;font-weight:700;border-radius:6px;padding:2px 7px}
.ms-rdy{color:#4ade80}.ms-warn{color:var(--gold)}.ms-pend{color:var(--tdim)}

/* ── SCORE STEPPER ── */
.score-box{display:flex;align-items:center;justify-content:center;gap:1.1rem;margin:1rem 0}
.score-team{text-align:center}.score-team-name{font-size:.74rem;font-weight:700;margin-bottom:.4rem;color:var(--tdim)}
.score-stepper{display:flex;align-items:center;gap:.45rem}
.score-num{font-family:var(--f1);font-size:2rem;font-weight:700;color:var(--white);min-width:32px;text-align:center}
.score-vs{font-family:var(--f1);font-size:1rem;color:var(--tdim)}
.step-btn{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--b1);background:transparent;color:var(--white);font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s}
.step-btn:hover,.step-btn.add{border-color:var(--gold);color:var(--gold)}
.honesty-check{display:flex;align-items:flex-start;gap:.45rem;font-size:.73rem;color:var(--tdim);cursor:pointer;line-height:1.4;margin:.5rem 0}
.upload-label{display:flex;align-items:center;gap:.5rem;padding:.62rem .85rem;border-radius:10px;border:1.5px dashed var(--b1);cursor:pointer;font-size:.8rem;color:var(--tdim);transition:.2s}
.upload-label:hover{border-color:var(--gold);color:var(--gold)}
.ss-preview{width:100%;max-height:160px;object-fit:contain;border-radius:8px;margin-top:.5rem;border:1px solid var(--b1)}

/* ── MESSENGER ── */
.msng-wrap{display:flex;flex-direction:column;height:calc(100dvh - var(--nav) - var(--bot) - var(--safe));overflow:hidden}
.msng-header{display:flex;align-items:center;gap:.6rem;padding:.6rem .9rem;border-bottom:1px solid var(--b2);flex-shrink:0}
.msng-back{background:none;border:none;color:var(--white);font-size:1.3rem;cursor:pointer;padding:.2rem .4rem;line-height:1}
.msng-title{flex:1;font-family:var(--f1);font-size:.82rem;font-weight:600;color:var(--white)}
.msng-new{background:rgba(255,255,255,.1);border:1px solid var(--b1);border-radius:7px;color:var(--white);font-size:1rem;cursor:pointer;width:30px;height:30px;display:flex;align-items:center;justify-content:center}
.msng-tabs{display:flex;border-bottom:1px solid var(--b2);flex-shrink:0}
.msng-tab{flex:1;padding:.52rem;background:none;border:none;color:var(--tdim);font-size:.7rem;font-weight:700;font-family:var(--f1);cursor:pointer;border-bottom:2px solid transparent;transition:.2s;letter-spacing:.06em;text-transform:uppercase}
.msng-tab.active{color:var(--white);border-bottom-color:var(--gold)}
.msng-content{flex:1;overflow:hidden;display:flex;flex-direction:column}
.msng-list-wrap{flex:1;overflow-y:auto}
.msng-conv-row{display:flex;align-items:center;gap:.72rem;padding:.78rem 1rem;cursor:pointer;border-bottom:1px solid var(--b2);transition:.15s}
.msng-conv-row:hover{background:rgba(255,255,255,.04)}
.msng-av{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;flex-shrink:0;position:relative;overflow:hidden}
.msng-av-dot{position:absolute;bottom:1px;right:1px;width:10px;height:10px;border-radius:50%;background:#4ade80;border:2px solid var(--g1)}
.msng-conv-info{flex:1;min-width:0}
.msng-conv-name{font-size:.84rem;font-weight:700;margin-bottom:2px;color:var(--white)}
.msng-conv-last{font-size:.72rem;color:var(--tdim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.msng-conv-last.unread{color:var(--tw);font-weight:600}
.msng-thread-wrap{display:flex;flex-direction:column;height:100%;overflow:hidden}
.msng-thread-header{display:flex;align-items:center;gap:.5rem;padding:.52rem .8rem;border-bottom:1px solid var(--b2);flex-shrink:0;background:rgba(7,26,7,.8)}
.msng-back-sm{background:none;border:none;color:var(--white);font-size:1.2rem;cursor:pointer;padding:.1rem .3rem;flex-shrink:0}
.msng-thread-name{flex:1;font-weight:700;font-size:.84rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--white)}
.msng-msgs{flex:1;overflow-y:auto;padding:.6rem .8rem;display:flex;flex-direction:column;gap:3px;-webkit-overflow-scrolling:touch}
.msng-msg{display:flex;flex-direction:column;margin-bottom:2px}
.msng-msg.mine{align-items:flex-end}.msng-msg.other{align-items:flex-start}
.msng-bubble{max-width:78vw;padding:.48rem .72rem;border-radius:15px;font-size:.84rem;line-height:1.42;word-break:break-word}
.msng-msg.other .msng-bubble{background:rgba(255,255,255,.1);border-bottom-left-radius:4px;color:var(--white)}
.msng-msg.mine .msng-bubble{background:linear-gradient(135deg,var(--gold),var(--gold2));border-bottom-right-radius:4px;color:var(--white)}
.msng-time{font-size:.56rem;color:var(--tdim);margin-top:2px;padding:0 3px}
.msng-sys{text-align:center;font-size:.62rem;color:var(--tdim);padding:.32rem;font-style:italic}
.msng-inp-row{display:flex;align-items:center;gap:.4rem;padding:.5rem .8rem calc(.5rem + var(--safe));border-top:1px solid var(--b2);background:rgba(7,26,7,.95);flex-shrink:0}
#msng-inp{flex:1;padding:.52rem .85rem;background:rgba(255,255,255,.08);border:1.5px solid var(--b1);border-radius:22px;color:var(--white);font-family:var(--f2);font-size:.86rem;outline:none}
#msng-inp:focus{border-color:rgba(255,255,255,.4)}
.msng-send{background:linear-gradient(135deg,var(--gold),var(--gold2));border:none;border-radius:50%;width:38px;height:38px;color:var(--white);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .15s}
.msng-send:active{transform:scale(.9)}
.dm-result-row{display:flex;align-items:center;gap:.6rem;padding:.62rem .5rem;cursor:pointer;border-radius:8px;transition:.15s}
.dm-result-row:hover{background:rgba(255,255,255,.06)}

/* ── MODALS ── */
.modal{position:fixed;inset:0;z-index:850;background:rgba(0,0,0,.7);display:none;align-items:flex-end;justify-content:center}
.modal.active{display:flex}
.modal-box{background:linear-gradient(180deg,var(--g2) 0%,var(--g1) 100%);border:1px solid var(--b1);border-radius:var(--r3) var(--r3) 0 0;padding:1.2rem 1.1rem calc(1.2rem + var(--safe));width:100%;max-width:480px;max-height:92dvh;overflow-y:auto;position:relative;animation:shUp .26s cubic-bezier(.4,0,.2,1);color:var(--white)}
@keyframes shUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-handle{width:34px;height:3.5px;background:rgba(255,255,255,.2);border-radius:2px;margin:0 auto .85rem}
.modal-close{position:absolute;top:.85rem;right:.85rem;background:rgba(255,255,255,.08);border:none;border-radius:50%;width:28px;height:28px;color:var(--tdim);font-size:.88rem;cursor:pointer;display:flex;align-items:center;justify-content:center}
.modal-title{font-family:var(--f1);font-weight:600;font-size:.88rem;color:var(--gold);letter-spacing:.04em;text-transform:uppercase;margin-bottom:.85rem}
.modal-btns{display:flex;gap:.45rem;margin-top:.75rem}
.form-group{display:flex;flex-direction:column;gap:4px;margin-bottom:.58rem}
.form-row{display:flex;gap:.45rem;flex-wrap:wrap}.form-row .form-group{flex:1;min-width:120px}

/* ── PROFILE ── */
.prof-cover{height:106px;background:linear-gradient(135deg,rgba(26,92,26,.6),rgba(245,166,35,.2));background-size:cover;background-position:center;border-radius:var(--r2) var(--r2) 0 0;position:relative}
.prof-av-wrap{position:absolute;bottom:-26px;left:1rem}
.prof-avatar{width:54px;height:54px;border-radius:50%;border:3px solid var(--g1);background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;overflow:hidden;cursor:pointer}
.prof-info{padding:1.9rem 1rem .85rem;border-bottom:1px solid var(--b2)}
.prof-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.38rem;padding:.85rem}
.prof-stat{background:rgba(255,255,255,.06);border:1px solid var(--b2);border-radius:var(--r1);padding:.58rem .4rem;text-align:center}
.prof-stat-val{font-family:var(--f1);font-size:.92rem;color:var(--gold)}
.prof-stat-lbl{font-family:var(--f1);font-size:.48rem;color:var(--tdim);letter-spacing:.07em;text-transform:uppercase;margin-top:2px}

/* ── UCL ── */
.ucl-prizes{display:grid;grid-template-columns:repeat(3,1fr);gap:.45rem;margin-bottom:.9rem}
.ucl-prize{background:var(--card-dark);border:1px solid var(--b2);border-radius:var(--r1);padding:.75rem .5rem;text-align:center}
.ucl-prize.gold{border-color:rgba(245,166,35,.35);background:rgba(245,166,35,.06)}
.ucl-prize-label{font-size:.56rem;color:var(--tdim);margin-bottom:.3rem;font-family:var(--f1);letter-spacing:.06em;text-transform:uppercase}
.ucl-prize-val{font-family:var(--f1);font-weight:600;font-size:.88rem;color:var(--gold)}
.ucl-fee-box{background:rgba(255,255,255,.05);border:1px solid var(--b1);border-radius:var(--r1);padding:.8rem;margin-bottom:.75rem}

/* ── ADMIN ── */
.admin-tabs{display:flex;gap:.3rem;overflow-x:auto;margin-bottom:.65rem;padding-bottom:2px}
.atab{padding:.38rem .7rem;border-radius:8px;border:1.5px solid var(--b1);background:transparent;color:var(--tdim);font-family:var(--f2);font-size:.7rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:.2s}
.atab:hover{border-color:rgba(255,255,255,.35);color:var(--white)}
.atab.active{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.35);color:var(--white)}
.apanel{display:none}.apanel.active{display:block}
.admin-card{background:var(--card-dark);border:1px solid var(--b1);border-radius:var(--r1);padding:.72rem .8rem;margin-bottom:.45rem;font-size:.8rem;color:var(--white)}
.admin-card.done{opacity:.55}

/* ── CHAT FAB ── */
#chat-fab{position:fixed;top:calc(var(--nav)+10px);right:13px;z-index:490;width:44px;height:44px;border-radius:50%;background:rgba(7,26,7,.9);border:1.5px solid var(--b1);display:none;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--sh2);transition:transform .2s}
#chat-fab:active{transform:scale(.92)}
#chat-fab svg{width:22px;height:22px;stroke:var(--gold);fill:none;stroke-width:1.8}
#fab-badge{position:absolute;top:-4px;right:-4px;background:var(--red);color:var(--white);font-size:.52rem;font-weight:800;border-radius:8px;padding:1px 5px;min-width:15px;text-align:center;display:none;border:2px solid var(--g1)}

/* ── NOTIF BANNERS ── */
#notif-wrap{position:fixed;top:calc(var(--nav)+10px);right:.8rem;z-index:550;display:flex;flex-direction:column;gap:.38rem;max-width:285px;pointer-events:none}
.notif-banner{background:var(--g1);border:1px solid var(--b1);border-radius:var(--r1);padding:.62rem .82rem;display:flex;align-items:flex-start;gap:.5rem;box-shadow:var(--sh3);animation:nIn .28s ease;pointer-events:all;backdrop-filter:blur(10px)}
@keyframes nIn{from{opacity:0;transform:translateX(18px)}to{opacity:1;transform:translateX(0)}}
.notif-icon{font-size:1.1rem;flex-shrink:0}
.notif-title{font-weight:700;font-size:.76rem;color:var(--white);font-family:var(--f1)}
.notif-msg{font-size:.68rem;color:var(--tdim);margin-top:2px}
.notif-close{margin-left:auto;background:none;border:none;color:var(--tdim);cursor:pointer;font-size:.85rem;flex-shrink:0}

/* ── RESULT CELEBRATION ── */
#result-celebration{position:fixed;inset:0;z-index:950;background:rgba(0,0,0,.85);display:flex;align-items:center;justify-content:center}
#result-celebration.hidden{display:none}
.celeb-inner{background:var(--card-dark);border:1px solid var(--b1);border-radius:var(--r3);padding:2rem;text-align:center;max-width:295px;width:90%;box-shadow:0 0 60px rgba(245,166,35,.2);animation:celebIn .5s cubic-bezier(.34,1.56,.64,1)}
@keyframes celebIn{from{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}
.celeb-score{font-family:var(--f1);font-size:3.2rem;font-weight:700;color:var(--gold);line-height:1;text-shadow:0 0 30px var(--gold-glow)}
.celeb-winner{font-family:var(--f1);font-size:.9rem;font-weight:600;color:var(--white);margin:.4rem 0 1.2rem;text-transform:uppercase}

/* ── MISC ── */
.hidden{display:none!important}
.lg-badge{font-size:.58rem;font-weight:700;padding:2px 6px;border-radius:5px;display:inline-block}
.card{background:var(--card-dark);border:1px solid var(--b1);border-radius:var(--r1);overflow:hidden}
.card.empty{padding:1.5rem;text-align:center;color:var(--tdim);font-size:.82rem}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:.45rem}
.swap-row{display:flex;align-items:center;gap:.58rem;padding:.58rem .5rem;cursor:pointer;border-radius:8px;border:1.5px solid transparent;transition:.2s;margin-bottom:.28rem}
.swap-row:hover{background:rgba(255,255,255,.06);border-color:var(--b1)}
.badge-chip{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;border:1.5px solid;cursor:help;margin:2px;transition:.15s}
.pred-card{background:var(--card-dark);border:1px solid var(--b1);border-radius:var(--r2);padding:.9rem;margin-bottom:.55rem}
.poll-card{background:var(--card-dark);border:1px solid var(--b1);border-radius:var(--r2);padding:.88rem;margin-bottom:.55rem}
.poll-opt{display:flex;align-items:center;gap:.45rem;padding:.48rem .58rem;border-radius:8px;border:1px solid var(--b1);margin-bottom:.38rem;cursor:pointer;transition:.2s;position:relative;overflow:hidden}
.poll-opt:hover{border-color:rgba(255,255,255,.3)}.poll-opt.voted{border-color:rgba(245,166,35,.4);background:rgba(245,166,35,.05)}
.poll-bar{position:absolute;left:0;top:0;bottom:0;background:rgba(245,166,35,.07);border-radius:8px;pointer-events:none;transition:width .4s ease}
.news-card{transition:.2s}.news-card:hover{background:rgba(255,255,255,.04)!important;border-color:rgba(255,255,255,.15)!important}
.filter-tabs{display:flex;gap:.35rem;margin-bottom:.75rem;overflow-x:auto;padding-bottom:2px}
.ftab{padding:.38rem .78rem;border-radius:8px;border:1.5px solid var(--b1);background:transparent;color:var(--tdim);font-size:.72rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:.2s;font-family:var(--f2)}
.ftab.active{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.35);color:var(--white)}
.ev-country-card{background:var(--card-dark);border:1px solid var(--b1);border-radius:var(--r2);padding:1.1rem .8rem;text-align:center;cursor:pointer;transition:.2s}
.ev-country-card:hover{border-color:rgba(255,255,255,.25);background:rgba(255,255,255,.05)}
.ev-event-row{border-radius:var(--r2);padding:.9rem;margin-bottom:.55rem;cursor:pointer;transition:.2s}
.ev-event-row:hover{filter:brightness(1.1)}
.mroom{background:var(--card-dark);border:1px solid var(--b1);border-radius:var(--r2);padding:.8rem;margin-bottom:.48rem}
*{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}
*::-webkit-scrollbar{width:3px;height:3px}
*::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}
@keyframes fadein{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}
.fade-in{animation:fadein .28s ease}

/* ── Backward-compat classes for original pages.js/features.js ── */
.standings-table{width:100%;border-collapse:collapse;font-size:.72rem}
.standings-table th{padding:.42rem .28rem;text-align:center;font-family:var(--f1);font-size:.5rem;color:var(--tdim);letter-spacing:.08em;text-transform:uppercase;border-bottom:1px solid rgba(255,255,255,.08)}
.standings-table td{padding:.42rem .28rem;text-align:center;border-bottom:1px solid rgba(255,255,255,.04);color:rgba(255,255,255,.85)}
.standings-table tr:hover td{background:rgba(255,255,255,.03)}
.table-wrap{overflow-x:auto}
.lg-full-table{background:var(--card-dark);border-radius:var(--r2);padding:.5rem;border:1px solid var(--b1)}
/* keep old Orbitron class working for news.js */
@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@400;700;900&display=swap');

/* ── LEGACY CSS VARIABLE ALIASES ─────────────────────────────
   Original feature files (pages.js, news.js, features.js etc)
   use the old dark-theme variable names. We map them here to
   the new green theme equivalents so all old code just works. */
:root {
  /* old dark theme → new green theme */
  --bg:        var(--g1);
  --dark:      var(--g1);
  --dim:       rgba(255,255,255,0.42);
  --border:    rgba(255,255,255,0.12);
  --text:      rgba(255,255,255,0.88);
  --cyan:      #4dd8a0;
  --green:     #4ade80;
  --gold:      #f5a623;
  --pink:      #f87171;
  --danger:    #f87171;
  --hot:       #f97316;
  --purple:    #a78bfa;
  --purple2:   #c4b5fd;
  --neon:      #4dd8a0;
  --neon2:     #86efac;
  --neon3:     #bbf7d0;
  --draw:      #fbbf24;
  --win:       #4ade80;
  --loss:      #f87171;

  /* old card styles → new */
  --card-bg:   rgba(255,255,255,0.06);
  --card-hov:  rgba(255,255,255,0.09);

  /* font aliases */
  --f-display: 'Oswald', sans-serif;
  --f-mono:    'Oswald', sans-serif;
  --f-body:    'Nunito', sans-serif;
  --f3:        'Oswald', sans-serif;

  /* spacing */
  --r:         10px;
  --r-lg:      14px;
  --r-xl:      20px;
  --safe-bottom: env(safe-area-inset-bottom, 0px);
}

/* .card alias for dark card */
.card {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--r1);
}
.card.empty {
  padding: 1.5rem;
  text-align: center;
  color: rgba(255,255,255,0.38);
  font-size: .82rem;
}
.card.hover { cursor: pointer; transition: background .18s; }
.card.hover:hover { background: rgba(255,255,255,0.09); }

/* section header aliases */
.section-header { display:flex;align-items:center;gap:.55rem;margin:.8rem 0 .5rem }
.section-title { font-family:var(--f1);font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,0.75) }
.section-line { flex:1;height:1.5px;background:linear-gradient(90deg,rgba(255,255,255,.18),transparent);border-radius:1px }
.section-line.green { background:linear-gradient(90deg,rgba(74,222,128,.3),transparent) }
.section-line.gold  { background:linear-gradient(90deg,rgba(245,166,35,.3),transparent) }
.c-cyan  { color: #4dd8a0 }
.c-green { color: #4ade80 }
.c-gold  { color: var(--gold) }
.c-pink  { color: #f87171 }

/* button aliases */
.bs { background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.14);color:rgba(255,255,255,0.8);border-radius:8px;cursor:pointer;font-family:var(--f2);font-weight:600;font-size:.78rem;padding:7px 14px;transition:.15s }
.bs:hover { background:rgba(255,255,255,0.12);color:white }
.btn-full { width:100%;padding:.68rem;border-radius:10px;border:none;background:var(--white);color:var(--g1);font-family:var(--f1);font-size:.8rem;cursor:pointer }
.btn-full:hover { background:#f0f5f0 }
.btn-outline-sm { background:transparent;border:1px solid rgba(255,255,255,0.18);color:rgba(255,255,255,0.7);border-radius:7px;cursor:pointer;font-size:.68rem;padding:.3rem .6rem;font-family:var(--f2) }

/* filter tabs aliases */
.filter-tabs { display:flex;gap:.35rem;margin-bottom:.75rem;overflow-x:auto;padding-bottom:2px }
.ftabs { display:flex;gap:.35rem;margin-bottom:.75rem;overflow-x:auto;padding-bottom:2px }
.ftab { padding:.38rem .78rem;border-radius:8px;border:1.5px solid rgba(255,255,255,0.14);background:transparent;color:rgba(255,255,255,0.5);font-size:.72rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:.2s;font-family:var(--f2) }
.ftab.active { background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.35);color:white }

/* form aliases */
.form-group, .form-g { display:flex;flex-direction:column;gap:4px;margin-bottom:.58rem }
.lbl { font-family:var(--f1);font-size:.6rem;font-weight:500;letter-spacing:.09em;text-transform:uppercase;color:rgba(255,255,255,0.5);display:block;margin-bottom:4px }
.errmsg { font-size:.72rem;color:#fca5a5;min-height:.9rem }
.page-hdr { display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem }

/* rivalry aliases */
.rivalry-teams { display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem }
.rivalry-vs { font-family:var(--f1);font-size:.9rem;font-weight:700;color:rgba(255,255,255,.5);flex-shrink:0 }
.streak-dots { display:flex;gap:4px;flex-wrap:wrap }
.streak-d { width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:800;font-family:var(--f1) }
.streak-d.w { background:rgba(74,222,128,.2);color:#4ade80;border:1px solid rgba(74,222,128,.3) }
.streak-d.d { background:rgba(251,191,36,.2);color:#fbbf24;border:1px solid rgba(251,191,36,.3) }
.streak-d.l { background:rgba(248,113,113,.2);color:#f87171;border:1px solid rgba(248,113,113,.3) }

/* news card aliases */
.news-card { background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.09);border-radius:12px;margin-bottom:.5rem;cursor:pointer;transition:.18s;overflow:hidden }
.news-card:hover { background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.16) }
.news-card-inner { padding:.85rem .9rem }
.news-headline { font-family:var(--f1);font-size:.88rem;font-weight:600;color:white;margin:.35rem 0 .25rem;line-height:1.3;letter-spacing:.02em }
.news-sub { font-size:.74rem;color:rgba(255,255,255,0.5);line-height:1.5;margin-bottom:.4rem }
.news-footer { display:flex;align-items:center;gap:.3rem;font-size:.62rem;color:rgba(255,255,255,0.38);font-family:var(--f1);letter-spacing:.04em }
.news-dot { width:5px;height:5px;border-radius:50%;background:var(--gold);flex-shrink:0 }
.news-cat { font-family:var(--f1);font-size:.52rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:2px 7px;border-radius:5px;display:inline-block;margin-bottom:.3rem }
.news-cat.tournament { background:rgba(245,166,35,.14);color:var(--gold);border:1px solid rgba(245,166,35,.28) }
.news-cat.update     { background:rgba(77,216,160,.12);color:#4dd8a0;border:1px solid rgba(77,216,160,.26) }
.news-cat.community  { background:rgba(167,139,250,.12);color:#a78bfa;border:1px solid rgba(167,139,250,.26) }

/* awards aliases */
.grid2 { display:grid;grid-template-columns:1fr 1fr;gap:.45rem }
.btn-accent-sm { background:linear-gradient(135deg,var(--gold),var(--gold2));color:white;border:none;border-radius:8px;padding:.35rem .75rem;font-size:.7rem;font-family:var(--f1);cursor:pointer }

/* rivalry page */
.rivalry { background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--r2);padding:1rem;margin-bottom:.55rem }
.rivalry-bar { height:4px;background:rgba(255,255,255,.08);border-radius:2px;overflow:hidden;margin-top:.35rem }
.rivalry-fill { height:100%;background:linear-gradient(90deg,#4ade80,#4dd8a0);border-radius:2px;transition:width .4s }

/* Orbitron fallback — used by old feature files */
@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@400;700;900&display=swap');

/* match room aliases */
.mcard { background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--r2);padding:.75rem .85rem;margin-bottom:.48rem }
.mcard-top { display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem;font-size:.82rem;color:white }
.mcard-btns { display:flex;gap:.3rem;margin-top:.48rem;flex-wrap:wrap }
.ms-rdy { color:#4ade80 }
.ms-warn { color:var(--gold) }
.ms-pend { color:rgba(255,255,255,.38) }

/* fix: .card used as dark card by feature files */
.admin-card { background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--r1);padding:.72rem .8rem;margin-bottom:.45rem;font-size:.8rem;color:white }
