/*
 * jQuery 1.2.6 - New Wave Javascript
 *
 * Copyright (c) 2008 John Resig (jquery.com)
 * Dual licensed under the MIT (MIT-LICENSE.txt)
 * and GPL (GPL-LICENSE.txt) licenses.
 *
 * $Date: 2008-05-24 14:22:17 -0400 (Sat, 24 May 2008) $
 * $Rev: 5685 $
 */

(function () {
	var _jQuery = window.jQuery, _$ = window.$;
	var jQuery = window.jQuery = window.$ = function (selector, context) {
		return new jQuery.fn.init(selector, context);
	};
	var quickExpr = /^[^<]*(<(.|\s)+>)[^>]*$|^#(\w+)$/, isSimple = /^.[^:#\[\.]*$/, undefined;
	jQuery.fn = jQuery.prototype = {init:function (selector, context) {
		selector = selector || document;
		if (selector.nodeType) {
			this[0] = selector;
			this.length = 1;
			return this;
		}
		if (typeof selector == "string") {
			var match = quickExpr.exec(selector);
			if (match && (match[1] || !context)) {
				if (match[1]) {
					selector = jQuery.clean([match[1]], context);
				} else {
					var elem = document.getElementById(match[3]);
					if (elem) {
						if (elem.id != match[3]) {
							return jQuery().find(selector);
						}
						return jQuery(elem);
					}
					selector = [];
				}
			} else {
				return jQuery(context).find(selector);
			}
		} else {
			if (jQuery.isFunction(selector)) {
				return jQuery(document)[jQuery.fn.ready ? "ready" : "load"](selector);
			}
		}
		return this.setArray(jQuery.makeArray(selector));
	}, jquery:"1.2.6", size:function () {
		return this.length;
	}, length:0, get:function (num) {
		return num == undefined ? jQuery.makeArray(this) : this[num];
	}, pushStack:function (elems) {
		var ret = jQuery(elems);
		ret.prevObject = this;
		return ret;
	}, setArray:function (elems) {
		this.length = 0;
		Array.prototype.push.apply(this, elems);
		return this;
	}, each:function (callback, args) {
		return jQuery.each(this, callback, args);
	}, index:function (elem) {
		var ret = -1;
		return jQuery.inArray(elem && elem.jquery ? elem[0] : elem, this);
	}, attr:function (name, value, type) {
		var options = name;
		if (name.constructor == String) {
			if (value === undefined) {
				return this[0] && jQuery[type || "attr"](this[0], name);
			} else {
				options = {};
				options[name] = value;
			}
		}
		return this.each(function (i) {
			for (name in options) {
				jQuery.attr(type ? this.style : this, name, jQuery.prop(this, options[name], type, i, name));
			}
		});
	}, css:function (key, value) {
		if ((key == "width" || key == "height") && parseFloat(value) < 0) {
			value = undefined;
		}
		return this.attr(key, value, "curCSS");
	}, text:function (text) {
		if (typeof text != "object" && text != null) {
			return this.empty().append((this[0] && this[0].ownerDocument || document).createTextNode(text));
		}
		var ret = "";
		jQuery.each(text || this, function () {
			jQuery.each(this.childNodes, function () {
				if (this.nodeType != 8) {
					ret += this.nodeType != 1 ? this.nodeValue : jQuery.fn.text([this]);
				}
			});
		});
		return ret;
	}, wrapAll:function (html) {
		if (this[0]) {
			jQuery(html, this[0].ownerDocument).clone().insertBefore(this[0]).map(function () {
				var elem = this;
				while (elem.firstChild) {
					elem = elem.firstChild;
				}
				return elem;
			}).append(this);
		}
		return this;
	}, wrapInner:function (html) {
		return this.each(function () {
			jQuery(this).contents().wrapAll(html);
		});
	}, wrap:function (html) {
		return this.each(function () {
			jQuery(this).wrapAll(html);
		});
	}, append:function () {
		return this.domManip(arguments, true, false, function (elem) {
			if (this.nodeType == 1) {
				this.appendChild(elem);
			}
		});
	}, prepend:function () {
		return this.domManip(arguments, true, true, function (elem) {
			if (this.nodeType == 1) {
				this.insertBefore(elem, this.firstChild);
			}
		});
	}, before:function () {
		return this.domManip(arguments, false, false, function (elem) {
			this.parentNode.insertBefore(elem, this);
		});
	}, after:function () {
		return this.domManip(arguments, false, true, function (elem) {
			this.parentNode.insertBefore(elem, this.nextSibling);
		});
	}, end:function () {
		return this.prevObject || jQuery([]);
	}, find:function (selector) {
		var elems = jQuery.map(this, function (elem) {
			return jQuery.find(selector, elem);
		});
		return this.pushStack(/[^+>] [^+>]/.test(selector) || selector.indexOf("..") > -1 ? jQuery.unique(elems) : elems);
	}, clone:function (events) {
		var ret = this.map(function () {
			if (jQuery.browser.msie && !jQuery.isXMLDoc(this)) {
				var clone = this.cloneNode(true), container = document.createElement("div");
				container.appendChild(clone);
				return jQuery.clean([container.innerHTML])[0];
			} else {
				return this.cloneNode(true);
			}
		});
		var clone = ret.find("*").andSelf().each(function () {
			if (this[expando] != undefined) {
				this[expando] = null;
			}
		});
		if (events === true) {
			this.find("*").andSelf().each(function (i) {
				if (this.nodeType == 3) {
					return;
				}
				var events = jQuery.data(this, "events");
				for (var type in events) {
					for (var handler in events[type]) {
						jQuery.event.add(clone[i], type, events[type][handler], events[type][handler].data);
					}
				}
			});
		}
		return ret;
	}, filter:function (selector) {
		return this.pushStack(jQuery.isFunction(selector) && jQuery.grep(this, function (elem, i) {
			return selector.call(elem, i);
		}) || jQuery.multiFilter(selector, this));
	}, not:function (selector) {
		if (selector.constructor == String) {
			if (isSimple.test(selector)) {
				return this.pushStack(jQuery.multiFilter(selector, this, true));
			} else {
				selector = jQuery.multiFilter(selector, this);
			}
		}
		var isArrayLike = selector.length && selector[selector.length - 1] !== undefined && !selector.nodeType;
		return this.filter(function () {
			return isArrayLike ? jQuery.inArray(this, selector) < 0 : this != selector;
		});
	}, add:function (selector) {
		return this.pushStack(jQuery.unique(jQuery.merge(this.get(), typeof selector == "string" ? jQuery(selector) : jQuery.makeArray(selector))));
	}, is:function (selector) {
		return !!selector && jQuery.multiFilter(selector, this).length > 0;
	}, hasClass:function (selector) {
		return this.is("." + selector);
	}, val:function (value) {
		if (value == undefined) {
			if (this.length) {
				var elem = this[0];
				if (jQuery.nodeName(elem, "select")) {
					var index = elem.selectedIndex, values = [], options = elem.options, one = elem.type == "select-one";
					if (index < 0) {
						return null;
					}
					for (var i = one ? index : 0, max = one ? index + 1 : options.length; i < max; i++) {
						var option = options[i];
						if (option.selected) {
							value = jQuery.browser.msie && !option.attributes.value.specified ? option.text : option.value;
							if (one) {
								return value;
							}
							values.push(value);
						}
					}
					return values;
				} else {
					return (this[0].value || "").replace(/\r/g, "");
				}
			}
			return undefined;
		}
		if (value.constructor == Number) {
			value += "";
		}
		return this.each(function () {
			if (this.nodeType != 1) {
				return;
			}
			if (value.constructor == Array && /radio|checkbox/.test(this.type)) {
				this.checked = (jQuery.inArray(this.value, value) >= 0 || jQuery.inArray(this.name, value) >= 0);
			} else {
				if (jQuery.nodeName(this, "select")) {
					var values = jQuery.makeArray(value);
					jQuery("option", this).each(function () {
						this.selected = (jQuery.inArray(this.value, values) >= 0 || jQuery.inArray(this.text, values) >= 0);
					});
					if (!values.length) {
						this.selectedIndex = -1;
					}
				} else {
					this.value = value;
				}
			}
		});
	}, html:function (value) {
		return value == undefined ? (this[0] ? this[0].innerHTML : null) : this.empty().append(value);
	}, replaceWith:function (value) {
		return this.after(value).remove();
	}, eq:function (i) {
		return this.slice(i, i + 1);
	}, slice:function () {
		return this.pushStack(Array.prototype.slice.apply(this, arguments));
	}, map:function (callback) {
		return this.pushStack(jQuery.map(this, function (elem, i) {
			return callback.call(elem, i, elem);
		}));
	}, andSelf:function () {
		return this.add(this.prevObject);
	}, data:function (key, value) {
		var parts = key.split(".");
		parts[1] = parts[1] ? "." + parts[1] : "";
		if (value === undefined) {
			var data = this.triggerHandler("getData" + parts[1] + "!", [parts[0]]);
			if (data === undefined && this.length) {
				data = jQuery.data(this[0], key);
			}
			return data === undefined && parts[1] ? this.data(parts[0]) : data;
		} else {
			return this.trigger("setData" + parts[1] + "!", [parts[0], value]).each(function () {
				jQuery.data(this, key, value);
			});
		}
	}, removeData:function (key) {
		return this.each(function () {
			jQuery.removeData(this, key);
		});
	}, domManip:function (args, table, reverse, callback) {
		var clone = this.length > 1, elems;
		return this.each(function () {
			if (!elems) {
				elems = jQuery.clean(args, this.ownerDocument);
				if (reverse) {
					elems.reverse();
				}
			}
			var obj = this;
			if (table && jQuery.nodeName(this, "table") && jQuery.nodeName(elems[0], "tr")) {
				obj = this.getElementsByTagName("tbody")[0] || this.appendChild(this.ownerDocument.createElement("tbody"));
			}
			var scripts = jQuery([]);
			jQuery.each(elems, function () {
				var elem = clone ? jQuery(this).clone(true)[0] : this;
				if (jQuery.nodeName(elem, "script")) {
					scripts = scripts.add(elem);
				} else {
					if (elem.nodeType == 1) {
						scripts = scripts.add(jQuery("script", elem).remove());
					}
					callback.call(obj, elem);
				}
			});
			scripts.each(evalScript);
		});
	}};
	jQuery.fn.init.prototype = jQuery.fn;
	function evalScript(i, elem) {
		if (elem.src) {
			jQuery.ajax({url:elem.src, async:false, dataType:"script"});
		} else {
			jQuery.globalEval(elem.text || elem.textContent || elem.innerHTML || "");
		}
		if (elem.parentNode) {
			elem.parentNode.removeChild(elem);
		}
	}
	function now() {
		return +new Date;
	}
	jQuery.extend = jQuery.fn.extend = function () {
		var target = arguments[0] || {}, i = 1, length = arguments.length, deep = false, options;
		if (target.constructor == Boolean) {
			deep = target;
			target = arguments[1] || {};
			i = 2;
		}
		if (typeof target != "object" && typeof target != "function") {
			target = {};
		}
		if (length == i) {
			target = this;
			--i;
		}
		for (; i < length; i++) {
			if ((options = arguments[i]) != null) {
				for (var name in options) {
					var src = target[name], copy = options[name];
					if (target === copy) {
						continue;
					}
					if (deep && copy && typeof copy == "object" && !copy.nodeType) {
						target[name] = jQuery.extend(deep, src || (copy.length != null ? [] : {}), copy);
					} else {
						if (copy !== undefined) {
							target[name] = copy;
						}
					}
				}
			}
		}
		return target;
	};
	var expando = "jQuery" + now(), uuid = 0, windowData = {}, exclude = /z-?index|font-?weight|opacity|zoom|line-?height/i, defaultView = document.defaultView || {};
	jQuery.extend({noConflict:function (deep) {
		window.$ = _$;
		if (deep) {
			window.jQuery = _jQuery;
		}
		return jQuery;
	}, isFunction:function (fn) {
		return !!fn && typeof fn != "string" && !fn.nodeName && fn.constructor != Array && /^[\s[]?function/.test(fn + "");
	}, isXMLDoc:function (elem) {
		return elem.documentElement && !elem.body || elem.tagName && elem.ownerDocument && !elem.ownerDocument.body;
	}, globalEval:function (data) {
		data = jQuery.trim(data);
		if (data) {
			var head = document.getElementsByTagName("head")[0] || document.documentElement, script = document.createElement("script");
			script.type = "text/javascript";
			if (jQuery.browser.msie) {
				script.text = data;
			} else {
				script.appendChild(document.createTextNode(data));
			}
			head.insertBefore(script, head.firstChild);
			head.removeChild(script);
		}
	}, nodeName:function (elem, name) {
		return elem.nodeName && elem.nodeName.toUpperCase() == name.toUpperCase();
	}, cache:{}, data:function (elem, name, data) {
		elem = elem == window ? windowData : elem;
		var id = elem[expando];
		if (!id) {
			id = elem[expando] = ++uuid;
		}
		if (name && !jQuery.cache[id]) {
			jQuery.cache[id] = {};
		}
		if (data !== undefined) {
			jQuery.cache[id][name] = data;
		}
		return name ? jQuery.cache[id][name] : id;
	}, removeData:function (elem, name) {
		elem = elem == window ? windowData : elem;
		var id = elem[expando];
		if (name) {
			if (jQuery.cache[id]) {
				delete jQuery.cache[id][name];
				name = "";
				for (name in jQuery.cache[id]) {
					break;
				}
				if (!name) {
					jQuery.removeData(elem);
				}
			}
		} else {
			try {
				delete elem[expando];
			}
			catch (e) {
				if (elem.removeAttribute) {
					elem.removeAttribute(expando);
				}
			}
			delete jQuery.cache[id];
		}
	}, each:function (object, callback, args) {
		var name, i = 0, length = object.length;
		if (args) {
			if (length == undefined) {
				for (name in object) {
					if (callback.apply(object[name], args) === false) {
						break;
					}
				}
			} else {
				for (; i < length; ) {
					if (callback.apply(object[i++], args) === false) {
						break;
					}
				}
			}
		} else {
			if (length == undefined) {
				for (name in object) {
					if (callback.call(object[name], name, object[name]) === false) {
						break;
					}
				}
			} else {
				for (var value = object[0]; i < length && callback.call(value, i, value) !== false; value = object[++i]) {
				}
			}
		}
		return object;
	}, prop:function (elem, value, type, i, name) {
		if (jQuery.isFunction(value)) {
			value = value.call(elem, i);
		}
		return value && value.constructor == Number && type == "curCSS" && !exclude.test(name) ? value + "px" : value;
	}, className:{add:function (elem, classNames) {
		jQuery.each((classNames || "").split(/\s+/), function (i, className) {
			if (elem.nodeType == 1 && !jQuery.className.has(elem.className, className)) {
				elem.className += (elem.className ? " " : "") + className;
			}
		});
	}, remove:function (elem, classNames) {
		if (elem.nodeType == 1) {
			elem.className = classNames != undefined ? jQuery.grep(elem.className.split(/\s+/), function (className) {
				return !jQuery.className.has(classNames, className);
			}).join(" ") : "";
		}
	}, has:function (elem, className) {
		return jQuery.inArray(className, (elem.className || elem).toString().split(/\s+/)) > -1;
	}}, swap:function (elem, options, callback) {
		var old = {};
		for (var name in options) {
			old[name] = elem.style[name];
			elem.style[name] = options[name];
		}
		callback.call(elem);
		for (var name in options) {
			elem.style[name] = old[name];
		}
	}, css:function (elem, name, force) {
		if (name == "width" || name == "height") {
			var val, props = {position:"absolute", visibility:"hidden", display:"block"}, which = name == "width" ? ["Left", "Right"] : ["Top", "Bottom"];
			function getWH() {
				val = name == "width" ? elem.offsetWidth : elem.offsetHeight;
				var padding = 0, border = 0;
				jQuery.each(which, function () {
					padding += parseFloat(jQuery.curCSS(elem, "padding" + this, true)) || 0;
					border += parseFloat(jQuery.curCSS(elem, "border" + this + "Width", true)) || 0;
				});
				val -= Math.round(padding + border);
			}
			if (jQuery(elem).is(":visible")) {
				getWH();
			} else {
				jQuery.swap(elem, props, getWH);
			}
			return Math.max(0, val);
		}
		return jQuery.curCSS(elem, name, force);
	}, curCSS:function (elem, name, force) {
		var ret, style = elem.style;
		function color(elem) {
			if (!jQuery.browser.safari) {
				return false;
			}
			var ret = defaultView.getComputedStyle(elem, null);
			return !ret || ret.getPropertyValue("color") == "";
		}
		if (name == "opacity" && jQuery.browser.msie) {
			ret = jQuery.attr(style, "opacity");
			return ret == "" ? "1" : ret;
		}
		if (jQuery.browser.opera && name == "display") {
			var save = style.outline;
			style.outline = "0 solid black";
			style.outline = save;
		}
		if (name.match(/float/i)) {
			name = styleFloat;
		}
		if (!force && style && style[name]) {
			ret = style[name];
		} else {
			if (defaultView.getComputedStyle) {
				if (name.match(/float/i)) {
					name = "float";
				}
				name = name.replace(/([A-Z])/g, "-$1").toLowerCase();
				var computedStyle = defaultView.getComputedStyle(elem, null);
				if (computedStyle && !color(elem)) {
					ret = computedStyle.getPropertyValue(name);
				} else {
					var swap = [], stack = [], a = elem, i = 0;
					for (; a && color(a); a = a.parentNode) {
						stack.unshift(a);
					}
					for (; i < stack.length; i++) {
						if (color(stack[i])) {
							swap[i] = stack[i].style.display;
							stack[i].style.display = "block";
						}
					}
					ret = name == "display" && swap[stack.length - 1] != null ? "none" : (computedStyle && computedStyle.getPropertyValue(name)) || "";
					for (i = 0; i < swap.length; i++) {
						if (swap[i] != null) {
							stack[i].style.display = swap[i];
						}
					}
				}
				if (name == "opacity" && ret == "") {
					ret = "1";
				}
			} else {
				if (elem.currentStyle) {
					var camelCase = name.replace(/\-(\w)/g, function (all, letter) {
						return letter.toUpperCase();
					});
					ret = elem.currentStyle[name] || elem.currentStyle[camelCase];
					if (!/^\d+(px)?$/i.test(ret) && /^\d/.test(ret)) {
						var left = style.left, rsLeft = elem.runtimeStyle.left;
						elem.runtimeStyle.left = elem.currentStyle.left;
						style.left = ret || 0;
						ret = style.pixelLeft + "px";
						style.left = left;
						elem.runtimeStyle.left = rsLeft;
					}
				}
			}
		}
		return ret;
	}, clean:function (elems, context) {
		var ret = [];
		context = context || document;
		if (typeof context.createElement == "undefined") {
			context = context.ownerDocument || context[0] && context[0].ownerDocument || document;
		}
		jQuery.each(elems, function (i, elem) {
			if (!elem) {
				return;
			}
			if (elem.constructor == Number) {
				elem += "";
			}
			if (typeof elem == "string") {
				elem = elem.replace(/(<(\w+)[^>]*?)\/>/g, function (all, front, tag) {
					return tag.match(/^(abbr|br|col|img|input|link|meta|param|hr|area|embed)$/i) ? all : front + "></" + tag + ">";
				});
				var tags = jQuery.trim(elem).toLowerCase(), div = context.createElement("div");
				var wrap = !tags.indexOf("<opt") && [1, "<select multiple='multiple'>", "</select>"] || !tags.indexOf("<leg") && [1, "<fieldset>", "</fieldset>"] || tags.match(/^<(thead|tbody|tfoot|colg|cap)/) && [1, "<table>", "</table>"] || !tags.indexOf("<tr") && [2, "<table><tbody>", "</tbody></table>"] || (!tags.indexOf("<td") || !tags.indexOf("<th")) && [3, "<table><tbody><tr>", "</tr></tbody></table>"] || !tags.indexOf("<col") && [2, "<table><tbody></tbody><colgroup>", "</colgroup></table>"] || jQuery.browser.msie && [1, "div<div>", "</div>"] || [0, "", ""];
				div.innerHTML = wrap[1] + elem + wrap[2];
				while (wrap[0]--) {
					div = div.lastChild;
				}
				if (jQuery.browser.msie) {
					var tbody = !tags.indexOf("<table") && tags.indexOf("<tbody") < 0 ? div.firstChild && div.firstChild.childNodes : wrap[1] == "<table>" && tags.indexOf("<tbody") < 0 ? div.childNodes : [];
					for (var j = tbody.length - 1; j >= 0; --j) {
						if (jQuery.nodeName(tbody[j], "tbody") && !tbody[j].childNodes.length) {
							tbody[j].parentNode.removeChild(tbody[j]);
						}
					}
					if (/^\s/.test(elem)) {
						div.insertBefore(context.createTextNode(elem.match(/^\s*/)[0]), div.firstChild);
					}
				}
				elem = jQuery.makeArray(div.childNodes);
			}
			if (elem.length === 0 && (!jQuery.nodeName(elem, "form") && !jQuery.nodeName(elem, "select"))) {
				return;
			}
			if (elem[0] == undefined || jQuery.nodeName(elem, "form") || elem.options) {
				ret.push(elem);
			} else {
				ret = jQuery.merge(ret, elem);
			}
		});
		return ret;
	}, attr:function (elem, name, value) {
		if (!elem || elem.nodeType == 3 || elem.nodeType == 8) {
			return undefined;
		}
		var notxml = !jQuery.isXMLDoc(elem), set = value !== undefined, msie = jQuery.browser.msie;
		name = notxml && jQuery.props[name] || name;
		if (elem.tagName) {
			var special = /href|src|style/.test(name);
			if (name == "selected" && jQuery.browser.safari) {
				elem.parentNode.selectedIndex;
			}
			if (name in elem && notxml && !special) {
				if (set) {
					if (name == "type" && jQuery.nodeName(elem, "input") && elem.parentNode) {
						throw "type property can't be changed";
					}
					elem[name] = value;
				}
				if (jQuery.nodeName(elem, "form") && elem.getAttributeNode(name)) {
					return elem.getAttributeNode(name).nodeValue;
				}
				return elem[name];
			}
			if (msie && notxml && name == "style") {
				return jQuery.attr(elem.style, "cssText", value);
			}
			if (set) {
				elem.setAttribute(name, "" + value);
			}
			var attr = msie && notxml && special ? elem.getAttribute(name, 2) : elem.getAttribute(name);
			return attr === null ? undefined : attr;
		}
		if (msie && name == "opacity") {
			if (set) {
				elem.zoom = 1;
				elem.filter = (elem.filter || "").replace(/alpha\([^)]*\)/, "") + (parseInt(value) + "" == "NaN" ? "" : "alpha(opacity=" + value * 100 + ")");
			}
			return elem.filter && elem.filter.indexOf("opacity=") >= 0 ? (parseFloat(elem.filter.match(/opacity=([^)]*)/)[1]) / 100) + "" : "";
		}
		name = name.replace(/-([a-z])/ig, function (all, letter) {
			return letter.toUpperCase();
		});
		if (set) {
			elem[name] = value;
		}
		return elem[name];
	}, trim:function (text) {
		return (text || "").replace(/^\s+|\s+$/g, "");
	}, makeArray:function (array) {
		var ret = [];
		if (array != null) {
			var i = array.length;
			if (i == null || array.split || array.setInterval || array.call) {
				ret[0] = array;
			} else {
				while (i) {
					ret[--i] = array[i];
				}
			}
		}
		return ret;
	}, inArray:function (elem, array) {
		for (var i = 0, length = array.length; i < length; i++) {
			if (array[i] === elem) {
				return i;
			}
		}
		return -1;
	}, merge:function (first, second) {
		var i = 0, elem, pos = first.length;
		if (jQuery.browser.msie) {
			while (elem = second[i++]) {
				if (elem.nodeType != 8) {
					first[pos++] = elem;
				}
			}
		} else {
			while (elem = second[i++]) {
				first[pos++] = elem;
			}
		}
		return first;
	}, unique:function (array) {
		var ret = [], done = {};
		try {
			for (var i = 0, length = array.length; i < length; i++) {
				var id = jQuery.data(array[i]);
				if (!done[id]) {
					done[id] = true;
					ret.push(array[i]);
				}
			}
		}
		catch (e) {
			ret = array;
		}
		return ret;
	}, grep:function (elems, callback, inv) {
		var ret = [];
		for (var i = 0, length = elems.length; i < length; i++) {
			if (!inv != !callback(elems[i], i)) {
				ret.push(elems[i]);
			}
		}
		return ret;
	}, map:function (elems, callback) {
		var ret = [];
		for (var i = 0, length = elems.length; i < length; i++) {
			var value = callback(elems[i], i);
			if (value != null) {
				ret[ret.length] = value;
			}
		}
		return ret.concat.apply([], ret);
	}});
	var userAgent = navigator.userAgent.toLowerCase();
	jQuery.browser = {version:(userAgent.match(/.+(?:rv|it|ra|ie)[\/: ]([\d.]+)/) || [])[1], safari:/webkit/.test(userAgent), opera:/opera/.test(userAgent), msie:/msie/.test(userAgent) && !/opera/.test(userAgent), mozilla:/mozilla/.test(userAgent) && !/(compatible|webkit)/.test(userAgent)};
	var styleFloat = jQuery.browser.msie ? "styleFloat" : "cssFloat";
	jQuery.extend({boxModel:!jQuery.browser.msie || document.compatMode == "CSS1Compat", props:{"for":"htmlFor", "class":"className", "float":styleFloat, cssFloat:styleFloat, styleFloat:styleFloat, readonly:"readOnly", maxlength:"maxLength", cellspacing:"cellSpacing"}});
	jQuery.each({parent:function (elem) {
		return elem.parentNode;
	}, parents:function (elem) {
		return jQuery.dir(elem, "parentNode");
	}, next:function (elem) {
		return jQuery.nth(elem, 2, "nextSibling");
	}, prev:function (elem) {
		return jQuery.nth(elem, 2, "previousSibling");
	}, nextAll:function (elem) {
		return jQuery.dir(elem, "nextSibling");
	}, prevAll:function (elem) {
		return jQuery.dir(elem, "previousSibling");
	}, siblings:function (elem) {
		return jQuery.sibling(elem.parentNode.firstChild, elem);
	}, children:function (elem) {
		return jQuery.sibling(elem.firstChild);
	}, contents:function (elem) {
		return jQuery.nodeName(elem, "iframe") ? elem.contentDocument || elem.contentWindow.document : jQuery.makeArray(elem.childNodes);
	}}, function (name, fn) {
		jQuery.fn[name] = function (selector) {
			var ret = jQuery.map(this, fn);
			if (selector && typeof selector == "string") {
				ret = jQuery.multiFilter(selector, ret);
			}
			return this.pushStack(jQuery.unique(ret));
		};
	});
	jQuery.each({appendTo:"append", prependTo:"prepend", insertBefore:"before", insertAfter:"after", replaceAll:"replaceWith"}, function (name, original) {
		jQuery.fn[name] = function () {
			var args = arguments;
			return this.each(function () {
				for (var i = 0, length = args.length; i < length; i++) {
					jQuery(args[i])[original](this);
				}
			});
		};
	});
	jQuery.each({removeAttr:function (name) {
		jQuery.attr(this, name, "");
		if (this.nodeType == 1) {
			this.removeAttribute(name);
		}
	}, addClass:function (classNames) {
		jQuery.className.add(this, classNames);
	}, removeClass:function (classNames) {
		jQuery.className.remove(this, classNames);
	}, toggleClass:function (classNames) {
		jQuery.className[jQuery.className.has(this, classNames) ? "remove" : "add"](this, classNames);
	}, remove:function (selector) {
		if (!selector || jQuery.filter(selector, [this]).r.length) {
			jQuery("*", this).add(this).each(function () {
				jQuery.event.remove(this);
				jQuery.removeData(this);
			});
			if (this.parentNode) {
				this.parentNode.removeChild(this);
			}
		}
	}, empty:function () {
		jQuery(">*", this).remove();
		while (this.firstChild) {
			this.removeChild(this.firstChild);
		}
	}}, function (name, fn) {
		jQuery.fn[name] = function () {
			return this.each(fn, arguments);
		};
	});
	jQuery.each(["Height", "Width"], function (i, name) {
		var type = name.toLowerCase();
		jQuery.fn[type] = function (size) {
			return this[0] == window ? jQuery.browser.opera && document.body["client" + name] || jQuery.browser.safari && window["inner" + name] || document.compatMode == "CSS1Compat" && document.documentElement["client" + name] || document.body["client" + name] : this[0] == document ? Math.max(Math.max(document.body["scroll" + name], document.documentElement["scroll" + name]), Math.max(document.body["offset" + name], document.documentElement["offset" + name])) : size == undefined ? (this.length ? jQuery.css(this[0], type) : null) : this.css(type, size.constructor == String ? size : size + "px");
		};
	});
	function num(elem, prop) {
		return elem[0] && parseInt(jQuery.curCSS(elem[0], prop, true), 10) || 0;
	}
	var chars = jQuery.browser.safari && parseInt(jQuery.browser.version) < 417 ? "(?:[\\w*_-]|\\\\.)" : "(?:[\\w\u0128-\uffff*_-]|\\\\.)", quickChild = new RegExp("^>\\s*(" + chars + "+)"), quickID = new RegExp("^(" + chars + "+)(#)(" + chars + "+)"), quickClass = new RegExp("^([#.]?)(" + chars + "*)");
	jQuery.extend({expr:{"":function (a, i, m) {
		return m[2] == "*" || jQuery.nodeName(a, m[2]);
	}, "#":function (a, i, m) {
		return a.getAttribute("id") == m[2];
	}, ":":{lt:function (a, i, m) {
		return i < m[3] - 0;
	}, gt:function (a, i, m) {
		return i > m[3] - 0;
	}, nth:function (a, i, m) {
		return m[3] - 0 == i;
	}, eq:function (a, i, m) {
		return m[3] - 0 == i;
	}, first:function (a, i) {
		return i == 0;
	}, last:function (a, i, m, r) {
		return i == r.length - 1;
	}, even:function (a, i) {
		return i % 2 == 0;
	}, odd:function (a, i) {
		return i % 2;
	}, "first-child":function (a) {
		return a.parentNode.getElementsByTagName("*")[0] == a;
	}, "last-child":function (a) {
		return jQuery.nth(a.parentNode.lastChild, 1, "previousSibling") == a;
	}, "only-child":function (a) {
		return !jQuery.nth(a.parentNode.lastChild, 2, "previousSibling");
	}, parent:function (a) {
		return a.firstChild;
	}, empty:function (a) {
		return !a.firstChild;
	}, contains:function (a, i, m) {
		return (a.textContent || a.innerText || jQuery(a).text() || "").indexOf(m[3]) >= 0;
	}, visible:function (a) {
		return "hidden" != a.type && jQuery.css(a, "display") != "none" && jQuery.css(a, "visibility") != "hidden";
	}, hidden:function (a) {
		return "hidden" == a.type || jQuery.css(a, "display") == "none" || jQuery.css(a, "visibility") == "hidden";
	}, enabled:function (a) {
		return !a.disabled;
	}, disabled:function (a) {
		return a.disabled;
	}, checked:function (a) {
		return a.checked;
	}, selected:function (a) {
		return a.selected || jQuery.attr(a, "selected");
	}, text:function (a) {
		return "text" == a.type;
	}, radio:function (a) {
		return "radio" == a.type;
	}, checkbox:function (a) {
		return "checkbox" == a.type;
	}, file:function (a) {
		return "file" == a.type;
	}, password:function (a) {
		return "password" == a.type;
	}, submit:function (a) {
		return "submit" == a.type;
	}, image:function (a) {
		return "image" == a.type;
	}, reset:function (a) {
		return "reset" == a.type;
	}, button:function (a) {
		return "button" == a.type || jQuery.nodeName(a, "button");
	}, input:function (a) {
		return /input|select|textarea|button/i.test(a.nodeName);
	}, has:function (a, i, m) {
		return jQuery.find(m[3], a).length;
	}, header:function (a) {
		return /h\d/i.test(a.nodeName);
	}, animated:function (a) {
		return jQuery.grep(jQuery.timers, function (fn) {
			return a == fn.elem;
		}).length;
	}}}, parse:[/^(\[) *@?([\w-]+) *([!*$^~=]*) *('?"?)(.*?)\4 *\]/, /^(:)([\w-]+)\("?'?(.*?(\(.*?\))?[^(]*?)"?'?\)/, new RegExp("^([:.#]*)(" + chars + "+)")], multiFilter:function (expr, elems, not) {
		var old, cur = [];
		while (expr && expr != old) {
			old = expr;
			var f = jQuery.filter(expr, elems, not);
			expr = f.t.replace(/^\s*,\s*/, "");
			cur = not ? elems = f.r : jQuery.merge(cur, f.r);
		}
		return cur;
	}, find:function (t, context) {
		if (typeof t != "string") {
			return [t];
		}
		if (context && context.nodeType != 1 && context.nodeType != 9) {
			return [];
		}
		context = context || document;
		var ret = [context], done = [], last, nodeName;
		while (t && last != t) {
			var r = [];
			last = t;
			t = jQuery.trim(t);
			var foundToken = false, re = quickChild, m = re.exec(t);
			if (m) {
				nodeName = m[1].toUpperCase();
				for (var i = 0; ret[i]; i++) {
					for (var c = ret[i].firstChild; c; c = c.nextSibling) {
						if (c.nodeType == 1 && (nodeName == "*" || c.nodeName.toUpperCase() == nodeName)) {
							r.push(c);
						}
					}
				}
				ret = r;
				t = t.replace(re, "");
				if (t.indexOf(" ") == 0) {
					continue;
				}
				foundToken = true;
			} else {
				re = /^([>+~])\s*(\w*)/i;
				if ((m = re.exec(t)) != null) {
					r = [];
					var merge = {};
					nodeName = m[2].toUpperCase();
					m = m[1];
					for (var j = 0, rl = ret.length; j < rl; j++) {
						var n = m == "~" || m == "+" ? ret[j].nextSibling : ret[j].firstChild;
						for (; n; n = n.nextSibling) {
							if (n.nodeType == 1) {
								var id = jQuery.data(n);
								if (m == "~" && merge[id]) {
									break;
								}
								if (!nodeName || n.nodeName.toUpperCase() == nodeName) {
									if (m == "~") {
										merge[id] = true;
									}
									r.push(n);
								}
								if (m == "+") {
									break;
								}
							}
						}
					}
					ret = r;
					t = jQuery.trim(t.replace(re, ""));
					foundToken = true;
				}
			}
			if (t && !foundToken) {
				if (!t.indexOf(",")) {
					if (context == ret[0]) {
						ret.shift();
					}
					done = jQuery.merge(done, ret);
					r = ret = [context];
					t = " " + t.substr(1, t.length);
				} else {
					var re2 = quickID;
					var m = re2.exec(t);
					if (m) {
						m = [0, m[2], m[3], m[1]];
					} else {
						re2 = quickClass;
						m = re2.exec(t);
					}
					m[2] = m[2].replace(/\\/g, "");
					var elem = ret[ret.length - 1];
					if (m[1] == "#" && elem && elem.getElementById && !jQuery.isXMLDoc(elem)) {
						var oid = elem.getElementById(m[2]);
						if ((jQuery.browser.msie || jQuery.browser.opera) && oid && typeof oid.id == "string" && oid.id != m[2]) {
							oid = jQuery("[@id=\"" + m[2] + "\"]", elem)[0];
						}
						ret = r = oid && (!m[3] || jQuery.nodeName(oid, m[3])) ? [oid] : [];
					} else {
						for (var i = 0; ret[i]; i++) {
							var tag = m[1] == "#" && m[3] ? m[3] : m[1] != "" || m[0] == "" ? "*" : m[2];
							if (tag == "*" && ret[i].nodeName.toLowerCase() == "object") {
								tag = "param";
							}
							r = jQuery.merge(r, ret[i].getElementsByTagName(tag));
						}
						if (m[1] == ".") {
							r = jQuery.classFilter(r, m[2]);
						}
						if (m[1] == "#") {
							var tmp = [];
							for (var i = 0; r[i]; i++) {
								if (r[i].getAttribute("id") == m[2]) {
									tmp = [r[i]];
									break;
								}
							}
							r = tmp;
						}
						ret = r;
					}
					t = t.replace(re2, "");
				}
			}
			if (t) {
				var val = jQuery.filter(t, r);
				ret = r = val.r;
				t = jQuery.trim(val.t);
			}
		}
		if (t) {
			ret = [];
		}
		if (ret && context == ret[0]) {
			ret.shift();
		}
		done = jQuery.merge(done, ret);
		return done;
	}, classFilter:function (r, m, not) {
		m = " " + m + " ";
		var tmp = [];
		for (var i = 0; r[i]; i++) {
			var pass = (" " + r[i].className + " ").indexOf(m) >= 0;
			if (!not && pass || not && !pass) {
				tmp.push(r[i]);
			}
		}
		return tmp;
	}, filter:function (t, r, not) {
		var last;
		while (t && t != last) {
			last = t;
			var p = jQuery.parse, m;
			for (var i = 0; p[i]; i++) {
				m = p[i].exec(t);
				if (m) {
					t = t.substring(m[0].length);
					m[2] = m[2].replace(/\\/g, "");
					break;
				}
			}
			if (!m) {
				break;
			}
			if (m[1] == ":" && m[2] == "not") {
				r = isSimple.test(m[3]) ? jQuery.filter(m[3], r, true).r : jQuery(r).not(m[3]);
			} else {
				if (m[1] == ".") {
					r = jQuery.classFilter(r, m[2], not);
				} else {
					if (m[1] == "[") {
						var tmp = [], type = m[3];
						for (var i = 0, rl = r.length; i < rl; i++) {
							var a = r[i], z = a[jQuery.props[m[2]] || m[2]];
							if (z == null || /href|src|selected/.test(m[2])) {
								z = jQuery.attr(a, m[2]) || "";
							}
							if ((type == "" && !!z || type == "=" && z == m[5] || type == "!=" && z != m[5] || type == "^=" && z && !z.indexOf(m[5]) || type == "$=" && z.substr(z.length - m[5].length) == m[5] || (type == "*=" || type == "~=") && z.indexOf(m[5]) >= 0) ^ not) {
								tmp.push(a);
							}
						}
						r = tmp;
					} else {
						if (m[1] == ":" && m[2] == "nth-child") {
							var merge = {}, tmp = [], test = /(-?)(\d*)n((?:\+|-)?\d*)/.exec(m[3] == "even" && "2n" || m[3] == "odd" && "2n+1" || !/\D/.test(m[3]) && "0n+" + m[3] || m[3]), first = (test[1] + (test[2] || 1)) - 0, last = test[3] - 0;
							for (var i = 0, rl = r.length; i < rl; i++) {
								var node = r[i], parentNode = node.parentNode, id = jQuery.data(parentNode);
								if (!merge[id]) {
									var c = 1;
									for (var n = parentNode.firstChild; n; n = n.nextSibling) {
										if (n.nodeType == 1) {
											n.nodeIndex = c++;
										}
									}
									merge[id] = true;
								}
								var add = false;
								if (first == 0) {
									if (node.nodeIndex == last) {
										add = true;
									}
								} else {
									if ((node.nodeIndex - last) % first == 0 && (node.nodeIndex - last) / first >= 0) {
										add = true;
									}
								}
								if (add ^ not) {
									tmp.push(node);
								}
							}
							r = tmp;
						} else {
							var fn = jQuery.expr[m[1]];
							if (typeof fn == "object") {
								fn = fn[m[2]];
							}
							if (typeof fn == "string") {
								fn = eval("false||function(a,i){return " + fn + ";}");
							}
							r = jQuery.grep(r, function (elem, i) {
								return fn(elem, i, m, r);
							}, not);
						}
					}
				}
			}
		}
		return {r:r, t:t};
	}, dir:function (elem, dir) {
		var matched = [], cur = elem[dir];
		while (cur && cur != document) {
			if (cur.nodeType == 1) {
				matched.push(cur);
			}
			cur = cur[dir];
		}
		return matched;
	}, nth:function (cur, result, dir, elem) {
		result = result || 1;
		var num = 0;
		for (; cur; cur = cur[dir]) {
			if (cur.nodeType == 1 && ++num == result) {
				break;
			}
		}
		return cur;
	}, sibling:function (n, elem) {
		var r = [];
		for (; n; n = n.nextSibling) {
			if (n.nodeType == 1 && n != elem) {
				r.push(n);
			}
		}
		return r;
	}});
	jQuery.event = {add:function (elem, types, handler, data) {
		if (elem.nodeType == 3 || elem.nodeType == 8) {
			return;
		}
		if (jQuery.browser.msie && elem.setInterval) {
			elem = window;
		}
		if (!handler.guid) {
			handler.guid = this.guid++;
		}
		if (data != undefined) {
			var fn = handler;
			handler = this.proxy(fn, function () {
				return fn.apply(this, arguments);
			});
			handler.data = data;
		}
		var events = jQuery.data(elem, "events") || jQuery.data(elem, "events", {}), handle = jQuery.data(elem, "handle") || jQuery.data(elem, "handle", function () {
			if (typeof jQuery != "undefined" && !jQuery.event.triggered) {
				return jQuery.event.handle.apply(arguments.callee.elem, arguments);
			}
		});
		handle.elem = elem;
		jQuery.each(types.split(/\s+/), function (index, type) {
			var parts = type.split(".");
			type = parts[0];
			handler.type = parts[1];
			var handlers = events[type];
			if (!handlers) {
				handlers = events[type] = {};
				if (!jQuery.event.special[type] || jQuery.event.special[type].setup.call(elem) === false) {
					if (elem.addEventListener) {
						elem.addEventListener(type, handle, false);
					} else {
						if (elem.attachEvent) {
							elem.attachEvent("on" + type, handle);
						}
					}
				}
			}
			handlers[handler.guid] = handler;
			jQuery.event.global[type] = true;
		});
		elem = null;
	}, guid:1, global:{}, remove:function (elem, types, handler) {
		if (elem.nodeType == 3 || elem.nodeType == 8) {
			return;
		}
		var events = jQuery.data(elem, "events"), ret, index;
		if (events) {
			if (types == undefined || (typeof types == "string" && types.charAt(0) == ".")) {
				for (var type in events) {
					this.remove(elem, type + (types || ""));
				}
			} else {
				if (types.type) {
					handler = types.handler;
					types = types.type;
				}
				jQuery.each(types.split(/\s+/), function (index, type) {
					var parts = type.split(".");
					type = parts[0];
					if (events[type]) {
						if (handler) {
							delete events[type][handler.guid];
						} else {
							for (handler in events[type]) {
								if (!parts[1] || events[type][handler].type == parts[1]) {
									delete events[type][handler];
								}
							}
						}
						for (ret in events[type]) {
							break;
						}
						if (!ret) {
							if (!jQuery.event.special[type] || jQuery.event.special[type].teardown.call(elem) === false) {
								if (elem.removeEventListener) {
									elem.removeEventListener(type, jQuery.data(elem, "handle"), false);
								} else {
									if (elem.detachEvent) {
										elem.detachEvent("on" + type, jQuery.data(elem, "handle"));
									}
								}
							}
							ret = null;
							delete events[type];
						}
					}
				});
			}
			for (ret in events) {
				break;
			}
			if (!ret) {
				var handle = jQuery.data(elem, "handle");
				if (handle) {
					handle.elem = null;
				}
				jQuery.removeData(elem, "events");
				jQuery.removeData(elem, "handle");
			}
		}
	}, trigger:function (type, data, elem, donative, extra) {
		data = jQuery.makeArray(data);
		if (type.indexOf("!") >= 0) {
			type = type.slice(0, -1);
			var exclusive = true;
		}
		if (!elem) {
			if (this.global[type]) {
				jQuery("*").add([window, document]).trigger(type, data);
			}
		} else {
			if (elem.nodeType == 3 || elem.nodeType == 8) {
				return undefined;
			}
			var val, ret, fn = jQuery.isFunction(elem[type] || null), event = !data[0] || !data[0].preventDefault;
			if (event) {
				data.unshift({type:type, target:elem, preventDefault:function () {
				}, stopPropagation:function () {
				}, timeStamp:now()});
				data[0][expando] = true;
			}
			data[0].type = type;
			if (exclusive) {
				data[0].exclusive = true;
			}
			var handle = jQuery.data(elem, "handle");
			if (handle) {
				val = handle.apply(elem, data);
			}
			if ((!fn || (jQuery.nodeName(elem, "a") && type == "click")) && elem["on" + type] && elem["on" + type].apply(elem, data) === false) {
				val = false;
			}
			if (event) {
				data.shift();
			}
			if (extra && jQuery.isFunction(extra)) {
				ret = extra.apply(elem, val == null ? data : data.concat(val));
				if (ret !== undefined) {
					val = ret;
				}
			}
			if (fn && donative !== false && val !== false && !(jQuery.nodeName(elem, "a") && type == "click")) {
				this.triggered = true;
				try {
					elem[type]();
				}
				catch (e) {
				}
			}
			this.triggered = false;
		}
		return val;
	}, handle:function (event) {
		var val, ret, namespace, all, handlers;
		event = arguments[0] = jQuery.event.fix(event || window.event);
		namespace = event.type.split(".");
		event.type = namespace[0];
		namespace = namespace[1];
		all = !namespace && !event.exclusive;
		handlers = (jQuery.data(this, "events") || {})[event.type];
		for (var j in handlers) {
			var handler = handlers[j];
			if (all || handler.type == namespace) {
				event.handler = handler;
				event.data = handler.data;
				ret = handler.apply(this, arguments);
				if (val !== false) {
					val = ret;
				}
				if (ret === false) {
					event.preventDefault();
					event.stopPropagation();
				}
			}
		}
		return val;
	}, fix:function (event) {
		if (event[expando] == true) {
			return event;
		}
		var originalEvent = event;
		event = {originalEvent:originalEvent};
		var props = "altKey attrChange attrName bubbles button cancelable charCode clientX clientY ctrlKey currentTarget data detail eventPhase fromElement handler keyCode metaKey newValue originalTarget pageX pageY prevValue relatedNode relatedTarget screenX screenY shiftKey srcElement target timeStamp toElement type view wheelDelta which".split(" ");
		for (var i = props.length; i; i--) {
			event[props[i]] = originalEvent[props[i]];
		}
		event[expando] = true;
		event.preventDefault = function () {
			if (originalEvent.preventDefault) {
				originalEvent.preventDefault();
			}
			originalEvent.returnValue = false;
		};
		event.stopPropagation = function () {
			if (originalEvent.stopPropagation) {
				originalEvent.stopPropagation();
			}
			originalEvent.cancelBubble = true;
		};
		event.timeStamp = event.timeStamp || now();
		if (!event.target) {
			event.target = event.srcElement || document;
		}
		if (event.target.nodeType == 3) {
			event.target = event.target.parentNode;
		}
		if (!event.relatedTarget && event.fromElement) {
			event.relatedTarget = event.fromElement == event.target ? event.toElement : event.fromElement;
		}
		if (event.pageX == null && event.clientX != null) {
			var doc = document.documentElement, body = document.body;
			event.pageX = event.clientX + (doc && doc.scrollLeft || body && body.scrollLeft || 0) - (doc.clientLeft || 0);
			event.pageY = event.clientY + (doc && doc.scrollTop || body && body.scrollTop || 0) - (doc.clientTop || 0);
		}
		if (!event.which && ((event.charCode || event.charCode === 0) ? event.charCode : event.keyCode)) {
			event.which = event.charCode || event.keyCode;
		}
		if (!event.metaKey && event.ctrlKey) {
			event.metaKey = event.ctrlKey;
		}
		if (!event.which && event.button) {
			event.which = (event.button & 1 ? 1 : (event.button & 2 ? 3 : (event.button & 4 ? 2 : 0)));
		}
		return event;
	}, proxy:function (fn, proxy) {
		proxy.guid = fn.guid = fn.guid || proxy.guid || this.guid++;
		return proxy;
	}, special:{ready:{setup:function () {
		bindReady();
		return;
	}, teardown:function () {
		return;
	}}, mouseenter:{setup:function () {
		if (jQuery.browser.msie) {
			return false;
		}
		jQuery(this).bind("mouseover", jQuery.event.special.mouseenter.handler);
		return true;
	}, teardown:function () {
		if (jQuery.browser.msie) {
			return false;
		}
		jQuery(this).unbind("mouseover", jQuery.event.special.mouseenter.handler);
		return true;
	}, handler:function (event) {
		if (withinElement(event, this)) {
			return true;
		}
		event.type = "mouseenter";
		return jQuery.event.handle.apply(this, arguments);
	}}, mouseleave:{setup:function () {
		if (jQuery.browser.msie) {
			return false;
		}
		jQuery(this).bind("mouseout", jQuery.event.special.mouseleave.handler);
		return true;
	}, teardown:function () {
		if (jQuery.browser.msie) {
			return false;
		}
		jQuery(this).unbind("mouseout", jQuery.event.special.mouseleave.handler);
		return true;
	}, handler:function (event) {
		if (withinElement(event, this)) {
			return true;
		}
		event.type = "mouseleave";
		return jQuery.event.handle.apply(this, arguments);
	}}}};
	jQuery.fn.extend({bind:function (type, data, fn) {
		return type == "unload" ? this.one(type, data, fn) : this.each(function () {
			jQuery.event.add(this, type, fn || data, fn && data);
		});
	}, one:function (type, data, fn) {
		var one = jQuery.event.proxy(fn || data, function (event) {
			jQuery(this).unbind(event, one);
			return (fn || data).apply(this, arguments);
		});
		return this.each(function () {
			jQuery.event.add(this, type, one, fn && data);
		});
	}, unbind:function (type, fn) {
		return this.each(function () {
			jQuery.event.remove(this, type, fn);
		});
	}, trigger:function (type, data, fn) {
		return this.each(function () {
			jQuery.event.trigger(type, data, this, true, fn);
		});
	}, triggerHandler:function (type, data, fn) {
		return this[0] && jQuery.event.trigger(type, data, this[0], false, fn);
	}, toggle:function (fn) {
		var args = arguments, i = 1;
		while (i < args.length) {
			jQuery.event.proxy(fn, args[i++]);
		}
		return this.click(jQuery.event.proxy(fn, function (event) {
			this.lastToggle = (this.lastToggle || 0) % i;
			event.preventDefault();
			return args[this.lastToggle++].apply(this, arguments) || false;
		}));
	}, hover:function (fnOver, fnOut) {
		return this.bind("mouseenter", fnOver).bind("mouseleave", fnOut);
	}, ready:function (fn) {
		bindReady();
		if (jQuery.isReady) {
			fn.call(document, jQuery);
		} else {
			jQuery.readyList.push(function () {
				return fn.call(this, jQuery);
			});
		}
		return this;
	}});
	jQuery.extend({isReady:false, readyList:[], ready:function () {
		if (!jQuery.isReady) {
			jQuery.isReady = true;
			if (jQuery.readyList) {
				jQuery.each(jQuery.readyList, function () {
					this.call(document);
				});
				jQuery.readyList = null;
			}
			jQuery(document).triggerHandler("ready");
		}
	}});
	var readyBound = false;
	function bindReady() {
		if (readyBound) {
			return;
		}
		readyBound = true;
		if (document.addEventListener && !jQuery.browser.opera) {
			document.addEventListener("DOMContentLoaded", jQuery.ready, false);
		}
		if (jQuery.browser.msie && window == top) {
			(function () {
				if (jQuery.isReady) {
					return;
				}
				try {
					document.documentElement.doScroll("left");
				}
				catch (error) {
					setTimeout(arguments.callee, 0);
					return;
				}
				jQuery.ready();
			})();
		}
		if (jQuery.browser.opera) {
			document.addEventListener("DOMContentLoaded", function () {
				if (jQuery.isReady) {
					return;
				}
				for (var i = 0; i < document.styleSheets.length; i++) {
					if (document.styleSheets[i].disabled) {
						setTimeout(arguments.callee, 0);
						return;
					}
				}
				jQuery.ready();
			}, false);
		}
		if (jQuery.browser.safari) {
			var numStyles;
			(function () {
				if (jQuery.isReady) {
					return;
				}
				if (document.readyState != "loaded" && document.readyState != "complete") {
					setTimeout(arguments.callee, 0);
					return;
				}
				if (numStyles === undefined) {
					numStyles = jQuery("style, link[rel=stylesheet]").length;
				}
				if (document.styleSheets.length != numStyles) {
					setTimeout(arguments.callee, 0);
					return;
				}
				jQuery.ready();
			})();
		}
		jQuery.event.add(window, "load", jQuery.ready);
	}
	jQuery.each(("blur,focus,load,resize,scroll,unload,click,dblclick," + "mousedown,mouseup,mousemove,mouseover,mouseout,change,select," + "submit,keydown,keypress,keyup,error").split(","), function (i, name) {
		jQuery.fn[name] = function (fn) {
			return fn ? this.bind(name, fn) : this.trigger(name);
		};
	});
	var withinElement = function (event, elem) {
		var parent = event.relatedTarget;
		while (parent && parent != elem) {
			try {
				parent = parent.parentNode;
			}
			catch (error) {
				parent = elem;
			}
		}
		return parent == elem;
	};
	jQuery(window).bind("unload", function () {
		jQuery("*").add(document).unbind();
	});
	jQuery.fn.extend({_load:jQuery.fn.load, load:function (url, params, callback) {
		if (typeof url != "string") {
			return this._load(url);
		}
		var off = url.indexOf(" ");
		if (off >= 0) {
			var selector = url.slice(off, url.length);
			url = url.slice(0, off);
		}
		callback = callback || function () {
		};
		var type = "GET";
		if (params) {
			if (jQuery.isFunction(params)) {
				callback = params;
				params = null;
			} else {
				params = jQuery.param(params);
				type = "POST";
			}
		}
		var self = this;
		jQuery.ajax({url:url, type:type, dataType:"html", data:params, complete:function (res, status) {
			if (status == "success" || status == "notmodified") {
				self.html(selector ? jQuery("<div/>").append(res.responseText.replace(/<script(.|\s)*?\/script>/g, "")).find(selector) : res.responseText);
			}
			self.each(callback, [res.responseText, status, res]);
		}});
		return this;
	}, serialize:function () {
		return jQuery.param(this.serializeArray());
	}, serializeArray:function () {
		return this.map(function () {
			return jQuery.nodeName(this, "form") ? jQuery.makeArray(this.elements) : this;
		}).filter(function () {
			return this.name && !this.disabled && (this.checked || /select|textarea/i.test(this.nodeName) || /text|hidden|password/i.test(this.type));
		}).map(function (i, elem) {
			var val = jQuery(this).val();
			return val == null ? null : val.constructor == Array ? jQuery.map(val, function (val, i) {
				return {name:elem.name, value:val};
			}) : {name:elem.name, value:val};
		}).get();
	}});
	jQuery.each("ajaxStart,ajaxStop,ajaxComplete,ajaxError,ajaxSuccess,ajaxSend".split(","), function (i, o) {
		jQuery.fn[o] = function (f) {
			return this.bind(o, f);
		};
	});
	var jsc = now();
	jQuery.extend({get:function (url, data, callback, type) {
		if (jQuery.isFunction(data)) {
			callback = data;
			data = null;
		}
		return jQuery.ajax({type:"GET", url:url, data:data, success:callback, dataType:type});
	}, getScript:function (url, callback) {
		return jQuery.get(url, null, callback, "script");
	}, getJSON:function (url, data, callback) {
		return jQuery.get(url, data, callback, "json");
	}, post:function (url, data, callback, type) {
		if (jQuery.isFunction(data)) {
			callback = data;
			data = {};
		}
		return jQuery.ajax({type:"POST", url:url, data:data, success:callback, dataType:type});
	}, ajaxSetup:function (settings) {
		jQuery.extend(jQuery.ajaxSettings, settings);
	}, ajaxSettings:{url:location.href, global:true, type:"GET", timeout:0, contentType:"application/x-www-form-urlencoded", processData:true, async:true, data:null, username:null, password:null, accepts:{xml:"application/xml, text/xml", html:"text/html", script:"text/javascript, application/javascript", json:"application/json, text/javascript", text:"text/plain", _default:"*/*"}}, lastModified:{}, ajax:function (s) {
		s = jQuery.extend(true, s, jQuery.extend(true, {}, jQuery.ajaxSettings, s));
		var jsonp, jsre = /=\?(&|$)/g, status, data, type = s.type.toUpperCase();
		if (s.data && s.processData && typeof s.data != "string") {
			s.data = jQuery.param(s.data);
		}
		if (s.dataType == "jsonp") {
			if (type == "GET") {
				if (!s.url.match(jsre)) {
					s.url += (s.url.match(/\?/) ? "&" : "?") + (s.jsonp || "callback") + "=?";
				}
			} else {
				if (!s.data || !s.data.match(jsre)) {
					s.data = (s.data ? s.data + "&" : "") + (s.jsonp || "callback") + "=?";
				}
			}
			s.dataType = "json";
		}
		if (s.dataType == "json" && (s.data && s.data.match(jsre) || s.url.match(jsre))) {
			jsonp = "jsonp" + jsc++;
			if (s.data) {
				s.data = (s.data + "").replace(jsre, "=" + jsonp + "$1");
			}
			s.url = s.url.replace(jsre, "=" + jsonp + "$1");
			s.dataType = "script";
			window[jsonp] = function (tmp) {
				data = tmp;
				success();
				complete();
				window[jsonp] = undefined;
				try {
					delete window[jsonp];
				}
				catch (e) {
				}
				if (head) {
					head.removeChild(script);
				}
			};
		}
		if (s.dataType == "script" && s.cache == null) {
			s.cache = false;
		}
		if (s.cache === false && type == "GET") {
			var ts = now();
			var ret = s.url.replace(/(\?|&)_=.*?(&|$)/, "$1_=" + ts + "$2");
			s.url = ret + ((ret == s.url) ? (s.url.match(/\?/) ? "&" : "?") + "_=" + ts : "");
		}
		if (s.data && type == "GET") {
			s.url += (s.url.match(/\?/) ? "&" : "?") + s.data;
			s.data = null;
		}
		if (s.global && !jQuery.active++) {
			jQuery.event.trigger("ajaxStart");
		}
		var remote = /^(?:\w+:)?\/\/([^\/?#]+)/;
		if (s.dataType == "script" && type == "GET" && remote.test(s.url) && remote.exec(s.url)[1] != location.host) {
			var head = document.getElementsByTagName("head")[0];
			var script = document.createElement("script");
			script.src = s.url;
			if (s.scriptCharset) {
				script.charset = s.scriptCharset;
			}
			if (!jsonp) {
				var done = false;
				script.onload = script.onreadystatechange = function () {
					if (!done && (!this.readyState || this.readyState == "loaded" || this.readyState == "complete")) {
						done = true;
						success();
						complete();
						head.removeChild(script);
					}
				};
			}
			head.appendChild(script);
			return undefined;
		}
		var requestDone = false;
		var xhr = window.ActiveXObject ? new ActiveXObject("Microsoft.XMLHTTP") : new XMLHttpRequest();
		if (s.username) {
			xhr.open(type, s.url, s.async, s.username, s.password);
		} else {
			xhr.open(type, s.url, s.async);
		}
		try {
			if (s.data) {
				xhr.setRequestHeader("Content-Type", s.contentType);
			}
			if (s.ifModified) {
				xhr.setRequestHeader("If-Modified-Since", jQuery.lastModified[s.url] || "Thu, 01 Jan 1970 00:00:00 GMT");
			}
			xhr.setRequestHeader("X-Requested-With", "XMLHttpRequest");
			xhr.setRequestHeader("Accept", s.dataType && s.accepts[s.dataType] ? s.accepts[s.dataType] + ", */*" : s.accepts._default);
		}
		catch (e) {
		}
		if (s.beforeSend && s.beforeSend(xhr, s) === false) {
			s.global && jQuery.active--;
			xhr.abort();
			return false;
		}
		if (s.global) {
			jQuery.event.trigger("ajaxSend", [xhr, s]);
		}
		var onreadystatechange = function (isTimeout) {
			if (!requestDone && xhr && (xhr.readyState == 4 || isTimeout == "timeout")) {
				requestDone = true;
				if (ival) {
					clearInterval(ival);
					ival = null;
				}
				status = isTimeout == "timeout" && "timeout" || !jQuery.httpSuccess(xhr) && "error" || s.ifModified && jQuery.httpNotModified(xhr, s.url) && "notmodified" || "success";
				if (status == "success") {
					try {
						data = jQuery.httpData(xhr, s.dataType, s.dataFilter);
					}
					catch (e) {
						status = "parsererror";
					}
				}
				if (status == "success") {
					var modRes;
					try {
						modRes = xhr.getResponseHeader("Last-Modified");
					}
					catch (e) {
					}
					if (s.ifModified && modRes) {
						jQuery.lastModified[s.url] = modRes;
					}
					if (!jsonp) {
						success();
					}
				} else {
					jQuery.handleError(s, xhr, status);
				}
				complete();
				if (s.async) {
					xhr = null;
				}
			}
		};
		if (s.async) {
			var ival = setInterval(onreadystatechange, 13);
			if (s.timeout > 0) {
				setTimeout(function () {
					if (xhr) {
						xhr.abort();
						if (!requestDone) {
							onreadystatechange("timeout");
						}
					}
				}, s.timeout);
			}
		}
		try {
			xhr.send(s.data);
		}
		catch (e) {
			jQuery.handleError(s, xhr, null, e);
		}
		if (!s.async) {
			onreadystatechange();
		}
		function success() {
			if (s.success) {
				s.success(data, status);
			}
			if (s.global) {
				jQuery.event.trigger("ajaxSuccess", [xhr, s]);
			}
		}
		function complete() {
			if (s.complete) {
				s.complete(xhr, status);
			}
			if (s.global) {
				jQuery.event.trigger("ajaxComplete", [xhr, s]);
			}
			if (s.global && !--jQuery.active) {
				jQuery.event.trigger("ajaxStop");
			}
		}
		return xhr;
	}, handleError:function (s, xhr, status, e) {
		if (s.error) {
			s.error(xhr, status, e);
		}
		if (s.global) {
			jQuery.event.trigger("ajaxError", [xhr, s, e]);
		}
	}, active:0, httpSuccess:function (xhr) {
		try {
			return !xhr.status && location.protocol == "file:" || (xhr.status >= 200 && xhr.status < 300) || xhr.status == 304 || xhr.status == 1223 || jQuery.browser.safari && xhr.status == undefined;
		}
		catch (e) {
		}
		return false;
	}, httpNotModified:function (xhr, url) {
		try {
			var xhrRes = xhr.getResponseHeader("Last-Modified");
			return xhr.status == 304 || xhrRes == jQuery.lastModified[url] || jQuery.browser.safari && xhr.status == undefined;
		}
		catch (e) {
		}
		return false;
	}, httpData:function (xhr, type, filter) {
		var ct = xhr.getResponseHeader("content-type"), xml = type == "xml" || !type && ct && ct.indexOf("xml") >= 0, data = xml ? xhr.responseXML : xhr.responseText;
		if (xml && data.documentElement.tagName == "parsererror") {
			throw "parsererror";
		}
		if (filter) {
			data = filter(data, type);
		}
		if (type == "script") {
			jQuery.globalEval(data);
		}
		if (type == "json") {
			data = eval("(" + data + ")");
		}
		return data;
	}, param:function (a) {
		var s = [];
		if (a.constructor == Array || a.jquery) {
			jQuery.each(a, function () {
				s.push(encodeURIComponent(this.name) + "=" + encodeURIComponent(this.value));
			});
		} else {
			for (var j in a) {
				if (a[j] && a[j].constructor == Array) {
					jQuery.each(a[j], function () {
						s.push(encodeURIComponent(j) + "=" + encodeURIComponent(this));
					});
				} else {
					s.push(encodeURIComponent(j) + "=" + encodeURIComponent(jQuery.isFunction(a[j]) ? a[j]() : a[j]));
				}
			}
		}
		return s.join("&").replace(/%20/g, "+");
	}});
	jQuery.fn.extend({show:function (speed, callback) {
		return speed ? this.animate({height:"show", width:"show", opacity:"show"}, speed, callback) : this.filter(":hidden").each(function () {
			this.style.display = this.oldblock || "";
			if (jQuery.css(this, "display") == "none") {
				var elem = jQuery("<" + this.tagName + " />").appendTo("body");
				this.style.display = elem.css("display");
				if (this.style.display == "none") {
					this.style.display = "block";
				}
				elem.remove();
			}
		}).end();
	}, hide:function (speed, callback) {
		return speed ? this.animate({height:"hide", width:"hide", opacity:"hide"}, speed, callback) : this.filter(":visible").each(function () {
			this.oldblock = this.oldblock || jQuery.css(this, "display");
			this.style.display = "none";
		}).end();
	}, _toggle:jQuery.fn.toggle, toggle:function (fn, fn2) {
		return jQuery.isFunction(fn) && jQuery.isFunction(fn2) ? this._toggle.apply(this, arguments) : fn ? this.animate({height:"toggle", width:"toggle", opacity:"toggle"}, fn, fn2) : this.each(function () {
			jQuery(this)[jQuery(this).is(":hidden") ? "show" : "hide"]();
		});
	}, slideDown:function (speed, callback) {
		return this.animate({height:"show"}, speed, callback);
	}, slideUp:function (speed, callback) {
		return this.animate({height:"hide"}, speed, callback);
	}, slideToggle:function (speed, callback) {
		return this.animate({height:"toggle"}, speed, callback);
	}, fadeIn:function (speed, callback) {
		return this.animate({opacity:"show"}, speed, callback);
	}, fadeOut:function (speed, callback) {
		return this.animate({opacity:"hide"}, speed, callback);
	}, fadeTo:function (speed, to, callback) {
		return this.animate({opacity:to}, speed, callback);
	}, animate:function (prop, speed, easing, callback) {
		var optall = jQuery.speed(speed, easing, callback);
		return this[optall.queue === false ? "each" : "queue"](function () {
			if (this.nodeType != 1) {
				return false;
			}
			var opt = jQuery.extend({}, optall), p, hidden = jQuery(this).is(":hidden"), self = this;
			for (p in prop) {
				if (prop[p] == "hide" && hidden || prop[p] == "show" && !hidden) {
					return opt.complete.call(this);
				}
				if (p == "height" || p == "width") {
					opt.display = jQuery.css(this, "display");
					opt.overflow = this.style.overflow;
				}
			}
			if (opt.overflow != null) {
				this.style.overflow = "hidden";
			}
			opt.curAnim = jQuery.extend({}, prop);
			jQuery.each(prop, function (name, val) {
				var e = new jQuery.fx(self, opt, name);
				if (/toggle|show|hide/.test(val)) {
					e[val == "toggle" ? hidden ? "show" : "hide" : val](prop);
				} else {
					var parts = val.toString().match(/^([+-]=)?([\d+-.]+)(.*)$/), start = e.cur(true) || 0;
					if (parts) {
						var end = parseFloat(parts[2]), unit = parts[3] || "px";
						if (unit != "px") {
							self.style[name] = (end || 1) + unit;
							start = ((end || 1) / e.cur(true)) * start;
							self.style[name] = start + unit;
						}
						if (parts[1]) {
							end = ((parts[1] == "-=" ? -1 : 1) * end) + start;
						}
						e.custom(start, end, unit);
					} else {
						e.custom(start, val, "");
					}
				}
			});
			return true;
		});
	}, queue:function (type, fn) {
		if (jQuery.isFunction(type) || (type && type.constructor == Array)) {
			fn = type;
			type = "fx";
		}
		if (!type || (typeof type == "string" && !fn)) {
			return queue(this[0], type);
		}
		return this.each(function () {
			if (fn.constructor == Array) {
				queue(this, type, fn);
			} else {
				queue(this, type).push(fn);
				if (queue(this, type).length == 1) {
					fn.call(this);
				}
			}
		});
	}, stop:function (clearQueue, gotoEnd) {
		var timers = jQuery.timers;
		if (clearQueue) {
			this.queue([]);
		}
		this.each(function () {
			for (var i = timers.length - 1; i >= 0; i--) {
				if (timers[i].elem == this) {
					if (gotoEnd) {
						timers[i](true);
					}
					timers.splice(i, 1);
				}
			}
		});
		if (!gotoEnd) {
			this.dequeue();
		}
		return this;
	}});
	var queue = function (elem, type, array) {
		if (elem) {
			type = type || "fx";
			var q = jQuery.data(elem, type + "queue");
			if (!q || array) {
				q = jQuery.data(elem, type + "queue", jQuery.makeArray(array));
			}
		}
		return q;
	};
	jQuery.fn.dequeue = function (type) {
		type = type || "fx";
		return this.each(function () {
			var q = queue(this, type);
			q.shift();
			if (q.length) {
				q[0].call(this);
			}
		});
	};
	jQuery.extend({speed:function (speed, easing, fn) {
		var opt = speed && speed.constructor == Object ? speed : {complete:fn || !fn && easing || jQuery.isFunction(speed) && speed, duration:speed, easing:fn && easing || easing && easing.constructor != Function && easing};
		opt.duration = (opt.duration && opt.duration.constructor == Number ? opt.duration : jQuery.fx.speeds[opt.duration]) || jQuery.fx.speeds.def;
		opt.old = opt.complete;
		opt.complete = function () {
			if (opt.queue !== false) {
				jQuery(this).dequeue();
			}
			if (jQuery.isFunction(opt.old)) {
				opt.old.call(this);
			}
		};
		return opt;
	}, easing:{linear:function (p, n, firstNum, diff) {
		return firstNum + diff * p;
	}, swing:function (p, n, firstNum, diff) {
		return ((-Math.cos(p * Math.PI) / 2) + 0.5) * diff + firstNum;
	}}, timers:[], timerId:null, fx:function (elem, options, prop) {
		this.options = options;
		this.elem = elem;
		this.prop = prop;
		if (!options.orig) {
			options.orig = {};
		}
	}});
	jQuery.fx.prototype = {update:function () {
		if (this.options.step) {
			this.options.step.call(this.elem, this.now, this);
		}
		(jQuery.fx.step[this.prop] || jQuery.fx.step._default)(this);
		if (this.prop == "height" || this.prop == "width") {
			this.elem.style.display = "block";
		}
	}, cur:function (force) {
		if (this.elem[this.prop] != null && this.elem.style[this.prop] == null) {
			return this.elem[this.prop];
		}
		var r = parseFloat(jQuery.css(this.elem, this.prop, force));
		return r && r > -10000 ? r : parseFloat(jQuery.curCSS(this.elem, this.prop)) || 0;
	}, custom:function (from, to, unit) {
		this.startTime = now();
		this.start = from;
		this.end = to;
		this.unit = unit || this.unit || "px";
		this.now = this.start;
		this.pos = this.state = 0;
		this.update();
		var self = this;
		function t(gotoEnd) {
			return self.step(gotoEnd);
		}
		t.elem = this.elem;
		jQuery.timers.push(t);
		if (jQuery.timerId == null) {
			jQuery.timerId = setInterval(function () {
				var timers = jQuery.timers;
				for (var i = 0; i < timers.length; i++) {
					if (!timers[i]()) {
						timers.splice(i--, 1);
					}
				}
				if (!timers.length) {
					clearInterval(jQuery.timerId);
					jQuery.timerId = null;
				}
			}, 13);
		}
	}, show:function () {
		this.options.orig[this.prop] = jQuery.attr(this.elem.style, this.prop);
		this.options.show = true;
		this.custom(0, this.cur());
		if (this.prop == "width" || this.prop == "height") {
			this.elem.style[this.prop] = "1px";
		}
		jQuery(this.elem).show();
	}, hide:function () {
		this.options.orig[this.prop] = jQuery.attr(this.elem.style, this.prop);
		this.options.hide = true;
		this.custom(this.cur(), 0);
	}, step:function (gotoEnd) {
		var t = now();
		if (gotoEnd || t > this.options.duration + this.startTime) {
			this.now = this.end;
			this.pos = this.state = 1;
			this.update();
			this.options.curAnim[this.prop] = true;
			var done = true;
			for (var i in this.options.curAnim) {
				if (this.options.curAnim[i] !== true) {
					done = false;
				}
			}
			if (done) {
				if (this.options.display != null) {
					this.elem.style.overflow = this.options.overflow;
					this.elem.style.display = this.options.display;
					if (jQuery.css(this.elem, "display") == "none") {
						this.elem.style.display = "block";
					}
				}
				if (this.options.hide) {
					this.elem.style.display = "none";
				}
				if (this.options.hide || this.options.show) {
					for (var p in this.options.curAnim) {
						jQuery.attr(this.elem.style, p, this.options.orig[p]);
					}
				}
			}
			if (done) {
				this.options.complete.call(this.elem);
			}
			return false;
		} else {
			var n = t - this.startTime;
			this.state = n / this.options.duration;
			this.pos = jQuery.easing[this.options.easing || (jQuery.easing.swing ? "swing" : "linear")](this.state, n, 0, 1, this.options.duration);
			this.now = this.start + ((this.end - this.start) * this.pos);
			this.update();
		}
		return true;
	}};
	jQuery.extend(jQuery.fx, {speeds:{slow:600, fast:200, def:400}, step:{scrollLeft:function (fx) {
		fx.elem.scrollLeft = fx.now;
	}, scrollTop:function (fx) {
		fx.elem.scrollTop = fx.now;
	}, opacity:function (fx) {
		jQuery.attr(fx.elem.style, "opacity", fx.now);
	}, _default:function (fx) {
		fx.elem.style[fx.prop] = fx.now + fx.unit;
	}}});
	jQuery.fn.offset = function () {
		var left = 0, top = 0, elem = this[0], results;
		if (elem) {
			with (jQuery.browser) {
				var parent = elem.parentNode, offsetChild = elem, offsetParent = elem.offsetParent, doc = elem.ownerDocument, safari2 = safari && parseInt(version) < 522 && !/adobeair/i.test(userAgent), css = jQuery.curCSS, fixed = css(elem, "position") == "fixed";
				if (elem.getBoundingClientRect) {
					var box = elem.getBoundingClientRect();
					add(box.left + Math.max(doc.documentElement.scrollLeft, doc.body.scrollLeft), box.top + Math.max(doc.documentElement.scrollTop, doc.body.scrollTop));
					add(-doc.documentElement.clientLeft, -doc.documentElement.clientTop);
				} else {
					add(elem.offsetLeft, elem.offsetTop);
					while (offsetParent) {
						add(offsetParent.offsetLeft, offsetParent.offsetTop);
						if (mozilla && !/^t(able|d|h)$/i.test(offsetParent.tagName) || safari && !safari2) {
							border(offsetParent);
						}
						if (!fixed && css(offsetParent, "position") == "fixed") {
							fixed = true;
						}
						offsetChild = /^body$/i.test(offsetParent.tagName) ? offsetChild : offsetParent;
						offsetParent = offsetParent.offsetParent;
					}
					while (parent && parent.tagName && !/^body|html$/i.test(parent.tagName)) {
						if (!/^inline|table.*$/i.test(css(parent, "display"))) {
							add(-parent.scrollLeft, -parent.scrollTop);
						}
						if (mozilla && css(parent, "overflow") != "visible") {
							border(parent);
						}
						parent = parent.parentNode;
					}
					if ((safari2 && (fixed || css(offsetChild, "position") == "absolute")) || (mozilla && css(offsetChild, "position") != "absolute")) {
						add(-doc.body.offsetLeft, -doc.body.offsetTop);
					}
					if (fixed) {
						add(Math.max(doc.documentElement.scrollLeft, doc.body.scrollLeft), Math.max(doc.documentElement.scrollTop, doc.body.scrollTop));
					}
				}
				results = {top:top, left:left};
			}
		}
		function border(elem) {
			add(jQuery.curCSS(elem, "borderLeftWidth", true), jQuery.curCSS(elem, "borderTopWidth", true));
		}
		function add(l, t) {
			left += parseInt(l, 10) || 0;
			top += parseInt(t, 10) || 0;
		}
		return results;
	};
	jQuery.fn.extend({position:function () {
		var left = 0, top = 0, results;
		if (this[0]) {
			var offsetParent = this.offsetParent(), offset = this.offset(), parentOffset = /^body|html$/i.test(offsetParent[0].tagName) ? {top:0, left:0} : offsetParent.offset();
			offset.top -= num(this, "marginTop");
			offset.left -= num(this, "marginLeft");
			parentOffset.top += num(offsetParent, "borderTopWidth");
			parentOffset.left += num(offsetParent, "borderLeftWidth");
			results = {top:offset.top - parentOffset.top, left:offset.left - parentOffset.left};
		}
		return results;
	}, offsetParent:function () {
		var offsetParent = this[0].offsetParent;
		while (offsetParent && (!/^body|html$/i.test(offsetParent.tagName) && jQuery.css(offsetParent, "position") == "static")) {
			offsetParent = offsetParent.offsetParent;
		}
		return jQuery(offsetParent);
	}});
	jQuery.each(["Left", "Top"], function (i, name) {
		var method = "scroll" + name;
		jQuery.fn[method] = function (val) {
			if (!this[0]) {
				return;
			}
			return val != undefined ? this.each(function () {
				this == window || this == document ? window.scrollTo(!i ? val : jQuery(window).scrollLeft(), i ? val : jQuery(window).scrollTop()) : this[method] = val;
			}) : this[0] == window || this[0] == document ? self[i ? "pageYOffset" : "pageXOffset"] || jQuery.boxModel && document.documentElement[method] || document.body[method] : this[0][method];
		};
	});
	jQuery.each(["Height", "Width"], function (i, name) {
		var tl = i ? "Left" : "Top", br = i ? "Right" : "Bottom";
		jQuery.fn["inner" + name] = function () {
			return this[name.toLowerCase()]() + num(this, "padding" + tl) + num(this, "padding" + br);
		};
		jQuery.fn["outer" + name] = function (margin) {
			return this["inner" + name]() + num(this, "border" + tl + "Width") + num(this, "border" + br + "Width") + (margin ? num(this, "margin" + tl) + num(this, "margin" + br) : 0);
		};
	});
})();

