
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,500;9..144,600;9..144,700&family=Hanken+Grotesk:wght@400;500;600;700&display=swap');
:root{
  --bg:#0b0d14; --surface:#13161f; --surface2:#181c27; --line:rgba(255,255,255,.07);
  --ink:#eceef3; --mut:#9098a8; --acc:#5b8cff; --acc2:#8a7bff;
  --plat:#7fe3ff; --gold:#f3c24b; --silver:#ccd5e0; --bronze:#d68b50;
  --disp:'Fraunces',Georgia,'Times New Roman',serif; --body:'Hanken Grotesk',system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;color:var(--ink);font-family:var(--body);font-size:15px;line-height:1.5;
  background:
   radial-gradient(1100px 600px at 80% -10%, rgba(124,92,255,.16), transparent 60%),
   radial-gradient(900px 500px at -5% 0%, rgba(62,123,255,.18), transparent 55%),
   var(--bg);
  background-attachment:fixed;min-height:100vh}
body::after{content:"";position:fixed;inset:0;pointer-events:none;opacity:.035;z-index:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
a{color:var(--acc);text-decoration:none}
a:hover{text-decoration:underline}
.muted{color:var(--mut)}
.top{position:relative;z-index:1;display:flex;align-items:center;padding:16px 28px;border-bottom:1px solid var(--line)}
.brand{font-family:var(--disp);font-weight:600;color:#fff;font-size:21px;letter-spacing:.01em}
main{position:relative;z-index:1;max-width:1180px;margin:0 auto;padding:32px 28px 80px}

/* landing */
.hero{text-align:center;padding:90px 0 40px}
.hero .kicker{font-family:var(--body);text-transform:uppercase;letter-spacing:.3em;color:var(--acc);font-size:12px;font-weight:700}
.hero h1{font-family:var(--disp);font-weight:600;font-size:clamp(40px,7vw,78px);line-height:1.04;letter-spacing:-.01em;margin:14px 0 10px;
  background:linear-gradient(180deg,#fff,#aab4cf);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p{color:var(--mut);max-width:520px;margin:0 auto}
.search{display:flex;gap:10px;justify-content:center;margin-top:34px;flex-wrap:wrap}
.search input{font-family:var(--body);padding:15px 18px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.04);color:#fff;min-width:320px;font-size:16px;outline:none;transition:.2s}
.search input:focus{border-color:var(--acc);box-shadow:0 0 0 4px rgba(62,123,255,.18)}
button,.btn{font-family:var(--body);font-weight:600;font-size:15px;padding:14px 22px;border-radius:14px;border:1px solid transparent;
  background:linear-gradient(180deg,var(--acc),#2c63e6);color:#fff;cursor:pointer;transition:.15s;white-space:nowrap}
button:hover,.btn:hover{filter:brightness(1.08);text-decoration:none}
button:disabled{background:#1c2233;color:var(--mut);border-color:var(--line);cursor:default;filter:none}
.btn.ghost{background:rgba(255,255,255,.05);border-color:var(--line);color:var(--ink)}

/* profile header */
.phead{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap}
.phead h1{font-family:var(--disp);font-weight:600;letter-spacing:0;font-size:clamp(30px,4vw,46px);margin:0}
.actions{display:flex;gap:10px;align-items:center}
.status{display:flex;align-items:center;gap:12px;margin:18px 0 6px;font-weight:500}
.dot{width:9px;height:9px;border-radius:50%;flex:none}
.dot.live{background:var(--gold);box-shadow:0 0 0 4px rgba(245,197,66,.18);animation:pulse 1.1s infinite}
.dot.done{background:#36d399;box-shadow:0 0 0 4px rgba(54,211,153,.16)}
.dot.err{background:#ff5d6c}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.bar{flex:1;max-width:360px;height:7px;background:rgba(255,255,255,.08);border-radius:99px;overflow:hidden}
.fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--acc),var(--acc2));transition:width .35s ease}

/* summary cards */
.summary{display:flex;flex-wrap:wrap;gap:12px;margin:22px 0 28px}
.cardv{position:relative;background:linear-gradient(180deg,var(--surface2),var(--surface));border:1px solid var(--line);
  border-radius:16px;padding:16px 20px;min-width:104px;text-align:center;overflow:hidden}
.cardv::before{content:"";position:absolute;inset:0 0 auto 0;height:2px;background:var(--acc)}
.cardv.lvl::before{background:linear-gradient(90deg,var(--acc),var(--acc2))}
.cardv.t-platinum::before{background:var(--plat)} .cardv.t-gold::before{background:var(--gold)}
.cardv.t-silver::before{background:var(--silver)} .cardv.t-bronze::before{background:var(--bronze)}
.cardv .v{font-family:var(--body);font-weight:800;font-size:25px;font-variant-numeric:tabular-nums}
.cardv .l{color:var(--mut);font-size:11px;text-transform:uppercase;letter-spacing:.12em;margin-top:2px}

/* games grid */
.games{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}
.game{background:linear-gradient(180deg,var(--surface2),var(--surface));border:1px solid var(--line);border-radius:16px;padding:14px;
  transition:.18s;animation:rise .4s both}
.game:hover{border-color:rgba(124,92,255,.4);transform:translateY(-2px);box-shadow:0 12px 30px -16px rgba(0,0,0,.7)}
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.grow{display:flex;gap:13px}
.game img,.noimg{width:62px;height:62px;border-radius:12px;object-fit:cover;background:#222838;flex:none;border:1px solid var(--line)}
.game .meta{min-width:0;flex:1}
.game .name{font-family:var(--body);font-weight:700;font-size:15px;letter-spacing:-.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.subrow{display:flex;gap:8px;align-items:center;margin:5px 0 9px;font-size:12px;flex-wrap:wrap}
.plat{font-weight:700;font-size:10px;letter-spacing:.06em;background:rgba(255,255,255,.07);border:1px solid var(--line);border-radius:7px;padding:2px 7px}
.gprog{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--mut)}
.gbar{width:80px;height:5px;background:rgba(255,255,255,.08);border-radius:99px;overflow:hidden}
.gbar i{display:block;height:100%;background:linear-gradient(90deg,var(--acc),var(--acc2))}

/* trophy chips — high-contrast, color-coded */
.chips{display:flex;gap:7px;flex-wrap:wrap}
.chip{display:inline-flex;align-items:center;gap:5px;font-weight:700;font-size:12px;padding:3px 9px;border-radius:9px;
  background:rgba(255,255,255,.04);border:1px solid var(--line)}
.chip .ic{width:9px;height:9px;border-radius:2px;transform:rotate(45deg)}
.chip.t-platinum{color:var(--plat);border-color:rgba(118,228,255,.4);background:rgba(118,228,255,.08)}
.chip.t-platinum .ic{background:var(--plat)}
.chip.t-gold{color:var(--gold);border-color:rgba(245,197,66,.4);background:rgba(245,197,66,.08)}
.chip.t-gold .ic{background:var(--gold);border-radius:50%;transform:none}
.chip.t-silver{color:var(--silver);border-color:rgba(205,214,226,.35);background:rgba(205,214,226,.07)}
.chip.t-silver .ic{background:var(--silver);border-radius:50%;transform:none}
.chip.t-bronze{color:var(--bronze);border-color:rgba(217,138,75,.4);background:rgba(217,138,75,.08)}
.chip.t-bronze .ic{background:var(--bronze);border-radius:50%;transform:none}
.chip.dim{opacity:.34}

.links{display:flex;gap:12px;font-size:13px;margin-top:10px;align-items:center}
.links a{font-weight:600}
.dbg{margin-top:9px;border-top:1px solid var(--line);padding-top:8px}
.dbg summary{cursor:pointer;color:var(--mut);font-size:11px;letter-spacing:.08em;text-transform:uppercase;list-style:none}
.dbg summary::-webkit-details-marker{display:none}
.dbg summary::before{content:"⟩ ";color:var(--acc)}
.dbg[open] summary::before{content:"⟱ "}
.kv{display:grid;grid-template-columns:auto 1fr;gap:2px 12px;font-size:12px;margin:8px 0;font-family:ui-monospace,SFMono-Regular,monospace}
.kv b{color:var(--mut);font-weight:500}
.dbg pre{background:#0a0c14;border:1px solid var(--line);border-radius:10px;padding:10px;overflow:auto;max-height:240px;font-size:11px;font-family:ui-monospace,SFMono-Regular,monospace;color:#b9c2d6}

/* per-game trophy drill-down */
.tbtn{font-size:12px;font-weight:700;padding:4px 10px;border-radius:8px;border:1px solid var(--line);background:rgba(255,255,255,.05);color:var(--ink);cursor:pointer}
.tbtn:hover{filter:none;border-color:rgba(124,92,255,.5)}
.tbtn[disabled]{opacity:.55}
.trlist:not(:empty){margin-top:11px;border-top:1px solid var(--line);padding-top:10px;animation:rise .3s both}
.trophies{display:flex;flex-direction:column;gap:8px;max-height:360px;overflow:auto;padding-right:4px}
.trow{display:flex;gap:10px;align-items:center}
.trow.locked{opacity:.5;filter:grayscale(.6)}
.trow img,.tico{width:38px;height:38px;border-radius:8px;object-fit:cover;background:#222838;flex:none;border:1px solid var(--line)}
.tinfo{min-width:0;flex:1}
.tname{display:flex;align-items:center;gap:7px;font-weight:600;font-size:13px}
.tdot{width:8px;height:8px;border-radius:50%;flex:none}
.tdot.t-platinum{background:var(--plat);border-radius:2px;transform:rotate(45deg)}
.tdot.t-gold{background:var(--gold)} .tdot.t-silver{background:var(--silver)} .tdot.t-bronze{background:var(--bronze)}
.tdesc{color:var(--mut);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tright{text-align:right;flex:none;display:flex;flex-direction:column;gap:1px;font-size:11px}
.tok{color:#36d399;font-weight:600}
.trate{color:var(--mut)}
.trerr{color:#ff8088;font-size:13px;margin:10px 0}
.rsum{font-weight:600;font-size:13px;color:var(--acc2);background:rgba(138,123,255,.10);
  border:1px solid rgba(138,123,255,.32);border-radius:10px;padding:9px 12px;margin:0 0 12px}

/* trophy modal */
.modal{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:24px;
  background:rgba(6,8,14,.66);backdrop-filter:blur(6px);animation:fade .18s both}
@keyframes fade{from{opacity:0}to{opacity:1}}
.dialog{width:min(660px,100%);max-height:84vh;display:flex;flex-direction:column;
  background:linear-gradient(180deg,var(--surface2),var(--surface));border:1px solid var(--line);
  border-radius:18px;box-shadow:0 30px 80px -30px rgba(0,0,0,.8);animation:pop .2s both}
@keyframes pop{from{opacity:0;transform:translateY(10px) scale(.985)}to{opacity:1;transform:none}}
.dhead{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 22px;border-bottom:1px solid var(--line)}
.dhead h3{font-family:var(--disp);font-weight:600;font-size:21px;margin:0;letter-spacing:0}
.dhead .x{background:rgba(255,255,255,.06);border:1px solid var(--line);color:var(--ink);border-radius:10px;padding:7px 12px;font-size:15px;line-height:1}
.dbody{padding:14px 22px 20px;overflow:auto}
.dbody .trophies{max-height:none}
.badge{display:inline-block;margin-left:7px;font-size:11px;font-weight:700;color:var(--acc2);background:rgba(138,123,255,.14);border:1px solid rgba(138,123,255,.4);border-radius:7px;padding:1px 7px;vertical-align:middle}
.srow{display:flex;align-items:center;gap:14px;flex-wrap:wrap;padding:11px 0;border-bottom:1px solid var(--line)}
.srow:last-child{border-bottom:0}
.srow .sinfo{display:flex;align-items:center;gap:9px;min-width:130px;font-size:12px}
.srow .chips{flex:1}

/* recently earned */
.recent{margin:4px 0 26px;background:linear-gradient(180deg,var(--surface2),var(--surface));
  border:1px solid var(--line);border-radius:16px;padding:16px 20px}
.rhead{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:12px}
.rhead h2{font-family:var(--disp);font-weight:600;font-size:19px;margin:0}
.rbadge{font-weight:800;color:#36d399;background:rgba(54,211,153,.12);border:1px solid rgba(54,211,153,.4);border-radius:8px;padding:2px 9px;font-size:13px}
.rlist{display:flex;flex-direction:column;gap:9px;max-height:340px;overflow:auto}
.rrow{display:flex;align-items:center;gap:12px}
.rrow img,.rrow .noimg{width:40px;height:40px;border-radius:9px;object-fit:cover;background:#222838;flex:none;border:1px solid var(--line)}
.rinfo{flex:1;min-width:0}
.rname{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rchips{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}
.rwhen{font-size:11px;flex:none}
