@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&family=Outfit:wght@300;400;500;600;700;800&display=swap";:root{--qn-primary: #6C5CE7;--qn-primary-light: #A29BFE;--qn-primary-dark: #4A3DB8;--qn-primary-glow: rgba(108, 92, 231, .25);--qn-secondary: #00CEC9;--qn-secondary-light: #55EFC4;--qn-secondary-dark: #00B894;--qn-accent: #FD79A8;--qn-accent-light: #FDCB6E;--qn-accent-warm: #E17055;--qn-color-red: #FF6B6B;--qn-color-red-light: #FF8787;--qn-color-red-dark: #E03131;--qn-color-orange: #FF922B;--qn-color-orange-light: #FFA94D;--qn-color-orange-dark: #E8590C;--qn-color-yellow: #FCC419;--qn-color-yellow-light: #FFD43B;--qn-color-yellow-dark: #E67700;--qn-color-green: #51CF66;--qn-color-green-light: #69DB7C;--qn-color-green-dark: #2F9E44;--qn-color-teal: #20C997;--qn-color-teal-light: #38D9A9;--qn-color-teal-dark: #0CA678;--qn-color-cyan: #22B8CF;--qn-color-cyan-light: #3BC9DB;--qn-color-cyan-dark: #1098AD;--qn-color-blue: #339AF0;--qn-color-blue-light: #4DABF7;--qn-color-blue-dark: #1C7ED6;--qn-color-indigo: #5C7CFA;--qn-color-indigo-light: #748FFC;--qn-color-indigo-dark: #4263EB;--qn-color-violet: #845EF7;--qn-color-violet-light: #9775FA;--qn-color-violet-dark: #6741D9;--qn-color-purple: #CC5DE8;--qn-color-purple-light: #DA77F2;--qn-color-purple-dark: #AE3EC9;--qn-color-pink: #F06595;--qn-color-pink-light: #F783AC;--qn-color-pink-dark: #D6336C;--qn-color-rose: #F783AC;--qn-color-rose-light: #FAA2C1;--qn-color-rose-dark: #E64980;--qn-color-gray: #868E96;--qn-color-gray-light: #A9B1B8;--qn-color-gray-dark: #495057;--qn-color-brown: #A1887F;--qn-color-brown-light: #BCAAA4;--qn-color-brown-dark: #6D4C41;--qn-success: #00B894;--qn-warning: #FDCB6E;--qn-error: #D63031;--qn-info: #74B9FF;--qn-bg-base: #000000;--qn-bg-surface: #050505;--qn-bg-elevated: #0a0a0a;--qn-bg-overlay: #111111;--qn-bg-hover: #1a1a1a;--qn-bg-active: #222222;--qn-border: rgba(255, 255, 255, .1);--qn-border-subtle: rgba(255, 255, 255, .05);--qn-border-strong: rgba(255, 255, 255, .2);--qn-border-focus: var(--qn-primary);--qn-text-primary: #ffffff;--qn-text-secondary: #a1a1aa;--qn-text-tertiary: #71717a;--qn-text-muted: #52525b;--qn-text-inverse: #000000;--qn-glass-bg: rgba(18, 18, 26, .75);--qn-glass-border: rgba(255, 255, 255, .08);--qn-glass-shadow: 0 8px 32px rgba(0, 0, 0, .4);--qn-glass-blur: blur(20px);--qn-shadow-sm: 0 1px 2px rgba(0, 0, 0, .25);--qn-shadow-md: 0 4px 12px rgba(0, 0, 0, .35);--qn-shadow-lg: 0 8px 30px rgba(0, 0, 0, .45);--qn-shadow-xl: 0 20px 60px rgba(0, 0, 0, .55);--qn-shadow-glow: 0 0 16px var(--qn-primary-glow);--qn-space-xs: 4px;--qn-space-sm: 8px;--qn-space-md: 16px;--qn-space-lg: 24px;--qn-space-xl: 32px;--qn-space-2xl: 48px;--qn-space-3xl: 64px;--qn-radius-xs: 4px;--qn-radius-sm: 6px;--qn-radius-md: 10px;--qn-radius-lg: 14px;--qn-radius-xl: 20px;--qn-radius-full: 9999px;--qn-font-sans: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--qn-font-display: "Outfit", var(--qn-font-sans);--qn-font-mono: "JetBrains Mono", "Fira Code", monospace;--qn-text-xs: .6875rem;--qn-text-sm: .8125rem;--qn-text-base: .875rem;--qn-text-md: 1rem;--qn-text-lg: 1.125rem;--qn-text-xl: 1.25rem;--qn-text-2xl: 1.5rem;--qn-text-3xl: 2rem;--qn-text-4xl: 2.5rem;--qn-transition-fast: .1s ease-out;--qn-transition-normal: .18s ease-out;--qn-transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--qn-transition-spring: .45s cubic-bezier(.34, 1.56, .64, 1);--qn-sidebar-width: 280px;--qn-sidebar-collapsed: 56px;--qn-topbar-height: 48px;--qn-panel-width: 360px;--qn-z-base: 1;--qn-z-dropdown: 100;--qn-z-sticky: 200;--qn-z-overlay: 300;--qn-z-modal: 400;--qn-z-toast: 500;--qn-z-max: 999}[data-theme=light]{--qn-bg-base: #F8F9FC;--qn-bg-surface: #FFFFFF;--qn-bg-elevated: #F0F1F5;--qn-bg-overlay: #E8E9EE;--qn-bg-hover: #EDEEF3;--qn-bg-active: #E0E1E8;--qn-border: rgba(0, 0, 0, .08);--qn-border-subtle: rgba(0, 0, 0, .04);--qn-border-strong: rgba(0, 0, 0, .15);--qn-text-primary: #1A1A2E;--qn-text-secondary: #5A5A70;--qn-text-tertiary: #8A8AA0;--qn-text-muted: #B0B0C0;--qn-text-inverse: #F0F0F5;--qn-glass-bg: rgba(255, 255, 255, .8);--qn-glass-border: rgba(0, 0, 0, .06);--qn-glass-shadow: 0 8px 32px rgba(0, 0, 0, .08);--qn-shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--qn-shadow-md: 0 4px 12px rgba(0, 0, 0, .07);--qn-shadow-lg: 0 8px 30px rgba(0, 0, 0, .09);--qn-shadow-xl: 0 20px 60px rgba(0, 0, 0, .1);--qn-text-muted: #a1a1aa}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--qn-font-sans);background:var(--qn-bg-base);color:var(--qn-text-primary);line-height:1.55;overflow:hidden;min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--qn-text-muted);border-radius:var(--qn-radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--qn-text-tertiary)}*{scrollbar-width:thin;scrollbar-color:var(--qn-text-muted) transparent}::selection{background:var(--qn-primary);color:#fff}a{color:var(--qn-primary-light);text-decoration:none;transition:color var(--qn-transition-fast)}a:hover{color:var(--qn-primary)}:focus-visible{outline:2px solid var(--qn-primary);outline-offset:2px}button{font-family:var(--qn-font-sans);cursor:pointer;border:none;background:none;color:inherit;font-size:inherit}button:disabled{cursor:not-allowed;opacity:.5}input,textarea,select{font-family:var(--qn-font-sans);color:var(--qn-text-primary);background:var(--qn-bg-elevated);border:1px solid var(--qn-border);border-radius:var(--qn-radius-md);padding:var(--qn-space-sm) var(--qn-space-md);font-size:var(--qn-text-base);transition:all var(--qn-transition-fast)}input:focus,textarea:focus,select:focus{border-color:var(--qn-primary);box-shadow:0 0 0 2px var(--qn-primary-glow);outline:none}input::placeholder,textarea::placeholder{color:var(--qn-text-muted)}.glass-card{background:var(--qn-glass-bg);backdrop-filter:var(--qn-glass-blur);-webkit-backdrop-filter:var(--qn-glass-blur);border:1px solid var(--qn-glass-border);border-radius:var(--qn-radius-lg);box-shadow:var(--qn-glass-shadow)}.gradient-text{background:linear-gradient(135deg,var(--qn-primary-light),var(--qn-secondary),var(--qn-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideRight{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes glow-pulse{0%,to{box-shadow:0 0 4px var(--qn-primary-glow)}50%{box-shadow:0 0 16px var(--qn-primary-glow),0 0 32px #6c5ce71f}}.animate-fade-in{animation:fadeIn var(--qn-transition-normal) forwards}.animate-slide-up{animation:slideUp var(--qn-transition-slow) forwards}.animate-slide-down{animation:slideDown var(--qn-transition-slow) forwards}.animate-scale-in{animation:scaleIn var(--qn-transition-spring) forwards}.animate-pulse{animation:pulse 2s infinite}.animate-shimmer{background:linear-gradient(90deg,transparent,rgba(255,255,255,.04),transparent);background-size:200% 100%;animation:shimmer 1.5s infinite}.animate-float{animation:float 3s ease-in-out infinite}.animate-glow{animation:glow-pulse 2s ease-in-out infinite}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.line-clamp-1{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}kbd{font-family:var(--qn-font-mono);font-size:var(--qn-text-xs);background:var(--qn-bg-overlay);border:1px solid var(--qn-border-strong);border-radius:var(--qn-radius-xs);padding:1px 5px;color:var(--qn-text-secondary);line-height:1.4}.markdown-content{line-height:1.7;color:var(--qn-text-primary)}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4,.markdown-content h5,.markdown-content h6{font-family:var(--qn-font-display);font-weight:600;margin-top:1.4em;margin-bottom:.4em;color:var(--qn-text-primary)}.markdown-content h1{font-size:var(--qn-text-3xl)}.markdown-content h2{font-size:var(--qn-text-2xl)}.markdown-content h3{font-size:var(--qn-text-xl)}.markdown-content h4{font-size:var(--qn-text-lg)}.markdown-content p{margin-bottom:.9em}.markdown-content code{font-family:var(--qn-font-mono);font-size:.85em;background:var(--qn-bg-overlay);padding:2px 5px;border-radius:var(--qn-radius-xs);color:var(--qn-accent)}.markdown-content pre{background:var(--qn-bg-elevated);border:1px solid var(--qn-border);border-radius:var(--qn-radius-md);padding:var(--qn-space-md);overflow-x:auto;margin-bottom:1em}.markdown-content pre code{background:none;padding:0;color:var(--qn-text-primary)}.markdown-content blockquote{border-left:3px solid var(--qn-primary);padding-left:var(--qn-space-md);color:var(--qn-text-secondary);margin-bottom:1em;font-style:italic}.markdown-content ul,.markdown-content ol{padding-left:1.4em;margin-bottom:1em}.markdown-content li{margin-bottom:.2em}.markdown-content hr{border:none;border-top:1px solid var(--qn-border);margin:1.8em 0}.markdown-content table{width:100%;border-collapse:collapse;margin-bottom:1em}.markdown-content th,.markdown-content td{border:1px solid var(--qn-border);padding:var(--qn-space-sm) var(--qn-space-md);text-align:left}.markdown-content th{background:var(--qn-bg-elevated);font-weight:600}.markdown-content img{max-width:100%;border-radius:var(--qn-radius-md)}.markdown-content a{color:var(--qn-primary-light);text-decoration:underline;text-decoration-color:#6c5ce740;text-underline-offset:2px}.markdown-content a:hover{text-decoration-color:var(--qn-primary)}.markdown-content input[type=checkbox]{appearance:none;width:15px;height:15px;border:2px solid var(--qn-border-strong);border-radius:3px;vertical-align:middle;margin-right:6px;position:relative;cursor:pointer;transition:all var(--qn-transition-fast)}.markdown-content input[type=checkbox]:checked{background:var(--qn-primary);border-color:var(--qn-primary)}.markdown-content input[type=checkbox]:checked:after{content:"✓";font-size:10px;color:#fff;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.toast-container{position:fixed;bottom:var(--qn-space-lg);right:var(--qn-space-lg);z-index:var(--qn-z-toast);display:flex;flex-direction:column;gap:var(--qn-space-sm)}@keyframes skeleton-pulse{0%,to{opacity:.4}50%{opacity:1}}.skeleton{background:linear-gradient(90deg,var(--qn-bg-elevated) 25%,var(--qn-bg-overlay) 50%,var(--qn-bg-elevated) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite,skeleton-pulse 2s ease-in-out infinite;border-radius:var(--qn-radius-md)}.skeleton-card{height:100px;border-radius:var(--qn-radius-lg);margin-bottom:var(--qn-space-sm)}.skeleton-line{height:12px;margin-bottom:6px;border-radius:3px}.skeleton-line.short{width:60%}.skeleton-line.medium{width:80%}.skeleton-line.long{width:95%}.btn-primary-sm,.btn-danger-sm,.btn-ghost-sm,.btn-ghost-xs,.btn-primary-lg,.topbar-btn,.toolbar-btn,.rail-tab,.card-action-btn,.icon-btn-sm,.view-mode-btn{transition:all .14s ease-out}.btn-primary-sm:active,.btn-danger-sm:active,.btn-ghost-sm:active,.btn-primary-lg:active,.topbar-btn:active,.toolbar-btn:active,.rail-tab:active,.card-action-btn:active,.icon-btn-sm:active,.view-mode-btn:active{transform:scale(.96)}.context-menu-overlay{position:fixed;inset:0;z-index:var(--qn-z-dropdown)}.context-menu{position:fixed;z-index:calc(var(--qn-z-dropdown) + 1);background:var(--qn-bg-elevated);border:1px solid var(--qn-border-strong);border-radius:var(--qn-radius-md);box-shadow:var(--qn-shadow-lg);min-width:180px;max-width:260px;padding:4px 0;animation:scaleIn .1s ease-out forwards;-webkit-backdrop-filter:var(--qn-glass-blur);backdrop-filter:var(--qn-glass-blur)}.context-menu button{display:flex;align-items:center;gap:8px;width:100%;padding:7px 12px;font-size:var(--qn-text-sm);color:var(--qn-text-secondary);transition:all var(--qn-transition-fast);text-align:left}.context-menu button:hover{background:var(--qn-bg-hover);color:var(--qn-text-primary)}.context-menu button.danger{color:var(--qn-error)}.context-menu button.danger:hover{background:#d630311a}.context-menu-divider{height:1px;background:var(--qn-border);margin:4px 0}.context-menu-submenu{padding:4px 12px}.context-menu-submenu-label{font-size:10px;color:var(--qn-text-muted);margin-bottom:4px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.color-picker-grid{display:flex;flex-wrap:wrap;gap:5px;padding:6px 12px}.color-swatch{width:22px;height:22px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:all var(--qn-transition-fast)}.color-swatch:hover{transform:scale(1.15);border-color:#ffffff80}.color-swatch.active{border-color:#fff;box-shadow:0 0 0 2px var(--qn-primary)}.find-replace-bar{position:absolute;top:0;right:0;left:0;z-index:var(--qn-z-sticky);background:var(--qn-bg-elevated);border-bottom:1px solid var(--qn-border-strong);padding:6px 10px;display:flex;flex-direction:column;gap:5px;animation:slideDown .12s ease-out forwards;box-shadow:var(--qn-shadow-md)}.find-row,.replace-row{display:flex;align-items:center;gap:5px}.find-row input,.replace-row input{flex:1;padding:4px 8px;font-size:var(--qn-text-sm);background:var(--qn-bg-surface);border:1px solid var(--qn-border);border-radius:var(--qn-radius-xs)}.find-row input:focus,.replace-row input:focus{border-color:var(--qn-primary);box-shadow:0 0 0 2px var(--qn-primary-glow)}.find-match-count{font-size:10px;color:var(--qn-text-muted);white-space:nowrap;min-width:60px;text-align:center}.find-btn{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:var(--qn-radius-xs);color:var(--qn-text-tertiary);transition:all var(--qn-transition-fast);flex-shrink:0}.find-btn:hover{background:var(--qn-bg-hover);color:var(--qn-text-primary)}.replace-btn{padding:4px 8px;font-size:10px;background:var(--qn-bg-overlay);border-radius:var(--qn-radius-xs);color:var(--qn-text-secondary);transition:all var(--qn-transition-fast);white-space:nowrap}.replace-btn:hover{background:var(--qn-primary);color:#fff}.find-highlight{background:#22d3ee40;border-radius:2px}.find-highlight-active{background:#22d3ee80;outline:2px solid #22d3ee}.editor-status-bar{display:flex;align-items:center;justify-content:space-between;padding:3px var(--qn-space-md);border-top:1px solid var(--qn-border-subtle);background:var(--qn-bg-surface);min-height:26px;flex-shrink:0}.status-bar-left,.status-bar-right{display:flex;align-items:center;gap:8px}.status-pill{display:inline-flex;align-items:center;gap:4px;font-size:10px;color:var(--qn-text-muted);cursor:pointer;padding:2px 6px;border-radius:var(--qn-radius-full);transition:all var(--qn-transition-fast);-webkit-user-select:none;user-select:none}.status-pill:hover{background:var(--qn-bg-hover);color:var(--qn-text-secondary)}.save-indicator{font-size:10px;display:flex;align-items:center;gap:4px;transition:opacity .25s ease}.save-indicator.saving{color:var(--qn-warning)}.save-indicator.saved{color:var(--qn-success)}.save-indicator.error{color:var(--qn-error)}.note-locked-banner{display:flex;align-items:center;justify-content:center;gap:6px;padding:6px 14px;background:#fdcb6e14;border-bottom:1px solid rgba(253,203,110,.15);font-size:var(--qn-text-sm);color:var(--qn-warning);cursor:pointer;transition:all var(--qn-transition-fast)}.note-locked-banner:hover{background:#fdcb6e1f}.editor-breadcrumb{font-size:11px;color:var(--qn-text-muted);display:flex;align-items:center;gap:4px;margin-bottom:6px}.breadcrumb-link{color:var(--qn-text-tertiary);cursor:pointer;transition:color var(--qn-transition-fast)}.breadcrumb-link:hover{color:var(--qn-primary-light)}.breadcrumb-separator{color:var(--qn-text-muted)}.note-color-bar-top{height:3px;width:100%;flex-shrink:0}.note-card.is-pinned{border-top:2px solid var(--qn-primary-light)}.note-card .pin-indicator{color:var(--qn-primary-light);font-size:11px}.editor-textarea.line-highlight-active{caret-color:var(--qn-primary)}.editor-textarea.no-wrap{white-space:pre;overflow-x:auto;word-wrap:normal}.shortcuts-table{width:100%;border-collapse:collapse}.shortcuts-table th,.shortcuts-table td{padding:6px 10px;text-align:left;border-bottom:1px solid var(--qn-border-subtle)}.shortcuts-table th{font-size:10px;color:var(--qn-text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.shortcuts-table td{font-size:var(--qn-text-sm);color:var(--qn-text-secondary)}.shortcuts-table td:first-child{white-space:nowrap}.custom-css-textarea{width:100%;min-height:100px;font-family:var(--qn-font-mono);font-size:11px;background:var(--qn-bg-base);color:var(--qn-text-primary);border:1px solid var(--qn-border);border-radius:var(--qn-radius-md);padding:var(--qn-space-sm);resize:vertical}.storage-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;margin-bottom:10px}.storage-stat{background:var(--qn-bg-base);border:1px solid var(--qn-border-subtle);border-radius:var(--qn-radius-md);padding:8px;text-align:center}.storage-stat-value{display:block;font-size:var(--qn-text-lg);font-weight:700;color:var(--qn-text-primary);font-family:var(--qn-font-display)}.storage-stat-label{font-size:10px;color:var(--qn-text-muted)}.focus-exit-btn{position:fixed;bottom:20px;right:20px;z-index:calc(var(--qn-z-overlay) + 10);padding:6px 14px;background:var(--qn-bg-elevated);border:1px solid var(--qn-border-strong);border-radius:var(--qn-radius-full);font-size:var(--qn-text-xs);color:var(--qn-text-secondary);display:flex;align-items:center;gap:5px;transition:all var(--qn-transition-fast);opacity:.5;-webkit-backdrop-filter:var(--qn-glass-blur);backdrop-filter:var(--qn-glass-blur)}.focus-exit-btn:hover{opacity:1;background:var(--qn-bg-overlay);border-color:var(--qn-primary);color:var(--qn-text-primary)}@media(max-width:640px){.mobile-back-btn{display:flex;align-items:center;gap:4px;padding:5px 8px;font-size:var(--qn-text-sm);color:var(--qn-text-secondary);background:var(--qn-bg-elevated);border-radius:var(--qn-radius-xs);margin-bottom:6px}.editor-content{padding:var(--qn-space-md)}.editor-toolbar{padding:4px 8px}}@media(min-width:641px){.mobile-back-btn{display:none}}.page-transition-enter{opacity:0;transform:translate(8px)}.page-transition-enter-active{opacity:1;transform:translate(0);transition:all .12s ease-out}.page-transition-exit{opacity:1}.page-transition-exit-active{opacity:0;transform:translate(-8px);transition:all .12s ease-out}.tag-autocomplete{position:absolute;top:100%;left:0;background:var(--qn-bg-elevated);border:1px solid var(--qn-border-strong);border-radius:var(--qn-radius-md);box-shadow:var(--qn-shadow-lg);min-width:140px;max-height:160px;overflow-y:auto;z-index:var(--qn-z-dropdown);animation:slideDown 80ms ease-out}.tag-autocomplete-item{display:flex;align-items:center;gap:5px;padding:5px 10px;font-size:var(--qn-text-sm);color:var(--qn-text-secondary);cursor:pointer;transition:all var(--qn-transition-fast)}.tag-autocomplete-item:hover,.tag-autocomplete-item.highlighted{background:var(--qn-bg-hover);color:var(--qn-text-primary)}.emoji-picker-dropdown{position:absolute;top:100%;left:0;background:var(--qn-bg-elevated);border:1px solid var(--qn-border-strong);border-radius:var(--qn-radius-md);box-shadow:var(--qn-shadow-lg);max-width:260px;max-height:180px;overflow-y:auto;z-index:var(--qn-z-dropdown);padding:5px;display:flex;flex-wrap:wrap;gap:3px}.emoji-picker-item{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:var(--qn-radius-xs);font-size:16px;cursor:pointer;transition:all var(--qn-transition-fast)}.emoji-picker-item:hover{background:var(--qn-bg-hover);transform:scale(1.1)}@keyframes pulse-cyan{0%,to{box-shadow:0 0 3px #22d3ee59}50%{box-shadow:0 0 10px #22d3eeb3,0 0 20px #22d3ee40}}@keyframes node-running{0%,to{opacity:1}50%{opacity:.4}}@keyframes live-border-glow{0%,to{border-color:#22d3ee33}50%{border-color:#22d3ee73}}.canvas-live-mode{border:2px solid rgba(34,211,238,.3);animation:live-border-glow 2s ease-in-out infinite}.canvas-minimap{position:absolute;bottom:12px;right:12px;width:120px;height:90px;background:var(--qn-bg-elevated);border:1px solid var(--qn-border-strong);border-radius:var(--qn-radius-md);overflow:hidden;z-index:10;box-shadow:var(--qn-shadow-md)}.minimap-viewport{position:absolute;border:1px solid rgba(34,211,238,.45);background:#22d3ee14;pointer-events:none}.minimap-node{position:absolute;border-radius:2px;min-width:3px;min-height:2px}.document-drop-zone{position:absolute;inset:0;background:#22d3ee0a;border:2px dashed rgba(34,211,238,.35);border-radius:var(--qn-radius-lg);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:6px;z-index:var(--qn-z-overlay);animation:fadeIn .15s ease-out}.document-drop-zone span{font-size:var(--qn-text-lg);font-weight:600;color:#22d3ee}.document-drop-zone p{font-size:var(--qn-text-sm);color:var(--qn-text-muted)}.btn-primary-sm{display:flex;align-items:center;gap:4px;padding:5px 10px;font-size:var(--qn-text-xs);font-weight:600;background:var(--qn-primary);color:#fff;border-radius:var(--qn-radius-xs);transition:all var(--qn-transition-fast)}.btn-primary-sm:hover{background:var(--qn-primary-dark);box-shadow:var(--qn-shadow-glow)}.btn-primary-lg{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;font-size:var(--qn-text-base);font-weight:600;background:var(--qn-primary);color:#fff;border-radius:var(--qn-radius-md);transition:all var(--qn-transition-fast)}.btn-primary-lg:hover{background:var(--qn-primary-dark);box-shadow:var(--qn-shadow-glow);transform:translateY(-1px)}.btn-ghost-sm{padding:4px 8px;font-size:var(--qn-text-xs);font-weight:500;color:var(--qn-text-secondary);border-radius:var(--qn-radius-xs);transition:all var(--qn-transition-fast)}.btn-ghost-sm:hover{background:var(--qn-bg-hover);color:var(--qn-text-primary)}.btn-ghost-xs{padding:3px 6px;font-size:10px;font-weight:500;color:var(--qn-text-tertiary);border-radius:var(--qn-radius-xs);transition:all var(--qn-transition-fast)}.btn-ghost-xs:hover{background:var(--qn-bg-hover);color:var(--qn-text-secondary)}.btn-danger-sm{padding:4px 8px;font-size:var(--qn-text-xs);font-weight:500;color:var(--qn-error);border-radius:var(--qn-radius-xs);transition:all var(--qn-transition-fast)}.btn-danger-sm:hover{background:#d630311a}.icon-btn-sm{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:var(--qn-radius-xs);color:var(--qn-text-tertiary);transition:all var(--qn-transition-fast)}.icon-btn-sm:hover{background:var(--qn-bg-hover);color:var(--qn-text-primary)}.sidebar{display:flex;height:100vh;flex-shrink:0;z-index:var(--qn-z-sticky);animation:slideRight var(--qn-transition-slow) forwards}.sidebar.collapsed{width:auto}.sidebar-rail{width:var(--qn-sidebar-collapsed);min-width:var(--qn-sidebar-collapsed);background:var(--qn-bg-surface);border-right:1px solid var(--qn-border);display:flex;flex-direction:column;justify-content:space-between;padding:var(--qn-space-xs) 0;z-index:2}.sidebar-rail-top,.sidebar-rail-bottom{display:flex;flex-direction:column;align-items:center;gap:2px}.sidebar-logo{width:36px;height:36px;display:flex;align-items:center;justify-content:center;margin-bottom:var(--qn-space-sm)}.logo-icon{font-family:var(--qn-font-display);font-size:var(--qn-text-xl);font-weight:800}.rail-tab{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--qn-radius-xs);color:var(--qn-text-tertiary);transition:all var(--qn-transition-fast);position:relative}.rail-tab:hover{background:var(--qn-bg-hover);color:var(--qn-text-primary)}.rail-tab.active{background:var(--qn-primary-glow);color:var(--qn-primary-light)}.rail-tab.active:after{content:"";position:absolute;left:-4px;top:50%;transform:translateY(-50%);width:2px;height:16px;background:var(--qn-primary);border-radius:0 2px 2px 0}.rail-tab-label{display:none}.sidebar-panel{width:var(--qn-sidebar-width);background:var(--qn-bg-surface);border-right:1px solid var(--qn-border);display:flex;flex-direction:column;overflow:hidden;animation:slideRight var(--qn-transition-slow) forwards}.sidebar-panel-header{padding:var(--qn-space-sm) var(--qn-space-md);display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--qn-border-subtle);min-height:var(--qn-topbar-height)}.sidebar-panel-title{font-family:var(--qn-font-display);font-size:var(--qn-text-sm);font-weight:600;color:var(--qn-text-primary)}.sidebar-panel-content{flex:1;overflow-y:auto;overflow-x:hidden}.sidebar-content-section{padding:var(--qn-space-xs)}.sidebar-section-header{display:flex;align-items:center;justify-content:space-between;padding:4px var(--qn-space-sm);margin-bottom:4px}.section-count{font-size:var(--qn-text-xs);color:var(--qn-text-tertiary);font-weight:500}.section-header-actions{display:flex;gap:3px}.note-group{margin-bottom:var(--qn-space-xs)}.note-group-label{font-size:10px;color:var(--qn-text-tertiary);font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:4px var(--qn-space-sm);display:flex;align-items:center;gap:5px}.sidebar-note-item{padding:var(--qn-space-xs) var(--qn-space-sm);border-radius:var(--qn-radius-xs);cursor:pointer;transition:all var(--qn-transition-fast);margin-bottom:2px;position:relative}.sidebar-note-item:hover{background:var(--qn-bg-hover)}.sidebar-note-item.active{background:var(--qn-bg-active);border-left:2px solid var(--qn-primary)}.sidebar-note-item.trashed{opacity:.6}.note-item-header{display:flex;align-items:center;gap:5px;margin-bottom:3px}.note-item-icon{font-size:var(--qn-text-sm);flex-shrink:0}.note-item-title{font-size:var(--qn-text-sm);font-weight:500;color:var(--qn-text-primary);flex:1;min-width:0}.note-item-pin{color:var(--qn-primary-light);flex-shrink:0}.note-item-star{color:var(--qn-accent-light);flex-shrink:0}.note-item-preview{font-size:10px;color:var(--qn-text-tertiary);line-height:1.35;margin-bottom:3px}.note-item-meta{display:flex;align-items:center;gap:3px;font-size:10px;color:var(--qn-text-muted)}.meta-dot{color:var(--qn-text-muted)}.note-context-menu{position:absolute;top:100%;right:var(--qn-space-xs);background:var(--qn-bg-elevated);border:1px solid var(--qn-border-strong);border-radius:var(--qn-radius-xs);padding:3px;z-index:var(--qn-z-dropdown);min-width:150px;box-shadow:var(--qn-shadow-lg);animation:scaleIn var(--qn-transition-fast) forwards}.note-context-menu button{display:flex;align-items:center;gap:6px;width:100%;padding:5px 8px;font-size:var(--qn-text-sm);border-radius:3px;color:var(--qn-text-secondary);transition:all var(--qn-transition-fast)}.note-context-menu button:hover{background:var(--qn-bg-hover);color:var(--qn-text-primary)}.note-context-menu button.danger:hover{background:#d630311a;color:var(--qn-error)}.context-menu-divider{height:1px;background:var(--qn-border);margin:3px 0}.folder-item{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:var(--qn-radius-xs);cursor:pointer;transition:all var(--qn-transition-fast);color:var(--qn-text-secondary);font-size:var(--qn-text-sm)}.folder-item:hover{background:var(--qn-bg-hover);color:var(--qn-text-primary)}.folder-item.active{background:var(--qn-bg-active);color:var(--qn-text-primary)}.folder-expand-btn{padding:2px;border-radius:3px;color:var(--qn-text-muted)}.folder-name{flex:1;min-width:0}.folder-count{font-size:10px;color:var(--qn-text-muted);background:var(--qn-bg-overlay);padding:1px 5px;border-radius:var(--qn-radius-full)}.folder-delete{opacity:0;transition:opacity var(--qn-transition-fast)}.folder-item:hover .folder-delete{opacity:1}.new-folder-input{padding:3px 6px}.new-folder-input input{width:100%;padding:5px 8px;font-size:var(--qn-text-sm);border-radius:var(--qn-radius-xs)}.tag-item{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:var(--qn-radius-xs);cursor:pointer;transition:all var(--qn-transition-fast)}.tag-item:hover{background:var(--qn-bg-hover)}.tag-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.tag-name{font-size:var(--qn-text-sm);color:var(--qn-text-secondary);flex:1}.tag-count{font-size:10px;color:var(--qn-text-muted)}.tag-delete{opacity:0;transition:opacity var(--qn-transition-fast)}.tag-item:hover .tag-delete{opacity:1}.sidebar-search-input{display:flex;align-items:center;gap:6px;padding:6px 10px;background:var(--qn-bg-elevated);border:1px solid var(--qn-border);border-radius:var(--qn-radius-xs);margin-bottom:var(--qn-space-xs);transition:all var(--qn-transition-fast)}.sidebar-search-input:focus-within{border-color:var(--qn-primary);box-shadow:0 0 0 2px var(--qn-primary-glow)}.sidebar-search-input input{border:none;background:none;flex:1;font-size:var(--qn-text-sm);padding:0}.sidebar-search-input input:focus{box-shadow:none}.sidebar-search-input svg{color:var(--qn-text-muted);flex-shrink:0}.search-clear{color:var(--qn-text-muted);padding:2px;border-radius:3px}.search-clear:hover{color:var(--qn-text-primary)}.search-results-count{font-size:10px;color:var(--qn-text-tertiary);padding:0 var(--qn-space-sm);margin-bottom:var(--qn-space-xs)}.search-filter-toggle{color:var(--qn-text-tertiary);padding:3px;border-radius:var(--qn-radius-xs);transition:all var(--qn-transition-fast)}.search-filter-toggle:hover{background:var(--qn-bg-hover);color:var(--qn-primary-light)}.search-filter-toggle.active{color:var(--qn-primary);background:var(--qn-primary-glow)}.sidebar-search-filters{background:var(--qn-bg-surface);border:1px solid var(--qn-border-subtle);border-radius:var(--qn-radius-xs);padding:var(--qn-space-xs);margin-bottom:var(--qn-space-sm);animation:slideDown var(--qn-transition-fast) ease-out}.filter-group{margin-bottom:var(--qn-space-xs)}.filter-group-label{display:block;font-size:9px;text-transform:uppercase;letter-spacing:.04em;color:var(--qn-text-tertiary);margin-bottom:4px;font-weight:600}.filter-pills{display:flex;flex-wrap:wrap;gap:3px}.filter-pill{font-size:9px;padding:2px 6px;border-radius:var(--qn-radius-full);background:var(--qn-bg-elevated);border:1px solid var(--qn-border);cursor:pointer;transition:all var(--qn-transition-fast);color:var(--qn-text-tertiary)}.filter-pill:hover{border-color:var(--qn-border-strong)}.filter-pill.active{background:var(--qn-primary);border-color:var(--qn-primary);color:#fff}.filter-select{width:100%;padding:4px 6px;font-size:var(--qn-text-xs);background:var(--qn-bg-elevated);border:1px solid var(--qn-border);border-radius:var(--qn-radius-xs);color:var(--qn-text-primary)}.trash-actions{display:flex;gap:5px;margin-top:5px}.sidebar-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--qn-space-xl);color:var(--qn-text-tertiary);text-align:center;gap:var(--qn-space-xs)}.sidebar-empty p{font-size:var(--qn-text-sm);font-weight:500}.sidebar-empty-sub{font-size:10px!important;color:var(--qn-text-muted)!important;font-weight:400!important}.sidebar-ai-actions{padding:0 6px;display:flex;flex-direction:column;gap:3px}.sidebar-ai-action-btn{display:flex;align-items:center;gap:6px;padding:6px 10px;font-size:var(--qn-text-sm);color:var(--qn-text-secondary);border-radius:var(--qn-radius-xs);transition:all var(--qn-transition-fast);text-align:left;width:100%}.sidebar-ai-action-btn:hover{background:linear-gradient(135deg,#a855f70f,#22d3ee0f);color:var(--qn-text-primary);transform:translate(2px)}.sidebar-graph-stats{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:4px 6px 6px}.graph-stat-card{display:flex;flex-direction:column;align-items:center;padding:10px 6px;background:var(--qn-bg-elevated);border:1px solid var(--qn-border);border-radius:var(--qn-radius-xs);transition:all var(--qn-transition-fast)}.graph-stat-card:hover{border-color:var(--qn-primary);box-shadow:0 0 6px var(--qn-primary-glow)}.graph-stat-value{font-size:var(--qn-text-lg);font-weight:700;color:var(--qn-primary-light);font-family:var(--qn-font-mono)}.graph-stat-label{font-size:9px;color:var(--qn-text-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600}.sidebar-template-categories{display:flex;flex-wrap:wrap;gap:3px;padding:0 6px 6px}.sidebar-template-cat-pill{font-size:9px;padding:2px 6px;border-radius:var(--qn-radius-full);background:var(--qn-bg-elevated);border:1px solid var(--qn-border);color:var(--qn-text-tertiary);font-weight:500}.sidebar-template-list{display:flex;flex-direction:column;gap:2px;padding:0 4px}.sidebar-template-card{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:var(--qn-radius-xs);cursor:pointer;transition:all var(--qn-transition-fast)}.sidebar-template-card:hover{background:var(--qn-bg-hover);transform:translate(2px)}.sidebar-template-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--qn-radius-xs);font-size:14px;flex-shrink:0}.sidebar-template-info{display:flex;flex-direction:column;gap:1px;min-width:0}.sidebar-template-name{font-size:var(--qn-text-sm);font-weight:600;color:var(--qn-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-template-desc{font-size:10px;color:var(--qn-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.connection-status{display:flex;align-items:center;gap:var(--qn-space-xs);padding:var(--qn-space-xs) var(--qn-space-sm);border-radius:var(--qn-radius-full);background:var(--qn-bg-tertiary);border:1px solid var(--qn-border);font-size:var(--qn-text-xs);font-weight:500;transition:all var(--qn-transition-fast)}.connection-status:hover{background:var(--qn-bg-hover)}.connection-status.status-online{border-color:#00b8944d}.connection-status.status-offline{border-color:#fdcb6e4d}.connection-status.status-error{border-color:#d630314d}.connection-status.status-syncing{border-color:#74b9ff4d}.status-icon{display:flex;align-items:center}.status-label{font-size:var(--qn-text-xs);font-weight:500}.status-badge{font-size:10px;padding:2px 6px;border-radius:var(--qn-radius-full);background:#fdcb6e33;color:var(--qn-warning);font-weight:600}.status-spinner{width:12px;height:12px;border:2px solid var(--qn-border);border-top-color:var(--qn-info);border-radius:50%;animation:spin 1s linear infinite}.connection-status[onclick]:hover{cursor:pointer;background:var(--qn-bg-active)}.animate-spin{animation:spin 1s linear infinite}.connection-status.compact{padding:4px 8px}.connection-status.compact .status-label,.connection-status.compact .status-badge{display:none}.connection-status.large{padding:var(--qn-space-sm) var(--qn-space-md);gap:var(--qn-space-sm)}.connection-status.large .status-icon{font-size:var(--qn-text-base)}.connection-status.large .status-label{font-size:var(--qn-text-sm)}.topbar{height:var(--qn-topbar-height);background:var(--qn-bg-surface);border-bottom:1px solid var(--qn-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--qn-space-md);flex-shrink:0;z-index:var(--qn-z-sticky);-webkit-backdrop-filter:var(--qn-glass-blur);backdrop-filter:var(--qn-glass-blur)}.topbar-left{display:flex;align-items:center;gap:var(--qn-space-sm);flex:1;min-width:0}.topbar-note-info{display:flex;flex-direction:column;min-width:0}.topbar-note-title{font-family:var(--qn-font-display);font-size:var(--qn-text-sm);font-weight:600;color:var(--qn-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-note-meta{display:flex;align-items:center;gap:3px;font-size:10px;color:var(--qn-text-muted)}.topbar-divider{color:var(--qn-text-muted)}.topbar-center{display:flex;align-items:center}.topbar-view-modes{display:flex;align-items:center;gap:2px;background:var(--qn-bg-elevated);border-radius:var(--qn-radius-xs);padding:2px}.view-mode-btn{width:30px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:var(--qn-radius-xs);color:var(--qn-text-tertiary);transition:all var(--qn-transition-fast)}.view-mode-btn:hover{color:var(--qn-text-primary);background:var(--qn-bg-hover)}.view-mode-btn.active{color:var(--qn-primary-light);background:var(--qn-primary-glow)}.topbar-right{display:flex;align-items:center;gap:3px;flex:1;justify-content:flex-end}.topbar-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--qn-radius-xs);color:var(--qn-text-tertiary);transition:all var(--qn-transition-fast)}.topbar-btn:hover{background:var(--qn-bg-hover);color:var(--qn-text-primary)}.topbar-btn.active{color:var(--qn-primary-light);background:var(--qn-primary-glow)}.topbar-more{position:relative}.topbar-dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:var(--qn-bg-elevated);border:1px solid var(--qn-border-strong);border-radius:var(--qn-radius-xs);padding:3px;min-width:170px;box-shadow:var(--qn-shadow-lg);z-index:var(--qn-z-dropdown);animation:scaleIn var(--qn-transition-fast) forwards}.topbar-dropdown button{display:flex;align-items:center;gap:8px;width:100%;padding:6px 10px;font-size:var(--qn-text-sm);border-radius:var(--qn-radius-xs);color:var(--qn-text-secondary);transition:all var(--qn-transition-fast)}.topbar-dropdown button:hover{background:var(--qn-bg-hover);color:var(--qn-text-primary)}.topbar-dropdown button.danger:hover{background:#d630311a;color:var(--qn-error)}.dropdown-divider{height:1px;background:var(--qn-border);margin:3px 0}.note-editor{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--qn-bg-base)}.note-editor.zen-mode{position:fixed;inset:0;z-index:var(--qn-z-overlay);background:var(--qn-bg-base)}.editor-toolbar{display:flex;align-items:center;justify-content:space-between;padding:4px var(--qn-space-md);border-bottom:1px solid var(--qn-border-subtle);background:var(--qn-bg-surface);min-height:38px;flex-shrink:0;overflow-x:auto}.toolbar-left{display:flex;align-items:center;gap:2px}.toolbar-right{display:flex;align-items:center;gap:3px}.toolbar-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--qn-radius-xs);color:var(--qn-text-tertiary);transition:all var(--qn-transition-fast);flex-shrink:0}.toolbar-btn:hover{background:var(--qn-bg-hover);color:var(--qn-text-primary)}.toolbar-btn.active{background:var(--qn-primary-glow);color:var(--qn-primary-light)}.preview-toggle{width:auto;padding:0 8px;gap:5px;font-size:var(--qn-text-xs);font-weight:500}.toolbar-divider{width:1px;height:18px;background:var(--qn-border);margin:0 3px;flex-shrink:0}.editor-content{flex:1;max-width:720px;width:100%;margin:0 auto;padding:var(--qn-space-xl) var(--qn-space-xl) var(--qn-space-3xl);overflow-y:auto;animation:fadeIn var(--qn-transition-normal) forwards}.zen-mode .editor-content{padding-top:var(--qn-space-3xl)}.editor-title{font-family:var(--qn-font-display);font-size:var(--qn-text-3xl);font-weight:700;color:var(--qn-text-primary);background:none;border:none;width:100%;padding:0;margin-bottom:var(--qn-space-sm);outline:none;line-height:1.3}.editor-title::placeholder{color:var(--qn-text-muted)}.editor-title:focus{box-shadow:none}.editor-tags{display:flex;flex-wrap:wrap;align-items:center;gap:5px;margin-bottom:var(--qn-space-md);min-height:24px}.editor-tag{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;background:var(--qn-bg-elevated);border:1px solid var(--qn-border);border-radius:var(--qn-radius-full);font-size:var(--qn-text-xs);color:var(--qn-text-secondary);transition:all var(--qn-transition-fast)}.editor-tag:hover{border-color:var(--qn-primary);color:var(--qn-primary-light)}.tag-remove{display:flex;align-items:center;justify-content:center;width:12px;height:12px;border-radius:50%;color:var(--qn-text-muted);transition:all var(--qn-transition-fast)}.tag-remove:hover{background:var(--qn-error);color:#fff}.tag-input-inline{border:1px solid var(--qn-primary)!important;background:var(--qn-bg-elevated)!important;padding:2px 8px!important;border-radius:var(--qn-radius-full)!important;font-size:var(--qn-text-xs)!important;width:110px;outline:none}.add-tag-btn{display:flex;align-items:center;gap:3px;padding:2px 8px;font-size:var(--qn-text-xs);color:var(--qn-text-muted);border:1px dashed var(--qn-border);border-radius:var(--qn-radius-full);transition:all var(--qn-transition-fast)}.add-tag-btn:hover{border-color:var(--qn-primary);color:var(--qn-primary-light);background:var(--qn-primary-glow)}.editor-textarea{width:100%;min-height:380px;height:calc(100vh - 260px);background:transparent;border:none;color:var(--qn-text-primary);font-size:15px;line-height:1.75;resize:none;outline:none;padding:0;font-family:var(--qn-font-sans)}.editor-textarea::placeholder{color:var(--qn-text-muted)}.editor-textarea:focus{box-shadow:none}.editor-preview{min-height:380px;animation:fadeIn var(--qn-transition-normal) forwards}.editor-empty-state{flex:1;display:flex;align-items:center;justify-content:center;background:var(--qn-bg-base)}.empty-state-content{text-align:center;padding:var(--qn-space-2xl)}.empty-state-icon{font-family:var(--qn-font-display);font-size:56px;font-weight:800;margin-bottom:var(--qn-space-md);display:block}.empty-state-content h2{font-family:var(--qn-font-display);font-size:var(--qn-text-lg);font-weight:600;color:var(--qn-text-primary);margin-bottom:var(--qn-space-xs)}.empty-state-content p{color:var(--qn-text-tertiary);font-size:var(--qn-text-base);margin-bottom:var(--qn-space-xl)}.empty-state-shortcuts{display:flex;flex-direction:column;gap:var(--qn-space-xs);align-items:center}.shortcut-item{display:flex;align-items:center;gap:5px;font-size:var(--qn-text-sm);color:var(--qn-text-tertiary)}.shortcut-item kbd{min-width:20px;text-align:center}.shortcut-item span{color:var(--qn-text-muted)}.editor-backlinks{margin-top:calc(var(--qn-space-xl) * 2);padding-top:var(--qn-space-xl);border-top:1px solid var(--qn-border-subtle)}.editor-backlinks h4{font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--qn-text-tertiary);margin-bottom:var(--qn-space-sm)}.backlinks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--qn-space-sm)}.backlink-card{padding:var(--qn-space-sm);background:var(--qn-bg-surface);border:1px solid var(--qn-border);border-radius:var(--qn-radius-xs);cursor:pointer;transition:all var(--qn-transition-fast)}.backlink-card:hover{border-color:var(--qn-primary);transform:translateY(-2px);box-shadow:var(--qn-shadow-sm)}.backlink-title{display:block;font-weight:600;font-size:var(--qn-text-sm);color:var(--qn-text-primary);margin-bottom:3px}.backlink-preview{font-size:10px;color:var(--qn-text-tertiary);margin:0;line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.version-history-panel{position:absolute;top:0;right:0;bottom:0;width:280px;background:var(--qn-bg-surface);border-left:1px solid var(--qn-border);z-index:var(--qn-z-overlay);display:flex;flex-direction:column;box-shadow:var(--qn-shadow-lg);animation:slideInRight .25s ease-out}.version-panel-header{padding:var(--qn-space-sm);border-bottom:1px solid var(--qn-border-subtle);display:flex;align-items:center;justify-content:space-between}.version-panel-header h3{margin:0;font-size:var(--qn-text-sm);font-weight:600}.version-list{flex:1;overflow-y:auto;padding:var(--qn-space-xs);display:flex;flex-direction:column;gap:var(--qn-space-xs)}.version-item{padding:var(--qn-space-sm);background:var(--qn-bg-elevated);border:1px solid var(--qn-border-subtle);border-radius:var(--qn-radius-xs);transition:all var(--qn-transition-fast)}.version-item:hover{border-color:var(--qn-border-strong)}.version-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:3px}.version-date{font-size:10px;color:var(--qn-text-muted)}.version-desc{font-size:var(--qn-text-xs);color:var(--qn-text-primary);margin:0;line-height:1.35}.version-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--qn-space-xl);text-align:center;color:var(--qn-text-tertiary);gap:var(--qn-space-sm)}.version-empty p{font-size:var(--qn-text-sm);margin:0}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.notes-view-container{flex:1;overflow-y:auto;padding:var(--qn-space-md)}.notes-view-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--qn-space-md)}.notes-count{font-size:var(--qn-text-sm);color:var(--qn-text-tertiary);font-weight:500}.notes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--qn-space-sm)}.notes-list{display:flex;flex-direction:column;gap:var(--qn-space-xs)}.note-card{background:var(--qn-bg-surface);border:1px solid var(--qn-border);border-radius:var(--qn-radius-md);overflow:hidden;cursor:pointer;transition:all var(--qn-transition-normal);animation:slideUp var(--qn-transition-slow) forwards;opacity:0;position:relative}.note-card:hover{border-color:var(--qn-border-strong);box-shadow:var(--qn-shadow-md);transform:translateY(-2px)}.note-card.active{border-color:var(--qn-primary);box-shadow:0 0 0 2px var(--qn-primary-glow)}.note-card.list{flex-direction:row;display:flex}.note-card.list .note-card-color-bar{width:4px;height:auto}.note-card-color-bar{height:3px;width:100%}.note-card-content{padding:var(--qn-space-sm);display:flex;flex-direction:column;gap:var(--qn-space-xs);flex:1}.note-card-header{display:flex;align-items:flex-start;justify-content:space-between}.note-card-title-row{display:flex;align-items:center;gap:5px;flex:1;min-width:0}.note-card-icon{font-size:var(--qn-text-sm);flex-shrink:0}.note-card-title{font-family:var(--qn-font-display);font-size:var(--qn-text-sm);font-weight:600;color:var(--qn-text-primary);margin:0}.note-card-badges{display:flex;gap:3px;flex-shrink:0}.badge-pin{color:var(--qn-primary-light)}.badge-star{color:var(--qn-accent-light)}.note-card-preview{font-size:var(--qn-text-xs);color:var(--qn-text-tertiary);line-height:1.45;margin:0}.note-card-tags{display:flex;flex-wrap:wrap;gap:3px}.note-card-tag{display:inline-flex;align-items:center;gap:2px;padding:1px 6px;background:var(--qn-bg-elevated);border-radius:var(--qn-radius-full);font-size:9px;color:var(--qn-text-muted);font-weight:500}.note-card-tag.more{color:var(--qn-primary-light)}.note-card-footer{display:flex;align-items:center;justify-content:space-between}.note-card-meta{display:flex;align-items:center;gap:3px;font-size:10px;color:var(--qn-text-muted)}.meta-separator{color:var(--qn-text-muted)}.note-card-actions{display:flex;gap:2px;opacity:0;transition:opacity var(--qn-transition-fast)}.note-card:hover .note-card-actions{opacity:1}.card-action-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--qn-radius-xs);color:var(--qn-text-muted);transition:all var(--qn-transition-fast)}.card-action-btn:hover{background:var(--qn-bg-hover);color:var(--qn-text-primary)}.card-action-btn.danger:hover{color:var(--qn-error);background:#d630311a}.notes-board{display:flex;gap:var(--qn-space-md);overflow-x:auto;padding-bottom:var(--qn-space-sm);min-height:360px}.board-column{min-width:260px;width:280px;flex-shrink:0;background:var(--qn-bg-surface);border:1px solid var(--qn-border);border-radius:var(--qn-radius-md);display:flex;flex-direction:column}.board-column-header{display:flex;align-items:center;justify-content:space-between;padding:var(--qn-space-sm);border-bottom:1px solid var(--qn-border-subtle)}.board-column-header h3{font-family:var(--qn-font-display);font-size:var(--qn-text-sm);font-weight:600;color:var(--qn-text-primary)}.board-column-count{font-size:10px;color:var(--qn-text-muted);background:var(--qn-bg-overlay);padding:1px 5px;border-radius:var(--qn-radius-full)}.board-column-cards{flex:1;padding:var(--qn-space-xs);overflow-y:auto;display:flex;flex-direction:column;gap:var(--qn-space-xs)}.board-column-cards .note-card{opacity:1;animation:none}.board-empty{padding:var(--qn-space-md);text-align:center;color:var(--qn-text-muted);font-size:var(--qn-text-xs)}.notes-timeline{padding:var(--qn-space-md);max-width:760px;margin:0 auto}.timeline-group{margin-bottom:var(--qn-space-xl);position:relative;padding-left:var(--qn-space-xl)}.timeline-group:before{content:"";position:absolute;left:5px;top:10px;bottom:-14px;width:2px;background:var(--qn-border)}.timeline-group:last-child:before{display:none}.timeline-date{display:flex;align-items:center;gap:var(--qn-space-sm);margin-bottom:var(--qn-space-sm);position:relative}.timeline-dot{width:12px;height:12px;border-radius:50%;background:var(--qn-primary);border:3px solid var(--qn-bg-base);position:absolute;left:-22px;z-index:1}.timeline-date h3{font-family:var(--qn-font-display);font-size:var(--qn-text-sm);font-weight:600;color:var(--qn-text-primary)}.timeline-count{font-size:var(--qn-text-xs);color:var(--qn-text-muted)}.timeline-notes{display:flex;flex-direction:column;gap:var(--qn-space-xs)}.timeline-notes .note-card{opacity:1;animation:none}.notes-empty-state{flex:1;display:flex;align-items:center;justify-content:center;min-height:360px}.notes-empty-content{text-align:center;color:var(--qn-text-tertiary)}.notes-empty-content h3{font-family:var(--qn-font-display);font-size:var(--qn-text-lg);font-weight:600;margin:var(--qn-space-sm) 0 var(--qn-space-xs);color:var(--qn-text-primary)}.notes-empty-content p{font-size:var(--qn-text-sm);margin-bottom:var(--qn-space-md)}.notes-view-info{display:flex;align-items:center;gap:6px}.note-card.grid .note-card-preview.line-clamp-3{-webkit-line-clamp:3;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.note-card.list .note-card-preview.line-clamp-2{-webkit-line-clamp:2;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.note-card.selected{border-color:var(--qn-primary);background:var(--qn-bg-overlay)}.selection-checkbox{position:absolute;top:10px;right:10px;width:18px;height:18px;border-radius:3px;border:2px solid var(--qn-border-strong);display:flex;align-items:center;justify-content:center;transition:all var(--qn-transition-fast);z-index:10;background:var(--qn-bg-surface);opacity:0}.note-card:hover .selection-checkbox,.note-card.selected .selection-checkbox{opacity:1}.selection-checkbox.checked{background:var(--qn-primary);border-color:var(--qn-primary)}.checkbox-inner{width:7px;height:7px;border-radius:1px;background:#fff;transform:scale(0);transition:transform .18s cubic-bezier(.34,1.56,.64,1)}.selection-checkbox.checked .checkbox-inner{transform:scale(1)}.batch-actions-bar{position:sticky;top:0;z-index:var(--qn-z-sticky);margin-bottom:var(--qn-space-sm);padding:8px 12px;background:var(--qn-bg-surface);border:1px solid var(--qn-primary);border-radius:var(--qn-radius-md);display:flex;align-items:center;justify-content:space-between;box-shadow:var(--qn-shadow-glow);animation:slideDown .25s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.batch-info{display:flex;align-items:center;gap:10px;font-weight:600;color:var(--qn-primary-light)}.batch-close{color:var(--qn-text-tertiary);display:flex;align-items:center}.batch-close:hover{color:var(--qn-text-primary)}.batch-actions{display:flex;gap:6px}.batch-btn{display:flex;align-items:center;gap:5px;padding:5px 10px;border-radius:var(--qn-radius-xs);font-size:var(--qn-text-sm);font-weight:500;background:var(--qn-bg-elevated);color:var(--qn-text-primary);transition:all .18s}.batch-btn:hover{background:var(--qn-bg-hover)}.batch-btn.danger:hover{color:#fff;background:var(--qn-error)}.graph-view-container{flex:1;position:relative;background:var(--qn-bg-base);overflow:hidden}.graph-canvas{width:100%;height:100%;cursor:grab}.graph-canvas:active{cursor:grabbing}.graph-legend{position:absolute;top:var(--qn-space-sm);left:var(--qn-space-sm);display:flex;align-items:center;gap:var(--qn-space-xs);padding:6px 12px;background:var(--qn-glass-bg);-webkit-backdrop-filter:var(--qn-glass-blur);backdrop-filter:var(--qn-glass-blur);border:1px solid var(--qn-glass-border);border-radius:var(--qn-radius-xs);font-size:var(--qn-text-xs);color:var(--qn-text-secondary)}.legend-item{display:flex;align-items:center;gap:5px}.legend-dot{width:7px;height:7px;border-radius:50%}.legend-line{width:14px;height:0;border-top:2px solid}.graph-info{position:absolute;bottom:var(--qn-space-sm);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:6px;padding:5px 12px;background:var(--qn-glass-bg);-webkit-backdrop-filter:var(--qn-glass-blur);backdrop-filter:var(--qn-glass-blur);border:1px solid var(--qn-glass-border);border-radius:var(--qn-radius-full);font-size:var(--qn-text-xs);color:var(--qn-text-muted)}.ai-panel{width:var(--qn-panel-width);height:100vh;display:flex;flex-direction:column;background:var(--qn-bg-surface);border-left:1px solid var(--qn-border);flex-shrink:0;animation:slideRight var(--qn-transition-slow) forwards;overflow:hidden}.ai-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--qn-space-sm);border-bottom:1px solid var(--qn-border-subtle);min-height:var(--qn-topbar-height)}.ai-header-left{display:flex;align-items:center;gap:6px}.ai-header-left h3{font-family:var(--qn-font-display);font-size:var(--qn-text-sm);font-weight:600}.ai-icon{color:var(--qn-primary-light)}.ai-close-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--qn-radius-xs);color:var(--qn-text-tertiary);transition:all var(--qn-transition-fast)}.ai-close-btn:hover{background:var(--qn-bg-hover);color:var(--qn-text-primary)}.ai-tabs{display:flex;padding:var(--qn-space-xs) var(--qn-space-sm);gap:3px;border-bottom:1px solid var(--qn-border-subtle)}.ai-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:6px;font-size:var(--qn-text-sm);font-weight:500;border-radius:var(--qn-radius-xs);color:var(--qn-text-tertiary);transition:all var(--qn-transition-fast)}.ai-tab:hover{background:var(--qn-bg-hover);color:var(--qn-text-primary)}.ai-tab.active{background:var(--qn-primary-glow);color:var(--qn-primary-light)}.ai-panel-content{flex:1;overflow-y:auto;padding:var(--qn-space-xs)}.ai-notice{display:flex;align-items:center;gap:6px;padding:8px 12px;background:var(--qn-bg-elevated);border-radius:var(--qn-radius-xs);font-size:var(--qn-text-xs);color:var(--qn-text-tertiary);margin-bottom:var(--qn-space-xs)}.prompt-category{margin-bottom:var(--qn-space-xs)}.prompt-category-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:6px 10px;font-size:var(--qn-text-sm);font-weight:600;color:var(--qn-text-secondary);border-radius:var(--qn-radius-xs);transition:all var(--qn-transition-fast)}.prompt-category-header:hover{background:var(--qn-bg-hover)}.prompt-category-header svg{transition:transform var(--qn-transition-fast)}.prompt-category-header svg.rotated{transform:rotate(180deg)}.prompt-list{padding-left:var(--qn-space-xs)}.prompt-item{display:flex;align-items:flex-start;gap:8px;width:100%;padding:6px 10px;border-radius:var(--qn-radius-xs);color:var(--qn-text-secondary);transition:all var(--qn-transition-fast);text-align:left}.prompt-item:hover:not(:disabled){background:var(--qn-bg-hover);color:var(--qn-text-primary)}.prompt-item:disabled{opacity:.4;cursor:not-allowed}.prompt-item svg{color:var(--qn-primary-light);flex-shrink:0;margin-top:1px}.prompt-item-info{display:flex;flex-direction:column;gap:1px}.prompt-item-name{font-size:var(--qn-text-sm);font-weight:500}.prompt-item-desc{font-size:10px;color:var(--qn-text-muted)}.ai-chat{height:100%;display:flex;flex-direction:column}.ai-messages{flex:1}.ai-chat-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--qn-space-xl);color:var(--qn-text-tertiary);text-align:center;gap:var(--qn-space-xs)}.ai-chat-empty p{font-size:var(--qn-text-sm);font-weight:500}.ai-chat-empty-sub{font-size:var(--qn-text-xs)!important;color:var(--qn-text-muted)!important;font-weight:400!important}.ai-message{display:flex;gap:10px;margin-bottom:var(--qn-space-md);animation:slideUp var(--qn-transition-normal) forwards}.ai-message.user{flex-direction:row-reverse}.ai-message-avatar{width:28px;height:28px;border-radius:50%;background:var(--qn-primary-glow);display:flex;align-items:center;justify-content:center;color:var(--qn-primary-light);flex-shrink:0;box-shadow:var(--qn-shadow-sm);border:1px solid var(--qn-border)}.ai-message-content{padding:10px 14px;font-size:var(--qn-text-sm);line-height:1.55;box-shadow:var(--qn-shadow-md);position:relative}.ai-message.user .ai-message-content{background:linear-gradient(135deg,var(--qn-primary),var(--qn-primary-dark));color:#fff;border-radius:16px 16px 2px;max-width:78%;margin-right:4px}.ai-message.assistant .ai-message-content{background:var(--qn-bg-elevated);border:1px solid var(--qn-border);border-radius:16px 16px 16px 2px;max-width:82%;color:var(--qn-text-primary)}.ai-message-content .markdown-content{font-size:var(--qn-text-sm)}.ai-message-actions{display:flex;gap:6px;margin-top:8px;padding-top:6px;border-top:1px solid var(--qn-border-subtle)}.ai-message-actions button{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--qn-radius-xs);color:var(--qn-text-muted);transition:all var(--qn-transition-fast)}.ai-message-actions button:hover{background:var(--qn-bg-hover);color:var(--qn-text-primary)}.ai-typing{display:flex;align-items:center;gap:6px;font-size:var(--qn-text-sm);color:var(--qn-text-tertiary)}.ai-input-container{padding:var(--qn-space-xs);border-top:1px solid var(--qn-border-subtle);display:flex;gap:6px;align-items:flex-end}.ai-clear-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--qn-radius-xs);color:var(--qn-text-muted);transition:all var(--qn-transition-fast);flex-shrink:0}.ai-clear-btn:hover{background:#d630311a;color:var(--qn-error)}.ai-input-wrapper{flex:1;display:flex;align-items:flex-end;gap:6px;background:var(--qn-bg-elevated);border:1px solid var(--qn-border);border-radius:var(--qn-radius-xs);padding:3px;transition:all var(--qn-transition-fast)}.ai-input-wrapper:focus-within{border-color:var(--qn-primary);box-shadow:0 0 0 2px var(--qn-primary-glow)}.ai-input{flex:1;border:none!important;background:none!important;padding:6px 8px!important;font-size:var(--qn-text-sm)!important;resize:none;min-height:32px;max-height:100px;outline:none}.ai-input:focus{box-shadow:none!important}.ai-send-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--qn-primary);color:#fff;border-radius:var(--qn-radius-xs);transition:all var(--qn-transition-fast);flex-shrink:0}.ai-send-btn:hover:not(:disabled){background:var(--qn-primary-dark);box-shadow:var(--qn-shadow-glow)}.ai-send-btn:disabled{opacity:.4;cursor:not-allowed}.command-palette-overlay{position:fixed;inset:0;background:#00000073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--qn-z-modal);display:flex;align-items:flex-start;justify-content:center;padding-top:12vh;animation:fadeIn 80ms ease-out}.command-palette{width:560px;max-height:480px;background:var(--qn-bg-elevated);border:1px solid var(--qn-border-strong);border-radius:var(--qn-radius-lg);box-shadow:0 20px 70px #0009;display:flex;flex-direction:column;overflow:hidden;animation:scaleIn .12s cubic-bezier(.16,1,.3,1);-webkit-backdrop-filter:var(--qn-glass-blur);backdrop-filter:var(--qn-glass-blur)}.command-search{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--qn-border)}.command-search svg{color:var(--qn-text-muted);flex-shrink:0}.command-search input{border:none;background:none;flex:1;font-size:var(--qn-text-base);color:var(--qn-text-primary);padding:0;outline:none}.command-search input:focus{box-shadow:none}.command-search input::placeholder{color:var(--qn-text-muted)}.command-results{flex:1;overflow-y:auto;padding:var(--qn-space-xs)}.command-empty{padding:var(--qn-space-xl);text-align:center;color:var(--qn-text-muted);font-size:var(--qn-text-sm)}.command-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 12px;border-radius:var(--qn-radius-xs);color:var(--qn-text-secondary);transition:all 70ms ease-out;text-align:left}.command-item:hover,.command-item.selected{background:var(--qn-bg-hover);color:var(--qn-text-primary)}.command-item-icon{width:26px;height:26px;display:flex;align-items:center;justify-content:center;border-radius:var(--qn-radius-xs);background:var(--qn-bg-overlay);flex-shrink:0}.command-item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.command-item-label{font-size:var(--qn-text-sm);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.command-item-desc{font-size:10px;color:var(--qn-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.command-item-shortcut{font-family:var(--qn-font-mono);font-size:10px;color:var(--qn-text-muted);background:var(--qn-bg-overlay);padding:2px 5px;border-radius:3px;flex-shrink:0}.command-item-category{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;flex-shrink:0}.command-footer{display:flex;align-items:center;justify-content:center;gap:var(--qn-space-md);padding:8px;border-top:1px solid var(--qn-border-subtle);font-size:10px;color:var(--qn-text-muted)}.command-footer kbd{font-size:9px;padding:1px 4px}.settings-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--qn-z-modal);display:flex;align-items:center;justify-content:center;animation:fadeIn 80ms ease-out}.settings-panel{width:500px;max-height:78vh;background:var(--qn-bg-elevated);border:1px solid var(--qn-border-strong);border-radius:var(--qn-radius-lg);box-shadow:var(--qn-shadow-xl);display:flex;flex-direction:column;overflow:hidden;animation:scaleIn .12s cubic-bezier(.4,0,.2,1)}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:var(--qn-space-md) var(--qn-space-lg);border-bottom:1px solid var(--qn-border)}.settings-header h2{font-family:var(--qn-font-display);font-size:var(--qn-text-lg);font-weight:700}.settings-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--qn-radius-xs);color:var(--qn-text-tertiary);transition:all var(--qn-transition-fast)}.settings-close:hover{background:var(--qn-bg-hover);color:var(--qn-text-primary)}.settings-content{flex:1;overflow-y:auto;padding:var(--qn-space-md) var(--qn-space-lg)}.settings-section{margin-bottom:var(--qn-space-lg)}.settings-section h3{font-family:var(--qn-font-display);font-size:var(--qn-text-sm);font-weight:600;color:var(--qn-text-primary);margin-bottom:var(--qn-space-sm);padding-bottom:var(--qn-space-xs);border-bottom:1px solid var(--qn-border-subtle)}.settings-info{font-size:var(--qn-text-sm);color:var(--qn-text-tertiary);line-height:1.55}.setting-item{margin-bottom:var(--qn-space-sm)}.setting-item label{display:block;font-size:var(--qn-text-sm);font-weight:500;color:var(--qn-text-secondary);margin-bottom:5px}.setting-item.toggle{display:flex;align-items:center;justify-content:space-between}.setting-item.toggle label{margin-bottom:0}.setting-item select{width:100%;padding:6px 10px;font-size:var(--qn-text-sm);cursor:pointer}.setting-item input[type=password],.setting-item input[type=text]{width:100%;padding:6px 10px;font-size:var(--qn-text-sm)}.setting-row{display:flex;align-items:center;gap:10px}.setting-row input[type=range]{flex:1;-webkit-appearance:none;height:4px;background:var(--qn-bg-overlay);border-radius:2px;outline:none;border:none;padding:0}.setting-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--qn-primary);cursor:pointer;border:2px solid var(--qn-bg-elevated);box-shadow:0 0 0 2px var(--qn-primary-glow)}.setting-value{font-family:var(--qn-font-mono);font-size:var(--qn-text-sm);color:var(--qn-text-tertiary);min-width:36px;text-align:right}.setting-hint{font-size:10px;color:var(--qn-text-muted);margin-top:3px;display:block}.theme-picker{display:flex;gap:6px}.theme-option{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:8px;border:1px solid var(--qn-border);border-radius:var(--qn-radius-xs);font-size:var(--qn-text-sm);font-weight:500;color:var(--qn-text-secondary);transition:all var(--qn-transition-fast)}.theme-option:hover{border-color:var(--qn-border-strong);background:var(--qn-bg-hover)}.theme-option.active{border-color:var(--qn-primary);background:var(--qn-primary-glow);color:var(--qn-primary-light)}.toggle-switch{width:40px;height:22px;border-radius:11px;background:var(--qn-bg-overlay);border:1px solid var(--qn-border);position:relative;cursor:pointer;transition:all var(--qn-transition-fast);flex-shrink:0}.toggle-switch.on{background:var(--qn-primary);border-color:var(--qn-primary)}.toggle-knob{width:16px;height:16px;border-radius:50%;background:#fff;position:absolute;top:2px;left:2px;transition:transform var(--qn-transition-fast);box-shadow:var(--qn-shadow-sm)}.toggle-switch.on .toggle-knob{transform:translate(18px)}.toast{display:flex;align-items:flex-start;gap:8px;padding:10px 14px;background:var(--qn-bg-elevated);border:1px solid var(--qn-border-strong);border-radius:var(--qn-radius-xs);box-shadow:var(--qn-shadow-lg);min-width:260px;max-width:380px;animation:slideUp var(--qn-transition-spring) forwards;-webkit-backdrop-filter:var(--qn-glass-blur);backdrop-filter:var(--qn-glass-blur)}.toast-success{border-left:3px solid var(--qn-success)}.toast-error{border-left:3px solid var(--qn-error)}.toast-warning{border-left:3px solid var(--qn-warning)}.toast-info{border-left:3px solid var(--qn-info)}.toast-icon{flex-shrink:0;margin-top:1px}.toast-success .toast-icon{color:var(--qn-success)}.toast-error .toast-icon{color:var(--qn-error)}.toast-warning .toast-icon{color:var(--qn-warning)}.toast-info .toast-icon{color:var(--qn-info)}.toast-content{flex:1;display:flex;flex-direction:column;gap:1px}.toast-title{font-size:var(--qn-text-sm);font-weight:600;color:var(--qn-text-primary)}.toast-description{font-size:var(--qn-text-xs);color:var(--qn-text-tertiary)}.toast-close{width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:var(--qn-radius-xs);color:var(--qn-text-muted);transition:all var(--qn-transition-fast);flex-shrink:0}.toast-close:hover{background:var(--qn-bg-hover);color:var(--qn-text-primary)}.template-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--qn-z-modal);display:flex;align-items:center;justify-content:center;animation:fadeIn .1s ease-out}.template-picker{width:640px;max-height:75vh;background:var(--qn-bg-elevated);border:1px solid var(--qn-border-strong);border-radius:var(--qn-radius-xl);box-shadow:var(--qn-shadow-xl);display:flex;flex-direction:column;overflow:hidden;animation:scaleIn .15s cubic-bezier(.4,0,.2,1)}.template-header{display:flex;align-items:center;justify-content:space-between;padding:var(--qn-space-lg) var(--qn-space-xl);border-bottom:1px solid var(--qn-border)}.template-header h2{font-family:var(--qn-font-display);font-size:var(--qn-text-xl);font-weight:700;color:var(--qn-text-primary);margin:0}.template-close{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:var(--qn-radius-md);color:var(--qn-text-tertiary);background:transparent;border:none;cursor:pointer;transition:all var(--qn-transition-fast)}.template-close:hover{background:var(--qn-bg-hover);color:var(--qn-text-primary)}.template-categories{display:flex;gap:6px;padding:var(--qn-space-sm) var(--qn-space-xl);overflow-x:auto;border-bottom:1px solid var(--qn-border-subtle)}.template-category-btn{padding:6px 14px;font-size:var(--qn-text-xs);font-weight:500;border-radius:var(--qn-radius-full);color:var(--qn-text-tertiary);border:1px solid var(--qn-border);background:transparent;cursor:pointer;transition:all var(--qn-transition-fast);white-space:nowrap}.template-category-btn:hover{border-color:var(--qn-border-strong);color:var(--qn-text-primary)}.template-category-btn.active{background:var(--qn-primary);border-color:var(--qn-primary);color:#fff}.template-grid{flex:1;overflow-y:auto;padding:var(--qn-space-lg) var(--qn-space-xl);display:grid;grid-template-columns:repeat(3,1fr);gap:var(--qn-space-sm)}.template-card{border:1px solid var(--qn-border);border-radius:var(--qn-radius-md);overflow:hidden;cursor:pointer;transition:all var(--qn-transition-normal)}.template-card:hover{border-color:var(--qn-border-strong);box-shadow:var(--qn-shadow-md);transform:translateY(-2px)}.template-card-header{height:48px;display:flex;align-items:center;justify-content:center;background:var(--qn-bg-tertiary)}.template-card-icon{font-size:22px}.template-card-body{padding:var(--qn-space-xs) var(--qn-space-sm)}.template-card-body h4{font-size:var(--qn-text-sm);font-weight:600;color:var(--qn-text-primary);margin:0 0 2px}.template-card-body p{font-size:11px;color:var(--qn-text-muted);line-height:1.3;margin:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.node-library{width:260px;height:100%;background:var(--qn-bg-secondary);border-right:1px solid var(--qn-border);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;z-index:10}.nl-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--qn-border)}.nl-header h3{font-size:14px;font-weight:700;color:var(--qn-text-primary)}.nl-close{width:24px;height:24px;border:none;background:var(--qn-bg-tertiary);color:var(--qn-text-secondary);border-radius:6px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .15s}.nl-close:hover{background:#e74c3c33;color:#e17055}.nl-content{flex:1;overflow-y:auto;padding:12px}.nl-category{margin-bottom:16px}.nl-category-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--qn-text-secondary);margin-bottom:8px;padding-left:4px}.nl-node-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--qn-bg-tertiary);border:1px solid var(--qn-border);border-left:3px solid;border-radius:8px;margin-bottom:6px;cursor:grab;transition:all .15s}.nl-node-item:hover{background:var(--qn-bg-hover);transform:translate(2px);box-shadow:0 2px 10px #00000026}.nl-node-item:active{cursor:grabbing;transform:scale(.98)}.nl-node-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.nl-node-info{display:flex;flex-direction:column;gap:2px;min-width:0}.nl-node-label{font-size:12px;font-weight:600;color:var(--qn-text-primary)}.nl-node-desc{font-size:10px;color:var(--qn-text-secondary);line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}.nl-footer{padding:10px 16px;border-top:1px solid var(--qn-border);text-align:center}.nl-footer p{font-size:11px;color:var(--qn-text-secondary)}.ncp-panel{width:310px;height:100%;background:var(--qn-bg-secondary);border-left:1px solid var(--qn-border);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;z-index:10}.ncp-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--qn-border)}.ncp-header h3{font-size:14px;font-weight:700;color:var(--qn-text-primary)}.ncp-header-actions{display:flex;align-items:center;gap:6px}.ncp-run-btn{padding:4px 12px;background:linear-gradient(135deg,#55efc4,#00cec9);color:#0a0a0a;border:none;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.ncp-run-btn:hover{transform:scale(1.05);box-shadow:0 2px 10px #55efc44d}.ncp-close{width:24px;height:24px;border:none;background:var(--qn-bg-tertiary);color:var(--qn-text-secondary);border-radius:6px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .15s}.ncp-close:hover{background:#e74c3c33;color:#e17055}.ncp-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:14px}.ncp-field{display:flex;flex-direction:column;gap:6px}.ncp-field label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--qn-text-secondary)}.ncp-field input,.ncp-field select,.ncp-field textarea{padding:8px 10px;background:var(--qn-bg-tertiary);border:1px solid var(--qn-border);border-radius:8px;color:var(--qn-text-primary);font-size:13px;transition:border-color .15s}.ncp-field input:focus,.ncp-field select:focus,.ncp-field textarea:focus{outline:none;border-color:var(--qn-accent)}.ncp-field input[type=range]{padding:0;background:transparent;border:none}.ncp-field textarea{resize:vertical;font-family:var(--qn-font-mono);font-size:12px;line-height:1.5}.ncp-code-input{font-family:var(--qn-font-mono)!important;font-size:12px!important;line-height:1.5}.ncp-hint{font-size:10px;color:var(--qn-text-secondary);font-style:italic}.ncp-checkbox{flex-direction:row!important;align-items:center!important}.ncp-checkbox label{display:flex;align-items:center;gap:8px;text-transform:none;font-size:13px;font-weight:500;cursor:pointer}.ncp-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:var(--qn-accent)}.ncp-output-section,.ncp-error-section{margin-top:8px;padding-top:12px;border-top:1px solid var(--qn-border)}.ncp-output-section h4,.ncp-error-section h4{font-size:11px;font-weight:600;text-transform:uppercase;color:var(--qn-text-secondary);margin-bottom:8px}.ncp-output{padding:10px;background:#55efc414;border:1px solid rgba(85,239,196,.2);border-radius:8px;font-family:var(--qn-font-mono);font-size:12px;color:#55efc4;max-height:200px;overflow-y:auto;white-space:pre-wrap;word-break:break-all}.ncp-error{padding:10px;background:#e74c3c14;border:1px solid rgba(231,76,60,.2);border-radius:8px;font-family:var(--qn-font-mono);font-size:12px;color:#e17055;max-height:120px;overflow-y:auto}.ncp-export-btn{width:100%;padding:10px 16px;background:linear-gradient(135deg,#6c5ce7,#a29bfe);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;letter-spacing:.02em}.ncp-export-btn:hover{transform:translateY(-1px);box-shadow:0 4px 14px #6c5ce766}.ncp-export-btn:active{transform:translateY(0)}.document-library{width:280px;height:100%;background:var(--qn-bg-secondary);border-right:1px solid var(--qn-border);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}.dl-header{display:flex;align-items:center;justify-content:space-between;padding:var(--qn-space-md) var(--qn-space-lg);border-bottom:1px solid var(--qn-border)}.dl-header h3{font-size:var(--qn-text-sm);font-weight:700;color:var(--qn-text-primary)}.dl-count{background:var(--qn-bg-tertiary);color:var(--qn-text-secondary);font-size:var(--qn-text-xs);font-weight:600;padding:2px 8px;border-radius:var(--qn-radius-full)}.dl-actions{display:flex;gap:var(--qn-space-xs);padding:var(--qn-space-sm) var(--qn-space-md);border-bottom:1px solid var(--qn-border)}.dl-upload-btn,.dl-manual-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:7px 10px;border:1px dashed var(--qn-border);border-radius:var(--qn-radius-md);background:transparent;color:var(--qn-text-secondary);font-size:var(--qn-text-xs);font-weight:500;cursor:pointer;transition:all var(--qn-transition-fast)}.dl-upload-btn:hover{background:#00cec91a;border-color:#00cec9;color:#00cec9}.dl-manual-btn:hover{background:#6c5ce71a;border-color:#6c5ce7;color:#6c5ce7}.dl-manual-form{padding:var(--qn-space-sm) var(--qn-space-md);border-bottom:1px solid var(--qn-border);display:flex;flex-direction:column;gap:var(--qn-space-xs)}.dl-input{padding:7px 10px;background:var(--qn-bg-tertiary);border:1px solid var(--qn-border);border-radius:var(--qn-radius-sm);color:var(--qn-text-primary);font-size:var(--qn-text-xs);transition:border-color var(--qn-transition-fast)}.dl-input:focus{outline:none;border-color:var(--qn-accent)}.dl-type-toggle{display:flex;gap:4px}.dl-type-btn{flex:1;padding:5px 10px;border:1px solid var(--qn-border);border-radius:var(--qn-radius-sm);background:transparent;color:var(--qn-text-secondary);font-size:var(--qn-text-xs);font-weight:600;cursor:pointer;transition:all var(--qn-transition-fast)}.dl-type-btn.active{background:#00cec926;border-color:#00cec9;color:#00cec9}.dl-textarea{padding:var(--qn-space-xs) 10px;background:var(--qn-bg-tertiary);border:1px solid var(--qn-border);border-radius:var(--qn-radius-sm);color:var(--qn-text-primary);font-family:var(--qn-font-mono);font-size:var(--qn-text-xs);line-height:1.5;resize:vertical;transition:border-color var(--qn-transition-fast)}.dl-textarea:focus{outline:none;border-color:var(--qn-accent)}.dl-manual-actions{display:flex;gap:var(--qn-space-xs)}.dl-add-btn{flex:1;padding:6px var(--qn-space-md);background:linear-gradient(135deg,#00cec9,#55efc4);color:#0a0a0a;border:none;border-radius:var(--qn-radius-sm);font-size:var(--qn-text-xs);font-weight:600;cursor:pointer;transition:all var(--qn-transition-fast)}.dl-add-btn:hover{transform:scale(1.02);box-shadow:0 2px 10px #00cec94d}.dl-cancel-btn{padding:6px var(--qn-space-md);background:var(--qn-bg-tertiary);color:var(--qn-text-secondary);border:1px solid var(--qn-border);border-radius:var(--qn-radius-sm);font-size:var(--qn-text-xs);cursor:pointer;transition:all var(--qn-transition-fast)}.dl-search{display:flex;align-items:center;gap:var(--qn-space-xs);margin:var(--qn-space-xs) var(--qn-space-md);padding:7px 10px;background:var(--qn-bg-tertiary);border:1px solid var(--qn-border);border-radius:var(--qn-radius-md);color:var(--qn-text-secondary);transition:border-color var(--qn-transition-fast)}.dl-search:focus-within{border-color:var(--qn-accent)}.dl-search input{flex:1;border:none;background:transparent;color:var(--qn-text-primary);font-size:var(--qn-text-xs);outline:none}.dl-list{flex:1;overflow-y:auto;padding:4px var(--qn-space-xs)}.dl-empty{text-align:center;padding:var(--qn-space-2xl) var(--qn-space-lg);color:var(--qn-text-secondary)}.dl-empty p:first-child{font-size:var(--qn-text-sm);font-weight:500}.dl-empty-hint{font-size:var(--qn-text-xs);margin-top:4px;opacity:.7}.dl-doc-item{background:var(--qn-bg-tertiary);border:1px solid var(--qn-border);border-radius:var(--qn-radius-md);margin-bottom:6px;overflow:hidden;transition:all var(--qn-transition-fast)}.dl-doc-item:hover{border-color:var(--qn-accent)}.dl-doc-item.active{border-color:#00cec9;box-shadow:0 0 0 1px #00cec94d}.dl-doc-main{display:flex;align-items:center;gap:10px;padding:var(--qn-space-sm);cursor:pointer}.dl-doc-icon{width:32px;height:32px;border-radius:var(--qn-radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.dl-doc-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.dl-doc-title{font-size:var(--qn-text-xs);font-weight:600;color:var(--qn-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dl-doc-meta{font-size:10px;color:var(--qn-text-secondary)}.dl-doc-status{display:flex;align-items:center;gap:6px;color:var(--qn-text-secondary)}.dl-status-dot{width:6px;height:6px;border-radius:50%}.dl-doc-expanded{padding:0 var(--qn-space-sm) var(--qn-space-sm);border-top:1px solid var(--qn-border)}.dl-preview-section{margin-top:var(--qn-space-xs)}.dl-preview-badge{font-size:10px;font-weight:600;color:var(--qn-text-secondary);display:block;margin-bottom:6px}.dl-mini-table{font-family:var(--qn-font-mono);font-size:10px;border:1px solid var(--qn-border);border-radius:var(--qn-radius-sm);overflow:hidden}.dl-mini-row{display:flex;border-bottom:1px solid var(--qn-border)}.dl-mini-row:last-child{border-bottom:none}.dl-mini-header{background:#00cec914;font-weight:600;color:#55efc4}.dl-mini-cell{flex:1;padding:3px 6px;border-right:1px solid var(--qn-border);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--qn-text-primary)}.dl-mini-cell:last-child{border-right:none}.dl-mini-more{justify-content:center;color:var(--qn-text-secondary);font-style:italic}.dl-mini-more span{padding:2px 6px}.dl-metrics-list{display:flex;flex-direction:column;gap:2px}.dl-metric-item{display:flex;justify-content:space-between;padding:3px 6px;background:#6c5ce70d;border-radius:4px;font-size:10px}.dl-metric-name{color:var(--qn-text-secondary)}.dl-metric-value{color:#6c5ce7;font-weight:600;font-family:var(--qn-font-mono)}.dl-doc-actions{display:flex;gap:6px;margin-top:var(--qn-space-xs)}.dl-action-btn{flex:1;padding:5px var(--qn-space-xs);background:var(--qn-bg-secondary);border:1px solid var(--qn-border);border-radius:var(--qn-radius-sm);color:var(--qn-text-secondary);font-size:10px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;transition:all var(--qn-transition-fast)}.dl-action-btn:hover{background:var(--qn-bg-hover);color:var(--qn-text-primary)}.dl-add-to-canvas{background:#00cec91a;border-color:#00cec94d;color:#00cec9}.dl-add-to-canvas:hover{background:#00cec933;color:#55efc4}.dl-delete-btn:hover{background:#e74c3c26;border-color:#e170554d;color:#e17055}.dl-footer{padding:var(--qn-space-xs) var(--qn-space-md);border-top:1px solid var(--qn-border);text-align:center}.dl-footer p{font-size:10px;color:var(--qn-text-secondary);opacity:.7}.insights-panel{width:340px;height:100%;background:var(--qn-bg-secondary);border-left:1px solid var(--qn-border);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}.ip-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--qn-border)}.ip-header-left{display:flex;align-items:center;gap:8px}.ip-header-icon{color:#a29bfe}.ip-header h3{font-size:14px;font-weight:700;color:var(--qn-text-primary)}.ip-badge{background:linear-gradient(135deg,#6c5ce7,#a29bfe);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px}.ip-header-right{display:flex;align-items:center;gap:4px}.ip-toggle-dismissed,.ip-close-btn{padding:4px;background:transparent;border:none;border-radius:6px;color:var(--qn-text-secondary);cursor:pointer;transition:all .15s}.ip-toggle-dismissed:hover,.ip-close-btn:hover{background:var(--qn-bg-hover);color:var(--qn-text-primary)}.ip-filters{display:flex;gap:4px;padding:10px 12px;border-bottom:1px solid var(--qn-border);overflow-x:auto;flex-shrink:0}.ip-filter-pill{display:flex;align-items:center;gap:4px;padding:4px 10px;border:1px solid var(--qn-border);border-radius:20px;background:transparent;color:var(--qn-text-secondary);font-size:11px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.ip-filter-pill:hover{background:var(--qn-bg-hover)}.ip-filter-pill.active{font-weight:600}.ip-filter-count{background:#ffffff14;padding:0 5px;border-radius:8px;font-size:10px}.ip-list{flex:1;overflow-y:auto;padding:8px}.ip-empty{text-align:center;padding:40px 20px;color:var(--qn-text-secondary)}.ip-empty p:first-of-type{font-size:13px;font-weight:500;margin-top:12px}.ip-empty-sub{font-size:11px;margin-top:4px;opacity:.7;line-height:1.5}.ip-insight{background:var(--qn-bg-tertiary);border:1px solid var(--qn-border);border-left:3px solid var(--qn-accent);border-radius:8px;margin-bottom:6px;overflow:hidden;transition:all .15s}.ip-insight:hover{border-color:var(--qn-border-hover)}.ip-insight.pinned{box-shadow:0 0 0 1px #6c5ce733}.ip-insight.dismissed{opacity:.5}.ip-insight-header{display:flex;align-items:center;gap:10px;padding:10px;cursor:pointer}.ip-insight-icon{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.ip-insight-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.ip-insight-title{font-size:12px;font-weight:600;color:var(--qn-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ip-insight-source{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--qn-text-secondary)}.ip-insight-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.ip-confidence{width:40px;height:4px;border-radius:2px;overflow:hidden}.ip-confidence-bar{height:100%;border-radius:2px;transition:width .3s}.ip-insight-expanded{padding:0 10px 10px;border-top:1px solid var(--qn-border)}.ip-insight-content{font-size:12px;line-height:1.6;color:var(--qn-text-primary);margin:8px 0}.ip-insight-data{display:grid;grid-template-columns:1fr 1fr;gap:3px;margin:8px 0;padding:8px;background:#00000026;border-radius:6px}.ip-data-item{display:flex;justify-content:space-between;align-items:center;padding:2px 0}.ip-data-key{font-size:10px;color:var(--qn-text-secondary);text-transform:capitalize}.ip-data-value{font-size:11px;font-family:var(--qn-font-mono);font-weight:600}.ip-insight-actions{display:flex;gap:6px;margin-top:8px}.ip-action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:4px;padding:5px 8px;background:var(--qn-bg-secondary);border:1px solid var(--qn-border);border-radius:6px;color:var(--qn-text-secondary);font-size:10px;cursor:pointer;transition:all .15s}.ip-action-btn:hover{background:var(--qn-bg-hover);color:var(--qn-text-primary)}.ip-delete-btn{max-width:32px}.ip-delete-btn:hover{background:#e74c3c26;color:#e17055}.ip-footer{padding:8px 12px;border-top:1px solid var(--qn-border)}.ip-clear-btn{width:100%;padding:6px 12px;background:#e74c3c1a;border:1px solid rgba(231,76,60,.2);border-radius:6px;color:#e17055;font-size:11px;font-weight:500;cursor:pointer;transition:all .15s}.ip-clear-btn:hover{background:#e74c3c33}:root{--qn-port-size: 10px;--qn-header-height: 32px;--qn-port-spacing: 26px;--qn-body-padding: 12px}.qf-canvas-container{display:flex;flex-direction:column;width:100%;height:100%;background:var(--qn-bg-primary);overflow:hidden}.qf-canvas-empty{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:var(--qn-bg-primary)}.qf-empty-content{text-align:center;animation:qf-float 3s ease-in-out infinite}.qf-empty-icon{font-size:64px;display:block;margin-bottom:16px}.qf-empty-content h2{font-size:24px;font-weight:700;background:linear-gradient(135deg,#00cec9,#6c5ce7);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:8px}.qf-empty-content p{color:var(--qn-text-secondary);margin-bottom:24px}.qf-btn-primary{padding:12px 28px;background:linear-gradient(135deg,#6c5ce7,#a29bfe);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.qf-btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 25px #6c5ce766}.qf-toolbar{display:flex;align-items:center;justify-content:space-between;height:48px;padding:0 16px;background:var(--qn-bg-secondary);border-bottom:1px solid var(--qn-border);gap:16px;flex-shrink:0}.qf-toolbar-left,.qf-toolbar-right{display:flex;align-items:center;gap:8px}.qf-toolbar-center{flex:1;display:flex;justify-content:center}.qf-toolbar-btn{display:flex;align-items:center;gap:5px;padding:6px 14px;background:var(--qn-bg-tertiary);border:1px solid var(--qn-border);border-radius:8px;color:var(--qn-text-primary);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.qf-toolbar-btn:hover{background:var(--qn-bg-hover);border-color:var(--qn-accent)}.qf-toolbar-btn.active{background:var(--qn-accent);color:#fff;border-color:var(--qn-accent)}.qf-toolbar-btn.live-pulse{animation:qf-live-pulse 1.5s ease-in-out infinite}@keyframes qf-live-pulse{0%,to{box-shadow:0 0 #e74c3c66}50%{box-shadow:0 0 0 6px #e74c3c00}}.qf-toolbar-separator{width:1px;height:24px;background:var(--qn-border)}.qf-flow-title{background:transparent;border:1px solid transparent;border-radius:8px;padding:6px 12px;color:var(--qn-text-primary);font-size:14px;font-weight:600;text-align:center;width:220px;transition:all .15s}.qf-flow-title:hover{border-color:var(--qn-border);background:var(--qn-bg-tertiary)}.qf-flow-title:focus{outline:none;border-color:var(--qn-accent);background:var(--qn-bg-tertiary)}.qf-toolbar-info{color:var(--qn-text-secondary);font-size:12px}.qf-zoom-display{color:var(--qn-text-secondary);font-size:11px;background:var(--qn-bg-tertiary);padding:3px 8px;border-radius:6px;font-family:var(--qn-font-mono)}.qf-execute-btn{background:linear-gradient(135deg,#55efc426,#00cec926);border-color:#55efc44d;color:#55efc4}.qf-execute-btn:hover{background:linear-gradient(135deg,#55efc440,#00cec940);border-color:#55efc4;box-shadow:0 0 12px #55efc433}.qf-zoom-btn{padding:6px 10px;font-size:16px;min-width:auto}.qf-insights-btn{background:linear-gradient(135deg,#a29bfe1a,#6c5ce71a);border-color:#a29bfe4d;color:#a29bfe;position:relative}.qf-insights-btn:hover{background:linear-gradient(135deg,#a29bfe33,#6c5ce733);border-color:#a29bfe;box-shadow:0 0 12px #a29bfe33}.qf-insights-btn.active{background:#a29bfe;color:#fff;border-color:#a29bfe}.qf-insights-badge{background:#e17055;color:#fff;font-size:9px;font-weight:700;padding:1px 5px;border-radius:8px;min-width:14px;text-align:center}.qf-workspace{display:flex;flex:1;overflow:hidden;position:relative}.qf-canvas{flex:1;position:relative;overflow:hidden;cursor:grab;-webkit-user-select:none;user-select:none}.qf-canvas.panning{cursor:grabbing}.qf-grid{position:absolute;inset:0;background-image:radial-gradient(circle,var(--qn-border) 1px,transparent 1px);background-size:20px 20px;pointer-events:none;opacity:.4}.qf-transform-layer{position:absolute;top:0;left:0;width:0;height:0;overflow:visible}.qf-wires-svg-overlay{position:absolute;top:0;left:0;width:100%;height:100%;overflow:visible;pointer-events:none;z-index:5}.qf-wires-svg-overlay g{pointer-events:none}.qf-wires-svg-overlay path{transition:stroke .2s,stroke-width .2s,opacity .2s}.qf-wires-svg-overlay path[stroke=transparent]{pointer-events:stroke}.qf-node{position:absolute;background:var(--qn-bg-secondary);border:2px solid var(--qn-border);border-radius:10px;box-shadow:0 4px 20px #00000040;z-index:2;cursor:move;transition:box-shadow .2s,border-color .2s;min-width:160px;font-family:var(--qn-font-sans)}.qf-node:hover{box-shadow:0 6px 30px #00000059}.qf-node.selected{box-shadow:0 0 0 2px var(--qn-accent),0 6px 30px #6c5ce74d;z-index:3}.qf-node.complete{border-color:#55efc480}.qf-node.error{border-color:#e1705580}.qf-node.running{animation:qf-node-running 1s ease-in-out infinite}@keyframes qf-node-running{0%,to{box-shadow:0 0 #fdcb6e4d}50%{box-shadow:0 0 0 8px #fdcb6e00}}.qf-node-header{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-radius:8px 8px 0 0;height:var(--qn-header-height);min-height:var(--qn-header-height)}.qf-node-header-left{display:flex;align-items:center;gap:6px}.qf-node-icon{font-size:13px;line-height:1}.qf-node-type{font-size:11px;font-weight:600;color:var(--qn-text-primary);letter-spacing:.02em}.qf-node-header-right{display:flex;align-items:center;gap:6px}.qf-node-status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.qf-node-delete{display:none;width:18px;height:18px;background:#e74c3c26;border:none;border-radius:50%;color:#e17055;font-size:12px;line-height:1;cursor:pointer;padding:0;transition:all .15s;align-items:center;justify-content:center}.qf-node:hover .qf-node-delete{display:flex}.qf-node-delete:hover{background:#e74c3c59}.qf-node-body{padding:var(--qn-body-padding);min-height:40px;overflow:hidden}.qf-node-output-preview{display:flex;flex-direction:column;gap:3px}.qf-output-label{font-size:9px;color:var(--qn-text-tertiary);text-transform:uppercase;letter-spacing:.05em}.qf-output-value{font-size:12px;font-family:var(--qn-font-mono);color:#55efc4;word-break:break-word;max-height:50px;overflow:hidden;line-height:1.3}.qf-node-error{font-size:10px;color:#e17055;font-family:var(--qn-font-mono);line-height:1.3}.qf-node-idle{font-size:11px;color:var(--qn-text-tertiary);font-style:italic}.qf-mini-chart{margin-top:6px;border-radius:4px;overflow:hidden;background:#00000026;padding:6px}.qf-chart-placeholder{font-size:24px;display:flex;justify-content:center}.qf-ports{position:absolute;width:100%;left:0;pointer-events:none}.qf-ports-input,.qf-ports-output{top:var(--qn-header-height)}.qf-port{position:absolute;display:flex;align-items:center;height:20px;cursor:crosshair;pointer-events:auto;transition:transform .1s}.qf-port-input{left:0;transform:translate(-50%);flex-direction:row;gap:4px}.qf-port-output{right:0;transform:translate(50%);flex-direction:row-reverse;gap:4px}.qf-port-dot{width:var(--qn-port-size);height:var(--qn-port-size);border-radius:50%;border:2px solid currentColor;background:var(--qn-bg-primary);transition:all .15s;flex-shrink:0;box-shadow:0 0 0 2px var(--qn-bg-secondary),0 1px 3px #0000004d}.qf-port:hover .qf-port-dot{transform:scale(1.25);box-shadow:0 0 0 2px var(--qn-bg-secondary),0 0 8px currentColor}.qf-port.connected .qf-port-dot{background:currentColor}.qf-port-label{font-size:9px;color:var(--qn-text-secondary);white-space:nowrap;pointer-events:none;background:var(--qn-bg-secondary);padding:1px 4px;border-radius:2px;max-width:80px;overflow:hidden;text-overflow:ellipsis}.qf-port-input .qf-port-label{margin-left:-2px}.qf-port-output .qf-port-label{margin-right:-2px}.qf-canvas-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:var(--qn-text-secondary);pointer-events:none;z-index:1}.qf-canvas-hint p{font-size:14px;opacity:.7}@keyframes qf-float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.qf-node-library .node-item{cursor:grab}.qf-node-library .node-item:active{cursor:grabbing}@media(max-width:768px){.qf-toolbar{padding:0 8px;gap:8px}.qf-toolbar-btn{padding:6px 10px;font-size:12px}.qf-flow-title{width:150px}}.onboarding-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:999;animation:fadeIn .25s ease-out}.onboarding-modal{background:var(--qn-bg-secondary);border-radius:var(--qn-radius-xl);width:100%;max-width:600px;max-height:88vh;overflow-y:auto;padding:var(--qn-space-xl);position:relative;box-shadow:0 20px 70px #00000080;animation:scaleIn .25s ease-out}.skip-btn{position:absolute;top:16px;right:16px;padding:6px 14px;background:transparent;border:1px solid var(--qn-border);border-radius:var(--qn-radius-xs);color:var(--qn-text-secondary);font-size:var(--qn-text-sm);cursor:pointer;transition:all .15s}.skip-btn:hover{background:var(--qn-bg-hover);color:var(--qn-text-primary)}.step-indicators{display:flex;justify-content:center;gap:10px;margin-bottom:var(--qn-space-lg)}.step-indicator{width:30px;height:30px;border-radius:50%;border:2px solid var(--qn-border);background:transparent;color:var(--qn-text-muted);font-size:var(--qn-text-sm);font-weight:600;cursor:pointer;transition:all .18s;display:flex;align-items:center;justify-content:center}.step-indicator:hover{border-color:var(--qn-accent);color:var(--qn-text-primary)}.step-indicator.active{background:var(--qn-accent);border-color:var(--qn-accent);color:#fff}.step-indicator.completed{background:var(--qn-success);border-color:var(--qn-success);color:#fff}.step-header{text-align:center;margin-bottom:var(--qn-space-lg)}.step-icon{font-size:44px;display:block;margin-bottom:var(--qn-space-sm)}.step-header h2{font-size:var(--qn-text-xl);font-weight:700;color:var(--qn-text-primary);margin:0 0 6px}.step-header p{font-size:var(--qn-text-sm);color:var(--qn-text-secondary);margin:0}.step-content{min-height:260px}.onboarding-welcome .welcome-features{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--qn-space-sm)}.feature-card{background:var(--qn-bg-tertiary);border-radius:var(--qn-radius-md);padding:var(--qn-space-md);text-align:center;transition:all .18s}.feature-card:hover{transform:translateY(-3px);box-shadow:var(--qn-shadow-md)}.feature-icon{font-size:28px;display:block;margin-bottom:var(--qn-space-xs)}.feature-card h4{font-size:var(--qn-text-sm);font-weight:600;color:var(--qn-text-primary);margin:0 0 4px}.feature-card p{font-size:var(--qn-text-xs);color:var(--qn-text-secondary);margin:0}.onboarding-profile{display:flex;flex-direction:column;gap:var(--qn-space-md)}.onboarding-profile .form-group{display:flex;flex-direction:column;gap:8px}.onboarding-profile label{font-size:var(--qn-text-sm);font-weight:500;color:var(--qn-text-primary)}.onboarding-profile input{padding:10px 14px;background:var(--qn-bg-tertiary);border:1px solid var(--qn-border);border-radius:var(--qn-radius-xs);color:var(--qn-text-primary);font-size:var(--qn-text-base)}.onboarding-profile input:focus{outline:none;border-color:var(--qn-accent)}.goal-options{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--qn-space-xs)}.goal-option{display:flex;align-items:center;gap:10px;padding:var(--qn-space-sm);background:var(--qn-bg-tertiary);border:2px solid var(--qn-border);border-radius:var(--qn-radius-xs);cursor:pointer;transition:all .15s}.goal-option:hover{border-color:var(--qn-accent)}.goal-option.selected{border-color:var(--qn-accent);background:#00cec914}.goal-icon{font-size:20px}.goal-label{font-size:var(--qn-text-sm);font-weight:500;color:var(--qn-text-primary)}.onboarding-tour{display:flex;flex-direction:column;gap:var(--qn-space-sm)}.tour-item{display:flex;align-items:center;gap:var(--qn-space-sm);padding:var(--qn-space-sm);background:var(--qn-bg-tertiary);border-radius:var(--qn-radius-xs)}.tour-icon{width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:var(--qn-bg-hover);border-radius:var(--qn-radius-xs);font-size:18px}.tour-content h4{font-size:var(--qn-text-sm);font-weight:600;color:var(--qn-text-primary);margin:0 0 3px}.tour-content p{font-size:var(--qn-text-xs);color:var(--qn-text-secondary);margin:0}.tour-content kbd{background:var(--qn-bg-hover);padding:2px 5px;border-radius:3px;font-size:10px}.tour-content code{background:var(--qn-bg-hover);padding:2px 5px;border-radius:3px;font-family:var(--qn-font-mono);color:var(--qn-accent)}.onboarding-complete{text-align:center;padding:var(--qn-space-lg)}.success-animation{font-size:56px;animation:scaleIn .4s ease-out}.onboarding-complete h3{font-size:var(--qn-text-lg);font-weight:700;color:var(--qn-text-primary);margin:var(--qn-space-sm) 0 var(--qn-space-xs) 0}.onboarding-complete p{font-size:var(--qn-text-sm);color:var(--qn-text-secondary);margin:0}.setup-summary{margin-top:var(--qn-space-md);text-align:left;background:var(--qn-bg-tertiary);padding:var(--qn-space-sm);border-radius:var(--qn-radius-xs)}.setup-summary p{font-size:var(--qn-text-sm);color:var(--qn-text-primary);margin:0;line-height:1.7}.step-actions{display:flex;justify-content:flex-end;gap:var(--qn-space-sm);margin-top:var(--qn-space-lg);padding-top:var(--qn-space-md);border-top:1px solid var(--qn-border)}.back-btn{padding:10px 20px;background:transparent;border:1px solid var(--qn-border);border-radius:var(--qn-radius-xs);color:var(--qn-text-secondary);font-size:var(--qn-text-sm);font-weight:500;cursor:pointer;transition:all .15s}.back-btn:hover{background:var(--qn-bg-hover);color:var(--qn-text-primary)}.next-btn,.complete-btn{padding:10px 28px;background:var(--qn-accent);border:none;border-radius:var(--qn-radius-xs);color:#fff;font-size:var(--qn-text-sm);font-weight:600;cursor:pointer;transition:all .15s}.next-btn:hover,.complete-btn:hover{opacity:.9;transform:translateY(-1px)}@media(max-width:640px){.onboarding-modal{margin:var(--qn-space-xs);padding:var(--qn-space-md)}.onboarding-welcome .welcome-features,.goal-options{grid-template-columns:1fr}}.app-loading{display:flex;align-items:center;justify-content:center;width:100vw;height:100vh;background:var(--qn-bg-base)}.app-loading .loading-spinner{width:40px;height:40px;border:3px solid var(--qn-border);border-top-color:var(--qn-accent);border-radius:50%;animation:spin 1s linear infinite}.app-container{display:flex;height:100vh;width:100vw;overflow:hidden;background:var(--qn-bg-base)}.app-container.zen-mode{background:var(--qn-bg-base)}.main-content{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.content-area{flex:1;display:flex;overflow:hidden;position:relative}@media(max-width:768px){.sidebar-panel{position:absolute;left:56px;top:0;height:100vh;z-index:var(--qn-z-overlay);box-shadow:var(--qn-shadow-xl)}.ai-panel{position:absolute;right:0;top:0;height:100vh;z-index:var(--qn-z-overlay);box-shadow:var(--qn-shadow-xl)}.notes-grid{grid-template-columns:1fr!important}.template-grid{grid-template-columns:repeat(2,1fr)}.command-palette{width:calc(100vw - 32px);margin:0 var(--qn-space-md)}.settings-panel{width:calc(100vw - 10px)!important;max-width:100%!important}.topbar-note-meta{display:none}.editor-content{max-width:100%!important;padding:var(--qn-space-sm)!important}}@media(max-width:640px){.sidebar-rail{width:48px;min-width:48px}.topbar-view-modes,.topbar-center{display:none}.topbar-right{gap:2px}.notes-board{flex-direction:column}.board-column{width:100%;min-width:100%}.editor-toolbar{overflow-x:auto;-webkit-overflow-scrolling:touch}.toolbar-left{overflow-x:auto;flex-wrap:nowrap;min-width:0}.editor-status-bar{flex-wrap:wrap;gap:4px}.status-bar-left .status-pill{font-size:10px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.find-replace-bar{gap:4px;padding:6px var(--qn-space-xs)}.find-row input,.replace-row input{font-size:var(--qn-text-sm)}}@media(max-width:480px){.sidebar{position:fixed;left:0;top:0;height:100vh;z-index:var(--qn-z-overlay)}.sidebar-panel{left:48px}.topbar{padding:0 var(--qn-space-xs);gap:4px}.topbar-btn{width:32px;height:32px}.editor-title{font-size:var(--qn-text-2xl)!important}.editor-textarea{font-size:15px!important}.notes-view-container,.note-card-content{padding:var(--qn-space-xs)}}@media print{.sidebar,.topbar,.ai-panel,.command-palette-overlay,.settings-overlay,.toast-container,.editor-toolbar,.editor-status-bar,.focus-exit-btn{display:none!important}.app-container{height:auto}.main-content{width:100%}.editor-content{max-width:100%!important;padding:0!important}.note-editor{position:static!important}}@keyframes spin{to{transform:rotate(360deg)}}
