body{margin:0}:root{--bg:#0d0d0f;--surface:#13141a;--surface2:#1c1d26;--border:#2a2b38;--text:#e8e6e0;--muted:#6b6a72;--bfs:#3b9eff;--bfs-dim:#1a3d5c;--dfs:#ff7c3b;--dfs-dim:#5c2e10;--greedy:#a78bfa;--greedy-dim:#3d2a5c;--start:#2dd4a0;--end:#e05b8a;--sans:"Syne", system-ui, sans-serif;--mono:"Space Mono", ui-monospace, monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:var(--sans);-webkit-font-smoothing:antialiased;min-height:100vh}#root{width:100%;max-width:1400px;margin:0 auto}.app{flex-direction:column;gap:1.5rem;min-height:100vh;padding:2rem 1.5rem;display:flex}header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1.5rem;display:flex}.header-left h1{letter-spacing:-.02em;font-size:clamp(1.6rem,4vw,2.4rem);font-weight:800;line-height:1}.header-left h1 .accent{color:var(--bfs)}.header-left h1 .accent2{color:var(--dfs)}.header-left p{color:var(--muted);font-size:.8rem;font-family:var(--mono);letter-spacing:.04em;margin-top:.5rem}.tags{flex-wrap:wrap;gap:.5rem;margin-top:.75rem;display:flex}.tag{font-family:var(--mono);border:1px solid var(--border);color:var(--muted);letter-spacing:.06em;text-transform:uppercase;border-radius:2px;padding:.25rem .6rem;font-size:.65rem}.controls{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.control-label{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;color:var(--muted);flex-direction:column;gap:.25rem;font-size:.6rem;display:flex}.control-label select{font-family:var(--mono);border:1px solid var(--border);background:var(--surface2);color:var(--text);cursor:pointer;border-radius:3px;padding:.45rem .7rem;font-size:.7rem}.btn{font-family:var(--mono);letter-spacing:.04em;border:1px solid var(--border);color:var(--text);cursor:pointer;text-transform:uppercase;background:0 0;border-radius:3px;padding:.55rem 1.1rem;font-size:.7rem;transition:background .15s,border-color .15s}.btn:hover:not(:disabled){background:var(--surface2);border-color:var(--muted)}.btn:disabled{opacity:.4;cursor:default}.btn.primary{background:var(--surface2);border-color:var(--bfs);color:var(--bfs)}.btn.primary:hover:not(:disabled){background:var(--bfs-dim)}.speed-group{display:flex}.speed-group .btn{border-right-width:0;border-radius:0;padding:.55rem .8rem}.speed-group .btn:first-child{border-radius:3px 0 0 3px}.speed-group .btn:last-child{border-right-width:1px;border-radius:0 3px 3px 0}.speed-group .btn.active{background:var(--surface2);color:var(--text);border-color:var(--muted)}.sep{background:var(--border);width:1px;height:28px;margin:0 .3rem}.mode-bar{background:var(--surface);border:1px solid var(--border);border-radius:6px;flex-wrap:wrap;align-items:center;gap:.75rem 1rem;padding:.75rem 1rem;display:flex}.toggle{font-family:var(--mono);text-transform:uppercase;letter-spacing:.05em;color:var(--muted);cursor:pointer;align-items:center;gap:.45rem;font-size:.68rem;display:flex}.toggle input{accent-color:var(--bfs)}.view-toggle,.edit-tools{gap:0;display:flex}.view-toggle .btn,.edit-tools .btn{border-right-width:0;border-radius:0;padding:.45rem .75rem}.view-toggle .btn:first-child,.edit-tools .btn:first-child{border-radius:3px 0 0 3px}.view-toggle .btn:last-child,.edit-tools .btn:last-child{border-right-width:1px;border-radius:0 3px 3px 0}.share-controls{flex-wrap:wrap;align-items:center;gap:.6rem;margin-left:auto;display:flex}.share-hint{font-family:var(--mono);color:var(--muted);font-size:.6rem}.main{grid-template-columns:repeat(2,1fr);align-items:start;gap:1.25rem;display:grid}.main.lesson-layout{grid-template-columns:1fr}@media (width>=1200px){.main:not(.lesson-layout){grid-template-columns:repeat(2,1fr)}}@media (width<=700px){.main{grid-template-columns:1fr}}.panel{background:var(--surface);border:1px solid var(--border);border-radius:6px;overflow:hidden}.panel-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1rem;display:flex}.panel-title{letter-spacing:.01em;align-items:center;gap:.6rem;font-size:.85rem;font-weight:700;display:flex}.dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.status-pill{font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--border);color:var(--muted);white-space:nowrap;border-radius:20px;padding:.2rem .55rem;font-size:.6rem}.status-pill.running{color:#ffb347;border-color:#ffb347;animation:1.2s ease-in-out infinite pulse}.status-pill.done{border-color:var(--start);color:var(--start)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.45}}.panel-body{display:block}.panel-body.with-lesson{grid-template-columns:1fr minmax(140px,200px);align-items:start;gap:.75rem;display:grid}@media (width<=600px){.panel-body.with-lesson{grid-template-columns:1fr}}.lesson-aside{flex-direction:column;gap:.6rem;padding:.5rem .75rem .75rem 0;display:flex}.lesson-hint{font-family:var(--mono);color:var(--muted);font-size:.62rem;line-height:1.55}.ds-view{font-family:var(--mono);font-size:.62rem}.ds-title{text-transform:uppercase;letter-spacing:.04em;margin-bottom:.4rem;font-weight:700}.ds-label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem;display:block}.ds-current{margin-bottom:.5rem}.ds-chip{border:1px solid var(--border);background:var(--surface2);border-radius:3px;padding:.15rem .4rem;display:inline-block}.ds-chip.current{color:#0d0d0f;background:#fff;font-weight:700}.ds-chip.next{font-weight:600}.ds-pri{color:var(--muted);font-size:.58rem}.ds-list{flex-direction:column;gap:.2rem;max-height:120px;list-style:none;display:flex;overflow-y:auto}.ds-list li{flex-wrap:wrap;align-items:center;gap:.35rem;display:flex}.ds-hint{color:var(--muted);font-size:.55rem}.ds-empty{color:var(--muted);font-style:italic}.ds-more{color:var(--muted)}.maze-wrap{background-image:radial-gradient(circle,#2a2b3820 1px,#0000 1px);background-size:20px 20px;justify-content:center;padding:1rem;display:flex;overflow:auto}.maze-canvas.editable{cursor:crosshair}.maze-canvas{image-rendering:pixelated;border:1px solid var(--border);border-radius:3px;max-width:100%;display:block}.stats{border-top:1px solid var(--border);grid-template-columns:repeat(3,1fr);display:grid}.stat{border-right:1px solid var(--border);padding:.75rem 1rem}.stat:last-child{border-right:none}.stat-label{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:.25rem;font-size:.55rem}.stat-value{letter-spacing:-.02em;font-size:1.4rem;font-weight:800;line-height:1}.stat-optimal{padding-top:.2rem;font-size:1rem}.panel-note{padding:.75rem 1rem 1rem}.note{background:var(--surface2);border-left:3px solid var(--bfs);color:var(--muted);font-size:.75rem;font-family:var(--mono);border-radius:0 4px 4px 0;padding:.6rem .9rem;line-height:1.6}.note strong{color:var(--text)}.note-dfs{border-left-color:var(--dfs)}.note-greedy{border-left-color:var(--greedy)}.status-text{color:var(--muted);font-size:.72rem;font-family:var(--mono);margin-top:.5rem;line-height:1.5}.comparison{background:var(--surface);border:1px solid var(--border);border-radius:6px;flex-direction:column;grid-column:1/-1;gap:1rem;padding:1.25rem;display:flex}.comparison h3{font-size:.75rem;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.comparison-grid{grid-template-columns:1fr 1fr;gap:1.5rem;display:grid}@media (width<=800px){.comparison-grid{grid-template-columns:1fr}}.comparison-bars{flex-direction:column;gap:.85rem;display:flex}.compare-row{flex-direction:column;gap:.4rem;display:flex}.compare-label{color:var(--muted);font-size:.75rem;font-family:var(--mono);flex-wrap:wrap;justify-content:space-between;gap:.25rem;display:flex}.compare-track{background:var(--surface2);border-radius:4px;height:8px;overflow:hidden}.compare-fill{border-radius:4px;height:100%;transition:width .4s}.comparison-info{flex-direction:column;gap:.7rem;display:flex}.complexity-grid{grid-template-columns:repeat(3,1fr);gap:.6rem;display:grid}@media (width<=500px){.complexity-grid{grid-template-columns:1fr}}.complexity-card{background:var(--surface2);border-left:3px solid var(--bfs);border-radius:4px;padding:.75rem}.complexity-value{font-family:var(--mono);margin-top:.3rem;font-size:.8rem}.complexity-note{color:var(--muted);margin-top:.2rem;font-size:.7rem}.comparison-summary{color:var(--muted);font-size:.7rem;font-family:var(--mono);background:var(--surface2);border-radius:4px;padding:.65rem .85rem;line-height:1.7}.comparison-summary strong{color:var(--text)}.legend{border-top:1px solid var(--border);flex-wrap:wrap;gap:1.25rem;padding:.75rem 0;display:flex}.legend-item{font-family:var(--mono);color:var(--muted);letter-spacing:.03em;align-items:center;gap:.45rem;font-size:.62rem;display:flex}.legend-box{border-radius:2px;flex-shrink:0;width:11px;height:11px}.benchmark-panel{background:var(--surface);border:1px solid var(--border);border-radius:6px;grid-column:1/-1;padding:1.25rem}.benchmark-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.75rem;display:flex}.benchmark-header h3{font-size:.75rem;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.benchmark-actions{gap:.5rem;display:flex}.benchmark-meta,.benchmark-status{font-family:var(--mono);color:var(--muted);margin-bottom:.75rem;font-size:.65rem}.benchmark-charts{grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem;display:grid}@media (width<=700px){.benchmark-charts{grid-template-columns:1fr}}.bench-chart-title{font-family:var(--mono);text-transform:uppercase;color:var(--muted);margin-bottom:.5rem;font-size:.6rem}.bench-chart-row{grid-template-columns:3rem 1fr 2.5rem;align-items:center;gap:.5rem;margin-bottom:.35rem;display:grid}.bench-chart-label{font-family:var(--mono);text-transform:uppercase;font-size:.65rem}.bench-chart-val{font-family:var(--mono);text-align:right;color:var(--muted);font-size:.65rem}.benchmark-table{border-collapse:collapse;width:100%;font-family:var(--mono);font-size:.7rem}.benchmark-table th,.benchmark-table td{text-align:left;border-top:1px solid var(--border);padding:.5rem .75rem}.benchmark-table th{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-size:.58rem}.algo-table{border-collapse:collapse;width:100%;font-family:var(--mono);margin-bottom:.5rem;font-size:.65rem}.algo-table th,.algo-table td{text-align:left;border-bottom:1px solid var(--border);padding:.35rem .5rem}.algo-table th{color:var(--muted)}.compare-foot{margin-top:.5rem;font-size:.65rem}footer{font-family:var(--mono);color:var(--muted);letter-spacing:.05em;border-top:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-top:auto;padding-top:1.25rem;font-size:.6rem;display:flex}
