/* SuperPredicto shared component styles — the dark design system used on every
   page (navbar, flash, panels, forms, footer, loader, skeleton, media queries).
   Loaded after tokens.css. Page-specific rules live in css/pages/<page>.css.

   Cross-page components (table-card, match-row, filterseg, page-head, ...) are
   being consolidated here as pages are migrated off their inline <style> blocks. */

/* Always RENDER the scrollbar track (not just reserve its space) so it looks
   identical on every page — tall or short. This stops the track from
   appearing/disappearing between pages (the flicker) and keeps the centered
   layout from shifting. scrollbar-gutter is kept as a belt-and-suspenders. */
html { overflow-y:scroll; scrollbar-gutter:stable; }

/* Soft cross-fade between full-page navigations (Chromium; no-op elsewhere). */
@view-transition { navigation:auto; }
body { background:var(--ink); color:var(--text); font-family:"Saira",system-ui,sans-serif; -webkit-font-smoothing:antialiased; min-height:100vh; display:flex; flex-direction:column; }
a { text-decoration:none; }
main.page { flex:1 0 auto; }

/* ---------- shared dark NAVBAR ---------- */
/* display:block overrides Bootstrap's `.nav { display:flex }` — our <header class="nav">
   collides with Bootstrap's .nav, which was turning .nav-inner into a centered,
   shrink-wrapped flex item (margin:0 auto centers a flex item). */
header.nav { display:block; position:sticky; top:0; z-index:50; height:var(--nav-h); background:rgba(8,12,26,.86); backdrop-filter:saturate(150%) blur(14px); border-bottom:1px solid var(--line); }
.nav-inner { height:100%; display:flex; align-items:center; justify-content:space-between; gap:26px; max-width:1240px; margin:0 auto; padding:0 32px; }
.brand { display:flex; align-items:center; flex:0 0 auto; }
.brand img { height:30px; width:auto; display:block; }
.nav-toggle { display:none; background:transparent; border:1px solid var(--line-strong); color:var(--text); border-radius:8px; padding:5px 12px; font-size:20px; line-height:1; cursor:pointer; }
.nav-menu { display:flex; align-items:center; gap:26px; margin-left:auto; }
nav.links { display:flex; align-items:center; gap:9px; }
nav.links a { font-family:"Saira Condensed",sans-serif; font-weight:600; font-size:14px; letter-spacing:.04em; text-transform:uppercase; color:var(--muted); padding:8px 12px; border-radius:8px; white-space:nowrap; transition:color .15s ease, background .15s ease; }
nav.links a:hover { color:var(--text); background:rgba(255,255,255,.05); }
nav.links a.active { color:var(--emb); box-shadow:inset 0 -2px 0 0 var(--em); }
.nav-right { display:flex; align-items:center; gap:14px; flex:0 0 auto; }
.nav-user-mb { display:none; }  /* desktop uses the avatar dropdown; this is the mobile inline menu */
.sp-btn { font-family:"Saira Condensed",sans-serif; font-weight:700; letter-spacing:.04em; text-transform:uppercase; font-size:14px; line-height:1; display:inline-flex; align-items:center; justify-content:center; gap:9px; padding:12px 20px; border-radius:9px; cursor:pointer; border:1px solid transparent; transition:transform .12s ease, background .15s ease; }
.sp-btn-primary { background:var(--em); color:#06210F; box-shadow:0 0 0 1px rgba(29,239,147,.25), 0 8px 24px -8px rgba(0,209,122,.55); }
.sp-btn-primary:hover { background:var(--emb); transform:translateY(-1px); color:#06210F; }
.sp-btn:disabled { opacity:.45; cursor:not-allowed; box-shadow:none; transform:none; pointer-events:none; }
.avatar { width:38px; height:38px; border-radius:50%; background:linear-gradient(135deg,#22305c,#0E1530); border:1.5px solid var(--line-strong); display:grid; place-items:center; font-family:"Saira Condensed",sans-serif; font-weight:800; font-size:15px; color:var(--emb); flex:0 0 auto; position:relative; cursor:pointer; }
.avatar::after { content:""; position:absolute; right:-1px; bottom:-1px; width:11px; height:11px; border-radius:50%; background:var(--em); border:2px solid var(--ink); }

/* ---------- flash ---------- */
.flashwrap { position:fixed; top:84px; left:50%; transform:translateX(-50%); z-index:120; display:flex; flex-direction:column; gap:8px; width:min(92%,460px); }
.flash { display:flex; align-items:flex-start; gap:11px; padding:13px 16px; border-radius:11px; font-size:14px; line-height:1.45; color:var(--text); background:var(--panel-2); border:1px solid var(--line-strong); border-left:4px solid var(--fl,var(--line-strong)); box-shadow:0 18px 44px -16px rgba(0,0,0,.85); transition:opacity .4s ease; }
.flash .fl-ico { font-size:18px; line-height:1.3; flex:0 0 auto; color:var(--fl,var(--text)); }
.flash .fl-msg { min-width:0; }
.flash-success { --fl:#1DEF93; background:linear-gradient(100deg, rgba(0,209,122,.18), var(--panel-2) 62%); }
.flash-warning { --fl:#F4C752; background:linear-gradient(100deg, rgba(244,199,82,.18), var(--panel-2) 62%); }
.flash-danger  { --fl:#FF6B7D; background:linear-gradient(100deg, rgba(255,107,125,.18), var(--panel-2) 62%); }
.flash-info    { --fl:#78AAFF; background:linear-gradient(100deg, rgba(120,170,255,.18), var(--panel-2) 62%); }

/* page content container for inner (Bootstrap) pages */
.page-wrap { max-width:1200px; margin:0 auto; padding:32px 24px 64px; }

/* ---------- shared panels & forms (inner pages) ---------- */
.panel { background:linear-gradient(180deg,var(--panel),var(--ink-2)); border:1px solid var(--line-strong); border-radius:18px; box-shadow:0 40px 80px -48px rgba(0,0,0,.8); }
.auth-wrap { max-width:460px; margin:0 auto; padding:44px 0 40px; }
.auth-card { padding:30px 30px 32px; }
.auth-head { text-align:center; margin-bottom:24px; display:flex; flex-direction:column; align-items:center; gap:11px; }
.auth-kicker { display:inline-flex; align-items:center; gap:9px; font-family:"Saira Condensed",sans-serif; font-weight:700; font-size:12.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); }
.auth-kicker .hb { width:40px; height:12px; }
.auth-kicker .hb path { stroke:var(--em); }
.auth-title { font-family:"Saira Condensed",sans-serif; font-weight:900; font-size:30px; line-height:1; letter-spacing:-.01em; text-transform:uppercase; }
.auth-title span { color:var(--emb); }
.auth-sub { font-size:14px; line-height:1.5; color:var(--muted); margin:0; max-width:360px; }
.sp-field { margin-bottom:16px; }
.sp-label { display:block; font-family:"Saira Condensed",sans-serif; font-weight:700; font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted-2); margin-bottom:7px; }
.sp-input { width:100%; font-family:"Saira",sans-serif; font-size:15px; color:var(--text); background:var(--ink-2); border:1px solid var(--line); border-radius:10px; padding:12px 14px; transition:border-color .15s ease, box-shadow .15s ease; }
.sp-input::placeholder { color:var(--muted-2); }
.sp-input:focus { outline:none; border-color:var(--em); box-shadow:0 0 0 3px var(--em-dim); }
.sp-input:disabled { opacity:.55; cursor:not-allowed; }
.sp-input.invalid { border-color:#FF6B7D; }
/* password show/hide toggle (eye icon) */
.sp-pw { position:relative; }
.sp-pw .sp-input { padding-right:44px; }
.pw-toggle { position:absolute; top:0; right:0; height:100%; width:44px; padding:0; display:grid; place-items:center; background:none; border:none; color:var(--muted-2); cursor:pointer; font-size:17px; transition:color .15s ease; }
.pw-toggle:hover { color:var(--text); }
.pw-toggle:focus-visible { outline:2px solid var(--em); outline-offset:-2px; border-radius:8px; }
.sp-help { font-size:12.5px; color:var(--muted-2); margin-top:6px; }
.sp-error { font-size:12.5px; color:#FF6B7D; margin-top:6px; }
.sp-check { display:flex; align-items:center; gap:9px; font-size:14px; color:var(--muted); margin-bottom:18px; }
.sp-check input { width:16px; height:16px; accent-color:var(--em); cursor:pointer; }
.sp-btn-block { width:100%; }
.auth-foot { text-align:center; margin-top:18px; font-size:14px; color:var(--muted); }
.auth-foot a { color:var(--emb); font-weight:600; }
/* inline page note / alert card */
.sp-note { display:flex; align-items:flex-start; gap:12px; padding:14px 16px; border-radius:12px; border:1px solid var(--line-strong); background:var(--ink-2); font-size:14px; line-height:1.5; color:var(--muted); }
.sp-note i { color:var(--emb); font-size:17px; margin-top:1px; flex:0 0 auto; }
.sp-note.ok { border-color:rgba(0,209,122,.4); }
.sp-note.ok i { color:var(--emb); }
.sp-note.warn { border-color:rgba(244,199,82,.4); }
.sp-note.warn i { color:var(--gold); }
.sp-note.err { border-color:rgba(255,107,125,.45); }
.sp-note.err i { color:#FF6B7D; }
.sp-note b { color:var(--text); font-weight:600; }

/* "which tournament am I working on" badge for picks/predictions/schedule headers */
.tournament-pill { display:inline-flex; align-items:center; gap:8px; align-self:flex-start; font-family:"Saira Condensed",sans-serif; font-weight:700; font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--emb); padding:5px 12px; border-radius:100px; background:var(--em-dim); border:1px solid rgba(0,209,122,.28); }
.tournament-pill .dot { width:6px; height:6px; border-radius:50%; background:var(--em); box-shadow:0 0 0 3px rgba(0,209,122,.2); }

/* ---------- footer ---------- */
footer.site { border-top:1px solid var(--line); padding:30px 0; flex-shrink:0; }
.foot-inner { display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; max-width:1240px; margin:0 auto; padding:0 32px; }
.foot-inner img { height:22px; opacity:.9; }
.foot-links { display:flex; gap:22px; flex-wrap:wrap; }
.foot-links a { font-size:13.5px; color:var(--muted); }
.foot-links a:hover { color:var(--emb); }
.foot-copy { font-size:13px; color:var(--muted-2); }

/* ---------- heartbeat loading overlay ---------- */
.hb-overlay { position:fixed; inset:0; z-index:2000; display:none; align-items:center; justify-content:center; background:rgba(8,12,26,.78); backdrop-filter:blur(4px); }
.hb-overlay.show { display:flex; }
.hb-loader { width:150px; height:auto; }
.hb-loader .track { stroke:rgba(29,239,147,.2); }
.hb-loader .runner { stroke:var(--emb); stroke-dasharray:34 120; animation:sweep 1.6s linear infinite; }
/* Travel == one dash period (pulse 34 + gap 120 = 154), with LITERAL numbers so
   the browser can interpolate it. Equal travel/period makes every pulse sweep the
   whole line and the loop seamless (per the heartbeat-spinner design). */
@keyframes sweep { from { stroke-dashoffset:154; } to { stroke-dashoffset:0; } }

/* ---------- reusable skeleton (shimmer placeholder) ---------- */
.skeleton { display:inline-block; vertical-align:middle; position:relative; overflow:hidden; background:rgba(255,255,255,.04); border-radius:7px; }
.skeleton::after { content:""; position:absolute; inset:0; transform:translateX(-100%); background:linear-gradient(90deg, transparent, rgba(255,255,255,.07), transparent); animation:skShimmer 1.25s ease-in-out infinite; }
.sk-line { height:13px; border-radius:6px; }
.sk-pill { height:30px; width:34px; border-radius:9px; }
.sk-circle { border-radius:50%; }
@keyframes skShimmer { 100% { transform:translateX(100%); } }

/* ---------- shared live-match pulse (homepage card, schedule, leaderboard) ---------- */
@keyframes livepulse { 0% { box-shadow:0 0 0 0 rgba(255,100,114,.55); } 70% { box-shadow:0 0 0 11px rgba(255,100,114,0); } 100% { box-shadow:0 0 0 0 rgba(255,100,114,0); } }

@media (prefers-reduced-motion:reduce) {
  .skeleton::after { animation:none; }
  .hb-loader .runner, .hb-mini .run { animation:none; }
  .livepill .dot, .livenow .dot, .tag.livenow .dot { animation:none; }
  ::view-transition-group(*), ::view-transition-old(*), ::view-transition-new(*) { animation:none !important; }
}

@media (max-width:900px) {
  .nav-toggle { display:block; }
  .nav-menu { display:none; position:absolute; top:var(--nav-h); left:0; right:0; flex-direction:column; align-items:stretch; gap:0; background:rgba(8,12,26,.98); border-bottom:1px solid var(--line); padding:12px 20px 18px; }
  .nav-menu.open { display:flex; }
  nav.links { flex-direction:column; align-items:stretch; gap:2px; margin-left:0; }
  nav.links a { padding:12px 8px; }
  nav.links a.active { box-shadow:inset 3px 0 0 0 var(--em); padding-left:12px; }
  .nav-right { margin-left:0; margin-top:12px; flex-direction:column; align-items:stretch; gap:10px; }
  .nav-right .sp-btn { width:100%; }
  /* swap the avatar popover for an inline, stacked user menu inside the hamburger */
  .nav-user-dt { display:none; }
  .nav-user-mb { display:flex; flex-direction:column; gap:2px; }
  .nav-user-id { display:flex; align-items:center; gap:11px; padding:12px 8px 10px; margin-top:4px; border-top:1px solid var(--line); }
  .nav-user-av { width:36px; height:36px; border-radius:50%; flex:0 0 auto; display:grid; place-items:center; background:linear-gradient(135deg,#22305c,#0E1530); border:1.5px solid var(--line-strong); font-family:"Saira Condensed",sans-serif; font-weight:800; font-size:14px; color:var(--emb); }
  .nav-user-meta { display:flex; flex-direction:column; min-width:0; }
  .nav-user-meta b { font-size:14px; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
  .nav-user-meta small { font-size:12px; color:var(--muted-2); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
  .nav-user-mb > a { font-family:"Saira Condensed",sans-serif; font-weight:600; font-size:14px; letter-spacing:.04em; text-transform:uppercase; color:var(--muted); padding:11px 8px; border-radius:8px; }
  .nav-user-mb > a:hover { color:var(--text); background:rgba(255,255,255,.05); }
  .nav-user-logout { color:#FF8A95; }
}
@media (max-width:768px) {
  .nav-inner, .foot-inner { padding-left:20px; padding-right:20px; }
  .page-wrap { padding:24px 16px 56px; }
}

/* ---------- promoted shared components (de-duplicated from per-page CSS) ---------- */
.page-head::before { content:""; position:absolute; inset:0; z-index:0; pointer-events:none; background:radial-gradient(720px 360px at 80% -20%, rgba(0,209,122,.12), transparent 60%); }
.ph-inner { position:relative; z-index:1; display:flex; align-items:flex-end; justify-content:space-between; gap:30px; flex-wrap:wrap; }
.ph-left { display:flex; flex-direction:column; gap:10px; }
.kicker { display:inline-flex; align-items:center; gap:9px; font-family:"Saira Condensed",sans-serif; font-weight:700; font-size:13px; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); }
.kicker .hb { width:40px; height:12px; }
.kicker .hb path { stroke:var(--em); }
h1.page-title { font-family:"Saira Condensed",sans-serif; font-weight:900; font-size:clamp(28px,3.4vw,44px); line-height:1; letter-spacing:-.01em; text-transform:uppercase; }
h1.page-title span { color:var(--emb); }
.ph-note i { color:var(--muted-2); }
.livepill .dot { width:8px; height:8px; border-radius:50%; background:#ff6472; box-shadow:0 0 0 0 rgba(255,100,114,.6); animation:livepulse 1.5s ease-out infinite; }
.table-card { background:linear-gradient(180deg,var(--ink-2),#0A0F22); border:1px solid var(--line); border-radius:18px; overflow:hidden; box-shadow:0 40px 90px -50px rgba(0,0,0,.9); }
.table-scroll { overflow-x:auto; }
.table-card table { width:100%; border-collapse:collapse; }
.table-card thead .grouprow th { font-family:"Saira Condensed",sans-serif; font-weight:700; font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted-2); padding:16px 18px 6px; text-align:center; }
.table-card thead .grouprow th.spanhead { border-bottom:1px solid var(--line); color:var(--muted); }
.table-card thead .colrow th { font-family:"Saira Condensed",sans-serif; font-weight:700; font-size:12.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); padding:14px 18px; text-align:center; white-space:nowrap; border-bottom:1px solid var(--line-strong); background:rgba(255,255,255,.015); }
.table-card thead .colrow th.lft { text-align:left; }
.table-card th.divider, .table-card td.divider { border-left:1px solid var(--line); }
.table-card tbody td { padding:16px 18px; text-align:center; font-size:15.5px; color:var(--text); border-bottom:1px solid rgba(255,255,255,.05); }
.table-card tbody tr:last-child td { border-bottom:none; }
.table-card tbody tr { transition:background .14s ease; }
.table-card tbody tr:hover { background:rgba(0,209,122,.045); }
td.rank { width:84px; }
.rankwrap { display:inline-flex; align-items:center; justify-content:center; width:40px; height:40px; border-radius:11px; font-family:"Saira Condensed",sans-serif; font-weight:800; font-size:18px; background:rgba(255,255,255,.04); border:1px solid var(--line); color:var(--muted); }
tr.r1 .rankwrap { background:rgba(244,199,82,.14); border-color:rgba(244,199,82,.5); color:var(--gold); }
tr.r2 .rankwrap { background:rgba(201,210,228,.12); border-color:rgba(201,210,228,.42); color:var(--silver); }
tr.r3 .rankwrap { background:rgba(216,150,90,.14); border-color:rgba(216,150,90,.46); color:var(--bronze); }
td.player { text-align:left; }
.playercell { display:flex; align-items:center; gap:14px; }
.pavatar { width:40px; height:40px; border-radius:11px; flex:0 0 auto; display:grid; place-items:center; font-family:"Saira Condensed",sans-serif; font-weight:800; font-size:16px; background:linear-gradient(150deg,#23305c,#111a37); border:1px solid var(--line-strong); color:var(--emb); }
.playercell .pname { display:flex; align-items:center; gap:9px; font-family:"Saira Condensed",sans-serif; font-weight:700; font-size:17px; letter-spacing:.02em; line-height:1; color:var(--text); }
td.points .pts { font-family:"Saira Condensed",sans-serif; font-weight:900; font-size:26px; color:var(--text); line-height:1; }
td.points .ptslbl { font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted-2); }
.cell-num { font-family:"Saira Condensed",sans-serif; font-weight:700; font-size:18px; color:var(--text); }
.cell-num.zero { color:var(--muted-2); font-weight:600; }
td.perfect .cell-num:not(.zero) { color:var(--emb); }
td.invalid .cell-num:not(.zero) { color:#FF6B7D; }
/* clickable rows + mobile tap-to-expand breakdown (shared by /leaderboard + index podium) */
.table-card tbody tr.clickable { cursor:pointer; }
.pname .chev { color:var(--muted-2); font-size:13px; opacity:0; transition:opacity .14s ease, color .14s ease; }
.table-card tbody tr:hover .pname .chev { opacity:1; color:var(--emb); }
.lb-detail { display:none; }
.lb-detail > td { background:rgba(255,255,255,.02); padding:0 16px 16px; border-top:none; }
.lb-detail-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px 14px; padding-top:4px; }
.lbd { display:flex; flex-direction:column; gap:3px; }
.lbd-lbl { font-size:10.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--muted-2); }
.lbd-val { font-family:"Saira Condensed",sans-serif; font-weight:800; font-size:20px; line-height:1; color:var(--text); }
.lbd-val.zero { color:var(--muted-2); font-weight:700; }
.lbd-val.good { color:var(--emb); }
.lbd-val.bad { color:#FF6B7D; }
.lbd-link { grid-column:1/-1; margin-top:2px; color:var(--emb); font-weight:600; font-size:13.5px; }
@media (max-width:768px) {
  /* show only Rank / Player / Points — drop the stat columns + their group header */
  .table-card thead .grouprow { display:none; }
  .table-card .colrow th:nth-child(n+4),
  .table-card tbody tr.lb-row td:nth-child(n+4) { display:none; }
  /* reveal the breakdown when a row is tapped */
  .lb-detail.open { display:table-row; }
  .lb-row .pname .chev { opacity:1; transition:transform .18s ease, color .18s ease; }
  .lb-row.expanded .pname .chev { transform:rotate(90deg); color:var(--emb); }
}
.filterseg { display:flex; gap:4px; background:var(--ink-2); border:1px solid var(--line); border-radius:11px; padding:4px; }
.filterseg button { font-family:"Saira Condensed",sans-serif; font-weight:700; font-size:13px; letter-spacing:.05em; text-transform:uppercase; white-space:nowrap; color:var(--muted); padding:9px 15px; border-radius:8px; border:none; background:transparent; cursor:pointer; transition:all .15s ease; }
.filterseg button.on { background:var(--em); color:#06210F; }
.filterseg button:not(.on):hover { color:var(--text); }
.ghostbtn { font-family:"Saira Condensed",sans-serif; font-weight:700; font-size:13px; letter-spacing:.04em; text-transform:uppercase; white-space:nowrap; color:var(--muted); background:transparent; border:1px solid var(--line); border-radius:9px; padding:9px 15px; cursor:pointer; transition:all .15s ease; display:inline-flex; align-items:center; gap:7px; }
.ghostbtn:hover { color:var(--text); border-color:var(--line-strong); }
.day { margin-bottom:18px; }
.day-head { display:flex; align-items:center; gap:14px; width:100%; cursor:pointer; background:transparent; border:none; padding:10px 4px; text-align:left; color:inherit; }
.chev { width:26px; height:26px; flex:0 0 auto; border-radius:7px; border:1px solid var(--line); display:grid; place-items:center; color:var(--muted); transition:transform .22s ease,color .15s ease,border-color .15s ease; }
.day.collapsed .chev { transform:rotate(-90deg); }
.day-head:hover .chev { color:var(--emb); border-color:var(--line-strong); }
.day-date { font-family:"Saira Condensed",sans-serif; font-weight:800; font-size:19px; letter-spacing:.02em; color:var(--text); text-transform:uppercase; white-space:nowrap; }
.day-dow { color:var(--emb); }
.day-count { margin-left:auto; display:inline-flex; align-items:center; gap:8px; font-family:"Saira Condensed",sans-serif; font-weight:700; font-size:12.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--muted-2); }
.day-count .pip { width:8px; height:8px; border-radius:50%; background:rgba(255,255,255,.14); }
.games { display:flex; flex-direction:column; gap:10px; padding-top:6px; }
.day.collapsed .games { display:none; }
.game { display:grid; grid-template-columns:110px minmax(0,1fr) auto; align-items:center; gap:18px; background:linear-gradient(180deg,var(--ink-2),#0A0F22); border:1px solid var(--line); border-left:3px solid transparent; border-radius:14px; padding:16px 20px; transition:border-color .18s ease, background .18s ease; }
.game:hover { border-color:var(--line-strong); }
.g-meta { display:flex; flex-direction:column; gap:5px; }
.g-no { font-family:"Saira Condensed",sans-serif; font-weight:800; font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--emb); }
.g-time { display:flex; align-items:center; gap:6px; font-size:13px; color:var(--muted); white-space:nowrap; }
.g-time i { color:var(--muted-2); font-size:13px; }
.g-match { display:grid; grid-template-columns:minmax(0,1fr) auto minmax(0,1fr); align-items:center; gap:16px; width:100%; min-width:0; }
.side { display:flex; align-items:center; gap:12px; min-width:0; }
.side.home { justify-content:flex-end; }
.side.away { justify-content:flex-start; }
.tbadge { width:42px; height:42px; border-radius:11px; flex:0 0 auto; display:flex; align-items:center; justify-content:center; text-align:center; font-family:"Saira Condensed",sans-serif; font-weight:900; font-size:14px; border:1px solid var(--line-strong); }
.tbadge.home { background:linear-gradient(160deg,#1b2a57,#101938); color:#dfe8ff; }
.tbadge.away { background:linear-gradient(160deg,#5a1730,#330f1d); color:#ffd6df; }
.tname { font-family:"Saira Condensed",sans-serif; font-weight:700; font-size:16px; letter-spacing:.01em; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; min-width:0; max-width:150px; }
.vsv { font-family:"Saira Condensed",sans-serif; font-weight:800; font-size:12px; letter-spacing:.1em; color:var(--muted-2); }
.dash { font-family:"Saira Condensed",sans-serif; font-weight:800; font-size:22px; color:var(--muted-2); }
.empty-note { text-align:center; color:var(--muted); padding:50px 0; }
.day-count.complete { color:var(--emb); }
.day-count.complete .pip { background:var(--em); box-shadow:0 0 0 3px rgba(0,209,122,.2); }
.g-score { display:flex; align-items:center; gap:12px; flex:0 0 auto; }
.savebar { position:fixed; left:0; right:0; bottom:0; z-index:55; background:rgba(8,12,26,.9); backdrop-filter:saturate(150%) blur(14px); border-top:1px solid var(--line-strong); }
.savebar-inner { max-width:1040px; margin:0 auto; padding:14px 32px; display:flex; align-items:center; gap:24px; }
.sb-progress { flex:1; min-width:0; display:flex; flex-direction:column; gap:8px; }
.sb-top { display:flex; align-items:center; justify-content:space-between; gap:12px; }
.sb-label { font-size:13.5px; color:var(--muted); white-space:nowrap; }
.sb-label b { font-family:"Saira Condensed",sans-serif; font-weight:800; font-size:16px; color:var(--text); }
.sb-label .em { color:var(--emb); }
.sb-remaining { font-family:"Saira Condensed",sans-serif; font-weight:700; font-size:12.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--muted-2); }
.bar { height:7px; border-radius:100px; background:rgba(255,255,255,.08); overflow:hidden; }
.bar > i { display:block; height:100%; width:1%; border-radius:100px; background:linear-gradient(90deg,var(--em),var(--emb)); transition:width .5s cubic-bezier(.2,.7,.2,1); }
.savebtn { font-family:"Saira Condensed",sans-serif; font-weight:800; letter-spacing:.05em; text-transform:uppercase; font-size:15px; padding:15px 28px; border-radius:11px; border:none; cursor:pointer; white-space:nowrap; background:var(--em); color:#06210F; box-shadow:0 0 0 1px rgba(29,239,147,.25), 0 10px 26px -10px rgba(0,209,122,.6); transition:background .15s ease, transform .12s ease; }
.savebtn:hover { background:var(--emb); transform:translateY(-1px); }
.adm-dd-btn { display:flex; align-items:center; justify-content:space-between; gap:12px; width:100%; font-family:"Saira Condensed",sans-serif; font-weight:600; font-size:14.5px; color:var(--text); background:var(--ink-2); border:1px solid var(--line); border-radius:10px; padding:10px 14px; cursor:pointer; text-align:left; transition:border-color .15s ease; }
.adm-dd-btn:hover { border-color:var(--line-strong); }
.adm-dd-btn i { color:var(--muted); font-size:13px; transition:transform .18s ease; flex:0 0 auto; }
.adm-dd.open .adm-dd-btn { border-color:var(--em); box-shadow:0 0 0 3px var(--em-dim); }
.adm-dd.open .adm-dd-btn i { transform:rotate(180deg); }
.adm-dd.open .adm-dd-menu { display:block; }
.adm-dd-opt { font-family:"Saira Condensed",sans-serif; font-weight:600; font-size:14.5px; color:var(--muted); padding:10px 12px; border-radius:8px; cursor:pointer; white-space:nowrap; transition:background .12s ease, color .12s ease; }
.adm-dd-opt:hover { background:rgba(255,255,255,.05); color:var(--text); }
.adm-dd-opt.sel { background:var(--em-dim); color:var(--emb); }
.adm-dd-menu::-webkit-scrollbar { width:9px; }
.adm-dd-menu::-webkit-scrollbar-thumb { background:var(--line-strong); border-radius:100px; }
.team-in:focus { outline:none; border-color:var(--em); }
.pts.p4 { background:var(--em); color:#06210F; border-color:transparent; box-shadow:0 0 0 1px rgba(29,239,147,.3); }
.pts.p2 { background:var(--em-dim); color:var(--emb); border-color:rgba(0,209,122,.4); }
.pts.p1 { background:rgba(255,255,255,.05); color:var(--text); }
