:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;background-color:#fafafa;color:#1a1a1a}@media(prefers-color-scheme:dark){:root{color:#f0f0f0;background-color:#1a1a1a}}body{margin:0;min-height:100vh}.app-layout{min-height:100vh;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid #e0e0e0;background:#fff}.app-header-title{flex:1}.app-title{font-size:1.5rem;margin:0}.app-subtitle{font-size:.875rem;color:#666;margin:.25rem 0 0}.app-sidebar-toggle,.app-sidebar-close{display:none}.app-content{flex:1;display:flex;align-items:stretch;min-height:0}.app-sidebar-wrapper{display:contents}.app-sidebar-backdrop{display:none}.app-main{flex:1;padding:1.5rem;min-height:0;overflow-y:auto}.views-row{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start;margin-top:2rem}@media(max-width:900px){.views-row{grid-template-columns:1fr}}@media(max-width:768px){.app-sidebar-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:none;cursor:pointer;font-size:1.25rem;flex-shrink:0;border-radius:4px}.app-sidebar-toggle:focus-visible{outline:2px solid #4a90e2;outline-offset:2px}.app-sidebar-close{display:flex;align-items:center;justify-content:center;position:absolute;top:.5rem;right:.5rem;width:32px;height:32px;border:none;background:#00000014;border-radius:50%;cursor:pointer;font-size:1.125rem;line-height:1;z-index:1;flex-shrink:0}.app-sidebar-close:hover{background:#00000024}.app-sidebar-close:focus-visible{outline:2px solid #4a90e2;outline-offset:2px;background:#00000014}.app-sidebar-wrapper{display:block;position:fixed;left:0;top:0;height:100%;width:280px;z-index:200;transform:translate(-100%);transition:transform .25s ease;overflow-y:auto;background:#fafafa}.app-sidebar-wrapper--open{transform:translate(0)}.app-sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:199}}@media(prefers-color-scheme:dark){.app-header{background:#1a1a1a;border-bottom-color:#333}.app-subtitle{color:#aaa}.app-sidebar-wrapper{background:#1f1f1f}}.dialog{border:1px solid #d0d0d0;border-radius:8px;padding:1.25rem 1.5rem;min-width:min(420px,calc(100vw - 2rem));max-width:560px;background:#fff;color:#1a1a1a;box-shadow:0 8px 24px #00000029}.dialog::backdrop{background:#00000052}.dialog-title{margin:0 0 .75rem;font-size:1.125rem}.dialog-body{margin:0 0 1rem;line-height:1.5}.dialog-field{display:flex;flex-direction:column;gap:.375rem;margin-bottom:1rem}.dialog-label{font-size:.875rem;color:#555}.dialog-field input[type=text]{font:inherit;padding:.5rem .625rem;border:1px solid #c0c0c0;border-radius:4px;background:#fff;color:inherit}.dialog-field input[type=text]:focus{outline:2px solid #4a90e2;outline-offset:1px}.dialog-field input[aria-invalid=true]{border-color:#d34141}.dialog-error{color:#d34141;font-size:.875rem}.dialog-actions{display:flex;justify-content:flex-end;gap:.5rem}.dialog-actions button{font:inherit;padding:.5rem 1rem;border:1px solid #c0c0c0;border-radius:4px;background:#f5f5f5;color:inherit;cursor:pointer}.dialog-actions button[type=submit],.dialog-actions .dialog-confirm-primary{background:#4a90e2;border-color:#3a7fd0;color:#fff}.dialog-actions .dialog-confirm-destructive{background:#d34141;border-color:#b53030;color:#fff}.dialog-actions button:focus-visible{outline:2px solid #4a90e2;outline-offset:1px}@media(prefers-color-scheme:dark){.dialog{background:#2a2a2a;color:#f0f0f0;border-color:#444}.dialog-label{color:#bbb}.dialog-field input[type=text]{background:#1a1a1a;border-color:#555}.dialog-actions button{background:#3a3a3a;border-color:#555}}.onboarding{max-width:480px;margin:4rem auto;text-align:center;padding:0 1rem}.onboarding-title{font-size:1.25rem;margin:0 0 .75rem}.onboarding-body{margin:0 0 1.5rem;line-height:1.6;color:#555}.onboarding-cta{font:inherit;font-size:1rem;padding:.625rem 1.25rem;border:0;border-radius:6px;background:#4a90e2;color:#fff;cursor:pointer}.onboarding-cta:hover,.onboarding-cta:focus-visible{background:#3a7fd0;outline:none}@media(prefers-color-scheme:dark){.onboarding-body{color:#bbb}}.tag-input{display:flex;flex-wrap:wrap;gap:.375rem;padding:.375rem .5rem;border:1px solid #c0c0c0;border-radius:4px;background:#fff;min-height:2.25rem;cursor:text}.tag-input:focus-within{outline:2px solid #4a90e2;outline-offset:1px}.tag-chip{display:inline-flex;align-items:center;gap:.25rem;background:#eaf3ff;border:1px solid #b3d4f5;border-radius:12px;padding:.125rem .25rem .125rem .625rem;font-size:.875rem;line-height:1.4}.tag-chip-text{white-space:nowrap}.tag-chip-remove{font:inherit;font-size:.875rem;line-height:1;width:1.25rem;height:1.25rem;border:0;background:transparent;cursor:pointer;color:#4a6280;border-radius:50%}.tag-chip-remove:hover,.tag-chip-remove:focus-visible{background:#4a90e229;outline:none}.tag-input-field{flex:1;min-width:8rem;border:0;outline:none;background:transparent;font:inherit;color:inherit;padding:.125rem .25rem}.tag-input-field:disabled{cursor:not-allowed}@media(prefers-color-scheme:dark){.tag-input{background:#1a1a1a;border-color:#555}.tag-chip{background:#4a90e229;border-color:#4a90e266;color:#e0e0e0}.tag-chip-remove{color:#a0c0e0}}.person-form-dialog textarea{font:inherit;padding:.5rem .625rem;border:1px solid #c0c0c0;border-radius:4px;background:#fff;color:inherit;resize:vertical;min-height:4rem}.person-form-dialog textarea:focus{outline:2px solid #4a90e2;outline-offset:1px}.person-form-dialog textarea[aria-invalid=true]{border-color:#d34141}@media(prefers-color-scheme:dark){.person-form-dialog textarea{background:#1a1a1a;border-color:#555}}.person-item{display:flex;gap:1rem;align-items:flex-start;padding:.875rem 1rem;border:1px solid #e0e0e0;border-radius:6px;background:#fff;margin-bottom:.5rem}.person-item-main{flex:1;min-width:0}.person-item-name{font-size:1rem;margin:0 0 .25rem}.person-item-tags{list-style:none;margin:0 0 .375rem;padding:0;display:flex;flex-wrap:wrap;gap:.25rem}.person-item-tag{font-size:.75rem;padding:.0625rem .5rem;border-radius:10px;background:#eaf3ff;color:#2a5a90;border:1px solid #b3d4f5}.person-item-note{margin:0;font-size:.875rem;color:#555;white-space:pre-wrap;word-break:break-word}.person-item-actions{display:flex;gap:.375rem;flex-shrink:0}.person-item-actions button{font:inherit;font-size:.875rem;padding:.25rem .625rem;border:1px solid #c0c0c0;border-radius:4px;background:#f5f5f5;color:inherit;cursor:pointer}.person-item-actions button:hover{background:#e0e0e0}.person-item-actions button:focus-visible{background:#e0e0e0;outline:2px solid #4a90e2;outline-offset:1px}.person-item-actions .person-item-delete{color:#d34141;border-color:#d3a9a9}.person-item-actions .person-item-delete:hover{background:#fdecec}.person-item-actions .person-item-delete:focus-visible{background:#fdecec;outline-color:#d34141}@media(prefers-color-scheme:dark){.person-item{background:#2a2a2a;border-color:#444}.person-item-tag{background:#4a90e229;border-color:#4a90e266;color:#d0e0f5}.person-item-note{color:#bbb}.person-item-actions button{background:#3a3a3a;border-color:#555}.person-item-actions button:hover{background:#4a4a4a}.person-item-actions button:focus-visible{background:#4a4a4a}.person-item-actions .person-item-delete{color:#ff8a8a;border-color:#6a3a3a}.person-item-actions .person-item-delete:hover,.person-item-actions .person-item-delete:focus-visible{background:#4a2a2a}}.persons-view{max-width:720px}.persons-view-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.persons-view-title{font-size:1.25rem;margin:0;word-break:break-word}.persons-view-add{font:inherit;font-size:.875rem;padding:.375rem .875rem;border:1px solid #3a7fd0;border-radius:4px;background:#4a90e2;color:#fff;cursor:pointer;flex-shrink:0}.persons-view-add:hover,.persons-view-add:focus-visible{background:#3a7fd0;outline:none}.persons-view-empty{margin:2rem 0;color:#777;text-align:center}.persons-view-list{list-style:none;margin:0;padding:0}@media(prefers-color-scheme:dark){.persons-view-empty{color:#aaa}}.project-item{position:relative;display:flex;align-items:stretch;border-bottom:1px solid #ececec}.project-item-active{background:#eaf3ff}.project-item-select{flex:1;display:flex;flex-direction:column;align-items:flex-start;gap:.125rem;padding:.5rem .75rem;border:0;background:transparent;text-align:left;cursor:pointer;font:inherit;color:inherit}.project-item-select:hover{background:#4a90e214}.project-item-select:focus-visible{background:#4a90e214;outline:2px solid #4a90e2;outline-offset:-2px}.project-item-name{font-weight:600}.project-item-meta{font-size:.75rem;color:#666}.project-item-actions{position:relative;display:flex;align-items:center}.project-item-menu-toggle{width:32px;height:32px;border:0;background:transparent;font-size:1rem;cursor:pointer;border-radius:4px;color:inherit}.project-item-menu-toggle:hover{background:#0000000f}.project-item-menu-toggle:focus-visible{background:#0000000f;outline:2px solid #4a90e2;outline-offset:1px}.project-item-menu{position:absolute;top:100%;right:4px;z-index:10;background:#fff;border:1px solid #d0d0d0;border-radius:4px;box-shadow:0 4px 12px #0000001f;display:flex;flex-direction:column;min-width:140px}.project-item-menu button{font:inherit;text-align:left;padding:.5rem .75rem;border:0;background:transparent;cursor:pointer;color:inherit}.project-item-menu button:hover{background:#4a90e214}.project-item-menu button:focus-visible{background:#4a90e214;outline:2px solid #4a90e2;outline-offset:-2px}.project-item-menu-destructive{color:#d34141}@media(prefers-color-scheme:dark){.project-item{border-bottom-color:#333}.project-item-active{background:#4a90e229}.project-item-meta{color:#aaa}.project-item-menu{background:#2a2a2a;border-color:#444}.project-item-menu-destructive{color:#ff8a8a}}.storage-bar{padding:.5rem 1rem .625rem;border-top:1px solid #ececec;font-size:.75rem;color:#767676}.storage-bar-track{height:4px;background:#e8e8e8;border-radius:2px;overflow:hidden;margin-bottom:.3rem}.storage-bar-fill{height:100%;background:#4a90e2;border-radius:2px;transition:width .3s ease}.storage-bar--warn .storage-bar-fill{background:#d97b00}.storage-bar-label{margin:0;display:flex;align-items:center;gap:.375rem}.storage-bar-warn-badge{color:#a05600;font-weight:600}@media(prefers-color-scheme:dark){.storage-bar{border-top-color:#333;color:#999}.storage-bar-track{background:#3a3a3a}.storage-bar--warn .storage-bar-fill{background:#e08b10}.storage-bar-warn-badge{color:#e08b10}}.project-sidebar{width:280px;flex-shrink:0;border-right:1px solid #e0e0e0;background:#fafafa;display:flex;flex-direction:column;overflow-y:auto}.project-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid #ececec}.project-sidebar-title{font-size:.875rem;font-weight:600;margin:0;color:#555;text-transform:uppercase;letter-spacing:.04em}.project-sidebar-header-actions{display:flex;gap:.375rem}.project-sidebar-new,.project-sidebar-import{font:inherit;font-size:.8125rem;border:1px solid #c0c0c0;border-radius:4px;background:#fff;color:inherit;padding:.25rem .5rem;cursor:pointer;white-space:nowrap}.project-sidebar-new:hover,.project-sidebar-new:focus-visible{background:#4a90e2;border-color:#3a7fd0;color:#fff;outline:none}.project-sidebar-import:hover,.project-sidebar-import:focus-visible{background:#f0f0f0;outline:none}.project-sidebar-file-input{display:none}.project-sidebar-list{list-style:none;margin:0;padding:0;flex:1}.project-sidebar-empty{padding:1rem;margin:0;color:#888;font-size:.875rem;text-align:center}@media(max-width:768px){.project-sidebar{height:100%;border-right:none;border-bottom:none}}@media(prefers-color-scheme:dark){.project-sidebar{background:#1f1f1f;border-right-color:#333}.project-sidebar-header{border-bottom-color:#333}.project-sidebar-title{color:#aaa}.project-sidebar-new,.project-sidebar-import{background:#2a2a2a;border-color:#555}.project-sidebar-import:hover,.project-sidebar-import:focus-visible{background:#3a3a3a}.project-sidebar-empty{color:#888}}.react-flow{direction:ltr;--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: rgba(255, 255, 255, .5);--xy-minimap-background-color-default: #fff;--xy-minimap-mask-background-color-default: rgba(240, 240, 240, .6);--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: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(0, 0, 0, .08);--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: rgba(0, 89, 220, .08);--xy-selection-border-default: 1px dotted rgba(0, 89, 220, .8);--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 rgba(0, 0, 0, .08);--xy-edge-label-background-color-default: #ffffff;--xy-edge-label-color-default: inherit;--xy-resize-background-color-default: #3367d9}.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: rgba(150, 150, 150, .25);--xy-minimap-background-color-default: #141414;--xy-minimap-mask-background-color-default: rgba(60, 60, 60, .6);--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: rgba(240, 240, 240, .25);--xy-node-boxshadow-hover-default: 0 1px 4px 1px rgba(255, 255, 255, .08);--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: rgba(200, 200, 220, .08);--xy-selection-border-default: 1px dotted rgba(200, 200, 220, .8);--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 rgba(0, 0, 0, .08);--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{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1}.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{overflow:visible;position:absolute;pointer-events:none}.react-flow__edge{pointer-events:visibleStroke}.react-flow__edge.selectable{cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:dashdraw .5s linear infinite}.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;-moz-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:dashdraw .5s linear infinite}svg.react-flow__connectionline{z-index:1001;overflow:visible;position:absolute}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:default}.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:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;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%}.react-flow__handle.connectingfrom{pointer-events:all}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:0;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{position:absolute;z-index:5;margin:15px}.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{font-size:10px;background:var(--xy-attribution-background-color, var(--xy-attribution-background-color-default));padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;left:0;top:0}.react-flow__viewport-portal{position:absolute;width:100%;height:100%;left:0;top:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}.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{display:flex;flex-direction:column;box-shadow:var(--xy-controls-box-shadow, var(--xy-controls-box-shadow-default))}.react-flow__controls.horizontal{flex-direction:row}.react-flow__controls-button{display:flex;justify-content:center;align-items:center;height:26px;width:26px;padding:4px;border:none;background:var(--xy-controls-button-background-color, var(--xy-controls-button-background-color-default));border-bottom:1px solid var( --xy-controls-button-border-color-props, var(--xy-controls-button-border-color, var(--xy-controls-button-border-color-default)) );color:var( --xy-controls-button-color-props, var(--xy-controls-button-color, var(--xy-controls-button-color-default)) );cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px;fill:currentColor}.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{padding:10px;border-radius:var(--xy-node-border-radius, var(--xy-node-border-radius-default));width:150px;font-size:12px;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))}.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{width:5px;height:5px;border:1px solid #fff;border-radius:1px;background-color:var(--xy-resize-background-color, var(--xy-resize-background-color-default));translate:-50% -50%}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.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-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.react-flow__edge-textbg{fill:var(--xy-edge-label-background-color, var(--xy-edge-label-background-color-default))}.react-flow__edge-text{fill:var(--xy-edge-label-color, var(--xy-edge-label-color-default))}.graph-export-menu{position:relative}.graph-export-toggle{font:inherit;font-size:.875rem;padding:.375rem .875rem;border:1px solid #c0c0c0;border-radius:4px;background:#fff;color:inherit;cursor:pointer}.graph-export-toggle:hover:not(:disabled){background:#f0f0f0}.graph-export-toggle:focus-visible:not(:disabled){background:#f0f0f0;outline:2px solid #4a90e2;outline-offset:1px}.graph-export-toggle:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.graph-export-popup{position:absolute;top:calc(100% + 4px);right:0;z-index:10;min-width:120px;background:#fff;border:1px solid #d0d0d0;border-radius:4px;box-shadow:0 4px 12px #0000001f;display:flex;flex-direction:column}.graph-export-popup button{font:inherit;text-align:left;padding:.5rem .875rem;border:0;background:transparent;cursor:pointer;color:inherit}.graph-export-popup button:hover{background:#eaf3ff}.graph-export-popup button:focus-visible{background:#eaf3ff;outline:2px solid #4a90e2;outline-offset:-2px}@media(prefers-color-scheme:dark){.graph-export-toggle{background:#2a2a2a;border-color:#555}.graph-export-toggle:hover:not(:disabled),.graph-export-toggle:focus-visible:not(:disabled){background:#3a3a3a}.graph-export-toggle:disabled{background:#2a2a2a;color:#666}.graph-export-popup{background:#2a2a2a;border-color:#444}.graph-export-popup button:hover,.graph-export-popup button:focus-visible{background:#4a90e22e}}.person-node{width:160px;min-height:60px;padding:.5rem .75rem;border:1px solid #c0c0c0;border-radius:8px;background:#fff;color:#1a1a1a;box-shadow:0 2px 4px #0000000f;display:flex;flex-direction:column;gap:.25rem;font-size:.875rem}.person-node-name{font-weight:600;word-break:break-word;text-align:center}.person-node-tags{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.25rem;justify-content:center}.person-node-tag{font-size:.6875rem;padding:.0625rem .375rem;border-radius:8px;background:#eaf3ff;color:#2a5a90;border:1px solid #b3d4f5;white-space:nowrap;max-width:6rem;overflow:hidden;text-overflow:ellipsis}.person-node-tag-more{background:#f0f0f0;color:#555;border-color:#d8d8d8}.person-node-handle{width:6px;height:6px;background:silver;border:0;visibility:hidden}@media(prefers-color-scheme:dark){.person-node{background:#2a2a2a;border-color:#555;color:#f0f0f0}.person-node-tag{background:#4a90e22e;color:#d0e0f5;border-color:#4a90e266}.person-node-tag-more{background:#3a3a3a;color:#ccc;border-color:#555}}.relationship-graph{margin-bottom:2rem}.relationship-graph-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.75rem}.relationship-graph-title{font-size:1.25rem;margin:0}.relationship-graph-canvas{width:100%;height:50vh;min-height:360px;border:1px solid #d0d0d0;border-radius:8px;background:#fafafa;overflow:hidden}.relationship-graph-canvas .react-flow__node{will-change:transform}.relationship-graph-empty{margin:1rem 0;color:#666;text-align:center;font-size:.95rem}.relation-edge-badge{display:inline-flex;align-items:center;gap:.125rem;padding:.0625rem .375rem;border-radius:10px;background:#fff;border:1px solid;font-size:.6875rem;font-weight:600;-webkit-user-select:none;user-select:none;white-space:nowrap}.relation-edge-good{color:#2a6db8;border-color:#b3d4f5;background:#f0f7ff}.relation-edge-bad{color:#b53030;border-color:#f0bcbc;background:#fff5f5}.relation-edge-symbol{font-weight:700;font-size:.875rem;line-height:1}.relation-edge-intensity{font-variant-numeric:tabular-nums}@media(max-width:768px){.relationship-graph-canvas{height:65vh;min-height:300px}}@media(prefers-color-scheme:dark){.relationship-graph-canvas{background:#1f1f1f;border-color:#444}.relationship-graph-empty{color:#aaa}.relation-edge-good{background:#1c3050;color:#a5c8ee;border-color:#2a4a70}.relation-edge-bad{background:#3a1414;color:#f3a8a8;border-color:#5a2020}}.relation-form-dialog{min-width:min(520px,calc(100vw - 2rem))}.relation-form-dialog textarea,.relation-form-dialog select{font:inherit;padding:.5rem .625rem;border:1px solid #c0c0c0;border-radius:4px;background:#fff;color:inherit}.relation-form-dialog textarea{resize:vertical;min-height:3rem}.relation-form-dialog textarea:focus,.relation-form-dialog select:focus{outline:2px solid #4a90e2;outline-offset:1px}.relation-form-pair{display:flex;align-items:flex-end;gap:.5rem;margin-bottom:1rem}.relation-form-pair>.dialog-field{flex:1;margin-bottom:0}.relation-form-arrow{font-size:1.25rem;padding:0 .25rem;align-self:center;-webkit-user-select:none;user-select:none}.radio-row{display:flex;align-items:center;gap:.375rem;margin:.25rem 0}.radio-row input[type=radio]{margin:0}.sentiment-good{color:#2a6db8}.sentiment-bad{color:#b53030}.intensity-segments{display:flex;gap:.25rem;border:1px solid #c0c0c0;border-radius:4px;overflow:hidden;width:max-content}.intensity-seg{position:relative;display:flex;align-items:center;justify-content:center;min-width:2.5rem;padding:.375rem .5rem;cursor:pointer;background:#fff;border-right:1px solid #e0e0e0}.intensity-seg:last-child{border-right:0}.intensity-seg.is-active{background:#4a90e2;color:#fff}.intensity-seg input[type=radio]{position:absolute;opacity:0;pointer-events:none}.intensity-seg:hover:not(.is-active){background:#eaf3ff}.intensity-seg:focus-within{outline:2px solid #4a90e2;outline-offset:1px}@media(prefers-color-scheme:dark){.relation-form-dialog textarea,.relation-form-dialog select{background:#1a1a1a;border-color:#555}.intensity-segments{border-color:#555}.sentiment-good{color:#88b8e8}.sentiment-bad{color:#ff8a8a}.intensity-seg{background:#2a2a2a;border-right-color:#444}.intensity-seg:hover:not(.is-active){background:#4a90e22e}}.relation-item{display:flex;gap:1rem;align-items:flex-start;padding:.75rem 1rem;border:1px solid #e0e0e0;border-left:4px solid #ccc;border-radius:6px;background:#fff;margin-bottom:.5rem}.relation-item-good{border-left-color:#4a90e2}.relation-item-bad{border-left-color:#d34141}.relation-item-main{flex:1;min-width:0}.relation-item-line{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;font-size:.95rem}.relation-person{font-weight:600;word-break:break-word}.relation-arrow{font-size:1.125rem;color:#888;-webkit-user-select:none;user-select:none}.relation-sentiment-badge,.relation-intensity-badge{font-size:.75rem;padding:.0625rem .5rem;border-radius:10px;border:1px solid transparent}.relation-sentiment-good{background:#eaf3ff;color:#2a6db8;border-color:#b3d4f5}.relation-sentiment-bad{background:#fdecec;color:#b53030;border-color:#f0bcbc}.relation-intensity-badge{background:#f5f5f5;color:#555;border-color:#d8d8d8}.relation-note{margin:.375rem 0 0;font-size:.875rem;color:#555;white-space:pre-wrap;word-break:break-word}.relation-item-actions{display:flex;gap:.375rem;flex-shrink:0}.relation-item-actions button{font:inherit;font-size:.875rem;padding:.25rem .625rem;border:1px solid #c0c0c0;border-radius:4px;background:#f5f5f5;color:inherit;cursor:pointer}.relation-item-actions button:hover,.relation-item-actions button:focus-visible{background:#e0e0e0;outline:none}.relation-item-actions .relation-item-delete{color:#d34141;border-color:#d3a9a9}.relation-item-actions .relation-item-delete:hover,.relation-item-actions .relation-item-delete:focus-visible{background:#fdecec}@media(prefers-color-scheme:dark){.relation-item{background:#2a2a2a;border-color:#444}.relation-arrow{color:#aaa}.relation-sentiment-good{background:#4a90e22e;color:#a5c8ee;border-color:#4a90e266}.relation-sentiment-bad{background:#d341412e;color:#f3a8a8;border-color:#d3414166}.relation-intensity-badge{background:#3a3a3a;color:#ccc;border-color:#555}.relation-note{color:#bbb}.relation-item-actions button{background:#3a3a3a;border-color:#555}.relation-item-actions button:hover,.relation-item-actions button:focus-visible{background:#4a4a4a}.relation-item-actions .relation-item-delete{color:#ff8a8a;border-color:#6a3a3a}}.relations-view{max-width:720px}.relations-view-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.relations-view-title{font-size:1.25rem;margin:0}.relations-view-add{font:inherit;font-size:.875rem;padding:.375rem .875rem;border:1px solid #3a7fd0;border-radius:4px;background:#4a90e2;color:#fff;cursor:pointer;flex-shrink:0}.relations-view-add:hover:not(:disabled),.relations-view-add:focus-visible:not(:disabled){background:#3a7fd0;outline:none}.relations-view-add:disabled{background:silver;border-color:silver;color:#fff;cursor:not-allowed}.relations-view-empty,.relations-view-hint{margin:1rem 0;color:#777;text-align:center;font-size:.95rem}.relations-view-list{list-style:none;margin:0;padding:0}@media(prefers-color-scheme:dark){.relations-view-empty,.relations-view-hint{color:#aaa}.relations-view-add:disabled{background:#444;border-color:#444;color:#777}}
