*{box-sizing:border-box;margin:0;padding:0}body{background:#fff;overflow:hidden}canvas{touch-action:none;width:100vw;height:100vh;display:block}#toolbar{z-index:10;background:#fff;border:1px solid #ddd;border-radius:10px;gap:6px;padding:6px;display:flex;position:fixed;top:16px;left:50%;transform:translate(-50%);box-shadow:0 2px 8px #0000001f}.tool-btn{cursor:pointer;background:0 0;border:2px solid #0000;border-radius:7px;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;transition:background .15s;display:flex}.tool-btn:hover{background:#f0f0f0}.tool-btn.active{background:#f0f0f0;border-color:#555}.tool-btn-delete:hover{background:#fee2e2}#component-library{z-index:10;background:#fff;border:1px solid #ddd;border-radius:10px;flex-direction:column;gap:8px;width:220px;max-height:70vh;padding:8px;display:flex;position:fixed;top:50%;right:16px;overflow-y:auto;transform:translateY(-50%);box-shadow:0 2px 8px #0000001f}.lib-header{color:#555;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #eee;flex-shrink:0;padding-bottom:4px;font-size:11px;font-weight:600}.lib-empty{color:#aaa;text-align:center;padding:8px 4px;font-size:11px;line-height:1.5}.lib-grid{grid-template-columns:1fr 1fr;gap:6px;display:grid}.lib-item{cursor:pointer;border:1px solid #eee;border-radius:6px;flex-direction:column;transition:border-color .12s,box-shadow .12s;display:flex;overflow:hidden}.lib-item:hover{border-color:#aaa;box-shadow:0 1px 4px #0000001a}.lib-thumb{aspect-ratio:1;background:#f8f8f8;justify-content:center;align-items:center;width:100%;display:flex}.lib-thumb img{object-fit:contain;width:100%;height:100%}.lib-thumb-empty{color:#ccc;font-size:22px}.lib-item-footer{background:#fff;border-top:1px solid #eee;align-items:center;gap:4px;padding:3px 5px;display:flex}.lib-name{color:#444;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:11px;overflow:hidden}.lib-delete{cursor:pointer;color:#bbb;background:0 0;border:none;flex-shrink:0;padding:0;font-size:14px;line-height:1}.lib-delete:hover{color:#e55}.selection-toolbar{z-index:20;pointer-events:auto;background:#fff;border:1px solid #ddd;border-radius:8px;gap:4px;padding:4px;display:flex;position:fixed;transform:translate(-50%);box-shadow:0 2px 8px #00000026}.toolbar-sep{background:#ddd;width:1px;height:28px;margin:0 2px}#options{z-index:10;position:fixed;top:50%;left:16px;transform:translateY(-50%)}.opt-panel[hidden]{display:none}.opt-panel{background:#fff;border:1px solid #ddd;border-radius:10px;flex-direction:column;align-items:center;gap:6px;padding:10px 8px;display:flex;box-shadow:0 2px 8px #0000001f}.opt-label{color:#999;text-transform:uppercase;letter-spacing:.05em;-webkit-user-select:none;user-select:none;font-size:10px}.opt-sep{background:#eee;width:100%;height:1px;margin:2px 0}.size-group{flex-direction:column;align-items:center;gap:2px;display:flex}.size-btn{cursor:pointer;background:0 0;border:2px solid #0000;border-radius:7px;justify-content:center;align-items:center;width:36px;height:36px;transition:background .15s;display:flex}.size-btn:hover{background:#f0f0f0}.size-btn.active{background:#f0f0f0;border-color:#555}.size-btn span{width:var(--s);height:var(--s);background:#222;border-radius:50%;display:block}.color-group{flex-direction:column;align-items:center;gap:5px;display:flex}.color-btn{background-color:var(--c);cursor:pointer;border:2px solid #0000;border-radius:50%;outline:none;width:22px;height:22px;transition:transform .1s;box-shadow:0 0 0 1px #ccc}.color-btn:hover{transform:scale(1.15)}.color-btn.active{box-shadow:0 0 0 2px #fff,0 0 0 4px #555}
