:root{--bg:#020617;--s1:#0f172a;--s2:#1e293b;--s3:#293548;--border:#334155;--border2:#475569;--text:#f1f5f9;--muted:#94a3b8;--subtle:#64748b;--blue:#38bdf8;--green:#34d399;--amber:#fbbf24;--red:#f87171;--purple:#a78bfa;--pink:#f472b6;--r:8px;--r-lg:14px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,sans-serif;font-size:13.5px;line-height:1.5}input,select,button,textarea{font-family:inherit;font-size:inherit}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--s3);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--border2)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}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(6px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes stepFlash{0%{background:#38bdf824}to{background:#38bdf80d}}@keyframes codeHL{0%{background:#38bdf833}to{background:#38bdf814}}@keyframes toastIn{0%{opacity:0;transform:translateY(20px)translate(-50%)}to{opacity:1;transform:translateY(0)translate(-50%)}}@keyframes toastOut{0%{opacity:1}to{opacity:0}}@keyframes shine{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes pop{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.app{flex-direction:column;width:100vw;height:100vh;display:flex;overflow:hidden}.main-layout{flex:1;min-height:0;display:flex;overflow:hidden}.topbar{background:var(--s1);border-bottom:1px solid var(--border);z-index:50;flex-shrink:0;align-items:center;gap:7px;height:54px;min-height:54px;padding:0 14px;display:flex;box-shadow:0 1px 16px #00000080}.logo{align-items:center;gap:9px;margin-right:4px;display:flex}.logo-mark{color:#fff;letter-spacing:-.5px;background:linear-gradient(135deg,#0ea5e9,#6366f1);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:800;display:flex;box-shadow:0 4px 16px #6366f173}.logo-text{flex-direction:column;display:flex}.logo-title{color:var(--text);letter-spacing:-.3px;font-size:14px;font-weight:700;line-height:1.15}.logo-sub{color:var(--subtle);font-size:10px;line-height:1.15}.tb-sep{background:var(--border);flex-shrink:0;width:1px;height:26px}.algo-select{border-radius:var(--r);background:var(--s2);border:1px solid var(--border);color:var(--text);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;outline:none;min-width:210px;padding:5px 30px 5px 10px;transition:border-color .15s}.algo-select:hover,.algo-select:focus{border-color:var(--blue)}.mode-toggle{background:var(--s2);border:1px solid var(--border);border-radius:var(--r);gap:2px;padding:2px;display:flex}.mode-btn{cursor:pointer;color:var(--muted);background:0 0;border:none;border-radius:6px;padding:4px 12px;font-size:12px;font-weight:600;transition:all .15s}.mode-btn:hover{color:var(--text);background:var(--s3)}.mode-btn.active[data-mode=graph]{color:var(--blue);background:#38bdf826}.mode-btn.active[data-mode=array]{color:var(--amber);background:#fbbf2426}.complexity-row{gap:6px;display:flex}.node-count{color:var(--subtle);background:var(--s2);border:1px solid var(--border);border-radius:20px;padding:3px 9px;font-family:JetBrains Mono,monospace;font-size:11px}.btn{border-radius:var(--r);cursor:pointer;white-space:nowrap;border:none;flex-shrink:0;align-items:center;gap:6px;padding:6px 13px;font-size:12.5px;font-weight:600;transition:all .15s;display:inline-flex}.btn:hover:not(:disabled){filter:brightness(1.14);transform:translateY(-1px)}.btn:active:not(:disabled){filter:brightness(.94);transform:translateY(0)}.btn:disabled{opacity:.33;pointer-events:none}.btn-icon{justify-content:center;width:32px;height:32px;padding:6px}.btn-ghost{background:var(--s2);border:1px solid var(--border);color:var(--muted)}.btn-ghost:hover{border-color:var(--border2);color:var(--text)}.btn-success{color:#fff;background:linear-gradient(135deg,#059669,#10b981)}.btn-primary{color:#fff;background:linear-gradient(135deg,#0ea5e9,#6366f1)}.btn-connecting{color:var(--purple);background:#a78bfa26;border:1px solid #a78bfa66;animation:1.6s ease-in-out infinite pulse}.btn-copied{color:var(--green)!important;border-color:var(--green)!important}.badge{border-radius:20px;align-items:center;padding:2px 8px;font-family:JetBrains Mono,monospace;font-size:10.5px;font-weight:600;display:inline-flex}.badge-blue{color:var(--blue);background:#38bdf81a;border:1px solid #38bdf84d}.badge-purple{color:var(--purple);background:#a78bfa1a;border:1px solid #a78bfa4d}kbd{background:var(--s3);border:1px solid var(--border2);color:var(--muted);border-radius:4px;align-items:center;padding:1px 6px;font-family:JetBrains Mono,monospace;font-size:10px;display:inline-flex}.sidebar{background:var(--s1);border-right:1px solid var(--border);flex-shrink:0;transition:width .22s cubic-bezier(.4,0,.2,1);overflow:hidden}.sidebar-open{width:256px}.sidebar-closed{width:0}.sidebar-inner{flex-direction:column;width:256px;height:100%;padding-bottom:16px;display:flex;overflow-y:auto}.sb-section{padding:10px 8px 6px}.sb-cat{letter-spacing:.1em;color:var(--subtle);text-transform:uppercase;margin-bottom:5px;padding:0 8px;font-size:10px;font-weight:700}.sb-item-wrap{position:relative}.sb-item{border-radius:var(--r);cursor:pointer;width:100%;color:var(--text);text-align:left;background:0 0;border:none;align-items:center;gap:10px;padding:7px 10px;transition:background .12s;display:flex}.sb-item:hover{background:var(--s2)}.sb-item-active{background:#38bdf814!important}.sb-item-active .sb-name{color:var(--blue)!important}.sb-icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:15px;transition:transform .15s;display:flex}.sb-item:hover .sb-icon{transform:scale(1.08)}.sb-text{flex:1;min-width:0;overflow:hidden}.sb-name{color:#cbd5e1;font-size:13px;font-weight:600;line-height:1.3;display:block}.sb-sub{color:var(--subtle);font-size:11px;line-height:1.3;display:block}.sb-badge{border:1px solid;border-radius:20px;flex-shrink:0;padding:2px 6px;font-family:JetBrains Mono,monospace;font-size:9.5px}.sb-tooltip{background:var(--s2);border:1px solid var(--border);border-radius:var(--r);margin:2px 10px 8px;padding:10px 12px;animation:.15s fadeIn,.15s slideDown}.sb-tooltip p{color:var(--muted);margin-bottom:8px;font-size:12px;line-height:1.6}.sb-tooltip-row{color:var(--subtle);gap:16px;font-size:11px;display:flex}.sb-tooltip-row strong{color:var(--text)}.sb-shortcuts{border-top:1px solid var(--border);margin-top:auto}.shortcut-row{justify-content:space-between;align-items:center;padding:4px 8px;display:flex}.shortcut-label{color:var(--muted);font-size:11px}.canvas-area{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.step-bar{border-bottom:1px solid var(--border);background:var(--bg);flex-shrink:0;align-items:center;gap:10px;height:40px;min-height:40px;padding:0 18px;transition:background .2s;display:flex}.step-bar-active{background:#38bdf80a;border-bottom-color:#38bdf833}.step-dot{background:var(--green);border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:1.3s ease-in-out infinite pulse}.step-text{color:var(--blue);font-size:13px;font-weight:500;animation:.18s ease-out slideRight}.step-hint{color:var(--subtle);font-size:12px}.progress-bar-wrap{background:var(--s2);flex-shrink:0;height:2px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, #0ea5e9, var(--blue));border-radius:2px;height:100%;transition:width .22s}.canvas-inner{flex:1;position:relative;overflow:hidden}.canvas-wrap{width:100%;height:100%;position:relative}.graph-svg{background:radial-gradient(ellipse at 42% 38%, #0f172a 0%, var(--bg) 72%);cursor:default;width:100%;height:100%;display:block}.graph-svg.cursor-crosshair{cursor:crosshair}.node-g{cursor:grab}.node-g:active{cursor:grabbing}.canvas-controls{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:var(--r);background:#0f172ae0;flex-direction:column;align-items:center;gap:3px;padding:6px;display:flex;position:absolute;bottom:88px;right:16px;box-shadow:0 4px 24px #00000080}.zoom-label{color:var(--subtle);padding:2px 0;font-family:JetBrains Mono,monospace;font-size:10px}.canvas-hint{color:var(--border2);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border);pointer-events:none;background:#0f172abf;border-radius:20px;flex-wrap:wrap;justify-content:center;align-items:center;gap:10px;padding:6px 16px;font-size:11px;display:flex;position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.array-canvas{background:radial-gradient(ellipse at 42% 38%, #0f172a 0%, var(--bg) 72%);flex-direction:column;justify-content:center;align-items:center;gap:24px;width:100%;height:100%;padding:24px 32px 90px;display:flex;position:relative}.bs-pointers{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.bs-pointer{color:var(--c,var(--blue));border:1px solid color-mix(in srgb, var(--c,var(--blue)) 40%, transparent);background:color-mix(in srgb, var(--c,var(--blue)) 12%, transparent);border-radius:8px;padding:4px 13px;font-family:JetBrains Mono,monospace;font-size:12px}.bs-pointer strong{font-weight:700}.bars-row{flex-wrap:wrap;justify-content:center;align-items:flex-end;gap:8px;display:flex}.bar-wrap{flex-direction:column;align-items:center;gap:4px;display:flex}.bar-top-label{text-align:center;min-height:16px;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:700}.bar{border:2px solid;border-radius:8px;justify-content:center;align-items:center;width:52px;font-family:JetBrains Mono,monospace;font-size:14px;font-weight:700;transition:height .25s,background .25s,border-color .25s,box-shadow .25s,color .25s;display:flex}.bar-idx{color:var(--subtle);font-family:JetBrains Mono,monospace;font-size:10px}.array-input-bar{background:var(--s1);border-top:1px solid var(--border);flex-shrink:0;align-items:center;gap:10px;padding:9px 18px;display:flex;position:absolute;bottom:0;left:0;right:0}.input-label{color:var(--subtle);flex-shrink:0;font-size:12px}.array-input{border-radius:var(--r);background:var(--s2);border:1px solid var(--border);max-width:300px;color:var(--text);outline:none;flex:1;padding:6px 10px;font-family:JetBrains Mono,monospace;font-size:12px;transition:border-color .15s}.array-input:focus{border-color:var(--blue)}.input-hint{color:var(--border2);font-size:11px}.float-controls{-webkit-backdrop-filter:blur(14px)saturate(1.5);backdrop-filter:blur(14px)saturate(1.5);border:1px solid var(--border);z-index:20;white-space:nowrap;background:#091223ed;border-radius:18px;align-items:center;gap:8px;padding:10px 16px;transition:border-color .3s;animation:.22s slideUp;display:flex;position:absolute;bottom:18px;left:50%;transform:translate(-50%);box-shadow:0 8px 48px #000000a6,0 0 0 1px #ffffff08}.float-controls-done{border-color:#fbbf2466!important}.fc-target{color:var(--green);letter-spacing:.02em;background:#10b98114;border:1px solid #34d39947;border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:11px;font-weight:700;display:inline-flex}.fc-target strong{color:var(--text);font-family:JetBrains Mono,monospace;font-size:12px}.fc-target-select{width:88px;color:var(--text);text-align:center;background:#060c18cc;border:1px solid #34d39947;border-radius:8px;outline:none;padding:3px 7px;font-family:JetBrains Mono,monospace;font-size:12px;font-weight:700}.fc-target-select:focus{border-color:var(--green);box-shadow:0 0 0 2px #34d3991f}.array-target-select{width:92px}.fc-sep{background:var(--border);flex-shrink:0;width:1px;height:24px}.fc-scrubber{align-items:center;gap:8px;display:flex}.scrubber-input{cursor:pointer;width:100px;accent-color:var(--blue)}.fc-count{color:var(--subtle);text-align:center;min-width:52px;font-family:JetBrains Mono,monospace;font-size:11px}.fc-play-btn{min-width:86px;color:var(--green);background:#34d3991a;border:1px solid #34d39959;gap:5px;font-size:12.5px;font-weight:700}.fc-play-btn.playing{color:var(--red);background:#f871711a;border-color:#f8717159}.fc-play-btn.done{color:var(--amber);background:#fbbf241f;border-color:#fbbf2466;animation:.6s pop}.speed-presets{background:var(--s2);border:1px solid var(--border);border-radius:6px;gap:2px;padding:2px;display:flex}.speed-btn{cursor:pointer;color:var(--muted);background:0 0;border:none;border-radius:5px;align-items:center;gap:5px;padding:3px 9px;font-size:11px;font-weight:600;transition:all .12s;display:inline-flex}.speed-btn:hover{color:var(--text);background:var(--s3)}.speed-btn.active{color:var(--blue);background:#38bdf826}.right-panel{background:var(--s1);border-left:1px solid var(--border);flex-direction:column;flex-shrink:0;transition:width .22s cubic-bezier(.4,0,.2,1);display:flex;overflow:hidden}.right-panel-open{width:272px}.right-panel-closed{align-items:center;width:40px;padding-top:8px}.rp-toggle-btn{border-radius:var(--r);border:1px solid var(--border);background:var(--s2);width:32px;height:32px;color:var(--muted);cursor:pointer;justify-content:center;align-items:center;transition:all .15s;display:flex}.rp-toggle-btn:hover{color:var(--text);border-color:var(--border2)}.rp-header{border-bottom:1px solid var(--border);background:#38bdf808;justify-content:space-between;align-items:flex-start;padding:12px 14px;display:flex}.rp-algo-title{color:var(--text);margin-bottom:6px;font-size:14px;font-weight:700}.rp-badges{flex-wrap:wrap;gap:6px;display:flex}.rp-step-box{border-bottom:1px solid var(--border);background:#38bdf80d;align-items:flex-start;gap:10px;padding:10px 14px;animation:.5s ease-out stepFlash;display:flex}.rp-step-emoji{flex-shrink:0;margin-top:1px;font-size:16px}.rp-step-text{color:var(--blue);font-size:12.5px;font-weight:500;line-height:1.55}.rp-code-wrap{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.rp-code-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 14px 6px;display:flex}.rp-label{letter-spacing:.1em;color:var(--subtle);text-transform:uppercase;font-size:10px;font-weight:700}.code-block{flex:1;padding:6px 0;overflow-y:auto}.code-line{border-left:3px solid #0000;align-items:flex-start;gap:10px;padding:2.5px 12px;transition:background .2s,border-color .2s;display:flex}.code-line-active{animation:.5s ease-out codeHL;border-left-color:var(--blue)!important;background:#38bdf817!important}.code-ln{text-align:right;width:18px;color:var(--subtle);flex-shrink:0;font-family:JetBrains Mono,monospace;font-size:11px}.code-text{color:#8b949e;white-space:pre;font-family:JetBrains Mono,monospace;font-size:12px;line-height:1.8}.code-line-active .code-text{color:#79c0ff}.rp-section{border-top:1px solid var(--border);padding:10px 14px}.legend-row{align-items:center;gap:8px;margin-bottom:6px;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.legend-label{color:var(--muted);font-size:12px}.start-select{border-radius:var(--r);background:var(--s2);width:100%;color:var(--green);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;border:1px solid #34d3994d;outline:none;padding:7px 30px 7px 10px;font-family:JetBrains Mono,monospace;font-size:12px}.start-select:focus{border-color:var(--green)}.rp-hint{color:var(--subtle);margin-top:6px;font-size:11px}.ctx-menu{z-index:900;background:var(--s2);border:1px solid var(--border);border-radius:var(--r-lg);min-width:185px;animation:.1s fadeIn,.12s slideUp;position:fixed;overflow:hidden;box-shadow:0 20px 60px #000000b3,0 0 0 1px #ffffff0a}.ctx-item{text-align:left;cursor:pointer;width:100%;color:var(--text);background:0 0;border:none;align-items:center;gap:9px;padding:9px 14px;font-size:13px;font-weight:500;transition:background .1s;display:flex}.ctx-item:hover{background:var(--s3)}.ctx-green{color:var(--green)!important}.ctx-blue{color:var(--blue)!important}.ctx-purple{color:var(--purple)!important}.ctx-red{color:var(--red)!important}.ctx-sep{background:var(--border);height:1px}.modal-bg{z-index:800;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#020617c7;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--s1);border:1px solid var(--border);border-radius:18px;width:360px;max-width:94vw;padding:22px 24px;animation:.2s slideUp;box-shadow:0 32px 80px #000000b3,0 0 0 1px #ffffff0a}.modal-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.modal-header h3{font-size:15px;font-weight:700}.modal-hint{color:var(--muted);margin-bottom:14px;font-size:12px}.modal-input{border-radius:var(--r);background:var(--bg);border:1px solid var(--border);width:100%;color:var(--text);outline:none;margin-bottom:14px;padding:9px 12px;font-family:JetBrains Mono,monospace;font-size:13px;transition:border-color .15s}.modal-input:focus{border-color:var(--blue)}.modal-actions{gap:10px;display:flex}.toast{z-index:1000;pointer-events:none;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);white-space:nowrap;border-radius:30px;padding:9px 20px;font-size:13px;font-weight:600;animation:.22s toastIn,.25s 2.5s forwards toastOut;position:fixed;bottom:90px;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #00000080}@media (width<=1100px){.right-panel-open{width:240px}}@media (width<=880px){.logo-text,.node-count,.complexity-row{display:none}}@media (width<=700px){.right-panel{display:none!important}.float-controls{flex-wrap:wrap;justify-content:center;bottom:12px;left:12px;right:12px;transform:none}.scrubber-input{width:70px}}@media (width<=500px){.topbar{gap:5px;padding:0 8px}.mode-toggle{display:none}.btn{padding:5px 9px;font-size:12px}.algo-select{min-width:150px}}
