.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))}:root{--bg-primary: #ffffff;--bg-secondary: #f9fafb;--bg-tertiary: #f3f4f6;--bg-error: #fee2e2;--bg-warning: #fffbeb;--bg-danger: #fef2f2;--bg-hover: #e5e7eb;--bg-active: #d1d5db;--border-color: #e5e7eb;--border-color-strong: #d1d5db;--text-primary: #111827;--text-secondary: #374151;--text-tertiary: #6b7280;--text-muted: #9ca3af;--text-error: #b91c1c;--text-warning: #b45309;--text-danger: #991b1b;--shadow-color: rgba(0, 0, 0, .1);--shadow-strong: rgba(0, 0, 0, .25);--code-bg: #f3f4f6;--overlay-bg: rgba(0, 0, 0, .5);--accent-blue: #3b82f6;--accent-blue-hover: #2563eb;--node-border: #000000;--entity-assets-bg: #fef08a;--entity-assets-border: #fbbf24;--entity-assets-text: #854d0e;--entity-components-bg: #fef08a;--entity-components-border: #fbbf24;--entity-components-text: #854d0e;--entity-dataflows-bg: #bfdbfe;--entity-dataflows-border: #60a5fa;--entity-dataflows-text: #1e3a8a;--entity-boundaries-bg: #fecaca;--entity-boundaries-border: #dc2626;--entity-boundaries-text: #7f1d1d;--entity-threats-bg: #fecaca;--entity-threats-border: #dc2626;--entity-threats-text: #7f1d1d;--entity-controls-bg: #bbf7d0;--entity-controls-border: #22c55e;--entity-controls-text: #15803d;--component-color-yellow-bg: #fef08a;--component-color-blue-bg: #bfdbfe;--component-color-green-bg: #bbf7d0;--component-color-red-bg: #fecaca;--component-color-orange-bg: #fed7aa;--component-color-purple-bg: #e3b6fd;--yaml-bg: #f9fafb;--yaml-header-bg: #e5e7eb;--yaml-border: #d1d5db;--yaml-text: #374151;--yaml-code: #111827;--yaml-line-numbers-bg: #f3f4f6;--yaml-line-number: #9ca3af;--yaml-button-bg: #d1d5db;--yaml-button-hover: #9ca3af;--yaml-disabled-bg: #e5e7eb;--yaml-disabled-text: #9ca3af;--yaml-button-apply-bg: #22c55e;--yaml-button-apply-hover: #16a34a;--yaml-button-apply-text: white;--yaml-button-regenerate-bg: #3b82f6;--yaml-button-regenerate-hover: #2563eb;--yaml-button-regenerate-text: white}[data-theme=dark]{--bg-primary: #1f2937;--bg-secondary: #111827;--bg-tertiary: #283548;--bg-hover: #4b5563;--bg-active: #6b7280;--bg-error: #7f1d1d;--bg-warning: #78350f;--bg-danger: #7f1d1d;--border-color: #374151;--border-color-strong: #4b5563;--text-primary: #f9fafb;--text-secondary: #e5e7eb;--text-tertiary: #9ca3af;--text-muted: #6b7280;--text-error: #fecaca;--text-warning: #fbbf24;--text-danger: #fecaca;--shadow-color: rgba(0, 0, 0, .3);--shadow-strong: rgba(0, 0, 0, .5);--code-bg: #374151;--overlay-bg: rgba(0, 0, 0, .7);--accent-blue: #3c6daa;--accent-blue-hover: #6099f3;--node-border: #d7c9c9;--entity-assets-bg: #854d0e;--entity-assets-border: #a16207;--entity-assets-text: #fef08a;--entity-components-bg: #854d0e;--entity-components-border: #a16207;--entity-components-text: #fef08a;--entity-dataflows-bg: #1e3a8a;--entity-dataflows-border: #1e40af;--entity-dataflows-text: #bfdbfe;--entity-boundaries-bg: #9a2929;--entity-boundaries-border: #ba2f2f;--entity-boundaries-text: #d82c2c;--entity-threats-bg: #7f1d1d;--entity-threats-border: #ab2424;--entity-threats-text: #fecaca;--entity-controls-bg: #166534;--entity-controls-border: #15803d;--entity-controls-text: #bbf7d0;--component-color-yellow-bg: #a16207;--component-color-blue-bg: #1e3a8a;--component-color-green-bg: #14532d;--component-color-red-bg: #7f1d1d;--component-color-orange-bg: #7c2d12;--component-color-purple-bg: #6b21a8;--yaml-bg: #111827;--yaml-header-bg: #1f2937;--yaml-border: #374151;--yaml-text: #e5e7eb;--yaml-code: #f9fafb;--yaml-line-numbers-bg: #1a202c;--yaml-line-number: #6b7280;--yaml-button-bg: #374151;--yaml-button-hover: #4b5563;--yaml-disabled-bg: #374151;--yaml-disabled-text: #6b7280;--yaml-button-apply-bg: #047857;--yaml-button-apply-hover: #065f46;--yaml-button-apply-text: white;--yaml-button-regenerate-bg: #0369a1;--yaml-button-regenerate-hover: #075985;--yaml-button-regenerate-text: white}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-track{background:var(--bg-secondary)}*::-webkit-scrollbar-thumb{background:var(--border-color-strong);border-radius:5px}*::-webkit-scrollbar-thumb:hover{background:var(--bg-hover)}*::-webkit-scrollbar-corner{background:var(--bg-secondary)}*{scrollbar-width:thin;scrollbar-color:var(--border-color-strong) var(--bg-secondary)}.app-container{display:flex;flex-direction:column;width:100vw;height:100vh;position:relative;background:var(--bg-secondary)}.app-container.selecting{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.app-loading{display:flex;align-items:center;justify-content:center;width:100vw;height:100vh;background:var(--bg-secondary);color:var(--text-primary);font-size:16px}.modal-overlay{position:fixed;inset:0;background:var(--overlay-bg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;display:flex;align-items:center;justify-content:center}.modal-content{background:var(--bg-primary);border-radius:12px;padding:32px;max-width:500px;width:90%;box-shadow:0 25px 50px -12px var(--shadow-strong);border:1px solid var(--border-color)}.modal-content h2{margin:0 0 16px;font-size:22px;font-weight:600;color:var(--text-primary)}.modal-content p{margin:0 0 20px;font-size:14px;color:var(--text-secondary)}.draft-info{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;padding:16px;margin-bottom:24px}.draft-name{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.draft-time{font-size:13px;color:var(--text-secondary)}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.button{padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.button-primary{background:var(--accent-blue);color:#fff}.button-primary:hover{background:var(--accent-blue-hover)}.button-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.button-secondary:hover{background:var(--bg-hover)}.drop-overlay{position:fixed;inset:0;background:#3b82f626;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1000;display:flex;align-items:center;justify-content:center;pointer-events:none}.drop-overlay-content{display:flex;flex-direction:column;align-items:center;gap:16px;padding:48px 64px;background:var(--bg-primary);border:3px dashed #3b82f6;border-radius:16px;box-shadow:0 25px 50px -12px var(--shadow-strong)}.drop-overlay-icon{font-size:64px}.drop-overlay-text{font-size:18px;font-weight:600;color:#3b82f6}.confirm-dialog-overlay{position:fixed;inset:0;background:var(--overlay-bg);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1001;display:flex;align-items:center;justify-content:center}.confirm-dialog{background:var(--bg-primary);border-radius:12px;padding:24px;max-width:420px;width:90%;box-shadow:0 25px 50px -12px var(--shadow-strong)}.confirm-dialog-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.confirm-dialog-header h3{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.confirm-dialog-icon{font-size:24px}.confirm-dialog-message{margin:0 0 24px;font-size:14px;color:var(--text-tertiary);line-height:1.5}.confirm-dialog-message strong{color:var(--text-primary)}.confirm-dialog-actions{display:flex;gap:12px;justify-content:flex-end}.confirm-dialog-button{padding:10px 20px;font-size:14px;font-weight:500;border:none;border-radius:8px;cursor:pointer;transition:all .2s}.confirm-dialog-button.cancel{background:var(--bg-tertiary);color:var(--text-secondary)}.confirm-dialog-button.cancel:hover{background:var(--bg-hover)}.confirm-dialog-button.confirm{background:#3b82f6;color:#fff}.confirm-dialog-button.confirm:hover{background:#2563eb}.content-wrapper{display:flex;flex:1;min-height:0;position:relative}.diagram-section{flex:1;min-width:0;position:relative}.diagram-section .react-flow__container{width:100%;height:100%}.tables-container{min-width:0;overflow-y:auto;overflow-x:hidden;padding:10px 20px 10px 10px;border-right:1px solid var(--border-color);background:var(--bg-secondary);position:relative;display:flex;flex-direction:column;flex-shrink:0}.tables-container-content{padding-left:10px}.tables-divider{margin-top:32px}.tables-container.yaml-view{padding:0;overflow:hidden}.yaml-editor{flex:1;width:100%}body,#root{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;font-size:14px;color:var(--text-primary);margin:0;padding:0;overflow:hidden;background:var(--bg-secondary)}*{box-sizing:border-box}h1,h2,h3,h4,h5{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;margin-top:0}.collapsible-section-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .2s ease;border-radius:4px}.collapsible-section-header:hover{color:var(--text-tertiary)}.collapsible-section-header .collapse-arrow{font-size:16px;color:var(--text-secondary);margin-left:8px;padding-right:6px;transition:transform .2s ease}.collapsible-section-header:hover .collapse-arrow{color:var(--text-tertiary)}.collapsible-section-header .collapse-arrow.expanded{transform:rotate(90deg)}.title-section{margin-bottom:16px}.threat-model-title{margin-bottom:8px}.threat-model-title .always-editable-cell-input{font-size:28px;font-weight:700;color:var(--text-primary);padding:8px 12px;min-height:48px;border-radius:6px;background-color:transparent;transition:all .2s ease}.threat-model-title .always-editable-cell-input:hover{background-color:var(--bg-secondary);border-color:var(--border-color-strong)}.threat-model-title .always-editable-cell-input:focus{background-color:var(--bg-primary);border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f61a}.threat-model-description .always-editable-textarea-input{font-size:15px;color:var(--text-secondary);line-height:1.6;padding:8px 12px;min-height:60px;border-radius:6px;background-color:transparent;transition:all .2s ease}.threat-model-description .always-editable-textarea-input:hover{background-color:var(--bg-secondary);border-color:var(--border-color-strong)}.threat-model-description .always-editable-textarea-input:focus{background-color:var(--bg-primary);border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f61a}.threat-model-participants{margin-top:4px}.threat-model-github-fields{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:16px}.threat-model-github-field{display:flex;flex-direction:column;gap:4px}.github-field-label{font-size:11px;font-weight:600;padding:6px 8px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.threat-model-github-field .editable-cell{font-size:13px;color:var(--text-secondary);padding:6px 8px;background:var(--bg-secondary);border-radius:4px;min-height:24px}.threat-model-github-field .editable-cell-input{font-size:13px;color:var(--text-primary);padding:6px 8px;width:100%;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px}.tables-container h2{margin:0 0 8px;font-size:20px;font-weight:600;color:var(--text-primary)}.table-content{margin-bottom:16px}.table-header{display:flex;align-items:center;gap:8px;width:100%;padding:12px 0;font-size:16px;font-weight:600;color:var(--text-secondary)}.header-help-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;color:var(--text-tertiary);font-size:11px;font-weight:600;cursor:help;transition:all .15s ease;-webkit-user-select:none;user-select:none;position:relative}.header-help-icon:hover{background:var(--primary);color:#fff;transform:scale(1.1)}.header-help-icon:after{content:attr(data-tooltip);position:absolute;left:50%;top:calc(100% + 4px);background:#000000e6;color:#fff;padding:6px 10px;border-radius:6px;font-size:12px;font-weight:400;white-space:normal;max-width:300px;width:max-content;pointer-events:none;opacity:0;transition:opacity .15s ease;z-index:1000}@media(max-width:768px){.header-help-icon:after{max-width:calc(100vw - 40px);left:auto;right:0;transform:none}}.header-help-icon:hover:after{opacity:1;transition-delay:.1s}.table-badge{margin-left:auto;padding:2px 8px;background:var(--bg-hover);border-radius:10px;font-size:12px;font-weight:500;color:var(--text-tertiary)}.table-content .table-container{margin-top:4px;margin-bottom:0}.table-container{margin-bottom:32px}.table-container h3{margin:0 0 12px;font-size:16px;font-weight:600;color:var(--text-secondary)}.table-container h4{margin:0 0 16px;font-size:13px;font-weight:500;color:var(--text-tertiary)}.add-row-buttons{display:flex;gap:8px}.add-row-button{display:block;width:100%;padding:8px 12px;margin-top:8px;background:transparent;border:1px dashed var(--border-color-strong);border-radius:6px;color:var(--text-tertiary);font-size:13px;cursor:pointer;transition:all .15s ease}.add-row-button:hover{background:var(--bg-secondary);border-color:#10b981;color:#10b981}.add-row-button.add-row-assets:hover,.add-row-button.add-row-components:hover{background:#fef9c3;border-color:#ca8a04;color:#854d0e}.add-row-button.add-row-threats:hover{background:#fee2e2;border-color:#dc2626;color:#7f1d1d}.add-row-button.add-row-controls:hover{background:#dcfce7;border-color:#16a34a;color:#15803d}[data-theme=dark] .add-row-button.add-row-assets:hover,[data-theme=dark] .add-row-button.add-row-components:hover{background:#854d0e;border-color:#ca8a04;color:#fef9c3}[data-theme=dark] .add-row-button.add-row-threats:hover{background:#7f1d1d;border-color:#dc2626;color:#fecaca}[data-theme=dark] .add-row-button.add-row-controls:hover{background:#166534;border-color:#16a34a;color:#dcfce7}.row-action-button{display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:none;border-radius:4px;cursor:pointer;font-size:16px;font-weight:600;transition:all .15s ease}.row-action-button.remove-button{background:transparent;color:var(--text-muted);opacity:0}tr:hover .row-action-button.remove-button{opacity:1}.row-action-button.remove-button:hover{background:#fee2e2;color:#dc2626}.action-column{width:30px;text-align:center}th.action-column,td.action-column{padding:5px 4px}table{width:100%;border-collapse:collapse;background:var(--bg-primary);border:1px solid var(--border-color);font-size:13px;table-layout:fixed}thead{background:var(--bg-tertiary)}thead.header-assets{background:#fef08a}thead.header-assets th{color:#854d0e}thead.header-dataflows{background:#bfdbfe}thead.header-dataflows th{color:#1e3a8a}thead.header-threats{background:#fecaca}thead.header-threats th{color:#7f1d1d}thead.header-controls{background:#bbf7d0}thead.header-controls th{color:#15803d}thead.header-components{background:#fef08a}thead.header-components th{color:#854d0e}thead.header-boundaries{background:#fecaca}thead.header-boundaries th{color:#dc2626}[data-theme=dark] thead.header-assets{background:#854d0e}[data-theme=dark] thead.header-assets th{color:#fef08a}[data-theme=dark] thead.header-dataflows{background:#1e3a8a}[data-theme=dark] thead.header-dataflows th{color:#bfdbfe}[data-theme=dark] thead.header-threats{background:#7f1d1d}[data-theme=dark] thead.header-threats th{color:#fecaca}[data-theme=dark] thead.header-controls{background:#166534}[data-theme=dark] thead.header-controls th{color:#bbf7d0}[data-theme=dark] thead.header-components{background:#854d0e}[data-theme=dark] thead.header-components th{color:#fef08a}[data-theme=dark] thead.header-boundaries{background:#991b1b}[data-theme=dark] thead.header-boundaries th{color:#fecaca}th{padding:10px 0 10px 12px;text-align:left;font-weight:600;color:var(--text-secondary);border-bottom:2px solid var(--border-color)}td{padding:10px 0 10px 6px;border-bottom:1px solid var(--border-color);color:var(--text-primary)}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--bg-tertiary)}code{background:var(--code-bg);padding:2px 6px;border-radius:3px;font-family:Courier New,monospace;font-size:12px;color:var(--text-secondary)}.architecture-section{border:1px solid var(--border-color);border-radius:8px;background:var(--bg-tertiary);margin-top:6px}.architecture-toggle{display:flex;align-items:center;gap:8px;width:100%;padding:12px 16px;background:none;border:none;cursor:pointer;font-size:12px;font-weight:600;color:var(--text-tertiary);text-align:left;transition:background-color .15s ease}.architecture-toggle:hover{background:var(--bg-hover)}.architecture-toggle-icon{font-size:8px;color:var(--text-tertiary);transition:transform .2s ease}.architecture-toggle-icon.expanded{transform:rotate(90deg)}.architecture-badge{margin-left:auto;padding:2px 8px;background:var(--bg-hover);border-radius:10px;font-size:12px;font-weight:500;color:var(--text-tertiary)}.architecture-content{padding:0 16px 16px;border-top:1px solid var(--border-color)}.architecture-content .table-container,.architecture-content .table-container:first-child{margin-top:16px}[data-theme=dark] .react-flow__background{background-color:#111827!important}[data-theme=dark] .react-flow__controls{background:var(--bg-tertiary);border-color:var(--border-color);box-shadow:0 2px 6px var(--shadow-color)}[data-theme=dark] .react-flow__controls-button{background:var(--bg-primary);border-color:var(--border-color);fill:var(--text-secondary)}[data-theme=dark] .react-flow__controls-button:hover{background:var(--bg-hover)}[data-theme=dark] .react-flow__minimap{background:var(--bg-tertiary)}[data-theme=dark] .react-flow__edge-path{stroke:var(--text-tertiary)}[data-theme=dark] .react-flow__edge-text{fill:var(--text-primary)}.react-flow__selection{background:#3b82f61a;border:1px dashed #3b82f6}[data-theme=dark] .react-flow__selection{background:#60a5fa26;border:1px dashed #60a5fa}[data-theme=dark] .react-flow__attribution{background:#1f2937cc!important;color:var(--text-secondary)!important;border-color:var(--border-color)!important}@media(max-width:600px){.navbar-button{width:44px}.tab-panel-tables{padding:6px}.threat-model-title .always-editable-cell-input{font-size:22px;padding:6px 10px;min-height:40px}.threat-model-description .always-editable-textarea-input{font-size:14px;padding:6px 10px;min-height:50px}.tables-section h2{font-size:18px;margin:0 0 8px}}.always-editable-cell-input{display:block;width:100%;padding:8px;border:1px solid transparent;background-color:transparent;font-size:14px;line-height:1.4;font-family:inherit;color:inherit;box-sizing:border-box;transition:border-color .15s ease,background-color .15s ease;resize:none;overflow:hidden;min-height:36px}.always-editable-cell-input:hover{border-color:var(--border-color-strong);border-radius:3px}.dragging .always-editable-cell-input:hover{border-color:transparent}.always-editable-cell-input:focus{outline:none;border-color:var(--accent-blue);background-color:var(--bg-primary);border-radius:3px}.always-editable-cell-input::placeholder{color:var(--text-primary)}.always-editable-cell-input:focus::placeholder{opacity:.5}.always-editable-textarea-input{display:block;width:100%;padding:8px;border:1px solid transparent;background-color:transparent;font-size:14px;line-height:1.4;font-family:inherit;color:inherit;box-sizing:border-box;resize:none;overflow:hidden;min-height:36px;transition:border-color .15s ease,background-color .15s ease}.always-editable-textarea-input:hover{border-color:var(--border-color-strong);border-radius:3px}.dragging .always-editable-textarea-input:hover{border-color:transparent}.always-editable-textarea-input:focus{outline:none;border-color:var(--accent-blue);background-color:var(--bg-primary);border-radius:3px}.always-editable-textarea-input::placeholder{color:var(--text-primary)}.always-editable-textarea-input:focus::placeholder{opacity:.5}.participants-input-container{display:flex;flex-wrap:wrap;align-items:center;gap:4px;padding:6px 10px;min-height:36px;border:1px solid transparent;border-radius:6px;background-color:transparent;transition:all .2s ease;cursor:text;box-sizing:border-box;margin-bottom:32px}.participants-input-container:hover{background-color:var(--bg-secondary);border-color:var(--border-color-strong)}.participants-input-container:focus-within{background-color:var(--bg-primary);border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f61a}.participant-tag{display:inline-flex;align-items:center;gap:2px;padding:2px 4px 2px 8px;background-color:var(--participant-tag-bg);color:var(--participant-tag-text);border-radius:3px;font-size:13px;font-weight:500;white-space:nowrap;max-width:200px;overflow:hidden;text-overflow:ellipsis}.participant-color-0{--participant-tag-bg: #dbeafe;--participant-tag-text: #1e40af}.participant-color-1{--participant-tag-bg: #fef08a;--participant-tag-text: #854d0e}.participant-color-2{--participant-tag-bg: #bbf7d0;--participant-tag-text: #166534}.participant-color-3{--participant-tag-bg: #fecaca;--participant-tag-text: #991b1b}.participant-color-4{--participant-tag-bg: #e9d5ff;--participant-tag-text: #6b21a8}.participant-color-5{--participant-tag-bg: #fed7aa;--participant-tag-text: #9a3412}[data-theme=dark] .participant-color-0{--participant-tag-bg: #1e3a8a;--participant-tag-text: #bfdbfe}[data-theme=dark] .participant-color-1{--participant-tag-bg: #854d0e;--participant-tag-text: #fef08a}[data-theme=dark] .participant-color-2{--participant-tag-bg: #166534;--participant-tag-text: #bbf7d0}[data-theme=dark] .participant-color-3{--participant-tag-bg: #7f1d1d;--participant-tag-text: #fecaca}[data-theme=dark] .participant-color-4{--participant-tag-bg: #581c87;--participant-tag-text: #e9d5ff}[data-theme=dark] .participant-color-5{--participant-tag-bg: #7c2d12;--participant-tag-text: #fed7aa}.participant-tag-text{overflow:hidden;text-overflow:ellipsis}.participant-tag-remove{border:none;background:none;color:var(--participant-tag-text);cursor:pointer;font-size:16px;line-height:1;padding:0 2px;margin:0;border-radius:2px;transition:background-color .2s;flex-shrink:0}.participant-tag-remove:hover{background-color:#0000001a}.participants-text-input{border:none;outline:none;background:transparent;font-size:14px;color:var(--text-secondary);padding:2px 0;min-width:120px;flex:1;font-family:inherit}.participants-text-input::placeholder{color:var(--text-primary)}.participants-text-input:focus::placeholder{opacity:.5}.always-editable-type-cell{position:relative;width:100%;outline:none;vertical-align:top}.type-display{width:100%;padding:8px;border-radius:3px;line-height:1.4;border:1px solid transparent;background-color:transparent;color:inherit;font-size:14px;font-family:inherit;cursor:pointer;display:flex;justify-content:space-between;align-items:center;-webkit-user-select:none;user-select:none;box-sizing:border-box}.type-display:hover{border:1px solid var(--border-color-strong)}.always-editable-type-cell:focus .type-display{outline:none;border-color:var(--accent-blue);background-color:var(--bg-primary);border-radius:3px}.type-arrow{font-size:10px;color:#666;margin-left:8px}.type-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:2px;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;box-shadow:0 4px 6px #0000001a;z-index:1000;max-height:200px;overflow-y:auto}.type-option{padding:8px 12px;cursor:pointer;font-size:14px;transition:background-color .1s}.type-option:hover,.type-option.highlighted{background-color:var(--bg-secondary, #f3f4f6)}.type-option.selected{background-color:var(--bg-hover);font-weight:500}.editable-picker-wrapper{outline:none;position:relative;width:100%;display:block;min-height:36px;box-sizing:border-box;border:1px solid transparent;border-radius:3px}.editable-picker-wrapper:hover{border-color:var(--border-color-strong)}.dragging .editable-picker-wrapper:hover{border-color:transparent}.editable-picker-wrapper:focus{border:1px solid var(--accent-blue);background-color:var(--bg-primary)}.picker-tags-display{display:flex;flex-wrap:wrap;gap:4px;padding:7px;min-height:36px;cursor:pointer;border-radius:3px;border:1px solid transparent;box-sizing:border-box;transition:background-color .2s,border-color .15s ease}.picker-readonly-wrapper{display:flex;flex-wrap:wrap;gap:4px;padding:7px;min-height:36px}.picker-tag-readonly{display:inline-flex;align-items:center;padding:2px 8px;margin:0;background-color:var(--picker-default-bg);color:var(--picker-default-text);border-radius:3px;font-size:12px;font-weight:500}.picker-tag-readonly.picker-variant-default{background-color:var(--entity-components-bg);color:var(--entity-components-text)}.picker-tag-readonly.picker-variant-assets{background-color:var(--entity-assets-bg);color:var(--entity-assets-text)}.picker-tag-readonly.picker-variant-threats{background-color:var(--entity-threats-bg);color:var(--entity-threats-text)}.picker-tag-readonly.picker-variant-controls{background-color:var(--entity-controls-bg);color:var(--entity-controls-text)}.picker-tag-readonly.picker-variant-components{background-color:var(--entity-components-bg);color:var(--entity-components-text)}.picker-tag-readonly.picker-variant-dataflows{background-color:var(--entity-dataflows-bg);color:var(--entity-dataflows-text)}.picker-tags-container{position:relative;width:100%;min-height:36px;box-sizing:border-box}.picker-tags{display:flex;flex-wrap:wrap;gap:4px;padding:7px;border:1px solid var(--accent-blue);background-color:var(--bg-primary);border-radius:3px;min-height:36px;box-sizing:border-box}.picker-tag{display:inline-flex;align-items:center;gap:2px;padding:2px 4px 2px 8px;background-color:var(--entity-components-bg);color:var(--entity-components-text);border-radius:3px;font-size:12px;font-weight:500}.picker-tag.picker-variant-default{background-color:var(--entity-components-bg);color:var(--entity-components-text)}.picker-tag.picker-variant-assets{background-color:var(--entity-assets-bg);color:var(--entity-assets-text)}.picker-tag.picker-variant-threats{background-color:var(--entity-threats-bg);color:var(--entity-threats-text)}.picker-tag.picker-variant-controls{background-color:var(--entity-controls-bg);color:var(--entity-controls-text)}.picker-tag.picker-variant-components{background-color:var(--entity-components-bg);color:var(--entity-components-text)}.picker-tag.picker-variant-dataflows{background-color:var(--entity-dataflows-bg);color:var(--entity-dataflows-text)}.picker-variant-threats .picker-tags-container,.picker-variant-threats .picker-tags{border-color:var(--entity-threats-border)}.picker-variant-controls .picker-tags-container,.picker-variant-controls .picker-tags{border-color:var(--entity-controls-border)}.picker-variant-components .picker-tags-container,.picker-variant-components .picker-tags{border-color:var(--picker-components-bg)}.picker-variant-dataflows .picker-tags-container,.picker-variant-dataflows .picker-tags{border-color:var(--picker-dataflows-bg)}.picker-tag-remove{border:none;background:none;color:var(--picker-default-text);cursor:pointer;font-size:18px;line-height:1;padding:0 2px;margin:0;border-radius:2px;transition:background-color .2s}.picker-tag-remove:hover{background-color:#854d0e26}.picker-variant-threats .picker-tag-remove{color:var(--picker-threats-text)}.picker-variant-threats .picker-tag-remove:hover{background-color:#7f1d1d26}.picker-variant-controls .picker-tag-remove{color:var(--picker-controls-text)}.picker-variant-controls .picker-tag-remove:hover{background-color:#15803d26}.picker-variant-components .picker-tag-remove{color:var(--picker-components-text)}.picker-variant-components .picker-tag-remove:hover{background-color:#6b21a826}.picker-variant-dataflows .picker-tag-remove{color:var(--picker-dataflows-text)}.picker-variant-dataflows .picker-tag-remove:hover{background-color:#1e3a8a26}.picker-tag-input{border:none;outline:none;flex:1;padding:4px;font-size:13px;background:transparent;color:var(--text-primary, inherit)}.picker-tag-input::placeholder{color:var(--text-muted, #9ca3af)}.picker-suggestions{position:absolute;top:100%;left:0;right:0;margin-top:2px;background:var(--bg-primary, white);border:1px solid var(--border-color-strong, #d1d5db);border-radius:4px;box-shadow:0 4px 6px var(--shadow-color, rgba(0, 0, 0, .1));max-height:200px;overflow-y:auto;z-index:1000}.picker-suggestion-item{padding:8px 12px;cursor:pointer;font-size:13px;color:var(--text-primary, inherit);transition:background-color .2s}.picker-suggestion-item:hover,.picker-suggestion-item.highlighted{background-color:var(--bg-tertiary, #f3f4f6)}.picker-suggestion-item:active{background-color:var(--bg-hover, #e5e7eb)}.picker-create-new{font-weight:500;color:var(--color-primary);border-top:1px solid var(--color-border);margin-top:4px;padding-top:8px}.create-new-icon{display:inline-block;font-weight:700;margin-right:4px;font-size:1.1em}.picker-compact-display{display:flex;align-items:center;padding:2px;min-height:24px;cursor:pointer;border-radius:3px;transition:background-color .2s}.picker-compact-display:hover{background-color:var(--bg-hover, #f0f0f0)}.picker-count-badge{display:inline-flex;align-items:center;padding:3px 10px;background-color:var(--picker-default-bg);color:var(--picker-default-text);border-radius:12px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}.picker-count-badge:hover{transform:scale(1.05);box-shadow:0 2px 4px #0000001a}.picker-count-badge.picker-variant-default{background-color:var(--picker-default-bg);color:var(--picker-default-text)}.picker-count-badge.picker-variant-assets{background-color:var(--entity-assets-bg);color:var(--entity-assets-text)}.picker-count-badge.picker-variant-threats{background-color:var(--entity-threats-bg);color:var(--entity-threats-text)}.picker-count-badge.picker-variant-controls{background-color:var(--entity-controls-bg);color:var(--entity-controls-text)}.picker-count-badge.picker-variant-components{background-color:var(--entity-components-bg);color:var(--entity-components-text)}.picker-count-badge.picker-variant-dataflows{background-color:var(--entity-dataflows-bg);color:var(--entity-dataflows-text)}.drag-handle-container{width:0;padding:0;position:relative;overflow:visible}.drag-handle{position:absolute;left:-12px;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;padding:4px;border:none;background:var(--bg-primary);color:var(--text-tertiary);cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;opacity:0;transition:opacity .2s ease,color .2s ease;z-index:1;border-radius:4px;box-shadow:2px 0 4px #0000001a}.sortable-row:hover .drag-handle{opacity:1}.dragging .sortable-row:hover .drag-handle{opacity:0}.dragging .sortable-row:hover{background-color:transparent}.drag-handle:hover{color:var(--text-secondary)}.drag-handle:active{cursor:grabbing;color:var(--text-primary)}.drag-handle:focus-visible{opacity:1;outline:2px solid var(--focus-ring);outline-offset:2px;border-radius:4px}.sortable-row.is-dragging td{border-bottom:1px transparent!important}.sortable-row.is-dragging td>*{visibility:hidden}.sortable-row.is-dragging .drag-handle-container{visibility:visible}.dragging table{border-collapse:separate;border-spacing:0}.dragging tbody tr td{border-bottom:1px transparent!important}@media print{.drag-handle{display:none}}th.status-column-th,td.status-column-td{padding:0!important;text-align:center;width:60px}th.status-column-th{vertical-align:middle}.status-cell-wrapper{display:flex;align-items:center;justify-content:center;width:100%;height:100%;min-height:40px}.status-button-group{display:inline-flex;flex-direction:column;gap:0;border-radius:50%;overflow:hidden;border:1px solid var(--border-color);transition:all .15s}.status-button-group:focus-within{outline:none;box-shadow:0 0 0 1px var(--accent-blue, #3b82f6)}.status-button-group:has(.link-button-area){border-radius:15px;width:auto}.status-button-group.status-empty-group{background:transparent;color:#424242}.status-button-group.status-gray{background:#e0e0e0;color:#424242}.status-button-group.status-blue{background:#2196f3;color:#fff}.status-button-group.status-green{background:#4caf50;color:#fff}.status-button-group.status-yellow{background:#ffc107;color:#424242}.status-button-group.status-red{background:#f44336;color:#fff}[data-theme=dark] .status-button-group.status-empty-group{background:transparent;color:#e0e0e0}[data-theme=dark] .status-button-group.status-gray{background:#404040;color:#e0e0e0}[data-theme=dark] .status-button-group.status-blue{background:#1565c0;color:#fff}[data-theme=dark] .status-button-group.status-green{background:#2e7d32;color:#fff}[data-theme=dark] .status-button-group.status-yellow{background:#f57f17;color:#fff}[data-theme=dark] .status-button-group.status-red{background:#c62828;color:#fff}.status-button-group:hover{box-shadow:0 2px 6px #00000026}.status-button-area,.link-button-area{background:transparent;border:none;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;font-weight:500;transition:all .15s;color:inherit;line-height:1;min-height:24px;min-width:24px}.status-button-area{flex:1}.status-button-group:has(.link-button-area) .status-button-area{border-bottom:1px solid var(--border-color);padding:6px 8px 7px}.status-button-area:hover{background-color:var(--bg-hover, #f0f0f0)}.link-button-area{padding:6px 8px 7px}.link-button-area:hover{background-color:var(--bg-hover, #f0f0f0)}.status-empty-text{font-size:12px}.status-picker-portal{background:var(--bg-primary, white);border:2px solid var(--status-picker-border-color, #15803d);border-radius:6px;box-shadow:0 8px 16px var(--shadow-strong, rgba(0, 0, 0, .15));z-index:10000;padding:12px;max-height:80vh;overflow-y:auto;overflow-x:hidden;box-sizing:border-box;animation:statusPopupFadeIn .15s ease-out}.status-picker-portal.status-picker-controls{--status-picker-border-color: var(--entity-controls-border);--status-picker-title-color: var(--entity-controls-border);--status-picker-close-bg: var(--entity-controls-bg);--status-picker-close-text: var(--entity-controls-text)}.status-picker-portal.status-picker-threats{--status-picker-border-color: var(--entity-threats-border);--status-picker-title-color: var(--entity-threats-border);--status-picker-close-bg: var(--entity-threats-bg);--status-picker-close-text: var(--entity-threats-text)}@keyframes statusPopupFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.status-picker-portal.render-upward{animation:statusPopupFadeInUpward .15s ease-out}@keyframes statusPopupFadeInUpward{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.status-picker-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-color, #e5e7eb)}.status-picker-title{font-size:13px;font-weight:700;color:var(--status-picker-title-color, #15803d);margin:0}.status-picker-close{width:24px;height:24px;border:none;border-radius:50%;cursor:pointer;font-size:20px;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .2s;background:var(--status-picker-close-bg);color:var(--status-picker-close-text)}.status-picker-close:hover{background:var(--status-picker-close-text);color:var(--status-picker-close-bg)}.status-picker-content{display:flex;flex-direction:column;gap:12px}.status-picker-section{display:flex;flex-direction:column;gap:6px}.status-picker-section:last-child{margin-bottom:0}.status-picker-label{font-size:11px;font-weight:600;color:var(--text-tertiary, #6b7280);text-transform:uppercase;letter-spacing:.5px}.status-options{display:grid;grid-template-columns:1fr 1fr;gap:6px}.status-option{padding:8px 10px;border:1px solid transparent;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;text-align:center;display:flex;align-items:center;justify-content:center;gap:6px}.status-option:focus{outline:none;border-color:var(--accent-blue);border-radius:3px}.status-option.status-gray{background:#e0e0e0;color:#424242}.status-option.status-blue{background:#2196f3;color:#fff}.status-option.status-green{background:#4caf50;color:#fff}.status-option.status-yellow{background:#ffc107;color:#424242}.status-option.status-red{background:#f44336;color:#fff}[data-theme=dark] .status-option.status-gray{background:#404040;color:#e0e0e0}[data-theme=dark] .status-option.status-blue{background:#1565c0;color:#fff}[data-theme=dark] .status-option.status-green{background:#2e7d32;color:#fff}[data-theme=dark] .status-option.status-yellow{background:#f57f17;color:#fff}[data-theme=dark] .status-option.status-red{background:#c62828;color:#fff}.status-option:hover{opacity:.85;transform:translateY(-1px)}.status-option.selected{border-color:var(--text-primary, #333);box-shadow:0 0 0 2px #0000001a}.clear-status-btn{padding:4px 8px;background:transparent;border:1px solid var(--border-color, #ddd);border-radius:4px;font-size:11px;color:var(--text-muted, #666);cursor:pointer;transition:all .15s}.clear-status-btn:hover{background:var(--bg-hover, rgba(0, 0, 0, .05));border-color:var(--text-muted, #999)}.clear-status-btn:focus{outline:none;border-color:var(--accent-blue)}.link-input-group{display:flex;gap:4px}.link-input{flex:1;padding:6px 8px;border:1px solid var(--border-color, #ddd);border-radius:4px;font-size:12px;font-family:inherit;color:var(--text-primary, #333);background:var(--bg-primary, white);transition:border-color .15s}.link-input.error{border-color:#f44336}.link-input:focus{outline:none;border-color:var(--link-color, #1976d2);box-shadow:0 0 0 2px #1976d21a}.link-input.error:focus{border-color:#f44336;box-shadow:0 0 0 2px #f443361a}.link-error{font-size:11px;color:#f44336;margin-top:2px}.open-link-btn{padding:6px 10px;background:var(--bg-secondary, #f5f5f5);border:1px solid var(--border-color, #ddd);border-radius:4px;font-size:14px;cursor:pointer;transition:all .15s;color:var(--text-primary, #333)}.open-link-btn:hover{background:var(--bg-hover, rgba(0, 0, 0, .05));border-color:var(--link-color, #1976d2)}.status-note-textarea{width:100%;padding:8px;border:1px solid var(--border-color, #ddd);border-radius:4px;font-size:12px;font-family:inherit;color:var(--text-primary, #333);background:var(--bg-primary, white);transition:border-color .15s;min-height:80px;resize:none}.status-note-textarea:focus{outline:none;border-color:var(--link-color, #1976d2);box-shadow:0 0 0 2px #1976d21a}.status-note-textarea::placeholder{color:var(--text-muted, #999)}.github-issue-btn{width:100%;padding:8px 12px;background:#24292e;color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:6px}.github-issue-btn:hover{background:#1b1f23;transform:translateY(-1px);box-shadow:0 2px 4px #0003}.github-issue-btn:active{transform:translateY(0);box-shadow:0 1px 2px #0003}td.multi-picker-cell,td.affected-items-td,td.control-items-td{padding-right:0;padding-left:0}th.affected-items-th,th.control-items-th{padding-right:0;padding-left:0;text-align:center}.multi-picker-cell{position:relative;width:100%;outline:none}.multi-picker-cell:focus:has(.multi-picker-summary){outline:1px solid var(--accent-blue, #007acc);outline-offset:-2px;border-radius:3px;background-color:var(--bg-primary)}.multi-picker-compact{display:flex;align-items:center;justify-content:center;padding:4px 0;min-height:24px;cursor:pointer;border-radius:3px}.multi-picker-compact:has(.multi-picker-summary):hover{background-color:var(--bg-hover, #f0f0f0)}.dragging .multi-picker-compact:has(.multi-picker-summary):hover{background-color:transparent}.no-items-text{color:var(--text-muted, #999)}.multi-picker-empty-button{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;color:var(--text-primary);border-radius:50%;border:1px solid var(--border-color);background:transparent;transition:all .15s}.multi-picker-empty-button:hover{box-shadow:0 2px 6px #00000026;background-color:var(--bg-hover, #f0f0f0)}.dragging .multi-picker-empty-button:hover{box-shadow:none;background-color:transparent}.multi-picker-cell:focus .multi-picker-empty-button{box-shadow:0 0 0 1px var(--accent-blue, #3b82f6)}.multi-picker-summary{display:flex;flex-wrap:wrap;gap:4px;align-items:center;justify-content:center;max-width:60px;margin:0 auto}.multi-picker-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 8px;border-radius:12px;font-size:12px;font-weight:700;cursor:pointer;transition:all .2s}.multi-picker-badge:hover{transform:scale(1.1);box-shadow:0 2px 4px #00000026}.badge-components{background-color:var(--entity-components-bg);color:var(--entity-components-text)}.badge-dataflows{background-color:var(--entity-dataflows-bg);color:var(--entity-dataflows-text)}.badge-assets{background-color:var(--entity-assets-bg);color:var(--entity-assets-text)}.badge-threats{background-color:var(--entity-threats-bg);color:var(--entity-threats-text)}.badge-controls{background-color:var(--entity-controls-bg);color:var(--entity-controls-text)}.multi-picker-expanded{background:var(--bg-primary, white);border-radius:6px;box-shadow:0 8px 16px var(--shadow-strong, rgba(0, 0, 0, .15));z-index:10000;padding:12px;max-height:80vh;overflow-y:auto;overflow-x:hidden;box-sizing:border-box;animation:popupFadeIn .15s ease-out}@keyframes popupFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.multi-picker-theme-threats{border:2px solid var(--entity-threats-border)}.multi-picker-theme-controls{border:2px solid var(--entity-controls-border)}.multi-picker-expanded.render-upward{transform-origin:bottom left}.multi-picker-expanded.render-upward{animation:popupFadeInUpward .15s ease-out}@keyframes popupFadeInUpward{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.multi-picker-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-color, #e5e7eb)}.multi-picker-title{font-size:13px;font-weight:700}.multi-picker-theme-threats .multi-picker-title{color:var(--entity-threats-border)}.multi-picker-theme-controls .multi-picker-title{color:var(--entity-controls-border)}.multi-picker-close{width:24px;height:24px;border:none;border-radius:50%;cursor:pointer;font-size:20px;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .2s}.multi-picker-theme-threats .multi-picker-close{background:var(--entity-threats-bg);color:var(--entity-threats-text)}.multi-picker-theme-threats .multi-picker-close:hover{background:var(--entity-threats-text);color:var(--entity-threats-bg)}.multi-picker-theme-controls .multi-picker-close{background:var(--entity-controls-bg);color:var(--entity-controls-text)}.multi-picker-theme-controls .multi-picker-close:hover{background:var(--entity-controls-text);color:var(--entity-controls-bg)}.multi-picker-section{margin-bottom:12px}.multi-picker-section:last-child{margin-bottom:0}.multi-picker-label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;color:var(--text-tertiary, #6b7280)}.always-editable-direction-cell{position:relative;width:100%;outline:none;vertical-align:top}.direction-display{width:100%;padding:8px;border-radius:3px;line-height:1.4;border:1px solid transparent;background-color:transparent;color:inherit;font-size:14px;font-family:inherit;cursor:pointer;display:flex;justify-content:space-between;align-items:center;-webkit-user-select:none;user-select:none;box-sizing:border-box}.direction-display:hover{border:1px solid var(--border-color-strong)}.always-editable-direction-cell:focus .direction-display{outline:none;border-color:var(--accent-blue);background-color:var(--bg-primary);border-radius:3px}.direction-arrow{font-size:10px;color:#666;margin-left:8px}.direction-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:2px;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;box-shadow:0 4px 6px #0000001a;z-index:1000;max-height:200px;overflow-y:auto}.direction-option{padding:8px 12px;cursor:pointer;font-size:14px;transition:background-color .1s}.direction-option:hover,.direction-option.highlighted{background-color:var(--bg-secondary)}.direction-option.selected{background-color:var(--bg-hover);font-weight:500}.summary-section{padding:16px 0}.summary-empty-state{color:var(--text-secondary);font-style:italic;padding:24px;text-align:center}.summary-subsection{margin-bottom:24px;padding:16px;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px}.summary-subsection:last-child{margin-bottom:0}.summary-subsection-title{display:flex;align-items:center;gap:8px;margin:0 0 16px;font-size:16px;font-weight:600;color:var(--text-primary)}.summary-subsection-title svg{color:var(--accent-blue)}.summary-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}.summary-stat-card{display:flex;flex-direction:column;align-items:center;padding:12px;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;text-align:center}.summary-stat-icon{color:var(--text-secondary);margin-bottom:8px}.summary-stat-label{font-size:12px;color:var(--text-secondary);margin-bottom:4px}.summary-stat-value{font-size:24px;font-weight:700;color:var(--text-primary)}.summary-stat-value.summary-stat-warning{color:#eab308}.summary-metrics{display:flex;flex-direction:column;gap:16px}.summary-metric-row{display:flex;flex-direction:column;gap:8px}.summary-metric-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.summary-metric-expandable{cursor:pointer;padding:8px;margin:-8px;border-radius:4px;transition:background-color .15s ease}.summary-metric-expandable:hover{background-color:var(--bg-secondary)}.summary-metric-header-content{display:flex;align-items:center;gap:8px;flex:1}.summary-metric-header-content svg{color:var(--text-secondary);flex-shrink:0}.summary-metric-label{font-size:14px;color:var(--text-secondary);font-weight:500}.summary-metric-value{display:flex;align-items:baseline;gap:8px;font-size:16px}.summary-metric-main{color:var(--text-primary);font-weight:600}.summary-metric-percentage{color:var(--text-secondary);font-size:14px}.summary-progress-bar{height:8px;background-color:var(--bg-primary);border-radius:4px;overflow:hidden;border:1px solid var(--border-color);box-sizing:border-box}.summary-progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#60a5fa);transition:width .3s ease,background .3s ease;min-width:2px}.summary-progress-fill-warning{height:100%;background:linear-gradient(90deg,#eab308,#fbbf24);transition:width .3s ease,background .3s ease;min-width:2px}.summary-progress-fill-complete{height:100%;background:linear-gradient(90deg,#22c55e,#4ade80);transition:width .3s ease,background .3s ease;min-width:2px}.summary-metric-details{padding:12px 16px;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;margin-top:4px}.summary-metric-detail-section{margin-bottom:12px}.summary-metric-detail-section:last-child{margin-bottom:0}.summary-metric-detail-header{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:6px}.summary-metric-items-list{margin:0;padding-left:20px;list-style-type:disc}.summary-metric-items-list li{font-size:13px;color:var(--text-secondary);line-height:1.6;margin-bottom:3px}.summary-metric-items-list li:last-child{margin-bottom:0}.summary-metric-threat-item{margin-bottom:8px}.summary-metric-threat-item:last-child{margin-bottom:0}.summary-metric-threat-name{display:inline-block}.summary-metric-controls-list{margin:4px 0 0;padding-left:20px;list-style-type:circle}.summary-metric-controls-list li{font-size:12px;color:var(--text-secondary);line-height:1.6;margin-bottom:2px}.summary-metric-controls-list li:last-child{margin-bottom:0}.summary-metric-items-list .summary-clickable-item:hover{color:var(--accent-blue)}.summary-distribution-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}.summary-distribution-card{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px;padding:12px}.summary-distribution-header{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.summary-distribution-items{display:flex;flex-direction:column;gap:8px}.summary-distribution-item{display:flex;justify-content:space-between;align-items:center;padding:4px 0}.summary-distribution-count{font-size:14px;font-weight:600;color:var(--text-primary);min-width:24px;text-align:right}.summary-status-badge{display:inline-block;padding:2px 8px;border-radius:3px;font-size:12px;font-weight:500}.summary-status-evaluate{background-color:#3b82f626;color:#3b82f6}.summary-status-mitigate{background-color:#22c55e26;color:#22c55e}.summary-status-accept{background-color:#eab30826;color:#eab308}.summary-status-dismiss,.summary-status-todo{background-color:#9ca3af26;color:#9ca3af}.summary-status-inprogress{background-color:#3b82f626;color:#3b82f6}.summary-status-done{background-color:#22c55e26;color:#22c55e}.summary-status-cancelled{background-color:#ef444426;color:#ef4444}.summary-status-none{background-color:#9ca3af1a;color:var(--text-secondary)}.summary-action-items{border-left:3px solid rgba(234,179,8,.5);background-color:#eab3080d}.summary-action-list{display:flex;flex-direction:column;gap:12px}.summary-action-item{display:flex;align-items:flex-start;gap:10px;padding:8px 12px;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:4px}.summary-action-icon{color:#eab308;flex-shrink:0;margin-top:2px}.summary-action-content{display:flex;flex-direction:column;gap:8px;flex:1}.summary-action-text{font-size:14px;color:var(--text-primary);line-height:1.5}.summary-action-text strong{color:var(--text-primary);font-weight:700}.summary-action-items-list{margin:0;padding-left:20px;list-style-type:disc}.summary-action-items-list li{font-size:13px;color:var(--text-secondary);line-height:1.6;margin-bottom:4px}.summary-action-items-list li:last-child{margin-bottom:0}.summary-clickable-item{cursor:pointer;transition:color .15s ease,transform .1s ease}.summary-clickable-item:hover{color:var(--accent-blue);text-decoration:underline}.summary-clickable-item:active{transform:translate(2px)}.summary-all-good{border-left:3px solid rgba(34,197,94,.5);background-color:#22c55e0d}.summary-all-good-content{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px}.summary-all-good-icon{color:#22c55e}.summary-all-good-text{font-size:16px;font-weight:600;color:var(--text-primary)}@media(max-width:768px){.summary-stats-grid{grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}.summary-distribution-grid{grid-template-columns:1fr}}.modal-overlay{position:fixed;inset:0;background-color:var(--overlay-bg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000}.modal-content{background:var(--bg-primary);padding:2rem;border-radius:8px;box-shadow:0 4px 12px var(--shadow-color);max-width:500px;width:90%;border:1px solid var(--border-color)}.modal-content h2{margin:0 0 1rem;font-size:1.5rem;color:var(--text-primary)}.modal-content p{margin:0 0 .75rem;color:var(--text-secondary);line-height:1.5}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.button{padding:.5rem 1rem;border:none;border-radius:4px;font-size:.875rem;cursor:pointer;transition:background-color .2s;font-weight:500}.button-primary{background-color:var(--accent-blue);color:#fff}.button-primary:hover{background-color:var(--accent-blue-hover)}.button-danger{background-color:#dc2626}.button-danger:hover{background-color:#b91c1c}.button-secondary{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.button-secondary:hover{background-color:var(--bg-hover)}.external-change-actions{flex-wrap:wrap}.pat-modal{max-width:480px}.pat-modal .action-description{background:var(--bg-secondary);padding:.75rem 1rem;border-radius:4px;margin-bottom:1.5rem}.pat-modal .form-group{margin-bottom:1rem}.pat-modal label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.pat-modal select,.pat-modal input[type=text],.pat-modal input[type=password]{width:100%;padding:.625rem .75rem;border:1px solid var(--border-color);border-radius:4px;font-size:.875rem;background:var(--bg-primary);color:var(--text-primary);box-sizing:border-box}.pat-modal select:focus,.pat-modal input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px var(--accent-color-muted)}.pat-input-wrapper input{padding-right:2.5rem}.pat-input-wrapper .toggle-visibility{position:absolute;right:.5rem;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center}.pat-input-wrapper .toggle-visibility:hover{color:var(--text-primary)}.checkbox-group{margin-top:1rem}.checkbox-label{display:flex!important;align-items:center;gap:.5rem;cursor:pointer;font-weight:400!important}.checkbox-label input[type=checkbox]{width:auto;margin:0}.field-hint{font-size:.75rem;color:var(--text-secondary);margin-top:.5rem;margin-bottom:0;line-height:1.4}.pat-error{background:var(--bg-error);color:var(--text-error);padding:.75rem 1rem;border-radius:4px;font-size:.875rem;margin-bottom:1rem}.pat-error-detailed{display:flex;flex-direction:column;gap:.5rem}.pat-error-header{display:flex;align-items:center;gap:.5rem}.pat-error-detailed p{margin:0;font-size:.8125rem;line-height:1.5}.scopes-info{background:var(--bg-secondary);padding:1rem;border-radius:4px;margin-bottom:1.5rem}.scopes-info h4{margin:0 0 .5rem;font-size:.875rem;color:var(--text-primary)}.scopes-info p{margin:0 0 .5rem;font-size:.8125rem;color:var(--text-secondary)}.scopes-info a{color:var(--accent-color);text-decoration:none;display:inline-flex;align-items:center;gap:.25rem}.scopes-info a:hover{text-decoration:underline}.scopes-info ul{margin:0;padding-left:1.5rem}.scopes-info li{font-size:.8125rem;color:var(--text-primary);font-family:monospace;margin-bottom:.25rem}.scopes-info li:last-child{margin-bottom:0}.github-settings-modal{max-width:520px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column}.settings-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-color)}.settings-section:last-of-type{border-bottom:none}.settings-section h3{margin:0 0 .5rem;font-size:1rem;color:var(--text-primary)}.settings-description{font-size:.875rem;color:var(--text-secondary);margin:0 0 1rem}.domain-selector{display:flex;flex-direction:column;gap:.5rem}.domain-option{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;border:1px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .15s ease}.domain-option:hover{background:var(--bg-secondary)}.domain-option:has(input:checked){border-color:var(--accent-color);background:var(--accent-color-muted)}.domain-option input[type=radio]{margin:.125rem 0 0}.domain-label{display:flex;flex-direction:column;gap:.125rem}.domain-label strong{color:var(--text-primary);font-size:.875rem}.domain-sublabel{font-size:.75rem;color:var(--text-secondary)}.pat-status{display:flex;flex-direction:column;gap:.75rem}.pat-status-info{display:flex;align-items:center;gap:.5rem}.pat-status-badge{display:inline-flex;align-items:center;padding:.375rem .75rem;border-radius:4px;font-size:.8125rem;font-weight:500}.pat-stored{background:var(--success-bg);color:var(--success-text)}.pat-not-stored{background:var(--bg-secondary);color:var(--text-secondary)}.toggle-visibility-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center}.toggle-visibility-btn:hover{color:var(--text-primary)}.pat-details{background:var(--bg-secondary);padding:.75rem 1rem;border-radius:4px;font-size:.8125rem}.pat-details p{margin:0 0 .375rem;color:var(--text-secondary)}.pat-details p:last-child{margin-bottom:0}.pat-details strong{color:var(--text-primary)}.clear-pat-btn{align-self:flex-start;display:inline-flex;align-items:center;gap:.375rem}.pat-hint{font-size:.8125rem;color:var(--text-secondary);margin:0}.pat-guide-link{display:inline-flex;align-items:center;gap:.25rem;font-size:.8125rem;color:var(--accent-color);text-decoration:none;margin-top:.5rem}.pat-guide-link:hover{text-decoration:underline}.pat-input-form{display:flex;flex-direction:column;gap:.75rem;padding:.75rem;background:var(--bg-secondary);border-radius:6px;border:1px solid var(--border-color)}.pat-input-group{display:flex;flex-direction:column;gap:.5rem}.pat-input-label{font-size:.8125rem;font-weight:500;color:var(--text-primary)}.pat-input-wrapper{position:relative;display:flex;align-items:center}.pat-input{flex:1;padding:.5rem 2.5rem .5rem .75rem;border:1px solid var(--border-color);border-radius:4px;font-size:.875rem;font-family:monospace;background:var(--bg-primary);color:var(--text-primary);transition:border-color .15s ease}.pat-input:focus{outline:none;border-color:var(--accent-color)}.pat-input:disabled{opacity:.6;cursor:not-allowed}.pat-input-toggle{position:absolute;right:.5rem}.pat-persist-option{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--text-secondary);cursor:pointer}.pat-persist-option input[type=checkbox]{cursor:pointer}.pat-error{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;background:var(--error-bg);border-radius:4px;font-size:.8125rem;color:var(--error-text)}.pat-input-actions{display:flex;gap:.5rem;margin-top:.25rem}.pat-input-actions .button{display:inline-flex;align-items:center;gap:.375rem}.spinner{animation:spin 1s linear infinite}.metadata-display{background:var(--bg-secondary);padding:.75rem 1rem;border-radius:4px;margin-bottom:.75rem}.metadata-row{display:flex;gap:.5rem;margin-bottom:.375rem;font-size:.8125rem}.metadata-row:last-child{margin-bottom:0}.metadata-label{color:var(--text-secondary);min-width:80px}.metadata-value{color:var(--text-primary);font-family:monospace;word-break:break-all}.sync-button{display:flex;align-items:center;gap:.5rem;width:100%;justify-content:center;margin-bottom:.75rem}.sync-button svg{flex-shrink:0}.metadata-warning{display:flex;align-items:flex-start;gap:.5rem;padding:.625rem .75rem;background:var(--warning-bg);border-radius:4px;font-size:.75rem;color:var(--warning-text)}.metadata-warning svg{flex-shrink:0;margin-top:.125rem}.github-commit-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem}.github-commit-modal{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:.5rem;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 12px #0000004d}.github-commit-modal-header{padding:1.5rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:.75rem}.github-commit-modal-header h2{margin:0;font-size:1.25rem;color:var(--text-primary)}.github-commit-modal-header svg{color:var(--brand-color)}.github-commit-modal-body{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.commit-info-section{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:var(--bg-secondary);border-radius:.375rem}.commit-info-item{display:flex;align-items:flex-start;gap:.5rem;font-size:.875rem}.commit-info-label{font-weight:600;color:var(--text-secondary);min-width:90px}.commit-info-value{color:var(--text-primary);word-break:break-word}.commit-form-group{display:flex;flex-direction:column;gap:.5rem}.commit-form-label{font-weight:600;font-size:.875rem;color:var(--text-primary)}.commit-form-input,.commit-form-textarea,.commit-form-select{padding:.625rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:.375rem;color:var(--text-primary);font-size:.875rem;font-family:inherit;width:100%}.commit-form-textarea{min-height:80px;resize:vertical;font-family:inherit}.commit-form-input:focus,.commit-form-textarea:focus,.commit-form-select:focus{outline:none;border-color:var(--brand-color);box-shadow:0 0 0 2px var(--brand-color-alpha)}.commit-form-hint{font-size:.8125rem;color:var(--text-secondary);margin:0}.commit-warning{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:#fef3c7;border:1px solid #f59e0b;border-radius:.375rem;font-size:.875rem}[data-theme=dark] .commit-warning{background:#78350f;border-color:#f59e0b}.commit-warning svg{color:#f59e0b;flex-shrink:0;margin-top:2px}.commit-warning-content{flex:1}.commit-warning-title{font-weight:600;margin:0 0 .25rem;color:var(--text-primary)}.commit-warning-message{margin:0;color:var(--text-primary)}.commit-error{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background:#fee2e2;border:1px solid #ef4444;border-radius:.375rem;font-size:.875rem}[data-theme=dark] .commit-error{background:#7f1d1d;border-color:#ef4444}.commit-error svg{color:#ef4444;flex-shrink:0;margin-top:2px}.commit-error-message{margin:0;color:var(--text-primary)}.github-commit-modal-footer{padding:1.5rem;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:.75rem}.github-commit-modal-footer button{padding:.625rem 1.25rem;border-radius:.375rem;font-size:.875rem;font-weight:500;border:none;cursor:pointer;transition:all .15s ease}.github-commit-modal-footer button:disabled{opacity:.5;cursor:not-allowed}.github-commit-modal-footer .cancel-button{background:transparent;color:var(--text-primary);border:1px solid var(--border-color)}.github-commit-modal-footer .cancel-button:hover:not(:disabled){background:var(--bg-secondary)}.github-commit-modal-footer .commit-button{background:var(--accent-blue);color:#fff;display:flex;align-items:center;gap:.5rem}.github-commit-modal-footer .commit-button:hover:not(:disabled){background:var(--accent-blue-hover)}.commit-loading-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.repo-search-input input[type=text]{width:100%;padding:.5rem 2.5rem!important;border:1px solid var(--border-color);border-radius:4px;font-size:.875rem;background:var(--bg-primary);color:var(--text-primary)}.repo-search-input input[type=text]:focus{outline:none;border-color:var(--brand-color);box-shadow:0 0 0 2px var(--brand-color-alpha)}.repo-search-input input[type=text]:disabled{opacity:.6;cursor:not-allowed}.repo-search-input .clear-search:hover{color:var(--text-primary)}.select-wrapper select:focus{outline:none;border-color:var(--brand-color);box-shadow:0 0 0 2px var(--brand-color-alpha)}.select-wrapper .loading-icon{position:absolute;right:1.75rem;color:var(--brand-color)}.github-selector-group>input[type=text],.github-selector-group>div>input[type=text]:not(.repo-search-input input){padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:.875rem}.github-selector-group>input[type=text]:focus,.github-selector-group>div>input[type=text]:not(.repo-search-input input):focus{outline:none;border-color:var(--brand-color);box-shadow:0 0 0 2px var(--brand-color-alpha)}.github-selector-group>input[type=text]:disabled,.github-selector-group>div>input[type=text]:not(.repo-search-input input):disabled{opacity:.6;cursor:not-allowed}.github-selector-group textarea{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:.875rem;font-family:inherit;resize:vertical}.github-selector-group textarea:focus{outline:none;border-color:var(--brand-color);box-shadow:0 0 0 2px var(--brand-color-alpha)}.github-selector-group textarea:disabled{opacity:.6;cursor:not-allowed}.commit-extra-files,.commit-extra-files-options{display:flex;flex-direction:column;gap:.5rem}.commit-form-label{display:flex;align-items:center;gap:.375rem;font-size:.75rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.025em}.commit-checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-primary);cursor:pointer;-webkit-user-select:none;user-select:none}.commit-checkbox-label input[type=checkbox]{width:1rem;height:1rem;accent-color:var(--brand-color);cursor:pointer;margin:0;flex-shrink:0}.commit-checkbox-label input[type=checkbox]:disabled{opacity:.5;cursor:not-allowed}.commit-checkbox-label svg{color:var(--text-secondary);flex-shrink:0}.commit-extra-files-hint{margin:.25rem 0 0;font-size:.8125rem;color:var(--text-secondary);font-style:italic;padding-left:1.5rem}.github-sync-modal{max-width:560px}.sync-modal-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.sync-modal-header h2{margin:0}.sync-icon{color:var(--text-warning);flex-shrink:0}.sync-modal-body{display:flex;flex-direction:column;gap:20px}.sync-warning{display:flex;align-items:flex-start;gap:12px;padding:12px;background-color:#f59e0b1a;border-left:3px solid var(--text-warning);border-radius:4px}.sync-warning svg{flex-shrink:0;color:var(--text-warning);margin-top:2px}.sync-warning p{margin:0;color:var(--text-primary)}.sync-details{display:flex;flex-direction:column;gap:8px;padding:12px;background-color:var(--bg-secondary);border-radius:4px}.sync-detail-row{display:flex;justify-content:space-between;align-items:center}.detail-label{font-weight:500;color:var(--text-secondary)}.detail-value{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.9em;color:var(--text-primary)}.sync-options{padding:12px;background-color:var(--bg-tertiary);border-radius:4px}.sync-options p{margin:0 0 8px;font-weight:500}.sync-options ul{margin:0;padding-left:20px}.sync-options li{margin-bottom:8px}.sync-options li:last-child{margin-bottom:0}.button-warning{background-color:var(--bg-warning);color:var(--text-warning)}.button-warning:hover:not(:disabled){background-color:var(--text-warning);color:var(--bg-warning)}.settings-dropdown{position:fixed;top:0;right:0;height:48px;display:flex;align-items:center;z-index:100}.settings-dropdown-trigger{width:48px;height:48px;background:var(--bg-primary);color:var(--text-secondary);border:none;border-left:1px solid var(--border-color);border-bottom:1px solid var(--border-color);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;padding:0}.settings-dropdown-trigger:hover{background:var(--bg-hover)}.settings-dropdown-trigger:active{background:var(--bg-active)}.settings-dropdown-menu{position:absolute;top:100%;right:0;background:var(--bg-primary);border:1px solid var(--border-color);border-top:none;border-radius:0 0 6px 6px;box-shadow:0 4px 12px var(--shadow-color);min-width:200px;z-index:1001;overflow:hidden}.settings-dropdown-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 16px;background:var(--bg-primary);color:var(--text-secondary);border:none;border-bottom:1px solid var(--border-color);font-size:14px;cursor:pointer;transition:all .2s;text-align:left;white-space:nowrap}.settings-dropdown-item:last-child{border-bottom:none}.settings-dropdown-item:hover{background:var(--bg-hover);color:var(--text-primary)}.settings-dropdown-item:active{background:var(--bg-active)}.settings-dropdown-icon{display:flex;align-items:center;justify-content:center;font-size:16px}.file-browser{width:100vw;height:100vh;display:flex;flex-direction:column;background:var(--bg-secondary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.file-browser-content{flex:1;overflow-y:auto;padding:30px}.file-browser .navbar-title{font-size:16px;font-weight:500;color:var(--text-primary);padding-left:16px;height:48px;display:flex;align-items:center;border-left:1px solid var(--border-color)}.file-list{max-width:600px}.file-list h2{margin:0 0 16px;font-size:18px;font-weight:600;color:var(--text-primary)}.file-list h3{margin:24px 0 12px;font-size:14px;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}.file-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;margin-bottom:8px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s ease;text-align:left}.file-item:hover{background:var(--bg-tertiary);border-color:var(--accent-blue);box-shadow:0 2px 8px var(--shadow-color);transform:translate(4px)}.file-item:active{transform:translate(2px)}.file-icon{font-size:20px;flex-shrink:0}.file-item-container{margin-bottom:8px;display:flex;align-items:center;gap:8px}.file-item-container .file-item{flex:1;margin-bottom:0}.file-actions{display:flex;gap:4px;opacity:0;transition:opacity .2s ease}.file-item-container:hover .file-actions{opacity:1}.action-button{padding:8px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;color:var(--text-secondary);transition:all .2s ease;display:flex;align-items:center;justify-content:center}.action-button:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--accent-blue)}.action-button.delete-button:hover{background:#fee;border-color:#f88;color:#c33}[data-theme=dark] .action-button.delete-button:hover{background:#4a1a1a;border-color:#c33;color:#f66}.rename-input{width:100%;padding:4px 8px;background:var(--bg-primary);border:1px solid var(--accent-blue);border-radius:4px;color:var(--text-primary);font-size:14px;font-weight:500;outline:none}.file-details{display:flex;flex-direction:column;gap:4px;flex:1}.file-name{font-size:14px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-description{font-size:12px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}.error-message{padding:12px 16px;margin-bottom:16px;background:#fee;border:1px solid #f88;border-radius:6px;color:#c33;font-size:14px}.loading{padding:20px;text-align:center;color:var(--text-secondary);font-size:14px}.empty-state{text-align:center;padding:40px 20px;color:var(--text-secondary)}.empty-state p{margin:0 0 16px;font-size:14px}.empty-hint{font-size:12px!important;color:var(--text-tertiary)!important}.placeholder-button{padding:8px 16px;background:var(--accent-blue);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease}.placeholder-button:hover{background:var(--accent-blue-hover);opacity:.9}.file-upload{max-width:600px}.file-upload h2{margin:0 0 24px;font-size:18px;font-weight:600;color:var(--text-primary)}.upload-area{position:relative;margin-bottom:24px}.upload-area input[type=file]{display:none}.upload-label{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;background:var(--bg-primary);border:2px dashed var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s ease;text-align:center}.upload-label:hover{border-color:var(--accent-blue);background:var(--bg-tertiary)}.upload-icon{font-size:32px;margin-bottom:12px}.upload-text{font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:4px}.upload-hint{font-size:12px;color:var(--text-secondary)}[data-theme=dark] .upload-label:hover{border-color:#06c;background:#333}[data-theme=dark] .upload-text{color:#fff}[data-theme=dark] .upload-hint{color:#aaa}.github-load-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem}.github-load-modal{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:.5rem;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 12px #0000004d;display:flex;flex-direction:column}.github-load-modal-header{padding:1.5rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:.75rem;position:relative}.github-load-modal-header h2{margin:0;font-size:1.25rem;color:var(--text-primary);flex:1}.github-load-modal-header svg:first-child{color:var(--brand-color)}.github-load-modal-close{background:none;border:none;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);border-radius:.25rem;transition:all .15s ease}.github-load-modal-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.github-load-modal-body{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem;flex:1;overflow-y:auto}.github-domain-info{display:flex;justify-content:flex-end}.github-domain-badge{font-size:.75rem;padding:.25rem .5rem;background:var(--bg-secondary);border-radius:4px;color:var(--text-secondary);font-family:monospace}.github-selector-group{display:flex;flex-direction:column;gap:.375rem}.github-selector-group label{display:flex;align-items:center;gap:.375rem;font-size:.75rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.025em}.select-wrapper{position:relative;display:flex;align-items:center}.select-wrapper select{width:100%;padding:.5rem 2rem .5rem .75rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--text-primary);font-size:.875rem;appearance:none;cursor:pointer}.select-wrapper select:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px var(--accent-color-muted)}.select-wrapper select:disabled{opacity:.6;cursor:not-allowed}.select-wrapper select option.load-more-option{font-weight:600;color:var(--accent-color);background:var(--bg-secondary)}.select-wrapper .select-icon{position:absolute;right:.5rem;color:var(--text-secondary);pointer-events:none}.select-wrapper .loading-icon{position:absolute;right:1.75rem;color:var(--accent-color)}.github-files-section{flex:1;display:flex;flex-direction:column;gap:.5rem;min-height:200px}.files-header{display:flex;align-items:center;justify-content:space-between}.files-header label{display:flex;align-items:center;gap:.375rem;font-size:.75rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.025em}.refresh-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;border-radius:4px;display:flex;align-items:center;justify-content:center}.refresh-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}.files-path-hint{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--text-secondary);opacity:.8}.files-path-hint code{font-family:var(--font-mono, monospace);font-size:.7rem;background:var(--bg-secondary);padding:.05rem .3rem;border-radius:3px}.github-files-list{flex:1;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-secondary);overflow-y:auto}.files-loading,.files-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:2rem 1rem;color:var(--text-secondary);font-size:.875rem;text-align:center}.github-file-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.625rem .75rem;border:none;border-bottom:1px solid var(--border-color);background:transparent;color:var(--text-primary);font-size:.875rem;text-align:left;cursor:pointer;transition:background-color .15s}.github-file-item:last-child{border-bottom:none}.github-file-item:hover{background:var(--bg-hover)}.github-file-item:disabled{opacity:.6;cursor:not-allowed}.github-file-item .file-name{flex:1;display:flex;align-items:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.github-file-item .file-subfolder{display:inline-flex;align-items:center;gap:.25rem;margin-left:.5rem;font-size:.75rem;color:var(--text-secondary);opacity:.7}.spin{animation:spin 1s linear infinite}.repo-search-wrapper{margin-bottom:.5rem;display:flex;flex-direction:column;gap:.5rem}.repo-search-input{position:relative;display:flex;align-items:center}.repo-search-input .search-icon{position:absolute;left:.75rem;color:var(--text-secondary);pointer-events:none}.repo-search-input input{width:100%;padding:.5rem 2.5rem;border:1px solid var(--border);border-radius:4px;font-size:.875rem;background:var(--bg-2);color:var(--text)}.repo-search-input input:focus{outline:none;border-color:var(--accent)}.repo-search-input .clear-search{position:absolute;right:.5rem;background:none;border:none;color:var(--text-secondary);font-size:1.5rem;line-height:1;cursor:pointer;padding:.25rem .5rem;transition:color .2s}.repo-search-input .clear-search:hover{color:var(--text)}.search-hint{padding:.375rem .75rem;font-size:.75rem;color:var(--text-secondary);background:var(--bg-secondary);border-radius:4px;text-align:center}.search-result-count{padding:.375rem .75rem;font-size:.75rem;color:var(--text-secondary);background:var(--bg-secondary);border-radius:4px;text-align:center;font-weight:500}.load-more-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.625rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-primary);color:var(--accent-color);font-size:.875rem;font-weight:500;cursor:pointer;transition:background-color .15s,border-color .15s}.load-more-btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--accent-color)}.load-more-btn:disabled{opacity:.6;cursor:not-allowed}.no-results{margin-top:.5rem;padding:.5rem;text-align:center;font-size:.875rem;color:var(--text-secondary);font-style:italic}.manual-owner-input{display:flex;gap:.5rem;margin-top:.5rem}.manual-owner-input input{flex:1;padding:.5rem;border:1px solid var(--border);border-radius:4px;font-size:.875rem;background:var(--bg-2);color:var(--text)}.manual-owner-input input:focus{outline:none;border-color:var(--accent)}.manual-search-btn{display:flex;align-items:center;gap:.25rem;padding:.5rem .75rem;background:var(--accent);color:#fff;border:none;border-radius:4px;font-size:.875rem;cursor:pointer;transition:background .2s}.manual-search-btn:hover:not(:disabled){background:var(--accent-hover)}.manual-search-btn:disabled{opacity:.5;cursor:not-allowed}.resize-divider{width:1px;background:var(--border-color);cursor:col-resize;position:relative;flex-shrink:0;transition:background .2s ease;z-index:10}.resize-divider:hover,.resize-divider:active{background:var(--accent-blue)}.resize-divider-handle{position:absolute;inset:0 -2px;cursor:col-resize}body:has(.resize-divider:active){cursor:col-resize!important;-webkit-user-select:none!important;user-select:none!important}.tab-panel-header{display:flex;align-items:center;justify-content:space-between;height:32px;min-height:32px;padding:0 4px 0 10px;background:var(--bg-primary);border-bottom:1px solid var(--border-color);position:relative;z-index:5;-webkit-user-select:none;user-select:none}.tab-panel-header-left{display:flex;align-items:center;gap:6px;position:relative}.tab-panel-header-right{display:flex;align-items:center;gap:2px}.tab-panel-header-icon{display:flex;align-items:center;flex-shrink:0;color:var(--text-tertiary)}.tab-panel-header-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}.tab-panel-header-chevron{display:flex;align-items:center;justify-content:center;width:18px;height:18px;padding:0;border:none;border-radius:3px;background:transparent;color:var(--text-tertiary);cursor:pointer;flex-shrink:0;transition:background .15s ease,color .15s ease}.tab-panel-header-chevron:hover{background:var(--bg-active);color:var(--text-primary)}.tab-panel-header-btn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;border:none;border-radius:4px;background:transparent;color:var(--text-tertiary);cursor:pointer;flex-shrink:0;transition:background .15s ease,color .15s ease}.tab-panel-header-btn:hover{background:var(--bg-active);color:var(--text-primary)}.tab-panel-header-dropdown{position:absolute;top:100%;left:0;z-index:100;min-width:120px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;box-shadow:0 4px 12px #00000026;padding:4px;margin-top:4px}.tab-panel-header-dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:6px 10px;border:none;border-radius:4px;background:transparent;color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:background .15s ease,color .15s ease}.tab-panel-header-dropdown-item:hover{background:var(--bg-hover);color:var(--text-primary)}.tab-panel-header-dropdown-item.active{background:var(--bg-active);color:var(--text-primary)}.tab-panel-header-drag-handle{display:flex;align-items:center;justify-content:center;width:16px;height:18px;padding:0;border:none;border-radius:3px;background:transparent;color:var(--text-tertiary);cursor:grab;flex-shrink:0;transition:background .15s ease,color .15s ease;touch-action:none}.tab-panel-header-drag-handle:hover{background:var(--bg-active);color:var(--text-primary)}.tab-panel-header-drag-handle:active{cursor:grabbing}.tab-panel-header--dragging{opacity:.3}.tab-panel-header--overlay{box-shadow:0 4px 12px #0003;border-radius:6px;border:1px solid var(--border-color);cursor:grabbing}.markdown-renderer{padding:0 2rem;color:var(--text-primary);line-height:1.6}.markdown-renderer h1{font-size:2rem;font-weight:600;margin:2rem 0 1rem;color:var(--text-primary);border-bottom:2px solid var(--border-color);padding-bottom:.5rem}.markdown-renderer h2{font-size:1.5rem;font-weight:600;margin:1.5rem 0 .75rem;color:var(--text-primary)}.markdown-renderer h3{font-size:1.25rem;font-weight:600;margin:1.25rem 0 .5rem;color:var(--text-primary)}.markdown-renderer h4,.markdown-renderer h5,.markdown-renderer h6{font-size:1rem;font-weight:600;margin:1rem 0 .5rem;color:var(--text-secondary)}.markdown-renderer p{margin:.75rem 0}.markdown-renderer a{color:var(--accent-blue);text-decoration:none}.markdown-renderer a.download-link{display:inline-flex;align-items:center;gap:4px;font-weight:500}.markdown-renderer a.download-link:hover{text-decoration:underline}.markdown-renderer a:hover{color:var(--accent-blue-hover);text-decoration:underline}.markdown-renderer ul,.markdown-renderer ol{margin:.75rem 0;padding-left:2rem}.markdown-renderer li{margin:.25rem 0}.markdown-renderer li>ul,.markdown-renderer li>ol{margin:.25rem 0}.markdown-renderer code{background:var(--bg-secondary);padding:.2em .4em;border-radius:3px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.9em;color:var(--text-primary)}.markdown-renderer pre{margin:1rem 0;border-radius:6px;overflow-x:auto;overflow-y:hidden;background:var(--bg-secondary);white-space:pre}.markdown-renderer pre code{background:none;padding:0;border-radius:0;display:block;white-space:pre;overflow-wrap:normal;word-break:normal}.markdown-renderer blockquote{margin:1rem 0;padding:.5rem 1rem;border-left:4px solid var(--accent-blue);background:var(--bg-secondary);color:var(--text-secondary)}.markdown-renderer blockquote p{margin:.5rem 0}.markdown-renderer table{width:100%;margin:1rem 0;border-collapse:collapse;border:1px solid var(--border-color)}.markdown-renderer th,.markdown-renderer td{padding:.75rem;border:1px solid var(--border-color);text-align:left}.markdown-renderer th{background:var(--bg-secondary);font-weight:600}.markdown-renderer tr:nth-child(2n){background:var(--bg-secondary)}.markdown-renderer img{max-width:100%;height:auto;border-radius:6px;margin:1rem 0;border:1px solid var(--border-color)}.markdown-renderer hr{margin:2rem 0;border:none;border-top:1px solid var(--border-color)}.markdown-renderer strong{font-weight:600;color:var(--text-primary)}.markdown-renderer em{font-style:italic}.markdown-renderer pre[class*=language-]{margin:1rem 0;border-radius:6px;overflow-x:auto!important;white-space:pre!important}.markdown-renderer pre[class*=language-] code{white-space:pre!important;overflow-wrap:normal!important;word-break:normal!important}.tutorial-list{height:100%;display:flex;flex-direction:column;background:var(--bg-secondary)}.tutorial-list-header{padding:2rem;border-bottom:1px solid var(--border-color)}.tutorial-list-header h2{margin:0 0 .5rem;font-size:1.5rem;color:var(--text-primary)}.tutorial-list-header p{margin:0;color:var(--text-secondary);font-size:.9rem}.tutorial-list-content{flex:1;overflow-y:auto;padding:2rem}.tutorial-category{margin-bottom:2rem}.tutorial-category:last-child{margin-bottom:0}.tutorial-category-header{margin-bottom:1rem}.tutorial-category-header h3{margin:0 0 .25rem;font-size:1.1rem;color:var(--text-primary)}.tutorial-category-header p{margin:0;color:var(--text-secondary);font-size:.85rem}.tutorial-cards{display:flex;flex-direction:column;gap:.75rem}.tutorial-card{display:flex;gap:1rem;padding:1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;text-align:left;cursor:pointer;transition:all .2s ease;width:100%}.tutorial-card:hover{background:var(--bg-tertiary);border-color:var(--accent-blue);transform:translateY(-1px);box-shadow:0 4px 8px var(--shadow-color)}.tutorial-card-icon{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--accent-blue);color:#fff;border-radius:8px}.tutorial-card-content{flex:1;min-width:0}.tutorial-card-content h4{margin:0 0 .5rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.tutorial-card-content p{margin:0;font-size:.85rem;color:var(--text-secondary);line-height:1.4}.tutorial-card-meta{display:flex;align-items:center;gap:.25rem;margin-top:.5rem;color:var(--text-tertiary);font-size:.8rem}.tutorial-card-meta svg{opacity:.7}.tutorial-list-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-secondary)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-blue);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.tutorial-list-error{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-secondary);padding:2rem;text-align:center}.tutorial-panel{flex:1;display:flex;flex-direction:column;overflow:hidden}.tutorial-panel-back{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;margin:12px 16px 4px;border:none;border-radius:4px;background:transparent;color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:background .15s ease,color .15s ease}.tutorial-panel-back:hover{background:var(--bg-hover);color:var(--text-primary)}.tutorial-panel-body{flex:1;overflow-y:auto;background:var(--bg-secondary)}.tutorial-panel-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:40px;color:var(--text-secondary)}.tutorial-panel-error{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--danger-text, #dc2626)}.tab-panel{min-width:0;overflow:hidden;position:relative;display:flex;flex-direction:column;flex-shrink:0}.tab-panel-tables{flex:1;overflow-y:auto;overflow-x:hidden;padding:10px 20px 10px 10px;background:var(--bg-secondary);display:flex;flex-direction:column}.tab-panel-yaml{flex:1;display:flex;overflow:hidden;background:var(--bg-secondary)}.tab-panel-canvas{flex:1;position:relative;min-width:0}.tab-panel-canvas .react-flow__container{width:100%;height:100%}.tab-drop-indicator{position:absolute;top:0;bottom:0;width:3px;margin-left:-1.5px;background:var(--accent-color, #4f8ff7);border-radius:2px;box-shadow:0 0 6px var(--accent-color, rgba(79, 143, 247, .5));pointer-events:none;z-index:10}.tab-panel-canvas-placeholder{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);font-size:13px;background:var(--bg-secondary);gap:8px}.threat-node{padding:4px;border:2px solid var(--node-border, #000);background:var(--component-fill, var(--bg-primary, white));min-width:100px;min-height:46px}.threat-node.component-color-yellow{--component-fill: var(--component-color-yellow-bg)}.threat-node.component-color-blue{--component-fill: var(--component-color-blue-bg)}.threat-node.component-color-green{--component-fill: var(--component-color-green-bg)}.threat-node.component-color-red{--component-fill: var(--component-color-red-bg)}.threat-node.component-color-orange{--component-fill: var(--component-color-orange-bg)}.threat-node.component-color-purple{--component-fill: var(--component-color-purple-bg)}.threat-node.internal{border-radius:25px;min-width:140px;position:relative}.threat-node.external-dependency{border-radius:0;min-width:140px;position:relative}.threat-node.data-store{border-radius:0;border-left:none;border-right:none;min-width:140px;position:relative}.node-content{position:relative;z-index:1;text-align:center}.node-label-wrapper{display:flex;align-items:center;justify-content:center;position:relative;width:100%}.node-label{font-weight:500;font-size:14px;padding:6px 0;color:var(--text-primary, #000);word-wrap:break-word;word-break:break-word;cursor:default;-webkit-user-select:none;user-select:none;line-height:1.4;display:block;max-width:120px;white-space:normal;border:1px solid transparent}.node-label.editable{cursor:text}.node-label.editable:hover{opacity:.7}.node-edit-button{position:absolute;left:100%;margin-left:-14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;width:18px;height:18px;background:transparent;border:none;cursor:pointer;color:var(--text-muted, #666);transition:opacity .15s ease,color .15s ease;padding:0;opacity:0}.node-edit-button.visible{opacity:1}.node-edit-button:hover{opacity:1;color:var(--accent-color, #4a90d9)}.node-edit-button:active{transform:scale(.9)}.node-label-input{font-weight:500;font-size:14px;color:var(--text-primary, #000);padding:6px 0;border:1px solid transparent;border-radius:3px;font-family:inherit;text-align:center;background:transparent;margin:0 auto;min-width:0;box-sizing:border-box;max-width:120px;word-wrap:break-word;word-break:break-word;white-space:normal;display:block;line-height:1.4;overflow-wrap:break-word;overflow:hidden;resize:none}.node-label-input:hover{border-color:var(--border-color-strong, #ccc)}.node-label-input:focus{outline:none;border-color:var(--accent-color, #4a90d9)}.react-flow__handle{width:12px;height:12px;background:#999;border:1px solid #ccc;border-radius:50%;opacity:0;transition:all .2s ease;z-index:5;cursor:crosshair}.react-flow__handle.connectingFrom,.react-flow__handle.connectingTo{background:#ff6b6b;opacity:1;border-color:red}.threat-node:hover .react-flow__handle{opacity:.5}.threat-node:hover .react-flow__handle:hover{background:#333;opacity:1;border-color:#333;box-shadow:0 0 6px #0006}.threat-node.selected .react-flow__handle{opacity:.5}.threat-node.selected .react-flow__handle:hover{background:#333;opacity:1;border-color:#333;box-shadow:0 0 6px #0006}.threat-node.edit-mode .react-flow__handle{opacity:0;pointer-events:none}.threat-node.handle-selection-mode .react-flow__handle{opacity:.5}.threat-node.handle-selection-mode .react-flow__handle:hover{background:#333;opacity:1;border-color:#333;box-shadow:0 0 6px #0006}.react-flow__container.dragging-edge .react-flow__handle{opacity:.5}.react-flow__container.dragging-edge .react-flow__handle:hover{background:#333;opacity:1;border-color:#333;box-shadow:0 0 6px #0006}.handle-wrapper{position:absolute;width:0;height:0}.handle-wrapper.handle-top-1{top:0;left:20%}.handle-wrapper.handle-top-2{top:0;left:50%}.handle-wrapper.handle-top-3{top:0;left:80%}.handle-wrapper.handle-right-1{right:0;top:20%}.handle-wrapper.handle-right-2{right:0;top:50%}.handle-wrapper.handle-right-3{right:0;top:81%}.handle-wrapper.handle-bottom-1{bottom:0;left:20%}.handle-wrapper.handle-bottom-2{bottom:0;left:50%}.handle-wrapper.handle-bottom-3{bottom:0;left:80%}.handle-wrapper.handle-left-1{left:0;top:20%}.handle-wrapper.handle-left-2{left:0;top:50%}.handle-wrapper.handle-left-3{left:0;top:81%}.handle-wrapper .react-flow__handle{position:absolute!important;top:50%!important;left:50%!important;transform:translate(-50%,-50%)!important}.handle-wrapper.focused .react-flow__handle{opacity:1;border:2px solid var(--accent-blue, #4a90d9)!important;box-shadow:0 0 0 2px #4a90d94d;z-index:10}.threat-node.connection-focused,.threat-node.selected{box-shadow:0 0 0 2px var(--accent-color, #4a90d9);outline:none}.threat-node.selected.edit-mode{box-shadow:none}.react-flow__node.selected .threat-node{outline:none;outline-width:0}.node-toolbar-top{display:flex;flex-direction:column;gap:6px;align-items:center;justify-content:center}.node-toolbar-row{display:flex;gap:6px;align-items:center;justify-content:center}.node-toolbar-color-row{flex-wrap:wrap;max-width:160px}.node-toolbar-bottom{display:flex;gap:6px;align-items:center;justify-content:center}.node-toolbar-button{display:flex;align-items:center;justify-content:center;background:var(--bg-primary, #fff);border:none;cursor:pointer;padding:4px 8px;transition:all .15s ease;font-size:10px;font-weight:500;color:var(--text-primary, #333)}.node-toolbar-button.type-internal{border:2px solid var(--text-primary, #333);border-radius:10px;width:28px;height:20px;padding:0}.node-toolbar-button.type-external{border:2px solid var(--text-primary, #333);border-radius:0;width:28px;height:20px;padding:0}.node-toolbar-button.type-datastore{border:none;border-top:2px solid var(--text-primary, #333);border-bottom:2px solid var(--text-primary, #333);border-radius:0;width:28px;height:20px;padding:0}.node-toolbar-button.type-internal:hover,.node-toolbar-button.type-external:hover,.node-toolbar-button.type-datastore:hover{background:var(--bg-hover, #e0e0e0)}.node-toolbar-button.type-internal.active,.node-toolbar-button.type-external.active{border-color:var(--accent-color, #4a90d9);background:#4a90d91a}.node-toolbar-button.type-datastore.active{border-top-color:var(--accent-color, #4a90d9);border-bottom-color:var(--accent-color, #4a90d9);background:#4a90d91a}.node-toolbar-color-swatch{width:16px;height:16px;border-radius:999px;border:2px solid rgba(17,24,39,.18);cursor:pointer;padding:0;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.node-toolbar-color-swatch:hover{transform:scale(1.08)}.node-toolbar-color-swatch.active{border-color:var(--accent-color, #4a90d9);box-shadow:0 0 0 2px #4a90d933}.node-toolbar-color-swatch.color-yellow{background:var(--component-color-yellow-bg)}.node-toolbar-color-swatch.color-blue{background:var(--component-color-blue-bg)}.node-toolbar-color-swatch.color-green{background:var(--component-color-green-bg)}.node-toolbar-color-swatch.color-red{background:var(--component-color-red-bg)}.node-toolbar-color-swatch.color-orange{background:var(--component-color-orange-bg)}.node-toolbar-color-swatch.color-purple{background:var(--component-color-purple-bg)}.node-info-dialog{width:220px;background:var(--bg-primary, #fff);border:1px solid var(--border-color, #ddd);border-radius:8px;box-shadow:0 4px 12px #00000026}.node-info-dialog-content{padding:12px;display:flex;flex-direction:column;gap:12px}.node-info-field{display:flex;flex-direction:column;gap:4px}.node-info-field label{font-size:10px;font-weight:600;text-transform:uppercase;color:var(--text-muted, #666)}.node-info-ref{font-size:11px;font-family:monospace;color:var(--text-muted);background:var(--bg-secondary, #f5f5f5);padding:4px 8px;border-radius:4px;cursor:not-allowed}.node-info-textarea{width:100%;padding:6px 8px;font-size:11px;font-family:inherit;border:1px solid var(--border-color, #ddd);border-radius:4px;background:var(--bg-primary, #fff);color:var(--text-primary, #333);resize:none;min-height:60px}.node-info-textarea:hover{border-color:var(--border-color-strong, #ccc)}.node-info-textarea:focus{outline:none;border-color:var(--accent-color, #4a90d9)}.node-info-textarea::placeholder{color:var(--text-muted, #999)}.node-input-wrapper{border:1px solid var(--border-color, #ddd);border-radius:4px}.react-flow__node-boundaryNode{pointer-events:none!important}.boundary-node{width:100%;height:100%;border:2px dashed var(--entity-boundaries-border);background:transparent;position:relative;pointer-events:none}.boundary-drag-frame{position:absolute;inset:-8px;pointer-events:auto;cursor:move;clip-path:polygon(evenodd,0 0,100% 0,100% 100%,0 100%,0 0,23px 23px,calc(100% - 23px) 23px,calc(100% - 23px) calc(100% - 23px),23px calc(100% - 23px),23px 23px)}.react-flow__node.selected .boundary-drag-frame{inset:0;clip-path:polygon(evenodd,0 0,100% 0,100% 100%,0 100%,0 0,15px 15px,calc(100% - 15px) 15px,calc(100% - 15px) calc(100% - 15px),15px calc(100% - 15px),15px 15px)}.react-flow__node.selected .boundary-node{border-color:var(--entity-boundaries-text);border-width:2px}.boundary-label-container{position:absolute;top:2px;left:2px;z-index:10;display:flex;align-items:center;gap:4px;pointer-events:auto}.boundary-label{font-weight:600;font-size:11px;color:var(--entity-boundaries-border);background:transparent;padding:2px 4px;border-radius:3px;cursor:default;-webkit-user-select:none;user-select:none;border:none}.boundary-edit-button{display:flex;align-items:center;justify-content:center;width:16px;height:16px;background:transparent;border:none;cursor:pointer;color:var(--entity-boundaries-border);transition:opacity .15s ease;padding:0;opacity:0;pointer-events:none}.boundary-edit-button.visible{opacity:.7;pointer-events:auto}.boundary-edit-button.visible:hover{opacity:1}.boundary-edit-button.visible:active{transform:scale(.9)}.boundary-label-input{font-weight:600;font-size:11px;color:var(--entity-boundaries-border);background:var(--bg-primary, #fff);padding:2px 4px;border:2px solid var(--entity-boundaries-border);border-radius:3px;font-family:inherit;min-width:80px}.boundary-label-input:focus{outline:none;box-shadow:0 0 4px var(--entity-boundaries-bg)}.boundary-resize-handle{width:14px!important;height:14px!important;border-radius:3px!important;background:var(--bg-primary, #fff)!important;border:2px solid var(--entity-boundaries-border)!important;opacity:.9!important;transition:all .15s ease!important;pointer-events:auto!important}.boundary-resize-handle:hover{opacity:1!important;background:var(--bg-primary, #fff)!important;transform:scale(1.2);box-shadow:0 2px 8px var(--entity-boundaries-bg)!important}.boundary-resize-line{opacity:0!important;pointer-events:none!important}.editable-edge-label{padding:2px;border-radius:2px;background-color:var(--bg-tertiary, #f0f0f0);color:var(--text-primary, inherit);font-size:8px;font-weight:500;cursor:pointer;border:2px solid transparent;white-space:normal;transition:all .2s ease;line-height:1.3;max-width:80px;word-wrap:break-word;word-break:break-word;box-sizing:border-box;text-align:center}.editable-edge-label:hover{background-color:var(--bg-hover, #e0e0e0)}.editable-edge-label.selected{border-color:var(--accent-color, #4a90d9)}.editable-edge-label-input{padding:2px 2px 5px;font-size:8px;font-weight:500;border:2px solid transparent;border-radius:2px;outline:none;background-color:var(--bg-tertiary, #f0f0f0);color:var(--text-primary, inherit);min-width:30px;box-sizing:border-box;line-height:1.3;margin:0;height:auto;min-height:auto;font-family:inherit;max-width:80px;word-wrap:break-word;word-break:break-word;white-space:normal;overflow-wrap:break-word;resize:none;overflow:hidden;text-align:center}.editable-edge-label-input:focus{outline:none}.edge-toolbar-button{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background-color:var(--bg-primary, #fff);border:1px solid var(--border-color, #ddd);border-radius:50%;cursor:pointer;font-size:12px;transition:all .15s ease;color:var(--text-primary, #333);box-shadow:0 2px 4px #0000001a}.edge-toolbar-button:hover{background-color:var(--bg-hover, #e0e0e0);border-color:var(--border-color-hover, #bbb)}.canvas-toolbar{position:absolute;bottom:12px;left:60px;z-index:10;display:flex;flex-direction:row;gap:8px}.canvas-toolbar-button{display:flex;align-items:center;justify-content:center;padding:6px;border:none;border-radius:6px;background:var(--bg-primary, white);cursor:grab;transition:all .15s ease;box-shadow:0 2px 6px var(--shadow-color, rgba(0, 0, 0, .15))}.canvas-toolbar-button:active{cursor:grabbing}.canvas-toolbar-button.dragging{opacity:.5;transform:scale(.95)}.canvas-toolbar-button:hover{background:var(--bg-tertiary, #f3f4f6);border-color:var(--text-muted, #9ca3af);transform:scale(1.02)}.canvas-toolbar-button:active{transform:scale(.98)}.mini-node{display:flex;align-items:center;justify-content:center;padding:4px 8px;min-width:70px;background:var(--bg-primary, white)}.mini-label{font-size:10px;font-weight:500;color:var(--text-primary, #000);white-space:nowrap}.mini-internal{border:2px solid var(--node-border, #000);border-radius:12px}.mini-external{border:2px solid var(--node-border, #000);border-radius:0}.mini-datastore{border-top:2px solid var(--node-border, #000);border-bottom:2px solid var(--node-border, #000);border-left:none;border-right:none;border-radius:0}.mini-boundary{border:2px dashed #dc2626;border-radius:0;background:transparent}.mini-boundary .mini-label{color:#dc2626;font-weight:600}.canvas-overlay{position:absolute;top:16px;left:50%;transform:translate(-50%);z-index:1000;pointer-events:none}.overlay-content{background:var(--bg-primary);padding:12px 24px;border-radius:8px;box-shadow:0 4px 12px #00000026;text-align:center;min-width:450px}.overlay-action{font-size:14px;font-weight:600;margin-bottom:4px;letter-spacing:.3px}.overlay-keybinds{font-size:12px;color:var(--color-secondary);margin-bottom:8px;display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}.keybind-group{display:inline-flex;flex-direction:column;align-items:center;gap:6px}.keybind-keys{display:inline-flex;align-items:center;gap:4px}.keybind-separator{opacity:.5;margin:0 4px}.keybind-label{font-size:12px;opacity:.9}.key{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:20px;padding:0 6px;background:#ffffff26;border:1px solid rgba(255,255,255,.25);border-radius:4px;font-size:11px;font-weight:600;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--color-background);box-shadow:0 1px 2px #0000001a;line-height:1}.key-arrow{min-width:20px;padding:0 4px;font-size:13px}.overlay-instruction{font-size:13px;font-weight:500;opacity:.95}[data-theme=dark] .overlay-content{box-shadow:0 4px 12px #0006}.navbar-dropdown{position:relative;display:flex;align-items:center;height:100%}.navbar-dropdown-trigger{width:48px;height:100%;background:var(--bg-primary);color:var(--text-secondary);border:none;border-left:1px solid var(--border-color);font-size:20px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;padding:0}.navbar-dropdown-trigger:hover{background:var(--bg-hover)}.navbar-dropdown-trigger:active{background:var(--bg-active)}.navbar-dropdown-menu{position:absolute;top:100%;right:0;background:var(--bg-primary);border:1px solid var(--border-color);border-top:none;border-radius:0 0 6px 6px;box-shadow:0 4px 12px var(--shadow-color);min-width:200px;z-index:10000;overflow:hidden}.navbar-dropdown-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 16px;background:var(--bg-primary);color:var(--text-secondary);border:none;border-bottom:1px solid var(--border-color);font-size:14px;cursor:pointer;transition:all .2s;text-align:left;white-space:nowrap}.navbar-dropdown-item:last-child{border-bottom:none}.navbar-dropdown-item:hover{background:var(--bg-hover);color:var(--text-primary)}.navbar-dropdown-item:active{background:var(--bg-active)}.navbar-dropdown-icon{display:flex;align-items:center;justify-content:center;font-size:16px}.navbar{display:flex;align-items:stretch;justify-content:space-between;height:48px;background:var(--bg-primary);border-bottom:1px solid var(--border-color);box-shadow:0 1px 3px var(--shadow-color);z-index:10000}.navbar-left{display:flex;align-items:center;justify-content:center;position:relative;padding-left:.75rem}.navbar-logo-link{display:flex;align-items:center;text-decoration:none;gap:0}.navbar-logo-link:hover{opacity:.8}.navbar-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0;padding:0;letter-spacing:.5px;border:none;line-height:48px;display:block}.navbar-center{display:flex;align-items:center;justify-content:center;position:absolute;left:50%;top:0;height:48px;transform:translate(-50%);pointer-events:none;border:none!important}.navbar-right{display:flex;align-items:stretch}.navbar-button{width:48px;height:100%;background:var(--bg-primary);color:var(--text-secondary);border:none;font-size:20px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;padding:0}.navbar-button:hover{background:var(--bg-hover);color:var(--text-secondary)}.navbar-button:active{background:var(--bg-active);color:var(--text-secondary)}.navbar-button.collapse-button{border-right:1px solid var(--border-color)}.navbar-button.save-browser-button,.navbar-button.download-button{border-left:1px solid var(--border-color)}.navbar .navbar-button.back-button{padding:0;width:48px;background:var(--bg-primary);border:none;border-radius:0;color:var(--text-secondary)}.navbar-button.canvas-collapse-button{border-right:1px solid var(--border-color)}.navbar-github-indicator{display:flex;align-items:center;gap:.375rem;padding:.25rem .5rem;margin-left:.75rem;background:var(--accent-color-muted);border:1px solid var(--border-color);border-radius:12px;color:var(--text-primary);font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s ease;pointer-events:auto;text-decoration:none}.navbar-github-indicator:hover{background:var(--bg-hover);color:#fff}.navbar-github-indicator span{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.navbar-local-file-indicator{display:flex;align-items:center;gap:.375rem;padding:.25rem .5rem;margin-left:.75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;color:var(--text-secondary);font-size:.75rem;font-weight:500;transition:all .15s ease}.navbar-local-file-indicator span{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.navbar-save-indicator{display:flex;align-items:center;gap:.375rem;padding:.25rem .625rem;margin-left:.75rem;border:1px solid var(--border-color);border-radius:12px;font-size:.75rem;font-weight:500;transition:all .15s ease;pointer-events:auto;text-decoration:none;white-space:nowrap}.navbar-save-indicator--github{background:var(--accent-color-muted);color:var(--text-primary);cursor:pointer}.navbar-save-indicator--github:hover{background:var(--bg-hover);color:#fff}.navbar-save-indicator--file,.navbar-save-indicator--browser{background:var(--bg-secondary);color:var(--text-secondary)}.navbar-save-indicator--none{background:transparent;border-color:transparent;color:var(--text-secondary);opacity:.7}.navbar-indicator-name{max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.navbar-indicator-saved{color:var(--text-secondary);font-weight:400;font-size:.6875rem;opacity:.8}.navbar-indicator-dirty{color:var(--accent-color, #3b82f6);font-size:.875rem;line-height:1;margin-left:-.125rem}.navbar-dropdown-shortcut{margin-left:auto;padding-left:1rem;font-size:.6875rem;color:var(--text-secondary);opacity:.7;font-weight:400}.toast-container{position:fixed;top:60px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:12px;max-width:400px}.toast{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;animation:slideIn .3s ease-out;min-width:300px;border-left:4px solid}.toast-info{border-left-color:#3b82f6}.toast-success{border-left-color:#10b981}.toast-error{border-left-color:#ef4444}.toast-loading,.toast-warning{border-left-color:#f59e0b}.toast-icon{font-size:20px;font-weight:700;flex-shrink:0;display:flex;align-items:center;justify-content:center;width:24px;height:24px}.toast-info .toast-icon{color:#3b82f6}.toast-success .toast-icon{color:#10b981}.toast-error .toast-icon{color:#ef4444}.toast-loading .toast-icon{color:#f59e0b;animation:spin 1s linear infinite}.toast-warning .toast-icon{color:#f59e0b}.toast-message{flex:1;color:#1f2937;font-size:14px;line-height:1.5}.toast-dismiss{background:none;border:none;color:#6b7280;cursor:pointer;font-size:18px;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .2s}.toast-dismiss:hover{color:#1f2937}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}[data-theme=dark] .toast{background:#1f2937}[data-theme=dark] .toast-message{color:#f3f4f6}[data-theme=dark] .toast-dismiss{color:#9ca3af}[data-theme=dark] .toast-dismiss:hover{color:#f3f4f6}
