na verdade, o jQuery simplesmente limpa o valor da propriedade 'display' e não o define como 'block' (consulte a implementação interna de jQuery.showHide ()) -
function showHide(elements, show) {
var display, elem, hidden,
...
if (show) {
// Reset the inline display of this element to learn if it is
// being hidden by cascaded rules or not
if (!values[index] && display === "none") {
elem.style.display = "";
}
...
if (!show || elem.style.display === "none" || elem.style.display === "") {
elem.style.display = show ? values[index] || "" : "none";
}
}
Observe que você pode substituir $ .fn.show () / $. Fn.hide (); armazenar a exibição original no próprio elemento ao ocultar (por exemplo, como um atributo ou no $ .data ()); e depois aplicá-lo novamente ao mostrar.
Além disso, usando css importante! provavelmente não funcionará aqui - já que definir um estilo embutido geralmente é mais forte do que qualquer outra regra