@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--site-navbar-height: 56px;--font-sans: "Inter", system-ui, -apple-system, Segoe UI, sans-serif;--font-mono: ui-monospace, "Cascadia Code", monospace;--color-bg: #0f1113;--color-surface: #1a1d21;--color-surface-elevated: #22262c;--color-border: #2d3339;--color-border-strong: #3d4654;--color-text: #e8eaed;--color-text-muted: #9aa0a8;--color-primary: #3b82f6;--color-primary-hover: #2563eb;--color-accent: #f59e0b;--color-danger: #ef4444;--color-success: #22c55e;--shadow-md: 0 8px 24px rgba(0, 0, 0, .35);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .25);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--transition-fast: .2s ease}*,*:before,*:after{box-sizing:border-box}body{display:flex;flex-direction:column;min-height:100vh;margin:0;background-color:var(--color-bg);background-image:radial-gradient(ellipse 120% 80% at 50% -20%,rgba(59,130,246,.08),transparent 50%);color:var(--color-text);font-family:var(--font-sans);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}html.game-shell-active{height:100%;overflow:hidden}html.game-shell-active body{height:100%;min-height:0;overflow:hidden}.site-navbar{position:sticky;top:0;flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:var(--site-navbar-height);padding:0 20px;box-sizing:border-box;background:#0f1113eb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--color-border);font-family:var(--font-sans);z-index:25}.site-navbar-brand{display:inline-flex;align-items:center;gap:10px;color:var(--color-text);font-weight:700;font-size:15px;text-decoration:none;letter-spacing:-.02em;transition:color var(--transition-fast)}.site-navbar-brand:hover{color:#fff}.site-navbar-logo{width:28px;height:28px;border-radius:8px;object-fit:contain;flex-shrink:0}.site-navbar-links{display:flex;align-items:center;flex-wrap:wrap;gap:4px}.site-navbar-links a{color:var(--color-text-muted);font-size:14px;font-weight:500;text-decoration:none;padding:8px 14px;border-radius:999px;transition:background var(--transition-fast),color var(--transition-fast)}.site-navbar-links a:hover{background:#ffffff0f;color:var(--color-text);text-decoration:none}.site-navbar-links a[aria-current=page]{background:#3b82f626;color:#93c5fd}.site-navbar-actions{display:flex;align-items:center;gap:8px;margin-left:8px;padding-left:12px;border-left:1px solid var(--color-border)}.btn-nav{padding:8px 14px;border-radius:999px;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.btn-nav--ghost{border:1px solid var(--color-border);background:transparent;color:var(--color-text-muted)}.btn-nav--ghost:hover{background:#ffffff0f;color:var(--color-text);border-color:var(--color-border-strong)}.btn-nav--danger{border:1px solid rgba(239,68,68,.35);background:#ef44441a;color:#fca5a5}.btn-nav--danger:hover{background:#ef444433;color:#fecaca}.site-main{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:0;width:100%}.auth-layout{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;max-width:440px;padding:32px 20px;gap:24px}.auth-hero{text-align:center}.auth-hero h1{margin:0 0 8px;font-size:clamp(1.5rem,4vw,1.85rem);font-weight:700;letter-spacing:-.03em;color:var(--color-text)}.auth-hero p{margin:0;font-size:14px;color:var(--color-text-muted);line-height:1.5;max-width:36ch}.auth-card{width:100%;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:28px 28px 24px;box-shadow:var(--shadow-md)}.auth-card h2{margin:0 0 20px;font-size:18px;font-weight:600;text-align:center;color:var(--color-text)}#game-view{display:none;position:fixed;left:0;right:0;bottom:0;top:var(--site-navbar-height);width:100%;margin:0;padding:0;overflow:hidden}#game-view canvas{display:block}.game-context-menu{position:absolute;z-index:50;min-width:140px;padding:4px 0;margin:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);font-family:var(--font-sans);font-size:13px;-webkit-user-select:none;user-select:none}.game-context-menu__item{display:block;width:100%;padding:6px 14px;margin:0;border:none;background:transparent;color:#e8e0d5;text-align:left;cursor:pointer;font:inherit}.game-context-menu__item:hover:not(:disabled){background:#ffffff14}.game-context-menu__item:disabled{color:#7a7268;cursor:default}.world-health-bar{position:absolute;left:0;top:0;z-index:40;width:72px;pointer-events:none;-webkit-user-select:none;user-select:none;will-change:transform;font-family:var(--font-sans)}.world-health-bar__track{height:5px;background:#d10000;overflow:hidden}.world-health-bar__fill{height:100%;width:100%}.world-health-bar__fill--high{background:#00b300}.world-health-bar__fill--mid{background:#cc0}.world-health-bar__fill--low{background:#d10000}.world-health-bar__label{margin-top:2px;font-size:10px;line-height:1.1;color:#f0f0f0;text-align:center;text-shadow:0 0 2px #000,0 1px 2px #000}.hitsplat{position:absolute;left:0;top:0;z-index:45;pointer-events:none;-webkit-user-select:none;user-select:none;will-change:transform;font-family:var(--font-sans);font-weight:700;font-size:16px;text-shadow:0 0 3px #000,0 1px 2px #000;animation:hitsplat-rise .75s ease-out forwards}.hitsplat--player{color:#f44}.hitsplat--npc{color:#ffeb3b}.hitsplat--heal{color:#4ade80}@keyframes hitsplat-rise{0%{opacity:1;transform:translate3d(var(--splat-x),var(--splat-y),0) translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate3d(var(--splat-x),var(--splat-y),0) translate(-50%,-120%) scale(1.05)}}.dungeon-compass{font-family:var(--font-sans);font-size:12px}#login-container{display:flex;justify-content:center;align-items:center;width:100%;flex:1;min-height:0}#login-form{margin:0}.form-group{margin-bottom:18px}.form-group label{display:block;color:var(--color-text-muted);font-size:13px;font-weight:500;margin-bottom:6px;-webkit-user-select:none;user-select:none}.form-group input{width:100%;padding:11px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-bg);color:var(--color-text);font-size:14px;font-family:inherit;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-group input:hover{border-color:var(--color-border-strong)}.form-group input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f633}#login-button{width:100%;padding:12px 16px;margin-top:4px;background:linear-gradient(180deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:#fff;border:none;border-radius:var(--radius-sm);font-size:15px;font-weight:600;font-family:inherit;cursor:pointer;transition:filter var(--transition-fast),transform .1s ease;box-shadow:0 2px 8px #3b82f659}#login-button:hover{filter:brightness(1.06)}#login-button:active{transform:translateY(1px)}.logout-button{padding:8px 14px;border-radius:999px;border:1px solid var(--color-border);background:transparent;color:var(--color-text-muted);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast);margin-left:0}.logout-button:hover{background:#ffffff0f;color:var(--color-text);border-color:var(--color-border-strong)}#settings-button.btn-nav--ghost{border-color:#3b82f659;background:#3b82f61a;color:#93c5fd}#settings-button.btn-nav--ghost:hover{background:#3b82f62e;color:#bfdbfe;border-color:#3b82f673}.error-message{color:#fca5a5;font-size:13px;margin-bottom:14px;min-height:20px;text-align:center;display:none;padding:8px 10px;border-radius:var(--radius-sm);background:#ef44441f;border:1px solid rgba(239,68,68,.25)}.error-message.show{display:block}.hidden{display:none!important}.lobby-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:30;display:flex;align-items:flex-start;justify-content:center;padding:24px 16px 32px;box-sizing:border-box;pointer-events:auto;background:radial-gradient(ellipse 100% 60% at 50% 0%,rgba(59,130,246,.06),transparent 55%),#0a0c0ff0;overflow:auto}.lobby-panel{background:var(--color-surface);border-radius:var(--radius-lg);padding:28px 28px 24px;max-width:min(520px,100%);width:100%;border:1px solid var(--color-border);box-shadow:var(--shadow-md);box-sizing:border-box}.lobby-title{color:var(--color-text);margin:0 0 6px;font-size:22px;font-weight:700;letter-spacing:-.02em}.lobby-user{color:#93c5fd;font-size:13px;margin:0 0 14px}.lobby-user strong{color:var(--color-text);font-weight:600}.lobby-hint{color:var(--color-text-muted);font-size:13px;margin:0 0 22px;line-height:1.5}.lobby-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin:0 0 10px}.lobby-model-picker{margin-bottom:22px}.lobby-model-options{display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:8px;width:100%}.lobby-model-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-height:72px;padding:8px 6px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text-muted);font-family:inherit;font-size:11px;cursor:pointer;transition:border-color var(--transition-fast),background var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast)}.lobby-model-card:hover{border-color:var(--color-border-strong);color:var(--color-text)}.lobby-model-card--active{border-color:var(--color-primary);background:#3b82f61f;color:var(--color-text);box-shadow:0 0 0 1px #3b82f659}.lobby-model-card__abbr{font-size:16px;font-weight:700;letter-spacing:.04em;color:var(--color-text)}.lobby-model-card__name{font-size:10px;line-height:1.2;text-align:center;word-break:break-word;max-width:100%;opacity:.85}.lobby-perk-picker{position:relative;margin-bottom:22px}.lobby-perk-hint{color:var(--color-text-muted);font-size:12px;margin:0 0 10px;line-height:1.45}.lobby-perk-options{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;width:100%}.lobby-perk-card{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:6px;min-height:88px;padding:10px 8px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text-muted);font-family:inherit;font-size:11px;cursor:pointer;transition:border-color var(--transition-fast),background var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast)}.lobby-perk-card:hover{border-color:var(--color-border-strong);color:var(--color-text)}.lobby-perk-card--active{border-color:var(--color-primary);background:#3b82f61f;color:var(--color-text);box-shadow:0 0 0 1px #3b82f659}.lobby-perk-card__icon{display:block;border-radius:6px;flex-shrink:0}.lobby-perk-card__name{font-size:10px;line-height:1.2;text-align:center;word-break:break-word;max-width:100%;font-weight:600;color:var(--color-text)}.lobby-perk-tooltip{position:fixed;z-index:12000;max-width:min(280px,calc(100vw - 24px));padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface-elevated);color:var(--color-text);font-size:12px;line-height:1.45;box-shadow:0 8px 24px #00000059;transform:translate(-50%);pointer-events:none;left:0;top:0}.lobby-modes{display:flex;flex-direction:column;gap:12px;margin-bottom:18px}.lobby-mode-card{padding:16px 16px 14px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface-elevated)}.lobby-mode-card--solo{border-color:#f59e0b40;background:linear-gradient(145deg,rgba(245,158,11,.08),transparent 60%)}.lobby-mode-title{margin:0 0 6px;font-size:15px;font-weight:600;color:var(--color-text)}.lobby-mode-text{margin:0 0 12px;font-size:13px;color:var(--color-text-muted);line-height:1.45}.lobby-mode-card--party .lobby-mode-text{margin-bottom:14px}.lobby-actions-party{display:flex;flex-direction:column;gap:10px}.lobby-join-row{display:flex;gap:8px;align-items:stretch}.lobby-input{flex:1;padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text);font-size:14px;font-family:inherit;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.lobby-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f633}.lobby-btn{padding:10px 16px;border:none;border-radius:var(--radius-sm);background:var(--color-primary);color:#fff;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:filter var(--transition-fast),transform .1s ease}.lobby-btn:hover{filter:brightness(1.06)}.lobby-btn:active{transform:translateY(1px)}.lobby-btn--accent{background:linear-gradient(180deg,#f59e0b,#d97706);box-shadow:0 2px 10px #f59e0b59;width:100%}.lobby-btn--accent:hover{filter:brightness(1.08)}.lobby-btn--secondary{background:var(--color-surface-elevated);border:1px solid var(--color-border);color:var(--color-text);width:100%}.lobby-btn--secondary:hover{background:#ffffff0f;filter:none}.lobby-party-info{color:var(--color-text);font-size:14px;margin-bottom:12px;padding:12px 14px;border-radius:var(--radius-sm);background:var(--color-bg);border:1px solid var(--color-border)}.lobby-code{font-weight:700;letter-spacing:.08em;font-family:var(--font-mono);color:#93c5fd}.lobby-copy{width:100%;margin-bottom:12px;background:#3b82f626;border:1px solid rgba(59,130,246,.35);font-size:13px;font-weight:600}.lobby-copy:hover{background:#3b82f640}.lobby-count{color:var(--color-text-muted);font-size:13px}.lobby-member-list{list-style:none;padding:0;margin:0 0 16px;font-size:14px;color:var(--color-text)}.lobby-member-list li{padding:10px 12px;margin-bottom:6px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg);display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.lobby-member-main{display:flex;align-items:center;gap:10px;min-width:0}.lobby-member-meta{font-size:12px;color:var(--color-text-muted)}.lobby-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.lobby-badge{font-size:11px;font-weight:600;padding:3px 8px;border-radius:999px;text-transform:uppercase;letter-spacing:.03em}.lobby-badge--ready{background:#22c55e26;color:#86efac;border:1px solid rgba(34,197,94,.35)}.lobby-badge--pending{background:#94a3b81f;color:var(--color-text-muted);border:1px solid var(--color-border)}.lobby-ready{width:100%;margin-bottom:10px;background:var(--color-surface-elevated);border:1px solid var(--color-border);color:var(--color-text)}.lobby-ready:hover{background:#ffffff0f}.lobby-start{width:100%;margin-bottom:12px;padding:14px 18px;font-size:16px;font-weight:700;background:linear-gradient(180deg,var(--color-success) 0%,#16a34a 100%);box-shadow:0 4px 16px #22c55e59}.lobby-start:hover:not(:disabled){filter:brightness(1.08)}.lobby-start:disabled{opacity:.45;cursor:not-allowed;filter:none;box-shadow:none}.lobby-status{min-height:22px;font-size:13px;color:#86efac;margin:0}.lobby-status-error{color:#fca5a5}.chat-panel{display:flex;flex-direction:column;font-family:var(--font-sans);box-sizing:border-box}.chat-messages{overflow-y:auto;overflow-x:hidden;max-height:260px;min-height:88px;padding:10px 12px;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.chat-msg{font-size:13px;color:var(--color-text);line-height:1.45;word-break:break-word;padding:6px 10px;margin-bottom:6px;border-radius:var(--radius-sm);background:#ffffff0a;border:1px solid transparent}.chat-msg-name{font-weight:600;color:#93c5fd}.chat-msg--client{color:var(--color-text-muted);font-style:italic;background:transparent}.chat-msg--party-system{color:var(--color-text);background:#f59e0b14;border-color:#f59e0b33}.dg-key-lock{font-weight:600}.dg-key-lock--red{color:#e53935}.dg-key-lock--blue{color:#1e88e5}.dg-key-lock--green{color:#43a047}.chat-input-row{display:flex;gap:8px;padding:10px 12px;border-top:1px solid var(--color-border);background:var(--color-surface-elevated)}.chat-input{flex:1;padding:9px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text);font-size:13px;font-family:inherit;box-sizing:border-box;outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.chat-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f633}.chat-send-btn{padding:9px 16px;border:none;border-radius:var(--radius-sm);background:var(--color-primary);color:#fff;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;flex-shrink:0;transition:filter var(--transition-fast)}.chat-send-btn:hover{filter:brightness(1.06)}.lobby-panel .chat-panel{margin-top:14px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);overflow:hidden}.chat-panel--game{position:absolute;bottom:16px;left:12px;width:420px;z-index:35;border-radius:8px;background:#0000008c;border:1px solid rgba(255,255,255,.12);pointer-events:none}.chat-panel--game .chat-messages{pointer-events:none}.chat-panel--game .chat-input-row{pointer-events:auto}.chat-panel--game .chat-input{background:#141418d9}.chat-panel--game .chat-send-btn{background:#3d6db5d9}.settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);font-family:var(--font-sans)}.settings-panel{background:var(--color-surface);border-radius:var(--radius-lg);padding:24px 28px;max-width:520px;width:100%;border:1px solid var(--color-border);box-shadow:var(--shadow-md);max-height:90vh;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#555 transparent}.settings-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.settings-title{color:#fff;margin:0;font-size:20px}.settings-close-btn{background:none;border:none;color:#aaa;font-size:24px;cursor:pointer;padding:0 4px;line-height:1}.settings-close-btn:hover{color:#fff}.settings-hint{color:#aaa;font-size:13px;margin:0 0 18px;line-height:1.4}.settings-keybind-list{display:flex;flex-direction:column;gap:8px}.settings-keybind-row{display:flex;align-items:center;gap:12px;padding:8px 10px;background:#ffffff0a;border-radius:6px}.settings-ability-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.settings-ability-name{color:#fff;font-size:14px;font-weight:600}.settings-ability-desc{color:#999;font-size:12px;line-height:1.3}.keybind-badge{flex-shrink:0;min-width:48px;padding:6px 12px;border:1px solid #555;border-radius:4px;background:#1a1a1e;color:#fff;font-size:14px;font-weight:700;font-family:monospace;text-align:center;cursor:pointer;transition:border-color .15s,background .15s}.keybind-badge:hover{border-color:#7ecbff;background:#222230}.keybind-badge--listening{border-color:#7ecbff;background:#222240;color:#7ecbff;font-family:var(--font-sans);font-weight:400;font-size:12px;animation:keybind-pulse 1s ease-in-out infinite}@keyframes keybind-pulse{0%,to{opacity:1}50%{opacity:.6}}.settings-error{color:#ff8a80;font-size:12px;min-width:0;flex-shrink:1}.settings-footer{margin-top:18px;display:flex;justify-content:flex-end}.settings-reset-btn{background:#5a3030;font-size:13px}.settings-reset-btn:hover{background:#6a3838}.ability-bar{position:absolute;left:50%;bottom:16px;transform:translate(-50%);z-index:20;pointer-events:none;display:flex;flex-direction:row;align-items:stretch;gap:8px;padding:10px 12px;background:#0f1113e0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);box-sizing:border-box}.ability-bar__slot{position:relative;width:54px;height:58px;box-sizing:border-box;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:linear-gradient(180deg,var(--color-surface-elevated) 0%,var(--color-bg) 100%);overflow:hidden;pointer-events:auto;cursor:default;flex-shrink:0;box-shadow:inset 0 1px #ffffff0d;transition:opacity .15s ease}.ability-bar__hotkey{position:absolute;top:3px;left:3px;z-index:6;min-width:1rem;padding:2px 5px;font-size:9px;font-weight:700;font-family:var(--font-sans);color:var(--color-text-muted);line-height:1.1;background:#00000080;border-radius:4px;border:1px solid var(--color-border);pointer-events:none}.ability-bar__mid{position:absolute;left:2px;right:2px;top:16px;bottom:20px;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:1}.ability-bar__icon{width:28px;height:28px;object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}.ability-bar__label{position:absolute;left:2px;right:2px;bottom:7px;z-index:2;font-size:8px;font-weight:600;font-family:var(--font-sans);color:var(--color-text-muted);line-height:1.1;text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;pointer-events:none}.ability-bar__cd-shade{position:absolute;left:0;top:0;width:100%;height:100%;background:#000000a6;transform-origin:left center;transform:scaleX(0);pointer-events:none;z-index:4}.ability-bar__cd-text{position:absolute;left:0;top:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;font-family:var(--font-sans);font-variant-numeric:tabular-nums;color:#fffffff2;text-shadow:0 0 4px rgba(0,0,0,.95);pointer-events:none;opacity:0;z-index:5}.ability-bar__channel{position:absolute;left:4px;right:4px;bottom:2px;height:3px;background:#00000080;border-radius:2px;overflow:hidden;opacity:0;z-index:3;pointer-events:none}.ability-bar__channel-fill{height:100%;width:0%;background:var(--color-primary);border-radius:2px;box-shadow:0 0 6px #3b82f666}.ability-bar .ability-tooltip{display:none;position:absolute;transform:translate(-50%);max-width:220px;padding:8px 12px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font-sans);font-size:12px;line-height:1.45;white-space:normal;pointer-events:none;z-index:50;text-align:center;box-shadow:var(--shadow-md)}.perk-hud{position:absolute;left:50%;bottom:102px;transform:translate(-50%);z-index:21;pointer-events:none}.perk-hud__slot{position:relative;width:56px;padding:8px 6px 6px;box-sizing:border-box;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:#0f1113e0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:var(--shadow-md);pointer-events:auto;cursor:default;display:flex;flex-direction:column;align-items:center;gap:4px}.perk-hud__icon{display:block;border-radius:6px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.5))}.perk-hud__label{font-size:8px;font-weight:600;font-family:var(--font-sans);color:var(--color-text-muted);text-align:center;line-height:1.1;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.perk-hud__tooltip{display:none;position:absolute;transform:translate(-50%);max-width:240px;padding:8px 12px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-family:var(--font-sans);font-size:12px;line-height:1.45;white-space:normal;pointer-events:none;z-index:50;text-align:center;box-shadow:var(--shadow-md)}.hs-page{display:flex;flex-direction:column;align-items:stretch;flex:1;width:100%;max-width:960px;margin:0 auto;box-sizing:border-box;padding:28px 20px 40px;min-height:calc(100vh - var(--site-navbar-height))}.hs-hero{margin-bottom:24px}.hs-hero h1{margin:0 0 6px;font-size:clamp(1.35rem,3vw,1.75rem);font-weight:700;letter-spacing:-.02em;color:var(--color-text)}.hs-hero p{margin:0;font-size:14px;color:var(--color-text-muted);line-height:1.45;max-width:48ch}#hiscores-status{font-size:14px;color:var(--color-text-muted);margin-bottom:16px;padding:12px 14px;border-radius:var(--radius-sm);background:var(--color-surface);border:1px solid var(--color-border)}.hs-toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;width:100%;margin-bottom:16px;padding:16px 18px;border-radius:var(--radius-md);background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.hs-filter-group{display:flex;flex-direction:column;gap:6px;min-width:0}.hs-filter-group label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.hs-filter-group input,.hs-filter-group select{padding:9px 12px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text);font-size:13px;font-family:inherit;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.hs-filter-group input:focus,.hs-filter-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f633}.hs-filter-group select{cursor:pointer}.hs-filter-group input[type=text]{width:min(180px,100%)}.hs-filter-group input[type=number]{width:76px}.hs-result-count{font-size:13px;color:var(--color-text-muted);width:100%;margin-bottom:10px}#hiscores-table-wrap{width:100%;overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface);box-shadow:var(--shadow-sm)}#hiscores-table{width:100%;border-collapse:collapse;font-size:14px}#hiscores-table th,#hiscores-table td{padding:12px 14px;text-align:left;white-space:nowrap}#hiscores-table th{background:var(--color-surface-elevated);color:#93c5fd;font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:1}#hiscores-table tbody tr{transition:background var(--transition-fast)}#hiscores-table tbody tr:nth-child(2n){background:#ffffff05}#hiscores-table tbody tr:hover{background:#3b82f614}#hiscores-table td{border-bottom:1px solid var(--color-border)}.hs-rank{color:var(--color-text-muted);width:56px;font-variant-numeric:tabular-nums}.hs-rank-inner{display:inline-flex;align-items:center;gap:6px}.hs-medal{font-size:1.05em;line-height:1}.hs-rank-num{font-weight:600;color:var(--color-text)}.hs-rank-1 .hs-rank-num{color:#fde047}.hs-rank-2 .hs-rank-num{color:#e2e8f0}.hs-rank-3 .hs-rank-num{color:#fb923c}.hs-time,.hs-pct{font-variant-numeric:tabular-nums}.hs-players span{display:inline-block;background:#3b82f61f;border:1px solid rgba(59,130,246,.25);border-radius:999px;padding:3px 10px;margin:2px 4px 2px 0;font-size:13px}.hs-load-more-wrap{width:100%;display:flex;justify-content:center;margin-top:20px}.hs-load-more{padding:10px 28px;border:1px solid var(--color-border);border-radius:999px;background:var(--color-surface);color:#93c5fd;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.hs-load-more:hover:not(:disabled){background:var(--color-surface-elevated);border-color:var(--color-border-strong)}.hs-load-more:disabled{opacity:.5;cursor:default}
