html{background-color:#161628;color:#eee;font-family:Arial,sans-serif}html.light-theme{background-color:#f2f2f5;color:#333}.container{display:flex;flex-direction:column;gap:2em;width:100vw;align-items:center;padding:2em 2em 4em;box-sizing:border-box}h1{font-size:2.5rem;font-weight:700;text-align:center;color:#0af;margin-bottom:1em}.light-theme h1{color:#005fa3}.start-end-control{display:flex;align-items:center;gap:1em;background:#1e1e3f;padding:1em;border-radius:12px;box-shadow:0 4px 8px #0000004d}.start-end-control label{font-size:1rem;font-weight:700}.start-end-control select{padding:.5em;font-size:1rem;border:1px solid #0077cc;border-radius:8px;background:#2a2a4f;color:#fff;cursor:pointer}.start-end-control select:hover{border-color:#005fa3}.light-theme .start-end-control{background:#e8e8f0;box-shadow:0 4px 8px #0000001a}.light-theme .start-end-control select{background:#fff;color:#333;border:1px solid #005fa3}.light-theme .start-end-control select:hover{border-color:#003f7f}.controls{display:flex;gap:1em;flex-wrap:wrap;justify-content:center}button{padding:.8em 1.5em;font-size:16px;font-weight:700;color:#fff;background-color:#07c;border:none;border-radius:8px;cursor:pointer;transition:background-color .3s ease}button:hover{background-color:#005fa3}.light-theme button{background-color:#005fa3;color:#fff}.light-theme button:hover{background-color:#003f7f}.speed-control{display:flex;align-items:center;gap:1em;font-size:16px}input[type=range]{appearance:none;width:200px;height:8px;background:#07c;border-radius:5px;outline:none;transition:background .3s ease}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;background:#fff;border:2px solid #0077cc;border-radius:50%;cursor:pointer;transition:background .3s ease}input[type=range]:hover,.light-theme input[type=range]{background:#005fa3}.light-theme input[type=range]::-webkit-slider-thumb{border-color:#003f7f}.light-theme input[type=range]:hover{background:#003f7f}.weights{background:#1e1e3f;padding:1.5em;border-radius:12px;box-shadow:0 4px 8px #0000004d;width:100%;max-width:600px}.weights h3{margin-bottom:1em;color:#0af}.light-theme .weights h3{color:#005fa3}.light-theme .weights{background:#e8e8f0;box-shadow:0 4px 8px #0000001a}.weight-item{display:flex;align-items:center;justify-content:space-between;margin-bottom:1em}.visited{display:flex;flex-wrap:wrap;gap:.5em;justify-content:center}.visited h3{width:100%;text-align:center;color:#0af}.light-theme .visited h3{color:#005fa3}.visited .visited-node{background:#07c;color:#fff;padding:.5em 1em;border-radius:8px}.light-theme .visited .visited-node{background:#005fa3}.distance-table{width:100%;max-width:600px;border-collapse:collapse;margin-top:1em}.distance-table th,.distance-table td{padding:.8em;text-align:center;border:1px solid #0077cc}.light-theme .distance-table th,.light-theme .distance-table td{border-color:#005fa3}.distance-table th{background:#07c;color:#fff}.light-theme .distance-table th{background:#005fa3}.distance-table tr:nth-child(2n){background:#1e1e3f}.light-theme .distance-table tr:nth-child(2n){background:#f2f2f5}.distance-table tr:nth-child(odd){background:#2a2a4f}.light-theme .distance-table tr:nth-child(odd){background:#e8e8f0}
