/* ===========================================================================
   TrackBJJ / Track* shared brand design system  (task #29)
   One source of truth for the whole suite. Fonts are <link>-loaded in base.
   =========================================================================== */
:root{
  --bg:#0a0a0c;--bg2:#0d0d10;--panel:#111114;--ink:#f5f2ea;--muted:#8d8a83;--faint:#56544f;
  --line:rgba(245,242,234,.10);--line2:rgba(245,242,234,.055);--crimson:#e7392e;--crimson-dim:#a3251d;
  --gold:#e9b949;--win:#41d18a;--loss:#e8503f;--mgold:#e9b949;--msilver:#c4cad3;--mbronze:#cd824b;
  --ease:cubic-bezier(.2,.7,.2,1);
  /* legacy aliases — keeps older page markup styled on the new palette */
  --card:#111114;--border:rgba(245,242,234,.10);--text:#f5f2ea;--accent:#e7392e;--gray:#17171c;
  --silver:#c4cad3;--bronze:#cd824b;--green:#41d18a;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--ink);font-family:"Hanken Grotesk",system-ui,sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden;min-height:100vh}
a{color:inherit;text-decoration:none}
body::before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;background:radial-gradient(1100px 680px at 80% -10%,rgba(231,57,46,.22),transparent 60%),radial-gradient(820px 560px at 2% 6%,rgba(233,185,73,.06),transparent 55%)}
body::after{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.05;mix-blend-mode:overlay;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>")}

/* ── shells ── */
.wrap,.container{position:relative;z-index:1;max-width:1080px;margin:0 auto;padding:0 18px}
@media(min-width:740px){.wrap,.container{padding:0 28px}}
.container{padding-top:24px;padding-bottom:24px}

/* ── top nav ── */
.nav{position:sticky;top:0;z-index:40;backdrop-filter:saturate(1.2) blur(12px);background:linear-gradient(180deg,rgba(10,10,12,.92),rgba(10,10,12,.55));border-bottom:1px solid var(--line)}
.nav-in{max-width:1080px;margin:0 auto;padding:13px 18px;display:flex;align-items:center;justify-content:space-between;gap:12px}
@media(min-width:740px){.nav-in{padding:15px 28px}}
.brand{display:flex;align-items:baseline;gap:9px;font-family:"Anton";letter-spacing:.05em;font-size:21px}
.brand .x{color:var(--crimson)}
.brand small{font-family:"JetBrains Mono";font-weight:500;font-size:9px;letter-spacing:.26em;color:var(--faint);text-transform:uppercase}
.nav-links{display:none;gap:4px}@media(min-width:740px){.nav-links{display:flex}}
.nav-links a{font-family:"JetBrains Mono";font-size:12px;color:var(--muted);padding:8px 12px;border-radius:8px}
.nav-links a:hover,.nav-links a.on{color:var(--ink);background:rgba(255,255,255,.04)}
.nav-cta{font-family:"JetBrains Mono";font-size:12px;color:var(--bg);background:var(--ink);border:none;border-radius:8px;padding:9px 15px;font-weight:700;cursor:pointer;white-space:nowrap}
.nav-search{flex:1;max-width:360px;display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.045);border:1px solid var(--line);border-radius:9px;padding:8px 12px;margin:0 4px;transition:border-color .15s}
.nav-search:focus-within{border-color:rgba(231,57,46,.5)}
.nav-search svg{flex-shrink:0;color:var(--faint)}
.nav-search input{flex:1;min-width:0;background:none;border:none;outline:none;color:var(--ink);font-family:"Hanken Grotesk";font-size:13.5px}
.nav-search input::placeholder{color:var(--faint)}
@media(max-width:640px){.nav-search{display:none}}

/* ── mobile bottom tab bar ── */
.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:45;display:flex;background:linear-gradient(0deg,rgba(8,8,10,.98),rgba(8,8,10,.86));border-top:1px solid var(--line);padding:7px 6px calc(7px + env(safe-area-inset-bottom));backdrop-filter:blur(14px)}
.tabbar a{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 2px;font-family:"JetBrains Mono";font-size:9.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint)}
.tabbar a .ic{font-size:18px}
.tabbar a.on{color:var(--crimson)}
@media(min-width:740px){.tabbar{display:none}}
body{padding-bottom:74px}@media(min-width:740px){body{padding-bottom:0}}

/* ── eyebrow / section headers ── */
.eyebrow{font-family:"JetBrains Mono";font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--crimson);font-weight:500;display:flex;align-items:center;gap:12px}
.eyebrow::after{content:"";height:1px;flex:1;max-width:120px;background:linear-gradient(90deg,var(--crimson-dim),transparent)}
.sec{margin-top:32px}@media(min-width:740px){.sec{margin-top:40px}}
.sec-h{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.sec-h h2{font-family:"Anton";font-size:14px;letter-spacing:.16em;text-transform:uppercase;white-space:nowrap}
.sec-h .ln{height:1px;flex:1;background:var(--line)}
.sec-h .src{font-family:"JetBrains Mono";font-size:10.5px;color:var(--crimson);white-space:nowrap}
.section-title{font-family:"JetBrains Mono";font-size:.72rem;font-weight:500;text-transform:uppercase;letter-spacing:.14em;color:var(--faint);margin:2rem 0 .75rem;display:flex;align-items:center;gap:.6rem}
.section-title::after{content:'';flex:1;height:1px;background:var(--line)}

/* ── profile hero ── */
header.pro{padding:30px 0 24px;border-bottom:1px solid var(--line)}
.hero{display:grid;grid-template-columns:1fr;gap:22px;align-items:end}@media(min-width:760px){.hero{grid-template-columns:1fr 290px;gap:30px}}
h1.name{font-family:"Anton";font-weight:400;line-height:.86;letter-spacing:.005em;font-size:clamp(44px,9vw,96px);text-transform:uppercase;margin-top:12px}
.name-accent{display:block;height:7px;width:138px;margin:16px 0 0;background:linear-gradient(90deg,var(--crimson),var(--gold));border-radius:2px}
.meta{margin-top:16px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.meta .m{font-family:"JetBrains Mono";font-size:12px;color:var(--muted)}
.meta .dot{color:var(--faint)}
.meta .team{color:var(--ink);font-weight:600;font-size:13.5px;border-bottom:1px solid var(--crimson-dim);padding-bottom:1px}
.belt{font-family:"JetBrains Mono";font-weight:700;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:#1b1b20;border:1px solid #33333b;border-radius:5px;padding:6px 10px;display:inline-flex;align-items:center;gap:7px}
.belt::before{content:"";width:8px;height:8px;border-radius:1px;background:#0c0c10;box-shadow:0 0 0 1px #3a3a44,11px 0 0 -1px var(--crimson)}
.rail{border-top:1px solid var(--line);padding-top:18px;display:flex;flex-direction:column;gap:2px}
@media(min-width:760px){.rail{border-top:none;border-left:1px solid var(--line);padding-top:0;padding-left:26px;align-self:stretch;justify-content:flex-end}}
.rail .lab{font-family:"JetBrains Mono";font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--faint)}
.elo{font-family:"Anton";font-size:clamp(72px,18vw,92px);line-height:.9;background:linear-gradient(180deg,#fff,#cfc6b4);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.rail-row{display:flex;gap:20px;margin-top:14px;flex-wrap:wrap}
.rail-row .v{font-family:"Anton";font-size:24px}.rail-row .v.gold{color:var(--gold)}
.rail-row .t{font-family:"JetBrains Mono";font-size:9px;letter-spacing:.13em;text-transform:uppercase;color:var(--faint);margin-top:3px}
.rec{font-family:"Anton";font-size:24px;margin-top:1px}.rec .w{color:var(--win)}.rec .l{color:var(--loss)}.rec .s{color:var(--faint);font-size:17px}
.badges{margin-top:18px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.bdg{font-family:"JetBrains Mono";font-size:10.5px;color:var(--muted);border:1px solid var(--line);border-radius:6px;padding:5px 10px}
.bdg.ok{color:var(--win);border-color:rgba(65,209,138,.3)}.bdg.go{color:var(--crimson)}

/* ── stat tiles ── */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:9px}@media(min-width:560px){.stats{grid-template-columns:repeat(5,1fr)}}
.stat{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:12px;padding:16px 15px;position:relative;overflow:hidden}
.stat::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent,#2a2a30)}
.stat .n{font-family:"Anton";font-size:36px;line-height:1}
.stat .t{font-family:"JetBrains Mono";font-size:9.5px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-top:7px}
.stat.cy::before{background:var(--crimson)}
.stat.gold{--accent:var(--mgold)}.stat.gold .n{color:var(--mgold)}
.stat.silver{--accent:var(--msilver)}.stat.silver .n{color:var(--msilver)}
.stat.bronze{--accent:var(--mbronze)}.stat.bronze .n{color:var(--mbronze)}
/* legacy stat-box (homepage) */
.stat-box{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:12px;padding:1rem 1.5rem;text-align:center;min-width:130px}
.stat-box .num,.stat-card .num{font-family:"Anton";font-size:1.9rem;line-height:1;color:var(--ink)}
.stat-box .lbl,.stat-card .lbl{font-family:"JetBrains Mono";font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.12em;margin-top:.35rem}
.cyan-num{color:var(--crimson)}.gold-num{color:var(--mgold)}.silver-num{color:var(--msilver)}.bronze-num{color:var(--mbronze)}

/* ── ranking cards ── */
.ranks{display:grid;grid-template-columns:repeat(2,1fr);gap:9px}@media(min-width:760px){.ranks{grid-template-columns:repeat(4,1fr)}}
.rk{background:radial-gradient(120% 100% at 100% 0,rgba(231,57,46,.06),transparent 70%),var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px 15px;position:relative}
.rk.one{border-color:rgba(233,185,73,.45);background:radial-gradient(130% 100% at 100% 0,rgba(233,185,73,.14),transparent 65%),var(--panel)}
.rk .rank-num{font-family:"Anton";font-size:44px;line-height:.86}.rk.one .rank-num{color:var(--gold)}
.rk .rank-num.unranked{font-size:26px;color:var(--faint)}
.rk .rank-lbl{font-family:"JetBrains Mono";font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:9px}
.rk .rank-sub{font-family:"JetBrains Mono";font-size:10.5px;color:var(--faint);margin-top:4px}

/* ── cards + tables ── */
.card{background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden}
table{width:100%;border-collapse:collapse}
thead th,th{font-family:"JetBrains Mono";font-size:9.5px;letter-spacing:.15em;text-transform:uppercase;color:var(--faint);text-align:left;padding:13px 16px;border-bottom:1px solid var(--line);font-weight:500}
thead th.r,td.r{text-align:right}
tbody td,td{padding:13px 16px;border-bottom:1px solid var(--line2);font-size:14px;vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover td,tr:hover td{background:rgba(255,255,255,.018)}
.lnk,.name-link,.team-link,.athlete-row-link{color:var(--ink)}
.lnk:hover,.name-link:hover,.team-link:hover,.athlete-row-link:hover{color:var(--crimson);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
/* athlete-name links — always visibly clickable (opponents, bracket mates, rivals) */
.aln{color:#ef6f63;text-decoration:none;border-bottom:1px solid rgba(239,111,99,.28)}
.aln:hover{color:#ff8a80;border-bottom-color:#ff8a80}
.dim{color:var(--muted);font-size:13px}
.mono{font-family:"JetBrains Mono";font-size:11.5px;color:var(--faint)}
.more{padding:13px 16px;border-top:1px solid var(--line);text-align:center;background:var(--bg2)}
.more button{background:none;border:none;color:var(--crimson);font-family:"JetBrains Mono";font-size:12px;cursor:pointer;letter-spacing:.04em}
.place-col{font-weight:700}.place-1{color:var(--mgold);font-weight:700}.place-2{color:var(--msilver);font-weight:700}.place-3{color:var(--mbronze);font-weight:700}

/* ── pills, medals, ribbons ── */
.pill{font-family:"JetBrains Mono";font-weight:700;font-size:10.5px;letter-spacing:.07em;padding:4px 9px;border-radius:5px;display:inline-block}
.pill.w{color:var(--win);background:rgba(65,209,138,.10);border:1px solid rgba(65,209,138,.30)}
.pill.l{color:var(--loss);background:rgba(232,80,63,.10);border:1px solid rgba(232,80,63,.28)}
.medal{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:8px;vertical-align:middle}
.m1{background:var(--mgold);box-shadow:0 0 9px rgba(233,185,73,.6)}.m2{background:var(--msilver)}.m3{background:var(--mbronze)}
.rib,.org-tag,.tag{font-family:"JetBrains Mono";font-weight:700;font-size:9.5px;letter-spacing:.07em;text-transform:uppercase;padding:3px 7px;border-radius:4px;border:1px solid transparent;white-space:nowrap;display:inline-block;line-height:1}
.rib-sc,.tag-sc{background:rgba(123,140,222,.14);color:#9aa6e8;border-color:rgba(123,140,222,.34)}
.rib-ibjjf,.tag-ibjjf{background:rgba(65,209,138,.12);color:#5fd6a0;border-color:rgba(65,209,138,.32)}
.rib-naga,.tag-naga{background:rgba(229,115,115,.14);color:#ee8585;border-color:rgba(229,115,115,.32)}
.rib-compnet,.tag-compnet{background:rgba(77,208,225,.12);color:#5fd3e0;border-color:rgba(77,208,225,.32)}
.rib-adcc,.tag-adcc{background:rgba(233,185,73,.14);color:var(--gold);border-color:rgba(233,185,73,.36)}
.rib-ajp,.tag-ajp{background:rgba(102,187,106,.12);color:#7cc47f;border-color:rgba(102,187,106,.32)}
.rib-uaejjf,.tag-uaejjf{background:rgba(239,154,154,.12);color:#f0a9a9;border-color:rgba(239,154,154,.32)}
.rib-sjjif,.tag-sjjif{background:rgba(255,204,128,.12);color:#ffcc80;border-color:rgba(255,204,128,.32)}
.rib-other{background:rgba(245,242,234,.06);color:var(--muted);border-color:var(--line)}
.rib-m1{background:rgba(233,185,73,.16);color:var(--mgold);border-color:rgba(233,185,73,.45);box-shadow:0 0 12px rgba(233,185,73,.12)}
.rib-m2{background:rgba(196,202,211,.13);color:var(--msilver);border-color:rgba(196,202,211,.4)}
.rib-m3{background:rgba(205,130,75,.15);color:var(--mbronze);border-color:rgba(205,130,75,.42)}

/* ── misc legacy bits (search / team / claim) ── */
.uid-badge{font-family:"JetBrains Mono";font-size:.7rem;color:var(--faint);background:var(--bg2);border:1px solid var(--line);border-radius:4px;padding:.12rem .45rem}
.team-line{color:var(--muted);font-size:.9rem}
.team-header{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.team-chip,.variant-chip{font-family:"JetBrains Mono";font-size:.72rem;color:var(--muted);background:var(--bg2);border:1px solid var(--line);border-radius:5px;padding:.2rem .55rem}
.claim-cta{background:var(--crimson);color:#fff;border:none;border-radius:8px;padding:.5rem 1rem;font-weight:700;cursor:pointer;font-size:.85rem;display:inline-block}
.claim-cta:hover{filter:brightness(1.08)}
.no-results{color:var(--muted);text-align:center;padding:2rem}
.loading{color:var(--faint);text-align:center;padding:1.5rem;font-family:"JetBrains Mono";font-size:.85rem}

/* ── feedback widget ── */
#fb-fab{position:fixed;left:14px;bottom:14px;z-index:1000;width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:var(--panel);color:var(--ink);font-size:1.2rem;cursor:pointer;box-shadow:0 2px 12px rgba(0,0,0,.5);line-height:1}
#fb-fab:hover{transform:translateY(-1px);border-color:rgba(231,57,46,.5)}
@media(max-width:740px){ #fb-fab{bottom:86px} }
#fb-overlay{position:fixed;inset:0;background:rgba(0,0,0,.66);z-index:1001;display:none;align-items:center;justify-content:center;padding:1rem;backdrop-filter:blur(3px)}
#fb-overlay.open{display:flex}
#fb-box{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:1.4rem;width:100%;max-width:420px;box-sizing:border-box;position:relative;max-height:90vh;overflow-y:auto}
#fb-box h3{margin:0 0 .3rem;font-size:1.15rem;font-family:"Anton";letter-spacing:.02em;text-transform:uppercase}
#fb-box .fb-sub{color:var(--muted);font-size:.85rem;margin-bottom:.8rem}
#fb-box label{display:block;font-size:.7rem;color:var(--faint);text-transform:uppercase;letter-spacing:.06em;margin:.8rem 0 .3rem;font-family:"JetBrains Mono"}
#fb-box select,#fb-box textarea,#fb-box input{width:100%;padding:10px 12px;border-radius:10px;background:var(--gray);border:1px solid var(--line);color:var(--ink);font-size:.92rem;box-sizing:border-box;font-family:inherit}
#fb-box textarea{resize:vertical;min-height:84px}
#fb-box .fb-ctx{font-size:.78rem;color:var(--muted);background:var(--gray);border:1px solid var(--line);border-radius:8px;padding:7px 10px;word-break:break-word}
#fb-send{margin-top:1rem;width:100%;padding:11px;border:none;border-radius:10px;background:var(--crimson);color:#fff;font-weight:700;font-size:.95rem;cursor:pointer}
#fb-close{position:absolute;top:10px;right:12px;background:none;border:none;color:var(--muted);font-size:1.2rem;cursor:pointer}
#fb-status{text-align:center;font-size:.82rem;margin-top:.6rem;min-height:18px}

/* ── footer ── */
footer.brand-foot{margin:46px 0 30px;padding-top:22px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;font-family:"JetBrains Mono";font-size:10.5px;color:var(--faint)}

/* ── entrance animation (never hides content if it can't run) ── */
@keyframes rise{from{opacity:0;transform:translateY(15px)}to{opacity:1;transform:none}}
.d1{animation-delay:.04s}.d2{animation-delay:.1s}.d3{animation-delay:.17s}.d4{animation-delay:.26s}.d5{animation-delay:.36s}.d6{animation-delay:.46s}.d7{animation-delay:.56s}
@media(prefers-reduced-motion:no-preference){.rise{opacity:0;animation:rise .6s var(--ease) forwards}}

/* ── responsive tables → cards ── */
@media(max-width:639px){
  table.responsive thead{display:none}
  table.responsive,table.responsive tbody,table.responsive tr,table.responsive td{display:block;width:100%}
  table.responsive tr{padding:12px 14px;border-bottom:1px solid var(--line2);position:relative}
  table.responsive td{padding:2px 0;border:none}
  table.responsive td[data-l]::before{content:attr(data-l);font-family:"JetBrains Mono";font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);display:inline-block;min-width:74px}
  table.responsive td.r{text-align:right;position:absolute;right:14px;top:12px;left:auto;width:auto;padding:0}
}

/* ── shared site-header → brand skin (ONLY trackbjj loads brand.css; trackmat keeps its own) ── */
.site-header{background:linear-gradient(180deg,rgba(10,10,12,.94),rgba(10,10,12,.6))!important;backdrop-filter:saturate(1.2) blur(12px);box-shadow:none!important;border-bottom:1px solid var(--line);padding:13px 18px}
.site-header .logo{color:var(--ink)}
.site-header .logo-name{font-family:"Anton";font-weight:400;letter-spacing:.04em;font-size:1.3rem;text-transform:uppercase}
.site-header .logo-sub{font-family:"JetBrains Mono";font-size:.58rem;letter-spacing:.22em;text-transform:uppercase;color:var(--faint);opacity:1}
.sibling-btn,.user-pill,.lang-btn{background:rgba(255,255,255,.05)!important;border:1px solid var(--line)!important;color:var(--ink)!important;font-family:"JetBrains Mono";font-size:.72rem;border-radius:8px!important}
.sibling-btn:hover,.user-pill:hover,.lang-btn:hover{background:rgba(255,255,255,.09)!important}
.pill-plan{font-family:"JetBrains Mono";font-size:.6rem;background:var(--crimson)}
.pill-plan.free{background:var(--faint)}
.modal-sheet,.sibling-dropdown,.lang-dropdown{background:var(--panel)!important;border:1px solid var(--line)!important}
.btn-primary,.btn-google{font-family:"JetBrains Mono"}
