*{box-sizing:border-box}body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:linear-gradient(180deg,#052e16,#14532d);color:#ecfccb}.wrap{max-width:620px;margin:0 auto;padding:16px}.topnav{margin-bottom:10px;color:#dcfce7}.topnav a{color:#bbf7d0;text-decoration:none}.topnav a:hover{text-decoration:underline}.subtitle{color:#dcfce7}.hud{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:14px 0}.hud>div{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:8px;text-align:center}.grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}.cell{aspect-ratio:1/1;border-radius:10px;border:1px solid rgba(255,255,255,.18);background:#166534;display:flex;align-items:center;justify-content:center;font-weight:700;cursor:pointer}.cell.path{background:#fef3c7;color:#78350f}.cell.start{outline:2px solid #93c5fd}.cell.goal{outline:2px solid #fca5a5}.cell.bog{background:#3f3f46;color:#f3f4f6}.cell.locked{opacity:.45;cursor:not-allowed}.controls{margin-top:12px}.controls button{border:0;border-radius:10px;padding:10px 12px;font-size:1rem;cursor:pointer;background:#84cc16;color:#052e16}.controls button:hover{background:#65a30d}.msg{min-height:1.2rem;color:#ecfccb}
