@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{color-scheme:light;--font-sans: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--bg: #f6f7fb;--bg-elev: rgba(255, 255, 255, .7);--panel: rgba(255, 255, 255, .72);--panel-solid: #ffffff;--text: #0b1220;--muted: rgba(15, 23, 42, .62);--border: rgba(15, 23, 42, .1);--border-strong: rgba(15, 23, 42, .16);--shadow-sm: 0 8px 18px rgba(15, 23, 42, .06);--shadow-md: 0 16px 40px rgba(15, 23, 42, .1);--primary: #6366f1;--primary-2: #8b5cf6;--primary-fg: #ffffff;--stage-bg: #f8fafc;--grid: rgba(15, 23, 42, .06);--grid-bold: rgba(15, 23, 42, .1);--r-lg: 18px;--r-md: 14px;--r-sm: 12px;--pad: 12px}:root[data-theme=dark]{color-scheme:dark;--bg: #070a12;--bg-elev: rgba(12, 16, 28, .6);--panel: rgba(12, 16, 28, .72);--panel-solid: #0c101c;--text: #e7ecff;--muted: rgba(231, 236, 255, .62);--border: rgba(231, 236, 255, .12);--border-strong: rgba(231, 236, 255, .18);--shadow-sm: 0 10px 26px rgba(0, 0, 0, .35);--shadow-md: 0 22px 60px rgba(0, 0, 0, .55);--primary: #7c83ff;--primary-2: #a78bfa;--primary-fg: #ffffff;--stage-bg: #070a12;--grid: rgba(231, 236, 255, .06);--grid-bold: rgba(231, 236, 255, .1)}*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:var(--font-sans);background:radial-gradient(1000px 700px at 15% -10%,rgba(99,102,241,.18),transparent 50%),radial-gradient(900px 650px at 85% 0%,rgba(139,92,246,.14),transparent 55%),var(--bg);color:var(--text)}::selection{background:rgba(99,102,241,.25)}a{color:inherit}.app{height:100vh;display:flex;flex-direction:column;overflow:hidden}.topbar{height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 14px;border-bottom:1px solid var(--border);background:linear-gradient(to bottom,var(--bg-elev),rgba(255,255,255,0));-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.brand{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:-.02em}.brandIcon{width:30px;height:30px;border-radius:10px;object-fit:cover}.brandMark{width:30px;height:30px;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--primary-2));box-shadow:0 10px 26px #6366f147}.topbarRight{display:flex;align-items:center;gap:10px}.statusPill{display:inline-flex;align-items:center;gap:8px;padding:7px 10px;border-radius:999px;border:1px solid var(--border);background:rgba(255,255,255,.35);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-size:12px;color:var(--muted)}:root[data-theme=dark] .statusPill{background:rgba(12,16,28,.42)}.statusDot{width:8px;height:8px;border-radius:50%;background:#ef4444;box-shadow:0 0 0 4px #ef44442e}.statusDotOnline{background:#22c55e;box-shadow:0 0 0 4px #22c55e2e}.main{flex:1;display:flex;min-height:0}.sidebar{width:300px;border-right:1px solid var(--border);padding:var(--pad);overflow:auto;background:linear-gradient(to bottom,rgba(255,255,255,.3),rgba(255,255,255,.06));-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}:root[data-theme=dark] .sidebar{background:linear-gradient(to bottom,rgba(12,16,28,.65),rgba(12,16,28,.18))}.stage{flex:1;position:relative;overflow:hidden;padding:14px}.stagePlaceholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--muted)}.panel{border:1px solid var(--border);border-radius:var(--r-lg);margin-bottom:12px;background:var(--panel);box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);overflow:hidden}.panelTitle{padding:10px 12px;font-weight:600;border-bottom:1px solid var(--border);letter-spacing:-.01em}.panelBody{padding:12px}.inputRow{display:flex;gap:10px;margin-bottom:10px}.buttonRow{display:flex;gap:10px}.input,.select{width:100%;border:1px solid var(--border);background:rgba(255,255,255,.55);color:var(--text);border-radius:12px;padding:10px;outline:none;transition:border-color .14s ease,box-shadow .14s ease,background .14s ease}:root[data-theme=dark] .input,:root[data-theme=dark] .select{background:rgba(12,16,28,.55)}.input:focus,.select:focus{border-color:#6366f18c;box-shadow:0 0 0 4px #6366f12e}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:rgba(255,255,255,.55);color:var(--text);cursor:pointer;font-weight:600;letter-spacing:-.01em;transition:transform .12s ease,background .14s ease,border-color .14s ease,box-shadow .14s ease,opacity .14s ease;-webkit-user-select:none;user-select:none}:root[data-theme=dark] .btn{background:rgba(12,16,28,.55)}.btn:hover{border-color:var(--border-strong);box-shadow:0 10px 22px #0000000f;transform:translateY(-1px)}:root[data-theme=dark] .btn:hover{box-shadow:0 16px 34px #0000004d}.btn:active{transform:translateY(0);box-shadow:none}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.btnPrimary{border:none;color:var(--primary-fg);background:linear-gradient(135deg,var(--primary),var(--primary-2));box-shadow:0 14px 30px #6366f13d}.btnPrimary:hover{box-shadow:0 18px 44px #6366f14d}.btnGhost{background:transparent;border:1px solid var(--border)}.btnIcon{padding:10px;width:40px;height:40px}.row{display:flex;gap:10px;align-items:center;margin-bottom:12px}.badge{font-size:12px;font-family:var(--font-mono);color:var(--text);background:rgba(99,102,241,.12);padding:5px 10px;border:1px solid rgba(99,102,241,.18);border-radius:999px}.colorInput{width:46px;height:34px;border:none;background:transparent;padding:0}.range{flex:1}.segmented{display:flex;gap:4px;padding:6px;border:1px solid var(--border);border-radius:14px;background:rgba(255,255,255,.35);flex-wrap:wrap}:root[data-theme=dark] .segmented{background:rgba(12,16,28,.35)}.segBtn{flex:1;padding:9px 10px;border-radius:12px;border:1px solid transparent;background:transparent;cursor:pointer;font-weight:700;letter-spacing:-.01em;color:var(--muted);transition:background .14s ease,color .14s ease,border-color .14s ease;display:flex;align-items:center;justify-content:center}.segBtn:hover{background:rgba(99,102,241,.1);color:var(--text)}.segBtnActive{background:rgba(99,102,241,.16);border-color:#6366f133;color:var(--text)}.usersList{padding-left:18px;margin:0}.userItem{display:flex;align-items:center;gap:8px;margin:6px 0}.userColor{display:inline-block;width:10px;height:10px;border-radius:50%}.userMode{color:var(--muted)}.canvasWrap{width:100%;height:100%}.canvasStage{width:100%;height:100%;position:relative;border-radius:20px;border:1px solid var(--border);box-shadow:var(--shadow-md);background:radial-gradient(1100px 700px at 10% 10%,rgba(99,102,241,.1),transparent 55%),radial-gradient(900px 650px at 90% 0%,rgba(139,92,246,.08),transparent 55%),linear-gradient(var(--grid) 1px,transparent 1px),linear-gradient(90deg,var(--grid) 1px,transparent 1px),var(--stage-bg);background-size:auto,auto,24px 24px,24px 24px,auto;touch-action:none;-webkit-user-select:none;user-select:none;overflow:hidden}.panningCursor{cursor:grab}.layer{position:absolute;top:0;right:0;bottom:0;left:0}.layerUi{pointer-events:none}.hud{position:absolute;left:12px;bottom:12px;display:flex;gap:8px;opacity:.95;flex-wrap:wrap;pointer-events:none}.hudItem{background:rgba(0,0,0,.62);color:#fff;padding:7px 10px;border-radius:12px;font-size:12px;border:1px solid rgba(255,255,255,.12);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}:root[data-theme=dark] .hudItem{background:rgba(0,0,0,.55)}.hint{font-size:12px;color:var(--muted);line-height:1.45}.hintMarginTop{margin-top:10px}.rowMarginTop{margin-top:12px}.statusTextMargin{margin-left:8px}.sidebar::-webkit-scrollbar{width:10px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:rgba(15,23,42,.18);border-radius:999px;border:2px solid transparent;background-clip:content-box}:root[data-theme=dark] .sidebar::-webkit-scrollbar-thumb{background:rgba(231,236,255,.14);background-clip:content-box}@media (max-width: 980px){.sidebar{width:320px}}@media (max-width: 820px){.sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border)}.main{flex-direction:column}.stage{padding:12px}}
