:root{--bg-primary: #0a0a14;--bg-secondary: #101020;--bg-surface: #151528;--bg-elevated: #1a1a35;--bg-hover: #20204a;--bg-active: #252560;--accent: #00d4ff;--accent-dim: rgba(0, 212, 255, .15);--accent-glow: rgba(0, 212, 255, .3);--text-primary: #e0e4f0;--text-secondary: #8890a8;--text-dim: #555a70;--border: #1e2040;--border-bright: #2a2d55;--danger: #ff4466;--toolbar-h: 48px;--statusbar-h: 28px;--sidebar-w: 280px;--radius: 6px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Outfit,sans-serif;background:var(--bg-primary);color:var(--text-primary);overflow:hidden;height:100vh;width:100vw;-webkit-user-select:none;user-select:none}#app{display:flex;flex-direction:column;height:100vh}.toolbar{height:var(--toolbar-h);background:var(--bg-secondary);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 12px;gap:6px;flex-shrink:0;z-index:3000}.tool-group{display:flex;align-items:center;gap:4px}.toolbar-sep{width:1px;height:28px;background:var(--border-bright);margin:0 8px}.tool-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;width:42px;height:36px;background:transparent;border:1px solid transparent;border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;transition:all .15s ease;position:relative;font-family:Outfit,sans-serif}.tool-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--border-bright)}.tool-btn.active{background:var(--accent-dim);color:var(--accent);border-color:var(--accent);box-shadow:0 0 12px var(--accent-glow),inset 0 0 8px #00d4ff0d}.tool-icon{font-size:16px;line-height:1}.tool-label{font-size:9px;font-weight:500;letter-spacing:.5px;margin-top:1px;opacity:.6}.tool-btn.active .tool-label{opacity:1}.tool-btn-container{display:flex;flex-direction:column;align-items:center;position:relative}.tool-mode-indicator{position:absolute;top:100%;left:50%;transform:translate(-50%);background:var(--bg-elevated);border:1px solid var(--border-bright);border-radius:var(--radius);padding:6px 8px;font-size:10px;color:var(--text-secondary);white-space:nowrap;pointer-events:auto;z-index:20;margin-top:4px;box-shadow:0 4px 12px #0006;display:flex;flex-direction:column;gap:2px}.tool-mode-indicator .mode-line{display:block;padding:4px 8px;border-radius:3px;cursor:pointer;transition:all .1s;-webkit-user-select:none;user-select:none}.tool-mode-indicator .mode-line:hover{background:var(--bg-hover);color:var(--text-primary)}.tool-mode-indicator .mode-line.active{background:var(--accent-dim);color:var(--accent);font-weight:600;border:1px solid var(--accent)}.tool-mode-indicator .mode-title{font-weight:700;color:var(--text-dim);padding:2px 8px;margin-bottom:2px;border-bottom:1px solid var(--border);font-size:9px;text-transform:uppercase}.icon-btn{width:30px;height:28px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;font-size:14px;font-family:Outfit,sans-serif;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.icon-btn:hover{background:var(--bg-hover);color:var(--accent);border-color:var(--accent)}.control-label{font-size:12px;color:var(--text-secondary);font-weight:500;margin-right:6px}.grid-input{width:80px;height:28px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-family:JetBrains Mono,monospace;font-size:12px;padding:0 8px;outline:none;transition:border-color .15s}.grid-input:focus{border-color:var(--accent);box-shadow:0 0 6px var(--accent-glow)}.unit-label{font-size:11px;color:var(--text-dim);margin-left:4px;font-family:JetBrains Mono,monospace}.zoom-label{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--text-secondary);min-width:50px;text-align:center}#main-content{display:flex;flex:1;overflow:hidden}#canvas-container{flex:1;position:relative;overflow:hidden;background:var(--bg-primary)}#canvas{display:block;width:100%;height:100%}.sidebar{width:var(--sidebar-w);background:var(--bg-secondary);border-left:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px 10px;border-bottom:1px solid var(--border)}.sidebar-title{font-size:14px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--text-secondary)}.add-layer-btn{width:26px;height:26px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--accent);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.add-layer-btn:hover{background:var(--accent-dim);border-color:var(--accent)}.layer-list{max-height:300px;overflow-y:auto;border-bottom:1px solid var(--border)}.layer-item{display:flex;align-items:center;padding:8px 12px;gap:8px;cursor:pointer;transition:background .1s;border-left:3px solid transparent}.layer-item:hover{background:var(--bg-hover)}.layer-item.active{background:var(--accent-dim);border-left-color:var(--accent)}.vis-btn{width:22px;height:22px;background:transparent;border:none;cursor:pointer;font-size:13px;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;border-radius:3px;transition:all .1s;flex-shrink:0}.vis-btn:hover{background:var(--bg-surface)}.vis-btn.off{opacity:.3;font-size:18px}.layer-swatch{width:14px;height:14px;border-radius:3px;flex-shrink:0;border:1px solid rgba(255,255,255,.1)}.layer-name{font-size:13px;font-weight:500;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lock-btn{width:22px;height:22px;background:transparent;border:none;cursor:pointer;font-size:11px;color:var(--text-dim);display:flex;align-items:center;justify-content:center;border-radius:3px;transition:all .1s;flex-shrink:0}.lock-btn:hover{background:var(--bg-surface)}.lock-btn.locked{color:var(--danger)}.del-layer-btn{width:20px;height:20px;background:transparent;border:none;cursor:pointer;font-size:14px;color:var(--text-dim);display:flex;align-items:center;justify-content:center;border-radius:3px;opacity:0;transition:all .1s;flex-shrink:0}.layer-item:hover .del-layer-btn{opacity:1}.del-layer-btn:hover{color:var(--danger);background:#ff44661a}.layer-properties{padding:14px 16px;flex:1}.props-title{font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--text-secondary);margin-bottom:14px}.prop-row{display:flex;align-items:center;margin-bottom:10px;gap:8px}.prop-label{font-size:12px;color:var(--text-secondary);min-width:80px;flex-shrink:0}.prop-input{flex:1;height:28px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-family:Outfit,sans-serif;font-size:12px;padding:0 8px;outline:none;transition:border-color .15s}.prop-input:focus{border-color:var(--accent)}.prop-input.small{width:60px;flex:0}.prop-color{width:40px;height:28px;padding:2px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color .15s}.prop-color:hover{border-color:var(--accent)}.prop-select{width:fit-content;min-width:130px;max-width:300px;height:28px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-family:JetBrains Mono,Consolas,monospace;font-size:11px;padding:0 8px;outline:none;cursor:pointer;transition:all .15s}.prop-select:focus{border-color:var(--accent)}.prop-select option{background:var(--bg-secondary);color:var(--text-primary)}.statusbar{height:var(--statusbar-h);background:var(--bg-secondary);border-top:1px solid var(--border);display:flex;align-items:center;padding:0 16px;gap:24px;flex-shrink:0}.status-item{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--text-secondary)}.coord-display{color:var(--accent);font-weight:500;min-width:260px}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-bright);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}:focus-visible{outline:1px solid var(--accent);outline-offset:2px}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-webkit-appearance:textfield;appearance:textfield;-moz-appearance:textfield}.context-menu{position:fixed;z-index:1000;background:var(--bg-elevated);border:1px solid var(--border-bright);border-radius:var(--radius);padding:10px 14px;box-shadow:0 8px 32px #00000080,0 0 16px #00d4ff0f;min-width:260px;max-width:600px;width:fit-content;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.context-menu-title{font-size:12px;font-weight:600;color:var(--accent);letter-spacing:.3px;margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border);cursor:move;-webkit-user-select:none;user-select:none}.layer-item.dragging{opacity:.5;background:var(--bg-hover)!important}.layer-item.drag-over{border-top:2px solid var(--accent)!important}.context-menu-row{display:flex;align-items:center;gap:10px;margin-bottom:8px;width:100%}.context-label{font-size:12px;color:var(--text-secondary);min-width:70px;flex-shrink:0}.context-input{width:70px;height:26px;background:var(--bg-surface);border:1px solid var(--border);border-radius:4px;color:var(--text-primary);font-family:JetBrains Mono,monospace;font-size:11px;padding:0 6px;outline:none;transition:border-color .15s}.context-input:focus{border-color:var(--accent)}.context-sep{color:var(--text-dim);font-size:12px}.context-apply-btn,.context-clear-btn,.context-use-btn,.context-delete-btn{height:28px;border:1px solid var(--border);border-radius:4px;font-family:Outfit,sans-serif;font-size:12px;font-weight:500;cursor:pointer;padding:0 14px;transition:all .15s}.context-use-btn{background:var(--bg-surface);color:var(--text-secondary)}.context-use-btn:hover{background:var(--bg-hover);color:var(--accent);border-color:var(--accent)}.context-apply-btn{background:var(--accent-dim);color:var(--accent);border-color:var(--accent)}.context-apply-btn:hover{background:#00d4ff40;box-shadow:0 0 8px var(--accent-glow)}.context-clear-btn{background:transparent;color:var(--text-secondary)}.context-clear-btn:hover{color:var(--danger);border-color:var(--danger);background:#ff44661a}.context-highlight-gold{border:1px solid #FFD700!important;box-shadow:0 0 4px #ffd70033}.context-highlight-gold:hover{background:#ffd7001a!important;box-shadow:0 0 8px #ffd70066!important}.active-alignment{background:#ff880026!important;color:#f80!important;border-color:#f80!important;box-shadow:0 0 10px #f803}.snap-label{font-size:11px;margin-left:2px}.snap-status{color:#f80;font-weight:600;letter-spacing:.5px}.dim-title{margin-top:16px;padding-top:12px;border-top:1px solid var(--border)}.context-menu-info{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--text-secondary);padding:4px 0}.context-menu-sep{height:1px;background:var(--border);margin:8px 0}.context-menu-subtitle{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);margin-bottom:8px}.context-menu-btnrow{display:flex;gap:6px;margin-top:8px}.context-action-row{display:flex;gap:8px;margin-top:12px}.context-action-row button{flex:1}.context-delete-btn{height:28px;background:transparent;border:1px solid var(--border);border-radius:4px;color:var(--text-dim);font-family:Outfit,sans-serif;font-size:12px;font-weight:500;cursor:pointer;padding:0 14px;transition:all .15s}.context-delete-btn:hover{color:var(--danger);border-color:var(--danger);background:#ff44661a}.context-menu-item{font-size:11px;color:var(--text-secondary);padding:6px 8px;cursor:pointer;border-radius:4px;transition:all .1s}.context-menu-item:hover{background:var(--bg-hover);color:var(--accent)}.context-menu-item.context-delete:hover{color:var(--danger);background:#ff44661a}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000}.modal-content{background:var(--bg-elevated);border:1px solid var(--border-bright);border-radius:8px;padding:20px;width:320px;box-shadow:0 16px 48px #0009}.modal-content h3{font-size:14px;color:var(--accent);margin-bottom:16px;text-align:center}.modal-btn-row{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.btn-primary,.btn-secondary{height:32px;padding:0 16px;border-radius:4px;font-family:Outfit,sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background:var(--accent);color:var(--bg-primary);border:none}.btn-primary:hover{filter:brightness(1.1);box-shadow:0 0 15px var(--accent-glow)}.btn-secondary{background:transparent;border:1px solid var(--border-bright);color:var(--text-secondary)}.btn-secondary:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-item-btn{width:100%;height:36px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);font-family:Outfit,sans-serif;font-size:13px;cursor:pointer;padding:0 12px;text-align:left;transition:all .15s;display:flex;align-items:center}.modal-item-btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--accent)}.modal-item-btn:focus{outline:none;border-color:var(--accent);box-shadow:0 0 6px var(--accent-glow)}.lang-select{height:28px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-primary);font-family:Outfit,sans-serif;font-size:12px;padding:0 8px;cursor:pointer;outline:none;transition:border-color .15s;-moz-appearance:none;appearance:none;-webkit-appearance:none;min-width:90px}.lang-select:hover{border-color:var(--accent)}.lang-select:focus{border-color:var(--accent);box-shadow:0 0 6px var(--accent-glow)}.lang-select option{background:var(--bg-secondary);color:var(--text-primary)}.context-confirm-btn{display:block;width:100%;height:32px;background:linear-gradient(135deg,#00b45033,#00dc6426);border:1px solid rgba(0,200,90,.5);border-radius:4px;color:#0d6;font-family:Outfit,sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;letter-spacing:.5px}.context-confirm-btn:hover{background:linear-gradient(135deg,#00b45059,#00dc644d);box-shadow:0 0 12px #00dc6440;border-color:#0d6}.context-confirm-btn:active{transform:scale(.98)}.context-layer-select{width:100%;height:28px;background:var(--bg-surface);border:1px solid var(--border);border-radius:4px;color:var(--text-primary);font-family:Outfit,sans-serif;font-size:12px;padding:0 8px;cursor:pointer;outline:none;transition:border-color .15s}.context-layer-select:hover{border-color:var(--accent)}.layer-swatch{width:14px;height:14px;flex-shrink:0;border-radius:2px;border:1px solid rgba(255,255,255,.4);display:inline-block;vertical-align:middle;box-shadow:0 0 4px #00000080}.context-layer-select:focus{border-color:var(--accent);box-shadow:0 0 6px var(--accent-glow)}.alignment-dialog{position:fixed;top:64px;left:50%;transform:translate(-50%);background:var(--bg-elevated);border:1px solid var(--border-bright);border-radius:8px;padding:16px;box-shadow:0 12px 48px #0009,0 0 20px var(--accent-glow);z-index:1000;min-width:320px;display:flex;flex-direction:column;gap:16px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);animation:slideDown .2s cubic-bezier(.16,1,.3,1)}@keyframes slideDown{0%{transform:translate(-50%,-10px);opacity:0}to{transform:translate(-50%);opacity:1}}.alignment-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);padding-bottom:10px}.alignment-title{font-size:14px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:1px}.alignment-close{background:transparent;border:none;color:var(--text-dim);cursor:pointer;font-size:18px;transition:color .15s}.alignment-close:hover{color:var(--danger)}.alignment-section{display:flex;flex-direction:column;gap:10px}.alignment-section-title{font-size:11px;font-weight:600;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px}.alignment-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}.alignment-btn{width:100%;aspect-ratio:1;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;position:relative}.alignment-btn svg{width:20px;height:20px;stroke:currentColor;stroke-width:1.5}.alignment-btn:hover{background:var(--bg-hover);color:var(--accent);border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.alignment-btn:active{transform:translateY(0)}.alignment-btn.active{background:var(--accent-dim);color:var(--accent);border-color:var(--accent)}.alignment-status{background:#ff88001a;border:1px dashed #ff8800;border-radius:4px;padding:8px 12px;font-size:12px;color:#f80;font-weight:500;display:flex;align-items:center;gap:8px}.alignment-status.success{background:#00ff881a;border-color:#0f8;color:#0f8}.picking-pulse{animation:pulseCyan 1.5s infinite}@keyframes pulseCyan{0%{box-shadow:0 0 #00d4ff66}70%{box-shadow:0 0 10px 10px #00d4ff00}to{box-shadow:0 0 #00d4ff00}}.distribution-controls{display:flex;align-items:center;gap:12px;margin-top:4px}.dist-mode-btn{flex:1;height:32px;background:var(--bg-surface);border:1px solid var(--border);border-radius:4px;font-size:11px;color:var(--text-secondary);cursor:pointer;transition:all .15s}.dist-mode-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.dist-mode-btn.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent);font-weight:600}
