@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Sora:wght@500;600;700&display=swap";:root{--site-navbar-height: 56px;--font-sans: "Inter", system-ui, -apple-system, Segoe UI, sans-serif;--font-lobby: "Sora", var(--font-sans);--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:stretch;justify-content:center;padding:0;box-sizing:border-box;pointer-events:auto;background:radial-gradient(ellipse 80% 50% at 50% -10%,rgba(59,130,246,.14),transparent 55%),radial-gradient(ellipse 60% 40% at 100% 80%,rgba(245,158,11,.06),transparent 50%),radial-gradient(ellipse 50% 45% at 0% 60%,rgba(34,197,94,.05),transparent 45%),linear-gradient(180deg,#06080cf7,#0a0c12fa);overflow:hidden;min-height:0}.lobby-shell{background:transparent;border-radius:0;padding:clamp(20px,3vw,40px);max-width:none;width:100%;height:100%;max-height:none;border:none;box-shadow:none;box-sizing:border-box;display:flex;flex-direction:column;min-height:0;position:relative}.lobby-shell:before{display:none}.lobby-header{flex-shrink:0;margin-bottom:clamp(14px,1.8vw,22px);display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:12px 24px;position:relative;z-index:1}.lobby-header__top{min-width:0}.lobby-header__meta{text-align:right;max-width:min(100%,380px)}@media (max-width: 640px){.lobby-header{flex-direction:column;align-items:stretch}.lobby-header__meta{text-align:left;max-width:none}}.lobby-eyebrow{display:block;font-family:var(--font-lobby);font-size:11px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:#93c5fdbf;margin-bottom:6px}.lobby-title__accent{background:linear-gradient(120deg,#93c5fd,#60a5fa 45%,#c4b5fd);-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent}.lobby-user__label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-right:6px}.lobby-body{flex:1;min-height:0;display:grid;grid-template-columns:minmax(500px,1.8fr) minmax(350px,1fr) minmax(300px,1.2fr);gap:clamp(24px,3vw,48px);align-items:stretch}.lobby-col{min-width:0;min-height:0;display:flex;flex-direction:column;gap:0}.lobby-col--session{gap:10px;overflow-y:auto;overflow-x:hidden}.lobby-col--loadout{gap:14px;overflow-y:auto;overflow-x:hidden}.lobby-col--chat{display:flex;flex-direction:column;min-height:0;border-radius:12px;border:1px solid rgba(70,85,110,.45);background:linear-gradient(180deg,#0f141ed9,#0a0c12f2);padding:14px;box-sizing:border-box;box-shadow:inset 0 0 32px #3b82f60a,0 4px 24px #00000040;position:relative;z-index:1}.lobby-chat-heading{flex-shrink:0;margin:0 0 10px;font-family:var(--font-lobby);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:#94b4dcd9}.lobby-chat-host{flex:1;min-height:0;display:flex;flex-direction:column}.lobby-chat-placeholder{flex:1;display:flex;align-items:center;justify-content:center;text-align:center;padding:20px;color:var(--color-text-muted);font-size:13px;line-height:1.6;border:1px dashed rgba(255,255,255,.1);border-radius:8px;background:#0000001a}.lobby-footer{flex-shrink:0;margin-top:14px;padding-top:14px;border-top:1px solid rgba(60,70,85,.45);position:relative;z-index:1}.lobby-title{font-family:var(--font-lobby);color:var(--color-text);margin:0;font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;letter-spacing:-.04em;line-height:1.1;text-shadow:0 4px 32px rgba(0,0,0,.5)}.lobby-user{color:#bfdbfe;font-size:13px;margin:0 0 8px}.lobby-user strong{color:var(--color-text);font-weight:600}.lobby-hint{color:#9aa4b2f2;font-size:13px;margin:0;line-height:1.5}.lobby-board{flex:1;min-height:0;display:flex;flex-direction:column;gap:16px;padding:24px 20px;border-radius:16px;background:linear-gradient(180deg,#00000059,#0f121899);border:1px solid rgba(75,85,110,.45);box-shadow:0 12px 48px #0006,inset 0 1px #ffffff0d;position:relative;z-index:1}.lobby-board--loadout{padding:0;overflow:hidden;background:transparent;border:none;box-shadow:none}.lobby-board--session{background:linear-gradient(180deg,#00000038,#12161e80)}.lobby-board__head{display:flex;align-items:center;gap:10px;margin:-4px 0 2px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.06)}.lobby-board__label{font-family:var(--font-lobby);font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#e2e8f0eb}.lobby-board__icon{width:28px;height:28px;border-radius:8px;background:linear-gradient(145deg,#3b82f673,#2563eb33);box-shadow:0 0 20px #3b82f640,inset 0 1px #ffffff26;border:1px solid rgba(100,160,255,.35)}.lobby-board__icon--session{background:linear-gradient(145deg,#f59e0b66,#d9770633);box-shadow:0 0 20px #f59e0b33,inset 0 1px #ffffff1f;border-color:#fbbf2459}.lobby-loadout-tabs{display:flex;gap:2px;margin-bottom:16px;background:#0003;padding:4px;border-radius:12px}.lobby-loadout-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;border:none;border-radius:8px;background:transparent;color:var(--color-text-muted);font-family:var(--font-lobby);font-weight:600;font-size:13px;cursor:pointer;transition:all .2s ease}.lobby-loadout-tab:hover{background:#ffffff0d;color:var(--color-text)}.lobby-loadout-tab--active{background:linear-gradient(180deg,#3b82f633,#2563eb1a);color:#93c5fd;box-shadow:0 2px 8px #0003}.lobby-loadout-tab__num{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:#ffffff1a;font-size:10px;color:inherit}.lobby-loadout-tab--active .lobby-loadout-tab__num{background:#3b82f6;color:#fff}.lobby-loadout-viewport{flex:1;overflow:hidden;position:relative;border-radius:16px;background:linear-gradient(180deg,#00000059,#0f121899);border:1px solid rgba(75,85,110,.45);box-shadow:0 12px 48px #0006}.lobby-loadout-slider{display:flex;width:100%;height:100%;transition:transform .4s cubic-bezier(.4,0,.2,1)}.lobby-loadout-step{flex:0 0 100%;width:100%;height:100%;padding:24px;box-sizing:border-box;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.lobby-character-preview{width:100%;aspect-ratio:16 / 9;max-height:280px;flex-shrink:0;background:radial-gradient(circle at center,#1e293b66,#0f172ab3);border-radius:20px;border:1px solid rgba(70,85,110,.4);margin-bottom:24px;overflow:hidden;position:relative;box-shadow:inset 0 0 80px #0009,0 12px 48px #0006}.lobby-character-preview canvas{width:100%;height:100%;display:block}#lobby-character-preview-host{width:100%;height:100%}.lobby-section-title{font-family:var(--font-lobby);font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:#94a3b8e6;margin:0 0 10px}.lobby-model-picker{margin-bottom:0}.lobby-model-options{display:grid;grid-template-columns:repeat(auto-fill,minmax(76px,1fr));gap:8px;width:100%}.lobby-model-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-height:64px;padding:8px 6px;border:1px solid rgba(55,65,80,.9);border-radius:10px;background:linear-gradient(165deg,#191c24f2,#0f1116fa);color:var(--color-text-muted);font-family:inherit;font-size:11px;cursor:pointer;transition:border-color .2s ease,background .2s ease,color .2s ease,box-shadow .2s ease,transform .15s ease}.lobby-model-card:hover{border-color:#648cc873;color:var(--color-text);box-shadow:0 4px 16px #00000059;transform:translateY(-1px)}.lobby-model-card--active{border-color:#60a5fabf;background:linear-gradient(165deg,#1e3a7873,#141e37d9);color:var(--color-text);box-shadow:0 0 0 1px #3b82f666,0 0 24px #3b82f633}.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:0}.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:80px;padding:10px 8px;border:1px solid rgba(55,65,80,.9);border-radius:10px;background:linear-gradient(165deg,#191c24f2,#0f1116fa);color:var(--color-text-muted);font-family:inherit;font-size:11px;cursor:pointer;transition:border-color .2s ease,background .2s ease,color .2s ease,box-shadow .2s ease,transform .15s ease}.lobby-perk-card:hover{border-color:#648cc873;color:var(--color-text);transform:translateY(-1px);box-shadow:0 4px 14px #0000004d}.lobby-perk-card--active{border-color:#60a5fabf;background:linear-gradient(165deg,#1e3a7866,#141e37e0);color:var(--color-text);box-shadow:0 0 0 1px #3b82f659,0 0 20px #3b82f626}.lobby-perk-card__icon{display:block;border-radius:8px;flex-shrink:0;box-shadow:0 2px 8px #00000059}.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-perk-detail{margin-top:16px;padding:12px 14px;border-radius:10px;background:#0f172a66;border:1px solid rgba(51,65,85,.5);min-height:64px}.lobby-perk-detail__title{font-size:11px;font-weight:700;color:#93c5fd;text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.lobby-perk-detail__desc{font-size:12px;line-height:1.5;color:var(--color-text-muted)}.lobby-modes{display:grid;grid-template-columns:1fr;gap:12px;margin-bottom:0}.lobby-mode-card{padding:12px 14px;border-radius:12px;border:1px solid rgba(60,70,85,.65);background:linear-gradient(165deg,#202630e6,#141820f2);box-shadow:0 4px 20px #0003,inset 0 1px #ffffff0d;transition:border-color .2s ease,box-shadow .2s ease,transform .15s ease}.lobby-mode-card:hover{border-color:#64789673;box-shadow:0 8px 28px #00000059}.lobby-mode-card--party{border-color:#3b82f647;background:linear-gradient(155deg,#192d5559,#121620f2 55%,#0e1016fa)}.lobby-mode-card--party:hover{border-color:#60a5fa73}.lobby-mode-title{font-family:var(--font-lobby);margin:0 0 8px;font-size:15px;font-weight:700;letter-spacing:-.02em;color:var(--color-text)}.lobby-mode-text{margin:0 0 10px;font-size:12px;color:var(--color-text-muted);line-height:1.4}.lobby-mode-card--party .lobby-mode-text{margin-bottom:10px}.lobby-party-bar{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:2px}.lobby-actions-party{display:flex;flex-direction:column;gap:12px}.lobby-join-row{display:flex;gap:8px;align-items:stretch;width:100%}.lobby-input{flex:1;padding:11px 14px;border:1px solid rgba(55,65,80,.85);border-radius:10px;background:linear-gradient(180deg,#12141af2,#0c0e12fa);color:var(--color-text);font-size:14px;font-family:var(--font-lobby);transition:border-color .2s ease,box-shadow .2s ease;box-shadow:inset 0 2px 6px #00000059}.lobby-input:focus{outline:none;border-color:#60a5faa6;box-shadow:inset 0 2px 6px #00000040,0 0 0 3px #3b82f638}.lobby-input::placeholder{color:#788291d9}.lobby-btn{padding:11px 18px;border:none;border-radius:10px;background:linear-gradient(180deg,#3b82f6,#2563eb);color:#fff;font-size:14px;font-weight:600;font-family:var(--font-lobby);cursor:pointer;box-shadow:0 2px 12px #2563eb59,inset 0 1px #ffffff1f;transition:filter .2s ease,transform .12s ease,box-shadow .2s ease}.lobby-btn:hover{filter:brightness(1.08);box-shadow:0 4px 18px #2563eb73,inset 0 1px #ffffff26}.lobby-btn:active{transform:translateY(1px)}.lobby-btn--accent{background:linear-gradient(180deg,#fbbf24,#d97706 55%,#b45309);box-shadow:0 3px 16px #d9770673,inset 0 1px #fff3;width:100%}.lobby-btn--accent:hover{filter:brightness(1.06)}.lobby-btn--secondary{background:linear-gradient(180deg,#2d3440f2,#1c2028fa);border:1px solid rgba(80,90,110,.6);color:var(--color-text);width:100%;box-shadow:0 2px 8px #00000040,inset 0 1px #ffffff0f}.lobby-btn--secondary:hover{background:linear-gradient(180deg,#373e4cfa,#20242e);border-color:#64789680;filter:none}.lobby-party-info{flex:1;min-width:0;color:var(--color-text);font-size:13px;margin:0;padding:12px 14px;border-radius:10px;background:linear-gradient(180deg,#141c2d99,#0c1018e6);border:1px solid rgba(59,130,246,.25);box-shadow:inset 0 0 24px #3b82f60a}.lobby-code{font-weight:700;letter-spacing:.08em;font-family:var(--font-mono);color:#93c5fd}.lobby-copy{width:auto;flex-shrink:0;margin:0;padding:10px 16px;background:linear-gradient(180deg,#28468280,#192d5ad9);border:1px solid rgba(96,165,250,.4);font-size:12px;font-weight:600;font-family:var(--font-lobby);white-space:nowrap;box-shadow:0 2px 10px #2563eb33,inset 0 1px #ffffff14}.lobby-copy:hover{background:linear-gradient(180deg,#3255a08c,#1e376ee6);border-color:#93c5fd80}.lobby-count{color:var(--color-text-muted);font-size:13px}.lobby-member-list{list-style:none;padding:0;margin:0 0 8px;font-size:13px;color:var(--color-text);display:grid;grid-template-columns:1fr;gap:6px}@media (min-width: 420px){.lobby-member-list{grid-template-columns:1fr 1fr}}.lobby-member-list li{padding:10px 12px;margin-bottom:0;border-radius:10px;border:1px solid rgba(55,65,80,.75);background:linear-gradient(90deg,#1e3a5f26,#12141ad9 8px,#12141ae6);box-shadow:inset 3px 0 #3b82f673;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-session-actions{display:flex;flex-direction:column;gap:8px;margin-top:auto;padding-top:4px}.lobby-ready{width:100%;margin-bottom:0;background:linear-gradient(180deg,#2d343ef2,#1c2028fa);border:1px solid rgba(100,120,140,.45);color:var(--color-text);font-family:var(--font-lobby);box-shadow:0 2px 12px #00000040,inset 0 1px #ffffff0f}.lobby-ready:hover{background:linear-gradient(180deg,#37404efa,#232832);border-color:#8296b473}.lobby-start{width:100%;margin-bottom:0;padding:14px 18px;font-size:16px;font-weight:700;font-family:var(--font-lobby);letter-spacing:.02em;border-radius:12px;background:linear-gradient(180deg,#4ade80,#22c55e 40%,#15803d);box-shadow:0 4px 22px #22c55e66,inset 0 1px #fff3;text-shadow:0 1px 2px rgba(0,0,0,.35)}.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:24px;font-size:13px;font-family:var(--font-lobby);font-weight:500;color:#86efac;margin:0;padding:8px 12px;border-radius:8px;background:#22c55e14;border:1px solid transparent}.lobby-status:not(:empty){border-color:#22c55e33}.lobby-status-error{color:#fecaca;background:#ef44441a;border-color:#ef444440}@media (max-height: 850px){.lobby-shell{padding:20px 32px}.lobby-header{margin-bottom:16px}.lobby-character-preview{max-height:220px}}@media (max-width: 1200px){.lobby-body{grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);gap:20px}.lobby-col--chat{grid-column:1 / -1;min-height:240px;max-height:320px}}@media (max-width: 900px){.lobby-overlay{overflow-y:auto;align-items:flex-start}.lobby-shell{height:auto;max-height:none;min-height:min(100%,100dvh)}.lobby-body{grid-template-columns:1fr}.lobby-col--chat{grid-column:auto;min-height:200px;max-height:40vh}}.chat-panel{display:flex;flex-direction:column;flex:1;min-height:0;font-family:var(--font-sans);box-sizing:border-box}.chat-messages{flex:1;overflow-y:auto;overflow-x:hidden;min-height:120px;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-chat-host .chat-panel{flex:1;min-height:0;display:flex;flex-direction:column;margin:0;border-radius:10px;border:1px solid rgba(55,65,85,.5);background:#00000059;overflow:hidden;box-shadow:inset 0 1px #ffffff0a}.lobby-chat-host .chat-messages{flex:1;min-height:0;max-height:none}.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}
