.header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-lg);background:var(--bg-primary);border-bottom:1px solid var(--border-color);height:56px;flex-shrink:0}.header-left{flex:1;display:flex;align-items:center}.back-link{color:var(--text-secondary);font-size:14px;transition:color var(--transition-fast)}.back-link:hover{color:var(--primary-color);text-decoration:none}.header-center{flex:2;display:flex;justify-content:center}.title-link,.title-link:hover{text-decoration:none}.title{font-size:20px;font-weight:600;color:var(--text-primary);transition:color var(--transition-fast)}.title-link:hover .title{color:var(--primary-color)}.header-right{flex:1;display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-md)}.algorithm-idea-btn{padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--border-radius);color:var(--text-primary);font-size:14px;transition:all var(--transition-fast)}.algorithm-idea-btn:hover{background:var(--primary-color);color:var(--text-light)}.github-link{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-dark);border-radius:var(--border-radius);color:var(--text-light);font-size:14px;transition:all var(--transition-fast)}.github-link:hover{background:#334155;text-decoration:none}.github-icon{width:20px;height:20px}.star-count{font-weight:500}.data-input{padding:var(--spacing-sm) var(--spacing-lg);background:var(--bg-primary);border-bottom:1px solid var(--border-color);flex-shrink:0}.data-input-row{display:flex;align-items:center;gap:var(--spacing-lg);flex-wrap:wrap}.algorithm-selector{display:flex;align-items:center;gap:var(--spacing-sm)}.algorithm-selector label{font-size:14px;color:var(--text-secondary);white-space:nowrap}.algorithm-tabs{display:flex;background:var(--bg-tertiary);border-radius:var(--border-radius);padding:2px}.algorithm-tab{padding:var(--spacing-xs) var(--spacing-md);font-size:13px;color:var(--text-secondary);border-radius:calc(var(--border-radius) - 2px);transition:all var(--transition-fast);white-space:nowrap}.algorithm-tab:hover{color:var(--text-primary)}.algorithm-tab.active{background:var(--primary-color);color:var(--text-light)}.input-group{display:flex;align-items:center;gap:var(--spacing-sm);flex:1;min-width:300px}.input-group label{font-size:14px;color:var(--text-secondary);white-space:nowrap}.input-group input{flex:1;padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--border-color);border-radius:var(--border-radius);font-size:14px;font-family:var(--font-mono);min-width:200px}.input-group input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #2563eb1a}.input-group input.input-error{border-color:var(--danger-color)}.submit-btn{padding:var(--spacing-xs) var(--spacing-md);background:var(--primary-color);color:var(--text-light);border-radius:var(--border-radius);font-size:14px;transition:background var(--transition-fast)}.submit-btn:hover{background:var(--primary-hover)}.examples-group{display:flex;align-items:center;gap:var(--spacing-xs);flex-wrap:wrap}.examples-label{font-size:14px;color:var(--text-secondary)}.example-btn{padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-tertiary);color:var(--text-secondary);border-radius:var(--border-radius);font-size:13px;transition:all var(--transition-fast)}.example-btn:hover{background:var(--secondary-color);color:var(--text-light)}.random-btn{padding:var(--spacing-xs) var(--spacing-sm);background:var(--accent-color);color:var(--text-light);border-radius:var(--border-radius);font-size:13px;transition:all var(--transition-fast)}.random-btn:hover{background:#d97706}.error-message{margin-top:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:#fef2f2;color:var(--danger-color);border-radius:var(--border-radius);font-size:13px}.code-panel{display:flex;flex-direction:column;background:var(--code-bg);border-radius:var(--border-radius-lg);overflow:hidden;height:100%}.code-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:#0f172a;border-bottom:1px solid #334155}.code-title{color:var(--text-light);font-size:14px;font-weight:500}.language-tabs{display:flex;gap:2px;background:#1e293b;border-radius:var(--border-radius);padding:2px}.language-tab{padding:4px 12px;font-size:12px;color:#94a3b8;border-radius:calc(var(--border-radius) - 2px);transition:all var(--transition-fast)}.language-tab:hover{color:var(--text-light)}.language-tab.active{background:var(--primary-color);color:var(--text-light)}.code-content{flex:1;overflow:auto;padding:var(--spacing-sm) 0}.code-block{margin:0;font-family:var(--font-mono);font-size:13px;line-height:1.6}.code-line{display:flex;align-items:flex-start;padding:0 var(--spacing-md);transition:background var(--transition-fast)}.code-line.highlighted{background:var(--code-line-highlight)}.line-number{flex-shrink:0;width:32px;color:var(--code-line-number);text-align:right;padding-right:var(--spacing-md);-webkit-user-select:none;user-select:none}.line-content{flex:1;color:#e2e8f0;white-space:pre}.variable-display{flex-shrink:0;margin-left:var(--spacing-md);padding:2px 8px;background:#10b98133;color:#10b981;border-radius:4px;font-size:11px;white-space:nowrap}.code-line .keyword{color:#f472b6}.code-line .string{color:#a5d6a7}.code-line .number{color:#fbbf24}.code-line .comment{color:#64748b;font-style:italic}.canvas-container{position:relative;flex:1;background:var(--bg-primary);border-radius:var(--border-radius-lg);overflow:hidden}.canvas-svg{width:100%;height:100%;display:block}.canvas-controls{position:absolute;top:var(--spacing-md);right:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-sm);z-index:10}.canvas-btn{padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius);font-size:12px;color:var(--text-secondary);transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.canvas-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.zoom-level{padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius);font-size:12px;color:var(--text-secondary);box-shadow:var(--shadow-sm)}.canvas-hint{position:absolute;bottom:var(--spacing-md);left:50%;transform:translate(-50%);padding:var(--spacing-xs) var(--spacing-md);background:#0009;color:var(--text-light);border-radius:var(--border-radius);font-size:12px;pointer-events:none}.control-panel{background:var(--bg-primary);border-top:1px solid var(--border-color);padding:var(--spacing-md) var(--spacing-lg);flex-shrink:0}.control-buttons{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md);flex-wrap:wrap}.control-btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--border-radius);color:var(--text-primary);font-size:14px;transition:all var(--transition-fast)}.control-btn:hover:not(:disabled){background:var(--primary-color);color:var(--text-light)}.control-btn:disabled{opacity:.5;cursor:not-allowed}.control-btn kbd{padding:2px 6px;background:#0000001a;border-radius:4px;font-size:11px;font-family:var(--font-mono)}.control-btn:hover:not(:disabled) kbd{background:#fff3}.play-btn{background:var(--secondary-color);color:var(--text-light);min-width:140px;justify-content:center}.play-btn:hover:not(:disabled){background:#059669}.reset-btn{background:var(--accent-color);color:var(--text-light)}.reset-btn:hover:not(:disabled){background:#d97706}.speed-control{position:relative}.speed-btn{padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--border-radius);color:var(--text-primary);font-size:14px;transition:all var(--transition-fast)}.speed-btn:hover{background:var(--bg-dark);color:var(--text-light)}.speed-menu{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:var(--spacing-xs);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--border-radius);box-shadow:var(--shadow-lg);overflow:hidden;z-index:100}.speed-option{display:block;width:100%;padding:var(--spacing-xs) var(--spacing-md);text-align:center;font-size:13px;color:var(--text-primary);transition:all var(--transition-fast)}.speed-option:hover{background:var(--bg-tertiary)}.speed-option.active{background:var(--primary-color);color:var(--text-light)}.step-info{padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border-radius:var(--border-radius);font-size:13px;color:var(--text-secondary);font-family:var(--font-mono)}.progress-bar{position:relative;height:8px;background:var(--bg-tertiary);border-radius:4px;cursor:pointer;overflow:visible}.progress-fill{position:absolute;top:0;left:0;height:100%;background:var(--secondary-color);border-radius:4px;transition:width .1s ease}.progress-handle{position:absolute;top:50%;width:16px;height:16px;background:var(--secondary-color);border:2px solid var(--bg-primary);border-radius:50%;transform:translate(-50%,-50%);box-shadow:var(--shadow-md);cursor:grab;transition:transform .1s ease}.progress-handle:hover{transform:translate(-50%,-50%) scale(1.2)}.progress-bar:active .progress-handle{cursor:grabbing;transform:translate(-50%,-50%) scale(1.3)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-lg)}.modal-content{background:var(--bg-primary);border-radius:var(--border-radius-lg);max-width:800px;max-height:90vh;width:100%;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--border-color)}.modal-header h2{font-size:18px;font-weight:600;color:var(--text-primary)}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:24px;color:var(--text-secondary);border-radius:var(--border-radius);transition:all var(--transition-fast)}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-body{flex:1;overflow-y:auto;padding:var(--spacing-lg)}.idea-section{margin-bottom:var(--spacing-lg)}.idea-section:last-child{margin-bottom:0}.idea-section h3{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.idea-section p{color:var(--text-secondary);line-height:1.7;margin-bottom:var(--spacing-sm)}.idea-content{background:var(--bg-secondary);border-radius:var(--border-radius);padding:var(--spacing-md)}.idea-content ul{margin:var(--spacing-sm) 0;padding-left:var(--spacing-lg)}.idea-content li{color:var(--text-secondary);line-height:1.7;margin-bottom:var(--spacing-xs)}.idea-content code{display:block;background:var(--code-bg);color:#e2e8f0;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--border-radius);font-family:var(--font-mono);font-size:13px;margin-top:var(--spacing-sm)}.complexity-table{width:100%;border-collapse:collapse;margin-top:var(--spacing-sm)}.complexity-table th,.complexity-table td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;border:1px solid var(--border-color)}.complexity-table th{background:var(--bg-tertiary);font-weight:600;color:var(--text-primary)}.complexity-table td{color:var(--text-secondary)}.wechat-float{position:fixed;bottom:var(--spacing-lg);right:var(--spacing-lg);z-index:100}.wechat-button{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:#07c160;color:#fff;border-radius:24px;box-shadow:var(--shadow-lg);cursor:pointer;transition:all var(--transition-fast)}.wechat-button:hover{background:#06ad56;transform:scale(1.05)}.wechat-icon{width:24px;height:24px}.wechat-text{font-size:14px;font-weight:500}.wechat-popup{position:absolute;bottom:100%;right:0;margin-bottom:var(--spacing-md);background:var(--bg-primary);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.popup-arrow{position:absolute;bottom:-8px;right:24px;width:16px;height:16px;background:var(--bg-primary);transform:rotate(45deg);box-shadow:2px 2px 4px #0000001a}.popup-content{position:relative;padding:var(--spacing-md);text-align:center;background:var(--bg-primary)}.popup-title{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-sm)}.qrcode-image{width:200px;height:auto;border-radius:var(--border-radius);margin-bottom:var(--spacing-sm)}.popup-hint{font-size:12px;color:var(--text-secondary)}:root{--primary-color: #2563eb;--primary-hover: #1d4ed8;--secondary-color: #10b981;--accent-color: #f59e0b;--danger-color: #ef4444;--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--bg-dark: #1e293b;--text-primary: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--text-light: #ffffff;--border-color: #e2e8f0;--border-radius: 8px;--border-radius-lg: 12px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--font-mono: "Fira Code", "Consolas", "Monaco", monospace;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--highlight-current: #fef3c7;--highlight-compare: #dbeafe;--highlight-update: #d1fae5;--highlight-result: #10b981;--code-bg: #1e293b;--code-line-highlight: rgba(37, 99, 235, .2);--code-line-number: #64748b}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:var(--font-sans);background-color:var(--bg-secondary);color:var(--text-primary);line-height:1.5}button{cursor:pointer;border:none;background:none;font-family:inherit;font-size:inherit}input,select{font-family:inherit;font-size:inherit}a{color:var(--primary-color);text-decoration:none}a:hover{text-decoration:underline}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:6px 12px;background:var(--bg-dark);color:var(--text-light);font-size:12px;border-radius:var(--border-radius);white-space:nowrap;opacity:0;visibility:hidden;transition:var(--transition-fast);z-index:1000}[data-tooltip]:hover:after{opacity:1;visibility:visible}.app{display:flex;flex-direction:column;height:100vh;width:100vw;overflow:hidden}.main-content{flex:1;display:flex;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);min-height:0;overflow:hidden}.left-panel{width:400px;flex-shrink:0;display:flex;flex-direction:column}.right-panel{flex:1;display:flex;flex-direction:column;min-width:0}@media(max-width:1200px){.main-content{flex-direction:column}.left-panel{width:100%;height:300px}.right-panel{flex:1}}
