*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #2563eb;--primary-hover: #1d4ed8;--success-color: #10b981;--warning-color: #f59e0b;--error-color: #ef4444;--bg-color: #f8fafc;--card-bg: #ffffff;--text-primary: #1e293b;--text-secondary: #64748b;--border-color: #e2e8f0;--highlight-i: #3b82f6;--highlight-left: #10b981;--highlight-right: #f59e0b;--highlight-found: #ec4899;--highlight-skip: #94a3b8}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:var(--bg-color);color:var(--text-primary);line-height:1.5}button{cursor:pointer;border:none;outline:none;font-family:inherit}input,select{font-family:inherit;outline:none}a{text-decoration:none;color:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:var(--card-bg);border-bottom:1px solid var(--border-color);height:48px;flex-shrink:0}.header-left{flex:1}.back-link{color:var(--primary-color);font-size:13px;transition:color .2s}.back-link:hover{color:var(--primary-hover)}.header-center{flex:2;text-align:center}.title-link{display:inline-block}.title{font-size:18px;font-weight:600;color:var(--text-primary);transition:color .2s}.title-link:hover .title{color:var(--primary-color)}.header-right{flex:1;display:flex;align-items:center;justify-content:flex-end;gap:12px}.algorithm-idea-btn{padding:6px 12px;background:var(--primary-color);color:#fff;border-radius:6px;font-size:13px;font-weight:500;transition:background .2s}.algorithm-idea-btn:hover{background:var(--primary-hover)}.github-link{display:flex;align-items:center;gap:6px;padding:6px 10px;background:#24292e;color:#fff;border-radius:6px;font-size:13px;transition:background .2s}.github-link:hover{background:#1b1f23}.github-icon{width:18px;height:18px}.star-count{font-weight:500}.data-input{padding:8px 16px;background:var(--card-bg);border-bottom:1px solid var(--border-color);flex-shrink:0}.input-row{display:flex;align-items:center;gap:8px}.input-label{font-size:13px;font-weight:500;color:var(--text-secondary);white-space:nowrap}.input-field{flex:1;max-width:400px;padding:6px 10px;border:1px solid var(--border-color);border-radius:6px;font-size:13px;transition:border-color .2s}.input-field:focus{border-color:var(--primary-color)}.input-field.input-error{border-color:var(--error-color)}.apply-btn{padding:6px 14px;background:var(--primary-color);color:#fff;border-radius:6px;font-size:13px;font-weight:500;transition:background .2s}.apply-btn:hover{background:var(--primary-hover)}.random-btn{padding:6px 14px;background:var(--success-color);color:#fff;border-radius:6px;font-size:13px;font-weight:500;transition:background .2s}.random-btn:hover{background:#059669}.error-message{margin-top:4px;font-size:12px;color:var(--error-color)}.examples-row{display:flex;align-items:center;gap:6px;margin-top:6px}.examples-label{font-size:12px;color:var(--text-secondary)}.example-btn{padding:3px 10px;background:#f1f5f9;color:var(--text-secondary);border-radius:4px;font-size:12px;transition:all .2s}.example-btn:hover{background:#e2e8f0;color:var(--text-primary)}.example-btn.active{background:var(--primary-color);color:#fff}.code-panel{display:flex;flex-direction:column;background:var(--card-bg);border-radius:8px;border:1px solid var(--border-color);overflow:hidden;height:100%}.code-header{padding:8px 12px;border-bottom:1px solid var(--border-color);background:#f8fafc}.language-tabs{display:flex;gap:4px}.language-tab{padding:4px 12px;background:transparent;color:var(--text-secondary);border-radius:4px;font-size:12px;font-weight:500;transition:all .2s}.language-tab:hover{background:#e2e8f0;color:var(--text-primary)}.language-tab.active{background:var(--primary-color);color:#fff}.code-container{flex:1;overflow:auto;padding:8px 0}.code-pre{margin:0;font-family:Fira Code,Monaco,Consolas,monospace;font-size:12px;line-height:1.6}.code-line{display:flex;align-items:flex-start;padding:0 12px;min-height:20px;transition:background .2s}.code-line.highlighted{background:#fef3c7;border-left:3px solid var(--warning-color);padding-left:9px}.line-number{width:32px;text-align:right;padding-right:12px;color:#94a3b8;-webkit-user-select:none;user-select:none;flex-shrink:0}.line-content{flex:1;white-space:pre}.line-variables{display:flex;gap:8px;margin-left:16px;flex-shrink:0}.variable{padding:1px 6px;background:#e0f2fe;color:#0369a1;border-radius:3px;font-size:11px;white-space:nowrap}.variable.highlight{background:#fce7f3;color:#be185d}.canvas-container{flex:1;position:relative;background:var(--card-bg);border-radius:8px;border:1px solid var(--border-color);overflow:hidden}.canvas-container svg{display:block;cursor:grab}.canvas-container svg:active{cursor:grabbing}.canvas-hint{position:absolute;bottom:8px;right:12px;font-size:11px;color:var(--text-secondary);background:#ffffffe6;padding:2px 8px;border-radius:4px}.array-cell{fill:#f1f5f9;stroke:#e2e8f0;stroke-width:1;transition:all .3s ease}.array-cell.i{fill:#dbeafe;stroke:var(--highlight-i);stroke-width:2}.array-cell.left{fill:#d1fae5;stroke:var(--highlight-left);stroke-width:2}.array-cell.right{fill:#fef3c7;stroke:var(--highlight-right);stroke-width:2}.array-cell.found{fill:#fce7f3;stroke:var(--highlight-found);stroke-width:2}.array-cell.skip{fill:#f1f5f9;stroke:var(--highlight-skip);stroke-width:2;opacity:.6}.cell-value{font-size:14px;font-weight:600;fill:var(--text-primary);text-anchor:middle;dominant-baseline:middle}.cell-index{font-size:10px;fill:var(--text-secondary);text-anchor:middle}.section-title{font-size:12px;font-weight:600;fill:var(--text-secondary)}.var-name{font-size:12px;fill:var(--text-secondary)}.var-value{font-size:12px;font-family:Fira Code,monospace;fill:var(--text-primary)}.var-name.highlight,.var-value.highlight{fill:var(--highlight-found);font-weight:600}.result-cell{fill:#ecfdf5;stroke:var(--success-color);stroke-width:1}.result-value{font-size:12px;font-weight:600;fill:#047857;text-anchor:middle}.step-description{font-size:13px;fill:var(--text-primary);font-weight:500}.controls{background:var(--card-bg);border-top:1px solid var(--border-color);padding:12px 16px;flex-shrink:0}.controls-main{display:flex;align-items:center;gap:8px;margin-bottom:10px}.control-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:#f1f5f9;color:var(--text-primary);border-radius:6px;font-size:13px;font-weight:500;transition:all .2s}.control-btn:hover:not(:disabled){background:#e2e8f0}.control-btn:disabled{opacity:.5;cursor:not-allowed}.control-btn kbd{padding:2px 5px;background:#e2e8f0;border-radius:3px;font-size:10px;font-family:inherit}.play-btn{background:var(--primary-color);color:#fff}.play-btn:hover{background:var(--primary-hover)}.play-btn kbd{background:#fff3;color:#fff}.reset-btn{background:#fef3c7;color:#92400e}.reset-btn:hover,.reset-btn kbd{background:#fde68a}.speed-control{position:relative;margin-left:auto}.speed-btn{padding:8px 14px;background:#f1f5f9;color:var(--text-primary);border-radius:6px;font-size:13px;font-weight:500;transition:all .2s}.speed-btn:hover{background:#e2e8f0}.speed-menu{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:4px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:6px;box-shadow:0 4px 12px #0000001a;overflow:hidden;z-index:100}.speed-option{display:block;width:100%;padding:8px 20px;background:transparent;color:var(--text-primary);font-size:13px;text-align:center;transition:background .2s}.speed-option:hover{background:#f1f5f9}.speed-option.active{background:var(--primary-color);color:#fff}.step-info{font-size:13px;color:var(--text-secondary);margin-left:12px}.progress-bar{cursor:pointer;padding:4px 0}.progress-track{position:relative;height:6px;background:#e2e8f0;border-radius:3px}.progress-fill{position:absolute;left:0;top:0;height:100%;background:var(--success-color);border-radius:3px;transition:width .1s ease}.progress-thumb{position:absolute;top:50%;transform:translate(-50%,-50%);width:14px;height:14px;background:var(--success-color);border:2px solid white;border-radius:50%;box-shadow:0 2px 4px #0003;transition:left .1s ease}.progress-bar:hover .progress-thumb{transform:translate(-50%,-50%) scale(1.2)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--card-bg);border-radius:12px;box-shadow:0 20px 40px #0003;max-width:600px;width:90%;max-height:80vh;display:flex;flex-direction:column;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color)}.modal-title{font-size:18px;font-weight:600;color:var(--text-primary)}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;color:var(--text-secondary);font-size:24px;border-radius:6px;transition:all .2s}.modal-close:hover{background:#f1f5f9;color:var(--text-primary)}.modal-body{padding:20px;overflow-y:auto;line-height:1.7;color:var(--text-primary)}.modal-body h3{font-size:15px;font-weight:600;margin:16px 0 8px;color:var(--primary-color)}.modal-body h3:first-child{margin-top:0}.modal-body p{margin:8px 0;font-size:14px}.modal-body ul{margin:8px 0;padding-left:20px}.modal-body li{margin:4px 0;font-size:14px}.modal-body code{background:#f1f5f9;padding:2px 6px;border-radius:4px;font-family:Fira Code,monospace;font-size:13px}.floating-ball-container{position:fixed;bottom:24px;right:24px;z-index:900}.floating-ball{display:flex;flex-direction:column;align-items:center;justify-content:center;width:60px;height:60px;background:#07c160;border-radius:50%;box-shadow:0 4px 12px #07c16066;cursor:pointer;transition:all .3s ease}.floating-ball:hover{transform:scale(1.1);box-shadow:0 6px 16px #07c16080}.wechat-icon{width:24px;height:24px;color:#fff}.ball-text{font-size:10px;color:#fff;margin-top:2px;font-weight:500}.qr-popup{position:absolute;bottom:70px;right:0;animation:popIn .3s ease}@keyframes popIn{0%{opacity:0;transform:translateY(10px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.qr-content{background:#fff;border-radius:12px;padding:16px;box-shadow:0 8px 24px #00000026;text-align:center}.qr-image{width:200px;height:auto;border-radius:8px}.qr-hint{margin-top:12px;font-size:12px;color:var(--text-secondary);max-width:200px}.app{display:flex;flex-direction:column;height:100vh;width:100vw;overflow:hidden}.main-content{flex:1;display:flex;gap:12px;padding:12px 16px;min-height:0;overflow:hidden}.code-section{width:456px;flex-shrink:0;display:flex;flex-direction:column}.canvas-section{flex:1;display:flex;flex-direction:column;min-width:0}
