/* ============================================================
   APEX ELITE UNITED FC — Shared Portal Styles v3.0
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Rajdhani:wght@300;400;500;600;700&family=Cinzel:wght@400;700;900&display=swap');

:root{
  --gold:#C9A84C;--gold-bright:#FFD700;--gold-light:#E8C567;--gold-dark:#8B6914;
  --silver:#E6E6F2;--silver-light:#FFFFFF;--wd:#FFFFFF;
  --black:#000;--bk:#050505;--bc:#0D0D0D;--bp:#111;
  --red:#FF3333;--green:#00C851;--orange:#FF8800;--blue:#4A9EFF;
  --gg:linear-gradient(135deg,#8B6914 0%,#C9A84C 40%,#FFD700 60%,#C9A84C 80%,#8B6914 100%);
  --glw:0 0 20px rgba(201,168,76,.5),0 0 40px rgba(201,168,76,.2);
  --glws:0 0 30px rgba(255,215,0,.6),0 0 60px rgba(201,168,76,.3);
  --shd:0 8px 32px rgba(0,0,0,.8);--bg:1px solid rgba(201,168,76,.3);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:126%;scroll-behavior:smooth;max-width:100%;overflow-x:hidden}
body{font-family:'Rajdhani',sans-serif;background:var(--bk);color:#fff;overflow-x:hidden;min-height:100vh;position:relative;font-weight:600;max-width:100%}

/* ── HYENA SPOTS BACKGROUND ── */
body::before{
  content:'';position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.1;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='420' height='420' viewBox='0 0 420 420'><defs><radialGradient id='sp' cx='50%25' cy='50%25' r='50%25'><stop offset='0%25' stop-color='%23E8E8F0' stop-opacity='0.9'/><stop offset='55%25' stop-color='%23B8B8C8' stop-opacity='0.55'/><stop offset='100%25' stop-color='%23888898' stop-opacity='0'/></radialGradient></defs><g fill='url(%23sp)'><ellipse cx='50' cy='45' rx='14' ry='9' transform='rotate(22 50 45)'/><ellipse cx='120' cy='30' rx='8' ry='6' transform='rotate(-18 120 30)'/><ellipse cx='195' cy='70' rx='16' ry='11' transform='rotate(35 195 70)'/><ellipse cx='280' cy='40' rx='11' ry='7' transform='rotate(-25 280 40)'/><ellipse cx='355' cy='85' rx='13' ry='9' transform='rotate(15 355 85)'/><ellipse cx='85' cy='115' rx='10' ry='7' transform='rotate(-40 85 115)'/><ellipse cx='170' cy='140' rx='15' ry='10' transform='rotate(28 170 140)'/><ellipse cx='245' cy='125' rx='9' ry='6' transform='rotate(-12 245 125)'/><ellipse cx='320' cy='165' rx='14' ry='9' transform='rotate(42 320 165)'/><ellipse cx='30' cy='200' rx='13' ry='9' transform='rotate(18 30 200)'/><ellipse cx='110' cy='230' rx='9' ry='6' transform='rotate(-22 110 230)'/><ellipse cx='195' cy='220' rx='16' ry='11' transform='rotate(38 195 220)'/><ellipse cx='265' cy='250' rx='10' ry='7' transform='rotate(-15 265 250)'/><ellipse cx='350' cy='275' rx='12' ry='8' transform='rotate(25 350 275)'/><ellipse cx='55' cy='295' rx='14' ry='10' transform='rotate(-35 55 295)'/></g></svg>");
  background-size:420px 420px;background-repeat:repeat;mix-blend-mode:screen;
  animation:spotDrift 140s linear infinite;
}
@keyframes spotDrift{0%{background-position:0 0}100%{background-position:420px 420px}}

/* ── FADED LOGO WATERMARK (behind all portal content) ── */
body::after{
  content:'';position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);
  z-index:0;pointer-events:none;
  width:62vmin;height:62vmin;
  background:url('logo.jpg') center/contain no-repeat;
  opacity:.045;filter:grayscale(100%) brightness(2.5);
}

/* Ensure content above spots */
header,.lang-bar,.portal-wrap,.mo,#apxToast{position:relative;z-index:1}
header,.lang-bar{z-index:1000}
.mo{z-index:9000}
#apxToast{z-index:99999}

::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:#000}
::-webkit-scrollbar-thumb{background:var(--gold-dark);border-radius:3px}
::selection{background:var(--gold-dark);color:var(--gold-bright)}

/* ── ANIMATIONS ── */
@keyframes fadeIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes fadeInDown{from{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:none}}
@keyframes shimmer{0%,100%{background-position:200% center}50%{background-position:-200% center}}
@keyframes pulse{0%,100%{box-shadow:0 0 18px rgba(201,168,76,.3)}50%{box-shadow:0 0 45px rgba(255,215,0,.7)}}
@keyframes pulseGlow{0%,100%{box-shadow:0 0 20px rgba(201,168,76,.3)}50%{box-shadow:0 0 50px rgba(255,215,0,.7)}}
@keyframes notifIn{from{opacity:0;transform:translateX(110%)}to{opacity:1;transform:none}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes borderShimmer{0%{border-color:rgba(201,168,76,.2)}50%{border-color:rgba(255,215,0,.5)}100%{border-color:rgba(201,168,76,.2)}}

/* ── HEADER ── */
.portal-header{
  position:fixed;top:0;left:0;right:0;z-index:1001;
  background:rgba(0,0,0,.97);border-bottom:1px solid rgba(201,168,76,.25);
  min-height:72px;display:flex;align-items:center;justify-content:space-between;
  padding:0 20px;backdrop-filter:blur(20px);
  box-shadow:0 2px 30px rgba(0,0,0,.8);
  flex-wrap:nowrap;gap:8px;
}
.ph-logo{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.ph-logo img{width:62px;height:62px;border-radius:50%;border:2px solid var(--gold);object-fit:cover;background:#fff;padding:3px;box-shadow:var(--glw),0 0 12px rgba(201,168,76,.3);flex-shrink:0;filter:brightness(1.08) contrast(1.05)}
.ph-title{font-family:'Bebas Neue';font-size:1.2rem;letter-spacing:3px;background:var(--gg);background-size:300% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:shimmer 4s linear infinite;white-space:nowrap}
.ph-right{display:flex;align-items:center;gap:10px;flex-shrink:0}
.ph-user{font-family:'Bebas Neue';font-size:.78rem;letter-spacing:1px;color:var(--gold-bright);white-space:nowrap;max-width:150px;overflow:hidden;text-overflow:ellipsis}
.ph-role{font-size:.52rem;color:var(--silver);letter-spacing:1.5px;white-space:nowrap}
.ph-avatar{width:34px;height:34px;border-radius:50%;border:2px solid var(--gold);object-fit:cover;cursor:pointer;box-shadow:var(--glw)}
.btn-logout{font-family:'Rajdhani';font-size:.6rem;letter-spacing:2px;font-weight:700;padding:5px 12px;border:1px solid rgba(255,51,51,.4);background:rgba(255,51,51,.07);color:#FF6666;cursor:pointer;text-transform:uppercase;transition:all .2s}
.btn-logout:hover{background:rgba(255,51,51,.18);border-color:#FF3333;color:#fff}

/* ── LANG BAR — collapsed, selector lives in the header now ── */
.lang-bar{display:none}
.lang-wrap{position:relative;display:inline-block}
.lang-trigger{font-family:'Rajdhani';font-size:.55rem;letter-spacing:2px;font-weight:700;padding:4px 10px;border:1px solid rgba(201,168,76,.28);border-radius:2px;background:rgba(201,168,76,.06);color:var(--gold);cursor:pointer;text-transform:uppercase;transition:all .2s;display:flex;align-items:center;gap:5px;user-select:none;white-space:nowrap}
.lang-trigger:hover{background:rgba(201,168,76,.14);border-color:var(--gold)}
.lang-trigger .lang-caret{font-size:.45rem;transition:transform .2s;color:var(--silver)}
.lang-wrap:hover .lang-caret{transform:rotate(180deg)}
.lang-dropdown{
  position:absolute;top:calc(100% + 4px);right:0;
  background:rgba(5,5,5,.98);border:1px solid rgba(201,168,76,.35);
  min-width:130px;z-index:9999;opacity:0;pointer-events:none;
  transform:translateY(-4px);transition:opacity .2s,transform .2s;
  box-shadow:0 8px 30px rgba(0,0,0,.8);
}
.lang-wrap:hover .lang-dropdown{opacity:1;pointer-events:auto;transform:translateY(0)}
.lang-opt{display:block;font-family:'Rajdhani';font-size:.58rem;letter-spacing:2px;font-weight:700;padding:9px 16px;color:var(--silver);cursor:pointer;text-transform:uppercase;transition:all .15s;text-align:center;border:none;background:none;width:100%}
.lang-opt:hover,.lang-opt.active{background:rgba(201,168,76,.12);color:var(--gold-bright)}
.lang-opt.active::before{content:'✓ ';color:var(--gold)}
/* Legacy button support (portals that haven't been updated) */
.lb-btn{font-family:'Rajdhani';font-size:.55rem;letter-spacing:2px;font-weight:700;padding:2px 10px;border:1px solid rgba(201,168,76,.3);background:transparent;color:var(--silver);cursor:pointer;transition:all .2s;text-transform:uppercase}
.lb-btn.active,.lb-btn:hover{background:var(--gg);color:#000;border-color:transparent}
/* Portal switch links on login cards */
.portal-switch{margin-top:14px;padding:10px 14px;background:rgba(255,255,255,.02);border:1px solid rgba(201,168,76,.12);text-align:center}
.portal-switch span{font-size:.55rem;letter-spacing:1px;color:var(--silver);margin-right:6px}
.ps-link{display:inline-block;font-family:'Rajdhani';font-size:.58rem;font-weight:700;letter-spacing:1.5px;padding:4px 10px;border:1px solid rgba(201,168,76,.3);color:var(--gold);text-decoration:none;text-transform:uppercase;transition:all .2s;margin:2px 3px}
.ps-link:hover{background:rgba(201,168,76,.1);border-color:var(--gold);color:var(--gold-bright)}

/* ── LAYOUT ── */
.portal-wrap{padding-top:62px;min-height:100vh;padding-bottom:60px}
body.has-ticker .portal-wrap{padding-top:104px}
.portal-main{width:100%;max-width:1100px;margin:0 auto;padding:0 clamp(12px,3vw,20px);box-sizing:border-box}

/* ── LOGIN CARD ── */
.login-card{
  width:min(460px,calc(100vw - 28px));max-width:460px;margin:50px auto;
  background:linear-gradient(160deg,rgba(255,255,255,.04) 0%,rgba(201,168,76,.04) 100%);
  border:1px solid rgba(201,168,76,.25);padding:40px 36px;
  box-shadow:var(--shd),inset 0 1px 0 rgba(255,215,0,.06);
  position:relative;overflow:hidden;animation:fadeIn .6s ease both;
}
.login-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--gg);background-size:300% auto;animation:shimmer 3s linear infinite}
.login-card::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(201,168,76,.06) 0%,transparent 60%);pointer-events:none}
.login-card h2{font-family:'Bebas Neue';font-size:2rem;letter-spacing:5px;background:var(--gg);background-size:300% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:shimmer 4s linear infinite;margin-bottom:6px}
.login-card p{font-size:.7rem;color:var(--silver);margin-bottom:24px;line-height:1.7}
.home-link{display:inline-block;margin-top:12px;font-size:.6rem;letter-spacing:2px;color:var(--gold);text-decoration:none;transition:color .2s}
.home-link:hover{color:var(--gold-bright)}

/* ── DASHBOARD HEADER ── */
.dash-header{
  margin-bottom:24px;padding:20px 24px;
  background:linear-gradient(160deg,rgba(255,255,255,.04),rgba(201,168,76,.04));
  border:1px solid rgba(201,168,76,.18);
  border-left:3px solid var(--gold);
  position:relative;overflow:hidden;
  animation:fadeInDown .5s ease both;
}
.dash-header::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 0% 50%,rgba(201,168,76,.08) 0%,transparent 60%);pointer-events:none}
.dash-title{font-family:'Bebas Neue';font-size:1.8rem;letter-spacing:5px;background:var(--gg);background-size:300% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:shimmer 4s linear infinite;margin-bottom:4px}
.dash-sub{font-size:.62rem;color:var(--silver);letter-spacing:2.5px}

/* ── TABS ── */
.tabs{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:18px;border-bottom:1px solid rgba(201,168,76,.15);padding-bottom:10px;max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
.tab{font-family:'Rajdhani';font-size:.6rem;letter-spacing:1.5px;font-weight:700;padding:7px 14px;border:1px solid rgba(201,168,76,.2);background:transparent;color:var(--silver);cursor:pointer;text-transform:uppercase;transition:all .2s;position:relative;white-space:nowrap}
.tab:hover{color:var(--gold);border-color:rgba(201,168,76,.5);background:rgba(201,168,76,.06)}
.tab.active{background:linear-gradient(135deg,rgba(201,168,76,.15),rgba(255,215,0,.08));border-color:var(--gold);color:var(--gold-bright);box-shadow:0 0 12px rgba(201,168,76,.2)}
.panel{display:none;animation:fadeIn .3s ease}
.panel.active{display:block}

/* ── FORMS ── */
.fi{margin-bottom:10px}
.fi label{display:block;font-family:'Bebas Neue';font-size:.6rem;letter-spacing:2px;color:var(--gold);margin-bottom:4px}
.fi input,.fi select,.fi textarea{
  width:100%;background:rgba(255,255,255,.04);border:1px solid rgba(201,168,76,.22);
  color:#fff;font-family:'Rajdhani';font-size:.82rem;padding:10px 13px;outline:none;
  transition:all .2s;font-weight:700;
}
.fi input:focus,.fi select:focus,.fi textarea:focus{border-color:var(--gold);background:rgba(201,168,76,.07);box-shadow:0 0 10px rgba(201,168,76,.12)}
.fi select option{background:#111;color:#fff}
.fig{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.fig .fi.full{grid-column:1/-1}
.pos-checks{display:flex;flex-wrap:wrap;gap:6px}
.pos-checks label{display:inline-flex!important;align-items:center;gap:5px;margin:0;padding:7px 9px;border:1px solid rgba(201,168,76,.28);background:#111;color:#fff;font-size:.64rem;letter-spacing:1px;cursor:pointer}
.pos-checks input{width:auto;margin:0;accent-color:var(--gold)}
.fi-row{display:flex;gap:8px}

/* ── BUTTONS ── */
.sbtn{
  width:100%;font-family:'Bebas Neue';font-size:.9rem;letter-spacing:4px;
  padding:13px;border:none;background:var(--gg);background-size:300% auto;
  color:#000;cursor:pointer;transition:all .3s;font-weight:900;margin-top:8px;
  animation:shimmer 4s linear infinite;
}
.sbtn:hover{box-shadow:var(--glws);transform:translateY(-1px)}
.abtn{font-family:'Rajdhani';font-size:.6rem;letter-spacing:1.5px;font-weight:700;padding:5px 11px;border:1px solid rgba(201,168,76,.35);background:transparent;color:var(--silver);cursor:pointer;text-transform:uppercase;transition:all .2s;white-space:nowrap}
.abtn:hover{color:var(--gold);border-color:var(--gold);background:rgba(201,168,76,.07)}
.abtn-red{border-color:rgba(255,51,51,.4);color:#FF6666}.abtn-red:hover{background:rgba(255,51,51,.12);border-color:#FF3333;color:#fff}
.abtn-green{border-color:rgba(0,200,81,.4);color:#00C851}.abtn-green:hover{background:rgba(0,200,81,.1);border-color:#00C851;color:#fff}
.abtn-blue{border-color:rgba(74,158,255,.4);color:#4A9EFF}.abtn-blue:hover{background:rgba(74,158,255,.1);border-color:#4A9EFF;color:#fff}
.abtn-gold{border-color:rgba(201,168,76,.6);color:var(--gold)}.abtn-gold:hover{background:rgba(201,168,76,.1);border-color:var(--gold-bright);color:var(--gold-bright)}
.btn-row{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}

/* ── SECTION LABELS ── */
.sec-label{
  font-family:'Bebas Neue';font-size:.72rem;letter-spacing:3px;color:var(--gold);
  margin:16px 0 8px;padding-bottom:6px;border-bottom:1px solid rgba(201,168,76,.15);
  position:relative;
}
.sec-label::after{content:'';position:absolute;bottom:-1px;left:0;width:40px;height:1px;background:var(--gold)}

/* ── CARDS / LISTS ── */
.dlist{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}
.ditem{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;
  background:linear-gradient(135deg,rgba(255,255,255,.03),rgba(201,168,76,.02));
  border:1px solid rgba(201,168,76,.1);gap:8px;transition:all .2s;
}
.ditem:hover{border-color:rgba(201,168,76,.3);background:linear-gradient(135deg,rgba(255,255,255,.05),rgba(201,168,76,.04));transform:translateX(2px)}
.dl{font-size:.78rem;color:var(--wd);font-weight:700;flex:1;min-width:0}
.dr{font-size:.72rem;color:var(--silver);font-weight:700;white-space:nowrap}
.dstats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}
.ds{
  background:linear-gradient(160deg,rgba(255,255,255,.04),rgba(201,168,76,.03));
  border:1px solid rgba(201,168,76,.15);padding:14px;text-align:center;
  transition:all .3s;position:relative;overflow:hidden;
}
.ds::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:var(--gg);background-size:300% auto;animation:shimmer 4s linear infinite;opacity:.5}
.ds:hover{border-color:rgba(201,168,76,.4);box-shadow:0 0 20px rgba(201,168,76,.1)}
.dsv{font-family:'Bebas Neue';font-size:1.7rem;color:var(--gold-bright);letter-spacing:1px}
.dsl{font-size:.55rem;letter-spacing:2px;color:var(--silver)}
.badge{display:inline-block;font-size:.55rem;letter-spacing:1.5px;padding:3px 8px;background:rgba(201,168,76,.1);border:1px solid rgba(201,168,76,.3);color:var(--gold)}

/* ── AGE GROUP ── */
.age-group-header{
  font-family:'Bebas Neue';font-size:.65rem;letter-spacing:3px;color:var(--gold-bright);
  padding:8px 12px;background:linear-gradient(90deg,rgba(201,168,76,.12),transparent);
  border-left:3px solid var(--gold);margin:14px 0 6px;
}
.age-badge{display:inline-block;font-family:'Bebas Neue';font-size:.55rem;letter-spacing:1px;padding:2px 6px;background:rgba(201,168,76,.12);border:1px solid rgba(201,168,76,.3);color:var(--gold);margin-left:4px}

/* ── PLAYER AVATAR IN TABLES ── */
.p-ava{width:30px;height:30px;border-radius:50%;border:1px solid rgba(201,168,76,.4);overflow:hidden;display:inline-flex;align-items:center;justify-content:center;font-size:.8rem;background:#111;vertical-align:middle;margin-right:6px;flex-shrink:0}
.p-ava img{width:100%;height:100%;object-fit:cover}

/* ── GAME CARDS ── */
.game-card{
  background:linear-gradient(160deg,rgba(255,255,255,.04),rgba(201,168,76,.02));
  border:1px solid rgba(201,168,76,.15);padding:16px;margin-bottom:12px;
  position:relative;transition:all .3s;overflow:hidden;
}
.game-card::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:var(--gg);background-size:300% auto;animation:shimmer 4s linear infinite}
.game-card:hover{border-color:rgba(201,168,76,.35);box-shadow:0 4px 20px rgba(0,0,0,.4)}
.game-vs{font-family:'Bebas Neue';font-size:1.2rem;letter-spacing:2px;color:#fff;margin-bottom:4px;padding-left:8px}
.game-meta{font-size:.62rem;color:var(--silver);letter-spacing:1px;margin-bottom:8px;padding-left:8px}
.game-result{font-family:'Bebas Neue';font-size:1.5rem;letter-spacing:3px;padding-left:8px}
.game-result.win{color:var(--green)}.game-result.loss{color:var(--red)}.game-result.draw{color:var(--orange)}
.game-status{position:absolute;top:10px;right:12px;font-size:.55rem;letter-spacing:2px;padding:2px 8px}
.status-scheduled{background:rgba(74,158,255,.15);color:#4A9EFF;border:1px solid rgba(74,158,255,.3)}
.status-completed{background:rgba(0,200,81,.12);color:#00C851;border:1px solid rgba(0,200,81,.25)}
.status-canceled{background:rgba(255,51,51,.1);color:#FF6666;border:1px solid rgba(255,51,51,.25)}
.game-scorers{font-size:.62rem;color:var(--silver);margin-top:6px;padding-left:8px}
.game-scorers span{color:var(--gold)}

/* ── WEATHER ── */
.wx-card{display:flex;flex-wrap:wrap;align-items:flex-start;gap:14px;padding:16px;background:rgba(74,158,255,.05);border:1px solid rgba(74,158,255,.2)}
.wx-icon{font-size:2.5rem;flex-shrink:0}
.wx-info{flex:1;min-width:180px}
.wx-temp{font-family:'Bebas Neue';font-size:1.5rem;color:#fff;letter-spacing:1px}
.wx-feels{font-size:.7rem;color:var(--silver)}
.wx-hl{font-size:.62rem;color:var(--gold);margin:2px 0}
.wx-desc{font-size:.65rem;color:#4A9EFF;margin:2px 0}
.wx-meta,.wx-addr{font-size:.6rem;color:var(--silver)}
.wx-unavail{font-size:.62rem;color:var(--silver);padding:10px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);text-align:center}
.wx-hourly{display:flex;overflow-x:auto;gap:6px;padding:10px 0 4px;width:100%;scrollbar-width:thin;scrollbar-color:var(--gold-dark) transparent}
.wx-hourly::-webkit-scrollbar{height:3px}.wx-hourly::-webkit-scrollbar-thumb{background:var(--gold-dark);border-radius:2px}
.wx-hr{flex-shrink:0;width:72px;text-align:center;background:rgba(74,158,255,.06);border:1px solid rgba(74,158,255,.15);padding:6px 4px;border-radius:2px}
.wx-hrt{font-family:'Bebas Neue';font-size:.65rem;letter-spacing:1px;color:var(--gold);margin-bottom:3px}
.wx-hri{font-size:1.1rem;margin:2px 0}
.wx-hrv{font-family:'Bebas Neue';font-size:.85rem;color:#fff}
.wx-hrd{font-size:.5rem;color:#4A9EFF;margin:2px 0;line-height:1.3;min-height:22px}
.wx-hrm{font-size:.5rem;color:var(--silver)}

/* ── NOTIFICATIONS ── */
.notif-item{padding:10px 14px;background:rgba(255,255,255,.03);border-left:3px solid rgba(201,168,76,.3);margin-bottom:6px;transition:all .2s}
.notif-item.unread{background:rgba(201,168,76,.07);border-left-color:var(--gold-bright);box-shadow:inset 2px 0 8px rgba(201,168,76,.1)}
.notif-item:hover{border-left-color:var(--gold);background:rgba(255,255,255,.05)}
.notif-title{font-family:'Bebas Neue';font-size:.7rem;letter-spacing:1px;color:var(--gold-bright);margin-bottom:2px}
.notif-body{font-size:.62rem;color:var(--wd)}
.notif-time{font-size:.55rem;color:var(--silver);margin-top:3px}

/* ── MODALS ── */
.mo{display:none;position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:9000;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(4px)}
.mo.open{display:flex}
.modal{
  background:linear-gradient(160deg,#111 0%,#0D0D0D 100%);
  border:1px solid rgba(201,168,76,.3);max-width:560px;width:100%;max-height:90vh;overflow-y:auto;
  box-shadow:var(--shd),0 0 60px rgba(201,168,76,.1);position:relative;
}
.modal::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--gg);background-size:300% auto;animation:shimmer 4s linear infinite}
.mh{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:rgba(201,168,76,.06);border-bottom:1px solid rgba(201,168,76,.2);position:sticky;top:0;z-index:1}
.mt{font-family:'Bebas Neue';font-size:1rem;letter-spacing:3px;color:var(--gold-bright)}
.mc{background:none;border:none;color:var(--silver);cursor:pointer;font-size:1.1rem;padding:0 4px;line-height:1;transition:color .2s}
.mc:hover{color:#fff}
.mb{padding:20px}
.mdesc{font-size:.65rem;color:var(--silver);line-height:1.7;margin-bottom:14px}

/* ── TOAST ── */
#apxToast{position:fixed;top:94px;right:16px;z-index:99999;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{
  background:#111;border:1px solid rgba(201,168,76,.3);border-left:3px solid var(--gold);
  padding:12px 16px;min-width:260px;max-width:340px;
  animation:notifIn .3s ease;box-shadow:var(--shd);pointer-events:auto;
}
.toast-title{font-family:'Bebas Neue';font-size:.72rem;letter-spacing:2px;margin-bottom:3px}
.toast-body{font-size:.62rem;color:var(--wd)}

/* ── TABLES ── */
.tbl{width:100%;border-collapse:collapse;font-size:.72rem;margin-bottom:12px}
.tbl thead{background:rgba(201,168,76,.07)}
.tbl th{font-family:'Bebas Neue';font-size:.68rem;letter-spacing:2px;color:var(--gold);padding:10px 12px;text-align:left;border-bottom:1px solid rgba(201,168,76,.25)}
.tbl td{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.05);color:var(--wd);vertical-align:middle;font-weight:700}
.tbl tr:hover td{background:rgba(201,168,76,.04)}
.tbl .num{text-align:center}
.tbl .gold{color:var(--gold-bright)}
.tbl .green{color:var(--green)}
.tbl .red{color:var(--red)}

/* ── REPORT PANEL ── */
.rpt-filters{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px;margin-bottom:14px;padding:14px;background:rgba(255,255,255,.02);border:1px solid rgba(201,168,76,.12)}
.rpt-out{overflow-x:auto}

/* ── AVATAR ── */
.avatar-wrap{display:flex;align-items:center;gap:14px;margin-bottom:14px;padding:14px;background:rgba(255,255,255,.03);border:1px solid rgba(201,168,76,.12)}
.avatar-circle{
  width:68px;height:68px;border-radius:50%;border:2px solid var(--gold);
  overflow:hidden;display:flex;align-items:center;justify-content:center;
  font-size:1.6rem;flex-shrink:0;background:#000;box-shadow:var(--glw);
  position:relative;user-select:none;
}
.avatar-circle.has-photo{cursor:grab}
.avatar-circle.has-photo:active{cursor:grabbing}
.avatar-circle img{width:100%;height:100%;object-fit:cover;display:none;transform-origin:center center}
/* photo drag hint shown inside avatar-wrap when photo loaded */
.photo-drag-hint{font-size:.52rem;color:var(--silver);margin-top:6px;opacity:.7;letter-spacing:.5px}

/* ── CHANGELOG ── */
.cl-entry{padding:9px 12px;border-left:2px solid rgba(201,168,76,.3);margin-bottom:5px;background:rgba(255,255,255,.02);transition:border-color .2s}
.cl-entry:hover{border-left-color:var(--gold)}
.cl-who{font-family:'Bebas Neue';font-size:.62rem;color:var(--gold);letter-spacing:1px}
.cl-action{font-size:.6rem;color:#4A9EFF}
.cl-detail{font-size:.6rem;color:var(--silver)}
.cl-ts{font-size:.55rem;color:rgba(184,184,200,.5)}

/* ── ENROLLMENT ── */
.enroll-section{margin-bottom:16px;padding:14px;border:1px solid rgba(201,168,76,.15);background:rgba(255,255,255,.02);position:relative}
.enroll-section.signed{border-color:rgba(0,200,81,.25);background:rgba(0,200,81,.04)}
.enroll-title{font-family:'Bebas Neue';font-size:.75rem;letter-spacing:2px;color:var(--gold);margin-bottom:8px}
.enroll-text{font-size:.62rem;color:var(--wd);line-height:1.7;margin-bottom:10px}
.enroll-sign{display:flex;gap:8px;align-items:center;margin-top:8px}
.enroll-sign input[type=checkbox]{accent-color:var(--gold);width:16px;height:16px;cursor:pointer}
.enroll-sign label{font-size:.62rem;color:var(--wd)}
.sig-field{border:none;border-bottom:1px solid var(--gold);background:transparent;color:var(--gold-bright);font-family:'Rajdhani';font-size:.75rem;width:180px;padding:4px;outline:none;transition:border-color .2s}
.sig-field:focus{border-bottom-color:var(--gold-bright)}
.sig-date{font-size:.6rem;color:var(--silver);margin-left:8px}
.enroll-locked-banner{
  background:rgba(0,200,81,.07);border:1px solid rgba(0,200,81,.3);
  padding:16px;text-align:center;margin-top:14px;
}
.enroll-locked-banner .lock-icon{font-size:1.5rem;display:block;margin-bottom:6px}
.enroll-locked-banner .lock-title{font-family:'Bebas Neue';font-size:.8rem;letter-spacing:2px;color:var(--green)}
.enroll-locked-banner .lock-detail{font-size:.6rem;color:var(--silver);margin-top:4px;line-height:1.6}

/* ── PAYMENT GATE ── */
.pay-gate{
  position:relative;padding:60px 20px;text-align:center;
  background:rgba(255,136,0,.04);border:1px solid rgba(255,136,0,.2);
}
.pay-gate-icon{font-size:2.5rem;display:block;margin-bottom:10px}
.pay-gate-title{font-family:'Bebas Neue';font-size:1.2rem;letter-spacing:3px;color:var(--orange)}
.pay-gate-desc{font-size:.65rem;color:var(--silver);margin-top:6px}

/* ── DIVIDER ── */
.divider{height:1px;background:linear-gradient(90deg,transparent,rgba(201,168,76,.3),transparent);margin:18px 0}

/* ── ALERTS ── */
.alert-box{padding:10px 12px;border:1px solid;margin-bottom:10px;font-size:.65rem}
.alert-green{background:rgba(0,200,81,.07);border-color:rgba(0,200,81,.3);color:#00C851}
.alert-red{background:rgba(255,51,51,.07);border-color:rgba(255,51,51,.3);color:#FF6666}
.alert-gold{background:rgba(201,168,76,.07);border-color:rgba(201,168,76,.3);color:var(--gold)}
.alert-blue{background:rgba(74,158,255,.07);border-color:rgba(74,158,255,.3);color:#4A9EFF}
.empty-state{text-align:center;padding:36px;color:var(--silver);font-size:.65rem;letter-spacing:1px}

/* ── CALENDAR ── */
.mini-cal{background:rgba(255,255,255,.03);border:1px solid rgba(201,168,76,.15);padding:12px;border-radius:2px}
.cal-header{font-family:'Bebas Neue';font-size:.75rem;letter-spacing:2px;color:var(--gold);text-align:center;margin-bottom:10px;display:flex;align-items:center;justify-content:space-between}
.cal-nav{background:none;border:none;color:var(--gold);cursor:pointer;font-size:1rem;padding:0 8px;line-height:1;transition:color .2s}
.cal-nav:hover{color:var(--gold-bright)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.cal-dn{font-size:.55rem;letter-spacing:1px;color:var(--silver);text-align:center;padding:3px 0;font-weight:700}
.cal-d{font-size:.65rem;text-align:center;padding:6px 2px;cursor:default;position:relative;color:var(--wd);min-height:26px;transition:background .2s}
.cal-d.empty{background:transparent}
.cal-d.cal-today{background:rgba(201,168,76,.22);color:var(--gold-bright);font-weight:700}
.cal-d.cal-ev{background:rgba(201,168,76,.08);border-bottom:2px solid var(--gold);cursor:pointer}
.cal-d.cal-ev:hover{background:rgba(201,168,76,.18)}
.cal-dot{display:block;font-size:.4rem;color:var(--gold);line-height:1;margin-top:1px}

/* ── EYE TOGGLE (show/hide password) ── */
.pw-wrap{position:relative}
.pw-wrap input{padding-right:36px}
.pw-eye{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--silver);cursor:pointer;font-size:.9rem;padding:2px;line-height:1;transition:color .2s}
.pw-eye:hover{color:var(--gold)}

/* ── CANCEL BUTTON RED GLOW ── */
@keyframes redGlow{0%,100%{box-shadow:0 0 8px rgba(255,51,51,.4),0 0 20px rgba(255,51,51,.2)}50%{box-shadow:0 0 20px rgba(255,51,51,.8),0 0 40px rgba(255,51,51,.5),0 0 60px rgba(255,51,51,.2)}}
.btn-cancel-glow{animation:redGlow 2s ease-in-out infinite;border-color:rgba(255,51,51,.6)!important}

/* ── PHOTO SCALE SLIDER ── */
.photo-scale-wrap{margin-top:8px;display:flex;align-items:center;gap:8px}
.photo-scale-wrap label{font-size:.55rem;letter-spacing:1px;color:var(--silver);white-space:nowrap}
.photo-scale-wrap input[type=range]{flex:1;accent-color:var(--gold);cursor:pointer;height:4px}
.avatar-scale-img{transform-origin:center;transition:transform .1s}

/* ── JERSEY COLOR SWATCH ── */
.jersey-swatch{display:inline-block;width:20px;height:20px;border-radius:50%;border:2px solid rgba(201,168,76,.5);vertical-align:middle;margin-left:6px;transition:background .2s;box-shadow:0 0 6px rgba(0,0,0,.5)}

/* ── VIDEO SECTION ── */
.video-card{
  background:linear-gradient(160deg,rgba(255,255,255,.04),rgba(74,158,255,.03));
  border:1px solid rgba(74,158,255,.2);padding:14px;margin-bottom:10px;
  display:flex;align-items:flex-start;gap:12px;transition:all .2s;
}
.video-card:hover{border-color:rgba(74,158,255,.4);background:rgba(74,158,255,.06)}
.video-thumb{width:80px;height:52px;background:#111;border:1px solid rgba(74,158,255,.2);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0;cursor:pointer;transition:transform .2s}
.video-thumb:hover{transform:scale(1.06)}
.video-info{flex:1;min-width:0}
.video-title{font-family:'Bebas Neue';font-size:.75rem;letter-spacing:1.5px;color:#4A9EFF;margin-bottom:3px}
.video-meta{font-size:.58rem;color:var(--silver)}
.video-link{display:inline-flex;align-items:center;gap:4px;font-size:.6rem;color:#4A9EFF;text-decoration:none;padding:3px 8px;border:1px solid rgba(74,158,255,.3);transition:all .2s;margin-top:4px}
.video-link:hover{background:rgba(74,158,255,.1);color:#fff}

/* ── NEWS ADMIN NOTIFICATION BADGE ── */
.news-notif-badge{display:inline-flex;align-items:center;justify-content:center;background:#FF3333;color:#fff;border-radius:50%;width:18px;height:18px;font-size:9px;font-weight:700;margin-left:6px;vertical-align:middle;animation:redGlow 2s infinite}

/* ── WEATHER GAME HOUR HIGHLIGHT ── */
.wx-hr-game{border-color:var(--gold)!important;background:rgba(201,168,76,.12)!important;position:relative}
.wx-hr-badge{font-family:'Bebas Neue';font-size:.45rem;letter-spacing:1px;color:var(--gold);background:rgba(201,168,76,.15);text-align:center;margin-bottom:2px;padding:1px 2px}
.wx-before{font-size:.58rem;color:var(--silver);margin-top:5px;padding:5px 8px;background:rgba(74,158,255,.06);border:1px solid rgba(74,158,255,.12)}
.wx-bl{color:#4A9EFF;font-weight:700}

/* ── ENROLLMENT PRINT BUTTON ── */
.enroll-print-btn{font-family:'Bebas Neue';font-size:.65rem;letter-spacing:2px;padding:5px 14px;border:1px solid rgba(74,158,255,.4);background:rgba(74,158,255,.08);color:#4A9EFF;cursor:pointer;transition:all .2s}
.enroll-print-btn:hover{background:rgba(74,158,255,.18);border-color:#4A9EFF;color:#fff}

/* ── PRINT ── */
@media print{
  .portal-header,.lang-bar,.tabs,.btn-row,.abtn,.sbtn{display:none!important}
  .panel{display:block!important}
  body{background:#fff;color:#000}
  body::before{display:none}
  .tbl th{color:#000;border-bottom:2px solid #000}
  .dash-title,.dash-sub{-webkit-text-fill-color:#000}
}

/* ── RESPONSIVE ── */
@media(max-width:640px){
  .fig{grid-template-columns:1fr}
  .dstats{grid-template-columns:1fr 1fr}
  .portal-header{padding:0 12px;gap:6px}
  .ph-title{font-size:.95rem;letter-spacing:2px}
  html{font-size:110%}
  .login-card{padding:28px 20px;margin:30px auto}
}
@media(max-width:480px){
  /* Hide portal title text on very small screens to prevent header overflow */
  .ph-title{display:none}
  .ph-user{max-width:110px}
  .portal-header{padding:0 10px}
}

/* ── LIVE TICKER ── */
@keyframes tickerScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.apex-ticker{
  position:fixed;top:72px;left:0;right:0;z-index:999;
  background:rgba(2,2,2,.98);border-bottom:1px solid rgba(201,168,76,.35);
  height:28px;display:none;align-items:center;overflow:hidden;
}
body.has-ticker .apex-ticker{display:flex}
.ticker-label{
  font-family:'Bebas Neue';font-size:.62rem;letter-spacing:3px;color:var(--gold-bright);
  padding:0 12px;border-right:1px solid rgba(201,168,76,.3);white-space:nowrap;
  flex-shrink:0;background:rgba(201,168,76,.1);height:100%;display:flex;align-items:center;
}
.ticker-track-wrap{flex:1;overflow:hidden;white-space:nowrap;cursor:default}
.ticker-track{
  display:inline-block;font-family:'Rajdhani';font-size:.65rem;font-weight:500;
  color:#c8c8d8;letter-spacing:.4px;animation:tickerScroll 80s linear infinite;
}
.ticker-track:hover{animation-play-state:paused}
.ticker-sep{color:rgba(201,168,76,.5);padding:0 8px}

/* ── WELCOME SCREEN ── */
.welcome-hero{text-align:center;padding:28px 10px 22px;border-bottom:1px solid rgba(201,168,76,.15);margin-bottom:20px}
.wh-logo{
  width:124px;height:124px;border-radius:50%;border:3px solid var(--gold);object-fit:cover;
  background:#fff;padding:4px;margin:0 auto 16px;display:block;
  box-shadow:0 0 24px rgba(201,168,76,.5),0 0 55px rgba(201,168,76,.18);
}
.wh-club{
  font-family:'Bebas Neue';font-size:1.72rem;letter-spacing:5px;
  background:var(--gg);background-size:300% auto;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;animation:shimmer 4s linear infinite;
}
.wh-tagline{font-size:.62rem;color:var(--silver);letter-spacing:3px;margin-top:4px}
.welcome-stats{display:flex;gap:20px;justify-content:center;margin-top:14px;flex-wrap:wrap}
.ws{text-align:center}
.wsv{font-family:'Bebas Neue';font-size:1.35rem;color:var(--gold-bright);line-height:1}
.wsl{font-size:.47rem;color:var(--silver);letter-spacing:2px;margin-top:2px}

/* Readability and phone fit pass */
img,video,canvas{max-width:100%;height:auto}
.fi label,.sec-label,.tab,.abtn,.badge,.dsl,.notif-body,.toast-body,.empty-state,.enroll-text,.enroll-sign label,.cl-detail,.cl-action{font-weight:700}
.rpt-out,.table-wrap{max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
@media(max-width:640px){
  html{font-size:114%}
  body{width:100%;max-width:100%;overflow-x:hidden}
  .portal-wrap{padding-bottom:36px}
  .portal-main{padding-left:12px;padding-right:12px}
  .login-card{width:calc(100vw - 24px);padding:28px 16px;margin:22px auto}
  .modal{width:calc(100vw - 24px);max-width:calc(100vw - 24px)}
  .mh,.mb{padding-left:14px;padding-right:14px}
  .tabs{flex-wrap:nowrap;gap:6px;padding-bottom:8px}
  .tab{font-size:.66rem;padding:8px 12px}
  .fi-row,.avatar-wrap,.enroll-sign{flex-direction:column;align-items:stretch}
  .ditem{align-items:flex-start;flex-direction:column}
  .dr{white-space:normal}
  .tbl{min-width:620px}
  .toast{min-width:0;width:calc(100vw - 32px);max-width:calc(100vw - 32px)}
  #apxToast{left:16px;right:16px}
}
@media(max-width:420px){
  html{font-size:108%}
  .ph-user{max-width:92px}
  .btn-logout,.lang-trigger{padding-left:8px;padding-right:8px;letter-spacing:1px}
  .dstats{grid-template-columns:1fr}
}

/* Admin top status buttons */
.portal-header-metrics{display:flex;align-items:center;gap:8px;background:rgba(0,0,0,.88);border:1px solid rgba(201,168,76,.32);padding:5px 7px;box-shadow:0 8px 24px rgba(0,0,0,.45)}
.header-stat-btn{display:inline-flex;align-items:center;gap:5px;font-family:'Bebas Neue';font-size:.7rem;letter-spacing:1.5px;padding:5px 11px;border:1px solid rgba(201,168,76,.45);background:#12100a;color:var(--gold-bright);cursor:pointer;white-space:nowrap;box-shadow:inset 0 1px 0 rgba(255,255,255,.06)}
.header-stat-btn.players{border-color:rgba(74,158,255,.55);background:#08111d;color:#79b8ff}
.header-stat-btn.news{border-color:rgba(255,51,51,.75);background:#210707;color:#fff;box-shadow:0 0 16px rgba(255,51,51,.18),inset 0 1px 0 rgba(255,255,255,.08)}
.header-stat-btn.news span{color:#fff}
@media(max-width:640px){.portal-header{min-height:68px}.ph-logo img{width:54px;height:54px}.portal-header-metrics{display:none}.wh-logo{width:108px;height:108px}.apex-ticker{top:68px}body.has-ticker .portal-wrap{padding-top:100px}}
