*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-success: #22c55e;--color-success-light: #4ade80;--color-warning: #f59e0b;--color-warning-light: #fbbf24;--color-error: #ef4444;--color-error-light: #f87171;--color-accent-blue: #60a5fa;--color-accent-pink: #f472b6;--color-accent-green: #4ade80;--color-accent-yellow: #fcd34d;--color-bg-primary: #0d1117;--color-bg-secondary: #1a1a2e;--color-bg-tertiary: #16213e;--color-border: #0f3460;--color-border-hover: #1e4976;--color-text-primary: #f1f5f9;--color-text-secondary: #94a3b8;--color-text-muted: #64748b;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: "Consolas", "Monaco", "Courier New", monospace}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--color-bg-primary);color:var(--color-text-primary);line-height:1.5;overflow:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-border-hover)}::selection{background:var(--color-primary);color:#fff}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}button{font-family:inherit;cursor:pointer}a{color:inherit;text-decoration:none}code{font-family:var(--font-mono)}.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:#60a5fa}.title-link{text-decoration:none}.title{color:#f1f5f9;font-size:18px;font-weight:600;margin:0;white-space:nowrap;transition:color .2s}.title-link:hover .title{color:#60a5fa}.algorithm-idea-btn{background:#0f3460;color:#f1f5f9;border:1px solid #1e4976;padding:6px 12px;border-radius:6px;font-size:13px;cursor:pointer;transition:all .2s;white-space:nowrap}.algorithm-idea-btn:hover{background:#1e4976;border-color:#2563eb}.github-link{display:flex;align-items:center;gap:6px;color:#f1f5f9;text-decoration:none;padding:6px 10px;border-radius:6px;background:#0f3460;border:1px solid #1e4976;transition:all .2s}.github-link:hover{background:#1e4976;border-color:#2563eb}.github-icon{width:20px;height:20px}.star-count{display:flex;align-items:center;gap:4px;font-size:13px;color:#fbbf24}.star-icon{width:14px;height:14px;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-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#1a1a2e;border-radius:12px;max-width:600px;width:90%;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;border:1px solid #0f3460;animation:slideIn .2s ease-out}@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-title{margin:0;font-size:18px;font-weight:600;color:#f1f5f9}.modal-close{background:none;border:none;font-size:28px;color:#94a3b8;cursor:pointer;padding:0;line-height:1;transition:color .2s}.modal-close:hover{color:#f1f5f9}.modal-body{padding:20px;overflow-y:auto;color:#e2e8f0;line-height:1.6}.algorithm-idea{font-size:14px}.idea-section{margin-bottom:20px}.idea-section:last-child{margin-bottom:0}.idea-section h3{color:#60a5fa;font-size:16px;margin:0 0 10px;padding-bottom:6px;border-bottom:1px solid #0f3460}.idea-section p{margin:8px 0}.idea-section code{background:#0f3460;padding:2px 6px;border-radius:4px;font-family:Consolas,Monaco,monospace;font-size:13px;color:#fbbf24}.idea-section ul,.idea-section ol{margin:8px 0;padding-left:20px}.idea-section li{margin:6px 0}.idea-section li ul{margin:4px 0}.formula{background:#0f3460;padding:12px 16px;border-radius:8px;font-family:Consolas,Monaco,monospace;font-size:16px;text-align:center;color:#4ade80;margin:12px 0}.example-table{overflow-x:auto;margin:12px 0}.example-table table{width:100%;border-collapse:collapse;font-family:Consolas,Monaco,monospace;font-size:13px}.example-table th,.example-table td{padding:8px 12px;text-align:center;border:1px solid #0f3460}.example-table th{background:#16213e;color:#94a3b8;font-weight:500}.example-table td{background:#1a1a2e}.example-table td:first-child{background:#16213e;color:#94a3b8;font-weight:500;text-align:left}.result-row td{background:#0f3460!important;color:#4ade80;font-weight:600}.result-row td:first-child{color:#4ade80!important}.data-input{padding:8px 16px;background:#16213e;border-bottom:1px solid #0f3460}.input-row{display:flex;align-items:center;gap:10px}.input-label{color:#94a3b8;font-size:13px;white-space:nowrap}.input-field{flex:1;max-width:300px;padding:6px 12px;background:#1a1a2e;border:1px solid #0f3460;border-radius:6px;color:#f1f5f9;font-size:13px;font-family:Consolas,Monaco,monospace;outline:none;transition:border-color .2s}.input-field:focus{border-color:#2563eb}.input-field.input-error{border-color:#ef4444}.input-field::placeholder{color:#64748b}.submit-btn,.random-btn{padding:6px 14px;border-radius:6px;font-size:13px;cursor:pointer;transition:all .2s;white-space:nowrap}.submit-btn{background:#2563eb;color:#fff;border:none}.submit-btn:hover{background:#1d4ed8}.random-btn{background:#0f3460;color:#f1f5f9;border:1px solid #1e4976}.random-btn:hover{background:#1e4976;border-color:#2563eb}.error-message{margin-top:6px;padding:6px 12px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:6px;color:#f87171;font-size:12px}.preset-row{display:flex;align-items:center;gap:10px;margin-top:8px}.preset-label{color:#94a3b8;font-size:13px;white-space:nowrap}.preset-buttons{display:flex;gap:8px;flex-wrap:wrap}.preset-btn{padding:4px 10px;background:#1a1a2e;border:1px solid #0f3460;border-radius:4px;color:#94a3b8;font-size:12px;font-family:Consolas,Monaco,monospace;cursor:pointer;transition:all .2s}.preset-btn:hover{border-color:#2563eb;color:#f1f5f9}.preset-btn.active{background:#0f3460;border-color:#2563eb;color:#60a5fa}.code-viewer{display:flex;flex-direction:column;background:#1a1a2e;border-radius:8px;border:1px solid #0f3460;overflow:hidden;height:100%}.code-tabs{display:flex;background:#16213e;border-bottom:1px solid #0f3460;padding:0 8px}.code-tab{padding:8px 16px;background:none;border:none;color:#94a3b8;font-size:12px;cursor:pointer;transition:all .2s;border-bottom:2px solid transparent;margin-bottom:-1px}.code-tab:hover{color:#f1f5f9}.code-tab.active{color:#60a5fa;border-bottom-color:#2563eb}.code-container{display:flex;flex:1;overflow:auto;position:relative}.line-numbers{display:flex;flex-direction:column;padding:12px 0;background:#16213e;border-right:1px solid #0f3460;-webkit-user-select:none;user-select:none;position:sticky;left:0;z-index:1}.line-number{padding:0 12px;font-family:Consolas,Monaco,monospace;font-size:12px;line-height:20px;color:#64748b;text-align:right;min-width:32px}.line-number.highlighted{color:#fbbf24;font-weight:600}.code-content{flex:1;position:relative;overflow:visible}.code-pre{margin:0;padding:12px 16px;background:transparent!important;font-size:12px;line-height:20px}.code-pre code{font-family:Consolas,Monaco,monospace!important;background:transparent!important;text-shadow:none!important}.code-pre .token.comment,.code-pre .token.prolog,.code-pre .token.doctype,.code-pre .token.cdata{color:#6b7280}.code-pre .token.punctuation{color:#94a3b8}.code-pre .token.property,.code-pre .token.tag,.code-pre .token.boolean,.code-pre .token.number,.code-pre .token.constant,.code-pre .token.symbol{color:#f472b6}.code-pre .token.selector,.code-pre .token.attr-name,.code-pre .token.string,.code-pre .token.char,.code-pre .token.builtin{color:#4ade80}.code-pre .token.operator,.code-pre .token.entity,.code-pre .token.url,.code-pre .token.variable{color:#f1f5f9}.code-pre .token.atrule,.code-pre .token.attr-value,.code-pre .token.function,.code-pre .token.class-name{color:#60a5fa}.code-pre .token.keyword{color:#c084fc}.code-pre .token.regex,.code-pre .token.important{color:#fbbf24}.line-overlays{position:absolute;top:12px;left:0;right:0;pointer-events:none}.line-overlay{height:20px;display:flex;align-items:center;padding-left:16px}.line-overlay.highlighted{background:#2563eb26;border-left:3px solid #2563eb;margin-left:-3px}.variable-value{position:absolute;right:16px;color:#4ade80;font-family:Consolas,Monaco,monospace;font-size:11px;background:#4ade801a;padding:2px 8px;border-radius:4px}.canvas-container{position:relative;flex:1;background:#0d1117;border-radius:8px;border:1px solid #0f3460;overflow:hidden;display:flex;flex-direction:column}.canvas-controls{position:absolute;top:8px;right:8px;display:flex;align-items:center;gap:8px;z-index:10}.canvas-btn{padding:4px 10px;background:#1a1a2e;border:1px solid #0f3460;border-radius:4px;color:#94a3b8;font-size:12px;cursor:pointer;transition:all .2s}.canvas-btn:hover{background:#0f3460;color:#f1f5f9}.zoom-level{color:#64748b;font-size:11px;font-family:Consolas,Monaco,monospace}.canvas-svg{flex:1;cursor:grab}.canvas-svg:active{cursor:grabbing}.step-description{position:absolute;bottom:0;left:0;right:0;padding:10px 16px;background:linear-gradient(transparent,#0d1117f2);display:flex;align-items:center;gap:12px}.step-number{background:#2563eb;color:#fff;padding:4px 10px;border-radius:4px;font-size:12px;font-weight:600;white-space:nowrap}.step-text{color:#e2e8f0;font-size:13px;line-height:1.4}.progress-bar{position:relative;height:24px;cursor:pointer;padding:8px 0}.progress-bar.dragging{cursor:grabbing}.progress-track{position:relative;height:6px;background:#1a1a2e;border-radius:3px;overflow:visible}.progress-fill{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,#22c55e,#4ade80);border-radius:3px;transition:width .1s ease-out}.progress-bar.dragging .progress-fill{transition:none}.progress-thumb{position:absolute;top:50%;width:14px;height:14px;background:#fff;border:2px solid #22c55e;border-radius:50%;transform:translate(-50%,-50%);transition:left .1s ease-out,transform .2s;box-shadow:0 2px 4px #0000004d}.progress-bar.dragging .progress-thumb{transition:transform .2s;transform:translate(-50%,-50%) scale(1.2)}.progress-bar:hover .progress-thumb{transform:translate(-50%,-50%) scale(1.1)}.progress-markers{position:absolute;top:8px;left:0;right:0;height:6px;pointer-events:none}.progress-marker{position:absolute;width:4px;height:4px;background:#475569;border-radius:50%;transform:translate(-50%);top:1px;transition:background .2s}.progress-marker.passed{background:#22c55e}.progress-marker.current{background:#fff;width:6px;height:6px;top:0}.speed-control{position:relative}.speed-btn{display:flex;align-items:center;gap:4px;padding:8px 12px;background:#1a1a2e;border:1px solid #0f3460;border-radius:6px;color:#f1f5f9;font-size:13px;cursor:pointer;transition:all .2s}.speed-btn:hover{background:#0f3460;border-color:#2563eb}.speed-icon{font-size:12px}.speed-value{font-family:Consolas,Monaco,monospace;font-weight:500;min-width:32px;text-align:center}.speed-dropdown{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:8px;background:#1a1a2e;border:1px solid #0f3460;border-radius:8px;padding:6px;display:flex;flex-direction:column;gap:4px;z-index:100;box-shadow:0 4px 12px #0000004d}.speed-option{padding:6px 16px;background:transparent;border:none;border-radius:4px;color:#94a3b8;font-size:13px;font-family:Consolas,Monaco,monospace;cursor:pointer;transition:all .2s;text-align:center}.speed-option:hover{background:#0f3460;color:#f1f5f9}.speed-option.active{background:#2563eb;color:#fff}.control-panel{background:#16213e;border-top:1px solid #0f3460;padding:12px 16px;display:flex;flex-direction:column;gap:10px}.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 14px;background:#1a1a2e;border:1px solid #0f3460;border-radius:6px;color:#f1f5f9;font-size:13px;cursor:pointer;transition:all .2s}.control-btn:hover:not(:disabled){background:#0f3460;border-color:#2563eb}.control-btn:disabled{opacity:.4;cursor:not-allowed}.control-btn.play-btn{background:#2563eb;border-color:#2563eb;min-width:100px}.control-btn.play-btn:hover{background:#1d4ed8}.control-btn.play-btn.playing{background:#dc2626;border-color:#dc2626}.control-btn.play-btn.playing:hover{background:#b91c1c}.btn-icon{font-size:14px}.btn-label{font-weight:500}.btn-shortcut{font-size:10px;color:#94a3b8;background:#0003;padding:2px 6px;border-radius:3px;font-family:Consolas,Monaco,monospace}.play-btn .btn-shortcut{background:#ffffff26;color:#fffc}.step-counter{margin-left:auto;color:#94a3b8;font-size:13px;font-family:Consolas,Monaco,monospace;padding:6px 12px;background:#1a1a2e;border-radius:4px}.floating-ball{position:fixed;bottom:20px;right:20px;z-index:1000}.ball-icon{display:flex;flex-direction:column;align-items:center;justify-content:center;width:56px;height:56px;background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:50%;color:#fff;cursor:pointer;box-shadow:0 4px 12px #22c55e66;transition:all .3s}.ball-icon:hover{transform:scale(1.1);box-shadow:0 6px 20px #22c55e80}.ball-icon svg{width:24px;height:24px}.ball-text{font-size:10px;font-weight:600;margin-top:2px}.qrcode-popup{position:absolute;bottom:70px;right:0;animation:fadeInUp .3s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.qrcode-content{background:#fff;border-radius:12px;padding:16px;box-shadow:0 8px 32px #0000004d;text-align:center}.qrcode-image{width:200px;height:auto;border-radius:8px;display:block}.qrcode-tip{margin:12px 0 0;font-size:12px;color:#374151;line-height:1.5}.qrcode-tip strong{color:#22c55e}.app{display:flex;flex-direction:column;height:100vh;background:#0d1117;overflow:hidden}.main-content{flex:1;display:flex;gap:12px;padding:12px;min-height:0}.code-section{width:380px;flex-shrink:0;display:flex;flex-direction:column}.canvas-section{flex:1;display:flex;flex-direction:column;min-width:0}
