:root{--bg: #0b0f17;--panel: rgba(17, 24, 39, .82);--panel-solid: #111827;--border: rgba(255, 255, 255, .08);--text: #e5e7eb;--muted: #9ca3af;--accent: #3b82f6;--danger: #ef4444;--ok: #22c55e;--warn: #eab308}*{box-sizing:border-box}html,body{margin:0;padding:0;width:100%;height:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}#app{position:relative;width:100vw;height:100vh}#game{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}#game canvas{display:block}#sidebar{position:absolute;top:16px;right:16px;width:240px;max-height:calc(100vh - 120px);overflow-y:auto;background:var(--panel);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:12px;padding:12px;box-shadow:0 8px 30px #00000073;z-index:10}.sidebar-header{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:10px}.user-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.user-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:8px;font-size:14px}.user-row.is-local{background:#3b82f62e;border:1px solid rgba(59,130,246,.4)}.user-dot{width:10px;height:10px;border-radius:50%;flex:0 0 auto;box-shadow:0 0 0 2px #00000059}.user-name{flex:1 1 auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-zone{font-size:11px;color:var(--muted);flex:0 0 auto}.status-badge{font-size:10px;padding:1px 5px;border-radius:6px;text-transform:uppercase;letter-spacing:.04em}.status-badge.dnd{background:#ef444433;color:#fca5a5}.status-badge.meeting{background:#eab30833;color:#fde68a}#controls{position:absolute;bottom:16px;left:50%;transform:translate(-50%);display:flex;gap:8px;background:var(--panel);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:14px;padding:8px;box-shadow:0 8px 30px #00000073;z-index:10}.ctrl-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--border);background:#ffffff0a;color:var(--text);font-size:13px;padding:8px 12px;border-radius:10px;cursor:pointer;transition:background .12s ease,border-color .12s ease,opacity .12s ease;white-space:nowrap}.ctrl-btn:hover:not(:disabled){background:#ffffff1a}.ctrl-btn:disabled{opacity:.4;cursor:not-allowed}.ctrl-btn.active{background:#3b82f640;border-color:#3b82f699}.ctrl-btn.danger.active{background:#ef444440;border-color:#ef444499}.pip-fallback{position:absolute;bottom:80px;right:16px;width:220px;background:var(--panel-solid);border:1px solid var(--border);border-radius:12px;padding:10px;z-index:20;box-shadow:0 8px 30px #00000080}.pip-canvas{display:block;width:100%;background:#0b0f17;border-radius:8px}.pip-toast{font-size:12px;color:var(--warn);min-height:16px;margin:6px 0}.pip-buttons{display:flex;gap:6px}.pip-buttons button{flex:1;font-size:12px;padding:6px 4px;border-radius:8px;border:1px solid var(--border);background:#ffffff0d;color:var(--text);cursor:pointer}.pip-buttons button.active{background:#3b82f64d}.cc-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#080a0eb8;display:flex;align-items:center;justify-content:center;z-index:1000}.cc-modal{background:#161a22;border:1px solid #2a2e36;border-radius:14px;padding:20px 24px;width:320px;color:#e5e7eb;font-family:system-ui,sans-serif;display:flex;flex-direction:column;align-items:center;gap:12px;box-shadow:0 20px 60px #00000080}.cc-modal h2{margin:0;font-size:16px}.cc-preview{image-rendering:pixelated;background:#2b3a2b;border-radius:8px}.cc-rows{width:100%;display:flex;flex-direction:column;gap:8px}.cc-row{display:flex;align-items:center;gap:8px}.cc-label{width:56px;font-size:13px;color:#cbd5e1}.cc-val{flex:1;text-align:center;font-size:13px;color:#9ca3af}.cc-row button,.cc-actions button{background:#232734;border:1px solid #333a47;color:#e5e7eb;border-radius:8px;padding:6px 12px;cursor:pointer;font-size:13px}.cc-row button:hover,.cc-actions button:hover{background:#2c3242}.cc-actions{display:flex;gap:10px;margin-top:6px}.cc-actions .cc-save{background:#2563eb;border-color:#2563eb;font-weight:600}.cc-actions .cc-save:hover{background:#1d4ed8}.editor-panel{position:fixed;top:12px;left:12px;z-index:1000;background:#12151c;border:1px solid #2a2e36;border-radius:12px;padding:12px;width:240px;color:#e5e7eb;font-family:system-ui,sans-serif;box-shadow:0 12px 40px #00000080}.editor-panel .ep-title{font-weight:700;font-size:14px;margin-bottom:4px}.editor-panel .ep-hint{font-size:11px;color:#9ca3af;margin-bottom:10px}.editor-panel .ep-tools{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;max-height:320px;overflow-y:auto}.editor-panel .ep-tool{display:flex;flex-direction:column;align-items:center;gap:2px;background:#1c2029;border:1px solid #2a2e36;border-radius:8px;padding:6px 2px;color:#cbd5e1;cursor:pointer;font-size:9px}.editor-panel .ep-tool img{width:28px;height:28px;object-fit:contain;image-rendering:pixelated}.editor-panel .ep-tool:hover{background:#252a35}.editor-panel .ep-tool.sel{border-color:#2563eb;background:#1e293b}.editor-panel .ep-actions{display:flex;gap:8px;margin-top:10px}.editor-panel .ep-actions button{flex:1;padding:7px;border-radius:8px;border:1px solid #333a47;background:#232734;color:#e5e7eb;cursor:pointer;font-size:12px}.editor-panel .ep-actions .ep-save{background:#2563eb;border-color:#2563eb;font-weight:600}.login-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;background:radial-gradient(120% 120% at 50% 0%,#1b2233,#0c0f17 70%);display:flex;align-items:center;justify-content:center;font-family:system-ui,sans-serif}.login-card{background:#12151c;border:1px solid #2a2e36;border-radius:16px;padding:32px 28px;width:320px;text-align:center;color:#e5e7eb;box-shadow:0 24px 70px #0000008c}.login-logo{font-size:34px;font-weight:800;letter-spacing:1px}.login-logo:first-letter{color:#3b82f6}.login-sub{color:#9ca3af;font-size:13px;margin:4px 0 22px}.login-google{width:100%;padding:11px;border-radius:10px;border:1px solid #333a47;background:#1c2029;color:#cbd5e1;cursor:pointer;font-size:13px}.login-google span{color:#6b7280}.login-divider{display:flex;align-items:center;gap:8px;color:#6b7280;font-size:11px;margin:18px 0}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:#2a2e36}.login-form{display:flex;gap:8px}.login-name{flex:1;padding:10px 12px;border-radius:10px;border:1px solid #333a47;background:#0e1117;color:#e5e7eb;font-size:14px}.login-enter{padding:10px 18px;border-radius:10px;border:1px solid #2563eb;background:#2563eb;color:#fff;font-weight:600;cursor:pointer;font-size:14px}.login-enter:hover{background:#1d4ed8}.ep-section{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:#8a91a0;margin:10px 2px 4px}.od-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:3000;background:#080a10b3;display:flex;align-items:center;justify-content:center;font-family:system-ui,sans-serif}.od-modal{background:#12151c;border:1px solid #2a2e36;border-radius:14px;width:880px;max-width:95vw;color:#e5e7eb;box-shadow:0 24px 70px #0009;overflow:hidden}.od-head{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid #232730;font-weight:600}.od-head .od-x{background:none;border:none;color:#9ca3af;font-size:16px;cursor:pointer}.od-body{display:grid;grid-template-columns:200px 1fr 240px;gap:12px;padding:14px}.od-sub{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:#8a91a0;margin-bottom:6px}.od-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;max-height:360px;overflow:auto}.od-asset{background:#1b1f27;border:1px solid #2c313b;border-radius:8px;color:#cbd5e1;cursor:pointer;padding:4px;display:flex;flex-direction:column;align-items:center;gap:2px}.od-asset img{width:28px;height:28px;object-fit:contain;image-rendering:pixelated}.od-asset span{font-size:9px;color:#9ca3af}.od-stage{display:flex;flex-direction:column;align-items:center}.od-canvas{position:relative;background:#0e1117;border:1px solid #2c313b;border-radius:8px;image-rendering:pixelated}.od-line{position:absolute;background:#7882961f}.od-h{left:0;right:0;height:1px}.od-v{top:0;bottom:0;width:1px}.od-piece{position:absolute;image-rendering:pixelated;cursor:pointer}.od-piece.sel{outline:2px solid #3b82f6;outline-offset:-1px}.od-hint{font-size:11px;color:#8a91a0;margin-top:8px}.od-layers{max-height:150px;overflow:auto;margin-bottom:10px}.od-lrow{display:flex;align-items:center;gap:8px;padding:4px 6px;border-radius:6px;cursor:pointer}.od-lrow img{width:20px;height:20px;object-fit:contain;image-rendering:pixelated}.od-lrow span{font-size:12px}.od-lrow.sel{background:#1e2230}.od-ctl label{display:flex;align-items:center;gap:6px;font-size:12px;color:#cbd5e1;margin:4px 0}.od-ctl label b{min-width:28px;text-align:center}.od-ctl button{background:#1b1f27;border:1px solid #2c313b;color:#cbd5e1;border-radius:6px;width:22px;height:22px;cursor:pointer}.od-ctl .od-del{width:auto;padding:4px 10px;margin-top:8px;color:#fca5a5}.od-foot{display:flex;gap:8px;padding:12px 16px;border-top:1px solid #232730}.od-name{flex:1;padding:8px 12px;border-radius:8px;border:1px solid #333a47;background:#0e1117;color:#e5e7eb}.od-save{padding:8px 16px;border-radius:8px;border:1px solid #2563eb;background:#2563eb;color:#fff;font-weight:600;cursor:pointer}.od-cancel{padding:8px 16px;border-radius:8px;border:1px solid #333a47;background:#1c2029;color:#cbd5e1;cursor:pointer}.dd-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:3000;background:#080a10b3;display:flex;align-items:center;justify-content:center;font-family:system-ui,sans-serif}.dd-modal{background:#12151c;border:1px solid #2a2e36;border-radius:14px;color:#e5e7eb;box-shadow:0 24px 70px #0009;overflow:hidden}.dd-head{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid #232730;font-weight:600}.dd-head .dd-x{background:none;border:none;color:#9ca3af;font-size:16px;cursor:pointer}.dd-body{display:flex;gap:16px;padding:16px}.dd-sub{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:#8a91a0;margin-bottom:8px}.dd-palette{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:150px}.dd-pal{background:#1b1f27;border:1px solid #2c313b;border-radius:8px;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center}.dd-pal img{width:30px;height:30px;object-fit:contain;image-rendering:pixelated}.dd-del{margin-top:12px;width:100%;padding:8px;border-radius:8px;border:1px solid #333a47;background:#1c2029;color:#fca5a5;cursor:pointer}.dd-del:disabled{color:#555b66;cursor:default}.dd-stage{display:flex;flex-direction:column;align-items:center}.dd-canvas{position:relative;background:#0e1117;border:1px solid #2c313b;border-radius:8px;image-rendering:pixelated;overflow:hidden}.dd-bg{position:absolute;image-rendering:pixelated;pointer-events:none}.dd-item{position:absolute;image-rendering:pixelated;cursor:grab;touch-action:none}.dd-item.sel{outline:2px solid #38bdf8;outline-offset:-1px}.dd-hint{font-size:11px;color:#8a91a0;margin-top:8px}.dd-foot{display:flex;gap:8px;padding:12px 16px;border-top:1px solid #232730;justify-content:flex-end}.dd-save{padding:8px 18px;border-radius:8px;border:1px solid #2563eb;background:#2563eb;color:#fff;font-weight:600;cursor:pointer}.dd-cancel{padding:8px 16px;border-radius:8px;border:1px solid #333a47;background:#1c2029;color:#cbd5e1;cursor:pointer}.draw-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:3200;background:#080a10b8;display:flex;align-items:center;justify-content:center;font-family:system-ui,sans-serif}.draw-modal{background:#12151c;border:1px solid #2a2e36;border-radius:14px;color:#e5e7eb;box-shadow:0 24px 70px #0009;overflow:hidden}.draw-head{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid #232730;font-weight:600}.draw-head .draw-x{background:none;border:none;color:#9ca3af;font-size:16px;cursor:pointer}.draw-body{display:flex;gap:16px;padding:16px}.draw-side{width:160px}.draw-sub{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:#8a91a0;margin-bottom:8px}.draw-palette{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.draw-sw{width:28px;height:28px;border-radius:6px;border:2px solid #2c313b;cursor:pointer}.draw-sw.on{border-color:#fff}.draw-pick{display:flex;align-items:center;gap:8px;font-size:12px;color:#cbd5e1;margin:12px 0}.draw-tool{display:block;width:100%;margin-top:8px;padding:8px;border-radius:8px;border:1px solid #333a47;background:#1c2029;color:#cbd5e1;cursor:pointer}.draw-tool.on{border-color:#3b82f6;color:#fff}.draw-canvas{background:#0e1117;border:1px solid #2c313b;border-radius:8px;image-rendering:pixelated;cursor:crosshair;touch-action:none}.draw-foot{display:flex;gap:8px;padding:12px 16px;border-top:1px solid #232730}.draw-name{flex:1;padding:8px 12px;border-radius:8px;border:1px solid #333a47;background:#0e1117;color:#e5e7eb}.draw-save{padding:8px 16px;border-radius:8px;border:1px solid #2563eb;background:#2563eb;color:#fff;font-weight:600;cursor:pointer}.draw-cancel{padding:8px 16px;border-radius:8px;border:1px solid #333a47;background:#1c2029;color:#cbd5e1;cursor:pointer}.od-draw,.dd-draw{display:flex;align-items:center;justify-content:center;color:#93c5fd;font-size:12px;text-align:center}.fp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:3100;background:#080a10b3;display:flex;align-items:center;justify-content:center;font-family:system-ui,sans-serif}.fp-modal{background:#12151c;border:1px solid #2a2e36;border-radius:14px;color:#e5e7eb;width:860px;max-width:95vw;height:600px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 70px #0009;overflow:hidden}.fp-head{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid #232730;font-weight:600}.fp-search{margin-left:auto;padding:7px 12px;border-radius:8px;border:1px solid #333a47;background:#0e1117;color:#e5e7eb;width:220px}.fp-head .fp-x{background:none;border:none;color:#9ca3af;font-size:16px;cursor:pointer}.fp-body{display:flex;flex:1;min-height:0}.fp-cats{width:200px;overflow-y:auto;border-right:1px solid #232730;padding:8px}.fp-cat{display:block;width:100%;text-align:left;padding:8px 10px;border-radius:8px;border:none;background:none;color:#cbd5e1;cursor:pointer;font-size:13px}.fp-cat:hover{background:#1a1f2a}.fp-cat.on{background:#1e2230;color:#fff}.fp-grid{flex:1;overflow-y:auto;padding:12px;display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(56px,1fr));align-content:start}.fp-item{background:#1b1f27;border:1px solid #2c313b;border-radius:8px;cursor:pointer;padding:4px;height:56px;display:flex;align-items:center;justify-content:center}.fp-item:hover{border-color:#3b82f6}.fp-item img{max-width:44px;max-height:44px;object-fit:contain;image-rendering:pixelated}.fp-empty{color:#8a91a0;padding:20px}.fp-banner{position:fixed;bottom:76px;left:50%;transform:translate(-50%);z-index:1500;display:flex;align-items:center;gap:10px;background:#12151c;border:1px solid #2a2e36;border-radius:10px;padding:8px 12px;color:#e5e7eb;font-family:system-ui,sans-serif;font-size:13px;box-shadow:0 10px 30px #00000080}.fp-banner img{width:26px;height:26px;object-fit:contain;image-rendering:pixelated}.fp-banner button{padding:6px 12px;border-radius:8px;border:1px solid #333a47;background:#1c2029;color:#cbd5e1;cursor:pointer}.fp-banner .fp-stop{border-color:#2563eb;background:#2563eb;color:#fff}
