fengjuan 4 gadi atpakaļ
vecāks
revīzija
a5c610b294
2 mainītis faili ar 8003 papildinājumiem un 79 dzēšanām
  1. 1 1
      index.html
  2. 8002 78
      skin/js/scripta.js

+ 1 - 1
index.html

@@ -239,7 +239,7 @@
 		<script type="text/html" id="FootlistTemplate">
 			<a href="{{= url}}?id={{= id }}">{{= name }}</a> <i>|</i>
 		</script>
-		<!--<script src="/skin/js/script.js"></script>-->
+		<script src="/skin/js/scripta.js"></script>
 		<script src="/skin/js/jquery.tmpl.js"></script>
 		<script type="text/javascript">
 			//页面转载完毕后启动

+ 8002 - 78
skin/js/scripta.js

@@ -1,97 +1,8021 @@
-/* global $ */
-
-$(window).load(function() {
-	preloadImagesForCarousel();
-	
-	$(".carousel").on("aCarouselHasBeenAdjusted", function() {
-		sizeChoosing();
-		chooseColor();
-		adjustIndexesOfCarousel();
-	});
-	
-	adjustAllCarousels();
-});
+/*! lywz 2018-02-06 */
+/*!
+ * jQuery JavaScript Library v1.9.1
+ * http://jquery.com/
+ *
+ * Includes Sizzle.js
+ * http://sizzlejs.com/
+ *
+ * Copyright 2005, 2012 jQuery Foundation, Inc. and other contributors
+ * Released under the MIT license
+ * http://jquery.org/license
+ *
+ * Date: 2013-2-4
+ */
+(function(window, undefined) {
+	var readyList, rootjQuery, core_strundefined = typeof undefined,
+		document = window.document,
+		location = window.location,
+		_jQuery = window.jQuery,
+		_$ = window.$,
+		class2type = {},
+		core_deletedIds = [],
+		core_version = "1.9.1",
+		core_concat = core_deletedIds.concat,
+		core_push = core_deletedIds.push,
+		core_slice = core_deletedIds.slice,
+		core_indexOf = core_deletedIds.indexOf,
+		core_toString = class2type.toString,
+		core_hasOwn = class2type.hasOwnProperty,
+		core_trim = core_version.trim,
+		jQuery = function(selector, context) {
+			return new jQuery.fn.init(selector, context, rootjQuery)
+		},
+		core_pnum = /[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,
+		core_rnotwhite = /\S+/g,
+		rtrim = /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,
+		rquickExpr = /^(?:(<[\w\W]+>)[^>]*|#([\w-]*))$/,
+		rsingleTag = /^<(\w+)\s*\/?>(?:<\/\1>|)$/,
+		rvalidchars = /^[\],:{}\s]*$/,
+		rvalidbraces = /(?:^|:|,)(?:\s*\[)+/g,
+		rvalidescape = /\\(?:["\\\/bfnrt]|u[\da-fA-F]{4})/g,
+		rvalidtokens = /"[^"\\\r\n]*"|true|false|null|-?(?:\d+\.|)\d+(?:[eE][+-]?\d+|)/g,
+		rmsPrefix = /^-ms-/,
+		rdashAlpha = /-([\da-z])/gi,
+		fcamelCase = function(all, letter) {
+			return letter.toUpperCase()
+		},
+		completed = function(event) {
+			if(document.addEventListener || event.type === "load" || document.readyState === "complete") {
+				detach();
+				jQuery.ready()
+			}
+		},
+		detach = function() {
+			if(document.addEventListener) {
+				document.removeEventListener("DOMContentLoaded", completed, false);
+				window.removeEventListener("load", completed, false)
+			} else {
+				document.detachEvent("onreadystatechange", completed);
+				window.detachEvent("onload", completed)
+			}
+		};
+	jQuery.fn = jQuery.prototype = {
+		jquery: core_version,
+		constructor: jQuery,
+		init: function(selector, context, rootjQuery) {
+			var match, elem;
+			if(!selector) {
+				return this
+			}
+			if(typeof selector === "string") {
+				if(selector.charAt(0) === "<" && selector.charAt(selector.length - 1) === ">" && selector.length >= 3) {
+					match = [null, selector, null]
+				} else {
+					match = rquickExpr.exec(selector)
+				}
+				if(match && (match[1] || !context)) {
+					if(match[1]) {
+						context = context instanceof jQuery ? context[0] : context;
+						jQuery.merge(this, jQuery.parseHTML(match[1], context && context.nodeType ? context.ownerDocument || context : document, true));
+						if(rsingleTag.test(match[1]) && jQuery.isPlainObject(context)) {
+							for(match in context) {
+								if(jQuery.isFunction(this[match])) {
+									this[match](context[match])
+								} else {
+									this.attr(match, context[match])
+								}
+							}
+						}
+						return this
+					} else {
+						elem = document.getElementById(match[2]);
+						if(elem && elem.parentNode) {
+							if(elem.id !== match[2]) {
+								return rootjQuery.find(selector)
+							}
+							this.length = 1;
+							this[0] = elem
+						}
+						this.context = document;
+						this.selector = selector;
+						return this
+					}
+				} else if(!context || context.jquery) {
+					return(context || rootjQuery).find(selector)
+				} else {
+					return this.constructor(context).find(selector)
+				}
+			} else if(selector.nodeType) {
+				this.context = this[0] = selector;
+				this.length = 1;
+				return this
+			} else if(jQuery.isFunction(selector)) {
+				return rootjQuery.ready(selector)
+			}
+			if(selector.selector !== undefined) {
+				this.selector = selector.selector;
+				this.context = selector.context
+			}
+			return jQuery.makeArray(selector, this)
+		},
+		selector: "",
+		length: 0,
+		size: function() {
+			return this.length
+		},
+		toArray: function() {
+			return core_slice.call(this)
+		},
+		get: function(num) {
+			return num == null ? this.toArray() : (num < 0 ? this[this.length + num] : this[num])
+		},
+		pushStack: function(elems) {
+			var ret = jQuery.merge(this.constructor(), elems);
+			ret.prevObject = this;
+			ret.context = this.context;
+			return ret
+		},
+		each: function(callback, args) {
+			return jQuery.each(this, callback, args)
+		},
+		ready: function(fn) {
+			jQuery.ready.promise().done(fn);
+			return this
+		},
+		slice: function() {
+			return this.pushStack(core_slice.apply(this, arguments))
+		},
+		first: function() {
+			return this.eq(0)
+		},
+		last: function() {
+			return this.eq(-1)
+		},
+		eq: function(i) {
+			var len = this.length,
+				j = +i + (i < 0 ? len : 0);
+			return this.pushStack(j >= 0 && j < len ? [this[j]] : [])
+		},
+		map: function(callback) {
+			return this.pushStack(jQuery.map(this, function(elem, i) {
+				return callback.call(elem, i, elem)
+			}))
+		},
+		end: function() {
+			return this.prevObject || this.constructor(null)
+		},
+		push: core_push,
+		sort: [].sort,
+		splice: [].splice
+	};
+	jQuery.fn.init.prototype = jQuery.fn;
+	jQuery.extend = jQuery.fn.extend = function() {
+		var src, copyIsArray, copy, name, options, clone, target = arguments[0] || {},
+			i = 1,
+			length = arguments.length,
+			deep = false;
+		if(typeof target === "boolean") {
+			deep = target;
+			target = arguments[1] || {};
+			i = 2
+		}
+		if(typeof target !== "object" && !jQuery.isFunction(target)) {
+			target = {}
+		}
+		if(length === i) {
+			target = this;
+			--i
+		}
+		for(; i < length; i++) {
+			if((options = arguments[i]) != null) {
+				for(name in options) {
+					src = target[name];
+					copy = options[name];
+					if(target === copy) {
+						continue
+					}
+					if(deep && copy && (jQuery.isPlainObject(copy) || (copyIsArray = jQuery.isArray(copy)))) {
+						if(copyIsArray) {
+							copyIsArray = false;
+							clone = src && jQuery.isArray(src) ? src : []
+						} else {
+							clone = src && jQuery.isPlainObject(src) ? src : {}
+						}
+						target[name] = jQuery.extend(deep, clone, copy)
+					} else if(copy !== undefined) {
+						target[name] = copy
+					}
+				}
+			}
+		}
+		return target
+	};
+	jQuery.extend({
+		noConflict: function(deep) {
+			if(window.$ === jQuery) {
+				window.$ = _$
+			}
+			if(deep && window.jQuery === jQuery) {
+				window.jQuery = _jQuery
+			}
+			return jQuery
+		},
+		isReady: false,
+		readyWait: 1,
+		holdReady: function(hold) {
+			if(hold) {
+				jQuery.readyWait++
+			} else {
+				jQuery.ready(true)
+			}
+		},
+		ready: function(wait) {
+			if(wait === true ? --jQuery.readyWait : jQuery.isReady) {
+				return
+			}
+			if(!document.body) {
+				return setTimeout(jQuery.ready)
+			}
+			jQuery.isReady = true;
+			if(wait !== true && --jQuery.readyWait > 0) {
+				return
+			}
+			readyList.resolveWith(document, [jQuery]);
+			if(jQuery.fn.trigger) {
+				jQuery(document).trigger("ready").off("ready")
+			}
+		},
+		isFunction: function(obj) {
+			return jQuery.type(obj) === "function"
+		},
+		isArray: Array.isArray || function(obj) {
+			return jQuery.type(obj) === "array"
+		},
+		isWindow: function(obj) {
+			return obj != null && obj == obj.window
+		},
+		isNumeric: function(obj) {
+			return !isNaN(parseFloat(obj)) && isFinite(obj)
+		},
+		type: function(obj) {
+			if(obj == null) {
+				return String(obj)
+			}
+			return typeof obj === "object" || typeof obj === "function" ? class2type[core_toString.call(obj)] || "object" : typeof obj
+		},
+		isPlainObject: function(obj) {
+			if(!obj || jQuery.type(obj) !== "object" || obj.nodeType || jQuery.isWindow(obj)) {
+				return false
+			}
+			try {
+				if(obj.constructor && !core_hasOwn.call(obj, "constructor") && !core_hasOwn.call(obj.constructor.prototype, "isPrototypeOf")) {
+					return false
+				}
+			} catch(e) {
+				return false
+			}
+			var key;
+			for(key in obj) {}
+			return key === undefined || core_hasOwn.call(obj, key)
+		},
+		isEmptyObject: function(obj) {
+			var name;
+			for(name in obj) {
+				return false
+			}
+			return true
+		},
+		error: function(msg) {
+			throw new Error(msg);
+		},
+		parseHTML: function(data, context, keepScripts) {
+			if(!data || typeof data !== "string") {
+				return null
+			}
+			if(typeof context === "boolean") {
+				keepScripts = context;
+				context = false
+			}
+			context = context || document;
+			var parsed = rsingleTag.exec(data),
+				scripts = !keepScripts && [];
+			if(parsed) {
+				return [context.createElement(parsed[1])]
+			}
+			parsed = jQuery.buildFragment([data], context, scripts);
+			if(scripts) {
+				jQuery(scripts).remove()
+			}
+			return jQuery.merge([], parsed.childNodes)
+		},
+		parseJSON: function(data) {
+			if(window.JSON && window.JSON.parse) {
+				return window.JSON.parse(data)
+			}
+			if(data === null) {
+				return data
+			}
+			if(typeof data === "string") {
+				data = jQuery.trim(data);
+				if(data) {
+					if(rvalidchars.test(data.replace(rvalidescape, "@").replace(rvalidtokens, "]").replace(rvalidbraces, ""))) {
+						return(new Function("return " + data))()
+					}
+				}
+			}
+			jQuery.error("Invalid JSON: " + data)
+		},
+		parseXML: function(data) {
+			var xml, tmp;
+			if(!data || typeof data !== "string") {
+				return null
+			}
+			try {
+				if(window.DOMParser) {
+					tmp = new DOMParser();
+					xml = tmp.parseFromString(data, "text/xml")
+				} else {
+					xml = new ActiveXObject("Microsoft.XMLDOM");
+					xml.async = "false";
+					xml.loadXML(data)
+				}
+			} catch(e) {
+				xml = undefined
+			}
+			if(!xml || !xml.documentElement || xml.getElementsByTagName("parsererror").length) {
+				jQuery.error("Invalid XML: " + data)
+			}
+			return xml
+		},
+		noop: function() {},
+		globalEval: function(data) {
+			if(data && jQuery.trim(data)) {
+				(window.execScript || function(data) {
+					window["eval"].call(window, data)
+				})(data)
+			}
+		},
+		camelCase: function(string) {
+			return string.replace(rmsPrefix, "ms-").replace(rdashAlpha, fcamelCase)
+		},
+		nodeName: function(elem, name) {
+			return elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase()
+		},
+		each: function(obj, callback, args) {
+			var value, i = 0,
+				length = obj.length,
+				isArray = isArraylike(obj);
+			if(args) {
+				if(isArray) {
+					for(; i < length; i++) {
+						value = callback.apply(obj[i], args);
+						if(value === false) {
+							break
+						}
+					}
+				} else {
+					for(i in obj) {
+						value = callback.apply(obj[i], args);
+						if(value === false) {
+							break
+						}
+					}
+				}
+			} else {
+				if(isArray) {
+					for(; i < length; i++) {
+						value = callback.call(obj[i], i, obj[i]);
+						if(value === false) {
+							break
+						}
+					}
+				} else {
+					for(i in obj) {
+						value = callback.call(obj[i], i, obj[i]);
+						if(value === false) {
+							break
+						}
+					}
+				}
+			}
+			return obj
+		},
+		trim: core_trim && !core_trim.call("\uFEFF\xA0") ? function(text) {
+			return text == null ? "" : core_trim.call(text)
+		} : function(text) {
+			return text == null ? "" : (text + "").replace(rtrim, "")
+		},
+		makeArray: function(arr, results) {
+			var ret = results || [];
+			if(arr != null) {
+				if(isArraylike(Object(arr))) {
+					jQuery.merge(ret, typeof arr === "string" ? [arr] : arr)
+				} else {
+					core_push.call(ret, arr)
+				}
+			}
+			return ret
+		},
+		inArray: function(elem, arr, i) {
+			var len;
+			if(arr) {
+				if(core_indexOf) {
+					return core_indexOf.call(arr, elem, i)
+				}
+				len = arr.length;
+				i = i ? i < 0 ? Math.max(0, len + i) : i : 0;
+				for(; i < len; i++) {
+					if(i in arr && arr[i] === elem) {
+						return i
+					}
+				}
+			}
+			return -1
+		},
+		merge: function(first, second) {
+			var l = second.length,
+				i = first.length,
+				j = 0;
+			if(typeof l === "number") {
+				for(; j < l; j++) {
+					first[i++] = second[j]
+				}
+			} else {
+				while(second[j] !== undefined) {
+					first[i++] = second[j++]
+				}
+			}
+			first.length = i;
+			return first
+		},
+		grep: function(elems, callback, inv) {
+			var retVal, ret = [],
+				i = 0,
+				length = elems.length;
+			inv = !!inv;
+			for(; i < length; i++) {
+				retVal = !!callback(elems[i], i);
+				if(inv !== retVal) {
+					ret.push(elems[i])
+				}
+			}
+			return ret
+		},
+		map: function(elems, callback, arg) {
+			var value, i = 0,
+				length = elems.length,
+				isArray = isArraylike(elems),
+				ret = [];
+			if(isArray) {
+				for(; i < length; i++) {
+					value = callback(elems[i], i, arg);
+					if(value != null) {
+						ret[ret.length] = value
+					}
+				}
+			} else {
+				for(i in elems) {
+					value = callback(elems[i], i, arg);
+					if(value != null) {
+						ret[ret.length] = value
+					}
+				}
+			}
+			return core_concat.apply([], ret)
+		},
+		guid: 1,
+		proxy: function(fn, context) {
+			var args, proxy, tmp;
+			if(typeof context === "string") {
+				tmp = fn[context];
+				context = fn;
+				fn = tmp
+			}
+			if(!jQuery.isFunction(fn)) {
+				return undefined
+			}
+			args = core_slice.call(arguments, 2);
+			proxy = function() {
+				return fn.apply(context || this, args.concat(core_slice.call(arguments)))
+			};
+			proxy.guid = fn.guid = fn.guid || jQuery.guid++;
+			return proxy
+		},
+		access: function(elems, fn, key, value, chainable, emptyGet, raw) {
+			var i = 0,
+				length = elems.length,
+				bulk = key == null;
+			if(jQuery.type(key) === "object") {
+				chainable = true;
+				for(i in key) {
+					jQuery.access(elems, fn, i, key[i], true, emptyGet, raw)
+				}
+			} else if(value !== undefined) {
+				chainable = true;
+				if(!jQuery.isFunction(value)) {
+					raw = true
+				}
+				if(bulk) {
+					if(raw) {
+						fn.call(elems, value);
+						fn = null
+					} else {
+						bulk = fn;
+						fn = function(elem, key, value) {
+							return bulk.call(jQuery(elem), value)
+						}
+					}
+				}
+				if(fn) {
+					for(; i < length; i++) {
+						fn(elems[i], key, raw ? value : value.call(elems[i], i, fn(elems[i], key)))
+					}
+				}
+			}
+			return chainable ? elems : bulk ? fn.call(elems) : length ? fn(elems[0], key) : emptyGet
+		},
+		now: function() {
+			return(new Date()).getTime()
+		}
+	});
+	jQuery.ready.promise = function(obj) {
+		if(!readyList) {
+			readyList = jQuery.Deferred();
+			if(document.readyState === "complete") {
+				setTimeout(jQuery.ready)
+			} else if(document.addEventListener) {
+				document.addEventListener("DOMContentLoaded", completed, false);
+				window.addEventListener("load", completed, false)
+			} else {
+				document.attachEvent("onreadystatechange", completed);
+				window.attachEvent("onload", completed);
+				var top = false;
+				try {
+					top = window.frameElement == null && document.documentElement
+				} catch(e) {}
+				if(top && top.doScroll) {
+					(function doScrollCheck() {
+						if(!jQuery.isReady) {
+							try {
+								top.doScroll("left")
+							} catch(e) {
+								return setTimeout(doScrollCheck, 50)
+							}
+							detach();
+							jQuery.ready()
+						}
+					})()
+				}
+			}
+		}
+		return readyList.promise(obj)
+	};
+	jQuery.each("Boolean Number String Function Array Date RegExp Object Error".split(" "), function(i, name) {
+		class2type["[object " + name + "]"] = name.toLowerCase()
+	});
 
-function sizeChoosing() {
-	$(".size .options").hide();
-	
-	$(".carousel").off("click").on("click", ".size", function() {
-		$(this).clearQueue();
-		
-		if ($(this).hasClass("shown"))
-		{
-			$(this).clearQueue().removeClass("shown").find(".options").slideUp(800);
+	function isArraylike(obj) {
+		var length = obj.length,
+			type = jQuery.type(obj);
+		if(jQuery.isWindow(obj)) {
+			return false
 		}
-		else
-		{
-			$(this).clearQueue().addClass("shown").find(".options").slideDown(800);
+		if(obj.nodeType === 1 && length) {
+			return true
+		}
+		return type === "array" || type !== "function" && (length === 0 || typeof length === "number" && length > 0 && (length - 1) in obj)
+	}
+	rootjQuery = jQuery(document);
+	var optionsCache = {};
+
+	function createOptions(options) {
+		var object = optionsCache[options] = {};
+		jQuery.each(options.match(core_rnotwhite) || [], function(_, flag) {
+			object[flag] = true
+		});
+		return object
+	}
+	jQuery.Callbacks = function(options) {
+		options = typeof options === "string" ? (optionsCache[options] || createOptions(options)) : jQuery.extend({}, options);
+		var firing, memory, fired, firingLength, firingIndex, firingStart, list = [],
+			stack = !options.once && [],
+			fire = function(data) {
+				memory = options.memory && data;
+				fired = true;
+				firingIndex = firingStart || 0;
+				firingStart = 0;
+				firingLength = list.length;
+				firing = true;
+				for(; list && firingIndex < firingLength; firingIndex++) {
+					if(list[firingIndex].apply(data[0], data[1]) === false && options.stopOnFalse) {
+						memory = false;
+						break
+					}
+				}
+				firing = false;
+				if(list) {
+					if(stack) {
+						if(stack.length) {
+							fire(stack.shift())
+						}
+					} else if(memory) {
+						list = []
+					} else {
+						self.disable()
+					}
+				}
+			},
+			self = {
+				add: function() {
+					if(list) {
+						var start = list.length;
+						(function add(args) {
+							jQuery.each(args, function(_, arg) {
+								var type = jQuery.type(arg);
+								if(type === "function") {
+									if(!options.unique || !self.has(arg)) {
+										list.push(arg)
+									}
+								} else if(arg && arg.length && type !== "string") {
+									add(arg)
+								}
+							})
+						})(arguments);
+						if(firing) {
+							firingLength = list.length
+						} else if(memory) {
+							firingStart = start;
+							fire(memory)
+						}
+					}
+					return this
+				},
+				remove: function() {
+					if(list) {
+						jQuery.each(arguments, function(_, arg) {
+							var index;
+							while((index = jQuery.inArray(arg, list, index)) > -1) {
+								list.splice(index, 1);
+								if(firing) {
+									if(index <= firingLength) {
+										firingLength--
+									}
+									if(index <= firingIndex) {
+										firingIndex--
+									}
+								}
+							}
+						})
+					}
+					return this
+				},
+				has: function(fn) {
+					return fn ? jQuery.inArray(fn, list) > -1 : !!(list && list.length)
+				},
+				empty: function() {
+					list = [];
+					return this
+				},
+				disable: function() {
+					list = stack = memory = undefined;
+					return this
+				},
+				disabled: function() {
+					return !list
+				},
+				lock: function() {
+					stack = undefined;
+					if(!memory) {
+						self.disable()
+					}
+					return this
+				},
+				locked: function() {
+					return !stack
+				},
+				fireWith: function(context, args) {
+					args = args || [];
+					args = [context, args.slice ? args.slice() : args];
+					if(list && (!fired || stack)) {
+						if(firing) {
+							stack.push(args)
+						} else {
+							fire(args)
+						}
+					}
+					return this
+				},
+				fire: function() {
+					self.fireWith(this, arguments);
+					return this
+				},
+				fired: function() {
+					return !!fired
+				}
+			};
+		return self
+	};
+	jQuery.extend({
+		Deferred: function(func) {
+			var tuples = [
+					["resolve", "done", jQuery.Callbacks("once memory"), "resolved"],
+					["reject", "fail", jQuery.Callbacks("once memory"), "rejected"],
+					["notify", "progress", jQuery.Callbacks("memory")]
+				],
+				state = "pending",
+				promise = {
+					state: function() {
+						return state
+					},
+					always: function() {
+						deferred.done(arguments).fail(arguments);
+						return this
+					},
+					then: function() {
+						var fns = arguments;
+						return jQuery.Deferred(function(newDefer) {
+							jQuery.each(tuples, function(i, tuple) {
+								var action = tuple[0],
+									fn = jQuery.isFunction(fns[i]) && fns[i];
+								deferred[tuple[1]](function() {
+									var returned = fn && fn.apply(this, arguments);
+									if(returned && jQuery.isFunction(returned.promise)) {
+										returned.promise().done(newDefer.resolve).fail(newDefer.reject).progress(newDefer.notify)
+									} else {
+										newDefer[action + "With"](this === promise ? newDefer.promise() : this, fn ? [returned] : arguments)
+									}
+								})
+							});
+							fns = null
+						}).promise()
+					},
+					promise: function(obj) {
+						return obj != null ? jQuery.extend(obj, promise) : promise
+					}
+				},
+				deferred = {};
+			promise.pipe = promise.then;
+			jQuery.each(tuples, function(i, tuple) {
+				var list = tuple[2],
+					stateString = tuple[3];
+				promise[tuple[1]] = list.add;
+				if(stateString) {
+					list.add(function() {
+						state = stateString
+					}, tuples[i ^ 1][2].disable, tuples[2][2].lock)
+				}
+				deferred[tuple[0]] = function() {
+					deferred[tuple[0] + "With"](this === deferred ? promise : this, arguments);
+					return this
+				};
+				deferred[tuple[0] + "With"] = list.fireWith
+			});
+			promise.promise(deferred);
+			if(func) {
+				func.call(deferred, deferred)
+			}
+			return deferred
+		},
+		when: function(subordinate) {
+			var i = 0,
+				resolveValues = core_slice.call(arguments),
+				length = resolveValues.length,
+				remaining = length !== 1 || (subordinate && jQuery.isFunction(subordinate.promise)) ? length : 0,
+				deferred = remaining === 1 ? subordinate : jQuery.Deferred(),
+				updateFunc = function(i, contexts, values) {
+					return function(value) {
+						contexts[i] = this;
+						values[i] = arguments.length > 1 ? core_slice.call(arguments) : value;
+						if(values === progressValues) {
+							deferred.notifyWith(contexts, values)
+						} else if(!(--remaining)) {
+							deferred.resolveWith(contexts, values)
+						}
+					}
+				},
+				progressValues, progressContexts, resolveContexts;
+			if(length > 1) {
+				progressValues = new Array(length);
+				progressContexts = new Array(length);
+				resolveContexts = new Array(length);
+				for(; i < length; i++) {
+					if(resolveValues[i] && jQuery.isFunction(resolveValues[i].promise)) {
+						resolveValues[i].promise().done(updateFunc(i, resolveContexts, resolveValues)).fail(deferred.reject).progress(updateFunc(i, progressContexts, progressValues))
+					} else {
+						--remaining
+					}
+				}
+			}
+			if(!remaining) {
+				deferred.resolveWith(resolveContexts, resolveValues)
+			}
+			return deferred.promise()
 		}
 	});
-	
-	$(".carousel").on("click", ".option", function() {
-		$(this).closest(".size").find(".header .number").html($(this).text());
+	jQuery.support = (function() {
+		var support, all, a, input, select, fragment, opt, eventName, isSupported, i, div = document.createElement("div");
+		div.setAttribute("className", "t");
+		div.innerHTML = "  <link/><table></table><a href='/a'>a</a><input type='checkbox'/>";
+		all = div.getElementsByTagName("*");
+		a = div.getElementsByTagName("a")[0];
+		if(!all || !a || !all.length) {
+			return {}
+		}
+		select = document.createElement("select");
+		opt = select.appendChild(document.createElement("option"));
+		input = div.getElementsByTagName("input")[0];
+		a.style.cssText = "top:1px;float:left;opacity:.5";
+		support = {
+			getSetAttribute: div.className !== "t",
+			leadingWhitespace: div.firstChild.nodeType === 3,
+			tbody: !div.getElementsByTagName("tbody").length,
+			htmlSerialize: !!div.getElementsByTagName("link").length,
+			style: /top/.test(a.getAttribute("style")),
+			hrefNormalized: a.getAttribute("href") === "/a",
+			opacity: /^0.5/.test(a.style.opacity),
+			cssFloat: !!a.style.cssFloat,
+			checkOn: !!input.value,
+			optSelected: opt.selected,
+			enctype: !!document.createElement("form").enctype,
+			html5Clone: document.createElement("nav").cloneNode(true).outerHTML !== "<:nav></:nav>",
+			boxModel: document.compatMode === "CSS1Compat",
+			deleteExpando: true,
+			noCloneEvent: true,
+			inlineBlockNeedsLayout: false,
+			shrinkWrapBlocks: false,
+			reliableMarginRight: true,
+			boxSizingReliable: true,
+			pixelPosition: false
+		};
+		input.checked = true;
+		support.noCloneChecked = input.cloneNode(true).checked;
+		select.disabled = true;
+		support.optDisabled = !opt.disabled;
+		try {
+			delete div.test
+		} catch(e) {
+			support.deleteExpando = false
+		}
+		input = document.createElement("input");
+		input.setAttribute("value", "");
+		support.input = input.getAttribute("value") === "";
+		input.value = "t";
+		input.setAttribute("type", "radio");
+		support.radioValue = input.value === "t";
+		input.setAttribute("checked", "t");
+		input.setAttribute("name", "t");
+		fragment = document.createDocumentFragment();
+		fragment.appendChild(input);
+		support.appendChecked = input.checked;
+		support.checkClone = fragment.cloneNode(true).cloneNode(true).lastChild.checked;
+		if(div.attachEvent) {
+			div.attachEvent("onclick", function() {
+				support.noCloneEvent = false
+			});
+			div.cloneNode(true).click()
+		}
+		for(i in {
+				submit: true,
+				change: true,
+				focusin: true
+			}) {
+			div.setAttribute(eventName = "on" + i, "t");
+			support[i + "Bubbles"] = eventName in window || div.attributes[eventName].expando === false
+		}
+		div.style.backgroundClip = "content-box";
+		div.cloneNode(true).style.backgroundClip = "";
+		support.clearCloneStyle = div.style.backgroundClip === "content-box";
+		jQuery(function() {
+			var container, marginDiv, tds, divReset = "padding:0;margin:0;border:0;display:block;box-sizing:content-box;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;",
+				body = document.getElementsByTagName("body")[0];
+			if(!body) {
+				return
+			}
+			container = document.createElement("div");
+			container.style.cssText = "border:0;width:0;height:0;position:absolute;top:0;left:-9999px;margin-top:1px";
+			body.appendChild(container).appendChild(div);
+			div.innerHTML = "<table><tr><td></td><td>t</td></tr></table>";
+			tds = div.getElementsByTagName("td");
+			tds[0].style.cssText = "padding:0;margin:0;border:0;display:none";
+			isSupported = (tds[0].offsetHeight === 0);
+			tds[0].style.display = "";
+			tds[1].style.display = "none";
+			support.reliableHiddenOffsets = isSupported && (tds[0].offsetHeight === 0);
+			div.innerHTML = "";
+			div.style.cssText = "box-sizing:border-box;-moz-box-sizing:border-box;-webkit-box-sizing:border-box;padding:1px;border:1px;display:block;width:4px;margin-top:1%;position:absolute;top:1%;";
+			support.boxSizing = (div.offsetWidth === 4);
+			support.doesNotIncludeMarginInBodyOffset = (body.offsetTop !== 1);
+			if(window.getComputedStyle) {
+				support.pixelPosition = (window.getComputedStyle(div, null) || {}).top !== "1%";
+				support.boxSizingReliable = (window.getComputedStyle(div, null) || {
+					width: "4px"
+				}).width === "4px";
+				marginDiv = div.appendChild(document.createElement("div"));
+				marginDiv.style.cssText = div.style.cssText = divReset;
+				marginDiv.style.marginRight = marginDiv.style.width = "0";
+				div.style.width = "1px";
+				support.reliableMarginRight = !parseFloat((window.getComputedStyle(marginDiv, null) || {}).marginRight)
+			}
+			if(typeof div.style.zoom !== core_strundefined) {
+				div.innerHTML = "";
+				div.style.cssText = divReset + "width:1px;padding:1px;display:inline;zoom:1";
+				support.inlineBlockNeedsLayout = (div.offsetWidth === 3);
+				div.style.display = "block";
+				div.innerHTML = "<div></div>";
+				div.firstChild.style.width = "5px";
+				support.shrinkWrapBlocks = (div.offsetWidth !== 3);
+				if(support.inlineBlockNeedsLayout) {
+					body.style.zoom = 1
+				}
+			}
+			body.removeChild(container);
+			container = div = tds = marginDiv = null
+		});
+		all = select = fragment = opt = a = input = null;
+		return support
+	})();
+	var rbrace = /(?:\{[\s\S]*\}|\[[\s\S]*\])$/,
+		rmultiDash = /([A-Z])/g;
+
+	function internalData(elem, name, data, pvt) {
+		if(!jQuery.acceptData(elem)) {
+			return
+		}
+		var thisCache, ret, internalKey = jQuery.expando,
+			getByName = typeof name === "string",
+			isNode = elem.nodeType,
+			cache = isNode ? jQuery.cache : elem,
+			id = isNode ? elem[internalKey] : elem[internalKey] && internalKey;
+		if((!id || !cache[id] || (!pvt && !cache[id].data)) && getByName && data === undefined) {
+			return
+		}
+		if(!id) {
+			if(isNode) {
+				elem[internalKey] = id = core_deletedIds.pop() || jQuery.guid++
+			} else {
+				id = internalKey
+			}
+		}
+		if(!cache[id]) {
+			cache[id] = {};
+			if(!isNode) {
+				cache[id].toJSON = jQuery.noop
+			}
+		}
+		if(typeof name === "object" || typeof name === "function") {
+			if(pvt) {
+				cache[id] = jQuery.extend(cache[id], name)
+			} else {
+				cache[id].data = jQuery.extend(cache[id].data, name)
+			}
+		}
+		thisCache = cache[id];
+		if(!pvt) {
+			if(!thisCache.data) {
+				thisCache.data = {}
+			}
+			thisCache = thisCache.data
+		}
+		if(data !== undefined) {
+			thisCache[jQuery.camelCase(name)] = data
+		}
+		if(getByName) {
+			ret = thisCache[name];
+			if(ret == null) {
+				ret = thisCache[jQuery.camelCase(name)]
+			}
+		} else {
+			ret = thisCache
+		}
+		return ret
+	}
+
+	function internalRemoveData(elem, name, pvt) {
+		if(!jQuery.acceptData(elem)) {
+			return
+		}
+		var i, l, thisCache, isNode = elem.nodeType,
+			cache = isNode ? jQuery.cache : elem,
+			id = isNode ? elem[jQuery.expando] : jQuery.expando;
+		if(!cache[id]) {
+			return
+		}
+		if(name) {
+			thisCache = pvt ? cache[id] : cache[id].data;
+			if(thisCache) {
+				if(!jQuery.isArray(name)) {
+					if(name in thisCache) {
+						name = [name]
+					} else {
+						name = jQuery.camelCase(name);
+						if(name in thisCache) {
+							name = [name]
+						} else {
+							name = name.split(" ")
+						}
+					}
+				} else {
+					name = name.concat(jQuery.map(name, jQuery.camelCase))
+				}
+				for(i = 0, l = name.length; i < l; i++) {
+					delete thisCache[name[i]]
+				}
+				if(!(pvt ? isEmptyDataObject : jQuery.isEmptyObject)(thisCache)) {
+					return
+				}
+			}
+		}
+		if(!pvt) {
+			delete cache[id].data;
+			if(!isEmptyDataObject(cache[id])) {
+				return
+			}
+		}
+		if(isNode) {
+			jQuery.cleanData([elem], true)
+		} else if(jQuery.support.deleteExpando || cache != cache.window) {
+			delete cache[id]
+		} else {
+			cache[id] = null
+		}
+	}
+	jQuery.extend({
+		cache: {},
+		expando: "jQuery" + (core_version + Math.random()).replace(/\D/g, ""),
+		noData: {
+			"embed": true,
+			"object": "clsid:D27CDB6E-AE6D-11cf-96B8-444553540000",
+			"applet": true
+		},
+		hasData: function(elem) {
+			elem = elem.nodeType ? jQuery.cache[elem[jQuery.expando]] : elem[jQuery.expando];
+			return !!elem && !isEmptyDataObject(elem)
+		},
+		data: function(elem, name, data) {
+			return internalData(elem, name, data)
+		},
+		removeData: function(elem, name) {
+			return internalRemoveData(elem, name)
+		},
+		_data: function(elem, name, data) {
+			return internalData(elem, name, data, true)
+		},
+		_removeData: function(elem, name) {
+			return internalRemoveData(elem, name, true)
+		},
+		acceptData: function(elem) {
+			if(elem.nodeType && elem.nodeType !== 1 && elem.nodeType !== 9) {
+				return false
+			}
+			var noData = elem.nodeName && jQuery.noData[elem.nodeName.toLowerCase()];
+			return !noData || noData !== true && elem.getAttribute("classid") === noData
+		}
 	});
-}
+	jQuery.fn.extend({
+		data: function(key, value) {
+			var attrs, name, elem = this[0],
+				i = 0,
+				data = null;
+			if(key === undefined) {
+				if(this.length) {
+					data = jQuery.data(elem);
+					if(elem.nodeType === 1 && !jQuery._data(elem, "parsedAttrs")) {
+						attrs = elem.attributes;
+						for(; i < attrs.length; i++) {
+							name = attrs[i].name;
+							if(!name.indexOf("data-")) {
+								name = jQuery.camelCase(name.slice(5));
+								dataAttr(elem, name, data[name])
+							}
+						}
+						jQuery._data(elem, "parsedAttrs", true)
+					}
+				}
+				return data
+			}
+			if(typeof key === "object") {
+				return this.each(function() {
+					jQuery.data(this, key)
+				})
+			}
+			return jQuery.access(this, function(value) {
+				if(value === undefined) {
+					return elem ? dataAttr(elem, key, jQuery.data(elem, key)) : null
+				}
+				this.each(function() {
+					jQuery.data(this, key, value)
+				})
+			}, null, value, arguments.length > 1, null, true)
+		},
+		removeData: function(key) {
+			return this.each(function() {
+				jQuery.removeData(this, key)
+			})
+		}
+	});
+
+	function dataAttr(elem, key, data) {
+		if(data === undefined && elem.nodeType === 1) {
+			var name = "data-" + key.replace(rmultiDash, "-$1").toLowerCase();
+			data = elem.getAttribute(name);
+			if(typeof data === "string") {
+				try {
+					data = data === "true" ? true : data === "false" ? false : data === "null" ? null : +data + "" === data ? +data : rbrace.test(data) ? jQuery.parseJSON(data) : data
+				} catch(e) {}
+				jQuery.data(elem, key, data)
+			} else {
+				data = undefined
+			}
+		}
+		return data
+	}
 
-function chooseColor() {
-	$(".carousel").on("click", ".choose-color div", function() {
-		var img_path = findPathToDirectory($(this).closest(".flex-item").find(".good-image img").attr("src")) + $(this).attr("class") + ".png";
-		
-		$(this).closest(".flex-item").find(".good-image img").stop().fadeTo("slow", 0, function() {
-			$(this).attr("src", img_path);
-		}).fadeTo("slow", 1);
+	function isEmptyDataObject(obj) {
+		var name;
+		for(name in obj) {
+			if(name === "data" && jQuery.isEmptyObject(obj[name])) {
+				continue
+			}
+			if(name !== "toJSON") {
+				return false
+			}
+		}
+		return true
+	}
+	jQuery.extend({
+		queue: function(elem, type, data) {
+			var queue;
+			if(elem) {
+				type = (type || "fx") + "queue";
+				queue = jQuery._data(elem, type);
+				if(data) {
+					if(!queue || jQuery.isArray(data)) {
+						queue = jQuery._data(elem, type, jQuery.makeArray(data))
+					} else {
+						queue.push(data)
+					}
+				}
+				return queue || []
+			}
+		},
+		dequeue: function(elem, type) {
+			type = type || "fx";
+			var queue = jQuery.queue(elem, type),
+				startLength = queue.length,
+				fn = queue.shift(),
+				hooks = jQuery._queueHooks(elem, type),
+				next = function() {
+					jQuery.dequeue(elem, type)
+				};
+			if(fn === "inprogress") {
+				fn = queue.shift();
+				startLength--
+			}
+			hooks.cur = fn;
+			if(fn) {
+				if(type === "fx") {
+					queue.unshift("inprogress")
+				}
+				delete hooks.stop;
+				fn.call(elem, next, hooks)
+			}
+			if(!startLength && hooks) {
+				hooks.empty.fire()
+			}
+		},
+		_queueHooks: function(elem, type) {
+			var key = type + "queueHooks";
+			return jQuery._data(elem, key) || jQuery._data(elem, key, {
+				empty: jQuery.Callbacks("once memory").add(function() {
+					jQuery._removeData(elem, type + "queue");
+					jQuery._removeData(elem, key)
+				})
+			})
+		}
 	});
-}
+	jQuery.fn.extend({
+		queue: function(type, data) {
+			var setter = 2;
+			if(typeof type !== "string") {
+				data = type;
+				type = "fx";
+				setter--
+			}
+			if(arguments.length < setter) {
+				return jQuery.queue(this[0], type)
+			}
+			return data === undefined ? this : this.each(function() {
+				var queue = jQuery.queue(this, type, data);
+				jQuery._queueHooks(this, type);
+				if(type === "fx" && queue[0] !== "inprogress") {
+					jQuery.dequeue(this, type)
+				}
+			})
+		},
+		dequeue: function(type) {
+			return this.each(function() {
+				jQuery.dequeue(this, type)
+			})
+		},
+		delay: function(time, type) {
+			time = jQuery.fx ? jQuery.fx.speeds[time] || time : time;
+			type = type || "fx";
+			return this.queue(type, function(next, hooks) {
+				var timeout = setTimeout(next, time);
+				hooks.stop = function() {
+					clearTimeout(timeout)
+				}
+			})
+		},
+		clearQueue: function(type) {
+			return this.queue(type || "fx", [])
+		},
+		promise: function(type, obj) {
+			var tmp, count = 1,
+				defer = jQuery.Deferred(),
+				elements = this,
+				i = this.length,
+				resolve = function() {
+					if(!(--count)) {
+						defer.resolveWith(elements, [elements])
+					}
+				};
+			if(typeof type !== "string") {
+				obj = type;
+				type = undefined
+			}
+			type = type || "fx";
+			while(i--) {
+				tmp = jQuery._data(elements[i], type + "queueHooks");
+				if(tmp && tmp.empty) {
+					count++;
+					tmp.empty.add(resolve)
+				}
+			}
+			resolve();
+			return defer.promise(obj)
+		}
+	});
+	var nodeHook, boolHook, rclass = /[\t\r\n]/g,
+		rreturn = /\r/g,
+		rfocusable = /^(?:input|select|textarea|button|object)$/i,
+		rclickable = /^(?:a|area)$/i,
+		rboolean = /^(?:checked|selected|autofocus|autoplay|async|controls|defer|disabled|hidden|loop|multiple|open|readonly|required|scoped)$/i,
+		ruseDefault = /^(?:checked|selected)$/i,
+		getSetAttribute = jQuery.support.getSetAttribute,
+		getSetInput = jQuery.support.input;
+	jQuery.fn.extend({
+		attr: function(name, value) {
+			return jQuery.access(this, jQuery.attr, name, value, arguments.length > 1)
+		},
+		removeAttr: function(name) {
+			return this.each(function() {
+				jQuery.removeAttr(this, name)
+			})
+		},
+		prop: function(name, value) {
+			return jQuery.access(this, jQuery.prop, name, value, arguments.length > 1)
+		},
+		removeProp: function(name) {
+			name = jQuery.propFix[name] || name;
+			return this.each(function() {
+				try {
+					this[name] = undefined;
+					delete this[name]
+				} catch(e) {}
+			})
+		},
+		addClass: function(value) {
+			var classes, elem, cur, clazz, j, i = 0,
+				len = this.length,
+				proceed = typeof value === "string" && value;
+			if(jQuery.isFunction(value)) {
+				return this.each(function(j) {
+					jQuery(this).addClass(value.call(this, j, this.className))
+				})
+			}
+			if(proceed) {
+				classes = (value || "").match(core_rnotwhite) || [];
+				for(; i < len; i++) {
+					elem = this[i];
+					cur = elem.nodeType === 1 && (elem.className ? (" " + elem.className + " ").replace(rclass, " ") : " ");
+					if(cur) {
+						j = 0;
+						while((clazz = classes[j++])) {
+							if(cur.indexOf(" " + clazz + " ") < 0) {
+								cur += clazz + " "
+							}
+						}
+						elem.className = jQuery.trim(cur)
+					}
+				}
+			}
+			return this
+		},
+		removeClass: function(value) {
+			var classes, elem, cur, clazz, j, i = 0,
+				len = this.length,
+				proceed = arguments.length === 0 || typeof value === "string" && value;
+			if(jQuery.isFunction(value)) {
+				return this.each(function(j) {
+					jQuery(this).removeClass(value.call(this, j, this.className))
+				})
+			}
+			if(proceed) {
+				classes = (value || "").match(core_rnotwhite) || [];
+				for(; i < len; i++) {
+					elem = this[i];
+					cur = elem.nodeType === 1 && (elem.className ? (" " + elem.className + " ").replace(rclass, " ") : "");
+					if(cur) {
+						j = 0;
+						while((clazz = classes[j++])) {
+							while(cur.indexOf(" " + clazz + " ") >= 0) {
+								cur = cur.replace(" " + clazz + " ", " ")
+							}
+						}
+						elem.className = value ? jQuery.trim(cur) : ""
+					}
+				}
+			}
+			return this
+		},
+		toggleClass: function(value, stateVal) {
+			var type = typeof value,
+				isBool = typeof stateVal === "boolean";
+			if(jQuery.isFunction(value)) {
+				return this.each(function(i) {
+					jQuery(this).toggleClass(value.call(this, i, this.className, stateVal), stateVal)
+				})
+			}
+			return this.each(function() {
+				if(type === "string") {
+					var className, i = 0,
+						self = jQuery(this),
+						state = stateVal,
+						classNames = value.match(core_rnotwhite) || [];
+					while((className = classNames[i++])) {
+						state = isBool ? state : !self.hasClass(className);
+						self[state ? "addClass" : "removeClass"](className)
+					}
+				} else if(type === core_strundefined || type === "boolean") {
+					if(this.className) {
+						jQuery._data(this, "__className__", this.className)
+					}
+					this.className = this.className || value === false ? "" : jQuery._data(this, "__className__") || ""
+				}
+			})
+		},
+		hasClass: function(selector) {
+			var className = " " + selector + " ",
+				i = 0,
+				l = this.length;
+			for(; i < l; i++) {
+				if(this[i].nodeType === 1 && (" " + this[i].className + " ").replace(rclass, " ").indexOf(className) >= 0) {
+					return true
+				}
+			}
+			return false
+		},
+		val: function(value) {
+			var ret, hooks, isFunction, elem = this[0];
+			if(!arguments.length) {
+				if(elem) {
+					hooks = jQuery.valHooks[elem.type] || jQuery.valHooks[elem.nodeName.toLowerCase()];
+					if(hooks && "get" in hooks && (ret = hooks.get(elem, "value")) !== undefined) {
+						return ret
+					}
+					ret = elem.value;
+					return typeof ret === "string" ? ret.replace(rreturn, "") : ret == null ? "" : ret
+				}
+				return
+			}
+			isFunction = jQuery.isFunction(value);
+			return this.each(function(i) {
+				var val, self = jQuery(this);
+				if(this.nodeType !== 1) {
+					return
+				}
+				if(isFunction) {
+					val = value.call(this, i, self.val())
+				} else {
+					val = value
+				}
+				if(val == null) {
+					val = ""
+				} else if(typeof val === "number") {
+					val += ""
+				} else if(jQuery.isArray(val)) {
+					val = jQuery.map(val, function(value) {
+						return value == null ? "" : value + ""
+					})
+				}
+				hooks = jQuery.valHooks[this.type] || jQuery.valHooks[this.nodeName.toLowerCase()];
+				if(!hooks || !("set" in hooks) || hooks.set(this, val, "value") === undefined) {
+					this.value = val
+				}
+			})
+		}
+	});
+	jQuery.extend({
+		valHooks: {
+			option: {
+				get: function(elem) {
+					var val = elem.attributes.value;
+					return !val || val.specified ? elem.value : elem.text
+				}
+			},
+			select: {
+				get: function(elem) {
+					var value, option, options = elem.options,
+						index = elem.selectedIndex,
+						one = elem.type === "select-one" || index < 0,
+						values = one ? null : [],
+						max = one ? index + 1 : options.length,
+						i = index < 0 ? max : one ? index : 0;
+					for(; i < max; i++) {
+						option = options[i];
+						if((option.selected || i === index) && (jQuery.support.optDisabled ? !option.disabled : option.getAttribute("disabled") === null) && (!option.parentNode.disabled || !jQuery.nodeName(option.parentNode, "optgroup"))) {
+							value = jQuery(option).val();
+							if(one) {
+								return value
+							}
+							values.push(value)
+						}
+					}
+					return values
+				},
+				set: function(elem, value) {
+					var values = jQuery.makeArray(value);
+					jQuery(elem).find("option").each(function() {
+						this.selected = jQuery.inArray(jQuery(this).val(), values) >= 0
+					});
+					if(!values.length) {
+						elem.selectedIndex = -1
+					}
+					return values
+				}
+			}
+		},
+		attr: function(elem, name, value) {
+			var hooks, notxml, ret, nType = elem.nodeType;
+			if(!elem || nType === 3 || nType === 8 || nType === 2) {
+				return
+			}
+			if(typeof elem.getAttribute === core_strundefined) {
+				return jQuery.prop(elem, name, value)
+			}
+			notxml = nType !== 1 || !jQuery.isXMLDoc(elem);
+			if(notxml) {
+				name = name.toLowerCase();
+				hooks = jQuery.attrHooks[name] || (rboolean.test(name) ? boolHook : nodeHook)
+			}
+			if(value !== undefined) {
+				if(value === null) {
+					jQuery.removeAttr(elem, name)
+				} else if(hooks && notxml && "set" in hooks && (ret = hooks.set(elem, value, name)) !== undefined) {
+					return ret
+				} else {
+					elem.setAttribute(name, value + "");
+					return value
+				}
+			} else if(hooks && notxml && "get" in hooks && (ret = hooks.get(elem, name)) !== null) {
+				return ret
+			} else {
+				if(typeof elem.getAttribute !== core_strundefined) {
+					ret = elem.getAttribute(name)
+				}
+				return ret == null ? undefined : ret
+			}
+		},
+		removeAttr: function(elem, value) {
+			var name, propName, i = 0,
+				attrNames = value && value.match(core_rnotwhite);
+			if(attrNames && elem.nodeType === 1) {
+				while((name = attrNames[i++])) {
+					propName = jQuery.propFix[name] || name;
+					if(rboolean.test(name)) {
+						if(!getSetAttribute && ruseDefault.test(name)) {
+							elem[jQuery.camelCase("default-" + name)] = elem[propName] = false
+						} else {
+							elem[propName] = false
+						}
+					} else {
+						jQuery.attr(elem, name, "")
+					}
+					elem.removeAttribute(getSetAttribute ? name : propName)
+				}
+			}
+		},
+		attrHooks: {
+			type: {
+				set: function(elem, value) {
+					if(!jQuery.support.radioValue && value === "radio" && jQuery.nodeName(elem, "input")) {
+						var val = elem.value;
+						elem.setAttribute("type", value);
+						if(val) {
+							elem.value = val
+						}
+						return value
+					}
+				}
+			}
+		},
+		propFix: {
+			tabindex: "tabIndex",
+			readonly: "readOnly",
+			"for": "htmlFor",
+			"class": "className",
+			maxlength: "maxLength",
+			cellspacing: "cellSpacing",
+			cellpadding: "cellPadding",
+			rowspan: "rowSpan",
+			colspan: "colSpan",
+			usemap: "useMap",
+			frameborder: "frameBorder",
+			contenteditable: "contentEditable"
+		},
+		prop: function(elem, name, value) {
+			var ret, hooks, notxml, nType = elem.nodeType;
+			if(!elem || nType === 3 || nType === 8 || nType === 2) {
+				return
+			}
+			notxml = nType !== 1 || !jQuery.isXMLDoc(elem);
+			if(notxml) {
+				name = jQuery.propFix[name] || name;
+				hooks = jQuery.propHooks[name]
+			}
+			if(value !== undefined) {
+				if(hooks && "set" in hooks && (ret = hooks.set(elem, value, name)) !== undefined) {
+					return ret
+				} else {
+					return(elem[name] = value)
+				}
+			} else {
+				if(hooks && "get" in hooks && (ret = hooks.get(elem, name)) !== null) {
+					return ret
+				} else {
+					return elem[name]
+				}
+			}
+		},
+		propHooks: {
+			tabIndex: {
+				get: function(elem) {
+					var attributeNode = elem.getAttributeNode("tabindex");
+					return attributeNode && attributeNode.specified ? parseInt(attributeNode.value, 10) : rfocusable.test(elem.nodeName) || rclickable.test(elem.nodeName) && elem.href ? 0 : undefined
+				}
+			}
+		}
+	});
+	boolHook = {
+		get: function(elem, name) {
+			var prop = jQuery.prop(elem, name),
+				attr = typeof prop === "boolean" && elem.getAttribute(name),
+				detail = typeof prop === "boolean" ? getSetInput && getSetAttribute ? attr != null : ruseDefault.test(name) ? elem[jQuery.camelCase("default-" + name)] : !!attr : elem.getAttributeNode(name);
+			return detail && detail.value !== false ? name.toLowerCase() : undefined
+		},
+		set: function(elem, value, name) {
+			if(value === false) {
+				jQuery.removeAttr(elem, name)
+			} else if(getSetInput && getSetAttribute || !ruseDefault.test(name)) {
+				elem.setAttribute(!getSetAttribute && jQuery.propFix[name] || name, name)
+			} else {
+				elem[jQuery.camelCase("default-" + name)] = elem[name] = true
+			}
+			return name
+		}
+	};
+	if(!getSetInput || !getSetAttribute) {
+		jQuery.attrHooks.value = {
+			get: function(elem, name) {
+				var ret = elem.getAttributeNode(name);
+				return jQuery.nodeName(elem, "input") ? elem.defaultValue : ret && ret.specified ? ret.value : undefined
+			},
+			set: function(elem, value, name) {
+				if(jQuery.nodeName(elem, "input")) {
+					elem.defaultValue = value
+				} else {
+					return nodeHook && nodeHook.set(elem, value, name)
+				}
+			}
+		}
+	}
+	if(!getSetAttribute) {
+		nodeHook = jQuery.valHooks.button = {
+			get: function(elem, name) {
+				var ret = elem.getAttributeNode(name);
+				return ret && (name === "id" || name === "name" || name === "coords" ? ret.value !== "" : ret.specified) ? ret.value : undefined
+			},
+			set: function(elem, value, name) {
+				var ret = elem.getAttributeNode(name);
+				if(!ret) {
+					elem.setAttributeNode((ret = elem.ownerDocument.createAttribute(name)))
+				}
+				ret.value = value += "";
+				return name === "value" || value === elem.getAttribute(name) ? value : undefined
+			}
+		};
+		jQuery.attrHooks.contenteditable = {
+			get: nodeHook.get,
+			set: function(elem, value, name) {
+				nodeHook.set(elem, value === "" ? false : value, name)
+			}
+		};
+		jQuery.each(["width", "height"], function(i, name) {
+			jQuery.attrHooks[name] = jQuery.extend(jQuery.attrHooks[name], {
+				set: function(elem, value) {
+					if(value === "") {
+						elem.setAttribute(name, "auto");
+						return value
+					}
+				}
+			})
+		})
+	}
+	if(!jQuery.support.hrefNormalized) {
+		jQuery.each(["href", "src", "width", "height"], function(i, name) {
+			jQuery.attrHooks[name] = jQuery.extend(jQuery.attrHooks[name], {
+				get: function(elem) {
+					var ret = elem.getAttribute(name, 2);
+					return ret == null ? undefined : ret
+				}
+			})
+		});
+		jQuery.each(["href", "src"], function(i, name) {
+			jQuery.propHooks[name] = {
+				get: function(elem) {
+					return elem.getAttribute(name, 4)
+				}
+			}
+		})
+	}
+	if(!jQuery.support.style) {
+		jQuery.attrHooks.style = {
+			get: function(elem) {
+				return elem.style.cssText || undefined
+			},
+			set: function(elem, value) {
+				return(elem.style.cssText = value + "")
+			}
+		}
+	}
+	if(!jQuery.support.optSelected) {
+		jQuery.propHooks.selected = jQuery.extend(jQuery.propHooks.selected, {
+			get: function(elem) {
+				var parent = elem.parentNode;
+				if(parent) {
+					parent.selectedIndex;
+					if(parent.parentNode) {
+						parent.parentNode.selectedIndex
+					}
+				}
+				return null
+			}
+		})
+	}
+	if(!jQuery.support.enctype) {
+		jQuery.propFix.enctype = "encoding"
+	}
+	if(!jQuery.support.checkOn) {
+		jQuery.each(["radio", "checkbox"], function() {
+			jQuery.valHooks[this] = {
+				get: function(elem) {
+					return elem.getAttribute("value") === null ? "on" : elem.value
+				}
+			}
+		})
+	}
+	jQuery.each(["radio", "checkbox"], function() {
+		jQuery.valHooks[this] = jQuery.extend(jQuery.valHooks[this], {
+			set: function(elem, value) {
+				if(jQuery.isArray(value)) {
+					return(elem.checked = jQuery.inArray(jQuery(elem).val(), value) >= 0)
+				}
+			}
+		})
+	});
+	var rformElems = /^(?:input|select|textarea)$/i,
+		rkeyEvent = /^key/,
+		rmouseEvent = /^(?:mouse|contextmenu)|click/,
+		rfocusMorph = /^(?:focusinfocus|focusoutblur)$/,
+		rtypenamespace = /^([^.]*)(?:\.(.+)|)$/;
 
-function findPathToDirectory(path_to_file) {
-	return path_to_file.slice(0, path_to_file.lastIndexOf("/") + 1);
-}
+	function returnTrue() {
+		return true
+	}
 
-function adjustIndexesOfCarousel() {
-	$(".carousel").each(function() {
-		setupIndexesOfCarousel($(this));
+	function returnFalse() {
+		return false
+	}
+	jQuery.event = {
+		global: {},
+		add: function(elem, types, handler, data, selector) {
+			var tmp, events, t, handleObjIn, special, eventHandle, handleObj, handlers, type, namespaces, origType, elemData = jQuery._data(elem);
+			if(!elemData) {
+				return
+			}
+			if(handler.handler) {
+				handleObjIn = handler;
+				handler = handleObjIn.handler;
+				selector = handleObjIn.selector
+			}
+			if(!handler.guid) {
+				handler.guid = jQuery.guid++
+			}
+			if(!(events = elemData.events)) {
+				events = elemData.events = {}
+			}
+			if(!(eventHandle = elemData.handle)) {
+				eventHandle = elemData.handle = function(e) {
+					return typeof jQuery !== core_strundefined && (!e || jQuery.event.triggered !== e.type) ? jQuery.event.dispatch.apply(eventHandle.elem, arguments) : undefined
+				};
+				eventHandle.elem = elem
+			}
+			types = (types || "").match(core_rnotwhite) || [""];
+			t = types.length;
+			while(t--) {
+				tmp = rtypenamespace.exec(types[t]) || [];
+				type = origType = tmp[1];
+				namespaces = (tmp[2] || "").split(".").sort();
+				special = jQuery.event.special[type] || {};
+				type = (selector ? special.delegateType : special.bindType) || type;
+				special = jQuery.event.special[type] || {};
+				handleObj = jQuery.extend({
+					type: type,
+					origType: origType,
+					data: data,
+					handler: handler,
+					guid: handler.guid,
+					selector: selector,
+					needsContext: selector && jQuery.expr.match.needsContext.test(selector),
+					namespace: namespaces.join(".")
+				}, handleObjIn);
+				if(!(handlers = events[type])) {
+					handlers = events[type] = [];
+					handlers.delegateCount = 0;
+					if(!special.setup || special.setup.call(elem, data, namespaces, eventHandle) === false) {
+						if(elem.addEventListener) {
+							elem.addEventListener(type, eventHandle, false)
+						} else if(elem.attachEvent) {
+							elem.attachEvent("on" + type, eventHandle)
+						}
+					}
+				}
+				if(special.add) {
+					special.add.call(elem, handleObj);
+					if(!handleObj.handler.guid) {
+						handleObj.handler.guid = handler.guid
+					}
+				}
+				if(selector) {
+					handlers.splice(handlers.delegateCount++, 0, handleObj)
+				} else {
+					handlers.push(handleObj)
+				}
+				jQuery.event.global[type] = true
+			}
+			elem = null
+		},
+		remove: function(elem, types, handler, selector, mappedTypes) {
+			var j, handleObj, tmp, origCount, t, events, special, handlers, type, namespaces, origType, elemData = jQuery.hasData(elem) && jQuery._data(elem);
+			if(!elemData || !(events = elemData.events)) {
+				return
+			}
+			types = (types || "").match(core_rnotwhite) || [""];
+			t = types.length;
+			while(t--) {
+				tmp = rtypenamespace.exec(types[t]) || [];
+				type = origType = tmp[1];
+				namespaces = (tmp[2] || "").split(".").sort();
+				if(!type) {
+					for(type in events) {
+						jQuery.event.remove(elem, type + types[t], handler, selector, true)
+					}
+					continue
+				}
+				special = jQuery.event.special[type] || {};
+				type = (selector ? special.delegateType : special.bindType) || type;
+				handlers = events[type] || [];
+				tmp = tmp[2] && new RegExp("(^|\\.)" + namespaces.join("\\.(?:.*\\.|)") + "(\\.|$)");
+				origCount = j = handlers.length;
+				while(j--) {
+					handleObj = handlers[j];
+					if((mappedTypes || origType === handleObj.origType) && (!handler || handler.guid === handleObj.guid) && (!tmp || tmp.test(handleObj.namespace)) && (!selector || selector === handleObj.selector || selector === "**" && handleObj.selector)) {
+						handlers.splice(j, 1);
+						if(handleObj.selector) {
+							handlers.delegateCount--
+						}
+						if(special.remove) {
+							special.remove.call(elem, handleObj)
+						}
+					}
+				}
+				if(origCount && !handlers.length) {
+					if(!special.teardown || special.teardown.call(elem, namespaces, elemData.handle) === false) {
+						jQuery.removeEvent(elem, type, elemData.handle)
+					}
+					delete events[type]
+				}
+			}
+			if(jQuery.isEmptyObject(events)) {
+				delete elemData.handle;
+				jQuery._removeData(elem, "events")
+			}
+		},
+		trigger: function(event, data, elem, onlyHandlers) {
+			var handle, ontype, cur, bubbleType, special, tmp, i, eventPath = [elem || document],
+				type = core_hasOwn.call(event, "type") ? event.type : event,
+				namespaces = core_hasOwn.call(event, "namespace") ? event.namespace.split(".") : [];
+			cur = tmp = elem = elem || document;
+			if(elem.nodeType === 3 || elem.nodeType === 8) {
+				return
+			}
+			if(rfocusMorph.test(type + jQuery.event.triggered)) {
+				return
+			}
+			if(type.indexOf(".") >= 0) {
+				namespaces = type.split(".");
+				type = namespaces.shift();
+				namespaces.sort()
+			}
+			ontype = type.indexOf(":") < 0 && "on" + type;
+			event = event[jQuery.expando] ? event : new jQuery.Event(type, typeof event === "object" && event);
+			event.isTrigger = true;
+			event.namespace = namespaces.join(".");
+			event.namespace_re = event.namespace ? new RegExp("(^|\\.)" + namespaces.join("\\.(?:.*\\.|)") + "(\\.|$)") : null;
+			event.result = undefined;
+			if(!event.target) {
+				event.target = elem
+			}
+			data = data == null ? [event] : jQuery.makeArray(data, [event]);
+			special = jQuery.event.special[type] || {};
+			if(!onlyHandlers && special.trigger && special.trigger.apply(elem, data) === false) {
+				return
+			}
+			if(!onlyHandlers && !special.noBubble && !jQuery.isWindow(elem)) {
+				bubbleType = special.delegateType || type;
+				if(!rfocusMorph.test(bubbleType + type)) {
+					cur = cur.parentNode
+				}
+				for(; cur; cur = cur.parentNode) {
+					eventPath.push(cur);
+					tmp = cur
+				}
+				if(tmp === (elem.ownerDocument || document)) {
+					eventPath.push(tmp.defaultView || tmp.parentWindow || window)
+				}
+			}
+			i = 0;
+			while((cur = eventPath[i++]) && !event.isPropagationStopped()) {
+				event.type = i > 1 ? bubbleType : special.bindType || type;
+				handle = (jQuery._data(cur, "events") || {})[event.type] && jQuery._data(cur, "handle");
+				if(handle) {
+					handle.apply(cur, data)
+				}
+				handle = ontype && cur[ontype];
+				if(handle && jQuery.acceptData(cur) && handle.apply && handle.apply(cur, data) === false) {
+					event.preventDefault()
+				}
+			}
+			event.type = type;
+			if(!onlyHandlers && !event.isDefaultPrevented()) {
+				if((!special._default || special._default.apply(elem.ownerDocument, data) === false) && !(type === "click" && jQuery.nodeName(elem, "a")) && jQuery.acceptData(elem)) {
+					if(ontype && elem[type] && !jQuery.isWindow(elem)) {
+						tmp = elem[ontype];
+						if(tmp) {
+							elem[ontype] = null
+						}
+						jQuery.event.triggered = type;
+						try {
+							elem[type]()
+						} catch(e) {}
+						jQuery.event.triggered = undefined;
+						if(tmp) {
+							elem[ontype] = tmp
+						}
+					}
+				}
+			}
+			return event.result
+		},
+		dispatch: function(event) {
+			event = jQuery.event.fix(event);
+			var i, ret, handleObj, matched, j, handlerQueue = [],
+				args = core_slice.call(arguments),
+				handlers = (jQuery._data(this, "events") || {})[event.type] || [],
+				special = jQuery.event.special[event.type] || {};
+			args[0] = event;
+			event.delegateTarget = this;
+			if(special.preDispatch && special.preDispatch.call(this, event) === false) {
+				return
+			}
+			handlerQueue = jQuery.event.handlers.call(this, event, handlers);
+			i = 0;
+			while((matched = handlerQueue[i++]) && !event.isPropagationStopped()) {
+				event.currentTarget = matched.elem;
+				j = 0;
+				while((handleObj = matched.handlers[j++]) && !event.isImmediatePropagationStopped()) {
+					if(!event.namespace_re || event.namespace_re.test(handleObj.namespace)) {
+						event.handleObj = handleObj;
+						event.data = handleObj.data;
+						ret = ((jQuery.event.special[handleObj.origType] || {}).handle || handleObj.handler).apply(matched.elem, args);
+						if(ret !== undefined) {
+							if((event.result = ret) === false) {
+								event.preventDefault();
+								event.stopPropagation()
+							}
+						}
+					}
+				}
+			}
+			if(special.postDispatch) {
+				special.postDispatch.call(this, event)
+			}
+			return event.result
+		},
+		handlers: function(event, handlers) {
+			var sel, handleObj, matches, i, handlerQueue = [],
+				delegateCount = handlers.delegateCount,
+				cur = event.target;
+			if(delegateCount && cur.nodeType && (!event.button || event.type !== "click")) {
+				for(; cur != this; cur = cur.parentNode || this) {
+					if(cur.nodeType === 1 && (cur.disabled !== true || event.type !== "click")) {
+						matches = [];
+						for(i = 0; i < delegateCount; i++) {
+							handleObj = handlers[i];
+							sel = handleObj.selector + " ";
+							if(matches[sel] === undefined) {
+								matches[sel] = handleObj.needsContext ? jQuery(sel, this).index(cur) >= 0 : jQuery.find(sel, this, null, [cur]).length
+							}
+							if(matches[sel]) {
+								matches.push(handleObj)
+							}
+						}
+						if(matches.length) {
+							handlerQueue.push({
+								elem: cur,
+								handlers: matches
+							})
+						}
+					}
+				}
+			}
+			if(delegateCount < handlers.length) {
+				handlerQueue.push({
+					elem: this,
+					handlers: handlers.slice(delegateCount)
+				})
+			}
+			return handlerQueue
+		},
+		fix: function(event) {
+			if(event[jQuery.expando]) {
+				return event
+			}
+			var i, prop, copy, type = event.type,
+				originalEvent = event,
+				fixHook = this.fixHooks[type];
+			if(!fixHook) {
+				this.fixHooks[type] = fixHook = rmouseEvent.test(type) ? this.mouseHooks : rkeyEvent.test(type) ? this.keyHooks : {}
+			}
+			copy = fixHook.props ? this.props.concat(fixHook.props) : this.props;
+			event = new jQuery.Event(originalEvent);
+			i = copy.length;
+			while(i--) {
+				prop = copy[i];
+				event[prop] = originalEvent[prop]
+			}
+			if(!event.target) {
+				event.target = originalEvent.srcElement || document
+			}
+			if(event.target.nodeType === 3) {
+				event.target = event.target.parentNode
+			}
+			event.metaKey = !!event.metaKey;
+			return fixHook.filter ? fixHook.filter(event, originalEvent) : event
+		},
+		props: "altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "),
+		fixHooks: {},
+		keyHooks: {
+			props: "char charCode key keyCode".split(" "),
+			filter: function(event, original) {
+				if(event.which == null) {
+					event.which = original.charCode != null ? original.charCode : original.keyCode
+				}
+				return event
+			}
+		},
+		mouseHooks: {
+			props: "button buttons clientX clientY fromElement offsetX offsetY pageX pageY screenX screenY toElement".split(" "),
+			filter: function(event, original) {
+				var body, eventDoc, doc, button = original.button,
+					fromElement = original.fromElement;
+				if(event.pageX == null && original.clientX != null) {
+					eventDoc = event.target.ownerDocument || document;
+					doc = eventDoc.documentElement;
+					body = eventDoc.body;
+					event.pageX = original.clientX + (doc && doc.scrollLeft || body && body.scrollLeft || 0) - (doc && doc.clientLeft || body && body.clientLeft || 0);
+					event.pageY = original.clientY + (doc && doc.scrollTop || body && body.scrollTop || 0) - (doc && doc.clientTop || body && body.clientTop || 0)
+				}
+				if(!event.relatedTarget && fromElement) {
+					event.relatedTarget = fromElement === event.target ? original.toElement : fromElement
+				}
+				if(!event.which && button !== undefined) {
+					event.which = (button & 1 ? 1 : (button & 2 ? 3 : (button & 4 ? 2 : 0)))
+				}
+				return event
+			}
+		},
+		special: {
+			load: {
+				noBubble: true
+			},
+			click: {
+				trigger: function() {
+					if(jQuery.nodeName(this, "input") && this.type === "checkbox" && this.click) {
+						this.click();
+						return false
+					}
+				}
+			},
+			focus: {
+				trigger: function() {
+					if(this !== document.activeElement && this.focus) {
+						try {
+							this.focus();
+							return false
+						} catch(e) {}
+					}
+				},
+				delegateType: "focusin"
+			},
+			blur: {
+				trigger: function() {
+					if(this === document.activeElement && this.blur) {
+						this.blur();
+						return false
+					}
+				},
+				delegateType: "focusout"
+			},
+			beforeunload: {
+				postDispatch: function(event) {
+					if(event.result !== undefined) {
+						event.originalEvent.returnValue = event.result
+					}
+				}
+			}
+		},
+		simulate: function(type, elem, event, bubble) {
+			var e = jQuery.extend(new jQuery.Event(), event, {
+				type: type,
+				isSimulated: true,
+				originalEvent: {}
+			});
+			if(bubble) {
+				jQuery.event.trigger(e, null, elem)
+			} else {
+				jQuery.event.dispatch.call(elem, e)
+			}
+			if(e.isDefaultPrevented()) {
+				event.preventDefault()
+			}
+		}
+	};
+	jQuery.removeEvent = document.removeEventListener ? function(elem, type, handle) {
+		if(elem.removeEventListener) {
+			elem.removeEventListener(type, handle, false)
+		}
+	} : function(elem, type, handle) {
+		var name = "on" + type;
+		if(elem.detachEvent) {
+			if(typeof elem[name] === core_strundefined) {
+				elem[name] = null
+			}
+			elem.detachEvent(name, handle)
+		}
+	};
+	jQuery.Event = function(src, props) {
+		if(!(this instanceof jQuery.Event)) {
+			return new jQuery.Event(src, props)
+		}
+		if(src && src.type) {
+			this.originalEvent = src;
+			this.type = src.type;
+			this.isDefaultPrevented = (src.defaultPrevented || src.returnValue === false || src.getPreventDefault && src.getPreventDefault()) ? returnTrue : returnFalse
+		} else {
+			this.type = src
+		}
+		if(props) {
+			jQuery.extend(this, props)
+		}
+		this.timeStamp = src && src.timeStamp || jQuery.now();
+		this[jQuery.expando] = true
+	};
+	jQuery.Event.prototype = {
+		isDefaultPrevented: returnFalse,
+		isPropagationStopped: returnFalse,
+		isImmediatePropagationStopped: returnFalse,
+		preventDefault: function() {
+			var e = this.originalEvent;
+			this.isDefaultPrevented = returnTrue;
+			if(!e) {
+				return
+			}
+			if(e.preventDefault) {
+				e.preventDefault()
+			} else {
+				e.returnValue = false
+			}
+		},
+		stopPropagation: function() {
+			var e = this.originalEvent;
+			this.isPropagationStopped = returnTrue;
+			if(!e) {
+				return
+			}
+			if(e.stopPropagation) {
+				e.stopPropagation()
+			}
+			e.cancelBubble = true
+		},
+		stopImmediatePropagation: function() {
+			this.isImmediatePropagationStopped = returnTrue;
+			this.stopPropagation()
+		}
+	};
+	jQuery.each({
+		mouseenter: "mouseover",
+		mouseleave: "mouseout"
+	}, function(orig, fix) {
+		jQuery.event.special[orig] = {
+			delegateType: fix,
+			bindType: fix,
+			handle: function(event) {
+				var ret, target = this,
+					related = event.relatedTarget,
+					handleObj = event.handleObj;
+				if(!related || (related !== target && !jQuery.contains(target, related))) {
+					event.type = handleObj.origType;
+					ret = handleObj.handler.apply(this, arguments);
+					event.type = fix
+				}
+				return ret
+			}
+		}
 	});
-	$(".carousel").on("slid.bs.carousel", function() {
-		setupIndexesOfCarousel($(this));
+	if(!jQuery.support.submitBubbles) {
+		jQuery.event.special.submit = {
+			setup: function() {
+				if(jQuery.nodeName(this, "form")) {
+					return false
+				}
+				jQuery.event.add(this, "click._submit keypress._submit", function(e) {
+					var elem = e.target,
+						form = jQuery.nodeName(elem, "input") || jQuery.nodeName(elem, "button") ? elem.form : undefined;
+					if(form && !jQuery._data(form, "submitBubbles")) {
+						jQuery.event.add(form, "submit._submit", function(event) {
+							event._submit_bubble = true
+						});
+						jQuery._data(form, "submitBubbles", true)
+					}
+				})
+			},
+			postDispatch: function(event) {
+				if(event._submit_bubble) {
+					delete event._submit_bubble;
+					if(this.parentNode && !event.isTrigger) {
+						jQuery.event.simulate("submit", this.parentNode, event, true)
+					}
+				}
+			},
+			teardown: function() {
+				if(jQuery.nodeName(this, "form")) {
+					return false
+				}
+				jQuery.event.remove(this, "._submit")
+			}
+		}
+	}
+	if(!jQuery.support.changeBubbles) {
+		jQuery.event.special.change = {
+			setup: function() {
+				if(rformElems.test(this.nodeName)) {
+					if(this.type === "checkbox" || this.type === "radio") {
+						jQuery.event.add(this, "propertychange._change", function(event) {
+							if(event.originalEvent.propertyName === "checked") {
+								this._just_changed = true
+							}
+						});
+						jQuery.event.add(this, "click._change", function(event) {
+							if(this._just_changed && !event.isTrigger) {
+								this._just_changed = false
+							}
+							jQuery.event.simulate("change", this, event, true)
+						})
+					}
+					return false
+				}
+				jQuery.event.add(this, "beforeactivate._change", function(e) {
+					var elem = e.target;
+					if(rformElems.test(elem.nodeName) && !jQuery._data(elem, "changeBubbles")) {
+						jQuery.event.add(elem, "change._change", function(event) {
+							if(this.parentNode && !event.isSimulated && !event.isTrigger) {
+								jQuery.event.simulate("change", this.parentNode, event, true)
+							}
+						});
+						jQuery._data(elem, "changeBubbles", true)
+					}
+				})
+			},
+			handle: function(event) {
+				var elem = event.target;
+				if(this !== elem || event.isSimulated || event.isTrigger || (elem.type !== "radio" && elem.type !== "checkbox")) {
+					return event.handleObj.handler.apply(this, arguments)
+				}
+			},
+			teardown: function() {
+				jQuery.event.remove(this, "._change");
+				return !rformElems.test(this.nodeName)
+			}
+		}
+	}
+	if(!jQuery.support.focusinBubbles) {
+		jQuery.each({
+			focus: "focusin",
+			blur: "focusout"
+		}, function(orig, fix) {
+			var attaches = 0,
+				handler = function(event) {
+					jQuery.event.simulate(fix, event.target, jQuery.event.fix(event), true)
+				};
+			jQuery.event.special[fix] = {
+				setup: function() {
+					if(attaches++ === 0) {
+						document.addEventListener(orig, handler, true)
+					}
+				},
+				teardown: function() {
+					if(--attaches === 0) {
+						document.removeEventListener(orig, handler, true)
+					}
+				}
+			}
+		})
+	}
+	jQuery.fn.extend({
+		on: function(types, selector, data, fn, one) {
+			var type, origFn;
+			if(typeof types === "object") {
+				if(typeof selector !== "string") {
+					data = data || selector;
+					selector = undefined
+				}
+				for(type in types) {
+					this.on(type, selector, data, types[type], one)
+				}
+				return this
+			}
+			if(data == null && fn == null) {
+				fn = selector;
+				data = selector = undefined
+			} else if(fn == null) {
+				if(typeof selector === "string") {
+					fn = data;
+					data = undefined
+				} else {
+					fn = data;
+					data = selector;
+					selector = undefined
+				}
+			}
+			if(fn === false) {
+				fn = returnFalse
+			} else if(!fn) {
+				return this
+			}
+			if(one === 1) {
+				origFn = fn;
+				fn = function(event) {
+					jQuery().off(event);
+					return origFn.apply(this, arguments)
+				};
+				fn.guid = origFn.guid || (origFn.guid = jQuery.guid++)
+			}
+			return this.each(function() {
+				jQuery.event.add(this, types, fn, data, selector)
+			})
+		},
+		one: function(types, selector, data, fn) {
+			return this.on(types, selector, data, fn, 1)
+		},
+		off: function(types, selector, fn) {
+			var handleObj, type;
+			if(types && types.preventDefault && types.handleObj) {
+				handleObj = types.handleObj;
+				jQuery(types.delegateTarget).off(handleObj.namespace ? handleObj.origType + "." + handleObj.namespace : handleObj.origType, handleObj.selector, handleObj.handler);
+				return this
+			}
+			if(typeof types === "object") {
+				for(type in types) {
+					this.off(type, selector, types[type])
+				}
+				return this
+			}
+			if(selector === false || typeof selector === "function") {
+				fn = selector;
+				selector = undefined
+			}
+			if(fn === false) {
+				fn = returnFalse
+			}
+			return this.each(function() {
+				jQuery.event.remove(this, types, fn, selector)
+			})
+		},
+		bind: function(types, data, fn) {
+			return this.on(types, null, data, fn)
+		},
+		unbind: function(types, fn) {
+			return this.off(types, null, fn)
+		},
+		delegate: function(selector, types, data, fn) {
+			return this.on(types, selector, data, fn)
+		},
+		undelegate: function(selector, types, fn) {
+			return arguments.length === 1 ? this.off(selector, "**") : this.off(types, selector || "**", fn)
+		},
+		trigger: function(type, data) {
+			return this.each(function() {
+				jQuery.event.trigger(type, data, this)
+			})
+		},
+		triggerHandler: function(type, data) {
+			var elem = this[0];
+			if(elem) {
+				return jQuery.event.trigger(type, data, elem, true)
+			}
+		}
 	});
-}
+	(function(window, undefined) {
+		var i, cachedruns, Expr, getText, isXML, compile, hasDuplicate, outermostContext, setDocument, document, docElem, documentIsXML, rbuggyQSA, rbuggyMatches, matches, contains, sortOrder, expando = "sizzle" + -(new Date()),
+			preferredDoc = window.document,
+			support = {},
+			dirruns = 0,
+			done = 0,
+			classCache = createCache(),
+			tokenCache = createCache(),
+			compilerCache = createCache(),
+			strundefined = typeof undefined,
+			MAX_NEGATIVE = 1 << 31,
+			arr = [],
+			pop = arr.pop,
+			push = arr.push,
+			slice = arr.slice,
+			indexOf = arr.indexOf || function(elem) {
+				var i = 0,
+					len = this.length;
+				for(; i < len; i++) {
+					if(this[i] === elem) {
+						return i
+					}
+				}
+				return -1
+			},
+			whitespace = "[\\x20\\t\\r\\n\\f]",
+			characterEncoding = "(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+",
+			identifier = characterEncoding.replace("w", "w#"),
+			operators = "([*^$|!~]?=)",
+			attributes = "\\[" + whitespace + "*(" + characterEncoding + ")" + whitespace + "*(?:" + operators + whitespace + "*(?:(['\"])((?:\\\\.|[^\\\\])*?)\\3|(" + identifier + ")|)|)" + whitespace + "*\\]",
+			pseudos = ":(" + characterEncoding + ")(?:\\(((['\"])((?:\\\\.|[^\\\\])*?)\\3|((?:\\\\.|[^\\\\()[\\]]|" + attributes.replace(3, 8) + ")*)|.*)\\)|)",
+			rtrim = new RegExp("^" + whitespace + "+|((?:^|[^\\\\])(?:\\\\.)*)" + whitespace + "+$", "g"),
+			rcomma = new RegExp("^" + whitespace + "*," + whitespace + "*"),
+			rcombinators = new RegExp("^" + whitespace + "*([\\x20\\t\\r\\n\\f>+~])" + whitespace + "*"),
+			rpseudo = new RegExp(pseudos),
+			ridentifier = new RegExp("^" + identifier + "$"),
+			matchExpr = {
+				"ID": new RegExp("^#(" + characterEncoding + ")"),
+				"CLASS": new RegExp("^\\.(" + characterEncoding + ")"),
+				"NAME": new RegExp("^\\[name=['\"]?(" + characterEncoding + ")['\"]?\\]"),
+				"TAG": new RegExp("^(" + characterEncoding.replace("w", "w*") + ")"),
+				"ATTR": new RegExp("^" + attributes),
+				"PSEUDO": new RegExp("^" + pseudos),
+				"CHILD": new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\(" + whitespace + "*(even|odd|(([+-]|)(\\d*)n|)" + whitespace + "*(?:([+-]|)" + whitespace + "*(\\d+)|))" + whitespace + "*\\)|)", "i"),
+				"needsContext": new RegExp("^" + whitespace + "*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\(" + whitespace + "*((?:-\\d)?\\d*)" + whitespace + "*\\)|)(?=[^-]|$)", "i")
+			},
+			rsibling = /[\x20\t\r\n\f]*[+~]/,
+			rnative = /^[^{]+\{\s*\[native code/,
+			rquickExpr = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,
+			rinputs = /^(?:input|select|textarea|button)$/i,
+			rheader = /^h\d$/i,
+			rescape = /'|\\/g,
+			rattributeQuotes = /\=[\x20\t\r\n\f]*([^'"\]]*)[\x20\t\r\n\f]*\]/g,
+			runescape = /\\([\da-fA-F]{1,6}[\x20\t\r\n\f]?|.)/g,
+			funescape = function(_, escaped) {
+				var high = "0x" + escaped - 0x10000;
+				return high !== high ? escaped : high < 0 ? String.fromCharCode(high + 0x10000) : String.fromCharCode(high >> 10 | 0xD800, high & 0x3FF | 0xDC00)
+			};
+		try {
+			slice.call(preferredDoc.documentElement.childNodes, 0)[0].nodeType
+		} catch(e) {
+			slice = function(i) {
+				var elem, results = [];
+				while((elem = this[i++])) {
+					results.push(elem)
+				}
+				return results
+			}
+		}
 
-function setupIndexesOfCarousel(carousel) {
-	var total_number = $(carousel).find(".item").length;
-	var current_number = $(carousel).find(".item.active").index() + 1;
-	
-	$(carousel).find(".index").text(String(current_number) + " / " + String(total_number));
-}
+		function isNative(fn) {
+			return rnative.test(fn + "")
+		}
 
-function preloadImages(images) { 
-  for (var i = 0; i < images.length; i++) {
-    $("<img />").attr("src", images[i]);
-  }
-}
+		function createCache() {
+			var cache, keys = [];
+			return(cache = function(key, value) {
+				if(keys.push(key += " ") > Expr.cacheLength) {
+					delete cache[keys.shift()]
+				}
+				return(cache[key] = value)
+			})
+		}
+
+		function markFunction(fn) {
+			fn[expando] = true;
+			return fn
+		}
+
+		function assert(fn) {
+			var div = document.createElement("div");
+			try {
+				return fn(div)
+			} catch(e) {
+				return false
+			} finally {
+				div = null
+			}
+		}
+
+		function Sizzle(selector, context, results, seed) {
+			var match, elem, m, nodeType, i, groups, old, nid, newContext, newSelector;
+			if((context ? context.ownerDocument || context : preferredDoc) !== document) {
+				setDocument(context)
+			}
+			context = context || document;
+			results = results || [];
+			if(!selector || typeof selector !== "string") {
+				return results
+			}
+			if((nodeType = context.nodeType) !== 1 && nodeType !== 9) {
+				return []
+			}
+			if(!documentIsXML && !seed) {
+				if((match = rquickExpr.exec(selector))) {
+					if((m = match[1])) {
+						if(nodeType === 9) {
+							elem = context.getElementById(m);
+							if(elem && elem.parentNode) {
+								if(elem.id === m) {
+									results.push(elem);
+									return results
+								}
+							} else {
+								return results
+							}
+						} else {
+							if(context.ownerDocument && (elem = context.ownerDocument.getElementById(m)) && contains(context, elem) && elem.id === m) {
+								results.push(elem);
+								return results
+							}
+						}
+					} else if(match[2]) {
+						push.apply(results, slice.call(context.getElementsByTagName(selector), 0));
+						return results
+					} else if((m = match[3]) && support.getByClassName && context.getElementsByClassName) {
+						push.apply(results, slice.call(context.getElementsByClassName(m), 0));
+						return results
+					}
+				}
+				if(support.qsa && !rbuggyQSA.test(selector)) {
+					old = true;
+					nid = expando;
+					newContext = context;
+					newSelector = nodeType === 9 && selector;
+					if(nodeType === 1 && context.nodeName.toLowerCase() !== "object") {
+						groups = tokenize(selector);
+						if((old = context.getAttribute("id"))) {
+							nid = old.replace(rescape, "\\$&")
+						} else {
+							context.setAttribute("id", nid)
+						}
+						nid = "[id='" + nid + "'] ";
+						i = groups.length;
+						while(i--) {
+							groups[i] = nid + toSelector(groups[i])
+						}
+						newContext = rsibling.test(selector) && context.parentNode || context;
+						newSelector = groups.join(",")
+					}
+					if(newSelector) {
+						try {
+							push.apply(results, slice.call(newContext.querySelectorAll(newSelector), 0));
+							return results
+						} catch(qsaError) {} finally {
+							if(!old) {
+								context.removeAttribute("id")
+							}
+						}
+					}
+				}
+			}
+			return select(selector.replace(rtrim, "$1"), context, results, seed)
+		}
+		isXML = Sizzle.isXML = function(elem) {
+			var documentElement = elem && (elem.ownerDocument || elem).documentElement;
+			return documentElement ? documentElement.nodeName !== "HTML" : false
+		};
+		setDocument = Sizzle.setDocument = function(node) {
+			var doc = node ? node.ownerDocument || node : preferredDoc;
+			if(doc === document || doc.nodeType !== 9 || !doc.documentElement) {
+				return document
+			}
+			document = doc;
+			docElem = doc.documentElement;
+			documentIsXML = isXML(doc);
+			support.tagNameNoComments = assert(function(div) {
+				div.appendChild(doc.createComment(""));
+				return !div.getElementsByTagName("*").length
+			});
+			support.attributes = assert(function(div) {
+				div.innerHTML = "<select></select>";
+				var type = typeof div.lastChild.getAttribute("multiple");
+				return type !== "boolean" && type !== "string"
+			});
+			support.getByClassName = assert(function(div) {
+				div.innerHTML = "<div class='hidden e'></div><div class='hidden'></div>";
+				if(!div.getElementsByClassName || !div.getElementsByClassName("e").length) {
+					return false
+				}
+				div.lastChild.className = "e";
+				return div.getElementsByClassName("e").length === 2
+			});
+			support.getByName = assert(function(div) {
+				div.id = expando + 0;
+				div.innerHTML = "<a name='" + expando + "'></a><div name='" + expando + "'></div>";
+				docElem.insertBefore(div, docElem.firstChild);
+				var pass = doc.getElementsByName && doc.getElementsByName(expando).length === 2 + doc.getElementsByName(expando + 0).length;
+				support.getIdNotName = !doc.getElementById(expando);
+				docElem.removeChild(div);
+				return pass
+			});
+			Expr.attrHandle = assert(function(div) {
+				div.innerHTML = "<a href='#'></a>";
+				return div.firstChild && typeof div.firstChild.getAttribute !== strundefined && div.firstChild.getAttribute("href") === "#"
+			}) ? {} : {
+				"href": function(elem) {
+					return elem.getAttribute("href", 2)
+				},
+				"type": function(elem) {
+					return elem.getAttribute("type")
+				}
+			};
+			if(support.getIdNotName) {
+				Expr.find["ID"] = function(id, context) {
+					if(typeof context.getElementById !== strundefined && !documentIsXML) {
+						var m = context.getElementById(id);
+						return m && m.parentNode ? [m] : []
+					}
+				};
+				Expr.filter["ID"] = function(id) {
+					var attrId = id.replace(runescape, funescape);
+					return function(elem) {
+						return elem.getAttribute("id") === attrId
+					}
+				}
+			} else {
+				Expr.find["ID"] = function(id, context) {
+					if(typeof context.getElementById !== strundefined && !documentIsXML) {
+						var m = context.getElementById(id);
+						return m ? m.id === id || typeof m.getAttributeNode !== strundefined && m.getAttributeNode("id").value === id ? [m] : undefined : []
+					}
+				};
+				Expr.filter["ID"] = function(id) {
+					var attrId = id.replace(runescape, funescape);
+					return function(elem) {
+						var node = typeof elem.getAttributeNode !== strundefined && elem.getAttributeNode("id");
+						return node && node.value === attrId
+					}
+				}
+			}
+			Expr.find["TAG"] = support.tagNameNoComments ? function(tag, context) {
+				if(typeof context.getElementsByTagName !== strundefined) {
+					return context.getElementsByTagName(tag)
+				}
+			} : function(tag, context) {
+				var elem, tmp = [],
+					i = 0,
+					results = context.getElementsByTagName(tag);
+				if(tag === "*") {
+					while((elem = results[i++])) {
+						if(elem.nodeType === 1) {
+							tmp.push(elem)
+						}
+					}
+					return tmp
+				}
+				return results
+			};
+			Expr.find["NAME"] = support.getByName && function(tag, context) {
+				if(typeof context.getElementsByName !== strundefined) {
+					return context.getElementsByName(name)
+				}
+			};
+			Expr.find["CLASS"] = support.getByClassName && function(className, context) {
+				if(typeof context.getElementsByClassName !== strundefined && !documentIsXML) {
+					return context.getElementsByClassName(className)
+				}
+			};
+			rbuggyMatches = [];
+			rbuggyQSA = [":focus"];
+			if((support.qsa = isNative(doc.querySelectorAll))) {
+				assert(function(div) {
+					div.innerHTML = "<select><option selected=''></option></select>";
+					if(!div.querySelectorAll("[selected]").length) {
+						rbuggyQSA.push("\\[" + whitespace + "*(?:checked|disabled|ismap|multiple|readonly|selected|value)")
+					}
+					if(!div.querySelectorAll(":checked").length) {
+						rbuggyQSA.push(":checked")
+					}
+				});
+				assert(function(div) {
+					div.innerHTML = "<input type='hidden' i=''/>";
+					if(div.querySelectorAll("[i^='']").length) {
+						rbuggyQSA.push("[*^$]=" + whitespace + "*(?:\"\"|'')")
+					}
+					if(!div.querySelectorAll(":enabled").length) {
+						rbuggyQSA.push(":enabled", ":disabled")
+					}
+					div.querySelectorAll("*,:x");
+					rbuggyQSA.push(",.*:")
+				})
+			}
+			if((support.matchesSelector = isNative((matches = docElem.matchesSelector || docElem.mozMatchesSelector || docElem.webkitMatchesSelector || docElem.oMatchesSelector || docElem.msMatchesSelector)))) {
+				assert(function(div) {
+					support.disconnectedMatch = matches.call(div, "div");
+					matches.call(div, "[s!='']:x");
+					rbuggyMatches.push("!=", pseudos)
+				})
+			}
+			rbuggyQSA = new RegExp(rbuggyQSA.join("|"));
+			rbuggyMatches = new RegExp(rbuggyMatches.join("|"));
+			contains = isNative(docElem.contains) || docElem.compareDocumentPosition ? function(a, b) {
+				var adown = a.nodeType === 9 ? a.documentElement : a,
+					bup = b && b.parentNode;
+				return a === bup || !!(bup && bup.nodeType === 1 && (adown.contains ? adown.contains(bup) : a.compareDocumentPosition && a.compareDocumentPosition(bup) & 16))
+			} : function(a, b) {
+				if(b) {
+					while((b = b.parentNode)) {
+						if(b === a) {
+							return true
+						}
+					}
+				}
+				return false
+			};
+			sortOrder = docElem.compareDocumentPosition ? function(a, b) {
+				var compare;
+				if(a === b) {
+					hasDuplicate = true;
+					return 0
+				}
+				if((compare = b.compareDocumentPosition && a.compareDocumentPosition && a.compareDocumentPosition(b))) {
+					if(compare & 1 || a.parentNode && a.parentNode.nodeType === 11) {
+						if(a === doc || contains(preferredDoc, a)) {
+							return -1
+						}
+						if(b === doc || contains(preferredDoc, b)) {
+							return 1
+						}
+						return 0
+					}
+					return compare & 4 ? -1 : 1
+				}
+				return a.compareDocumentPosition ? -1 : 1
+			} : function(a, b) {
+				var cur, i = 0,
+					aup = a.parentNode,
+					bup = b.parentNode,
+					ap = [a],
+					bp = [b];
+				if(a === b) {
+					hasDuplicate = true;
+					return 0
+				} else if(!aup || !bup) {
+					return a === doc ? -1 : b === doc ? 1 : aup ? -1 : bup ? 1 : 0
+				} else if(aup === bup) {
+					return siblingCheck(a, b)
+				}
+				cur = a;
+				while((cur = cur.parentNode)) {
+					ap.unshift(cur)
+				}
+				cur = b;
+				while((cur = cur.parentNode)) {
+					bp.unshift(cur)
+				}
+				while(ap[i] === bp[i]) {
+					i++
+				}
+				return i ? siblingCheck(ap[i], bp[i]) : ap[i] === preferredDoc ? -1 : bp[i] === preferredDoc ? 1 : 0
+			};
+			hasDuplicate = false;
+			[0, 0].sort(sortOrder);
+			support.detectDuplicates = hasDuplicate;
+			return document
+		};
+		Sizzle.matches = function(expr, elements) {
+			return Sizzle(expr, null, null, elements)
+		};
+		Sizzle.matchesSelector = function(elem, expr) {
+			if((elem.ownerDocument || elem) !== document) {
+				setDocument(elem)
+			}
+			expr = expr.replace(rattributeQuotes, "='$1']");
+			if(support.matchesSelector && !documentIsXML && (!rbuggyMatches || !rbuggyMatches.test(expr)) && !rbuggyQSA.test(expr)) {
+				try {
+					var ret = matches.call(elem, expr);
+					if(ret || support.disconnectedMatch || elem.document && elem.document.nodeType !== 11) {
+						return ret
+					}
+				} catch(e) {}
+			}
+			return Sizzle(expr, document, null, [elem]).length > 0
+		};
+		Sizzle.contains = function(context, elem) {
+			if((context.ownerDocument || context) !== document) {
+				setDocument(context)
+			}
+			return contains(context, elem)
+		};
+		Sizzle.attr = function(elem, name) {
+			var val;
+			if((elem.ownerDocument || elem) !== document) {
+				setDocument(elem)
+			}
+			if(!documentIsXML) {
+				name = name.toLowerCase()
+			}
+			if((val = Expr.attrHandle[name])) {
+				return val(elem)
+			}
+			if(documentIsXML || support.attributes) {
+				return elem.getAttribute(name)
+			}
+			return((val = elem.getAttributeNode(name)) || elem.getAttribute(name)) && elem[name] === true ? name : val && val.specified ? val.value : null
+		};
+		Sizzle.error = function(msg) {
+			throw new Error("Syntax error, unrecognized expression: " + msg);
+		};
+		Sizzle.uniqueSort = function(results) {
+			var elem, duplicates = [],
+				i = 1,
+				j = 0;
+			hasDuplicate = !support.detectDuplicates;
+			results.sort(sortOrder);
+			if(hasDuplicate) {
+				for(;
+					(elem = results[i]); i++) {
+					if(elem === results[i - 1]) {
+						j = duplicates.push(i)
+					}
+				}
+				while(j--) {
+					results.splice(duplicates[j], 1)
+				}
+			}
+			return results
+		};
+
+		function siblingCheck(a, b) {
+			var cur = b && a,
+				diff = cur && (~b.sourceIndex || MAX_NEGATIVE) - (~a.sourceIndex || MAX_NEGATIVE);
+			if(diff) {
+				return diff
+			}
+			if(cur) {
+				while((cur = cur.nextSibling)) {
+					if(cur === b) {
+						return -1
+					}
+				}
+			}
+			return a ? 1 : -1
+		}
+
+		function createInputPseudo(type) {
+			return function(elem) {
+				var name = elem.nodeName.toLowerCase();
+				return name === "input" && elem.type === type
+			}
+		}
+
+		function createButtonPseudo(type) {
+			return function(elem) {
+				var name = elem.nodeName.toLowerCase();
+				return(name === "input" || name === "button") && elem.type === type
+			}
+		}
+
+		function createPositionalPseudo(fn) {
+			return markFunction(function(argument) {
+				argument = +argument;
+				return markFunction(function(seed, matches) {
+					var j, matchIndexes = fn([], seed.length, argument),
+						i = matchIndexes.length;
+					while(i--) {
+						if(seed[(j = matchIndexes[i])]) {
+							seed[j] = !(matches[j] = seed[j])
+						}
+					}
+				})
+			})
+		}
+		getText = Sizzle.getText = function(elem) {
+			var node, ret = "",
+				i = 0,
+				nodeType = elem.nodeType;
+			if(!nodeType) {
+				for(;
+					(node = elem[i]); i++) {
+					ret += getText(node)
+				}
+			} else if(nodeType === 1 || nodeType === 9 || nodeType === 11) {
+				if(typeof elem.textContent === "string") {
+					return elem.textContent
+				} else {
+					for(elem = elem.firstChild; elem; elem = elem.nextSibling) {
+						ret += getText(elem)
+					}
+				}
+			} else if(nodeType === 3 || nodeType === 4) {
+				return elem.nodeValue
+			}
+			return ret
+		};
+		Expr = Sizzle.selectors = {
+			cacheLength: 50,
+			createPseudo: markFunction,
+			match: matchExpr,
+			find: {},
+			relative: {
+				">": {
+					dir: "parentNode",
+					first: true
+				},
+				" ": {
+					dir: "parentNode"
+				},
+				"+": {
+					dir: "previousSibling",
+					first: true
+				},
+				"~": {
+					dir: "previousSibling"
+				}
+			},
+			preFilter: {
+				"ATTR": function(match) {
+					match[1] = match[1].replace(runescape, funescape);
+					match[3] = (match[4] || match[5] || "").replace(runescape, funescape);
+					if(match[2] === "~=") {
+						match[3] = " " + match[3] + " "
+					}
+					return match.slice(0, 4)
+				},
+				"CHILD": function(match) {
+					match[1] = match[1].toLowerCase();
+					if(match[1].slice(0, 3) === "nth") {
+						if(!match[3]) {
+							Sizzle.error(match[0])
+						}
+						match[4] = +(match[4] ? match[5] + (match[6] || 1) : 2 * (match[3] === "even" || match[3] === "odd"));
+						match[5] = +((match[7] + match[8]) || match[3] === "odd")
+					} else if(match[3]) {
+						Sizzle.error(match[0])
+					}
+					return match
+				},
+				"PSEUDO": function(match) {
+					var excess, unquoted = !match[5] && match[2];
+					if(matchExpr["CHILD"].test(match[0])) {
+						return null
+					}
+					if(match[4]) {
+						match[2] = match[4]
+					} else if(unquoted && rpseudo.test(unquoted) && (excess = tokenize(unquoted, true)) && (excess = unquoted.indexOf(")", unquoted.length - excess) - unquoted.length)) {
+						match[0] = match[0].slice(0, excess);
+						match[2] = unquoted.slice(0, excess)
+					}
+					return match.slice(0, 3)
+				}
+			},
+			filter: {
+				"TAG": function(nodeName) {
+					if(nodeName === "*") {
+						return function() {
+							return true
+						}
+					}
+					nodeName = nodeName.replace(runescape, funescape).toLowerCase();
+					return function(elem) {
+						return elem.nodeName && elem.nodeName.toLowerCase() === nodeName
+					}
+				},
+				"CLASS": function(className) {
+					var pattern = classCache[className + " "];
+					return pattern || (pattern = new RegExp("(^|" + whitespace + ")" + className + "(" + whitespace + "|$)")) && classCache(className, function(elem) {
+						return pattern.test(elem.className || (typeof elem.getAttribute !== strundefined && elem.getAttribute("class")) || "")
+					})
+				},
+				"ATTR": function(name, operator, check) {
+					return function(elem) {
+						var result = Sizzle.attr(elem, name);
+						if(result == null) {
+							return operator === "!="
+						}
+						if(!operator) {
+							return true
+						}
+						result += "";
+						return operator === "=" ? result === check : operator === "!=" ? result !== check : operator === "^=" ? check && result.indexOf(check) === 0 : operator === "*=" ? check && result.indexOf(check) > -1 : operator === "$=" ? check && result.slice(-check.length) === check : operator === "~=" ? (" " + result + " ").indexOf(check) > -1 : operator === "|=" ? result === check || result.slice(0, check.length + 1) === check + "-" : false
+					}
+				},
+				"CHILD": function(type, what, argument, first, last) {
+					var simple = type.slice(0, 3) !== "nth",
+						forward = type.slice(-4) !== "last",
+						ofType = what === "of-type";
+					return first === 1 && last === 0 ? function(elem) {
+						return !!elem.parentNode
+					} : function(elem, context, xml) {
+						var cache, outerCache, node, diff, nodeIndex, start, dir = simple !== forward ? "nextSibling" : "previousSibling",
+							parent = elem.parentNode,
+							name = ofType && elem.nodeName.toLowerCase(),
+							useCache = !xml && !ofType;
+						if(parent) {
+							if(simple) {
+								while(dir) {
+									node = elem;
+									while((node = node[dir])) {
+										if(ofType ? node.nodeName.toLowerCase() === name : node.nodeType === 1) {
+											return false
+										}
+									}
+									start = dir = type === "only" && !start && "nextSibling"
+								}
+								return true
+							}
+							start = [forward ? parent.firstChild : parent.lastChild];
+							if(forward && useCache) {
+								outerCache = parent[expando] || (parent[expando] = {});
+								cache = outerCache[type] || [];
+								nodeIndex = cache[0] === dirruns && cache[1];
+								diff = cache[0] === dirruns && cache[2];
+								node = nodeIndex && parent.childNodes[nodeIndex];
+								while((node = ++nodeIndex && node && node[dir] || (diff = nodeIndex = 0) || start.pop())) {
+									if(node.nodeType === 1 && ++diff && node === elem) {
+										outerCache[type] = [dirruns, nodeIndex, diff];
+										break
+									}
+								}
+							} else if(useCache && (cache = (elem[expando] || (elem[expando] = {}))[type]) && cache[0] === dirruns) {
+								diff = cache[1]
+							} else {
+								while((node = ++nodeIndex && node && node[dir] || (diff = nodeIndex = 0) || start.pop())) {
+									if((ofType ? node.nodeName.toLowerCase() === name : node.nodeType === 1) && ++diff) {
+										if(useCache) {
+											(node[expando] || (node[expando] = {}))[type] = [dirruns, diff]
+										}
+										if(node === elem) {
+											break
+										}
+									}
+								}
+							}
+							diff -= last;
+							return diff === first || (diff % first === 0 && diff / first >= 0)
+						}
+					}
+				},
+				"PSEUDO": function(pseudo, argument) {
+					var args, fn = Expr.pseudos[pseudo] || Expr.setFilters[pseudo.toLowerCase()] || Sizzle.error("unsupported pseudo: " + pseudo);
+					if(fn[expando]) {
+						return fn(argument)
+					}
+					if(fn.length > 1) {
+						args = [pseudo, pseudo, "", argument];
+						return Expr.setFilters.hasOwnProperty(pseudo.toLowerCase()) ? markFunction(function(seed, matches) {
+							var idx, matched = fn(seed, argument),
+								i = matched.length;
+							while(i--) {
+								idx = indexOf.call(seed, matched[i]);
+								seed[idx] = !(matches[idx] = matched[i])
+							}
+						}) : function(elem) {
+							return fn(elem, 0, args)
+						}
+					}
+					return fn
+				}
+			},
+			pseudos: {
+				"not": markFunction(function(selector) {
+					var input = [],
+						results = [],
+						matcher = compile(selector.replace(rtrim, "$1"));
+					return matcher[expando] ? markFunction(function(seed, matches, context, xml) {
+						var elem, unmatched = matcher(seed, null, xml, []),
+							i = seed.length;
+						while(i--) {
+							if((elem = unmatched[i])) {
+								seed[i] = !(matches[i] = elem)
+							}
+						}
+					}) : function(elem, context, xml) {
+						input[0] = elem;
+						matcher(input, null, xml, results);
+						return !results.pop()
+					}
+				}),
+				"has": markFunction(function(selector) {
+					return function(elem) {
+						return Sizzle(selector, elem).length > 0
+					}
+				}),
+				"contains": markFunction(function(text) {
+					return function(elem) {
+						return(elem.textContent || elem.innerText || getText(elem)).indexOf(text) > -1
+					}
+				}),
+				"lang": markFunction(function(lang) {
+					if(!ridentifier.test(lang || "")) {
+						Sizzle.error("unsupported lang: " + lang)
+					}
+					lang = lang.replace(runescape, funescape).toLowerCase();
+					return function(elem) {
+						var elemLang;
+						do {
+							if((elemLang = documentIsXML ? elem.getAttribute("xml:lang") || elem.getAttribute("lang") : elem.lang)) {
+								elemLang = elemLang.toLowerCase();
+								return elemLang === lang || elemLang.indexOf(lang + "-") === 0
+							}
+						} while ((elem = elem.parentNode) && elem.nodeType === 1);
+						return false
+					}
+				}),
+				"target": function(elem) {
+					var hash = window.location && window.location.hash;
+					return hash && hash.slice(1) === elem.id
+				},
+				"root": function(elem) {
+					return elem === docElem
+				},
+				"focus": function(elem) {
+					return elem === document.activeElement && (!document.hasFocus || document.hasFocus()) && !!(elem.type || elem.href || ~elem.tabIndex)
+				},
+				"enabled": function(elem) {
+					return elem.disabled === false
+				},
+				"disabled": function(elem) {
+					return elem.disabled === true
+				},
+				"checked": function(elem) {
+					var nodeName = elem.nodeName.toLowerCase();
+					return(nodeName === "input" && !!elem.checked) || (nodeName === "option" && !!elem.selected)
+				},
+				"selected": function(elem) {
+					if(elem.parentNode) {
+						elem.parentNode.selectedIndex
+					}
+					return elem.selected === true
+				},
+				"empty": function(elem) {
+					for(elem = elem.firstChild; elem; elem = elem.nextSibling) {
+						if(elem.nodeName > "@" || elem.nodeType === 3 || elem.nodeType === 4) {
+							return false
+						}
+					}
+					return true
+				},
+				"parent": function(elem) {
+					return !Expr.pseudos["empty"](elem)
+				},
+				"header": function(elem) {
+					return rheader.test(elem.nodeName)
+				},
+				"input": function(elem) {
+					return rinputs.test(elem.nodeName)
+				},
+				"button": function(elem) {
+					var name = elem.nodeName.toLowerCase();
+					return name === "input" && elem.type === "button" || name === "button"
+				},
+				"text": function(elem) {
+					var attr;
+					return elem.nodeName.toLowerCase() === "input" && elem.type === "text" && ((attr = elem.getAttribute("type")) == null || attr.toLowerCase() === elem.type)
+				},
+				"first": createPositionalPseudo(function() {
+					return [0]
+				}),
+				"last": createPositionalPseudo(function(matchIndexes, length) {
+					return [length - 1]
+				}),
+				"eq": createPositionalPseudo(function(matchIndexes, length, argument) {
+					return [argument < 0 ? argument + length : argument]
+				}),
+				"even": createPositionalPseudo(function(matchIndexes, length) {
+					var i = 0;
+					for(; i < length; i += 2) {
+						matchIndexes.push(i)
+					}
+					return matchIndexes
+				}),
+				"odd": createPositionalPseudo(function(matchIndexes, length) {
+					var i = 1;
+					for(; i < length; i += 2) {
+						matchIndexes.push(i)
+					}
+					return matchIndexes
+				}),
+				"lt": createPositionalPseudo(function(matchIndexes, length, argument) {
+					var i = argument < 0 ? argument + length : argument;
+					for(; --i >= 0;) {
+						matchIndexes.push(i)
+					}
+					return matchIndexes
+				}),
+				"gt": createPositionalPseudo(function(matchIndexes, length, argument) {
+					var i = argument < 0 ? argument + length : argument;
+					for(; ++i < length;) {
+						matchIndexes.push(i)
+					}
+					return matchIndexes
+				})
+			}
+		};
+		for(i in {
+				radio: true,
+				checkbox: true,
+				file: true,
+				password: true,
+				image: true
+			}) {
+			Expr.pseudos[i] = createInputPseudo(i)
+		}
+		for(i in {
+				submit: true,
+				reset: true
+			}) {
+			Expr.pseudos[i] = createButtonPseudo(i)
+		}
+
+		function tokenize(selector, parseOnly) {
+			var matched, match, tokens, type, soFar, groups, preFilters, cached = tokenCache[selector + " "];
+			if(cached) {
+				return parseOnly ? 0 : cached.slice(0)
+			}
+			soFar = selector;
+			groups = [];
+			preFilters = Expr.preFilter;
+			while(soFar) {
+				if(!matched || (match = rcomma.exec(soFar))) {
+					if(match) {
+						soFar = soFar.slice(match[0].length) || soFar
+					}
+					groups.push(tokens = [])
+				}
+				matched = false;
+				if((match = rcombinators.exec(soFar))) {
+					matched = match.shift();
+					tokens.push({
+						value: matched,
+						type: match[0].replace(rtrim, " ")
+					});
+					soFar = soFar.slice(matched.length)
+				}
+				for(type in Expr.filter) {
+					if((match = matchExpr[type].exec(soFar)) && (!preFilters[type] || (match = preFilters[type](match)))) {
+						matched = match.shift();
+						tokens.push({
+							value: matched,
+							type: type,
+							matches: match
+						});
+						soFar = soFar.slice(matched.length)
+					}
+				}
+				if(!matched) {
+					break
+				}
+			}
+			return parseOnly ? soFar.length : soFar ? Sizzle.error(selector) : tokenCache(selector, groups).slice(0)
+		}
+
+		function toSelector(tokens) {
+			var i = 0,
+				len = tokens.length,
+				selector = "";
+			for(; i < len; i++) {
+				selector += tokens[i].value
+			}
+			return selector
+		}
+
+		function addCombinator(matcher, combinator, base) {
+			var dir = combinator.dir,
+				checkNonElements = base && dir === "parentNode",
+				doneName = done++;
+			return combinator.first ? function(elem, context, xml) {
+				while((elem = elem[dir])) {
+					if(elem.nodeType === 1 || checkNonElements) {
+						return matcher(elem, context, xml)
+					}
+				}
+			} : function(elem, context, xml) {
+				var data, cache, outerCache, dirkey = dirruns + " " + doneName;
+				if(xml) {
+					while((elem = elem[dir])) {
+						if(elem.nodeType === 1 || checkNonElements) {
+							if(matcher(elem, context, xml)) {
+								return true
+							}
+						}
+					}
+				} else {
+					while((elem = elem[dir])) {
+						if(elem.nodeType === 1 || checkNonElements) {
+							outerCache = elem[expando] || (elem[expando] = {});
+							if((cache = outerCache[dir]) && cache[0] === dirkey) {
+								if((data = cache[1]) === true || data === cachedruns) {
+									return data === true
+								}
+							} else {
+								cache = outerCache[dir] = [dirkey];
+								cache[1] = matcher(elem, context, xml) || cachedruns;
+								if(cache[1] === true) {
+									return true
+								}
+							}
+						}
+					}
+				}
+			}
+		}
+
+		function elementMatcher(matchers) {
+			return matchers.length > 1 ? function(elem, context, xml) {
+				var i = matchers.length;
+				while(i--) {
+					if(!matchers[i](elem, context, xml)) {
+						return false
+					}
+				}
+				return true
+			} : matchers[0]
+		}
+
+		function condense(unmatched, map, filter, context, xml) {
+			var elem, newUnmatched = [],
+				i = 0,
+				len = unmatched.length,
+				mapped = map != null;
+			for(; i < len; i++) {
+				if((elem = unmatched[i])) {
+					if(!filter || filter(elem, context, xml)) {
+						newUnmatched.push(elem);
+						if(mapped) {
+							map.push(i)
+						}
+					}
+				}
+			}
+			return newUnmatched
+		}
+
+		function setMatcher(preFilter, selector, matcher, postFilter, postFinder, postSelector) {
+			if(postFilter && !postFilter[expando]) {
+				postFilter = setMatcher(postFilter)
+			}
+			if(postFinder && !postFinder[expando]) {
+				postFinder = setMatcher(postFinder, postSelector)
+			}
+			return markFunction(function(seed, results, context, xml) {
+				var temp, i, elem, preMap = [],
+					postMap = [],
+					preexisting = results.length,
+					elems = seed || multipleContexts(selector || "*", context.nodeType ? [context] : context, []),
+					matcherIn = preFilter && (seed || !selector) ? condense(elems, preMap, preFilter, context, xml) : elems,
+					matcherOut = matcher ? postFinder || (seed ? preFilter : preexisting || postFilter) ? [] : results : matcherIn;
+				if(matcher) {
+					matcher(matcherIn, matcherOut, context, xml)
+				}
+				if(postFilter) {
+					temp = condense(matcherOut, postMap);
+					postFilter(temp, [], context, xml);
+					i = temp.length;
+					while(i--) {
+						if((elem = temp[i])) {
+							matcherOut[postMap[i]] = !(matcherIn[postMap[i]] = elem)
+						}
+					}
+				}
+				if(seed) {
+					if(postFinder || preFilter) {
+						if(postFinder) {
+							temp = [];
+							i = matcherOut.length;
+							while(i--) {
+								if((elem = matcherOut[i])) {
+									temp.push((matcherIn[i] = elem))
+								}
+							}
+							postFinder(null, (matcherOut = []), temp, xml)
+						}
+						i = matcherOut.length;
+						while(i--) {
+							if((elem = matcherOut[i]) && (temp = postFinder ? indexOf.call(seed, elem) : preMap[i]) > -1) {
+								seed[temp] = !(results[temp] = elem)
+							}
+						}
+					}
+				} else {
+					matcherOut = condense(matcherOut === results ? matcherOut.splice(preexisting, matcherOut.length) : matcherOut);
+					if(postFinder) {
+						postFinder(null, results, matcherOut, xml)
+					} else {
+						push.apply(results, matcherOut)
+					}
+				}
+			})
+		}
+
+		function matcherFromTokens(tokens) {
+			var checkContext, matcher, j, len = tokens.length,
+				leadingRelative = Expr.relative[tokens[0].type],
+				implicitRelative = leadingRelative || Expr.relative[" "],
+				i = leadingRelative ? 1 : 0,
+				matchContext = addCombinator(function(elem) {
+					return elem === checkContext
+				}, implicitRelative, true),
+				matchAnyContext = addCombinator(function(elem) {
+					return indexOf.call(checkContext, elem) > -1
+				}, implicitRelative, true),
+				matchers = [function(elem, context, xml) {
+					return(!leadingRelative && (xml || context !== outermostContext)) || ((checkContext = context).nodeType ? matchContext(elem, context, xml) : matchAnyContext(elem, context, xml))
+				}];
+			for(; i < len; i++) {
+				if((matcher = Expr.relative[tokens[i].type])) {
+					matchers = [addCombinator(elementMatcher(matchers), matcher)]
+				} else {
+					matcher = Expr.filter[tokens[i].type].apply(null, tokens[i].matches);
+					if(matcher[expando]) {
+						j = ++i;
+						for(; j < len; j++) {
+							if(Expr.relative[tokens[j].type]) {
+								break
+							}
+						}
+						return setMatcher(i > 1 && elementMatcher(matchers), i > 1 && toSelector(tokens.slice(0, i - 1)).replace(rtrim, "$1"), matcher, i < j && matcherFromTokens(tokens.slice(i, j)), j < len && matcherFromTokens((tokens = tokens.slice(j))), j < len && toSelector(tokens))
+					}
+					matchers.push(matcher)
+				}
+			}
+			return elementMatcher(matchers)
+		}
+
+		function matcherFromGroupMatchers(elementMatchers, setMatchers) {
+			var matcherCachedRuns = 0,
+				bySet = setMatchers.length > 0,
+				byElement = elementMatchers.length > 0,
+				superMatcher = function(seed, context, xml, results, expandContext) {
+					var elem, j, matcher, setMatched = [],
+						matchedCount = 0,
+						i = "0",
+						unmatched = seed && [],
+						outermost = expandContext != null,
+						contextBackup = outermostContext,
+						elems = seed || byElement && Expr.find["TAG"]("*", expandContext && context.parentNode || context),
+						dirrunsUnique = (dirruns += contextBackup == null ? 1 : Math.random() || 0.1);
+					if(outermost) {
+						outermostContext = context !== document && context;
+						cachedruns = matcherCachedRuns
+					}
+					for(;
+						(elem = elems[i]) != null; i++) {
+						if(byElement && elem) {
+							j = 0;
+							while((matcher = elementMatchers[j++])) {
+								if(matcher(elem, context, xml)) {
+									results.push(elem);
+									break
+								}
+							}
+							if(outermost) {
+								dirruns = dirrunsUnique;
+								cachedruns = ++matcherCachedRuns
+							}
+						}
+						if(bySet) {
+							if((elem = !matcher && elem)) {
+								matchedCount--
+							}
+							if(seed) {
+								unmatched.push(elem)
+							}
+						}
+					}
+					matchedCount += i;
+					if(bySet && i !== matchedCount) {
+						j = 0;
+						while((matcher = setMatchers[j++])) {
+							matcher(unmatched, setMatched, context, xml)
+						}
+						if(seed) {
+							if(matchedCount > 0) {
+								while(i--) {
+									if(!(unmatched[i] || setMatched[i])) {
+										setMatched[i] = pop.call(results)
+									}
+								}
+							}
+							setMatched = condense(setMatched)
+						}
+						push.apply(results, setMatched);
+						if(outermost && !seed && setMatched.length > 0 && (matchedCount + setMatchers.length) > 1) {
+							Sizzle.uniqueSort(results)
+						}
+					}
+					if(outermost) {
+						dirruns = dirrunsUnique;
+						outermostContext = contextBackup
+					}
+					return unmatched
+				};
+			return bySet ? markFunction(superMatcher) : superMatcher
+		}
+		compile = Sizzle.compile = function(selector, group) {
+			var i, setMatchers = [],
+				elementMatchers = [],
+				cached = compilerCache[selector + " "];
+			if(!cached) {
+				if(!group) {
+					group = tokenize(selector)
+				}
+				i = group.length;
+				while(i--) {
+					cached = matcherFromTokens(group[i]);
+					if(cached[expando]) {
+						setMatchers.push(cached)
+					} else {
+						elementMatchers.push(cached)
+					}
+				}
+				cached = compilerCache(selector, matcherFromGroupMatchers(elementMatchers, setMatchers))
+			}
+			return cached
+		};
+
+		function multipleContexts(selector, contexts, results) {
+			var i = 0,
+				len = contexts.length;
+			for(; i < len; i++) {
+				Sizzle(selector, contexts[i], results)
+			}
+			return results
+		}
+
+		function select(selector, context, results, seed) {
+			var i, tokens, token, type, find, match = tokenize(selector);
+			if(!seed) {
+				if(match.length === 1) {
+					tokens = match[0] = match[0].slice(0);
+					if(tokens.length > 2 && (token = tokens[0]).type === "ID" && context.nodeType === 9 && !documentIsXML && Expr.relative[tokens[1].type]) {
+						context = Expr.find["ID"](token.matches[0].replace(runescape, funescape), context)[0];
+						if(!context) {
+							return results
+						}
+						selector = selector.slice(tokens.shift().value.length)
+					}
+					i = matchExpr["needsContext"].test(selector) ? 0 : tokens.length;
+					while(i--) {
+						token = tokens[i];
+						if(Expr.relative[(type = token.type)]) {
+							break
+						}
+						if((find = Expr.find[type])) {
+							if((seed = find(token.matches[0].replace(runescape, funescape), rsibling.test(tokens[0].type) && context.parentNode || context))) {
+								tokens.splice(i, 1);
+								selector = seed.length && toSelector(tokens);
+								if(!selector) {
+									push.apply(results, slice.call(seed, 0));
+									return results
+								}
+								break
+							}
+						}
+					}
+				}
+			}
+			compile(selector, match)(seed, context, documentIsXML, results, rsibling.test(selector));
+			return results
+		}
+		Expr.pseudos["nth"] = Expr.pseudos["eq"];
+
+		function setFilters() {}
+		Expr.filters = setFilters.prototype = Expr.pseudos;
+		Expr.setFilters = new setFilters();
+		setDocument();
+		Sizzle.attr = jQuery.attr;
+		jQuery.find = Sizzle;
+		jQuery.expr = Sizzle.selectors;
+		jQuery.expr[":"] = jQuery.expr.pseudos;
+		jQuery.unique = Sizzle.uniqueSort;
+		jQuery.text = Sizzle.getText;
+		jQuery.isXMLDoc = Sizzle.isXML;
+		jQuery.contains = Sizzle.contains
+	})(window);
+	var runtil = /Until$/,
+		rparentsprev = /^(?:parents|prev(?:Until|All))/,
+		isSimple = /^.[^:#\[\.,]*$/,
+		rneedsContext = jQuery.expr.match.needsContext,
+		guaranteedUnique = {
+			children: true,
+			contents: true,
+			next: true,
+			prev: true
+		};
+	jQuery.fn.extend({
+		find: function(selector) {
+			var i, ret, self, len = this.length;
+			if(typeof selector !== "string") {
+				self = this;
+				return this.pushStack(jQuery(selector).filter(function() {
+					for(i = 0; i < len; i++) {
+						if(jQuery.contains(self[i], this)) {
+							return true
+						}
+					}
+				}))
+			}
+			ret = [];
+			for(i = 0; i < len; i++) {
+				jQuery.find(selector, this[i], ret)
+			}
+			ret = this.pushStack(len > 1 ? jQuery.unique(ret) : ret);
+			ret.selector = (this.selector ? this.selector + " " : "") + selector;
+			return ret
+		},
+		has: function(target) {
+			var i, targets = jQuery(target, this),
+				len = targets.length;
+			return this.filter(function() {
+				for(i = 0; i < len; i++) {
+					if(jQuery.contains(this, targets[i])) {
+						return true
+					}
+				}
+			})
+		},
+		not: function(selector) {
+			return this.pushStack(winnow(this, selector, false))
+		},
+		filter: function(selector) {
+			return this.pushStack(winnow(this, selector, true))
+		},
+		is: function(selector) {
+			return !!selector && (typeof selector === "string" ? rneedsContext.test(selector) ? jQuery(selector, this.context).index(this[0]) >= 0 : jQuery.filter(selector, this).length > 0 : this.filter(selector).length > 0)
+		},
+		closest: function(selectors, context) {
+			var cur, i = 0,
+				l = this.length,
+				ret = [],
+				pos = rneedsContext.test(selectors) || typeof selectors !== "string" ? jQuery(selectors, context || this.context) : 0;
+			for(; i < l; i++) {
+				cur = this[i];
+				while(cur && cur.ownerDocument && cur !== context && cur.nodeType !== 11) {
+					if(pos ? pos.index(cur) > -1 : jQuery.find.matchesSelector(cur, selectors)) {
+						ret.push(cur);
+						break
+					}
+					cur = cur.parentNode
+				}
+			}
+			return this.pushStack(ret.length > 1 ? jQuery.unique(ret) : ret)
+		},
+		index: function(elem) {
+			if(!elem) {
+				return(this[0] && this[0].parentNode) ? this.first().prevAll().length : -1
+			}
+			if(typeof elem === "string") {
+				return jQuery.inArray(this[0], jQuery(elem))
+			}
+			return jQuery.inArray(elem.jquery ? elem[0] : elem, this)
+		},
+		add: function(selector, context) {
+			var set = typeof selector === "string" ? jQuery(selector, context) : jQuery.makeArray(selector && selector.nodeType ? [selector] : selector),
+				all = jQuery.merge(this.get(), set);
+			return this.pushStack(jQuery.unique(all))
+		},
+		addBack: function(selector) {
+			return this.add(selector == null ? this.prevObject : this.prevObject.filter(selector))
+		}
+	});
+	jQuery.fn.andSelf = jQuery.fn.addBack;
 
-function collectImagesForPreloading() {
-	var images = [];
-	
-	$(".carousel .choose-color").each(function() {
-		var files = [];
-		
-		$(this).find("div").each(function() {
-			files.push($(this).attr("class"));
+	function sibling(cur, dir) {
+		do {
+			cur = cur[dir]
+		} while (cur && cur.nodeType !== 1);
+		return cur
+	}
+	jQuery.each({
+		parent: function(elem) {
+			var parent = elem.parentNode;
+			return parent && parent.nodeType !== 11 ? parent : null
+		},
+		parents: function(elem) {
+			return jQuery.dir(elem, "parentNode")
+		},
+		parentsUntil: function(elem, i, until) {
+			return jQuery.dir(elem, "parentNode", until)
+		},
+		next: function(elem) {
+			return sibling(elem, "nextSibling")
+		},
+		prev: function(elem) {
+			return sibling(elem, "previousSibling")
+		},
+		nextAll: function(elem) {
+			return jQuery.dir(elem, "nextSibling")
+		},
+		prevAll: function(elem) {
+			return jQuery.dir(elem, "previousSibling")
+		},
+		nextUntil: function(elem, i, until) {
+			return jQuery.dir(elem, "nextSibling", until)
+		},
+		prevUntil: function(elem, i, until) {
+			return jQuery.dir(elem, "previousSibling", until)
+		},
+		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.merge([], elem.childNodes)
+		}
+	}, function(name, fn) {
+		jQuery.fn[name] = function(until, selector) {
+			var ret = jQuery.map(this, fn, until);
+			if(!runtil.test(name)) {
+				selector = until
+			}
+			if(selector && typeof selector === "string") {
+				ret = jQuery.filter(selector, ret)
+			}
+			ret = this.length > 1 && !guaranteedUnique[name] ? jQuery.unique(ret) : ret;
+			if(this.length > 1 && rparentsprev.test(name)) {
+				ret = ret.reverse()
+			}
+			return this.pushStack(ret)
+		}
+	});
+	jQuery.extend({
+		filter: function(expr, elems, not) {
+			if(not) {
+				expr = ":not(" + expr + ")"
+			}
+			return elems.length === 1 ? jQuery.find.matchesSelector(elems[0], expr) ? [elems[0]] : [] : jQuery.find.matches(expr, elems)
+		},
+		dir: function(elem, dir, until) {
+			var matched = [],
+				cur = elem[dir];
+			while(cur && cur.nodeType !== 9 && (until === undefined || cur.nodeType !== 1 || !jQuery(cur).is(until))) {
+				if(cur.nodeType === 1) {
+					matched.push(cur)
+				}
+				cur = cur[dir]
+			}
+			return matched
+		},
+		sibling: function(n, elem) {
+			var r = [];
+			for(; n; n = n.nextSibling) {
+				if(n.nodeType === 1 && n !== elem) {
+					r.push(n)
+				}
+			}
+			return r
+		}
+	});
+
+	function winnow(elements, qualifier, keep) {
+		qualifier = qualifier || 0;
+		if(jQuery.isFunction(qualifier)) {
+			return jQuery.grep(elements, function(elem, i) {
+				var retVal = !!qualifier.call(elem, i, elem);
+				return retVal === keep
+			})
+		} else if(qualifier.nodeType) {
+			return jQuery.grep(elements, function(elem) {
+				return(elem === qualifier) === keep
+			})
+		} else if(typeof qualifier === "string") {
+			var filtered = jQuery.grep(elements, function(elem) {
+				return elem.nodeType === 1
+			});
+			if(isSimple.test(qualifier)) {
+				return jQuery.filter(qualifier, filtered, !keep)
+			} else {
+				qualifier = jQuery.filter(qualifier, filtered)
+			}
+		}
+		return jQuery.grep(elements, function(elem) {
+			return(jQuery.inArray(elem, qualifier) >= 0) === keep
+		})
+	}
+
+	function createSafeFragment(document) {
+		var list = nodeNames.split("|"),
+			safeFrag = document.createDocumentFragment();
+		if(safeFrag.createElement) {
+			while(list.length) {
+				safeFrag.createElement(list.pop())
+			}
+		}
+		return safeFrag
+	}
+	var nodeNames = "abbr|article|aside|audio|bdi|canvas|data|datalist|details|figcaption|figure|footer|header|hgroup|mark|meter|nav|output|progress|section|summary|time|video",
+		rinlinejQuery = / jQuery\d+="(?:null|\d+)"/g,
+		rnoshimcache = new RegExp("<(?:" + nodeNames + ")[\\s/>]", "i"),
+		rleadingWhitespace = /^\s+/,
+		rxhtmlTag = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi,
+		rtagName = /<([\w:]+)/,
+		rtbody = /<tbody/i,
+		rhtml = /<|&#?\w+;/,
+		rnoInnerhtml = /<(?:script|style|link)/i,
+		manipulation_rcheckableType = /^(?:checkbox|radio)$/i,
+		rchecked = /checked\s*(?:[^=]|=\s*.checked.)/i,
+		rscriptType = /^$|\/(?:java|ecma)script/i,
+		rscriptTypeMasked = /^true\/(.*)/,
+		rcleanScript = /^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g,
+		wrapMap = {
+			option: [1, "<select multiple='multiple'>", "</select>"],
+			legend: [1, "<fieldset>", "</fieldset>"],
+			area: [1, "<map>", "</map>"],
+			param: [1, "<object>", "</object>"],
+			thead: [1, "<table>", "</table>"],
+			tr: [2, "<table><tbody>", "</tbody></table>"],
+			col: [2, "<table><tbody></tbody><colgroup>", "</colgroup></table>"],
+			td: [3, "<table><tbody><tr>", "</tr></tbody></table>"],
+			_default: jQuery.support.htmlSerialize ? [0, "", ""] : [1, "X<div>", "</div>"]
+		},
+		safeFragment = createSafeFragment(document),
+		fragmentDiv = safeFragment.appendChild(document.createElement("div"));
+	wrapMap.optgroup = wrapMap.option;
+	wrapMap.tbody = wrapMap.tfoot = wrapMap.colgroup = wrapMap.caption = wrapMap.thead;
+	wrapMap.th = wrapMap.td;
+	jQuery.fn.extend({
+		text: function(value) {
+			return jQuery.access(this, function(value) {
+				return value === undefined ? jQuery.text(this) : this.empty().append((this[0] && this[0].ownerDocument || document).createTextNode(value))
+			}, null, value, arguments.length)
+		},
+		wrapAll: function(html) {
+			if(jQuery.isFunction(html)) {
+				return this.each(function(i) {
+					jQuery(this).wrapAll(html.call(this, i))
+				})
+			}
+			if(this[0]) {
+				var wrap = jQuery(html, this[0].ownerDocument).eq(0).clone(true);
+				if(this[0].parentNode) {
+					wrap.insertBefore(this[0])
+				}
+				wrap.map(function() {
+					var elem = this;
+					while(elem.firstChild && elem.firstChild.nodeType === 1) {
+						elem = elem.firstChild
+					}
+					return elem
+				}).append(this)
+			}
+			return this
+		},
+		wrapInner: function(html) {
+			if(jQuery.isFunction(html)) {
+				return this.each(function(i) {
+					jQuery(this).wrapInner(html.call(this, i))
+				})
+			}
+			return this.each(function() {
+				var self = jQuery(this),
+					contents = self.contents();
+				if(contents.length) {
+					contents.wrapAll(html)
+				} else {
+					self.append(html)
+				}
+			})
+		},
+		wrap: function(html) {
+			var isFunction = jQuery.isFunction(html);
+			return this.each(function(i) {
+				jQuery(this).wrapAll(isFunction ? html.call(this, i) : html)
+			})
+		},
+		unwrap: function() {
+			return this.parent().each(function() {
+				if(!jQuery.nodeName(this, "body")) {
+					jQuery(this).replaceWith(this.childNodes)
+				}
+			}).end()
+		},
+		append: function() {
+			return this.domManip(arguments, true, function(elem) {
+				if(this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9) {
+					this.appendChild(elem)
+				}
+			})
+		},
+		prepend: function() {
+			return this.domManip(arguments, true, function(elem) {
+				if(this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9) {
+					this.insertBefore(elem, this.firstChild)
+				}
+			})
+		},
+		before: function() {
+			return this.domManip(arguments, false, function(elem) {
+				if(this.parentNode) {
+					this.parentNode.insertBefore(elem, this)
+				}
+			})
+		},
+		after: function() {
+			return this.domManip(arguments, false, function(elem) {
+				if(this.parentNode) {
+					this.parentNode.insertBefore(elem, this.nextSibling)
+				}
+			})
+		},
+		remove: function(selector, keepData) {
+			var elem, i = 0;
+			for(;
+				(elem = this[i]) != null; i++) {
+				if(!selector || jQuery.filter(selector, [elem]).length > 0) {
+					if(!keepData && elem.nodeType === 1) {
+						jQuery.cleanData(getAll(elem))
+					}
+					if(elem.parentNode) {
+						if(keepData && jQuery.contains(elem.ownerDocument, elem)) {
+							setGlobalEval(getAll(elem, "script"))
+						}
+						elem.parentNode.removeChild(elem)
+					}
+				}
+			}
+			return this
+		},
+		empty: function() {
+			var elem, i = 0;
+			for(;
+				(elem = this[i]) != null; i++) {
+				if(elem.nodeType === 1) {
+					jQuery.cleanData(getAll(elem, false))
+				}
+				while(elem.firstChild) {
+					elem.removeChild(elem.firstChild)
+				}
+				if(elem.options && jQuery.nodeName(elem, "select")) {
+					elem.options.length = 0
+				}
+			}
+			return this
+		},
+		clone: function(dataAndEvents, deepDataAndEvents) {
+			dataAndEvents = dataAndEvents == null ? false : dataAndEvents;
+			deepDataAndEvents = deepDataAndEvents == null ? dataAndEvents : deepDataAndEvents;
+			return this.map(function() {
+				return jQuery.clone(this, dataAndEvents, deepDataAndEvents)
+			})
+		},
+		html: function(value) {
+			return jQuery.access(this, function(value) {
+				var elem = this[0] || {},
+					i = 0,
+					l = this.length;
+				if(value === undefined) {
+					return elem.nodeType === 1 ? elem.innerHTML.replace(rinlinejQuery, "") : undefined
+				}
+				if(typeof value === "string" && !rnoInnerhtml.test(value) && (jQuery.support.htmlSerialize || !rnoshimcache.test(value)) && (jQuery.support.leadingWhitespace || !rleadingWhitespace.test(value)) && !wrapMap[(rtagName.exec(value) || ["", ""])[1].toLowerCase()]) {
+					value = value.replace(rxhtmlTag, "<$1></$2>");
+					try {
+						for(; i < l; i++) {
+							elem = this[i] || {};
+							if(elem.nodeType === 1) {
+								jQuery.cleanData(getAll(elem, false));
+								elem.innerHTML = value
+							}
+						}
+						elem = 0
+					} catch(e) {}
+				}
+				if(elem) {
+					this.empty().append(value)
+				}
+			}, null, value, arguments.length)
+		},
+		replaceWith: function(value) {
+			var isFunc = jQuery.isFunction(value);
+			if(!isFunc && typeof value !== "string") {
+				value = jQuery(value).not(this).detach()
+			}
+			return this.domManip([value], true, function(elem) {
+				var next = this.nextSibling,
+					parent = this.parentNode;
+				if(parent) {
+					jQuery(this).remove();
+					parent.insertBefore(elem, next)
+				}
+			})
+		},
+		detach: function(selector) {
+			return this.remove(selector, true)
+		},
+		domManip: function(args, table, callback) {
+			args = core_concat.apply([], args);
+			var first, node, hasScripts, scripts, doc, fragment, i = 0,
+				l = this.length,
+				set = this,
+				iNoClone = l - 1,
+				value = args[0],
+				isFunction = jQuery.isFunction(value);
+			if(isFunction || !(l <= 1 || typeof value !== "string" || jQuery.support.checkClone || !rchecked.test(value))) {
+				return this.each(function(index) {
+					var self = set.eq(index);
+					if(isFunction) {
+						args[0] = value.call(this, index, table ? self.html() : undefined)
+					}
+					self.domManip(args, table, callback)
+				})
+			}
+			if(l) {
+				fragment = jQuery.buildFragment(args, this[0].ownerDocument, false, this);
+				first = fragment.firstChild;
+				if(fragment.childNodes.length === 1) {
+					fragment = first
+				}
+				if(first) {
+					table = table && jQuery.nodeName(first, "tr");
+					scripts = jQuery.map(getAll(fragment, "script"), disableScript);
+					hasScripts = scripts.length;
+					for(; i < l; i++) {
+						node = fragment;
+						if(i !== iNoClone) {
+							node = jQuery.clone(node, true, true);
+							if(hasScripts) {
+								jQuery.merge(scripts, getAll(node, "script"))
+							}
+						}
+						callback.call(table && jQuery.nodeName(this[i], "table") ? findOrAppend(this[i], "tbody") : this[i], node, i)
+					}
+					if(hasScripts) {
+						doc = scripts[scripts.length - 1].ownerDocument;
+						jQuery.map(scripts, restoreScript);
+						for(i = 0; i < hasScripts; i++) {
+							node = scripts[i];
+							if(rscriptType.test(node.type || "") && !jQuery._data(node, "globalEval") && jQuery.contains(doc, node)) {
+								if(node.src) {
+									jQuery.ajax({
+										url: node.src,
+										type: "GET",
+										dataType: "script",
+										async: false,
+										global: false,
+										"throws": true
+									})
+								} else {
+									jQuery.globalEval((node.text || node.textContent || node.innerHTML || "").replace(rcleanScript, ""))
+								}
+							}
+						}
+					}
+					fragment = first = null
+				}
+			}
+			return this
+		}
+	});
+
+	function findOrAppend(elem, tag) {
+		return elem.getElementsByTagName(tag)[0] || elem.appendChild(elem.ownerDocument.createElement(tag))
+	}
+
+	function disableScript(elem) {
+		var attr = elem.getAttributeNode("type");
+		elem.type = (attr && attr.specified) + "/" + elem.type;
+		return elem
+	}
+
+	function restoreScript(elem) {
+		var match = rscriptTypeMasked.exec(elem.type);
+		if(match) {
+			elem.type = match[1]
+		} else {
+			elem.removeAttribute("type")
+		}
+		return elem
+	}
+
+	function setGlobalEval(elems, refElements) {
+		var elem, i = 0;
+		for(;
+			(elem = elems[i]) != null; i++) {
+			jQuery._data(elem, "globalEval", !refElements || jQuery._data(refElements[i], "globalEval"))
+		}
+	}
+
+	function cloneCopyEvent(src, dest) {
+		if(dest.nodeType !== 1 || !jQuery.hasData(src)) {
+			return
+		}
+		var type, i, l, oldData = jQuery._data(src),
+			curData = jQuery._data(dest, oldData),
+			events = oldData.events;
+		if(events) {
+			delete curData.handle;
+			curData.events = {};
+			for(type in events) {
+				for(i = 0, l = events[type].length; i < l; i++) {
+					jQuery.event.add(dest, type, events[type][i])
+				}
+			}
+		}
+		if(curData.data) {
+			curData.data = jQuery.extend({}, curData.data)
+		}
+	}
+
+	function fixCloneNodeIssues(src, dest) {
+		var nodeName, e, data;
+		if(dest.nodeType !== 1) {
+			return
+		}
+		nodeName = dest.nodeName.toLowerCase();
+		if(!jQuery.support.noCloneEvent && dest[jQuery.expando]) {
+			data = jQuery._data(dest);
+			for(e in data.events) {
+				jQuery.removeEvent(dest, e, data.handle)
+			}
+			dest.removeAttribute(jQuery.expando)
+		}
+		if(nodeName === "script" && dest.text !== src.text) {
+			disableScript(dest).text = src.text;
+			restoreScript(dest)
+		} else if(nodeName === "object") {
+			if(dest.parentNode) {
+				dest.outerHTML = src.outerHTML
+			}
+			if(jQuery.support.html5Clone && (src.innerHTML && !jQuery.trim(dest.innerHTML))) {
+				dest.innerHTML = src.innerHTML
+			}
+		} else if(nodeName === "input" && manipulation_rcheckableType.test(src.type)) {
+			dest.defaultChecked = dest.checked = src.checked;
+			if(dest.value !== src.value) {
+				dest.value = src.value
+			}
+		} else if(nodeName === "option") {
+			dest.defaultSelected = dest.selected = src.defaultSelected
+		} else if(nodeName === "input" || nodeName === "textarea") {
+			dest.defaultValue = src.defaultValue
+		}
+	}
+	jQuery.each({
+		appendTo: "append",
+		prependTo: "prepend",
+		insertBefore: "before",
+		insertAfter: "after",
+		replaceAll: "replaceWith"
+	}, function(name, original) {
+		jQuery.fn[name] = function(selector) {
+			var elems, i = 0,
+				ret = [],
+				insert = jQuery(selector),
+				last = insert.length - 1;
+			for(; i <= last; i++) {
+				elems = i === last ? this : this.clone(true);
+				jQuery(insert[i])[original](elems);
+				core_push.apply(ret, elems.get())
+			}
+			return this.pushStack(ret)
+		}
+	});
+
+	function getAll(context, tag) {
+		var elems, elem, i = 0,
+			found = typeof context.getElementsByTagName !== core_strundefined ? context.getElementsByTagName(tag || "*") : typeof context.querySelectorAll !== core_strundefined ? context.querySelectorAll(tag || "*") : undefined;
+		if(!found) {
+			for(found = [], elems = context.childNodes || context;
+				(elem = elems[i]) != null; i++) {
+				if(!tag || jQuery.nodeName(elem, tag)) {
+					found.push(elem)
+				} else {
+					jQuery.merge(found, getAll(elem, tag))
+				}
+			}
+		}
+		return tag === undefined || tag && jQuery.nodeName(context, tag) ? jQuery.merge([context], found) : found
+	}
+
+	function fixDefaultChecked(elem) {
+		if(manipulation_rcheckableType.test(elem.type)) {
+			elem.defaultChecked = elem.checked
+		}
+	}
+	jQuery.extend({
+		clone: function(elem, dataAndEvents, deepDataAndEvents) {
+			var destElements, node, clone, i, srcElements, inPage = jQuery.contains(elem.ownerDocument, elem);
+			if(jQuery.support.html5Clone || jQuery.isXMLDoc(elem) || !rnoshimcache.test("<" + elem.nodeName + ">")) {
+				clone = elem.cloneNode(true)
+			} else {
+				fragmentDiv.innerHTML = elem.outerHTML;
+				fragmentDiv.removeChild(clone = fragmentDiv.firstChild)
+			}
+			if((!jQuery.support.noCloneEvent || !jQuery.support.noCloneChecked) && (elem.nodeType === 1 || elem.nodeType === 11) && !jQuery.isXMLDoc(elem)) {
+				destElements = getAll(clone);
+				srcElements = getAll(elem);
+				for(i = 0;
+					(node = srcElements[i]) != null; ++i) {
+					if(destElements[i]) {
+						fixCloneNodeIssues(node, destElements[i])
+					}
+				}
+			}
+			if(dataAndEvents) {
+				if(deepDataAndEvents) {
+					srcElements = srcElements || getAll(elem);
+					destElements = destElements || getAll(clone);
+					for(i = 0;
+						(node = srcElements[i]) != null; i++) {
+						cloneCopyEvent(node, destElements[i])
+					}
+				} else {
+					cloneCopyEvent(elem, clone)
+				}
+			}
+			destElements = getAll(clone, "script");
+			if(destElements.length > 0) {
+				setGlobalEval(destElements, !inPage && getAll(elem, "script"))
+			}
+			destElements = srcElements = node = null;
+			return clone
+		},
+		buildFragment: function(elems, context, scripts, selection) {
+			var j, elem, contains, tmp, tag, tbody, wrap, l = elems.length,
+				safe = createSafeFragment(context),
+				nodes = [],
+				i = 0;
+			for(; i < l; i++) {
+				elem = elems[i];
+				if(elem || elem === 0) {
+					if(jQuery.type(elem) === "object") {
+						jQuery.merge(nodes, elem.nodeType ? [elem] : elem)
+					} else if(!rhtml.test(elem)) {
+						nodes.push(context.createTextNode(elem))
+					} else {
+						tmp = tmp || safe.appendChild(context.createElement("div"));
+						tag = (rtagName.exec(elem) || ["", ""])[1].toLowerCase();
+						wrap = wrapMap[tag] || wrapMap._default;
+						tmp.innerHTML = wrap[1] + elem.replace(rxhtmlTag, "<$1></$2>") + wrap[2];
+						j = wrap[0];
+						while(j--) {
+							tmp = tmp.lastChild
+						}
+						if(!jQuery.support.leadingWhitespace && rleadingWhitespace.test(elem)) {
+							nodes.push(context.createTextNode(rleadingWhitespace.exec(elem)[0]))
+						}
+						if(!jQuery.support.tbody) {
+							elem = tag === "table" && !rtbody.test(elem) ? tmp.firstChild : wrap[1] === "<table>" && !rtbody.test(elem) ? tmp : 0;
+							j = elem && elem.childNodes.length;
+							while(j--) {
+								if(jQuery.nodeName((tbody = elem.childNodes[j]), "tbody") && !tbody.childNodes.length) {
+									elem.removeChild(tbody)
+								}
+							}
+						}
+						jQuery.merge(nodes, tmp.childNodes);
+						tmp.textContent = "";
+						while(tmp.firstChild) {
+							tmp.removeChild(tmp.firstChild)
+						}
+						tmp = safe.lastChild
+					}
+				}
+			}
+			if(tmp) {
+				safe.removeChild(tmp)
+			}
+			if(!jQuery.support.appendChecked) {
+				jQuery.grep(getAll(nodes, "input"), fixDefaultChecked)
+			}
+			i = 0;
+			while((elem = nodes[i++])) {
+				if(selection && jQuery.inArray(elem, selection) !== -1) {
+					continue
+				}
+				contains = jQuery.contains(elem.ownerDocument, elem);
+				tmp = getAll(safe.appendChild(elem), "script");
+				if(contains) {
+					setGlobalEval(tmp)
+				}
+				if(scripts) {
+					j = 0;
+					while((elem = tmp[j++])) {
+						if(rscriptType.test(elem.type || "")) {
+							scripts.push(elem)
+						}
+					}
+				}
+			}
+			tmp = null;
+			return safe
+		},
+		cleanData: function(elems, acceptData) {
+			var elem, type, id, data, i = 0,
+				internalKey = jQuery.expando,
+				cache = jQuery.cache,
+				deleteExpando = jQuery.support.deleteExpando,
+				special = jQuery.event.special;
+			for(;
+				(elem = elems[i]) != null; i++) {
+				if(acceptData || jQuery.acceptData(elem)) {
+					id = elem[internalKey];
+					data = id && cache[id];
+					if(data) {
+						if(data.events) {
+							for(type in data.events) {
+								if(special[type]) {
+									jQuery.event.remove(elem, type)
+								} else {
+									jQuery.removeEvent(elem, type, data.handle)
+								}
+							}
+						}
+						if(cache[id]) {
+							delete cache[id];
+							if(deleteExpando) {
+								delete elem[internalKey]
+							} else if(typeof elem.removeAttribute !== core_strundefined) {
+								elem.removeAttribute(internalKey)
+							} else {
+								elem[internalKey] = null
+							}
+							core_deletedIds.push(id)
+						}
+					}
+				}
+			}
+		}
+	});
+	var iframe, getStyles, curCSS, ralpha = /alpha\([^)]*\)/i,
+		ropacity = /opacity\s*=\s*([^)]*)/,
+		rposition = /^(top|right|bottom|left)$/,
+		rdisplayswap = /^(none|table(?!-c[ea]).+)/,
+		rmargin = /^margin/,
+		rnumsplit = new RegExp("^(" + core_pnum + ")(.*)$", "i"),
+		rnumnonpx = new RegExp("^(" + core_pnum + ")(?!px)[a-z%]+$", "i"),
+		rrelNum = new RegExp("^([+-])=(" + core_pnum + ")", "i"),
+		elemdisplay = {
+			BODY: "block"
+		},
+		cssShow = {
+			position: "absolute",
+			visibility: "hidden",
+			display: "block"
+		},
+		cssNormalTransform = {
+			letterSpacing: 0,
+			fontWeight: 400
+		},
+		cssExpand = ["Top", "Right", "Bottom", "Left"],
+		cssPrefixes = ["Webkit", "O", "Moz", "ms"];
+
+	function vendorPropName(style, name) {
+		if(name in style) {
+			return name
+		}
+		var capName = name.charAt(0).toUpperCase() + name.slice(1),
+			origName = name,
+			i = cssPrefixes.length;
+		while(i--) {
+			name = cssPrefixes[i] + capName;
+			if(name in style) {
+				return name
+			}
+		}
+		return origName
+	}
+
+	function isHidden(elem, el) {
+		elem = el || elem;
+		return jQuery.css(elem, "display") === "none" || !jQuery.contains(elem.ownerDocument, elem)
+	}
+
+	function showHide(elements, show) {
+		var display, elem, hidden, values = [],
+			index = 0,
+			length = elements.length;
+		for(; index < length; index++) {
+			elem = elements[index];
+			if(!elem.style) {
+				continue
+			}
+			values[index] = jQuery._data(elem, "olddisplay");
+			display = elem.style.display;
+			if(show) {
+				if(!values[index] && display === "none") {
+					elem.style.display = ""
+				}
+				if(elem.style.display === "" && isHidden(elem)) {
+					values[index] = jQuery._data(elem, "olddisplay", css_defaultDisplay(elem.nodeName))
+				}
+			} else {
+				if(!values[index]) {
+					hidden = isHidden(elem);
+					if(display && display !== "none" || !hidden) {
+						jQuery._data(elem, "olddisplay", hidden ? display : jQuery.css(elem, "display"))
+					}
+				}
+			}
+		}
+		for(index = 0; index < length; index++) {
+			elem = elements[index];
+			if(!elem.style) {
+				continue
+			}
+			if(!show || elem.style.display === "none" || elem.style.display === "") {
+				elem.style.display = show ? values[index] || "" : "none"
+			}
+		}
+		return elements
+	}
+	jQuery.fn.extend({
+		css: function(name, value) {
+			return jQuery.access(this, function(elem, name, value) {
+				var len, styles, map = {},
+					i = 0;
+				if(jQuery.isArray(name)) {
+					styles = getStyles(elem);
+					len = name.length;
+					for(; i < len; i++) {
+						map[name[i]] = jQuery.css(elem, name[i], false, styles)
+					}
+					return map
+				}
+				return value !== undefined ? jQuery.style(elem, name, value) : jQuery.css(elem, name)
+			}, name, value, arguments.length > 1)
+		},
+		show: function() {
+			return showHide(this, true)
+		},
+		hide: function() {
+			return showHide(this)
+		},
+		toggle: function(state) {
+			var bool = typeof state === "boolean";
+			return this.each(function() {
+				if(bool ? state : isHidden(this)) {
+					jQuery(this).show()
+				} else {
+					jQuery(this).hide()
+				}
+			})
+		}
+	});
+	jQuery.extend({
+		cssHooks: {
+			opacity: {
+				get: function(elem, computed) {
+					if(computed) {
+						var ret = curCSS(elem, "opacity");
+						return ret === "" ? "1" : ret
+					}
+				}
+			}
+		},
+		cssNumber: {
+			"columnCount": true,
+			"fillOpacity": true,
+			"fontWeight": true,
+			"lineHeight": true,
+			"opacity": true,
+			"orphans": true,
+			"widows": true,
+			"zIndex": true,
+			"zoom": true
+		},
+		cssProps: {
+			"float": jQuery.support.cssFloat ? "cssFloat" : "styleFloat"
+		},
+		style: function(elem, name, value, extra) {
+			if(!elem || elem.nodeType === 3 || elem.nodeType === 8 || !elem.style) {
+				return
+			}
+			var ret, type, hooks, origName = jQuery.camelCase(name),
+				style = elem.style;
+			name = jQuery.cssProps[origName] || (jQuery.cssProps[origName] = vendorPropName(style, origName));
+			hooks = jQuery.cssHooks[name] || jQuery.cssHooks[origName];
+			if(value !== undefined) {
+				type = typeof value;
+				if(type === "string" && (ret = rrelNum.exec(value))) {
+					value = (ret[1] + 1) * ret[2] + parseFloat(jQuery.css(elem, name));
+					type = "number"
+				}
+				if(value == null || type === "number" && isNaN(value)) {
+					return
+				}
+				if(type === "number" && !jQuery.cssNumber[origName]) {
+					value += "px"
+				}
+				if(!jQuery.support.clearCloneStyle && value === "" && name.indexOf("background") === 0) {
+					style[name] = "inherit"
+				}
+				if(!hooks || !("set" in hooks) || (value = hooks.set(elem, value, extra)) !== undefined) {
+					try {
+						style[name] = value
+					} catch(e) {}
+				}
+			} else {
+				if(hooks && "get" in hooks && (ret = hooks.get(elem, false, extra)) !== undefined) {
+					return ret
+				}
+				return style[name]
+			}
+		},
+		css: function(elem, name, extra, styles) {
+			var num, val, hooks, origName = jQuery.camelCase(name);
+			name = jQuery.cssProps[origName] || (jQuery.cssProps[origName] = vendorPropName(elem.style, origName));
+			hooks = jQuery.cssHooks[name] || jQuery.cssHooks[origName];
+			if(hooks && "get" in hooks) {
+				val = hooks.get(elem, true, extra)
+			}
+			if(val === undefined) {
+				val = curCSS(elem, name, styles)
+			}
+			if(val === "normal" && name in cssNormalTransform) {
+				val = cssNormalTransform[name]
+			}
+			if(extra === "" || extra) {
+				num = parseFloat(val);
+				return extra === true || jQuery.isNumeric(num) ? num || 0 : val
+			}
+			return val
+		},
+		swap: function(elem, options, callback, args) {
+			var ret, name, old = {};
+			for(name in options) {
+				old[name] = elem.style[name];
+				elem.style[name] = options[name]
+			}
+			ret = callback.apply(elem, args || []);
+			for(name in options) {
+				elem.style[name] = old[name]
+			}
+			return ret
+		}
+	});
+	if(window.getComputedStyle) {
+		getStyles = function(elem) {
+			return window.getComputedStyle(elem, null)
+		};
+		curCSS = function(elem, name, _computed) {
+			var width, minWidth, maxWidth, computed = _computed || getStyles(elem),
+				ret = computed ? computed.getPropertyValue(name) || computed[name] : undefined,
+				style = elem.style;
+			if(computed) {
+				if(ret === "" && !jQuery.contains(elem.ownerDocument, elem)) {
+					ret = jQuery.style(elem, name)
+				}
+				if(rnumnonpx.test(ret) && rmargin.test(name)) {
+					width = style.width;
+					minWidth = style.minWidth;
+					maxWidth = style.maxWidth;
+					style.minWidth = style.maxWidth = style.width = ret;
+					ret = computed.width;
+					style.width = width;
+					style.minWidth = minWidth;
+					style.maxWidth = maxWidth
+				}
+			}
+			return ret
+		}
+	} else if(document.documentElement.currentStyle) {
+		getStyles = function(elem) {
+			return elem.currentStyle
+		};
+		curCSS = function(elem, name, _computed) {
+			var left, rs, rsLeft, computed = _computed || getStyles(elem),
+				ret = computed ? computed[name] : undefined,
+				style = elem.style;
+			if(ret == null && style && style[name]) {
+				ret = style[name]
+			}
+			if(rnumnonpx.test(ret) && !rposition.test(name)) {
+				left = style.left;
+				rs = elem.runtimeStyle;
+				rsLeft = rs && rs.left;
+				if(rsLeft) {
+					rs.left = elem.currentStyle.left
+				}
+				style.left = name === "fontSize" ? "1em" : ret;
+				ret = style.pixelLeft + "px";
+				style.left = left;
+				if(rsLeft) {
+					rs.left = rsLeft
+				}
+			}
+			return ret === "" ? "auto" : ret
+		}
+	}
+
+	function setPositiveNumber(elem, value, subtract) {
+		var matches = rnumsplit.exec(value);
+		return matches ? Math.max(0, matches[1] - (subtract || 0)) + (matches[2] || "px") : value
+	}
+
+	function augmentWidthOrHeight(elem, name, extra, isBorderBox, styles) {
+		var i = extra === (isBorderBox ? "border" : "content") ? 4 : name === "width" ? 1 : 0,
+			val = 0;
+		for(; i < 4; i += 2) {
+			if(extra === "margin") {
+				val += jQuery.css(elem, extra + cssExpand[i], true, styles)
+			}
+			if(isBorderBox) {
+				if(extra === "content") {
+					val -= jQuery.css(elem, "padding" + cssExpand[i], true, styles)
+				}
+				if(extra !== "margin") {
+					val -= jQuery.css(elem, "border" + cssExpand[i] + "Width", true, styles)
+				}
+			} else {
+				val += jQuery.css(elem, "padding" + cssExpand[i], true, styles);
+				if(extra !== "padding") {
+					val += jQuery.css(elem, "border" + cssExpand[i] + "Width", true, styles)
+				}
+			}
+		}
+		return val
+	}
+
+	function getWidthOrHeight(elem, name, extra) {
+		var valueIsBorderBox = true,
+			val = name === "width" ? elem.offsetWidth : elem.offsetHeight,
+			styles = getStyles(elem),
+			isBorderBox = jQuery.support.boxSizing && jQuery.css(elem, "boxSizing", false, styles) === "border-box";
+		if(val <= 0 || val == null) {
+			val = curCSS(elem, name, styles);
+			if(val < 0 || val == null) {
+				val = elem.style[name]
+			}
+			if(rnumnonpx.test(val)) {
+				return val
+			}
+			valueIsBorderBox = isBorderBox && (jQuery.support.boxSizingReliable || val === elem.style[name]);
+			val = parseFloat(val) || 0
+		}
+		return(val + augmentWidthOrHeight(elem, name, extra || (isBorderBox ? "border" : "content"), valueIsBorderBox, styles)) + "px"
+	}
+
+	function css_defaultDisplay(nodeName) {
+		var doc = document,
+			display = elemdisplay[nodeName];
+		if(!display) {
+			display = actualDisplay(nodeName, doc);
+			if(display === "none" || !display) {
+				iframe = (iframe || jQuery("<iframe frameborder='0' width='0' height='0'/>").css("cssText", "display:block !important")).appendTo(doc.documentElement);
+				doc = (iframe[0].contentWindow || iframe[0].contentDocument).document;
+				doc.write("<!doctype html><html><body>");
+				doc.close();
+				display = actualDisplay(nodeName, doc);
+				iframe.detach()
+			}
+			elemdisplay[nodeName] = display
+		}
+		return display
+	}
+
+	function actualDisplay(name, doc) {
+		var elem = jQuery(doc.createElement(name)).appendTo(doc.body),
+			display = jQuery.css(elem[0], "display");
+		elem.remove();
+		return display
+	}
+	jQuery.each(["height", "width"], function(i, name) {
+		jQuery.cssHooks[name] = {
+			get: function(elem, computed, extra) {
+				if(computed) {
+					return elem.offsetWidth === 0 && rdisplayswap.test(jQuery.css(elem, "display")) ? jQuery.swap(elem, cssShow, function() {
+						return getWidthOrHeight(elem, name, extra)
+					}) : getWidthOrHeight(elem, name, extra)
+				}
+			},
+			set: function(elem, value, extra) {
+				var styles = extra && getStyles(elem);
+				return setPositiveNumber(elem, value, extra ? augmentWidthOrHeight(elem, name, extra, jQuery.support.boxSizing && jQuery.css(elem, "boxSizing", false, styles) === "border-box", styles) : 0)
+			}
+		}
+	});
+	if(!jQuery.support.opacity) {
+		jQuery.cssHooks.opacity = {
+			get: function(elem, computed) {
+				return ropacity.test((computed && elem.currentStyle ? elem.currentStyle.filter : elem.style.filter) || "") ? (0.01 * parseFloat(RegExp.$1)) + "" : computed ? "1" : ""
+			},
+			set: function(elem, value) {
+				var style = elem.style,
+					currentStyle = elem.currentStyle,
+					opacity = jQuery.isNumeric(value) ? "alpha(opacity=" + value * 100 + ")" : "",
+					filter = currentStyle && currentStyle.filter || style.filter || "";
+				style.zoom = 1;
+				if((value >= 1 || value === "") && jQuery.trim(filter.replace(ralpha, "")) === "" && style.removeAttribute) {
+					style.removeAttribute("filter");
+					if(value === "" || currentStyle && !currentStyle.filter) {
+						return
+					}
+				}
+				style.filter = ralpha.test(filter) ? filter.replace(ralpha, opacity) : filter + " " + opacity
+			}
+		}
+	}
+	jQuery(function() {
+		if(!jQuery.support.reliableMarginRight) {
+			jQuery.cssHooks.marginRight = {
+				get: function(elem, computed) {
+					if(computed) {
+						return jQuery.swap(elem, {
+							"display": "inline-block"
+						}, curCSS, [elem, "marginRight"])
+					}
+				}
+			}
+		}
+		if(!jQuery.support.pixelPosition && jQuery.fn.position) {
+			jQuery.each(["top", "left"], function(i, prop) {
+				jQuery.cssHooks[prop] = {
+					get: function(elem, computed) {
+						if(computed) {
+							computed = curCSS(elem, prop);
+							return rnumnonpx.test(computed) ? jQuery(elem).position()[prop] + "px" : computed
+						}
+					}
+				}
+			})
+		}
+	});
+	if(jQuery.expr && jQuery.expr.filters) {
+		jQuery.expr.filters.hidden = function(elem) {
+			return elem.offsetWidth <= 0 && elem.offsetHeight <= 0 || (!jQuery.support.reliableHiddenOffsets && ((elem.style && elem.style.display) || jQuery.css(elem, "display")) === "none")
+		};
+		jQuery.expr.filters.visible = function(elem) {
+			return !jQuery.expr.filters.hidden(elem)
+		}
+	}
+	jQuery.each({
+		margin: "",
+		padding: "",
+		border: "Width"
+	}, function(prefix, suffix) {
+		jQuery.cssHooks[prefix + suffix] = {
+			expand: function(value) {
+				var i = 0,
+					expanded = {},
+					parts = typeof value === "string" ? value.split(" ") : [value];
+				for(; i < 4; i++) {
+					expanded[prefix + cssExpand[i] + suffix] = parts[i] || parts[i - 2] || parts[0]
+				}
+				return expanded
+			}
+		};
+		if(!rmargin.test(prefix)) {
+			jQuery.cssHooks[prefix + suffix].set = setPositiveNumber
+		}
+	});
+	var r20 = /%20/g,
+		rbracket = /\[\]$/,
+		rCRLF = /\r?\n/g,
+		rsubmitterTypes = /^(?:submit|button|image|reset|file)$/i,
+		rsubmittable = /^(?:input|select|textarea|keygen)/i;
+	jQuery.fn.extend({
+		serialize: function() {
+			return jQuery.param(this.serializeArray())
+		},
+		serializeArray: function() {
+			return this.map(function() {
+				var elements = jQuery.prop(this, "elements");
+				return elements ? jQuery.makeArray(elements) : this
+			}).filter(function() {
+				var type = this.type;
+				return this.name && !jQuery(this).is(":disabled") && rsubmittable.test(this.nodeName) && !rsubmitterTypes.test(type) && (this.checked || !manipulation_rcheckableType.test(type))
+			}).map(function(i, elem) {
+				var val = jQuery(this).val();
+				return val == null ? null : jQuery.isArray(val) ? jQuery.map(val, function(val) {
+					return {
+						name: elem.name,
+						value: val.replace(rCRLF, "\r\n")
+					}
+				}) : {
+					name: elem.name,
+					value: val.replace(rCRLF, "\r\n")
+				}
+			}).get()
+		}
+	});
+	jQuery.param = function(a, traditional) {
+		var prefix, s = [],
+			add = function(key, value) {
+				value = jQuery.isFunction(value) ? value() : (value == null ? "" : value);
+				s[s.length] = encodeURIComponent(key) + "=" + encodeURIComponent(value)
+			};
+		if(traditional === undefined) {
+			traditional = jQuery.ajaxSettings && jQuery.ajaxSettings.traditional
+		}
+		if(jQuery.isArray(a) || (a.jquery && !jQuery.isPlainObject(a))) {
+			jQuery.each(a, function() {
+				add(this.name, this.value)
+			})
+		} else {
+			for(prefix in a) {
+				buildParams(prefix, a[prefix], traditional, add)
+			}
+		}
+		return s.join("&").replace(r20, "+")
+	};
+
+	function buildParams(prefix, obj, traditional, add) {
+		var name;
+		if(jQuery.isArray(obj)) {
+			jQuery.each(obj, function(i, v) {
+				if(traditional || rbracket.test(prefix)) {
+					add(prefix, v)
+				} else {
+					buildParams(prefix + "[" + (typeof v === "object" ? i : "") + "]", v, traditional, add)
+				}
+			})
+		} else if(!traditional && jQuery.type(obj) === "object") {
+			for(name in obj) {
+				buildParams(prefix + "[" + name + "]", obj[name], traditional, add)
+			}
+		} else {
+			add(prefix, obj)
+		}
+	}
+	jQuery.each(("blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error contextmenu").split(" "), function(i, name) {
+		jQuery.fn[name] = function(data, fn) {
+			return arguments.length > 0 ? this.on(name, null, data, fn) : this.trigger(name)
+		}
+	});
+	jQuery.fn.hover = function(fnOver, fnOut) {
+		return this.mouseenter(fnOver).mouseleave(fnOut || fnOver)
+	};
+	var ajaxLocParts, ajaxLocation, ajax_nonce = jQuery.now(),
+		ajax_rquery = /\?/,
+		rhash = /#.*$/,
+		rts = /([?&])_=[^&]*/,
+		rheaders = /^(.*?):[ \t]*([^\r\n]*)\r?$/mg,
+		rlocalProtocol = /^(?:about|app|app-storage|.+-extension|file|res|widget):$/,
+		rnoContent = /^(?:GET|HEAD)$/,
+		rprotocol = /^\/\//,
+		rurl = /^([\w.+-]+:)(?:\/\/([^\/?#:]*)(?::(\d+)|)|)/,
+		_load = jQuery.fn.load,
+		prefilters = {},
+		transports = {},
+		allTypes = "*/".concat("*");
+	try {
+		ajaxLocation = location.href
+	} catch(e) {
+		ajaxLocation = document.createElement("a");
+		ajaxLocation.href = "";
+		ajaxLocation = ajaxLocation.href
+	}
+	ajaxLocParts = rurl.exec(ajaxLocation.toLowerCase()) || [];
+
+	function addToPrefiltersOrTransports(structure) {
+		return function(dataTypeExpression, func) {
+			if(typeof dataTypeExpression !== "string") {
+				func = dataTypeExpression;
+				dataTypeExpression = "*"
+			}
+			var dataType, i = 0,
+				dataTypes = dataTypeExpression.toLowerCase().match(core_rnotwhite) || [];
+			if(jQuery.isFunction(func)) {
+				while((dataType = dataTypes[i++])) {
+					if(dataType[0] === "+") {
+						dataType = dataType.slice(1) || "*";
+						(structure[dataType] = structure[dataType] || []).unshift(func)
+					} else {
+						(structure[dataType] = structure[dataType] || []).push(func)
+					}
+				}
+			}
+		}
+	}
+
+	function inspectPrefiltersOrTransports(structure, options, originalOptions, jqXHR) {
+		var inspected = {},
+			seekingTransport = (structure === transports);
+
+		function inspect(dataType) {
+			var selected;
+			inspected[dataType] = true;
+			jQuery.each(structure[dataType] || [], function(_, prefilterOrFactory) {
+				var dataTypeOrTransport = prefilterOrFactory(options, originalOptions, jqXHR);
+				if(typeof dataTypeOrTransport === "string" && !seekingTransport && !inspected[dataTypeOrTransport]) {
+					options.dataTypes.unshift(dataTypeOrTransport);
+					inspect(dataTypeOrTransport);
+					return false
+				} else if(seekingTransport) {
+					return !(selected = dataTypeOrTransport)
+				}
+			});
+			return selected
+		}
+		return inspect(options.dataTypes[0]) || !inspected["*"] && inspect("*")
+	}
+
+	function ajaxExtend(target, src) {
+		var deep, key, flatOptions = jQuery.ajaxSettings.flatOptions || {};
+		for(key in src) {
+			if(src[key] !== undefined) {
+				(flatOptions[key] ? target : (deep || (deep = {})))[key] = src[key]
+			}
+		}
+		if(deep) {
+			jQuery.extend(true, target, deep)
+		}
+		return target
+	}
+	jQuery.fn.load = function(url, params, callback) {
+		if(typeof url !== "string" && _load) {
+			return _load.apply(this, arguments)
+		}
+		var selector, response, type, self = this,
+			off = url.indexOf(" ");
+		if(off >= 0) {
+			selector = url.slice(off, url.length);
+			url = url.slice(0, off)
+		}
+		if(jQuery.isFunction(params)) {
+			callback = params;
+			params = undefined
+		} else if(params && typeof params === "object") {
+			type = "POST"
+		}
+		if(self.length > 0) {
+			jQuery.ajax({
+				url: url,
+				type: type,
+				dataType: "html",
+				data: params
+			}).done(function(responseText) {
+				response = arguments;
+				self.html(selector ? jQuery("<div>").append(jQuery.parseHTML(responseText)).find(selector) : responseText)
+			}).complete(callback && function(jqXHR, status) {
+				self.each(callback, response || [jqXHR.responseText, status, jqXHR])
+			})
+		}
+		return this
+	};
+	jQuery.each(["ajaxStart", "ajaxStop", "ajaxComplete", "ajaxError", "ajaxSuccess", "ajaxSend"], function(i, type) {
+		jQuery.fn[type] = function(fn) {
+			return this.on(type, fn)
+		}
+	});
+	jQuery.each(["get", "post"], function(i, method) {
+		jQuery[method] = function(url, data, callback, type) {
+			if(jQuery.isFunction(data)) {
+				type = type || callback;
+				callback = data;
+				data = undefined
+			}
+			return jQuery.ajax({
+				url: url,
+				type: method,
+				dataType: type,
+				data: data,
+				success: callback
+			})
+		}
+	});
+	jQuery.extend({
+		active: 0,
+		lastModified: {},
+		etag: {},
+		ajaxSettings: {
+			url: ajaxLocation,
+			type: "GET",
+			isLocal: rlocalProtocol.test(ajaxLocParts[1]),
+			global: true,
+			processData: true,
+			async: true,
+			contentType: "application/x-www-form-urlencoded; charset=UTF-8",
+			accepts: {
+				"*": allTypes,
+				text: "text/plain",
+				html: "text/html",
+				xml: "application/xml, text/xml",
+				json: "application/json, text/javascript"
+			},
+			contents: {
+				xml: /xml/,
+				html: /html/,
+				json: /json/
+			},
+			responseFields: {
+				xml: "responseXML",
+				text: "responseText"
+			},
+			converters: {
+				"* text": window.String,
+				"text html": true,
+				"text json": jQuery.parseJSON,
+				"text xml": jQuery.parseXML
+			},
+			flatOptions: {
+				url: true,
+				context: true
+			}
+		},
+		ajaxSetup: function(target, settings) {
+			return settings ? ajaxExtend(ajaxExtend(target, jQuery.ajaxSettings), settings) : ajaxExtend(jQuery.ajaxSettings, target)
+		},
+		ajaxPrefilter: addToPrefiltersOrTransports(prefilters),
+		ajaxTransport: addToPrefiltersOrTransports(transports),
+		ajax: function(url, options) {
+			if(typeof url === "object") {
+				options = url;
+				url = undefined
+			}
+			options = options || {};
+			var parts, i, cacheURL, responseHeadersString, timeoutTimer, fireGlobals, transport, responseHeaders, s = jQuery.ajaxSetup({}, options),
+				callbackContext = s.context || s,
+				globalEventContext = s.context && (callbackContext.nodeType || callbackContext.jquery) ? jQuery(callbackContext) : jQuery.event,
+				deferred = jQuery.Deferred(),
+				completeDeferred = jQuery.Callbacks("once memory"),
+				statusCode = s.statusCode || {},
+				requestHeaders = {},
+				requestHeadersNames = {},
+				state = 0,
+				strAbort = "canceled",
+				jqXHR = {
+					readyState: 0,
+					getResponseHeader: function(key) {
+						var match;
+						if(state === 2) {
+							if(!responseHeaders) {
+								responseHeaders = {};
+								while((match = rheaders.exec(responseHeadersString))) {
+									responseHeaders[match[1].toLowerCase()] = match[2]
+								}
+							}
+							match = responseHeaders[key.toLowerCase()]
+						}
+						return match == null ? null : match
+					},
+					getAllResponseHeaders: function() {
+						return state === 2 ? responseHeadersString : null
+					},
+					setRequestHeader: function(name, value) {
+						var lname = name.toLowerCase();
+						if(!state) {
+							name = requestHeadersNames[lname] = requestHeadersNames[lname] || name;
+							requestHeaders[name] = value
+						}
+						return this
+					},
+					overrideMimeType: function(type) {
+						if(!state) {
+							s.mimeType = type
+						}
+						return this
+					},
+					statusCode: function(map) {
+						var code;
+						if(map) {
+							if(state < 2) {
+								for(code in map) {
+									statusCode[code] = [statusCode[code], map[code]]
+								}
+							} else {
+								jqXHR.always(map[jqXHR.status])
+							}
+						}
+						return this
+					},
+					abort: function(statusText) {
+						var finalText = statusText || strAbort;
+						if(transport) {
+							transport.abort(finalText)
+						}
+						done(0, finalText);
+						return this
+					}
+				};
+			deferred.promise(jqXHR).complete = completeDeferred.add;
+			jqXHR.success = jqXHR.done;
+			jqXHR.error = jqXHR.fail;
+			s.url = ((url || s.url || ajaxLocation) + "").replace(rhash, "").replace(rprotocol, ajaxLocParts[1] + "//");
+			s.type = options.method || options.type || s.method || s.type;
+			s.dataTypes = jQuery.trim(s.dataType || "*").toLowerCase().match(core_rnotwhite) || [""];
+			if(s.crossDomain == null) {
+				parts = rurl.exec(s.url.toLowerCase());
+				s.crossDomain = !!(parts && (parts[1] !== ajaxLocParts[1] || parts[2] !== ajaxLocParts[2] || (parts[3] || (parts[1] === "http:" ? 80 : 443)) != (ajaxLocParts[3] || (ajaxLocParts[1] === "http:" ? 80 : 443))))
+			}
+			if(s.data && s.processData && typeof s.data !== "string") {
+				s.data = jQuery.param(s.data, s.traditional)
+			}
+			inspectPrefiltersOrTransports(prefilters, s, options, jqXHR);
+			if(state === 2) {
+				return jqXHR
+			}
+			fireGlobals = s.global;
+			if(fireGlobals && jQuery.active++ === 0) {
+				jQuery.event.trigger("ajaxStart")
+			}
+			s.type = s.type.toUpperCase();
+			s.hasContent = !rnoContent.test(s.type);
+			cacheURL = s.url;
+			if(!s.hasContent) {
+				if(s.data) {
+					cacheURL = (s.url += (ajax_rquery.test(cacheURL) ? "&" : "?") + s.data);
+					delete s.data
+				}
+				if(s.cache === false) {
+					s.url = rts.test(cacheURL) ? cacheURL.replace(rts, "$1_=" + ajax_nonce++) : cacheURL + (ajax_rquery.test(cacheURL) ? "&" : "?") + "_=" + ajax_nonce++
+				}
+			}
+			if(s.ifModified) {
+				if(jQuery.lastModified[cacheURL]) {
+					jqXHR.setRequestHeader("If-Modified-Since", jQuery.lastModified[cacheURL])
+				}
+				if(jQuery.etag[cacheURL]) {
+					jqXHR.setRequestHeader("If-None-Match", jQuery.etag[cacheURL])
+				}
+			}
+			if(s.data && s.hasContent && s.contentType !== false || options.contentType) {
+				jqXHR.setRequestHeader("Content-Type", s.contentType)
+			}
+			jqXHR.setRequestHeader("Accept", s.dataTypes[0] && s.accepts[s.dataTypes[0]] ? s.accepts[s.dataTypes[0]] + (s.dataTypes[0] !== "*" ? ", " + allTypes + "; q=0.01" : "") : s.accepts["*"]);
+			for(i in s.headers) {
+				jqXHR.setRequestHeader(i, s.headers[i])
+			}
+			if(s.beforeSend && (s.beforeSend.call(callbackContext, jqXHR, s) === false || state === 2)) {
+				return jqXHR.abort()
+			}
+			strAbort = "abort";
+			for(i in {
+					success: 1,
+					error: 1,
+					complete: 1
+				}) {
+				jqXHR[i](s[i])
+			}
+			transport = inspectPrefiltersOrTransports(transports, s, options, jqXHR);
+			if(!transport) {
+				done(-1, "No Transport")
+			} else {
+				jqXHR.readyState = 1;
+				if(fireGlobals) {
+					globalEventContext.trigger("ajaxSend", [jqXHR, s])
+				}
+				if(s.async && s.timeout > 0) {
+					timeoutTimer = setTimeout(function() {
+						jqXHR.abort("timeout")
+					}, s.timeout)
+				}
+				try {
+					state = 1;
+					transport.send(requestHeaders, done)
+				} catch(e) {
+					if(state < 2) {
+						done(-1, e)
+					} else {
+						throw e;
+					}
+				}
+			}
+
+			function done(status, nativeStatusText, responses, headers) {
+				var isSuccess, success, error, response, modified, statusText = nativeStatusText;
+				if(state === 2) {
+					return
+				}
+				state = 2;
+				if(timeoutTimer) {
+					clearTimeout(timeoutTimer)
+				}
+				transport = undefined;
+				responseHeadersString = headers || "";
+				jqXHR.readyState = status > 0 ? 4 : 0;
+				if(responses) {
+					response = ajaxHandleResponses(s, jqXHR, responses)
+				}
+				if(status >= 200 && status < 300 || status === 304) {
+					if(s.ifModified) {
+						modified = jqXHR.getResponseHeader("Last-Modified");
+						if(modified) {
+							jQuery.lastModified[cacheURL] = modified
+						}
+						modified = jqXHR.getResponseHeader("etag");
+						if(modified) {
+							jQuery.etag[cacheURL] = modified
+						}
+					}
+					if(status === 204) {
+						isSuccess = true;
+						statusText = "nocontent"
+					} else if(status === 304) {
+						isSuccess = true;
+						statusText = "notmodified"
+					} else {
+						isSuccess = ajaxConvert(s, response);
+						statusText = isSuccess.state;
+						success = isSuccess.data;
+						error = isSuccess.error;
+						isSuccess = !error
+					}
+				} else {
+					error = statusText;
+					if(status || !statusText) {
+						statusText = "error";
+						if(status < 0) {
+							status = 0
+						}
+					}
+				}
+				jqXHR.status = status;
+				jqXHR.statusText = (nativeStatusText || statusText) + "";
+				if(isSuccess) {
+					deferred.resolveWith(callbackContext, [success, statusText, jqXHR])
+				} else {
+					deferred.rejectWith(callbackContext, [jqXHR, statusText, error])
+				}
+				jqXHR.statusCode(statusCode);
+				statusCode = undefined;
+				if(fireGlobals) {
+					globalEventContext.trigger(isSuccess ? "ajaxSuccess" : "ajaxError", [jqXHR, s, isSuccess ? success : error])
+				}
+				completeDeferred.fireWith(callbackContext, [jqXHR, statusText]);
+				if(fireGlobals) {
+					globalEventContext.trigger("ajaxComplete", [jqXHR, s]);
+					if(!(--jQuery.active)) {
+						jQuery.event.trigger("ajaxStop")
+					}
+				}
+			}
+			return jqXHR
+		},
+		getScript: function(url, callback) {
+			return jQuery.get(url, undefined, callback, "script")
+		},
+		getJSON: function(url, data, callback) {
+			return jQuery.get(url, data, callback, "json")
+		}
+	});
+
+	function ajaxHandleResponses(s, jqXHR, responses) {
+		var firstDataType, ct, finalDataType, type, contents = s.contents,
+			dataTypes = s.dataTypes,
+			responseFields = s.responseFields;
+		for(type in responseFields) {
+			if(type in responses) {
+				jqXHR[responseFields[type]] = responses[type]
+			}
+		}
+		while(dataTypes[0] === "*") {
+			dataTypes.shift();
+			if(ct === undefined) {
+				ct = s.mimeType || jqXHR.getResponseHeader("Content-Type")
+			}
+		}
+		if(ct) {
+			for(type in contents) {
+				if(contents[type] && contents[type].test(ct)) {
+					dataTypes.unshift(type);
+					break
+				}
+			}
+		}
+		if(dataTypes[0] in responses) {
+			finalDataType = dataTypes[0]
+		} else {
+			for(type in responses) {
+				if(!dataTypes[0] || s.converters[type + " " + dataTypes[0]]) {
+					finalDataType = type;
+					break
+				}
+				if(!firstDataType) {
+					firstDataType = type
+				}
+			}
+			finalDataType = finalDataType || firstDataType
+		}
+		if(finalDataType) {
+			if(finalDataType !== dataTypes[0]) {
+				dataTypes.unshift(finalDataType)
+			}
+			return responses[finalDataType]
+		}
+	}
+
+	function ajaxConvert(s, response) {
+		var conv2, current, conv, tmp, converters = {},
+			i = 0,
+			dataTypes = s.dataTypes.slice(),
+			prev = dataTypes[0];
+		if(s.dataFilter) {
+			response = s.dataFilter(response, s.dataType)
+		}
+		if(dataTypes[1]) {
+			for(conv in s.converters) {
+				converters[conv.toLowerCase()] = s.converters[conv]
+			}
+		}
+		for(;
+			(current = dataTypes[++i]);) {
+			if(current !== "*") {
+				if(prev !== "*" && prev !== current) {
+					conv = converters[prev + " " + current] || converters["* " + current];
+					if(!conv) {
+						for(conv2 in converters) {
+							tmp = conv2.split(" ");
+							if(tmp[1] === current) {
+								conv = converters[prev + " " + tmp[0]] || converters["* " + tmp[0]];
+								if(conv) {
+									if(conv === true) {
+										conv = converters[conv2]
+									} else if(converters[conv2] !== true) {
+										current = tmp[0];
+										dataTypes.splice(i--, 0, current)
+									}
+									break
+								}
+							}
+						}
+					}
+					if(conv !== true) {
+						if(conv && s["throws"]) {
+							response = conv(response)
+						} else {
+							try {
+								response = conv(response)
+							} catch(e) {
+								return {
+									state: "parsererror",
+									error: conv ? e : "No conversion from " + prev + " to " + current
+								}
+							}
+						}
+					}
+				}
+				prev = current
+			}
+		}
+		return {
+			state: "success",
+			data: response
+		}
+	}
+	jQuery.ajaxSetup({
+		accepts: {
+			script: "text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"
+		},
+		contents: {
+			script: /(?:java|ecma)script/
+		},
+		converters: {
+			"text script": function(text) {
+				jQuery.globalEval(text);
+				return text
+			}
+		}
+	});
+	jQuery.ajaxPrefilter("script", function(s) {
+		if(s.cache === undefined) {
+			s.cache = false
+		}
+		if(s.crossDomain) {
+			s.type = "GET";
+			s.global = false
+		}
+	});
+	jQuery.ajaxTransport("script", function(s) {
+		if(s.crossDomain) {
+			var script, head = document.head || jQuery("head")[0] || document.documentElement;
+			return {
+				send: function(_, callback) {
+					script = document.createElement("script");
+					script.async = true;
+					if(s.scriptCharset) {
+						script.charset = s.scriptCharset
+					}
+					script.src = s.url;
+					script.onload = script.onreadystatechange = function(_, isAbort) {
+						if(isAbort || !script.readyState || /loaded|complete/.test(script.readyState)) {
+							script.onload = script.onreadystatechange = null;
+							if(script.parentNode) {
+								script.parentNode.removeChild(script)
+							}
+							script = null;
+							if(!isAbort) {
+								callback(200, "success")
+							}
+						}
+					};
+					head.insertBefore(script, head.firstChild)
+				},
+				abort: function() {
+					if(script) {
+						script.onload(undefined, true)
+					}
+				}
+			}
+		}
+	});
+	var oldCallbacks = [],
+		rjsonp = /(=)\?(?=&|$)|\?\?/;
+	jQuery.ajaxSetup({
+		jsonp: "callback",
+		jsonpCallback: function() {
+			var callback = oldCallbacks.pop() || (jQuery.expando + "_" + (ajax_nonce++));
+			this[callback] = true;
+			return callback
+		}
+	});
+	jQuery.ajaxPrefilter("json jsonp", function(s, originalSettings, jqXHR) {
+		var callbackName, overwritten, responseContainer, jsonProp = s.jsonp !== false && (rjsonp.test(s.url) ? "url" : typeof s.data === "string" && !(s.contentType || "").indexOf("application/x-www-form-urlencoded") && rjsonp.test(s.data) && "data");
+		if(jsonProp || s.dataTypes[0] === "jsonp") {
+			callbackName = s.jsonpCallback = jQuery.isFunction(s.jsonpCallback) ? s.jsonpCallback() : s.jsonpCallback;
+			if(jsonProp) {
+				s[jsonProp] = s[jsonProp].replace(rjsonp, "$1" + callbackName)
+			} else if(s.jsonp !== false) {
+				s.url += (ajax_rquery.test(s.url) ? "&" : "?") + s.jsonp + "=" + callbackName
+			}
+			s.converters["script json"] = function() {
+				if(!responseContainer) {
+					jQuery.error(callbackName + " was not called")
+				}
+				return responseContainer[0]
+			};
+			s.dataTypes[0] = "json";
+			overwritten = window[callbackName];
+			window[callbackName] = function() {
+				responseContainer = arguments
+			};
+			jqXHR.always(function() {
+				window[callbackName] = overwritten;
+				if(s[callbackName]) {
+					s.jsonpCallback = originalSettings.jsonpCallback;
+					oldCallbacks.push(callbackName)
+				}
+				if(responseContainer && jQuery.isFunction(overwritten)) {
+					overwritten(responseContainer[0])
+				}
+				responseContainer = overwritten = undefined
+			});
+			return "script"
+		}
+	});
+	var xhrCallbacks, xhrSupported, xhrId = 0,
+		xhrOnUnloadAbort = window.ActiveXObject && function() {
+			var key;
+			for(key in xhrCallbacks) {
+				xhrCallbacks[key](undefined, true)
+			}
+		};
+
+	function createStandardXHR() {
+		try {
+			return new window.XMLHttpRequest()
+		} catch(e) {}
+	}
+
+	function createActiveXHR() {
+		try {
+			return new window.ActiveXObject("Microsoft.XMLHTTP")
+		} catch(e) {}
+	}
+	jQuery.ajaxSettings.xhr = window.ActiveXObject ? function() {
+		return !this.isLocal && createStandardXHR() || createActiveXHR()
+	} : createStandardXHR;
+	xhrSupported = jQuery.ajaxSettings.xhr();
+	jQuery.support.cors = !!xhrSupported && ("withCredentials" in xhrSupported);
+	xhrSupported = jQuery.support.ajax = !!xhrSupported;
+	if(xhrSupported) {
+		jQuery.ajaxTransport(function(s) {
+			if(!s.crossDomain || jQuery.support.cors) {
+				var callback;
+				return {
+					send: function(headers, complete) {
+						var handle, i, xhr = s.xhr();
+						if(s.username) {
+							xhr.open(s.type, s.url, s.async, s.username, s.password)
+						} else {
+							xhr.open(s.type, s.url, s.async)
+						}
+						if(s.xhrFields) {
+							for(i in s.xhrFields) {
+								xhr[i] = s.xhrFields[i]
+							}
+						}
+						if(s.mimeType && xhr.overrideMimeType) {
+							xhr.overrideMimeType(s.mimeType)
+						}
+						if(!s.crossDomain && !headers["X-Requested-With"]) {
+							headers["X-Requested-With"] = "XMLHttpRequest"
+						}
+						try {
+							for(i in headers) {
+								xhr.setRequestHeader(i, headers[i])
+							}
+						} catch(err) {}
+						xhr.send((s.hasContent && s.data) || null);
+						callback = function(_, isAbort) {
+							var status, responseHeaders, statusText, responses;
+							try {
+								if(callback && (isAbort || xhr.readyState === 4)) {
+									callback = undefined;
+									if(handle) {
+										xhr.onreadystatechange = jQuery.noop;
+										if(xhrOnUnloadAbort) {
+											delete xhrCallbacks[handle]
+										}
+									}
+									if(isAbort) {
+										if(xhr.readyState !== 4) {
+											xhr.abort()
+										}
+									} else {
+										responses = {};
+										status = xhr.status;
+										responseHeaders = xhr.getAllResponseHeaders();
+										if(typeof xhr.responseText === "string") {
+											responses.text = xhr.responseText
+										}
+										try {
+											statusText = xhr.statusText
+										} catch(e) {
+											statusText = ""
+										}
+										if(!status && s.isLocal && !s.crossDomain) {
+											status = responses.text ? 200 : 404
+										} else if(status === 1223) {
+											status = 204
+										}
+									}
+								}
+							} catch(firefoxAccessException) {
+								if(!isAbort) {
+									complete(-1, firefoxAccessException)
+								}
+							}
+							if(responses) {
+								complete(status, statusText, responses, responseHeaders)
+							}
+						};
+						if(!s.async) {
+							callback()
+						} else if(xhr.readyState === 4) {
+							setTimeout(callback)
+						} else {
+							handle = ++xhrId;
+							if(xhrOnUnloadAbort) {
+								if(!xhrCallbacks) {
+									xhrCallbacks = {};
+									jQuery(window).unload(xhrOnUnloadAbort)
+								}
+								xhrCallbacks[handle] = callback
+							}
+							xhr.onreadystatechange = callback
+						}
+					},
+					abort: function() {
+						if(callback) {
+							callback(undefined, true)
+						}
+					}
+				}
+			}
+		})
+	}
+	var fxNow, timerId, rfxtypes = /^(?:toggle|show|hide)$/,
+		rfxnum = new RegExp("^(?:([+-])=|)(" + core_pnum + ")([a-z%]*)$", "i"),
+		rrun = /queueHooks$/,
+		animationPrefilters = [defaultPrefilter],
+		tweeners = {
+			"*": [function(prop, value) {
+				var end, unit, tween = this.createTween(prop, value),
+					parts = rfxnum.exec(value),
+					target = tween.cur(),
+					start = +target || 0,
+					scale = 1,
+					maxIterations = 20;
+				if(parts) {
+					end = +parts[2];
+					unit = parts[3] || (jQuery.cssNumber[prop] ? "" : "px");
+					if(unit !== "px" && start) {
+						start = jQuery.css(tween.elem, prop, true) || end || 1;
+						do {
+							scale = scale || ".5";
+							start = start / scale;
+							jQuery.style(tween.elem, prop, start + unit)
+						} while (scale !== (scale = tween.cur() / target) && scale !== 1 && --maxIterations)
+					}
+					tween.unit = unit;
+					tween.start = start;
+					tween.end = parts[1] ? start + (parts[1] + 1) * end : end
+				}
+				return tween
+			}]
+		};
+
+	function createFxNow() {
+		setTimeout(function() {
+			fxNow = undefined
 		});
-		
-		var directory = findPathToDirectory($(this).closest(".flex-item").find(".good-image img").attr("src"));
-		
-		for (var i = 0; i < files.length; i++)
-		{
-			images.push(directory + files[i] + ".png");
+		return(fxNow = jQuery.now())
+	}
+
+	function createTweens(animation, props) {
+		jQuery.each(props, function(prop, value) {
+			var collection = (tweeners[prop] || []).concat(tweeners["*"]),
+				index = 0,
+				length = collection.length;
+			for(; index < length; index++) {
+				if(collection[index].call(animation, prop, value)) {
+					return
+				}
+			}
+		})
+	}
+
+	function Animation(elem, properties, options) {
+		var result, stopped, index = 0,
+			length = animationPrefilters.length,
+			deferred = jQuery.Deferred().always(function() {
+				delete tick.elem
+			}),
+			tick = function() {
+				if(stopped) {
+					return false
+				}
+				var currentTime = fxNow || createFxNow(),
+					remaining = Math.max(0, animation.startTime + animation.duration - currentTime),
+					temp = remaining / animation.duration || 0,
+					percent = 1 - temp,
+					index = 0,
+					length = animation.tweens.length;
+				for(; index < length; index++) {
+					animation.tweens[index].run(percent)
+				}
+				deferred.notifyWith(elem, [animation, percent, remaining]);
+				if(percent < 1 && length) {
+					return remaining
+				} else {
+					deferred.resolveWith(elem, [animation]);
+					return false
+				}
+			},
+			animation = deferred.promise({
+				elem: elem,
+				props: jQuery.extend({}, properties),
+				opts: jQuery.extend(true, {
+					specialEasing: {}
+				}, options),
+				originalProperties: properties,
+				originalOptions: options,
+				startTime: fxNow || createFxNow(),
+				duration: options.duration,
+				tweens: [],
+				createTween: function(prop, end) {
+					var tween = jQuery.Tween(elem, animation.opts, prop, end, animation.opts.specialEasing[prop] || animation.opts.easing);
+					animation.tweens.push(tween);
+					return tween
+				},
+				stop: function(gotoEnd) {
+					var index = 0,
+						length = gotoEnd ? animation.tweens.length : 0;
+					if(stopped) {
+						return this
+					}
+					stopped = true;
+					for(; index < length; index++) {
+						animation.tweens[index].run(1)
+					}
+					if(gotoEnd) {
+						deferred.resolveWith(elem, [animation, gotoEnd])
+					} else {
+						deferred.rejectWith(elem, [animation, gotoEnd])
+					}
+					return this
+				}
+			}),
+			props = animation.props;
+		propFilter(props, animation.opts.specialEasing);
+		for(; index < length; index++) {
+			result = animationPrefilters[index].call(animation, elem, props, animation.opts);
+			if(result) {
+				return result
+			}
+		}
+		createTweens(animation, props);
+		if(jQuery.isFunction(animation.opts.start)) {
+			animation.opts.start.call(elem, animation)
+		}
+		jQuery.fx.timer(jQuery.extend(tick, {
+			elem: elem,
+			anim: animation,
+			queue: animation.opts.queue
+		}));
+		return animation.progress(animation.opts.progress).done(animation.opts.done, animation.opts.complete).fail(animation.opts.fail).always(animation.opts.always)
+	}
+
+	function propFilter(props, specialEasing) {
+		var value, name, index, easing, hooks;
+		for(index in props) {
+			name = jQuery.camelCase(index);
+			easing = specialEasing[name];
+			value = props[index];
+			if(jQuery.isArray(value)) {
+				easing = value[1];
+				value = props[index] = value[0]
+			}
+			if(index !== name) {
+				props[name] = value;
+				delete props[index]
+			}
+			hooks = jQuery.cssHooks[name];
+			if(hooks && "expand" in hooks) {
+				value = hooks.expand(value);
+				delete props[name];
+				for(index in value) {
+					if(!(index in props)) {
+						props[index] = value[index];
+						specialEasing[index] = easing
+					}
+				}
+			} else {
+				specialEasing[name] = easing
+			}
+		}
+	}
+	jQuery.Animation = jQuery.extend(Animation, {
+		tweener: function(props, callback) {
+			if(jQuery.isFunction(props)) {
+				callback = props;
+				props = ["*"]
+			} else {
+				props = props.split(" ")
+			}
+			var prop, index = 0,
+				length = props.length;
+			for(; index < length; index++) {
+				prop = props[index];
+				tweeners[prop] = tweeners[prop] || [];
+				tweeners[prop].unshift(callback)
+			}
+		},
+		prefilter: function(callback, prepend) {
+			if(prepend) {
+				animationPrefilters.unshift(callback)
+			} else {
+				animationPrefilters.push(callback)
+			}
+		}
+	});
+
+	function defaultPrefilter(elem, props, opts) {
+		var prop, index, length, value, dataShow, toggle, tween, hooks, oldfire, anim = this,
+			style = elem.style,
+			orig = {},
+			handled = [],
+			hidden = elem.nodeType && isHidden(elem);
+		if(!opts.queue) {
+			hooks = jQuery._queueHooks(elem, "fx");
+			if(hooks.unqueued == null) {
+				hooks.unqueued = 0;
+				oldfire = hooks.empty.fire;
+				hooks.empty.fire = function() {
+					if(!hooks.unqueued) {
+						oldfire()
+					}
+				}
+			}
+			hooks.unqueued++;
+			anim.always(function() {
+				anim.always(function() {
+					hooks.unqueued--;
+					if(!jQuery.queue(elem, "fx").length) {
+						hooks.empty.fire()
+					}
+				})
+			})
+		}
+		if(elem.nodeType === 1 && ("height" in props || "width" in props)) {
+			opts.overflow = [style.overflow, style.overflowX, style.overflowY];
+			if(jQuery.css(elem, "display") === "inline" && jQuery.css(elem, "float") === "none") {
+				if(!jQuery.support.inlineBlockNeedsLayout || css_defaultDisplay(elem.nodeName) === "inline") {
+					style.display = "inline-block"
+				} else {
+					style.zoom = 1
+				}
+			}
+		}
+		if(opts.overflow) {
+			style.overflow = "hidden";
+			if(!jQuery.support.shrinkWrapBlocks) {
+				anim.always(function() {
+					style.overflow = opts.overflow[0];
+					style.overflowX = opts.overflow[1];
+					style.overflowY = opts.overflow[2]
+				})
+			}
+		}
+		for(index in props) {
+			value = props[index];
+			if(rfxtypes.exec(value)) {
+				delete props[index];
+				toggle = toggle || value === "toggle";
+				if(value === (hidden ? "hide" : "show")) {
+					continue
+				}
+				handled.push(index)
+			}
+		}
+		length = handled.length;
+		if(length) {
+			dataShow = jQuery._data(elem, "fxshow") || jQuery._data(elem, "fxshow", {});
+			if("hidden" in dataShow) {
+				hidden = dataShow.hidden
+			}
+			if(toggle) {
+				dataShow.hidden = !hidden
+			}
+			if(hidden) {
+				jQuery(elem).show()
+			} else {
+				anim.done(function() {
+					jQuery(elem).hide()
+				})
+			}
+			anim.done(function() {
+				var prop;
+				jQuery._removeData(elem, "fxshow");
+				for(prop in orig) {
+					jQuery.style(elem, prop, orig[prop])
+				}
+			});
+			for(index = 0; index < length; index++) {
+				prop = handled[index];
+				tween = anim.createTween(prop, hidden ? dataShow[prop] : 0);
+				orig[prop] = dataShow[prop] || jQuery.style(elem, prop);
+				if(!(prop in dataShow)) {
+					dataShow[prop] = tween.start;
+					if(hidden) {
+						tween.end = tween.start;
+						tween.start = prop === "width" || prop === "height" ? 1 : 0
+					}
+				}
+			}
+		}
+	}
+
+	function Tween(elem, options, prop, end, easing) {
+		return new Tween.prototype.init(elem, options, prop, end, easing)
+	}
+	jQuery.Tween = Tween;
+	Tween.prototype = {
+		constructor: Tween,
+		init: function(elem, options, prop, end, easing, unit) {
+			this.elem = elem;
+			this.prop = prop;
+			this.easing = easing || "swing";
+			this.options = options;
+			this.start = this.now = this.cur();
+			this.end = end;
+			this.unit = unit || (jQuery.cssNumber[prop] ? "" : "px")
+		},
+		cur: function() {
+			var hooks = Tween.propHooks[this.prop];
+			return hooks && hooks.get ? hooks.get(this) : Tween.propHooks._default.get(this)
+		},
+		run: function(percent) {
+			var eased, hooks = Tween.propHooks[this.prop];
+			if(this.options.duration) {
+				this.pos = eased = jQuery.easing[this.easing](percent, this.options.duration * percent, 0, 1, this.options.duration)
+			} else {
+				this.pos = eased = percent
+			}
+			this.now = (this.end - this.start) * eased + this.start;
+			if(this.options.step) {
+				this.options.step.call(this.elem, this.now, this)
+			}
+			if(hooks && hooks.set) {
+				hooks.set(this)
+			} else {
+				Tween.propHooks._default.set(this)
+			}
+			return this
+		}
+	};
+	Tween.prototype.init.prototype = Tween.prototype;
+	Tween.propHooks = {
+		_default: {
+			get: function(tween) {
+				var result;
+				if(tween.elem[tween.prop] != null && (!tween.elem.style || tween.elem.style[tween.prop] == null)) {
+					return tween.elem[tween.prop]
+				}
+				result = jQuery.css(tween.elem, tween.prop, "");
+				return !result || result === "auto" ? 0 : result
+			},
+			set: function(tween) {
+				if(jQuery.fx.step[tween.prop]) {
+					jQuery.fx.step[tween.prop](tween)
+				} else if(tween.elem.style && (tween.elem.style[jQuery.cssProps[tween.prop]] != null || jQuery.cssHooks[tween.prop])) {
+					jQuery.style(tween.elem, tween.prop, tween.now + tween.unit)
+				} else {
+					tween.elem[tween.prop] = tween.now
+				}
+			}
+		}
+	};
+	Tween.propHooks.scrollTop = Tween.propHooks.scrollLeft = {
+		set: function(tween) {
+			if(tween.elem.nodeType && tween.elem.parentNode) {
+				tween.elem[tween.prop] = tween.now
+			}
+		}
+	};
+	jQuery.each(["toggle", "show", "hide"], function(i, name) {
+		var cssFn = jQuery.fn[name];
+		jQuery.fn[name] = function(speed, easing, callback) {
+			return speed == null || typeof speed === "boolean" ? cssFn.apply(this, arguments) : this.animate(genFx(name, true), speed, easing, callback)
+		}
+	});
+	jQuery.fn.extend({
+		fadeTo: function(speed, to, easing, callback) {
+			return this.filter(isHidden).css("opacity", 0).show().end().animate({
+				opacity: to
+			}, speed, easing, callback)
+		},
+		animate: function(prop, speed, easing, callback) {
+			var empty = jQuery.isEmptyObject(prop),
+				optall = jQuery.speed(speed, easing, callback),
+				doAnimation = function() {
+					var anim = Animation(this, jQuery.extend({}, prop), optall);
+					doAnimation.finish = function() {
+						anim.stop(true)
+					};
+					if(empty || jQuery._data(this, "finish")) {
+						anim.stop(true)
+					}
+				};
+			doAnimation.finish = doAnimation;
+			return empty || optall.queue === false ? this.each(doAnimation) : this.queue(optall.queue, doAnimation)
+		},
+		stop: function(type, clearQueue, gotoEnd) {
+			var stopQueue = function(hooks) {
+				var stop = hooks.stop;
+				delete hooks.stop;
+				stop(gotoEnd)
+			};
+			if(typeof type !== "string") {
+				gotoEnd = clearQueue;
+				clearQueue = type;
+				type = undefined
+			}
+			if(clearQueue && type !== false) {
+				this.queue(type || "fx", [])
+			}
+			return this.each(function() {
+				var dequeue = true,
+					index = type != null && type + "queueHooks",
+					timers = jQuery.timers,
+					data = jQuery._data(this);
+				if(index) {
+					if(data[index] && data[index].stop) {
+						stopQueue(data[index])
+					}
+				} else {
+					for(index in data) {
+						if(data[index] && data[index].stop && rrun.test(index)) {
+							stopQueue(data[index])
+						}
+					}
+				}
+				for(index = timers.length; index--;) {
+					if(timers[index].elem === this && (type == null || timers[index].queue === type)) {
+						timers[index].anim.stop(gotoEnd);
+						dequeue = false;
+						timers.splice(index, 1)
+					}
+				}
+				if(dequeue || !gotoEnd) {
+					jQuery.dequeue(this, type)
+				}
+			})
+		},
+		finish: function(type) {
+			if(type !== false) {
+				type = type || "fx"
+			}
+			return this.each(function() {
+				var index, data = jQuery._data(this),
+					queue = data[type + "queue"],
+					hooks = data[type + "queueHooks"],
+					timers = jQuery.timers,
+					length = queue ? queue.length : 0;
+				data.finish = true;
+				jQuery.queue(this, type, []);
+				if(hooks && hooks.cur && hooks.cur.finish) {
+					hooks.cur.finish.call(this)
+				}
+				for(index = timers.length; index--;) {
+					if(timers[index].elem === this && timers[index].queue === type) {
+						timers[index].anim.stop(true);
+						timers.splice(index, 1)
+					}
+				}
+				for(index = 0; index < length; index++) {
+					if(queue[index] && queue[index].finish) {
+						queue[index].finish.call(this)
+					}
+				}
+				delete data.finish
+			})
 		}
 	});
-	
-	return images;
+
+	function genFx(type, includeWidth) {
+		var which, attrs = {
+				height: type
+			},
+			i = 0;
+		includeWidth = includeWidth ? 1 : 0;
+		for(; i < 4; i += 2 - includeWidth) {
+			which = cssExpand[i];
+			attrs["margin" + which] = attrs["padding" + which] = type
+		}
+		if(includeWidth) {
+			attrs.opacity = attrs.width = type
+		}
+		return attrs
+	}
+	jQuery.each({
+		slideDown: genFx("show"),
+		slideUp: genFx("hide"),
+		slideToggle: genFx("toggle"),
+		fadeIn: {
+			opacity: "show"
+		},
+		fadeOut: {
+			opacity: "hide"
+		},
+		fadeToggle: {
+			opacity: "toggle"
+		}
+	}, function(name, props) {
+		jQuery.fn[name] = function(speed, easing, callback) {
+			return this.animate(props, speed, easing, callback)
+		}
+	});
+	jQuery.speed = function(speed, easing, fn) {
+		var opt = speed && typeof speed === "object" ? jQuery.extend({}, speed) : {
+			complete: fn || !fn && easing || jQuery.isFunction(speed) && speed,
+			duration: speed,
+			easing: fn && easing || easing && !jQuery.isFunction(easing) && easing
+		};
+		opt.duration = jQuery.fx.off ? 0 : typeof opt.duration === "number" ? opt.duration : opt.duration in jQuery.fx.speeds ? jQuery.fx.speeds[opt.duration] : jQuery.fx.speeds._default;
+		if(opt.queue == null || opt.queue === true) {
+			opt.queue = "fx"
+		}
+		opt.old = opt.complete;
+		opt.complete = function() {
+			if(jQuery.isFunction(opt.old)) {
+				opt.old.call(this)
+			}
+			if(opt.queue) {
+				jQuery.dequeue(this, opt.queue)
+			}
+		};
+		return opt
+	};
+	jQuery.easing = {
+		linear: function(p) {
+			return p
+		},
+		swing: function(p) {
+			return 0.5 - Math.cos(p * Math.PI) / 2
+		}
+	};
+	jQuery.timers = [];
+	jQuery.fx = Tween.prototype.init;
+	jQuery.fx.tick = function() {
+		var timer, timers = jQuery.timers,
+			i = 0;
+		fxNow = jQuery.now();
+		for(; i < timers.length; i++) {
+			timer = timers[i];
+			if(!timer() && timers[i] === timer) {
+				timers.splice(i--, 1)
+			}
+		}
+		if(!timers.length) {
+			jQuery.fx.stop()
+		}
+		fxNow = undefined
+	};
+	jQuery.fx.timer = function(timer) {
+		if(timer() && jQuery.timers.push(timer)) {
+			jQuery.fx.start()
+		}
+	};
+	jQuery.fx.interval = 13;
+	jQuery.fx.start = function() {
+		if(!timerId) {
+			timerId = setInterval(jQuery.fx.tick, jQuery.fx.interval)
+		}
+	};
+	jQuery.fx.stop = function() {
+		clearInterval(timerId);
+		timerId = null
+	};
+	jQuery.fx.speeds = {
+		slow: 600,
+		fast: 200,
+		_default: 400
+	};
+	jQuery.fx.step = {};
+	if(jQuery.expr && jQuery.expr.filters) {
+		jQuery.expr.filters.animated = function(elem) {
+			return jQuery.grep(jQuery.timers, function(fn) {
+				return elem === fn.elem
+			}).length
+		}
+	}
+	jQuery.fn.offset = function(options) {
+		if(arguments.length) {
+			return options === undefined ? this : this.each(function(i) {
+				jQuery.offset.setOffset(this, options, i)
+			})
+		}
+		var docElem, win, box = {
+				top: 0,
+				left: 0
+			},
+			elem = this[0],
+			doc = elem && elem.ownerDocument;
+		if(!doc) {
+			return
+		}
+		docElem = doc.documentElement;
+		if(!jQuery.contains(docElem, elem)) {
+			return box
+		}
+		if(typeof elem.getBoundingClientRect !== core_strundefined) {
+			box = elem.getBoundingClientRect()
+		}
+		win = getWindow(doc);
+		return {
+			top: box.top + (win.pageYOffset || docElem.scrollTop) - (docElem.clientTop || 0),
+			left: box.left + (win.pageXOffset || docElem.scrollLeft) - (docElem.clientLeft || 0)
+		}
+	};
+	jQuery.offset = {
+		setOffset: function(elem, options, i) {
+			var position = jQuery.css(elem, "position");
+			if(position === "static") {
+				elem.style.position = "relative"
+			}
+			var curElem = jQuery(elem),
+				curOffset = curElem.offset(),
+				curCSSTop = jQuery.css(elem, "top"),
+				curCSSLeft = jQuery.css(elem, "left"),
+				calculatePosition = (position === "absolute" || position === "fixed") && jQuery.inArray("auto", [curCSSTop, curCSSLeft]) > -1,
+				props = {},
+				curPosition = {},
+				curTop, curLeft;
+			if(calculatePosition) {
+				curPosition = curElem.position();
+				curTop = curPosition.top;
+				curLeft = curPosition.left
+			} else {
+				curTop = parseFloat(curCSSTop) || 0;
+				curLeft = parseFloat(curCSSLeft) || 0
+			}
+			if(jQuery.isFunction(options)) {
+				options = options.call(elem, i, curOffset)
+			}
+			if(options.top != null) {
+				props.top = (options.top - curOffset.top) + curTop
+			}
+			if(options.left != null) {
+				props.left = (options.left - curOffset.left) + curLeft
+			}
+			if("using" in options) {
+				options.using.call(elem, props)
+			} else {
+				curElem.css(props)
+			}
+		}
+	};
+	jQuery.fn.extend({
+		position: function() {
+			if(!this[0]) {
+				return
+			}
+			var offsetParent, offset, parentOffset = {
+					top: 0,
+					left: 0
+				},
+				elem = this[0];
+			if(jQuery.css(elem, "position") === "fixed") {
+				offset = elem.getBoundingClientRect()
+			} else {
+				offsetParent = this.offsetParent();
+				offset = this.offset();
+				if(!jQuery.nodeName(offsetParent[0], "html")) {
+					parentOffset = offsetParent.offset()
+				}
+				parentOffset.top += jQuery.css(offsetParent[0], "borderTopWidth", true);
+				parentOffset.left += jQuery.css(offsetParent[0], "borderLeftWidth", true)
+			}
+			return {
+				top: offset.top - parentOffset.top - jQuery.css(elem, "marginTop", true),
+				left: offset.left - parentOffset.left - jQuery.css(elem, "marginLeft", true)
+			}
+		},
+		offsetParent: function() {
+			return this.map(function() {
+				var offsetParent = this.offsetParent || document.documentElement;
+				while(offsetParent && (!jQuery.nodeName(offsetParent, "html") && jQuery.css(offsetParent, "position") === "static")) {
+					offsetParent = offsetParent.offsetParent
+				}
+				return offsetParent || document.documentElement
+			})
+		}
+	});
+	jQuery.each({
+		scrollLeft: "pageXOffset",
+		scrollTop: "pageYOffset"
+	}, function(method, prop) {
+		var top = /Y/.test(prop);
+		jQuery.fn[method] = function(val) {
+			return jQuery.access(this, function(elem, method, val) {
+				var win = getWindow(elem);
+				if(val === undefined) {
+					return win ? (prop in win) ? win[prop] : win.document.documentElement[method] : elem[method]
+				}
+				if(win) {
+					win.scrollTo(!top ? val : jQuery(win).scrollLeft(), top ? val : jQuery(win).scrollTop())
+				} else {
+					elem[method] = val
+				}
+			}, method, val, arguments.length, null)
+		}
+	});
+
+	function getWindow(elem) {
+		return jQuery.isWindow(elem) ? elem : elem.nodeType === 9 ? elem.defaultView || elem.parentWindow : false
+	}
+	jQuery.each({
+		Height: "height",
+		Width: "width"
+	}, function(name, type) {
+		jQuery.each({
+			padding: "inner" + name,
+			content: type,
+			"": "outer" + name
+		}, function(defaultExtra, funcName) {
+			jQuery.fn[funcName] = function(margin, value) {
+				var chainable = arguments.length && (defaultExtra || typeof margin !== "boolean"),
+					extra = defaultExtra || (margin === true || value === true ? "margin" : "border");
+				return jQuery.access(this, function(elem, type, value) {
+					var doc;
+					if(jQuery.isWindow(elem)) {
+						return elem.document.documentElement["client" + name]
+					}
+					if(elem.nodeType === 9) {
+						doc = elem.documentElement;
+						return Math.max(elem.body["scroll" + name], doc["scroll" + name], elem.body["offset" + name], doc["offset" + name], doc["client" + name])
+					}
+					return value === undefined ? jQuery.css(elem, type, extra) : jQuery.style(elem, type, value, extra)
+				}, type, chainable ? margin : undefined, chainable, null)
+			}
+		})
+	});
+	window.jQuery = window.$ = jQuery;
+	if(typeof define === "function" && define.amd && define.amd.jQuery) {
+		define("jquery", [], function() {
+			return jQuery
+		})
+	}
+})(window);
+
+/*!
+ * Bootstrap v3.3.6 (http://getbootstrap.com)
+ * Copyright 2011-2015 Twitter, Inc.
+ * Licensed under the MIT license
+ */
+if("undefined" == typeof jQuery) throw new Error("Bootstrap's JavaScript requires jQuery"); + function(a) {
+	"use strict";
+	var b = a.fn.jquery.split(" ")[0].split(".");
+	if(b[0] < 2 && b[1] < 9 || 1 == b[0] && 9 == b[1] && b[2] < 1 || b[0] > 2) throw new Error("Bootstrap's JavaScript requires jQuery version 1.9.1 or higher, but lower than version 3")
+}(jQuery), + function(a) {
+	"use strict";
+
+	function b() {
+		var a = document.createElement("bootstrap"),
+			b = {
+				WebkitTransition: "webkitTransitionEnd",
+				MozTransition: "transitionend",
+				OTransition: "oTransitionEnd otransitionend",
+				transition: "transitionend"
+			};
+		for(var c in b)
+			if(void 0 !== a.style[c]) return {
+				end: b[c]
+			};
+		return !1
+	}
+	a.fn.emulateTransitionEnd = function(b) {
+		var c = !1,
+			d = this;
+		a(this).one("bsTransitionEnd", function() {
+			c = !0
+		});
+		var e = function() {
+			c || a(d).trigger(a.support.transition.end)
+		};
+		return setTimeout(e, b), this
+	}, a(function() {
+		a.support.transition = b(), a.support.transition && (a.event.special.bsTransitionEnd = {
+			bindType: a.support.transition.end,
+			delegateType: a.support.transition.end,
+			handle: function(b) {
+				return a(b.target).is(this) ? b.handleObj.handler.apply(this, arguments) : void 0
+			}
+		})
+	})
+}(jQuery), + function(a) {
+	"use strict";
+
+	function b(b) {
+		return this.each(function() {
+			var c = a(this),
+				e = c.data("bs.alert");
+			e || c.data("bs.alert", e = new d(this)), "string" == typeof b && e[b].call(c)
+		})
+	}
+	var c = '[data-dismiss="alert"]',
+		d = function(b) {
+			a(b).on("click", c, this.close)
+		};
+	d.VERSION = "3.3.6", d.TRANSITION_DURATION = 150, d.prototype.close = function(b) {
+		function c() {
+			g.detach().trigger("closed.bs.alert").remove()
+		}
+		var e = a(this),
+			f = e.attr("data-target");
+		f || (f = e.attr("href"), f = f && f.replace(/.*(?=#[^\s]*$)/, ""));
+		var g = a(f);
+		b && b.preventDefault(), g.length || (g = e.closest(".alert")), g.trigger(b = a.Event("close.bs.alert")), b.isDefaultPrevented() || (g.removeClass("in"), a.support.transition && g.hasClass("fade") ? g.one("bsTransitionEnd", c).emulateTransitionEnd(d.TRANSITION_DURATION) : c())
+	};
+	var e = a.fn.alert;
+	a.fn.alert = b, a.fn.alert.Constructor = d, a.fn.alert.noConflict = function() {
+		return a.fn.alert = e, this
+	}, a(document).on("click.bs.alert.data-api", c, d.prototype.close)
+}(jQuery), + function(a) {
+	"use strict";
+
+	function b(b) {
+		return this.each(function() {
+			var d = a(this),
+				e = d.data("bs.button"),
+				f = "object" == typeof b && b;
+			e || d.data("bs.button", e = new c(this, f)), "toggle" == b ? e.toggle() : b && e.setState(b)
+		})
+	}
+	var c = function(b, d) {
+		this.$element = a(b), this.options = a.extend({}, c.DEFAULTS, d), this.isLoading = !1
+	};
+	c.VERSION = "3.3.6", c.DEFAULTS = {
+		loadingText: "loading..."
+	}, c.prototype.setState = function(b) {
+		var c = "disabled",
+			d = this.$element,
+			e = d.is("input") ? "val" : "html",
+			f = d.data();
+		b += "Text", null == f.resetText && d.data("resetText", d[e]()), setTimeout(a.proxy(function() {
+			d[e](null == f[b] ? this.options[b] : f[b]), "loadingText" == b ? (this.isLoading = !0, d.addClass(c).attr(c, c)) : this.isLoading && (this.isLoading = !1, d.removeClass(c).removeAttr(c))
+		}, this), 0)
+	}, c.prototype.toggle = function() {
+		var a = !0,
+			b = this.$element.closest('[data-toggle="buttons"]');
+		if(b.length) {
+			var c = this.$element.find("input");
+			"radio" == c.prop("type") ? (c.prop("checked") && (a = !1), b.find(".active").removeClass("active"), this.$element.addClass("active")) : "checkbox" == c.prop("type") && (c.prop("checked") !== this.$element.hasClass("active") && (a = !1), this.$element.toggleClass("active")), c.prop("checked", this.$element.hasClass("active")), a && c.trigger("change")
+		} else this.$element.attr("aria-pressed", !this.$element.hasClass("active")), this.$element.toggleClass("active")
+	};
+	var d = a.fn.button;
+	a.fn.button = b, a.fn.button.Constructor = c, a.fn.button.noConflict = function() {
+		return a.fn.button = d, this
+	}, a(document).on("click.bs.button.data-api", '[data-toggle^="button"]', function(c) {
+		var d = a(c.target);
+		d.hasClass("btn") || (d = d.closest(".btn")), b.call(d, "toggle"), a(c.target).is('input[type="radio"]') || a(c.target).is('input[type="checkbox"]') || c.preventDefault()
+	}).on("focus.bs.button.data-api blur.bs.button.data-api", '[data-toggle^="button"]', function(b) {
+		a(b.target).closest(".btn").toggleClass("focus", /^focus(in)?$/.test(b.type))
+	})
+}(jQuery), + function(a) {
+	"use strict";
+
+	function b(b) {
+		return this.each(function() {
+			var d = a(this),
+				e = d.data("bs.carousel"),
+				f = a.extend({}, c.DEFAULTS, d.data(), "object" == typeof b && b),
+				g = "string" == typeof b ? b : f.slide;
+			e || d.data("bs.carousel", e = new c(this, f)), "number" == typeof b ? e.to(b) : g ? e[g]() : f.interval && e.pause().cycle()
+		})
+	}
+	var c = function(b, c) {
+		this.$element = a(b), this.$indicators = this.$element.find(".carousel-indicators"), this.options = c, this.paused = null, this.sliding = null, this.interval = null, this.$active = null, this.$items = null, this.options.keyboard && this.$element.on("keydown.bs.carousel", a.proxy(this.keydown, this)), "hover" == this.options.pause && !("ontouchstart" in document.documentElement) && this.$element.on("mouseenter.bs.carousel", a.proxy(this.pause, this)).on("mouseleave.bs.carousel", a.proxy(this.cycle, this))
+	};
+	c.VERSION = "3.3.6", c.TRANSITION_DURATION = 600, c.DEFAULTS = {
+		interval: 5e3,
+		pause: "hover",
+		wrap: !0,
+		keyboard: !0
+	}, c.prototype.keydown = function(a) {
+		if(!/input|textarea/i.test(a.target.tagName)) {
+			switch(a.which) {
+				case 37:
+					this.prev();
+					break;
+				case 39:
+					this.next();
+					break;
+				default:
+					return
+			}
+			a.preventDefault()
+		}
+	}, c.prototype.cycle = function(b) {
+		return b || (this.paused = !1), this.interval && clearInterval(this.interval), this.options.interval && !this.paused && (this.interval = setInterval(a.proxy(this.next, this), this.options.interval)), this
+	}, c.prototype.getItemIndex = function(a) {
+		return this.$items = a.parent().children(".item"), this.$items.index(a || this.$active)
+	}, c.prototype.getItemForDirection = function(a, b) {
+		var c = this.getItemIndex(b),
+			d = "prev" == a && 0 === c || "next" == a && c == this.$items.length - 1;
+		if(d && !this.options.wrap) return b;
+		var e = "prev" == a ? -1 : 1,
+			f = (c + e) % this.$items.length;
+		return this.$items.eq(f)
+	}, c.prototype.to = function(a) {
+		var b = this,
+			c = this.getItemIndex(this.$active = this.$element.find(".item.active"));
+		return a > this.$items.length - 1 || 0 > a ? void 0 : this.sliding ? this.$element.one("slid.bs.carousel", function() {
+			b.to(a)
+		}) : c == a ? this.pause().cycle() : this.slide(a > c ? "next" : "prev", this.$items.eq(a))
+	}, c.prototype.pause = function(b) {
+		return b || (this.paused = !0), this.$element.find(".next, .prev").length && a.support.transition && (this.$element.trigger(a.support.transition.end), this.cycle(!0)), this.interval = clearInterval(this.interval), this
+	}, c.prototype.next = function() {
+		return this.sliding ? void 0 : this.slide("next")
+	}, c.prototype.prev = function() {
+		return this.sliding ? void 0 : this.slide("prev")
+	}, c.prototype.slide = function(b, d) {
+		var e = this.$element.find(".item.active"),
+			f = d || this.getItemForDirection(b, e),
+			g = this.interval,
+			h = "next" == b ? "left" : "right",
+			i = this;
+		if(f.hasClass("active")) return this.sliding = !1;
+		var j = f[0],
+			k = a.Event("slide.bs.carousel", {
+				relatedTarget: j,
+				direction: h
+			});
+		if(this.$element.trigger(k), !k.isDefaultPrevented()) {
+			if(this.sliding = !0, g && this.pause(), this.$indicators.length) {
+				this.$indicators.find(".active").removeClass("active");
+				var l = a(this.$indicators.children()[this.getItemIndex(f)]);
+				l && l.addClass("active")
+			}
+			var m = a.Event("slid.bs.carousel", {
+				relatedTarget: j,
+				direction: h
+			});
+			return a.support.transition && this.$element.hasClass("slide") ? (f.addClass(b), f[0].offsetWidth, e.addClass(h), f.addClass(h), e.one("bsTransitionEnd", function() {
+				f.removeClass([b, h].join(" ")).addClass("active"), e.removeClass(["active", h].join(" ")), i.sliding = !1, setTimeout(function() {
+					i.$element.trigger(m)
+				}, 0)
+			}).emulateTransitionEnd(c.TRANSITION_DURATION)) : (e.removeClass("active"), f.addClass("active"), this.sliding = !1, this.$element.trigger(m)), g && this.cycle(), this
+		}
+	};
+	var d = a.fn.carousel;
+	a.fn.carousel = b, a.fn.carousel.Constructor = c, a.fn.carousel.noConflict = function() {
+		return a.fn.carousel = d, this
+	};
+	var e = function(c) {
+		var d, e = a(this),
+			f = a(e.attr("data-target") || (d = e.attr("href")) && d.replace(/.*(?=#[^\s]+$)/, ""));
+		if(f.hasClass("carousel")) {
+			var g = a.extend({}, f.data(), e.data()),
+				h = e.attr("data-slide-to");
+			h && (g.interval = !1), b.call(f, g), h && f.data("bs.carousel").to(h), c.preventDefault()
+		}
+	};
+	a(document).on("click.bs.carousel.data-api", "[data-slide]", e).on("click.bs.carousel.data-api", "[data-slide-to]", e), a(window).on("load", function() {
+		a('[data-ride="carousel"]').each(function() {
+			var c = a(this);
+			b.call(c, c.data())
+		})
+	})
+}(jQuery), + function(a) {
+	"use strict";
+
+	function b(b) {
+		var c, d = b.attr("data-target") || (c = b.attr("href")) && c.replace(/.*(?=#[^\s]+$)/, "");
+		return a(d)
+	}
+
+	function c(b) {
+		return this.each(function() {
+			var c = a(this),
+				e = c.data("bs.collapse"),
+				f = a.extend({}, d.DEFAULTS, c.data(), "object" == typeof b && b);
+			!e && f.toggle && /show|hide/.test(b) && (f.toggle = !1), e || c.data("bs.collapse", e = new d(this, f)), "string" == typeof b && e[b]()
+		})
+	}
+	var d = function(b, c) {
+		this.$element = a(b), this.options = a.extend({}, d.DEFAULTS, c), this.$trigger = a('[data-toggle="collapse"][href="#' + b.id + '"],[data-toggle="collapse"][data-target="#' + b.id + '"]'), this.transitioning = null, this.options.parent ? this.$parent = this.getParent() : this.addAriaAndCollapsedClass(this.$element, this.$trigger), this.options.toggle && this.toggle()
+	};
+	d.VERSION = "3.3.6", d.TRANSITION_DURATION = 350, d.DEFAULTS = {
+		toggle: !0
+	}, d.prototype.dimension = function() {
+		var a = this.$element.hasClass("width");
+		return a ? "width" : "height"
+	}, d.prototype.show = function() {
+		if(!this.transitioning && !this.$element.hasClass("in")) {
+			var b, e = this.$parent && this.$parent.children(".panel").children(".in, .collapsing");
+			if(!(e && e.length && (b = e.data("bs.collapse"), b && b.transitioning))) {
+				var f = a.Event("show.bs.collapse");
+				if(this.$element.trigger(f), !f.isDefaultPrevented()) {
+					e && e.length && (c.call(e, "hide"), b || e.data("bs.collapse", null));
+					var g = this.dimension();
+					this.$element.removeClass("collapse").addClass("collapsing")[g](0).attr("aria-expanded", !0), this.$trigger.removeClass("collapsed").attr("aria-expanded", !0), this.transitioning = 1;
+					var h = function() {
+						this.$element.removeClass("collapsing").addClass("collapse in")[g](""), this.transitioning = 0, this.$element.trigger("shown.bs.collapse")
+					};
+					if(!a.support.transition) return h.call(this);
+					var i = a.camelCase(["scroll", g].join("-"));
+					this.$element.one("bsTransitionEnd", a.proxy(h, this)).emulateTransitionEnd(d.TRANSITION_DURATION)[g](this.$element[0][i])
+				}
+			}
+		}
+	}, d.prototype.hide = function() {
+		if(!this.transitioning && this.$element.hasClass("in")) {
+			var b = a.Event("hide.bs.collapse");
+			if(this.$element.trigger(b), !b.isDefaultPrevented()) {
+				var c = this.dimension();
+				this.$element[c](this.$element[c]())[0].offsetHeight, this.$element.addClass("collapsing").removeClass("collapse in").attr("aria-expanded", !1), this.$trigger.addClass("collapsed").attr("aria-expanded", !1), this.transitioning = 1;
+				var e = function() {
+					this.transitioning = 0, this.$element.removeClass("collapsing").addClass("collapse").trigger("hidden.bs.collapse")
+				};
+				return a.support.transition ? void this.$element[c](0).one("bsTransitionEnd", a.proxy(e, this)).emulateTransitionEnd(d.TRANSITION_DURATION) : e.call(this)
+			}
+		}
+	}, d.prototype.toggle = function() {
+		this[this.$element.hasClass("in") ? "hide" : "show"]()
+	}, d.prototype.getParent = function() {
+		return a(this.options.parent).find('[data-toggle="collapse"][data-parent="' + this.options.parent + '"]').each(a.proxy(function(c, d) {
+			var e = a(d);
+			this.addAriaAndCollapsedClass(b(e), e)
+		}, this)).end()
+	}, d.prototype.addAriaAndCollapsedClass = function(a, b) {
+		var c = a.hasClass("in");
+		a.attr("aria-expanded", c), b.toggleClass("collapsed", !c).attr("aria-expanded", c)
+	};
+	var e = a.fn.collapse;
+	a.fn.collapse = c, a.fn.collapse.Constructor = d, a.fn.collapse.noConflict = function() {
+		return a.fn.collapse = e, this
+	}, a(document).on("click.bs.collapse.data-api", '[data-toggle="collapse"]', function(d) {
+		var e = a(this);
+		e.attr("data-target") || d.preventDefault();
+		var f = b(e),
+			g = f.data("bs.collapse"),
+			h = g ? "toggle" : e.data();
+		c.call(f, h)
+	})
+}(jQuery), + function(a) {
+	"use strict";
+
+	function b(b) {
+		var c = b.attr("data-target");
+		c || (c = b.attr("href"), c = c && /#[A-Za-z]/.test(c) && c.replace(/.*(?=#[^\s]*$)/, ""));
+		var d = c && a(c);
+		return d && d.length ? d : b.parent()
+	}
+
+	function c(c) {
+		c && 3 === c.which || (a(e).remove(), a(f).each(function() {
+			var d = a(this),
+				e = b(d),
+				f = {
+					relatedTarget: this
+				};
+			e.hasClass("open") && (c && "click" == c.type && /input|textarea/i.test(c.target.tagName) && a.contains(e[0], c.target) || (e.trigger(c = a.Event("hide.bs.dropdown", f)), c.isDefaultPrevented() || (d.attr("aria-expanded", "false"), e.removeClass("open").trigger(a.Event("hidden.bs.dropdown", f)))))
+		}))
+	}
+
+	function d(b) {
+		return this.each(function() {
+			var c = a(this),
+				d = c.data("bs.dropdown");
+			d || c.data("bs.dropdown", d = new g(this)), "string" == typeof b && d[b].call(c)
+		})
+	}
+	var e = ".dropdown-backdrop",
+		f = '[data-toggle="dropdown"]',
+		g = function(b) {
+			a(b).on("click.bs.dropdown", this.toggle)
+		};
+	g.VERSION = "3.3.6", g.prototype.toggle = function(d) {
+		var e = a(this);
+		if(!e.is(".disabled, :disabled")) {
+			var f = b(e),
+				g = f.hasClass("open");
+			if(c(), !g) {
+				"ontouchstart" in document.documentElement && !f.closest(".navbar-nav").length && a(document.createElement("div")).addClass("dropdown-backdrop").insertAfter(a(this)).on("click", c);
+				var h = {
+					relatedTarget: this
+				};
+				if(f.trigger(d = a.Event("show.bs.dropdown", h)), d.isDefaultPrevented()) return;
+				e.trigger("focus").attr("aria-expanded", "true"), f.toggleClass("open").trigger(a.Event("shown.bs.dropdown", h))
+			}
+			return !1
+		}
+	}, g.prototype.keydown = function(c) {
+		if(/(38|40|27|32)/.test(c.which) && !/input|textarea/i.test(c.target.tagName)) {
+			var d = a(this);
+			if(c.preventDefault(), c.stopPropagation(), !d.is(".disabled, :disabled")) {
+				var e = b(d),
+					g = e.hasClass("open");
+				if(!g && 27 != c.which || g && 27 == c.which) return 27 == c.which && e.find(f).trigger("focus"), d.trigger("click");
+				var h = " li:not(.disabled):visible a",
+					i = e.find(".dropdown-menu" + h);
+				if(i.length) {
+					var j = i.index(c.target);
+					38 == c.which && j > 0 && j--, 40 == c.which && j < i.length - 1 && j++, ~j || (j = 0), i.eq(j).trigger("focus")
+				}
+			}
+		}
+	};
+	var h = a.fn.dropdown;
+	a.fn.dropdown = d, a.fn.dropdown.Constructor = g, a.fn.dropdown.noConflict = function() {
+		return a.fn.dropdown = h, this
+	}, a(document).on("click.bs.dropdown.data-api", c).on("click.bs.dropdown.data-api", ".dropdown form", function(a) {
+		a.stopPropagation()
+	}).on("click.bs.dropdown.data-api", f, g.prototype.toggle).on("keydown.bs.dropdown.data-api", f, g.prototype.keydown).on("keydown.bs.dropdown.data-api", ".dropdown-menu", g.prototype.keydown)
+}(jQuery), + function(a) {
+	"use strict";
+
+	function b(b, d) {
+		return this.each(function() {
+			var e = a(this),
+				f = e.data("bs.modal"),
+				g = a.extend({}, c.DEFAULTS, e.data(), "object" == typeof b && b);
+			f || e.data("bs.modal", f = new c(this, g)), "string" == typeof b ? f[b](d) : g.show && f.show(d)
+		})
+	}
+	var c = function(b, c) {
+		this.options = c, this.$body = a(document.body), this.$element = a(b), this.$dialog = this.$element.find(".modal-dialog"), this.$backdrop = null, this.isShown = null, this.originalBodyPad = null, this.scrollbarWidth = 0, this.ignoreBackdropClick = !1, this.options.remote && this.$element.find(".modal-content").load(this.options.remote, a.proxy(function() {
+			this.$element.trigger("loaded.bs.modal")
+		}, this))
+	};
+	c.VERSION = "3.3.6", c.TRANSITION_DURATION = 300, c.BACKDROP_TRANSITION_DURATION = 150, c.DEFAULTS = {
+		backdrop: !0,
+		keyboard: !0,
+		show: !0
+	}, c.prototype.toggle = function(a) {
+		return this.isShown ? this.hide() : this.show(a)
+	}, c.prototype.show = function(b) {
+		var d = this,
+			e = a.Event("show.bs.modal", {
+				relatedTarget: b
+			});
+		this.$element.trigger(e), this.isShown || e.isDefaultPrevented() || (this.isShown = !0, this.checkScrollbar(), this.setScrollbar(), this.$body.addClass("modal-open"), this.escape(), this.resize(), this.$element.on("click.dismiss.bs.modal", '[data-dismiss="modal"]', a.proxy(this.hide, this)), this.$dialog.on("mousedown.dismiss.bs.modal", function() {
+			d.$element.one("mouseup.dismiss.bs.modal", function(b) {
+				a(b.target).is(d.$element) && (d.ignoreBackdropClick = !0)
+			})
+		}), this.backdrop(function() {
+			var e = a.support.transition && d.$element.hasClass("fade");
+			d.$element.parent().length || d.$element.appendTo(d.$body), d.$element.show().scrollTop(0), d.adjustDialog(), e && d.$element[0].offsetWidth, d.$element.addClass("in"), d.enforceFocus();
+			var f = a.Event("shown.bs.modal", {
+				relatedTarget: b
+			});
+			e ? d.$dialog.one("bsTransitionEnd", function() {
+				d.$element.trigger("focus").trigger(f)
+			}).emulateTransitionEnd(c.TRANSITION_DURATION) : d.$element.trigger("focus").trigger(f)
+		}))
+	}, c.prototype.hide = function(b) {
+		b && b.preventDefault(), b = a.Event("hide.bs.modal"), this.$element.trigger(b), this.isShown && !b.isDefaultPrevented() && (this.isShown = !1, this.escape(), this.resize(), a(document).off("focusin.bs.modal"), this.$element.removeClass("in").off("click.dismiss.bs.modal").off("mouseup.dismiss.bs.modal"), this.$dialog.off("mousedown.dismiss.bs.modal"), a.support.transition && this.$element.hasClass("fade") ? this.$element.one("bsTransitionEnd", a.proxy(this.hideModal, this)).emulateTransitionEnd(c.TRANSITION_DURATION) : this.hideModal())
+	}, c.prototype.enforceFocus = function() {
+		a(document).off("focusin.bs.modal").on("focusin.bs.modal", a.proxy(function(a) {
+			this.$element[0] === a.target || this.$element.has(a.target).length || this.$element.trigger("focus")
+		}, this))
+	}, c.prototype.escape = function() {
+		this.isShown && this.options.keyboard ? this.$element.on("keydown.dismiss.bs.modal", a.proxy(function(a) {
+			27 == a.which && this.hide()
+		}, this)) : this.isShown || this.$element.off("keydown.dismiss.bs.modal")
+	}, c.prototype.resize = function() {
+		this.isShown ? a(window).on("resize.bs.modal", a.proxy(this.handleUpdate, this)) : a(window).off("resize.bs.modal")
+	}, c.prototype.hideModal = function() {
+		var a = this;
+		this.$element.hide(), this.backdrop(function() {
+			a.$body.removeClass("modal-open"), a.resetAdjustments(), a.resetScrollbar(), a.$element.trigger("hidden.bs.modal")
+		})
+	}, c.prototype.removeBackdrop = function() {
+		this.$backdrop && this.$backdrop.remove(), this.$backdrop = null
+	}, c.prototype.backdrop = function(b) {
+		var d = this,
+			e = this.$element.hasClass("fade") ? "fade" : "";
+		if(this.isShown && this.options.backdrop) {
+			var f = a.support.transition && e;
+			if(this.$backdrop = a(document.createElement("div")).addClass("modal-backdrop " + e).appendTo(this.$body), this.$element.on("click.dismiss.bs.modal", a.proxy(function(a) {
+					return this.ignoreBackdropClick ? void(this.ignoreBackdropClick = !1) : void(a.target === a.currentTarget && ("static" == this.options.backdrop ? this.$element[0].focus() : this.hide()))
+				}, this)), f && this.$backdrop[0].offsetWidth, this.$backdrop.addClass("in"), !b) return;
+			f ? this.$backdrop.one("bsTransitionEnd", b).emulateTransitionEnd(c.BACKDROP_TRANSITION_DURATION) : b()
+		} else if(!this.isShown && this.$backdrop) {
+			this.$backdrop.removeClass("in");
+			var g = function() {
+				d.removeBackdrop(), b && b()
+			};
+			a.support.transition && this.$element.hasClass("fade") ? this.$backdrop.one("bsTransitionEnd", g).emulateTransitionEnd(c.BACKDROP_TRANSITION_DURATION) : g()
+		} else b && b()
+	}, c.prototype.handleUpdate = function() {
+		this.adjustDialog()
+	}, c.prototype.adjustDialog = function() {
+		var a = this.$element[0].scrollHeight > document.documentElement.clientHeight;
+		this.$element.css({
+			paddingLeft: !this.bodyIsOverflowing && a ? this.scrollbarWidth : "",
+			paddingRight: this.bodyIsOverflowing && !a ? this.scrollbarWidth : ""
+		})
+	}, c.prototype.resetAdjustments = function() {
+		this.$element.css({
+			paddingLeft: "",
+			paddingRight: ""
+		})
+	}, c.prototype.checkScrollbar = function() {
+		var a = window.innerWidth;
+		if(!a) {
+			var b = document.documentElement.getBoundingClientRect();
+			a = b.right - Math.abs(b.left)
+		}
+		this.bodyIsOverflowing = document.body.clientWidth < a, this.scrollbarWidth = this.measureScrollbar()
+	}, c.prototype.setScrollbar = function() {
+		var a = parseInt(this.$body.css("padding-right") || 0, 10);
+		this.originalBodyPad = document.body.style.paddingRight || "", this.bodyIsOverflowing && this.$body.css("padding-right", a + this.scrollbarWidth)
+	}, c.prototype.resetScrollbar = function() {
+		this.$body.css("padding-right", this.originalBodyPad)
+	}, c.prototype.measureScrollbar = function() {
+		var a = document.createElement("div");
+		a.className = "modal-scrollbar-measure", this.$body.append(a);
+		var b = a.offsetWidth - a.clientWidth;
+		return this.$body[0].removeChild(a), b
+	};
+	var d = a.fn.modal;
+	a.fn.modal = b, a.fn.modal.Constructor = c, a.fn.modal.noConflict = function() {
+		return a.fn.modal = d, this
+	}, a(document).on("click.bs.modal.data-api", '[data-toggle="modal"]', function(c) {
+		var d = a(this),
+			e = d.attr("href"),
+			f = a(d.attr("data-target") || e && e.replace(/.*(?=#[^\s]+$)/, "")),
+			g = f.data("bs.modal") ? "toggle" : a.extend({
+				remote: !/#/.test(e) && e
+			}, f.data(), d.data());
+		d.is("a") && c.preventDefault(), f.one("show.bs.modal", function(a) {
+			a.isDefaultPrevented() || f.one("hidden.bs.modal", function() {
+				d.is(":visible") && d.trigger("focus")
+			})
+		}), b.call(f, g, this)
+	})
+}(jQuery), + function(a) {
+	"use strict";
+
+	function b(b) {
+		return this.each(function() {
+			var d = a(this),
+				e = d.data("bs.tooltip"),
+				f = "object" == typeof b && b;
+			(e || !/destroy|hide/.test(b)) && (e || d.data("bs.tooltip", e = new c(this, f)), "string" == typeof b && e[b]())
+		})
+	}
+	var c = function(a, b) {
+		this.type = null, this.options = null, this.enabled = null, this.timeout = null, this.hoverState = null, this.$element = null, this.inState = null, this.init("tooltip", a, b)
+	};
+	c.VERSION = "3.3.6", c.TRANSITION_DURATION = 150, c.DEFAULTS = {
+		animation: !0,
+		placement: "top",
+		selector: !1,
+		template: '<div class="tooltip" role="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>',
+		trigger: "hover focus",
+		title: "",
+		delay: 0,
+		html: !1,
+		container: !1,
+		viewport: {
+			selector: "body",
+			padding: 0
+		}
+	}, c.prototype.init = function(b, c, d) {
+		if(this.enabled = !0, this.type = b, this.$element = a(c), this.options = this.getOptions(d), this.$viewport = this.options.viewport && a(a.isFunction(this.options.viewport) ? this.options.viewport.call(this, this.$element) : this.options.viewport.selector || this.options.viewport), this.inState = {
+				click: !1,
+				hover: !1,
+				focus: !1
+			}, this.$element[0] instanceof document.constructor && !this.options.selector) throw new Error("`selector` option must be specified when initializing " + this.type + " on the window.document object!");
+		for(var e = this.options.trigger.split(" "), f = e.length; f--;) {
+			var g = e[f];
+			if("click" == g) this.$element.on("click." + this.type, this.options.selector, a.proxy(this.toggle, this));
+			else if("manual" != g) {
+				var h = "hover" == g ? "mouseenter" : "focusin",
+					i = "hover" == g ? "mouseleave" : "focusout";
+				this.$element.on(h + "." + this.type, this.options.selector, a.proxy(this.enter, this)), this.$element.on(i + "." + this.type, this.options.selector, a.proxy(this.leave, this))
+			}
+		}
+		this.options.selector ? this._options = a.extend({}, this.options, {
+			trigger: "manual",
+			selector: ""
+		}) : this.fixTitle()
+	}, c.prototype.getDefaults = function() {
+		return c.DEFAULTS
+	}, c.prototype.getOptions = function(b) {
+		return b = a.extend({}, this.getDefaults(), this.$element.data(), b), b.delay && "number" == typeof b.delay && (b.delay = {
+			show: b.delay,
+			hide: b.delay
+		}), b
+	}, c.prototype.getDelegateOptions = function() {
+		var b = {},
+			c = this.getDefaults();
+		return this._options && a.each(this._options, function(a, d) {
+			c[a] != d && (b[a] = d)
+		}), b
+	}, c.prototype.enter = function(b) {
+		var c = b instanceof this.constructor ? b : a(b.currentTarget).data("bs." + this.type);
+		return c || (c = new this.constructor(b.currentTarget, this.getDelegateOptions()), a(b.currentTarget).data("bs." + this.type, c)), b instanceof a.Event && (c.inState["focusin" == b.type ? "focus" : "hover"] = !0), c.tip().hasClass("in") || "in" == c.hoverState ? void(c.hoverState = "in") : (clearTimeout(c.timeout), c.hoverState = "in", c.options.delay && c.options.delay.show ? void(c.timeout = setTimeout(function() {
+			"in" == c.hoverState && c.show()
+		}, c.options.delay.show)) : c.show())
+	}, c.prototype.isInStateTrue = function() {
+		for(var a in this.inState)
+			if(this.inState[a]) return !0;
+		return !1
+	}, c.prototype.leave = function(b) {
+		var c = b instanceof this.constructor ? b : a(b.currentTarget).data("bs." + this.type);
+		return c || (c = new this.constructor(b.currentTarget, this.getDelegateOptions()), a(b.currentTarget).data("bs." + this.type, c)), b instanceof a.Event && (c.inState["focusout" == b.type ? "focus" : "hover"] = !1), c.isInStateTrue() ? void 0 : (clearTimeout(c.timeout), c.hoverState = "out", c.options.delay && c.options.delay.hide ? void(c.timeout = setTimeout(function() {
+			"out" == c.hoverState && c.hide()
+		}, c.options.delay.hide)) : c.hide())
+	}, c.prototype.show = function() {
+		var b = a.Event("show.bs." + this.type);
+		if(this.hasContent() && this.enabled) {
+			this.$element.trigger(b);
+			var d = a.contains(this.$element[0].ownerDocument.documentElement, this.$element[0]);
+			if(b.isDefaultPrevented() || !d) return;
+			var e = this,
+				f = this.tip(),
+				g = this.getUID(this.type);
+			this.setContent(), f.attr("id", g), this.$element.attr("aria-describedby", g), this.options.animation && f.addClass("fade");
+			var h = "function" == typeof this.options.placement ? this.options.placement.call(this, f[0], this.$element[0]) : this.options.placement,
+				i = /\s?auto?\s?/i,
+				j = i.test(h);
+			j && (h = h.replace(i, "") || "top"), f.detach().css({
+				top: 0,
+				left: 0,
+				display: "block"
+			}).addClass(h).data("bs." + this.type, this), this.options.container ? f.appendTo(this.options.container) : f.insertAfter(this.$element), this.$element.trigger("inserted.bs." + this.type);
+			var k = this.getPosition(),
+				l = f[0].offsetWidth,
+				m = f[0].offsetHeight;
+			if(j) {
+				var n = h,
+					o = this.getPosition(this.$viewport);
+				h = "bottom" == h && k.bottom + m > o.bottom ? "top" : "top" == h && k.top - m < o.top ? "bottom" : "right" == h && k.right + l > o.width ? "left" : "left" == h && k.left - l < o.left ? "right" : h, f.removeClass(n).addClass(h)
+			}
+			var p = this.getCalculatedOffset(h, k, l, m);
+			this.applyPlacement(p, h);
+			var q = function() {
+				var a = e.hoverState;
+				e.$element.trigger("shown.bs." + e.type), e.hoverState = null, "out" == a && e.leave(e)
+			};
+			a.support.transition && this.$tip.hasClass("fade") ? f.one("bsTransitionEnd", q).emulateTransitionEnd(c.TRANSITION_DURATION) : q()
+		}
+	}, c.prototype.applyPlacement = function(b, c) {
+		var d = this.tip(),
+			e = d[0].offsetWidth,
+			f = d[0].offsetHeight,
+			g = parseInt(d.css("margin-top"), 10),
+			h = parseInt(d.css("margin-left"), 10);
+		isNaN(g) && (g = 0), isNaN(h) && (h = 0), b.top += g, b.left += h, a.offset.setOffset(d[0], a.extend({
+			using: function(a) {
+				d.css({
+					top: Math.round(a.top),
+					left: Math.round(a.left)
+				})
+			}
+		}, b), 0), d.addClass("in");
+		var i = d[0].offsetWidth,
+			j = d[0].offsetHeight;
+		"top" == c && j != f && (b.top = b.top + f - j);
+		var k = this.getViewportAdjustedDelta(c, b, i, j);
+		k.left ? b.left += k.left : b.top += k.top;
+		var l = /top|bottom/.test(c),
+			m = l ? 2 * k.left - e + i : 2 * k.top - f + j,
+			n = l ? "offsetWidth" : "offsetHeight";
+		d.offset(b), this.replaceArrow(m, d[0][n], l)
+	}, c.prototype.replaceArrow = function(a, b, c) {
+		this.arrow().css(c ? "left" : "top", 50 * (1 - a / b) + "%").css(c ? "top" : "left", "")
+	}, c.prototype.setContent = function() {
+		var a = this.tip(),
+			b = this.getTitle();
+		a.find(".tooltip-inner")[this.options.html ? "html" : "text"](b), a.removeClass("fade in top bottom left right")
+	}, c.prototype.hide = function(b) {
+		function d() {
+			"in" != e.hoverState && f.detach(), e.$element.removeAttr("aria-describedby").trigger("hidden.bs." + e.type), b && b()
+		}
+		var e = this,
+			f = a(this.$tip),
+			g = a.Event("hide.bs." + this.type);
+		return this.$element.trigger(g), g.isDefaultPrevented() ? void 0 : (f.removeClass("in"), a.support.transition && f.hasClass("fade") ? f.one("bsTransitionEnd", d).emulateTransitionEnd(c.TRANSITION_DURATION) : d(), this.hoverState = null, this)
+	}, c.prototype.fixTitle = function() {
+		var a = this.$element;
+		(a.attr("title") || "string" != typeof a.attr("data-original-title")) && a.attr("data-original-title", a.attr("title") || "").attr("title", "")
+	}, c.prototype.hasContent = function() {
+		return this.getTitle()
+	}, c.prototype.getPosition = function(b) {
+		b = b || this.$element;
+		var c = b[0],
+			d = "BODY" == c.tagName,
+			e = c.getBoundingClientRect();
+		null == e.width && (e = a.extend({}, e, {
+			width: e.right - e.left,
+			height: e.bottom - e.top
+		}));
+		var f = d ? {
+				top: 0,
+				left: 0
+			} : b.offset(),
+			g = {
+				scroll: d ? document.documentElement.scrollTop || document.body.scrollTop : b.scrollTop()
+			},
+			h = d ? {
+				width: a(window).width(),
+				height: a(window).height()
+			} : null;
+		return a.extend({}, e, g, h, f)
+	}, c.prototype.getCalculatedOffset = function(a, b, c, d) {
+		return "bottom" == a ? {
+			top: b.top + b.height,
+			left: b.left + b.width / 2 - c / 2
+		} : "top" == a ? {
+			top: b.top - d,
+			left: b.left + b.width / 2 - c / 2
+		} : "left" == a ? {
+			top: b.top + b.height / 2 - d / 2,
+			left: b.left - c
+		} : {
+			top: b.top + b.height / 2 - d / 2,
+			left: b.left + b.width
+		}
+	}, c.prototype.getViewportAdjustedDelta = function(a, b, c, d) {
+		var e = {
+			top: 0,
+			left: 0
+		};
+		if(!this.$viewport) return e;
+		var f = this.options.viewport && this.options.viewport.padding || 0,
+			g = this.getPosition(this.$viewport);
+		if(/right|left/.test(a)) {
+			var h = b.top - f - g.scroll,
+				i = b.top + f - g.scroll + d;
+			h < g.top ? e.top = g.top - h : i > g.top + g.height && (e.top = g.top + g.height - i)
+		} else {
+			var j = b.left - f,
+				k = b.left + f + c;
+			j < g.left ? e.left = g.left - j : k > g.right && (e.left = g.left + g.width - k)
+		}
+		return e
+	}, c.prototype.getTitle = function() {
+		var a, b = this.$element,
+			c = this.options;
+		return a = b.attr("data-original-title") || ("function" == typeof c.title ? c.title.call(b[0]) : c.title)
+	}, c.prototype.getUID = function(a) {
+		do a += ~~(1e6 * Math.random()); while (document.getElementById(a));
+		return a
+	}, c.prototype.tip = function() {
+		if(!this.$tip && (this.$tip = a(this.options.template), 1 != this.$tip.length)) throw new Error(this.type + " `template` option must consist of exactly 1 top-level element!");
+		return this.$tip
+	}, c.prototype.arrow = function() {
+		return this.$arrow = this.$arrow || this.tip().find(".tooltip-arrow")
+	}, c.prototype.enable = function() {
+		this.enabled = !0
+	}, c.prototype.disable = function() {
+		this.enabled = !1
+	}, c.prototype.toggleEnabled = function() {
+		this.enabled = !this.enabled
+	}, c.prototype.toggle = function(b) {
+		var c = this;
+		b && (c = a(b.currentTarget).data("bs." + this.type), c || (c = new this.constructor(b.currentTarget, this.getDelegateOptions()), a(b.currentTarget).data("bs." + this.type, c))), b ? (c.inState.click = !c.inState.click, c.isInStateTrue() ? c.enter(c) : c.leave(c)) : c.tip().hasClass("in") ? c.leave(c) : c.enter(c)
+	}, c.prototype.destroy = function() {
+		var a = this;
+		clearTimeout(this.timeout), this.hide(function() {
+			a.$element.off("." + a.type).removeData("bs." + a.type), a.$tip && a.$tip.detach(), a.$tip = null, a.$arrow = null, a.$viewport = null
+		})
+	};
+	var d = a.fn.tooltip;
+	a.fn.tooltip = b, a.fn.tooltip.Constructor = c, a.fn.tooltip.noConflict = function() {
+		return a.fn.tooltip = d, this
+	}
+}(jQuery), + function(a) {
+	"use strict";
+
+	function b(b) {
+		return this.each(function() {
+			var d = a(this),
+				e = d.data("bs.popover"),
+				f = "object" == typeof b && b;
+			(e || !/destroy|hide/.test(b)) && (e || d.data("bs.popover", e = new c(this, f)), "string" == typeof b && e[b]())
+		})
+	}
+	var c = function(a, b) {
+		this.init("popover", a, b)
+	};
+	if(!a.fn.tooltip) throw new Error("Popover requires tooltip.js");
+	c.VERSION = "3.3.6", c.DEFAULTS = a.extend({}, a.fn.tooltip.Constructor.DEFAULTS, {
+		placement: "right",
+		trigger: "click",
+		content: "",
+		template: '<div class="popover" role="tooltip"><div class="arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>'
+	}), c.prototype = a.extend({}, a.fn.tooltip.Constructor.prototype), c.prototype.constructor = c, c.prototype.getDefaults = function() {
+		return c.DEFAULTS
+	}, c.prototype.setContent = function() {
+		var a = this.tip(),
+			b = this.getTitle(),
+			c = this.getContent();
+		a.find(".popover-title")[this.options.html ? "html" : "text"](b), a.find(".popover-content").children().detach().end()[this.options.html ? "string" == typeof c ? "html" : "append" : "text"](c), a.removeClass("fade top bottom left right in"), a.find(".popover-title").html() || a.find(".popover-title").hide()
+	}, c.prototype.hasContent = function() {
+		return this.getTitle() || this.getContent()
+	}, c.prototype.getContent = function() {
+		var a = this.$element,
+			b = this.options;
+		return a.attr("data-content") || ("function" == typeof b.content ? b.content.call(a[0]) : b.content)
+	}, c.prototype.arrow = function() {
+		return this.$arrow = this.$arrow || this.tip().find(".arrow")
+	};
+	var d = a.fn.popover;
+	a.fn.popover = b, a.fn.popover.Constructor = c, a.fn.popover.noConflict = function() {
+		return a.fn.popover = d, this
+	}
+}(jQuery), + function(a) {
+	"use strict";
+
+	function b(c, d) {
+		this.$body = a(document.body), this.$scrollElement = a(a(c).is(document.body) ? window : c), this.options = a.extend({}, b.DEFAULTS, d), this.selector = (this.options.target || "") + " .nav li > a", this.offsets = [], this.targets = [], this.activeTarget = null, this.scrollHeight = 0, this.$scrollElement.on("scroll.bs.scrollspy", a.proxy(this.process, this)), this.refresh(), this.process()
+	}
+
+	function c(c) {
+		return this.each(function() {
+			var d = a(this),
+				e = d.data("bs.scrollspy"),
+				f = "object" == typeof c && c;
+			e || d.data("bs.scrollspy", e = new b(this, f)), "string" == typeof c && e[c]()
+		})
+	}
+	b.VERSION = "3.3.6", b.DEFAULTS = {
+		offset: 10
+	}, b.prototype.getScrollHeight = function() {
+		return this.$scrollElement[0].scrollHeight || Math.max(this.$body[0].scrollHeight, document.documentElement.scrollHeight)
+	}, b.prototype.refresh = function() {
+		var b = this,
+			c = "offset",
+			d = 0;
+		this.offsets = [], this.targets = [], this.scrollHeight = this.getScrollHeight(), a.isWindow(this.$scrollElement[0]) || (c = "position", d = this.$scrollElement.scrollTop()), this.$body.find(this.selector).map(function() {
+			var b = a(this),
+				e = b.data("target") || b.attr("href"),
+				f = /^#./.test(e) && a(e);
+			return f && f.length && f.is(":visible") && [
+				[f[c]().top + d, e]
+			] || null
+		}).sort(function(a, b) {
+			return a[0] - b[0]
+		}).each(function() {
+			b.offsets.push(this[0]), b.targets.push(this[1])
+		})
+	}, b.prototype.process = function() {
+		var a, b = this.$scrollElement.scrollTop() + this.options.offset,
+			c = this.getScrollHeight(),
+			d = this.options.offset + c - this.$scrollElement.height(),
+			e = this.offsets,
+			f = this.targets,
+			g = this.activeTarget;
+		if(this.scrollHeight != c && this.refresh(), b >= d) return g != (a = f[f.length - 1]) && this.activate(a);
+		if(g && b < e[0]) return this.activeTarget = null, this.clear();
+		for(a = e.length; a--;) g != f[a] && b >= e[a] && (void 0 === e[a + 1] || b < e[a + 1]) && this.activate(f[a])
+	}, b.prototype.activate = function(b) {
+		this.activeTarget = b, this.clear();
+		var c = this.selector + '[data-target="' + b + '"],' + this.selector + '[href="' + b + '"]',
+			d = a(c).parents("li").addClass("active");
+		d.parent(".dropdown-menu").length && (d = d.closest("li.dropdown").addClass("active")), d.trigger("activate.bs.scrollspy")
+	}, b.prototype.clear = function() {
+		a(this.selector).parentsUntil(this.options.target, ".active").removeClass("active")
+	};
+	var d = a.fn.scrollspy;
+	a.fn.scrollspy = c, a.fn.scrollspy.Constructor = b, a.fn.scrollspy.noConflict = function() {
+		return a.fn.scrollspy = d, this
+	}, a(window).on("load.bs.scrollspy.data-api", function() {
+		a('[data-spy="scroll"]').each(function() {
+			var b = a(this);
+			c.call(b, b.data())
+		})
+	})
+}(jQuery), + function(a) {
+	"use strict";
+
+	function b(b) {
+		return this.each(function() {
+			var d = a(this),
+				e = d.data("bs.tab");
+			e || d.data("bs.tab", e = new c(this)), "string" == typeof b && e[b]()
+		})
+	}
+	var c = function(b) {
+		this.element = a(b)
+	};
+	c.VERSION = "3.3.6", c.TRANSITION_DURATION = 150, c.prototype.show = function() {
+		var b = this.element,
+			c = b.closest("ul:not(.dropdown-menu)"),
+			d = b.data("target");
+		if(d || (d = b.attr("href"), d = d && d.replace(/.*(?=#[^\s]*$)/, "")), !b.parent("li").hasClass("active")) {
+			var e = c.find(".active:last a"),
+				f = a.Event("hide.bs.tab", {
+					relatedTarget: b[0]
+				}),
+				g = a.Event("show.bs.tab", {
+					relatedTarget: e[0]
+				});
+			if(e.trigger(f), b.trigger(g), !g.isDefaultPrevented() && !f.isDefaultPrevented()) {
+				var h = a(d);
+				this.activate(b.closest("li"), c), this.activate(h, h.parent(), function() {
+					e.trigger({
+						type: "hidden.bs.tab",
+						relatedTarget: b[0]
+					}), b.trigger({
+						type: "shown.bs.tab",
+						relatedTarget: e[0]
+					})
+				})
+			}
+		}
+	}, c.prototype.activate = function(b, d, e) {
+		function f() {
+			g.removeClass("active").find("> .dropdown-menu > .active").removeClass("active").end().find('[data-toggle="tab"]').attr("aria-expanded", !1), b.addClass("active").find('[data-toggle="tab"]').attr("aria-expanded", !0), h ? (b[0].offsetWidth, b.addClass("in")) : b.removeClass("fade"), b.parent(".dropdown-menu").length && b.closest("li.dropdown").addClass("active").end().find('[data-toggle="tab"]').attr("aria-expanded", !0), e && e()
+		}
+		var g = d.find("> .active"),
+			h = e && a.support.transition && (g.length && g.hasClass("fade") || !!d.find("> .fade").length);
+		g.length && h ? g.one("bsTransitionEnd", f).emulateTransitionEnd(c.TRANSITION_DURATION) : f(), g.removeClass("in")
+	};
+	var d = a.fn.tab;
+	a.fn.tab = b, a.fn.tab.Constructor = c, a.fn.tab.noConflict = function() {
+		return a.fn.tab = d, this
+	};
+	var e = function(c) {
+		c.preventDefault(), b.call(a(this), "show")
+	};
+	a(document).on("click.bs.tab.data-api", '[data-toggle="tab"]', e).on("click.bs.tab.data-api", '[data-toggle="pill"]', e)
+}(jQuery), + function(a) {
+	"use strict";
+
+	function b(b) {
+		return this.each(function() {
+			var d = a(this),
+				e = d.data("bs.affix"),
+				f = "object" == typeof b && b;
+			e || d.data("bs.affix", e = new c(this, f)), "string" == typeof b && e[b]()
+		})
+	}
+	var c = function(b, d) {
+		this.options = a.extend({}, c.DEFAULTS, d), this.$target = a(this.options.target).on("scroll.bs.affix.data-api", a.proxy(this.checkPosition, this)).on("click.bs.affix.data-api", a.proxy(this.checkPositionWithEventLoop, this)), this.$element = a(b), this.affixed = null, this.unpin = null, this.pinnedOffset = null, this.checkPosition()
+	};
+	c.VERSION = "3.3.6", c.RESET = "affix affix-top affix-bottom", c.DEFAULTS = {
+		offset: 0,
+		target: window
+	}, c.prototype.getState = function(a, b, c, d) {
+		var e = this.$target.scrollTop(),
+			f = this.$element.offset(),
+			g = this.$target.height();
+		if(null != c && "top" == this.affixed) return c > e ? "top" : !1;
+		if("bottom" == this.affixed) return null != c ? e + this.unpin <= f.top ? !1 : "bottom" : a - d >= e + g ? !1 : "bottom";
+		var h = null == this.affixed,
+			i = h ? e : f.top,
+			j = h ? g : b;
+		return null != c && c >= e ? "top" : null != d && i + j >= a - d ? "bottom" : !1
+	}, c.prototype.getPinnedOffset = function() {
+		if(this.pinnedOffset) return this.pinnedOffset;
+		this.$element.removeClass(c.RESET).addClass("affix");
+		var a = this.$target.scrollTop(),
+			b = this.$element.offset();
+		return this.pinnedOffset = b.top - a
+	}, c.prototype.checkPositionWithEventLoop = function() {
+		setTimeout(a.proxy(this.checkPosition, this), 1)
+	}, c.prototype.checkPosition = function() {
+		if(this.$element.is(":visible")) {
+			var b = this.$element.height(),
+				d = this.options.offset,
+				e = d.top,
+				f = d.bottom,
+				g = Math.max(a(document).height(), a(document.body).height());
+			"object" != typeof d && (f = e = d), "function" == typeof e && (e = d.top(this.$element)), "function" == typeof f && (f = d.bottom(this.$element));
+			var h = this.getState(g, b, e, f);
+			if(this.affixed != h) {
+				null != this.unpin && this.$element.css("top", "");
+				var i = "affix" + (h ? "-" + h : ""),
+					j = a.Event(i + ".bs.affix");
+				if(this.$element.trigger(j), j.isDefaultPrevented()) return;
+				this.affixed = h, this.unpin = "bottom" == h ? this.getPinnedOffset() : null, this.$element.removeClass(c.RESET).addClass(i).trigger(i.replace("affix", "affixed") + ".bs.affix")
+			}
+			"bottom" == h && this.$element.offset({
+				top: g - b - f
+			})
+		}
+	};
+	var d = a.fn.affix;
+	a.fn.affix = b, a.fn.affix.Constructor = c, a.fn.affix.noConflict = function() {
+		return a.fn.affix = d, this
+	}, a(window).on("load", function() {
+		a('[data-spy="affix"]').each(function() {
+			var c = a(this),
+				d = c.data();
+			d.offset = d.offset || {}, null != d.offsetBottom && (d.offset.bottom = d.offsetBottom), null != d.offsetTop && (d.offset.top = d.offsetTop), b.call(c, d)
+		})
+	})
+}(jQuery);
+
+/*
+ HTML5 Shiv v3.7.0 | @afarkas @jdalton @jon_neal @rem | MIT/GPL2 Licensed
+*/
+(function(l, f) {
+	function m() {
+		var a = e.elements;
+		return "string" == typeof a ? a.split(" ") : a
+	}
+
+	function i(a) {
+		var b = n[a[o]];
+		b || (b = {}, h++, a[o] = h, n[h] = b);
+		return b
+	}
+
+	function p(a, b, c) {
+		b || (b = f);
+		if(g) return b.createElement(a);
+		c || (c = i(b));
+		b = c.cache[a] ? c.cache[a].cloneNode() : r.test(a) ? (c.cache[a] = c.createElem(a)).cloneNode() : c.createElem(a);
+		return b.canHaveChildren && !s.test(a) ? c.frag.appendChild(b) : b
+	}
+
+	function t(a, b) {
+		if(!b.cache) b.cache = {}, b.createElem = a.createElement, b.createFrag = a.createDocumentFragment, b.frag = b.createFrag();
+		a.createElement = function(c) {
+			return !e.shivMethods ? b.createElem(c) : p(c, a, b)
+		};
+		a.createDocumentFragment = Function("h,f", "return function(){var n=f.cloneNode(),c=n.createElement;h.shivMethods&&(" + m().join().replace(/[\w\-]+/g, function(a) {
+			b.createElem(a);
+			b.frag.createElement(a);
+			return 'c("' + a + '")'
+		}) + ");return n}")(e, b.frag)
+	}
+
+	function q(a) {
+		a || (a = f);
+		var b = i(a);
+		if(e.shivCSS && !j && !b.hasCSS) {
+			var c, d = a;
+			c = d.createElement("p");
+			d = d.getElementsByTagName("head")[0] || d.documentElement;
+			c.innerHTML = "x<style>article,aside,dialog,figcaption,figure,footer,header,hgroup,main,nav,section{display:block}mark{background:#FF0;color:#000}template{display:none}</style>";
+			c = d.insertBefore(c.lastChild, d.firstChild);
+			b.hasCSS = !!c
+		}
+		g || t(a, b);
+		return a
+	}
+	var k = l.html5 || {},
+		s = /^<|^(?:button|map|select|textarea|object|iframe|option|optgroup)$/i,
+		r = /^(?:a|b|code|div|fieldset|h1|h2|h3|h4|h5|h6|i|label|li|ol|p|q|span|strong|style|table|tbody|td|th|tr|ul)$/i,
+		j, o = "_html5shiv",
+		h = 0,
+		n = {},
+		g;
+	(function() {
+		try {
+			var a = f.createElement("a");
+			a.innerHTML = "<xyz></xyz>";
+			j = "hidden" in a;
+			var b;
+			if(!(b = 1 == a.childNodes.length)) {
+				f.createElement("a");
+				var c = f.createDocumentFragment();
+				b = "undefined" == typeof c.cloneNode ||
+					"undefined" == typeof c.createDocumentFragment || "undefined" == typeof c.createElement
+			}
+			g = b
+		} catch(d) {
+			g = j = !0
+		}
+	})();
+	var e = {
+		elements: k.elements || "abbr article aside audio bdi canvas data datalist details dialog figcaption figure footer header hgroup main mark meter nav output progress section summary template time video",
+		version: "3.7.0",
+		shivCSS: !1 !== k.shivCSS,
+		supportsUnknownElements: g,
+		shivMethods: !1 !== k.shivMethods,
+		type: "default",
+		shivDocument: q,
+		createElement: p,
+		createDocumentFragment: function(a, b) {
+			a || (a = f);
+			if(g) return a.createDocumentFragment();
+			for(var b = b || i(a), c = b.frag.cloneNode(), d = 0, e = m(), h = e.length; d < h; d++) c.createElement(e[d]);
+			return c
+		}
+	};
+	l.html5 = e;
+	q(f)
+})(this, document);
+
+/*!
+ * @fileOverview TouchSwipe - jQuery Plugin
+ * @version 1.6.18
+ *
+ * @author Matt Bryson http://www.github.com/mattbryson
+ * @see https://github.com/mattbryson/TouchSwipe-Jquery-Plugin
+ * @see http://labs.rampinteractive.co.uk/touchSwipe/
+ * @see http://plugins.jquery.com/project/touchSwipe
+ * @license
+ * Copyright (c) 2010-2015 Matt Bryson
+ * Dual licensed under the MIT or GPL Version 2 licenses.
+ *
+ */
+! function(factory) {
+	"function" == typeof define && define.amd && define.amd.jQuery ? define(["jquery"], factory) : factory("undefined" != typeof module && module.exports ? require("jquery") : jQuery)
+}(function($) {
+	"use strict";
+
+	function init(options) {
+		return !options || void 0 !== options.allowPageScroll || void 0 === options.swipe && void 0 === options.swipeStatus || (options.allowPageScroll = NONE), void 0 !== options.click && void 0 === options.tap && (options.tap = options.click), options || (options = {}), options = $.extend({}, $.fn.swipe.defaults, options), this.each(function() {
+			var $this = $(this),
+				plugin = $this.data(PLUGIN_NS);
+			plugin || (plugin = new TouchSwipe(this, options), $this.data(PLUGIN_NS, plugin))
+		})
+	}
+
+	function TouchSwipe(element, options) {
+		function touchStart(jqEvent) {
+			if(!(getTouchInProgress() || $(jqEvent.target).closest(options.excludedElements, $element).length > 0)) {
+				var event = jqEvent.originalEvent ? jqEvent.originalEvent : jqEvent;
+				if(!event.pointerType || "mouse" != event.pointerType || 0 != options.fallbackToMouseEvents) {
+					var ret, touches = event.touches,
+						evt = touches ? touches[0] : event;
+					return phase = PHASE_START, touches ? fingerCount = touches.length : options.preventDefaultEvents !== !1 && jqEvent.preventDefault(), distance = 0, direction = null, currentDirection = null, pinchDirection = null, duration = 0, startTouchesDistance = 0, endTouchesDistance = 0, pinchZoom = 1, pinchDistance = 0, maximumsMap = createMaximumsData(), cancelMultiFingerRelease(), createFingerData(0, evt), !touches || fingerCount === options.fingers || options.fingers === ALL_FINGERS || hasPinches() ? (startTime = getTimeStamp(), 2 == fingerCount && (createFingerData(1, touches[1]), startTouchesDistance = endTouchesDistance = calculateTouchesDistance(fingerData[0].start, fingerData[1].start)), (options.swipeStatus || options.pinchStatus) && (ret = triggerHandler(event, phase))) : ret = !1, ret === !1 ? (phase = PHASE_CANCEL, triggerHandler(event, phase), ret) : (options.hold && (holdTimeout = setTimeout($.proxy(function() {
+						$element.trigger("hold", [event.target]), options.hold && (ret = options.hold.call($element, event, event.target))
+					}, this), options.longTapThreshold)), setTouchInProgress(!0), null)
+				}
+			}
+		}
+
+		function touchMove(jqEvent) {
+			var event = jqEvent.originalEvent ? jqEvent.originalEvent : jqEvent;
+			if(phase !== PHASE_END && phase !== PHASE_CANCEL && !inMultiFingerRelease()) {
+				var ret, touches = event.touches,
+					evt = touches ? touches[0] : event,
+					currentFinger = updateFingerData(evt);
+				if(endTime = getTimeStamp(), touches && (fingerCount = touches.length), options.hold && clearTimeout(holdTimeout), phase = PHASE_MOVE, 2 == fingerCount && (0 == startTouchesDistance ? (createFingerData(1, touches[1]), startTouchesDistance = endTouchesDistance = calculateTouchesDistance(fingerData[0].start, fingerData[1].start)) : (updateFingerData(touches[1]), endTouchesDistance = calculateTouchesDistance(fingerData[0].end, fingerData[1].end), pinchDirection = calculatePinchDirection(fingerData[0].end, fingerData[1].end)), pinchZoom = calculatePinchZoom(startTouchesDistance, endTouchesDistance), pinchDistance = Math.abs(startTouchesDistance - endTouchesDistance)), fingerCount === options.fingers || options.fingers === ALL_FINGERS || !touches || hasPinches()) {
+					if(direction = calculateDirection(currentFinger.start, currentFinger.end), currentDirection = calculateDirection(currentFinger.last, currentFinger.end), validateDefaultEvent(jqEvent, currentDirection), distance = calculateDistance(currentFinger.start, currentFinger.end), duration = calculateDuration(), setMaxDistance(direction, distance), ret = triggerHandler(event, phase), !options.triggerOnTouchEnd || options.triggerOnTouchLeave) {
+						var inBounds = !0;
+						if(options.triggerOnTouchLeave) {
+							var bounds = getbounds(this);
+							inBounds = isInBounds(currentFinger.end, bounds)
+						}!options.triggerOnTouchEnd && inBounds ? phase = getNextPhase(PHASE_MOVE) : options.triggerOnTouchLeave && !inBounds && (phase = getNextPhase(PHASE_END)), phase != PHASE_CANCEL && phase != PHASE_END || triggerHandler(event, phase)
+					}
+				} else phase = PHASE_CANCEL, triggerHandler(event, phase);
+				ret === !1 && (phase = PHASE_CANCEL, triggerHandler(event, phase))
+			}
+		}
+
+		function touchEnd(jqEvent) {
+			var event = jqEvent.originalEvent ? jqEvent.originalEvent : jqEvent,
+				touches = event.touches;
+			if(touches) {
+				if(touches.length && !inMultiFingerRelease()) return startMultiFingerRelease(event), !0;
+				if(touches.length && inMultiFingerRelease()) return !0
+			}
+			return inMultiFingerRelease() && (fingerCount = fingerCountAtRelease), endTime = getTimeStamp(), duration = calculateDuration(), didSwipeBackToCancel() || !validateSwipeDistance() ? (phase = PHASE_CANCEL, triggerHandler(event, phase)) : options.triggerOnTouchEnd || options.triggerOnTouchEnd === !1 && phase === PHASE_MOVE ? (options.preventDefaultEvents !== !1 && jqEvent.cancelable !== !1 && jqEvent.preventDefault(), phase = PHASE_END, triggerHandler(event, phase)) : !options.triggerOnTouchEnd && hasTap() ? (phase = PHASE_END, triggerHandlerForGesture(event, phase, TAP)) : phase === PHASE_MOVE && (phase = PHASE_CANCEL, triggerHandler(event, phase)), setTouchInProgress(!1), null
+		}
+
+		function touchCancel() {
+			fingerCount = 0, endTime = 0, startTime = 0, startTouchesDistance = 0, endTouchesDistance = 0, pinchZoom = 1, cancelMultiFingerRelease(), setTouchInProgress(!1)
+		}
+
+		function touchLeave(jqEvent) {
+			var event = jqEvent.originalEvent ? jqEvent.originalEvent : jqEvent;
+			options.triggerOnTouchLeave && (phase = getNextPhase(PHASE_END), triggerHandler(event, phase))
+		}
+
+		function removeListeners() {
+			$element.unbind(START_EV, touchStart), $element.unbind(CANCEL_EV, touchCancel), $element.unbind(MOVE_EV, touchMove), $element.unbind(END_EV, touchEnd), LEAVE_EV && $element.unbind(LEAVE_EV, touchLeave), setTouchInProgress(!1)
+		}
+
+		function getNextPhase(currentPhase) {
+			var nextPhase = currentPhase,
+				validTime = validateSwipeTime(),
+				validDistance = validateSwipeDistance(),
+				didCancel = didSwipeBackToCancel();
+			return !validTime || didCancel ? nextPhase = PHASE_CANCEL : !validDistance || currentPhase != PHASE_MOVE || options.triggerOnTouchEnd && !options.triggerOnTouchLeave ? !validDistance && currentPhase == PHASE_END && options.triggerOnTouchLeave && (nextPhase = PHASE_CANCEL) : nextPhase = PHASE_END, nextPhase
+		}
+
+		function triggerHandler(event, phase) {
+			var ret, touches = event.touches;
+			return(didSwipe() || hasSwipes()) && (ret = triggerHandlerForGesture(event, phase, SWIPE)), (didPinch() || hasPinches()) && ret !== !1 && (ret = triggerHandlerForGesture(event, phase, PINCH)), didDoubleTap() && ret !== !1 ? ret = triggerHandlerForGesture(event, phase, DOUBLE_TAP) : didLongTap() && ret !== !1 ? ret = triggerHandlerForGesture(event, phase, LONG_TAP) : didTap() && ret !== !1 && (ret = triggerHandlerForGesture(event, phase, TAP)), phase === PHASE_CANCEL && touchCancel(event), phase === PHASE_END && (touches ? touches.length || touchCancel(event) : touchCancel(event)), ret
+		}
+
+		function triggerHandlerForGesture(event, phase, gesture) {
+			var ret;
+			if(gesture == SWIPE) {
+				if($element.trigger("swipeStatus", [phase, direction || null, distance || 0, duration || 0, fingerCount, fingerData, currentDirection]), options.swipeStatus && (ret = options.swipeStatus.call($element, event, phase, direction || null, distance || 0, duration || 0, fingerCount, fingerData, currentDirection), ret === !1)) return !1;
+				if(phase == PHASE_END && validateSwipe()) {
+					if(clearTimeout(singleTapTimeout), clearTimeout(holdTimeout), $element.trigger("swipe", [direction, distance, duration, fingerCount, fingerData, currentDirection]), options.swipe && (ret = options.swipe.call($element, event, direction, distance, duration, fingerCount, fingerData, currentDirection), ret === !1)) return !1;
+					switch(direction) {
+						case LEFT:
+							$element.trigger("swipeLeft", [direction, distance, duration, fingerCount, fingerData, currentDirection]), options.swipeLeft && (ret = options.swipeLeft.call($element, event, direction, distance, duration, fingerCount, fingerData, currentDirection));
+							break;
+						case RIGHT:
+							$element.trigger("swipeRight", [direction, distance, duration, fingerCount, fingerData, currentDirection]), options.swipeRight && (ret = options.swipeRight.call($element, event, direction, distance, duration, fingerCount, fingerData, currentDirection));
+							break;
+						case UP:
+							$element.trigger("swipeUp", [direction, distance, duration, fingerCount, fingerData, currentDirection]), options.swipeUp && (ret = options.swipeUp.call($element, event, direction, distance, duration, fingerCount, fingerData, currentDirection));
+							break;
+						case DOWN:
+							$element.trigger("swipeDown", [direction, distance, duration, fingerCount, fingerData, currentDirection]), options.swipeDown && (ret = options.swipeDown.call($element, event, direction, distance, duration, fingerCount, fingerData, currentDirection))
+					}
+				}
+			}
+			if(gesture == PINCH) {
+				if($element.trigger("pinchStatus", [phase, pinchDirection || null, pinchDistance || 0, duration || 0, fingerCount, pinchZoom, fingerData]), options.pinchStatus && (ret = options.pinchStatus.call($element, event, phase, pinchDirection || null, pinchDistance || 0, duration || 0, fingerCount, pinchZoom, fingerData), ret === !1)) return !1;
+				if(phase == PHASE_END && validatePinch()) switch(pinchDirection) {
+					case IN:
+						$element.trigger("pinchIn", [pinchDirection || null, pinchDistance || 0, duration || 0, fingerCount, pinchZoom, fingerData]), options.pinchIn && (ret = options.pinchIn.call($element, event, pinchDirection || null, pinchDistance || 0, duration || 0, fingerCount, pinchZoom, fingerData));
+						break;
+					case OUT:
+						$element.trigger("pinchOut", [pinchDirection || null, pinchDistance || 0, duration || 0, fingerCount, pinchZoom, fingerData]), options.pinchOut && (ret = options.pinchOut.call($element, event, pinchDirection || null, pinchDistance || 0, duration || 0, fingerCount, pinchZoom, fingerData))
+				}
+			}
+			return gesture == TAP ? phase !== PHASE_CANCEL && phase !== PHASE_END || (clearTimeout(singleTapTimeout), clearTimeout(holdTimeout), hasDoubleTap() && !inDoubleTap() ? (doubleTapStartTime = getTimeStamp(), singleTapTimeout = setTimeout($.proxy(function() {
+				doubleTapStartTime = null, $element.trigger("tap", [event.target]), options.tap && (ret = options.tap.call($element, event, event.target))
+			}, this), options.doubleTapThreshold)) : (doubleTapStartTime = null, $element.trigger("tap", [event.target]), options.tap && (ret = options.tap.call($element, event, event.target)))) : gesture == DOUBLE_TAP ? phase !== PHASE_CANCEL && phase !== PHASE_END || (clearTimeout(singleTapTimeout), clearTimeout(holdTimeout), doubleTapStartTime = null, $element.trigger("doubletap", [event.target]), options.doubleTap && (ret = options.doubleTap.call($element, event, event.target))) : gesture == LONG_TAP && (phase !== PHASE_CANCEL && phase !== PHASE_END || (clearTimeout(singleTapTimeout), doubleTapStartTime = null, $element.trigger("longtap", [event.target]), options.longTap && (ret = options.longTap.call($element, event, event.target)))), ret
+		}
+
+		function validateSwipeDistance() {
+			var valid = !0;
+			return null !== options.threshold && (valid = distance >= options.threshold), valid
+		}
+
+		function didSwipeBackToCancel() {
+			var cancelled = !1;
+			return null !== options.cancelThreshold && null !== direction && (cancelled = getMaxDistance(direction) - distance >= options.cancelThreshold), cancelled
+		}
+
+		function validatePinchDistance() {
+			return null === options.pinchThreshold || pinchDistance >= options.pinchThreshold
+		}
+
+		function validateSwipeTime() {
+			var result;
+			return result = !options.maxTimeThreshold || !(duration >= options.maxTimeThreshold)
+		}
+
+		function validateDefaultEvent(jqEvent, direction) {
+			if(options.preventDefaultEvents !== !1)
+				if(options.allowPageScroll === NONE) jqEvent.preventDefault();
+				else {
+					var auto = options.allowPageScroll === AUTO;
+					switch(direction) {
+						case LEFT:
+							(options.swipeLeft && auto || !auto && options.allowPageScroll != HORIZONTAL) && jqEvent.preventDefault();
+							break;
+						case RIGHT:
+							(options.swipeRight && auto || !auto && options.allowPageScroll != HORIZONTAL) && jqEvent.preventDefault();
+							break;
+						case UP:
+							(options.swipeUp && auto || !auto && options.allowPageScroll != VERTICAL) && jqEvent.preventDefault();
+							break;
+						case DOWN:
+							(options.swipeDown && auto || !auto && options.allowPageScroll != VERTICAL) && jqEvent.preventDefault();
+							break;
+						case NONE:
+					}
+				}
+		}
+
+		function validatePinch() {
+			var hasCorrectFingerCount = validateFingers(),
+				hasEndPoint = validateEndPoint(),
+				hasCorrectDistance = validatePinchDistance();
+			return hasCorrectFingerCount && hasEndPoint && hasCorrectDistance
+		}
+
+		function hasPinches() {
+			return !!(options.pinchStatus || options.pinchIn || options.pinchOut)
+		}
+
+		function didPinch() {
+			return !(!validatePinch() || !hasPinches())
+		}
+
+		function validateSwipe() {
+			var hasValidTime = validateSwipeTime(),
+				hasValidDistance = validateSwipeDistance(),
+				hasCorrectFingerCount = validateFingers(),
+				hasEndPoint = validateEndPoint(),
+				didCancel = didSwipeBackToCancel(),
+				valid = !didCancel && hasEndPoint && hasCorrectFingerCount && hasValidDistance && hasValidTime;
+			return valid
+		}
+
+		function hasSwipes() {
+			return !!(options.swipe || options.swipeStatus || options.swipeLeft || options.swipeRight || options.swipeUp || options.swipeDown)
+		}
+
+		function didSwipe() {
+			return !(!validateSwipe() || !hasSwipes())
+		}
+
+		function validateFingers() {
+			return fingerCount === options.fingers || options.fingers === ALL_FINGERS || !SUPPORTS_TOUCH
+		}
+
+		function validateEndPoint() {
+			return 0 !== fingerData[0].end.x
+		}
+
+		function hasTap() {
+			return !!options.tap
+		}
+
+		function hasDoubleTap() {
+			return !!options.doubleTap
+		}
+
+		function hasLongTap() {
+			return !!options.longTap
+		}
+
+		function validateDoubleTap() {
+			if(null == doubleTapStartTime) return !1;
+			var now = getTimeStamp();
+			return hasDoubleTap() && now - doubleTapStartTime <= options.doubleTapThreshold
+		}
+
+		function inDoubleTap() {
+			return validateDoubleTap()
+		}
+
+		function validateTap() {
+			return(1 === fingerCount || !SUPPORTS_TOUCH) && (isNaN(distance) || distance < options.threshold)
+		}
+
+		function validateLongTap() {
+			return duration > options.longTapThreshold && distance < DOUBLE_TAP_THRESHOLD
+		}
+
+		function didTap() {
+			return !(!validateTap() || !hasTap())
+		}
+
+		function didDoubleTap() {
+			return !(!validateDoubleTap() || !hasDoubleTap())
+		}
+
+		function didLongTap() {
+			return !(!validateLongTap() || !hasLongTap())
+		}
+
+		function startMultiFingerRelease(event) {
+			previousTouchEndTime = getTimeStamp(), fingerCountAtRelease = event.touches.length + 1
+		}
+
+		function cancelMultiFingerRelease() {
+			previousTouchEndTime = 0, fingerCountAtRelease = 0
+		}
+
+		function inMultiFingerRelease() {
+			var withinThreshold = !1;
+			if(previousTouchEndTime) {
+				var diff = getTimeStamp() - previousTouchEndTime;
+				diff <= options.fingerReleaseThreshold && (withinThreshold = !0)
+			}
+			return withinThreshold
+		}
+
+		function getTouchInProgress() {
+			return !($element.data(PLUGIN_NS + "_intouch") !== !0)
+		}
+
+		function setTouchInProgress(val) {
+			$element && (val === !0 ? ($element.bind(MOVE_EV, touchMove), $element.bind(END_EV, touchEnd), LEAVE_EV && $element.bind(LEAVE_EV, touchLeave)) : ($element.unbind(MOVE_EV, touchMove, !1), $element.unbind(END_EV, touchEnd, !1), LEAVE_EV && $element.unbind(LEAVE_EV, touchLeave, !1)), $element.data(PLUGIN_NS + "_intouch", val === !0))
+		}
+
+		function createFingerData(id, evt) {
+			var f = {
+				start: {
+					x: 0,
+					y: 0
+				},
+				last: {
+					x: 0,
+					y: 0
+				},
+				end: {
+					x: 0,
+					y: 0
+				}
+			};
+			return f.start.x = f.last.x = f.end.x = evt.pageX || evt.clientX, f.start.y = f.last.y = f.end.y = evt.pageY || evt.clientY, fingerData[id] = f, f
+		}
+
+		function updateFingerData(evt) {
+			var id = void 0 !== evt.identifier ? evt.identifier : 0,
+				f = getFingerData(id);
+			return null === f && (f = createFingerData(id, evt)), f.last.x = f.end.x, f.last.y = f.end.y, f.end.x = evt.pageX || evt.clientX, f.end.y = evt.pageY || evt.clientY, f
+		}
+
+		function getFingerData(id) {
+			return fingerData[id] || null
+		}
+
+		function setMaxDistance(direction, distance) {
+			direction != NONE && (distance = Math.max(distance, getMaxDistance(direction)), maximumsMap[direction].distance = distance)
+		}
+
+		function getMaxDistance(direction) {
+			if(maximumsMap[direction]) return maximumsMap[direction].distance
+		}
+
+		function createMaximumsData() {
+			var maxData = {};
+			return maxData[LEFT] = createMaximumVO(LEFT), maxData[RIGHT] = createMaximumVO(RIGHT), maxData[UP] = createMaximumVO(UP), maxData[DOWN] = createMaximumVO(DOWN), maxData
+		}
+
+		function createMaximumVO(dir) {
+			return {
+				direction: dir,
+				distance: 0
+			}
+		}
+
+		function calculateDuration() {
+			return endTime - startTime
+		}
+
+		function calculateTouchesDistance(startPoint, endPoint) {
+			var diffX = Math.abs(startPoint.x - endPoint.x),
+				diffY = Math.abs(startPoint.y - endPoint.y);
+			return Math.round(Math.sqrt(diffX * diffX + diffY * diffY))
+		}
+
+		function calculatePinchZoom(startDistance, endDistance) {
+			var percent = endDistance / startDistance * 1;
+			return percent.toFixed(2)
+		}
+
+		function calculatePinchDirection() {
+			return pinchZoom < 1 ? OUT : IN
+		}
+
+		function calculateDistance(startPoint, endPoint) {
+			return Math.round(Math.sqrt(Math.pow(endPoint.x - startPoint.x, 2) + Math.pow(endPoint.y - startPoint.y, 2)))
+		}
+
+		function calculateAngle(startPoint, endPoint) {
+			var x = startPoint.x - endPoint.x,
+				y = endPoint.y - startPoint.y,
+				r = Math.atan2(y, x),
+				angle = Math.round(180 * r / Math.PI);
+			return angle < 0 && (angle = 360 - Math.abs(angle)), angle
+		}
+
+		function calculateDirection(startPoint, endPoint) {
+			if(comparePoints(startPoint, endPoint)) return NONE;
+			var angle = calculateAngle(startPoint, endPoint);
+			return angle <= 45 && angle >= 0 ? LEFT : angle <= 360 && angle >= 315 ? LEFT : angle >= 135 && angle <= 225 ? RIGHT : angle > 45 && angle < 135 ? DOWN : UP
+		}
+
+		function getTimeStamp() {
+			var now = new Date;
+			return now.getTime()
+		}
+
+		function getbounds(el) {
+			el = $(el);
+			var offset = el.offset(),
+				bounds = {
+					left: offset.left,
+					right: offset.left + el.outerWidth(),
+					top: offset.top,
+					bottom: offset.top + el.outerHeight()
+				};
+			return bounds
+		}
+
+		function isInBounds(point, bounds) {
+			return point.x > bounds.left && point.x < bounds.right && point.y > bounds.top && point.y < bounds.bottom
+		}
+
+		function comparePoints(pointA, pointB) {
+			return pointA.x == pointB.x && pointA.y == pointB.y
+		}
+		var options = $.extend({}, options),
+			useTouchEvents = SUPPORTS_TOUCH || SUPPORTS_POINTER || !options.fallbackToMouseEvents,
+			START_EV = useTouchEvents ? SUPPORTS_POINTER ? SUPPORTS_POINTER_IE10 ? "MSPointerDown" : "pointerdown" : "touchstart" : "mousedown",
+			MOVE_EV = useTouchEvents ? SUPPORTS_POINTER ? SUPPORTS_POINTER_IE10 ? "MSPointerMove" : "pointermove" : "touchmove" : "mousemove",
+			END_EV = useTouchEvents ? SUPPORTS_POINTER ? SUPPORTS_POINTER_IE10 ? "MSPointerUp" : "pointerup" : "touchend" : "mouseup",
+			LEAVE_EV = useTouchEvents ? SUPPORTS_POINTER ? "mouseleave" : null : "mouseleave",
+			CANCEL_EV = SUPPORTS_POINTER ? SUPPORTS_POINTER_IE10 ? "MSPointerCancel" : "pointercancel" : "touchcancel",
+			distance = 0,
+			direction = null,
+			currentDirection = null,
+			duration = 0,
+			startTouchesDistance = 0,
+			endTouchesDistance = 0,
+			pinchZoom = 1,
+			pinchDistance = 0,
+			pinchDirection = 0,
+			maximumsMap = null,
+			$element = $(element),
+			phase = "start",
+			fingerCount = 0,
+			fingerData = {},
+			startTime = 0,
+			endTime = 0,
+			previousTouchEndTime = 0,
+			fingerCountAtRelease = 0,
+			doubleTapStartTime = 0,
+			singleTapTimeout = null,
+			holdTimeout = null;
+		try {
+			$element.bind(START_EV, touchStart), $element.bind(CANCEL_EV, touchCancel)
+		} catch(e) {
+			$.error("events not supported " + START_EV + "," + CANCEL_EV + " on jQuery.swipe")
+		}
+		this.enable = function() {
+			return this.disable(), $element.bind(START_EV, touchStart), $element.bind(CANCEL_EV, touchCancel), $element
+		}, this.disable = function() {
+			return removeListeners(), $element
+		}, this.destroy = function() {
+			removeListeners(), $element.data(PLUGIN_NS, null), $element = null
+		}, this.option = function(property, value) {
+			if("object" == typeof property) options = $.extend(options, property);
+			else if(void 0 !== options[property]) {
+				if(void 0 === value) return options[property];
+				options[property] = value
+			} else {
+				if(!property) return options;
+				$.error("Option " + property + " does not exist on jQuery.swipe.options")
+			}
+			return null
+		}
+	}
+	var VERSION = "1.6.18",
+		LEFT = "left",
+		RIGHT = "right",
+		UP = "up",
+		DOWN = "down",
+		IN = "in",
+		OUT = "out",
+		NONE = "none",
+		AUTO = "auto",
+		SWIPE = "swipe",
+		PINCH = "pinch",
+		TAP = "tap",
+		DOUBLE_TAP = "doubletap",
+		LONG_TAP = "longtap",
+		HORIZONTAL = "horizontal",
+		VERTICAL = "vertical",
+		ALL_FINGERS = "all",
+		DOUBLE_TAP_THRESHOLD = 10,
+		PHASE_START = "start",
+		PHASE_MOVE = "move",
+		PHASE_END = "end",
+		PHASE_CANCEL = "cancel",
+		SUPPORTS_TOUCH = "ontouchstart" in window,
+		SUPPORTS_POINTER_IE10 = window.navigator.msPointerEnabled && !window.navigator.pointerEnabled && !SUPPORTS_TOUCH,
+		SUPPORTS_POINTER = (window.navigator.pointerEnabled || window.navigator.msPointerEnabled) && !SUPPORTS_TOUCH,
+		PLUGIN_NS = "TouchSwipe",
+		defaults = {
+			fingers: 1,
+			threshold: 75,
+			cancelThreshold: null,
+			pinchThreshold: 20,
+			maxTimeThreshold: null,
+			fingerReleaseThreshold: 250,
+			longTapThreshold: 500,
+			doubleTapThreshold: 200,
+			swipe: null,
+			swipeLeft: null,
+			swipeRight: null,
+			swipeUp: null,
+			swipeDown: null,
+			swipeStatus: null,
+			pinchIn: null,
+			pinchOut: null,
+			pinchStatus: null,
+			click: null,
+			tap: null,
+			doubleTap: null,
+			longTap: null,
+			hold: null,
+			triggerOnTouchEnd: !0,
+			triggerOnTouchLeave: !1,
+			allowPageScroll: "auto",
+			fallbackToMouseEvents: !0,
+			excludedElements: ".noSwipe",
+			preventDefaultEvents: !0
+		};
+	$.fn.swipe = function(method) {
+		var $this = $(this),
+			plugin = $this.data(PLUGIN_NS);
+		if(plugin && "string" == typeof method) {
+			if(plugin[method]) return plugin[method].apply(plugin, Array.prototype.slice.call(arguments, 1));
+			$.error("Method " + method + " does not exist on jQuery.swipe")
+		} else if(plugin && "object" == typeof method) plugin.option.apply(plugin, arguments);
+		else if(!(plugin || "object" != typeof method && method)) return init.apply(this, arguments);
+		return $this
+	}, $.fn.swipe.version = VERSION, $.fn.swipe.defaults = defaults, $.fn.swipe.phases = {
+		PHASE_START: PHASE_START,
+		PHASE_MOVE: PHASE_MOVE,
+		PHASE_END: PHASE_END,
+		PHASE_CANCEL: PHASE_CANCEL
+	}, $.fn.swipe.directions = {
+		LEFT: LEFT,
+		RIGHT: RIGHT,
+		UP: UP,
+		DOWN: DOWN,
+		IN: IN,
+		OUT: OUT
+	}, $.fn.swipe.pageScroll = {
+		NONE: NONE,
+		HORIZONTAL: HORIZONTAL,
+		VERTICAL: VERTICAL,
+		AUTO: AUTO
+	}, $.fn.swipe.fingers = {
+		ONE: 1,
+		TWO: 2,
+		THREE: 3,
+		FOUR: 4,
+		FIVE: 5,
+		ALL: ALL_FINGERS
+	}
+});
+
+/*! WOW - v1.1.3 - 2016-05-06
+ * Copyright (c) 2016 Matthieu Aussaguel;*/
+(function() {
+	var a, b, c, d, e, f = function(a, b) {
+			return function() {
+				return a.apply(b, arguments)
+			}
+		},
+		g = [].indexOf || function(a) {
+			for(var b = 0, c = this.length; c > b; b++)
+				if(b in this && this[b] === a) return b;
+			return -1
+		};
+	b = function() {
+		function a() {}
+		return a.prototype.extend = function(a, b) {
+			var c, d;
+			for(c in b) d = b[c], null == a[c] && (a[c] = d);
+			return a
+		}, a.prototype.isMobile = function(a) {
+			return /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(a)
+		}, a.prototype.createEvent = function(a, b, c, d) {
+			var e;
+			return null == b && (b = !1), null == c && (c = !1), null == d && (d = null), null != document.createEvent ? (e = document.createEvent("CustomEvent"), e.initCustomEvent(a, b, c, d)) : null != document.createEventObject ? (e = document.createEventObject(), e.eventType = a) : e.eventName = a, e
+		}, a.prototype.emitEvent = function(a, b) {
+			return null != a.dispatchEvent ? a.dispatchEvent(b) : b in (null != a) ? a[b]() : "on" + b in (null != a) ? a["on" + b]() : void 0
+		}, a.prototype.addEvent = function(a, b, c) {
+			return null != a.addEventListener ? a.addEventListener(b, c, !1) : null != a.attachEvent ? a.attachEvent("on" + b, c) : a[b] = c
+		}, a.prototype.removeEvent = function(a, b, c) {
+			return null != a.removeEventListener ? a.removeEventListener(b, c, !1) : null != a.detachEvent ? a.detachEvent("on" + b, c) : delete a[b]
+		}, a.prototype.innerHeight = function() {
+			return "innerHeight" in window ? window.innerHeight : document.documentElement.clientHeight
+		}, a
+	}(), c = this.WeakMap || this.MozWeakMap || (c = function() {
+		function a() {
+			this.keys = [], this.values = []
+		}
+		return a.prototype.get = function(a) {
+			var b, c, d, e, f;
+			for(f = this.keys, b = d = 0, e = f.length; e > d; b = ++d)
+				if(c = f[b], c === a) return this.values[b]
+		}, a.prototype.set = function(a, b) {
+			var c, d, e, f, g;
+			for(g = this.keys, c = e = 0, f = g.length; f > e; c = ++e)
+				if(d = g[c], d === a) return void(this.values[c] = b);
+			return this.keys.push(a), this.values.push(b)
+		}, a
+	}()), a = this.MutationObserver || this.WebkitMutationObserver || this.MozMutationObserver || (a = function() {
+		function a() {
+			"undefined" != typeof console && null !== console && console.warn("MutationObserver is not supported by your browser."), "undefined" != typeof console && null !== console && console.warn("WOW.js cannot detect dom mutations, please call .sync() after loading new content.")
+		}
+		return a.notSupported = !0, a.prototype.observe = function() {}, a
+	}()), d = this.getComputedStyle || function(a, b) {
+		return this.getPropertyValue = function(b) {
+			var c;
+			return "float" === b && (b = "styleFloat"), e.test(b) && b.replace(e, function(a, b) {
+				return b.toUpperCase()
+			}), (null != (c = a.currentStyle) ? c[b] : void 0) || null
+		}, this
+	}, e = /(\-([a-z]){1})/g, this.WOW = function() {
+		function e(a) {
+			null == a && (a = {}), this.scrollCallback = f(this.scrollCallback, this), this.scrollHandler = f(this.scrollHandler, this), this.resetAnimation = f(this.resetAnimation, this), this.start = f(this.start, this), this.scrolled = !0, this.config = this.util().extend(a, this.defaults), null != a.scrollContainer && (this.config.scrollContainer = document.querySelector(a.scrollContainer)), this.animationNameCache = new c, this.wowEvent = this.util().createEvent(this.config.boxClass)
+		}
+		return e.prototype.defaults = {
+			boxClass: "wow",
+			animateClass: "animated",
+			offset: 0,
+			mobile: !0,
+			live: !0,
+			callback: null,
+			scrollContainer: null
+		}, e.prototype.init = function() {
+			var a;
+			return this.element = window.document.documentElement, "interactive" === (a = document.readyState) || "complete" === a ? this.start() : this.util().addEvent(document, "DOMContentLoaded", this.start), this.finished = []
+		}, e.prototype.start = function() {
+			var b, c, d, e;
+			if(this.stopped = !1, this.boxes = function() {
+					var a, c, d, e;
+					for(d = this.element.querySelectorAll("." + this.config.boxClass), e = [], a = 0, c = d.length; c > a; a++) b = d[a], e.push(b);
+					return e
+				}.call(this), this.all = function() {
+					var a, c, d, e;
+					for(d = this.boxes, e = [], a = 0, c = d.length; c > a; a++) b = d[a], e.push(b);
+					return e
+				}.call(this), this.boxes.length)
+				if(this.disabled()) this.resetStyle();
+				else
+					for(e = this.boxes, c = 0, d = e.length; d > c; c++) b = e[c], this.applyStyle(b, !0);
+			return this.disabled() || (this.util().addEvent(this.config.scrollContainer || window, "scroll", this.scrollHandler), this.util().addEvent(window, "resize", this.scrollHandler), this.interval = setInterval(this.scrollCallback, 50)), this.config.live ? new a(function(a) {
+				return function(b) {
+					var c, d, e, f, g;
+					for(g = [], c = 0, d = b.length; d > c; c++) f = b[c], g.push(function() {
+						var a, b, c, d;
+						for(c = f.addedNodes || [], d = [], a = 0, b = c.length; b > a; a++) e = c[a], d.push(this.doSync(e));
+						return d
+					}.call(a));
+					return g
+				}
+			}(this)).observe(document.body, {
+				childList: !0,
+				subtree: !0
+			}) : void 0
+		}, e.prototype.stop = function() {
+			return this.stopped = !0, this.util().removeEvent(this.config.scrollContainer || window, "scroll", this.scrollHandler), this.util().removeEvent(window, "resize", this.scrollHandler), null != this.interval ? clearInterval(this.interval) : void 0
+		}, e.prototype.sync = function(b) {
+			return a.notSupported ? this.doSync(this.element) : void 0
+		}, e.prototype.doSync = function(a) {
+			var b, c, d, e, f;
+			if(null == a && (a = this.element), 1 === a.nodeType) {
+				for(a = a.parentNode || a, e = a.querySelectorAll("." + this.config.boxClass), f = [], c = 0, d = e.length; d > c; c++) b = e[c], g.call(this.all, b) < 0 ? (this.boxes.push(b), this.all.push(b), this.stopped || this.disabled() ? this.resetStyle() : this.applyStyle(b, !0), f.push(this.scrolled = !0)) : f.push(void 0);
+				return f
+			}
+		}, e.prototype.show = function(a) {
+			return this.applyStyle(a), a.className = a.className + " " + this.config.animateClass, null != this.config.callback && this.config.callback(a), this.util().emitEvent(a, this.wowEvent), this.util().addEvent(a, "animationend", this.resetAnimation), this.util().addEvent(a, "oanimationend", this.resetAnimation), this.util().addEvent(a, "webkitAnimationEnd", this.resetAnimation), this.util().addEvent(a, "MSAnimationEnd", this.resetAnimation), a
+		}, e.prototype.applyStyle = function(a, b) {
+			var c, d, e;
+			return d = a.getAttribute("data-wow-duration"), c = a.getAttribute("data-wow-delay"), e = a.getAttribute("data-wow-iteration"), this.animate(function(f) {
+				return function() {
+					return f.customStyle(a, b, d, c, e)
+				}
+			}(this))
+		}, e.prototype.animate = function() {
+			return "requestAnimationFrame" in window ? function(a) {
+				return window.requestAnimationFrame(a)
+			} : function(a) {
+				return a()
+			}
+		}(), e.prototype.resetStyle = function() {
+			var a, b, c, d, e;
+			for(d = this.boxes, e = [], b = 0, c = d.length; c > b; b++) a = d[b], e.push(a.style.visibility = "visible");
+			return e
+		}, e.prototype.resetAnimation = function(a) {
+			var b;
+			return a.type.toLowerCase().indexOf("animationend") >= 0 ? (b = a.target || a.srcElement, b.className = b.className.replace(this.config.animateClass, "").trim()) : void 0
+		}, e.prototype.customStyle = function(a, b, c, d, e) {
+			return b && this.cacheAnimationName(a), a.style.visibility = b ? "hidden" : "visible", c && this.vendorSet(a.style, {
+				animationDuration: c
+			}), d && this.vendorSet(a.style, {
+				animationDelay: d
+			}), e && this.vendorSet(a.style, {
+				animationIterationCount: e
+			}), this.vendorSet(a.style, {
+				animationName: b ? "none" : this.cachedAnimationName(a)
+			}), a
+		}, e.prototype.vendors = ["moz", "webkit"], e.prototype.vendorSet = function(a, b) {
+			var c, d, e, f;
+			d = [];
+			for(c in b) e = b[c], a["" + c] = e, d.push(function() {
+				var b, d, g, h;
+				for(g = this.vendors, h = [], b = 0, d = g.length; d > b; b++) f = g[b], h.push(a["" + f + c.charAt(0).toUpperCase() + c.substr(1)] = e);
+				return h
+			}.call(this));
+			return d
+		}, e.prototype.vendorCSS = function(a, b) {
+			var c, e, f, g, h, i;
+			for(h = d(a), g = h.getPropertyCSSValue(b), f = this.vendors, c = 0, e = f.length; e > c; c++) i = f[c], g = g || h.getPropertyCSSValue("-" + i + "-" + b);
+			return g
+		}, e.prototype.animationName = function(a) {
+			var b;
+			try {
+				b = this.vendorCSS(a, "animation-name").cssText
+			} catch(c) {
+				b = d(a).getPropertyValue("animation-name")
+			}
+			return "none" === b ? "" : b
+		}, e.prototype.cacheAnimationName = function(a) {
+			return this.animationNameCache.set(a, this.animationName(a))
+		}, e.prototype.cachedAnimationName = function(a) {
+			return this.animationNameCache.get(a)
+		}, e.prototype.scrollHandler = function() {
+			return this.scrolled = !0
+		}, e.prototype.scrollCallback = function() {
+			var a;
+			return !this.scrolled || (this.scrolled = !1, this.boxes = function() {
+				var b, c, d, e;
+				for(d = this.boxes, e = [], b = 0, c = d.length; c > b; b++) a = d[b], a && (this.isVisible(a) ? this.show(a) : e.push(a));
+				return e
+			}.call(this), this.boxes.length || this.config.live) ? void 0 : this.stop()
+		}, e.prototype.offsetTop = function(a) {
+			for(var b; void 0 === a.offsetTop;) a = a.parentNode;
+			for(b = a.offsetTop; a = a.offsetParent;) b += a.offsetTop;
+			return b
+		}, e.prototype.isVisible = function(a) {
+			var b, c, d, e, f;
+			return c = a.getAttribute("data-wow-offset") || this.config.offset, f = this.config.scrollContainer && this.config.scrollContainer.scrollTop || window.pageYOffset, e = f + Math.min(this.element.clientHeight, this.util().innerHeight()) - c, d = this.offsetTop(a), b = d + a.clientHeight, e >= d && b >= f
+		}, e.prototype.util = function() {
+			return null != this._util ? this._util : this._util = new b
+		}, e.prototype.disabled = function() {
+			return !this.config.mobile && this.util().isMobile(navigator.userAgent)
+		}, e
+	}()
+}).call(this);
+
+/*!
+ * app.js
+ */
+'use strict';
+var browser = navigator.appName
+var b_version = navigator.appVersion
+var version = b_version.split(";");
+var trim_Version = version[1] ? version[1].replace(/[ ]/g, "") : '';
+var browser;
+if(browser == "Microsoft Internet Explorer" && trim_Version == "MSIE6.0") {
+	browser = 'ie6';
+} else if(browser == "Microsoft Internet Explorer" && trim_Version == "MSIE7.0") {
+	browser = 'ie7';
+} else if(browser == "Microsoft Internet Explorer" && trim_Version == "MSIE8.0") {
+	browser = 'ie8';
+} else if(browser == "Microsoft Internet Explorer" && trim_Version == "MSIE9.0") {
+	browser = 'ie9';
 }
 
-function preloadImagesForCarousel() {
-	var images = collectImagesForPreloading();
-	
-	preloadImages(images);
-}