html,body,#app{width:100%;height:100%;margin:0}body{overflow:hidden;background:#08090c;color:#f6f4ee;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;touch-action:none;-webkit-user-select:none;user-select:none}canvas{display:block;outline:none}.auth-modal{position:fixed;inset:0;z-index:120;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at top,rgba(243,201,105,.16),transparent 34%),#04060ad1;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.auth-card{width:min(100%,520px);padding:28px;border:1px solid rgba(217,251,255,.16);border-radius:24px;background:linear-gradient(160deg,#141c25f7,#090d13f7);box-shadow:0 28px 70px #0000006b}.auth-eyebrow{font-size:11px;font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:#f3c969}.auth-title{margin:10px 0 18px;font-size:28px;line-height:1.1}.auth-body{margin:0 0 18px;color:#f6f4eed1;line-height:1.55}.auth-input-wrap{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.auth-input-label{color:#d9fbffc7;font-size:12px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.auth-input{width:100%;box-sizing:border-box;padding:14px 16px;border:1px solid rgba(217,251,255,.16);border-radius:14px;background:#ffffff0d;color:#f6f4ee;font:inherit;font-size:18px;font-weight:800;outline:none}.auth-input:focus{border-color:#f3c969e6;box-shadow:0 0 0 3px #f3c96924}.auth-input::placeholder{color:#9fcbd46b}.auth-error{margin-bottom:16px;padding:10px 12px;border:1px solid rgba(255,116,136,.22);border-radius:12px;background:#7b1b2f2e;color:#ffb8c5;font-size:13px;font-weight:700}.auth-provider-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.auth-provider{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;min-height:86px;padding:16px 14px;border:1px solid rgba(243,201,105,.18);border-radius:16px;background:linear-gradient(180deg,#222b38f5,#10161ff5);box-shadow:inset 0 1px #ffffff0d;color:#f6f4ee;cursor:pointer;text-align:center;transition:transform .12s ease,border-color .12s ease,background .12s ease,box-shadow .12s ease}.auth-provider:hover{transform:translateY(-1px);background:linear-gradient(180deg,#2a3443fa,#141b26fa);box-shadow:inset 0 1px #ffffff14,0 10px 24px #0000002e}.auth-provider:disabled{opacity:.54;cursor:not-allowed}.auth-provider:disabled:hover{transform:none;background:#ffffff08}.auth-provider-github:hover{border-color:#fff3}.auth-provider-google:hover{border-color:#75f6ff52}.auth-provider-wechat:hover{border-color:#65e48957}.auth-provider-name{font-size:17px;font-weight:900}.auth-provider-reason{color:#f3c969;font-size:11px;font-weight:700;line-height:1.4}.auth-footer{margin-top:18px;display:flex;flex-direction:column;gap:10px}.auth-skip{border:0;border-radius:999px;background:#f3c969;color:#08090c;padding:12px 14px;font:inherit;font-size:13px;font-weight:900;cursor:pointer}.auth-note{margin:0;color:#9fcbd4b8;font-size:12px;line-height:1.5}.auth-bar{position:fixed;top:14px;right:14px;z-index:80;display:flex;align-items:center;gap:10px;max-width:min(92vw,420px);padding:10px 12px;border:1px solid rgba(217,251,255,.22);border-radius:14px;background:#0a0d12e0;box-shadow:0 18px 44px #00000047;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.auth-status{font-size:12px;font-weight:700;color:#d9fbff;line-height:1.35}.auth-button{border:0;border-radius:999px;background:#f3c969;color:#08090c;padding:8px 12px;font:inherit;font-size:12px;font-weight:900;cursor:pointer;white-space:nowrap}.auth-button:hover{filter:brightness(1.04)}.global-hud{position:fixed;top:14px;left:14px;z-index:95;pointer-events:none}.global-button{pointer-events:auto;min-width:92px;padding:12px 16px;border:1px solid rgba(243,201,105,.32);border-radius:14px;background:linear-gradient(180deg,#1f2733f5,#0e1219f5);color:#f6f4ee;font:inherit;font-size:13px;font-weight:900;letter-spacing:.08em;cursor:pointer;box-shadow:inset 0 1px #ffffff0f,0 16px 32px #0000003d}.global-button[data-state=stale]{border-color:#75f6ff66}.global-button[data-state=open]{background:linear-gradient(180deg,#f3c969fa,#c99d38fa);color:#08090c}.leaderboard-modal{position:fixed;inset:0;z-index:110}.leaderboard-scrim{position:absolute;inset:0;background:radial-gradient(circle at top left,rgba(243,201,105,.14),transparent 28%),#04060ac2;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.leaderboard-card{position:absolute;top:72px;left:14px;right:14px;max-width:760px;margin:0 auto;max-height:min(82vh,860px);overflow:auto;padding:22px;border:1px solid rgba(217,251,255,.18);border-radius:24px;background:linear-gradient(160deg,#141c25fa,#080c12fa);box-shadow:0 28px 70px #00000061;pointer-events:auto}.leaderboard-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px}.leaderboard-title-wrap{min-width:0}.leaderboard-eyebrow{font-size:11px;font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:#f3c969}.leaderboard-title{margin:8px 0 6px;font-size:28px;line-height:1.05}.leaderboard-subtitle{margin:0;color:#f6f4eeb8;font-size:13px}.leaderboard-actions{display:flex;align-items:center;gap:10px}.leaderboard-action-button,.leaderboard-close-button{border:1px solid rgba(217,251,255,.14);border-radius:999px;background:#ffffff0d;color:#f6f4ee;padding:9px 12px;font:inherit;font-size:11px;font-weight:900;letter-spacing:.06em;cursor:pointer}.leaderboard-action-button:disabled{opacity:.54;cursor:wait}.leaderboard-close-button{background:#f3c969;border-color:#f3c969cc;color:#08090c}.leaderboard-status{margin-top:16px;padding:12px 14px;border-radius:14px;background:#ffffff0d;color:#f6f4eec7;font-size:13px;font-weight:700}.leaderboard-status[data-kind=error]{background:#7b1b2f38;color:#ffb8c5}.leaderboard-status[data-kind=stale]{background:#162c387a;color:#d9fbff}.leaderboard-self-card{margin-top:16px;padding:16px;border:1px solid rgba(243,201,105,.18);border-radius:18px;background:linear-gradient(180deg,#2a1e0d8f,#12121266)}.leaderboard-self-title{font-size:13px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:#f3c969}.leaderboard-self-empty{margin-top:10px;color:#f6f4eebd;font-size:14px}.leaderboard-self-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:14px}.leaderboard-self-metric{display:flex;flex-direction:column;gap:6px;padding:12px;border-radius:14px;background:#0000002e}.leaderboard-self-label{color:#9fcbd4ad;font-size:11px;font-weight:800;letter-spacing:.06em}.leaderboard-self-value{color:#f6f4ee;font-size:18px;font-weight:900}.leaderboard-list{margin-top:18px;display:flex;flex-direction:column;gap:8px}.leaderboard-row{display:grid;grid-template-columns:76px minmax(0,1.7fr) 76px 76px 88px 88px;gap:10px;align-items:center;padding:12px 14px;border-radius:14px;background:#ffffff0a;color:#f6f4ee;font-size:14px;font-weight:700}.leaderboard-row-header{background:transparent;color:#9fcbd4bd;font-size:11px;font-weight:900;letter-spacing:.08em}.leaderboard-row-self{border:1px solid rgba(243,201,105,.3);background:linear-gradient(180deg,#4f39168a,#221c1266)}.leaderboard-player-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.leaderboard-empty{padding:18px 14px;border-radius:14px;background:#ffffff0a;color:#f6f4eeb3;font-size:14px;font-weight:700}@media(max-width:640px){.auth-card{padding:22px 18px;border-radius:20px}.auth-title{font-size:24px}.auth-provider-list{grid-template-columns:repeat(2,minmax(0,1fr))}.auth-bar{inset:auto 10px 10px;justify-content:space-between}.auth-status{font-size:11px}.global-hud{top:10px;left:10px}.global-button{min-width:84px;padding:10px 14px;font-size:12px}.leaderboard-card{top:60px;left:10px;right:10px;padding:18px;border-radius:20px}.leaderboard-header{flex-direction:column}.leaderboard-title{font-size:24px}.leaderboard-actions{width:100%;justify-content:space-between}.leaderboard-self-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.leaderboard-row{grid-template-columns:62px minmax(0,1.3fr) 62px 62px 72px 72px;padding:11px 12px;font-size:12px}}
