:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:linear-gradient(135deg,#1a1a2e,#16213e);border-bottom:1px solid #0f3460;height:48px;box-sizing:border-box}.header-left{flex:1;display:flex;align-items:center}.header-center{flex:2;display:flex;justify-content:center;align-items:center}.header-right{flex:1;display:flex;align-items:center;justify-content:flex-end;gap:12px}.back-link{color:#94a3b8;text-decoration:none;font-size:13px;transition:color .2s;white-space:nowrap}.back-link:hover{color:#e94560}.title-link{text-decoration:none}.title{color:#fff;font-size:18px;font-weight:600;margin:0;transition:color .2s;white-space:nowrap}.title-link:hover .title{color:#e94560}.algorithm-idea-btn{background:transparent;border:1px solid #0f3460;color:#94a3b8;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:13px;transition:all .2s;white-space:nowrap}.algorithm-idea-btn:hover{background:#0f3460;color:#fff;border-color:#e94560}.github-link{display:flex;align-items:center;gap:6px;color:#94a3b8;text-decoration:none;transition:color .2s}.github-link:hover{color:#fff}.github-icon{width:22px;height:22px}.star-count{display:flex;align-items:center;gap:3px;font-size:13px;background:#0f3460;padding:3px 8px;border-radius:10px}.star-icon{color:#fbbf24}.modal-overlay{position:fixed;inset:0;background:#000000b3;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:#1a1a2e;border-radius:12px;width:90%;max-width:600px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;border:1px solid #0f3460;animation:slideIn .2s ease}@keyframes slideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #0f3460;background:#16213e}.modal-header h2{margin:0;font-size:18px;color:#fff}.modal-close{background:transparent;border:none;color:#94a3b8;font-size:24px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.modal-close:hover{background:#0f3460;color:#e94560}.modal-body{padding:20px;overflow-y:auto;color:#e2e8f0;line-height:1.6}.idea-section{margin-bottom:20px}.idea-section:last-child{margin-bottom:0}.idea-section h3{color:#e94560;font-size:16px;margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid #0f3460}.idea-section p{margin:0 0 8px;color:#cbd5e1}.idea-section strong{color:#22d3ee}.flow-item{background:#16213e;padding:12px 16px;border-radius:8px;margin-bottom:12px;border-left:3px solid #e94560}.flow-item:last-child{margin-bottom:0}.flow-item h4{color:#fbbf24;font-size:14px;margin:0 0 8px}.flow-item p{margin:0;font-size:14px}.idea-section ul{margin:0;padding-left:20px}.idea-section li{margin-bottom:8px;color:#cbd5e1}.idea-section li:last-child{margin-bottom:0}.reference{background:#16213e;padding:12px 16px;border-radius:8px}.reference h3{border-bottom:none;padding-bottom:0;margin-bottom:8px}.reference a{color:#22d3ee;text-decoration:none}.reference a:hover{text-decoration:underline}.input-panel{padding:8px 16px;background:#16213e;border-bottom:1px solid #0f3460}.input-row{display:flex;gap:12px;align-items:flex-start}.input-group{flex:1;display:flex;flex-direction:column;gap:4px}.input-label{color:#94a3b8;font-size:12px;font-weight:500}.input-textarea{background:#1a1a2e;border:1px solid #0f3460;border-radius:6px;color:#e2e8f0;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:12px;padding:8px 12px;resize:none;outline:none;transition:border-color .2s;line-height:1.4}.input-textarea:focus{border-color:#e94560}.input-textarea::placeholder{color:#475569}.input-error{color:#ef4444;font-size:12px;padding:4px 0}.input-actions{display:flex;flex-direction:column;gap:6px;padding-top:18px}.submit-btn,.random-btn{padding:8px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.submit-btn{background:#e94560;border:none;color:#fff}.submit-btn:hover{background:#d63d56}.random-btn{background:transparent;border:1px solid #0f3460;color:#94a3b8}.random-btn:hover{background:#0f3460;color:#fff}.preset-row{display:flex;align-items:center;gap:8px;margin-top:8px}.preset-label{color:#64748b;font-size:12px;white-space:nowrap}.preset-buttons{display:flex;gap:8px;flex-wrap:wrap}.preset-btn{background:#1a1a2e;border:1px solid #0f3460;color:#94a3b8;padding:4px 10px;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s}.preset-btn:hover{background:#0f3460;color:#22d3ee;border-color:#22d3ee}.code-panel{display:flex;flex-direction:column;height:100%;background:#1e1e1e;border-radius:8px;overflow:hidden;font-family:Consolas,Monaco,Courier New,monospace}.code-tabs{display:flex;background:#252526;border-bottom:1px solid #3c3c3c;padding:0}.code-tab{padding:8px 16px;background:transparent;border:none;color:gray;cursor:pointer;font-size:13px;font-family:inherit;transition:all .2s ease;border-bottom:2px solid transparent}.code-tab:hover{color:#ccc;background:#2d2d2d}.code-tab.active{color:#fff;background:#1e1e1e;border-bottom-color:#007acc}.code-container{display:flex;flex:1;overflow:auto;position:relative}.line-numbers{display:flex;flex-direction:column;padding:12px 0;background:#1e1e1e;border-right:1px solid #3c3c3c;-webkit-user-select:none;user-select:none;min-width:40px}.line-number{padding:0 12px;text-align:right;color:#858585;font-size:13px;line-height:20px;height:20px;transition:all .15s ease}.line-number.highlighted{color:#fff;background:#ffd50026}.code-content{flex:1;position:relative;overflow:auto}.code-pre{margin:0;padding:12px 16px;background:transparent;font-size:13px;line-height:20px;white-space:pre;overflow:visible}.code-pre code{font-family:Consolas,Monaco,Courier New,monospace;background:transparent}.highlight-overlay{position:absolute;top:12px;left:0;right:0;pointer-events:none}.highlight-line{height:20px;line-height:20px;display:flex;align-items:center;padding-left:16px;transition:background-color .15s ease}.highlight-line.active{background:#ffd50026;border-left:3px solid #ffd500;margin-left:-3px}.variables-panel{background:#252526;border-top:1px solid #3c3c3c;padding:8px 12px;animation:fadeIn .2s ease}.variables-title{font-size:11px;color:gray;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.variables-list{display:flex;flex-wrap:wrap;gap:8px 16px}.variable-item{display:flex;align-items:center;gap:4px;font-size:12px;font-family:Consolas,Monaco,Courier New,monospace}.variable-name{color:#9cdcfe}.variable-equals{color:#d4d4d4}.variable-value{color:#7ee787}@keyframes fadeIn{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.code-panel code[class*=language-],.code-panel pre[class*=language-]{color:#d4d4d4;background:none;text-shadow:none;font-family:Consolas,Monaco,Courier New,monospace;font-size:13px;text-align:left;white-space:pre;word-spacing:normal;word-break:normal;word-wrap:normal;line-height:20px;tab-size:4;-webkit-hyphens:none;hyphens:none}.code-panel .token.keyword{color:#569cd6}.code-panel .token.string{color:#ce9178}.code-panel .token.number{color:#b5cea8}.code-panel .token.comment{color:#6a9955;font-style:italic}.code-panel .token.function{color:#dcdcaa}.code-panel .token.class-name{color:#4ec9b0}.code-panel .token.operator,.code-panel .token.punctuation{color:#d4d4d4}.code-panel .token.boolean{color:#569cd6}.code-panel .token.builtin{color:#4ec9b0}.code-panel .token.keyword.self,.code-panel .token.keyword.this{color:#569cd6}.code-panel .token.annotation{color:#4ec9b0}.code-container::-webkit-scrollbar{width:10px;height:10px}.code-container::-webkit-scrollbar-track{background:#1e1e1e}.code-container::-webkit-scrollbar-thumb{background:#424242;border-radius:5px}.code-container::-webkit-scrollbar-thumb:hover{background:#4f4f4f}.code-container::-webkit-scrollbar-corner{background:#1e1e1e}.canvas-wrapper{position:relative;width:100%;height:100%;background:#161b22;border-radius:8px;overflow:hidden}.canvas-svg{display:block;cursor:grab}.canvas-svg:active{cursor:grabbing}.canvas-controls{position:absolute;top:12px;right:12px;display:flex;gap:8px}.canvas-control-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#21262de6;border:1px solid #30363d;border-radius:6px;color:#8b949e;cursor:pointer;transition:all .2s ease}.canvas-control-btn:hover{background:#30363d;color:#c9d1d9;border-color:#8b949e}.canvas-hint{position:absolute;bottom:12px;right:12px;font-size:12px;color:#484f58;background:#161b22cc;padding:4px 8px;border-radius:4px}.canvas-step-info{position:absolute;top:12px;left:12px;max-width:400px;background:#21262df2;border:1px solid #30363d;border-radius:8px;padding:12px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.step-badge{display:inline-block;font-size:12px;font-weight:600;color:#58a6ff;background:#58a6ff1a;padding:2px 8px;border-radius:4px;margin-bottom:8px}.step-desc{font-size:14px;color:#c9d1d9;line-height:1.5}.control-panel-container{display:flex;flex-direction:column;gap:12px;padding:12px 16px;background:#161b22;border-radius:8px;border:1px solid #30363d}.control-buttons{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}.control-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#21262d;border:1px solid #30363d;border-radius:6px;color:#c9d1d9;cursor:pointer;font-size:13px;transition:all .2s ease;white-space:nowrap}.control-btn:hover:not(:disabled){background:#30363d;border-color:#8b949e}.control-btn:active:not(:disabled){transform:scale(.98)}.control-btn:disabled{opacity:.4;cursor:not-allowed}.btn-icon{font-size:14px}.btn-text{font-weight:500}.btn-shortcut{font-size:11px;padding:2px 5px;background:#0d1117;border-radius:3px;color:#8b949e;font-family:Consolas,Monaco,monospace}.play-btn{background:#238636;border-color:#238636}.play-btn:hover:not(:disabled){background:#2ea043;border-color:#2ea043}.reset-btn{background:#21262d}.reset-btn:hover:not(:disabled){background:#da3633;border-color:#da3633}.speed-control{position:relative}.speed-btn{display:flex;align-items:center;gap:4px;padding:8px 12px;background:#21262d;border:1px solid #30363d;border-radius:6px;color:#c9d1d9;cursor:pointer;font-size:13px;transition:all .2s ease}.speed-btn:hover{background:#30363d;border-color:#8b949e}.speed-value{font-weight:600;color:#58a6ff;min-width:32px;text-align:center}.speed-arrow{font-size:10px;color:#8b949e}.speed-menu{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:8px;background:#21262d;border:1px solid #30363d;border-radius:6px;padding:4px;display:flex;flex-direction:column;gap:2px;z-index:100;box-shadow:0 8px 24px #0006}.speed-option{padding:6px 16px;background:transparent;border:none;border-radius:4px;color:#c9d1d9;cursor:pointer;font-size:13px;text-align:center;transition:all .15s ease}.speed-option:hover{background:#30363d}.speed-option.active{background:#238636;color:#fff}.step-counter{display:flex;align-items:center;gap:2px;padding:8px 12px;background:#0d1117;border-radius:6px;font-family:Consolas,Monaco,monospace;font-size:14px}.current-step{color:#58a6ff;font-weight:600}.step-separator{color:#484f58}.total-steps{color:#8b949e}.progress-bar{position:relative;height:8px;background:#21262d;border-radius:4px;cursor:pointer;overflow:visible}.progress-bar:hover,.progress-bar.dragging{height:10px}.progress-fill{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,#238636,#2ea043);border-radius:4px;transition:width .1s ease}.progress-bar.dragging .progress-fill{transition:none}.progress-thumb{position:absolute;top:50%;width:16px;height:16px;background:#fff;border:2px solid #238636;border-radius:50%;transform:translate(-50%,-50%);transition:transform .1s ease,box-shadow .2s ease;box-shadow:0 2px 8px #0000004d;z-index:2}.progress-bar:hover .progress-thumb,.progress-bar.dragging .progress-thumb{transform:translate(-50%,-50%) scale(1.2);box-shadow:0 2px 12px #23863680}.progress-bar.dragging .progress-thumb{transition:none}.progress-ticks{position:absolute;top:0;left:0;right:0;height:100%;pointer-events:none}.progress-tick{position:absolute;top:50%;width:4px;height:4px;background:#484f58;border-radius:50%;transform:translate(-50%,-50%);transition:background .2s ease}.progress-tick.passed{background:#7ee787}@media(max-width:768px){.control-buttons{gap:6px}.control-btn{padding:6px 10px;font-size:12px}.btn-text{display:none}.btn-shortcut{font-size:10px;padding:1px 4px}.step-counter{padding:6px 10px;font-size:12px}}.floating-ball-container{position:fixed;bottom:24px;right:24px;z-index:1000}.floating-ball{display:flex;flex-direction:column;align-items:center;justify-content:center;width:60px;height:60px;background:linear-gradient(135deg,#07c160,#06ad56);border-radius:50%;cursor:pointer;box-shadow:0 4px 12px #07c16066;transition:all .3s ease}.floating-ball:hover{transform:scale(1.1);box-shadow:0 6px 16px #07c16080}.wechat-group-icon{width:24px;height:24px;color:#fff}.ball-text{font-size:10px;color:#fff;margin-top:2px;font-weight:500}.qrcode-popup{position:absolute;bottom:70px;right:0;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;padding:16px;animation:fadeIn .2s ease}.qrcode-popup:after{content:"";position:absolute;bottom:-8px;right:20px;width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-top:8px solid white}.qrcode-content{display:flex;flex-direction:column;align-items:center}.qrcode-image{width:200px;height:auto;border-radius:8px}.qrcode-tip{margin-top:12px;font-size:13px;color:#333;text-align:center;line-height:1.5}.qrcode-tip strong{color:#07c160}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;overflow:hidden}.app{display:flex;flex-direction:column;height:100vh;background:#0d1117;color:#c9d1d9;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif}.main-content{flex:1;display:flex;flex-direction:column;padding:12px 16px;gap:12px;overflow:hidden}.visualization-area{flex:1;display:flex;gap:16px;min-height:0}.canvas-container{flex:1;background:#161b22;border-radius:8px;border:1px solid #30363d;display:flex;align-items:center;justify-content:center;overflow:hidden}.canvas-placeholder{text-align:center;padding:20px}.placeholder-text{color:#8b949e;font-size:16px}.step-info{text-align:left}.step-counter{font-size:14px;color:#58a6ff;margin-bottom:8px}.step-description{font-size:16px;color:#c9d1d9;margin-bottom:16px;line-height:1.5}.stack-display{display:flex;flex-direction:column;gap:8px}.stack-item{display:flex;gap:8px;font-family:Consolas,Monaco,monospace}.stack-label{color:#8b949e;min-width:60px}.stack-value{color:#7ee787}.code-container{width:400px;min-width:350px;max-width:450px;display:flex;flex-direction:column}
