*{margin:0;box-sizing:border-box}body{font-family:sans-serif;height:100vh}#root{display:flex;height:100vh}#canvas-wrap{position:relative;flex:1;min-height:0;min-width:0;overflow:hidden}#canvas-wrap canvas{width:100%;height:100%;outline:none}.inline-edit{position:absolute;transform:translate(-50%,-50%);text-align:center;background:transparent;border:none;outline:none;resize:none;overflow:hidden;padding:2px 4px;margin:0;color:#000;line-height:1.2;z-index:10;white-space:pre}#toolpanel{order:1;flex-shrink:0;background:#f5f5f5;padding:8px 6px;display:flex;flex-direction:column;align-items:stretch;gap:0;font-size:11px;color:#444;overflow-y:auto;border-left:1px solid #ddd;user-select:none;-webkit-user-select:none}.tp-section{display:flex;flex-direction:column;gap:1px}.tp-label{font-size:8px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#999;padding:0 4px;text-align:left;margin-top:2px;margin-bottom:4px}.tp-row{display:flex;flex-direction:row-reverse;align-items:center;justify-content:space-between;gap:6px;padding:2px 4px;border-radius:3px;line-height:1.3;white-space:nowrap}.tp-row.clickable{cursor:pointer}.tp-row.clickable:hover{background:#00000012;color:#111}#root[data-mode=draw-box] .tp-row[data-mode=draw-box],#root[data-mode=draw-text] .tp-row[data-mode=draw-text],#root[data-mode=draw-line] .tp-row[data-mode=draw-line],#root[data-mode=draw-grid] .tp-row[data-mode=draw-grid],#root[data-mode=draw-arrow] .tp-row[data-mode=draw-arrow]{background:#4a90d91f;color:#2a6bb5}.tp-key{font-family:monospace;font-weight:700;color:#999;font-size:10px;flex-shrink:0}.tp-icon-label{display:inline-flex;align-items:center;gap:6px;vertical-align:middle}.tp-icon{width:13px;height:13px;flex-shrink:0;display:block;margin-top:-1px}.tp-sep{border-top:1px solid #ddd;align-self:stretch;margin:4px 0}.tp-cols{display:flex;gap:16px}.tp-col{display:flex;flex-direction:column;gap:1px;flex:1}.tp-section.disabled,.tp-row.row-disabled{opacity:.3;pointer-events:none}.tp-colors{display:flex;gap:3px;padding:2px 0;justify-content:start}.tp-color{width:20px;height:20px;border-radius:3px;cursor:pointer;border:1px solid rgba(0,0,0,.15);font-size:9px;text-align:center;line-height:20px;font-weight:700}.tp-color:hover{border-color:#0006}.tp-align-btn{padding:2px 5px;border-radius:3px;border:1px solid #ccc;background:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;color:#555}.tp-align-btn:hover{background:#e8e8e8}.panel-collapse-btn{display:flex;align-items:center;justify-content:center;padding:4px;border:none;background:none;cursor:pointer;color:#999;align-self:flex-end;border-radius:4px}.panel-collapse-btn:hover{background:#00000012;color:#555}.panel-expand-btn{display:flex;align-items:center;justify-content:center;width:24px;flex-shrink:0;border:none;cursor:pointer;color:#999;background:#f5f5f5}.panel-expand-btn:hover{background:#e8e8e8;color:#555}.panel-expand-left{border-right:1px solid #ddd}.panel-expand-right{order:1;border-left:1px solid #ddd}#chat{width:360px;flex-shrink:0;height:100%;border-right:1px solid #ccc;display:flex;flex-direction:column}#chat-header{display:flex;align-items:center;min-height:34px;padding:4px 8px;border-bottom:1px solid #eee;justify-content:space-between;font-weight:600;font-size:13px;color:#333;-webkit-user-select:none;user-select:none}.chat-header-btn{font-size:11px;padding:2px 8px;border:1px solid #ddd;border-radius:4px;background:#fff;cursor:pointer;color:#666}.chat-header-btn:hover{background:#f0f0f0}.chat-messages{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:10px}.chat-user{align-self:flex-end;background:#333;color:#fff;padding:8px 12px;border-radius:12px 12px 2px;max-width:85%;white-space:pre-wrap;word-break:break-word;font-size:13px;line-height:1.4}.chat-user-img{max-width:200px;max-height:150px;border-radius:8px;display:block;margin-bottom:6px}.chat-ai{align-self:flex-start;max-width:95%;display:flex;flex-direction:column;gap:6px}.chat-ai-text{color:#333;font-size:13px;line-height:1.5;word-break:break-word}.chat-lof-pill{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:12px;border:1px solid #ccc;background:#f5f5f5;cursor:pointer;font-size:11px;color:#555;transition:all .15s}.chat-lof-pill:hover{border-color:#aaa}.chat-lof-pill.active{border-color:#4a90d9;background:#e8f0fe;color:#4a90d9;font-weight:600}.chat-lof-pill.invalid{border-color:#ddd;background:#fafafa;cursor:default;opacity:.5;color:#999}.chat-error{background:#fef2f2;color:#b91c1c;font-size:12px;padding:6px 10px;border-radius:6px;border:1px solid #fecaca}.chat-thinking{color:#999;font-size:12px;font-style:italic;padding:4px 0}.chat-retry{align-self:flex-end;max-width:85%;font-size:11px;color:#999}.chat-retry summary{cursor:pointer}.chat-retry pre{white-space:pre-wrap;margin:4px 0 0;font-size:11px;color:#999}.chat-input-area{border-top:1px solid #eee;padding:8px}.chat-input-wrap{display:flex;flex-direction:column;gap:6px}.chat-input-row{display:flex;gap:6px}.chat-attach-btn{padding:0 6px;border:1px solid #ddd;border-radius:6px;background:#fff;color:#999;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.chat-attach-btn:hover{border-color:#aaa;color:#666}.chat-textarea{flex:1;resize:none;border:1px solid #ddd;border-radius:6px;padding:8px;font-size:13px;font-family:inherit;outline:none;line-height:1.4;min-height:36px;max-height:100px}.chat-textarea:focus{border-color:#aaa}.chat-send-btn{padding:0 12px;border:none;border-radius:6px;background:#333;color:#fff;cursor:pointer;font-size:13px;font-weight:500;align-self:stretch}.chat-send-btn:hover{background:#222}.chat-limit{font-size:12px;color:#999;padding:8px;text-align:center}.chat-pending-img{position:relative;align-self:flex-start}.chat-pending-img img{max-width:120px;max-height:80px;border-radius:6px;border:1px solid #ddd}.chat-pending-img-close{position:absolute;top:-6px;right:-6px;width:18px;height:18px;border-radius:50%;border:none;background:#666;color:#fff;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:1}#chat p{margin:0 0 .4em}#chat p:last-child{margin-bottom:0}#chat ul{margin-top:.4em;margin-bottom:.6em;padding-left:1.2em}#chat h1,#chat h2,#chat h3,#chat h4{font-size:13px;font-weight:600;margin:.6em 0 .3em}#chat h1:first-child,#chat h2:first-child,#chat h3:first-child{margin-top:0}#chat code{font-size:12px;background:#f0f0f0;padding:1px 4px;border-radius:3px}#chat strong{font-weight:600}
