:root{--bg: #0f1115;--panel: #1a1d24;--panel2: #22262f;--line: #2e333d;--text: #e7e9ee;--muted: #9aa3b2;--accent: #6c5ce7;--accent2: #00d2a8;--danger: #e74c3c}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,system-ui,sans-serif;overflow:hidden}#game{position:fixed;top:0;right:0;bottom:0;left:0}#game canvas{image-rendering:pixelated;display:block}.hidden{display:none!important}#join{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:flex;align-items:center;justify-content:center;background:radial-gradient(1200px 800px at 50% -10%,#1c2030,#0c0e13 60%)}.join-card{width:420px;max-width:92vw;padding:32px;background:linear-gradient(180deg,#1b1f29,#15181f);border:1px solid var(--line);border-radius:18px;box-shadow:0 30px 80px #0000008c}.brand{font-size:22px;font-weight:700;display:flex;align-items:center;gap:10px}.logo{filter:drop-shadow(0 2px 6px rgba(108,92,231,.5))}.sub{color:var(--muted);margin:6px 0 22px;font-size:14px}.join-card label{display:block;font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin:16px 0 8px}#name-input{width:100%;padding:12px 14px;border-radius:10px;background:var(--panel2);border:1px solid var(--line);color:var(--text);font-size:15px;outline:none}#name-input:focus{border-color:var(--accent)}#avatars{display:flex;gap:10px}.avatar-pick{flex:1;aspect-ratio:1;border-radius:12px;cursor:pointer;background:var(--panel2);border:2px solid var(--line);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;transition:.12s;position:relative}.avatar-pick canvas{image-rendering:pixelated;width:48px;height:64px}.avatar-pick span{font-size:11px;color:var(--muted)}.avatar-pick.sel{border-color:var(--accent);background:#272341}.avatar-pick:hover{border-color:#4a4f5e}#join-btn{width:100%;margin-top:24px;padding:14px;border:0;border-radius:12px;background:linear-gradient(90deg,var(--accent),#8b7bff);color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:.12s}#join-btn:hover{transform:translateY(-1px);box-shadow:0 10px 30px #6c5ce766}.hint{margin-top:16px;font-size:12px;color:var(--muted);line-height:1.5}#topbar{position:fixed;top:0;left:0;right:0;height:52px;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:0 18px;background:linear-gradient(180deg,rgba(15,17,21,.92),rgba(15,17,21,.55) 70%,transparent);pointer-events:none}.tb-left{font-weight:700;font-size:16px;display:flex;align-items:center;gap:8px}#room-tag{font-size:12px;font-weight:600;color:#fff;background:var(--accent);padding:3px 10px;border-radius:20px;margin-left:6px}.tb-right{font-size:13px;color:var(--muted);background:#22262fcc;padding:5px 12px;border-radius:20px}#online-count{color:var(--accent2);font-weight:700}#people{position:fixed;top:64px;left:12px;z-index:20;width:210px;background:#14171dd1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:12px;padding:10px;max-height:50vh;overflow:auto}#people h4{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}.person{display:flex;align-items:center;gap:8px;padding:5px 4px;font-size:13px;border-radius:8px}.person .dot{width:8px;height:8px;border-radius:50%;background:var(--accent2);flex:none}.person .pz{margin-left:auto;font-size:10px;color:var(--muted)}.person.me{color:var(--accent2);font-weight:600}#videos{position:fixed;top:64px;right:12px;z-index:20;width:220px;display:flex;flex-direction:column;gap:8px}.vtile{position:relative;width:100%;aspect-ratio:4/3;border-radius:12px;overflow:hidden;background:#11141a;border:1px solid var(--line);box-shadow:0 8px 24px #0006}.vtile video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1);background:#11141a}.vtile.screen video{transform:none}.vtile .label{position:absolute;bottom:6px;left:8px;font-size:12px;font-weight:600;text-shadow:0 1px 3px #000;display:flex;align-items:center;gap:5px}.vtile .label .vol{width:22px;height:3px;border-radius:2px;background:#ffffff40;overflow:hidden}.vtile .label .vol i{display:block;height:100%;background:var(--accent2);width:100%}.vtile .ph{display:none;position:absolute;top:0;right:0;bottom:0;left:0;align-items:center;justify-content:center;font-size:34px;opacity:.5;background:#11141a}.vtile.nocam video{display:none}.vtile.nocam .ph{display:flex}#controls{position:fixed;bottom:18px;left:50%;transform:translate(-50%);z-index:20;display:flex;align-items:center;gap:7px;padding:8px 12px;background:#14171deb;border:1px solid var(--line);border-radius:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 12px 32px #0006}.ctrl{width:44px;height:44px;border-radius:12px;border:0;cursor:pointer;background:var(--panel2);color:var(--text);transition:.12s;display:flex;align-items:center;justify-content:center}.ctrl:hover{background:#333a47;transform:translateY(-1px)}.ctrl svg{display:block}.ctrl.small{width:38px;height:38px;color:var(--muted)}.ctrl.off{background:var(--danger);color:#fff}.ctrl.active{background:var(--accent);color:#fff}.ctrl.danger:hover{background:var(--danger);color:#fff}.ctrl-sep{width:1px;height:26px;background:var(--line);margin:0 3px}.me-name{font-size:13px;color:var(--text);font-weight:600;padding:0 10px 0 4px;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}#chat{position:fixed;bottom:76px;left:50%;transform:translate(-50%);z-index:20;width:360px;max-width:92vw;height:320px;display:flex;flex-direction:column;background:#12151bf2;border:1px solid var(--line);border-radius:14px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 16px 40px #00000080;overflow:hidden}#chat-head{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--line);font-weight:600;font-size:14px}.chat-x{background:transparent;border:0;color:var(--muted);cursor:pointer;display:flex;padding:2px;border-radius:6px}.chat-x:hover{background:var(--panel2);color:var(--text)}#chat-msgs{flex:1;overflow-y:auto;padding:10px 14px;display:flex;flex-direction:column;gap:8px}.cmsg{font-size:13px;line-height:1.4}.cmsg .who{font-weight:700;color:var(--accent2);margin-right:6px}.cmsg.me .who{color:var(--accent)}.cmsg .txt{color:var(--text);word-break:break-word}.cmsg .time{font-size:10px;color:var(--muted);margin-left:6px}#chat-form{display:flex;gap:8px;padding:10px;border-top:1px solid var(--line)}#chat-input{flex:1;padding:10px 12px;border-radius:10px;background:var(--panel2);border:1px solid var(--line);color:var(--text);font-size:14px;outline:none}#chat-input:focus{border-color:var(--accent)}#chat-send{width:40px;border:0;border-radius:10px;background:var(--accent);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}#chat-send:hover{background:#8b7bff}.unread{position:absolute;top:-3px;right:-3px;width:9px;height:9px;border-radius:50%;background:var(--danger);border:2px solid #14171d}#btn-chat{position:relative}.vtile{cursor:pointer;transition:box-shadow .12s,border-color .12s}.vtile.speaking{border-color:var(--accent2);box-shadow:0 0 0 2px var(--accent2),0 0 18px #00d2a8a6}#call-exit{position:fixed;top:16px;right:16px;z-index:61;display:none;padding:10px 16px;border:1px solid var(--line);border-radius:24px;background:#14171df2;color:var(--text);font-size:14px;font-weight:600;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 8px 24px #00000080}#call-exit:hover{background:var(--danger);border-color:var(--danger);color:#fff}body.call-mode #call-exit{display:block}body.call-mode:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:55;background:#080a0ed9;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}body.call-mode #videos{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;width:auto;display:flex;flex-wrap:wrap;align-content:center;justify-content:center;gap:16px;padding:72px 40px;overflow:auto}body.call-mode .vtile{width:min(40vw,460px);aspect-ratio:4/3;border-radius:16px}body.call-mode .vtile .label{font-size:15px}#editor{position:fixed;top:64px;right:12px;bottom:84px;z-index:30;width:280px;display:flex;flex-direction:column;background:#12151bf5;border:1px solid var(--line);border-radius:14px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 16px 40px #00000080;overflow:hidden}.ed-head{padding:12px 14px;border-bottom:1px solid var(--line)}.ed-head>span{font-weight:700;font-size:14px}.ed-actions{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}.ed-btn{flex:1;padding:8px 6px;border:1px solid var(--line);border-radius:8px;background:var(--panel2);color:var(--text);font-size:12px;cursor:pointer;font-weight:600}.ed-btn:hover{background:#2c313c}.ed-btn.primary{background:var(--accent2);border-color:var(--accent2);color:#06231c}.ed-btn.primary:hover{filter:brightness(1.08)}.ed-btn.ghost{flex:0 0 auto;color:var(--muted)}.ed-tools{display:flex;gap:4px;padding:10px;border-bottom:1px solid var(--line)}.ed-tool{flex:1;padding:7px 4px;border:0;border-radius:8px;background:var(--panel2);color:var(--muted);font-size:12px;cursor:pointer;font-weight:600}.ed-tool.active{background:var(--accent);color:#fff}.ed-body{flex:1;overflow-y:auto;padding:10px}.ed-cat{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:10px 0 6px}.ed-cat:first-child{margin-top:0}.ed-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.ed-item{aspect-ratio:1;background:var(--panel2);border:2px solid transparent;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden}.ed-item:hover{border-color:#4a4f5e}.ed-item.sel{border-color:var(--accent);background:#272341}.ed-item img{width:80%;height:80%;object-fit:contain;image-rendering:pixelated}.ed-floors{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}.ed-floor{padding:10px 8px;background:var(--panel2);border:2px solid transparent;border-radius:8px;font-size:12px;text-align:center;cursor:pointer;font-weight:600}.ed-floor:hover{border-color:#4a4f5e}.ed-floor.sel{border-color:var(--accent);background:#272341}.ed-rotbar{display:flex;flex-direction:column;gap:2px;padding:8px 10px;margin-bottom:8px;background:var(--panel2);border-radius:8px;font-size:12px}.ed-rotbar b{color:var(--accent2)}.ed-rotbar span{font-size:10px;color:var(--muted)}.ed-tip{font-size:12px;color:var(--muted);line-height:1.5}.ed-tip b{color:var(--text)}#ed-hint{position:fixed;top:60px;left:50%;transform:translate(-50%);z-index:30;background:#14171deb;border:1px solid var(--line);border-radius:20px;padding:7px 16px;font-size:12px;color:var(--text);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}#minimap-label{position:fixed;bottom:18px;right:12px;z-index:20;font-size:11px;color:var(--muted);background:#14171db3;padding:4px 10px;border-radius:8px}
