*{box-sizing:border-box}body{color:#111827;background:#f7f8fb;margin:0;font-family:Arial,sans-serif}.layout{background:#f7f8fb;grid-template-columns:320px 1fr;gap:16px;min-height:calc(100vh - 57px);padding:16px;display:grid}.control-panel,.visualizer{background:#fff;border:1px solid #e2e6ef;border-radius:10px;padding:16px}.top-nav{background:#fff;border-bottom:1px solid #e2e6ef;align-items:center;gap:10px;height:57px;padding:10px 16px;display:flex}.nav-button{color:#1f2937;cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:8px;height:36px;padding:0 14px}.nav-button-active{color:#2563eb;background:#eff6ff;border-color:#2563eb}.panel-title{color:#1f2937;margin:0 0 16px;font-size:18px}.panel-block{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.label{color:#374151;font-size:14px}.select,.input{color:#111827;background:#fff;border:1px solid #cbd5e1;border-radius:8px;height:36px;padding:0 10px;font-size:14px}.button{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:8px;height:36px;font-size:14px}.button-secondary{background:#4b5563}.range{width:100%}.step-text{color:#4b5563;margin:6px 0 0;font-size:14px}.path-layout{background:#f7f8fb;grid-template-columns:320px 1fr;gap:16px;min-height:calc(100vh - 57px);padding:16px;display:grid}.bars{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;align-items:flex-end;gap:10px;height:70vh;padding:12px;display:flex}.bar-wrap{flex-direction:column;flex:1;justify-content:space-between;align-items:center;gap:8px;min-width:24px;height:100%;display:flex}.bar-track{align-items:flex-end;width:100%;height:100%;display:flex}.bar{border-radius:6px 6px 0 0;width:100%;min-height:6px;transition:height .2s linear,background-color .2s linear}.bar-default{background:#5b7cfa}.bar-comparing{background:#f2c94c}.bar-swapping{background:#eb5757}.bar-sorted{background:#6fcf97}.bar-label{color:#334155;font-size:13px}.grid{-webkit-user-select:none;user-select:none;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;grid-template-columns:repeat(32,22px);gap:2px;width:fit-content;padding:10px;display:grid}.cell{background:#fff;border:1px solid #e5e7eb;border-radius:4px;width:22px;height:22px}.cell-visited{background:#93c5fd}.cell-frontier{background:#fde68a}.cell-current{background:#f87171}.cell-path{background:#6ee7b7}.cell-wall{background:#334155}.cell-start{background:#2563eb}.cell-end{background:#dc2626}
