jQuery.fn.thornMenu = function(options) {
	settings = jQuery.extend({
		open: false
	}, options);

	this.each(function (index, domEle) {
		// hide sub nav items
		$(domEle).find('ul').hide();
		
		// all top level items just min/max, not actual links
		$(domEle).find('>li>a').hover(function(event) {
			$(this).next().slideToggle('slow');
			event.preventDefault();
			return false;
		});
	});
	
	if ( settings.open != false && $(settings.open) != undefined){
		$(settings.open).children('ul').show();
		$(settings.open).parents('ul').show();
	}
}

$(function () {
        $('.brandInfo').each(function () {
            var distance = 35;
            var time = 250;
            var hideDelay = 250;

            var hideDelayTimer = null;

            var beingShown = false;
            var shown = false;
            var trigger = $('.trigger', this);
            var info = $('.popup', this).css('opacity', 0);


            $([trigger.get(0), info.get(0)]).mouseover(function () {
                if (hideDelayTimer) clearTimeout(hideDelayTimer);
                if (beingShown || shown) {
                    // don't trigger the animation again
                    return;
                } else {
                    // reset position of info box
                    beingShown = true;

                    info.css({
                        top: -70,
                        left: -80,
                        display: 'block'
                    }).animate({
                        top: '-=' + distance + 'px',
                        opacity: 1
                    }, time, 'swing', function() {
                        beingShown = false;
                        shown = true;
                    });
                }

                return false;
            }).mouseout(function () {
                if (hideDelayTimer) clearTimeout(hideDelayTimer);
                hideDelayTimer = setTimeout(function () {
                    hideDelayTimer = null;
                    info.animate({
                        top: '-=' + distance + 'px',
                        opacity: 0
                    }, time, 'swing', function () {
                        shown = false;
                        info.css('display', 'none');
                    });

                }, hideDelay);

                return false;
            });
        });
    });