.react-flow{--xy-edge-stroke-default:#b1b1b7;--xy-edge-stroke-width-default:1;--xy-edge-stroke-selected-default:#555;--xy-connectionline-stroke-default:#b1b1b7;--xy-connectionline-stroke-width-default:1;--xy-attribution-background-color-default:#ffffff80;--xy-minimap-background-color-default:#fff;--xy-minimap-mask-background-color-default:#f0f0f099;--xy-minimap-mask-stroke-color-default:transparent;--xy-minimap-mask-stroke-width-default:1;--xy-minimap-node-background-color-default:#e2e2e2;--xy-minimap-node-stroke-color-default:transparent;--xy-minimap-node-stroke-width-default:2;--xy-background-color-default:transparent;--xy-background-pattern-dots-color-default:#91919a;--xy-background-pattern-lines-color-default:#eee;--xy-background-pattern-cross-color-default:#e2e2e2;background-color:var(--xy-background-color,var(--xy-background-color-default));--xy-node-color-default:inherit;--xy-node-border-default:1px solid #1a192b;--xy-node-background-color-default:#fff;--xy-node-group-background-color-default:#f0f0f040;--xy-node-boxshadow-hover-default:0 1px 4px 1px #00000014;--xy-node-boxshadow-selected-default:0 0 0 .5px #1a192b;--xy-node-border-radius-default:3px;--xy-handle-background-color-default:#1a192b;--xy-handle-border-color-default:#fff;--xy-selection-background-color-default:#0059dc14;--xy-selection-border-default:1px dotted #0059dccc;--xy-controls-button-background-color-default:#fefefe;--xy-controls-button-background-color-hover-default:#f4f4f4;--xy-controls-button-color-default:inherit;--xy-controls-button-color-hover-default:inherit;--xy-controls-button-border-color-default:#eee;--xy-controls-box-shadow-default:0 0 2px 1px #00000014;--xy-edge-label-background-color-default:#fff;--xy-edge-label-color-default:inherit;--xy-resize-background-color-default:#3367d9;direction:ltr}.react-flow.dark{--xy-edge-stroke-default:#3e3e3e;--xy-edge-stroke-width-default:1;--xy-edge-stroke-selected-default:#727272;--xy-connectionline-stroke-default:#b1b1b7;--xy-connectionline-stroke-width-default:1;--xy-attribution-background-color-default:#96969640;--xy-minimap-background-color-default:#141414;--xy-minimap-mask-background-color-default:#3c3c3c99;--xy-minimap-mask-stroke-color-default:transparent;--xy-minimap-mask-stroke-width-default:1;--xy-minimap-node-background-color-default:#2b2b2b;--xy-minimap-node-stroke-color-default:transparent;--xy-minimap-node-stroke-width-default:2;--xy-background-color-default:#141414;--xy-background-pattern-dots-color-default:#777;--xy-background-pattern-lines-color-default:#777;--xy-background-pattern-cross-color-default:#777;--xy-node-color-default:#f8f8f8;--xy-node-border-default:1px solid #3c3c3c;--xy-node-background-color-default:#1e1e1e;--xy-node-group-background-color-default:#f0f0f040;--xy-node-boxshadow-hover-default:0 1px 4px 1px #ffffff14;--xy-node-boxshadow-selected-default:0 0 0 .5px #999;--xy-handle-background-color-default:#bebebe;--xy-handle-border-color-default:#1e1e1e;--xy-selection-background-color-default:#c8c8dc14;--xy-selection-border-default:1px dotted #c8c8dccc;--xy-controls-button-background-color-default:#2b2b2b;--xy-controls-button-background-color-hover-default:#3e3e3e;--xy-controls-button-color-default:#f8f8f8;--xy-controls-button-color-hover-default:#fff;--xy-controls-button-border-color-default:#5b5b5b;--xy-controls-box-shadow-default:0 0 2px 1px #00000014;--xy-edge-label-background-color-default:#141414;--xy-edge-label-color-default:#f8f8f8}.react-flow__background{background-color:var(--xy-background-color-props,var(--xy-background-color,var(--xy-background-color-default)));pointer-events:none;z-index:-1}.react-flow__container{width:100%;height:100%;position:absolute;top:0;left:0}.react-flow__pane{z-index:1;touch-action:none}.react-flow__pane.draggable{cursor:grab}.react-flow__pane.dragging{cursor:grabbing}.react-flow__pane.selection{cursor:pointer}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow__edge-path{stroke:var(--xy-edge-stroke,var(--xy-edge-stroke-default));stroke-width:var(--xy-edge-stroke-width,var(--xy-edge-stroke-width-default));fill:none}.react-flow__connection-path{stroke:var(--xy-connectionline-stroke,var(--xy-connectionline-stroke-default));stroke-width:var(--xy-connectionline-stroke-width,var(--xy-connectionline-stroke-width-default));fill:none}.react-flow .react-flow__edges{position:absolute}.react-flow .react-flow__edges svg{pointer-events:none;position:absolute;overflow:visible}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:.5s linear infinite dashdraw}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge.selectable:focus .react-flow__edge-path,.react-flow__edge.selectable:focus-visible .react-flow__edge-path{stroke:var(--xy-edge-stroke-selected,var(--xy-edge-stroke-selected-default))}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;user-select:none}.react-flow__arrowhead polyline{stroke:var(--xy-edge-stroke,var(--xy-edge-stroke-default))}.react-flow__arrowhead polyline.arrowclosed{fill:var(--xy-edge-stroke,var(--xy-edge-stroke-default))}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:.5s linear infinite dashdraw}svg.react-flow__connectionline{z-index:1001;position:absolute;overflow:visible}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{-webkit-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:default;position:absolute}.react-flow__node.selectable{cursor:pointer}.react-flow__node.draggable{cursor:grab;pointer-events:all}.react-flow__node.draggable.dragging{cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:0 0;pointer-events:none}.react-flow__nodesselection-rect{pointer-events:all;cursor:grab;position:absolute}.react-flow__handle{pointer-events:none;background-color:var(--xy-handle-background-color,var(--xy-handle-background-color-default));border:1px solid var(--xy-handle-border-color,var(--xy-handle-border-color-default));border-radius:100%;width:6px;min-width:5px;height:6px;min-height:5px;position:absolute}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;bottom:0;left:50%;transform:translate(-50%,50%)}.react-flow__handle-top{top:0;left:50%;transform:translate(-50%,-50%)}.react-flow__handle-left{top:50%;left:0;transform:translate(-50%,-50%)}.react-flow__handle-right{top:50%;right:0;transform:translate(50%,-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__pane.selection .react-flow__panel{pointer-events:none}.react-flow__panel{z-index:5;margin:15px;position:absolute}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.top.center,.react-flow__panel.bottom.center{left:50%;transform:translate(-15px)translate(-50%)}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.left.center,.react-flow__panel.right.center{top:50%;transform:translateY(-15px)translateY(-50%)}.react-flow__attribution{background:var(--xy-attribution-background-color,var(--xy-attribution-background-color-default));margin:0;padding:2px 3px;font-size:10px}.react-flow__attribution a{color:#999;text-decoration:none}@keyframes dashdraw{0%{stroke-dashoffset:10px}}.react-flow__edgelabel-renderer{pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute;top:0;left:0}.react-flow__viewport-portal{-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute;top:0;left:0}.react-flow__minimap{background:var(--xy-minimap-background-color-props,var(--xy-minimap-background-color,var(--xy-minimap-background-color-default)))}.react-flow__minimap-svg{display:block}.react-flow__minimap-mask{fill:var(--xy-minimap-mask-background-color-props,var(--xy-minimap-mask-background-color,var(--xy-minimap-mask-background-color-default)));stroke:var(--xy-minimap-mask-stroke-color-props,var(--xy-minimap-mask-stroke-color,var(--xy-minimap-mask-stroke-color-default)));stroke-width:var(--xy-minimap-mask-stroke-width-props,var(--xy-minimap-mask-stroke-width,var(--xy-minimap-mask-stroke-width-default)))}.react-flow__minimap-node{fill:var(--xy-minimap-node-background-color-props,var(--xy-minimap-node-background-color,var(--xy-minimap-node-background-color-default)));stroke:var(--xy-minimap-node-stroke-color-props,var(--xy-minimap-node-stroke-color,var(--xy-minimap-node-stroke-color-default)));stroke-width:var(--xy-minimap-node-stroke-width-props,var(--xy-minimap-node-stroke-width,var(--xy-minimap-node-stroke-width-default)))}.react-flow__background-pattern.dots{fill:var(--xy-background-pattern-color-props,var(--xy-background-pattern-color,var(--xy-background-pattern-dots-color-default)))}.react-flow__background-pattern.lines{stroke:var(--xy-background-pattern-color-props,var(--xy-background-pattern-color,var(--xy-background-pattern-lines-color-default)))}.react-flow__background-pattern.cross{stroke:var(--xy-background-pattern-color-props,var(--xy-background-pattern-color,var(--xy-background-pattern-cross-color-default)))}.react-flow__controls{box-shadow:var(--xy-controls-box-shadow,var(--xy-controls-box-shadow-default));flex-direction:column;display:flex}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{background:var(--xy-controls-button-background-color,var(--xy-controls-button-background-color-default));border:none;border-bottom:1px solid var(--xy-controls-button-border-color-props,var(--xy-controls-button-border-color,var(--xy-controls-button-border-color-default)));width:26px;height:26px;color:var(--xy-controls-button-color-props,var(--xy-controls-button-color,var(--xy-controls-button-color-default)));cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;padding:4px;display:flex}.react-flow__controls-button svg{fill:currentColor;width:100%;max-width:12px;max-height:12px}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-input,.react-flow__node-default,.react-flow__node-output,.react-flow__node-group{border-radius:var(--xy-node-border-radius,var(--xy-node-border-radius-default));width:150px;color:var(--xy-node-color,var(--xy-node-color-default));text-align:center;border:var(--xy-node-border,var(--xy-node-border-default));background-color:var(--xy-node-background-color,var(--xy-node-background-color-default));padding:10px;font-size:12px}.react-flow__node-input.selectable:hover,.react-flow__node-default.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:var(--xy-node-boxshadow-hover,var(--xy-node-boxshadow-hover-default))}.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:var(--xy-node-boxshadow-selected,var(--xy-node-boxshadow-selected-default))}.react-flow__node-group{background-color:var(--xy-node-group-background-color,var(--xy-node-group-background-color-default))}.react-flow__nodesselection-rect,.react-flow__selection{background:var(--xy-selection-background-color,var(--xy-selection-background-color-default));border:var(--xy-selection-border,var(--xy-selection-border-default))}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls-button:hover{background:var(--xy-controls-button-background-color-hover-props,var(--xy-controls-button-background-color-hover,var(--xy-controls-button-background-color-hover-default)));color:var(--xy-controls-button-color-hover-props,var(--xy-controls-button-color-hover,var(--xy-controls-button-color-hover-default)))}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__controls-button:last-child{border-bottom:none}.react-flow__controls.horizontal .react-flow__controls-button{border-bottom:none;border-right:1px solid var(--xy-controls-button-border-color-props,var(--xy-controls-button-border-color,var(--xy-controls-button-border-color-default)))}.react-flow__controls.horizontal .react-flow__controls-button:last-child{border-right:none}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{background-color:var(--xy-resize-background-color,var(--xy-resize-background-color-default));border:1px solid #fff;border-radius:1px;width:5px;height:5px;translate:-50% -50%}.react-flow__resize-control.handle.left{top:50%;left:0}.react-flow__resize-control.handle.right{top:50%;left:100%}.react-flow__resize-control.handle.top{top:0;left:50%}.react-flow__resize-control.handle.bottom{top:100%;left:50%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:var(--xy-resize-background-color,var(--xy-resize-background-color-default));border-style:solid;border-width:0}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;height:100%;top:0;transform:translate(-50%)}.react-flow__resize-control.line.left{border-left-width:1px;left:0}.react-flow__resize-control.line.right{border-right-width:1px;left:100%}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{width:100%;height:1px;left:0;transform:translateY(-50%)}.react-flow__resize-control.line.top{border-top-width:1px;top:0}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.react-flow__edge-text{fill:var(--xy-edge-label-color,var(--xy-edge-label-color-default))}:root{color:#172026;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f7f8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}button,input,select,textarea{font:inherit}.app-shell{--editor-bg:#eef3f5;--editor-panel:#fff;--editor-panel-muted:#f8fafb;--editor-panel-strong:#f1f5f6;--editor-border:#d9e0e4;--editor-border-strong:#ccd5da;--editor-text:#172026;--editor-text-muted:#65727b;--editor-text-soft:#718089;--editor-accent:#1f6f68;--editor-accent-soft:#e8f3f1;--editor-focus-ring:#d9ece9;--editor-danger-bg:#fff4f4;--editor-danger-border:#d99a9a;--editor-danger-text:#8a2424;--editor-grid:#c7d1d6;--editor-minimap-mask:#eef3f5b8;background:var(--editor-bg);height:100vh;color:var(--editor-text);grid-template-columns:280px minmax(0,1fr) 0;transition:grid-template-columns .2s cubic-bezier(.4,0,.2,1);display:grid;overflow:hidden}.app-shell.left-sidebar-collapsed{grid-template-columns:64px minmax(0,1fr) 0}.app-shell.right-detail-open{grid-template-columns:280px minmax(0,1fr) 320px}.app-shell.left-sidebar-collapsed.right-detail-open{grid-template-columns:64px minmax(0,1fr) 320px}.sidebar{border-color:var(--editor-border);background:var(--editor-panel);min-width:0;color:var(--editor-text);flex-direction:column;gap:20px;padding:20px;display:flex}.sidebar-left{border-right:1px solid var(--editor-border);overflow:hidden}.sidebar-left-collapsed{align-items:center;gap:12px;padding:12px 8px}.sidebar-right{border-left:1px solid var(--editor-border);opacity:0;pointer-events:none;width:320px;transition:opacity .18s,padding .2s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1);overflow-y:auto;transform:translate(16px)}.detail-sidebar-close{display:none}.sidebar-right-open{opacity:1;pointer-events:auto;transform:translate(0)}.sidebar-right-content{opacity:0;flex-direction:column;gap:20px;transition:opacity .12s 80ms;display:flex}.sidebar-right-open .sidebar-right-content{opacity:1}.brand{grid-template-columns:48px minmax(0,1fr);align-items:center;gap:12px;display:grid}.sidebar-header{align-items:flex-start;gap:6px;display:flex}.sidebar-header .brand{flex:1}.sidebar-header-actions{grid-template-columns:repeat(2,28px);gap:2px;margin-top:10px;display:grid}.sidebar-left-collapsed .brand-mark{width:44px;height:44px}.sidebar-left>*{animation:.16s ease-out both sidebar-content-in}@keyframes sidebar-content-in{0%{opacity:0;transform:translate(-6px)}to{opacity:1;transform:translate(0)}}@media (prefers-reduced-motion:reduce){.app-shell,.sidebar-right,.sidebar-right-content{transition:none}.sidebar-left>*{animation:none}}.brand-mark{color:#f7d85a;background:#15191d;border-radius:8px;place-items:center;width:48px;height:48px;font-weight:800;display:grid}.brand h1{margin:0;font-size:18px;line-height:1.2}.brand p{color:var(--editor-text-muted);margin:4px 0 0;font-size:12px}.save-status{min-height:20px;color:var(--editor-text-muted);align-items:center;gap:6px;font-size:12px;font-weight:700;display:inline-flex}.save-status-error{color:#9a3030}.storage-mode-badge{border:1px solid var(--editor-border-strong);background:var(--editor-panel-strong);min-height:18px;color:var(--editor-text-muted);border-radius:6px;align-items:center;padding:0 6px;font-size:10px;font-weight:900;line-height:1;display:inline-flex}.storage-mode-api{color:#1f6f68;background:#e7f5f2;border-color:#b6d8d3}.spin{animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.canvas-area{background:var(--editor-bg);min-width:0;min-height:0}.board-panel{flex:1;min-height:0}.board-list{min-height:0;overflow-y:auto}.user-footer{border-top:1px solid var(--editor-border);grid-template-columns:34px minmax(0,1fr);align-items:center;gap:9px;padding-top:12px;display:grid}.user-avatar{color:#f7d85a;background:#172026;border-radius:7px;place-items:center;width:34px;height:34px;font-size:11px;font-weight:900;display:grid}.user-avatar img{border-radius:inherit;object-fit:cover;width:100%;height:100%}.user-footer div{min-width:0}.user-name,.user-id{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.user-name{color:var(--editor-text);font-size:12px;font-weight:800}.user-id{color:var(--editor-text-soft);margin-top:2px;font-size:10px;font-weight:700}.app-theme-dark{--editor-bg:#151b1f;--editor-panel:#20282d;--editor-panel-muted:#172026;--editor-panel-strong:#263238;--editor-border:#334149;--editor-border-strong:#3c4a52;--editor-text:#edf3f5;--editor-text-muted:#aebbc2;--editor-text-soft:#8f9da5;--editor-accent:#80d6cb;--editor-accent-soft:#263b3a;--editor-focus-ring:#80d6cb38;--editor-danger-bg:#3a2224;--editor-danger-border:#7d4448;--editor-danger-text:#ffb8ba;--editor-grid:#3d4b52;--editor-minimap-mask:#151b1fb8}@media (prefers-color-scheme:dark){.app-theme-system{--editor-bg:#151b1f;--editor-panel:#20282d;--editor-panel-muted:#172026;--editor-panel-strong:#263238;--editor-border:#334149;--editor-border-strong:#3c4a52;--editor-text:#edf3f5;--editor-text-muted:#aebbc2;--editor-text-soft:#8f9da5;--editor-accent:#80d6cb;--editor-accent-soft:#263b3a;--editor-focus-ring:#80d6cb38;--editor-danger-bg:#3a2224;--editor-danger-border:#7d4448;--editor-danger-text:#ffb8ba;--editor-grid:#3d4b52;--editor-minimap-mask:#151b1fb8}}.primary-action,.danger-action{border:1px solid var(--editor-border-strong,#ccd5da);background:var(--editor-panel,#fff);color:var(--editor-text,#172026);cursor:pointer;border-radius:8px}.primary-action{border-color:var(--editor-accent,#1f6f68);background:var(--editor-accent,#1f6f68);color:#fff;justify-content:center;align-items:center;gap:8px;min-height:42px;font-weight:700;display:inline-flex}.secondary-action{border:1px solid var(--editor-border-strong,#ccd5da);background:var(--editor-panel-muted,#f8fafb);min-height:36px;color:var(--editor-text,#26323a);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:6px;font-weight:700;display:inline-flex}.secondary-action:disabled{cursor:not-allowed;opacity:.45}.primary-action:disabled{cursor:not-allowed;opacity:.55}.secondary-action:hover,.primary-action:hover,.danger-action:hover{filter:brightness(.98)}.danger-action{border-color:var(--editor-danger-border,#d99a9a);background:var(--editor-danger-bg,#fff4f4);min-height:40px;color:var(--editor-danger-text,#8a2424);justify-content:center;align-items:center;gap:8px;font-weight:800;display:inline-flex}.panel-section{flex-direction:column;gap:8px;display:flex}.section-heading{color:var(--editor-text-muted,#59666f);letter-spacing:0;text-transform:uppercase;justify-content:space-between;align-items:center;gap:12px;font-size:12px;font-weight:800;display:flex}.icon-button,.board-actions button,.board-rename button{width:28px;height:28px;color:var(--editor-text-muted,#59666f);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;flex:none;place-items:center;padding:0;display:inline-grid}.icon-button:hover,.board-actions button:hover,.board-rename button:hover{background:var(--editor-panel-strong,#f1f5f6);color:var(--editor-text,#172026);border-color:#ccd5da}.board-search{border:1px solid var(--editor-border-strong,#ccd5da);background:var(--editor-panel,#fff);min-height:36px;color:var(--editor-text-soft,#718089);border-radius:8px;grid-template-columns:18px minmax(0,1fr);align-items:center;gap:6px;padding:0 10px;display:grid}.board-search:focus-within{box-shadow:0 0 0 2px var(--editor-focus-ring,#d9ece9);border-color:#1f6f68}.board-search input{min-width:0;color:var(--editor-text,#172026);background:0 0;border:0;outline:0;font-size:13px}.board-list{flex-direction:column;gap:6px;padding-right:2px;display:flex}.board-row{border:1px solid var(--editor-border,#d9e0e4);background:var(--editor-panel,#fff);border-radius:8px;grid-template-columns:minmax(0,1fr) 84px;align-items:center;min-height:52px;display:grid;overflow:hidden}.board-row.active{border-color:var(--editor-accent,#1f6f68);background:var(--editor-accent-soft,#e8f3f1)}.board-select{min-width:0;min-height:50px;color:var(--editor-text,#172026);cursor:pointer;text-align:left;background:0 0;border:0;flex-direction:column;justify-content:center;align-items:flex-start;gap:4px;padding:7px 4px 7px 10px;display:flex}.board-title{text-overflow:ellipsis;white-space:nowrap;width:100%;font-size:13px;font-weight:700;display:block;overflow:hidden}.board-meta{color:var(--editor-text-soft,#718089);align-items:center;gap:5px;font-size:11px;display:inline-flex}.board-actions{opacity:0;grid-template-columns:repeat(3,28px);width:84px;display:grid}.board-row:hover .board-actions,.board-row:focus-within .board-actions,.board-row.active .board-actions{opacity:1}.board-actions button:last-child:hover{border-color:var(--editor-danger-border,#e3b5b5);background:var(--editor-danger-bg,#fff1f1);color:var(--editor-danger-text,#9a3030)}.board-rename{grid-column:1/-1;grid-template-columns:minmax(0,1fr) 28px 28px;align-items:center;gap:2px;width:100%;padding:6px;display:grid}.board-rename input{border:1px solid var(--editor-accent,#1f6f68);border-radius:6px;outline:0;min-width:0;height:34px;padding:0 8px}.board-list-empty{color:var(--editor-text-soft,#718089);text-align:center;margin:8px 0;font-size:12px}.field{color:var(--editor-text-muted,#52616b);flex-direction:column;gap:8px;font-size:13px;font-weight:700;display:flex}.field input,.field select,.field textarea{border:1px solid var(--editor-border-strong,#ccd5da);background:var(--editor-panel,#fff);width:100%;color:var(--editor-text,#172026);border-radius:8px;padding:10px 12px}.field textarea{resize:vertical;min-height:120px}.color-field,.option-field{min-width:0;color:var(--editor-text-muted,#52616b);border:0;margin:0;padding:0}.color-field legend,.option-field legend{margin-bottom:8px;padding:0;font-size:13px;font-weight:700}.edge-option-buttons{grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;display:grid}.edge-width-options{grid-template-columns:repeat(4,minmax(0,1fr))}.edge-direction-options{grid-template-columns:repeat(2,minmax(0,1fr))}.edge-option-buttons button{border:1px solid var(--editor-border-strong,#ccd5da);background:var(--editor-panel-muted,#f8fafb);min-width:0;min-height:34px;color:var(--editor-text,#344149);cursor:pointer;border-radius:6px;font-size:12px;font-weight:700}.edge-option-buttons button[aria-pressed=true]{border-color:var(--editor-accent,#1f6f68);background:var(--editor-accent-soft,#e8f3f1);color:var(--editor-accent,#174f4a);box-shadow:inset 0 0 0 1px var(--editor-accent,#1f6f68)}.edge-label-presets{flex-wrap:nowrap;gap:5px;display:flex}.edge-label-presets button{border:1px solid var(--editor-border-strong,#ccd5da);background:var(--editor-panel-muted,#f8fafb);min-height:28px;color:var(--editor-text,#344149);cursor:pointer;border-radius:6px;flex:none;padding:0 5px;font-size:11px;font-weight:700}.edge-style-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.color-swatches{flex-wrap:nowrap;gap:8px;display:flex}.color-swatch{border:2px solid var(--editor-panel,#fff);cursor:pointer;border-radius:50%;flex:0 0 26px;width:26px;height:26px;box-shadow:0 0 0 1px #aeb9bf}.color-swatch-neutral{background:#dce3e6}.color-swatch-blue{background:#6f9fc6}.color-swatch-cyan{background:#54a9b5}.color-swatch-green{background:#68a77c}.color-swatch-amber{background:#d3a72d}.color-swatch-red{background:#c96c66}.color-swatch-pink{background:#cb7694}.color-swatch-violet{background:#8d79b8}.color-swatch[aria-pressed=true]{box-shadow:0 0 0 2px var(--editor-panel,#fff), 0 0 0 4px var(--editor-accent,#1f6f68)}.empty-detail{border:1px dashed var(--editor-border-strong,#ccd5da);color:var(--editor-text-soft,#718089);text-align:center;border-radius:8px;padding:20px}.pattern-node{--action-bg:var(--editor-panel);--action-border:var(--editor-border-strong);--action-text:var(--editor-text);--action-meta-bg:#ffffffb8;--action-meta-border:var(--action-border);--action-meta-text:var(--action-text);--action-damage-bg:#ffffffdb;border:1px solid var(--action-border);background:var(--action-bg);min-width:168px;min-height:44px;color:var(--action-text);border-radius:8px;place-items:center;padding:12px 18px;font-weight:700;display:grid;position:relative;box-shadow:0 6px 16px #17202612}.pattern-node-neutral{--action-border:#9aa8af}.pattern-node-blue{--action-bg:#edf6ff;--action-border:#5f8fb8;--action-text:#244d70}.pattern-node-cyan{--action-bg:#eaf8fa;--action-border:#4b96a1;--action-text:#245b63}.pattern-node-green{--action-bg:#edf8f0;--action-border:#57916a;--action-text:#285d3a}.pattern-node-amber{--action-bg:#fff6d8;--action-border:#a97900;--action-text:#624900}.pattern-node-red{--action-bg:#fff0ef;--action-border:#b65b55;--action-text:#762e2a}.pattern-node-pink{--action-bg:#fff0f5;--action-border:#b96180;--action-text:#71354a}.pattern-node-violet{--action-bg:#f4f0fb;--action-border:#7965a2;--action-text:#493a69}.pattern-node-content{flex-direction:column;align-items:center;gap:6px;display:flex}.pattern-node-label{text-align:center;word-break:keep-all;overflow-wrap:anywhere}.pattern-node-meta{flex-direction:column;align-items:center;gap:4px;display:flex}.pattern-node-frame,.pattern-node-damage{border:1px solid var(--action-meta-border);background:var(--action-meta-bg);color:var(--action-meta-text);border-radius:999px;padding:2px 7px;font-size:11px;font-weight:800;line-height:1.3}.pattern-node-damage{background:var(--action-damage-bg)}.pattern-node .react-flow__handle{border-color:var(--editor-text-soft);background:var(--editor-panel);width:8px;height:8px}.pattern-node .react-flow__handle-top.react-flow__handle-target,.pattern-node .react-flow__handle-bottom.react-flow__handle-target,.condition-node .react-flow__handle-top.react-flow__handle-target,.condition-node .react-flow__handle-bottom.react-flow__handle-target{transform:translate(-8px,-50%)}.pattern-node .react-flow__handle-top.react-flow__handle-source,.pattern-node .react-flow__handle-bottom.react-flow__handle-source,.condition-node .react-flow__handle-top.react-flow__handle-source,.condition-node .react-flow__handle-bottom.react-flow__handle-source{transform:translate(8px,-50%)}.pattern-node .react-flow__handle-left.react-flow__handle-target,.pattern-node .react-flow__handle-right.react-flow__handle-target,.condition-node .react-flow__handle-left.react-flow__handle-target,.condition-node .react-flow__handle-right.react-flow__handle-target{transform:translate(-50%,-8px)}.pattern-node .react-flow__handle-left.react-flow__handle-source,.pattern-node .react-flow__handle-right.react-flow__handle-source,.condition-node .react-flow__handle-left.react-flow__handle-source,.condition-node .react-flow__handle-right.react-flow__handle-source{transform:translate(-50%,8px)}.react-flow__node.selected .pattern-node{border-color:var(--editor-accent);box-shadow:0 0 0 3px #1f6f682e}.condition-node{place-items:center;width:156px;height:156px;display:grid;position:relative}.condition-node:before{content:"";background:#fff6d8;border:1px solid #7c5a00;position:absolute;inset:16px;transform:rotate(45deg);box-shadow:0 8px 20px #17202614}.condition-node-inner{color:#4a3700;text-align:center;word-break:keep-all;overflow-wrap:anywhere;place-items:center;width:104px;min-height:64px;font-size:13px;font-weight:800;line-height:1.35;display:grid;position:relative}.condition-node .react-flow__handle{background:#fff6d8;border-color:#7c5a00;width:8px;height:8px}.react-flow__node.selected .condition-node:before{border-color:var(--editor-accent);box-shadow:0 0 0 3px #1f6f682e}.note-node{--note-bg:#fff2a8;--note-border:#d2a82e;--note-text:#4b3900;--note-fold:#ab821438;border:1px solid var(--note-border);background:linear-gradient(135deg, transparent 0 86%, var(--note-fold) 86%), var(--note-bg);width:172px;min-height:132px;color:var(--note-text);border-radius:6px 6px 14px;padding:24px 16px 16px;position:relative;box-shadow:0 10px 20px #1720261f}.note-node-blue{--note-bg:#dbeeff;--note-border:#5b8ab5;--note-text:#1e3d5a;--note-fold:#5082b933}.note-node-cyan{--note-bg:#d4f6f8;--note-border:#3d9ba8;--note-text:#1a4d55;--note-fold:#37919b33}.note-node-green{--note-bg:#d8f4df;--note-border:#4a9060;--note-text:#1e4d30;--note-fold:#41875533}.note-node-amber{--note-bg:#ffe8c8;--note-border:#c58a2a;--note-text:#5a3a00;--note-fold:#b9821e33}.note-node-red{--note-bg:#ffe0de;--note-border:#b85550;--note-text:#5a1d1a;--note-fold:#af4b4633}.note-node-pink{--note-bg:#ffe0ed;--note-border:#b95b7a;--note-text:#5a1e35;--note-fold:#af507333}.note-node-violet{--note-bg:#ede0ff;--note-border:#7965a2;--note-text:#362054;--note-fold:#6e5a9b33}.note-node-pin{background:#d34f4f;border-radius:50%;width:10px;height:10px;position:absolute;top:9px;left:50%;transform:translate(-50%);box-shadow:0 1px #0000002e}.note-node-text{white-space:pre-wrap;word-break:keep-all;overflow-wrap:anywhere;font-size:13px;font-weight:700;line-height:1.45}.react-flow__node.selected .note-node{border-color:var(--editor-accent);box-shadow:0 0 0 3px #1f6f682e}.react-flow__edge.selected .react-flow__edge-path{filter:drop-shadow(0 0 2px #1f6f68a6)}.react-flow__edge-textbg{fill:var(--editor-panel)}.app-theme-dark .pattern-node-neutral{--action-bg:#20282d;--action-border:#6f7f87;--action-text:#edf3f5}.app-theme-dark .pattern-node{--action-meta-bg:#edf3f5eb;--action-meta-border:#edf3f5a6;--action-meta-text:#172026;--action-damage-bg:#fffffff5}.app-theme-dark .condition-node:before{background:#3a311b;border-color:#b69432}.app-theme-dark .condition-node-inner{color:#ffe19a}.app-theme-dark .condition-node .react-flow__handle{background:#3a311b;border-color:#b69432}.app-theme-dark .note-node{--note-bg:#3a311b;--note-border:#b69432;--note-text:#ffe19a;--note-fold:#ffe19a1f}.app-theme-dark .note-node-blue{--note-bg:#152030;--note-border:#4a78a8;--note-text:#a8d0f0;--note-fold:#4678b41f}.app-theme-dark .note-node-cyan{--note-bg:#152528;--note-border:#3a8a98;--note-text:#9adce8;--note-fold:#3787961f}.app-theme-dark .note-node-green{--note-bg:#152318;--note-border:#3d7d52;--note-text:#9ad8b0;--note-fold:#37784b1f}.app-theme-dark .note-node-amber{--note-bg:#291e08;--note-border:#a07820;--note-text:#f0d080;--note-fold:#a0731e1f}.app-theme-dark .note-node-red{--note-bg:#291010;--note-border:#9e4a45;--note-text:#f0a0a0;--note-fold:#9b46411f}.app-theme-dark .note-node-pink{--note-bg:#290f18;--note-border:#9e4a68;--note-text:#f0a0c0;--note-fold:#9b46691f}.app-theme-dark .note-node-violet{--note-bg:#1b1530;--note-border:#6855a0;--note-text:#c0a8f0;--note-fold:#6955a01f}.app-theme-dark .react-flow__controls,.app-theme-dark .react-flow__minimap{border:1px solid var(--editor-border);background:var(--editor-panel);color:var(--editor-text)}.app-theme-dark .react-flow__controls-button{border-bottom-color:var(--editor-border);background:var(--editor-panel);color:var(--editor-text);fill:var(--editor-text)}.app-theme-dark .react-flow__controls-button:hover{background:var(--editor-panel-strong)}@media (prefers-color-scheme:dark){.app-theme-system .pattern-node-neutral{--action-bg:#20282d;--action-border:#6f7f87;--action-text:#edf3f5}.app-theme-system .pattern-node{--action-meta-bg:#edf3f5eb;--action-meta-border:#edf3f5a6;--action-meta-text:#172026;--action-damage-bg:#fffffff5}.app-theme-system .condition-node:before{background:#3a311b;border-color:#b69432}.app-theme-system .condition-node-inner{color:#ffe19a}.app-theme-system .condition-node .react-flow__handle{background:#3a311b;border-color:#b69432}.app-theme-system .note-node{--note-bg:#3a311b;--note-border:#b69432;--note-text:#ffe19a;--note-fold:#ffe19a1f}.app-theme-system .note-node-blue{--note-bg:#152030;--note-border:#4a78a8;--note-text:#a8d0f0;--note-fold:#4678b41f}.app-theme-system .note-node-cyan{--note-bg:#152528;--note-border:#3a8a98;--note-text:#9adce8;--note-fold:#3787961f}.app-theme-system .note-node-green{--note-bg:#152318;--note-border:#3d7d52;--note-text:#9ad8b0;--note-fold:#37784b1f}.app-theme-system .note-node-amber{--note-bg:#291e08;--note-border:#a07820;--note-text:#f0d080;--note-fold:#a0731e1f}.app-theme-system .note-node-red{--note-bg:#291010;--note-border:#9e4a45;--note-text:#f0a0a0;--note-fold:#9b46411f}.app-theme-system .note-node-pink{--note-bg:#290f18;--note-border:#9e4a68;--note-text:#f0a0c0;--note-fold:#9b46691f}.app-theme-system .note-node-violet{--note-bg:#1b1530;--note-border:#6855a0;--note-text:#c0a8f0;--note-fold:#6955a01f}.app-theme-system .react-flow__controls,.app-theme-system .react-flow__minimap{border:1px solid var(--editor-border);background:var(--editor-panel);color:var(--editor-text)}.app-theme-system .react-flow__controls-button{border-bottom-color:var(--editor-border);background:var(--editor-panel);color:var(--editor-text);fill:var(--editor-text)}.app-theme-system .react-flow__controls-button:hover{background:var(--editor-panel-strong)}}.board-library-page{color:#172026;background:#eef3f5;min-height:100vh}.library-header{background:#fff;border-bottom:1px solid #d9e0e4;justify-content:space-between;align-items:center;gap:24px;min-height:76px;padding:12px clamp(20px,4vw,56px);display:flex}.library-header-actions{align-items:center;gap:8px;min-width:0;display:flex}.library-user-menu-wrap{min-width:0;position:relative}.library-user-chip{color:#344149;cursor:pointer;background:#f8fafb;border:1px solid #d9e0e4;border-radius:8px;grid-template-columns:28px minmax(0,1fr) 14px;align-items:center;gap:8px;min-width:0;max-width:180px;padding:4px 8px 4px 4px;font-size:12px;font-weight:800;display:grid}.library-user-chip:hover,.library-user-chip:focus-visible{border-color:#1f6f68;outline:0;box-shadow:0 0 0 2px #d9ece9}.library-user-chip .user-avatar{width:28px;height:28px;font-size:10px}.library-user-chip>span:nth-child(2){text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.library-user-menu{z-index:30;background:#fff;border:1px solid #ccd5da;border-radius:8px;min-width:180px;padding:6px;display:grid;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 12px 28px #17202629}.library-user-menu button{color:#344149;cursor:pointer;text-align:left;background:0 0;border:0;border-radius:6px;grid-template-columns:18px minmax(0,1fr);align-items:center;gap:8px;width:100%;min-height:34px;padding:0 8px;font-size:12px;font-weight:800;display:grid}.library-user-menu button:hover,.library-user-menu button:focus-visible{color:#1f6f68;background:#edf6f4;outline:0}.library-user-menu button:disabled{color:#9aa6ad;cursor:not-allowed}.library-brand{align-items:center;gap:12px;display:flex}.library-brand h1,.library-brand p{margin:0}.library-brand h1{font-size:18px}.library-brand p{color:#65727b;text-transform:uppercase;align-items:center;gap:7px;margin-top:3px;font-size:12px;font-weight:700;display:flex}.library-create{min-width:136px;padding:0 16px}.library-filters{background:#fff;border-bottom:1px solid #d9e0e4;grid-template-columns:220px minmax(360px,1fr) minmax(220px,320px);align-items:end;gap:20px;padding:18px clamp(20px,4vw,56px);display:grid}.library-character-filter{color:#52616b;flex-direction:column;gap:7px;font-size:12px;font-weight:800;display:flex}.library-character-filter select{color:#172026;background:#fff;border:1px solid #ccd5da;border-radius:7px;width:100%;height:38px;padding:0 10px}.library-scope-tabs{background:#f4f7f8;border:1px solid #ccd5da;border-radius:7px;grid-template-columns:repeat(3,minmax(0,1fr));height:38px;display:grid;overflow:hidden}.library-scope-tabs button{color:#52616b;cursor:pointer;background:0 0;border:0;border-right:1px solid #d9e0e4;min-width:0;padding:0 10px;font-size:12px;font-weight:800}.library-scope-tabs button:last-child{border-right:0}.library-scope-tabs button[aria-selected=true]{color:#fff;background:#1f6f68}.library-search{color:#718089;background:#fff;border:1px solid #ccd5da;border-radius:7px;grid-template-columns:20px minmax(0,1fr);align-items:center;gap:7px;height:38px;padding:0 10px;display:grid}.library-search:focus-within,.library-character-filter select:focus{border-color:#1f6f68;outline:0;box-shadow:0 0 0 2px #d9ece9}.library-search input{background:0 0;border:0;outline:0;min-width:0}.library-error{color:#8a2424;background:#fff1f1;border:1px solid #e3b5b5;border-radius:7px;margin:16px clamp(20px,4vw,56px) 0;padding:10px 12px;font-size:13px;font-weight:700}.library-content{max-width:1500px;margin:0 auto;padding:28px clamp(20px,4vw,56px) 48px}.library-section-heading{justify-content:space-between;align-items:flex-end;min-height:44px;margin-bottom:16px;display:flex}.library-section-heading h2,.library-section-heading p{margin:0}.library-section-heading h2{font-size:20px}.library-section-heading p{color:#718089;margin-top:4px;font-size:12px;font-weight:700}.board-card-grid{grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:14px;display:grid}.library-board-card{--board-card-accent:#aeb9bf;color:#172026;cursor:pointer;min-width:0;min-height:210px;box-shadow:inset 4px 0 0 var(--board-card-accent);text-align:left;background:#fff;border:1px solid #d4dde1;border-radius:8px;flex-direction:column;align-items:flex-start;padding:16px;transition:border-color .14s,box-shadow .14s,transform .14s;display:flex}.board-card-neutral{--board-card-accent:#aeb9bf}.board-card-blue{--board-card-accent:#6f9fc6}.board-card-cyan{--board-card-accent:#54a9b5}.board-card-green{--board-card-accent:#68a77c}.board-card-amber{--board-card-accent:#d3a72d}.board-card-red{--board-card-accent:#c96c66}.board-card-pink{--board-card-accent:#cb7694}.board-card-violet{--board-card-accent:#8d79b8}.library-board-card:hover,.library-board-card:focus-visible{box-shadow:inset 4px 0 0 var(--board-card-accent), 0 5px 16px #1720261a;border-color:#1f6f68;outline:0;transform:translateY(-2px)}.card-visibility{color:#59666f;align-items:center;gap:5px;font-size:11px;font-weight:800;display:inline-flex}.card-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;width:100%;margin-top:12px;font-size:17px;font-weight:800;line-height:1.35;display:-webkit-box;overflow:hidden}.character-matchup{color:#344149;grid-template-columns:minmax(0,1fr) 18px minmax(0,1fr);align-items:center;gap:7px;width:100%;margin-top:14px;font-size:12px;font-weight:700;display:grid}.matchup-character{grid-template-columns:34px minmax(0,1fr);align-items:center;gap:7px;min-width:0;display:grid}.matchup-character>span:last-child{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.matchup-character-opponent{text-align:right;grid-template-columns:minmax(0,1fr) 34px}.matchup-character-opponent .character-icon{grid-area:1/2}.matchup-character-opponent>span:last-child{grid-area:1/1}.character-matchup>svg{color:#b48b13}.character-icon{background:var(--character-icon-background);width:34px;height:34px;color:var(--character-icon-foreground);border:1px solid #1720261a;border-radius:7px;place-items:center;font-size:11px;font-weight:900;display:grid}.character-icon-empty{color:#718089;background:#edf1f3}.character-icon-image{background:0 0;border-color:#1720261a;overflow:hidden}.character-icon-image img{object-fit:cover;width:100%;height:100%;display:block}.card-description{color:#65727b;-webkit-line-clamp:2;-webkit-box-orient:vertical;width:100%;margin-top:12px;font-size:12px;line-height:1.5;display:-webkit-box;overflow:hidden}.card-creator{color:#344149;cursor:pointer;background:#f8fafb;border:1px solid #d9e0e4;border-radius:7px;grid-template-columns:26px minmax(0,1fr);align-items:center;gap:7px;max-width:100%;margin-top:12px;padding:4px 8px 4px 4px;font-size:11px;font-weight:800;display:grid}.card-creator:hover,.card-creator:focus-visible{border-color:#1f6f68;outline:0;box-shadow:0 0 0 2px #d9ece9}.card-creator .user-avatar{border-radius:6px;width:26px;height:26px;font-size:9px}.card-creator>span:last-child{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.card-footer{color:#718089;border-top:1px solid #edf0f2;justify-content:space-between;gap:12px;width:100%;margin-top:auto;padding-top:12px;font-size:11px;font-weight:700;display:flex}.card-operation-type{margin-left:auto}.library-empty{color:#718089;text-align:center;border:1px dashed #bcc8ce;place-items:center;min-height:280px;display:grid}.library-empty h3,.library-empty p{margin:0}.library-empty h3{color:#344149;font-size:16px}.library-empty p{font-size:13px}.board-dialog-backdrop{z-index:100;background:#12181c94;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.board-dialog{background:#fff;border:1px solid #ccd5da;border-radius:8px;width:min(620px,100%);max-height:calc(100vh - 40px);padding:22px;overflow-y:auto;box-shadow:0 18px 50px #00000038}.board-dialog>header,.board-dialog>footer{justify-content:space-between;align-items:center;gap:16px;display:flex}.board-dialog h2{margin:4px 0 0;font-size:22px}.dialog-eyebrow{color:#1f6f68;font-size:11px;font-weight:800}.dialog-description{color:#52616b;margin:18px 0;line-height:1.65}.board-details-form{flex-direction:column;gap:14px;margin-top:20px;display:flex}.board-details-form .field textarea{min-height:96px}.board-card-color-field .color-swatches{justify-content:flex-start}.board-character-fields{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.field-error{color:#9a3030;font-size:11px;font-weight:700}.board-details-form [aria-invalid=true]{background:#fff8f8;border-color:#c96c66}.board-dialog-details{border-top:1px solid #e1e6e9;border-left:1px solid #e1e6e9;grid-template-columns:repeat(2,minmax(0,1fr));margin:0;display:grid}.board-dialog-details div{border-bottom:1px solid #e1e6e9;border-right:1px solid #e1e6e9;min-width:0;padding:11px 12px}.board-dialog-details dt{color:#718089;font-size:11px;font-weight:700}.board-dialog-details dd{text-overflow:ellipsis;white-space:nowrap;margin:4px 0 0;font-size:13px;font-weight:700;overflow:hidden}.dialog-tags{flex-wrap:wrap;gap:6px;margin-top:16px;display:flex}.dialog-tags span{color:#52616b;background:#f4f7f8;border:1px solid #ccd5da;border-radius:6px;padding:4px 7px;font-size:11px;font-weight:700}.board-dialog>footer{border-top:1px solid #e1e6e9;justify-content:flex-end;margin-top:22px;padding-top:16px}.board-dialog>footer button{min-height:38px;padding:0 14px}.dialog-open-button{align-items:center;gap:7px;display:inline-flex}.dialog-edit-button{align-items:center;gap:7px;margin-right:auto;display:inline-flex}.dialog-delete-confirm-label{color:#8a2424;margin-right:auto;font-size:.875rem}.board-dialog>footer .danger-action{align-items:center;gap:7px;display:inline-flex}.user-dialog{width:min(460px,100%)}.user-dialog-heading{grid-template-columns:42px minmax(0,1fr);align-items:center;gap:12px;display:grid}.user-dialog-heading .user-avatar{border-radius:8px;width:42px;height:42px;font-size:12px}.user-dialog-details{grid-template-columns:1fr;margin-top:18px}.user-settings-dialog{width:min(520px,100%)}.user-settings-form{gap:14px;margin-top:20px;display:grid}.user-avatar-setting{grid-template-columns:48px minmax(0,1fr);align-items:start;gap:12px;display:grid}.user-avatar-setting .user-avatar{border-radius:8px;width:48px;height:48px;font-size:13px}.avatar-upload-controls{gap:8px;min-width:0;display:grid}.avatar-clear-button{width:fit-content;min-height:32px;padding:0 10px;font-size:12px}.user-settings-form footer{z-index:1;background:#fff;border-top:1px solid #e1e6e9;justify-content:flex-end;gap:8px;margin:4px -22px -22px;padding:16px 22px 22px;display:flex;position:sticky;bottom:-22px}.library-theme-dark{color:#edf3f5;background:#151b1f}.library-theme-dark .library-header,.library-theme-dark .library-filters,.library-theme-dark .library-board-card,.library-theme-dark .board-dialog,.library-theme-dark .library-user-menu{color:#edf3f5;background:#20282d;border-color:#334149}.library-theme-dark .library-brand p,.library-theme-dark .library-section-heading p,.library-theme-dark .card-description,.library-theme-dark .card-footer,.library-theme-dark .field,.library-theme-dark .board-dialog-details dt{color:#aebbc2}.library-theme-dark .library-user-chip,.library-theme-dark .library-search,.library-theme-dark .library-character-filter select,.library-theme-dark .library-scope-tabs,.library-theme-dark .card-creator,.library-theme-dark .field input,.library-theme-dark .field select,.library-theme-dark .field textarea{color:#edf3f5;background:#172026;border-color:#3c4a52}.library-theme-dark .library-user-menu button,.library-theme-dark .character-matchup,.library-theme-dark .board-dialog-details dd{color:#edf3f5}.library-theme-dark .library-user-menu button:hover,.library-theme-dark .library-user-menu button:focus-visible{color:#80d6cb;background:#263b3a}.library-theme-dark .card-footer,.library-theme-dark .board-dialog-details,.library-theme-dark .board-dialog-details div,.library-theme-dark .user-settings-form footer{border-color:#334149}.library-theme-dark .user-settings-form footer{background:#20282d}@media (width<=900px){.library-filters{grid-template-columns:200px minmax(0,1fr)}.library-search{grid-column:1/-1}}@media (width<=640px){.library-header{min-height:68px;padding:10px 14px}.library-brand .brand-mark{width:42px;height:42px}.library-brand h1{font-size:15px}.library-create{width:42px;min-width:42px;padding:0;font-size:0}.library-user-chip{grid-template-columns:28px;width:38px;padding-right:4px}.library-user-chip>span:nth-child(2),.library-user-chip>svg{display:none}.library-filters{grid-template-columns:1fr;gap:12px;padding:14px}.library-scope-tabs,.library-search{grid-column:1}.library-scope-tabs button{padding:0 4px;font-size:11px}.library-content{padding:20px 14px 36px}.board-card-grid{grid-template-columns:1fr}.board-dialog{padding:18px}.board-dialog-details,.board-character-fields{grid-template-columns:1fr}}@media (prefers-reduced-motion:reduce){.library-board-card{transition:none}}@media (prefers-color-scheme:dark){.library-theme-system{color:#edf3f5;background:#151b1f}.library-theme-system .library-header,.library-theme-system .library-filters,.library-theme-system .library-board-card,.library-theme-system .board-dialog,.library-theme-system .library-user-menu{color:#edf3f5;background:#20282d;border-color:#334149}.library-theme-system .library-brand p,.library-theme-system .library-section-heading p,.library-theme-system .card-description,.library-theme-system .card-footer,.library-theme-system .field,.library-theme-system .board-dialog-details dt{color:#aebbc2}.library-theme-system .library-user-chip,.library-theme-system .library-search,.library-theme-system .library-character-filter select,.library-theme-system .library-scope-tabs,.library-theme-system .card-creator,.library-theme-system .field input,.library-theme-system .field select,.library-theme-system .field textarea{color:#edf3f5;background:#172026;border-color:#3c4a52}.library-theme-system .library-user-menu button,.library-theme-system .character-matchup,.library-theme-system .board-dialog-details dd{color:#edf3f5}.library-theme-system .library-user-menu button:hover,.library-theme-system .library-user-menu button:focus-visible{color:#80d6cb;background:#263b3a}.library-theme-system .card-footer,.library-theme-system .board-dialog-details,.library-theme-system .board-dialog-details div,.library-theme-system .user-settings-form footer{border-color:#334149}.library-theme-system .user-settings-form footer{background:#20282d}}.login-page{background:linear-gradient(135deg,#eef1f3 0%,#cfd6db 52%,#aeb8bf 100%);place-items:center;min-height:100vh;padding:24px;display:grid}.login-panel{background:#fffffff5;border:1px solid #ffffff29;border-radius:8px;flex-direction:column;gap:24px;width:min(100%,420px);padding:28px;display:flex;box-shadow:0 24px 70px #00000052}.login-brand{grid-template-columns:48px minmax(0,1fr);align-items:center;gap:12px;display:grid}.login-eyebrow{color:#1f6f68;letter-spacing:0;text-transform:uppercase;font-size:12px;font-weight:900}.login-brand h1{color:#172026;margin:2px 0 0;font-size:28px;line-height:1.15}.login-form{flex-direction:column;gap:16px;display:flex}.login-submit{width:100%;margin-top:4px}.login-links{justify-content:space-between;align-items:center;gap:12px;font-size:13px;font-weight:800;display:flex}.login-links a{color:#1f6f68;text-decoration:none}.login-links a:hover{text-decoration:underline}.login-links-center{justify-content:center}.reset-copy{color:#52616b;margin:0;font-size:13px;font-weight:700;line-height:1.5}.login-note{color:#65727b;border-top:1px solid #d9e0e4;align-items:center;gap:8px;padding-top:16px;font-size:12px;font-weight:700;display:flex}@media (width<=960px){.app-shell{grid-template-columns:220px minmax(0,1fr)}.app-shell.left-sidebar-collapsed{grid-template-columns:64px minmax(0,1fr)}.app-shell.right-detail-open{grid-template-columns:220px minmax(0,1fr)}.app-shell.left-sidebar-collapsed.right-detail-open{grid-template-columns:64px minmax(0,1fr)}.sidebar-right{border-left:none;border-top:1px solid var(--editor-border);opacity:1;z-index:10;border-radius:12px 12px 0 0;width:100%;max-height:60vh;position:fixed;bottom:0;left:0;right:0;overflow-y:auto;transform:translateY(100%);box-shadow:0 -4px 24px #0000001f}.sidebar-right-open{pointer-events:auto;transform:translateY(0)}.detail-sidebar-close{display:flex}}@media (width<=720px){.app-shell{grid-template-rows:auto minmax(0,1fr);grid-template-columns:1fr}.app-shell.left-sidebar-collapsed,.app-shell.right-detail-open{grid-template-columns:1fr}.sidebar-left{border-right:0;border-bottom:1px solid var(--editor-border)}.sidebar-left-collapsed{flex-direction:row;justify-content:space-between}.panel-section{display:none}}
