: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;max-height:calc(100vh - 160px);overflow-y:auto;overflow-x:hidden;padding-right:3px;scrollbar-width:thin}#videos::-webkit-scrollbar{width:7px}#videos::-webkit-scrollbar-thumb{background:#ffffff29;border-radius:4px}#videos::-webkit-scrollbar-thumb:hover{background:#ffffff47}.vtile{position:relative;width:100%;aspect-ratio:4/3;border-radius:12px;overflow:hidden;flex-shrink:0;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;transform-origin:center}.vtile.screen video,.vtile.wide video{object-fit:contain;transform:none;background:#000}.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;left:0;right:0;bottom:0;top:auto;width:auto;height:132px;z-index:63;display:flex;flex-direction:row;flex-wrap:nowrap;align-items:center;justify-content:flex-start;gap:10px;padding:8px 18px;overflow-x:auto;overflow-y:hidden;background:linear-gradient(to top,#06080cf0,#06080c00);scrollbar-width:thin}body.call-mode #videos::-webkit-scrollbar{height:8px}body.call-mode #videos::-webkit-scrollbar-thumb{background:#ffffff2e;border-radius:4px}body.call-mode .vtile{width:168px;height:110px;aspect-ratio:auto;border-radius:10px;flex:0 0 auto;opacity:.7;transition:opacity .12s;cursor:pointer}body.call-mode .vtile:hover{opacity:1}body.call-mode .vtile.focused{position:fixed;top:60px;right:20px;bottom:148px;left:20px;width:auto;height:auto;aspect-ratio:auto;border-radius:16px;opacity:1;border-color:var(--accent2);z-index:60;margin:0;overflow:hidden}body.call-mode .vtile.focused video{cursor:default}body.call-mode .vtile .label{font-size:12px}body.call-mode .vtile.focused .label{font-size:15px}body.call-mode .vtile.focused:after{content:"scroll = zoom · arraste = mover";position:absolute;top:8px;left:50%;transform:translate(-50%);font-size:11px;color:var(--muted);background:#080a0eb3;padding:3px 10px;border-radius:10px;pointer-events:none}#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}.imp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#06080cb8;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.imp-modal{width:min(560px,94vw);max-height:90vh;overflow:auto;background:var(--panel, #1a1d24);border:1px solid var(--line, #2c313c);border-radius:14px;padding:16px 18px;box-shadow:0 20px 60px #00000080}.imp-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:15px}.imp-x{background:none;border:none;color:var(--muted, #9aa0ab);font-size:16px;cursor:pointer}.imp-cols{display:flex;gap:16px}.imp-left{flex:1;display:flex;flex-direction:column;gap:10px}.imp-right{width:170px;display:flex;flex-direction:column;align-items:center;gap:6px}.imp-prevwrap{width:160px;height:160px;border-radius:10px;border:1px solid var(--line, #2c313c);background:linear-gradient(45deg,#232733 25%,transparent 25%) 0 0/16px 16px,linear-gradient(-45deg,#232733 25%,transparent 25%) 0 8px/16px 16px,linear-gradient(45deg,transparent 75%,#232733 75%) 8px -8px/16px 16px,linear-gradient(-45deg,transparent 75%,#232733 75%) -8px 0/16px 16px,#1b1e26;display:flex;align-items:center;justify-content:center}.imp-tip{font-size:11px;color:var(--muted, #9aa0ab)}.imp-field{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted, #9aa0ab)}.imp-field input{padding:7px 9px;border-radius:8px;border:1px solid var(--line, #2c313c);background:var(--panel2, #232733);color:#fff}.imp-check{display:flex;align-items:center;gap:7px;font-size:12.5px;cursor:pointer}.imp-range{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted, #9aa0ab)}.imp-range input{flex:1}.imp-size{display:flex;gap:10px}.imp-size label{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted, #9aa0ab)}.imp-size input{width:52px;padding:6px;border-radius:7px;border:1px solid var(--line, #2c313c);background:var(--panel2, #232733);color:#fff}.imp-slots{display:flex;gap:8px;flex-wrap:wrap}.imp-slot{width:64px;height:64px;border-radius:9px;border:1px dashed #3a3f4c;background:var(--panel2, #232733);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;position:relative;overflow:hidden}.imp-slot.has{border-style:solid;border-color:var(--accent2, #00d2a8)}.imp-slot span{position:absolute;top:2px;left:5px;font-size:9px;color:var(--muted, #9aa0ab);z-index:1}.imp-slot img{max-width:100%;max-height:100%;image-rendering:pixelated}.imp-plus{font-size:22px;color:#555b68}.imp-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:14px}.imp-actions .ed-btn{flex:0 0 auto;padding:8px 16px}#net-status{position:fixed;top:14px;left:50%;transform:translate(-50%);z-index:200;padding:9px 18px;border-radius:22px;font-size:13px;font-weight:600;color:#fff;box-shadow:0 10px 28px #00000073;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;gap:10px}#net-status.hidden{display:none}#net-status.warn{background:#be8c1ef5}#net-status.ok{background:#14a05ff5}#net-status.err{background:#cd3737f7}#net-status.err button{background:#fff;color:#b22;border:0;border-radius:12px;padding:5px 13px;font-weight:700;cursor:pointer;font-size:12.5px}#net-status.warn:before{content:"";width:11px;height:11px;border-radius:50%;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;animation:nsspin .7s linear infinite}@keyframes nsspin{to{transform:rotate(360deg)}}
