*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{color:#e2e8f0;background:#070b14;font-family:Noto Sans Thai,-apple-system,Segoe UI,system-ui,sans-serif;overflow:hidden}.app{position:fixed;inset:0}.app canvas{display:block}.hud{pointer-events:none;padding:14px;position:absolute;inset:0}.hud__panel{pointer-events:auto;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0d1321d1;border:1px solid #94a3b82e;border-radius:16px;flex-direction:column;width:290px;max-height:calc(100vh - 28px);padding:14px;display:flex;box-shadow:0 10px 40px #00000073}.hud__head{justify-content:space-between;align-items:flex-start;display:flex}.hud__title{letter-spacing:.2px;font-size:17px;font-weight:800}.hud__sub{color:#94a3b8;margin-top:2px;font-size:11px}.hud__online{color:#4ade80;align-items:center;gap:6px;font-size:20px;font-weight:800;display:flex}.hud__dot{background:#4ade80;border-radius:50%;width:9px;height:9px;box-shadow:0 0 10px #4ade80}.hud__modes{gap:6px;margin:12px 0 8px;display:flex}.hud__modes button{cursor:pointer;color:#cbd5e1;background:0 0;border:1px solid #94a3b840;border-radius:9px;flex:1;padding:7px;font-family:inherit;font-size:12px}.hud__modes button.on{color:#fff;background:#2563eb;border-color:#2563eb;font-weight:700}.hud__warn{color:#fbbf24;margin-bottom:6px;font-size:11px}.hud__legend{color:#cbd5e1;flex-wrap:wrap;gap:8px 12px;margin:6px 0 10px;font-size:11px;display:flex}.legend{align-items:center;gap:5px;display:inline-flex}.legend i{border-radius:3px;width:10px;height:10px;display:inline-block}.legend b{color:#fff}.hud__list{flex-direction:column;gap:3px;display:flex;overflow-y:auto}.row{pointer-events:auto;text-align:left;cursor:pointer;color:#e2e8f0;background:0 0;border:1px solid #0000;border-radius:9px;align-items:center;gap:8px;width:100%;padding:7px 8px;font-family:inherit;font-size:13px;display:flex}.row:hover{background:#94a3b81a}.row--sel{background:#2563eb40;border-color:#2563eb}.row__aura{border-radius:50%;flex-shrink:0;width:9px;height:9px}.row__name{white-space:nowrap;text-overflow:ellipsis;flex:1;font-weight:600;overflow:hidden}.row__admin{color:#fff;background:#7c3aed;border-radius:4px;margin-left:5px;padding:1px 5px;font-size:9px;font-style:normal}.row__room{color:#94a3b8;white-space:nowrap;font-size:11px}.hud__empty{color:#64748b;text-align:center;padding:16px 4px;font-size:12px}.hud__hint{color:#64748b;white-space:nowrap;background:#0d1321b3;border-radius:20px;padding:5px 12px;font-size:11px;position:absolute;bottom:14px;left:50%;transform:translate(-50%)}.nametag{white-space:nowrap;color:#f1f5f9;background:#070b14c7;border:1px solid #94a3b840;border-radius:20px;align-items:center;gap:5px;padding:3px 8px;font-size:13px;font-weight:700;display:flex;transform:translateY(-50%)}.nametag--sel{border-color:#fff;box-shadow:0 0 0 2px #fff6}.nametag__name{line-height:1}.nametag__badge{color:#07111e;border-radius:6px;padding:1px 5px;font-size:9px;font-weight:800;line-height:1.4}.nametag__badge--admin{color:#fff;background:#7c3aed}.boot{color:#94a3b8;justify-content:center;align-items:center;font-size:14px;display:flex;position:fixed;inset:0}.login{background:radial-gradient(120% 120% at 50% 0,#122036 0%,#070b14 60%);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.login__card{background:#0d1321e6;border:1px solid #94a3b82e;border-radius:18px;flex-direction:column;gap:10px;width:320px;padding:26px 22px;display:flex;box-shadow:0 20px 60px #00000080}.login__brand{letter-spacing:.2px;font-size:22px;font-weight:800}.login__sub{color:#94a3b8;margin-bottom:8px;font-size:12px}.login__card input{color:#e2e8f0;background:#0b1220;border:1px solid #94a3b840;border-radius:10px;padding:11px 13px;font-family:inherit;font-size:14px}.login__card input:focus{border-color:#2563eb;outline:none}.login__card button[type=submit]{cursor:pointer;color:#fff;background:#2563eb;border:none;border-radius:10px;margin-top:4px;padding:11px;font-family:inherit;font-size:14px;font-weight:700}.login__card button[type=submit]:disabled{opacity:.6;cursor:default}.login__ghost{cursor:pointer;color:#cbd5e1;background:0 0;border:1px solid #94a3b840;border-radius:10px;padding:9px;font-family:inherit;font-size:13px}.login__err{color:#fb7185;font-size:12px}.login__meta{color:#94a3b8;justify-content:space-between;align-items:center;font-size:11px;display:flex}.login__link{color:#60a5fa;cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:11px}.login__card input[inputmode=numeric]{letter-spacing:6px;text-align:center;font-size:18px}.signout{pointer-events:auto;color:#cbd5e1;cursor:pointer;white-space:nowrap;text-overflow:ellipsis;background:#0d1321d1;border:1px solid #94a3b833;border-radius:20px;max-width:240px;padding:7px 12px;font-family:inherit;font-size:12px;position:absolute;top:14px;right:14px;overflow:hidden}.signout:hover{color:#fff;border-color:#fb7185}.roomtag{white-space:nowrap;color:#e2e8f0;background:#070b148c;border:1px solid;border-radius:10px;align-items:center;gap:8px;padding:3px 10px;font-size:13px;font-weight:700;display:flex}.roomtag b{font-size:13px}
