.board-switcher{position:relative}.board-switcher-btn{display:flex;align-items:center;gap:6px;background:var(--color-hover);border:1px solid var(--color-border);border-radius:7px;padding:5px 10px;cursor:default;font-size:14px;font-weight:500;color:var(--color-text);transition:background .1s;max-width:220px}.board-switcher-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:text;border-radius:4px;padding:1px 3px;transition:background .1s}.board-switcher-title:hover{background:var(--color-border)}.board-switcher-chevron{font-size:10px;color:var(--color-text-muted);flex-shrink:0;cursor:pointer;padding:2px 4px;border-radius:4px;transition:background .1s}.board-switcher-chevron:hover{background:var(--color-border)}.board-active-rename{border:1px solid var(--color-accent);border-radius:7px;padding:5px 10px;font-size:14px;font-weight:500;color:var(--color-text);background:var(--color-card-bg);outline:none;min-width:140px;max-width:220px}.board-switcher-dropdown{position:absolute;top:calc(100% + 6px);left:0;min-width:200px;background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:10px;box-shadow:0 8px 24px #0000001f;z-index:1000;overflow:hidden;display:flex;flex-direction:column}.board-switcher-item{display:flex;align-items:center;padding:8px 12px;gap:8px;transition:background .1s}.board-switcher-item:hover{background:var(--color-hover)}.board-switcher-item.active{background:#0d948814}.board-item-title{flex:1;font-size:14px;color:var(--color-text);cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.board-rename-input{flex:1;border:1px solid var(--color-accent);border-radius:4px;padding:2px 6px;font-size:14px;color:var(--color-text);background:var(--color-card-bg);outline:none}.board-item-delete{background:none;border:none;cursor:pointer;padding:2px 5px;border-radius:4px;color:var(--color-text-muted);font-size:12px;opacity:0;transition:opacity .1s,background .1s}.board-switcher-item:hover .board-item-delete{opacity:1}.board-item-delete:hover{background:#fee2e2;color:#dc2626}.board-new-btn{padding:10px 12px;background:none;border:none;border-top:1px solid var(--color-border);cursor:pointer;font-size:13px;color:var(--color-accent);font-weight:500;text-align:left;transition:background .1s}.board-new-btn:hover{background:var(--color-hover)}.snapshot-bar{display:flex;align-items:center;gap:4px;flex-shrink:0}.snapshot-label{font-size:14px;margin-right:2px;flex-shrink:0}.snapshot-pill-wrap{display:flex;align-items:center;position:relative}.snapshot-pill{font-size:12px;padding:3px 10px;border-radius:999px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);cursor:pointer;white-space:nowrap;transition:background .1s,border-color .1s}.snapshot-pill:hover{border-color:var(--color-accent);background:var(--color-hover)}.snapshot-delete{display:none;position:absolute;right:-4px;top:-4px;width:16px;height:16px;border-radius:50%;border:none;background:var(--color-border);color:var(--color-text);font-size:11px;line-height:1;cursor:pointer;padding:0;align-items:center;justify-content:center}.snapshot-pill-wrap:hover .snapshot-delete{display:flex}.snapshot-delete:hover{background:#dc2626;color:#fff}.snapshot-edit-input{font-size:12px;padding:2px 8px;border:1px solid var(--color-accent);border-radius:999px;outline:none;width:100px;color:var(--color-text);background:var(--color-card-bg);font-family:inherit}.snapshot-add-btn{font-size:11px;padding:3px 8px;border-radius:999px;border:1px dashed var(--color-border);background:none;color:var(--color-text-muted);cursor:pointer;white-space:nowrap;transition:border-color .1s,color .1s}.snapshot-add-btn:hover{border-color:var(--color-accent);color:var(--color-accent)}.snapshot-add-input{font-size:11px;padding:2px 8px;border:1px solid var(--color-accent);border-radius:999px;outline:none;width:90px;color:var(--color-text);background:var(--color-card-bg);font-family:inherit}.toolbar{position:fixed;top:0;left:0;right:0;height:48px;background:var(--color-card-bg);border-bottom:1px solid var(--color-border);display:flex;align-items:center;gap:8px;padding:0 12px;z-index:500;box-shadow:0 1px 4px var(--color-shadow)}.toolbar-sep{width:1px;height:24px;background:var(--color-border);flex-shrink:0}.toolbar-spacer{flex:1}.toolbar-btn{display:flex;align-items:center;gap:5px;background:none;border:1px solid var(--color-border);border-radius:7px;padding:5px 10px;cursor:pointer;font-size:13px;color:var(--color-text);transition:background .1s,border-color .1s;white-space:nowrap}.toolbar-btn:hover{background:var(--color-hover)}.toolbar-btn:disabled{opacity:.35;cursor:not-allowed}.toolbar-btn.primary{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.toolbar-btn.primary:hover{opacity:.88;background:var(--color-accent)}.toolbar-btn-icon{font-size:15px}.toolbar-btn-project{border-style:dashed}.toolbar-btn.active{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.toolbar-menu-wrap{position:relative}.toolbar-hamburger{padding:5px 7px}.toolbar-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:600}.toolbar-menu{position:absolute;top:calc(100% + 6px);right:0;z-index:601;background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:10px;padding:4px;box-shadow:0 4px 20px var(--color-shadow-hover);min-width:180px}.toolbar-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;border-radius:7px;background:none;color:var(--color-text);font-size:13px;font-family:inherit;cursor:pointer;text-align:left;transition:background .1s}.toolbar-menu-item:hover{background:var(--color-hover)}.toolbar-menu-item:disabled{opacity:.35;cursor:not-allowed}.toolbar-menu-sep{height:1px;background:var(--color-border);margin:4px 8px}.logo{display:flex;align-items:center;flex-shrink:0}.tag-filter-bar{position:fixed;top:48px;left:0;right:0;height:36px;background:var(--color-card-bg);border-bottom:1px solid var(--color-border);display:flex;align-items:center;gap:6px;padding:0 14px;z-index:499;overflow-x:auto;scrollbar-width:none}.tag-filter-bar::-webkit-scrollbar{display:none}.tag-filter-label{font-size:11px;color:var(--color-text-muted);flex-shrink:0;margin-right:2px}.tag-filter-pill{display:inline-flex;align-items:center;gap:3px;font-size:12px;padding:3px 10px;border-radius:999px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .1s,border-color .1s,color .1s}.tag-filter-pill:hover{border-color:var(--color-accent);color:var(--color-accent)}.tag-filter-pill.active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.tag-filter-clear{font-size:14px;line-height:1;margin-left:1px}.tag-filter-reset{font-size:11px;padding:3px 8px;border-radius:5px;border:none;background:none;color:var(--color-text-muted);cursor:pointer;margin-left:4px;flex-shrink:0;transition:color .1s}.tag-filter-reset:hover{color:var(--color-text)}.card-editor{width:100%;border:none;border-radius:4px;background:#0000000d;padding:2px 4px;font-family:inherit;font-size:13px;color:var(--color-text);resize:none;overflow:hidden;outline:2px solid var(--color-accent);box-sizing:border-box;line-height:1.5}.card-editor-title{font-size:14px;font-weight:600}.card-editor-body{color:var(--color-text-muted)}.card-comments{padding:4px 10px 10px}.card-comments-toggle{width:100%;display:flex;align-items:center;gap:6px;background:none;border:none;padding:4px 0;cursor:pointer;font-size:12px;color:var(--color-text-muted);text-align:left;border-radius:4px;transition:color .1s}.card-comments-toggle:hover{color:var(--color-text)}.comments-icon{font-size:13px}.comments-chevron{margin-left:auto;font-size:10px}.card-comments-body{margin-top:6px;display:flex;flex-direction:column;gap:6px}.comment-item{background:var(--color-surface);border-radius:6px;padding:6px 8px;font-size:12px}.comment-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:3px}.comment-ts{color:var(--color-text-muted);font-size:11px}.comment-item-actions{display:none;gap:2px}.comment-item:hover .comment-item-actions{display:flex}.comment-action-btn{background:none;border:none;cursor:pointer;padding:2px 4px;border-radius:3px;font-size:11px;color:var(--color-text-muted);transition:background .1s}.comment-action-btn:hover{background:var(--color-hover)}.comment-action-btn.danger:hover{background:#fee2e2;color:#dc2626}.comment-text{color:var(--color-text);line-height:1.4;word-break:break-word}.comment-text a{color:var(--color-accent);text-decoration:underline}.comment-edit-input{width:100%;border:1px solid var(--color-accent);border-radius:4px;padding:3px 5px;font-size:12px;font-family:inherit;color:var(--color-text);background:var(--color-card-bg);resize:none;overflow:hidden;outline:none;box-sizing:border-box}.comment-add{display:flex;flex-direction:column;gap:4px}.comment-add-input{width:100%;border:1px solid var(--color-border);border-radius:6px;padding:5px 8px;font-size:12px;font-family:inherit;color:var(--color-text);background:var(--color-surface);resize:none;overflow:hidden;outline:none;box-sizing:border-box;transition:border-color .15s}.comment-add-input:focus{border-color:var(--color-accent)}.comment-add-btn{align-self:flex-end;background:var(--color-accent);color:#fff;border:none;border-radius:5px;padding:4px 12px;font-size:12px;cursor:pointer;transition:opacity .1s}.comment-add-btn:hover{opacity:.85}.card-todos{padding:4px 10px 6px}.card-todos-toggle{width:100%;display:flex;align-items:center;gap:6px;background:none;border:none;padding:4px 0;cursor:pointer;font-size:12px;color:var(--color-text-muted);text-align:left;border-radius:4px;transition:color .1s}.card-todos-toggle:hover{color:var(--color-text)}.todos-icon{font-size:13px}.todos-progress{flex:1;height:4px;background:var(--color-border);border-radius:999px;overflow:hidden;margin:0 4px}.todos-progress-fill{display:block;height:100%;background:var(--color-accent);border-radius:999px;transition:width .2s}.todos-chevron{font-size:10px;flex-shrink:0}.card-todos-body{margin-top:6px;display:flex;flex-direction:column;gap:3px}.todo-item{display:flex;align-items:center;gap:6px;padding:3px 4px;border-radius:5px;transition:background .1s}.todo-item:hover{background:var(--color-hover)}.todo-checkbox{flex-shrink:0;width:14px;height:14px;cursor:pointer;accent-color:var(--color-accent)}.todo-text{flex:1;font-size:13px;color:var(--color-text);word-break:break-word;line-height:1.4;cursor:default}.todo-item.done .todo-text{text-decoration:line-through;color:var(--color-text-muted)}.todo-edit-input{flex:1;border:1px solid var(--color-accent);border-radius:4px;padding:1px 5px;font-size:13px;font-family:inherit;color:var(--color-text);background:var(--color-card-bg);outline:none}.todo-delete-btn{display:none;background:none;border:none;cursor:pointer;padding:1px 4px;border-radius:3px;font-size:11px;color:var(--color-text-muted);line-height:1;flex-shrink:0}.todo-item:hover .todo-delete-btn{display:block}.todo-delete-btn:hover{background:#fee2e2;color:#dc2626}.todo-add{margin-top:2px}.todo-add-input{width:100%;border:1px solid var(--color-border);border-radius:6px;padding:4px 8px;font-size:12px;font-family:inherit;color:var(--color-text);background:var(--color-surface);outline:none;box-sizing:border-box;transition:border-color .15s}.todo-add-input:focus{border-color:var(--color-accent)}.canvas-label{position:absolute;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;padding:4px 8px;border-radius:4px;display:flex;align-items:center;gap:4px}.canvas-label:active{cursor:grabbing}.canvas-label-text{font-size:16px;font-weight:500;color:var(--color-text);cursor:text;white-space:nowrap}.canvas-label .card-editor{min-width:150px;width:auto;font-size:16px;font-weight:500;white-space:nowrap}.canvas-label:not(.has-frame):hover{background:#0000000a}[data-theme=dark] .canvas-label:not(.has-frame):hover{background:#ffffff0f}.canvas-label-delete{opacity:0;background:none;border:none;cursor:pointer;font-size:12px;color:var(--color-text-muted);padding:1px 3px;border-radius:3px;line-height:1;transition:opacity .1s}.canvas-label:hover .canvas-label-delete{opacity:1}.canvas-label-delete:hover{background:#fee2e2;color:#dc2626}.canvas-image{position:absolute;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;border-radius:6px;overflow:hidden;box-shadow:0 2px 8px var(--color-shadow);border:2px solid transparent;transition:border-color .15s}.canvas-image:hover{border-color:var(--color-border)}.canvas-image.is-selected{outline:2px solid var(--color-accent);outline-offset:1px}.canvas-image:active{cursor:grabbing}.canvas-image-img{width:100%;height:100%;object-fit:cover;pointer-events:none;display:block}.canvas-image-delete{position:absolute;top:6px;right:6px;opacity:0;background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:50%;width:22px;height:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:12px;color:var(--color-text-muted);transition:opacity .15s}.canvas-image:hover .canvas-image-delete{opacity:1}.canvas-image-delete:hover{background:#fee2e2;color:#dc2626}.canvas-image-resize{position:absolute;bottom:0;right:0;width:18px;height:18px;cursor:nwse-resize;background:linear-gradient(135deg,transparent 50%,var(--color-border) 50%);border-radius:0 0 4px;opacity:0;transition:opacity .15s;touch-action:none}.canvas-image:hover .canvas-image-resize{opacity:1}.canvas-image-resize:hover{background:linear-gradient(135deg,transparent 50%,var(--color-accent) 50%)}.card{position:absolute;width:400px;min-height:80px;border-radius:10px;border:1.5px solid var(--color-border);background:var(--color-card-bg);box-shadow:0 2px 8px var(--color-shadow);display:flex;flex-direction:column;transition:box-shadow .15s ease;cursor:default;touch-action:none}.card.kind-group{min-height:unset;border-width:2px;border-style:dashed;overflow:visible}.section-bracket{position:absolute;pointer-events:none}.section-bracket-tl{top:-6px;left:-6px}.section-bracket-br{bottom:-6px;right:-6px}.card.kind-note.is-in-section{box-shadow:inset 0 0 0 2px #6366f126,0 2px 8px var(--color-shadow)}.card.is-selected{outline:2px solid var(--color-accent);outline-offset:1px}.section-resize-handle{position:absolute;bottom:0;right:0;width:18px;height:18px;cursor:nwse-resize;background:linear-gradient(135deg,transparent 50%,var(--color-border) 50%);border-radius:0 0 8px;touch-action:none;z-index:1}.section-resize-handle:hover{background:linear-gradient(135deg,transparent 50%,var(--color-accent) 50%)}.card:hover{box-shadow:0 4px 16px var(--color-shadow-hover)}.card.is-dragging{box-shadow:0 8px 24px #0000002e;opacity:.9}.card-header{display:flex;align-items:center;gap:6px;padding:10px 10px 6px;cursor:grab;border-radius:8px 8px 0 0}.card-header:active{cursor:grabbing}.card-drag-handle{color:var(--color-text-muted);font-size:14px;opacity:.4;flex-shrink:0;pointer-events:none}.card-title{flex:1;font-weight:600;font-size:15px;color:var(--color-text);word-break:break-word;cursor:text;min-height:22px;line-height:1.4}.card-title:empty:after{content:"Titel…";color:var(--color-text-muted);font-weight:400}.card-actions{display:none;flex-shrink:0;gap:2px;align-items:center}.card:hover .card-actions{display:flex}.card-action-btn{background:none;border:none;padding:3px 5px;border-radius:4px;cursor:pointer;color:var(--color-text-muted);font-size:13px;line-height:1;transition:background .1s,color .1s}.card-action-btn:hover{background:var(--color-hover);color:var(--color-text)}.card-action-btn.danger:hover{background:#fee2e2;color:#dc2626}.card-settings-popup{position:absolute;top:36px;right:6px;z-index:10;background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:8px;padding:8px 10px;box-shadow:0 4px 16px var(--color-shadow-hover);display:flex;flex-direction:column;gap:8px;min-width:200px}.card-settings-portal{position:fixed;top:auto;right:auto;z-index:10000}.card-settings-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999}.card-settings-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.card-settings-label{font-size:11px;color:var(--color-text-muted);flex-shrink:0;width:46px}.card-color-dots{display:flex;gap:4px}.card-project-select{flex:1;font-size:11px;font-family:inherit;padding:2px 4px;border:1px solid var(--color-border);border-radius:5px;background:var(--color-surface);color:var(--color-text);cursor:pointer;outline:none;transition:border-color .15s}.card-project-select:focus{border-color:var(--color-accent)}.card-settings-action-btn{width:100%;font-size:12px;padding:5px 8px;border-radius:6px;border:1px solid var(--color-border);background:none;color:var(--color-text);cursor:pointer;text-align:left;transition:background .1s,border-color .1s}.card-settings-action-btn:hover{background:var(--color-hover);border-color:var(--color-accent)}.section-toggle-btn{font-size:11px;padding:2px 8px;border-radius:999px;border:1px solid var(--color-border);background:none;color:var(--color-text-placeholder);cursor:pointer;transition:background .1s,border-color .1s,color .1s}.section-toggle-btn:hover{border-color:var(--color-accent);color:var(--color-accent)}.section-toggle-btn.active{background:var(--color-tag-bg);border-color:var(--color-accent);color:var(--color-accent)}.card-body-wrap{padding:0 10px 8px}.card-body{font-size:14px;color:var(--color-text-muted);word-break:break-word;line-height:1.5;min-height:16px;cursor:text}.card-body:empty:after{content:"Beschrijving toevoegen…";color:var(--color-text-placeholder);font-style:italic}.card-body a{color:var(--color-accent);text-decoration:underline}.color-dot{width:16px;height:16px;border-radius:50%;border:1.5px solid transparent;cursor:pointer;transition:transform .1s,border-color .1s}.color-dot:hover,.color-dot.active{transform:scale(1.25);border-color:var(--color-text)}.card-tags-row{display:flex;flex-wrap:wrap;align-items:center;gap:4px;padding:0 10px 8px}.card-tag{display:inline-flex;align-items:center;gap:2px;font-size:11px;padding:2px 6px 2px 7px;border-radius:999px;background:var(--color-tag-bg);color:var(--color-text-muted)}.card-tag-remove{background:none;border:none;cursor:pointer;padding:0 1px;font-size:13px;line-height:1;color:var(--color-text-muted);opacity:0;transition:opacity .1s}.card-tag:hover .card-tag-remove{opacity:1}.card-tag-remove:hover{color:#dc2626}.card-tag-add{background:none;border:1px dashed var(--color-border);border-radius:999px;padding:2px 7px;font-size:11px;color:var(--color-text-placeholder);cursor:pointer;transition:border-color .1s,color .1s}.card-tag-add:hover{border-color:var(--color-accent);color:var(--color-accent)}.card-tag-input{font-size:11px;padding:1px 6px;border:1px solid var(--color-accent);border-radius:999px;outline:none;width:70px;color:var(--color-text);background:var(--color-card-bg);font-family:inherit}.card-divider{border:none;border-top:1px solid var(--color-border);margin:0 10px}.card-todo-badge{font-size:11px;padding:1px 6px;border-radius:999px;background:var(--color-tag-bg);color:var(--color-text-muted);flex-shrink:0}.card.collapsed .card-body-wrap,.card.collapsed .card-tags,.card.collapsed .card-divider{display:none}[data-theme=dark] .card[data-color=default]{background:#1e1e1e!important;border-color:#444!important}[data-theme=dark] .card[data-color=yellow]{background:#3d3510!important;border-color:#a08c14!important}[data-theme=dark] .card[data-color=blue]{background:#152948!important;border-color:#2d5aa0!important}[data-theme=dark] .card[data-color=green]{background:#143024!important;border-color:#28704a!important}[data-theme=dark] .card[data-color=pink]{background:#3a1830!important;border-color:#8a3068!important}[data-theme=dark] .card[data-color=purple]{background:#261a45!important;border-color:#5e3ea0!important}[data-theme=dark] .card[data-color=orange]{background:#382210!important;border-color:#a06020!important}[data-theme=dark] .card .card-title{color:#e2e8f0}[data-theme=dark] .card .card-body{color:#94a3b8}[data-theme=dark] .card .card-tag{background:#ffffff14;color:#94a3b8}.label-format-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999}.label-format-popup{position:fixed;z-index:10000;background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:10px;padding:10px 12px;box-shadow:0 4px 20px var(--color-shadow-hover);display:flex;flex-direction:column;gap:8px;min-width:180px}.label-format-row{display:flex;align-items:center;gap:4px}.label-format-label{font-size:11px;color:var(--color-text-muted);min-width:48px}.label-format-toggle{font-size:13px;padding:4px 10px;border-radius:6px;border:1px solid var(--color-border);background:none;color:var(--color-text);cursor:pointer;transition:background .1s,border-color .1s}.label-format-toggle:hover{border-color:var(--color-accent)}.label-format-toggle.active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.label-format-select{flex:1;font-size:12px;font-family:inherit;padding:3px 6px;border:1px solid var(--color-border);border-radius:6px;background:var(--color-surface);color:var(--color-text);cursor:pointer;outline:none}.label-format-select:focus{border-color:var(--color-accent)}.label-format-colors{display:flex;flex-wrap:wrap;gap:4px}.label-color-dot{width:18px;height:18px;border-radius:50%;border:2px solid var(--color-border);cursor:pointer;transition:border-color .1s,transform .1s}.label-color-dot:hover{transform:scale(1.15)}.label-color-dot.active{border-color:var(--color-accent);box-shadow:0 0 0 2px var(--color-accent)}.label-color-dot.no-fill{background:repeating-conic-gradient(var(--color-border) 0% 25%,transparent 0% 50%) 50% / 8px 8px}.canvas-lines-svg{position:absolute;top:0;left:0}.canvas-lines-svg>defs{pointer-events:none}.canvas-line{stroke:var(--color-text-muted);stroke-width:2;stroke-linecap:round;pointer-events:none}.canvas-line-selected{stroke:var(--color-accent);stroke-width:6;stroke-linecap:round;opacity:.3;pointer-events:none}.canvas-line-handle{fill:var(--color-accent);stroke:#fff;stroke-width:2;pointer-events:all;cursor:grab;opacity:0;transition:opacity .15s}.canvas-line-handle:active{cursor:grabbing}.canvas-line-handle.visible{opacity:1}.canvas-line-delete circle{fill:var(--color-card-bg);stroke:var(--color-border);stroke-width:1;pointer-events:all}.canvas-line-delete:hover circle{fill:#fee2e2;stroke:#dc2626}.canvas-line-delete text{fill:var(--color-text-muted);pointer-events:none}.canvas-line-delete:hover text{fill:#dc2626}.canvas-viewport{position:fixed;top:48px;right:0;bottom:0;left:0;overflow:hidden;background:var(--color-surface);cursor:grab;-webkit-user-select:none;user-select:none}.canvas-viewport:active{cursor:grabbing}.canvas-viewport.draw-mode,.canvas-viewport.draw-mode:active{cursor:crosshair}.canvas-world{position:absolute;top:0;left:0;transform-origin:0 0}.canvas-viewport:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle,var(--color-dot) 1px,transparent 1px);background-size:24px 24px;pointer-events:none}.canvas-controls{position:fixed;bottom:16px;left:16px;display:flex;align-items:center;gap:2px;background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:10px;padding:4px 6px;box-shadow:0 2px 8px var(--color-shadow);z-index:400}.canvas-ctrl-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:none;border:none;border-radius:6px;cursor:pointer;font-size:15px;color:var(--color-text);transition:background .1s}.canvas-ctrl-btn:hover{background:var(--color-hover)}.canvas-ctrl-btn:disabled{opacity:.3;cursor:not-allowed}.canvas-ctrl-sep{width:1px;height:18px;background:var(--color-border);margin:0 4px}.canvas-ctrl-zoom{font-size:12px;color:var(--color-text-muted);min-width:38px;text-align:center;cursor:pointer;padding:2px 4px;border-radius:4px;transition:background .1s}.canvas-ctrl-zoom:hover{background:var(--color-hover);color:var(--color-text)}:root{--color-accent: #0D9488;--color-surface: #F1F5F9;--color-card-bg: #FFFFFF;--color-text: #1E293B;--color-text-muted: #64748B;--color-text-placeholder: #94A3B8;--color-border: #E2E8F0;--color-hover: #F8FAFC;--color-shadow: rgba(0, 0, 0, .06);--color-shadow-hover: rgba(0, 0, 0, .12);--color-dot: #CBD5E1;--color-tag-bg: #F1F5F9;--color-logo: #3D5280;--color-bracket: #94A3B8}[data-theme=dark]{--color-accent: #14B8A6;--color-surface: #141414;--color-card-bg: #1e1e1e;--color-text: #e8e8e8;--color-text-muted: #999999;--color-text-placeholder: #616161;--color-border: #333333;--color-hover: #2a2a2a;--color-shadow: rgba(0, 0, 0, .35);--color-shadow-hover: rgba(0, 0, 0, .5);--color-dot: #2a2a2a;--color-tag-bg: #252525;--color-logo: #8BA3D4;--color-bracket: #64748B}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--color-surface);color:var(--color-text);overflow:hidden}.app{width:100vw;height:100vh;overflow:hidden}.canvas-empty{display:flex;align-items:center;justify-content:center;cursor:default}.canvas-empty-msg{text-align:center;color:var(--color-text-muted);font-size:15px;line-height:2}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}
