*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.app{position:relative;width:100vw;height:100vh;background:#f5f5f5}.canvas-host{position:absolute;top:0;right:0;bottom:0;left:0}.canvas-host canvas{display:block;outline:none}.toolbar{position:absolute;top:12px;left:12px;display:flex;gap:8px;padding:8px;background:#ffffffeb;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 8px #00000014;z-index:10;-webkit-user-select:none;user-select:none}.toolbar button{padding:6px 12px;border:1px solid #ccc;background:#fff;border-radius:6px;cursor:pointer;font-size:13px}.toolbar button.active{background:#2b7fff;color:#fff;border-color:#2b7fff}.hint{position:absolute;bottom:12px;left:12px;padding:6px 10px;background:#000000b3;color:#fff;font-size:12px;border-radius:6px;z-index:10;pointer-events:none}.properties-panel{position:absolute;top:12px;right:12px;width:220px;padding:12px;background:#fffffff5;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 8px #00000014;z-index:10;display:flex;flex-direction:column;gap:10px;font-size:13px}.properties-header{font-weight:600;font-size:14px;color:#333;border-bottom:1px solid #eee;padding-bottom:6px}.field{display:flex;flex-direction:column;gap:4px}.field span{font-size:12px;color:#666}.field input{padding:6px 8px;border:1px solid #ccc;border-radius:4px;font-size:13px;font-family:inherit;transition:border-color .15s}.field input:focus{outline:none;border-color:#2b7fff}.field input.error{border-color:#dc2626;background:#fee2e2}.properties-panel button.danger{padding:6px 10px;background:#fff;border:1px solid #dc2626;color:#dc2626;border-radius:6px;cursor:pointer;font-size:13px;font-family:inherit}.properties-panel button.danger:hover{background:#dc2626;color:#fff}.project-bar{position:absolute;top:12px;left:50%;transform:translate(-50%);display:flex;gap:6px;align-items:center;padding:6px 8px;background:#fffffff5;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 8px #00000014;z-index:11;font-size:13px}.project-bar input.project-name{padding:6px 10px;border:1px solid #ccc;border-radius:6px;font-size:13px;font-family:inherit;width:200px}.project-bar input.project-name:disabled{background:#f5f5f5;color:#999}.project-bar button{padding:6px 10px;border:1px solid #ccc;background:#fff;border-radius:6px;cursor:pointer;font-size:13px;font-family:inherit}.project-bar button:hover{background:#f5f5f5}.save-status{font-size:12px;color:#6b7280;margin-left:4px;min-width:90px;transition:color .2s}.save-status.save-saving{color:#6b7280}.save-status.save-saved{color:#059669}.save-status.save-error{color:#dc2626}.project-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;min-width:280px;max-height:320px;overflow-y:auto;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 8px 24px #0000001f;z-index:20;padding:4px}.dropdown-empty{padding:12px;text-align:center;color:#6b7280;font-size:12px}.dropdown-item{display:flex;align-items:stretch;gap:2px;border-radius:4px}.dropdown-item:hover{background:#f5f5f5}.dropdown-item.active{background:#eff6ff}.dropdown-load{flex:1;display:flex;flex-direction:column;gap:2px;align-items:flex-start;padding:8px 10px;background:transparent;border:none;cursor:pointer;font-family:inherit;text-align:left}.dropdown-name{font-size:13px;color:#111827}.dropdown-ts{font-size:11px;color:#9ca3af}.dropdown-delete{padding:0 10px;background:transparent;border:none;color:#9ca3af;font-size:18px;cursor:pointer;font-family:inherit;line-height:1}.dropdown-delete:hover{color:#dc2626}
