Hi,
I had the exact same questions for my own site but somehow I cannot find my thread back! 
With the feedback from the forum guys this is basically what I did and it works like a charm for me:
1) look in your X-Cart root for the following file: error_message.php and empty the contents.
2) Open your home page in a browser and copy all the code over to error_message.php
3) Put this line of code on top of the code on the first line. 
<?php header("HTTP/1.0 404 Not Found"); ?>
This ensures your site returns a proper 404 header when the error page is called.
4) Change your page title into something like "This page could not be found. Error 404" or similar.
5) Edit your welcome text with some text explaining how the user might have gotten there and some suggestions what to do next like:
"Oops, were sorry. The requested page was not found or might have been moved. Maybe you followed an invalid link or made a typo in your address bar. We like to know how you got here and appreciate if you contact us."
6) Save and upload the error_message.php to your root and check. Now you should have a nice looking custom 404 page with all your navigations and search working. And the best thing is that your featured products are shown as well 
 
Alternatively you can add specialized code from Google Webmaster Tools that will put a Google search box on your error page called: 
Enhance 404 pages 
 
You can find it in the "Tools" section of your Google Webmaster tools account.
Haven't tested it myself since I am using Altered Cart Smart Search which works very well instead...
Hope you find this information useful for creating your own custom 404 error page.
Cheers,
Nico