.pathfinding-visualizer{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;background-color:#0a0a0a;position:relative}.grid-wrapper{flex:1;display:flex;align-items:center;justify-content:center;padding:12px}.grid{display:grid;width:calc(100vw - 24px);height:calc(100vw - 24px);max-width:500px;max-height:500px;border:1px solid rgba(255,255,255,.1);background-color:#111;border-radius:8px;overflow:hidden}.cell{border:1px solid rgba(255,255,255,.05);background-color:#1a1a1a;cursor:pointer;transition:background-color .2s}.cell:hover{opacity:.8}.cell.wall{background-color:#37474f}.cell.start{background-color:#ff5252;box-shadow:inset 0 0 4px #ff525280}.cell.end{background-color:#ffd740;box-shadow:inset 0 0 4px #ffd74080}.cell.visited{background-color:#1565c0;animation:fadeIn .3s}.cell.path{background-color:#69f0ae;animation:pathAnimation .3s}.bottom-info{padding:12px 16px;display:flex;flex-direction:column;gap:8px;align-items:center}.info-text{font-size:12px;color:#fff6;margin:0}.controls-bar{display:flex;gap:8px;padding:12px 16px;justify-content:center;align-items:center;flex-wrap:wrap;background:#ffffff0d;border-top:1px solid rgba(255,255,255,.08)}.controls-bar select{padding:8px 28px 8px 12px;border:1px solid rgba(255,255,255,.2);border-radius:8px;font-size:13px;cursor:pointer;background-color:#ffffff1a;color:#fff;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='white' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.controls-bar button{padding:8px 16px;border:none;border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;transition:all .2s;color:#fff}.controls-bar .btn-clear{background:#ffffff14}.controls-bar .btn-clear:hover:not(:disabled){background:#ffffff26}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pathAnimation{0%{transform:scale(.8)}to{transform:scale(1)}}.sorting-visualizer{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;background-color:#0a0a0a;position:relative}.algo-title{text-align:center;padding:56px 16px 8px}.algo-title h2{margin:0;font-size:32px;font-weight:800;color:#fff;letter-spacing:-.5px}.algo-title .algo-subtitle{margin:4px 0 0;font-size:14px;color:#ffffff80;font-weight:400}.step-info{padding:12px 20px;text-align:center;min-height:52px;display:flex;align-items:center;justify-content:center}.step-description{margin:0;font-size:15px;font-weight:600;color:#4fc3f7;line-height:1.4}.array-container{display:flex;align-items:flex-end;justify-content:center;padding:0 12px;gap:1px;height:50vh}.bar{background-color:#42a5f5;border-radius:2px 2px 0 0;transition:background-color .15s;position:relative}.bar-value{display:none}.bar.comparing{background-color:#ff5252}.bar.swapping{background-color:#69f0ae}.bar.highlight-pivot{background-color:#ff9800;box-shadow:0 0 12px #ff980080}.bar.highlight-range{background-color:#7c4dff}.bar.highlight-minimum{background-color:#f50057;box-shadow:0 0 8px #f5005766}.bar.highlight-key{background-color:#ffc107;box-shadow:0 0 8px #ffc10766}.bar.highlight-heap-root{background-color:#00e5ff;box-shadow:0 0 8px #00e5ff66}.bar.highlight-merged{background-color:#76ff03}.bottom-info{padding:16px 16px 24px;display:flex;flex-direction:column;gap:12px}.stats-row{display:flex;justify-content:center;gap:24px}.stat-item{text-align:center}.stat-value{font-size:24px;font-weight:800;color:#fff;display:block;line-height:1}.stat-label{font-size:11px;color:#ffffff80;text-transform:uppercase;letter-spacing:.5px;margin-top:4px;display:block}.legend{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.legend-item{display:flex;align-items:center;gap:4px;font-size:11px;color:#ffffff80}.legend-swatch{width:10px;height:10px;border-radius:2px}.controls-bar{display:flex;gap:8px;padding:12px 16px;justify-content:center;align-items:center;background:#ffffff0d;border-top:1px solid rgba(255,255,255,.08)}.controls-bar select{padding:8px 28px 8px 12px;border:1px solid rgba(255,255,255,.2);border-radius:8px;font-size:13px;cursor:pointer;background-color:#ffffff1a;color:#fff;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='white' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.controls-bar button{padding:8px 20px;border:none;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;color:#fff}.controls-bar .btn-start{background:linear-gradient(135deg,#43a047,#66bb6a)}.controls-bar .btn-start:hover:not(:disabled){background:linear-gradient(135deg,#388e3c,#4caf50)}.controls-bar .btn-reset{background:#ffffff1f}.controls-bar .btn-reset:hover:not(:disabled){background:#fff3}.controls-bar button:disabled{opacity:.4;cursor:not-allowed}.controls-bar .speed-control{display:flex;align-items:center;gap:4px;color:#fff9;font-size:12px}.controls-bar input[type=range]{width:60px;accent-color:#42a5f5}.math-visualizer{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;background-color:#0a0a0a}.math-visualizer .algo-title{text-align:center;padding:56px 16px 8px}.math-visualizer .algo-title h2{margin:0;font-size:32px;font-weight:800;color:#fff;letter-spacing:-.5px}.math-visualizer .algo-title .algo-subtitle{margin:4px 0 0;font-size:14px;color:#ffffff80;font-weight:400}.math-visualizer .canvas-wrapper{flex:1;display:flex;align-items:center;justify-content:center;padding:12px}.math-visualizer canvas{max-width:100%;border-radius:8px}.math-visualizer .formula{text-align:center;padding:12px 16px;font-size:18px;font-weight:700;color:#4fc3f7;font-family:Courier New,monospace}.math-visualizer .controls-bar{display:flex;gap:12px;padding:12px 16px;justify-content:center;align-items:center;flex-wrap:wrap;background:#ffffff0d;border-top:1px solid rgba(255,255,255,.08)}.math-visualizer .slider-group{display:flex;align-items:center;gap:8px;color:#ffffffb3;font-size:13px}.math-visualizer .slider-group label{font-weight:600;min-width:20px}.math-visualizer .slider-group input[type=range]{width:80px;accent-color:#42a5f5}.math-visualizer .slider-group .value{min-width:30px;text-align:right;color:#fff;font-weight:700}.math-visualizer .step-info{padding:12px 20px;text-align:center;min-height:52px;display:flex;align-items:center;justify-content:center}.math-visualizer .step-description{margin:0;font-size:15px;font-weight:600;color:#4fc3f7;line-height:1.4}.math-visualizer .info-panel{padding:16px;display:flex;flex-direction:column;gap:8px;align-items:center}.math-visualizer .stats-row{display:flex;justify-content:center;gap:24px;flex-wrap:wrap}.math-visualizer .stat-item{text-align:center}.math-visualizer .stat-value{font-size:20px;font-weight:800;color:#fff;display:block;line-height:1;font-family:Courier New,monospace}.math-visualizer .stat-label{font-size:11px;color:#ffffff80;letter-spacing:.5px;margin-top:4px;display:block}.math-visualizer .btn-step{padding:8px 20px;border:none;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;color:#fff;background:linear-gradient(135deg,#43a047,#66bb6a)}.math-visualizer .btn-step:hover:not(:disabled){background:linear-gradient(135deg,#388e3c,#4caf50)}.math-visualizer .btn-reset{padding:8px 20px;border:none;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;color:#fff;background:#ffffff1f}.math-visualizer .btn-reset:hover:not(:disabled){background:#fff3}.math-visualizer button:disabled{opacity:.4;cursor:not-allowed}.math-visualizer .rsa-flow{display:flex;flex-direction:column;gap:16px;padding:0 16px;width:100%;max-width:500px;margin:0 auto}.math-visualizer .rsa-step{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:16px;transition:all .3s}.math-visualizer .rsa-step.active{border-color:#4fc3f7;background:#4fc3f714}.math-visualizer .rsa-step.completed{border-color:#69f0ae;background:#69f0ae0d}.math-visualizer .rsa-step h3{margin:0 0 8px;font-size:14px;color:#fff9;font-weight:600}.math-visualizer .rsa-step .rsa-value{font-size:18px;font-weight:800;color:#fff;font-family:Courier New,monospace;word-break:break-all}.math-visualizer .rsa-step .rsa-detail{font-size:12px;color:#fff6;margin-top:4px}.app{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}.app-home{justify-content:center;align-items:center;padding:24px}.app-home h1{font-size:28px;margin-bottom:32px;font-weight:800}.category-grid{display:flex;flex-direction:column;gap:16px;width:100%;max-width:400px}.category-card{padding:32px 24px;background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid rgba(255,255,255,.1);border-radius:16px;cursor:pointer;transition:all .3s;display:block}.category-card:hover{transform:translateY(-2px);border-color:#ffffff4d;box-shadow:0 8px 32px #0000004d}.category-card h2{margin:0;color:#fff;font-size:20px;text-align:center;font-weight:700}.app-visualizer{padding:0}.header{display:flex;align-items:center;gap:12px;padding:12px 16px;position:absolute;top:0;left:0;right:0;z-index:10}.back-button{padding:6px 12px;background-color:#ffffff26;color:#fff;border:none;border-radius:20px;cursor:pointer;font-size:13px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:background-color .3s;white-space:nowrap}.back-button:hover{background-color:#ffffff40}.header h1{display:none}*{box-sizing:border-box}body{margin:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background-color:#0a0a0a;color:#fff;-webkit-text-size-adjust:100%;overflow-x:hidden}h1{text-align:center;color:#fff;margin:0}button{font-family:inherit}a{color:inherit;text-decoration:none}
