:root{--bg:#0b0f14;--panel:#121821;--muted:#8aa0b6;--acc:#3aa0ff;--text:#e6eef7;--border:#1f2a38;--z-friends-dock:4400;--z-friends-popup:4500;--z-chatwindow:5000}*{box-sizing:border-box}html,body,#root{height:100%;margin:0;background:var(--bg);color:var(--text);font:14px/1.4 system-ui,-apple-system,Segoe UI,Roboto,sans-serif}.app{display:flex;flex-direction:column;height:100%}.topbar{height:48px;display:flex;align-items:center;justify-content:space-between;padding:0 12px;background:var(--panel);border-bottom:1px solid var(--border)}.body{display:flex;flex:1;min-height:0}.sidebar{width:220px;background:var(--panel);border-right:1px solid var(--border);padding:12px}.content{flex:1;padding:16px;overflow:auto}button{background:var(--acc);color:#000;border:none;padding:8px 12px;border-radius:8px;cursor:pointer}button.ghost{background:transparent;color:var(--text);border:1px solid var(--border)}.grid{margin-top:16px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.card{background:#0f141c;padding:16px;border-radius:12px;border:1px solid var(--border)}a{color:var(--acc);text-decoration:none}.input{width:100%;padding:8px 10px;border-radius:8px;border:1px solid var(--border);background:#0f141c;color:var(--text)}.row{display:flex;gap:12px;align-items:center}.badge{font-size:12px;opacity:.9;padding:2px 8px;border:1px solid var(--border);border-radius:999px}.navlink{display:block;padding:8px 10px;border-radius:8px;color:var(--text)}.navlink.active{background:#0f141c;border:1px solid var(--border)}.table{width:100%;border-collapse:collapse}.table th,.table td{border-bottom:1px solid var(--border);padding:8px;text-align:left}.progress{width:100%;height:8px;background:#0f141c;border:1px solid var(--border);border-radius:8px;overflow:hidden}.progress>div{height:100%;background:var(--acc)}.kv{display:grid;grid-template-columns:180px 1fr;gap:8px 12px;align-items:center}.code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.rank-grid{display:grid;gap:16px;align-items:start;width:100%;max-width:100%;overflow:visible}.rank-chart{position:relative;min-height:300px}.rank-panel{justify-self:start;width:100%;max-width:880px}.sidepanel{display:grid;gap:12px;padding:10px;border-radius:12px;border:1px solid var(--border);background:#0f141c;width:260px;min-width:240px;max-width:280px}.sidepanel.compact{padding:8px;width:240px;min-width:220px;max-width:260px}.sidepanel.plain{background:transparent;border:none;box-shadow:none}.hide-title .section-title,.hide-title .panel-title{display:none!important}.rank-panel .sidepanel{width:100%;max-width:880px}.rank-panel .sidepanel>div{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}@media (max-width: 720px){.rank-panel .sidepanel>div{grid-template-columns:1fr}}.stat-row{display:grid;grid-template-columns:20px 1fr auto;gap:8px;align-items:center}.stat-row .icon{opacity:.7}.stat-row .value{font-variant-numeric:tabular-nums}.bar{position:relative;height:6px;background:var(--border);border:1px solid #1a2433;border-radius:9999px;overflow:hidden}.bar>span{position:absolute;inset:0 auto 0 0;width:0%;background:var(--acc);opacity:.9}.kda-bar{display:flex;width:100%;height:6px;border-radius:9999px;overflow:hidden;border:1px solid #1a2433;background:#0f141c}.kda-bar .seg{height:100%}.kda-bar .seg.kill{background:#3aa0ff;opacity:.95}.kda-bar .seg.death{background:#ef4444;opacity:.95}.kda-bar .seg.assist{background:#22c55e;opacity:.95}.dbt-bar{display:flex;width:100%;height:6px;border-radius:9999px;overflow:hidden;border:1px solid #1a2433;background:#0f141c}.dbt-bar .seg{height:100%}.dbt-bar .seg.dmg{background:#60a5fa;opacity:.95}.dbt-bar .seg.blk{background:#94a3b8;opacity:.95}.dbt-bar .seg.heal{background:#a78bfa;opacity:.95}.tooltip-card{position:absolute;top:8px;right:8px;background:#0f141c;border:1px solid var(--border);border-radius:10px;padding:8px 10px;box-shadow:0 6px 24px #00000059;font-size:12px;backdrop-filter:blur(3px)}.tooltip-card .title{font-weight:600;margin-bottom:6px}.tooltip-grid{display:grid;grid-template-columns:auto auto;gap:4px 12px}.tooltip-grid .num{text-align:right;font-variant-numeric:tabular-nums}.divider{height:1px;background:#ffffff0f;margin:4px 0}.muted{color:var(--muted)}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.tabular-nums{font-variant-numeric:tabular-nums}.mission-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:12px;margin-top:8px}.mission-card{background:#0f141c;border:1px solid var(--border);border-radius:12px;padding:12px;display:flex;flex-direction:column;gap:10px}.reward-chip{display:inline-block;padding:2px 8px;border-radius:999px;font-size:12px;background:#3aa0ff1f;border:1px solid #2b4a63}.progress-ticks{position:relative}.progress-ticks .tick{position:absolute;top:-6px;transform:translate(-50%);text-align:center;pointer-events:none}.progress-ticks .tick-line{width:2px;height:12px;background:#c9ced6;margin:0 auto;border-radius:1px}.progress-ticks .tick-line.reached{background:#a6d5a6}.progress-ticks .tick-line.done{background:#5ecf77}.progress-labels,.progress-ticks .tick-label{font-size:10px;color:#8896a7;margin-top:2px;white-space:nowrap}.badge-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(84px,1fr));gap:10px}.badge-item{background:#0c0e11;border:1px solid var(--border);border-radius:12px;padding:10px 8px;display:flex;flex-direction:column;align-items:center;gap:6px}.badge-image{width:56px;height:56px;object-fit:contain;border-radius:50%;background:#0f1720;border:1px solid #223245}.badge-name{font-size:12px;text-align:center;color:#dbeafe;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.friends-layout{display:grid;grid-template-columns:minmax(280px,360px) 1fr;gap:16px;height:100%}.friends-list{display:flex;flex-direction:column;gap:8px;overflow:auto}.friend-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px;align-items:center;padding:8px 10px;border:1px solid var(--border);border-radius:10px;background:#0f141c}.friend-row .meta{font-size:12px;color:#6b7280;margin-top:2px}.presence-dot--online{width:10px;height:10px;border-radius:9999px;background:#22c55e;display:inline-block}.presence-dot--away{width:10px;height:10px;border-radius:9999px;background:#f59e0b;display:inline-block}.presence-dot--invisible{width:10px;height:10px;border-radius:9999px;background:#64748b;display:inline-block}.presence-dot--offline{width:10px;height:10px;border-radius:9999px;background:#9ca3af;display:inline-block}.chat-window{display:flex;flex-direction:column;height:320px;max-height:320px;min-height:320px}.chat-messages{flex:1;min-height:0;overflow:auto;display:flex;flex-direction:column-reverse;gap:8px;padding:8px;border:1px solid var(--border);border-radius:8px}.chat-input{display:flex;align-items:center;gap:8px;margin-top:8px}.chat-message--me{display:flex;justify-content:flex-end}.chat-message--them{display:flex;justify-content:flex-start}.chat-message--me .bubble{background:#3aa0ff26;border:1px solid #2b4a63}.chat-message--them .bubble{background:#94a3b826;border:1px solid #2a394d}.bubble{max-width:70%;padding:6px 10px;border-radius:10px;color:#dbeafe}.chat-typing{font-size:12px;color:var(--muted);margin-top:6px}.emoji-panel{margin-top:6px;border:1px solid var(--border);background:#0f172a;border-radius:10px;padding:8px}.emoji-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(28px,1fr));gap:6px;max-height:160px;overflow:auto}.emoji-btn{width:32px;height:32px;display:grid;place-items:center;font-size:18px;line-height:1;background:transparent;border:none;border-radius:6px;cursor:pointer}.emoji-btn:hover{background:#94a3b826}@media (max-width: 900px){.friends-layout{grid-template-columns:1fr}.chat-window{display:none}}.friends-dock-btn{position:fixed;right:24px;bottom:24px;z-index:var(--z-friends-dock)}.friends-popup{position:fixed;right:24px;bottom:72px;z-index:var(--z-friends-popup);width:360px;max-width:92vw;max-height:80vh}.chat-window-floating{position:fixed;z-index:var(--z-chatwindow)}@media (max-width: 640px){.friends-dock-btn{right:12px;bottom:16px}.friends-popup{right:12px;bottom:64px;width:calc(100vw - 24px);height:clamp(380px,70vh,560px)}.chat-window-floating{left:12px!important;right:12px!important;width:calc(100vw - 24px);max-width:none}}.minigame-canvas{background:#0a2740}
