
Need a magician in Kenton with this kind of impact?
Magic for Extraordinary Events
You get to transform your event into a fun and unique experience through magic, mind reading, and interactive entertainment.
The Master Mentalist will delight your audience with his Bohemian-style, personalized command performances of magic, giving each attendee the chance to shine.
Since the magic happens in their hands, there will be cheers, screams, lots of discussion, and a buzz in the atmosphere, bringing everyone in your group together.
Happy clients of Kenton magician Jon Finch




Batavia magician, Bellevue magician, document.addEventListener('DOMContentLoaded', function() { // Target the UL elements with their unique classes const topRow = document.querySelector('.logos-top-row'); const bottomRow = document.querySelector('.logos-bottm-row'); // Function to set up scrolling for a specific row with custom duration function setupScroll(list, duration) { // Make sure the list has the right CSS list.style.display = 'flex'; list.style.width = 'fit-content'; // Get the first half of items (your original logos) const items = Array.from(list.children).slice(0, list.children.length / 2); // Calculate the width of the first half (original set of logos) const firstHalfWidth = items.reduce((width, item) => { return width + item.offsetWidth; }, 0); // Set the scroll function function scroll() { // Reset position instantly list.style.transition = 'none'; list.style.transform = 'translateX(0)'; // Force reflow void list.offsetWidth; // Start smooth scrolling animation with custom duration list.style.transition = `transform ${duration}s cubic-bezier(0.4, 0.0, 0.2, 1)`; list.style.transform = `translateX(-${firstHalfWidth}px)`; } // Initial scroll scroll(); // Set up infinite scrolling with specific event list.addEventListener('transitionend', function(event) { // Only trigger scroll reset if it's the transform transition that ended if (event.propertyName === 'transform') { scroll(); } }); } // Reduce speed for mobile const speedMultiplier = window.innerWidth Bethel magician<“We hired Magician Jon Finch for our company dinner party. WOW! He is simply AMAZING! Highly recommend him to anyone that wants to keep a crowd entertained. We plan to use him again in the future. Thank You Jon for your enteGoshen magicianMagician Goshen | Jon Finch | (317) 766-6519 | Magic show event entertainment Goshen | Best illusionists in Goshen for parties | Corporate magician Jon Finch in Goshen Ohio | Wedding cocktail hour magician Goshen | Mentalist walk around magician and illusionist Goshen, IN | Magician entertainers performing in Goshen Ohio | Fundraiser entertainer Goshen | Mentalist mind reading party Goshen | Corporate event entertainment Goshen | Trade show magician Goshen | Close up magician Goshen | Mingle magic shows strolling magician Goshen | Birthday party magician GoshenSkip to main contentSkip to footer VIDEOS VIRTUAL SHOWSVIRTUAL MENTALISTHOLIDAY PARTY MAGICVIRTUAL MAGIC SHOWSVIRTUAL TEAM BUILDING

VIRTUAL SHOWS
HOLIDAY PARTY MAGIC
document.addEventListener('DOMContentLoaded', function() { // Target the UL elements with their unique classes const topRow = document.querySelector('.logos-top-row'); const bottomRow = document.querySelector('.logos-bottm-row'); // Function to set up scrolling for a specific row with custom duration function setupScroll(list, duration) { // Make sure the list has the right CSS list.style.display = 'flex'; list.style.width = 'fit-content'; // Get the first half of items (your original logos) const items = Array.from(list.children).slice(0, list.children.length / 2); // Calculate the width of the first half (original set of logos) const firstHalfWidth = items.reduce((width, item) => { return width + item.offsetWidth; }, 0); // Set the scroll function function scroll() { // Reset position instantly list.style.transition = 'none'; list.style.transform = 'translateX(0)'; // Force reflow void list.offsetWidth; // Start smooth scrolling animation with custom duration list.style.transition = `transform ${duration}s cubic-bezier(0.4, 0.0, 0.2, 1)`; list.style.transform = `translateX(-${firstHalfWidth}px)`; } // Initial scroll scroll(); // Set up infinite scrolling with specific event list.addEventListener('transitionend', function(event) { // Only trigger scroll reset if it's the transform transition that ended if (event.propertyName === 'transform') { scroll(); } }); } // Reduce speed for mobile const speedMultiplier = window.innerWidth VIRTUAL MAGIC SHOWS

































