(function () {
    var l = this,
        g, y = l.jQuery,
        p = l.$,
        o = l.jQuery = l.$ = function (E, F) {
            return new o.fn.init(E, F)
        },
        D = /^[^<]*(<(.|\s)+>)[^>]*$|^#([\w-]+)$/,
        f = /^.[^:#\[\.,]*$/;
    o.fn = o.prototype = {
        init: function (E, H) {
            E = E || document;
            if (E.nodeType) {
                this[0] = E;
                this.length = 1;
                this.context = E;
                return this
            }
            if (typeof E === "string") {
                var G = D.exec(E);
                if (G && (G[1] || !H)) {
                    if (G[1]) {
                        E = o.clean([G[1]], H)
                    } else {
                        var I = document.getElementById(G[3]);
                        if (I && I.id != G[3]) {
                            return o().find(E)
                        }
                        var F = o(I || []);
                        F.context = document;
                        F.selector = E;
                        return F
                    }
                } else {
                    return o(H).find(E)
                }
            } else {
                if (o.isFunction(E)) {
                    return o(document).ready(E)
                }
            }
            if (E.selector && E.context) {
                this.selector = E.selector;
                this.context = E.context
            }
            return this.setArray(o.makeArray(E))
        },
        selector: "",
        jquery: "1.3.1",
        size: function () {
            return this.length
        },
        get: function (E) {
            return E === g ? o.makeArray(this) : this[E]
        },
        pushStack: function (F, H, E) {
            var G = o(F);
            G.prevObject = this;
            G.context = this.context;
            if (H === "find") {
                G.selector = this.selector + (this.selector ? " " : "") + E
            } else {
                if (H) {
                    G.selector = this.selector + "." + H + "(" + E + ")"
                }
            }
            return G
        },
        setArray: function (E) {
            this.length = 0;
            Array.prototype.push.apply(this, E);
            return this
        },
        each: function (F, E) {
            return o.each(this, F, E)
        },
        index: function (E) {
            return o.inArray(E && E.jquery ? E[0] : E, this)
        },
        attr: function (F, H, G) {
            var E = F;
            if (typeof F === "string") {
                if (H === g) {
                    return this[0] && o[G || "attr"](this[0], F)
                } else {
                    E = {};
                    E[F] = H
                }
            }
            return this.each(function (I) {
                for (F in E) {
                    o.attr(G ? this.style : this, F, o.prop(this, E[F], G, I, F))
                }
            })
        },
        css: function (E, F) {
            if ((E == "width" || E == "height") && parseFloat(F) < 0) {
                F = g
            }
            return this.attr(E, F, "curCSS")
        },
        text: function (F) {
            if (typeof F !== "object" && F != null) {
                return this.empty().append((this[0] && this[0].ownerDocument || document).createTextNode(F))
            }
            var E = "";
            o.each(F || this, function () {
                o.each(this.childNodes, function () {
                    if (this.nodeType != 8) {
                        E += this.nodeType != 1 ? this.nodeValue : o.fn.text([this])
                    }
                })
            });
            return E
        },
        wrapAll: function (E) {
            if (this[0]) {
                var F = o(E, this[0].ownerDocument).clone();
                if (this[0].parentNode) {
                    F.insertBefore(this[0])
                }
                F.map(function () {
                    var G = this;
                    while (G.firstChild) {
                        G = G.firstChild
                    }
                    return G
                }).append(this)
            }
            return this
        },
        wrapInner: function (E) {
            return this.each(function () {
                o(this).contents().wrapAll(E)
            })
        },
        wrap: function (E) {
            return this.each(function () {
                o(this).wrapAll(E)
            })
        },
        append: function () {
            return this.domManip(arguments, true, function (E) {
                if (this.nodeType == 1) {
                    this.appendChild(E)
                }
            })
        },
        prepend: function () {
            return this.domManip(arguments, true, function (E) {
                if (this.nodeType == 1) {
                    this.insertBefore(E, this.firstChild)
                }
            })
        },
        before: function () {
            return this.domManip(arguments, false, function (E) {
                this.parentNode.insertBefore(E, this)
            })
        },
        after: function () {
            return this.domManip(arguments, false, function (E) {
                this.parentNode.insertBefore(E, this.nextSibling)
            })
        },
        end: function () {
            return this.prevObject || o([])
        },
        push: [].push,
        find: function (E) {
            if (this.length === 1 && !/,/.test(E)) {
                var G = this.pushStack([], "find", E);
                G.length = 0;
                o.find(E, this[0], G);
                return G
            } else {
                var F = o.map(this, function (H) {
                    return o.find(E, H)
                });
                return this.pushStack(/[^+>] [^+>]/.test(E) ? o.unique(F) : F, "find", E)
            }
        },
        clone: function (F) {
            var E = this.map(function () {
                if (!o.support.noCloneEvent && !o.isXMLDoc(this)) {
                    var I = this.cloneNode(true),
                        H = document.createElement("div");
                    H.appendChild(I);
                    return o.clean([H.innerHTML])[0]
                } else {
                    return this.cloneNode(true)
                }
            });
            var G = E.find("*").andSelf().each(function () {
                if (this[h] !== g) {
                    this[h] = null
                }
            });
            if (F === true) {
                this.find("*").andSelf().each(function (I) {
                    if (this.nodeType == 3) {
                        return
                    }
                    var H = o.data(this, "events");
                    for (var K in H) {
                        for (var J in H[K]) {
                            o.event.add(G[I], K, H[K][J], H[K][J].data)
                        }
                    }
                })
            }
            return E
        },
        filter: function (E) {
            return this.pushStack(o.isFunction(E) && o.grep(this, function (G, F) {
                return E.call(G, F)
            }) || o.multiFilter(E, o.grep(this, function (F) {
                return F.nodeType === 1
            })), "filter", E)
        },
        closest: function (E) {
            var F = o.expr.match.POS.test(E) ? o(E) : null;
            return this.map(function () {
                var G = this;
                while (G && G.ownerDocument) {
                    if (F ? F.index(G) > -1 : o(G).is(E)) {
                        return G
                    }
                    G = G.parentNode
                }
            })
        },
        not: function (E) {
            if (typeof E === "string") {
                if (f.test(E)) {
                    return this.pushStack(o.multiFilter(E, this, true), "not", E)
                } else {
                    E = o.multiFilter(E, this)
                }
            }
            var F = E.length && E[E.length - 1] !== g && !E.nodeType;
            return this.filter(function () {
                return F ? o.inArray(this, E) < 0 : this != E
            })
        },
        add: function (E) {
            return this.pushStack(o.unique(o.merge(this.get(), typeof E === "string" ? o(E) : o.makeArray(E))))
        },
        is: function (E) {
            return !!E && o.multiFilter(E, this).length > 0
        },
        hasClass: function (E) {
            return !!E && this.is("." + E)
        },
        val: function (K) {
            if (K === g) {
                var E = this[0];
                if (E) {
                    if (o.nodeName(E, "option")) {
                        return (E.attributes.value || {}).specified ? E.value : E.text
                    }
                    if (o.nodeName(E, "select")) {
                        var I = E.selectedIndex,
                            L = [],
                            M = E.options,
                            H = E.type == "select-one";
                        if (I < 0) {
                            return null
                        }
                        for (var F = H ? I : 0, J = H ? I + 1 : M.length; F < J; F++) {
                            var G = M[F];
                            if (G.selected) {
                                K = o(G).val();
                                if (H) {
                                    return K
                                }
                                L.push(K)
                            }
                        }
                        return L
                    }
                    return (E.value || "").replace(/\r/g, "")
                }
                return g
            }
            if (typeof K === "number") {
                K += ""
            }
            return this.each(function () {
                if (this.nodeType != 1) {
                    return
                }
                if (o.isArray(K) && /radio|checkbox/.test(this.type)) {
                    this.checked = (o.inArray(this.value, K) >= 0 || o.inArray(this.name, K) >= 0)
                } else {
                    if (o.nodeName(this, "select")) {
                        var N = o.makeArray(K);
                        o("option", this).each(function () {
                            this.selected = (o.inArray(this.value, N) >= 0 || o.inArray(this.text, N) >= 0)
                        });
                        if (!N.length) {
                            this.selectedIndex = -1
                        }
                    } else {
                        this.value = K
                    }
                }
            })
        },
        html: function (E) {
            return E === g ? (this[0] ? this[0].innerHTML : null) : this.empty().append(E)
        },
        replaceWith: function (E) {
            return this.after(E).remove()
        },
        eq: function (E) {
            return this.slice(E, +E + 1)
        },
        slice: function () {
            return this.pushStack(Array.prototype.slice.apply(this, arguments), "slice", Array.prototype.slice.call(arguments).join(","))
        },
        map: function (E) {
            return this.pushStack(o.map(this, function (G, F) {
                return E.call(G, F, G)
            }))
        },
        andSelf: function () {
            return this.add(this.prevObject)
        },
        domManip: function (K, N, M) {
            if (this[0]) {
                var J = (this[0].ownerDocument || this[0]).createDocumentFragment(),
                    G = o.clean(K, (this[0].ownerDocument || this[0]), J),
                    I = J.firstChild,
                    E = this.length > 1 ? J.cloneNode(true) : J;
                if (I) {
                    for (var H = 0, F = this.length; H < F; H++) {
                        M.call(L(this[H], I), H > 0 ? E.cloneNode(true) : J)
                    }
                }
                if (G) {
                    o.each(G, z)
                }
            }
            return this;

            function L(O, P) {
                return N && o.nodeName(O, "table") && o.nodeName(P, "tr") ? (O.getElementsByTagName("tbody")[0] || O.appendChild(O.ownerDocument.createElement("tbody"))) : O
            }
        }
    };
    o.fn.init.prototype = o.fn;

    function z(E, F) {
        if (F.src) {
            o.ajax({
                url: F.src,
                async: false,
                dataType: "script"
            })
        } else {
            o.globalEval(F.text || F.textContent || F.innerHTML || "")
        }
        if (F.parentNode) {
            F.parentNode.removeChild(F)
        }
    }
    function e() {
        return +new Date
    }
    o.extend = o.fn.extend = function () {
        var J = arguments[0] || {},
            H = 1,
            I = arguments.length,
            E = false,
            G;
        if (typeof J === "boolean") {
            E = J;
            J = arguments[1] || {};
            H = 2
        }
        if (typeof J !== "object" && !o.isFunction(J)) {
            J = {}
        }
        if (I == H) {
            J = this;
            --H
        }
        for (; H < I; H++) {
            if ((G = arguments[H]) != null) {
                for (var F in G) {
                    var K = J[F],
                        L = G[F];
                    if (J === L) {
                        continue
                    }
                    if (E && L && typeof L === "object" && !L.nodeType) {
                        J[F] = o.extend(E, K || (L.length != null ? [] : {}), L)
                    } else {
                        if (L !== g) {
                            J[F] = L
                        }
                    }
                }
            }
        }
        return J
    };
    var b = /z-?index|font-?weight|opacity|zoom|line-?height/i,
        q = document.defaultView || {},
        s = Object.prototype.toString;
    o.extend({
        noConflict: function (E) {
            l.$ = p;
            if (E) {
                l.jQuery = y
            }
            return o
        },
        isFunction: function (E) {
            return s.call(E) === "[object Function]"
        },
        isArray: function (E) {
            return s.call(E) === "[object Array]"
        },
        isXMLDoc: function (E) {
            return E.nodeType === 9 && E.documentElement.nodeName !== "HTML" || !! E.ownerDocument && o.isXMLDoc(E.ownerDocument)
        },
        globalEval: function (G) {
            G = o.trim(G);
            if (G) {
                var F = document.getElementsByTagName("head")[0] || document.documentElement,
                    E = document.createElement("script");
                E.type = "text/javascript";
                if (o.support.scriptEval) {
                    E.appendChild(document.createTextNode(G))
                } else {
                    E.text = G
                }
                F.insertBefore(E, F.firstChild);
                F.removeChild(E)
            }
        },
        nodeName: function (F, E) {
            return F.nodeName && F.nodeName.toUpperCase() == E.toUpperCase()
        },
        each: function (G, K, F) {
            var E, H = 0,
                I = G.length;
            if (F) {
                if (I === g) {
                    for (E in G) {
                        if (K.apply(G[E], F) === false) {
                            break
                        }
                    }
                } else {
                    for (; H < I;) {
                        if (K.apply(G[H++], F) === false) {
                            break
                        }
                    }
                }
            } else {
                if (I === g) {
                    for (E in G) {
                        if (K.call(G[E], E, G[E]) === false) {
                            break
                        }
                    }
                } else {
                    for (var J = G[0]; H < I && K.call(J, H, J) !== false; J = G[++H]) {}
                }
            }
            return G
        },
        prop: function (H, I, G, F, E) {
            if (o.isFunction(I)) {
                I = I.call(H, F)
            }
            return typeof I === "number" && G == "curCSS" && !b.test(E) ? I + "px" : I
        },
        className: {
            add: function (E, F) {
                o.each((F || "").split(/\s+/), function (G, H) {
                    if (E.nodeType == 1 && !o.className.has(E.className, H)) {
                        E.className += (E.className ? " " : "") + H
                    }
                })
            },
            remove: function (E, F) {
                if (E.nodeType == 1) {
                    E.className = F !== g ? o.grep(E.className.split(/\s+/), function (G) {
                        return !o.className.has(F, G)
                    }).join(" ") : ""
                }
            },
            has: function (F, E) {
                return F && o.inArray(E, (F.className || F).toString().split(/\s+/)) > -1
            }
        },
        swap: function (H, G, I) {
            var E = {};
            for (var F in G) {
                E[F] = H.style[F];
                H.style[F] = G[F]
            }
            I.call(H);
            for (var F in G) {
                H.style[F] = E[F]
            }
        },
        css: function (G, E, I) {
            if (E == "width" || E == "height") {
                var K, F = {
                    position: "absolute",
                    visibility: "hidden",
                    display: "block"
                },
                    J = E == "width" ? ["Left", "Right"] : ["Top", "Bottom"];

                function H() {
                    K = E == "width" ? G.offsetWidth : G.offsetHeight;
                    var M = 0,
                        L = 0;
                    o.each(J, function () {
                        M += parseFloat(o.curCSS(G, "padding" + this, true)) || 0;
                        L += parseFloat(o.curCSS(G, "border" + this + "Width", true)) || 0
                    });
                    K -= Math.round(M + L)
                }
                if (o(G).is(":visible")) {
                    H()
                } else {
                    o.swap(G, F, H)
                }
                return Math.max(0, K)
            }
            return o.curCSS(G, E, I)
        },
        curCSS: function (I, F, G) {
            var L, E = I.style;
            if (F == "opacity" && !o.support.opacity) {
                L = o.attr(E, "opacity");
                return L == "" ? "1" : L
            }
            if (F.match(/float/i)) {
                F = w
            }
            if (!G && E && E[F]) {
                L = E[F]
            } else {
                if (q.getComputedStyle) {
                    if (F.match(/float/i)) {
                        F = "float"
                    }
                    F = F.replace(/([A-Z])/g, "-$1").toLowerCase();
                    var M = q.getComputedStyle(I, null);
                    if (M) {
                        L = M.getPropertyValue(F)
                    }
                    if (F == "opacity" && L == "") {
                        L = "1"
                    }
                } else {
                    if (I.currentStyle) {
                        var J = F.replace(/\-(\w)/g, function (N, O) {
                            return O.toUpperCase()
                        });
                        L = I.currentStyle[F] || I.currentStyle[J];
                        if (!/^\d+(px)?$/i.test(L) && /^\d/.test(L)) {
                            var H = E.left,
                                K = I.runtimeStyle.left;
                            I.runtimeStyle.left = I.currentStyle.left;
                            E.left = L || 0;
                            L = E.pixelLeft + "px";
                            E.left = H;
                            I.runtimeStyle.left = K
                        }
                    }
                }
            }
            return L
        },
        clean: function (F, K, I) {
            K = K || document;
            if (typeof K.createElement === "undefined") {
                K = K.ownerDocument || K[0] && K[0].ownerDocument || document
            }
            if (!I && F.length === 1 && typeof F[0] === "string") {
                var H = /^<(\w+)\s*\/?>$/.exec(F[0]);
                if (H) {
                    return [K.createElement(H[1])]
                }
            }
            var G = [],
                E = [],
                L = K.createElement("div");
            o.each(F, function (P, R) {
                if (typeof R === "number") {
                    R += ""
                }
                if (!R) {
                    return
                }
                if (typeof R === "string") {
                    R = R.replace(/(<(\w+)[^>]*?)\/>/g, function (T, U, S) {
                        return S.match(/^(abbr|br|col|img|input|link|meta|param|hr|area|embed)$/i) ? T : U + "></" + S + ">"
                    });
                    var O = o.trim(R).toLowerCase();
                    var Q = !O.indexOf("<opt") && [1, "<select multiple='multiple'>", "</select>"] || !O.indexOf("<leg") && [1, "<fieldset>", "</fieldset>"] || O.match(/^<(thead|tbody|tfoot|colg|cap)/) && [1, "<table>", "</table>"] || !O.indexOf("<tr") && [2, "<table><tbody>", "</tbody></table>"] || (!O.indexOf("<td") || !O.indexOf("<th")) && [3, "<table><tbody><tr>", "</tr></tbody></table>"] || !O.indexOf("<col") && [2, "<table><tbody></tbody><colgroup>", "</colgroup></table>"] || !o.support.htmlSerialize && [1, "div<div>", "</div>"] || [0, "", ""];
                    L.innerHTML = Q[1] + R + Q[2];
                    while (Q[0]--) {
                        L = L.lastChild
                    }
                    if (!o.support.tbody) {
                        var N = !O.indexOf("<table") && O.indexOf("<tbody") < 0 ? L.firstChild && L.firstChild.childNodes : Q[1] == "<table>" && O.indexOf("<tbody") < 0 ? L.childNodes : [];
                        for (var M = N.length - 1; M >= 0; --M) {
                            if (o.nodeName(N[M], "tbody") && !N[M].childNodes.length) {
                                N[M].parentNode.removeChild(N[M])
                            }
                        }
                    }
                    if (!o.support.leadingWhitespace && /^\s/.test(R)) {
                        L.insertBefore(K.createTextNode(R.match(/^\s*/)[0]), L.firstChild)
                    }
                    R = o.makeArray(L.childNodes)
                }
                if (R.nodeType) {
                    G.push(R)
                } else {
                    G = o.merge(G, R)
                }
            });
            if (I) {
                for (var J = 0; G[J]; J++) {
                    if (o.nodeName(G[J], "script") && (!G[J].type || G[J].type.toLowerCase() === "text/javascript")) {
                        E.push(G[J].parentNode ? G[J].parentNode.removeChild(G[J]) : G[J])
                    } else {
                        if (G[J].nodeType === 1) {
                            G.splice.apply(G, [J + 1, 0].concat(o.makeArray(G[J].getElementsByTagName("script"))))
                        }
                        I.appendChild(G[J])
                    }
                }
                return E
            }
            return G
        },
        attr: function (J, G, K) {
            if (!J || J.nodeType == 3 || J.nodeType == 8) {
                return g
            }
            var H = !o.isXMLDoc(J),
                L = K !== g;
            G = H && o.props[G] || G;
            if (J.tagName) {
                var F = /href|src|style/.test(G);
                if (G == "selected" && J.parentNode) {
                    J.parentNode.selectedIndex
                }
                if (G in J && H && !F) {
                    if (L) {
                        if (G == "type" && o.nodeName(J, "input") && J.parentNode) {
                            throw "type property can't be changed"
                        }
                        J[G] = K
                    }
                    if (o.nodeName(J, "form") && J.getAttributeNode(G)) {
                        return J.getAttributeNode(G).nodeValue
                    }
                    if (G == "tabIndex") {
                        var I = J.getAttributeNode("tabIndex");
                        return I && I.specified ? I.value : J.nodeName.match(/(button|input|object|select|textarea)/i) ? 0 : J.nodeName.match(/^(a|area)$/i) && J.href ? 0 : g
                    }
                    return J[G]
                }
                if (!o.support.style && H && G == "style") {
                    return o.attr(J.style, "cssText", K)
                }
                if (L) {
                    J.setAttribute(G, "" + K)
                }
                var E = !o.support.hrefNormalized && H && F ? J.getAttribute(G, 2) : J.getAttribute(G);
                return E === null ? g : E
            }
            if (!o.support.opacity && G == "opacity") {
                if (L) {
                    J.zoom = 1;
                    J.filter = (J.filter || "").replace(/alpha\([^)]*\)/, "") + (parseInt(K) + "" == "NaN" ? "" : "alpha(opacity=" + K * 100 + ")")
                }
                return J.filter && J.filter.indexOf("opacity=") >= 0 ? (parseFloat(J.filter.match(/opacity=([^)]*)/)[1]) / 100) + "" : ""
            }
            G = G.replace(/-([a-z])/ig, function (M, N) {
                return N.toUpperCase()
            });
            if (L) {
                J[G] = K
            }
            return J[G]
        },
        trim: function (E) {
            return (E || "").replace(/^\s+|\s+$/g, "")
        },
        makeArray: function (G) {
            var E = [];
            if (G != null) {
                var F = G.length;
                if (F == null || typeof G === "string" || o.isFunction(G) || G.setInterval) {
                    E[0] = G
                } else {
                    while (F) {
                        E[--F] = G[F]
                    }
                }
            }
            return E
        },
        inArray: function (G, H) {
            for (var E = 0, F = H.length; E < F; E++) {
                if (H[E] === G) {
                    return E
                }
            }
            return -1
        },
        merge: function (H, E) {
            var F = 0,
                G, I = H.length;
            if (!o.support.getAll) {
                while ((G = E[F++]) != null) {
                    if (G.nodeType != 8) {
                        H[I++] = G
                    }
                }
            } else {
                while ((G = E[F++]) != null) {
                    H[I++] = G
                }
            }
            return H
        },
        unique: function (K) {
            var F = [],
                E = {};
            try {
                for (var G = 0, H = K.length; G < H; G++) {
                    var J = o.data(K[G]);
                    if (!E[J]) {
                        E[J] = true;
                        F.push(K[G])
                    }
                }
            } catch (I) {
                F = K
            }
            return F
        },
        grep: function (F, J, E) {
            var G = [];
            for (var H = 0, I = F.length; H < I; H++) {
                if (!E != !J(F[H], H)) {
                    G.push(F[H])
                }
            }
            return G
        },
        map: function (E, J) {
            var F = [];
            for (var G = 0, H = E.length; G < H; G++) {
                var I = J(E[G], G);
                if (I != null) {
                    F[F.length] = I
                }
            }
            return F.concat.apply([], F)
        }
    });
    var C = navigator.userAgent.toLowerCase();
    o.browser = {
        version: (C.match(/.+(?:rv|it|ra|ie)[\/: ]([\d.]+)/) || [0, "0"])[1],
        safari: /webkit/.test(C),
        opera: /opera/.test(C),
        msie: /msie/.test(C) && !/opera/.test(C),
        mozilla: /mozilla/.test(C) && !/(compatible|webkit)/.test(C)
    };
    o.each({
        parent: function (E) {
            return E.parentNode
        },
        parents: function (E) {
            return o.dir(E, "parentNode")
        },
        next: function (E) {
            return o.nth(E, 2, "nextSibling")
        },
        prev: function (E) {
            return o.nth(E, 2, "previousSibling")
        },
        nextAll: function (E) {
            return o.dir(E, "nextSibling")
        },
        prevAll: function (E) {
            return o.dir(E, "previousSibling")
        },
        siblings: function (E) {
            return o.sibling(E.parentNode.firstChild, E)
        },
        children: function (E) {
            return o.sibling(E.firstChild)
        },
        contents: function (E) {
            return o.nodeName(E, "iframe") ? E.contentDocument || E.contentWindow.document : o.makeArray(E.childNodes)
        }
    }, function (E, F) {
        o.fn[E] = function (G) {
            var H = o.map(this, F);
            if (G && typeof G == "string") {
                H = o.multiFilter(G, H)
            }
            return this.pushStack(o.unique(H), E, G)
        }
    });
    o.each({
        appendTo: "append",
        prependTo: "prepend",
        insertBefore: "before",
        insertAfter: "after",
        replaceAll: "replaceWith"
    }, function (E, F) {
        o.fn[E] = function () {
            var G = arguments;
            return this.each(function () {
                for (var H = 0, I = G.length; H < I; H++) {
                    o(G[H])[F](this)
                }
            })
        }
    });
    o.each({
        removeAttr: function (E) {
            o.attr(this, E, "");
            if (this.nodeType == 1) {
                this.removeAttribute(E)
            }
        },
        addClass: function (E) {
            o.className.add(this, E)
        },
        removeClass: function (E) {
            o.className.remove(this, E)
        },
        toggleClass: function (F, E) {
            if (typeof E !== "boolean") {
                E = !o.className.has(this, F)
            }
            o.className[E ? "add" : "remove"](this, F)
        },
        remove: function (E) {
            if (!E || o.filter(E, [this]).length) {
                o("*", this).add([this]).each(function () {
                    o.event.remove(this);
                    o.removeData(this)
                });
                if (this.parentNode) {
                    this.parentNode.removeChild(this)
                }
            }
        },
        empty: function () {
            o(">*", this).remove();
            while (this.firstChild) {
                this.removeChild(this.firstChild)
            }
        }
    }, function (E, F) {
        o.fn[E] = function () {
            return this.each(F, arguments)
        }
    });

    function j(E, F) {
        return E[0] && parseInt(o.curCSS(E[0], F, true), 10) || 0
    }
    var h = "jQuery" + e(),
        v = 0,
        A = {};
    o.extend({
        cache: {},
        data: function (F, E, G) {
            F = F == l ? A : F;
            var H = F[h];
            if (!H) {
                H = F[h] = ++v
            }
            if (E && !o.cache[H]) {
                o.cache[H] = {}
            }
            if (G !== g) {
                o.cache[H][E] = G
            }
            return E ? o.cache[H][E] : H
        },
        removeData: function (F, E) {
            F = F == l ? A : F;
            var H = F[h];
            if (E) {
                if (o.cache[H]) {
                    delete o.cache[H][E];
                    E = "";
                    for (E in o.cache[H]) {
                        break
                    }
                    if (!E) {
                        o.removeData(F)
                    }
                }
            } else {
                try {
                    delete F[h]
                } catch (G) {
                    if (F.removeAttribute) {
                        F.removeAttribute(h)
                    }
                }
                delete o.cache[H]
            }
        },
        queue: function (F, E, H) {
            if (F) {
                E = (E || "fx") + "queue";
                var G = o.data(F, E);
                if (!G || o.isArray(H)) {
                    G = o.data(F, E, o.makeArray(H))
                } else {
                    if (H) {
                        G.push(H)
                    }
                }
            }
            return G
        },
        dequeue: function (H, G) {
            var E = o.queue(H, G),
                F = E.shift();
            if (!G || G === "fx") {
                F = E[0]
            }
            if (F !== g) {
                F.call(H)
            }
        }
    });
    o.fn.extend({
        data: function (E, G) {
            var H = E.split(".");
            H[1] = H[1] ? "." + H[1] : "";
            if (G === g) {
                var F = this.triggerHandler("getData" + H[1] + "!", [H[0]]);
                if (F === g && this.length) {
                    F = o.data(this[0], E)
                }
                return F === g && H[1] ? this.data(H[0]) : F
            } else {
                return this.trigger("setData" + H[1] + "!", [H[0], G]).each(function () {
                    o.data(this, E, G)
                })
            }
        },
        removeData: function (E) {
            return this.each(function () {
                o.removeData(this, E)
            })
        },
        queue: function (E, F) {
            if (typeof E !== "string") {
                F = E;
                E = "fx"
            }
            if (F === g) {
                return o.queue(this[0], E)
            }
            return this.each(function () {
                var G = o.queue(this, E, F);
                if (E == "fx" && G.length == 1) {
                    G[0].call(this)
                }
            })
        },
        dequeue: function (E) {
            return this.each(function () {
                o.dequeue(this, E)
            })
        }
    });
    (function () {
        var Q = /((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^[\]]*\]|['"][^'"]+['"]|[^[\]'"]+)+\]|\\.|[^ >+~,(\[]+)+|[>+~])(\s*,\s*)?/g,
            K = 0,
            G = Object.prototype.toString;
        var F = function (X, T, aa, ab) {
                aa = aa || [];
                T = T || document;
                if (T.nodeType !== 1 && T.nodeType !== 9) {
                    return []
                }
                if (!X || typeof X !== "string") {
                    return aa
                }
                var Y = [],
                    V, ae, ah, S, ac, U, W = true;
                Q.lastIndex = 0;
                while ((V = Q.exec(X)) !== null) {
                    Y.push(V[1]);
                    if (V[2]) {
                        U = RegExp.rightContext;
                        break
                    }
                }
                if (Y.length > 1 && L.exec(X)) {
                    if (Y.length === 2 && H.relative[Y[0]]) {
                        ae = I(Y[0] + Y[1], T)
                    } else {
                        ae = H.relative[Y[0]] ? [T] : F(Y.shift(), T);
                        while (Y.length) {
                            X = Y.shift();
                            if (H.relative[X]) {
                                X += Y.shift()
                            }
                            ae = I(X, ae)
                        }
                    }
                } else {
                    var ad = ab ? {
                        expr: Y.pop(),
                        set: E(ab)
                    } : F.find(Y.pop(), Y.length === 1 && T.parentNode ? T.parentNode : T, P(T));
                    ae = F.filter(ad.expr, ad.set);
                    if (Y.length > 0) {
                        ah = E(ae)
                    } else {
                        W = false
                    }
                    while (Y.length) {
                        var ag = Y.pop(),
                            af = ag;
                        if (!H.relative[ag]) {
                            ag = ""
                        } else {
                            af = Y.pop()
                        }
                        if (af == null) {
                            af = T
                        }
                        H.relative[ag](ah, af, P(T))
                    }
                }
                if (!ah) {
                    ah = ae
                }
                if (!ah) {
                    throw "Syntax error, unrecognized expression: " + (ag || X)
                }
                if (G.call(ah) === "[object Array]") {
                    if (!W) {
                        aa.push.apply(aa, ah)
                    } else {
                        if (T.nodeType === 1) {
                            for (var Z = 0; ah[Z] != null; Z++) {
                                if (ah[Z] && (ah[Z] === true || ah[Z].nodeType === 1 && J(T, ah[Z]))) {
                                    aa.push(ae[Z])
                                }
                            }
                        } else {
                            for (var Z = 0; ah[Z] != null; Z++) {
                                if (ah[Z] && ah[Z].nodeType === 1) {
                                    aa.push(ae[Z])
                                }
                            }
                        }
                    }
                } else {
                    E(ah, aa)
                }
                if (U) {
                    F(U, T, aa, ab)
                }
                return aa
            };
        F.matches = function (S, T) {
            return F(S, null, null, T)
        };
        F.find = function (Z, S, aa) {
            var Y, W;
            if (!Z) {
                return []
            }
            for (var V = 0, U = H.order.length; V < U; V++) {
                var X = H.order[V],
                    W;
                if ((W = H.match[X].exec(Z))) {
                    var T = RegExp.leftContext;
                    if (T.substr(T.length - 1) !== "\\") {
                        W[1] = (W[1] || "").replace(/\\/g, "");
                        Y = H.find[X](W, S, aa);
                        if (Y != null) {
                            Z = Z.replace(H.match[X], "");
                            break
                        }
                    }
                }
            }
            if (!Y) {
                Y = S.getElementsByTagName("*")
            }
            return {
                set: Y,
                expr: Z
            }
        };
        F.filter = function (ab, aa, ae, V) {
            var U = ab,
                ag = [],
                Y = aa,
                X, S;
            while (ab && aa.length) {
                for (var Z in H.filter) {
                    if ((X = H.match[Z].exec(ab)) != null) {
                        var T = H.filter[Z],
                            af, ad;
                        S = false;
                        if (Y == ag) {
                            ag = []
                        }
                        if (H.preFilter[Z]) {
                            X = H.preFilter[Z](X, Y, ae, ag, V);
                            if (!X) {
                                S = af = true
                            } else {
                                if (X === true) {
                                    continue
                                }
                            }
                        }
                        if (X) {
                            for (var W = 0;
                            (ad = Y[W]) != null; W++) {
                                if (ad) {
                                    af = T(ad, X, W, Y);
                                    var ac = V ^ !! af;
                                    if (ae && af != null) {
                                        if (ac) {
                                            S = true
                                        } else {
                                            Y[W] = false
                                        }
                                    } else {
                                        if (ac) {
                                            ag.push(ad);
                                            S = true
                                        }
                                    }
                                }
                            }
                        }
                        if (af !== g) {
                            if (!ae) {
                                Y = ag
                            }
                            ab = ab.replace(H.match[Z], "");
                            if (!S) {
                                return []
                            }
                            break
                        }
                    }
                }
                ab = ab.replace(/\s*,\s*/, "");
                if (ab == U) {
                    if (S == null) {
                        throw "Syntax error, unrecognized expression: " + ab
                    } else {
                        break
                    }
                }
                U = ab
            }
            return Y
        };
        var H = F.selectors = {
            order: ["ID", "NAME", "TAG"],
            match: {
                ID: /#((?:[\w\u00c0-\uFFFF_-]|\\.)+)/,
                CLASS: /\.((?:[\w\u00c0-\uFFFF_-]|\\.)+)/,
                NAME: /\[name=['"]*((?:[\w\u00c0-\uFFFF_-]|\\.)+)['"]*\]/,
                ATTR: /\[\s*((?:[\w\u00c0-\uFFFF_-]|\\.)+)\s*(?:(\S?=)\s*(['"]*)(.*?)\3|)\s*\]/,
                TAG: /^((?:[\w\u00c0-\uFFFF\*_-]|\\.)+)/,
                CHILD: /:(only|nth|last|first)-child(?:\((even|odd|[\dn+-]*)\))?/,
                POS: /:(nth|eq|gt|lt|first|last|even|odd)(?:\((\d*)\))?(?=[^-]|$)/,
                PSEUDO: /:((?:[\w\u00c0-\uFFFF_-]|\\.)+)(?:\((['"]*)((?:\([^\)]+\)|[^\2\(\)]*)+)\2\))?/
            },
            attrMap: {
                "class": "className",
                "for": "htmlFor"
            },
            attrHandle: {
                href: function (S) {
                    return S.getAttribute("href")
                }
            },
            relative: {
                "+": function (W, T) {
                    for (var U = 0, S = W.length; U < S; U++) {
                        var V = W[U];
                        if (V) {
                            var X = V.previousSibling;
                            while (X && X.nodeType !== 1) {
                                X = X.previousSibling
                            }
                            W[U] = typeof T === "string" ? X || false : X === T
                        }
                    }
                    if (typeof T === "string") {
                        F.filter(T, W, true)
                    }
                },
                ">": function (X, T, Y) {
                    if (typeof T === "string" && !/\W/.test(T)) {
                        T = Y ? T : T.toUpperCase();
                        for (var U = 0, S = X.length; U < S; U++) {
                            var W = X[U];
                            if (W) {
                                var V = W.parentNode;
                                X[U] = V.nodeName === T ? V : false
                            }
                        }
                    } else {
                        for (var U = 0, S = X.length; U < S; U++) {
                            var W = X[U];
                            if (W) {
                                X[U] = typeof T === "string" ? W.parentNode : W.parentNode === T
                            }
                        }
                        if (typeof T === "string") {
                            F.filter(T, X, true)
                        }
                    }
                },
                "": function (V, T, X) {
                    var U = "done" + (K++),
                        S = R;
                    if (!T.match(/\W/)) {
                        var W = T = X ? T : T.toUpperCase();
                        S = O
                    }
                    S("parentNode", T, U, V, W, X)
                },
                "~": function (V, T, X) {
                    var U = "done" + (K++),
                        S = R;
                    if (typeof T === "string" && !T.match(/\W/)) {
                        var W = T = X ? T : T.toUpperCase();
                        S = O
                    }
                    S("previousSibling", T, U, V, W, X)
                }
            },
            find: {
                ID: function (T, U, V) {
                    if (typeof U.getElementById !== "undefined" && !V) {
                        var S = U.getElementById(T[1]);
                        return S ? [S] : []
                    }
                },
                NAME: function (S, T, U) {
                    if (typeof T.getElementsByName !== "undefined" && !U) {
                        return T.getElementsByName(S[1])
                    }
                },
                TAG: function (S, T) {
                    return T.getElementsByTagName(S[1])
                }
            },
            preFilter: {
                CLASS: function (V, T, U, S, Y) {
                    V = " " + V[1].replace(/\\/g, "") + " ";
                    var X;
                    for (var W = 0;
                    (X = T[W]) != null; W++) {
                        if (X) {
                            if (Y ^ (" " + X.className + " ").indexOf(V) >= 0) {
                                if (!U) {
                                    S.push(X)
                                }
                            } else {
                                if (U) {
                                    T[W] = false
                                }
                            }
                        }
                    }
                    return false
                },
                ID: function (S) {
                    return S[1].replace(/\\/g, "")
                },
                TAG: function (T, S) {
                    for (var U = 0; S[U] === false; U++) {}
                    return S[U] && P(S[U]) ? T[1] : T[1].toUpperCase()
                },
                CHILD: function (S) {
                    if (S[1] == "nth") {
                        var T = /(-?)(\d*)n((?:\+|-)?\d*)/.exec(S[2] == "even" && "2n" || S[2] == "odd" && "2n+1" || !/\D/.test(S[2]) && "0n+" + S[2] || S[2]);
                        S[2] = (T[1] + (T[2] || 1)) - 0;
                        S[3] = T[3] - 0
                    }
                    S[0] = "done" + (K++);
                    return S
                },
                ATTR: function (T) {
                    var S = T[1].replace(/\\/g, "");
                    if (H.attrMap[S]) {
                        T[1] = H.attrMap[S]
                    }
                    if (T[2] === "~=") {
                        T[4] = " " + T[4] + " "
                    }
                    return T
                },
                PSEUDO: function (W, T, U, S, X) {
                    if (W[1] === "not") {
                        if (W[3].match(Q).length > 1) {
                            W[3] = F(W[3], null, null, T)
                        } else {
                            var V = F.filter(W[3], T, U, true ^ X);
                            if (!U) {
                                S.push.apply(S, V)
                            }
                            return false
                        }
                    } else {
                        if (H.match.POS.test(W[0])) {
                            return true
                        }
                    }
                    return W
                },
                POS: function (S) {
                    S.unshift(true);
                    return S
                }
            },
            filters: {
                enabled: function (S) {
                    return S.disabled === false && S.type !== "hidden"
                },
                disabled: function (S) {
                    return S.disabled === true
                },
                checked: function (S) {
                    return S.checked === true
                },
                selected: function (S) {
                    S.parentNode.selectedIndex;
                    return S.selected === true
                },
                parent: function (S) {
                    return !!S.firstChild
                },
                empty: function (S) {
                    return !S.firstChild
                },
                has: function (U, T, S) {
                    return !!F(S[3], U).length
                },
                header: function (S) {
                    return /h\d/i.test(S.nodeName)
                },
                text: function (S) {
                    return "text" === S.type
                },
                radio: function (S) {
                    return "radio" === S.type
                },
                checkbox: function (S) {
                    return "checkbox" === S.type
                },
                file: function (S) {
                    return "file" === S.type
                },
                password: function (S) {
                    return "password" === S.type
                },
                submit: function (S) {
                    return "submit" === S.type
                },
                image: function (S) {
                    return "image" === S.type
                },
                reset: function (S) {
                    return "reset" === S.type
                },
                button: function (S) {
                    return "button" === S.type || S.nodeName.toUpperCase() === "BUTTON"
                },
                input: function (S) {
                    return /input|select|textarea|button/i.test(S.nodeName)
                }
            },
            setFilters: {
                first: function (T, S) {
                    return S === 0
                },
                last: function (U, T, S, V) {
                    return T === V.length - 1
                },
                even: function (T, S) {
                    return S % 2 === 0
                },
                odd: function (T, S) {
                    return S % 2 === 1
                },
                lt: function (U, T, S) {
                    return T < S[3] - 0
                },
                gt: function (U, T, S) {
                    return T > S[3] - 0
                },
                nth: function (U, T, S) {
                    return S[3] - 0 == T
                },
                eq: function (U, T, S) {
                    return S[3] - 0 == T
                }
            },
            filter: {
                CHILD: function (S, V) {
                    var Y = V[1],
                        Z = S.parentNode;
                    var X = V[0];
                    if (Z && (!Z[X] || !S.nodeIndex)) {
                        var W = 1;
                        for (var T = Z.firstChild; T; T = T.nextSibling) {
                            if (T.nodeType == 1) {
                                T.nodeIndex = W++
                            }
                        }
                        Z[X] = W - 1
                    }
                    if (Y == "first") {
                        return S.nodeIndex == 1
                    } else {
                        if (Y == "last") {
                            return S.nodeIndex == Z[X]
                        } else {
                            if (Y == "only") {
                                return Z[X] == 1
                            } else {
                                if (Y == "nth") {
                                    var ab = false,
                                        U = V[2],
                                        aa = V[3];
                                    if (U == 1 && aa == 0) {
                                        return true
                                    }
                                    if (U == 0) {
                                        if (S.nodeIndex == aa) {
                                            ab = true
                                        }
                                    } else {
                                        if ((S.nodeIndex - aa) % U == 0 && (S.nodeIndex - aa) / U >= 0) {
                                            ab = true
                                        }
                                    }
                                    return ab
                                }
                            }
                        }
                    }
                },
                PSEUDO: function (Y, U, V, Z) {
                    var T = U[1],
                        W = H.filters[T];
                    if (W) {
                        return W(Y, V, U, Z)
                    } else {
                        if (T === "contains") {
                            return (Y.textContent || Y.innerText || "").indexOf(U[3]) >= 0
                        } else {
                            if (T === "not") {
                                var X = U[3];
                                for (var V = 0, S = X.length; V < S; V++) {
                                    if (X[V] === Y) {
                                        return false
                                    }
                                }
                                return true
                            }
                        }
                    }
                },
                ID: function (T, S) {
                    return T.nodeType === 1 && T.getAttribute("id") === S
                },
                TAG: function (T, S) {
                    return (S === "*" && T.nodeType === 1) || T.nodeName === S
                },
                CLASS: function (T, S) {
                    return S.test(T.className)
                },
                ATTR: function (W, U) {
                    var S = H.attrHandle[U[1]] ? H.attrHandle[U[1]](W) : W[U[1]] || W.getAttribute(U[1]),
                        X = S + "",
                        V = U[2],
                        T = U[4];
                    return S == null ? V === "!=" : V === "=" ? X === T : V === "*=" ? X.indexOf(T) >= 0 : V === "~=" ? (" " + X + " ").indexOf(T) >= 0 : !U[4] ? S : V === "!=" ? X != T : V === "^=" ? X.indexOf(T) === 0 : V === "$=" ? X.substr(X.length - T.length) === T : V === "|=" ? X === T || X.substr(0, T.length + 1) === T + "-" : false
                },
                POS: function (W, T, U, X) {
                    var S = T[2],
                        V = H.setFilters[S];
                    if (V) {
                        return V(W, U, T, X)
                    }
                }
            }
        };
        var L = H.match.POS;
        for (var N in H.match) {
            H.match[N] = RegExp(H.match[N].source + /(?![^\[]*\])(?![^\(]*\))/.source)
        }
        var E = function (T, S) {
                T = Array.prototype.slice.call(T);
                if (S) {
                    S.push.apply(S, T);
                    return S
                }
                return T
            };
        try {
            Array.prototype.slice.call(document.documentElement.childNodes)
        } catch (M) {
            E = function (W, V) {
                var T = V || [];
                if (G.call(W) === "[object Array]") {
                    Array.prototype.push.apply(T, W)
                } else {
                    if (typeof W.length === "number") {
                        for (var U = 0, S = W.length; U < S; U++) {
                            T.push(W[U])
                        }
                    } else {
                        for (var U = 0; W[U]; U++) {
                            T.push(W[U])
                        }
                    }
                }
                return T
            }
        }(function () {
            var T = document.createElement("form"),
                U = "script" + (new Date).getTime();
            T.innerHTML = "<input name='" + U + "'/>";
            var S = document.documentElement;
            S.insertBefore(T, S.firstChild);
            if ( !! document.getElementById(U)) {
                H.find.ID = function (W, X, Y) {
                    if (typeof X.getElementById !== "undefined" && !Y) {
                        var V = X.getElementById(W[1]);
                        return V ? V.id === W[1] || typeof V.getAttributeNode !== "undefined" && V.getAttributeNode("id").nodeValue === W[1] ? [V] : g : []
                    }
                };
                H.filter.ID = function (X, V) {
                    var W = typeof X.getAttributeNode !== "undefined" && X.getAttributeNode("id");
                    return X.nodeType === 1 && W && W.nodeValue === V
                }
            }
            S.removeChild(T)
        })();
        (function () {
            var S = document.createElement("div");
            S.appendChild(document.createComment(""));
            if (S.getElementsByTagName("*").length > 0) {
                H.find.TAG = function (T, X) {
                    var W = X.getElementsByTagName(T[1]);
                    if (T[1] === "*") {
                        var V = [];
                        for (var U = 0; W[U]; U++) {
                            if (W[U].nodeType === 1) {
                                V.push(W[U])
                            }
                        }
                        W = V
                    }
                    return W
                }
            }
            S.innerHTML = "<a href='#'></a>";
            if (S.firstChild && S.firstChild.getAttribute("href") !== "#") {
                H.attrHandle.href = function (T) {
                    return T.getAttribute("href", 2)
                }
            }
        })();
        if (document.querySelectorAll) {
            (function () {
                var S = F,
                    T = document.createElement("div");
                T.innerHTML = "<p class='TEST'></p>";
                if (T.querySelectorAll && T.querySelectorAll(".TEST").length === 0) {
                    return
                }
                F = function (X, W, U, V) {
                    W = W || document;
                    if (!V && W.nodeType === 9 && !P(W)) {
                        try {
                            return E(W.querySelectorAll(X), U)
                        } catch (Y) {}
                    }
                    return S(X, W, U, V)
                };
                F.find = S.find;
                F.filter = S.filter;
                F.selectors = S.selectors;
                F.matches = S.matches
            })()
        }
        if (document.getElementsByClassName && document.documentElement.getElementsByClassName) {
            H.order.splice(1, 0, "CLASS");
            H.find.CLASS = function (S, T) {
                return T.getElementsByClassName(S[1])
            }
        }
        function O(T, Z, Y, ac, aa, ab) {
            for (var W = 0, U = ac.length; W < U; W++) {
                var S = ac[W];
                if (S) {
                    S = S[T];
                    var X = false;
                    while (S && S.nodeType) {
                        var V = S[Y];
                        if (V) {
                            X = ac[V];
                            break
                        }
                        if (S.nodeType === 1 && !ab) {
                            S[Y] = W
                        }
                        if (S.nodeName === Z) {
                            X = S;
                            break
                        }
                        S = S[T]
                    }
                    ac[W] = X
                }
            }
        }
        function R(T, Y, X, ab, Z, aa) {
            for (var V = 0, U = ab.length; V < U; V++) {
                var S = ab[V];
                if (S) {
                    S = S[T];
                    var W = false;
                    while (S && S.nodeType) {
                        if (S[X]) {
                            W = ab[S[X]];
                            break
                        }
                        if (S.nodeType === 1) {
                            if (!aa) {
                                S[X] = V
                            }
                            if (typeof Y !== "string") {
                                if (S === Y) {
                                    W = true;
                                    break
                                }
                            } else {
                                if (F.filter(Y, [S]).length > 0) {
                                    W = S;
                                    break
                                }
                            }
                        }
                        S = S[T]
                    }
                    ab[V] = W
                }
            }
        }
        var J = document.compareDocumentPosition ?
        function (T, S) {
            return T.compareDocumentPosition(S) & 16
        } : function (T, S) {
            return T !== S && (T.contains ? T.contains(S) : true)
        };
        var P = function (S) {
                return S.nodeType === 9 && S.documentElement.nodeName !== "HTML" || !! S.ownerDocument && P(S.ownerDocument)
            };
        var I = function (S, Z) {
                var V = [],
                    W = "",
                    X, U = Z.nodeType ? [Z] : Z;
                while ((X = H.match.PSEUDO.exec(S))) {
                    W += X[0];
                    S = S.replace(H.match.PSEUDO, "")
                }
                S = H.relative[S] ? S + "*" : S;
                for (var Y = 0, T = U.length; Y < T; Y++) {
                    F(S, U[Y], V)
                }
                return F.filter(W, V)
            };
        o.find = F;
        o.filter = F.filter;
        o.expr = F.selectors;
        o.expr[":"] = o.expr.filters;
        F.selectors.filters.hidden = function (S) {
            return "hidden" === S.type || o.css(S, "display") === "none" || o.css(S, "visibility") === "hidden"
        };
        F.selectors.filters.visible = function (S) {
            return "hidden" !== S.type && o.css(S, "display") !== "none" && o.css(S, "visibility") !== "hidden"
        };
        F.selectors.filters.animated = function (S) {
            return o.grep(o.timers, function (T) {
                return S === T.elem
            }).length
        };
        o.multiFilter = function (U, S, T) {
            if (T) {
                U = ":not(" + U + ")"
            }
            return F.matches(U, S)
        };
        o.dir = function (U, T) {
            var S = [],
                V = U[T];
            while (V && V != document) {
                if (V.nodeType == 1) {
                    S.push(V)
                }
                V = V[T]
            }
            return S
        };
        o.nth = function (W, S, U, V) {
            S = S || 1;
            var T = 0;
            for (; W; W = W[U]) {
                if (W.nodeType == 1 && ++T == S) {
                    break
                }
            }
            return W
        };
        o.sibling = function (U, T) {
            var S = [];
            for (; U; U = U.nextSibling) {
                if (U.nodeType == 1 && U != T) {
                    S.push(U)
                }
            }
            return S
        };
        return;
        l.Sizzle = F
    })();
    o.event = {
        add: function (I, F, H, K) {
            if (I.nodeType == 3 || I.nodeType == 8) {
                return
            }
            if (I.setInterval && I != l) {
                I = l
            }
            if (!H.guid) {
                H.guid = this.guid++
            }
            if (K !== g) {
                var G = H;
                H = this.proxy(G);
                H.data = K
            }
            var E = o.data(I, "events") || o.data(I, "events", {}),
                J = o.data(I, "handle") || o.data(I, "handle", function () {
                    return typeof o !== "undefined" && !o.event.triggered ? o.event.handle.apply(arguments.callee.elem, arguments) : g
                });
            J.elem = I;
            o.each(F.split(/\s+/), function (M, N) {
                var O = N.split(".");
                N = O.shift();
                H.type = O.slice().sort().join(".");
                var L = E[N];
                if (o.event.specialAll[N]) {
                    o.event.specialAll[N].setup.call(I, K, O)
                }
                if (!L) {
                    L = E[N] = {};
                    if (!o.event.special[N] || o.event.special[N].setup.call(I, K, O) === false) {
                        if (I.addEventListener) {
                            I.addEventListener(N, J, false)
                        } else {
                            if (I.attachEvent) {
                                I.attachEvent("on" + N, J)
                            }
                        }
                    }
                }
                L[H.guid] = H;
                o.event.global[N] = true
            });
            I = null
        },
        guid: 1,
        global: {},
        remove: function (K, H, J) {
            if (K.nodeType == 3 || K.nodeType == 8) {
                return
            }
            var G = o.data(K, "events"),
                F, E;
            if (G) {
                if (H === g || (typeof H === "string" && H.charAt(0) == ".")) {
                    for (var I in G) {
                        this.remove(K, I + (H || ""))
                    }
                } else {
                    if (H.type) {
                        J = H.handler;
                        H = H.type
                    }
                    o.each(H.split(/\s+/), function (M, O) {
                        var Q = O.split(".");
                        O = Q.shift();
                        var N = RegExp("(^|\\.)" + Q.slice().sort().join(".*\\.") + "(\\.|$)");
                        if (G[O]) {
                            if (J) {
                                delete G[O][J.guid]
                            } else {
                                for (var P in G[O]) {
                                    if (N.test(G[O][P].type)) {
                                        delete G[O][P]
                                    }
                                }
                            }
                            if (o.event.specialAll[O]) {
                                o.event.specialAll[O].teardown.call(K, Q)
                            }
                            for (F in G[O]) {
                                break
                            }
                            if (!F) {
                                if (!o.event.special[O] || o.event.special[O].teardown.call(K, Q) === false) {
                                    if (K.removeEventListener) {
                                        K.removeEventListener(O, o.data(K, "handle"), false)
                                    } else {
                                        if (K.detachEvent) {
                                            K.detachEvent("on" + O, o.data(K, "handle"))
                                        }
                                    }
                                }
                                F = null;
                                delete G[O]
                            }
                        }
                    })
                }
                for (F in G) {
                    break
                }
                if (!F) {
                    var L = o.data(K, "handle");
                    if (L) {
                        L.elem = null
                    }
                    o.removeData(K, "events");
                    o.removeData(K, "handle")
                }
            }
        },
        trigger: function (I, K, H, E) {
            var G = I.type || I;
            if (!E) {
                I = typeof I === "object" ? I[h] ? I : o.extend(o.Event(G), I) : o.Event(G);
                if (G.indexOf("!") >= 0) {
                    I.type = G = G.slice(0, -1);
                    I.exclusive = true
                }
                if (!H) {
                    I.stopPropagation();
                    if (this.global[G]) {
                        o.each(o.cache, function () {
                            if (this.events && this.events[G]) {
                                o.event.trigger(I, K, this.handle.elem)
                            }
                        })
                    }
                }
                if (!H || H.nodeType == 3 || H.nodeType == 8) {
                    return g
                }
                I.result = g;
                I.target = H;
                K = o.makeArray(K);
                K.unshift(I)
            }
            I.currentTarget = H;
            var J = o.data(H, "handle");
            if (J) {
                J.apply(H, K)
            }
            if ((!H[G] || (o.nodeName(H, "a") && G == "click")) && H["on" + G] && H["on" + G].apply(H, K) === false) {
                I.result = false
            }
            if (!E && H[G] && !I.isDefaultPrevented() && !(o.nodeName(H, "a") && G == "click")) {
                this.triggered = true;
                try {
                    H[G]()
                } catch (L) {}
            }
            this.triggered = false;
            if (!I.isPropagationStopped()) {
                var F = H.parentNode || H.ownerDocument;
                if (F) {
                    o.event.trigger(I, K, F, true)
                }
            }
        },
        handle: function (K) {
            var J, E;
            K = arguments[0] = o.event.fix(K || l.event);
            var L = K.type.split(".");
            K.type = L.shift();
            J = !L.length && !K.exclusive;
            var I = RegExp("(^|\\.)" + L.slice().sort().join(".*\\.") + "(\\.|$)");
            E = (o.data(this, "events") || {})[K.type];
            for (var G in E) {
                var H = E[G];
                if (J || I.test(H.type)) {
                    K.handler = H;
                    K.data = H.data;
                    var F = H.apply(this, arguments);
                    if (F !== g) {
                        K.result = F;
                        if (F === false) {
                            K.preventDefault();
                            K.stopPropagation()
                        }
                    }
                    if (K.isImmediatePropagationStopped()) {
                        break
                    }
                }
            }
        },
        props: "altKey attrChange attrName bubbles button cancelable charCode clientX clientY ctrlKey currentTarget data detail eventPhase fromElement handler keyCode metaKey newValue originalTarget pageX pageY prevValue relatedNode relatedTarget screenX screenY shiftKey srcElement target toElement view wheelDelta which".split(" "),
        fix: function (H) {
            if (H[h]) {
                return H
            }
            var F = H;
            H = o.Event(F);
            for (var G = this.props.length, J; G;) {
                J = this.props[--G];
                H[J] = F[J]
            }
            if (!H.target) {
                H.target = H.srcElement || document
            }
            if (H.target.nodeType == 3) {
                H.target = H.target.parentNode
            }
            if (!H.relatedTarget && H.fromElement) {
                H.relatedTarget = H.fromElement == H.target ? H.toElement : H.fromElement
            }
            if (H.pageX == null && H.clientX != null) {
                var I = document.documentElement,
                    E = document.body;
                H.pageX = H.clientX + (I && I.scrollLeft || E && E.scrollLeft || 0) - (I.clientLeft || 0);
                H.pageY = H.clientY + (I && I.scrollTop || E && E.scrollTop || 0) - (I.clientTop || 0)
            }
            if (!H.which && ((H.charCode || H.charCode === 0) ? H.charCode : H.keyCode)) {
                H.which = H.charCode || H.keyCode
            }
            if (!H.metaKey && H.ctrlKey) {
                H.metaKey = H.ctrlKey
            }
            if (!H.which && H.button) {
                H.which = (H.button & 1 ? 1 : (H.button & 2 ? 3 : (H.button & 4 ? 2 : 0)))
            }
            return H
        },
        proxy: function (F, E) {
            E = E ||
            function () {
                return F.apply(this, arguments)
            };
            E.guid = F.guid = F.guid || E.guid || this.guid++;
            return E
        },
        special: {
            ready: {
                setup: B,
                teardown: function () {}
            }
        },
        specialAll: {
            live: {
                setup: function (E, F) {
                    o.event.add(this, F[0], c)
                },
                teardown: function (G) {
                    if (G.length) {
                        var E = 0,
                            F = RegExp("(^|\\.)" + G[0] + "(\\.|$)");
                        o.each((o.data(this, "events").live || {}), function () {
                            if (F.test(this.type)) {
                                E++
                            }
                        });
                        if (E < 1) {
                            o.event.remove(this, G[0], c)
                        }
                    }
                }
            }
        }
    };
    o.Event = function (E) {
        if (!this.preventDefault) {
            return new o.Event(E)
        }
        if (E && E.type) {
            this.originalEvent = E;
            this.type = E.type
        } else {
            this.type = E
        }
        this.timeStamp = e();
        this[h] = true
    };

    function k() {
        return false
    }
    function u() {
        return true
    }
    o.Event.prototype = {
        preventDefault: function () {
            this.isDefaultPrevented = u;
            var E = this.originalEvent;
            if (!E) {
                return
            }
            if (E.preventDefault) {
                E.preventDefault()
            }
            E.returnValue = false
        },
        stopPropagation: function () {
            this.isPropagationStopped = u;
            var E = this.originalEvent;
            if (!E) {
                return
            }
            if (E.stopPropagation) {
                E.stopPropagation()
            }
            E.cancelBubble = true
        },
        stopImmediatePropagation: function () {
            this.isImmediatePropagationStopped = u;
            this.stopPropagation()
        },
        isDefaultPrevented: k,
        isPropagationStopped: k,
        isImmediatePropagationStopped: k
    };
    var a = function (F) {
            var E = F.relatedTarget;
            while (E && E != this) {
                try {
                    E = E.parentNode
                } catch (G) {
                    E = this
                }
            }
            if (E != this) {
                F.type = F.data;
                o.event.handle.apply(this, arguments)
            }
        };
    o.each({
        mouseover: "mouseenter",
        mouseout: "mouseleave"
    }, function (F, E) {
        o.event.special[E] = {
            setup: function () {
                o.event.add(this, F, a, E)
            },
            teardown: function () {
                o.event.remove(this, F, a)
            }
        }
    });
    o.fn.extend({
        bind: function (F, G, E) {
            return F == "unload" ? this.one(F, G, E) : this.each(function () {
                o.event.add(this, F, E || G, E && G)
            })
        },
        one: function (G, H, F) {
            var E = o.event.proxy(F || H, function (I) {
                o(this).unbind(I, E);
                return (F || H).apply(this, arguments)
            });
            return this.each(function () {
                o.event.add(this, G, E, F && H)
            })
        },
        unbind: function (F, E) {
            return this.each(function () {
                o.event.remove(this, F, E)
            })
        },
        trigger: function (E, F) {
            return this.each(function () {
                o.event.trigger(E, F, this)
            })
        },
        triggerHandler: function (E, G) {
            if (this[0]) {
                var F = o.Event(E);
                F.preventDefault();
                F.stopPropagation();
                o.event.trigger(F, G, this[0]);
                return F.result
            }
        },
        toggle: function (G) {
            var E = arguments,
                F = 1;
            while (F < E.length) {
                o.event.proxy(G, E[F++])
            }
            return this.click(o.event.proxy(G, function (H) {
                this.lastToggle = (this.lastToggle || 0) % F;
                H.preventDefault();
                return E[this.lastToggle++].apply(this, arguments) || false
            }))
        },
        hover: function (E, F) {
            return this.mouseenter(E).mouseleave(F)
        },
        ready: function (E) {
            B();
            if (o.isReady) {
                E.call(document, o)
            } else {
                o.readyList.push(E)
            }
            return this
        },
        live: function (G, F) {
            var E = o.event.proxy(F);
            E.guid += this.selector + G;
            o(document).bind(i(G, this.selector), this.selector, E);
            return this
        },
        die: function (F, E) {
            o(document).unbind(i(F, this.selector), E ? {
                guid: E.guid + this.selector + F
            } : null);
            return this
        }
    });

    function c(H) {
        var E = RegExp("(^|\\.)" + H.type + "(\\.|$)"),
            G = true,
            F = [];
        o.each(o.data(this, "events").live || [], function (I, J) {
            if (E.test(J.type)) {
                var K = o(H.target).closest(J.data)[0];
                if (K) {
                    F.push({
                        elem: K,
                        fn: J
                    })
                }
            }
        });
        o.each(F, function () {
            if (this.fn.call(this.elem, H, this.fn.data) === false) {
                G = false
            }
        });
        return G
    }
    function i(F, E) {
        return ["live", F, E.replace(/\./g, "`").replace(/ /g, "|")].join(".")
    }
    o.extend({
        isReady: false,
        readyList: [],
        ready: function () {
            if (!o.isReady) {
                o.isReady = true;
                if (o.readyList) {
                    o.each(o.readyList, function () {
                        this.call(document, o)
                    });
                    o.readyList = null
                }
                o(document).triggerHandler("ready")
            }
        }
    });
    var x = false;

    function B() {
        if (x) {
            return
        }
        x = true;
        if (document.addEventListener) {
            document.addEventListener("DOMContentLoaded", function () {
                document.removeEventListener("DOMContentLoaded", arguments.callee, false);
                o.ready()
            }, false)
        } else {
            if (document.attachEvent) {
                document.attachEvent("onreadystatechange", function () {
                    if (document.readyState === "complete") {
                        document.detachEvent("onreadystatechange", arguments.callee);
                        o.ready()
                    }
                });
                if (document.documentElement.doScroll && typeof l.frameElement === "undefined") {
                    (function () {
                        if (o.isReady) {
                            return
                        }
                        try {
                            document.documentElement.doScroll("left")
                        } catch (E) {
                            setTimeout(arguments.callee, 0);
                            return
                        }
                        o.ready()
                    })()
                }
            }
        }
        o.event.add(l, "load", o.ready)
    }
    o.each(("blur,focus,load,resize,scroll,unload,click,dblclick,mousedown,mouseup,mousemove,mouseover,mouseout,mouseenter,mouseleave,change,select,submit,keydown,keypress,keyup,error").split(","), function (F, E) {
        o.fn[E] = function (G) {
            return G ? this.bind(E, G) : this.trigger(E)
        }
    });
    o(l).bind("unload", function () {
        for (var E in o.cache) {
            if (E != 1 && o.cache[E].handle) {
                o.event.remove(o.cache[E].handle.elem)
            }
        }
    });
    (function () {
        o.support = {};
        var F = document.documentElement,
            G = document.createElement("script"),
            K = document.createElement("div"),
            J = "script" + (new Date).getTime();
        K.style.display = "none";
        K.innerHTML = '   <link/><table></table><a href="/a" style="color:red;float:left;opacity:.5;">a</a><select><option>text</option></select><object><param/></object>';
        var H = K.getElementsByTagName("*"),
            E = K.getElementsByTagName("a")[0];
        if (!H || !H.length || !E) {
            return
        }
        o.support = {
            leadingWhitespace: K.firstChild.nodeType == 3,
            tbody: !K.getElementsByTagName("tbody").length,
            objectAll: !! K.getElementsByTagName("object")[0].getElementsByTagName("*").length,
            htmlSerialize: !! K.getElementsByTagName("link").length,
            style: /red/.test(E.getAttribute("style")),
            hrefNormalized: E.getAttribute("href") === "/a",
            opacity: E.style.opacity === "0.5",
            cssFloat: !! E.style.cssFloat,
            scriptEval: false,
            noCloneEvent: true,
            boxModel: null
        };
        G.type = "text/javascript";
        try {
            G.appendChild(document.createTextNode("window." + J + "=1;"))
        } catch (I) {}
        F.insertBefore(G, F.firstChild);
        if (l[J]) {
            o.support.scriptEval = true;
            delete l[J]
        }
        F.removeChild(G);
        if (K.attachEvent && K.fireEvent) {
            K.attachEvent("onclick", function () {
                o.support.noCloneEvent = false;
                K.detachEvent("onclick", arguments.callee)
            });
            K.cloneNode(true).fireEvent("onclick")
        }
        o(function () {
            var L = document.createElement("div");
            L.style.width = "1px";
            L.style.paddingLeft = "1px";
            document.body.appendChild(L);
            o.boxModel = o.support.boxModel = L.offsetWidth === 2;
            document.body.removeChild(L)
        })
    })();
    var w = o.support.cssFloat ? "cssFloat" : "styleFloat";
    o.props = {
        "for": "htmlFor",
        "class": "className",
        "float": w,
        cssFloat: w,
        styleFloat: w,
        readonly: "readOnly",
        maxlength: "maxLength",
        cellspacing: "cellSpacing",
        rowspan: "rowSpan",
        tabindex: "tabIndex"
    };
    o.fn.extend({
        _load: o.fn.load,
        load: function (G, J, K) {
            if (typeof G !== "string") {
                return this._load(G)
            }
            var I = G.indexOf(" ");
            if (I >= 0) {
                var E = G.slice(I, G.length);
                G = G.slice(0, I)
            }
            var H = "GET";
            if (J) {
                if (o.isFunction(J)) {
                    K = J;
                    J = null
                } else {
                    if (typeof J === "object") {
                        J = o.param(J);
                        H = "POST"
                    }
                }
            }
            var F = this;
            o.ajax({
                url: G,
                type: H,
                dataType: "html",
                data: J,
                complete: function (M, L) {
                    if (L == "success" || L == "notmodified") {
                        F.html(E ? o("<div/>").append(M.responseText.replace(/<script(.|\s)*?\/script>/g, "")).find(E) : M.responseText)
                    }
                    if (K) {
                        F.each(K, [M.responseText, L, M])
                    }
                }
            });
            return this
        },
        serialize: function () {
            return o.param(this.serializeArray())
        },
        serializeArray: function () {
            return this.map(function () {
                return this.elements ? o.makeArray(this.elements) : this
            }).filter(function () {
                return this.name && !this.disabled && (this.checked || /select|textarea/i.test(this.nodeName) || /text|hidden|password/i.test(this.type))
            }).map(function (E, F) {
                var G = o(this).val();
                return G == null ? null : o.isArray(G) ? o.map(G, function (I, H) {
                    return {
                        name: F.name,
                        value: I
                    }
                }) : {
                    name: F.name,
                    value: G
                }
            }).get()
        }
    });
    o.each("ajaxStart,ajaxStop,ajaxComplete,ajaxError,ajaxSuccess,ajaxSend".split(","), function (E, F) {
        o.fn[F] = function (G) {
            return this.bind(F, G)
        }
    });
    var r = e();
    o.extend({
        get: function (E, G, H, F) {
            if (o.isFunction(G)) {
                H = G;
                G = null
            }
            return o.ajax({
                type: "GET",
                url: E,
                data: G,
                success: H,
                dataType: F
            })
        },
        getScript: function (E, F) {
            return o.get(E, null, F, "script")
        },
        getJSON: function (E, F, G) {
            return o.get(E, F, G, "json")
        },
        post: function (E, G, H, F) {
            if (o.isFunction(G)) {
                H = G;
                G = {}
            }
            return o.ajax({
                type: "POST",
                url: E,
                data: G,
                success: H,
                dataType: F
            })
        },
        ajaxSetup: function (E) {
            o.extend(o.ajaxSettings, E)
        },
        ajaxSettings: {
            url: location.href,
            global: true,
            type: "GET",
            contentType: "application/x-www-form-urlencoded",
            processData: true,
            async: true,
            xhr: function () {
                return l.ActiveXObject ? new ActiveXObject("Microsoft.XMLHTTP") : new XMLHttpRequest()
            },
            accepts: {
                xml: "application/xml, text/xml",
                html: "text/html",
                script: "text/javascript, application/javascript",
                json: "application/json, text/javascript",
                text: "text/plain",
                _default: "*/*"
            }
        },
        lastModified: {},
        ajax: function (M) {
            M = o.extend(true, M, o.extend(true, {}, o.ajaxSettings, M));
            var W, F = /=\?(&|$)/g,
                R, V, G = M.type.toUpperCase();
            if (M.data && M.processData && typeof M.data !== "string") {
                M.data = o.param(M.data)
            }
            if (M.dataType == "jsonp") {
                if (G == "GET") {
                    if (!M.url.match(F)) {
                        M.url += (M.url.match(/\?/) ? "&" : "?") + (M.jsonp || "callback") + "=?"
                    }
                } else {
                    if (!M.data || !M.data.match(F)) {
                        M.data = (M.data ? M.data + "&" : "") + (M.jsonp || "callback") + "=?"
                    }
                }
                M.dataType = "json"
            }
            if (M.dataType == "json" && (M.data && M.data.match(F) || M.url.match(F))) {
                W = "jsonp" + r++;
                if (M.data) {
                    M.data = (M.data + "").replace(F, "=" + W + "$1")
                }
                M.url = M.url.replace(F, "=" + W + "$1");
                M.dataType = "script";
                l[W] = function (X) {
                    V = X;
                    I();
                    L();
                    l[W] = g;
                    try {
                        delete l[W]
                    } catch (Y) {}
                    if (H) {
                        H.removeChild(T)
                    }
                }
            }
            if (M.dataType == "script" && M.cache == null) {
                M.cache = false
            }
            if (M.cache === false && G == "GET") {
                var E = e();
                var U = M.url.replace(/(\?|&)_=.*?(&|$)/, "$1_=" + E + "$2");
                M.url = U + ((U == M.url) ? (M.url.match(/\?/) ? "&" : "?") + "_=" + E : "")
            }
            if (M.data && G == "GET") {
                M.url += (M.url.match(/\?/) ? "&" : "?") + M.data;
                M.data = null
            }
            if (M.global && !o.active++) {
                o.event.trigger("ajaxStart")
            }
            var Q = /^(\w+:)?\/\/([^\/?#]+)/.exec(M.url);
            if (M.dataType == "script" && G == "GET" && Q && (Q[1] && Q[1] != location.protocol || Q[2] != location.host)) {
                var H = document.getElementsByTagName("head")[0];
                var T = document.createElement("script");
                T.src = M.url;
                if (M.scriptCharset) {
                    T.charset = M.scriptCharset
                }
                if (!W) {
                    var O = false;
                    T.onload = T.onreadystatechange = function () {
                        if (!O && (!this.readyState || this.readyState == "loaded" || this.readyState == "complete")) {
                            O = true;
                            I();
                            L();
                            H.removeChild(T)
                        }
                    }
                }
                H.appendChild(T);
                return g
            }
            var K = false;
            var J = M.xhr();
            if (M.username) {
                J.open(G, M.url, M.async, M.username, M.password)
            } else {
                J.open(G, M.url, M.async)
            }
            try {
                if (M.data) {
                    J.setRequestHeader("Content-Type", M.contentType)
                }
                if (M.ifModified) {
                    J.setRequestHeader("If-Modified-Since", o.lastModified[M.url] || "Thu, 01 Jan 1970 00:00:00 GMT")
                }
                J.setRequestHeader("X-Requested-With", "XMLHttpRequest");
                J.setRequestHeader("Accept", M.dataType && M.accepts[M.dataType] ? M.accepts[M.dataType] + ", */*" : M.accepts._default)
            } catch (S) {}
            if (M.beforeSend && M.beforeSend(J, M) === false) {
                if (M.global && !--o.active) {
                    o.event.trigger("ajaxStop")
                }
                J.abort();
                return false
            }
            if (M.global) {
                o.event.trigger("ajaxSend", [J, M])
            }
            var N = function (X) {
                    if (J.readyState == 0) {
                        if (P) {
                            clearInterval(P);
                            P = null;
                            if (M.global && !--o.active) {
                                o.event.trigger("ajaxStop")
                            }
                        }
                    } else {
                        if (!K && J && (J.readyState == 4 || X == "timeout")) {
                            K = true;
                            if (P) {
                                clearInterval(P);
                                P = null
                            }
                            R = X == "timeout" ? "timeout" : !o.httpSuccess(J) ? "error" : M.ifModified && o.httpNotModified(J, M.url) ? "notmodified" : "success";
                            if (R == "success") {
                                try {
                                    V = o.httpData(J, M.dataType, M)
                                } catch (Z) {
                                    R = "parsererror"
                                }
                            }
                            if (R == "success") {
                                var Y;
                                try {
                                    Y = J.getResponseHeader("Last-Modified")
                                } catch (Z) {}
                                if (M.ifModified && Y) {
                                    o.lastModified[M.url] = Y
                                }
                                if (!W) {
                                    I()
                                }
                            } else {
                                o.handleError(M, J, R)
                            }
                            L();
                            if (X) {
                                J.abort()
                            }
                            if (M.async) {
                                J = null
                            }
                        }
                    }
                };
            if (M.async) {
                var P = setInterval(N, 13);
                if (M.timeout > 0) {
                    setTimeout(function () {
                        if (J && !K) {
                            N("timeout")
                        }
                    }, M.timeout)
                }
            }
            try {
                J.send(M.data)
            } catch (S) {
                o.handleError(M, J, null, S)
            }
            if (!M.async) {
                N()
            }
            function I() {
                if (M.success) {
                    M.success(V, R)
                }
                if (M.global) {
                    o.event.trigger("ajaxSuccess", [J, M])
                }
            }
            function L() {
                if (M.complete) {
                    M.complete(J, R)
                }
                if (M.global) {
                    o.event.trigger("ajaxComplete", [J, M])
                }
                if (M.global && !--o.active) {
                    o.event.trigger("ajaxStop")
                }
            }
            return J
        },
        handleError: function (F, H, E, G) {
            if (F.error) {
                F.error(H, E, G)
            }
            if (F.global) {
                o.event.trigger("ajaxError", [H, F, G])
            }
        },
        active: 0,
        httpSuccess: function (F) {
            try {
                return !F.status && location.protocol == "file:" || (F.status >= 200 && F.status < 300) || F.status == 304 || F.status == 1223
            } catch (E) {}
            return false
        },
        httpNotModified: function (G, E) {
            try {
                var H = G.getResponseHeader("Last-Modified");
                return G.status == 304 || H == o.lastModified[E]
            } catch (F) {}
            return false
        },
        httpData: function (J, H, G) {
            var F = J.getResponseHeader("content-type"),
                E = H == "xml" || !H && F && F.indexOf("xml") >= 0,
                I = E ? J.responseXML : J.responseText;
            if (E && I.documentElement.tagName == "parsererror") {
                throw "parsererror"
            }
            if (G && G.dataFilter) {
                I = G.dataFilter(I, H)
            }
            if (typeof I === "string") {
                if (H == "script") {
                    o.globalEval(I)
                }
                if (H == "json") {
                    I = l["eval"]("(" + I + ")")
                }
            }
            return I
        },
        param: function (E) {
            var G = [];

            function H(I, J) {
                G[G.length] = encodeURIComponent(I) + "=" + encodeURIComponent(J)
            }
            if (o.isArray(E) || E.jquery) {
                o.each(E, function () {
                    H(this.name, this.value)
                })
            } else {
                for (var F in E) {
                    if (o.isArray(E[F])) {
                        o.each(E[F], function () {
                            H(F, this)
                        })
                    } else {
                        H(F, o.isFunction(E[F]) ? E[F]() : E[F])
                    }
                }
            }
            return G.join("&").replace(/%20/g, "+")
        }
    });
    var m = {},
        n, d = [
            ["height", "marginTop", "marginBottom", "paddingTop", "paddingBottom"],
            ["width", "marginLeft", "marginRight", "paddingLeft", "paddingRight"],
            ["opacity"]
        ];

    function t(F, E) {
        var G = {};
        o.each(d.concat.apply([], d.slice(0, E)), function () {
            G[this] = F
        });
        return G
    }
    o.fn.extend({
        show: function (J, L) {
            if (J) {
                return this.animate(t("show", 3), J, L)
            } else {
                for (var H = 0, F = this.length; H < F; H++) {
                    var E = o.data(this[H], "olddisplay");
                    this[H].style.display = E || "";
                    if (o.css(this[H], "display") === "none") {
                        var G = this[H].tagName,
                            K;
                        if (m[G]) {
                            K = m[G]
                        } else {
                            var I = o("<" + G + " />").appendTo("body");
                            K = I.css("display");
                            if (K === "none") {
                                K = "block"
                            }
                            I.remove();
                            m[G] = K
                        }
                        this[H].style.display = o.data(this[H], "olddisplay", K)
                    }
                }
                return this
            }
        },
        hide: function (H, I) {
            if (H) {
                return this.animate(t("hide", 3), H, I)
            } else {
                for (var G = 0, F = this.length; G < F; G++) {
                    var E = o.data(this[G], "olddisplay");
                    if (!E && E !== "none") {
                        o.data(this[G], "olddisplay", o.css(this[G], "display"))
                    }
                    this[G].style.display = "none"
                }
                return this
            }
        },
        _toggle: o.fn.toggle,
        toggle: function (G, F) {
            var E = typeof G === "boolean";
            return o.isFunction(G) && o.isFunction(F) ? this._toggle.apply(this, arguments) : G == null || E ? this.each(function () {
                var H = E ? G : o(this).is(":hidden");
                o(this)[H ? "show" : "hide"]()
            }) : this.animate(t("toggle", 3), G, F)
        },
        fadeTo: function (E, G, F) {
            return this.animate({
                opacity: G
            }, E, F)
        },
        animate: function (I, F, H, G) {
            var E = o.speed(F, H, G);
            return this[E.queue === false ? "each" : "queue"](function () {
                var K = o.extend({}, E),
                    M, L = this.nodeType == 1 && o(this).is(":hidden"),
                    J = this;
                for (M in I) {
                    if (I[M] == "hide" && L || I[M] == "show" && !L) {
                        return K.complete.call(this)
                    }
                    if ((M == "height" || M == "width") && this.style) {
                        K.display = o.css(this, "display");
                        K.overflow = this.style.overflow
                    }
                }
                if (K.overflow != null) {
                    this.style.overflow = "hidden"
                }
                K.curAnim = o.extend({}, I);
                o.each(I, function (O, S) {
                    var R = new o.fx(J, K, O);
                    if (/toggle|show|hide/.test(S)) {
                        R[S == "toggle" ? L ? "show" : "hide" : S](I)
                    } else {
                        var Q = S.toString().match(/^([+-]=)?([\d+-.]+)(.*)$/),
                            T = R.cur(true) || 0;
                        if (Q) {
                            var N = parseFloat(Q[2]),
                                P = Q[3] || "px";
                            if (P != "px") {
                                J.style[O] = (N || 1) + P;
                                T = ((N || 1) / R.cur(true)) * T;
                                J.style[O] = T + P
                            }
                            if (Q[1]) {
                                N = ((Q[1] == "-=" ? -1 : 1) * N) + T
                            }
                            R.custom(T, N, P)
                        } else {
                            R.custom(T, S, "")
                        }
                    }
                });
                return true
            })
        },
        stop: function (F, E) {
            var G = o.timers;
            if (F) {
                this.queue([])
            }
            this.each(function () {
                for (var H = G.length - 1; H >= 0; H--) {
                    if (G[H].elem == this) {
                        if (E) {
                            G[H](true)
                        }
                        G.splice(H, 1)
                    }
                }
            });
            if (!E) {
                this.dequeue()
            }
            return this
        }
    });
    o.each({
        slideDown: t("show", 1),
        slideUp: t("hide", 1),
        slideToggle: t("toggle", 1),
        fadeIn: {
            opacity: "show"
        },
        fadeOut: {
            opacity: "hide"
        }
    }, function (E, F) {
        o.fn[E] = function (G, H) {
            return this.animate(F, G, H)
        }
    });
    o.extend({
        speed: function (G, H, F) {
            var E = typeof G === "object" ? G : {
                complete: F || !F && H || o.isFunction(G) && G,
                duration: G,
                easing: F && H || H && !o.isFunction(H) && H
            };
            E.duration = o.fx.off ? 0 : typeof E.duration === "number" ? E.duration : o.fx.speeds[E.duration] || o.fx.speeds._default;
            E.old = E.complete;
            E.complete = function () {
                if (E.queue !== false) {
                    o(this).dequeue()
                }
                if (o.isFunction(E.old)) {
                    E.old.call(this)
                }
            };
            return E
        },
        easing: {
            linear: function (G, H, E, F) {
                return E + F * G
            },
            swing: function (G, H, E, F) {
                return ((-Math.cos(G * Math.PI) / 2) + 0.5) * F + E
            }
        },
        timers: [],
        fx: function (F, E, G) {
            this.options = E;
            this.elem = F;
            this.prop = G;
            if (!E.orig) {
                E.orig = {}
            }
        }
    });
    o.fx.prototype = {
        update: function () {
            if (this.options.step) {
                this.options.step.call(this.elem, this.now, this)
            }(o.fx.step[this.prop] || o.fx.step._default)(this);
            if ((this.prop == "height" || this.prop == "width") && this.elem.style) {
                this.elem.style.display = "block"
            }
        },
        cur: function (F) {
            if (this.elem[this.prop] != null && (!this.elem.style || this.elem.style[this.prop] == null)) {
                return this.elem[this.prop]
            }
            var E = parseFloat(o.css(this.elem, this.prop, F));
            return E && E > -10000 ? E : parseFloat(o.curCSS(this.elem, this.prop)) || 0
        },
        custom: function (I, H, G) {
            this.startTime = e();
            this.start = I;
            this.end = H;
            this.unit = G || this.unit || "px";
            this.now = this.start;
            this.pos = this.state = 0;
            var E = this;

            function F(J) {
                return E.step(J)
            }
            F.elem = this.elem;
            if (F() && o.timers.push(F) == 1) {
                n = setInterval(function () {
                    var K = o.timers;
                    for (var J = 0; J < K.length; J++) {
                        if (!K[J]()) {
                            K.splice(J--, 1)
                        }
                    }
                    if (!K.length) {
                        clearInterval(n)
                    }
                }, 13)
            }
        },
        show: function () {
            this.options.orig[this.prop] = o.attr(this.elem.style, this.prop);
            this.options.show = true;
            this.custom(this.prop == "width" || this.prop == "height" ? 1 : 0, this.cur());
            o(this.elem).show()
        },
        hide: function () {
            this.options.orig[this.prop] = o.attr(this.elem.style, this.prop);
            this.options.hide = true;
            this.custom(this.cur(), 0)
        },
        step: function (H) {
            var G = e();
            if (H || G >= this.options.duration + this.startTime) {
                this.now = this.end;
                this.pos = this.state = 1;
                this.update();
                this.options.curAnim[this.prop] = true;
                var E = true;
                for (var F in this.options.curAnim) {
                    if (this.options.curAnim[F] !== true) {
                        E = false
                    }
                }
                if (E) {
                    if (this.options.display != null) {
                        this.elem.style.overflow = this.options.overflow;
                        this.elem.style.display = this.options.display;
                        if (o.css(this.elem, "display") == "none") {
                            this.elem.style.display = "block"
                        }
                    }
                    if (this.options.hide) {
                        o(this.elem).hide()
                    }
                    if (this.options.hide || this.options.show) {
                        for (var I in this.options.curAnim) {
                            o.attr(this.elem.style, I, this.options.orig[I])
                        }
                    }
                    this.options.complete.call(this.elem)
                }
                return false
            } else {
                var J = G - this.startTime;
                this.state = J / this.options.duration;
                this.pos = o.easing[this.options.easing || (o.easing.swing ? "swing" : "linear")](this.state, J, 0, 1, this.options.duration);
                this.now = this.start + ((this.end - this.start) * this.pos);
                this.update()
            }
            return true
        }
    };
    o.extend(o.fx, {
        speeds: {
            slow: 600,
            fast: 200,
            _default: 400
        },
        step: {
            opacity: function (E) {
                o.attr(E.elem.style, "opacity", E.now)
            },
            _default: function (E) {
                if (E.elem.style && E.elem.style[E.prop] != null) {
                    E.elem.style[E.prop] = E.now + E.unit
                } else {
                    E.elem[E.prop] = E.now
                }
            }
        }
    });
    if (document.documentElement.getBoundingClientRect) {
        o.fn.offset = function () {
            if (!this[0]) {
                return {
                    top: 0,
                    left: 0
                }
            }
            if (this[0] === this[0].ownerDocument.body) {
                return o.offset.bodyOffset(this[0])
            }
            var G = this[0].getBoundingClientRect(),
                J = this[0].ownerDocument,
                F = J.body,
                E = J.documentElement,
                L = E.clientTop || F.clientTop || 0,
                K = E.clientLeft || F.clientLeft || 0,
                I = G.top + (self.pageYOffset || o.boxModel && E.scrollTop || F.scrollTop) - L,
                H = G.left + (self.pageXOffset || o.boxModel && E.scrollLeft || F.scrollLeft) - K;
            return {
                top: I,
                left: H
            }
        }
    } else {
        o.fn.offset = function () {
            if (!this[0]) {
                return {
                    top: 0,
                    left: 0
                }
            }
            if (this[0] === this[0].ownerDocument.body) {
                return o.offset.bodyOffset(this[0])
            }
            o.offset.initialized || o.offset.initialize();
            var J = this[0],
                G = J.offsetParent,
                F = J,
                O = J.ownerDocument,
                M, H = O.documentElement,
                K = O.body,
                L = O.defaultView,
                E = L.getComputedStyle(J, null),
                N = J.offsetTop,
                I = J.offsetLeft;
            while ((J = J.parentNode) && J !== K && J !== H) {
                M = L.getComputedStyle(J, null);
                N -= J.scrollTop, I -= J.scrollLeft;
                if (J === G) {
                    N += J.offsetTop, I += J.offsetLeft;
                    if (o.offset.doesNotAddBorder && !(o.offset.doesAddBorderForTableAndCells && /^t(able|d|h)$/i.test(J.tagName))) {
                        N += parseInt(M.borderTopWidth, 10) || 0, I += parseInt(M.borderLeftWidth, 10) || 0
                    }
                    F = G, G = J.offsetParent
                }
                if (o.offset.subtractsBorderForOverflowNotVisible && M.overflow !== "visible") {
                    N += parseInt(M.borderTopWidth, 10) || 0, I += parseInt(M.borderLeftWidth, 10) || 0
                }
                E = M
            }
            if (E.position === "relative" || E.position === "static") {
                N += K.offsetTop, I += K.offsetLeft
            }
            if (E.position === "fixed") {
                N += Math.max(H.scrollTop, K.scrollTop), I += Math.max(H.scrollLeft, K.scrollLeft)
            }
            return {
                top: N,
                left: I
            }
        }
    }
    o.offset = {
        initialize: function () {
            if (this.initialized) {
                return
            }
            var L = document.body,
                F = document.createElement("div"),
                H, G, N, I, M, E, J = L.style.marginTop,
                K = '<div style="position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;"><div></div></div><table style="position:absolute;top:0;left:0;margin:0;border:5px solid #000;padding:0;width:1px;height:1px;" cellpadding="0" cellspacing="0"><tr><td></td></tr></table>';
            M = {
                position: "absolute",
                top: 0,
                left: 0,
                margin: 0,
                border: 0,
                width: "1px",
                height: "1px",
                visibility: "hidden"
            };
            for (E in M) {
                F.style[E] = M[E]
            }
            F.innerHTML = K;
            L.insertBefore(F, L.firstChild);
            H = F.firstChild, G = H.firstChild, I = H.nextSibling.firstChild.firstChild;
            this.doesNotAddBorder = (G.offsetTop !== 5);
            this.doesAddBorderForTableAndCells = (I.offsetTop === 5);
            H.style.overflow = "hidden", H.style.position = "relative";
            this.subtractsBorderForOverflowNotVisible = (G.offsetTop === -5);
            L.style.marginTop = "1px";
            this.doesNotIncludeMarginInBodyOffset = (L.offsetTop === 0);
            L.style.marginTop = J;
            L.removeChild(F);
            this.initialized = true
        },
        bodyOffset: function (E) {
            o.offset.initialized || o.offset.initialize();
            var G = E.offsetTop,
                F = E.offsetLeft;
            if (o.offset.doesNotIncludeMarginInBodyOffset) {
                G += parseInt(o.curCSS(E, "marginTop", true), 10) || 0, F += parseInt(o.curCSS(E, "marginLeft", true), 10) || 0
            }
            return {
                top: G,
                left: F
            }
        }
    };
    o.fn.extend({
        position: function () {
            var I = 0,
                H = 0,
                F;
            if (this[0]) {
                var G = this.offsetParent(),
                    J = this.offset(),
                    E = /^body|html$/i.test(G[0].tagName) ? {
                        top: 0,
                        left: 0
                    } : G.offset();
                J.top -= j(this, "marginTop");
                J.left -= j(this, "marginLeft");
                E.top += j(G, "borderTopWidth");
                E.left += j(G, "borderLeftWidth");
                F = {
                    top: J.top - E.top,
                    left: J.left - E.left
                }
            }
            return F
        },
        offsetParent: function () {
            var E = this[0].offsetParent || document.body;
            while (E && (!/^body|html$/i.test(E.tagName) && o.css(E, "position") == "static")) {
                E = E.offsetParent
            }
            return o(E)
        }
    });
    o.each(["Left", "Top"], function (F, E) {
        var G = "scroll" + E;
        o.fn[G] = function (H) {
            if (!this[0]) {
                return null
            }
            return H !== g ? this.each(function () {
                this == l || this == document ? l.scrollTo(!F ? H : o(l).scrollLeft(), F ? H : o(l).scrollTop()) : this[G] = H
            }) : this[0] == l || this[0] == document ? self[F ? "pageYOffset" : "pageXOffset"] || o.boxModel && document.documentElement[G] || document.body[G] : this[0][G]
        }
    });
    o.each(["Height", "Width"], function (H, F) {
        var E = H ? "Left" : "Top",
            G = H ? "Right" : "Bottom";
        o.fn["inner" + F] = function () {
            return this[F.toLowerCase()]() + j(this, "padding" + E) + j(this, "padding" + G)
        };
        o.fn["outer" + F] = function (J) {
            return this["inner" + F]() + j(this, "border" + E + "Width") + j(this, "border" + G + "Width") + (J ? j(this, "margin" + E) + j(this, "margin" + G) : 0)
        };
        var I = F.toLowerCase();
        o.fn[I] = function (J) {
            return this[0] == l ? document.compatMode == "CSS1Compat" && document.documentElement["client" + F] || document.body["client" + F] : this[0] == document ? Math.max(document.documentElement["client" + F], document.body["scroll" + F], document.documentElement["scroll" + F], document.body["offset" + F], document.documentElement["offset" + F]) : J === g ? (this.length ? o.css(this[0], I) : null) : this.css(I, typeof J === "string" ? J : J + "px")
        }
    })
})();;
(function (G) {
    var A = "2.30";
    var B = G.browser.msie && /MSIE 6.0/.test(navigator.userAgent);

    function D() {
        if (window.console && window.console.log) {
            window.console.log("[cycle] " + Array.prototype.join.call(arguments, ""))
        }
    }
    G.fn.cycle = function (I) {
        var J = arguments[1];
        return this.each(function () {
            if (I === undefined || I === null) {
                I = {}
            }
            if (I.constructor == String) {
                switch (I) {
                case "stop":
                    if (this.cycleTimeout) {
                        clearTimeout(this.cycleTimeout)
                    }
                    this.cycleTimeout = 0;
                    G(this).data("cycle.opts", "");
                    return;
                case "pause":
                    this.cyclePause = 1;
                    return;
                case "resume":
                    this.cyclePause = 0;
                    if (J === true) {
                        I = G(this).data("cycle.opts");
                        if (!I) {
                            D("options not found, can not resume");
                            return
                        }
                        if (this.cycleTimeout) {
                            clearTimeout(this.cycleTimeout);
                            this.cycleTimeout = 0
                        }
                        E(I.elements, I, 1, 1)
                    }
                    return;
                default:
                    I = {
                        fx: I
                    }
                }
            } else {
                if (I.constructor == Number) {
                    var O = I;
                    I = G(this).data("cycle.opts");
                    if (!I) {
                        D("options not found, can not advance slide");
                        return
                    }
                    if (O < 0 || O >= I.elements.length) {
                        D("invalid slide index: " + O);
                        return
                    }
                    I.nextSlide = O;
                    if (this.cycleTimeout) {
                        clearTimeout(this.cycleTimeout);
                        this.cycleTimeout = 0
                    }
                    E(I.elements, I, 1, O >= I.currSlide);
                    return
                }
            }
            if (this.cycleTimeout) {
                clearTimeout(this.cycleTimeout)
            }
            this.cycleTimeout = 0;
            this.cyclePause = 0;
            var R = G(this);
            var P = I.slideExpr ? G(I.slideExpr, this) : R.children();
            var L = P.get();
            if (L.length < 2) {
                D("terminating; too few slides: " + L.length);
                return
            }
            var K = G.extend({}, G.fn.cycle.defaults, I || {}, G.metadata ? R.metadata() : G.meta ? R.data() : {});
            if (K.autostop) {
                K.countdown = K.autostopCount || L.length
            }
            R.data("cycle.opts", K);
            K.container = this;
            K.elements = L;
            K.before = K.before ? [K.before] : [];
            K.after = K.after ? [K.after] : [];
            K.after.unshift(function () {
                K.busy = 0
            });
            if (K.continuous) {
                K.after.push(function () {
                    E(L, K, 0, !K.rev)
                })
            }
            if (B && K.cleartype && !K.cleartypeNoBg) {
                C(P)
            }
            var T = this.className;
            K.width = parseInt((T.match(/w:(\d+)/) || [])[1]) || K.width;
            K.height = parseInt((T.match(/h:(\d+)/) || [])[1]) || K.height;
            K.timeout = parseInt((T.match(/t:(\d+)/) || [])[1]) || K.timeout;
            if (R.css("position") == "static") {
                R.css("position", "relative")
            }
            if (K.width) {
                R.width(K.width)
            }
            if (K.height && K.height != "auto") {
                R.height(K.height)
            }
            if (K.startingSlide) {
                K.startingSlide = parseInt(K.startingSlide)
            }
            if (K.random) {
                K.randomMap = [];
                for (var M = 0; M < L.length; M++) {
                    K.randomMap.push(M)
                }
                K.randomMap.sort(function (V, U) {
                    return Math.random() - 0.5
                });
                K.randomIndex = 0;
                K.startingSlide = K.randomMap[0]
            } else {
                if (K.startingSlide >= L.length) {
                    K.startingSlide = 0
                }
            }
            var N = K.startingSlide || 0;
            P.css({
                position: "absolute",
                top: 0,
                left: 0
            }).hide().each(function (U) {
                var V = N ? U >= N ? L.length - (U - N) : N - U : L.length - U;
                G(this).css("z-index", V)
            });
            G(L[N]).css("opacity", 1).show();
            if (G.browser.msie) {
                L[N].style.removeAttribute("filter")
            }
            if (K.fit && K.width) {
                P.width(K.width)
            }
            if (K.fit && K.height && K.height != "auto") {
                P.height(K.height)
            }
            if (K.pause) {
                R.hover(function () {
                    this.cyclePause = 1
                }, function () {
                    this.cyclePause = 0
                })
            }
            var S = G.fn.cycle.transitions[K.fx];
            if (G.isFunction(S)) {
                S(R, P, K)
            } else {
                if (K.fx != "custom") {
                    D("unknown transition: " + K.fx)
                }
            }
            P.each(function () {
                var U = G(this);
                this.cycleH = (K.fit && K.height) ? K.height : U.height();
                this.cycleW = (K.fit && K.width) ? K.width : U.width()
            });
            K.cssBefore = K.cssBefore || {};
            K.animIn = K.animIn || {};
            K.animOut = K.animOut || {};
            P.not(":eq(" + N + ")").css(K.cssBefore);
            if (K.cssFirst) {
                G(P[N]).css(K.cssFirst)
            }
            if (K.timeout) {
                K.timeout = parseInt(K.timeout);
                if (K.speed.constructor == String) {
                    K.speed = G.fx.speeds[K.speed] || parseInt(K.speed)
                }
                if (!K.sync) {
                    K.speed = K.speed / 2
                }
                while ((K.timeout - K.speed) < 250) {
                    K.timeout += K.speed
                }
            }
            if (K.easing) {
                K.easeIn = K.easeOut = K.easing
            }
            if (!K.speedIn) {
                K.speedIn = K.speed
            }
            if (!K.speedOut) {
                K.speedOut = K.speed
            }
            K.slideCount = L.length;
            K.currSlide = N;
            if (K.random) {
                K.nextSlide = K.currSlide;
                if (++K.randomIndex == L.length) {
                    K.randomIndex = 0
                }
                K.nextSlide = K.randomMap[K.randomIndex]
            } else {
                K.nextSlide = K.startingSlide >= (L.length - 1) ? 0 : K.startingSlide + 1
            }
            var Q = P[N];
            if (K.before.length) {
                K.before[0].apply(Q, [Q, Q, K, true])
            }
            if (K.after.length > 1) {
                K.after[1].apply(Q, [Q, Q, K, true])
            }
            if (K.click && !K.next) {
                K.next = K.click
            }
            if (K.next) {
                G(K.next).bind("click", function () {
                    return F(L, K, K.rev ? -1 : 1)
                })
            }
            if (K.prev) {
                G(K.prev).bind("click", function () {
                    return F(L, K, K.rev ? 1 : -1)
                })
            }
            if (K.pager) {
                H(L, K)
            }
            K.addSlide = function (V, W) {
                var U = G(V),
                    X = U[0];
                if (!K.autostopCount) {
                    K.countdown++
                }
                L[W ? "unshift" : "push"](X);
                if (K.els) {
                    K.els[W ? "unshift" : "push"](X)
                }
                K.slideCount = L.length;
                U.css("position", "absolute");
                U[W ? "prependTo" : "appendTo"](R);
                if (W) {
                    K.currSlide++;
                    K.nextSlide++
                }
                if (B && K.cleartype && !K.cleartypeNoBg) {
                    C(U)
                }
                if (K.fit && K.width) {
                    U.width(K.width)
                }
                if (K.fit && K.height && K.height != "auto") {
                    P.height(K.height)
                }
                X.cycleH = (K.fit && K.height) ? K.height : U.height();
                X.cycleW = (K.fit && K.width) ? K.width : U.width();
                U.css(K.cssBefore);
                if (K.pager) {
                    G.fn.cycle.createPagerAnchor(L.length - 1, X, G(K.pager), L, K)
                }
                if (typeof K.onAddSlide == "function") {
                    K.onAddSlide(U)
                }
            };
            if (K.timeout || K.continuous) {
                this.cycleTimeout = setTimeout(function () {
                    E(L, K, 0, !K.rev)
                }, K.continuous ? 10 : K.timeout + (K.delay || 0))
            }
        })
    };

    function E(N, I, M, O) {
        if (I.busy) {
            return
        }
        var L = I.container,
            Q = N[I.currSlide],
            P = N[I.nextSlide];
        if (L.cycleTimeout === 0 && !M) {
            return
        }
        if (!M && !L.cyclePause && ((I.autostop && (--I.countdown <= 0)) || (I.nowrap && !I.random && I.nextSlide < I.currSlide))) {
            if (I.end) {
                I.end(I)
            }
            return
        }
        if (M || !L.cyclePause) {
            if (I.before.length) {
                G.each(I.before, function (R, S) {
                    S.apply(P, [Q, P, I, O])
                })
            }
            var J = function () {
                    if (G.browser.msie && I.cleartype) {
                        this.style.removeAttribute("filter")
                    }
                    G.each(I.after, function (R, S) {
                        S.apply(P, [Q, P, I, O])
                    })
                };
            if (I.nextSlide != I.currSlide) {
                I.busy = 1;
                if (I.fxFn) {
                    I.fxFn(Q, P, I, J, O)
                } else {
                    if (G.isFunction(G.fn.cycle[I.fx])) {
                        G.fn.cycle[I.fx](Q, P, I, J)
                    } else {
                        G.fn.cycle.custom(Q, P, I, J, M && I.fastOnEvent)
                    }
                }
            }
            if (I.random) {
                I.currSlide = I.nextSlide;
                if (++I.randomIndex == N.length) {
                    I.randomIndex = 0
                }
                I.nextSlide = I.randomMap[I.randomIndex]
            } else {
                var K = (I.nextSlide + 1) == N.length;
                I.nextSlide = K ? 0 : I.nextSlide + 1;
                I.currSlide = K ? N.length - 1 : I.nextSlide - 1
            }
            if (I.pager) {
                G.fn.cycle.updateActivePagerLink(I.pager, I.currSlide)
            }
        }
        if (I.timeout && !I.continuous) {
            L.cycleTimeout = setTimeout(function () {
                E(N, I, 0, !I.rev)
            }, I.timeout)
        } else {
            if (I.continuous && L.cyclePause) {
                L.cycleTimeout = setTimeout(function () {
                    E(N, I, 0, !I.rev)
                }, 10)
            }
        }
    }
    G.fn.cycle.updateActivePagerLink = function (I, J) {
        G(I).find("a").removeClass("activeSlide").filter("a:eq(" + J + ")").addClass("activeSlide")
    };

    function F(I, J, M) {
        var L = J.container,
            K = L.cycleTimeout;
        if (K) {
            clearTimeout(K);
            L.cycleTimeout = 0
        }
        if (J.random && M < 0) {
            J.randomIndex--;
            if (--J.randomIndex == -2) {
                J.randomIndex = I.length - 2
            } else {
                if (J.randomIndex == -1) {
                    J.randomIndex = I.length - 1
                }
            }
            J.nextSlide = J.randomMap[J.randomIndex]
        } else {
            if (J.random) {
                if (++J.randomIndex == I.length) {
                    J.randomIndex = 0
                }
                J.nextSlide = J.randomMap[J.randomIndex]
            } else {
                J.nextSlide = J.currSlide + M;
                if (J.nextSlide < 0) {
                    if (J.nowrap) {
                        return false
                    }
                    J.nextSlide = I.length - 1
                } else {
                    if (J.nextSlide >= I.length) {
                        if (J.nowrap) {
                            return false
                        }
                        J.nextSlide = 0
                    }
                }
            }
        }
        if (J.prevNextClick && typeof J.prevNextClick == "function") {
            J.prevNextClick(M > 0, J.nextSlide, I[J.nextSlide])
        }
        E(I, J, 1, M >= 0);
        return false
    }
    function H(J, K) {
        var I = G(K.pager);
        G.each(J, function (L, M) {
            G.fn.cycle.createPagerAnchor(L, M, I, J, K)
        });
        G.fn.cycle.updateActivePagerLink(K.pager, K.startingSlide)
    }
    G.fn.cycle.createPagerAnchor = function (K, L, I, J, M) {
        var N = (typeof M.pagerAnchorBuilder == "function") ? G(M.pagerAnchorBuilder(K, L)) : G('<a href="#">' + (K + 1) + "</a>");
        if (N.parents("body").length == 0) {
            N.appendTo(I)
        }
        N.bind(M.pagerEvent, function () {
            M.nextSlide = K;
            var P = M.container,
                O = P.cycleTimeout;
            if (O) {
                clearTimeout(O);
                P.cycleTimeout = 0
            }
            if (typeof M.pagerClick == "function") {
                M.pagerClick(M.nextSlide, J[M.nextSlide])
            }
            E(J, M, 1, M.currSlide < K);
            return false
        });
        if (M.pauseOnPagerHover) {
            N.hover(function () {
                M.container.cyclePause = 1
            }, function () {
                M.container.cyclePause = 0
            })
        }
    };

    function C(K) {
        function J(L) {
            var L = parseInt(L).toString(16);
            return L.length < 2 ? "0" + L : L
        }
        function I(N) {
            for (; N && N.nodeName.toLowerCase() != "html"; N = N.parentNode) {
                var L = G.css(N, "background-color");
                if (L.indexOf("rgb") >= 0) {
                    var M = L.match(/\d+/g);
                    return "#" + J(M[0]) + J(M[1]) + J(M[2])
                }
                if (L && L != "transparent") {
                    return L
                }
            }
            return "#ffffff"
        }
        K.each(function () {
            G(this).css("background-color", I(this))
        })
    }
    G.fn.cycle.custom = function (T, N, I, K, J) {
        var S = G(T),
            O = G(N);
        O.css(I.cssBefore);
        var L = J ? 1 : I.speedIn;
        var R = J ? 1 : I.speedOut;
        var M = J ? null : I.easeIn;
        var Q = J ? null : I.easeOut;
        var P = function () {
                O.animate(I.animIn, L, M, K)
            };
        S.animate(I.animOut, R, Q, function () {
            if (I.cssAfter) {
                S.css(I.cssAfter)
            }
            if (!I.sync) {
                P()
            }
        });
        if (I.sync) {
            P()
        }
    };
    G.fn.cycle.transitions = {
        fade: function (J, K, I) {
            K.not(":eq(" + I.startingSlide + ")").css("opacity", 0);
            I.before.push(function () {
                G(this).show()
            });
            I.animIn = {
                opacity: 1
            };
            I.animOut = {
                opacity: 0
            };
            I.cssBefore = {
                opacity: 0
            };
            I.cssAfter = {
                display: "none"
            };
            I.onAddSlide = function (L) {
                L.hide()
            }
        }
    };
    G.fn.cycle.ver = function () {
        return A
    };
    G.fn.cycle.defaults = {
        fx: "fade",
        timeout: 4000,
        continuous: 0,
        speed: 1000,
        speedIn: null,
        speedOut: null,
        next: null,
        prev: null,
        prevNextClick: null,
        pager: null,
        pagerClick: null,
        pagerEvent: "click",
        pagerAnchorBuilder: null,
        before: null,
        after: null,
        end: null,
        easing: null,
        easeIn: null,
        easeOut: null,
        shuffle: null,
        animIn: null,
        animOut: null,
        cssBefore: null,
        cssAfter: null,
        fxFn: null,
        height: "auto",
        startingSlide: 0,
        sync: 1,
        random: 0,
        fit: 0,
        pause: 0,
        pauseOnPagerHover: 0,
        autostop: 0,
        autostopCount: 0,
        delay: 0,
        slideExpr: null,
        cleartype: 0,
        nowrap: 0,
        fastOnEvent: 0
    }
})(jQuery);
(function (A) {
    A.fn.cycle.transitions.scrollUp = function (C, D, B) {
        C.css("overflow", "hidden");
        B.before.push(function (G, E, F) {
            A(this).show();
            F.cssBefore.top = E.offsetHeight;
            F.animOut.top = 0 - G.offsetHeight
        });
        B.cssFirst = {
            top: 0
        };
        B.animIn = {
            top: 0
        };
        B.cssAfter = {
            display: "none"
        }
    };
    A.fn.cycle.transitions.scrollDown = function (C, D, B) {
        C.css("overflow", "hidden");
        B.before.push(function (G, E, F) {
            A(this).show();
            F.cssBefore.top = 0 - E.offsetHeight;
            F.animOut.top = G.offsetHeight
        });
        B.cssFirst = {
            top: 0
        };
        B.animIn = {
            top: 0
        };
        B.cssAfter = {
            display: "none"
        }
    };
    A.fn.cycle.transitions.scrollLeft = function (C, D, B) {
        C.css("overflow", "hidden");
        B.before.push(function (G, E, F) {
            A(this).show();
            F.cssBefore.left = E.offsetWidth;
            F.animOut.left = 0 - G.offsetWidth
        });
        B.cssFirst = {
            left: 0
        };
        B.animIn = {
            left: 0
        }
    };
    A.fn.cycle.transitions.scrollRight = function (C, D, B) {
        C.css("overflow", "hidden");
        B.before.push(function (G, E, F) {
            A(this).show();
            F.cssBefore.left = 0 - E.offsetWidth;
            F.animOut.left = G.offsetWidth
        });
        B.cssFirst = {
            left: 0
        };
        B.animIn = {
            left: 0
        }
    };
    A.fn.cycle.transitions.scrollHorz = function (C, D, B) {
        C.css("overflow", "hidden").width();
        B.before.push(function (I, G, H, F) {
            A(this).show();
            var E = I.offsetWidth,
                J = G.offsetWidth;
            H.cssBefore = F ? {
                left: J
            } : {
                left: -J
            };
            H.animIn.left = 0;
            H.animOut.left = F ? -E : E;
            D.not(I).css(H.cssBefore)
        });
        B.cssFirst = {
            left: 0
        };
        B.cssAfter = {
            display: "none"
        }
    };
    A.fn.cycle.transitions.scrollVert = function (C, D, B) {
        C.css("overflow", "hidden");
        B.before.push(function (J, G, H, F) {
            A(this).show();
            var I = J.offsetHeight,
                E = G.offsetHeight;
            H.cssBefore = F ? {
                top: -E
            } : {
                top: E
            };
            H.animIn.top = 0;
            H.animOut.top = F ? I : -I;
            D.not(J).css(H.cssBefore)
        });
        B.cssFirst = {
            top: 0
        };
        B.cssAfter = {
            display: "none"
        }
    };
    A.fn.cycle.transitions.slideX = function (C, D, B) {
        B.before.push(function (G, E, F) {
            A(G).css("zIndex", 1)
        });
        B.onAddSlide = function (E) {
            E.hide()
        };
        B.cssBefore = {
            zIndex: 2
        };
        B.animIn = {
            width: "show"
        };
        B.animOut = {
            width: "hide"
        }
    };
    A.fn.cycle.transitions.slideY = function (C, D, B) {
        B.before.push(function (G, E, F) {
            A(G).css("zIndex", 1)
        });
        B.onAddSlide = function (E) {
            E.hide()
        };
        B.cssBefore = {
            zIndex: 2
        };
        B.animIn = {
            height: "show"
        };
        B.animOut = {
            height: "hide"
        }
    };
    A.fn.cycle.transitions.shuffle = function (E, F, D) {
        var B = E.css("overflow", "visible").width();
        F.css({
            left: 0,
            top: 0
        });
        D.before.push(function () {
            A(this).show()
        });
        D.speed = D.speed / 2;
        D.random = 0;
        D.shuffle = D.shuffle || {
            left: -B,
            top: 15
        };
        D.els = [];
        for (var C = 0; C < F.length; C++) {
            D.els.push(F[C])
        }
        for (var C = 0; C < D.startingSlide; C++) {
            D.els.push(D.els.shift())
        }
        D.fxFn = function (L, J, K, G, I) {
            var H = I ? A(L) : A(J);
            H.animate(K.shuffle, K.speedIn, K.easeIn, function () {
                I ? K.els.push(K.els.shift()) : K.els.unshift(K.els.pop());
                if (I) {
                    for (var N = 0, M = K.els.length; N < M; N++) {
                        A(K.els[N]).css("z-index", M - N)
                    }
                } else {
                    var O = A(L).css("z-index");
                    H.css("z-index", parseInt(O) + 1)
                }
                H.animate({
                    left: 0,
                    top: 0
                }, K.speedOut, K.easeOut, function () {
                    A(I ? this : L).hide();
                    if (G) {
                        G()
                    }
                })
            })
        };
        D.onAddSlide = function (G) {
            G.hide()
        }
    };
    A.fn.cycle.transitions.turnUp = function (C, D, B) {
        B.before.push(function (G, E, F) {
            A(this).show();
            F.cssBefore.top = E.cycleH;
            F.animIn.height = E.cycleH
        });
        B.onAddSlide = function (E) {
            E.hide()
        };
        B.cssFirst = {
            top: 0
        };
        B.cssBefore = {
            height: 0
        };
        B.animIn = {
            top: 0
        };
        B.animOut = {
            height: 0
        };
        B.cssAfter = {
            display: "none"
        }
    };
    A.fn.cycle.transitions.turnDown = function (C, D, B) {
        B.before.push(function (G, E, F) {
            A(this).show();
            F.animIn.height = E.cycleH;
            F.animOut.top = G.cycleH
        });
        B.onAddSlide = function (E) {
            E.hide()
        };
        B.cssFirst = {
            top: 0
        };
        B.cssBefore = {
            top: 0,
            height: 0
        };
        B.animOut = {
            height: 0
        };
        B.cssAfter = {
            display: "none"
        }
    };
    A.fn.cycle.transitions.turnLeft = function (C, D, B) {
        B.before.push(function (G, E, F) {
            A(this).show();
            F.cssBefore.left = E.cycleW;
            F.animIn.width = E.cycleW
        });
        B.onAddSlide = function (E) {
            E.hide()
        };
        B.cssBefore = {
            width: 0
        };
        B.animIn = {
            left: 0
        };
        B.animOut = {
            width: 0
        };
        B.cssAfter = {
            display: "none"
        }
    };
    A.fn.cycle.transitions.turnRight = function (C, D, B) {
        B.before.push(function (G, E, F) {
            A(this).show();
            F.animIn.width = E.cycleW;
            F.animOut.left = G.cycleW
        });
        B.onAddSlide = function (E) {
            E.hide()
        };
        B.cssBefore = {
            left: 0,
            width: 0
        };
        B.animIn = {
            left: 0
        };
        B.animOut = {
            width: 0
        };
        B.cssAfter = {
            display: "none"
        }
    };
    A.fn.cycle.transitions.zoom = function (C, D, B) {
        B.cssFirst = {
            top: 0,
            left: 0
        };
        B.cssAfter = {
            display: "none"
        };
        B.before.push(function (G, E, F) {
            A(this).show();
            F.cssBefore = {
                width: 0,
                height: 0,
                top: E.cycleH / 2,
                left: E.cycleW / 2
            };
            F.cssAfter = {
                display: "none"
            };
            F.animIn = {
                top: 0,
                left: 0,
                width: E.cycleW,
                height: E.cycleH
            };
            F.animOut = {
                width: 0,
                height: 0,
                top: G.cycleH / 2,
                left: G.cycleW / 2
            };
            A(G).css("zIndex", 2);
            A(E).css("zIndex", 1)
        });
        B.onAddSlide = function (E) {
            E.hide()
        }
    };
    A.fn.cycle.transitions.fadeZoom = function (C, D, B) {
        B.before.push(function (G, E, F) {
            F.cssBefore = {
                width: 0,
                height: 0,
                opacity: 1,
                left: E.cycleW / 2,
                top: E.cycleH / 2,
                zIndex: 1
            };
            F.animIn = {
                top: 0,
                left: 0,
                width: E.cycleW,
                height: E.cycleH
            }
        });
        B.animOut = {
            opacity: 0
        };
        B.cssAfter = {
            zIndex: 0
        }
    };
    A.fn.cycle.transitions.blindX = function (D, E, C) {
        var B = D.css("overflow", "hidden").width();
        E.show();
        C.before.push(function (H, F, G) {
            A(H).css("zIndex", 1)
        });
        C.cssBefore = {
            left: B,
            zIndex: 2
        };
        C.cssAfter = {
            zIndex: 1
        };
        C.animIn = {
            left: 0
        };
        C.animOut = {
            left: B
        }
    };
    A.fn.cycle.transitions.blindY = function (D, E, C) {
        var B = D.css("overflow", "hidden").height();
        E.show();
        C.before.push(function (H, F, G) {
            A(H).css("zIndex", 1)
        });
        C.cssBefore = {
            top: B,
            zIndex: 2
        };
        C.cssAfter = {
            zIndex: 1
        };
        C.animIn = {
            top: 0
        };
        C.animOut = {
            top: B
        }
    };
    A.fn.cycle.transitions.blindZ = function (E, F, D) {
        var C = E.css("overflow", "hidden").height();
        var B = E.width();
        F.show();
        D.before.push(function (I, G, H) {
            A(I).css("zIndex", 1)
        });
        D.cssBefore = {
            top: C,
            left: B,
            zIndex: 2
        };
        D.cssAfter = {
            zIndex: 1
        };
        D.animIn = {
            top: 0,
            left: 0
        };
        D.animOut = {
            top: C,
            left: B
        }
    };
    A.fn.cycle.transitions.growX = function (C, D, B) {
        B.before.push(function (G, E, F) {
            F.cssBefore = {
                left: this.cycleW / 2,
                width: 0,
                zIndex: 2
            };
            F.animIn = {
                left: 0,
                width: this.cycleW
            };
            F.animOut = {
                left: 0
            };
            A(G).css("zIndex", 1)
        });
        B.onAddSlide = function (E) {
            E.hide().css("zIndex", 1)
        }
    };
    A.fn.cycle.transitions.growY = function (C, D, B) {
        B.before.push(function (G, E, F) {
            F.cssBefore = {
                top: this.cycleH / 2,
                height: 0,
                zIndex: 2
            };
            F.animIn = {
                top: 0,
                height: this.cycleH
            };
            F.animOut = {
                top: 0
            };
            A(G).css("zIndex", 1)
        });
        B.onAddSlide = function (E) {
            E.hide().css("zIndex", 1)
        }
    };
    A.fn.cycle.transitions.curtainX = function (C, D, B) {
        B.before.push(function (G, E, F) {
            F.cssBefore = {
                left: E.cycleW / 2,
                width: 0,
                zIndex: 1,
                display: "block"
            };
            F.animIn = {
                left: 0,
                width: this.cycleW
            };
            F.animOut = {
                left: G.cycleW / 2,
                width: 0
            };
            A(G).css("zIndex", 2)
        });
        B.onAddSlide = function (E) {
            E.hide()
        };
        B.cssAfter = {
            zIndex: 1,
            display: "none"
        }
    };
    A.fn.cycle.transitions.curtainY = function (C, D, B) {
        B.before.push(function (G, E, F) {
            F.cssBefore = {
                top: E.cycleH / 2,
                height: 0,
                zIndex: 1,
                display: "block"
            };
            F.animIn = {
                top: 0,
                height: this.cycleH
            };
            F.animOut = {
                top: G.cycleH / 2,
                height: 0
            };
            A(G).css("zIndex", 2)
        });
        B.onAddSlide = function (E) {
            E.hide()
        };
        B.cssAfter = {
            zIndex: 1,
            display: "none"
        }
    };
    A.fn.cycle.transitions.cover = function (E, F, D) {
        var G = D.direction || "left";
        var B = E.css("overflow", "hidden").width();
        var C = E.height();
        D.before.push(function (J, H, I) {
            I.cssBefore = I.cssBefore || {};
            I.cssBefore.zIndex = 2;
            I.cssBefore.display = "block";
            if (G == "right") {
                I.cssBefore.left = -B
            } else {
                if (G == "up") {
                    I.cssBefore.top = C
                } else {
                    if (G == "down") {
                        I.cssBefore.top = -C
                    } else {
                        I.cssBefore.left = B
                    }
                }
            }
            A(J).css("zIndex", 1)
        });
        if (!D.animIn) {
            D.animIn = {
                left: 0,
                top: 0
            }
        }
        if (!D.animOut) {
            D.animOut = {
                left: 0,
                top: 0
            }
        }
        D.cssAfter = D.cssAfter || {};
        D.cssAfter.zIndex = 2;
        D.cssAfter.display = "none"
    };
    A.fn.cycle.transitions.uncover = function (E, F, D) {
        var G = D.direction || "left";
        var B = E.css("overflow", "hidden").width();
        var C = E.height();
        D.before.push(function (J, H, I) {
            I.cssBefore.display = "block";
            if (G == "right") {
                I.animOut.left = B
            } else {
                if (G == "up") {
                    I.animOut.top = -C
                } else {
                    if (G == "down") {
                        I.animOut.top = C
                    } else {
                        I.animOut.left = -B
                    }
                }
            }
            A(J).css("zIndex", 2);
            A(H).css("zIndex", 1)
        });
        D.onAddSlide = function (H) {
            H.hide()
        };
        if (!D.animIn) {
            D.animIn = {
                left: 0,
                top: 0
            }
        }
        D.cssBefore = D.cssBefore || {};
        D.cssBefore.top = 0;
        D.cssBefore.left = 0;
        D.cssAfter = D.cssAfter || {};
        D.cssAfter.zIndex = 1;
        D.cssAfter.display = "none"
    };
    A.fn.cycle.transitions.toss = function (E, F, D) {
        var B = E.css("overflow", "visible").width();
        var C = E.height();
        D.before.push(function (I, G, H) {
            A(I).css("zIndex", 2);
            H.cssBefore.display = "block";
            if (!H.animOut.left && !H.animOut.top) {
                H.animOut = {
                    left: B * 2,
                    top: -C / 2,
                    opacity: 0
                }
            } else {
                H.animOut.opacity = 0
            }
        });
        D.onAddSlide = function (G) {
            G.hide()
        };
        D.cssBefore = {
            left: 0,
            top: 0,
            zIndex: 1,
            opacity: 1
        };
        D.animIn = {
            left: 0
        };
        D.cssAfter = {
            zIndex: 2,
            display: "none"
        }
    };
    A.fn.cycle.transitions.wipe = function (K, H, C) {
        var J = K.css("overflow", "hidden").width();
        var F = K.height();
        C.cssBefore = C.cssBefore || {};
        var D;
        if (C.clip) {
            if (/l2r/.test(C.clip)) {
                D = "rect(0px 0px " + F + "px 0px)"
            } else {
                if (/r2l/.test(C.clip)) {
                    D = "rect(0px " + J + "px " + F + "px " + J + "px)"
                } else {
                    if (/t2b/.test(C.clip)) {
                        D = "rect(0px " + J + "px 0px 0px)"
                    } else {
                        if (/b2t/.test(C.clip)) {
                            D = "rect(" + F + "px " + J + "px " + F + "px 0px)"
                        } else {
                            if (/zoom/.test(C.clip)) {
                                var L = parseInt(F / 2);
                                var E = parseInt(J / 2);
                                D = "rect(" + L + "px " + E + "px " + L + "px " + E + "px)"
                            }
                        }
                    }
                }
            }
        }
        C.cssBefore.clip = C.cssBefore.clip || D || "rect(0px 0px 0px 0px)";
        var G = C.cssBefore.clip.match(/(\d+)/g);
        var L = parseInt(G[0]),
            B = parseInt(G[1]),
            I = parseInt(G[2]),
            E = parseInt(G[3]);
        C.before.push(function (T, O, R) {
            if (T == O) {
                return
            }
            var N = A(T).css("zIndex", 2);
            var M = A(O).css({
                zIndex: 3,
                display: "block"
            });
            var Q = 1,
                P = parseInt((R.speedIn / 13)) - 1;

            function S() {
                var V = L ? L - parseInt(Q * (L / P)) : 0;
                var W = E ? E - parseInt(Q * (E / P)) : 0;
                var X = I < F ? I + parseInt(Q * ((F - I) / P || 1)) : F;
                var U = B < J ? B + parseInt(Q * ((J - B) / P || 1)) : J;
                M.css({
                    clip: "rect(" + V + "px " + U + "px " + X + "px " + W + "px)"
                });
                (Q++ <= P) ? setTimeout(S, 13) : N.css("display", "none")
            }
            S()
        });
        C.cssAfter = {};
        C.animIn = {
            left: 0
        };
        C.animOut = {
            left: 0
        }
    }
})(jQuery);
jQuery(function ($) {
    var userAgent = navigator.userAgent.toLowerCase();
    var browserVersion = (userAgent.match(/.+(?:rv|webkit|khtml|opera|msie)[\/: ]([\d.]+)/) || [0, '0'])[1];
    var isIE6 = (/msie/.test(userAgent) && !/opera/.test(userAgent) && parseInt(browserVersion) < 7 && !window.XMLHttpRequest);
    var body = $('body');
    var currentSettings;
    var shouldResize = false;
    var gallery = {};
    var fixFF = false;
    var contentElt;
    var contentEltLast;
    var modal = {
        started: false,
        ready: false,
        dataReady: false,
        anim: false,
        animContent: false,
        loadingShown: false,
        transition: false,
        resizing: false,
        closing: false,
        error: false,
        blocker: null,
        blockerVars: null,
        full: null,
        bg: null,
        loading: null,
        tmp: null,
        content: null,
        wrapper: null,
        contentWrapper: null,
        scripts: new Array(),
        scriptsShown: new Array()
    };
    var resized = {
        width: false,
        height: false,
        windowResizing: false
    };
    var initSettingsSize = {
        width: null,
        height: null,
        windowResizing: true
    };
    var windowResizeTimeout;
    $.fn.nyroModal = function (settings) {
        if (!this) return false;
        return this.each(function () {
            var me = $(this);
            if (this.nodeName.toLowerCase() == 'form') {
                me.unbind('submit.nyroModal').bind('submit.nyroModal', function (e) {
                    if (e.isDefaultPrevented()) return false;
                    if (me.data('nyroModalprocessing')) return true;
                    if (this.enctype == 'multipart/form-data') {
                        processModal($.extend(settings, {
                            from: this
                        }));
                        return true
                    }
                    e.preventDefault();
                    processModal($.extend(settings, {
                        from: this
                    }));
                    return false
                })
            } else {
                me.unbind('click.nyroModal').bind('click.nyroModal', function (e) {
                    if (e.isDefaultPrevented()) return false;
                    e.preventDefault();
                    processModal($.extend(settings, {
                        from: this
                    }));
                    return false
                })
            }
        })
    };
    $.fn.nyroModalManual = function (settings) {
        if (!this.length) processModal(settings);
        return this.each(function () {
            processModal($.extend(settings, {
                from: this
            }))
        })
    };
    $.nyroModalManual = function (settings) {
        processModal(settings)
    };
    $.nyroModalSettings = function (settings, deep1, deep2) {
        setCurrentSettings(settings, deep1, deep2);
        if (!deep1 && modal.started) {
            if (modal.bg && settings.bgColor) currentSettings.updateBgColor(modal, currentSettings, function () {});
            if (modal.contentWrapper && settings.title) setTitle();
            if (!modal.error && (settings.windowResizing || (!modal.resizing && (('width' in settings && settings.width == currentSettings.width) || ('height' in settings && settings.height == currentSettings.height))))) {
                modal.resizing = true;
                if (modal.contentWrapper) calculateSize(true);
                if (modal.contentWrapper && modal.contentWrapper.is(':visible') && !modal.animContent) {
                    if (fixFF) modal.content.css({
                        position: ''
                    });
                    currentSettings.resize(modal, currentSettings, function () {
                        currentSettings.windowResizing = false;
                        modal.resizing = false;
                        if (fixFF) modal.content.css({
                            position: 'fixed'
                        });
                        if ($.isFunction(currentSettings.endResize)) currentSettings.endResize(modal, currentSettings)
                    })
                }
            }
        }
    };
    $.nyroModalRemove = function () {
        removeModal()
    };
    $.nyroModalNext = function () {
        var link = getGalleryLink(1);
        if (link) return link.nyroModalManual(getCurrentSettingsNew());
        return false
    };
    $.nyroModalPrev = function () {
        var link = getGalleryLink(-1);
        if (link) return link.nyroModalManual(getCurrentSettingsNew());
        return false
    };
    $.fn.nyroModal.settings = {
        debug: false,
        blocker: false,
        modal: false,
        type: '',
        forceType: null,
        from: '',
        hash: '',
        processHandler: null,
        selIndicator: 'nyroModalSel',
        formIndicator: 'nyroModal',
        content: null,
        bgColor: '#000000',
        ajax: {},
        swf: {
            wmode: 'transparent'
        },
        width: null,
        height: null,
        minWidth: 400,
        minHeight: 300,
        resizable: true,
        autoSizable: true,
        padding: 25,
        regexImg: '[^\.]\.(jpg|jpeg|png|tiff|gif|bmp)\s*$',
        addImageDivTitle: false,
        defaultImgAlt: 'Image',
        setWidthImgTitle: true,
        ltr: true,
        gallery: null,
        galleryLinks: '<a href="#" class="nyroModalPrev">Prev</a><a href="#"  class="nyroModalNext">Next</a>',
        galleryCounts: galleryCounts,
        zIndexStart: 100,
        css: {
            bg: {
                position: 'absolute',
                overflow: 'hidden',
                top: 0,
                left: 0,
                height: '100%',
                width: '100%'
            },
            wrapper: {
                position: 'absolute',
                top: '50%',
                left: '50%'
            },
            wrapper2: {},
            content: {
                overflow: 'auto'
            },
            loading: {
                position: 'absolute',
                top: '50%',
                left: '50%',
                marginTop: '-50px',
                marginLeft: '-50px'
            }
        },
        wrap: {
            div: '<div class="wrapper"></div>',
            ajax: '<div class="wrapper"></div>',
            form: '<div class="wrapper"></div>',
            formData: '<div class="wrapper"></div>',
            image: '<div class="wrapperImg"></div>',
            swf: '<div class="wrapperSwf"></div>',
            iframe: '<div class="wrapperIframe"></div>',
            iframeForm: '<div class="wrapperIframe"></div>',
            manual: '<div class="wrapper"></div>'
        },
        closeButton: '<a href="#" class="nyroModalClose" id="closeBut" title="close">Close</a>',
        title: null,
        titleFromIframe: true,
        openSelector: '.nyroModal',
        closeSelector: '.nyroModalClose',
        contentLoading: '<a href="#" class="nyroModalClose">Cancel</a>',
        errorClass: 'error',
        contentError: 'The requested content cannot be loaded.<br />Please try again later.<br /><a href="#" class="nyroModalClose">Close</a>',
        handleError: null,
        showBackground: showBackground,
        hideBackground: hideBackground,
        endFillContent: null,
        showContent: showContent,
        endShowContent: null,
        beforeHideContent: null,
        hideContent: hideContent,
        showTransition: showTransition,
        hideTransition: hideTransition,
        showLoading: showLoading,
        hideLoading: hideLoading,
        resize: resize,
        endResize: null,
        updateBgColor: updateBgColor,
        endRemove: null
    };

    function processModal(settings) {
        if (modal.loadingShown || modal.transition || modal.anim) return;
        debug('processModal');
        modal.started = true;
        setDefaultCurrentSettings(settings);
        if (!modal.full) modal.blockerVars = modal.blocker = null;
        modal.error = false;
        modal.closing = false;
        modal.dataReady = false;
        modal.scripts = new Array();
        modal.scriptsShown = new Array();
        currentSettings.type = fileType();
        if (currentSettings.forceType) {
            if (!currentSettings.content) currentSettings.from = true;
            currentSettings.type = currentSettings.forceType;
            currentSettings.forceType = null
        }
        if ($.isFunction(currentSettings.processHandler)) currentSettings.processHandler(currentSettings);
        var from = currentSettings.from;
        var url = currentSettings.url;
        initSettingsSize.width = currentSettings.width;
        initSettingsSize.height = currentSettings.height;
        if (currentSettings.type == 'swf') {
            setCurrentSettings({
                overflow: 'hidden'
            }, 'css', 'content');
            currentSettings.content = '<object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" width="' + currentSettings.width + '" height="' + currentSettings.height + '"><param name="movie" value="' + url + '"></param>';
            var tmp = '';
            $.each(currentSettings.swf, function (name, val) {
                currentSettings.content += '<param name="' + name + '" value="' + val + '"></param>';
                tmp += ' ' + name + '="' + val + '"'
            });
            currentSettings.content += '<embed src="' + url + '" type="application/x-shockwave-flash" width="' + currentSettings.width + '" height="' + currentSettings.height + '"' + tmp + '></embed></object>'
        }
        if (from) {
            var jFrom = $(from).blur();
            if (currentSettings.type == 'form') {
                var data = $(from).serializeArray();
                data.push({
                    name: currentSettings.formIndicator,
                    value: 1
                });
                if (currentSettings.selector) data.push({
                    name: currentSettings.selIndicator,
                    value: currentSettings.selector.substring(1)
                });
                $.ajax($.extend({}, currentSettings.ajax, {
                    url: url,
                    data: data,
                    type: jFrom.attr('method') ? jFrom.attr('method') : 'get',
                    success: ajaxLoaded,
                    error: loadingError
                }));
                debug('Form Ajax Load: ' + jFrom.attr('action'));
                showModal()
            } else if (currentSettings.type == 'formData') {
                initModal();
                jFrom.attr('target', 'nyroModalIframe');
                jFrom.attr('action', url);
                jFrom.prepend('<input type="hidden" name="' + currentSettings.formIndicator + '" value="1" />');
                if (currentSettings.selector) jFrom.prepend('<input type="hidden" name="' + currentSettings.selIndicator + '" value="' + currentSettings.selector.substring(1) + '" />');
                modal.tmp.html('<iframe frameborder="0" hspace="0" name="nyroModalIframe" src="javascript:\'\';"></iframe>');
                $('iframe', modal.tmp).css({
                    width: currentSettings.width,
                    height: currentSettings.height
                }).error(loadingError).load(formDataLoaded);
                debug('Form Data Load: ' + jFrom.attr('action'));
                showModal();
                showContentOrLoading()
            } else if (currentSettings.type == 'image') {
                debug('Image Load: ' + url);
                var title = jFrom.attr('title') || currentSettings.defaultImgAlt;
                initModal();
                modal.tmp.html('<img id="nyroModalImg" />').find('img').attr('alt', title);
                modal.tmp.css({
                    lineHeight: 0
                });
                $('img', modal.tmp).error(loadingError).load(function () {
                    debug('Image Loaded: ' + this.src);
                    $(this).unbind('load');
                    var w = modal.tmp.width();
                    var h = modal.tmp.height();
                    modal.tmp.css({
                        lineHeight: ''
                    });
                    resized.width = w;
                    resized.height = h;
                    setCurrentSettings({
                        width: w,
                        height: h,
                        imgWidth: w,
                        imgHeight: h
                    });
                    initSettingsSize.width = w;
                    initSettingsSize.height = h;
                    setCurrentSettings({
                        overflow: 'hidden'
                    }, 'css', 'content');
                    modal.dataReady = true;
                    if (modal.loadingShown || modal.transition) showContentOrLoading()
                }).attr('src', url);
                showModal()
            } else if (currentSettings.type == 'iframeForm') {
                initModal();
                modal.tmp.html('<iframe frameborder="0" hspace="0" src="javascript:\'\';" name="nyroModalIframe" id="nyroModalIframe"></iframe>');
                debug('Iframe Form Load: ' + url);
                $('iframe', modal.tmp).eq(0).css({
                    width: '100%',
                    height: $.support.boxModel ? '99%' : '100%'
                }).load(iframeLoaded);
                modal.dataReady = true;
                showModal()
            } else if (currentSettings.type == 'iframe') {
                initModal();
                modal.tmp.html('<iframe frameborder="0" hspace="0" src="javascript:\'\';" name="nyroModalIframe" id="nyroModalIframe"></iframe>');
                debug('Iframe Load: ' + url);
                $('iframe', modal.tmp).eq(0).css({
                    width: '100%',
                    height: $.support.boxModel ? '99%' : '100%'
                }).load(iframeLoaded);
                modal.dataReady = true;
                showModal()
            } else if (currentSettings.type) {
                debug('Content: ' + currentSettings.type);
                initModal();
                modal.tmp.html(currentSettings.content);
                var w = modal.tmp.width();
                var h = modal.tmp.height();
                var div = $(currentSettings.type);
                if (div.length) {
                    setCurrentSettings({
                        type: 'div'
                    });
                    w = div.width();
                    h = div.height();
                    if (contentElt) contentEltLast = contentElt;
                    contentElt = div;
                    modal.tmp.append(div.contents())
                }
                initSettingsSize.width = w;
                initSettingsSize.height = h;
                setCurrentSettings({
                    width: w,
                    height: h
                });
                if (modal.tmp.html()) modal.dataReady = true;
                else loadingError();
                if (!modal.ready) showModal();
                else endHideContent()
            } else {
                debug('Ajax Load: ' + url);
                setCurrentSettings({
                    type: 'ajax'
                });
                var data = currentSettings.ajax.data || {};
                if (currentSettings.selector) {
                    if (typeof data == "string") {
                        data += '&' + currentSettings.selIndicator + '=' + currentSettings.selector.substring(1)
                    } else {
                        data[currentSettings.selIndicator] = currentSettings.selector.substring(1)
                    }
                }
                $.ajax($.extend(true, currentSettings.ajax, {
                    url: url,
                    success: ajaxLoaded,
                    error: loadingError,
                    data: data
                }));
                showModal()
            }
        } else if (currentSettings.content) {
            debug('Content: ' + currentSettings.type);
            setCurrentSettings({
                type: 'manual'
            });
            initModal();
            modal.tmp.html($('<div/>').html(currentSettings.content).contents());
            if (modal.tmp.html()) modal.dataReady = true;
            else loadingError();
            showModal()
        } else {}
    }
    function setDefaultCurrentSettings(settings) {
        debug('setDefaultCurrentSettings');
        currentSettings = $.extend(true, {}, $.fn.nyroModal.settings, settings);
        currentSettings.selector = '';
        currentSettings.borderW = 0;
        currentSettings.borderH = 0;
        currentSettings.resizable = true;
        setMargin()
    }
    function setCurrentSettings(settings, deep1, deep2) {
        if (modal.started) {
            if (deep1 && deep2) {
                $.extend(true, currentSettings[deep1][deep2], settings)
            } else if (deep1) {
                $.extend(true, currentSettings[deep1], settings)
            } else {
                if (modal.animContent) {
                    if ('width' in settings) {
                        if (!modal.resizing) {
                            settings.setWidth = settings.width;
                            shouldResize = true
                        }
                        delete settings['width']
                    }
                    if ('height' in settings) {
                        if (!modal.resizing) {
                            settings.setHeight = settings.height;
                            shouldResize = true
                        }
                        delete settings['height']
                    }
                }
                $.extend(true, currentSettings, settings)
            }
        } else {
            if (deep1 && deep2) {
                $.extend(true, $.fn.nyroModal.settings[deep1][deep2], settings)
            } else if (deep1) {
                $.extend(true, $.fn.nyroModal.settings[deep1], settings)
            } else {
                $.extend(true, $.fn.nyroModal.settings, settings)
            }
        }
    }
    function setMarginScroll() {
        if (isIE6 && !modal.blocker) {
            if (document.documentElement) {
                currentSettings.marginScrollLeft = document.documentElement.scrollLeft;
                currentSettings.marginScrollTop = document.documentElement.scrollTop
            } else {
                currentSettings.marginScrollLeft = document.body.scrollLeft;
                currentSettings.marginScrollTop = document.body.scrollTop
            }
        } else {
            currentSettings.marginScrollLeft = 0;
            currentSettings.marginScrollTop = 0
        }
    }
    function setMargin() {
        setMarginScroll();
        currentSettings.marginLeft = -(currentSettings.width + currentSettings.borderW) / 2;
        currentSettings.marginTop = -(currentSettings.height + currentSettings.borderH) / 2;
        if (!modal.blocker) {
            currentSettings.marginLeft += currentSettings.marginScrollLeft;
            currentSettings.marginTop += currentSettings.marginScrollTop
        }
    }
    function setMarginLoading() {
        setMarginScroll();
        var outer = getOuter(modal.loading);
        currentSettings.marginTopLoading = -(modal.loading.height() + outer.h.border + outer.h.padding) / 2;
        currentSettings.marginLeftLoading = -(modal.loading.width() + outer.w.border + outer.w.padding) / 2;
        if (!modal.blocker) {
            currentSettings.marginLefttLoading += currentSettings.marginScrollLeft;
            currentSettings.marginTopLoading += currentSettings.marginScrollTop
        }
    }
    function setTitle() {
        var title = $('h1#nyroModalTitle', modal.contentWrapper);
        if (title.length) title.text(currentSettings.title);
        else modal.contentWrapper.prepend('<h1 id="nyroModalTitle">' + currentSettings.title + '</h1>')
    }
    function initModal() {
        debug('initModal');
        if (!modal.full) {
            if (currentSettings.debug) setCurrentSettings({
                color: 'white'
            }, 'css', 'bg');
            var full = {
                zIndex: currentSettings.zIndexStart,
                position: 'fixed',
                top: 0,
                left: 0,
                width: '100%',
                height: '100%'
            };
            var contain = body;
            var iframeHideIE = '';
            if (currentSettings.blocker) {
                modal.blocker = contain = $(currentSettings.blocker);
                var pos = modal.blocker.offset();
                var w = modal.blocker.outerWidth();
                var h = modal.blocker.outerHeight();
                if (isIE6) {
                    setCurrentSettings({
                        height: '100%',
                        width: '100%',
                        top: 0,
                        left: 0
                    }, 'css', 'bg')
                }
                modal.blockerVars = {
                    top: pos.top,
                    left: pos.left,
                    width: w,
                    height: h
                };
                var plusTop = (/msie/.test(userAgent) ? 0 : getCurCSS(body.get(0), 'borderTopWidth'));
                var plusLeft = (/msie/.test(userAgent) ? 0 : getCurCSS(body.get(0), 'borderLeftWidth'));
                full = {
                    position: 'absolute',
                    top: pos.top + plusTop,
                    left: pos.left + plusLeft,
                    width: w,
                    height: h
                }
            } else if (isIE6) {
                body.css({
                    height: '130%',
                    width: '130%',
                    position: 'static',
                    overflow: 'hidden'
                });
                $('html').css({
                    overflow: 'hidden'
                });
                setCurrentSettings({
                    css: {
                        bg: {
                            position: 'absolute',
                            zIndex: currentSettings.zIndexStart + 1,
                            height: '110%',
                            width: '110%',
                            top: currentSettings.marginScrollTop + 'px',
                            left: currentSettings.marginScrollLeft + 'px'
                        },
                        wrapper: {
                            zIndex: currentSettings.zIndexStart + 2
                        },
                        loading: {
                            zIndex: currentSettings.zIndexStart + 3
                        }
                    }
                });
                iframeHideIE = $('<iframe id="nyroModalIframeHideIe" src="javascript:\'\';"></iframe>').css($.extend({}, currentSettings.css.bg, {
                    opacity: 0,
                    zIndex: 50,
                    border: 'none'
                }))
            }
            contain.append($('<div id="nyroModalFull"><div id="nyroModalBg"></div><div id="nyroModalWrapper"><div id="nyroModalContent"></div></div><div id="nyrModalTmp"></div><div id="nyroModalLoading"></div></div>').hide());
            modal.full = $('#nyroModalFull').css(full).show();
            modal.bg = $('#nyroModalBg').css($.extend({
                backgroundColor: currentSettings.bgColor
            }, currentSettings.css.bg)).before(iframeHideIE);
            if (!currentSettings.modal) modal.bg.click(removeModal);
            modal.loading = $('#nyroModalLoading').css(currentSettings.css.loading).hide();
            modal.contentWrapper = $('#nyroModalWrapper').css(currentSettings.css.wrapper).hide();
            modal.content = $('#nyroModalContent');
            modal.tmp = $('#nyrModalTmp').hide();
            if ($.isFunction($.fn.mousewheel)) {
                modal.content.mousewheel(function (e, d) {
                    var elt = modal.content.get(0);
                    if ((d > 0 && elt.scrollTop == 0) || (d < 0 && elt.scrollHeight - elt.scrollTop == elt.clientHeight)) {
                        e.preventDefault();
                        e.stopPropagation()
                    }
                })
            }
            $(document).bind('keydown.nyroModal', keyHandler);
            modal.content.css({
                width: 'auto',
                height: 'auto'
            });
            modal.contentWrapper.css({
                width: 'auto',
                height: 'auto'
            });
            if (!currentSettings.blocker) {
                $(window).bind('resize.nyroModal', function () {
                    window.clearTimeout(windowResizeTimeout);
                    windowResizeTimeout = window.setTimeout(windowResizeHandler, 200)
                })
            }
        }
    }
    function windowResizeHandler() {
        $.nyroModalSettings(initSettingsSize)
    }
    function showModal() {
        debug('showModal');
        if (!modal.ready) {
            initModal();
            modal.anim = true;
            currentSettings.showBackground(modal, currentSettings, endBackground)
        } else {
            modal.anim = true;
            modal.transition = true;
            currentSettings.showTransition(modal, currentSettings, function () {
                endHideContent();
                modal.anim = false;
                showContentOrLoading()
            })
        }
    }
    function keyHandler(e) {
        if (e.keyCode == 27) {
            if (!currentSettings.modal) removeModal()
        } else if (currentSettings.gallery && modal.ready && modal.dataReady && !modal.anim && !modal.transition) {
            if (e.keyCode == 39 || e.keyCode == 40) {
                e.preventDefault();
                $.nyroModalNext();
                return false
            } else if (e.keyCode == 37 || e.keyCode == 38) {
                e.preventDefault();
                $.nyroModalPrev();
                return false
            }
        }
    }
    function fileType() {
        var from = currentSettings.from;
        var url;
        if (from && from.nodeName) {
            var jFrom = $(from);
            url = jFrom.attr(from.nodeName.toLowerCase() == 'form' ? 'action' : 'href');
            if (!url) url = location.href.substring(window.location.host.length + 7);
            currentSettings.url = url;
            if (jFrom.attr('rev') == 'modal') currentSettings.modal = true;
            currentSettings.title = jFrom.attr('title');
            if (from && from.rel && from.rel.toLowerCase() != 'nofollow') {
                var indexSpace = from.rel.indexOf(' ');
                currentSettings.gallery = indexSpace > 0 ? from.rel.substr(0, indexSpace) : from.rel
            }
            var imgType = imageType(url, from);
            if (imgType) return imgType;
            if (isSwf(url)) return 'swf';
            var iframe = false;
            if (from.target && from.target.toLowerCase() == '_blank' || (from.hostname && from.hostname.replace(/:\d*$/, '') != window.location.hostname.replace(/:\d*$/, ''))) {
                iframe = true
            }
            if (from.nodeName.toLowerCase() == 'form') {
                if (iframe) return 'iframeForm';
                setCurrentSettings(extractUrlSel(url));
                if (jFrom.attr('enctype') == 'multipart/form-data') return 'formData';
                return 'form'
            }
            if (iframe) return 'iframe'
        } else {
            url = currentSettings.url;
            if (!currentSettings.content) currentSettings.from = true;
            if (!url) return null;
            if (isSwf(url)) return 'swf';
            var reg1 = new RegExp("^http://|https://", "g");
            if (url.match(reg1)) return 'iframe'
        }
        var imgType = imageType(url, from);
        if (imgType) return imgType;
        var tmp = extractUrlSel(url);
        setCurrentSettings(tmp);
        if (!tmp.url) return tmp.selector
    }
    function imageType(url, from) {
        var image = new RegExp(currentSettings.regexImg, 'i');
        if (image.test(url)) {
            return 'image'
        }
    }
    function isSwf(url) {
        var swf = new RegExp('[^\.]\.(swf)\s*$', 'i');
        return swf.test(url)
    }
    function extractUrlSel(url) {
        var ret = {
            url: null,
            selector: null
        };
        if (url) {
            var hash = getHash(url);
            var hashLoc = getHash(window.location.href);
            var curLoc = window.location.href.substring(0, window.location.href.length - hashLoc.length);
            var req = url.substring(0, url.length - hash.length);
            if (req == curLoc || req == $('base').attr('href')) {
                ret.selector = hash
            } else {
                ret.url = req;
                ret.selector = hash
            }
        }
        return ret
    }
    function loadingError() {
        debug('loadingError');
        modal.error = true;
        if (!modal.ready) return;
        if ($.isFunction(currentSettings.handleError)) currentSettings.handleError(modal, currentSettings);
        modal.loading.addClass(currentSettings.errorClass).html(currentSettings.contentError);
        $(currentSettings.closeSelector, modal.loading).unbind('click.nyroModal').bind('click.nyroModal', removeModal);
        setMarginLoading();
        modal.loading.css({
            marginTop: currentSettings.marginTopLoading + 'px',
            marginLeft: currentSettings.marginLeftLoading + 'px'
        })
    }
    function fillContent() {
        debug('fillContent');
        if (!modal.tmp.html()) return;
        modal.content.html(modal.tmp.contents());
        modal.tmp.empty();
        wrapContent();
        if (currentSettings.type == 'iframeForm') {
            $(currentSettings.from).attr('target', 'nyroModalIframe').data('nyroModalprocessing', 1).submit().attr('target', '_blank').removeData('nyroModalprocessing')
        }
        if (!currentSettings.modal) modal.wrapper.prepend(currentSettings.closeButton);
        if ($.isFunction(currentSettings.endFillContent)) currentSettings.endFillContent(modal, currentSettings);
        modal.content.append(modal.scripts);
        $(currentSettings.closeSelector, modal.contentWrapper).unbind('click.nyroModal').bind('click.nyroModal', removeModal);
        $(currentSettings.openSelector, modal.contentWrapper).nyroModal(getCurrentSettingsNew())
    }
    function getCurrentSettingsNew() {
        var currentSettingsNew = $.extend(true, {}, currentSettings);
        if (resized.width) currentSettingsNew.width = null;
        else currentSettingsNew.width = initSettingsSize.width;
        if (resized.height) currentSettingsNew.height = null;
        else currentSettingsNew.height = initSettingsSize.height;
        currentSettingsNew.css.content.overflow = 'auto';
        return currentSettingsNew
    }
    function wrapContent() {
        debug('wrapContent');
        var wrap = $(currentSettings.wrap[currentSettings.type]);
        modal.content.append(wrap.children().remove());
        modal.contentWrapper.wrapInner(wrap);
        if (currentSettings.gallery) {
            modal.content.append(currentSettings.galleryLinks);
            gallery.links = $('[rel="' + currentSettings.gallery + '"], [rel^="' + currentSettings.gallery + ' "]');
            gallery.index = gallery.links.index(currentSettings.from);
            if (currentSettings.galleryCounts && $.isFunction(currentSettings.galleryCounts)) currentSettings.galleryCounts(gallery.index + 1, gallery.links.length, modal, currentSettings);
            var currentSettingsNew = getCurrentSettingsNew();
            var linkPrev = getGalleryLink(-1);
            if (linkPrev) {
                var prev = $('.nyroModalPrev', modal.contentWrapper).attr('href', linkPrev.attr('href')).click(function (e) {
                    e.preventDefault();
                    $.nyroModalPrev();
                    return false
                });
                if (isIE6 && currentSettings.type == 'swf') {
                    prev.before($('<iframe id="nyroModalIframeHideIeGalleryPrev" src="javascript:\'\';"></iframe>').css({
                        position: prev.css('position'),
                        top: prev.css('top'),
                        left: prev.css('left'),
                        width: prev.width(),
                        height: prev.height(),
                        opacity: 0,
                        border: 'none'
                    }))
                }
            } else {
                $('.nyroModalPrev', modal.contentWrapper).remove()
            }
            var linkNext = getGalleryLink(1);
            if (linkNext) {
                var next = $('.nyroModalNext', modal.contentWrapper).attr('href', linkNext.attr('href')).click(function (e) {
                    e.preventDefault();
                    $.nyroModalNext();
                    return false
                });
                if (isIE6 && currentSettings.type == 'swf') {
                    next.before($('<iframe id="nyroModalIframeHideIeGalleryNext" src="javascript:\'\';"></iframe>').css($.extend({}, {
                        position: next.css('position'),
                        top: next.css('top'),
                        left: next.css('left'),
                        width: next.width(),
                        height: next.height(),
                        opacity: 0,
                        border: 'none'
                    })))
                }
            } else {
                $('.nyroModalNext', modal.contentWrapper).remove()
            }
        }
        calculateSize()
    }
    function getGalleryLink(dir) {
        if (currentSettings.gallery) {
            if (!currentSettings.ltr) dir *= -1;
            var index = gallery.index + dir;
            if (index >= 0 && index < gallery.links.length) return gallery.links.eq(index)
        }
        return false
    }
    function calculateSize(resizing) {
        debug('calculateSize');
        modal.wrapper = modal.contentWrapper.children('div:first');
        resized.width = false;
        resized.height = false;
        if (false && !currentSettings.windowResizing) {
            initSettingsSize.width = currentSettings.width;
            initSettingsSize.height = currentSettings.height
        }
        if (currentSettings.autoSizable && (!currentSettings.width || !currentSettings.height)) {
            modal.contentWrapper.css({
                opacity: 0,
                width: 'auto',
                height: 'auto'
            }).show();
            var tmp = {
                width: 'auto',
                height: 'auto'
            };
            if (currentSettings.width) {
                tmp.width = currentSettings.width
            } else if (currentSettings.type == 'iframe') {
                tmp.width = currentSettings.minWidth
            }
            if (currentSettings.height) {
                tmp.height = currentSettings.height
            } else if (currentSettings.type == 'iframe') {
                tmp.height = currentSettings.minHeight
            }
            modal.content.css(tmp);
            if (!currentSettings.width) {
                currentSettings.width = modal.content.outerWidth(true);
                resized.width = true
            }
            if (!currentSettings.height) {
                currentSettings.height = modal.content.outerHeight(true);
                resized.height = true
            }
            modal.contentWrapper.css({
                opacity: 1
            });
            if (!resizing) modal.contentWrapper.hide()
        }
        if (currentSettings.type != 'image' && currentSettings.type != 'swf') {
            currentSettings.width = Math.max(currentSettings.width, currentSettings.minWidth);
            currentSettings.height = Math.max(currentSettings.height, currentSettings.minHeight)
        }
        var outerWrapper = getOuter(modal.contentWrapper);
        var outerWrapper2 = getOuter(modal.wrapper);
        var outerContent = getOuter(modal.content);
        var tmp = {
            content: {
                width: currentSettings.width,
                height: currentSettings.height
            },
            wrapper2: {
                width: currentSettings.width + outerContent.w.total,
                height: currentSettings.height + outerContent.h.total
            },
            wrapper: {
                width: currentSettings.width + outerContent.w.total + outerWrapper2.w.total,
                height: currentSettings.height + outerContent.h.total + outerWrapper2.h.total
            }
        };
        if (currentSettings.resizable) {
            var maxHeight = modal.blockerVars ? modal.blockerVars.height : $(window).height() - outerWrapper.h.border - (tmp.wrapper.height - currentSettings.height);
            var maxWidth = modal.blockerVars ? modal.blockerVars.width : $(window).width() - outerWrapper.w.border - (tmp.wrapper.width - currentSettings.width);
            maxHeight -= currentSettings.padding * 2;
            maxWidth -= currentSettings.padding * 2;
            if (tmp.content.height > maxHeight || tmp.content.width > maxWidth) {
                if (currentSettings.type == 'image' || currentSettings.type == 'swf') {
                    var useW = currentSettings.imgWidth ? currentSettings.imgWidth : currentSettings.width;
                    var useH = currentSettings.imgHeight ? currentSettings.imgHeight : currentSettings.height;
                    var diffW = tmp.content.width - useW;
                    var diffH = tmp.content.height - useH;
                    if (diffH < 0) diffH = 0;
                    if (diffW < 0) diffW = 0;
                    var calcH = maxHeight - diffH;
                    var calcW = maxWidth - diffW;
                    var ratio = Math.min(calcH / useH, calcW / useW);
                    calcW = Math.floor(useW * ratio);
                    calcH = Math.floor(useH * ratio);
                    tmp.content.height = calcH + diffH;
                    tmp.content.width = calcW + diffW
                } else {
                    tmp.content.height = Math.min(tmp.content.height, maxHeight);
                    tmp.content.width = Math.min(tmp.content.width, maxWidth)
                }
                tmp.wrapper2 = {
                    width: tmp.content.width + outerContent.w.total,
                    height: tmp.content.height + outerContent.h.total
                };
                tmp.wrapper = {
                    width: tmp.content.width + outerContent.w.total + outerWrapper2.w.total,
                    height: tmp.content.height + outerContent.h.total + outerWrapper2.h.total
                }
            }
        }
        if (currentSettings.type == 'swf') {
            $('object, embed', modal.content).attr('width', tmp.content.width).attr('height', tmp.content.height)
        } else if (currentSettings.type == 'image') {
            $('img', modal.content).css({
                width: tmp.content.width,
                height: tmp.content.height
            })
        }
        modal.content.css($.extend({}, tmp.content, currentSettings.css.content));
        modal.wrapper.css($.extend({}, tmp.wrapper2, currentSettings.css.wrapper2));
        if (!resizing) modal.contentWrapper.css($.extend({}, tmp.wrapper, currentSettings.css.wrapper));
        if (currentSettings.type == 'image' && currentSettings.addImageDivTitle) {
            $('img', modal.content).removeAttr('alt');
            var divTitle = $('div', modal.content);
            if (currentSettings.title != currentSettings.defaultImgAlt && currentSettings.title) {
                if (divTitle.length == 0) {
                    divTitle = $('<div>' + currentSettings.title + '</div>');
                    modal.content.append(divTitle)
                }
                if (currentSettings.setWidthImgTitle) {
                    var outerDivTitle = getOuter(divTitle);
                    divTitle.css({
                        width: (tmp.content.width + outerContent.w.padding - outerDivTitle.w.total) + 'px'
                    })
                }
            } else if (divTitle.length = 0) {
                divTitle.remove()
            }
        }
        if (currentSettings.title) setTitle();
        tmp.wrapper.borderW = outerWrapper.w.border;
        tmp.wrapper.borderH = outerWrapper.h.border;
        setCurrentSettings(tmp.wrapper);
        setMargin()
    }
    function removeModal(e) {
        debug('removeModal');
        if (e) e.preventDefault();
        if (modal.full && modal.ready) {
            $(document).unbind('keydown.nyroModal');
            if (!currentSettings.blocker) $(window).unbind('resize.nyroModal');
            modal.ready = false;
            modal.anim = true;
            modal.closing = true;
            if (modal.loadingShown || modal.transition) {
                currentSettings.hideLoading(modal, currentSettings, function () {
                    modal.loading.hide();
                    modal.loadingShown = false;
                    modal.transition = false;
                    currentSettings.hideBackground(modal, currentSettings, endRemove)
                })
            } else {
                if (fixFF) modal.content.css({
                    position: ''
                });
                modal.wrapper.css({
                    overflow: 'hidden'
                });
                modal.content.css({
                    overflow: 'hidden'
                });
                if ($.isFunction(currentSettings.beforeHideContent)) {
                    currentSettings.beforeHideContent(modal, currentSettings, function () {
                        currentSettings.hideContent(modal, currentSettings, function () {
                            endHideContent();
                            currentSettings.hideBackground(modal, currentSettings, endRemove)
                        })
                    })
                } else {
                    currentSettings.hideContent(modal, currentSettings, function () {
                        endHideContent();
                        currentSettings.hideBackground(modal, currentSettings, endRemove)
                    })
                }
            }
        }
        if (e) return false
    }
    function showContentOrLoading() {
        debug('showContentOrLoading');
        if (modal.ready && !modal.anim) {
            if (modal.dataReady) {
                if (modal.tmp.html()) {
                    modal.anim = true;
                    if (modal.transition) {
                        fillContent();
                        modal.animContent = true;
                        currentSettings.hideTransition(modal, currentSettings, function () {
                            modal.loading.hide();
                            modal.transition = false;
                            modal.loadingShown = false;
                            endShowContent()
                        })
                    } else {
                        currentSettings.hideLoading(modal, currentSettings, function () {
                            modal.loading.hide();
                            modal.loadingShown = false;
                            fillContent();
                            setMarginLoading();
                            setMargin();
                            modal.animContent = true;
                            currentSettings.showContent(modal, currentSettings, endShowContent)
                        })
                    }
                }
            } else if (!modal.loadingShown && !modal.transition) {
                modal.anim = true;
                modal.loadingShown = true;
                if (modal.error) loadingError();
                else modal.loading.html(currentSettings.contentLoading);
                $(currentSettings.closeSelector, modal.loading).unbind('click.nyroModal').bind('click.nyroModal', removeModal);
                setMarginLoading();
                currentSettings.showLoading(modal, currentSettings, function () {
                    modal.anim = false;
                    showContentOrLoading()
                })
            }
        }
    }
    function ajaxLoaded(data) {
        debug('AjaxLoaded: ' + this.url);
        modal.tmp.html(currentSettings.selector ? filterScripts($('<div>' + data + '</div>').find(currentSettings.selector).contents()) : filterScripts(data));
        if (modal.tmp.html()) {
            modal.dataReady = true;
            showContentOrLoading()
        } else loadingError()
    }
    function formDataLoaded() {
        debug('formDataLoaded');
        var jFrom = $(currentSettings.from);
        jFrom.attr('action', jFrom.attr('action') + currentSettings.selector);
        jFrom.attr('target', '');
        $('input[name=' + currentSettings.formIndicator + ']', currentSettings.from).remove();
        var iframe = modal.tmp.children('iframe');
        var iframeContent = iframe.unbind('load').contents().find(currentSettings.selector || 'body').not('script[src]');
        iframe.attr('src', 'about:blank');
        modal.tmp.html(iframeContent.html());
        if (modal.tmp.html()) {
            modal.dataReady = true;
            showContentOrLoading()
        } else loadingError()
    }
    function iframeLoaded() {
        if ((window.location.hostname && currentSettings.url.indexOf(window.location.hostname) > -1) || currentSettings.url.indexOf('http://')) {
            var iframe = $('iframe', modal.full).contents();
            var tmp = {};
            if (currentSettings.titleFromIframe) tmp.title = iframe.find('title').text();
            if (!tmp.title) {
                try {
                    tmp.title = iframe.find('title').html()
                } catch (err) {}
            }
            var body = iframe.find('body');
            if (!currentSettings.height && body.height()) tmp.height = body.height();
            if (!currentSettings.width && body.width()) tmp.width = body.width();
            $.extend(initSettingsSize, tmp);
            $.nyroModalSettings(tmp)
        }
    }
    function galleryCounts(nb, total, elts, settings) {
        if (total > 1) settings.title += (settings.title ? ' - ' : '') + nb + '/' + total
    }
    function endHideContent() {
        debug('endHideContent');
        modal.anim = false;
        if (contentEltLast) {
            contentEltLast.append(modal.content.contents());
            contentEltLast = null
        } else if (contentElt) {
            contentElt.append(modal.content.contents());
            contentElt = null
        }
        modal.content.empty();
        gallery = {};
        modal.contentWrapper.hide().children().remove().empty().attr('style', '').hide();
        if (modal.closing || modal.transition) modal.contentWrapper.hide();
        modal.contentWrapper.css(currentSettings.css.wrapper).append(modal.content);
        showContentOrLoading()
    }
    function endRemove() {
        debug('endRemove');
        $(document).unbind('keydown', keyHandler);
        modal.anim = false;
        modal.full.remove();
        modal.full = null;
        if (isIE6) {
            body.css({
                height: '',
                width: '',
                position: '',
                overflow: ''
            });
            $('html').css({
                overflow: ''
            })
        }
        if ($.isFunction(currentSettings.endRemove)) currentSettings.endRemove(modal, currentSettings)
    }
    function endBackground() {
        debug('endBackground');
        modal.ready = true;
        modal.anim = false;
        showContentOrLoading()
    }
    function endShowContent() {
        debug('endShowContent');
        modal.anim = false;
        modal.animContent = false;
        modal.contentWrapper.css({
            opacity: ''
        });
        fixFF = /mozilla/.test(userAgent) && !/(compatible|webkit)/.test(userAgent) && parseFloat(browserVersion) < 1.9 && currentSettings.type != 'image';
        if (fixFF) modal.content.css({
            position: 'fixed'
        });
        modal.content.append(modal.scriptsShown);
        if (currentSettings.type == 'iframe') modal.content.find('iframe').attr('src', currentSettings.url);
        if ($.isFunction(currentSettings.endShowContent)) currentSettings.endShowContent(modal, currentSettings);
        if (shouldResize) {
            shouldResize = false;
            $.nyroModalSettings({
                width: currentSettings.setWidth,
                height: currentSettings.setHeight
            });
            delete currentSettings['setWidth'];
            delete currentSettings['setHeight']
        }
        if (resized.width) setCurrentSettings({
            width: null
        });
        if (resized.height) setCurrentSettings({
            height: null
        })
    }
    function getHash(url) {
        if (typeof url == 'string') {
            var hashPos = url.indexOf('#');
            if (hashPos > -1) return url.substring(hashPos)
        }
        return ''
    }
    function filterScripts(data) {
        if (typeof data == 'string') data = data.replace(/<\/?(html|head|body)([^>]*)>/gi, '');
        var tmp = new Array();
        $.each($.clean({
            0: data
        }, this.ownerDocument), function () {
            if ($.nodeName(this, "script")) {
                if (!this.src || $(this).attr('rel') == 'forceLoad') {
                    if ($(this).attr('rev') == 'shown') modal.scriptsShown.push(this);
                    else modal.scripts.push(this)
                }
            } else tmp.push(this)
        });
        return tmp
    }
    function getOuter(elm) {
        elm = elm.get(0);
        var ret = {
            h: {
                margin: getCurCSS(elm, 'marginTop') + getCurCSS(elm, 'marginBottom'),
                border: getCurCSS(elm, 'borderTopWidth') + getCurCSS(elm, 'borderBottomWidth'),
                padding: getCurCSS(elm, 'paddingTop') + getCurCSS(elm, 'paddingBottom')
            },
            w: {
                margin: getCurCSS(elm, 'marginLeft') + getCurCSS(elm, 'marginRight'),
                border: getCurCSS(elm, 'borderLeftWidth') + getCurCSS(elm, 'borderRightWidth'),
                padding: getCurCSS(elm, 'paddingLeft') + getCurCSS(elm, 'paddingRight')
            }
        };
        ret.h.outer = ret.h.margin + ret.h.border;
        ret.w.outer = ret.w.margin + ret.w.border;
        ret.h.inner = ret.h.padding + ret.h.border;
        ret.w.inner = ret.w.padding + ret.w.border;
        ret.h.total = ret.h.outer + ret.h.padding;
        ret.w.total = ret.w.outer + ret.w.padding;
        return ret
    }
    function getCurCSS(elm, name) {
        var ret = parseInt($.curCSS(elm, name, true));
        if (isNaN(ret)) ret = 0;
        return ret
    }
    function debug(msg) {
        if ($.fn.nyroModal.settings.debug || currentSettings && currentSettings.debug) nyroModalDebug(msg, modal, currentSettings || {})
    }
    function showBackground(elts, settings, callback) {
        elts.bg.css({
            opacity: 0
        }).fadeTo(500, 0.75, callback)
    }
    function hideBackground(elts, settings, callback) {
        elts.bg.fadeOut(300, callback)
    }
    function showLoading(elts, settings, callback) {
        elts.loading.css({
            marginTop: settings.marginTopLoading + 'px',
            marginLeft: settings.marginLeftLoading + 'px',
            opacity: 0
        }).show().animate({
            opacity: 1
        }, {
            complete: callback,
            duration: 400
        })
    }
    function hideLoading(elts, settings, callback) {
        callback()
    }
    function showContent(elts, settings, callback) {
        elts.loading.css({
            marginTop: settings.marginTopLoading + 'px',
            marginLeft: settings.marginLeftLoading + 'px'
        }).show().animate({
            width: settings.width + 'px',
            height: settings.height + 'px',
            marginTop: settings.marginTop + 'px',
            marginLeft: settings.marginLeft + 'px'
        }, {
            duration: 350,
            complete: function () {
                elts.contentWrapper.css({
                    width: settings.width + 'px',
                    height: settings.height + 'px',
                    marginTop: settings.marginTop + 'px',
                    marginLeft: settings.marginLeft + 'px'
                }).show();
                elts.loading.fadeOut(200, callback)
            }
        })
    }
    function hideContent(elts, settings, callback) {
        elts.contentWrapper.animate({
            height: '50px',
            width: '50px',
            marginTop: (-(25 + settings.borderH) / 2 + settings.marginScrollTop) + 'px',
            marginLeft: (-(25 + settings.borderW) / 2 + settings.marginScrollLeft) + 'px'
        }, {
            duration: 350,
            complete: function () {
                elts.contentWrapper.hide();
                callback()
            }
        })
    }
    function showTransition(elts, settings, callback) {
        elts.loading.css({
            marginTop: elts.contentWrapper.css('marginTop'),
            marginLeft: elts.contentWrapper.css('marginLeft'),
            height: elts.contentWrapper.css('height'),
            width: elts.contentWrapper.css('width'),
            opacity: 0
        }).show().fadeTo(400, 1, function () {
            elts.contentWrapper.hide();
            callback()
        })
    }
    function hideTransition(elts, settings, callback) {
        elts.contentWrapper.hide().css({
            width: settings.width + 'px',
            height: settings.height + 'px',
            marginLeft: settings.marginLeft + 'px',
            marginTop: settings.marginTop + 'px',
            opacity: 1
        });
        elts.loading.animate({
            width: settings.width + 'px',
            height: settings.height + 'px',
            marginLeft: settings.marginLeft + 'px',
            marginTop: settings.marginTop + 'px'
        }, {
            complete: function () {
                elts.contentWrapper.show();
                elts.loading.fadeOut(400, function () {
                    elts.loading.hide();
                    callback()
                })
            },
            duration: 350
        })
    }
    function resize(elts, settings, callback) {
        elts.contentWrapper.animate({
            width: settings.width + 'px',
            height: settings.height + 'px',
            marginLeft: settings.marginLeft + 'px',
            marginTop: settings.marginTop + 'px'
        }, {
            complete: callback,
            duration: 400
        })
    }
    function updateBgColor(elts, settings, callback) {
        if (!$.fx.step.backgroundColor) {
            elts.bg.css({
                backgroundColor: settings.bgColor
            });
            callback()
        } else elts.bg.animate({
            backgroundColor: settings.bgColor
        }, {
            complete: callback,
            duration: 400
        })
    }
    $($.fn.nyroModal.settings.openSelector).nyroModal()
});

function nyroModalDebug(msg, elts, settings) {
    if (elts.full) elts.bg.prepend(msg + '<br />')
}(function (d) {
    function g(b) {
        var a;
        if (b && b.constructor == Array && b.length == 3) return b;
        if (a = /rgb\(\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*\)/.exec(b)) return [parseInt(a[1]), parseInt(a[2]), parseInt(a[3])];
        if (a = /rgb\(\s*([0-9]+(?:\.[0-9]+)?)\%\s*,\s*([0-9]+(?:\.[0-9]+)?)\%\s*,\s*([0-9]+(?:\.[0-9]+)?)\%\s*\)/.exec(b)) return [parseFloat(a[1]) * 2.55, parseFloat(a[2]) * 2.55, parseFloat(a[3]) * 2.55];
        if (a = /#([a-fA-F0-9]{2})([a-fA-F0-9]{2})([a-fA-F0-9]{2})/.exec(b)) return [parseInt(a[1], 16), parseInt(a[2], 16), parseInt(a[3], 16)];
        if (a = /#([a-fA-F0-9])([a-fA-F0-9])([a-fA-F0-9])/.exec(b)) return [parseInt(a[1] + a[1], 16), parseInt(a[2] + a[2], 16), parseInt(a[3] + a[3], 16)];
        return e[d.trim(b).toLowerCase()]
    }
    d.each(["backgroundColor", "borderBottomColor", "borderLeftColor", "borderRightColor", "borderTopColor", "color", "outlineColor"], function (b, a) {
        d.fx.step[a] = function (c) {
            if (c.state == 0) {
                var f;
                f = c.elem;
                var i = a,
                    h;
                do {
                    h = d.curCSS(f, i);
                    if (h != "" && h != "transparent" || d.nodeName(f, "body")) break;
                    i = "backgroundColor"
                } while (f = f.parentNode);
                f = g(h);
                c.start = f;
                c.end = g(c.end)
            }
            c.elem.style[a] = "rgb(" + [Math.max(Math.min(parseInt(c.pos * (c.end[0] - c.start[0]) + c.start[0]), 255), 0), Math.max(Math.min(parseInt(c.pos * (c.end[1] - c.start[1]) + c.start[1]), 255), 0), Math.max(Math.min(parseInt(c.pos * (c.end[2] - c.start[2]) + c.start[2]), 255), 0)].join(",") + ")"
        }
    });
    var e = {
        aqua: [0, 255, 255],
        azure: [240, 255, 255],
        beige: [245, 245, 220],
        black: [0, 0, 0],
        blue: [0, 0, 255],
        brown: [165, 42, 42],
        cyan: [0, 255, 255],
        darkblue: [0, 0, 139],
        darkcyan: [0, 139, 139],
        darkgrey: [169, 169, 169],
        darkgreen: [0, 100, 0],
        darkkhaki: [189, 183, 107],
        darkmagenta: [139, 0, 139],
        darkolivegreen: [85, 107, 47],
        darkorange: [255, 140, 0],
        darkorchid: [153, 50, 204],
        darkred: [139, 0, 0],
        darksalmon: [233, 150, 122],
        darkviolet: [148, 0, 211],
        fuchsia: [255, 0, 255],
        gold: [255, 215, 0],
        green: [0, 128, 0],
        indigo: [75, 0, 130],
        khaki: [240, 230, 140],
        lightblue: [173, 216, 230],
        lightcyan: [224, 255, 255],
        lightgreen: [144, 238, 144],
        lightgrey: [211, 211, 211],
        lightpink: [255, 182, 193],
        lightyellow: [255, 255, 224],
        lime: [0, 255, 0],
        magenta: [255, 0, 255],
        maroon: [128, 0, 0],
        navy: [0, 0, 128],
        olive: [128, 128, 0],
        orange: [255, 165, 0],
        pink: [255, 192, 203],
        purple: [128, 0, 128],
        violet: [128, 0, 128],
        red: [255, 0, 0],
        silver: [192, 192, 192],
        white: [255, 255, 255],
        yellow: [255, 255, 0]
    }
})(jQuery);
$(document).ready(function () {
    $("ul.subnav").parent().append("<span></span>");
    $("ul.topnav li span").click(function () {
        $(this).parent().find("ul.subnav").show();
        $(this).parent().hover(function () {}, function () {
            $(this).parent().find("ul.subnav").hide()
        })
    }).hover(function () {
        $(this).addClass("subhover_active")
    }, function () {
        $(this).removeClass("subhover_active")
    });
    $("ul.topnav li").mouseover(function () {
        $(this).find("span").addClass("subhover")
    }).mouseout(function () {
        $(this).find("span").removeClass("subhover")
    });
    var d = $("#main").height();
    $("#sidebar").height() < d && $("#sidebar").height(d);
    $("a.contact-a").addClass("gated-asset");
    gated = $("a.gated-asset");
    gated.attr("target", "_blank");
    for (d = 0; d < gated.length; d++) {
        var g = $(gated[d]);
        g.attr("href", g.attr("href") + "?modal")
    }
    oca = $("a.oca");
    for (d = 0; d < oca.length; d++) {
        var o = $(oca[d]);
        o.attr("href", o.attr("href") + "&oca")
    }
    gated.nyroModal({
        height: 680,
        autoSizable: true,
        showBackground: function (e, b, a) {
            a()
        },
        showContent: function (e, b, a) {
            e.bg.css({
                opacity: 0.75
            }).show();
            e.loading.css({
                opacity: 0,
                width: b.width + "px",
                height: b.height + "px",
                marginTop: b.marginTop + "px",
                marginLeft: b.marginLeft + "px"
            }).show().animate({
                opacity: 1
            }, {
                duration: 350,
                complete: function () {
                    e.contentWrapper.css({
                        width: b.width + "px",
                        height: b.height + "px",
                        marginTop: b.marginTop + "px",
                        marginLeft: b.marginLeft + "px"
                    }).show();
                    e.loading.fadeOut(200, a)
                }
            })
        },
        hideContent: function (e, b, a) {
            e.contentWrapper.animate({
                opacity: 0
            }, {
                duration: 150,
                complete: function () {
                    e.contentWrapper.hide();
                    a()
                }
            })
        }
    })
});

