.sketch-canvas{display:block}.node-label{fill:var(--text-primary,#212529);pointer-events:none;-webkit-user-select:none;user-select:none;font-size:13px}.node-type-badge{fill:var(--text-secondary,#6c757d);pointer-events:none;-webkit-user-select:none;user-select:none;text-transform:uppercase;letter-spacing:.5px;font-size:9px}.edge-label{fill:var(--text-secondary,#6c757d);pointer-events:none;-webkit-user-select:none;user-select:none;font-size:11px}g.node{cursor:grab}g.node:hover{filter:brightness(1.05)}g.node.dragging{cursor:grabbing;filter:brightness(1.1)drop-shadow(0 2px 8px #00000026)}g.node.selected{filter:brightness(1.05)}.container-label{fill:var(--text-secondary,#6c757d);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.selection-highlight{pointer-events:none}.selection-overlay .resize-handle{transition:opacity .1s}.selection-overlay .resize-handle:hover rect{fill:#1a73e8}.selection-overlay .node-delete{opacity:0;transition:opacity .15s}.selection-node-overlay:hover .node-delete{opacity:1}.connection-port{cursor:crosshair;transition:opacity .15s}.connection-port:hover circle{r:8;fill:#3b82f6;stroke:#1d4ed8}.connection-port:hover path{stroke:#fff}.edge-drawing-line{pointer-events:none;animation:.6s linear infinite edge-draw-dash}.edge-drawing-active .connection-port{opacity:.6!important}@keyframes edge-draw-dash{to{stroke-dashoffset:-20px}}g.edge{cursor:pointer}g.edge.selected path,g.edge.selected line{stroke:var(--accent-pink,#ec4899)!important;stroke-width:3px!important}.edge-delete{transition:opacity .15s}.pin-indicator{pointer-events:none;transition:opacity .15s}.sketch-canvas.drag-over{outline:2px dashed var(--accent-pink,#ec4899);outline-offset:-2px}.zoom-controls{border:1px solid var(--border-color,#dee2e6);z-index:10;-webkit-user-select:none;user-select:none;background:#ffffffeb;border-radius:8px;align-items:center;gap:2px;padding:4px 6px;display:flex;position:absolute;bottom:12px;right:12px;box-shadow:0 2px 8px #00000014}.zoom-btn{cursor:pointer;width:28px;height:28px;color:var(--text-primary,#212529);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;font-size:16px;transition:background .15s;display:flex}.zoom-btn:hover{background:var(--bg-hover,#f1f3f5)}.zoom-btn:active{background:var(--bg-active,#e9ecef)}.zoom-level{text-align:center;min-width:40px;color:var(--text-secondary,#6c757d);font-size:12px;font-weight:500}.box-select-rect{pointer-events:none}.status-save-dirty,.status-save-saving,.status-save-saved,.status-save-error{margin-left:auto}.status-save-dirty{color:var(--text-secondary,#6c757d)}.status-save-saving{color:var(--accent-pink,#ec4899)}.status-save-saved{color:#22c55e}.status-save-error{color:var(--danger-color,#dc3545)}.ai-thinking .node,.ai-thinking .edge{animation:1.5s ease-in-out infinite ai-pulse}@keyframes ai-pulse{0%,to{opacity:1;filter:none}50%{opacity:.5;filter:brightness(1.2)}}.grid-bg,.alignment-guides line{pointer-events:none}.align-tools{align-items:center;gap:2px;padding:0 4px;display:flex}.align-btn{cursor:pointer;color:var(--text-primary,#212529);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;transition:background .15s;display:flex;width:26px!important;height:26px!important;padding:0!important}.align-btn:hover{background:var(--bg-hover,#f1f3f5)}.align-btn:active{background:var(--bg-active,#e9ecef)}.align-btn svg{flex-shrink:0}.sketch-ctx-menu{z-index:1000;background:var(--bg-primary,#fff);border:1px solid var(--border-color,#e5e7eb);border-radius:8px;min-width:170px;padding:4px;font-size:13px;position:fixed;box-shadow:0 8px 24px #0000001f}.sketch-ctx-item{cursor:pointer;color:var(--text-primary,#212529);border-radius:4px;align-items:center;gap:8px;padding:6px 12px;transition:background .1s;display:flex}.sketch-ctx-item:hover{background:var(--bg-hover,#f1f3f5)}.sketch-ctx-separator{background:var(--border-color,#e5e7eb);height:1px;margin:4px 0}.node-lock-icon{opacity:.7}g.node.locked{cursor:default}.toolbar-bg{border:1px solid var(--border-color,#dee2e6);background:var(--bg-card,#fff);color:var(--text-primary,#212529);cursor:pointer;border-radius:4px;padding:2px 4px;font-size:12px}.minimap{border:1px solid var(--border-color,#dee2e6);z-index:10;cursor:pointer;-webkit-user-select:none;user-select:none;background:#fffffff2;border-radius:6px;width:150px;height:100px;position:absolute;bottom:12px;left:30px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.minimap canvas{width:150px;height:100px;display:block}.search-bar-wrapper{z-index:20;width:280px;position:absolute;top:12px;left:50%;transform:translate(-50%)}.search-bar-input{border:1px solid var(--border-color,#dee2e6);width:100%;color:var(--text-primary,#212529);box-sizing:border-box;background:#fff;border-radius:8px;outline:none;padding:8px 14px;font-size:14px;box-shadow:0 2px 12px #0000001a}.search-bar-input:focus{border-color:var(--accent-pink,#ec4899);box-shadow:0 2px 12px #ec489926}.search-bar-dropdown{border:1px solid var(--border-color,#dee2e6);background:#fff;border-radius:8px;max-height:320px;margin-top:2px;overflow-y:auto;box-shadow:0 4px 16px #0000001a}.search-bar-dropdown:empty{display:none}.search-bar-item{cursor:pointer;justify-content:space-between;align-items:center;padding:8px 12px;font-size:13px;transition:background .1s;display:flex}.search-bar-item:hover{background:var(--bg-hover,#f1f3f5)}.search-bar-item-label{color:var(--text-primary,#212529);text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:500;overflow:hidden}.search-bar-item-type{color:var(--text-secondary,#6c757d);text-transform:uppercase;letter-spacing:.5px;flex-shrink:0;margin-left:8px;font-size:11px}.search-bar-empty{color:var(--text-secondary,#6c757d);cursor:default;justify-content:center}.search-bar-empty:hover{background:0 0}.shape-toolbar{border:1px solid var(--border-color,#dee2e6);z-index:10;-webkit-user-select:none;user-select:none;background:#fffffff2;border-radius:8px;flex-direction:column;gap:2px;max-height:400px;padding:4px;display:flex;position:absolute;top:50%;left:12px;overflow-y:auto;transform:translateY(-50%);box-shadow:0 2px 8px #00000014}.shape-toolbar-btn{cursor:pointer;color:var(--text-primary,#212529);white-space:nowrap;background:0 0;border:none;border-radius:6px;align-items:center;gap:6px;padding:5px 8px;font-size:12px;transition:background .15s;display:flex}.shape-toolbar-btn:hover{background:var(--bg-hover,#f1f3f5)}.shape-toolbar-btn.active{background:var(--accent-pink,#ec4899);color:#fff}.shape-toolbar-icon{background:var(--bg-hover,#f1f3f5);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;font-weight:600;display:flex}.shape-toolbar-btn.active .shape-toolbar-icon{background:#ffffff40}.shape-toolbar-label{font-size:11px}.edge-reconnect-handle{cursor:grab;transition:r .15s}.edge-reconnect-handle:hover{r:8}.edge-reconnect-line{pointer-events:none;animation:.6s linear infinite edge-draw-dash}.presentation-hidden{display:none!important}.presentation-fullscreen{z-index:9998!important;width:100vw!important;height:100vh!important;margin:0!important;padding:0!important;position:fixed!important;inset:0!important}.presentation-overlay{z-index:9999;pointer-events:none;position:fixed;inset:0}.presentation-exit-btn{z-index:10000;pointer-events:auto;color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000073;border:none;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:500;transition:background .2s;position:fixed;bottom:24px;right:24px}.presentation-exit-btn:hover{background:#000000b3}.presentation-counter{z-index:10000;pointer-events:none;color:#fff;font-variant-numeric:tabular-nums;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);letter-spacing:1px;background:#00000073;border-radius:16px;padding:6px 16px;font-size:14px;font-weight:600;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.toolbar-bg-color{border:1px solid var(--border-color,#dee2e6);cursor:pointer;vertical-align:middle;background:0 0;border-radius:4px;width:28px;height:26px;padding:1px}.canvas-ruler{z-index:11;-webkit-user-select:none;user-select:none;border-color:var(--border-color,#dee2e6);cursor:pointer;background:#fffffff2;position:absolute;overflow:hidden}.canvas-ruler-h{border-bottom:1px solid var(--border-color,#dee2e6);height:20px;top:0;left:20px;right:0}.canvas-ruler-v{border-right:1px solid var(--border-color,#dee2e6);width:20px;top:20px;bottom:0;left:0}.canvas-ruler canvas{display:block}.canvas-ruler-h canvas{height:20px}.canvas-ruler-v canvas{width:20px}.ruler-guide-line{pointer-events:none}.signup-prompt{text-align:center}.signup-subtitle{color:var(--text-secondary);margin-bottom:20px;font-size:14px}.plan-picker{gap:10px;margin-bottom:20px;display:flex}.plan-option{border:2px solid var(--border-color);background:var(--bg-secondary);cursor:pointer;text-align:center;border-radius:10px;flex:1;padding:12px 16px;transition:all .2s}.plan-option strong{color:var(--text-primary);margin-bottom:2px;font-size:14px;display:block}.plan-option span{color:var(--text-secondary);font-size:13px}.plan-option:hover{border-color:#ec48994d}.plan-option-active{border-color:var(--accent-pink);background:#ec48990d}.plan-option-active strong{color:var(--accent-pink)}.oauth-buttons{flex-direction:column;gap:10px;margin-bottom:16px;display:flex}.oauth-btn-container{min-height:44px}.oauth-btn-container>div,.oauth-btn-container>div>div{width:100%!important;max-width:100%!important}.oauth-btn-container iframe{width:100%!important}.oauth-btn{border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:10px 16px;font-size:14px;transition:background .15s;display:flex}.oauth-btn:hover{background:var(--border-color)}.oauth-icon{border-radius:4px;justify-content:center;align-items:center;width:24px;height:24px;font-size:16px;font-weight:700;display:flex}.google-btn .oauth-icon{color:#4285f4}.facebook-btn .oauth-icon{color:#1877f2}.microsoft-btn .oauth-icon{color:#00a4ef}.oauth-icon-svg{flex-shrink:0;width:20px;height:20px}.upgrade-features{text-align:left;margin-bottom:20px;padding:0;list-style:none}.upgrade-features li{color:var(--text-secondary);align-items:center;gap:8px;padding:6px 0;font-size:14px;display:flex}.upgrade-features .check{color:var(--accent-green,#10b981);font-weight:700}.ctx-picker{text-align:center;width:720px;max-width:95vw;padding:20px 24px}.ctx-picker-header{margin-bottom:16px}.ctx-picker-icon{width:40px;height:40px;color:var(--accent-pink);background:linear-gradient(135deg,#ec48991a,#f973161a);border-radius:10px;justify-content:center;align-items:center;margin-bottom:8px;display:inline-flex}.ctx-picker-header h2{margin-bottom:8px;font-size:22px;font-weight:700}.ctx-picker-header p{color:var(--text-muted);font-size:14px;line-height:1.5}.ctx-picker-section{margin-bottom:14px}.ctx-picker-label{text-transform:uppercase;letter-spacing:.8px;text-align:left;border-bottom:1px solid var(--border-subtle,#f3f4f6);align-items:center;gap:8px;margin-bottom:14px;padding-bottom:8px;font-size:12px;font-weight:600;display:flex}.ctx-picker-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;display:inline-block}.ctx-picker-grid{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.ctx-pick-card{border:1px solid var(--border-color);background:var(--bg-card);cursor:pointer;border-radius:12px;flex-direction:column;align-items:center;gap:8px;padding:18px 10px;transition:all .2s;display:flex}.ctx-pick-card:hover{border-color:var(--card-color,var(--accent-pink));background:var(--card-hover-bg,#ec48990a);box-shadow:var(--shadow-md);transform:translateY(-1px)}.ctx-pick-icon{background:var(--card-icon-bg,#ec489914);border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.ctx-pick-icon svg{width:20px;height:20px;color:var(--card-color,var(--accent-pink))}.ctx-pick-label{color:var(--text-primary);font-size:12px;font-weight:500;line-height:1.2}.ctx-pro-badge{text-transform:uppercase;letter-spacing:.3px;color:#fff;vertical-align:middle;background:linear-gradient(135deg,#ec4899,#f97316);border-radius:4px;margin-left:3px;padding:1px 5px;font-size:9px;font-weight:600;display:inline-block}.ctx-pick-locked{opacity:.6}.ctx-pick-locked:hover{opacity:.85}.ctx-item-locked{opacity:.55}.ctx-item-locked:hover{opacity:.8}.confirm-overlay{z-index:2000}.confirm-dialog{text-align:center;width:400px}.confirm-message{color:var(--text-secondary);margin-bottom:24px;font-size:14px;line-height:1.5}.confirm-actions{justify-content:center;gap:10px;display:flex}.confirm-btn-cancel{flex:1}.confirm-btn-primary{background:var(--gradient-primary);color:#fff;border-color:#0000;flex:1}.confirm-btn-danger{background:var(--danger-color);color:#fff;border-color:#0000;flex:1}.relayout-dialog{text-align:center;width:440px}.relayout-options{flex-direction:column;gap:10px;margin-bottom:16px;display:flex}.relayout-option{border:1px solid var(--border-color);background:var(--bg-card);cursor:pointer;text-align:left;border-radius:12px;align-items:flex-start;gap:14px;padding:16px;transition:all .2s;display:flex}.relayout-option:hover{border-color:var(--accent-pink);box-shadow:var(--shadow-md);background:linear-gradient(135deg,#ec489908,#f9731608);transform:translateY(-1px)}.relayout-option-ai{border-color:#ec489933}.relayout-option-icon{width:44px;height:44px;color:var(--accent-pink);background:linear-gradient(135deg,#ec489914,#f9731614);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.relayout-option-text{flex-direction:column;gap:3px;display:flex}.relayout-option-text strong{font-size:14px}.relayout-option-text span{color:var(--text-muted);font-size:12px;line-height:1.4}@media (width<=600px){.ctx-picker-grid{grid-template-columns:repeat(3,1fr)}.ctx-picker{width:95vw}}.welcome-modal{text-align:center;padding:40px 48px 32px;width:680px!important;max-width:95vw!important}.welcome-header{margin-bottom:24px}.welcome-icon{background:linear-gradient(135deg,#ec48991a,#f973161a);border-radius:16px;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:16px;display:inline-flex}.welcome-header h2{margin-bottom:8px;font-size:24px;font-weight:700}.welcome-subtitle{color:var(--text-secondary);font-size:15px;line-height:1.5}.welcome-features{text-align:left;flex-direction:column;gap:14px;margin-bottom:24px;display:flex}.welcome-feature{background:var(--bg-secondary);border-radius:10px;align-items:flex-start;gap:14px;padding:12px;display:flex}.welcome-feature-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.welcome-feature div:last-child{flex-direction:column;gap:2px;display:flex}.welcome-feature strong{color:var(--text-primary);font-size:14px;font-weight:600}.welcome-feature span{color:var(--text-secondary);font-size:12px;line-height:1.4}.welcome-comparison{gap:12px;margin-bottom:24px;display:flex}.welcome-plan{border:1px solid var(--border-color);text-align:left;border-radius:10px;flex:1;padding:14px}.welcome-plan-header{text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-size:13px;font-weight:700}.welcome-plan ul{margin:0;padding:0;list-style:none}.welcome-plan li{color:var(--text-secondary);padding:3px 0;font-size:12px;line-height:1.4}.welcome-plan li:before{content:"✓";color:var(--accent-green,#10b981);margin-right:4px;font-weight:700}.welcome-cta{background:var(--gradient-primary);color:#fff;cursor:pointer;border:none;border-radius:10px;width:100%;margin-bottom:12px;padding:14px;font-size:15px;font-weight:600;transition:box-shadow .2s;display:block}.welcome-cta:hover{box-shadow:0 4px 16px #ec48994d}.welcome-fine-print{color:var(--text-muted);font-size:12px}.welcome-hero{margin-bottom:28px}.welcome-logo{margin-bottom:12px}.welcome-logo img{border-radius:12px}.welcome-tagline{color:var(--text-secondary);font-size:15px}.welcome-grid{text-align:left;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:28px;display:grid}.welcome-card{border:1px solid var(--border-color);background:var(--bg-primary);border-radius:10px;flex-direction:column;gap:4px;padding:16px;display:flex}.welcome-card-icon{margin-bottom:4px}.welcome-card strong{color:var(--text-primary);font-size:13px;font-weight:600}.welcome-card span{color:var(--text-secondary);font-size:12px;line-height:1.4}.welcome-style-section{margin-bottom:24px}.welcome-style-label{color:var(--text-primary);margin-bottom:12px;font-size:13px;font-weight:600}.welcome-style-options{justify-content:center;gap:16px;max-width:440px;margin:0 auto;display:flex}.welcome-style-option{border:2px solid var(--border-color);background:var(--bg-primary);cursor:pointer;text-align:center;border-radius:12px;flex-direction:column;flex:1;align-items:center;gap:8px;max-width:200px;padding:16px;transition:border-color .2s,box-shadow .2s;display:flex}.welcome-style-option:hover{border-color:var(--text-muted)}.welcome-style-option.active{border-color:var(--accent-pink,#ec4899);box-shadow:0 0 0 3px #ec48991a}.welcome-style-preview{border:1px solid var(--border-color);background:#fafafa;border-radius:8px;overflow:hidden}.welcome-style-option strong{color:var(--text-primary);font-size:14px;font-weight:600}.welcome-style-option span{color:var(--text-muted);font-size:11px}@media (width<=600px){.welcome-grid{grid-template-columns:1fr}.welcome-style-options{flex-direction:column;align-items:center}}.signup-dismiss{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;padding:8px;font-size:13px}.signup-dismiss:hover{color:var(--text-primary)}.toolbar-user{align-items:center;gap:6px;margin-left:auto;display:flex}.toolbar-avatar{object-fit:cover;border-radius:50%;width:28px;height:28px}.toolbar-username{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;max-width:100px;font-size:12px;overflow:hidden}.file-manager-dialog{flex-direction:column;height:70vh;display:flex;width:900px!important;max-width:95vw!important;max-height:80vh!important;padding:0!important}.fm-header{justify-content:space-between;align-items:center;padding:20px 24px 0;display:flex}.fm-header h2{margin:0;font-size:18px}.fm-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:24px;line-height:1}.fm-close:hover{color:var(--text-primary);background:var(--bg-secondary)}.fm-toolbar{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;gap:12px;padding:12px 24px;display:flex}.fm-action-btn{border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;white-space:nowrap;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;transition:background .15s;display:inline-flex}.fm-action-btn:hover{background:var(--border-color)}.fm-body{flex:1;min-height:0;display:flex}.fm-main{border-right:1px solid var(--border-color);flex-direction:column;flex:1;min-width:0;max-width:440px;display:flex}.fm-detail{background:var(--bg-secondary);flex:1;min-width:0;overflow-y:auto}.fm-detail-empty{height:100%;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;font-size:13px;display:flex}.fm-detail-content{padding:20px}.fm-detail-title{color:var(--text-primary);margin:0 0 4px;font-size:16px;font-weight:700;line-height:1.3}.fm-detail-meta{color:var(--text-muted);margin-bottom:16px;font-size:12px}.fm-detail-section{margin-bottom:16px}.fm-detail-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:11px;font-weight:600}.fm-detail-canvas{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;justify-content:center;align-items:center;min-height:120px;padding:8px;display:flex}.fm-detail-text{color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;max-height:120px;padding:8px;font-size:12px;line-height:1.6;overflow-y:auto}.fm-detail-summary{white-space:pre-wrap}.fm-detail-actions{justify-content:space-between;align-items:center;margin-top:20px;display:flex}.fm-detail-actions-left{gap:8px;display:flex}.fm-btn-danger{color:var(--danger-color)}.fm-btn-danger:hover{color:var(--danger-color);background:#ef444414}.fm-item-selected{border-left:2px solid var(--accent-pink);background:#ec48990f!important}.fm-list{flex:1;padding:8px 16px 16px;overflow-y:auto}.fm-item{border-radius:8px;align-items:center;gap:12px;padding:10px 12px;transition:background .15s;display:flex;position:relative}.fm-item:hover{background:var(--bg-secondary)}.fm-item-icon{width:36px;height:36px;color:var(--accent-pink);background:#ec489914;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.fm-diagram-icon{color:var(--accent-blue);background:#3b82f614}.fm-diagram-icon svg{width:18px;height:18px}.fm-item-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.fm-item-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:500;overflow:hidden}.fm-item-meta{color:var(--text-muted);font-size:12px}.fm-item-actions{opacity:0;gap:4px;transition:opacity .15s;display:flex}.fm-item:hover .fm-item-actions{opacity:1}.fm-btn{border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;border-radius:6px;padding:5px 10px;font-size:12px;transition:background .15s}.fm-btn:hover{background:var(--border-color)}.fm-btn-primary{background:var(--gradient-primary);color:#fff;border-color:#0000;font-weight:600}.fm-btn-primary:hover{background:var(--gradient-primary);box-shadow:0 2px 8px #ec489933}.fm-btn-icon{color:var(--text-muted);justify-content:center;align-items:center;padding:5px;display:flex}.fm-btn-icon:hover{color:var(--text-primary)}.move-popover{z-index:10;background:var(--bg-card);border:1px solid var(--border-color);box-shadow:var(--shadow-lg);border-radius:10px;width:260px;padding:12px;position:absolute;top:100%;right:0}.move-popover-header{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:8px;font-size:13px;font-weight:600;overflow:hidden}.move-folder-select{width:100%;margin-bottom:8px}.move-popover-actions{justify-content:flex-end;gap:6px;display:flex}.folder-breadcrumb{flex-wrap:wrap;flex:1;align-items:center;gap:2px;min-width:0;font-size:13px;display:flex}.breadcrumb-link{color:var(--accent-pink);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:13px}.breadcrumb-link:hover{background:#ec489914}.breadcrumb-sep{color:var(--text-muted);margin:0 2px}.breadcrumb-current{color:var(--text-primary);padding:2px 6px;font-weight:600}.save-dialog{width:620px!important;max-width:95vw!important;padding:0!important}.save-tabs{border-bottom:1px solid var(--border-color);display:flex}.save-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:14px 16px;font-size:14px;font-weight:500;transition:all .2s}.save-tab:hover{color:var(--text-primary);background:var(--bg-secondary)}.save-tab.active{color:var(--accent-pink);border-bottom-color:var(--accent-pink)}.save-tab-content{padding:20px 24px}.save-textarea{resize:vertical;border:1px solid var(--border-color);background:var(--bg-secondary);width:100%;color:var(--text-primary);border-radius:8px;padding:10px 12px;font-family:inherit;font-size:13px;line-height:1.6}.save-textarea:focus{border-color:var(--accent-pink);outline:none;box-shadow:0 0 0 2px #ec48991a}.save-textarea[readonly]{opacity:.8;cursor:default}.folder-picker{align-items:stretch;gap:8px;display:flex}.create-choice-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.create-choice-card{border:1px solid var(--border-color);background:var(--bg-primary);cursor:pointer;text-align:center;border-radius:10px;flex-direction:column;align-items:center;gap:6px;padding:18px 14px;transition:border-color .15s,box-shadow .15s;display:flex}.create-choice-card:hover{border-color:var(--accent-pink,#ec4899);box-shadow:0 2px 8px #ec489914}.create-choice-card svg,.create-choice-icon{color:var(--text-secondary);width:28px;height:28px;margin-bottom:2px}.create-choice-icon svg{width:100%;height:100%}.create-choice-card strong{color:var(--text-primary);font-size:13px;font-weight:600}.create-choice-card span{color:var(--text-muted);font-size:11px;line-height:1.3}@media (width<=500px){.create-choice-grid{grid-template-columns:1fr}}.create-tabs{border-bottom:1px solid var(--border-color);gap:0;margin-bottom:16px;display:flex}.create-tab{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:8px 12px;font-size:13px;font-weight:500;transition:color .15s,border-color .15s}.create-tab:hover{color:var(--text-primary)}.create-tab.active{color:var(--accent-pink,#ec4899);border-bottom-color:var(--accent-pink,#ec4899)}.create-template-list{flex-direction:column;gap:6px;max-height:350px;display:flex;overflow-y:auto}.create-template-card{border:1px solid var(--border-color);cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;transition:border-color .15s,background .15s;display:flex}.create-template-card:hover{border-color:var(--accent-pink,#ec4899);background:#ec489908}.create-template-icon{width:28px;height:28px;color:var(--text-secondary);flex-shrink:0}.create-template-icon svg{width:100%;height:100%}.create-template-info{flex-direction:column;gap:2px;min-width:0;display:flex}.create-template-info strong{color:var(--text-primary);font-size:13px;font-weight:600}.create-template-info span{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.notes-label-row{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.notes-label-row label{margin-bottom:0}#create-context-container .ctx-dropdown{width:100%;display:block!important}#create-context-container .ctx-trigger{justify-content:space-between;width:100%}#create-context-container .ctx-panel{width:100%;max-height:280px;left:0;right:0}.save-dialog:has(.ctx-dropdown-open){overflow:visible}.save-dialog:has(.ctx-dropdown-open) .save-tab-content{overflow:visible}.fm-inline-input{border:1px solid var(--accent-pink);background:var(--bg-primary);color:var(--text-primary);border-radius:6px;outline:none;width:100%;padding:6px 10px;font-family:inherit;font-size:13px}.fm-inline-input:focus{box-shadow:0 0 0 2px #ec489926}@media (width<=900px){.file-manager-dialog{border-radius:12px 12px 0 0;width:100%!important;max-height:90vh!important}.fm-detail{display:none}.fm-main{border-right:none}}.export-dialog{width:440px}.export-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.export-header h2{margin:0;font-size:18px}.export-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:22px;line-height:1}.export-close:hover{color:var(--text-primary)}.export-error{color:var(--danger-color);background:#ef44440f;border-radius:6px;margin-bottom:10px;padding:8px 12px;font-size:13px;display:none}.export-formats{gap:8px;margin-bottom:16px;display:flex}.export-format-btn{border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;border-radius:10px;flex-direction:column;flex:1;align-items:center;gap:6px;padding:14px 8px;font-size:12px;font-weight:500;transition:border-color .15s,background .15s;display:flex}.export-format-btn:hover{border-color:var(--accent-pink);background:#ec48990a}.export-format-icon{width:36px;height:36px;color:var(--text-secondary);background:#ffffff0f;border-radius:8px;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:flex}.export-warning{color:var(--text-secondary);background:#f59e0b14;border:1px solid #f59e0b33;border-radius:8px;margin-bottom:12px;padding:8px 12px;font-size:12px}.export-warning strong{color:#f59e0b}.export-mermaid-preview{display:none}.export-preview-label{color:var(--text-secondary);margin-bottom:6px;font-size:12px;font-weight:500}.export-preview-code{background:var(--bg-secondary);border:1px solid var(--border-color);white-space:pre-wrap;word-break:break-all;max-height:180px;color:var(--text-primary);border-radius:8px;margin:0;padding:12px;font-family:SF Mono,Cascadia Code,Fira Code,monospace;font-size:12px;overflow-y:auto}.export-actions{gap:6px;margin-top:10px;display:flex}.export-action-btn{border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;border-radius:6px;padding:6px 12px;font-size:12px;transition:all .15s}.export-action-btn:hover{border-color:var(--accent-pink);color:var(--accent-pink)}.export-badge-output{border-top:1px solid var(--border-color);margin-top:10px;padding-top:10px;display:none}.export-badge-label{color:var(--text-muted);margin-bottom:4px;font-size:11px}.export-badge-snippet{background:var(--bg-secondary);width:100%;height:50px;color:var(--text-primary);border:1px solid var(--border-color);resize:none;box-sizing:border-box;border-radius:6px;margin-bottom:6px;padding:8px;font-family:monospace;font-size:11px}.mn-dialog{flex-direction:column;width:90vw;max-width:640px;max-height:80vh;display:flex}.mn-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.mn-header h2{white-space:nowrap;text-overflow:ellipsis;flex:1;margin:0;font-size:18px;overflow:hidden}.mn-new-btn{white-space:nowrap;background:var(--gradient-primary)!important;color:#fff!important;border-color:#0000!important;font-weight:600!important}.mn-list{flex:1;min-height:120px;margin-bottom:16px;overflow-y:auto}.mn-empty{text-align:center;color:var(--text-secondary);padding:40px 20px}.mn-list-item{border:1px solid var(--border-color);border-radius:8px;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:8px;padding:12px;transition:border-color .15s;display:flex}.mn-list-item:hover{border-color:var(--accent-purple)}.mn-list-info{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.mn-list-title{color:var(--text-primary);font-size:14px}.mn-list-meta{color:var(--text-muted);font-size:12px}.mn-list-summary{color:var(--text-secondary);font-size:13px;line-height:1.4}.mn-list-actions{flex-shrink:0;gap:6px;display:flex}.mn-form{flex-direction:column;flex:1;gap:8px;margin-bottom:16px;display:flex;overflow-y:auto}.mn-label{color:var(--text-secondary);font-size:13px;font-weight:500}.mn-input{border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);border-radius:6px;outline:none;padding:8px 12px;font-family:inherit;font-size:14px;transition:border-color .15s}.mn-input:focus{border-color:var(--accent-purple)}.mn-textarea{border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);resize:vertical;border-radius:6px;outline:none;padding:10px 12px;font-family:inherit;font-size:13px;line-height:1.5;transition:border-color .15s}.mn-textarea:focus{border-color:var(--accent-purple)}.mn-form-error{color:var(--danger-color);font-size:13px}.mn-organize-btn{align-self:flex-start;margin-top:4px;background:var(--gradient-primary)!important;color:#fff!important;border-color:#0000!important;padding:8px 20px!important;font-weight:600!important}.mn-organize-btn:disabled{opacity:.6;cursor:not-allowed}.mn-detail{flex:1;margin-bottom:16px;overflow-y:auto}.mn-summary-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-left:3px solid var(--accent-purple);border-radius:8px;margin-bottom:20px;padding:14px 16px}.mn-summary-label{text-transform:uppercase;letter-spacing:.05em;color:var(--accent-purple);margin-bottom:6px;font-size:11px;font-weight:600}.mn-summary-text{color:var(--text-primary);margin:0;font-size:14px;line-height:1.5}.mn-folder{border:1px solid var(--border-color);border-radius:8px;margin-bottom:10px;overflow:hidden}.mn-folder-header{background:var(--bg-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;padding:10px 14px;transition:background .15s;display:flex}.mn-folder-header:hover{background:var(--border-subtle)}.mn-folder-header svg{color:var(--accent-purple);flex-shrink:0}.mn-folder-name{color:var(--text-primary);flex:1;font-size:14px;font-weight:600}.mn-folder-count{color:var(--text-muted);font-size:12px}.mn-folder-items{padding:6px 14px 10px}.mn-folder-collapsed .mn-folder-items{display:none}.mn-note-item{border-bottom:1px solid var(--border-subtle);align-items:flex-start;gap:8px;padding:6px 0;display:flex}.mn-note-item:last-child{border-bottom:none}.mn-item-badge{text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;border-radius:4px;flex-shrink:0;margin-top:2px;padding:2px 6px;font-size:10px;font-weight:600}.mn-item-action-item .mn-item-badge{color:var(--danger-color);background:#ef44441f}.mn-item-decision .mn-item-badge{color:var(--success-color);background:#10b9811f}.mn-item-discussion .mn-item-badge{color:var(--accent-blue);background:#3b82f61f}.mn-item-info .mn-item-badge{color:var(--text-muted);background:#9ca3af1f}.mn-item-text{color:var(--text-primary);font-size:13px;line-height:1.4}.mn-share-btn{white-space:nowrap}.mn-share-menu{z-index:10001;background:var(--bg-primary);border:1px solid var(--border-color);box-shadow:var(--shadow-lg);border-radius:8px;min-width:180px;padding:4px}.mn-share-option{width:100%;color:var(--text-primary);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:8px;padding:8px 12px;font-family:inherit;font-size:13px;transition:background .15s;display:flex}.mn-share-option:hover{background:var(--bg-secondary)}.mn-share-option svg{color:var(--text-secondary);flex-shrink:0}.mn-share-copied{text-align:center;color:var(--success-color);padding:6px;font-size:12px;font-weight:600}.dashboard{height:calc(100vh - var(--nav-height,56px));height:calc(100dvh - var(--nav-height,56px));background:var(--bg-primary);display:flex;overflow:hidden}.dashboard-sidebar{border-right:1px solid var(--border-color,#e5e7eb);background:var(--bg-secondary,#f9fafb);flex-direction:column;width:240px;min-width:240px;padding:16px 0;display:flex;overflow-y:auto}.dashboard-main{flex-direction:column;flex:1;display:flex;overflow:hidden}.dash-nav-section{margin-bottom:8px}.dash-nav-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted,#9ca3af);padding:8px 20px 4px;font-size:11px;font-weight:600}.dash-nav-item{color:var(--text-primary,#374151);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:0;align-items:center;gap:10px;width:100%;padding:8px 20px;font-size:13px;transition:background .15s;display:flex}.dash-nav-item:hover{background:var(--bg-hover,#f3f4f6)}.dash-nav-item.active{background:var(--accent-blue-bg,#eff6ff);color:var(--accent-blue,#3b82f6);font-weight:600}.dash-nav-item svg{opacity:.7;flex-shrink:0;width:16px;height:16px}.dash-nav-item.active svg{opacity:1}.dash-nav-separator{background:var(--border-color,#e5e7eb);height:1px;margin:8px 16px}.dash-folder-item{padding-left:36px;font-size:12px}.dash-topbar{border-bottom:1px solid var(--border-color,#e5e7eb);flex-shrink:0;align-items:center;gap:12px;padding:16px 24px;display:flex}.dash-new-btn{background:var(--accent-blue,#3b82f6);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;transition:background .15s;display:flex}.dash-new-btn:hover{background:var(--accent-blue-hover,#2563eb)}.dash-new-btn svg{width:16px;height:16px}.dash-import-mermaid-btn{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.dash-import-mermaid-btn:hover{background:var(--bg-tertiary,var(--bg-secondary));border-color:var(--accent-pink);color:var(--accent-pink)}.dash-search{flex:1;max-width:400px;position:relative}.dash-search input{border:1px solid var(--border-color,#e5e7eb);background:var(--bg-primary,#fff);width:100%;color:var(--text-primary,#374151);border-radius:8px;outline:none;padding:8px 12px 8px 34px;font-size:13px;transition:border-color .15s}.dash-search input:focus{border-color:var(--accent-blue,#3b82f6)}.dash-search svg{width:16px;height:16px;color:var(--text-muted,#9ca3af);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.dash-view-controls{align-items:center;gap:8px;margin-left:auto;display:flex}.dash-sort-select{border:1px solid var(--border-color,#e5e7eb);background:var(--bg-primary,#fff);color:var(--text-primary,#374151);cursor:pointer;border-radius:6px;outline:none;padding:6px 10px;font-size:12px}.dash-view-btn{border:1px solid var(--border-color,#e5e7eb);background:var(--bg-primary,#fff);color:var(--text-muted,#9ca3af);cursor:pointer;border-radius:6px;padding:6px;transition:all .15s}.dash-view-btn.active{background:var(--accent-blue-bg,#eff6ff);color:var(--accent-blue,#3b82f6);border-color:var(--accent-blue,#3b82f6)}.dash-view-btn svg{width:16px;height:16px;display:block}.dash-content{flex:1;padding:20px 24px;overflow-y:auto}.dash-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.dash-card{border:1px solid var(--border-color,#e5e7eb);background:var(--bg-primary,#fff);cursor:pointer;border-radius:10px;transition:box-shadow .2s,border-color .2s;position:relative;overflow:hidden}.dash-card:hover{border-color:var(--accent-blue,#3b82f6);box-shadow:0 4px 12px #00000014}.dash-card-thumb{background:var(--bg-secondary,#f9fafb);border-bottom:1px solid var(--border-color,#e5e7eb);justify-content:center;align-items:center;height:140px;display:flex;overflow:hidden}.dash-card-thumb svg{max-width:100%;max-height:100%}.dash-card-thumb .thumb-placeholder{color:var(--text-muted,#9ca3af);opacity:.3;font-size:32px}.dash-card-info{padding:12px}.dash-card-title{color:var(--text-primary,#374151);white-space:nowrap;text-overflow:ellipsis;margin-bottom:6px;font-size:13px;font-weight:600;overflow:hidden}.dash-card-meta{color:var(--text-muted,#9ca3af);justify-content:space-between;align-items:center;font-size:11px;display:flex}.dash-card-type{align-items:center;gap:4px;display:flex}.dash-card-type svg{width:14px;height:14px}.dash-card-star{cursor:pointer;opacity:0;background:#ffffffe6;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;transition:opacity .15s;display:flex;position:absolute;top:8px;right:8px}.dash-card:hover .dash-card-star,.dash-card-star.starred{opacity:1}.dash-card-star svg{width:16px;height:16px}.dash-card-star.starred svg{fill:#f59e0b;stroke:#f59e0b}.dash-card-menu{cursor:pointer;opacity:0;width:28px;height:28px;color:var(--text-secondary,#6b7280);background:#ffffffe6;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:16px;transition:opacity .15s;display:flex;position:absolute;top:8px;right:40px}.dash-card:hover .dash-card-menu{opacity:1}.dash-ctx-menu{z-index:1000;background:var(--bg-primary,#fff);border:1px solid var(--border-color,#e5e7eb);border-radius:8px;min-width:160px;padding:4px;font-size:13px;position:fixed;box-shadow:0 8px 24px #0000001f}.dash-ctx-item{text-align:left;cursor:pointer;width:100%;color:var(--text-primary,#374151);background:0 0;border:none;border-radius:6px;align-items:center;gap:8px;padding:8px 12px;transition:background .1s;display:flex}.dash-ctx-item:hover{background:var(--bg-hover,#f3f4f6)}.dash-ctx-item.danger{color:#ef4444}.dash-ctx-item.danger:hover{background:#fef2f2}.dash-ctx-item svg{flex-shrink:0;width:14px;height:14px}.dash-list{flex-direction:column;gap:2px;display:flex}.dash-list-item{cursor:pointer;border-radius:8px;align-items:center;gap:12px;padding:10px 12px;transition:background .1s;display:flex}.dash-list-item:hover{background:var(--bg-hover,#f3f4f6)}.dash-list-item-icon{background:var(--bg-secondary,#f9fafb);border-radius:6px;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.dash-list-item-icon svg{width:18px;height:18px;color:var(--text-muted,#9ca3af)}.dash-list-item-title{color:var(--text-primary,#374151);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:13px;font-weight:500;overflow:hidden}.dash-list-item-type{color:var(--text-muted,#9ca3af);min-width:120px;font-size:12px}.dash-list-item-date{color:var(--text-muted,#9ca3af);text-align:right;min-width:100px;font-size:12px}.dash-empty{text-align:center;color:var(--text-muted,#9ca3af);flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.dash-empty svg{opacity:.4;width:48px;height:48px;margin-bottom:16px}.dash-empty-title{color:var(--text-primary,#374151);margin-bottom:8px;font-size:16px;font-weight:600}.dash-empty-subtitle{max-width:300px;font-size:13px}.dash-templates{flex:1;padding:0;overflow-y:auto}.dash-template-category{margin-bottom:16px}.dash-template-category-title{color:var(--text-primary,#374151);margin-bottom:12px;font-size:14px;font-weight:600}.dash-template-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;display:grid}.dash-template-card{border:1px solid var(--border-color,#e5e7eb);cursor:pointer;background:var(--bg-primary,#fff);text-align:center;border-radius:8px;padding:16px;transition:all .15s}.dash-template-card:hover{border-color:var(--accent-blue,#3b82f6);box-shadow:0 2px 8px #3b82f61a}.dash-template-card svg{width:28px;height:28px;color:var(--text-secondary,#6b7280);margin-bottom:8px}.dash-template-card-name{color:var(--text-primary,#374151);margin-bottom:4px;font-size:13px;font-weight:600}.dash-template-card-desc{color:var(--text-muted,#9ca3af);font-size:11px}@media (width<=768px){.dashboard-sidebar{display:none}.dashboard.sidebar-open .dashboard-sidebar{left:0;top:var(--nav-height,56px);z-index:100;display:flex;position:fixed;bottom:0;box-shadow:4px 0 20px #0000001a}.dash-topbar{padding:12px 16px}.dash-content{padding:16px}.dash-grid{grid-template-columns:1fr}}.app-root.app-mode-authenticated .landing-content,.app-root.app-mode-authenticated .nav-links,.app-root.app-mode-authenticated .nav-hamburger{display:none}.app-root.app-mode-authenticated{height:100dvh;overflow:hidden}.dashboard-mount.hidden,.sketch-section.hidden{display:none}.dash-confirm-overlay{z-index:2000;background:#0006;justify-content:center;align-items:center;animation:.15s dash-fade-in;display:flex;position:fixed;inset:0}@keyframes dash-fade-in{0%{opacity:0}to{opacity:1}}.dash-confirm-dialog{background:var(--bg-primary,#fff);border-radius:12px;width:400px;max-width:90vw;padding:24px;animation:.2s dash-slide-up;box-shadow:0 20px 60px #00000026}@keyframes dash-slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.dash-confirm-icon{background:#fef2f2;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:16px;display:flex}.dash-confirm-icon svg{color:#ef4444;width:24px;height:24px}.dash-confirm-title{color:var(--text-primary,#111827);margin-bottom:8px;font-size:16px;font-weight:600}.dash-confirm-message{color:var(--text-secondary,#6b7280);margin-bottom:20px;font-size:13px;line-height:1.5}.dash-confirm-actions{justify-content:flex-end;gap:8px;display:flex}.dash-confirm-btn{cursor:pointer;border:1px solid var(--border-color,#e5e7eb);background:var(--bg-primary,#fff);color:var(--text-primary,#374151);border-radius:8px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .15s}.dash-confirm-btn:hover{background:var(--bg-hover,#f3f4f6)}.dash-confirm-btn-danger{color:#fff;background:#ef4444;border-color:#ef4444}.dash-confirm-btn-danger:hover{background:#dc2626;border-color:#dc2626}
