/* ============================================================================
   THE TENNIS KING — design system
   Aesthetic: championship-broadcast analytics terminal. Deep court-charcoal,
   one signature optic-yellow (tennis-ball) accent, surface color system
   (grass/clay/hard), editorial Bricolage Grotesque display + Hanken Grotesk
   body + JetBrains Mono numerics, film-grain + glow atmosphere.
   All pages share these class names — restyle here, the whole site updates.
   ========================================================================== */
:root{
  --bg:#0a0f0c; --bg-2:#0c120e; --panel:#111a13; --panel-solid:#111a13;
  --panel-2:#16211a; --raise:#1b2a20; --hair:#26352b; --hair-2:#33473a;
  --line:#26352b;                 /* alias: legacy inline borders */
  --ink:#f1f6f1; --ink-2:#aebcb1; --ink-3:#6f8377; --ink-4:#4a5a50;
  /* signature */
  --optic:#d6f73a; --optic-2:#ecff8a; --optic-ink:#0a0f0c;
  --ball:#d6f73a; --gold:#d6f73a;  /* aliases: legacy inline refs */
  /* surfaces */
  --grass:#35c46e; --clay:#e3753f; --hard:#3f9bf0; --carpet:#a78bff;
  --pos:#54e39a; --neg:#ff7d7d; --discord:#5865F2;
  --glow:radial-gradient(1100px 560px at 78% -12%,rgba(214,247,58,.10),transparent 58%),
         radial-gradient(820px 520px at 6% -6%,rgba(63,155,240,.06),transparent 56%);
  --shadow:0 18px 44px -18px rgba(0,0,0,.7);
  --r:16px; --r-sm:11px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);background-image:var(--glow);background-attachment:fixed;
  color:var(--ink);font-family:'Hanken Grotesk',system-ui,sans-serif;font-size:15px;
  line-height:1.55;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  letter-spacing:-.005em}
/* film grain overlay */
body::after{content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.05;
  mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
h1,h2,h3,.display{font-family:'Bricolage Grotesque','Hanken Grotesk',sans-serif;margin:0;
  font-weight:800;letter-spacing:-.02em;line-height:.98}
.mono{font-family:'JetBrains Mono',ui-monospace,monospace;font-variant-numeric:tabular-nums;letter-spacing:-.01em}
a{color:inherit;text-decoration:none}
::selection{background:var(--optic);color:var(--optic-ink)}
:focus-visible{outline:2px solid var(--optic);outline-offset:2px;border-radius:4px}
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-thumb{background:var(--hair-2);border-radius:99px;border:3px solid var(--bg)}

/* ---------- topbar ---------- */
.topbar{display:flex;align-items:center;gap:14px;padding:13px 24px;
  background:rgba(10,15,12,.72);border-bottom:1px solid var(--hair);
  position:sticky;top:0;z-index:200;backdrop-filter:blur(16px) saturate(1.2)}
.logo{display:flex;align-items:center;gap:11px}
.crown{width:34px;height:34px;display:grid;place-items:center;border-radius:11px;font-size:18px;
  background:radial-gradient(circle at 32% 28%,var(--optic-2),var(--optic) 55%,#9bcc1f);
  box-shadow:0 0 0 1px rgba(214,247,58,.4),0 6px 18px -6px rgba(214,247,58,.55)}
.name{font-family:'Bricolage Grotesque',sans-serif;font-size:18px;font-weight:800;letter-spacing:-.01em}
.name .gold{color:var(--optic)}
.nav{display:flex;gap:3px;align-items:center;position:relative}
.nav>a{color:var(--ink-2);padding:9px 13px;border-radius:9px;font-size:13.5px;font-weight:600;transition:.16s}
.nav>a:hover{background:var(--panel-2);color:var(--ink)}
.nav>a.active{color:var(--optic)}
.nav>a.active::after{content:"";display:block;height:2px;margin-top:5px;border-radius:2px;background:var(--optic)}
[data-auth-slot]{display:flex;gap:10px;align-items:center;margin-left:6px}
.tk-discord{background:var(--discord);color:#fff;border:0;font-weight:700;font-size:13px;padding:9px 15px;border-radius:9px;cursor:pointer;transition:.16s}
.tk-discord:hover{filter:brightness(1.1);transform:translateY(-1px)}
.tk-signout{border:1px solid var(--hair-2);background:transparent;color:var(--ink-2);font-weight:600;font-size:12px;padding:7px 12px;border-radius:8px;cursor:pointer}
.tk-user{font-weight:800;color:var(--optic);font-size:13px}

/* nav dropdowns */
.navgrp{position:relative}
.navgrp-btn{background:transparent;border:0;color:var(--ink-2);font-weight:600;font-size:13.5px;
  padding:9px 13px;border-radius:9px;cursor:pointer;font-family:inherit;transition:.16s}
.navgrp-btn:hover{background:var(--panel-2);color:var(--ink)}
.navgrp-menu{position:absolute;top:100%;right:0;min-width:206px;margin-top:4px;
  background:rgba(17,26,19,.97);border:1px solid var(--hair-2);border-radius:13px;padding:7px;
  display:none;z-index:120;box-shadow:var(--shadow);backdrop-filter:blur(14px)}
.navgrp::after{content:"";position:absolute;top:100%;right:0;width:140px;height:10px;display:none}
.navgrp:hover::after{display:block}
.navgrp:hover .navgrp-menu,.navgrp.open .navgrp-menu{display:block;animation:pop .16s ease both}
.navgrp.open>.navgrp-btn{color:var(--optic)}
.navgrp-menu a{display:block;padding:9px 12px;border-radius:8px;color:var(--ink-2);font-size:13.5px;font-weight:600;transition:.12s}
.navgrp-menu a:hover{background:var(--panel-2);color:var(--optic);transform:translateX(2px)}

/* header search */
.navsearch{margin-left:auto;background:var(--panel-2);border:1px solid var(--hair);color:var(--ink);
  border-radius:10px;padding:9px 13px;font-size:13.5px;width:210px;font-family:inherit;transition:.18s}
.navsearch:focus{outline:none;border-color:var(--optic);width:248px;background:var(--panel-solid)}
.navsearch::placeholder{color:var(--ink-3)}
.navsearch-results{position:absolute;top:60px;right:24px;width:300px;max-height:380px;overflow:auto;
  background:rgba(17,26,19,.97);border:1px solid var(--hair-2);border-radius:13px;display:none;z-index:210;
  box-shadow:var(--shadow);backdrop-filter:blur(14px)}
.navsearch-results.open{display:block;animation:pop .16s ease both}
.navsearch-results a{display:flex;justify-content:space-between;gap:10px;padding:10px 14px;
  border-bottom:1px solid var(--hair);color:var(--ink-2);font-size:13.5px;font-weight:600}
.navsearch-results a:last-child{border-bottom:0}
.navsearch-results a:hover,.navsearch-results a.sel{background:var(--panel-2);color:var(--ink)}
.navsearch-results .r-tour{color:var(--ink-3);font-size:11px;font-weight:700;font-family:'JetBrains Mono',monospace}
@media(max-width:820px){.navsearch{width:140px}.navsearch:focus{width:170px}.nav .navgrp:nth-last-child(n+2){display:none}}

/* ---------- layout ---------- */
.wrap{max-width:1140px;margin:0 auto;padding:34px 24px 84px}
.hero{animation:rise .6s cubic-bezier(.2,.8,.2,1) both}
.hero h1{font-size:clamp(46px,8vw,86px);letter-spacing:-.04em;line-height:.9}
.hero h1 .gold{color:var(--optic);position:relative}
.hero p{color:var(--ink-2);max-width:680px;margin:14px 0 0;font-size:16px}
.hero .pill{margin-bottom:18px}
.sect{margin-top:38px;animation:rise .6s cubic-bezier(.2,.8,.2,1) both}
.sect:nth-of-type(2){animation-delay:.06s} .sect:nth-of-type(3){animation-delay:.12s}
.sect:nth-of-type(4){animation-delay:.18s}
.sect h2{font-size:15px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);
  font-weight:800;margin-bottom:16px;display:flex;align-items:center;gap:12px}
.sect h2::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,var(--hair-2),transparent)}
h3{font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-2);font-weight:800}

/* ---------- panels / cards ---------- */
.panel{background:linear-gradient(168deg,var(--panel-2),var(--panel-solid));
  border:1px solid var(--hair);border-radius:var(--r);box-shadow:var(--shadow);position:relative}
a.panel,.matchcard{transition:transform .18s cubic-bezier(.2,.8,.2,1),border-color .18s,box-shadow .18s}
.matchcard{cursor:pointer}
a.panel:hover,.matchcard:hover{transform:translateY(-3px);border-color:var(--hair-2);
  box-shadow:0 26px 50px -22px rgba(0,0,0,.8),0 0 0 1px rgba(214,247,58,.12)}
.note{margin-top:30px;color:var(--ink-3);font-size:12.5px;line-height:1.7;border-top:1px solid var(--hair);padding-top:18px}
.note a{color:var(--optic-2);text-decoration:underline;text-underline-offset:2px}
.pill{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:800;letter-spacing:.1em;
  text-transform:uppercase;color:var(--optic);background:rgba(214,247,58,.1);
  border:1px solid rgba(214,247,58,.22);padding:5px 11px;border-radius:999px}

/* ---------- the lens (rankings/stats controls) ---------- */
.lens{display:flex;flex-wrap:wrap;gap:11px;align-items:center;margin-top:22px}
.seg{display:inline-flex;background:var(--panel-2);border:1px solid var(--hair);border-radius:11px;padding:3px;gap:2px}
.seg button{background:transparent;border:0;color:var(--ink-2);font-weight:800;font-size:13px;
  padding:8px 17px;cursor:pointer;letter-spacing:.02em;border-radius:8px;transition:.16s;font-family:inherit}
.seg button[aria-pressed="true"]{background:var(--optic);color:var(--optic-ink);box-shadow:0 4px 12px -4px rgba(214,247,58,.5)}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{border:1px solid var(--hair);background:var(--panel-2);color:var(--ink-2);font-weight:700;font-size:12.5px;
  padding:8px 14px;border-radius:999px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:.16s}
.chip:hover{border-color:var(--hair-2);color:var(--ink)}
.chip[aria-pressed="true"]{color:var(--ink);border-color:transparent}
.chip[data-surface="overall"][aria-pressed="true"]{background:var(--raise)}
.chip[data-surface="hard"][aria-pressed="true"]{background:color-mix(in srgb,var(--hard) 30%,var(--panel-solid));box-shadow:0 0 0 1px var(--hard) inset}
.chip[data-surface="clay"][aria-pressed="true"]{background:color-mix(in srgb,var(--clay) 30%,var(--panel-solid));box-shadow:0 0 0 1px var(--clay) inset}
.chip[data-surface="grass"][aria-pressed="true"]{background:color-mix(in srgb,var(--grass) 32%,var(--panel-solid));box-shadow:0 0 0 1px var(--grass) inset}
.dot{width:9px;height:9px;border-radius:50%}
.dot.hard{background:var(--hard)} .dot.clay{background:var(--clay)} .dot.grass{background:var(--grass)} .dot.overall{background:var(--ink-3)}
.breadcrumb{margin-left:auto;color:var(--ink-3);font-size:12px;font-weight:700;letter-spacing:.04em;font-family:'JetBrains Mono',monospace}
.breadcrumb b{color:var(--optic-2)}

/* ---------- ranking rows ---------- */
.rrow{display:grid;grid-template-columns:46px 1fr auto;gap:15px;align-items:center;padding:13px 18px;border-bottom:1px solid var(--hair);transition:.14s}
.rrow:last-child{border-bottom:0}
.rrow:hover{background:var(--panel-2)}
.rrank{font-family:'Bricolage Grotesque',sans-serif;font-size:23px;font-weight:800;color:var(--ink-4);text-align:center}
.rrow:nth-child(-n+3) .rrank{color:var(--optic)}
.rname{font-weight:800;font-size:15.5px;letter-spacing:-.01em}
.rmeta{color:var(--ink-3);font-size:12px;margin-top:1px;font-family:'JetBrains Mono',monospace}
.relo{font-family:'JetBrains Mono',monospace;font-weight:700;font-size:17px;text-align:right}
.relo small{display:block;color:var(--ink-4);font-size:10px;font-weight:700;letter-spacing:.1em}

/* ---------- match cards (Today) ---------- */
.matchcard{display:block;padding:16px 18px;text-decoration:none}
.mc-top{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:13px}
.mc-meta{color:var(--ink-3);font-size:11px;font-weight:700;font-family:'JetBrains Mono',monospace;letter-spacing:-.01em}
.mc-row{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:4px 0}
.mc-name{font-weight:800;font-size:16px;letter-spacing:-.01em;display:flex;align-items:center;gap:9px;min-width:0}
.mc-name a{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mc-pct{font-family:'JetBrains Mono',monospace;font-weight:800;font-size:18px;color:var(--ink-4)}
.mc-pct.fav{color:var(--optic)}
.mc-foot{display:flex;justify-content:space-between;gap:10px;color:var(--ink-3);font-size:11.5px;
  margin-top:12px;padding-top:11px;border-top:1px solid var(--hair);font-family:'JetBrains Mono',monospace}
.mc-val{display:flex;flex-wrap:wrap;gap:7px;margin-top:11px}
.vchip{font-size:11px;font-weight:800;padding:5px 10px;border-radius:8px;letter-spacing:.01em;
  background:rgba(84,227,154,.12);color:var(--pos);border:1px solid rgba(84,227,154,.26)}

/* ---------- match rows (lists) ---------- */
.mrow{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;padding:14px 18px;border-bottom:1px solid var(--hair);transition:.14s}
.mrow:last-child{border-bottom:0}
.mrow:hover{background:var(--panel-2)}
.mteams{font-weight:800;font-size:15px}
.mmeta{color:var(--ink-3);font-size:12px;margin-top:2px;font-family:'JetBrains Mono',monospace}

/* ---------- probability bars ---------- */
.bar{position:relative;height:7px;border-radius:99px;background:rgba(255,255,255,.05);margin-top:5px;overflow:hidden}
.bar span{position:absolute;left:0;top:0;bottom:0;border-radius:99px;transform-origin:left;
  background:linear-gradient(90deg,var(--optic),var(--optic-2));
  animation:grow .8s cubic-bezier(.2,.85,.25,1) both}

/* ---------- player page ---------- */
.pp-head{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-end;margin-top:6px;animation:rise .6s cubic-bezier(.2,.8,.2,1) both}
.pp-name{font-family:'Bricolage Grotesque',sans-serif;font-size:clamp(38px,6.5vw,64px);font-weight:800;letter-spacing:-.035em;line-height:.92}
.pp-meta{color:var(--ink-2);font-size:13px;font-weight:600;display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-top:10px}
.pp-rankpill{background:var(--optic);color:var(--optic-ink);font-weight:800;padding:5px 13px;border-radius:999px;font-size:12.5px;letter-spacing:.02em;
  box-shadow:0 6px 16px -6px rgba(214,247,58,.5)}
.statgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(125px,1fr));gap:1px;
  background:var(--hair);border:1px solid var(--hair);border-radius:var(--r);overflow:hidden;margin-top:22px;box-shadow:var(--shadow)}
.statgrid .cell{background:linear-gradient(168deg,var(--panel-2),var(--panel-solid));padding:16px 18px;position:relative;transition:.18s}
.statgrid .cell:hover{background:var(--raise)}
.statgrid .cell::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--optic),transparent);opacity:0;transition:.2s}
.statgrid .cell:hover::before{opacity:.7}
.statgrid .v{font-family:'Bricolage Grotesque',sans-serif;font-size:34px;font-weight:800;line-height:1;letter-spacing:-.02em}
.statgrid .v.pos{color:var(--pos)} .statgrid .v.gold{color:var(--optic)}
.statgrid .lbl{color:var(--ink-3);font-size:10.5px;font-weight:800;letter-spacing:.11em;text-transform:uppercase;margin-top:6px}

/* tabs */
.tabs{display:flex;gap:4px;flex-wrap:wrap;margin:30px 0 16px;border-bottom:1px solid var(--hair)}
.tab{background:transparent;border:0;border-bottom:2px solid transparent;color:var(--ink-3);
  font-weight:800;font-size:13px;letter-spacing:.02em;padding:11px 16px;cursor:pointer;font-family:inherit;transition:.16s;margin-bottom:-1px}
.tab:hover{color:var(--ink-2)}
.tab.active{color:var(--optic);border-bottom-color:var(--optic)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:15px}
@media(max-width:680px){.grid2{grid-template-columns:1fr}}
.kv{display:flex;justify-content:space-between;gap:14px;padding:11px 0;border-bottom:1px solid var(--hair);font-size:13.5px}
.kv:last-child{border-bottom:0}
.kv .k{color:var(--ink-2)} .kv .val{font-family:'JetBrains Mono',monospace;font-weight:700;text-align:right}

/* surface bars */
.surfbar{display:grid;grid-template-columns:52px 1fr 104px;gap:12px;align-items:center;padding:9px 0}
.surfbar .nm{font-size:12px;font-weight:800;color:var(--ink-2);letter-spacing:.02em}
.surfbar .track{height:9px;border-radius:99px;background:rgba(255,255,255,.05);overflow:hidden}
.surfbar .fill{display:block;height:100%;border-radius:99px;transform-origin:left;animation:grow .85s cubic-bezier(.2,.85,.25,1) both}
.fill.hard{background:linear-gradient(90deg,var(--hard),#7cc0ff)} .fill.clay{background:linear-gradient(90deg,var(--clay),#ff9e6e)} .fill.grass{background:linear-gradient(90deg,var(--grass),#62e496)}
.surfbar span:last-child{font-family:'JetBrains Mono',monospace;font-weight:700;text-align:right;font-size:13px}

/* tables */
.mtable{width:100%;border-collapse:collapse;font-size:13px}
.mtable th{text-align:left;color:var(--ink-3);font-size:10.5px;text-transform:uppercase;letter-spacing:.07em;
  padding:11px 12px;border-bottom:1px solid var(--hair-2);font-weight:800;white-space:nowrap;position:sticky;top:0;background:var(--panel-solid)}
.mtable th.sortcol{color:var(--optic)}
.mtable td{padding:11px 12px;border-bottom:1px solid var(--hair)}
.mtable tbody tr{transition:.12s}
.mtable tbody tr:hover td{background:var(--panel-2)}
.res-w{color:var(--pos);font-weight:800} .res-l{color:var(--ink-4);font-weight:800}
.s-tag{font-size:9.5px;font-weight:800;padding:3px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.05em}
.s-tag.hard{background:color-mix(in srgb,var(--hard) 22%,transparent);color:#9cc4ff}
.s-tag.clay{background:color-mix(in srgb,var(--clay) 28%,transparent);color:#ffb38a}
.s-tag.grass{background:color-mix(in srgb,var(--grass) 26%,transparent);color:#7fe0a8}

@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes grow{from{transform:scaleX(0)}to{transform:scaleX(1)}}
@keyframes pop{from{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
@media(max-width:560px){.breadcrumb{width:100%;margin:6px 0 0}.rrow{grid-template-columns:34px 1fr auto;gap:11px}.wrap{padding:24px 16px 70px}}

.wstar.on{color:var(--optic)!important}

/* ---------- mobile drawer + app-shell polish (Phase 4) ---------- */
.burger{display:none;background:none;border:0;color:var(--ink);font-size:22px;cursor:pointer;margin-left:8px;padding:4px 8px;line-height:1}
@media(max-width:820px){
  .nav{display:none}
  .burger{display:block}
  input[type=search]{font-size:16px}        /* stop iOS focus-zoom */
}
.drawer{position:fixed;top:0;right:0;bottom:0;width:min(84vw,330px);background:var(--panel-solid);
  border-left:1px solid var(--hair-2);z-index:320;transform:translateX(100%);
  transition:transform .26s cubic-bezier(.2,.8,.2,1);padding:18px 18px calc(28px + env(safe-area-inset-bottom));
  overflow:auto;box-shadow:-22px 0 60px rgba(0,0,0,.55)}
.drawer.open{transform:none}
.drawer-scrim{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:310;opacity:0;pointer-events:none;transition:opacity .26s;backdrop-filter:blur(2px)}
.drawer-scrim.open{opacity:1;pointer-events:auto}
.drawer h4{color:var(--ink-3);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;margin:16px 0 4px;font-weight:800}
.drawer a{display:block;padding:12px 11px;border-radius:10px;color:var(--ink);font-weight:700;font-size:15.5px}
.drawer a:active,.drawer a:hover{background:var(--panel-2);color:var(--optic)}
.drawer-close{background:none;border:0;color:var(--ink-2);font-size:26px;cursor:pointer;float:right;line-height:1}
.drawer [data-auth-slot]{margin-top:8px}
/* app-shell: kill tap highlight, allow safe areas */
*{-webkit-tap-highlight-color:transparent}
@supports(padding:max(0px)){.topbar{padding-left:max(24px,env(safe-area-inset-left));padding-right:max(24px,env(safe-area-inset-right))}}

/* ---------- glossary tooltips ---------- */
.gloss-term{border-bottom:1px dotted var(--ink-4);cursor:help}
.gloss-pop{position:fixed;display:none;z-index:400;background:rgba(17,26,19,.98);border:1px solid var(--hair-2);
  border-radius:11px;padding:11px 13px;font-size:12.5px;line-height:1.5;color:var(--ink-2);
  box-shadow:var(--shadow);backdrop-filter:blur(12px);font-family:'Hanken Grotesk',sans-serif;font-weight:500;letter-spacing:0}

/* ---------- install banner ---------- */
.install-banner{position:fixed;left:50%;transform:translateX(-50%);bottom:calc(16px + env(safe-area-inset-bottom));
  z-index:330;display:flex;align-items:center;gap:14px;background:rgba(17,26,19,.97);border:1px solid var(--hair-2);
  border-radius:14px;padding:11px 12px 11px 16px;box-shadow:var(--shadow);backdrop-filter:blur(14px);
  font-size:13.5px;max-width:calc(100vw - 28px);animation:rise .4s both}
.install-banner b{color:var(--optic)}
.ib-actions{display:flex;gap:7px;align-items:center;flex-shrink:0}
.ib-add{background:var(--optic);color:var(--optic-ink);border:0;font-weight:800;font-size:13px;padding:8px 14px;border-radius:9px;cursor:pointer}
.ib-x{background:transparent;border:0;color:var(--ink-3);font-size:20px;cursor:pointer;line-height:1;padding:0 4px}

/* ---------- standalone bottom tab bar ---------- */
.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:300;display:flex;
  background:rgba(10,15,12,.92);border-top:1px solid var(--hair);backdrop-filter:blur(16px);
  padding-bottom:env(safe-area-inset-bottom)}
.tabbar a{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:9px 0 7px;
  color:var(--ink-3);font-size:10.5px;font-weight:700;letter-spacing:.02em}
.tabbar a.active{color:var(--optic)}
.tabbar .ti{font-size:18px;line-height:1}
body.has-tabbar{padding-bottom:62px}
body.has-tabbar .install-banner{bottom:calc(70px + env(safe-area-inset-bottom))}

/* ---------- share button ---------- */
.tk-share{background:var(--panel-2);border:1px solid var(--hair-2);color:var(--ink-2);font-weight:800;
  font-size:12.5px;padding:8px 14px;border-radius:9px;cursor:pointer;font-family:inherit;transition:.16s}
.tk-share:hover{border-color:var(--optic);color:var(--optic)}

/* active nav (set by shell.js) */
.navgrp-btn.active{color:var(--optic)}
.navgrp-menu a.active,.drawer a.active{color:var(--optic)}

/* model-lean chip (Today cards) — neutral, not a "guaranteed winner" green */
.echip{font-size:11px;font-weight:700;padding:5px 10px;border-radius:8px;letter-spacing:.01em;
  background:var(--panel-2);color:var(--ink-2);border:1px solid var(--hair-2)}
.echip b{color:var(--optic)} .echip .m{color:var(--ink-3);font-weight:600}

/* mobile: keep "Sign in"/account visible in the top bar (not just the drawer) */
.auth-mobile{display:none}
@media(max-width:820px){
  .auth-mobile{display:flex;align-items:center;gap:8px;margin-left:auto}
  .auth-mobile .tk-discord{font-size:12px;padding:8px 12px}
  .navsearch{margin-left:8px}
}
@media(max-width:520px){ .navsearch{display:none} }   /* tightest screens: drop inline search to fit logo+login+menu */

/* --- bet slip: floating badge, toast, add-to-slip buttons, parlay page --- */
.slip-badge{position:fixed;right:18px;bottom:18px;z-index:60;display:none;align-items:center;gap:8px;
  background:linear-gradient(135deg,var(--ball),var(--optic));color:#0a0f0c;font-weight:800;
  padding:11px 15px;border-radius:999px;text-decoration:none;box-shadow:0 6px 22px rgba(0,0,0,.45);
  font-family:'Hanken Grotesk',sans-serif;transition:transform .12s}
.slip-badge:hover{transform:translateY(-2px)}
.slip-badge .sb-ic{font-size:16px;line-height:1}
.slip-badge .sb-n{background:#0a0f0c;color:var(--optic);border-radius:999px;min-width:20px;height:20px;
  display:inline-flex;align-items:center;justify-content:center;font-size:12px;padding:0 6px}
.has-tabbar .slip-badge{bottom:74px}
.slip-toast{position:fixed;left:50%;bottom:30px;translate:-50% 20px;z-index:70;
  background:var(--panel-2);color:var(--ink);border:1px solid var(--hair);border-left:3px solid var(--optic);
  padding:11px 16px;border-radius:10px;font-weight:700;font-size:14px;opacity:0;pointer-events:none;
  transition:opacity .2s,translate .2s;box-shadow:0 6px 22px rgba(0,0,0,.4)}
.slip-toast.show{opacity:1;translate:-50% 0}
.slip-btn{cursor:pointer;background:rgba(214,247,58,.1);border:1px solid rgba(214,247,58,.3);color:var(--optic);
  font-weight:800;font-size:11px;border-radius:7px;padding:3px 9px;font-family:inherit;white-space:nowrap;transition:background .12s}
.slip-btn:hover{background:rgba(214,247,58,.2)}
.slip-btn.in{background:var(--optic);color:#0a0f0c;border-color:var(--optic)}

/* --- alerts: topbar bell + dropdown panel --- */
.alert-bell{position:relative;background:none;border:0;cursor:pointer;font-size:18px;line-height:1;padding:6px;margin-left:4px;filter:grayscale(.2)}
.alert-bell:hover{filter:none}
.alert-bell .ab-n{position:absolute;top:-2px;right:-2px;background:var(--optic);color:#0a0f0c;font-size:10px;font-weight:800;
  min-width:16px;height:16px;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 4px;font-family:'Hanken Grotesk'}
.alert-panel{position:fixed;z-index:80;width:min(360px,calc(100vw - 24px));background:var(--panel);border:1px solid var(--hair);
  border-radius:14px;box-shadow:0 14px 44px rgba(0,0,0,.5);opacity:0;visibility:hidden;transform:translateY(-6px);
  transition:opacity .14s,transform .14s,visibility .14s;overflow:hidden;max-height:78vh;display:flex;flex-direction:column}
.alert-panel.open{opacity:1;visibility:visible;transform:none}
.al-head{display:flex;justify-content:space-between;align-items:center;padding:13px 16px;border-bottom:1px solid var(--hair);font-size:15px}
.al-read{background:none;border:0;color:var(--optic);font-weight:700;cursor:pointer;font-size:12px;font-family:inherit}
.al-list{overflow:auto;flex:1}
.al-item{display:grid;grid-template-columns:26px 1fr;gap:10px;padding:11px 16px;border-bottom:1px solid var(--hair);text-decoration:none;color:var(--ink)}
.al-item:hover{background:var(--panel-2)}
.al-item.new{background:rgba(214,247,58,.05)}
.al-item.new .al-t::after{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--optic);margin-left:6px;vertical-align:middle}
.al-ic{font-size:14px;text-align:center;line-height:1.4}
.al-edge{color:var(--optic)}.al-arb{color:var(--optic)}.al-watch{color:var(--ball)}
.al-t{display:block;font-weight:700;font-size:13px}
.al-s{display:block;color:var(--ink-3);font-size:11.5px;margin-top:1px}
.al-empty{padding:22px 16px;color:var(--ink-3);font-size:13px;line-height:1.6}
.al-settings{border-top:1px solid var(--hair);padding:12px 16px;background:var(--panel-2);display:flex;flex-direction:column;gap:8px}
.al-opt{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-2);cursor:pointer}
.al-opt input{accent-color:var(--optic)}
.al-sel{background:var(--panel);border:1px solid var(--hair);color:var(--ink);border-radius:6px;padding:2px 6px;font-family:inherit;margin-top:-4px;align-self:flex-start}
.al-notify{margin-top:4px;background:rgba(214,247,58,.1);border:1px solid rgba(214,247,58,.3);color:var(--optic);
  font-weight:700;border-radius:8px;padding:8px 12px;cursor:pointer;font-family:inherit;font-size:12.5px}
.al-notify[data-state="on"]{background:var(--optic);color:#0a0f0c}
.al-notify[data-state="blocked"]{opacity:.6;cursor:not-allowed}
.al-foot{color:var(--ink-4);font-size:10.5px;line-height:1.5;margin-top:2px}
.al-off{background:none;border:1px solid var(--hair-2);color:var(--ink-3);font-weight:600;border-radius:8px;padding:6px 12px;cursor:pointer;font-family:inherit;font-size:12px;align-self:flex-start}
.al-off:hover{color:var(--neg);border-color:rgba(255,138,138,.3)}
