Difference between revisions of "Team:NKU CHINA/interlab"

Line 9,326: Line 9,326:
 
         </footer>
 
         </footer>
 
          
 
          
        <script src="js/vendor/jquery-1.11.0.min.js"></script>
+
 
        <script>window.jQuery || document.write('<script src="js/vendor/jquery-1.11.0.min.js"><\/script>')</script>
+
        <script src="js/bootstrap.js"></script>
+
        <script src="js/plugins.js"></script>
+
        <script src="js/main.js"></script>
+
  
 +
        <script type="text/javascript">
 +
/**
 +
* bootstrap.js v3.0.0 by @fat and @mdo
 +
* Copyright 2013 Twitter Inc.
 +
* http://www.apache.org/licenses/LICENSE-2.0
 +
*/
 +
if (!jQuery) { throw new Error("Bootstrap requires jQuery") }
 +
 +
/* ========================================================================
 +
* Bootstrap: transition.js v3.0.0
 +
* http://twbs.github.com/bootstrap/javascript.html#transitions
 +
* ========================================================================
 +
* Copyright 2013 Twitter, Inc.
 +
*
 +
* Licensed under the Apache License, Version 2.0 (the "License");
 +
* you may not use this file except in compliance with the License.
 +
* You may obtain a copy of the License at
 +
*
 +
* http://www.apache.org/licenses/LICENSE-2.0
 +
*
 +
* Unless required by applicable law or agreed to in writing, software
 +
* distributed under the License is distributed on an "AS IS" BASIS,
 +
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 +
* See the License for the specific language governing permissions and
 +
* limitations under the License.
 +
* ======================================================================== */
 +
 +
 +
+function ($) { "use strict";
 +
 +
  // CSS TRANSITION SUPPORT (Shoutout: http://www.modernizr.com/)
 +
  // ============================================================
 +
 +
  function transitionEnd() {
 +
    var el = document.createElement('bootstrap')
 +
 +
    var transEndEventNames = {
 +
      'WebkitTransition' : 'webkitTransitionEnd'
 +
    , 'MozTransition'    : 'transitionend'
 +
    , 'OTransition'      : 'oTransitionEnd otransitionend'
 +
    , 'transition'      : 'transitionend'
 +
    }
 +
 +
    for (var name in transEndEventNames) {
 +
      if (el.style[name] !== undefined) {
 +
        return { end: transEndEventNames[name] }
 +
      }
 +
    }
 +
  }
 +
 +
  // http://blog.alexmaccaw.com/css-transitions
 +
  $.fn.emulateTransitionEnd = function (duration) {
 +
    var called = false, $el = this
 +
    $(this).one($.support.transition.end, function () { called = true })
 +
    var callback = function () { if (!called) $($el).trigger($.support.transition.end) }
 +
    setTimeout(callback, duration)
 +
    return this
 +
  }
 +
 +
  $(function () {
 +
    $.support.transition = transitionEnd()
 +
  })
 +
 +
}(window.jQuery);
 +
 +
/* ========================================================================
 +
* Bootstrap: alert.js v3.0.0
 +
* http://twbs.github.com/bootstrap/javascript.html#alerts
 +
* ========================================================================
 +
* Copyright 2013 Twitter, Inc.
 +
*
 +
* Licensed under the Apache License, Version 2.0 (the "License");
 +
* you may not use this file except in compliance with the License.
 +
* You may obtain a copy of the License at
 +
*
 +
* http://www.apache.org/licenses/LICENSE-2.0
 +
*
 +
* Unless required by applicable law or agreed to in writing, software
 +
* distributed under the License is distributed on an "AS IS" BASIS,
 +
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 +
* See the License for the specific language governing permissions and
 +
* limitations under the License.
 +
* ======================================================================== */
 +
 +
 +
+function ($) { "use strict";
 +
 +
  // ALERT CLASS DEFINITION
 +
  // ======================
 +
 +
  var dismiss = '[data-dismiss="alert"]'
 +
  var Alert  = function (el) {
 +
    $(el).on('click', dismiss, this.close)
 +
  }
 +
 +
  Alert.prototype.close = function (e) {
 +
    var $this    = $(this)
 +
    var selector = $this.attr('data-target')
 +
 +
    if (!selector) {
 +
      selector = $this.attr('href')
 +
      selector = selector && selector.replace(/.*(?=#[^\s]*$)/, '') // strip for ie7
 +
    }
 +
 +
    var $parent = $(selector)
 +
 +
    if (e) e.preventDefault()
 +
 +
    if (!$parent.length) {
 +
      $parent = $this.hasClass('alert') ? $this : $this.parent()
 +
    }
 +
 +
    $parent.trigger(e = $.Event('close.bs.alert'))
 +
 +
    if (e.isDefaultPrevented()) return
 +
 +
    $parent.removeClass('in')
 +
 +
    function removeElement() {
 +
      $parent.trigger('closed.bs.alert').remove()
 +
    }
 +
 +
    $.support.transition && $parent.hasClass('fade') ?
 +
      $parent
 +
        .one($.support.transition.end, removeElement)
 +
        .emulateTransitionEnd(150) :
 +
      removeElement()
 +
  }
 +
 +
 +
  // ALERT PLUGIN DEFINITION
 +
  // =======================
 +
 +
  var old = $.fn.alert
 +
 +
  $.fn.alert = function (option) {
 +
    return this.each(function () {
 +
      var $this = $(this)
 +
      var data  = $this.data('bs.alert')
 +
 +
      if (!data) $this.data('bs.alert', (data = new Alert(this)))
 +
      if (typeof option == 'string') data[option].call($this)
 +
    })
 +
  }
 +
 +
  $.fn.alert.Constructor = Alert
 +
 +
 +
  // ALERT NO CONFLICT
 +
  // =================
 +
 +
  $.fn.alert.noConflict = function () {
 +
    $.fn.alert = old
 +
    return this
 +
  }
 +
 +
 +
  // ALERT DATA-API
 +
  // ==============
 +
 +
  $(document).on('click.bs.alert.data-api', dismiss, Alert.prototype.close)
 +
 +
}(window.jQuery);
 +
 +
/* ========================================================================
 +
* Bootstrap: button.js v3.0.0
 +
* http://twbs.github.com/bootstrap/javascript.html#buttons
 +
* ========================================================================
 +
* Copyright 2013 Twitter, Inc.
 +
*
 +
* Licensed under the Apache License, Version 2.0 (the "License");
 +
* you may not use this file except in compliance with the License.
 +
* You may obtain a copy of the License at
 +
*
 +
* http://www.apache.org/licenses/LICENSE-2.0
 +
*
 +
* Unless required by applicable law or agreed to in writing, software
 +
* distributed under the License is distributed on an "AS IS" BASIS,
 +
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 +
* See the License for the specific language governing permissions and
 +
* limitations under the License.
 +
* ======================================================================== */
 +
 +
 +
+function ($) { "use strict";
 +
 +
  // BUTTON PUBLIC CLASS DEFINITION
 +
  // ==============================
 +
 +
  var Button = function (element, options) {
 +
    this.$element = $(element)
 +
    this.options  = $.extend({}, Button.DEFAULTS, options)
 +
  }
 +
 +
  Button.DEFAULTS = {
 +
    loadingText: 'loading...'
 +
  }
 +
 +
  Button.prototype.setState = function (state) {
 +
    var d    = 'disabled'
 +
    var $el  = this.$element
 +
    var val  = $el.is('input') ? 'val' : 'html'
 +
    var data = $el.data()
 +
 +
    state = state + 'Text'
 +
 +
    if (!data.resetText) $el.data('resetText', $el[val]())
 +
 +
    $el[val](data[state] || this.options[state])
 +
 +
    // push to event loop to allow forms to submit
 +
    setTimeout(function () {
 +
      state == 'loadingText' ?
 +
        $el.addClass(d).attr(d, d) :
 +
        $el.removeClass(d).removeAttr(d);
 +
    }, 0)
 +
  }
 +
 +
  Button.prototype.toggle = function () {
 +
    var $parent = this.$element.closest('[data-toggle="buttons"]')
 +
 +
    if ($parent.length) {
 +
      var $input = this.$element.find('input')
 +
        .prop('checked', !this.$element.hasClass('active'))
 +
        .trigger('change')
 +
      if ($input.prop('type') === 'radio') $parent.find('.active').removeClass('active')
 +
    }
 +
 +
    this.$element.toggleClass('active')
 +
  }
 +
 +
 +
  // BUTTON PLUGIN DEFINITION
 +
  // ========================
 +
 +
  var old = $.fn.button
 +
 +
  $.fn.button = function (option) {
 +
    return this.each(function () {
 +
      var $this  = $(this)
 +
      var data    = $this.data('bs.button')
 +
      var options = typeof option == 'object' && option
 +
 +
      if (!data) $this.data('bs.button', (data = new Button(this, options)))
 +
 +
      if (option == 'toggle') data.toggle()
 +
      else if (option) data.setState(option)
 +
    })
 +
  }
 +
 +
  $.fn.button.Constructor = Button
 +
 +
 +
  // BUTTON NO CONFLICT
 +
  // ==================
 +
 +
  $.fn.button.noConflict = function () {
 +
    $.fn.button = old
 +
    return this
 +
  }
 +
 +
 +
  // BUTTON DATA-API
 +
  // ===============
 +
 +
  $(document).on('click.bs.button.data-api', '[data-toggle^=button]', function (e) {
 +
    var $btn = $(e.target)
 +
    if (!$btn.hasClass('btn')) $btn = $btn.closest('.btn')
 +
    $btn.button('toggle')
 +
    e.preventDefault()
 +
  })
 +
 +
}(window.jQuery);
 +
 +
/* ========================================================================
 +
* Bootstrap: carousel.js v3.0.0
 +
* http://twbs.github.com/bootstrap/javascript.html#carousel
 +
* ========================================================================
 +
* Copyright 2012 Twitter, Inc.
 +
*
 +
* Licensed under the Apache License, Version 2.0 (the "License");
 +
* you may not use this file except in compliance with the License.
 +
* You may obtain a copy of the License at
 +
*
 +
* http://www.apache.org/licenses/LICENSE-2.0
 +
*
 +
* Unless required by applicable law or agreed to in writing, software
 +
* distributed under the License is distributed on an "AS IS" BASIS,
 +
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 +
* See the License for the specific language governing permissions and
 +
* limitations under the License.
 +
* ======================================================================== */
 +
 +
 +
+function ($) { "use strict";
 +
 +
  // CAROUSEL CLASS DEFINITION
 +
  // =========================
 +
 +
  var Carousel = function (element, options) {
 +
    this.$element    = $(element)
 +
    this.$indicators = this.$element.find('.carousel-indicators')
 +
    this.options    = options
 +
    this.paused      =
 +
    this.sliding    =
 +
    this.interval    =
 +
    this.$active    =
 +
    this.$items      = null
 +
 +
    this.options.pause == 'hover' && this.$element
 +
      .on('mouseenter', $.proxy(this.pause, this))
 +
      .on('mouseleave', $.proxy(this.cycle, this))
 +
  }
 +
 +
  Carousel.DEFAULTS = {
 +
    interval: 5000
 +
  , pause: 'hover'
 +
  , wrap: true
 +
  }
 +
 +
  Carousel.prototype.cycle =  function (e) {
 +
    e || (this.paused = false)
 +
 +
    this.interval && clearInterval(this.interval)
 +
 +
    this.options.interval
 +
      && !this.paused
 +
      && (this.interval = setInterval($.proxy(this.next, this), this.options.interval))
 +
 +
    return this
 +
  }
 +
 +
  Carousel.prototype.getActiveIndex = function () {
 +
    this.$active = this.$element.find('.item.active')
 +
    this.$items  = this.$active.parent().children()
 +
 +
    return this.$items.index(this.$active)
 +
  }
 +
 +
  Carousel.prototype.to = function (pos) {
 +
    var that        = this
 +
    var activeIndex = this.getActiveIndex()
 +
 +
    if (pos > (this.$items.length - 1) || pos < 0) return
 +
 +
    if (this.sliding)      return this.$element.one('slid', function () { that.to(pos) })
 +
    if (activeIndex == pos) return this.pause().cycle()
 +
 +
    return this.slide(pos > activeIndex ? 'next' : 'prev', $(this.$items[pos]))
 +
  }
 +
 +
  Carousel.prototype.pause = function (e) {
 +
    e || (this.paused = true)
 +
 +
    if (this.$element.find('.next, .prev').length && $.support.transition.end) {
 +
      this.$element.trigger($.support.transition.end)
 +
      this.cycle(true)
 +
    }
 +
 +
    this.interval = clearInterval(this.interval)
 +
 +
    return this
 +
  }
 +
 +
  Carousel.prototype.next = function () {
 +
    if (this.sliding) return
 +
    return this.slide('next')
 +
  }
 +
 +
  Carousel.prototype.prev = function () {
 +
    if (this.sliding) return
 +
    return this.slide('prev')
 +
  }
 +
 +
  Carousel.prototype.slide = function (type, next) {
 +
    var $active  = this.$element.find('.item.active')
 +
    var $next    = next || $active[type]()
 +
    var isCycling = this.interval
 +
    var direction = type == 'next' ? 'left' : 'right'
 +
    var fallback  = type == 'next' ? 'first' : 'last'
 +
    var that      = this
 +
 +
    if (!$next.length) {
 +
      if (!this.options.wrap) return
 +
      $next = this.$element.find('.item')[fallback]()
 +
    }
 +
 +
    this.sliding = true
 +
 +
    isCycling && this.pause()
 +
 +
    var e = $.Event('slide.bs.carousel', { relatedTarget: $next[0], direction: direction })
 +
 +
    if ($next.hasClass('active')) return
 +
 +
    if (this.$indicators.length) {
 +
      this.$indicators.find('.active').removeClass('active')
 +
      this.$element.one('slid', function () {
 +
        var $nextIndicator = $(that.$indicators.children()[that.getActiveIndex()])
 +
        $nextIndicator && $nextIndicator.addClass('active')
 +
      })
 +
    }
 +
 +
    if ($.support.transition && this.$element.hasClass('slide')) {
 +
      this.$element.trigger(e)
 +
      if (e.isDefaultPrevented()) return
 +
      $next.addClass(type)
 +
      $next[0].offsetWidth // force reflow
 +
      $active.addClass(direction)
 +
      $next.addClass(direction)
 +
      $active
 +
        .one($.support.transition.end, function () {
 +
          $next.removeClass([type, direction].join(' ')).addClass('active')
 +
          $active.removeClass(['active', direction].join(' '))
 +
          that.sliding = false
 +
          setTimeout(function () { that.$element.trigger('slid') }, 0)
 +
        })
 +
        .emulateTransitionEnd(600)
 +
    } else {
 +
      this.$element.trigger(e)
 +
      if (e.isDefaultPrevented()) return
 +
      $active.removeClass('active')
 +
      $next.addClass('active')
 +
      this.sliding = false
 +
      this.$element.trigger('slid')
 +
    }
 +
 +
    isCycling && this.cycle()
 +
 +
    return this
 +
  }
 +
 +
 +
  // CAROUSEL PLUGIN DEFINITION
 +
  // ==========================
 +
 +
  var old = $.fn.carousel
 +
 +
  $.fn.carousel = function (option) {
 +
    return this.each(function () {
 +
      var $this  = $(this)
 +
      var data    = $this.data('bs.carousel')
 +
      var options = $.extend({}, Carousel.DEFAULTS, $this.data(), typeof option == 'object' && option)
 +
      var action  = typeof option == 'string' ? option : options.slide
 +
 +
      if (!data) $this.data('bs.carousel', (data = new Carousel(this, options)))
 +
      if (typeof option == 'number') data.to(option)
 +
      else if (action) data[action]()
 +
      else if (options.interval) data.pause().cycle()
 +
    })
 +
  }
 +
 +
  $.fn.carousel.Constructor = Carousel
 +
 +
 +
  // CAROUSEL NO CONFLICT
 +
  // ====================
 +
 +
  $.fn.carousel.noConflict = function () {
 +
    $.fn.carousel = old
 +
    return this
 +
  }
 +
 +
 +
  // CAROUSEL DATA-API
 +
  // =================
 +
 +
  $(document).on('click.bs.carousel.data-api', '[data-slide], [data-slide-to]', function (e) {
 +
    var $this  = $(this), href
 +
    var $target = $($this.attr('data-target') || (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '')) //strip for ie7
 +
    var options = $.extend({}, $target.data(), $this.data())
 +
    var slideIndex = $this.attr('data-slide-to')
 +
    if (slideIndex) options.interval = false
 +
 +
    $target.carousel(options)
 +
 +
    if (slideIndex = $this.attr('data-slide-to')) {
 +
      $target.data('bs.carousel').to(slideIndex)
 +
    }
 +
 +
    e.preventDefault()
 +
  })
 +
 +
  $(window).on('load', function () {
 +
    $('[data-ride="carousel"]').each(function () {
 +
      var $carousel = $(this)
 +
      $carousel.carousel($carousel.data())
 +
    })
 +
  })
 +
 +
}(window.jQuery);
 +
 +
/* ========================================================================
 +
* Bootstrap: collapse.js v3.0.0
 +
* http://twbs.github.com/bootstrap/javascript.html#collapse
 +
* ========================================================================
 +
* Copyright 2012 Twitter, Inc.
 +
*
 +
* Licensed under the Apache License, Version 2.0 (the "License");
 +
* you may not use this file except in compliance with the License.
 +
* You may obtain a copy of the License at
 +
*
 +
* http://www.apache.org/licenses/LICENSE-2.0
 +
*
 +
* Unless required by applicable law or agreed to in writing, software
 +
* distributed under the License is distributed on an "AS IS" BASIS,
 +
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 +
* See the License for the specific language governing permissions and
 +
* limitations under the License.
 +
* ======================================================================== */
 +
 +
 +
+function ($) { "use strict";
 +
 +
  // COLLAPSE PUBLIC CLASS DEFINITION
 +
  // ================================
 +
 +
  var Collapse = function (element, options) {
 +
    this.$element      = $(element)
 +
    this.options      = $.extend({}, Collapse.DEFAULTS, options)
 +
    this.transitioning = null
 +
 +
    if (this.options.parent) this.$parent = $(this.options.parent)
 +
    if (this.options.toggle) this.toggle()
 +
  }
 +
 +
  Collapse.DEFAULTS = {
 +
    toggle: true
 +
  }
 +
 +
  Collapse.prototype.dimension = function () {
 +
    var hasWidth = this.$element.hasClass('width')
 +
    return hasWidth ? 'width' : 'height'
 +
  }
 +
 +
  Collapse.prototype.show = function () {
 +
    if (this.transitioning || this.$element.hasClass('in')) return
 +
 +
    var startEvent = $.Event('show.bs.collapse')
 +
    this.$element.trigger(startEvent)
 +
    if (startEvent.isDefaultPrevented()) return
 +
 +
    var actives = this.$parent && this.$parent.find('> .panel > .in')
 +
 +
    if (actives && actives.length) {
 +
      var hasData = actives.data('bs.collapse')
 +
      if (hasData && hasData.transitioning) return
 +
      actives.collapse('hide')
 +
      hasData || actives.data('bs.collapse', null)
 +
    }
 +
 +
    var dimension = this.dimension()
 +
 +
    this.$element
 +
      .removeClass('collapse')
 +
      .addClass('collapsing')
 +
      [dimension](0)
 +
 +
    this.transitioning = 1
 +
 +
    var complete = function () {
 +
      this.$element
 +
        .removeClass('collapsing')
 +
        .addClass('in')
 +
        [dimension]('auto')
 +
      this.transitioning = 0
 +
      this.$element.trigger('shown.bs.collapse')
 +
    }
 +
 +
    if (!$.support.transition) return complete.call(this)
 +
 +
    var scrollSize = $.camelCase(['scroll', dimension].join('-'))
 +
 +
    this.$element
 +
      .one($.support.transition.end, $.proxy(complete, this))
 +
      .emulateTransitionEnd(350)
 +
      [dimension](this.$element[0][scrollSize])
 +
  }
 +
 +
  Collapse.prototype.hide = function () {
 +
    if (this.transitioning || !this.$element.hasClass('in')) return
 +
 +
    var startEvent = $.Event('hide.bs.collapse')
 +
    this.$element.trigger(startEvent)
 +
    if (startEvent.isDefaultPrevented()) return
 +
 +
    var dimension = this.dimension()
 +
 +
    this.$element
 +
      [dimension](this.$element[dimension]())
 +
      [0].offsetHeight
 +
 +
    this.$element
 +
      .addClass('collapsing')
 +
      .removeClass('collapse')
 +
      .removeClass('in')
 +
 +
    this.transitioning = 1
 +
 +
    var complete = function () {
 +
      this.transitioning = 0
 +
      this.$element
 +
        .trigger('hidden.bs.collapse')
 +
        .removeClass('collapsing')
 +
        .addClass('collapse')
 +
    }
 +
 +
    if (!$.support.transition) return complete.call(this)
 +
 +
    this.$element
 +
      [dimension](0)
 +
      .one($.support.transition.end, $.proxy(complete, this))
 +
      .emulateTransitionEnd(350)
 +
  }
 +
 +
  Collapse.prototype.toggle = function () {
 +
    this[this.$element.hasClass('in') ? 'hide' : 'show']()
 +
  }
 +
 +
 +
  // COLLAPSE PLUGIN DEFINITION
 +
  // ==========================
 +
 +
  var old = $.fn.collapse
 +
 +
  $.fn.collapse = function (option) {
 +
    return this.each(function () {
 +
      var $this  = $(this)
 +
      var data    = $this.data('bs.collapse')
 +
      var options = $.extend({}, Collapse.DEFAULTS, $this.data(), typeof option == 'object' && option)
 +
 +
      if (!data) $this.data('bs.collapse', (data = new Collapse(this, options)))
 +
      if (typeof option == 'string') data[option]()
 +
    })
 +
  }
 +
 +
  $.fn.collapse.Constructor = Collapse
 +
 +
 +
  // COLLAPSE NO CONFLICT
 +
  // ====================
 +
 +
  $.fn.collapse.noConflict = function () {
 +
    $.fn.collapse = old
 +
    return this
 +
  }
 +
 +
 +
  // COLLAPSE DATA-API
 +
  // =================
 +
 +
  $(document).on('click.bs.collapse.data-api', '[data-toggle=collapse]', function (e) {
 +
    var $this  = $(this), href
 +
    var target  = $this.attr('data-target')
 +
        || e.preventDefault()
 +
        || (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '') //strip for ie7
 +
    var $target = $(target)
 +
    var data    = $target.data('bs.collapse')
 +
    var option  = data ? 'toggle' : $this.data()
 +
    var parent  = $this.attr('data-parent')
 +
    var $parent = parent && $(parent)
 +
 +
    if (!data || !data.transitioning) {
 +
      if ($parent) $parent.find('[data-toggle=collapse][data-parent="' + parent + '"]').not($this).addClass('collapsed')
 +
      $this[$target.hasClass('in') ? 'addClass' : 'removeClass']('collapsed')
 +
    }
 +
 +
    $target.collapse(option)
 +
  })
 +
 +
}(window.jQuery);
 +
 +
/* ========================================================================
 +
* Bootstrap: dropdown.js v3.0.0
 +
* http://twbs.github.com/bootstrap/javascript.html#dropdowns
 +
* ========================================================================
 +
* Copyright 2012 Twitter, Inc.
 +
*
 +
* Licensed under the Apache License, Version 2.0 (the "License");
 +
* you may not use this file except in compliance with the License.
 +
* You may obtain a copy of the License at
 +
*
 +
* http://www.apache.org/licenses/LICENSE-2.0
 +
*
 +
* Unless required by applicable law or agreed to in writing, software
 +
* distributed under the License is distributed on an "AS IS" BASIS,
 +
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 +
* See the License for the specific language governing permissions and
 +
* limitations under the License.
 +
* ======================================================================== */
 +
 +
 +
+function ($) { "use strict";
 +
 +
  // DROPDOWN CLASS DEFINITION
 +
  // =========================
 +
 +
  var backdrop = '.dropdown-backdrop'
 +
  var toggle  = '[data-toggle=dropdown]'
 +
  var Dropdown = function (element) {
 +
    var $el = $(element).on('click.bs.dropdown', this.toggle)
 +
  }
 +
 +
  Dropdown.prototype.toggle = function (e) {
 +
    var $this = $(this)
 +
 +
    if ($this.is('.disabled, :disabled')) return
 +
 +
    var $parent  = getParent($this)
 +
    var isActive = $parent.hasClass('open')
 +
 +
    clearMenus()
 +
 +
    if (!isActive) {
 +
      if ('ontouchstart' in document.documentElement && !$parent.closest('.navbar-nav').length) {
 +
        // if mobile we we use a backdrop because click events don't delegate
 +
        $('<div class="dropdown-backdrop"/>').insertAfter($(this)).on('click', clearMenus)
 +
      }
 +
 +
      $parent.trigger(e = $.Event('show.bs.dropdown'))
 +
 +
      if (e.isDefaultPrevented()) return
 +
 +
      $parent
 +
        .toggleClass('open')
 +
        .trigger('shown.bs.dropdown')
 +
 +
      $this.focus()
 +
    }
 +
 +
    return false
 +
  }
 +
 +
  Dropdown.prototype.keydown = function (e) {
 +
    if (!/(38|40|27)/.test(e.keyCode)) return
 +
 +
    var $this = $(this)
 +
 +
    e.preventDefault()
 +
    e.stopPropagation()
 +
 +
    if ($this.is('.disabled, :disabled')) return
 +
 +
    var $parent  = getParent($this)
 +
    var isActive = $parent.hasClass('open')
 +
 +
    if (!isActive || (isActive && e.keyCode == 27)) {
 +
      if (e.which == 27) $parent.find(toggle).focus()
 +
      return $this.click()
 +
    }
 +
 +
    var $items = $('[role=menu] li:not(.divider):visible a', $parent)
 +
 +
    if (!$items.length) return
 +
 +
    var index = $items.index($items.filter(':focus'))
 +
 +
    if (e.keyCode == 38 && index > 0)                index--                        // up
 +
    if (e.keyCode == 40 && index < $items.length - 1) index++                        // down
 +
    if (!~index)                                      index=0
 +
 +
    $items.eq(index).focus()
 +
  }
 +
 +
  function clearMenus() {
 +
    $(backdrop).remove()
 +
    $(toggle).each(function (e) {
 +
      var $parent = getParent($(this))
 +
      if (!$parent.hasClass('open')) return
 +
      $parent.trigger(e = $.Event('hide.bs.dropdown'))
 +
      if (e.isDefaultPrevented()) return
 +
      $parent.removeClass('open').trigger('hidden.bs.dropdown')
 +
    })
 +
  }
 +
 +
  function getParent($this) {
 +
    var selector = $this.attr('data-target')
 +
 +
    if (!selector) {
 +
      selector = $this.attr('href')
 +
      selector = selector && /#/.test(selector) && selector.replace(/.*(?=#[^\s]*$)/, '') //strip for ie7
 +
    }
 +
 +
    var $parent = selector && $(selector)
 +
 +
    return $parent && $parent.length ? $parent : $this.parent()
 +
  }
 +
 +
 +
  // DROPDOWN PLUGIN DEFINITION
 +
  // ==========================
 +
 +
  var old = $.fn.dropdown
 +
 +
  $.fn.dropdown = function (option) {
 +
    return this.each(function () {
 +
      var $this = $(this)
 +
      var data  = $this.data('dropdown')
 +
 +
      if (!data) $this.data('dropdown', (data = new Dropdown(this)))
 +
      if (typeof option == 'string') data[option].call($this)
 +
    })
 +
  }
 +
 +
  $.fn.dropdown.Constructor = Dropdown
 +
 +
 +
  // DROPDOWN NO CONFLICT
 +
  // ====================
 +
 +
  $.fn.dropdown.noConflict = function () {
 +
    $.fn.dropdown = old
 +
    return this
 +
  }
 +
 +
 +
  // APPLY TO STANDARD DROPDOWN ELEMENTS
 +
  // ===================================
 +
 +
  $(document)
 +
    .on('click.bs.dropdown.data-api', clearMenus)
 +
    .on('click.bs.dropdown.data-api', '.dropdown form', function (e) { e.stopPropagation() })
 +
    .on('click.bs.dropdown.data-api'  , toggle, Dropdown.prototype.toggle)
 +
    .on('keydown.bs.dropdown.data-api', toggle + ', [role=menu]' , Dropdown.prototype.keydown)
 +
 +
}(window.jQuery);
 +
 +
/* ========================================================================
 +
* Bootstrap: modal.js v3.0.0
 +
* http://twbs.github.com/bootstrap/javascript.html#modals
 +
* ========================================================================
 +
* Copyright 2012 Twitter, Inc.
 +
*
 +
* Licensed under the Apache License, Version 2.0 (the "License");
 +
* you may not use this file except in compliance with the License.
 +
* You may obtain a copy of the License at
 +
*
 +
* http://www.apache.org/licenses/LICENSE-2.0
 +
*
 +
* Unless required by applicable law or agreed to in writing, software
 +
* distributed under the License is distributed on an "AS IS" BASIS,
 +
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 +
* See the License for the specific language governing permissions and
 +
* limitations under the License.
 +
* ======================================================================== */
 +
 +
 +
+function ($) { "use strict";
 +
 +
  // MODAL CLASS DEFINITION
 +
  // ======================
 +
 +
  var Modal = function (element, options) {
 +
    this.options  = options
 +
    this.$element  = $(element)
 +
    this.$backdrop =
 +
    this.isShown  = null
 +
 +
    if (this.options.remote) this.$element.load(this.options.remote)
 +
  }
 +
 +
  Modal.DEFAULTS = {
 +
      backdrop: true
 +
    , keyboard: true
 +
    , show: true
 +
  }
 +
 +
  Modal.prototype.toggle = function (_relatedTarget) {
 +
    return this[!this.isShown ? 'show' : 'hide'](_relatedTarget)
 +
  }
 +
 +
  Modal.prototype.show = function (_relatedTarget) {
 +
    var that = this
 +
    var e    = $.Event('show.bs.modal', { relatedTarget: _relatedTarget })
 +
 +
    this.$element.trigger(e)
 +
 +
    if (this.isShown || e.isDefaultPrevented()) return
 +
 +
    this.isShown = true
 +
 +
    this.escape()
 +
 +
    this.$element.on('click.dismiss.modal', '[data-dismiss="modal"]', $.proxy(this.hide, this))
 +
 +
    this.backdrop(function () {
 +
      var transition = $.support.transition && that.$element.hasClass('fade')
 +
 +
      if (!that.$element.parent().length) {
 +
        that.$element.appendTo(document.body) // don't move modals dom position
 +
      }
 +
 +
      that.$element.show()
 +
 +
      if (transition) {
 +
        that.$element[0].offsetWidth // force reflow
 +
      }
 +
 +
      that.$element
 +
        .addClass('in')
 +
        .attr('aria-hidden', false)
 +
 +
      that.enforceFocus()
 +
 +
      var e = $.Event('shown.bs.modal', { relatedTarget: _relatedTarget })
 +
 +
      transition ?
 +
        that.$element.find('.modal-dialog') // wait for modal to slide in
 +
          .one($.support.transition.end, function () {
 +
            that.$element.focus().trigger(e)
 +
          })
 +
          .emulateTransitionEnd(300) :
 +
        that.$element.focus().trigger(e)
 +
    })
 +
  }
 +
 +
  Modal.prototype.hide = function (e) {
 +
    if (e) e.preventDefault()
 +
 +
    e = $.Event('hide.bs.modal')
 +
 +
    this.$element.trigger(e)
 +
 +
    if (!this.isShown || e.isDefaultPrevented()) return
 +
 +
    this.isShown = false
 +
 +
    this.escape()
 +
 +
    $(document).off('focusin.bs.modal')
 +
 +
    this.$element
 +
      .removeClass('in')
 +
      .attr('aria-hidden', true)
 +
      .off('click.dismiss.modal')
 +
 +
    $.support.transition && this.$element.hasClass('fade') ?
 +
      this.$element
 +
        .one($.support.transition.end, $.proxy(this.hideModal, this))
 +
        .emulateTransitionEnd(300) :
 +
      this.hideModal()
 +
  }
 +
 +
  Modal.prototype.enforceFocus = function () {
 +
    $(document)
 +
      .off('focusin.bs.modal') // guard against infinite focus loop
 +
      .on('focusin.bs.modal', $.proxy(function (e) {
 +
        if (this.$element[0] !== e.target && !this.$element.has(e.target).length) {
 +
          this.$element.focus()
 +
        }
 +
      }, this))
 +
  }
 +
 +
  Modal.prototype.escape = function () {
 +
    if (this.isShown && this.options.keyboard) {
 +
      this.$element.on('keyup.dismiss.bs.modal', $.proxy(function (e) {
 +
        e.which == 27 && this.hide()
 +
      }, this))
 +
    } else if (!this.isShown) {
 +
      this.$element.off('keyup.dismiss.bs.modal')
 +
    }
 +
  }
 +
 +
  Modal.prototype.hideModal = function () {
 +
    var that = this
 +
    this.$element.hide()
 +
    this.backdrop(function () {
 +
      that.removeBackdrop()
 +
      that.$element.trigger('hidden.bs.modal')
 +
    })
 +
  }
 +
 +
  Modal.prototype.removeBackdrop = function () {
 +
    this.$backdrop && this.$backdrop.remove()
 +
    this.$backdrop = null
 +
  }
 +
 +
  Modal.prototype.backdrop = function (callback) {
 +
    var that    = this
 +
    var animate = this.$element.hasClass('fade') ? 'fade' : ''
 +
 +
    if (this.isShown && this.options.backdrop) {
 +
      var doAnimate = $.support.transition && animate
 +
 +
      this.$backdrop = $('<div class="modal-backdrop ' + animate + '" />')
 +
        .appendTo(document.body)
 +
 +
      this.$element.on('click.dismiss.modal', $.proxy(function (e) {
 +
        if (e.target !== e.currentTarget) return
 +
        this.options.backdrop == 'static'
 +
          ? this.$element[0].focus.call(this.$element[0])
 +
          : this.hide.call(this)
 +
      }, this))
 +
 +
      if (doAnimate) this.$backdrop[0].offsetWidth // force reflow
 +
 +
      this.$backdrop.addClass('in')
 +
 +
      if (!callback) return
 +
 +
      doAnimate ?
 +
        this.$backdrop
 +
          .one($.support.transition.end, callback)
 +
          .emulateTransitionEnd(150) :
 +
        callback()
 +
 +
    } else if (!this.isShown && this.$backdrop) {
 +
      this.$backdrop.removeClass('in')
 +
 +
      $.support.transition && this.$element.hasClass('fade')?
 +
        this.$backdrop
 +
          .one($.support.transition.end, callback)
 +
          .emulateTransitionEnd(150) :
 +
        callback()
 +
 +
    } else if (callback) {
 +
      callback()
 +
    }
 +
  }
 +
 +
 +
  // MODAL PLUGIN DEFINITION
 +
  // =======================
 +
 +
  var old = $.fn.modal
 +
 +
  $.fn.modal = function (option, _relatedTarget) {
 +
    return this.each(function () {
 +
      var $this  = $(this)
 +
      var data    = $this.data('bs.modal')
 +
      var options = $.extend({}, Modal.DEFAULTS, $this.data(), typeof option == 'object' && option)
 +
 +
      if (!data) $this.data('bs.modal', (data = new Modal(this, options)))
 +
      if (typeof option == 'string') data[option](_relatedTarget)
 +
      else if (options.show) data.show(_relatedTarget)
 +
    })
 +
  }
 +
 +
  $.fn.modal.Constructor = Modal
 +
 +
 +
  // MODAL NO CONFLICT
 +
  // =================
 +
 +
  $.fn.modal.noConflict = function () {
 +
    $.fn.modal = old
 +
    return this
 +
  }
 +
 +
 +
  // MODAL DATA-API
 +
  // ==============
 +
 +
  $(document).on('click.bs.modal.data-api', '[data-toggle="modal"]', function (e) {
 +
    var $this  = $(this)
 +
    var href    = $this.attr('href')
 +
    var $target = $($this.attr('data-target') || (href && href.replace(/.*(?=#[^\s]+$)/, ''))) //strip for ie7
 +
    var option  = $target.data('modal') ? 'toggle' : $.extend({ remote: !/#/.test(href) && href }, $target.data(), $this.data())
 +
 +
    e.preventDefault()
 +
 +
    $target
 +
      .modal(option, this)
 +
      .one('hide', function () {
 +
        $this.is(':visible') && $this.focus()
 +
      })
 +
  })
 +
 +
  $(document)
 +
    .on('show.bs.modal',  '.modal', function () { $(document.body).addClass('modal-open') })
 +
    .on('hidden.bs.modal', '.modal', function () { $(document.body).removeClass('modal-open') })
 +
 +
}(window.jQuery);
 +
 +
/* ========================================================================
 +
* Bootstrap: tooltip.js v3.0.0
 +
* http://twbs.github.com/bootstrap/javascript.html#tooltip
 +
* Inspired by the original jQuery.tipsy by Jason Frame
 +
* ========================================================================
 +
* Copyright 2012 Twitter, Inc.
 +
*
 +
* Licensed under the Apache License, Version 2.0 (the "License");
 +
* you may not use this file except in compliance with the License.
 +
* You may obtain a copy of the License at
 +
*
 +
* http://www.apache.org/licenses/LICENSE-2.0
 +
*
 +
* Unless required by applicable law or agreed to in writing, software
 +
* distributed under the License is distributed on an "AS IS" BASIS,
 +
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 +
* See the License for the specific language governing permissions and
 +
* limitations under the License.
 +
* ======================================================================== */
 +
 +
 +
+function ($) { "use strict";
 +
 +
  // TOOLTIP PUBLIC CLASS DEFINITION
 +
  // ===============================
 +
 +
  var Tooltip = function (element, options) {
 +
    this.type      =
 +
    this.options    =
 +
    this.enabled    =
 +
    this.timeout    =
 +
    this.hoverState =
 +
    this.$element  = null
 +
 +
    this.init('tooltip', element, options)
 +
  }
 +
 +
  Tooltip.DEFAULTS = {
 +
    animation: true
 +
  , placement: 'top'
 +
  , selector: false
 +
  , template: '<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>'
 +
  , trigger: 'hover focus'
 +
  , title: ''
 +
  , delay: 0
 +
  , html: false
 +
  , container: false
 +
  }
 +
 +
  Tooltip.prototype.init = function (type, element, options) {
 +
    this.enabled  = true
 +
    this.type    = type
 +
    this.$element = $(element)
 +
    this.options  = this.getOptions(options)
 +
 +
    var triggers = this.options.trigger.split(' ')
 +
 +
    for (var i = triggers.length; i--;) {
 +
      var trigger = triggers[i]
 +
 +
      if (trigger == 'click') {
 +
        this.$element.on('click.' + this.type, this.options.selector, $.proxy(this.toggle, this))
 +
      } else if (trigger != 'manual') {
 +
        var eventIn  = trigger == 'hover' ? 'mouseenter' : 'focus'
 +
        var eventOut = trigger == 'hover' ? 'mouseleave' : 'blur'
 +
 +
        this.$element.on(eventIn  + '.' + this.type, this.options.selector, $.proxy(this.enter, this))
 +
        this.$element.on(eventOut + '.' + this.type, this.options.selector, $.proxy(this.leave, this))
 +
      }
 +
    }
 +
 +
    this.options.selector ?
 +
      (this._options = $.extend({}, this.options, { trigger: 'manual', selector: '' })) :
 +
      this.fixTitle()
 +
  }
 +
 +
  Tooltip.prototype.getDefaults = function () {
 +
    return Tooltip.DEFAULTS
 +
  }
 +
 +
  Tooltip.prototype.getOptions = function (options) {
 +
    options = $.extend({}, this.getDefaults(), this.$element.data(), options)
 +
 +
    if (options.delay && typeof options.delay == 'number') {
 +
      options.delay = {
 +
        show: options.delay
 +
      , hide: options.delay
 +
      }
 +
    }
 +
 +
    return options
 +
  }
 +
 +
  Tooltip.prototype.getDelegateOptions = function () {
 +
    var options  = {}
 +
    var defaults = this.getDefaults()
 +
 +
    this._options && $.each(this._options, function (key, value) {
 +
      if (defaults[key] != value) options[key] = value
 +
    })
 +
 +
    return options
 +
  }
 +
 +
  Tooltip.prototype.enter = function (obj) {
 +
    var self = obj instanceof this.constructor ?
 +
      obj : $(obj.currentTarget)[this.type](this.getDelegateOptions()).data('bs.' + this.type)
 +
 +
    clearTimeout(self.timeout)
 +
 +
    self.hoverState = 'in'
 +
 +
    if (!self.options.delay || !self.options.delay.show) return self.show()
 +
 +
    self.timeout = setTimeout(function () {
 +
      if (self.hoverState == 'in') self.show()
 +
    }, self.options.delay.show)
 +
  }
 +
 +
  Tooltip.prototype.leave = function (obj) {
 +
    var self = obj instanceof this.constructor ?
 +
      obj : $(obj.currentTarget)[this.type](this.getDelegateOptions()).data('bs.' + this.type)
 +
 +
    clearTimeout(self.timeout)
 +
 +
    self.hoverState = 'out'
 +
 +
    if (!self.options.delay || !self.options.delay.hide) return self.hide()
 +
 +
    self.timeout = setTimeout(function () {
 +
      if (self.hoverState == 'out') self.hide()
 +
    }, self.options.delay.hide)
 +
  }
 +
 +
  Tooltip.prototype.show = function () {
 +
    var e = $.Event('show.bs.'+ this.type)
 +
 +
    if (this.hasContent() && this.enabled) {
 +
      this.$element.trigger(e)
 +
 +
      if (e.isDefaultPrevented()) return
 +
 +
      var $tip = this.tip()
 +
 +
      this.setContent()
 +
 +
      if (this.options.animation) $tip.addClass('fade')
 +
 +
      var placement = typeof this.options.placement == 'function' ?
 +
        this.options.placement.call(this, $tip[0], this.$element[0]) :
 +
        this.options.placement
 +
 +
      var autoToken = /\s?auto?\s?/i
 +
      var autoPlace = autoToken.test(placement)
 +
      if (autoPlace) placement = placement.replace(autoToken, '') || 'top'
 +
 +
      $tip
 +
        .detach()
 +
        .css({ top: 0, left: 0, display: 'block' })
 +
        .addClass(placement)
 +
 +
      this.options.container ? $tip.appendTo(this.options.container) : $tip.insertAfter(this.$element)
 +
 +
      var pos          = this.getPosition()
 +
      var actualWidth  = $tip[0].offsetWidth
 +
      var actualHeight = $tip[0].offsetHeight
 +
 +
      if (autoPlace) {
 +
        var $parent = this.$element.parent()
 +
 +
        var orgPlacement = placement
 +
        var docScroll    = document.documentElement.scrollTop || document.body.scrollTop
 +
        var parentWidth  = this.options.container == 'body' ? window.innerWidth  : $parent.outerWidth()
 +
        var parentHeight = this.options.container == 'body' ? window.innerHeight : $parent.outerHeight()
 +
        var parentLeft  = this.options.container == 'body' ? 0 : $parent.offset().left
 +
 +
        placement = placement == 'bottom' && pos.top  + pos.height  + actualHeight - docScroll > parentHeight  ? 'top'    :
 +
                    placement == 'top'    && pos.top  - docScroll  - actualHeight < 0                        ? 'bottom' :
 +
                    placement == 'right'  && pos.right + actualWidth > parentWidth                              ? 'left'  :
 +
                    placement == 'left'  && pos.left  - actualWidth < parentLeft                              ? 'right'  :
 +
                    placement
 +
 +
        $tip
 +
          .removeClass(orgPlacement)
 +
          .addClass(placement)
 +
      }
 +
 +
      var calculatedOffset = this.getCalculatedOffset(placement, pos, actualWidth, actualHeight)
 +
 +
      this.applyPlacement(calculatedOffset, placement)
 +
      this.$element.trigger('shown.bs.' + this.type)
 +
    }
 +
  }
 +
 +
  Tooltip.prototype.applyPlacement = function(offset, placement) {
 +
    var replace
 +
    var $tip  = this.tip()
 +
    var width  = $tip[0].offsetWidth
 +
    var height = $tip[0].offsetHeight
 +
 +
    // manually read margins because getBoundingClientRect includes difference
 +
    var marginTop = parseInt($tip.css('margin-top'), 10)
 +
    var marginLeft = parseInt($tip.css('margin-left'), 10)
 +
 +
    // we must check for NaN for ie 8/9
 +
    if (isNaN(marginTop))  marginTop  = 0
 +
    if (isNaN(marginLeft)) marginLeft = 0
 +
 +
    offset.top  = offset.top  + marginTop
 +
    offset.left = offset.left + marginLeft
 +
 +
    $tip
 +
      .offset(offset)
 +
      .addClass('in')
 +
 +
    // check to see if placing tip in new offset caused the tip to resize itself
 +
    var actualWidth  = $tip[0].offsetWidth
 +
    var actualHeight = $tip[0].offsetHeight
 +
 +
    if (placement == 'top' && actualHeight != height) {
 +
      replace = true
 +
      offset.top = offset.top + height - actualHeight
 +
    }
 +
 +
    if (/bottom|top/.test(placement)) {
 +
      var delta = 0
 +
 +
      if (offset.left < 0) {
 +
        delta      = offset.left * -2
 +
        offset.left = 0
 +
 +
        $tip.offset(offset)
 +
 +
        actualWidth  = $tip[0].offsetWidth
 +
        actualHeight = $tip[0].offsetHeight
 +
      }
 +
 +
      this.replaceArrow(delta - width + actualWidth, actualWidth, 'left')
 +
    } else {
 +
      this.replaceArrow(actualHeight - height, actualHeight, 'top')
 +
    }
 +
 +
    if (replace) $tip.offset(offset)
 +
  }
 +
 +
  Tooltip.prototype.replaceArrow = function(delta, dimension, position) {
 +
    this.arrow().css(position, delta ? (50 * (1 - delta / dimension) + "%") : '')
 +
  }
 +
 +
  Tooltip.prototype.setContent = function () {
 +
    var $tip  = this.tip()
 +
    var title = this.getTitle()
 +
 +
    $tip.find('.tooltip-inner')[this.options.html ? 'html' : 'text'](title)
 +
    $tip.removeClass('fade in top bottom left right')
 +
  }
 +
 +
  Tooltip.prototype.hide = function () {
 +
    var that = this
 +
    var $tip = this.tip()
 +
    var e    = $.Event('hide.bs.' + this.type)
 +
 +
    function complete() {
 +
      if (that.hoverState != 'in') $tip.detach()
 +
    }
 +
 +
    this.$element.trigger(e)
 +
 +
    if (e.isDefaultPrevented()) return
 +
 +
    $tip.removeClass('in')
 +
 +
    $.support.transition && this.$tip.hasClass('fade') ?
 +
      $tip
 +
        .one($.support.transition.end, complete)
 +
        .emulateTransitionEnd(150) :
 +
      complete()
 +
 +
    this.$element.trigger('hidden.bs.' + this.type)
 +
 +
    return this
 +
  }
 +
 +
  Tooltip.prototype.fixTitle = function () {
 +
    var $e = this.$element
 +
    if ($e.attr('title') || typeof($e.attr('data-original-title')) != 'string') {
 +
      $e.attr('data-original-title', $e.attr('title') || '').attr('title', '')
 +
    }
 +
  }
 +
 +
  Tooltip.prototype.hasContent = function () {
 +
    return this.getTitle()
 +
  }
 +
 +
  Tooltip.prototype.getPosition = function () {
 +
    var el = this.$element[0]
 +
    return $.extend({}, (typeof el.getBoundingClientRect == 'function') ? el.getBoundingClientRect() : {
 +
      width: el.offsetWidth
 +
    , height: el.offsetHeight
 +
    }, this.$element.offset())
 +
  }
 +
 +
  Tooltip.prototype.getCalculatedOffset = function (placement, pos, actualWidth, actualHeight) {
 +
    return placement == 'bottom' ? { top: pos.top + pos.height,  left: pos.left + pos.width / 2 - actualWidth / 2  } :
 +
          placement == 'top'    ? { top: pos.top - actualHeight, left: pos.left + pos.width / 2 - actualWidth / 2  } :
 +
          placement == 'left'  ? { top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left - actualWidth } :
 +
        /* placement == 'right' */ { top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left + pos.width  }
 +
  }
 +
 +
  Tooltip.prototype.getTitle = function () {
 +
    var title
 +
    var $e = this.$element
 +
    var o  = this.options
 +
 +
    title = $e.attr('data-original-title')
 +
      || (typeof o.title == 'function' ? o.title.call($e[0]) :  o.title)
 +
 +
    return title
 +
  }
 +
 +
  Tooltip.prototype.tip = function () {
 +
    return this.$tip = this.$tip || $(this.options.template)
 +
  }
 +
 +
  Tooltip.prototype.arrow = function () {
 +
    return this.$arrow = this.$arrow || this.tip().find('.tooltip-arrow')
 +
  }
 +
 +
  Tooltip.prototype.validate = function () {
 +
    if (!this.$element[0].parentNode) {
 +
      this.hide()
 +
      this.$element = null
 +
      this.options  = null
 +
    }
 +
  }
 +
 +
  Tooltip.prototype.enable = function () {
 +
    this.enabled = true
 +
  }
 +
 +
  Tooltip.prototype.disable = function () {
 +
    this.enabled = false
 +
  }
 +
 +
  Tooltip.prototype.toggleEnabled = function () {
 +
    this.enabled = !this.enabled
 +
  }
 +
 +
  Tooltip.prototype.toggle = function (e) {
 +
    var self = e ? $(e.currentTarget)[this.type](this.getDelegateOptions()).data('bs.' + this.type) : this
 +
    self.tip().hasClass('in') ? self.leave(self) : self.enter(self)
 +
  }
 +
 +
  Tooltip.prototype.destroy = function () {
 +
    this.hide().$element.off('.' + this.type).removeData('bs.' + this.type)
 +
  }
 +
 +
 +
  // TOOLTIP PLUGIN DEFINITION
 +
  // =========================
 +
 +
  var old = $.fn.tooltip
 +
 +
  $.fn.tooltip = function (option) {
 +
    return this.each(function () {
 +
      var $this  = $(this)
 +
      var data    = $this.data('bs.tooltip')
 +
      var options = typeof option == 'object' && option
 +
 +
      if (!data) $this.data('bs.tooltip', (data = new Tooltip(this, options)))
 +
      if (typeof option == 'string') data[option]()
 +
    })
 +
  }
 +
 +
  $.fn.tooltip.Constructor = Tooltip
 +
 +
 +
  // TOOLTIP NO CONFLICT
 +
  // ===================
 +
 +
  $.fn.tooltip.noConflict = function () {
 +
    $.fn.tooltip = old
 +
    return this
 +
  }
 +
 +
}(window.jQuery);
 +
 +
/* ========================================================================
 +
* Bootstrap: popover.js v3.0.0
 +
* http://twbs.github.com/bootstrap/javascript.html#popovers
 +
* ========================================================================
 +
* Copyright 2012 Twitter, Inc.
 +
*
 +
* Licensed under the Apache License, Version 2.0 (the "License");
 +
* you may not use this file except in compliance with the License.
 +
* You may obtain a copy of the License at
 +
*
 +
* http://www.apache.org/licenses/LICENSE-2.0
 +
*
 +
* Unless required by applicable law or agreed to in writing, software
 +
* distributed under the License is distributed on an "AS IS" BASIS,
 +
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 +
* See the License for the specific language governing permissions and
 +
* limitations under the License.
 +
* ======================================================================== */
 +
 +
 +
+function ($) { "use strict";
 +
 +
  // POPOVER PUBLIC CLASS DEFINITION
 +
  // ===============================
 +
 +
  var Popover = function (element, options) {
 +
    this.init('popover', element, options)
 +
  }
 +
 +
  if (!$.fn.tooltip) throw new Error('Popover requires tooltip.js')
 +
 +
  Popover.DEFAULTS = $.extend({} , $.fn.tooltip.Constructor.DEFAULTS, {
 +
    placement: 'right'
 +
  , trigger: 'click'
 +
  , content: ''
 +
  , template: '<div class="popover"><div class="arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>'
 +
  })
 +
 +
 +
  // NOTE: POPOVER EXTENDS tooltip.js
 +
  // ================================
 +
 +
  Popover.prototype = $.extend({}, $.fn.tooltip.Constructor.prototype)
 +
 +
  Popover.prototype.constructor = Popover
 +
 +
  Popover.prototype.getDefaults = function () {
 +
    return Popover.DEFAULTS
 +
  }
 +
 +
  Popover.prototype.setContent = function () {
 +
    var $tip    = this.tip()
 +
    var title  = this.getTitle()
 +
    var content = this.getContent()
 +
 +
    $tip.find('.popover-title')[this.options.html ? 'html' : 'text'](title)
 +
    $tip.find('.popover-content')[this.options.html ? 'html' : 'text'](content)
 +
 +
    $tip.removeClass('fade top bottom left right in')
 +
 +
    // IE8 doesn't accept hiding via the `:empty` pseudo selector, we have to do
 +
    // this manually by checking the contents.
 +
    if (!$tip.find('.popover-title').html()) $tip.find('.popover-title').hide()
 +
  }
 +
 +
  Popover.prototype.hasContent = function () {
 +
    return this.getTitle() || this.getContent()
 +
  }
 +
 +
  Popover.prototype.getContent = function () {
 +
    var $e = this.$element
 +
    var o  = this.options
 +
 +
    return $e.attr('data-content')
 +
      || (typeof o.content == 'function' ?
 +
            o.content.call($e[0]) :
 +
            o.content)
 +
  }
 +
 +
  Popover.prototype.arrow = function () {
 +
    return this.$arrow = this.$arrow || this.tip().find('.arrow')
 +
  }
 +
 +
  Popover.prototype.tip = function () {
 +
    if (!this.$tip) this.$tip = $(this.options.template)
 +
    return this.$tip
 +
  }
 +
 +
 +
  // POPOVER PLUGIN DEFINITION
 +
  // =========================
 +
 +
  var old = $.fn.popover
 +
 +
  $.fn.popover = function (option) {
 +
    return this.each(function () {
 +
      var $this  = $(this)
 +
      var data    = $this.data('bs.popover')
 +
      var options = typeof option == 'object' && option
 +
 +
      if (!data) $this.data('bs.popover', (data = new Popover(this, options)))
 +
      if (typeof option == 'string') data[option]()
 +
    })
 +
  }
 +
 +
  $.fn.popover.Constructor = Popover
 +
 +
 +
  // POPOVER NO CONFLICT
 +
  // ===================
 +
 +
  $.fn.popover.noConflict = function () {
 +
    $.fn.popover = old
 +
    return this
 +
  }
 +
 +
}(window.jQuery);
 +
 +
/* ========================================================================
 +
* Bootstrap: scrollspy.js v3.0.0
 +
* http://twbs.github.com/bootstrap/javascript.html#scrollspy
 +
* ========================================================================
 +
* Copyright 2012 Twitter, Inc.
 +
*
 +
* Licensed under the Apache License, Version 2.0 (the "License");
 +
* you may not use this file except in compliance with the License.
 +
* You may obtain a copy of the License at
 +
*
 +
* http://www.apache.org/licenses/LICENSE-2.0
 +
*
 +
* Unless required by applicable law or agreed to in writing, software
 +
* distributed under the License is distributed on an "AS IS" BASIS,
 +
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 +
* See the License for the specific language governing permissions and
 +
* limitations under the License.
 +
* ======================================================================== */
 +
 +
 +
+function ($) { "use strict";
 +
 +
  // SCROLLSPY CLASS DEFINITION
 +
  // ==========================
 +
 +
  function ScrollSpy(element, options) {
 +
    var href
 +
    var process  = $.proxy(this.process, this)
 +
 +
    this.$element      = $(element).is('body') ? $(window) : $(element)
 +
    this.$body          = $('body')
 +
    this.$scrollElement = this.$element.on('scroll.bs.scroll-spy.data-api', process)
 +
    this.options        = $.extend({}, ScrollSpy.DEFAULTS, options)
 +
    this.selector      = (this.options.target
 +
      || ((href = $(element).attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '')) //strip for ie7
 +
      || '') + ' .nav li > a'
 +
    this.offsets        = $([])
 +
    this.targets        = $([])
 +
    this.activeTarget  = null
 +
 +
    this.refresh()
 +
    this.process()
 +
  }
 +
 +
  ScrollSpy.DEFAULTS = {
 +
    offset: 10
 +
  }
 +
 +
  ScrollSpy.prototype.refresh = function () {
 +
    var offsetMethod = this.$element[0] == window ? 'offset' : 'position'
 +
 +
    this.offsets = $([])
 +
    this.targets = $([])
 +
 +
    var self    = this
 +
    var $targets = this.$body
 +
      .find(this.selector)
 +
      .map(function () {
 +
        var $el  = $(this)
 +
        var href  = $el.data('target') || $el.attr('href')
 +
        var $href = /^#\w/.test(href) && $(href)
 +
 +
        return ($href
 +
          && $href.length
 +
          && [[ $href[offsetMethod]().top + (!$.isWindow(self.$scrollElement.get(0)) && self.$scrollElement.scrollTop()), href ]]) || null
 +
      })
 +
      .sort(function (a, b) { return a[0] - b[0] })
 +
      .each(function () {
 +
        self.offsets.push(this[0])
 +
        self.targets.push(this[1])
 +
      })
 +
  }
 +
 +
  ScrollSpy.prototype.process = function () {
 +
    var scrollTop    = this.$scrollElement.scrollTop() + this.options.offset
 +
    var scrollHeight = this.$scrollElement[0].scrollHeight || this.$body[0].scrollHeight
 +
    var maxScroll    = scrollHeight - this.$scrollElement.height()
 +
    var offsets      = this.offsets
 +
    var targets      = this.targets
 +
    var activeTarget = this.activeTarget
 +
    var i
 +
 +
    if (scrollTop >= maxScroll) {
 +
      return activeTarget != (i = targets.last()[0]) && this.activate(i)
 +
    }
 +
 +
    for (i = offsets.length; i--;) {
 +
      activeTarget != targets[i]
 +
        && scrollTop >= offsets[i]
 +
        && (!offsets[i + 1] || scrollTop <= offsets[i + 1])
 +
        && this.activate( targets[i] )
 +
    }
 +
  }
 +
 +
  ScrollSpy.prototype.activate = function (target) {
 +
    this.activeTarget = target
 +
 +
    $(this.selector)
 +
      .parents('.active')
 +
      .removeClass('active')
 +
 +
    var selector = this.selector
 +
      + '[data-target="' + target + '"],'
 +
      + this.selector + '[href="' + target + '"]'
 +
 +
    var active = $(selector)
 +
      .parents('li')
 +
      .addClass('active')
 +
 +
    if (active.parent('.dropdown-menu').length)  {
 +
      active = active
 +
        .closest('li.dropdown')
 +
        .addClass('active')
 +
    }
 +
 +
    active.trigger('activate')
 +
  }
 +
 +
 +
  // SCROLLSPY PLUGIN DEFINITION
 +
  // ===========================
 +
 +
  var old = $.fn.scrollspy
 +
 +
  $.fn.scrollspy = function (option) {
 +
    return this.each(function () {
 +
      var $this  = $(this)
 +
      var data    = $this.data('bs.scrollspy')
 +
      var options = typeof option == 'object' && option
 +
 +
      if (!data) $this.data('bs.scrollspy', (data = new ScrollSpy(this, options)))
 +
      if (typeof option == 'string') data[option]()
 +
    })
 +
  }
 +
 +
  $.fn.scrollspy.Constructor = ScrollSpy
 +
 +
 +
  // SCROLLSPY NO CONFLICT
 +
  // =====================
 +
 +
  $.fn.scrollspy.noConflict = function () {
 +
    $.fn.scrollspy = old
 +
    return this
 +
  }
 +
 +
 +
  // SCROLLSPY DATA-API
 +
  // ==================
 +
 +
  $(window).on('load', function () {
 +
    $('[data-spy="scroll"]').each(function () {
 +
      var $spy = $(this)
 +
      $spy.scrollspy($spy.data())
 +
    })
 +
  })
 +
 +
}(window.jQuery);
 +
 +
/* ========================================================================
 +
* Bootstrap: tab.js v3.0.0
 +
* http://twbs.github.com/bootstrap/javascript.html#tabs
 +
* ========================================================================
 +
* Copyright 2012 Twitter, Inc.
 +
*
 +
* Licensed under the Apache License, Version 2.0 (the "License");
 +
* you may not use this file except in compliance with the License.
 +
* You may obtain a copy of the License at
 +
*
 +
* http://www.apache.org/licenses/LICENSE-2.0
 +
*
 +
* Unless required by applicable law or agreed to in writing, software
 +
* distributed under the License is distributed on an "AS IS" BASIS,
 +
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 +
* See the License for the specific language governing permissions and
 +
* limitations under the License.
 +
* ======================================================================== */
 +
 +
 +
+function ($) { "use strict";
 +
 +
  // TAB CLASS DEFINITION
 +
  // ====================
 +
 +
  var Tab = function (element) {
 +
    this.element = $(element)
 +
  }
 +
 +
  Tab.prototype.show = function () {
 +
    var $this    = this.element
 +
    var $ul      = $this.closest('ul:not(.dropdown-menu)')
 +
    var selector = $this.attr('data-target')
 +
 +
    if (!selector) {
 +
      selector = $this.attr('href')
 +
      selector = selector && selector.replace(/.*(?=#[^\s]*$)/, '') //strip for ie7
 +
    }
 +
 +
    if ($this.parent('li').hasClass('active')) return
 +
 +
    var previous = $ul.find('.active:last a')[0]
 +
    var e        = $.Event('show.bs.tab', {
 +
      relatedTarget: previous
 +
    })
 +
 +
    $this.trigger(e)
 +
 +
    if (e.isDefaultPrevented()) return
 +
 +
    var $target = $(selector)
 +
 +
    this.activate($this.parent('li'), $ul)
 +
    this.activate($target, $target.parent(), function () {
 +
      $this.trigger({
 +
        type: 'shown.bs.tab'
 +
      , relatedTarget: previous
 +
      })
 +
    })
 +
  }
 +
 +
  Tab.prototype.activate = function (element, container, callback) {
 +
    var $active    = container.find('> .active')
 +
    var transition = callback
 +
      && $.support.transition
 +
      && $active.hasClass('fade')
 +
 +
    function next() {
 +
      $active
 +
        .removeClass('active')
 +
        .find('> .dropdown-menu > .active')
 +
        .removeClass('active')
 +
 +
      element.addClass('active')
 +
 +
      if (transition) {
 +
        element[0].offsetWidth // reflow for transition
 +
        element.addClass('in')
 +
      } else {
 +
        element.removeClass('fade')
 +
      }
 +
 +
      if (element.parent('.dropdown-menu')) {
 +
        element.closest('li.dropdown').addClass('active')
 +
      }
 +
 +
      callback && callback()
 +
    }
 +
 +
    transition ?
 +
      $active
 +
        .one($.support.transition.end, next)
 +
        .emulateTransitionEnd(150) :
 +
      next()
 +
 +
    $active.removeClass('in')
 +
  }
 +
 +
 +
  // TAB PLUGIN DEFINITION
 +
  // =====================
 +
 +
  var old = $.fn.tab
 +
 +
  $.fn.tab = function ( option ) {
 +
    return this.each(function () {
 +
      var $this = $(this)
 +
      var data  = $this.data('bs.tab')
 +
 +
      if (!data) $this.data('bs.tab', (data = new Tab(this)))
 +
      if (typeof option == 'string') data[option]()
 +
    })
 +
  }
 +
 +
  $.fn.tab.Constructor = Tab
 +
 +
 +
  // TAB NO CONFLICT
 +
  // ===============
 +
 +
  $.fn.tab.noConflict = function () {
 +
    $.fn.tab = old
 +
    return this
 +
  }
 +
 +
 +
  // TAB DATA-API
 +
  // ============
 +
 +
  $(document).on('click.bs.tab.data-api', '[data-toggle="tab"], [data-toggle="pill"]', function (e) {
 +
    e.preventDefault()
 +
    $(this).tab('show')
 +
  })
 +
 +
}(window.jQuery);
 +
 +
/* ========================================================================
 +
* Bootstrap: affix.js v3.0.0
 +
* http://twbs.github.com/bootstrap/javascript.html#affix
 +
* ========================================================================
 +
* Copyright 2012 Twitter, Inc.
 +
*
 +
* Licensed under the Apache License, Version 2.0 (the "License");
 +
* you may not use this file except in compliance with the License.
 +
* You may obtain a copy of the License at
 +
*
 +
* http://www.apache.org/licenses/LICENSE-2.0
 +
*
 +
* Unless required by applicable law or agreed to in writing, software
 +
* distributed under the License is distributed on an "AS IS" BASIS,
 +
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 +
* See the License for the specific language governing permissions and
 +
* limitations under the License.
 +
* ======================================================================== */
 +
 +
 +
+function ($) { "use strict";
 +
 +
  // AFFIX CLASS DEFINITION
 +
  // ======================
 +
 +
  var Affix = function (element, options) {
 +
    this.options = $.extend({}, Affix.DEFAULTS, options)
 +
    this.$window = $(window)
 +
      .on('scroll.bs.affix.data-api', $.proxy(this.checkPosition, this))
 +
      .on('click.bs.affix.data-api',  $.proxy(this.checkPositionWithEventLoop, this))
 +
 +
    this.$element = $(element)
 +
    this.affixed  =
 +
    this.unpin    = null
 +
 +
    this.checkPosition()
 +
  }
 +
 +
  Affix.RESET = 'affix affix-top affix-bottom'
 +
 +
  Affix.DEFAULTS = {
 +
    offset: 0
 +
  }
 +
 +
  Affix.prototype.checkPositionWithEventLoop = function () {
 +
    setTimeout($.proxy(this.checkPosition, this), 1)
 +
  }
 +
 +
  Affix.prototype.checkPosition = function () {
 +
    if (!this.$element.is(':visible')) return
 +
 +
    var scrollHeight = $(document).height()
 +
    var scrollTop    = this.$window.scrollTop()
 +
    var position    = this.$element.offset()
 +
    var offset      = this.options.offset
 +
    var offsetTop    = offset.top
 +
    var offsetBottom = offset.bottom
 +
 +
    if (typeof offset != 'object')        offsetBottom = offsetTop = offset
 +
    if (typeof offsetTop == 'function')    offsetTop    = offset.top()
 +
    if (typeof offsetBottom == 'function') offsetBottom = offset.bottom()
 +
 +
    var affix = this.unpin  != null && (scrollTop + this.unpin <= position.top) ? false :
 +
                offsetBottom != null && (position.top + this.$element.height() >= scrollHeight - offsetBottom) ? 'bottom' :
 +
                offsetTop    != null && (scrollTop <= offsetTop) ? 'top' : false
 +
 +
    if (this.affixed === affix) return
 +
    if (this.unpin) this.$element.css('top', '')
 +
 +
    this.affixed = affix
 +
    this.unpin  = affix == 'bottom' ? position.top - scrollTop : null
 +
 +
    this.$element.removeClass(Affix.RESET).addClass('affix' + (affix ? '-' + affix : ''))
 +
 +
    if (affix == 'bottom') {
 +
      this.$element.offset({ top: document.body.offsetHeight - offsetBottom - this.$element.height() })
 +
    }
 +
  }
 +
 +
 +
  // AFFIX PLUGIN DEFINITION
 +
  // =======================
 +
 +
  var old = $.fn.affix
 +
 +
  $.fn.affix = function (option) {
 +
    return this.each(function () {
 +
      var $this  = $(this)
 +
      var data    = $this.data('bs.affix')
 +
      var options = typeof option == 'object' && option
 +
 +
      if (!data) $this.data('bs.affix', (data = new Affix(this, options)))
 +
      if (typeof option == 'string') data[option]()
 +
    })
 +
  }
 +
 +
  $.fn.affix.Constructor = Affix
 +
 +
 +
  // AFFIX NO CONFLICT
 +
  // =================
 +
 +
  $.fn.affix.noConflict = function () {
 +
    $.fn.affix = old
 +
    return this
 +
  }
 +
 +
 +
  // AFFIX DATA-API
 +
  // ==============
 +
 +
  $(window).on('load', function () {
 +
    $('[data-spy="affix"]').each(function () {
 +
      var $spy = $(this)
 +
      var data = $spy.data()
 +
 +
      data.offset = data.offset || {}
 +
 +
      if (data.offsetBottom) data.offset.bottom = data.offsetBottom
 +
      if (data.offsetTop)    data.offset.top    = data.offsetTop
 +
 +
      $spy.affix(data)
 +
    })
 +
  })
 +
 +
}(window.jQuery);jQuery(document).ready(function($) {
 +
 +
'use strict';
 +
 +
    $('.imageGallery1 a').simpleLightbox();
 +
 +
 +
    var owl = $("#owl-portfolio");
 +
 +
      owl.owlCarousel({
 +
       
 +
        pagination : true,
 +
        paginationNumbers: false,
 +
        autoPlay: 6000, //Set AutoPlay to 3 seconds
 +
        items : 4, //10 items above 1000px browser width
 +
        itemsDesktop : [1000,4], //5 items between 1000px and 901px
 +
        itemsDesktopSmall : [900,3], // betweem 900px and 601px
 +
        itemsTablet: [600,2], //2 items between 600 and 0
 +
        itemsMobile : false // itemsMobile disabled - inherit from itemsTablet option
 +
       
 +
    });
 +
 +
 +
    $('.tabgroup > div').hide();
 +
    $('.tabgroup > div:first-of-type').show();
 +
    $('.tabs a').click(function(e){
 +
      e.preventDefault();
 +
        var $this = $(this),
 +
        tabgroup = '#'+$this.parents('.tabs').data('tabgroup'),
 +
        others = $this.closest('li').siblings().children('a'),
 +
        target = $this.attr('href');
 +
    others.removeClass('active');
 +
    $this.addClass('active');
 +
    $(tabgroup).children('div').hide();
 +
    $(target).show();
 +
 
 +
    })
 +
 +
 +
/************** Toggle *********************/
 +
    // Cache selectors
 +
    var lastId,
 +
        topMenu = $(".menu-first"),
 +
        topMenuHeight = 80,
 +
        // All list items
 +
        menuItems = topMenu.find("a"),
 +
        // Anchors corresponding to menu items
 +
        scrollItems = menuItems.map(function(){
 +
         
 +
          if($(this).hasClass('external')) {
 +
            return;
 +
          }
 +
           
 +
          var item = $($(this).attr("href"));
 +
          if (item.length) { return item; }
 +
        });
 +
 +
    // Bind click handler to menu items
 +
    // so we can get a fancy scroll animation
 +
    menuItems.click(function(e){
 +
      var href = $(this).attr("href"),
 +
          offsetTop = href === "#" ? 0 : $(href).offset().top-topMenuHeight+1;
 +
      $('html, body').stop().animate({
 +
          scrollTop: offsetTop
 +
      }, 750);
 +
      e.preventDefault();
 +
    });
 +
 +
    // Bind to scroll
 +
    $(window).scroll(function(){
 +
      // Get container scroll position
 +
      var fromTop = $(this).scrollTop()+topMenuHeight;
 
        
 
        
        <script src="js/vendor/jquery.gmap3.min.js"></script>
+
      // Get id of current scroll item
 +
      var cur = scrollItems.map(function(){
 +
        if ($(this).offset().top < fromTop)
 +
          return this;
 +
      });
 +
      // Get the id of the current element
 +
      cur = cur[cur.length-1];
 +
      var id = cur && cur.length ? cur[0].id : "";
 +
     
 +
      if (lastId !== id) {
 +
          lastId = id;
 +
          // Set/remove active class
 +
          menuItems
 +
            .parent().removeClass("active")
 +
            .end().filter("[href=#"+id+"]").parent().addClass("active");
 +
      }                 
 +
    });
  
         <script type="text/javascript">
+
 
 +
 
 +
    $(window).scroll(function(){
 +
        $('.main-header').toggleClass('scrolled', $(this).scrollTop() > 1);
 +
    });
 +
 
 +
 
 +
 
 +
    $('a[href="#top"]').click(function(){
 +
         $('html, body').animate({scrollTop: 0}, 'slow');
 +
        return false;
 +
    });
 +
 
 +
 
 +
    $('.toggle-menu').click(function(){
 +
        $('.menu-first').toggleClass('show');
 +
        // $('.menu-first').slideToggle();
 +
    });
 +
 
 +
    $('.menu-first li a').click(function(){
 +
      $('.menu-first').removeClass('show');
 +
    });
 +
 
 +
 
 +
    $('a[href*=#]').on('click', function(e) {
 +
      e.preventDefault();
 +
      $('html, body').animate({ scrollTop: $($(this).attr('href')).offset().top -79 }, 500, 'linear');
 +
    });
 +
 
 +
 
 +
 
 +
 
 +
});
 +
jQuery(document).ready(function(e){"use strict";function o(){e(".sf-menu").superfish({delay:50,autoArrows:!0,animation:{opacity:"show"}})}e(".toggle-id").on("click",function(){var o=e(this).attr("href");return e(o).slideToggle(250),!1}),e("a.toggle-menu").click(function(){return e("#responsive-menu").stop(!0,!0).slideToggle(),!1}),o(),e(".sub-menu").addClass("animated fadeInRight"),e("#search-icon").on("click",function(){return e("#search-overlay").removeClass("animated bounceOutUp"),e("#search-overlay").fadeIn(0).addClass("animated bounceInDown"),e('.search-form-holder input[type="search"]').focus(),!1}),e(".close-search").on("click",function(){return e("#search-overlay").removeClass("animated bounceInDown"),e("#search-overlay").addClass("animated bounceOutUp"),!1}),jQuery(document).keyup(function(o){return 27===o.keyCode?(e("#search-overlay").removeClass("animated bounceInDown"),e("#search-overlay").addClass("animated bounceOutUp"),!1):void 0}),e(window).resize(function(){var o=e(window).height(),a=e(window).width();e(".swiper-container, .swiper-slide").height(o),e(".swiper-container, .swiper-slide").width(a)}),e(window).resize(),e(".arrow-left, .arrow-right").on("click",function(){e(".slider-caption h2").removeClass("animated fadeInDown"),e(".slider-caption h2").fadeIn(0).addClass("animated fadeInDown"),e(".slider-caption p").removeClass("animated fadeInUp"),e(".slider-caption p").fadeIn(0).addClass("animated fadeInUp")});var a=new Swiper(".swiper-container",{mode:"horizontal",loop:!0,keyboardControl:!0});e(".arrow-left").on("click",function(e){e.preventDefault(),a.swipePrev()}),e(".arrow-right").on("click",function(e){e.preventDefault(),a.swipeNext()}),e(".project-slider").slidesjs({pagination:!1,navigation:{active:!1,effect:"fade"}}),e(".staff-member").hover(function(){e(".overlay .social-network").addClass("animated fadeIn")},function(){e(".overlay .social-network").removeClass("animated fadeIn")}),e(".blog-thumb, .project-item").hover(function(){e(".overlay-b a").addClass("animated fadeIn")},function(){e(".overlay-b a").removeClass("animated fadeIn")}),e(".projects-holder").mixitup({effects:["fade","grayscale"],easing:"snap",transitionSpeed:400}),e(".fancybox").fancybox(),e("#contactform").submit(function(){var o=e(this).attr("action");return e("#message").slideUp(750,function(){e("#message").hide(),e("#submit").attr("disabled","disabled"),e.post(o,{name:e("#name").val(),email:e("#email").val(),phone:e("#phone").val(),comments:e("#comments").val()},function(o){document.getElementById("message").innerHTML=o,e("#message").slideDown("slow"),e("#submit").removeAttr("disabled"),null!=o.match("success")&&e("#contactform").slideUp("slow")})}),!1})}),$(window).load(function(){blogisotope=function(){var e,o=$(".blog-masonry").width(),a=Math.floor(o);return $(".blog-masonry").hasClass("masonry-true")===!0&&(a=Math.floor(.3033*o),e=Math.floor(.04*o),a=$(window).width()<1023?$(window).width()<768?Math.floor(1*o):Math.floor(.48*o):Math.floor(.3033*o)),e};var e=$(".blog-masonry");bloggingisotope=function(){e.isotope({itemSelector:".post-masonry",animationEngine:"jquery",masonry:{gutterWidth:blogisotope()}})},bloggingisotope(),$(window).smartresize(bloggingisotope)});(function(factory) {
 +
 
 +
    if (typeof define === 'function' && define.amd) {
 +
        define(['jquery'], factory);
 +
    } else if (typeof module === 'object' && module.exports) {
 +
        module.exports = factory(require('jquery'));
 +
    } else {
 +
        factory(jQuery);
 +
    }
 +
 
 +
}(function($) {
 +
 
 +
    var instanceNum = 0,
 +
        $html = $('html'),
 +
        $document = $(document),
 +
        $window = $(window);
 +
 
 +
    function SimpleLightbox(options) {
 +
 
 +
        this.init.apply(this, arguments);
 +
 
 +
    }
 +
 
 +
    SimpleLightbox.defaults = {
 +
 
 +
        // add custom classes to lightbox elements
 +
        elementClass: '',
 +
        elementLoadingClass: 'slbLoading',
 +
        htmlClass: 'slbActive',
 +
        closeBtnClass: '',
 +
        nextBtnClass: '',
 +
        prevBtnClass: '',
 +
        loadingTextClass: '',
 +
 
 +
        // customize / localize controls captions
 +
        closeBtnCaption: 'Close',
 +
        nextBtnCaption: 'Next',
 +
        prevBtnCaption: 'Previous',
 +
        loadingCaption: 'Loading...',
 +
 
 +
        bindToItems: true, // set click event handler to trigger lightbox on provided $items
 +
        closeOnOverlayClick: true,
 +
        closeOnEscapeKey: true,
 +
        nextOnImageClick: true,
 +
        showCaptions: true,
 +
 
 +
        captionAttribute: 'title', // choose data source for library to glean image caption from
 +
        urlAttribute: 'href', // where to expect large image
 +
 
 +
        startAt: 0, // start gallery at custom index
 +
        loadingTimeout: 100, // time after loading element will appear
 +
 
 +
        appendTarget: 'body', // append elsewhere if needed
 +
 
 +
        beforeSetContent: null, // convenient hooks for extending library behavoiur
 +
        beforeClose: null,
 +
        beforeDestroy: null,
 +
 
 +
        videoRegex: new RegExp(/youtube.com|vimeo.com/) // regex which tests load url for iframe content
 +
 
 +
    };
 +
 
 +
    $.extend(SimpleLightbox.prototype, {
 +
 
 +
        init: function(options) {
 +
 
 +
            this.options = $.extend({}, SimpleLightbox.defaults, options);
 +
            this.ens = '.slb' + (++instanceNum);
 +
            this.items = [];
 +
            this.captions = [];
 +
 
 +
            var self = this;
 +
 
 +
            if (this.options.$items) {
 +
 
 +
                this.$items = this.options.$items;
 +
 
 +
                this.$items.each(function() {
 +
 
 +
                    var $item = $(this);
 +
 
 +
                    self.items.push($item.attr(self.options.urlAttribute));
 +
                    self.captions.push($item.attr(self.options.captionAttribute));
 +
 
 +
                });
 +
 
 +
                this.options.bindToItems && this.$items.on('click' + this.ens, function(e) {
 +
 
 +
                    e.preventDefault();
 +
                    self.showPosition(self.$items.index($(e.currentTarget)));
 +
 
 +
                });
 +
 
 +
            } else if (this.options.items) {
 +
 
 +
                this.items = this.options.items;
 +
 
 +
            }
 +
 
 +
            if (this.options.captions) {
 +
                this.captions = this.options.captions;
 +
            }
 +
 
 +
        },
 +
 
 +
        next: function() {
 +
 
 +
            return this.showPosition(this.currentPosition + 1);
 +
 
 +
        },
 +
 
 +
        prev: function() {
 +
 
 +
            return this.showPosition(this.currentPosition - 1);
 +
 
 +
        },
 +
 
 +
        normalizePosition: function(position) {
 +
 
 +
            if (position >= this.items.length) {
 +
                position = 0;
 +
            } else if (position < 0) {
 +
                position = this.items.length - 1;
 +
            }
 +
 
 +
            return position;
 +
 
 +
        },
 +
 
 +
        showPosition: function(position) {
 +
 
 +
            var self = this;
 +
 
 +
            this.currentPosition = this.normalizePosition(position);
 +
 
 +
            return this.setupLightboxHtml().prepareItem(this.currentPosition, this.setContent).show();
 +
 
 +
        },
 +
 
 +
        loading: function(on) {
 +
 
 +
            var self = this;
 +
 
 +
            if (on) {
 +
 
 +
                this.loadingTimeout = setTimeout(function() {
 +
 
 +
                    self.$el.addClass(self.options.elementLoadingClass);
 +
 
 +
                    self.$content.html('<p class="slbLoadingText ' + self.options.loadingTextClass + '">' + self.options.loadingCaption + '</p>');
 +
                    self.show();
 +
 
 +
                }, this.options.loadingTimeout);
 +
 
 +
            } else {
 +
 
 +
                this.$el && this.$el.removeClass(this.options.elementLoadingClass);
 +
                clearTimeout(this.loadingTimeout);
 +
 
 +
            }
 +
 
 +
        },
 +
 
 +
        prepareItem: function(position, callback) {
 +
 
 +
            var self = this,
 +
                url = this.items[position];
 +
 
 +
            this.loading(true);
 +
 
 +
            if (this.options.videoRegex.test(url)) {
 +
 
 +
                callback.call(self, $('<div class="slbIframeCont"><iframe class="slbIframe" frameborder="0" allowfullscreen src="' + url + '"></iframe></div>'));
 +
 
 +
            } else {
 +
 
 +
                var $imageCont = $('<div class="slbImageWrap"><img class="slbImage" src="' + url + '" /></div>');
 +
 
 +
                this.$currentImage = $imageCont.find('.slbImage');
 +
 
 +
                if (this.options.showCaptions && this.captions[position]) {
 +
                    $imageCont.append('<div class="slbCaption">' + this.captions[position] + '</div>');
 +
                }
 +
 
 +
                this.loadImage(url, function() {
 +
 
 +
                    self.setImageDimensions();
 +
 
 +
                    callback.call(self, $imageCont);
 +
 
 +
                    self.loadImage(self.items[self.normalizePosition(self.currentPosition + 1)]);
 +
 
 +
                });
 +
 
 +
            }
 +
 
 +
            return this;
 +
 
 +
        },
 +
 
 +
        loadImage: function(url, callback) {
 +
 
 +
            if (!this.options.videoRegex.test(url)) {
 +
 
 +
                var image = new Image();
 +
                callback && (image.onload = callback);
 +
                image.src = url;
 +
 
 +
            }
 +
 
 +
        },
 +
 
 +
        setupLightboxHtml: function() {
 +
 
 +
            var o = this.options;
 +
 
 +
            if (!this.$el) {
 +
 
 +
                this.$el = $(
 +
                    '<div class="slbElement ' + o.elementClass + '">' +
 +
                        '<div class="slbOverlay"></div>' +
 +
                        '<div class="slbWrapOuter">' +
 +
                            '<div class="slbWrap">' +
 +
                                '<div class="slbContentOuter">' +
 +
                                    '<div class="slbContent"></div>' +
 +
                                    '<button type="button" title="' + o.closeBtnCaption + '" class="slbCloseBtn ' + o.closeBtnClass + '">×</button>' +
 +
                                '</div>' +
 +
                            '</div>' +
 +
                        '</div>' +
 +
                    '</div>'
 +
                );
 +
 
 +
                if (this.items.length > 1) {
 +
 
 +
                    $(
 +
                        '<div class="slbArrows">' +
 +
                            '<button type="button" title="' + o.prevBtnCaption + '" class="prev slbArrow' + o.prevBtnClass + '">' + o.prevBtnCaption + '</button>' +
 +
                            '<button type="button" title="' + o.nextBtnCaption + '" class="next slbArrow' + o.nextBtnClass + '">' + o.nextBtnCaption + '</button>' +
 +
                        '</div>'
 +
                    ).appendTo(this.$el.find('.slbContentOuter'));
 +
 
 +
                }
 +
 
 +
                this.$content = this.$el.find('.slbContent');
 +
 
 +
            }
 +
 
 +
            this.$content.empty();
 +
 
 +
            return this;
 +
 
 +
        },
 +
 
 +
        show: function() {
 +
 
 +
            if (!this.modalInDom) {
 +
 
 +
                this.$el.appendTo($(this.options.appendTarget));
 +
                $html.addClass(this.options.htmlClass);
 +
                this.setupLightboxEvents();
 +
 
 +
                this.modalInDom = true;
 +
 
 +
            }
 +
 
 +
            return this;
 +
 
 +
        },
 +
 
 +
        setContent: function(content) {
 +
 
 +
            var $content = $(content);
 +
 
 +
            this.loading(false);
 +
 
 +
            this.setupLightboxHtml();
 +
            this.options.beforeSetContent && this.options.beforeSetContent($content, this);
 +
            this.$content.html($content);
 +
 
 +
            return this;
 +
 
 +
        },
 +
 
 +
        setImageDimensions: function() {
 +
 
 +
            this.$currentImage && this.$currentImage.css('max-height', $window.height() + 'px');
 +
 
 +
        },
 +
 
 +
        setupLightboxEvents: function() {
 +
 
 +
            var self = this;
 +
 
 +
            if (!this.lightboxEventsSetuped) {
 +
 
 +
                this.$el.on('click' + this.ens, function(e) {
 +
 
 +
                    var $target = $(e.target);
 +
 
 +
                    if ($target.is('.slbCloseBtn') || (self.options.closeOnOverlayClick && $target.is('.slbWrap'))) {
 +
 
 +
                        self.close();
 +
 
 +
                    } else if ($target.is('.slbArrow')) {
 +
 
 +
                        $target.hasClass('next') ? self.next() : self.prev();
 +
 
 +
                    } else if (self.options.nextOnImageClick && self.items.length > 1 && $target.is('.slbImage')) {
 +
 
 +
                        self.next();
 +
 
 +
                    }
 +
 
 +
                });
 +
 
 +
                $document.on('keyup' + this.ens, function(e) {
 +
 
 +
                    self.options.closeOnEscapeKey && e.keyCode === 27 && self.close();
 +
 
 +
                    if (self.items.length > 1) {
 +
                        (e.keyCode === 39 || e.keyCode === 68) && self.next();
 +
                        (e.keyCode === 37 || e.keyCode === 65) && self.prev();
 +
                    }
 +
 
 +
                });
 +
 
 +
                $window.on('resize' + this.ens, function() {
 +
 
 +
                    self.setImageDimensions();
 +
 
 +
                });
 +
 
 +
                this.lightboxEventsSetuped = true;
 +
 
 +
            }
 +
 
 +
        },
 +
 
 +
        close: function() {
 +
 
 +
            if (this.modalInDom) {
 +
 
 +
                this.options.beforeClose && this.options.beforeClose(this);
 +
 
 +
                this.$el && this.$el.off(this.ens);
 +
                $document.off(this.ens);
 +
                $window.off(this.ens);
 +
                this.lightboxEventsSetuped = false;
 +
 
 +
                this.$el.detach();
 +
                $html.removeClass(this.options.htmlClass);
 +
                this.modalInDom = false;
 +
            }
 +
 
 +
        },
 +
 
 +
        destroy: function() {
 +
 
 +
            this.close();
 +
            this.options.beforeDestroy && this.options.beforeDestroy(this);
 +
            this.$items && this.$items.off(this.ens);
 +
            this.$el && this.$el.remove();
 +
 
 +
        }
 +
 
 +
    });
 +
 
 +
    SimpleLightbox.open = function(options) {
 +
 
 +
        var instance = new SimpleLightbox(options);
 +
 
 +
        return options.content ? instance.setContent(options.content).show() : instance.showPosition(instance.options.startAt);
 +
 
 +
    };
 +
 
 +
    $.fn.simpleLightbox = function(options) {
 +
 
 +
        var lightboxInstance,
 +
            $items = this;
 +
 
 +
        return this.each(function() {
 +
            if (!$.data(this, 'simpleLightbox')) {
 +
                lightboxInstance = lightboxInstance || new SimpleLightbox($.extend({}, options, {$items: $items}));
 +
                $.data(this, 'simpleLightbox', lightboxInstance);
 +
            }
 +
        });
 +
 
 +
    };
 +
 
 +
    $.simpleLightbox = $.SimpleLightbox = SimpleLightbox;
 +
 
 +
    return $;
 +
 
 +
}));
 +
 
 +
/*
 +
*  jQuery OwlCarousel v1.3.3
 +
*
 +
*  Copyright (c) 2013 Bartosz Wojciechowski
 +
*  http://www.owlgraphic.com/owlcarousel/
 +
*
 +
*  Licensed under MIT
 +
*
 +
*/
 +
 
 +
/*JS Lint helpers: */
 +
/*global dragMove: false, dragEnd: false, $, jQuery, alert, window, document */
 +
/*jslint nomen: true, continue:true */
 +
 
 +
if (typeof Object.create !== "function") {
 +
    Object.create = function (obj) {
 +
        function F() {}
 +
        F.prototype = obj;
 +
        return new F();
 +
    };
 +
}
 +
(function ($, window, document) {
 +
 
 +
    var Carousel = {
 +
        init : function (options, el) {
 +
            var base = this;
 +
 
 +
            base.$elem = $(el);
 +
            base.options = $.extend({}, $.fn.owlCarousel.options, base.$elem.data(), options);
 +
 
 +
            base.userOptions = options;
 +
            base.loadContent();
 +
        },
 +
 
 +
        loadContent : function () {
 +
            var base = this, url;
 +
 
 +
            function getData(data) {
 +
                var i, content = "";
 +
                if (typeof base.options.jsonSuccess === "function") {
 +
                    base.options.jsonSuccess.apply(this, [data]);
 +
                } else {
 +
                    for (i in data.owl) {
 +
                        if (data.owl.hasOwnProperty(i)) {
 +
                            content += data.owl[i].item;
 +
                        }
 +
                    }
 +
                    base.$elem.html(content);
 +
                }
 +
                base.logIn();
 +
            }
 +
 
 +
            if (typeof base.options.beforeInit === "function") {
 +
                base.options.beforeInit.apply(this, [base.$elem]);
 +
            }
 +
 
 +
            if (typeof base.options.jsonPath === "string") {
 +
                url = base.options.jsonPath;
 +
                $.getJSON(url, getData);
 +
            } else {
 +
                base.logIn();
 +
            }
 +
        },
 +
 
 +
        logIn : function () {
 +
            var base = this;
 +
 
 +
            base.$elem.data("owl-originalStyles", base.$elem.attr("style"));
 +
            base.$elem.data("owl-originalClasses", base.$elem.attr("class"));
 +
 
 +
            base.$elem.css({opacity: 0});
 +
            base.orignalItems = base.options.items;
 +
            base.checkBrowser();
 +
            base.wrapperWidth = 0;
 +
            base.checkVisible = null;
 +
            base.setVars();
 +
        },
 +
 
 +
        setVars : function () {
 +
            var base = this;
 +
            if (base.$elem.children().length === 0) {return false; }
 +
            base.baseClass();
 +
            base.eventTypes();
 +
            base.$userItems = base.$elem.children();
 +
            base.itemsAmount = base.$userItems.length;
 +
            base.wrapItems();
 +
            base.$owlItems = base.$elem.find(".owl-item");
 +
            base.$owlWrapper = base.$elem.find(".owl-wrapper");
 +
            base.playDirection = "next";
 +
            base.prevItem = 0;
 +
            base.prevArr = [0];
 +
            base.currentItem = 0;
 +
            base.customEvents();
 +
            base.onStartup();
 +
        },
 +
 
 +
        onStartup : function () {
 +
            var base = this;
 +
            base.updateItems();
 +
            base.calculateAll();
 +
            base.buildControls();
 +
            base.updateControls();
 +
            base.response();
 +
            base.moveEvents();
 +
            base.stopOnHover();
 +
            base.owlStatus();
 +
 
 +
            if (base.options.transitionStyle !== false) {
 +
                base.transitionTypes(base.options.transitionStyle);
 +
            }
 +
            if (base.options.autoPlay === true) {
 +
                base.options.autoPlay = 5000;
 +
            }
 +
            base.play();
 +
 
 +
            base.$elem.find(".owl-wrapper").css("display", "block");
 +
 
 +
            if (!base.$elem.is(":visible")) {
 +
                base.watchVisibility();
 +
            } else {
 +
                base.$elem.css("opacity", 1);
 +
            }
 +
            base.onstartup = false;
 +
            base.eachMoveUpdate();
 +
            if (typeof base.options.afterInit === "function") {
 +
                base.options.afterInit.apply(this, [base.$elem]);
 +
            }
 +
        },
 +
 
 +
        eachMoveUpdate : function () {
 +
            var base = this;
 +
 
 +
            if (base.options.lazyLoad === true) {
 +
                base.lazyLoad();
 +
            }
 +
            if (base.options.autoHeight === true) {
 +
                base.autoHeight();
 +
            }
 +
            base.onVisibleItems();
 +
 
 +
            if (typeof base.options.afterAction === "function") {
 +
                base.options.afterAction.apply(this, [base.$elem]);
 +
            }
 +
        },
 +
 
 +
        updateVars : function () {
 +
            var base = this;
 +
            if (typeof base.options.beforeUpdate === "function") {
 +
                base.options.beforeUpdate.apply(this, [base.$elem]);
 +
            }
 +
            base.watchVisibility();
 +
            base.updateItems();
 +
            base.calculateAll();
 +
            base.updatePosition();
 +
            base.updateControls();
 +
            base.eachMoveUpdate();
 +
            if (typeof base.options.afterUpdate === "function") {
 +
                base.options.afterUpdate.apply(this, [base.$elem]);
 +
            }
 +
        },
 +
 
 +
        reload : function () {
 +
            var base = this;
 +
            window.setTimeout(function () {
 +
                base.updateVars();
 +
            }, 0);
 +
        },
 +
 
 +
        watchVisibility : function () {
 +
            var base = this;
 +
 
 +
            if (base.$elem.is(":visible") === false) {
 +
                base.$elem.css({opacity: 0});
 +
                window.clearInterval(base.autoPlayInterval);
 +
                window.clearInterval(base.checkVisible);
 +
            } else {
 +
                return false;
 +
            }
 +
            base.checkVisible = window.setInterval(function () {
 +
                if (base.$elem.is(":visible")) {
 +
                    base.reload();
 +
                    base.$elem.animate({opacity: 1}, 200);
 +
                    window.clearInterval(base.checkVisible);
 +
                }
 +
            }, 500);
 +
        },
 +
 
 +
        wrapItems : function () {
 +
            var base = this;
 +
            base.$userItems.wrapAll("<div class=\"owl-wrapper\">").wrap("<div class=\"owl-item\"></div>");
 +
            base.$elem.find(".owl-wrapper").wrap("<div class=\"owl-wrapper-outer\">");
 +
            base.wrapperOuter = base.$elem.find(".owl-wrapper-outer");
 +
            base.$elem.css("display", "block");
 +
        },
 +
 
 +
        baseClass : function () {
 +
            var base = this,
 +
                hasBaseClass = base.$elem.hasClass(base.options.baseClass),
 +
                hasThemeClass = base.$elem.hasClass(base.options.theme);
 +
 
 +
            if (!hasBaseClass) {
 +
                base.$elem.addClass(base.options.baseClass);
 +
            }
 +
 
 +
            if (!hasThemeClass) {
 +
                base.$elem.addClass(base.options.theme);
 +
            }
 +
        },
 +
 
 +
        updateItems : function () {
 +
            var base = this, width, i;
 +
 
 +
            if (base.options.responsive === false) {
 +
                return false;
 +
            }
 +
            if (base.options.singleItem === true) {
 +
                base.options.items = base.orignalItems = 1;
 +
                base.options.itemsCustom = false;
 +
                base.options.itemsDesktop = false;
 +
                base.options.itemsDesktopSmall = false;
 +
                base.options.itemsTablet = false;
 +
                base.options.itemsTabletSmall = false;
 +
                base.options.itemsMobile = false;
 +
                return false;
 +
            }
 +
 
 +
            width = $(base.options.responsiveBaseWidth).width();
 +
 
 +
            if (width > (base.options.itemsDesktop[0] || base.orignalItems)) {
 +
                base.options.items = base.orignalItems;
 +
            }
 +
            if (base.options.itemsCustom !== false) {
 +
                //Reorder array by screen size
 +
                base.options.itemsCustom.sort(function (a, b) {return a[0] - b[0]; });
 +
 
 +
                for (i = 0; i < base.options.itemsCustom.length; i += 1) {
 +
                    if (base.options.itemsCustom[i][0] <= width) {
 +
                        base.options.items = base.options.itemsCustom[i][1];
 +
                    }
 +
                }
 +
 
 +
            } else {
 +
 
 +
                if (width <= base.options.itemsDesktop[0] && base.options.itemsDesktop !== false) {
 +
                    base.options.items = base.options.itemsDesktop[1];
 +
                }
 +
 
 +
                if (width <= base.options.itemsDesktopSmall[0] && base.options.itemsDesktopSmall !== false) {
 +
                    base.options.items = base.options.itemsDesktopSmall[1];
 +
                }
 +
 
 +
                if (width <= base.options.itemsTablet[0] && base.options.itemsTablet !== false) {
 +
                    base.options.items = base.options.itemsTablet[1];
 +
                }
 +
 
 +
                if (width <= base.options.itemsTabletSmall[0] && base.options.itemsTabletSmall !== false) {
 +
                    base.options.items = base.options.itemsTabletSmall[1];
 +
                }
 +
 
 +
                if (width <= base.options.itemsMobile[0] && base.options.itemsMobile !== false) {
 +
                    base.options.items = base.options.itemsMobile[1];
 +
                }
 +
            }
 +
 
 +
            //if number of items is less than declared
 +
            if (base.options.items > base.itemsAmount && base.options.itemsScaleUp === true) {
 +
                base.options.items = base.itemsAmount;
 +
            }
 +
        },
 +
 
 +
        response : function () {
 +
            var base = this,
 +
                smallDelay,
 +
                lastWindowWidth;
 +
 
 +
            if (base.options.responsive !== true) {
 +
                return false;
 +
            }
 +
            lastWindowWidth = $(window).width();
 +
 
 +
            base.resizer = function () {
 +
                if ($(window).width() !== lastWindowWidth) {
 +
                    if (base.options.autoPlay !== false) {
 +
                        window.clearInterval(base.autoPlayInterval);
 +
                    }
 +
                    window.clearTimeout(smallDelay);
 +
                    smallDelay = window.setTimeout(function () {
 +
                        lastWindowWidth = $(window).width();
 +
                        base.updateVars();
 +
                    }, base.options.responsiveRefreshRate);
 +
                }
 +
            };
 +
            $(window).resize(base.resizer);
 +
        },
 +
 
 +
        updatePosition : function () {
 +
            var base = this;
 +
            base.jumpTo(base.currentItem);
 +
            if (base.options.autoPlay !== false) {
 +
                base.checkAp();
 +
            }
 +
        },
 +
 
 +
        appendItemsSizes : function () {
 +
            var base = this,
 +
                roundPages = 0,
 +
                lastItem = base.itemsAmount - base.options.items;
 +
 
 +
            base.$owlItems.each(function (index) {
 +
                var $this = $(this);
 +
                $this
 +
                    .css({"width": base.itemWidth})
 +
                    .data("owl-item", Number(index));
 +
 
 +
                if (index % base.options.items === 0 || index === lastItem) {
 +
                    if (!(index > lastItem)) {
 +
                        roundPages += 1;
 +
                    }
 +
                }
 +
                $this.data("owl-roundPages", roundPages);
 +
            });
 +
        },
 +
 
 +
        appendWrapperSizes : function () {
 +
            var base = this,
 +
                width = base.$owlItems.length * base.itemWidth;
 +
 
 +
            base.$owlWrapper.css({
 +
                "width": width * 2,
 +
                "left": 0
 +
            });
 +
            base.appendItemsSizes();
 +
        },
 +
 
 +
        calculateAll : function () {
 +
            var base = this;
 +
            base.calculateWidth();
 +
            base.appendWrapperSizes();
 +
            base.loops();
 +
            base.max();
 +
        },
 +
 
 +
        calculateWidth : function () {
 +
            var base = this;
 +
            base.itemWidth = Math.round(base.$elem.width() / base.options.items);
 +
        },
 +
 
 +
        max : function () {
 +
            var base = this,
 +
                maximum = ((base.itemsAmount * base.itemWidth) - base.options.items * base.itemWidth) * -1;
 +
            if (base.options.items > base.itemsAmount) {
 +
                base.maximumItem = 0;
 +
                maximum = 0;
 +
                base.maximumPixels = 0;
 +
            } else {
 +
                base.maximumItem = base.itemsAmount - base.options.items;
 +
                base.maximumPixels = maximum;
 +
            }
 +
            return maximum;
 +
        },
 +
 
 +
        min : function () {
 +
            return 0;
 +
        },
 +
 
 +
        loops : function () {
 +
            var base = this,
 +
                prev = 0,
 +
                elWidth = 0,
 +
                i,
 +
                item,
 +
                roundPageNum;
 +
 
 +
            base.positionsInArray = [0];
 +
            base.pagesInArray = [];
 +
 
 +
            for (i = 0; i < base.itemsAmount; i += 1) {
 +
                elWidth += base.itemWidth;
 +
                base.positionsInArray.push(-elWidth);
 +
 
 +
                if (base.options.scrollPerPage === true) {
 +
                    item = $(base.$owlItems[i]);
 +
                    roundPageNum = item.data("owl-roundPages");
 +
                    if (roundPageNum !== prev) {
 +
                        base.pagesInArray[prev] = base.positionsInArray[i];
 +
                        prev = roundPageNum;
 +
                    }
 +
                }
 +
            }
 +
        },
 +
 
 +
        buildControls : function () {
 +
            var base = this;
 +
            if (base.options.navigation === true || base.options.pagination === true) {
 +
                base.owlControls = $("<div class=\"owl-controls\"/>").toggleClass("clickable", !base.browser.isTouch).appendTo(base.$elem);
 +
            }
 +
            if (base.options.pagination === true) {
 +
                base.buildPagination();
 +
            }
 +
            if (base.options.navigation === true) {
 +
                base.buildButtons();
 +
            }
 +
        },
 +
 
 +
        buildButtons : function () {
 +
            var base = this,
 +
                buttonsWrapper = $("<div class=\"owl-buttons\"/>");
 +
            base.owlControls.append(buttonsWrapper);
 +
 
 +
            base.buttonPrev = $("<div/>", {
 +
                "class" : "owl-prev",
 +
                "html" : base.options.navigationText[0] || ""
 +
            });
 +
 
 +
            base.buttonNext = $("<div/>", {
 +
                "class" : "owl-next",
 +
                "html" : base.options.navigationText[1] || ""
 +
            });
 +
 
 +
            buttonsWrapper
 +
                .append(base.buttonPrev)
 +
                .append(base.buttonNext);
 +
 
 +
            buttonsWrapper.on("touchstart.owlControls mousedown.owlControls", "div[class^=\"owl\"]", function (event) {
 +
                event.preventDefault();
 +
            });
 +
 
 +
            buttonsWrapper.on("touchend.owlControls mouseup.owlControls", "div[class^=\"owl\"]", function (event) {
 +
                event.preventDefault();
 +
                if ($(this).hasClass("owl-next")) {
 +
                    base.next();
 +
                } else {
 +
                    base.prev();
 +
                }
 +
            });
 +
        },
 +
 
 +
        buildPagination : function () {
 +
            var base = this;
 +
 
 +
            base.paginationWrapper = $("<div class=\"owl-pagination\"/>");
 +
            base.owlControls.append(base.paginationWrapper);
 +
 
 +
            base.paginationWrapper.on("touchend.owlControls mouseup.owlControls", ".owl-page", function (event) {
 +
                event.preventDefault();
 +
                if (Number($(this).data("owl-page")) !== base.currentItem) {
 +
                    base.goTo(Number($(this).data("owl-page")), true);
 +
                }
 +
            });
 +
        },
 +
 
 +
        updatePagination : function () {
 +
            var base = this,
 +
                counter,
 +
                lastPage,
 +
                lastItem,
 +
                i,
 +
                paginationButton,
 +
                paginationButtonInner;
 +
 
 +
            if (base.options.pagination === false) {
 +
                return false;
 +
            }
 +
 
 +
            base.paginationWrapper.html("");
 +
 
 +
            counter = 0;
 +
            lastPage = base.itemsAmount - base.itemsAmount % base.options.items;
 +
 
 +
            for (i = 0; i < base.itemsAmount; i += 1) {
 +
                if (i % base.options.items === 0) {
 +
                    counter += 1;
 +
                    if (lastPage === i) {
 +
                        lastItem = base.itemsAmount - base.options.items;
 +
                    }
 +
                    paginationButton = $("<div/>", {
 +
                        "class" : "owl-page"
 +
                    });
 +
                    paginationButtonInner = $("<span></span>", {
 +
                        "text": base.options.paginationNumbers === true ? counter : "",
 +
                        "class": base.options.paginationNumbers === true ? "owl-numbers" : ""
 +
                    });
 +
                    paginationButton.append(paginationButtonInner);
 +
 
 +
                    paginationButton.data("owl-page", lastPage === i ? lastItem : i);
 +
                    paginationButton.data("owl-roundPages", counter);
 +
 
 +
                    base.paginationWrapper.append(paginationButton);
 +
                }
 +
            }
 +
            base.checkPagination();
 +
        },
 +
        checkPagination : function () {
 +
            var base = this;
 +
            if (base.options.pagination === false) {
 +
                return false;
 +
            }
 +
            base.paginationWrapper.find(".owl-page").each(function () {
 +
                if ($(this).data("owl-roundPages") === $(base.$owlItems[base.currentItem]).data("owl-roundPages")) {
 +
                    base.paginationWrapper
 +
                        .find(".owl-page")
 +
                        .removeClass("active");
 +
                    $(this).addClass("active");
 +
                }
 +
            });
 +
        },
 +
 
 +
        checkNavigation : function () {
 +
            var base = this;
 +
 
 +
            if (base.options.navigation === false) {
 +
                return false;
 +
            }
 +
            if (base.options.rewindNav === false) {
 +
                if (base.currentItem === 0 && base.maximumItem === 0) {
 +
                    base.buttonPrev.addClass("disabled");
 +
                    base.buttonNext.addClass("disabled");
 +
                } else if (base.currentItem === 0 && base.maximumItem !== 0) {
 +
                    base.buttonPrev.addClass("disabled");
 +
                    base.buttonNext.removeClass("disabled");
 +
                } else if (base.currentItem === base.maximumItem) {
 +
                    base.buttonPrev.removeClass("disabled");
 +
                    base.buttonNext.addClass("disabled");
 +
                } else if (base.currentItem !== 0 && base.currentItem !== base.maximumItem) {
 +
                    base.buttonPrev.removeClass("disabled");
 +
                    base.buttonNext.removeClass("disabled");
 +
                }
 +
            }
 +
        },
 +
 
 +
        updateControls : function () {
 +
            var base = this;
 +
            base.updatePagination();
 +
            base.checkNavigation();
 +
            if (base.owlControls) {
 +
                if (base.options.items >= base.itemsAmount) {
 +
                    base.owlControls.hide();
 +
                } else {
 +
                    base.owlControls.show();
 +
                }
 +
            }
 +
        },
 +
 
 +
        destroyControls : function () {
 +
            var base = this;
 +
            if (base.owlControls) {
 +
                base.owlControls.remove();
 +
            }
 +
        },
 +
 
 +
        next : function (speed) {
 +
            var base = this;
 +
 
 +
            if (base.isTransition) {
 +
                return false;
 +
            }
 +
 
 +
            base.currentItem += base.options.scrollPerPage === true ? base.options.items : 1;
 +
            if (base.currentItem > base.maximumItem + (base.options.scrollPerPage === true ? (base.options.items - 1) : 0)) {
 +
                if (base.options.rewindNav === true) {
 +
                    base.currentItem = 0;
 +
                    speed = "rewind";
 +
                } else {
 +
                    base.currentItem = base.maximumItem;
 +
                    return false;
 +
                }
 +
            }
 +
            base.goTo(base.currentItem, speed);
 +
        },
 +
 
 +
        prev : function (speed) {
 +
            var base = this;
 +
 
 +
            if (base.isTransition) {
 +
                return false;
 +
            }
 +
 
 +
            if (base.options.scrollPerPage === true && base.currentItem > 0 && base.currentItem < base.options.items) {
 +
                base.currentItem = 0;
 +
            } else {
 +
                base.currentItem -= base.options.scrollPerPage === true ? base.options.items : 1;
 +
            }
 +
            if (base.currentItem < 0) {
 +
                if (base.options.rewindNav === true) {
 +
                    base.currentItem = base.maximumItem;
 +
                    speed = "rewind";
 +
                } else {
 +
                    base.currentItem = 0;
 +
                    return false;
 +
                }
 +
            }
 +
            base.goTo(base.currentItem, speed);
 +
        },
 +
 
 +
        goTo : function (position, speed, drag) {
 +
            var base = this,
 +
                goToPixel;
 +
 
 +
            if (base.isTransition) {
 +
                return false;
 +
            }
 +
            if (typeof base.options.beforeMove === "function") {
 +
                base.options.beforeMove.apply(this, [base.$elem]);
 +
            }
 +
            if (position >= base.maximumItem) {
 +
                position = base.maximumItem;
 +
            } else if (position <= 0) {
 +
                position = 0;
 +
            }
 +
 
 +
            base.currentItem = base.owl.currentItem = position;
 +
            if (base.options.transitionStyle !== false && drag !== "drag" && base.options.items === 1 && base.browser.support3d === true) {
 +
                base.swapSpeed(0);
 +
                if (base.browser.support3d === true) {
 +
                    base.transition3d(base.positionsInArray[position]);
 +
                } else {
 +
                    base.css2slide(base.positionsInArray[position], 1);
 +
                }
 +
                base.afterGo();
 +
                base.singleItemTransition();
 +
                return false;
 +
            }
 +
            goToPixel = base.positionsInArray[position];
 +
 
 +
            if (base.browser.support3d === true) {
 +
                base.isCss3Finish = false;
 +
 
 +
                if (speed === true) {
 +
                    base.swapSpeed("paginationSpeed");
 +
                    window.setTimeout(function () {
 +
                        base.isCss3Finish = true;
 +
                    }, base.options.paginationSpeed);
 +
 
 +
                } else if (speed === "rewind") {
 +
                    base.swapSpeed(base.options.rewindSpeed);
 +
                    window.setTimeout(function () {
 +
                        base.isCss3Finish = true;
 +
                    }, base.options.rewindSpeed);
 +
 
 +
                } else {
 +
                    base.swapSpeed("slideSpeed");
 +
                    window.setTimeout(function () {
 +
                        base.isCss3Finish = true;
 +
                    }, base.options.slideSpeed);
 +
                }
 +
                base.transition3d(goToPixel);
 +
            } else {
 +
                if (speed === true) {
 +
                    base.css2slide(goToPixel, base.options.paginationSpeed);
 +
                } else if (speed === "rewind") {
 +
                    base.css2slide(goToPixel, base.options.rewindSpeed);
 +
                } else {
 +
                    base.css2slide(goToPixel, base.options.slideSpeed);
 +
                }
 +
            }
 +
            base.afterGo();
 +
        },
 +
 
 +
        jumpTo : function (position) {
 +
            var base = this;
 +
            if (typeof base.options.beforeMove === "function") {
 +
                base.options.beforeMove.apply(this, [base.$elem]);
 +
            }
 +
            if (position >= base.maximumItem || position === -1) {
 +
                position = base.maximumItem;
 +
            } else if (position <= 0) {
 +
                position = 0;
 +
            }
 +
            base.swapSpeed(0);
 +
            if (base.browser.support3d === true) {
 +
                base.transition3d(base.positionsInArray[position]);
 +
            } else {
 +
                base.css2slide(base.positionsInArray[position], 1);
 +
            }
 +
            base.currentItem = base.owl.currentItem = position;
 +
            base.afterGo();
 +
        },
 +
 
 +
        afterGo : function () {
 +
            var base = this;
 +
 
 +
            base.prevArr.push(base.currentItem);
 +
            base.prevItem = base.owl.prevItem = base.prevArr[base.prevArr.length - 2];
 +
            base.prevArr.shift(0);
 +
 
 +
            if (base.prevItem !== base.currentItem) {
 +
                base.checkPagination();
 +
                base.checkNavigation();
 +
                base.eachMoveUpdate();
 +
 
 +
                if (base.options.autoPlay !== false) {
 +
                    base.checkAp();
 +
                }
 +
            }
 +
            if (typeof base.options.afterMove === "function" && base.prevItem !== base.currentItem) {
 +
                base.options.afterMove.apply(this, [base.$elem]);
 +
            }
 +
        },
 +
 
 +
        stop : function () {
 +
            var base = this;
 +
            base.apStatus = "stop";
 +
            window.clearInterval(base.autoPlayInterval);
 +
        },
 +
 
 +
        checkAp : function () {
 +
            var base = this;
 +
            if (base.apStatus !== "stop") {
 +
                base.play();
 +
            }
 +
        },
 +
 
 +
        play : function () {
 +
            var base = this;
 +
            base.apStatus = "play";
 +
            if (base.options.autoPlay === false) {
 +
                return false;
 +
            }
 +
            window.clearInterval(base.autoPlayInterval);
 +
            base.autoPlayInterval = window.setInterval(function () {
 +
                base.next(true);
 +
            }, base.options.autoPlay);
 +
        },
 +
 
 +
        swapSpeed : function (action) {
 +
            var base = this;
 +
            if (action === "slideSpeed") {
 +
                base.$owlWrapper.css(base.addCssSpeed(base.options.slideSpeed));
 +
            } else if (action === "paginationSpeed") {
 +
                base.$owlWrapper.css(base.addCssSpeed(base.options.paginationSpeed));
 +
            } else if (typeof action !== "string") {
 +
                base.$owlWrapper.css(base.addCssSpeed(action));
 +
            }
 +
        },
 +
 
 +
        addCssSpeed : function (speed) {
 +
            return {
 +
                "-webkit-transition": "all " + speed + "ms ease",
 +
                "-moz-transition": "all " + speed + "ms ease",
 +
                "-o-transition": "all " + speed + "ms ease",
 +
                "transition": "all " + speed + "ms ease"
 +
            };
 +
        },
 +
 
 +
        removeTransition : function () {
 +
            return {
 +
                "-webkit-transition": "",
 +
                "-moz-transition": "",
 +
                "-o-transition": "",
 +
                "transition": ""
 +
            };
 +
        },
 +
 
 +
        doTranslate : function (pixels) {
 +
            return {
 +
                "-webkit-transform": "translate3d(" + pixels + "px, 0px, 0px)",
 +
                "-moz-transform": "translate3d(" + pixels + "px, 0px, 0px)",
 +
                "-o-transform": "translate3d(" + pixels + "px, 0px, 0px)",
 +
                "-ms-transform": "translate3d(" + pixels + "px, 0px, 0px)",
 +
                "transform": "translate3d(" + pixels + "px, 0px,0px)"
 +
            };
 +
        },
 +
 
 +
        transition3d : function (value) {
 +
            var base = this;
 +
            base.$owlWrapper.css(base.doTranslate(value));
 +
        },
 +
 
 +
        css2move : function (value) {
 +
            var base = this;
 +
            base.$owlWrapper.css({"left" : value});
 +
        },
 +
 
 +
        css2slide : function (value, speed) {
 +
            var base = this;
 +
 
 +
            base.isCssFinish = false;
 +
            base.$owlWrapper.stop(true, true).animate({
 +
                "left" : value
 +
            }, {
 +
                duration : speed || base.options.slideSpeed,
 +
                complete : function () {
 +
                    base.isCssFinish = true;
 +
                }
 +
            });
 +
        },
 +
 
 +
        checkBrowser : function () {
 +
            var base = this,
 +
                translate3D = "translate3d(0px, 0px, 0px)",
 +
                tempElem = document.createElement("div"),
 +
                regex,
 +
                asSupport,
 +
                support3d,
 +
                isTouch;
 +
 
 +
            tempElem.style.cssText = "  -moz-transform:" + translate3D +
 +
                                  "; -ms-transform:"    + translate3D +
 +
                                  "; -o-transform:"      + translate3D +
 +
                                  "; -webkit-transform:" + translate3D +
 +
                                  "; transform:"        + translate3D;
 +
            regex = /translate3d\(0px, 0px, 0px\)/g;
 +
            asSupport = tempElem.style.cssText.match(regex);
 +
            support3d = (asSupport !== null && asSupport.length === 1);
 +
 
 +
            isTouch = "ontouchstart" in window || window.navigator.msMaxTouchPoints;
 +
 
 +
            base.browser = {
 +
                "support3d" : support3d,
 +
                "isTouch" : isTouch
 +
            };
 +
        },
 +
 
 +
        moveEvents : function () {
 +
            var base = this;
 +
            if (base.options.mouseDrag !== false || base.options.touchDrag !== false) {
 +
                base.gestures();
 +
                base.disabledEvents();
 +
            }
 +
        },
 +
 
 +
        eventTypes : function () {
 +
            var base = this,
 +
                types = ["s", "e", "x"];
 +
 
 +
            base.ev_types = {};
 +
 
 +
            if (base.options.mouseDrag === true && base.options.touchDrag === true) {
 +
                types = [
 +
                    "touchstart.owl mousedown.owl",
 +
                    "touchmove.owl mousemove.owl",
 +
                    "touchend.owl touchcancel.owl mouseup.owl"
 +
                ];
 +
            } else if (base.options.mouseDrag === false && base.options.touchDrag === true) {
 +
                types = [
 +
                    "touchstart.owl",
 +
                    "touchmove.owl",
 +
                    "touchend.owl touchcancel.owl"
 +
                ];
 +
            } else if (base.options.mouseDrag === true && base.options.touchDrag === false) {
 +
                types = [
 +
                    "mousedown.owl",
 +
                    "mousemove.owl",
 +
                    "mouseup.owl"
 +
                ];
 +
            }
 +
 
 +
            base.ev_types.start = types[0];
 +
            base.ev_types.move = types[1];
 +
            base.ev_types.end = types[2];
 +
        },
 +
 
 +
        disabledEvents :  function () {
 +
            var base = this;
 +
            base.$elem.on("dragstart.owl", function (event) { event.preventDefault(); });
 +
            base.$elem.on("mousedown.disableTextSelect", function (e) {
 +
                return $(e.target).is('input, textarea, select, option');
 +
            });
 +
        },
 +
 
 +
        gestures : function () {
 +
            /*jslint unparam: true*/
 +
            var base = this,
 +
                locals = {
 +
                    offsetX : 0,
 +
                    offsetY : 0,
 +
                    baseElWidth : 0,
 +
                    relativePos : 0,
 +
                    position: null,
 +
                    minSwipe : null,
 +
                    maxSwipe: null,
 +
                    sliding : null,
 +
                    dargging: null,
 +
                    targetElement : null
 +
                };
 +
 
 +
            base.isCssFinish = true;
 +
 
 +
            function getTouches(event) {
 +
                if (event.touches !== undefined) {
 +
                    return {
 +
                        x : event.touches[0].pageX,
 +
                        y : event.touches[0].pageY
 +
                    };
 +
                }
 +
 
 +
                if (event.touches === undefined) {
 +
                    if (event.pageX !== undefined) {
 +
                        return {
 +
                            x : event.pageX,
 +
                            y : event.pageY
 +
                        };
 +
                    }
 +
                    if (event.pageX === undefined) {
 +
                        return {
 +
                            x : event.clientX,
 +
                            y : event.clientY
 +
                        };
 +
                    }
 +
                }
 +
            }
 +
 
 +
            function swapEvents(type) {
 +
                if (type === "on") {
 +
                    $(document).on(base.ev_types.move, dragMove);
 +
                    $(document).on(base.ev_types.end, dragEnd);
 +
                } else if (type === "off") {
 +
                    $(document).off(base.ev_types.move);
 +
                    $(document).off(base.ev_types.end);
 +
                }
 +
            }
 +
 
 +
            function dragStart(event) {
 +
                var ev = event.originalEvent || event || window.event,
 +
                    position;
 +
 
 +
                if (ev.which === 3) {
 +
                    return false;
 +
                }
 +
                if (base.itemsAmount <= base.options.items) {
 +
                    return;
 +
                }
 +
                if (base.isCssFinish === false && !base.options.dragBeforeAnimFinish) {
 +
                    return false;
 +
                }
 +
                if (base.isCss3Finish === false && !base.options.dragBeforeAnimFinish) {
 +
                    return false;
 +
                }
 +
 
 +
                if (base.options.autoPlay !== false) {
 +
                    window.clearInterval(base.autoPlayInterval);
 +
                }
 +
 
 +
                if (base.browser.isTouch !== true && !base.$owlWrapper.hasClass("grabbing")) {
 +
                    base.$owlWrapper.addClass("grabbing");
 +
                }
 +
 
 +
                base.newPosX = 0;
 +
                base.newRelativeX = 0;
 +
 
 +
                $(this).css(base.removeTransition());
 +
 
 +
                position = $(this).position();
 +
                locals.relativePos = position.left;
 +
 
 +
                locals.offsetX = getTouches(ev).x - position.left;
 +
                locals.offsetY = getTouches(ev).y - position.top;
 +
 
 +
                swapEvents("on");
 +
 
 +
                locals.sliding = false;
 +
                locals.targetElement = ev.target || ev.srcElement;
 +
            }
 +
 
 +
            function dragMove(event) {
 +
                var ev = event.originalEvent || event || window.event,
 +
                    minSwipe,
 +
                    maxSwipe;
 +
 
 +
                base.newPosX = getTouches(ev).x - locals.offsetX;
 +
                base.newPosY = getTouches(ev).y - locals.offsetY;
 +
                base.newRelativeX = base.newPosX - locals.relativePos;
 +
 
 +
                if (typeof base.options.startDragging === "function" && locals.dragging !== true && base.newRelativeX !== 0) {
 +
                    locals.dragging = true;
 +
                    base.options.startDragging.apply(base, [base.$elem]);
 +
                }
 +
 
 +
                if ((base.newRelativeX > 8 || base.newRelativeX < -8) && (base.browser.isTouch === true)) {
 +
                    if (ev.preventDefault !== undefined) {
 +
                        ev.preventDefault();
 +
                    } else {
 +
                        ev.returnValue = false;
 +
                    }
 +
                    locals.sliding = true;
 +
                }
 +
 
 +
                if ((base.newPosY > 10 || base.newPosY < -10) && locals.sliding === false) {
 +
                    $(document).off("touchmove.owl");
 +
                }
 +
 
 +
                minSwipe = function () {
 +
                    return base.newRelativeX / 5;
 +
                };
 +
 
 +
                maxSwipe = function () {
 +
                    return base.maximumPixels + base.newRelativeX / 5;
 +
                };
 +
 
 +
                base.newPosX = Math.max(Math.min(base.newPosX, minSwipe()), maxSwipe());
 +
                if (base.browser.support3d === true) {
 +
                    base.transition3d(base.newPosX);
 +
                } else {
 +
                    base.css2move(base.newPosX);
 +
                }
 +
            }
 +
 
 +
            function dragEnd(event) {
 +
                var ev = event.originalEvent || event || window.event,
 +
                    newPosition,
 +
                    handlers,
 +
                    owlStopEvent;
 +
 
 +
                ev.target = ev.target || ev.srcElement;
 +
 
 +
                locals.dragging = false;
 +
 
 +
                if (base.browser.isTouch !== true) {
 +
                    base.$owlWrapper.removeClass("grabbing");
 +
                }
 +
 
 +
                if (base.newRelativeX < 0) {
 +
                    base.dragDirection = base.owl.dragDirection = "left";
 +
                } else {
 +
                    base.dragDirection = base.owl.dragDirection = "right";
 +
                }
 +
 
 +
                if (base.newRelativeX !== 0) {
 +
                    newPosition = base.getNewPosition();
 +
                    base.goTo(newPosition, false, "drag");
 +
                    if (locals.targetElement === ev.target && base.browser.isTouch !== true) {
 +
                        $(ev.target).on("click.disable", function (ev) {
 +
                            ev.stopImmediatePropagation();
 +
                            ev.stopPropagation();
 +
                            ev.preventDefault();
 +
                            $(ev.target).off("click.disable");
 +
                        });
 +
                        handlers = $._data(ev.target, "events").click;
 +
                        owlStopEvent = handlers.pop();
 +
                        handlers.splice(0, 0, owlStopEvent);
 +
                    }
 +
                }
 +
                swapEvents("off");
 +
            }
 +
            base.$elem.on(base.ev_types.start, ".owl-wrapper", dragStart);
 +
        },
 +
 
 +
        getNewPosition : function () {
 +
            var base = this,
 +
                newPosition = base.closestItem();
 +
 
 +
            if (newPosition > base.maximumItem) {
 +
                base.currentItem = base.maximumItem;
 +
                newPosition  = base.maximumItem;
 +
            } else if (base.newPosX >= 0) {
 +
                newPosition = 0;
 +
                base.currentItem = 0;
 +
            }
 +
            return newPosition;
 +
        },
 +
        closestItem : function () {
 +
            var base = this,
 +
                array = base.options.scrollPerPage === true ? base.pagesInArray : base.positionsInArray,
 +
                goal = base.newPosX,
 +
                closest = null;
 +
 
 +
            $.each(array, function (i, v) {
 +
                if (goal - (base.itemWidth / 20) > array[i + 1] && goal - (base.itemWidth / 20) < v && base.moveDirection() === "left") {
 +
                    closest = v;
 +
                    if (base.options.scrollPerPage === true) {
 +
                        base.currentItem = $.inArray(closest, base.positionsInArray);
 +
                    } else {
 +
                        base.currentItem = i;
 +
                    }
 +
                } else if (goal + (base.itemWidth / 20) < v && goal + (base.itemWidth / 20) > (array[i + 1] || array[i] - base.itemWidth) && base.moveDirection() === "right") {
 +
                    if (base.options.scrollPerPage === true) {
 +
                        closest = array[i + 1] || array[array.length - 1];
 +
                        base.currentItem = $.inArray(closest, base.positionsInArray);
 +
                    } else {
 +
                        closest = array[i + 1];
 +
                        base.currentItem = i + 1;
 +
                    }
 +
                }
 +
            });
 +
            return base.currentItem;
 +
        },
 +
 
 +
        moveDirection : function () {
 +
            var base = this,
 +
                direction;
 +
            if (base.newRelativeX < 0) {
 +
                direction = "right";
 +
                base.playDirection = "next";
 +
            } else {
 +
                direction = "left";
 +
                base.playDirection = "prev";
 +
            }
 +
            return direction;
 +
        },
 +
 
 +
        customEvents : function () {
 +
            /*jslint unparam: true*/
 +
            var base = this;
 +
            base.$elem.on("owl.next", function () {
 +
                base.next();
 +
            });
 +
            base.$elem.on("owl.prev", function () {
 +
                base.prev();
 +
            });
 +
            base.$elem.on("owl.play", function (event, speed) {
 +
                base.options.autoPlay = speed;
 +
                base.play();
 +
                base.hoverStatus = "play";
 +
            });
 +
            base.$elem.on("owl.stop", function () {
 +
                base.stop();
 +
                base.hoverStatus = "stop";
 +
            });
 +
            base.$elem.on("owl.goTo", function (event, item) {
 +
                base.goTo(item);
 +
            });
 +
            base.$elem.on("owl.jumpTo", function (event, item) {
 +
                base.jumpTo(item);
 +
            });
 +
        },
 +
 
 +
        stopOnHover : function () {
 +
            var base = this;
 +
            if (base.options.stopOnHover === true && base.browser.isTouch !== true && base.options.autoPlay !== false) {
 +
                base.$elem.on("mouseover", function () {
 +
                    base.stop();
 +
                });
 +
                base.$elem.on("mouseout", function () {
 +
                    if (base.hoverStatus !== "stop") {
 +
                        base.play();
 +
                    }
 +
                });
 +
            }
 +
        },
 +
 
 +
        lazyLoad : function () {
 +
            var base = this,
 +
                i,
 +
                $item,
 +
                itemNumber,
 +
                $lazyImg,
 +
                follow;
 +
 
 +
            if (base.options.lazyLoad === false) {
 +
                return false;
 +
            }
 +
            for (i = 0; i < base.itemsAmount; i += 1) {
 +
                $item = $(base.$owlItems[i]);
 +
 
 +
                if ($item.data("owl-loaded") === "loaded") {
 +
                    continue;
 +
                }
 +
 
 +
                itemNumber = $item.data("owl-item");
 +
                $lazyImg = $item.find(".lazyOwl");
 +
 
 +
                if (typeof $lazyImg.data("src") !== "string") {
 +
                    $item.data("owl-loaded", "loaded");
 +
                    continue;
 +
                }
 +
                if ($item.data("owl-loaded") === undefined) {
 +
                    $lazyImg.hide();
 +
                    $item.addClass("loading").data("owl-loaded", "checked");
 +
                }
 +
                if (base.options.lazyFollow === true) {
 +
                    follow = itemNumber >= base.currentItem;
 +
                } else {
 +
                    follow = true;
 +
                }
 +
                if (follow && itemNumber < base.currentItem + base.options.items && $lazyImg.length) {
 +
                    base.lazyPreload($item, $lazyImg);
 +
                }
 +
            }
 +
        },
 +
 
 +
        lazyPreload : function ($item, $lazyImg) {
 +
            var base = this,
 +
                iterations = 0,
 +
                isBackgroundImg;
 +
 
 +
            if ($lazyImg.prop("tagName") === "DIV") {
 +
                $lazyImg.css("background-image", "url(" + $lazyImg.data("src") + ")");
 +
                isBackgroundImg = true;
 +
            } else {
 +
                $lazyImg[0].src = $lazyImg.data("src");
 +
            }
 +
 
 +
            function showImage() {
 +
                $item.data("owl-loaded", "loaded").removeClass("loading");
 +
                $lazyImg.removeAttr("data-src");
 +
                if (base.options.lazyEffect === "fade") {
 +
                    $lazyImg.fadeIn(400);
 +
                } else {
 +
                    $lazyImg.show();
 +
                }
 +
                if (typeof base.options.afterLazyLoad === "function") {
 +
                    base.options.afterLazyLoad.apply(this, [base.$elem]);
 +
                }
 +
            }
 +
 
 +
            function checkLazyImage() {
 +
                iterations += 1;
 +
                if (base.completeImg($lazyImg.get(0)) || isBackgroundImg === true) {
 +
                    showImage();
 +
                } else if (iterations <= 100) {//if image loads in less than 10 seconds
 +
                    window.setTimeout(checkLazyImage, 100);
 +
                } else {
 +
                    showImage();
 +
                }
 +
            }
 +
 
 +
            checkLazyImage();
 +
        },
 +
 
 +
        autoHeight : function () {
 +
            var base = this,
 +
                $currentimg = $(base.$owlItems[base.currentItem]).find("img"),
 +
                iterations;
 +
 
 +
            function addHeight() {
 +
                var $currentItem = $(base.$owlItems[base.currentItem]).height();
 +
                base.wrapperOuter.css("height", $currentItem + "px");
 +
                if (!base.wrapperOuter.hasClass("autoHeight")) {
 +
                    window.setTimeout(function () {
 +
                        base.wrapperOuter.addClass("autoHeight");
 +
                    }, 0);
 +
                }
 +
            }
 +
 
 +
            function checkImage() {
 +
                iterations += 1;
 +
                if (base.completeImg($currentimg.get(0))) {
 +
                    addHeight();
 +
                } else if (iterations <= 100) { //if image loads in less than 10 seconds
 +
                    window.setTimeout(checkImage, 100);
 +
                } else {
 +
                    base.wrapperOuter.css("height", ""); //Else remove height attribute
 +
                }
 +
            }
 +
 
 +
            if ($currentimg.get(0) !== undefined) {
 +
                iterations = 0;
 +
                checkImage();
 +
            } else {
 +
                addHeight();
 +
            }
 +
        },
 +
 
 +
        completeImg : function (img) {
 +
            var naturalWidthType;
 +
 
 +
            if (!img.complete) {
 +
                return false;
 +
            }
 +
            naturalWidthType = typeof img.naturalWidth;
 +
            if (naturalWidthType !== "undefined" && img.naturalWidth === 0) {
 +
                return false;
 +
            }
 +
            return true;
 +
        },
 +
 
 +
        onVisibleItems : function () {
 +
            var base = this,
 +
                i;
 +
 
 +
            if (base.options.addClassActive === true) {
 +
                base.$owlItems.removeClass("active");
 +
            }
 +
            base.visibleItems = [];
 +
            for (i = base.currentItem; i < base.currentItem + base.options.items; i += 1) {
 +
                base.visibleItems.push(i);
 +
 
 +
                if (base.options.addClassActive === true) {
 +
                    $(base.$owlItems[i]).addClass("active");
 +
                }
 +
            }
 +
            base.owl.visibleItems = base.visibleItems;
 +
        },
 +
 
 +
        transitionTypes : function (className) {
 +
            var base = this;
 +
            //Currently available: "fade", "backSlide", "goDown", "fadeUp"
 +
            base.outClass = "owl-" + className + "-out";
 +
            base.inClass = "owl-" + className + "-in";
 +
        },
 +
 
 +
        singleItemTransition : function () {
 +
            var base = this,
 +
                outClass = base.outClass,
 +
                inClass = base.inClass,
 +
                $currentItem = base.$owlItems.eq(base.currentItem),
 +
                $prevItem = base.$owlItems.eq(base.prevItem),
 +
                prevPos = Math.abs(base.positionsInArray[base.currentItem]) + base.positionsInArray[base.prevItem],
 +
                origin = Math.abs(base.positionsInArray[base.currentItem]) + base.itemWidth / 2,
 +
                animEnd = 'webkitAnimationEnd oAnimationEnd MSAnimationEnd animationend';
 +
 
 +
            base.isTransition = true;
 +
 
 +
            base.$owlWrapper
 +
                .addClass('owl-origin')
 +
                .css({
 +
                    "-webkit-transform-origin" : origin + "px",
 +
                    "-moz-perspective-origin" : origin + "px",
 +
                    "perspective-origin" : origin + "px"
 +
                });
 +
            function transStyles(prevPos) {
 +
                return {
 +
                    "position" : "relative",
 +
                    "left" : prevPos + "px"
 +
                };
 +
            }
 +
 
 +
            $prevItem
 +
                .css(transStyles(prevPos, 10))
 +
                .addClass(outClass)
 +
                .on(animEnd, function () {
 +
                    base.endPrev = true;
 +
                    $prevItem.off(animEnd);
 +
                    base.clearTransStyle($prevItem, outClass);
 +
                });
 +
 
 +
            $currentItem
 +
                .addClass(inClass)
 +
                .on(animEnd, function () {
 +
                    base.endCurrent = true;
 +
                    $currentItem.off(animEnd);
 +
                    base.clearTransStyle($currentItem, inClass);
 +
                });
 +
        },
 +
 
 +
        clearTransStyle : function (item, classToRemove) {
 +
            var base = this;
 +
            item.css({
 +
                "position" : "",
 +
                "left" : ""
 +
            }).removeClass(classToRemove);
 +
 
 +
            if (base.endPrev && base.endCurrent) {
 +
                base.$owlWrapper.removeClass('owl-origin');
 +
                base.endPrev = false;
 +
                base.endCurrent = false;
 +
                base.isTransition = false;
 +
            }
 +
        },
 +
 
 +
        owlStatus : function () {
 +
            var base = this;
 +
            base.owl = {
 +
                "userOptions"  : base.userOptions,
 +
                "baseElement"  : base.$elem,
 +
                "userItems"    : base.$userItems,
 +
                "owlItems"      : base.$owlItems,
 +
                "currentItem"  : base.currentItem,
 +
                "prevItem"      : base.prevItem,
 +
                "visibleItems"  : base.visibleItems,
 +
                "isTouch"      : base.browser.isTouch,
 +
                "browser"      : base.browser,
 +
                "dragDirection" : base.dragDirection
 +
            };
 +
        },
 +
 
 +
        clearEvents : function () {
 +
            var base = this;
 +
            base.$elem.off(".owl owl mousedown.disableTextSelect");
 +
            $(document).off(".owl owl");
 +
            $(window).off("resize", base.resizer);
 +
        },
 +
 
 +
        unWrap : function () {
 +
            var base = this;
 +
            if (base.$elem.children().length !== 0) {
 +
                base.$owlWrapper.unwrap();
 +
                base.$userItems.unwrap().unwrap();
 +
                if (base.owlControls) {
 +
                    base.owlControls.remove();
 +
                }
 +
            }
 +
            base.clearEvents();
 +
            base.$elem
 +
                .attr("style", base.$elem.data("owl-originalStyles") || "")
 +
                .attr("class", base.$elem.data("owl-originalClasses"));
 +
        },
 +
 
 +
        destroy : function () {
 +
            var base = this;
 +
            base.stop();
 +
            window.clearInterval(base.checkVisible);
 +
            base.unWrap();
 +
            base.$elem.removeData();
 +
        },
 +
 
 +
        reinit : function (newOptions) {
 +
            var base = this,
 +
                options = $.extend({}, base.userOptions, newOptions);
 +
            base.unWrap();
 +
            base.init(options, base.$elem);
 +
        },
 +
 
 +
        addItem : function (htmlString, targetPosition) {
 +
            var base = this,
 +
                position;
 +
 
 +
            if (!htmlString) {return false; }
 +
 
 +
            if (base.$elem.children().length === 0) {
 +
                base.$elem.append(htmlString);
 +
                base.setVars();
 +
                return false;
 +
            }
 +
            base.unWrap();
 +
            if (targetPosition === undefined || targetPosition === -1) {
 +
                position = -1;
 +
            } else {
 +
                position = targetPosition;
 +
            }
 +
            if (position >= base.$userItems.length || position === -1) {
 +
                base.$userItems.eq(-1).after(htmlString);
 +
            } else {
 +
                base.$userItems.eq(position).before(htmlString);
 +
            }
 +
 
 +
            base.setVars();
 +
        },
 +
 
 +
        removeItem : function (targetPosition) {
 +
            var base = this,
 +
                position;
 +
 
 +
            if (base.$elem.children().length === 0) {
 +
                return false;
 +
            }
 +
            if (targetPosition === undefined || targetPosition === -1) {
 +
                position = -1;
 +
            } else {
 +
                position = targetPosition;
 +
            }
 +
 
 +
            base.unWrap();
 +
            base.$userItems.eq(position).remove();
 +
            base.setVars();
 +
        }
 +
 
 +
    };
 +
 
 +
    $.fn.owlCarousel = function (options) {
 +
        return this.each(function () {
 +
            if ($(this).data("owl-init") === true) {
 +
                return false;
 +
            }
 +
            $(this).data("owl-init", true);
 +
            var carousel = Object.create(Carousel);
 +
            carousel.init(options, this);
 +
            $.data(this, "owlCarousel", carousel);
 +
        });
 +
    };
 +
 
 +
    $.fn.owlCarousel.options = {
 +
 
 +
        items : 5,
 +
        itemsCustom : false,
 +
        itemsDesktop : [1199, 4],
 +
        itemsDesktopSmall : [979, 3],
 +
        itemsTablet : [768, 2],
 +
        itemsTabletSmall : false,
 +
        itemsMobile : [479, 1],
 +
        singleItem : false,
 +
        itemsScaleUp : false,
 +
 
 +
        slideSpeed : 200,
 +
        paginationSpeed : 800,
 +
        rewindSpeed : 1000,
 +
 
 +
        autoPlay : false,
 +
        stopOnHover : false,
 +
 
 +
        navigation : false,
 +
        navigationText : ["prev", "next"],
 +
        rewindNav : true,
 +
        scrollPerPage : false,
 +
 
 +
        pagination : true,
 +
        paginationNumbers : false,
 +
 
 +
        responsive : true,
 +
        responsiveRefreshRate : 200,
 +
        responsiveBaseWidth : window,
 +
 
 +
        baseClass : "owl-carousel",
 +
        theme : "owl-theme",
 +
 
 +
        lazyLoad : false,
 +
        lazyFollow : true,
 +
        lazyEffect : "fade",
 +
 
 +
        autoHeight : false,
 +
 
 +
        jsonPath : false,
 +
        jsonSuccess : false,
 +
 
 +
        dragBeforeAnimFinish : true,
 +
        mouseDrag : true,
 +
        touchDrag : true,
 +
 
 +
        addClassActive : false,
 +
        transitionStyle : false,
 +
 
 +
        beforeUpdate : false,
 +
        afterUpdate : false,
 +
        beforeInit : false,
 +
        afterInit : false,
 +
        beforeMove : false,
 +
        afterMove : false,
 +
        afterAction : false,
 +
        startDragging : false,
 +
        afterLazyLoad: false
 +
    };
 +
}(jQuery, window, document));
 +
 
 +
 
 +
 
 +
/*
 +
* jQuery FlexSlider v2.2.0
 +
* Copyright 2012 WooThemes
 +
* Contributing Author: Tyler Smith
 +
*/
 +
;
 +
(function ($) {
 +
 
 +
  //FlexSlider: Object Instance
 +
  $.flexslider = function(el, options) {
 +
    var slider = $(el);
 +
 
 +
    // making variables public
 +
    slider.vars = $.extend({}, $.flexslider.defaults, options);
 +
 
 +
    var namespace = slider.vars.namespace,
 +
        msGesture = window.navigator && window.navigator.msPointerEnabled && window.MSGesture,
 +
        touch = (( "ontouchstart" in window ) || msGesture || window.DocumentTouch && document instanceof DocumentTouch) && slider.vars.touch,
 +
        // depricating this idea, as devices are being released with both of these events
 +
        //eventType = (touch) ? "touchend" : "click",
 +
        eventType = "click touchend MSPointerUp",
 +
        watchedEvent = "",
 +
        watchedEventClearTimer,
 +
        vertical = slider.vars.direction === "vertical",
 +
        reverse = slider.vars.reverse,
 +
        carousel = (slider.vars.itemWidth > 0),
 +
        fade = slider.vars.animation === "fade",
 +
        asNav = slider.vars.asNavFor !== "",
 +
        methods = {},
 +
        focused = true;
 +
 
 +
    // Store a reference to the slider object
 +
    $.data(el, "flexslider", slider);
 +
 
 +
    // Private slider methods
 +
    methods = {
 +
      init: function() {
 +
        slider.animating = false;
 +
        // Get current slide and make sure it is a number
 +
        slider.currentSlide = parseInt( ( slider.vars.startAt ? slider.vars.startAt : 0) );
 +
        if ( isNaN( slider.currentSlide ) ) slider.currentSlide = 0;
 +
        slider.animatingTo = slider.currentSlide;
 +
        slider.atEnd = (slider.currentSlide === 0 || slider.currentSlide === slider.last);
 +
        slider.containerSelector = slider.vars.selector.substr(0,slider.vars.selector.search(' '));
 +
        slider.slides = $(slider.vars.selector, slider);
 +
        slider.container = $(slider.containerSelector, slider);
 +
        slider.count = slider.slides.length;
 +
        // SYNC:
 +
        slider.syncExists = $(slider.vars.sync).length > 0;
 +
        // SLIDE:
 +
        if (slider.vars.animation === "slide") slider.vars.animation = "swing";
 +
        slider.prop = (vertical) ? "top" : "marginLeft";
 +
        slider.args = {};
 +
        // SLIDESHOW:
 +
        slider.manualPause = false;
 +
        slider.stopped = false;
 +
        //PAUSE WHEN INVISIBLE
 +
        slider.started = false;
 +
        slider.startTimeout = null;
 +
        // TOUCH/USECSS:
 +
        slider.transitions = !slider.vars.video && !fade && slider.vars.useCSS && (function() {
 +
          var obj = document.createElement('div'),
 +
              props = ['perspectiveProperty', 'WebkitPerspective', 'MozPerspective', 'OPerspective', 'msPerspective'];
 +
          for (var i in props) {
 +
            if ( obj.style[ props[i] ] !== undefined ) {
 +
              slider.pfx = props[i].replace('Perspective','').toLowerCase();
 +
              slider.prop = "-" + slider.pfx + "-transform";
 +
              return true;
 +
            }
 +
          }
 +
          return false;
 +
        }());
 +
        // CONTROLSCONTAINER:
 +
        if (slider.vars.controlsContainer !== "") slider.controlsContainer = $(slider.vars.controlsContainer).length > 0 && $(slider.vars.controlsContainer);
 +
        // MANUAL:
 +
        if (slider.vars.manualControls !== "") slider.manualControls = $(slider.vars.manualControls).length > 0 && $(slider.vars.manualControls);
 +
 
 +
        // RANDOMIZE:
 +
        if (slider.vars.randomize) {
 +
          slider.slides.sort(function() { return (Math.round(Math.random())-0.5); });
 +
          slider.container.empty().append(slider.slides);
 +
        }
 +
 
 +
        slider.doMath();
 +
 
 +
        // INIT
 +
        slider.setup("init");
 +
 
 +
        // CONTROLNAV:
 +
        if (slider.vars.controlNav) methods.controlNav.setup();
 +
 
 +
        // DIRECTIONNAV:
 +
        if (slider.vars.directionNav) methods.directionNav.setup();
 +
 
 +
        // KEYBOARD:
 +
        if (slider.vars.keyboard && ($(slider.containerSelector).length === 1 || slider.vars.multipleKeyboard)) {
 +
          $(document).bind('keyup', function(event) {
 +
            var keycode = event.keyCode;
 +
            if (!slider.animating && (keycode === 39 || keycode === 37)) {
 +
              var target = (keycode === 39) ? slider.getTarget('next') :
 +
                          (keycode === 37) ? slider.getTarget('prev') : false;
 +
              slider.flexAnimate(target, slider.vars.pauseOnAction);
 +
            }
 +
          });
 +
        }
 +
        // MOUSEWHEEL:
 +
        if (slider.vars.mousewheel) {
 +
          slider.bind('mousewheel', function(event, delta, deltaX, deltaY) {
 +
            event.preventDefault();
 +
            var target = (delta < 0) ? slider.getTarget('next') : slider.getTarget('prev');
 +
            slider.flexAnimate(target, slider.vars.pauseOnAction);
 +
          });
 +
        }
 +
 
 +
        // PAUSEPLAY
 +
        if (slider.vars.pausePlay) methods.pausePlay.setup();
 +
 
 +
        //PAUSE WHEN INVISIBLE
 +
        if (slider.vars.slideshow && slider.vars.pauseInvisible) methods.pauseInvisible.init();
 +
 
 +
        // SLIDSESHOW
 +
        if (slider.vars.slideshow) {
 +
          if (slider.vars.pauseOnHover) {
 +
            slider.hover(function() {
 +
              if (!slider.manualPlay && !slider.manualPause) slider.pause();
 +
            }, function() {
 +
              if (!slider.manualPause && !slider.manualPlay && !slider.stopped) slider.play();
 +
            });
 +
          }
 +
          // initialize animation
 +
          //If we're visible, or we don't use PageVisibility API
 +
          if(!slider.vars.pauseInvisible || !methods.pauseInvisible.isHidden()) {
 +
            (slider.vars.initDelay > 0) ? slider.startTimeout = setTimeout(slider.play, slider.vars.initDelay) : slider.play();
 +
          }
 +
        }
 +
 
 +
        // ASNAV:
 +
        if (asNav) methods.asNav.setup();
 +
 
 +
        // TOUCH
 +
        if (touch && slider.vars.touch) methods.touch();
 +
 
 +
        // FADE&&SMOOTHHEIGHT || SLIDE:
 +
        if (!fade || (fade && slider.vars.smoothHeight)) $(window).bind("resize orientationchange focus", methods.resize);
 +
 
 +
        slider.find("img").attr("draggable", "false");
 +
 
 +
        // API: start() Callback
 +
        setTimeout(function(){
 +
          slider.vars.start(slider);
 +
        }, 200);
 +
      },
 +
      asNav: {
 +
        setup: function() {
 +
          slider.asNav = true;
 +
          slider.animatingTo = Math.floor(slider.currentSlide/slider.move);
 +
          slider.currentItem = slider.currentSlide;
 +
          slider.slides.removeClass(namespace + "active-slide").eq(slider.currentItem).addClass(namespace + "active-slide");
 +
          if(!msGesture){
 +
              slider.slides.click(function(e){
 +
                e.preventDefault();
 +
                var $slide = $(this),
 +
                    target = $slide.index();
 +
                var posFromLeft = $slide.offset().left - $(slider).scrollLeft(); // Find position of slide relative to left of slider container
 +
                if( posFromLeft <= 0 && $slide.hasClass( namespace + 'active-slide' ) ) {
 +
                  slider.flexAnimate(slider.getTarget("prev"), true);
 +
                } else if (!$(slider.vars.asNavFor).data('flexslider').animating && !$slide.hasClass(namespace + "active-slide")) {
 +
                  slider.direction = (slider.currentItem < target) ? "next" : "prev";
 +
                  slider.flexAnimate(target, slider.vars.pauseOnAction, false, true, true);
 +
                }
 +
              });
 +
          }else{
 +
              el._slider = slider;
 +
              slider.slides.each(function (){
 +
                  var that = this;
 +
                  that._gesture = new MSGesture();
 +
                  that._gesture.target = that;
 +
                  that.addEventListener("MSPointerDown", function (e){
 +
                      e.preventDefault();
 +
                      if(e.currentTarget._gesture)
 +
                          e.currentTarget._gesture.addPointer(e.pointerId);
 +
                  }, false);
 +
                  that.addEventListener("MSGestureTap", function (e){
 +
                      e.preventDefault();
 +
                      var $slide = $(this),
 +
                          target = $slide.index();
 +
                      if (!$(slider.vars.asNavFor).data('flexslider').animating && !$slide.hasClass('active')) {
 +
                          slider.direction = (slider.currentItem < target) ? "next" : "prev";
 +
                          slider.flexAnimate(target, slider.vars.pauseOnAction, false, true, true);
 +
                      }
 +
                  });
 +
              });
 +
          }
 +
        }
 +
      },
 +
      controlNav: {
 +
        setup: function() {
 +
          if (!slider.manualControls) {
 +
            methods.controlNav.setupPaging();
 +
          } else { // MANUALCONTROLS:
 +
            methods.controlNav.setupManual();
 +
          }
 +
        },
 +
        setupPaging: function() {
 +
          var type = (slider.vars.controlNav === "thumbnails") ? 'control-thumbs' : 'control-paging',
 +
              j = 1,
 +
              item,
 +
              slide;
 +
 
 +
          slider.controlNavScaffold = $('<ol class="'+ namespace + 'control-nav ' + namespace + type + '"></ol>');
 +
 
 +
          if (slider.pagingCount > 1) {
 +
            for (var i = 0; i < slider.pagingCount; i++) {
 +
              slide = slider.slides.eq(i);
 +
              item = (slider.vars.controlNav === "thumbnails") ? '<img src="' + slide.attr( 'data-thumb' ) + '"/>' : '<a>' + j + '</a>';
 +
              if ( 'thumbnails' === slider.vars.controlNav && true === slider.vars.thumbCaptions ) {
 +
                var captn = slide.attr( 'data-thumbcaption' );
 +
                if ( '' != captn && undefined != captn ) item += '<span class="' + namespace + 'caption">' + captn + '</span>';
 +
              }
 +
              slider.controlNavScaffold.append('<li>' + item + '</li>');
 +
              j++;
 +
            }
 +
          }
 +
 
 +
          // CONTROLSCONTAINER:
 +
          (slider.controlsContainer) ? $(slider.controlsContainer).append(slider.controlNavScaffold) : slider.append(slider.controlNavScaffold);
 +
          methods.controlNav.set();
 +
 
 +
          methods.controlNav.active();
 +
 
 +
          slider.controlNavScaffold.delegate('a, img', eventType, function(event) {
 +
            event.preventDefault();
 +
 
 +
            if (watchedEvent === "" || watchedEvent === event.type) {
 +
              var $this = $(this),
 +
                  target = slider.controlNav.index($this);
 +
 
 +
              if (!$this.hasClass(namespace + 'active')) {
 +
                slider.direction = (target > slider.currentSlide) ? "next" : "prev";
 +
                slider.flexAnimate(target, slider.vars.pauseOnAction);
 +
              }
 +
            }
 +
 
 +
            // setup flags to prevent event duplication
 +
            if (watchedEvent === "") {
 +
              watchedEvent = event.type;
 +
            }
 +
            methods.setToClearWatchedEvent();
 +
 
 +
          });
 +
        },
 +
        setupManual: function() {
 +
          slider.controlNav = slider.manualControls;
 +
          methods.controlNav.active();
 +
 
 +
          slider.controlNav.bind(eventType, function(event) {
 +
            event.preventDefault();
 +
 
 +
            if (watchedEvent === "" || watchedEvent === event.type) {
 +
              var $this = $(this),
 +
                  target = slider.controlNav.index($this);
 +
 
 +
              if (!$this.hasClass(namespace + 'active')) {
 +
                (target > slider.currentSlide) ? slider.direction = "next" : slider.direction = "prev";
 +
                slider.flexAnimate(target, slider.vars.pauseOnAction);
 +
              }
 +
            }
 +
 
 +
            // setup flags to prevent event duplication
 +
            if (watchedEvent === "") {
 +
              watchedEvent = event.type;
 +
            }
 +
            methods.setToClearWatchedEvent();
 +
          });
 +
        },
 +
        set: function() {
 +
          var selector = (slider.vars.controlNav === "thumbnails") ? 'img' : 'a';
 +
          slider.controlNav = $('.' + namespace + 'control-nav li ' + selector, (slider.controlsContainer) ? slider.controlsContainer : slider);
 +
        },
 +
        active: function() {
 +
          slider.controlNav.removeClass(namespace + "active").eq(slider.animatingTo).addClass(namespace + "active");
 +
        },
 +
        update: function(action, pos) {
 +
          if (slider.pagingCount > 1 && action === "add") {
 +
            slider.controlNavScaffold.append($('<li><a>' + slider.count + '</a></li>'));
 +
          } else if (slider.pagingCount === 1) {
 +
            slider.controlNavScaffold.find('li').remove();
 +
          } else {
 +
            slider.controlNav.eq(pos).closest('li').remove();
 +
          }
 +
          methods.controlNav.set();
 +
          (slider.pagingCount > 1 && slider.pagingCount !== slider.controlNav.length) ? slider.update(pos, action) : methods.controlNav.active();
 +
        }
 +
      },
 +
      directionNav: {
 +
        setup: function() {
 +
          var directionNavScaffold = $('<ul class="' + namespace + 'direction-nav"><li><a class="' + namespace + 'prev" href="#">' + slider.vars.prevText + '</a></li><li><a class="' + namespace + 'next" href="#">' + slider.vars.nextText + '</a></li></ul>');
 +
 
 +
          // CONTROLSCONTAINER:
 +
          if (slider.controlsContainer) {
 +
            $(slider.controlsContainer).append(directionNavScaffold);
 +
            slider.directionNav = $('.' + namespace + 'direction-nav li a', slider.controlsContainer);
 +
          } else {
 +
            slider.append(directionNavScaffold);
 +
            slider.directionNav = $('.' + namespace + 'direction-nav li a', slider);
 +
          }
 +
 
 +
          methods.directionNav.update();
 +
 
 +
          slider.directionNav.bind(eventType, function(event) {
 +
            event.preventDefault();
 +
            var target;
 +
 
 +
            if (watchedEvent === "" || watchedEvent === event.type) {
 +
              target = ($(this).hasClass(namespace + 'next')) ? slider.getTarget('next') : slider.getTarget('prev');
 +
              slider.flexAnimate(target, slider.vars.pauseOnAction);
 +
            }
 +
 
 +
            // setup flags to prevent event duplication
 +
            if (watchedEvent === "") {
 +
              watchedEvent = event.type;
 +
            }
 +
            methods.setToClearWatchedEvent();
 +
          });
 +
        },
 +
        update: function() {
 +
          var disabledClass = namespace + 'disabled';
 +
          if (slider.pagingCount === 1) {
 +
            slider.directionNav.addClass(disabledClass).attr('tabindex', '-1');
 +
          } else if (!slider.vars.animationLoop) {
 +
            if (slider.animatingTo === 0) {
 +
              slider.directionNav.removeClass(disabledClass).filter('.' + namespace + "prev").addClass(disabledClass).attr('tabindex', '-1');
 +
            } else if (slider.animatingTo === slider.last) {
 +
              slider.directionNav.removeClass(disabledClass).filter('.' + namespace + "next").addClass(disabledClass).attr('tabindex', '-1');
 +
            } else {
 +
              slider.directionNav.removeClass(disabledClass).removeAttr('tabindex');
 +
            }
 +
          } else {
 +
            slider.directionNav.removeClass(disabledClass).removeAttr('tabindex');
 +
          }
 +
        }
 +
      },
 +
      pausePlay: {
 +
        setup: function() {
 +
          var pausePlayScaffold = $('<div class="' + namespace + 'pauseplay"><a></a></div>');
 +
 
 +
          // CONTROLSCONTAINER:
 +
          if (slider.controlsContainer) {
 +
            slider.controlsContainer.append(pausePlayScaffold);
 +
            slider.pausePlay = $('.' + namespace + 'pauseplay a', slider.controlsContainer);
 +
          } else {
 +
            slider.append(pausePlayScaffold);
 +
            slider.pausePlay = $('.' + namespace + 'pauseplay a', slider);
 +
          }
 +
 
 +
          methods.pausePlay.update((slider.vars.slideshow) ? namespace + 'pause' : namespace + 'play');
 +
 
 +
          slider.pausePlay.bind(eventType, function(event) {
 +
            event.preventDefault();
 +
 
 +
            if (watchedEvent === "" || watchedEvent === event.type) {
 +
              if ($(this).hasClass(namespace + 'pause')) {
 +
                slider.manualPause = true;
 +
                slider.manualPlay = false;
 +
                slider.pause();
 +
              } else {
 +
                slider.manualPause = false;
 +
                slider.manualPlay = true;
 +
                slider.play();
 +
              }
 +
            }
 +
 
 +
            // setup flags to prevent event duplication
 +
            if (watchedEvent === "") {
 +
              watchedEvent = event.type;
 +
            }
 +
            methods.setToClearWatchedEvent();
 +
          });
 +
        },
 +
        update: function(state) {
 +
          (state === "play") ? slider.pausePlay.removeClass(namespace + 'pause').addClass(namespace + 'play').html(slider.vars.playText) : slider.pausePlay.removeClass(namespace + 'play').addClass(namespace + 'pause').html(slider.vars.pauseText);
 +
        }
 +
      },
 +
      touch: function() {
 +
        var startX,
 +
          startY,
 +
          offset,
 +
          cwidth,
 +
          dx,
 +
          startT,
 +
          scrolling = false,
 +
          localX = 0,
 +
          localY = 0,
 +
          accDx = 0;
 +
 
 +
        if(!msGesture){
 +
            el.addEventListener('touchstart', onTouchStart, false);
 +
 
 +
            function onTouchStart(e) {
 +
              if (slider.animating) {
 +
                e.preventDefault();
 +
              } else if ( ( window.navigator.msPointerEnabled ) || e.touches.length === 1 ) {
 +
                slider.pause();
 +
                // CAROUSEL:
 +
                cwidth = (vertical) ? slider.h : slider. w;
 +
                startT = Number(new Date());
 +
                // CAROUSEL:
 +
 
 +
                // Local vars for X and Y points.
 +
                localX = e.touches[0].pageX;
 +
                localY = e.touches[0].pageY;
 +
 
 +
                offset = (carousel && reverse && slider.animatingTo === slider.last) ? 0 :
 +
                        (carousel && reverse) ? slider.limit - (((slider.itemW + slider.vars.itemMargin) * slider.move) * slider.animatingTo) :
 +
                        (carousel && slider.currentSlide === slider.last) ? slider.limit :
 +
                        (carousel) ? ((slider.itemW + slider.vars.itemMargin) * slider.move) * slider.currentSlide :
 +
                        (reverse) ? (slider.last - slider.currentSlide + slider.cloneOffset) * cwidth : (slider.currentSlide + slider.cloneOffset) * cwidth;
 +
                startX = (vertical) ? localY : localX;
 +
                startY = (vertical) ? localX : localY;
 +
 
 +
                el.addEventListener('touchmove', onTouchMove, false);
 +
                el.addEventListener('touchend', onTouchEnd, false);
 +
              }
 +
            }
 +
 
 +
            function onTouchMove(e) {
 +
              // Local vars for X and Y points.
 +
 
 +
              localX = e.touches[0].pageX;
 +
              localY = e.touches[0].pageY;
 +
 
 +
              dx = (vertical) ? startX - localY : startX - localX;
 +
              scrolling = (vertical) ? (Math.abs(dx) < Math.abs(localX - startY)) : (Math.abs(dx) < Math.abs(localY - startY));
 +
 
 +
              var fxms = 500;
 +
 
 +
              if ( ! scrolling || Number( new Date() ) - startT > fxms ) {
 +
                e.preventDefault();
 +
                if (!fade && slider.transitions) {
 +
                  if (!slider.vars.animationLoop) {
 +
                    dx = dx/((slider.currentSlide === 0 && dx < 0 || slider.currentSlide === slider.last && dx > 0) ? (Math.abs(dx)/cwidth+2) : 1);
 +
                  }
 +
                  slider.setProps(offset + dx, "setTouch");
 +
                }
 +
              }
 +
            }
 +
 
 +
            function onTouchEnd(e) {
 +
              // finish the touch by undoing the touch session
 +
              el.removeEventListener('touchmove', onTouchMove, false);
 +
 
 +
              if (slider.animatingTo === slider.currentSlide && !scrolling && !(dx === null)) {
 +
                var updateDx = (reverse) ? -dx : dx,
 +
                    target = (updateDx > 0) ? slider.getTarget('next') : slider.getTarget('prev');
 +
 
 +
                if (slider.canAdvance(target) && (Number(new Date()) - startT < 550 && Math.abs(updateDx) > 50 || Math.abs(updateDx) > cwidth/2)) {
 +
                  slider.flexAnimate(target, slider.vars.pauseOnAction);
 +
                } else {
 +
                  if (!fade) slider.flexAnimate(slider.currentSlide, slider.vars.pauseOnAction, true);
 +
                }
 +
              }
 +
              el.removeEventListener('touchend', onTouchEnd, false);
 +
 
 +
              startX = null;
 +
              startY = null;
 +
              dx = null;
 +
              offset = null;
 +
            }
 +
        }else{
 +
            el.style.msTouchAction = "none";
 +
            el._gesture = new MSGesture();
 +
            el._gesture.target = el;
 +
            el.addEventListener("MSPointerDown", onMSPointerDown, false);
 +
            el._slider = slider;
 +
            el.addEventListener("MSGestureChange", onMSGestureChange, false);
 +
            el.addEventListener("MSGestureEnd", onMSGestureEnd, false);
 +
 
 +
            function onMSPointerDown(e){
 +
                e.stopPropagation();
 +
                if (slider.animating) {
 +
                    e.preventDefault();
 +
                }else{
 +
                    slider.pause();
 +
                    el._gesture.addPointer(e.pointerId);
 +
                    accDx = 0;
 +
                    cwidth = (vertical) ? slider.h : slider. w;
 +
                    startT = Number(new Date());
 +
                    // CAROUSEL:
 +
 
 +
                    offset = (carousel && reverse && slider.animatingTo === slider.last) ? 0 :
 +
                        (carousel && reverse) ? slider.limit - (((slider.itemW + slider.vars.itemMargin) * slider.move) * slider.animatingTo) :
 +
                            (carousel && slider.currentSlide === slider.last) ? slider.limit :
 +
                                (carousel) ? ((slider.itemW + slider.vars.itemMargin) * slider.move) * slider.currentSlide :
 +
                                    (reverse) ? (slider.last - slider.currentSlide + slider.cloneOffset) * cwidth : (slider.currentSlide + slider.cloneOffset) * cwidth;
 +
                }
 +
            }
 +
 
 +
            function onMSGestureChange(e) {
 +
                e.stopPropagation();
 +
                var slider = e.target._slider;
 +
                if(!slider){
 +
                    return;
 +
                }
 +
                var transX = -e.translationX,
 +
                    transY = -e.translationY;
 +
 
 +
                //Accumulate translations.
 +
                accDx = accDx + ((vertical) ? transY : transX);
 +
                dx = accDx;
 +
                scrolling = (vertical) ? (Math.abs(accDx) < Math.abs(-transX)) : (Math.abs(accDx) < Math.abs(-transY));
 +
 
 +
                if(e.detail === e.MSGESTURE_FLAG_INERTIA){
 +
                    setImmediate(function (){
 +
                        el._gesture.stop();
 +
                    });
 +
 
 +
                    return;
 +
                }
 +
 
 +
                if (!scrolling || Number(new Date()) - startT > 500) {
 +
                    e.preventDefault();
 +
                    if (!fade && slider.transitions) {
 +
                        if (!slider.vars.animationLoop) {
 +
                            dx = accDx / ((slider.currentSlide === 0 && accDx < 0 || slider.currentSlide === slider.last && accDx > 0) ? (Math.abs(accDx) / cwidth + 2) : 1);
 +
                        }
 +
                        slider.setProps(offset + dx, "setTouch");
 +
                    }
 +
                }
 +
            }
 +
 
 +
            function onMSGestureEnd(e) {
 +
                e.stopPropagation();
 +
                var slider = e.target._slider;
 +
                if(!slider){
 +
                    return;
 +
                }
 +
                if (slider.animatingTo === slider.currentSlide && !scrolling && !(dx === null)) {
 +
                    var updateDx = (reverse) ? -dx : dx,
 +
                        target = (updateDx > 0) ? slider.getTarget('next') : slider.getTarget('prev');
 +
 
 +
                    if (slider.canAdvance(target) && (Number(new Date()) - startT < 550 && Math.abs(updateDx) > 50 || Math.abs(updateDx) > cwidth/2)) {
 +
                        slider.flexAnimate(target, slider.vars.pauseOnAction);
 +
                    } else {
 +
                        if (!fade) slider.flexAnimate(slider.currentSlide, slider.vars.pauseOnAction, true);
 +
                    }
 +
                }
 +
 
 +
                startX = null;
 +
                startY = null;
 +
                dx = null;
 +
                offset = null;
 +
                accDx = 0;
 +
            }
 +
        }
 +
      },
 +
      resize: function() {
 +
        if (!slider.animating && slider.is(':visible')) {
 +
          if (!carousel) slider.doMath();
 +
 
 +
          if (fade) {
 +
            // SMOOTH HEIGHT:
 +
            methods.smoothHeight();
 +
          } else if (carousel) { //CAROUSEL:
 +
            slider.slides.width(slider.computedW);
 +
            slider.update(slider.pagingCount);
 +
            slider.setProps();
 +
          }
 +
          else if (vertical) { //VERTICAL:
 +
            slider.viewport.height(slider.h);
 +
            slider.setProps(slider.h, "setTotal");
 +
          } else {
 +
            // SMOOTH HEIGHT:
 +
            if (slider.vars.smoothHeight) methods.smoothHeight();
 +
            slider.newSlides.width(slider.computedW);
 +
            slider.setProps(slider.computedW, "setTotal");
 +
          }
 +
        }
 +
      },
 +
      smoothHeight: function(dur) {
 +
        if (!vertical || fade) {
 +
          var $obj = (fade) ? slider : slider.viewport;
 +
          (dur) ? $obj.animate({"height": slider.slides.eq(slider.animatingTo).height()}, dur) : $obj.height(slider.slides.eq(slider.animatingTo).height());
 +
        }
 +
      },
 +
      sync: function(action) {
 +
        var $obj = $(slider.vars.sync).data("flexslider"),
 +
            target = slider.animatingTo;
 +
 
 +
        switch (action) {
 +
          case "animate": $obj.flexAnimate(target, slider.vars.pauseOnAction, false, true); break;
 +
          case "play": if (!$obj.playing && !$obj.asNav) { $obj.play(); } break;
 +
          case "pause": $obj.pause(); break;
 +
        }
 +
      },
 +
      pauseInvisible: {
 +
        visProp: null,
 +
        init: function() {
 +
          var prefixes = ['webkit','moz','ms','o'];
 +
 
 +
          if ('hidden' in document) return 'hidden';
 +
          for (var i = 0; i < prefixes.length; i++) {
 +
            if ((prefixes[i] + 'Hidden') in document)
 +
            methods.pauseInvisible.visProp = prefixes[i] + 'Hidden';
 +
          }
 +
          if (methods.pauseInvisible.visProp) {
 +
            var evtname = methods.pauseInvisible.visProp.replace(/[H|h]idden/,'') + 'visibilitychange';
 +
            document.addEventListener(evtname, function() {
 +
              if (methods.pauseInvisible.isHidden()) {
 +
                if(slider.startTimeout) clearTimeout(slider.startTimeout); //If clock is ticking, stop timer and prevent from starting while invisible
 +
                else slider.pause(); //Or just pause
 +
              }
 +
              else {
 +
                if(slider.started) slider.play(); //Initiated before, just play
 +
                else (slider.vars.initDelay > 0) ? setTimeout(slider.play, slider.vars.initDelay) : slider.play(); //Didn't init before: simply init or wait for it
 +
              }
 +
            });
 +
          }     
 +
        },
 +
        isHidden: function() {
 +
          return document[methods.pauseInvisible.visProp] || false;
 +
        }
 +
      },
 +
      setToClearWatchedEvent: function() {
 +
        clearTimeout(watchedEventClearTimer);
 +
        watchedEventClearTimer = setTimeout(function() {
 +
          watchedEvent = "";
 +
        }, 3000);
 +
      }
 +
    }
 +
 
 +
    // public methods
 +
    slider.flexAnimate = function(target, pause, override, withSync, fromNav) {
 +
      if (!slider.vars.animationLoop && target !== slider.currentSlide) {
 +
        slider.direction = (target > slider.currentSlide) ? "next" : "prev";
 +
      }
 +
 
 +
      if (asNav && slider.pagingCount === 1) slider.direction = (slider.currentItem < target) ? "next" : "prev";
 +
 
 +
      if (!slider.animating && (slider.canAdvance(target, fromNav) || override) && slider.is(":visible")) {
 +
        if (asNav && withSync) {
 +
          var master = $(slider.vars.asNavFor).data('flexslider');
 +
          slider.atEnd = target === 0 || target === slider.count - 1;
 +
          master.flexAnimate(target, true, false, true, fromNav);
 +
          slider.direction = (slider.currentItem < target) ? "next" : "prev";
 +
          master.direction = slider.direction;
 +
 
 +
          if (Math.ceil((target + 1)/slider.visible) - 1 !== slider.currentSlide && target !== 0) {
 +
            slider.currentItem = target;
 +
            slider.slides.removeClass(namespace + "active-slide").eq(target).addClass(namespace + "active-slide");
 +
            target = Math.floor(target/slider.visible);
 +
          } else {
 +
            slider.currentItem = target;
 +
            slider.slides.removeClass(namespace + "active-slide").eq(target).addClass(namespace + "active-slide");
 +
            return false;
 +
          }
 +
        }
 +
 
 +
        slider.animating = true;
 +
        slider.animatingTo = target;
 +
 
 +
        // SLIDESHOW:
 +
        if (pause) slider.pause();
 +
 
 +
        // API: before() animation Callback
 +
        slider.vars.before(slider);
 +
 
 +
        // SYNC:
 +
        if (slider.syncExists && !fromNav) methods.sync("animate");
 +
 
 +
        // CONTROLNAV
 +
        if (slider.vars.controlNav) methods.controlNav.active();
 +
 
 +
        // !CAROUSEL:
 +
        // CANDIDATE: slide active class (for add/remove slide)
 +
        if (!carousel) slider.slides.removeClass(namespace + 'active-slide').eq(target).addClass(namespace + 'active-slide');
 +
 
 +
        // INFINITE LOOP:
 +
        // CANDIDATE: atEnd
 +
        slider.atEnd = target === 0 || target === slider.last;
 +
 
 +
        // DIRECTIONNAV:
 +
        if (slider.vars.directionNav) methods.directionNav.update();
 +
 
 +
        if (target === slider.last) {
 +
          // API: end() of cycle Callback
 +
          slider.vars.end(slider);
 +
          // SLIDESHOW && !INFINITE LOOP:
 +
          if (!slider.vars.animationLoop) slider.pause();
 +
        }
 +
 
 +
        // SLIDE:
 +
        if (!fade) {
 +
          var dimension = (vertical) ? slider.slides.filter(':first').height() : slider.computedW,
 +
              margin, slideString, calcNext;
 +
 
 +
          // INFINITE LOOP / REVERSE:
 +
          if (carousel) {
 +
            //margin = (slider.vars.itemWidth > slider.w) ? slider.vars.itemMargin * 2 : slider.vars.itemMargin;
 +
            margin = slider.vars.itemMargin;
 +
            calcNext = ((slider.itemW + margin) * slider.move) * slider.animatingTo;
 +
            slideString = (calcNext > slider.limit && slider.visible !== 1) ? slider.limit : calcNext;
 +
          } else if (slider.currentSlide === 0 && target === slider.count - 1 && slider.vars.animationLoop && slider.direction !== "next") {
 +
            slideString = (reverse) ? (slider.count + slider.cloneOffset) * dimension : 0;
 +
          } else if (slider.currentSlide === slider.last && target === 0 && slider.vars.animationLoop && slider.direction !== "prev") {
 +
            slideString = (reverse) ? 0 : (slider.count + 1) * dimension;
 +
          } else {
 +
            slideString = (reverse) ? ((slider.count - 1) - target + slider.cloneOffset) * dimension : (target + slider.cloneOffset) * dimension;
 +
          }
 +
          slider.setProps(slideString, "", slider.vars.animationSpeed);
 +
          if (slider.transitions) {
 +
            if (!slider.vars.animationLoop || !slider.atEnd) {
 +
              slider.animating = false;
 +
              slider.currentSlide = slider.animatingTo;
 +
            }
 +
            slider.container.unbind("webkitTransitionEnd transitionend");
 +
            slider.container.bind("webkitTransitionEnd transitionend", function() {
 +
              slider.wrapup(dimension);
 +
            });
 +
          } else {
 +
            slider.container.animate(slider.args, slider.vars.animationSpeed, slider.vars.easing, function(){
 +
              slider.wrapup(dimension);
 +
            });
 +
          }
 +
        } else { // FADE:
 +
          if (!touch) {
 +
            //slider.slides.eq(slider.currentSlide).fadeOut(slider.vars.animationSpeed, slider.vars.easing);
 +
            //slider.slides.eq(target).fadeIn(slider.vars.animationSpeed, slider.vars.easing, slider.wrapup);
 +
 
 +
            slider.slides.eq(slider.currentSlide).css({"zIndex": 1}).animate({"opacity": 0}, slider.vars.animationSpeed, slider.vars.easing);
 +
            slider.slides.eq(target).css({"zIndex": 2}).animate({"opacity": 1}, slider.vars.animationSpeed, slider.vars.easing, slider.wrapup);
 +
 
 +
          } else {
 +
            slider.slides.eq(slider.currentSlide).css({ "opacity": 0, "zIndex": 1 });
 +
            slider.slides.eq(target).css({ "opacity": 1, "zIndex": 2 });
 +
            slider.wrapup(dimension);
 +
          }
 +
        }
 +
        // SMOOTH HEIGHT:
 +
        if (slider.vars.smoothHeight) methods.smoothHeight(slider.vars.animationSpeed);
 +
      }
 +
    }
 +
    slider.wrapup = function(dimension) {
 +
      // SLIDE:
 +
      if (!fade && !carousel) {
 +
        if (slider.currentSlide === 0 && slider.animatingTo === slider.last && slider.vars.animationLoop) {
 +
          slider.setProps(dimension, "jumpEnd");
 +
        } else if (slider.currentSlide === slider.last && slider.animatingTo === 0 && slider.vars.animationLoop) {
 +
          slider.setProps(dimension, "jumpStart");
 +
        }
 +
      }
 +
      slider.animating = false;
 +
      slider.currentSlide = slider.animatingTo;
 +
      // API: after() animation Callback
 +
      slider.vars.after(slider);
 +
    }
 +
 
 +
    // SLIDESHOW:
 +
    slider.animateSlides = function() {
 +
      if (!slider.animating && focused ) slider.flexAnimate(slider.getTarget("next"));
 +
    }
 +
    // SLIDESHOW:
 +
    slider.pause = function() {
 +
      clearInterval(slider.animatedSlides);
 +
      slider.animatedSlides = null;
 +
      slider.playing = false;
 +
      // PAUSEPLAY:
 +
      if (slider.vars.pausePlay) methods.pausePlay.update("play");
 +
      // SYNC:
 +
      if (slider.syncExists) methods.sync("pause");
 +
    }
 +
    // SLIDESHOW:
 +
    slider.play = function() {
 +
      if (slider.playing) clearInterval(slider.animatedSlides);
 +
      slider.animatedSlides = slider.animatedSlides || setInterval(slider.animateSlides, slider.vars.slideshowSpeed);
 +
      slider.started = slider.playing = true;
 +
      // PAUSEPLAY:
 +
      if (slider.vars.pausePlay) methods.pausePlay.update("pause");
 +
      // SYNC:
 +
      if (slider.syncExists) methods.sync("play");
 +
    }
 +
    // STOP:
 +
    slider.stop = function () {
 +
      slider.pause();
 +
      slider.stopped = true;
 +
    }
 +
    slider.canAdvance = function(target, fromNav) {
 +
      // ASNAV:
 +
      var last = (asNav) ? slider.pagingCount - 1 : slider.last;
 +
      return (fromNav) ? true :
 +
            (asNav && slider.currentItem === slider.count - 1 && target === 0 && slider.direction === "prev") ? true :
 +
            (asNav && slider.currentItem === 0 && target === slider.pagingCount - 1 && slider.direction !== "next") ? false :
 +
            (target === slider.currentSlide && !asNav) ? false :
 +
            (slider.vars.animationLoop) ? true :
 +
            (slider.atEnd && slider.currentSlide === 0 && target === last && slider.direction !== "next") ? false :
 +
            (slider.atEnd && slider.currentSlide === last && target === 0 && slider.direction === "next") ? false :
 +
            true;
 +
    }
 +
    slider.getTarget = function(dir) {
 +
      slider.direction = dir;
 +
      if (dir === "next") {
 +
        return (slider.currentSlide === slider.last) ? 0 : slider.currentSlide + 1;
 +
      } else {
 +
        return (slider.currentSlide === 0) ? slider.last : slider.currentSlide - 1;
 +
      }
 +
    }
 +
 
 +
    // SLIDE:
 +
    slider.setProps = function(pos, special, dur) {
 +
      var target = (function() {
 +
        var posCheck = (pos) ? pos : ((slider.itemW + slider.vars.itemMargin) * slider.move) * slider.animatingTo,
 +
            posCalc = (function() {
 +
              if (carousel) {
 +
                return (special === "setTouch") ? pos :
 +
                      (reverse && slider.animatingTo === slider.last) ? 0 :
 +
                      (reverse) ? slider.limit - (((slider.itemW + slider.vars.itemMargin) * slider.move) * slider.animatingTo) :
 +
                      (slider.animatingTo === slider.last) ? slider.limit : posCheck;
 +
              } else {
 +
                switch (special) {
 +
                  case "setTotal": return (reverse) ? ((slider.count - 1) - slider.currentSlide + slider.cloneOffset) * pos : (slider.currentSlide + slider.cloneOffset) * pos;
 +
                  case "setTouch": return (reverse) ? pos : pos;
 +
                  case "jumpEnd": return (reverse) ? pos : slider.count * pos;
 +
                  case "jumpStart": return (reverse) ? slider.count * pos : pos;
 +
                  default: return pos;
 +
                }
 +
              }
 +
            }());
 +
 
 +
            return (posCalc * -1) + "px";
 +
          }());
 +
 
 +
      if (slider.transitions) {
 +
        target = (vertical) ? "translate3d(0," + target + ",0)" : "translate3d(" + target + ",0,0)";
 +
        dur = (dur !== undefined) ? (dur/1000) + "s" : "0s";
 +
        slider.container.css("-" + slider.pfx + "-transition-duration", dur);
 +
      }
 +
 
 +
      slider.args[slider.prop] = target;
 +
      if (slider.transitions || dur === undefined) slider.container.css(slider.args);
 +
    }
 +
 
 +
    slider.setup = function(type) {
 +
      // SLIDE:
 +
      if (!fade) {
 +
        var sliderOffset, arr;
 +
 
 +
        if (type === "init") {
 +
          slider.viewport = $('<div class="' + namespace + 'viewport"></div>').css({"overflow": "hidden", "position": "relative"}).appendTo(slider).append(slider.container);
 +
          // INFINITE LOOP:
 +
          slider.cloneCount = 0;
 +
          slider.cloneOffset = 0;
 +
          // REVERSE:
 +
          if (reverse) {
 +
            arr = $.makeArray(slider.slides).reverse();
 +
            slider.slides = $(arr);
 +
            slider.container.empty().append(slider.slides);
 +
          }
 +
        }
 +
        // INFINITE LOOP && !CAROUSEL:
 +
        if (slider.vars.animationLoop && !carousel) {
 +
          slider.cloneCount = 2;
 +
          slider.cloneOffset = 1;
 +
          // clear out old clones
 +
          if (type !== "init") slider.container.find('.clone').remove();
 +
          slider.container.append(slider.slides.first().clone().addClass('clone').attr('aria-hidden', 'true')).prepend(slider.slides.last().clone().addClass('clone').attr('aria-hidden', 'true'));
 +
        }
 +
        slider.newSlides = $(slider.vars.selector, slider);
 +
 
 +
        sliderOffset = (reverse) ? slider.count - 1 - slider.currentSlide + slider.cloneOffset : slider.currentSlide + slider.cloneOffset;
 +
        // VERTICAL:
 +
        if (vertical && !carousel) {
 +
          slider.container.height((slider.count + slider.cloneCount) * 200 + "%").css("position", "absolute").width("100%");
 +
          setTimeout(function(){
 +
            slider.newSlides.css({"display": "block"});
 +
            slider.doMath();
 +
            slider.viewport.height(slider.h);
 +
            slider.setProps(sliderOffset * slider.h, "init");
 +
          }, (type === "init") ? 100 : 0);
 +
        } else {
 +
          slider.container.width((slider.count + slider.cloneCount) * 200 + "%");
 +
          slider.setProps(sliderOffset * slider.computedW, "init");
 +
          setTimeout(function(){
 +
            slider.doMath();
 +
            slider.newSlides.css({"width": slider.computedW, "float": "left", "display": "block"});
 +
            // SMOOTH HEIGHT:
 +
            if (slider.vars.smoothHeight) methods.smoothHeight();
 +
          }, (type === "init") ? 100 : 0);
 +
        }
 +
      } else { // FADE:
 +
        slider.slides.css({"width": "100%", "float": "left", "marginRight": "-100%", "position": "relative"});
 +
        if (type === "init") {
 +
          if (!touch) {
 +
            //slider.slides.eq(slider.currentSlide).fadeIn(slider.vars.animationSpeed, slider.vars.easing);
 +
            slider.slides.css({ "opacity": 0, "display": "block", "zIndex": 1 }).eq(slider.currentSlide).css({"zIndex": 2}).animate({"opacity": 1},slider.vars.animationSpeed,slider.vars.easing);
 +
          } else {
 +
            slider.slides.css({ "opacity": 0, "display": "block", "webkitTransition": "opacity " + slider.vars.animationSpeed / 1000 + "s ease", "zIndex": 1 }).eq(slider.currentSlide).css({ "opacity": 1, "zIndex": 2});
 +
          }
 +
        }
 +
        // SMOOTH HEIGHT:
 +
        if (slider.vars.smoothHeight) methods.smoothHeight();
 +
      }
 +
      // !CAROUSEL:
 +
      // CANDIDATE: active slide
 +
      if (!carousel) slider.slides.removeClass(namespace + "active-slide").eq(slider.currentSlide).addClass(namespace + "active-slide");
 +
    }
 +
 
 +
 
 +
    slider.doMath = function() {
 +
      var slide = slider.slides.first(),
 +
          slideMargin = slider.vars.itemMargin,
 +
          minItems = slider.vars.minItems,
 +
          maxItems = slider.vars.maxItems;
 +
 
 +
      slider.w = (slider.viewport===undefined) ? slider.width() : slider.viewport.width();
 +
      slider.h = slide.height();
 +
      slider.boxPadding = slide.outerWidth() - slide.width();
 +
 
 +
      // CAROUSEL:
 +
      if (carousel) {
 +
        slider.itemT = slider.vars.itemWidth + slideMargin;
 +
        slider.minW = (minItems) ? minItems * slider.itemT : slider.w;
 +
        slider.maxW = (maxItems) ? (maxItems * slider.itemT) - slideMargin : slider.w;
 +
        slider.itemW = (slider.minW > slider.w) ? (slider.w - (slideMargin * (minItems - 1)))/minItems :
 +
                      (slider.maxW < slider.w) ? (slider.w - (slideMargin * (maxItems - 1)))/maxItems :
 +
                      (slider.vars.itemWidth > slider.w) ? slider.w : slider.vars.itemWidth;
 +
 
 +
        slider.visible = Math.floor(slider.w/(slider.itemW));
 +
        slider.move = (slider.vars.move > 0 && slider.vars.move < slider.visible ) ? slider.vars.move : slider.visible;
 +
        slider.pagingCount = Math.ceil(((slider.count - slider.visible)/slider.move) + 1);
 +
        slider.last =  slider.pagingCount - 1;
 +
        slider.limit = (slider.pagingCount === 1) ? 0 :
 +
                      (slider.vars.itemWidth > slider.w) ? (slider.itemW * (slider.count - 1)) + (slideMargin * (slider.count - 1)) : ((slider.itemW + slideMargin) * slider.count) - slider.w - slideMargin;
 +
      } else {
 +
        slider.itemW = slider.w;
 +
        slider.pagingCount = slider.count;
 +
        slider.last = slider.count - 1;
 +
      }
 +
      slider.computedW = slider.itemW - slider.boxPadding;
 +
    }
 +
 
 +
 
 +
    slider.update = function(pos, action) {
 +
      slider.doMath();
 +
 
 +
      // update currentSlide and slider.animatingTo if necessary
 +
      if (!carousel) {
 +
        if (pos < slider.currentSlide) {
 +
          slider.currentSlide += 1;
 +
        } else if (pos <= slider.currentSlide && pos !== 0) {
 +
          slider.currentSlide -= 1;
 +
        }
 +
        slider.animatingTo = slider.currentSlide;
 +
      }
 +
 
 +
      // update controlNav
 +
      if (slider.vars.controlNav && !slider.manualControls) {
 +
        if ((action === "add" && !carousel) || slider.pagingCount > slider.controlNav.length) {
 +
          methods.controlNav.update("add");
 +
        } else if ((action === "remove" && !carousel) || slider.pagingCount < slider.controlNav.length) {
 +
          if (carousel && slider.currentSlide > slider.last) {
 +
            slider.currentSlide -= 1;
 +
            slider.animatingTo -= 1;
 +
          }
 +
          methods.controlNav.update("remove", slider.last);
 +
        }
 +
      }
 +
      // update directionNav
 +
      if (slider.vars.directionNav) methods.directionNav.update();
 +
 
 +
    }
 +
 
 +
    slider.addSlide = function(obj, pos) {
 +
      var $obj = $(obj);
 +
 
 +
      slider.count += 1;
 +
      slider.last = slider.count - 1;
 +
 
 +
      // append new slide
 +
      if (vertical && reverse) {
 +
        (pos !== undefined) ? slider.slides.eq(slider.count - pos).after($obj) : slider.container.prepend($obj);
 +
      } else {
 +
        (pos !== undefined) ? slider.slides.eq(pos).before($obj) : slider.container.append($obj);
 +
      }
 +
 
 +
      // update currentSlide, animatingTo, controlNav, and directionNav
 +
      slider.update(pos, "add");
 +
 
 +
      // update slider.slides
 +
      slider.slides = $(slider.vars.selector + ':not(.clone)', slider);
 +
      // re-setup the slider to accomdate new slide
 +
      slider.setup();
 +
 
 +
      //FlexSlider: added() Callback
 +
      slider.vars.added(slider);
 +
    }
 +
    slider.removeSlide = function(obj) {
 +
      var pos = (isNaN(obj)) ? slider.slides.index($(obj)) : obj;
 +
 
 +
      // update count
 +
      slider.count -= 1;
 +
      slider.last = slider.count - 1;
 +
 
 +
      // remove slide
 +
      if (isNaN(obj)) {
 +
        $(obj, slider.slides).remove();
 +
      } else {
 +
        (vertical && reverse) ? slider.slides.eq(slider.last).remove() : slider.slides.eq(obj).remove();
 +
      }
 +
 
 +
      // update currentSlide, animatingTo, controlNav, and directionNav
 +
      slider.doMath();
 +
      slider.update(pos, "remove");
 +
 
 +
      // update slider.slides
 +
      slider.slides = $(slider.vars.selector + ':not(.clone)', slider);
 +
      // re-setup the slider to accomdate new slide
 +
      slider.setup();
 +
 
 +
      // FlexSlider: removed() Callback
 +
      slider.vars.removed(slider);
 +
    }
 +
 
 +
    //FlexSlider: Initialize
 +
    methods.init();
 +
  }
 +
 
 +
  // Ensure the slider isn't focussed if the window loses focus.
 +
  $( window ).blur( function ( e ) {
 +
    focused = false;
 +
  }).focus( function ( e ) {
 +
    focused = true;
 +
  });
 +
 
 +
  //FlexSlider: Default Settings
 +
  $.flexslider.defaults = {
 +
    namespace: "flex-",            //{NEW} String: Prefix string attached to the class of every element generated by the plugin
 +
    selector: ".slides > li",      //{NEW} Selector: Must match a simple pattern. '{container} > {slide}' -- Ignore pattern at your own peril
 +
    animation: "fade",              //String: Select your animation type, "fade" or "slide"
 +
    easing: "swing",                //{NEW} String: Determines the easing method used in jQuery transitions. jQuery easing plugin is supported!
 +
    direction: "horizontal",        //String: Select the sliding direction, "horizontal" or "vertical"
 +
    reverse: false,                //{NEW} Boolean: Reverse the animation direction
 +
    animationLoop: true,            //Boolean: Should the animation loop? If false, directionNav will received "disable" classes at either end
 +
    smoothHeight: false,            //{NEW} Boolean: Allow height of the slider to animate smoothly in horizontal mode
 +
    startAt: 0,                    //Integer: The slide that the slider should start on. Array notation (0 = first slide)
 +
    slideshow: true,                //Boolean: Animate slider automatically
 +
    slideshowSpeed: 7000,          //Integer: Set the speed of the slideshow cycling, in milliseconds
 +
    animationSpeed: 600,            //Integer: Set the speed of animations, in milliseconds
 +
    initDelay: 0,                  //{NEW} Integer: Set an initialization delay, in milliseconds
 +
    randomize: false,              //Boolean: Randomize slide order
 +
    thumbCaptions: false,          //Boolean: Whether or not to put captions on thumbnails when using the "thumbnails" controlNav.
 +
 
 +
    // Usability features
 +
    pauseOnAction: true,            //Boolean: Pause the slideshow when interacting with control elements, highly recommended.
 +
    pauseOnHover: false,            //Boolean: Pause the slideshow when hovering over slider, then resume when no longer hovering
 +
    pauseInvisible: true,  //{NEW} Boolean: Pause the slideshow when tab is invisible, resume when visible. Provides better UX, lower CPU usage.
 +
    useCSS: true,                  //{NEW} Boolean: Slider will use CSS3 transitions if available
 +
    touch: true,                    //{NEW} Boolean: Allow touch swipe navigation of the slider on touch-enabled devices
 +
    video: false,                  //{NEW} Boolean: If using video in the slider, will prevent CSS3 3D Transforms to avoid graphical glitches
 +
 
 +
    // Primary Controls
 +
    controlNav: true,              //Boolean: Create navigation for paging control of each clide? Note: Leave true for manualControls usage
 +
    directionNav: true,            //Boolean: Create navigation for previous/next navigation? (true/false)
 +
    prevText: "Previous",          //String: Set the text for the "previous" directionNav item
 +
    nextText: "Next",              //String: Set the text for the "next" directionNav item
 +
 
 +
    // Secondary Navigation
 +
    keyboard: true,                //Boolean: Allow slider navigating via keyboard left/right keys
 +
    multipleKeyboard: false,        //{NEW} Boolean: Allow keyboard navigation to affect multiple sliders. Default behavior cuts out keyboard navigation with more than one slider present.
 +
    mousewheel: false,              //{UPDATED} Boolean: Requires jquery.mousewheel.js (https://github.com/brandonaaron/jquery-mousewheel) - Allows slider navigating via mousewheel
 +
    pausePlay: false,              //Boolean: Create pause/play dynamic element
 +
    pauseText: "Pause",            //String: Set the text for the "pause" pausePlay item
 +
    playText: "Play",              //String: Set the text for the "play" pausePlay item
 +
 
 +
    // Special properties
 +
    controlsContainer: "",          //{UPDATED} jQuery Object/Selector: Declare which container the navigation elements should be appended too. Default container is the FlexSlider element. Example use would be $(".flexslider-container"). Property is ignored if given element is not found.
 +
    manualControls: "",            //{UPDATED} jQuery Object/Selector: Declare custom control navigation. Examples would be $(".flex-control-nav li") or "#tabs-nav li img", etc. The number of elements in your controlNav should match the number of slides/tabs.
 +
    sync: "",                      //{NEW} Selector: Mirror the actions performed on this slider with another slider. Use with care.
 +
    asNavFor: "",                  //{NEW} Selector: Internal property exposed for turning the slider into a thumbnail navigation for another slider
 +
 
 +
    // Carousel Options
 +
    itemWidth: 0,                  //{NEW} Integer: Box-model width of individual carousel items, including horizontal borders and padding.
 +
    itemMargin: 0,                  //{NEW} Integer: Margin between carousel items.
 +
    minItems: 1,                    //{NEW} Integer: Minimum number of carousel items that should be visible. Items will resize fluidly when below this.
 +
    maxItems: 0,                    //{NEW} Integer: Maxmimum number of carousel items that should be visible. Items will resize fluidly when above this limit.
 +
    move: 0,                        //{NEW} Integer: Number of carousel items that should move on animation. If 0, slider will move all visible items.
 +
    allowOneSlide: true,          //{NEW} Boolean: Whether or not to allow a slider comprised of a single slide
 +
 
 +
    // Callback API
 +
    start: function(){},            //Callback: function(slider) - Fires when the slider loads the first slide
 +
    before: function(){},          //Callback: function(slider) - Fires asynchronously with each slider animation
 +
    after: function(){},            //Callback: function(slider) - Fires after each slider animation completes
 +
    end: function(){},              //Callback: function(slider) - Fires when the slider reaches the last slide (asynchronous)
 +
    added: function(){},            //{NEW} Callback: function(slider) - Fires after a slide is added
 +
    removed: function(){}          //{NEW} Callback: function(slider) - Fires after a slide is removed
 +
  }
 +
 
 +
 
 +
  //FlexSlider: Plugin Function
 +
  $.fn.flexslider = function(options) {
 +
    if (options === undefined) options = {};
 +
 
 +
    if (typeof options === "object") {
 +
      return this.each(function() {
 +
        var $this = $(this),
 +
            selector = (options.selector) ? options.selector : ".slides > li",
 +
            $slides = $this.find(selector);
 +
 
 +
      if ( ( $slides.length === 1 && options.allowOneSlide === true ) || $slides.length === 0 ) {
 +
          $slides.fadeIn(400);
 +
          if (options.start) options.start($this);
 +
        } else if ($this.data('flexslider') === undefined) {
 +
          new $.flexslider(this, options);
 +
        }
 +
      });
 +
    } else {
 +
      // Helper strings to quickly perform functions on the slider
 +
      var $slider = $(this).data('flexslider');
 +
      switch (options) {
 +
        case "play": $slider.play(); break;
 +
        case "pause": $slider.pause(); break;
 +
        case "stop": $slider.stop(); break;
 +
        case "next": $slider.flexAnimate($slider.getTarget("next"), true); break;
 +
        case "prev":
 +
        case "previous": $slider.flexAnimate($slider.getTarget("prev"), true); break;
 +
        default: if (typeof options === "number") $slider.flexAnimate(options, true);
 +
      }
 +
    }
 +
  }
 +
})(jQuery);
 +
 
 +
 
 +
 
 +
 
 +
 
 +
 
 +
 
 +
/*!
 +
* jquery.lightbox.js
 +
* https://github.com/duncanmcdougall/Responsive-Lightbox
 +
* Copyright 2013 Duncan McDougall and other contributors; @license Creative Commons Attribution 2.5
 +
*
 +
* Options:
 +
* margin - int - default 50. Minimum margin around the image
 +
* nav - bool - default true. enable navigation
 +
* blur - bool - default true. Blur other content when open using css filter
 +
* minSize - int - default 0. Min window width or height to open lightbox. Below threshold will open image in a new tab.
 +
*
 +
*/
 +
(function ($) {
 +
 
 +
    'use strict';
 +
 
 +
    $.fn.lightbox = function (options) {
 +
 
 +
        var opts = {
 +
            margin: 50,
 +
            nav: true,
 +
            blur: true,
 +
            minSize: 0
 +
        };
 +
 
 +
        var plugin = {
 +
 
 +
            items: [],
 +
            lightbox: null,
 +
            image: null,
 +
            current: null,
 +
            locked: false,
 +
            caption: null,
 +
     
 +
            init: function (items) {
 +
                plugin.items = items;
 +
        plugin.selector = "lightbox-"+Math.random().toString().replace('.','');
 +
 
 +
                if (!plugin.lightbox) {
 +
                    $('body').append(
 +
                      '<div id="lightbox" style="display:none;">'+
 +
                      '<a href="#" class="lightbox-close lightbox-button"></a>' +
 +
                      '<div class="lightbox-nav">'+
 +
                      '<a href="#" class="lightbox-previous lightbox-button"></a>' +
 +
                      '<a href="#" class="lightbox-next lightbox-button"></a>' +
 +
                      '</div>' +
 +
                      '<div href="#" class="lightbox-caption"><p></p></div>' +
 +
                      '</div>'
 +
                    );
 +
 
 +
                    plugin.lightbox = $("#lightbox");
 +
                    plugin.caption = $('.lightbox-caption', plugin.lightbox);
 +
                }
 +
 
 +
                if (plugin.items.length > 1 && opts.nav) {
 +
                    $('.lightbox-nav', plugin.lightbox).show();
 +
                } else {
 +
                    $('.lightbox-nav', plugin.lightbox).hide();
 +
                }
 +
 
 +
                plugin.bindEvents();
 +
 
 +
            },
 +
 
 +
            loadImage: function () {
 +
                if(opts.blur) {
 +
                    $("body").addClass("blurred");
 +
                }
 +
                $("img", plugin.lightbox).remove();
 +
                plugin.lightbox.fadeIn('fast').append('<span class="lightbox-loading"></span>');
 +
 
 +
                var img = $('<img src="' + $(plugin.current).attr('href') + '" draggable="false">');
 +
 
 +
                $(img).load(function () {
 +
                    $('.lightbox-loading').remove();
 +
                    plugin.lightbox.append(img);
 +
                    plugin.image = $("img", plugin.lightbox).hide();
 +
                    plugin.resizeImage();
 +
                    plugin.setCaption();
 +
                });
 +
            },
 +
 
 +
            setCaption: function () {
 +
                var caption = $(plugin.current).data('caption');
 +
                if(!!caption && caption.length > 0) {
 +
                    plugin.caption.fadeIn();
 +
                    $('p', plugin.caption).text(caption);
 +
                }else{
 +
                    plugin.caption.hide();
 +
                }
 +
            },
 +
 
 +
            resizeImage: function () {
 +
                var ratio, wHeight, wWidth, iHeight, iWidth;
 +
                wHeight = $(window).height() - opts.margin;
 +
                wWidth = $(window).outerWidth(true) - opts.margin;
 +
                plugin.image.width('').height('');
 +
                iHeight = plugin.image.height();
 +
                iWidth = plugin.image.width();
 +
                if (iWidth > wWidth) {
 +
                    ratio = wWidth / iWidth;
 +
                    iWidth = wWidth;
 +
                    iHeight = Math.round(iHeight * ratio);
 +
                }
 +
                if (iHeight > wHeight) {
 +
                    ratio = wHeight / iHeight;
 +
                    iHeight = wHeight;
 +
                    iWidth = Math.round(iWidth * ratio);
 +
                }
 +
 
 +
                plugin.image.width(iWidth).height(iHeight).css({
 +
            'top': ($(window).height() - plugin.image.outerHeight()) / 2 + 'px',
 +
            'left': ($(window).width() - plugin.image.outerWidth()) / 2 + 'px'
 +
          }).show();
 +
                plugin.locked = false;
 +
            },
 +
 
 +
            getCurrentIndex: function () {
 +
                return $.inArray(plugin.current, plugin.items);
 +
            },
 +
 
 +
            next: function () {
 +
                if (plugin.locked) {
 +
                    return false;
 +
                }
 +
                plugin.locked = true;
 +
                if (plugin.getCurrentIndex() >= plugin.items.length - 1) {
 +
                    $(plugin.items[0]).click();
 +
                } else {
 +
                    $(plugin.items[plugin.getCurrentIndex() + 1]).click();
 +
                }
 +
            },
 +
 
 +
            previous: function () {
 +
                if (plugin.locked) {
 +
                    return false;
 +
                }
 +
                plugin.locked = true;
 +
                if (plugin.getCurrentIndex() <= 0) {
 +
                    $(plugin.items[plugin.items.length - 1]).click();
 +
                } else {
 +
                    $(plugin.items[plugin.getCurrentIndex() - 1]).click();
 +
                }
 +
            },
 +
 
 +
            bindEvents: function () {
 +
                $(plugin.items).click(function (e) {
 +
                    if(!$("#lightbox").is(":visible") && ($(window).width() < opts.minSize || $(window).height() < opts.minSize)) {
 +
                        $(this).attr("target", "_blank");
 +
                        return;
 +
                    }
 +
                    var self = $(this)[0];
 +
                    e.preventDefault();
 +
                    plugin.current = self;
 +
                    plugin.loadImage();
 +
 
 +
                    // Bind Keyboard Shortcuts
 +
                    $(document).on('keydown', function (e) {
 +
                        // Close lightbox with ESC
 +
                        if (e.keyCode === 27) {
 +
                            plugin.close();
 +
                        }
 +
                        // Go to next image pressing the right key
 +
                        if (e.keyCode === 39) {
 +
                            plugin.next();
 +
                        }
 +
                        // Go to previous image pressing the left key
 +
                        if (e.keyCode === 37) {
 +
                            plugin.previous();
 +
                        }
 +
                    });
 +
                });
 +
 
 +
                // Add click state on overlay background only
 +
                plugin.lightbox.on('click', function (e) {
 +
                    if (this === e.target) {
 +
                        plugin.close();
 +
                    }
 +
                });
 +
 
 +
                // Previous click
 +
                $(plugin.lightbox).on('click', '.lightbox-previous', function () {
 +
                    plugin.previous();
 +
                    return false;
 +
                });
 +
 
 +
                // Next click
 +
                $(plugin.lightbox).on('click', '.lightbox-next', function () {
 +
                    plugin.next();
 +
                    return false;
 +
                });
 +
 
 +
                // Close click
 +
                $(plugin.lightbox).on('click', '.lightbox-close', function () {
 +
                    plugin.close();
 +
                    return false;
 +
                });
 +
 
 +
                $(window).resize(function () {
 +
                    if (!plugin.image) {
 +
                        return;
 +
                    }
 +
                    plugin.resizeImage();
 +
                });
 +
            },
 +
 
 +
            close: function () {
 +
                $(document).off('keydown'); // Unbind all key events each time the lightbox is closed
 +
                $(plugin.lightbox).fadeOut('fast');
 +
                $('body').removeClass('blurred');
 +
            }
 +
        };
 +
 
 +
        $.extend(opts, options);
 +
 
 +
        plugin.init(this);
 +
    };
 +
 
 +
})(jQuery);!function(e){"use strict";var t=function(){var t={bcClass:"sf-breadcrumb",menuClass:"sf-js-enabled",anchorClass:"sf-with-ul",menuArrowClass:"sf-arrows"},i=function(){var t=/iPhone|iPad|iPod/i.test(navigator.userAgent);return t&&e(window).load(function(){e("body").children().on("click",e.noop)}),t}(),n=function(){var e=document.documentElement.style;return"behavior"in e&&"fill"in e&&/iemobile/i.test(navigator.userAgent)}(),s=function(e,i){var n=t.menuClass;i.cssArrows&&(n+=" "+t.menuArrowClass),e.toggleClass(n)},o=function(i,n){return i.find("li."+n.pathClass).slice(0,n.pathLevels).addClass(n.hoverClass+" "+t.bcClass).filter(function(){return e(this).children(n.popUpSelector).hide().show().length}).removeClass(n.pathClass)},a=function(e){e.children("a").toggleClass(t.anchorClass)},r=function(e){var t=e.css("ms-touch-action");t="pan-y"===t?"auto":"pan-y",e.css("ms-touch-action",t)},l=function(t,s){var o="li:has("+s.popUpSelector+")";e.fn.hoverIntent&&!s.disableHI?t.hoverIntent(c,p,o):t.on("mouseenter.superfish",o,c).on("mouseleave.superfish",o,p);var a="MSPointerDown.superfish";i||(a+=" touchend.superfish"),n&&(a+=" mousedown.superfish"),t.on("focusin.superfish","li",c).on("focusout.superfish","li",p).on(a,"a",s,d)},d=function(t){var i=e(this),n=i.siblings(t.data.popUpSelector);n.length>0&&n.is(":hidden")&&(i.one("click.superfish",!1),"MSPointerDown"===t.type?i.trigger("focus"):e.proxy(c,i.parent("li"))())},c=function(){var t=e(this),i=f(t);clearTimeout(i.sfTimer),t.siblings().superfish("hide").end().superfish("show")},p=function(){var t=e(this),n=f(t);i?e.proxy(u,t,n)():(clearTimeout(n.sfTimer),n.sfTimer=setTimeout(e.proxy(u,t,n),n.delay))},u=function(t){t.retainPath=e.inArray(this[0],t.$path)>-1,this.superfish("hide"),this.parents("."+t.hoverClass).length||(t.onIdle.call(h(this)),t.$path.length&&e.proxy(c,t.$path)())},h=function(e){return e.closest("."+t.menuClass)},f=function(e){return h(e).data("sf-options")};return{hide:function(t){if(this.length){var i=this,n=f(i);if(!n)return this;var s=n.retainPath===!0?n.$path:"",o=i.find("li."+n.hoverClass).add(this).not(s).removeClass(n.hoverClass).children(n.popUpSelector),a=n.speedOut;t&&(o.show(),a=0),n.retainPath=!1,n.onBeforeHide.call(o),o.stop(!0,!0).animate(n.animationOut,a,function(){var t=e(this);n.onHide.call(t)})}return this},show:function(){var e=f(this);if(!e)return this;var t=this.addClass(e.hoverClass),i=t.children(e.popUpSelector);return e.onBeforeShow.call(i),i.stop(!0,!0).animate(e.animation,e.speed,function(){e.onShow.call(i)}),this},destroy:function(){return this.each(function(){var i,n=e(this),o=n.data("sf-options");return o?(i=n.find(o.popUpSelector).parent("li"),clearTimeout(o.sfTimer),s(n,o),a(i),r(n),n.off(".superfish").off(".hoverIntent"),i.children(o.popUpSelector).attr("style",function(e,t){return t.replace(/display[^;]+;?/g,"")}),o.$path.removeClass(o.hoverClass+" "+t.bcClass).addClass(o.pathClass),n.find("."+o.hoverClass).removeClass(o.hoverClass),o.onDestroy.call(n),n.removeData("sf-options"),void 0):!1})},init:function(i){return this.each(function(){var n=e(this);if(n.data("sf-options"))return!1;var d=e.extend({},e.fn.superfish.defaults,i),c=n.find(d.popUpSelector).parent("li");d.$path=o(n,d),n.data("sf-options",d),s(n,d),a(c),r(n),l(n,d),c.not("."+t.bcClass).superfish("hide",!0),d.onInit.call(this)})}}}();e.fn.superfish=function(i){return t[i]?t[i].apply(this,Array.prototype.slice.call(arguments,1)):"object"!=typeof i&&i?e.error("Method "+i+" does not exist on jQuery.fn.superfish"):t.init.apply(this,arguments)},e.fn.superfish.defaults={popUpSelector:"ul,.sf-mega",hoverClass:"sfHover",pathClass:"overrideThisToUse",pathLevels:1,delay:800,animation:{opacity:"show"},animationOut:{opacity:"hide"},speed:"normal",speedOut:"fast",cssArrows:!0,disableHI:!1,onInit:e.noop,onBeforeShow:e.noop,onShow:e.noop,onBeforeHide:e.noop,onHide:e.noop,onIdle:e.noop,onDestroy:e.noop},e.fn.extend({hideSuperfishUl:t.hide,showSuperfishUl:t.show})}(jQuery);var Swiper=function(e,t){"use strict";function i(e,t){return document.querySelectorAll?(t||document).querySelectorAll(e):jQuery(e,t)}function n(e){return"[object Array]"===Object.prototype.toString.apply(e)?!0:!1}function s(){var e=A-D;return t.freeMode&&(e=A-D),t.slidesPerView>_.slides.length&&!t.centeredSlides&&(e=0),0>e&&(e=0),e}function o(){function e(e){var i=new Image;i.onload=function(){_&&void 0!==_.imagesLoaded&&_.imagesLoaded++,_.imagesLoaded===_.imagesToLoad.length&&(_.reInit(),t.onImagesReady&&_.fireCallback(t.onImagesReady,_))},i.src=e}var n=_.h.addEventListener,s="wrapper"===t.eventTarget?_.wrapper:_.container;if(_.browser.ie10||_.browser.ie11?(n(s,_.touchEvents.touchStart,g),n(document,_.touchEvents.touchMove,m),n(document,_.touchEvents.touchEnd,v)):(_.support.touch&&(n(s,"touchstart",g),n(s,"touchmove",m),n(s,"touchend",v)),t.simulateTouch&&(n(s,"mousedown",g),n(document,"mousemove",m),n(document,"mouseup",v))),t.autoResize&&n(window,"resize",_.resizeFix),a(),_._wheelEvent=!1,t.mousewheelControl){if(void 0!==document.onmousewheel&&(_._wheelEvent="mousewheel"),!_._wheelEvent)try{new WheelEvent("wheel"),_._wheelEvent="wheel"}catch(o){}_._wheelEvent||(_._wheelEvent="DOMMouseScroll"),_._wheelEvent&&n(_.container,_._wheelEvent,d)}if(t.keyboardControl&&n(document,"keydown",l),t.updateOnImagesReady){_.imagesToLoad=i("img",_.container);for(var r=0;r<_.imagesToLoad.length;r++)e(_.imagesToLoad[r].getAttribute("src"))}}function a(){var e,n=_.h.addEventListener;if(t.preventLinks){var s=i("a",_.container);for(e=0;e<s.length;e++)n(s[e],"click",h)}if(t.releaseFormElements){var o=i("input, textarea, select",_.container);for(e=0;e<o.length;e++)n(o[e],_.touchEvents.touchStart,f,!0)}if(t.onSlideClick)for(e=0;e<_.slides.length;e++)n(_.slides[e],"click",c);if(t.onSlideTouch)for(e=0;e<_.slides.length;e++)n(_.slides[e],_.touchEvents.touchStart,p)}function r(){var e,n=_.h.removeEventListener;if(t.onSlideClick)for(e=0;e<_.slides.length;e++)n(_.slides[e],"click",c);if(t.onSlideTouch)for(e=0;e<_.slides.length;e++)n(_.slides[e],_.touchEvents.touchStart,p);if(t.releaseFormElements){var s=i("input, textarea, select",_.container);for(e=0;e<s.length;e++)n(s[e],_.touchEvents.touchStart,f,!0)}if(t.preventLinks){var o=i("a",_.container);for(e=0;e<o.length;e++)n(o[e],"click",h)}}function l(e){var t=e.keyCode||e.charCode;if(!(e.shiftKey||e.altKey||e.ctrlKey||e.metaKey)){if(37===t||39===t||38===t||40===t){for(var i=!1,n=_.h.getOffset(_.container),s=_.h.windowScroll().left,o=_.h.windowScroll().top,a=_.h.windowWidth(),r=_.h.windowHeight(),l=[[n.left,n.top],[n.left+_.width,n.top],[n.left,n.top+_.height],[n.left+_.width,n.top+_.height]],d=0;d<l.length;d++){var c=l[d];c[0]>=s&&c[0]<=s+a&&c[1]>=o&&c[1]<=o+r&&(i=!0)}if(!i)return}W?((37===t||39===t)&&(e.preventDefault?e.preventDefault():e.returnValue=!1),39===t&&_.swipeNext(),37===t&&_.swipePrev()):((38===t||40===t)&&(e.preventDefault?e.preventDefault():e.returnValue=!1),40===t&&_.swipeNext(),38===t&&_.swipePrev())}}function d(e){var i=_._wheelEvent,n=0;if(e.detail)n=-e.detail;else if("mousewheel"===i)if(t.mousewheelControlForceToAxis)if(W){if(!(Math.abs(e.wheelDeltaX)>Math.abs(e.wheelDeltaY)))return;n=e.wheelDeltaX}else{if(!(Math.abs(e.wheelDeltaY)>Math.abs(e.wheelDeltaX)))return;n=e.wheelDeltaY}else n=e.wheelDelta;else if("DOMMouseScroll"===i)n=-e.detail;else if("wheel"===i)if(t.mousewheelControlForceToAxis)if(W){if(!(Math.abs(e.deltaX)>Math.abs(e.deltaY)))return;n=-e.deltaX}else{if(!(Math.abs(e.deltaY)>Math.abs(e.deltaX)))return;n=-e.deltaY}else n=Math.abs(e.deltaX)>Math.abs(e.deltaY)?-e.deltaX:-e.deltaY;if(t.freeMode){var o=_.getWrapperTranslate()+n;if(o>0&&(o=0),o<-s()&&(o=-s()),_.setWrapperTransition(0),_.setWrapperTranslate(o),_.updateActiveSlide(o),0===o||o===-s())return}else(new Date).getTime()-Y>60&&(0>n?_.swipeNext():_.swipePrev()),Y=(new Date).getTime();return t.autoplay&&_.stopAutoplay(!0),e.preventDefault?e.preventDefault():e.returnValue=!1,!1}function c(e){_.allowSlideClick&&(u(e),_.fireCallback(t.onSlideClick,_,e))}function p(e){u(e),_.fireCallback(t.onSlideTouch,_,e)}function u(e){if(e.currentTarget)_.clickedSlide=e.currentTarget;else{var i=e.srcElement;do{if(i.className.indexOf(t.slideClass)>-1)break;i=i.parentNode}while(i);_.clickedSlide=i}_.clickedSlideIndex=_.slides.indexOf(_.clickedSlide),_.clickedSlideLoopIndex=_.clickedSlideIndex-(_.loopedSlides||0)}function h(e){return _.allowLinks?void 0:(e.preventDefault?e.preventDefault():e.returnValue=!1,t.preventLinksPropagation&&"stopPropagation"in e&&e.stopPropagation(),!1)}function f(e){return e.stopPropagation?e.stopPropagation():e.returnValue=!1,!1}function g(e){if(t.preventLinks&&(_.allowLinks=!0),_.isTouched||t.onlyExternal)return!1;if(t.noSwiping&&(e.target||e.srcElement)&&y(e.target||e.srcElement))return!1;if(Z=!1,_.isTouched=!0,K="touchstart"===e.type,!K||1===e.targetTouches.length){_.callPlugins("onTouchStartBegin"),K||_.isAndroid||(e.preventDefault?e.preventDefault():e.returnValue=!1);var i=K?e.targetTouches[0].pageX:e.pageX||e.clientX,n=K?e.targetTouches[0].pageY:e.pageY||e.clientY;_.touches.startX=_.touches.currentX=i,_.touches.startY=_.touches.currentY=n,_.touches.start=_.touches.current=W?i:n,_.setWrapperTransition(0),_.positions.start=_.positions.current=_.getWrapperTranslate(),_.setWrapperTranslate(_.positions.start),_.times.start=(new Date).getTime(),I=void 0,t.moveStartThreshold>0&&(q=!1),t.onTouchStart&&_.fireCallback(t.onTouchStart,_,e),_.callPlugins("onTouchStartEnd")}}function m(e){if(_.isTouched&&!t.onlyExternal&&(!K||"mousemove"!==e.type)){var i=K?e.targetTouches[0].pageX:e.pageX||e.clientX,n=K?e.targetTouches[0].pageY:e.pageY||e.clientY;if("undefined"==typeof I&&W&&(I=!!(I||Math.abs(n-_.touches.startY)>Math.abs(i-_.touches.startX))),"undefined"!=typeof I||W||(I=!!(I||Math.abs(n-_.touches.startY)<Math.abs(i-_.touches.startX))),I)return _.isTouched=!1,void 0;if(e.assignedToSwiper)return _.isTouched=!1,void 0;if(e.assignedToSwiper=!0,t.preventLinks&&(_.allowLinks=!1),t.onSlideClick&&(_.allowSlideClick=!1),t.autoplay&&_.stopAutoplay(!0),!K||1===e.touches.length){if(_.isMoved||(_.callPlugins("onTouchMoveStart"),t.loop&&(_.fixLoop(),_.positions.start=_.getWrapperTranslate()),t.onTouchMoveStart&&_.fireCallback(t.onTouchMoveStart,_)),_.isMoved=!0,e.preventDefault?e.preventDefault():e.returnValue=!1,_.touches.current=W?i:n,_.positions.current=(_.touches.current-_.touches.start)*t.touchRatio+_.positions.start,_.positions.current>0&&t.onResistanceBefore&&_.fireCallback(t.onResistanceBefore,_,_.positions.current),_.positions.current<-s()&&t.onResistanceAfter&&_.fireCallback(t.onResistanceAfter,_,Math.abs(_.positions.current+s())),t.resistance&&"100%"!==t.resistance){var o;if(_.positions.current>0&&(o=1-_.positions.current/D/2,_.positions.current=.5>o?D/2:_.positions.current*o),_.positions.current<-s()){var a=(_.touches.current-_.touches.start)*t.touchRatio+(s()+_.positions.start);o=(D+a)/D;var r=_.positions.current-a*(1-o)/2,l=-s()-D/2;_.positions.current=l>r||0>=o?l:r}}if(t.resistance&&"100%"===t.resistance&&(_.positions.current>0&&(!t.freeMode||t.freeModeFluid)&&(_.positions.current=0),_.positions.current<-s()&&(!t.freeMode||t.freeModeFluid)&&(_.positions.current=-s())),!t.followFinger)return;if(t.moveStartThreshold)if(Math.abs(_.touches.current-_.touches.start)>t.moveStartThreshold||q){if(!q)return q=!0,_.touches.start=_.touches.current,void 0;_.setWrapperTranslate(_.positions.current)}else _.positions.current=_.positions.start;else _.setWrapperTranslate(_.positions.current);return(t.freeMode||t.watchActiveIndex)&&_.updateActiveSlide(_.positions.current),t.grabCursor&&(_.container.style.cursor="move",_.container.style.cursor="grabbing",_.container.style.cursor="-moz-grabbin",_.container.style.cursor="-webkit-grabbing"),Q||(Q=_.touches.current),U||(U=(new Date).getTime()),_.velocity=(_.touches.current-Q)/((new Date).getTime()-U)/2,Math.abs(_.touches.current-Q)<2&&(_.velocity=0),Q=_.touches.current,U=(new Date).getTime(),_.callPlugins("onTouchMoveEnd"),t.onTouchMove&&_.fireCallback(t.onTouchMove,_,e),!1}}}function v(e){if(I&&_.swipeReset(),!t.onlyExternal&&_.isTouched){_.isTouched=!1,t.grabCursor&&(_.container.style.cursor="move",_.container.style.cursor="grab",_.container.style.cursor="-moz-grab",_.container.style.cursor="-webkit-grab"),_.positions.current||0===_.positions.current||(_.positions.current=_.positions.start),t.followFinger&&_.setWrapperTranslate(_.positions.current),_.times.end=(new Date).getTime(),_.touches.diff=_.touches.current-_.touches.start,_.touches.abs=Math.abs(_.touches.diff),_.positions.diff=_.positions.current-_.positions.start,_.positions.abs=Math.abs(_.positions.diff);var i=_.positions.diff,n=_.positions.abs,o=_.times.end-_.times.start;5>n&&300>o&&_.allowLinks===!1&&(t.freeMode||0===n||_.swipeReset(),t.preventLinks&&(_.allowLinks=!0),t.onSlideClick&&(_.allowSlideClick=!0)),setTimeout(function(){t.preventLinks&&(_.allowLinks=!0),t.onSlideClick&&(_.allowSlideClick=!0)},100);var a=s();if(!_.isMoved&&t.freeMode)return _.isMoved=!1,t.onTouchEnd&&_.fireCallback(t.onTouchEnd,_,e),_.callPlugins("onTouchEnd"),void 0;if(!_.isMoved||_.positions.current>0||_.positions.current<-a)return _.swipeReset(),t.onTouchEnd&&_.fireCallback(t.onTouchEnd,_,e),_.callPlugins("onTouchEnd"),void 0;if(_.isMoved=!1,t.freeMode){if(t.freeModeFluid){var r,l=1e3*t.momentumRatio,d=_.velocity*l,c=_.positions.current+d,p=!1,u=20*Math.abs(_.velocity)*t.momentumBounceRatio;-a>c&&(t.momentumBounce&&_.support.transitions?(-u>c+a&&(c=-a-u),r=-a,p=!0,Z=!0):c=-a),c>0&&(t.momentumBounce&&_.support.transitions?(c>u&&(c=u),r=0,p=!0,Z=!0):c=0),0!==_.velocity&&(l=Math.abs((c-_.positions.current)/_.velocity)),_.setWrapperTranslate(c),_.setWrapperTransition(l),t.momentumBounce&&p&&_.wrapperTransitionEnd(function(){Z&&(t.onMomentumBounce&&_.fireCallback(t.onMomentumBounce,_),_.callPlugins("onMomentumBounce"),_.setWrapperTranslate(r),_.setWrapperTransition(300))}),_.updateActiveSlide(c)}return(!t.freeModeFluid||o>=300)&&_.updateActiveSlide(_.positions.current),t.onTouchEnd&&_.fireCallback(t.onTouchEnd,_,e),_.callPlugins("onTouchEnd"),void 0}O=0>i?"toNext":"toPrev","toNext"===O&&300>=o&&(30>n||!t.shortSwipes?_.swipeReset():_.swipeNext(!0)),"toPrev"===O&&300>=o&&(30>n||!t.shortSwipes?_.swipeReset():_.swipePrev(!0));var h=0;if("auto"===t.slidesPerView){for(var f,g=Math.abs(_.getWrapperTranslate()),m=0,v=0;v<_.slides.length;v++)if(f=W?_.slides[v].getWidth(!0,t.roundLengths):_.slides[v].getHeight(!0,t.roundLengths),m+=f,m>g){h=f;break}h>D&&(h=D)}else h=P*t.slidesPerView;"toNext"===O&&o>300&&(n>=h*t.longSwipesRatio?_.swipeNext(!0):_.swipeReset()),"toPrev"===O&&o>300&&(n>=h*t.longSwipesRatio?_.swipePrev(!0):_.swipeReset()),t.onTouchEnd&&_.fireCallback(t.onTouchEnd,_,e),_.callPlugins("onTouchEnd")}}function y(e){var i=!1;do e.className.indexOf(t.noSwipingClass)>-1&&(i=!0),e=e.parentElement;while(!i&&e.parentElement&&-1===e.className.indexOf(t.wrapperClass));return!i&&e.className.indexOf(t.wrapperClass)>-1&&e.className.indexOf(t.noSwipingClass)>-1&&(i=!0),i}function w(e,t){var i,n=document.createElement("div");return n.innerHTML=t,i=n.firstChild,i.className+=" "+e,i.outerHTML}function x(e,i,n){function s(){var o=+new Date,p=o-a;r+=l*p/(1e3/60),c="toNext"===d?r>e:e>r,c?(_.setWrapperTranslate(Math.round(r)),_._DOMAnimating=!0,window.setTimeout(function(){s()},1e3/60)):(t.onSlideChangeEnd&&("to"===i?n.runCallbacks===!0&&_.fireCallback(t.onSlideChangeEnd,_):_.fireCallback(t.onSlideChangeEnd,_)),_.setWrapperTranslate(e),_._DOMAnimating=!1)}var o="to"===i&&n.speed>=0?n.speed:t.speed,a=+new Date;if(_.support.transitions||!t.DOMAnimation)_.setWrapperTranslate(e),_.setWrapperTransition(o);else{var r=_.getWrapperTranslate(),l=Math.ceil((e-r)/o*(1e3/60)),d=r>e?"toNext":"toPrev",c="toNext"===d?r>e:e>r;if(_._DOMAnimating)return;s()}_.updateActiveSlide(e),t.onSlideNext&&"next"===i&&_.fireCallback(t.onSlideNext,_,e),t.onSlidePrev&&"prev"===i&&_.fireCallback(t.onSlidePrev,_,e),t.onSlideReset&&"reset"===i&&_.fireCallback(t.onSlideReset,_,e),("next"===i||"prev"===i||"to"===i&&n.runCallbacks===!0)&&b(i)}function b(e){if(_.callPlugins("onSlideChangeStart"),t.onSlideChangeStart)if(t.queueStartCallbacks&&_.support.transitions){if(_._queueStartCallbacks)return;_._queueStartCallbacks=!0,_.fireCallback(t.onSlideChangeStart,_,e),_.wrapperTransitionEnd(function(){_._queueStartCallbacks=!1})}else _.fireCallback(t.onSlideChangeStart,_,e);if(t.onSlideChangeEnd)if(_.support.transitions)if(t.queueEndCallbacks){if(_._queueEndCallbacks)return;_._queueEndCallbacks=!0,_.wrapperTransitionEnd(function(i){_.fireCallback(t.onSlideChangeEnd,i,e)})}else _.wrapperTransitionEnd(function(i){_.fireCallback(t.onSlideChangeEnd,i,e)});else t.DOMAnimation||setTimeout(function(){_.fireCallback(t.onSlideChangeEnd,_,e)},10)}function S(){var e=_.paginationButtons;if(e)for(var t=0;t<e.length;t++)_.h.removeEventListener(e[t],"click",T)}function C(){var e=_.paginationButtons;if(e)for(var t=0;t<e.length;t++)_.h.addEventListener(e[t],"click",T)}function T(e){for(var t,i=e.target||e.srcElement,n=_.paginationButtons,s=0;s<n.length;s++)i===n[s]&&(t=s);_.swipeTo(t)}function k(){J=setTimeout(function(){t.loop?(_.fixLoop(),_.swipeNext(!0)):_.swipeNext(!0)||(t.autoplayStopOnLast?(clearTimeout(J),J=void 0):_.swipeTo(0)),_.wrapperTransitionEnd(function(){"undefined"!=typeof J&&k()})},t.autoplay)}function M(){_.calcSlides(),t.loader.slides.length>0&&0===_.slides.length&&_.loadSlides(),t.loop&&_.createLoop(),_.init(),o(),t.pagination&&_.createPagination(!0),t.loop||t.initialSlide>0?_.swipeTo(t.initialSlide,0,!1):_.updateActiveSlide(0),t.autoplay&&_.startAutoplay(),_.centerIndex=_.activeIndex,t.onSwiperCreated&&_.fireCallback(t.onSwiperCreated,_),_.callPlugins("onSwiperCreated")}if(document.body.__defineGetter__&&HTMLElement){var L=HTMLElement.prototype;L.__defineGetter__&&L.__defineGetter__("outerHTML",function(){return(new XMLSerializer).serializeToString(this)})}if(window.getComputedStyle||(window.getComputedStyle=function(e){return this.el=e,this.getPropertyValue=function(t){var i=/(\-([a-z]){1})/g;return"float"===t&&(t="styleFloat"),i.test(t)&&(t=t.replace(i,function(){return arguments[2].toUpperCase()})),e.currentStyle[t]?e.currentStyle[t]:null},this}),Array.prototype.indexOf||(Array.prototype.indexOf=function(e,t){for(var i=t||0,n=this.length;n>i;i++)if(this[i]===e)return i;return-1}),(document.querySelectorAll||window.jQuery)&&"undefined"!=typeof e&&(e.nodeType||0!==i(e).length)){var _=this;_.touches={start:0,startX:0,startY:0,current:0,currentX:0,currentY:0,diff:0,abs:0},_.positions={start:0,abs:0,diff:0,current:0},_.times={start:0,end:0},_.id=(new Date).getTime(),_.container=e.nodeType?e:i(e)[0],_.isTouched=!1,_.isMoved=!1,_.activeIndex=0,_.centerIndex=0,_.activeLoaderIndex=0,_.activeLoopIndex=0,_.previousIndex=null,_.velocity=0,_.snapGrid=[],_.slidesGrid=[],_.imagesToLoad=[],_.imagesLoaded=0,_.wrapperLeft=0,_.wrapperRight=0,_.wrapperTop=0,_.wrapperBottom=0,_.isAndroid=navigator.userAgent.toLowerCase().indexOf("android")>=0;var E,P,A,O,I,D,z={eventTarget:"wrapper",mode:"horizontal",touchRatio:1,speed:300,freeMode:!1,freeModeFluid:!1,momentumRatio:1,momentumBounce:!0,momentumBounceRatio:1,slidesPerView:1,slidesPerGroup:1,slidesPerViewFit:!0,simulateTouch:!0,followFinger:!0,shortSwipes:!0,longSwipesRatio:.5,moveStartThreshold:!1,onlyExternal:!1,createPagination:!0,pagination:!1,paginationElement:"span",paginationClickable:!1,paginationAsRange:!0,resistance:!0,scrollContainer:!1,preventLinks:!0,preventLinksPropagation:!1,noSwiping:!1,noSwipingClass:"swiper-no-swiping",initialSlide:0,keyboardControl:!1,mousewheelControl:!1,mousewheelControlForceToAxis:!1,useCSS3Transforms:!0,autoplay:!1,autoplayDisableOnInteraction:!0,autoplayStopOnLast:!1,loop:!1,loopAdditionalSlides:0,roundLengths:!1,calculateHeight:!1,cssWidthAndHeight:!1,updateOnImagesReady:!0,releaseFormElements:!0,watchActiveIndex:!1,visibilityFullFit:!1,offsetPxBefore:0,offsetPxAfter:0,offsetSlidesBefore:0,offsetSlidesAfter:0,centeredSlides:!1,queueStartCallbacks:!1,queueEndCallbacks:!1,autoResize:!0,resizeReInit:!1,DOMAnimation:!0,loader:{slides:[],slidesHTMLType:"inner",surroundGroups:1,logic:"reload",loadAllSlides:!1},slideElement:"div",slideClass:"swiper-slide",slideActiveClass:"swiper-slide-active",slideVisibleClass:"swiper-slide-visible",slideDuplicateClass:"swiper-slide-duplicate",wrapperClass:"swiper-wrapper",paginationElementClass:"swiper-pagination-switch",paginationActiveClass:"swiper-active-switch",paginationVisibleClass:"swiper-visible-switch"};t=t||{};for(var H in z)if(H in t&&"object"==typeof t[H])for(var R in z[H])R in t[H]||(t[H][R]=z[H][R]);else H in t||(t[H]=z[H]);_.params=t,t.scrollContainer&&(t.freeMode=!0,t.freeModeFluid=!0),t.loop&&(t.resistance="100%");var W="horizontal"===t.mode,j=["mousedown","mousemove","mouseup"];_.browser.ie10&&(j=["MSPointerDown","MSPointerMove","MSPointerUp"]),_.browser.ie11&&(j=["pointerdown","pointermove","pointerup"]),_.touchEvents={touchStart:_.support.touch||!t.simulateTouch?"touchstart":j[0],touchMove:_.support.touch||!t.simulateTouch?"touchmove":j[1],touchEnd:_.support.touch||!t.simulateTouch?"touchend":j[2]};for(var B=_.container.childNodes.length-1;B>=0;B--)if(_.container.childNodes[B].className)for(var G=_.container.childNodes[B].className.split(/\s+/),F=0;F<G.length;F++)G[F]===t.wrapperClass&&(E=_.container.childNodes[B]);_.wrapper=E,_._extendSwiperSlide=function(e){return e.append=function(){return t.loop?e.insertAfter(_.slides.length-_.loopedSlides):(_.wrapper.appendChild(e),_.reInit()),e},e.prepend=function(){return t.loop?(_.wrapper.insertBefore(e,_.slides[_.loopedSlides]),_.removeLoopedSlides(),_.calcSlides(),_.createLoop()):_.wrapper.insertBefore(e,_.wrapper.firstChild),_.reInit(),e},e.insertAfter=function(i){if("undefined"==typeof i)return!1;var n;return t.loop?(n=_.slides[i+1+_.loopedSlides],n?_.wrapper.insertBefore(e,n):_.wrapper.appendChild(e),_.removeLoopedSlides(),_.calcSlides(),_.createLoop()):(n=_.slides[i+1],_.wrapper.insertBefore(e,n)),_.reInit(),e},e.clone=function(){return _._extendSwiperSlide(e.cloneNode(!0))},e.remove=function(){_.wrapper.removeChild(e),_.reInit()},e.html=function(t){return"undefined"==typeof t?e.innerHTML:(e.innerHTML=t,e)},e.index=function(){for(var t,i=_.slides.length-1;i>=0;i--)e===_.slides[i]&&(t=i);return t},e.isActive=function(){return e.index()===_.activeIndex?!0:!1},e.swiperSlideDataStorage||(e.swiperSlideDataStorage={}),e.getData=function(t){return e.swiperSlideDataStorage[t]},e.setData=function(t,i){return e.swiperSlideDataStorage[t]=i,e},e.data=function(t,i){return"undefined"==typeof i?e.getAttribute("data-"+t):(e.setAttribute("data-"+t,i),e)},e.getWidth=function(t,i){return _.h.getWidth(e,t,i)},e.getHeight=function(t,i){return _.h.getHeight(e,t,i)},e.getOffset=function(){return _.h.getOffset(e)},e},_.calcSlides=function(e){var i=_.slides?_.slides.length:!1;_.slides=[],_.displaySlides=[];for(var n=0;n<_.wrapper.childNodes.length;n++)if(_.wrapper.childNodes[n].className)for(var s=_.wrapper.childNodes[n].className,o=s.split(/\s+/),l=0;l<o.length;l++)o[l]===t.slideClass&&_.slides.push(_.wrapper.childNodes[n]);for(n=_.slides.length-1;n>=0;n--)_._extendSwiperSlide(_.slides[n]);i!==!1&&(i!==_.slides.length||e)&&(r(),a(),_.updateActiveSlide(),_.params.pagination&&_.createPagination(),_.callPlugins("numberOfSlidesChanged"))},_.createSlide=function(e,i,n){i=i||_.params.slideClass,n=n||t.slideElement;var s=document.createElement(n);return s.innerHTML=e||"",s.className=i,_._extendSwiperSlide(s)},_.appendSlide=function(e,t,i){return e?e.nodeType?_._extendSwiperSlide(e).append():_.createSlide(e,t,i).append():void 0},_.prependSlide=function(e,t,i){return e?e.nodeType?_._extendSwiperSlide(e).prepend():_.createSlide(e,t,i).prepend():void 0},_.insertSlideAfter=function(e,t,i,n){return"undefined"==typeof e?!1:t.nodeType?_._extendSwiperSlide(t).insertAfter(e):_.createSlide(t,i,n).insertAfter(e)},_.removeSlide=function(e){if(_.slides[e]){if(t.loop){if(!_.slides[e+_.loopedSlides])return!1;_.slides[e+_.loopedSlides].remove(),_.removeLoopedSlides(),_.calcSlides(),_.createLoop()}else _.slides[e].remove();return!0}return!1},_.removeLastSlide=function(){return _.slides.length>0?(t.loop?(_.slides[_.slides.length-1-_.loopedSlides].remove(),_.removeLoopedSlides(),_.calcSlides(),_.createLoop()):_.slides[_.slides.length-1].remove(),!0):!1},_.removeAllSlides=function(){for(var e=_.slides.length-1;e>=0;e--)_.slides[e].remove()},_.getSlide=function(e){return _.slides[e]},_.getLastSlide=function(){return _.slides[_.slides.length-1]},_.getFirstSlide=function(){return _.slides[0]},_.activeSlide=function(){return _.slides[_.activeIndex]},_.fireCallback=function(){var e=arguments[0];if("[object Array]"===Object.prototype.toString.call(e))for(var i=0;i<e.length;i++)"function"==typeof e[i]&&e[i](arguments[1],arguments[2],arguments[3],arguments[4],arguments[5]);else"[object String]"===Object.prototype.toString.call(e)?t["on"+e]&&_.fireCallback(t["on"+e]):e(arguments[1],arguments[2],arguments[3],arguments[4],arguments[5])},_.addCallback=function(e,t){var i,s=this;return s.params["on"+e]?n(this.params["on"+e])?this.params["on"+e].push(t):"function"==typeof this.params["on"+e]?(i=this.params["on"+e],this.params["on"+e]=[],this.params["on"+e].push(i),this.params["on"+e].push(t)):void 0:(this.params["on"+e]=[],this.params["on"+e].push(t))},_.removeCallbacks=function(e){_.params["on"+e]&&(_.params["on"+e]=null)};var N=[];for(var V in _.plugins)if(t[V]){var X=_.plugins[V](_,t[V]);X&&N.push(X)}_.callPlugins=function(e,t){t||(t={});for(var i=0;i<N.length;i++)e in N[i]&&N[i][e](t)},!_.browser.ie10&&!_.browser.ie11||t.onlyExternal||_.wrapper.classList.add("swiper-wp8-"+(W?"horizontal":"vertical")),t.freeMode&&(_.container.className+=" swiper-free-mode"),_.initialized=!1,_.init=function(e,i){var n=_.h.getWidth(_.container,!1,t.roundLengths),s=_.h.getHeight(_.container,!1,t.roundLengths);if(n!==_.width||s!==_.height||e){_.width=n,_.height=s;var o,a,r,l,d,c,p;D=W?n:s;var u=_.wrapper;if(e&&_.calcSlides(i),"auto"===t.slidesPerView){var h=0,f=0;t.slidesOffset>0&&(u.style.paddingLeft="",u.style.paddingRight="",u.style.paddingTop="",u.style.paddingBottom=""),u.style.width="",u.style.height="",t.offsetPxBefore>0&&(W?_.wrapperLeft=t.offsetPxBefore:_.wrapperTop=t.offsetPxBefore),t.offsetPxAfter>0&&(W?_.wrapperRight=t.offsetPxAfter:_.wrapperBottom=t.offsetPxAfter),t.centeredSlides&&(W?(_.wrapperLeft=(D-this.slides[0].getWidth(!0,t.roundLengths))/2,_.wrapperRight=(D-_.slides[_.slides.length-1].getWidth(!0,t.roundLengths))/2):(_.wrapperTop=(D-_.slides[0].getHeight(!0,t.roundLengths))/2,_.wrapperBottom=(D-_.slides[_.slides.length-1].getHeight(!0,t.roundLengths))/2)),W?(_.wrapperLeft>=0&&(u.style.paddingLeft=_.wrapperLeft+"px"),_.wrapperRight>=0&&(u.style.paddingRight=_.wrapperRight+"px")):(_.wrapperTop>=0&&(u.style.paddingTop=_.wrapperTop+"px"),_.wrapperBottom>=0&&(u.style.paddingBottom=_.wrapperBottom+"px")),c=0;var g=0;for(_.snapGrid=[],_.slidesGrid=[],r=0,p=0;p<_.slides.length;p++){o=_.slides[p].getWidth(!0,t.roundLengths),a=_.slides[p].getHeight(!0,t.roundLengths),t.calculateHeight&&(r=Math.max(r,a));var m=W?o:a;if(t.centeredSlides){var v=p===_.slides.length-1?0:_.slides[p+1].getWidth(!0,t.roundLengths),y=p===_.slides.length-1?0:_.slides[p+1].getHeight(!0,t.roundLengths),w=W?v:y;if(m>D){if(t.slidesPerViewFit)_.snapGrid.push(c+_.wrapperLeft),_.snapGrid.push(c+m-D+_.wrapperLeft);else for(var x=0;x<=Math.floor(m/(D+_.wrapperLeft));x++)0===x?_.snapGrid.push(c+_.wrapperLeft):_.snapGrid.push(c+_.wrapperLeft+D*x);_.slidesGrid.push(c+_.wrapperLeft)}else _.snapGrid.push(g),_.slidesGrid.push(g);g+=m/2+w/2}else{if(m>D)if(t.slidesPerViewFit)_.snapGrid.push(c),_.snapGrid.push(c+m-D);else if(0!==D)for(var b=0;b<=Math.floor(m/D);b++)_.snapGrid.push(c+D*b);else _.snapGrid.push(c);else _.snapGrid.push(c);_.slidesGrid.push(c)}c+=m,h+=o,f+=a}t.calculateHeight&&(_.height=r),W?(A=h+_.wrapperRight+_.wrapperLeft,u.style.width=h+"px",u.style.height=_.height+"px"):(A=f+_.wrapperTop+_.wrapperBottom,u.style.width=_.width+"px",u.style.height=f+"px")}else if(t.scrollContainer)u.style.width="",u.style.height="",l=_.slides[0].getWidth(!0,t.roundLengths),d=_.slides[0].getHeight(!0,t.roundLengths),A=W?l:d,u.style.width=l+"px",u.style.height=d+"px",P=W?l:d;else{if(t.calculateHeight){for(r=0,d=0,W||(_.container.style.height=""),u.style.height="",p=0;p<_.slides.length;p++)_.slides[p].style.height="",r=Math.max(_.slides[p].getHeight(!0),r),W||(d+=_.slides[p].getHeight(!0));a=r,_.height=a,W?d=a:(D=a,_.container.style.height=D+"px")}else a=W?_.height:_.height/t.slidesPerView,t.roundLengths&&(a=Math.round(a)),d=W?_.height:_.slides.length*a;for(o=W?_.width/t.slidesPerView:_.width,t.roundLengths&&(o=Math.round(o)),l=W?_.slides.length*o:_.width,P=W?o:a,t.offsetSlidesBefore>0&&(W?_.wrapperLeft=P*t.offsetSlidesBefore:_.wrapperTop=P*t.offsetSlidesBefore),t.offsetSlidesAfter>0&&(W?_.wrapperRight=P*t.offsetSlidesAfter:_.wrapperBottom=P*t.offsetSlidesAfter),t.offsetPxBefore>0&&(W?_.wrapperLeft=t.offsetPxBefore:_.wrapperTop=t.offsetPxBefore),t.offsetPxAfter>0&&(W?_.wrapperRight=t.offsetPxAfter:_.wrapperBottom=t.offsetPxAfter),t.centeredSlides&&(W?(_.wrapperLeft=(D-P)/2,_.wrapperRight=(D-P)/2):(_.wrapperTop=(D-P)/2,_.wrapperBottom=(D-P)/2)),W?(_.wrapperLeft>0&&(u.style.paddingLeft=_.wrapperLeft+"px"),_.wrapperRight>0&&(u.style.paddingRight=_.wrapperRight+"px")):(_.wrapperTop>0&&(u.style.paddingTop=_.wrapperTop+"px"),_.wrapperBottom>0&&(u.style.paddingBottom=_.wrapperBottom+"px")),A=W?l+_.wrapperRight+_.wrapperLeft:d+_.wrapperTop+_.wrapperBottom,t.cssWidthAndHeight||(parseFloat(l)>0&&(u.style.width=l+"px"),parseFloat(d)>0&&(u.style.height=d+"px")),c=0,_.snapGrid=[],_.slidesGrid=[],p=0;p<_.slides.length;p++)_.snapGrid.push(c),_.slidesGrid.push(c),c+=P,t.cssWidthAndHeight||(parseFloat(o)>0&&(_.slides[p].style.width=o+"px"),parseFloat(a)>0&&(_.slides[p].style.height=a+"px"))}_.initialized?(_.callPlugins("onInit"),t.onInit&&_.fireCallback(t.onInit,_)):(_.callPlugins("onFirstInit"),t.onFirstInit&&_.fireCallback(t.onFirstInit,_)),_.initialized=!0}},_.reInit=function(e){_.init(!0,e)},_.resizeFix=function(e){_.callPlugins("beforeResizeFix"),_.init(t.resizeReInit||e),t.freeMode?_.getWrapperTranslate()<-s()&&(_.setWrapperTransition(0),_.setWrapperTranslate(-s())):(_.swipeTo(t.loop?_.activeLoopIndex:_.activeIndex,0,!1),t.autoplay&&(_.support.transitions&&"undefined"!=typeof J?"undefined"!=typeof J&&(clearTimeout(J),J=void 0,_.startAutoplay()):"undefined"!=typeof et&&(clearInterval(et),et=void 0,_.startAutoplay()))),_.callPlugins("afterResizeFix")},_.destroy=function(){var e=_.h.removeEventListener,i="wrapper"===t.eventTarget?_.wrapper:_.container;_.browser.ie10||_.browser.ie11?(e(i,_.touchEvents.touchStart,g),e(document,_.touchEvents.touchMove,m),e(document,_.touchEvents.touchEnd,v)):(_.support.touch&&(e(i,"touchstart",g),e(i,"touchmove",m),e(i,"touchend",v)),t.simulateTouch&&(e(i,"mousedown",g),e(document,"mousemove",m),e(document,"mouseup",v))),t.autoResize&&e(window,"resize",_.resizeFix),r(),t.paginationClickable&&S(),t.mousewheelControl&&_._wheelEvent&&e(_.container,_._wheelEvent,d),t.keyboardControl&&e(document,"keydown",l),t.autoplay&&_.stopAutoplay(),_.callPlugins("onDestroy"),_=null},_.disableKeyboardControl=function(){t.keyboardControl=!1,_.h.removeEventListener(document,"keydown",l)},_.enableKeyboardControl=function(){t.keyboardControl=!0,_.h.addEventListener(document,"keydown",l)};var Y=(new Date).getTime();if(_.disableMousewheelControl=function(){return _._wheelEvent?(t.mousewheelControl=!1,_.h.removeEventListener(_.container,_._wheelEvent,d),!0):!1},_.enableMousewheelControl=function(){return _._wheelEvent?(t.mousewheelControl=!0,_.h.addEventListener(_.container,_._wheelEvent,d),!0):!1},t.grabCursor){var $=_.container.style;$.cursor="move",$.cursor="grab",$.cursor="-moz-grab",$.cursor="-webkit-grab"}_.allowSlideClick=!0,_.allowLinks=!0;var q,Q,U,K=!1,Z=!0;_.swipeNext=function(e){!e&&t.loop&&_.fixLoop(),!e&&t.autoplay&&_.stopAutoplay(!0),_.callPlugins("onSwipeNext");
 +
var i=_.getWrapperTranslate(),n=i;if("auto"===t.slidesPerView){for(var o=0;o<_.snapGrid.length;o++)if(-i>=_.snapGrid[o]&&-i<_.snapGrid[o+1]){n=-_.snapGrid[o+1];break}}else{var a=P*t.slidesPerGroup;n=-(Math.floor(Math.abs(i)/Math.floor(a))*a+a)}return n<-s()&&(n=-s()),n===i?!1:(x(n,"next"),!0)},_.swipePrev=function(e){!e&&t.loop&&_.fixLoop(),!e&&t.autoplay&&_.stopAutoplay(!0),_.callPlugins("onSwipePrev");var i,n=Math.ceil(_.getWrapperTranslate());if("auto"===t.slidesPerView){i=0;for(var s=1;s<_.snapGrid.length;s++){if(-n===_.snapGrid[s]){i=-_.snapGrid[s-1];break}if(-n>_.snapGrid[s]&&-n<_.snapGrid[s+1]){i=-_.snapGrid[s];break}}}else{var o=P*t.slidesPerGroup;i=-(Math.ceil(-n/o)-1)*o}return i>0&&(i=0),i===n?!1:(x(i,"prev"),!0)},_.swipeReset=function(){_.callPlugins("onSwipeReset");{var e,i=_.getWrapperTranslate(),n=P*t.slidesPerGroup;-s()}if("auto"===t.slidesPerView){e=0;for(var o=0;o<_.snapGrid.length;o++){if(-i===_.snapGrid[o])return;if(-i>=_.snapGrid[o]&&-i<_.snapGrid[o+1]){e=_.positions.diff>0?-_.snapGrid[o+1]:-_.snapGrid[o];break}}-i>=_.snapGrid[_.snapGrid.length-1]&&(e=-_.snapGrid[_.snapGrid.length-1]),i<=-s()&&(e=-s())}else e=0>i?Math.round(i/n)*n:0;return t.scrollContainer&&(e=0>i?i:0),e<-s()&&(e=-s()),t.scrollContainer&&D>P&&(e=0),e===i?!1:(x(e,"reset"),!0)},_.swipeTo=function(e,i,n){e=parseInt(e,10),_.callPlugins("onSwipeTo",{index:e,speed:i}),t.loop&&(e+=_.loopedSlides);var o=_.getWrapperTranslate();if(!(e>_.slides.length-1||0>e)){var a;return a="auto"===t.slidesPerView?-_.slidesGrid[e]:-e*P,a<-s()&&(a=-s()),a===o?!1:(n=n===!1?!1:!0,x(a,"to",{index:e,speed:i,runCallbacks:n}),!0)}},_._queueStartCallbacks=!1,_._queueEndCallbacks=!1,_.updateActiveSlide=function(e){if(_.initialized&&0!==_.slides.length){_.previousIndex=_.activeIndex,"undefined"==typeof e&&(e=_.getWrapperTranslate()),e>0&&(e=0);var i;if("auto"===t.slidesPerView){if(_.activeIndex=_.slidesGrid.indexOf(-e),_.activeIndex<0){for(i=0;i<_.slidesGrid.length-1&&!(-e>_.slidesGrid[i]&&-e<_.slidesGrid[i+1]);i++);var n=Math.abs(_.slidesGrid[i]+e),s=Math.abs(_.slidesGrid[i+1]+e);_.activeIndex=s>=n?i:i+1}}else _.activeIndex=Math[t.visibilityFullFit?"ceil":"round"](-e/P);if(_.activeIndex===_.slides.length&&(_.activeIndex=_.slides.length-1),_.activeIndex<0&&(_.activeIndex=0),_.slides[_.activeIndex]){if(_.calcVisibleSlides(e),_.support.classList){var o;for(i=0;i<_.slides.length;i++)o=_.slides[i],o.classList.remove(t.slideActiveClass),_.visibleSlides.indexOf(o)>=0?o.classList.add(t.slideVisibleClass):o.classList.remove(t.slideVisibleClass);_.slides[_.activeIndex].classList.add(t.slideActiveClass)}else{var a=new RegExp("\\s*"+t.slideActiveClass),r=new RegExp("\\s*"+t.slideVisibleClass);for(i=0;i<_.slides.length;i++)_.slides[i].className=_.slides[i].className.replace(a,"").replace(r,""),_.visibleSlides.indexOf(_.slides[i])>=0&&(_.slides[i].className+=" "+t.slideVisibleClass);_.slides[_.activeIndex].className+=" "+t.slideActiveClass}if(t.loop){var l=_.loopedSlides;_.activeLoopIndex=_.activeIndex-l,_.activeLoopIndex>=_.slides.length-2*l&&(_.activeLoopIndex=_.slides.length-2*l-_.activeLoopIndex),_.activeLoopIndex<0&&(_.activeLoopIndex=_.slides.length-2*l+_.activeLoopIndex),_.activeLoopIndex<0&&(_.activeLoopIndex=0)}else _.activeLoopIndex=_.activeIndex;t.pagination&&_.updatePagination(e)}}},_.createPagination=function(e){if(t.paginationClickable&&_.paginationButtons&&S(),_.paginationContainer=t.pagination.nodeType?t.pagination:i(t.pagination)[0],t.createPagination){var n="",s=_.slides.length,o=s;t.loop&&(o-=2*_.loopedSlides);for(var a=0;o>a;a++)n+="<"+t.paginationElement+' class="'+t.paginationElementClass+'"></'+t.paginationElement+">";_.paginationContainer.innerHTML=n}_.paginationButtons=i("."+t.paginationElementClass,_.paginationContainer),e||_.updatePagination(),_.callPlugins("onCreatePagination"),t.paginationClickable&&C()},_.updatePagination=function(e){if(t.pagination&&!(_.slides.length<1)){var n=i("."+t.paginationActiveClass,_.paginationContainer);if(n){var s=_.paginationButtons;if(0!==s.length){for(var o=0;o<s.length;o++)s[o].className=t.paginationElementClass;var a=t.loop?_.loopedSlides:0;if(t.paginationAsRange){_.visibleSlides||_.calcVisibleSlides(e);var r,l=[];for(r=0;r<_.visibleSlides.length;r++){var d=_.slides.indexOf(_.visibleSlides[r])-a;t.loop&&0>d&&(d=_.slides.length-2*_.loopedSlides+d),t.loop&&d>=_.slides.length-2*_.loopedSlides&&(d=_.slides.length-2*_.loopedSlides-d,d=Math.abs(d)),l.push(d)}for(r=0;r<l.length;r++)s[l[r]]&&(s[l[r]].className+=" "+t.paginationVisibleClass);t.loop?void 0!==s[_.activeLoopIndex]&&(s[_.activeLoopIndex].className+=" "+t.paginationActiveClass):s[_.activeIndex].className+=" "+t.paginationActiveClass}else t.loop?s[_.activeLoopIndex]&&(s[_.activeLoopIndex].className+=" "+t.paginationActiveClass+" "+t.paginationVisibleClass):s[_.activeIndex].className+=" "+t.paginationActiveClass+" "+t.paginationVisibleClass}}}},_.calcVisibleSlides=function(e){var i=[],n=0,s=0,o=0;W&&_.wrapperLeft>0&&(e+=_.wrapperLeft),!W&&_.wrapperTop>0&&(e+=_.wrapperTop);for(var a=0;a<_.slides.length;a++){n+=s,s="auto"===t.slidesPerView?W?_.h.getWidth(_.slides[a],!0,t.roundLengths):_.h.getHeight(_.slides[a],!0,t.roundLengths):P,o=n+s;var r=!1;t.visibilityFullFit?(n>=-e&&-e+D>=o&&(r=!0),-e>=n&&o>=-e+D&&(r=!0)):(o>-e&&-e+D>=o&&(r=!0),n>=-e&&-e+D>n&&(r=!0),-e>n&&o>-e+D&&(r=!0)),r&&i.push(_.slides[a])}0===i.length&&(i=[_.slides[_.activeIndex]]),_.visibleSlides=i};var J,et;_.startAutoplay=function(){if(_.support.transitions){if("undefined"!=typeof J)return!1;if(!t.autoplay)return;_.callPlugins("onAutoplayStart"),t.onAutoplayStart&&_.fireCallback(t.onAutoplayStart,_),k()}else{if("undefined"!=typeof et)return!1;if(!t.autoplay)return;_.callPlugins("onAutoplayStart"),t.onAutoplayStart&&_.fireCallback(t.onAutoplayStart,_),et=setInterval(function(){t.loop?(_.fixLoop(),_.swipeNext(!0)):_.swipeNext(!0)||(t.autoplayStopOnLast?(clearInterval(et),et=void 0):_.swipeTo(0))},t.autoplay)}},_.stopAutoplay=function(e){if(_.support.transitions){if(!J)return;J&&clearTimeout(J),J=void 0,e&&!t.autoplayDisableOnInteraction&&_.wrapperTransitionEnd(function(){k()}),_.callPlugins("onAutoplayStop"),t.onAutoplayStop&&_.fireCallback(t.onAutoplayStop,_)}else et&&clearInterval(et),et=void 0,_.callPlugins("onAutoplayStop"),t.onAutoplayStop&&_.fireCallback(t.onAutoplayStop,_)},_.loopCreated=!1,_.removeLoopedSlides=function(){if(_.loopCreated)for(var e=0;e<_.slides.length;e++)_.slides[e].getData("looped")===!0&&_.wrapper.removeChild(_.slides[e])},_.createLoop=function(){if(0!==_.slides.length){_.loopedSlides="auto"===t.slidesPerView?t.loopedSlides||1:t.slidesPerView+t.loopAdditionalSlides,_.loopedSlides>_.slides.length&&(_.loopedSlides=_.slides.length);var e,i="",n="",s="",o=_.slides.length,a=Math.floor(_.loopedSlides/o),r=_.loopedSlides%o;for(e=0;a*o>e;e++){var l=e;if(e>=o){var d=Math.floor(e/o);l=e-o*d}s+=_.slides[l].outerHTML}for(e=0;r>e;e++)n+=w(t.slideDuplicateClass,_.slides[e].outerHTML);for(e=o-r;o>e;e++)i+=w(t.slideDuplicateClass,_.slides[e].outerHTML);var c=i+s+E.innerHTML+s+n;for(E.innerHTML=c,_.loopCreated=!0,_.calcSlides(),e=0;e<_.slides.length;e++)(e<_.loopedSlides||e>=_.slides.length-_.loopedSlides)&&_.slides[e].setData("looped",!0);_.callPlugins("onCreateLoop")}},_.fixLoop=function(){var e;_.activeIndex<_.loopedSlides?(e=_.slides.length-3*_.loopedSlides+_.activeIndex,_.swipeTo(e,0,!1)):("auto"===t.slidesPerView&&_.activeIndex>=2*_.loopedSlides||_.activeIndex>_.slides.length-2*t.slidesPerView)&&(e=-_.slides.length+_.activeIndex+_.loopedSlides,_.swipeTo(e,0,!1))},_.loadSlides=function(){var e="";_.activeLoaderIndex=0;for(var i=t.loader.slides,n=t.loader.loadAllSlides?i.length:t.slidesPerView*(1+t.loader.surroundGroups),s=0;n>s;s++)e+="outer"===t.loader.slidesHTMLType?i[s]:"<"+t.slideElement+' class="'+t.slideClass+'" data-swiperindex="'+s+'">'+i[s]+"</"+t.slideElement+">";_.wrapper.innerHTML=e,_.calcSlides(!0),t.loader.loadAllSlides||_.wrapperTransitionEnd(_.reloadSlides,!0)},_.reloadSlides=function(){var e=t.loader.slides,i=parseInt(_.activeSlide().data("swiperindex"),10);if(!(0>i||i>e.length-1)){_.activeLoaderIndex=i;var n=Math.max(0,i-t.slidesPerView*t.loader.surroundGroups),s=Math.min(i+t.slidesPerView*(1+t.loader.surroundGroups)-1,e.length-1);if(i>0){var o=-P*(i-n);_.setWrapperTranslate(o),_.setWrapperTransition(0)}var a;if("reload"===t.loader.logic){_.wrapper.innerHTML="";var r="";for(a=n;s>=a;a++)r+="outer"===t.loader.slidesHTMLType?e[a]:"<"+t.slideElement+' class="'+t.slideClass+'" data-swiperindex="'+a+'">'+e[a]+"</"+t.slideElement+">";_.wrapper.innerHTML=r}else{var l=1e3,d=0;for(a=0;a<_.slides.length;a++){var c=_.slides[a].data("swiperindex");n>c||c>s?_.wrapper.removeChild(_.slides[a]):(l=Math.min(c,l),d=Math.max(c,d))}for(a=n;s>=a;a++){var p;l>a&&(p=document.createElement(t.slideElement),p.className=t.slideClass,p.setAttribute("data-swiperindex",a),p.innerHTML=e[a],_.wrapper.insertBefore(p,_.wrapper.firstChild)),a>d&&(p=document.createElement(t.slideElement),p.className=t.slideClass,p.setAttribute("data-swiperindex",a),p.innerHTML=e[a],_.wrapper.appendChild(p))}}_.reInit(!0)}},M()}};Swiper.prototype={plugins:{},wrapperTransitionEnd:function(e,t){"use strict";function i(){if(e(s),s.params.queueEndCallbacks&&(s._queueEndCallbacks=!1),!t)for(n=0;n<a.length;n++)s.h.removeEventListener(o,a[n],i)}var n,s=this,o=s.wrapper,a=["webkitTransitionEnd","transitionend","oTransitionEnd","MSTransitionEnd","msTransitionEnd"];if(e)for(n=0;n<a.length;n++)s.h.addEventListener(o,a[n],i)},getWrapperTranslate:function(e){"use strict";var t,i,n,s,o=this.wrapper;return"undefined"==typeof e&&(e="horizontal"===this.params.mode?"x":"y"),this.support.transforms&&this.params.useCSS3Transforms?(n=window.getComputedStyle(o,null),window.WebKitCSSMatrix?s=new WebKitCSSMatrix("none"===n.webkitTransform?"":n.webkitTransform):(s=n.MozTransform||n.OTransform||n.MsTransform||n.msTransform||n.transform||n.getPropertyValue("transform").replace("translate(","matrix(1, 0, 0, 1,"),t=s.toString().split(",")),"x"===e&&(i=window.WebKitCSSMatrix?s.m41:16===t.length?parseFloat(t[12]):parseFloat(t[4])),"y"===e&&(i=window.WebKitCSSMatrix?s.m42:16===t.length?parseFloat(t[13]):parseFloat(t[5]))):("x"===e&&(i=parseFloat(o.style.left,10)||0),"y"===e&&(i=parseFloat(o.style.top,10)||0)),i||0},setWrapperTranslate:function(e,t,i){"use strict";var n,s=this.wrapper.style,o={x:0,y:0,z:0};3===arguments.length?(o.x=e,o.y=t,o.z=i):("undefined"==typeof t&&(t="horizontal"===this.params.mode?"x":"y"),o[t]=e),this.support.transforms&&this.params.useCSS3Transforms?(n=this.support.transforms3d?"translate3d("+o.x+"px, "+o.y+"px, "+o.z+"px)":"translate("+o.x+"px, "+o.y+"px)",s.webkitTransform=s.MsTransform=s.msTransform=s.MozTransform=s.OTransform=s.transform=n):(s.left=o.x+"px",s.top=o.y+"px"),this.callPlugins("onSetWrapperTransform",o),this.params.onSetWrapperTransform&&this.fireCallback(this.params.onSetWrapperTransform,this,o)},setWrapperTransition:function(e){"use strict";var t=this.wrapper.style;t.webkitTransitionDuration=t.MsTransitionDuration=t.msTransitionDuration=t.MozTransitionDuration=t.OTransitionDuration=t.transitionDuration=e/1e3+"s",this.callPlugins("onSetWrapperTransition",{duration:e}),this.params.onSetWrapperTransition&&this.fireCallback(this.params.onSetWrapperTransition,this,e)},h:{getWidth:function(e,t,i){"use strict";var n=window.getComputedStyle(e,null).getPropertyValue("width"),s=parseFloat(n);return(isNaN(s)||n.indexOf("%")>0)&&(s=e.offsetWidth-parseFloat(window.getComputedStyle(e,null).getPropertyValue("padding-left"))-parseFloat(window.getComputedStyle(e,null).getPropertyValue("padding-right"))),t&&(s+=parseFloat(window.getComputedStyle(e,null).getPropertyValue("padding-left"))+parseFloat(window.getComputedStyle(e,null).getPropertyValue("padding-right"))),i?Math.round(s):s},getHeight:function(e,t,i){"use strict";if(t)return e.offsetHeight;var n=window.getComputedStyle(e,null).getPropertyValue("height"),s=parseFloat(n);return(isNaN(s)||n.indexOf("%")>0)&&(s=e.offsetHeight-parseFloat(window.getComputedStyle(e,null).getPropertyValue("padding-top"))-parseFloat(window.getComputedStyle(e,null).getPropertyValue("padding-bottom"))),t&&(s+=parseFloat(window.getComputedStyle(e,null).getPropertyValue("padding-top"))+parseFloat(window.getComputedStyle(e,null).getPropertyValue("padding-bottom"))),i?Math.round(s):s},getOffset:function(e){"use strict";var t=e.getBoundingClientRect(),i=document.body,n=e.clientTop||i.clientTop||0,s=e.clientLeft||i.clientLeft||0,o=window.pageYOffset||e.scrollTop,a=window.pageXOffset||e.scrollLeft;return document.documentElement&&!window.pageYOffset&&(o=document.documentElement.scrollTop,a=document.documentElement.scrollLeft),{top:t.top+o-n,left:t.left+a-s}},windowWidth:function(){"use strict";return window.innerWidth?window.innerWidth:document.documentElement&&document.documentElement.clientWidth?document.documentElement.clientWidth:void 0},windowHeight:function(){"use strict";return window.innerHeight?window.innerHeight:document.documentElement&&document.documentElement.clientHeight?document.documentElement.clientHeight:void 0},windowScroll:function(){"use strict";return"undefined"!=typeof pageYOffset?{left:window.pageXOffset,top:window.pageYOffset}:document.documentElement?{left:document.documentElement.scrollLeft,top:document.documentElement.scrollTop}:void 0},addEventListener:function(e,t,i,n){"use strict";"undefined"==typeof n&&(n=!1),e.addEventListener?e.addEventListener(t,i,n):e.attachEvent&&e.attachEvent("on"+t,i)},removeEventListener:function(e,t,i,n){"use strict";"undefined"==typeof n&&(n=!1),e.removeEventListener?e.removeEventListener(t,i,n):e.detachEvent&&e.detachEvent("on"+t,i)}},setTransform:function(e,t){"use strict";var i=e.style;i.webkitTransform=i.MsTransform=i.msTransform=i.MozTransform=i.OTransform=i.transform=t},setTranslate:function(e,t){"use strict";var i=e.style,n={x:t.x||0,y:t.y||0,z:t.z||0},s=this.support.transforms3d?"translate3d("+n.x+"px,"+n.y+"px,"+n.z+"px)":"translate("+n.x+"px,"+n.y+"px)";i.webkitTransform=i.MsTransform=i.msTransform=i.MozTransform=i.OTransform=i.transform=s,this.support.transforms||(i.left=n.x+"px",i.top=n.y+"px")},setTransition:function(e,t){"use strict";var i=e.style;i.webkitTransitionDuration=i.MsTransitionDuration=i.msTransitionDuration=i.MozTransitionDuration=i.OTransitionDuration=i.transitionDuration=t+"ms"},support:{touch:window.Modernizr&&Modernizr.touch===!0||function(){"use strict";return!!("ontouchstart"in window||window.DocumentTouch&&document instanceof DocumentTouch)}(),transforms3d:window.Modernizr&&Modernizr.csstransforms3d===!0||function(){"use strict";var e=document.createElement("div").style;return"webkitPerspective"in e||"MozPerspective"in e||"OPerspective"in e||"MsPerspective"in e||"perspective"in e}(),transforms:window.Modernizr&&Modernizr.csstransforms===!0||function(){"use strict";var e=document.createElement("div").style;return"transform"in e||"WebkitTransform"in e||"MozTransform"in e||"msTransform"in e||"MsTransform"in e||"OTransform"in e}(),transitions:window.Modernizr&&Modernizr.csstransitions===!0||function(){"use strict";var e=document.createElement("div").style;return"transition"in e||"WebkitTransition"in e||"MozTransition"in e||"msTransition"in e||"MsTransition"in e||"OTransition"in e}(),classList:function(){"use strict";var e=document.createElement("div").style;return"classList"in e}()},browser:{ie8:function(){"use strict";var e=-1;if("Microsoft Internet Explorer"===navigator.appName){var t=navigator.userAgent,i=new RegExp(/MSIE ([0-9]{1,}[\.0-9]{0,})/);null!==i.exec(t)&&(e=parseFloat(RegExp.$1))}return-1!==e&&9>e}(),ie10:window.navigator.msPointerEnabled,ie11:window.navigator.pointerEnabled}},(window.jQuery||window.Zepto)&&!function(e){"use strict";e.fn.swiper=function(t){var i=new Swiper(e(this)[0],t);return e(this).data("swiper",i),i}}(window.jQuery||window.Zepto),"undefined"!=typeof module&&(module.exports=Swiper),"function"==typeof define&&define.amd&&define([],function(){"use strict";return Swiper}),function(){!function(e,t,i){var n,s,o;return o="slidesjs",s={width:940,height:528,start:1,navigation:{active:!0,effect:"slide"},pagination:{active:!0,effect:"slide"},play:{active:!1,effect:"slide",interval:5e3,auto:!1,swap:!0,pauseOnHover:!1,restartDelay:2500},effect:{slide:{speed:500},fade:{speed:300,crossfade:!0}},callback:{loaded:function(){},start:function(){},complete:function(){}}},n=function(){function t(t,i){this.element=t,this.options=e.extend(!0,{},s,i),this._defaults=s,this._name=o,this.init()}return t}(),n.prototype.init=function(){var i,n,s,o,a,r,l=this;return i=e(this.element),this.data=e.data(this),e.data(this,"animating",!1),e.data(this,"total",i.children().not(".slidesjs-navigation",i).length),e.data(this,"current",this.options.start-1),e.data(this,"vendorPrefix",this._getVendorPrefix()),"undefined"!=typeof TouchEvent&&(e.data(this,"touch",!0),this.options.effect.slide.speed=this.options.effect.slide.speed/2),i.css({overflow:"hidden"}),i.slidesContainer=i.children().not(".slidesjs-navigation",i).wrapAll("<div class='slidesjs-container'>",i).parent().css({overflow:"hidden",position:"relative"}),e(".slidesjs-container",i).wrapInner("<div class='slidesjs-control'>",i).children(),e(".slidesjs-control",i).css({position:"relative",left:0}),e(".slidesjs-control",i).children().addClass("slidesjs-slide").css({position:"absolute",top:0,left:0,width:"100%",zIndex:0,display:"none",webkitBackfaceVisibility:"hidden"}),e.each(e(".slidesjs-control",i).children(),function(t){var i;return i=e(this),i.attr("slidesjs-index",t)}),this.data.touch&&(e(".slidesjs-control",i).on("touchstart",function(e){return l._touchstart(e)}),e(".slidesjs-control",i).on("touchmove",function(e){return l._touchmove(e)}),e(".slidesjs-control",i).on("touchend",function(e){return l._touchend(e)})),i.fadeIn(0),this.update(),this.data.touch&&this._setuptouch(),e(".slidesjs-control",i).children(":eq("+this.data.current+")").eq(0).fadeIn(0,function(){return e(this).css({zIndex:10})}),this.options.navigation.active&&(a=e("<a>",{"class":"slidesjs-previous slidesjs-navigation",href:"#",title:"Previous",text:"Previous"}).appendTo(i),n=e("<a>",{"class":"slidesjs-next slidesjs-navigation",href:"#",title:"Next",text:"Next"}).appendTo(i)),e(".slidesjs-next",i).click(function(e){return e.preventDefault(),l.stop(!0),l.next(l.options.navigation.effect)}),e(".slidesjs-previous",i).click(function(e){return e.preventDefault(),l.stop(!0),l.previous(l.options.navigation.effect)}),this.options.play.active&&(o=e("<a>",{"class":"slidesjs-play slidesjs-navigation",href:"#",title:"Play",text:"Play"}).appendTo(i),r=e("<a>",{"class":"slidesjs-stop slidesjs-navigation",href:"#",title:"Stop",text:"Stop"}).appendTo(i),o.click(function(e){return e.preventDefault(),l.play(!0)}),r.click(function(e){return e.preventDefault(),l.stop(!0)}),this.options.play.swap&&r.css({display:"none"})),this.options.pagination.active&&(s=e("<ul>",{"class":"slidesjs-pagination"}).appendTo(i),e.each(new Array(this.data.total),function(t){var i,n;return i=e("<li>",{"class":"slidesjs-pagination-item"}).appendTo(s),n=e("<a>",{href:"#","data-slidesjs-item":t,html:t+1}).appendTo(i),n.click(function(t){return t.preventDefault(),l.stop(!0),l.goto(1*e(t.currentTarget).attr("data-slidesjs-item")+1)})})),e(t).bind("resize",function(){return l.update()}),this._setActive(),this.options.play.auto&&this.play(),this.options.callback.loaded(this.options.start)},n.prototype._setActive=function(t){var i,n;return i=e(this.element),this.data=e.data(this),n=t>-1?t:this.data.current,e(".active",i).removeClass("active"),e(".slidesjs-pagination li:eq("+n+") a",i).addClass("active")},n.prototype.update=function(){var t,i,n;return t=e(this.element),this.data=e.data(this),e(".slidesjs-control",t).children(":not(:eq("+this.data.current+"))").css({display:"none",left:0,zIndex:0}),n=t.width(),i=this.options.height/this.options.width*n,this.options.width=n,this.options.height=i,e(".slidesjs-control, .slidesjs-container",t).css({width:n,height:i})},n.prototype.next=function(t){var i;return i=e(this.element),this.data=e.data(this),e.data(this,"direction","next"),void 0===t&&(t=this.options.navigation.effect),"fade"===t?this._fade():this._slide()},n.prototype.previous=function(t){var i;return i=e(this.element),this.data=e.data(this),e.data(this,"direction","previous"),void 0===t&&(t=this.options.navigation.effect),"fade"===t?this._fade():this._slide()},n.prototype.goto=function(t){var i,n;if(i=e(this.element),this.data=e.data(this),void 0===n&&(n=this.options.pagination.effect),t>this.data.total?t=this.data.total:1>t&&(t=1),"number"==typeof t)return"fade"===n?this._fade(t):this._slide(t);if("string"==typeof t){if("first"===t)return"fade"===n?this._fade(0):this._slide(0);if("last"===t)return"fade"===n?this._fade(this.data.total):this._slide(this.data.total)}},n.prototype._setuptouch=function(){var t,i,n,s;return t=e(this.element),this.data=e.data(this),s=e(".slidesjs-control",t),i=this.data.current+1,n=this.data.current-1,0>n&&(n=this.data.total-1),i>this.data.total-1&&(i=0),s.children(":eq("+i+")").css({display:"block",left:this.options.width}),s.children(":eq("+n+")").css({display:"block",left:-this.options.width})},n.prototype._touchstart=function(t){var i,n;return i=e(this.element),this.data=e.data(this),n=t.originalEvent.touches[0],this._setuptouch(),e.data(this,"touchtimer",Number(new Date)),e.data(this,"touchstartx",n.pageX),e.data(this,"touchstarty",n.pageY),t.stopPropagation()},n.prototype._touchend=function(t){var i,n,s,o,a,r,l,d=this;return i=e(this.element),this.data=e.data(this),r=t.originalEvent.touches[0],o=e(".slidesjs-control",i),o.position().left>.5*this.options.width||o.position().left>.1*this.options.width&&Number(new Date)-this.data.touchtimer<250?(e.data(this,"direction","previous"),this._slide()):o.position().left<-(.5*this.options.width)||o.position().left<-(.1*this.options.width)&&Number(new Date)-this.data.touchtimer<250?(e.data(this,"direction","next"),this._slide()):(s=this.data.vendorPrefix,l=s+"Transform",n=s+"TransitionDuration",a=s+"TransitionTimingFunction",o[0].style[l]="translateX(0px)",o[0].style[n]=.85*this.options.effect.slide.speed+"ms"),o.on("transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd",function(){return s=d.data.vendorPrefix,l=s+"Transform",n=s+"TransitionDuration",a=s+"TransitionTimingFunction",o[0].style[l]="",o[0].style[n]="",o[0].style[a]=""}),t.stopPropagation()},n.prototype._touchmove=function(t){var i,n,s,o,a;return i=e(this.element),this.data=e.data(this),o=t.originalEvent.touches[0],n=this.data.vendorPrefix,s=e(".slidesjs-control",i),a=n+"Transform",e.data(this,"scrolling",Math.abs(o.pageX-this.data.touchstartx)<Math.abs(o.pageY-this.data.touchstarty)),this.data.animating||this.data.scrolling||(t.preventDefault(),this._setuptouch(),s[0].style[a]="translateX("+(o.pageX-this.data.touchstartx)+"px)"),t.stopPropagation()},n.prototype.play=function(t){var i,n,s,o=this;return i=e(this.element),this.data=e.data(this),!this.data.playInterval&&(t&&(n=this.data.current,this.data.direction="next","fade"===this.options.play.effect?this._fade():this._slide()),e.data(this,"playInterval",setInterval(function(){return n=o.data.current,o.data.direction="next","fade"===o.options.play.effect?o._fade():o._slide()},this.options.play.interval)),s=e(".slidesjs-container",i),this.options.play.pauseOnHover&&(s.unbind(),s.bind("mouseenter",function(){return o.stop()}),s.bind("mouseleave",function(){return o.options.play.restartDelay?e.data(o,"restartDelay",setTimeout(function(){return o.play(!0)},o.options.play.restartDelay)):o.play()})),e.data(this,"playing",!0),e(".slidesjs-play",i).addClass("slidesjs-playing"),this.options.play.swap)?(e(".slidesjs-play",i).hide(),e(".slidesjs-stop",i).show()):void 0},n.prototype.stop=function(t){var i;return i=e(this.element),this.data=e.data(this),clearInterval(this.data.playInterval),this.options.play.pauseOnHover&&t&&e(".slidesjs-container",i).unbind(),e.data(this,"playInterval",null),e.data(this,"playing",!1),e(".slidesjs-play",i).removeClass("slidesjs-playing"),this.options.play.swap?(e(".slidesjs-stop",i).hide(),e(".slidesjs-play",i).show()):void 0},n.prototype._slide=function(t){var i,n,s,o,a,r,l,d,c,p,u=this;return i=e(this.element),this.data=e.data(this),this.data.animating||t===this.data.current+1?void 0:(e.data(this,"animating",!0),n=this.data.current,t>-1?(t-=1,p=t>n?1:-1,s=t>n?-this.options.width:this.options.width,a=t):(p="next"===this.data.direction?1:-1,s="next"===this.data.direction?-this.options.width:this.options.width,a=n+p),-1===a&&(a=this.data.total-1),a===this.data.total&&(a=0),this._setActive(a),l=e(".slidesjs-control",i),t>-1&&l.children(":not(:eq("+n+"))").css({display:"none",left:0,zIndex:0}),l.children(":eq("+a+")").css({display:"block",left:p*this.options.width,zIndex:10}),this.options.callback.start(n+1),this.data.vendorPrefix?(r=this.data.vendorPrefix,c=r+"Transform",o=r+"TransitionDuration",d=r+"TransitionTimingFunction",l[0].style[c]="translateX("+s+"px)",l[0].style[o]=this.options.effect.slide.speed+"ms",l.on("transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd",function(){return l[0].style[c]="",l[0].style[o]="",l.children(":eq("+a+")").css({left:0}),l.children(":eq("+n+")").css({display:"none",left:0,zIndex:0}),e.data(u,"current",a),e.data(u,"animating",!1),l.unbind("transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd"),l.children(":not(:eq("+a+"))").css({display:"none",left:0,zIndex:0}),u.data.touch&&u._setuptouch(),u.options.callback.complete(a+1)})):l.stop().animate({left:s},this.options.effect.slide.speed,function(){return l.css({left:0}),l.children(":eq("+a+")").css({left:0}),l.children(":eq("+n+")").css({display:"none",left:0,zIndex:0},e.data(u,"current",a),e.data(u,"animating",!1),u.options.callback.complete(a+1))}))},n.prototype._fade=function(t){var i,n,s,o,a,r=this;return i=e(this.element),this.data=e.data(this),this.data.animating||t===this.data.current+1?void 0:(e.data(this,"animating",!0),n=this.data.current,t?(t-=1,a=t>n?1:-1,s=t):(a="next"===this.data.direction?1:-1,s=n+a),-1===s&&(s=this.data.total-1),s===this.data.total&&(s=0),this._setActive(s),o=e(".slidesjs-control",i),o.children(":eq("+s+")").css({display:"none",left:0,zIndex:10}),this.options.callback.start(n+1),this.options.effect.fade.crossfade?(o.children(":eq("+this.data.current+")").stop().fadeOut(this.options.effect.fade.speed),o.children(":eq("+s+")").stop().fadeIn(this.options.effect.fade.speed,function(){return o.children(":eq("+s+")").css({zIndex:0}),e.data(r,"animating",!1),e.data(r,"current",s),r.options.callback.complete(s+1)})):o.children(":eq("+n+")").stop().fadeOut(this.options.effect.fade.speed,function(){return o.children(":eq("+s+")").stop().fadeIn(r.options.effect.fade.speed,function(){return o.children(":eq("+s+")").css({zIndex:10})}),e.data(r,"animating",!1),e.data(r,"current",s),r.options.callback.complete(s+1)}))},n.prototype._getVendorPrefix=function(){var e,t,n,s,o;for(e=i.body||i.documentElement,n=e.style,s="transition",o=["Moz","Webkit","Khtml","O","ms"],s=s.charAt(0).toUpperCase()+s.substr(1),t=0;t<o.length;){if("string"==typeof n[o[t]+s])return o[t];t++}return!1},e.fn[o]=function(t){return this.each(function(){return e.data(this,"plugin_"+o)?void 0:e.data(this,"plugin_"+o,new n(this,t))})}}(jQuery,window,document)}.call(this),function(e){function t(t,n,a,r,l){function d(){m.unbind("webkitTransitionEnd transitionend otransitionend oTransitionEnd"),n&&i(n,a,r,l),l.startOrder=[],l.newOrder=[],l.origSort=[],l.checkSort=[],g.removeStyle(l.prefix+"filter, filter, "+l.prefix+"transform, transform, opacity, display").css(l.clean).removeAttr("data-checksum"),window.atob||g.css({display:"none",opacity:"0"});var e=l.resizeContainer?"height":"";m.removeStyle(l.prefix+"transition, transition, "+l.prefix+"perspective, perspective, "+l.prefix+"perspective-origin, perspective-origin, "+e),"list"==l.layoutMode?(y.css({display:l.targetDisplayList,opacity:"1"}),l.origDisplay=l.targetDisplayList):(y.css({display:l.targetDisplayGrid,opacity:"1"}),l.origDisplay=l.targetDisplayGrid),l.origLayout=l.layoutMode;setTimeout(function(){if(g.removeStyle(l.prefix+"transition, transition"),l.mixing=!1,"function"==typeof l.onMixEnd){var e=l.onMixEnd.call(this,l);l=e?e:l}})}if(clearInterval(l.failsafe),l.mixing=!0,l.filter=t,"function"==typeof l.onMixStart){var c=l.onMixStart.call(this,l);l=c?c:l}for(var p=l.transitionSpeed,u=0;2>u;u++){var h=0==u?h=l.prefix:"";l.transition[h+"transition"]="all "+p+"ms linear",l.transition[h+"transform"]=h+"translate3d(0,0,0)",l.perspective[h+"perspective"]=l.perspectiveDistance+"px",l.perspective[h+"perspective-origin"]=l.perspectiveOrigin}var f=l.targetSelector,g=r.find(f);g.each(function(){this.data={}});var m=g.parent();m.css(l.perspective),l.easingFallback="ease-in-out","smooth"==l.easing&&(l.easing="cubic-bezier(0.25, 0.46, 0.45, 0.94)"),"snap"==l.easing&&(l.easing="cubic-bezier(0.77, 0, 0.175, 1)"),"windback"==l.easing&&(l.easing="cubic-bezier(0.175, 0.885, 0.320, 1.275)",l.easingFallback="cubic-bezier(0.175, 0.885, 0.320, 1)"),"windup"==l.easing&&(l.easing="cubic-bezier(0.6, -0.28, 0.735, 0.045)",l.easingFallback="cubic-bezier(0.6, 0.28, 0.735, 0.045)");var v="list"==l.layoutMode&&null!=l.listEffects?l.listEffects:l.effects;Array.prototype.indexOf&&(l.fade=v.indexOf("fade")>-1?"0":"",l.scale=v.indexOf("scale")>-1?"scale(.01)":"",l.rotateZ=v.indexOf("rotateZ")>-1?"rotate(180deg)":"",l.rotateY=v.indexOf("rotateY")>-1?"rotateY(90deg)":"",l.rotateX=v.indexOf("rotateX")>-1?"rotateX(90deg)":"",l.blur=v.indexOf("blur")>-1?"blur(8px)":"",l.grayscale=v.indexOf("grayscale")>-1?"grayscale(100%)":"");var y=e(),w=e(),x=[],b=!1;"string"==typeof t?x=o(t):(b=!0,e.each(t,function(e){x[e]=o(this)})),"or"==l.filterLogic?(""==x[0]&&x.shift(),x.length<1?w=w.add(r.find(f+":visible")):g.each(function(){var t=e(this);if(b){var i=0;e.each(x,function(){this.length?t.is("."+this.join(", ."))&&i++:i>0&&i++}),i==x.length?y=y.add(t):w=w.add(t)}else t.is("."+x.join(", ."))?y=y.add(t):w=w.add(t)})):(y=y.add(m.find(f+"."+x.join("."))),w=w.add(m.find(f+":not(."+x.join(".")+"):visible")));var S=y.length,C=e(),T=e(),k=e();if(w.each(function(){var t=e(this);"none"!=t.css("display")&&(C=C.add(t),k=k.add(t))}),y.filter(":visible").length==S&&!C.length&&!n){if(l.origLayout==l.layoutMode)return d(),!1;if(1==y.length)return"list"==l.layoutMode?(r.addClass(l.listClass),r.removeClass(l.gridClass),k.css("display",l.targetDisplayList)):(r.addClass(l.gridClass),r.removeClass(l.listClass),k.css("display",l.targetDisplayGrid)),d(),!1}if(l.origHeight=m.height(),y.length){if(r.removeClass(l.failClass),y.each(function(){var t=e(this);"none"==t.css("display")?T=T.add(t):k=k.add(t)}),l.origLayout!=l.layoutMode&&0==l.animateGridList)return"list"==l.layoutMode?(r.addClass(l.listClass),r.removeClass(l.gridClass),k.css("display",l.targetDisplayList)):(r.addClass(l.gridClass),r.removeClass(l.listClass),k.css("display",l.targetDisplayGrid)),d(),!1;if(!window.atob)return d(),!1;if(g.css(l.clean),k.each(function(){this.data.origPos=e(this).offset()}),"list"==l.layoutMode?(r.addClass(l.listClass),r.removeClass(l.gridClass),T.css("display",l.targetDisplayList)):(r.addClass(l.gridClass),r.removeClass(l.listClass),T.css("display",l.targetDisplayGrid)),T.each(function(){this.data.showInterPos=e(this).offset()}),C.each(function(){this.data.hideInterPos=e(this).offset()}),k.each(function(){this.data.preInterPos=e(this).offset()}),"list"==l.layoutMode?k.css("display",l.targetDisplayList):k.css("display",l.targetDisplayGrid),n&&i(n,a,r,l),n&&s(l.origSort,l.checkSort))return d(),!1;C.hide(),T.each(function(){this.data.finalPos=e(this).offset()}),k.each(function(){this.data.finalPrePos=e(this).offset()}),l.newHeight=m.height(),n&&i("reset",null,r,l),T.hide(),k.css("display",l.origDisplay),"block"==l.origDisplay?(r.addClass(l.listClass),T.css("display",l.targetDisplayList)):(r.removeClass(l.listClass),T.css("display",l.targetDisplayGrid)),l.resizeContainer&&m.css("height",l.origHeight+"px");
 +
for(var M={},u=0;2>u;u++){var h=0==u?h=l.prefix:"";M[h+"transform"]=l.scale+" "+l.rotateX+" "+l.rotateY+" "+l.rotateZ,M[h+"filter"]=l.blur+" "+l.grayscale}T.css(M),k.each(function(){var t=this.data,i=e(this);i.hasClass("mix_tohide")?(t.preTX=t.origPos.left-t.hideInterPos.left,t.preTY=t.origPos.top-t.hideInterPos.top):(t.preTX=t.origPos.left-t.preInterPos.left,t.preTY=t.origPos.top-t.preInterPos.top);for(var n={},s=0;2>s;s++){var o=0==s?o=l.prefix:"";n[o+"transform"]="translate("+t.preTX+"px,"+t.preTY+"px)"}i.css(n)}),"list"==l.layoutMode?(r.addClass(l.listClass),r.removeClass(l.gridClass)):(r.addClass(l.gridClass),r.removeClass(l.listClass));{setTimeout(function(){if(l.resizeContainer){for(var t={},i=0;2>i;i++){var n=0==i?n=l.prefix:"";t[n+"transition"]="all "+p+"ms ease-in-out",t.height=l.newHeight+"px"}m.css(t)}C.css("opacity",l.fade),T.css("opacity",1),T.each(function(){var t=this.data;t.tX=t.finalPos.left-t.showInterPos.left,t.tY=t.finalPos.top-t.showInterPos.top;for(var i={},n=0;2>n;n++){var s=0==n?s=l.prefix:"";i[s+"transition-property"]=s+"transform, "+s+"filter, opacity",i[s+"transition-timing-function"]=l.easing+", linear, linear",i[s+"transition-duration"]=p+"ms",i[s+"transition-delay"]="0",i[s+"transform"]="translate("+t.tX+"px,"+t.tY+"px)",i[s+"filter"]="none"}e(this).css("-webkit-transition","all "+p+"ms "+l.easingFallback).css(i)}),k.each(function(){var t=this.data;t.tX=0!=t.finalPrePos.left?t.finalPrePos.left-t.preInterPos.left:0,t.tY=0!=t.finalPrePos.left?t.finalPrePos.top-t.preInterPos.top:0;for(var i={},n=0;2>n;n++){var s=0==n?s=l.prefix:"";i[s+"transition"]="all "+p+"ms "+l.easing,i[s+"transform"]="translate("+t.tX+"px,"+t.tY+"px)"}e(this).css("-webkit-transition","all "+p+"ms "+l.easingFallback).css(i)});for(var s={},i=0;2>i;i++){var n=0==i?n=l.prefix:"";s[n+"transition"]="all "+p+"ms "+l.easing+", "+n+"filter "+p+"ms linear, opacity "+p+"ms linear",s[n+"transform"]=l.scale+" "+l.rotateX+" "+l.rotateY+" "+l.rotateZ,s[n+"filter"]=l.blur+" "+l.grayscale,s.opacity=l.fade}C.css(s),m.bind("webkitTransitionEnd transitionend otransitionend oTransitionEnd",function(t){(t.originalEvent.propertyName.indexOf("transform")>-1||t.originalEvent.propertyName.indexOf("opacity")>-1)&&(f.indexOf(".")>-1?e(t.target).hasClass(f.replace(".",""))&&d():e(t.target).is(f)&&d())})},10)}l.failsafe=setTimeout(function(){l.mixing&&d()},p+400)}else{if(l.resizeContainer&&m.css("height",l.origHeight+"px"),!window.atob)return d(),!1;C=w;{setTimeout(function(){if(m.css(l.perspective),l.resizeContainer){for(var e={},t=0;2>t;t++){var i=0==t?i=l.prefix:"";e[i+"transition"]="height "+p+"ms ease-in-out",e.height=l.minHeight+"px"}m.css(e)}g.css(l.transition);var n=w.length;if(n){for(var s={},t=0;2>t;t++){var i=0==t?i=l.prefix:"";s[i+"transform"]=l.scale+" "+l.rotateX+" "+l.rotateY+" "+l.rotateZ,s[i+"filter"]=l.blur+" "+l.grayscale,s.opacity=l.fade}C.css(s),m.bind("webkitTransitionEnd transitionend otransitionend oTransitionEnd",function(e){(e.originalEvent.propertyName.indexOf("transform")>-1||e.originalEvent.propertyName.indexOf("opacity")>-1)&&(r.addClass(l.failClass),d())})}else l.mixing=!1},10)}}}function i(t,i,n,s){function o(e,i){var n=isNaN(1*e.attr(t))?e.attr(t).toLowerCase():1*e.attr(t),s=isNaN(1*i.attr(t))?i.attr(t).toLowerCase():1*i.attr(t);return s>n?-1:n>s?1:0}function a(e){"asc"==i?l.prepend(e).prepend(" "):l.append(e).append(" ")}function r(e){for(var t=e.slice(),i=t.length,n=i;n--;){var s=parseInt(Math.random()*i),o=t[n];t[n]=t[s],t[s]=o}return t}n.find(s.targetSelector).wrapAll('<div class="mix_sorter"/>');var l=n.find(".mix_sorter");if(s.origSort.length||l.find(s.targetSelector+":visible").each(function(){e(this).wrap("<s/>"),s.origSort.push(e(this).parent().html().replace(/\s+/g,"")),e(this).unwrap()}),l.empty(),"reset"==t)e.each(s.startOrder,function(){l.append(this).append(" ")});else if("default"==t)e.each(s.origOrder,function(){a(this)});else if("random"==t)s.newOrder.length||(s.newOrder=r(s.startOrder)),e.each(s.newOrder,function(){l.append(this).append(" ")});else if("custom"==t)e.each(i,function(){a(this)});else{if("undefined"==typeof s.origOrder[0].attr(t))return console.log("No such attribute found. Terminating"),!1;s.newOrder.length||(e.each(s.origOrder,function(){s.newOrder.push(e(this))}),s.newOrder.sort(o)),e.each(s.newOrder,function(){a(this)})}s.checkSort=[],l.find(s.targetSelector+":visible").each(function(t){var i=e(this);0==t&&i.attr("data-checksum","1"),i.wrap("<s/>"),s.checkSort.push(i.parent().html().replace(/\s+/g,"")),i.unwrap()}),n.find(s.targetSelector).unwrap()}function n(e){for(var t=["Webkit","Moz","O","ms"],i=0;i<t.length;i++)if(t[i]+"Transition"in e.style)return t[i];return"transition"in e.style?"":!1}function s(e,t){if(e.length!=t.length)return!1;for(var i=0;i<t.length;i++){if(e[i].compare&&!e[i].compare(t[i]))return!1;if(e[i]!==t[i])return!1}return!0}function o(t){t=t.replace(/\s{2,}/g," ");var i=t.split(" ");return e.each(i,function(e){"all"==this&&(i[e]="mix_all")}),""==i[0]&&i.shift(),i}var a={init:function(s){return this.each(function(){var o=window.navigator.appVersion.match(/Chrome\/(\d+)\./),a=o?parseInt(o[1],10):!1,r=function(e){var t=document.getElementById(e),i=t.parentElement,n=document.createElement("div"),s=document.createDocumentFragment();i.insertBefore(n,t),s.appendChild(t),i.replaceChild(t,n),s=null,n=null};(a&&31==a||32==a)&&r(this.id);var l={targetSelector:".mix",filterSelector:".filter",sortSelector:".sort",buttonEvent:"click",effects:["fade","scale"],listEffects:null,easing:"smooth",layoutMode:"grid",targetDisplayGrid:"inline-block",targetDisplayList:"block",listClass:"",gridClass:"",transitionSpeed:600,showOnLoad:"all",sortOnLoad:!1,multiFilter:!1,filterLogic:"or",resizeContainer:!0,minHeight:0,failClass:"fail",perspectiveDistance:"3000",perspectiveOrigin:"50% 50%",animateGridList:!0,onMixLoad:null,onMixStart:null,onMixEnd:null,container:null,origOrder:[],startOrder:[],newOrder:[],origSort:[],checkSort:[],filter:"",mixing:!1,origDisplay:"",origLayout:"",origHeight:0,newHeight:0,isTouch:!1,resetDelay:0,failsafe:null,prefix:"",easingFallback:"ease-in-out",transition:{},perspective:{},clean:{},fade:"1",scale:"",rotateX:"",rotateY:"",rotateZ:"",blur:"",grayscale:""};s&&e.extend(l,s),this.config=l,e.support.touch="ontouchend"in document,e.support.touch&&(l.isTouch=!0,l.resetDelay=350),l.container=e(this);var d=l.container;if(l.prefix=n(d[0]),l.prefix=l.prefix?"-"+l.prefix.toLowerCase()+"-":"",d.find(l.targetSelector).each(function(){l.origOrder.push(e(this))}),l.sortOnLoad){var c,p;e.isArray(l.sortOnLoad)?(c=l.sortOnLoad[0],p=l.sortOnLoad[1],e(l.sortSelector+"[data-sort="+l.sortOnLoad[0]+"][data-order="+l.sortOnLoad[1]+"]").addClass("active")):(e(l.sortSelector+"[data-sort="+l.sortOnLoad+"]").addClass("active"),c=l.sortOnLoad,l.sortOnLoad="desc"),i(c,p,d,l)}for(var u=0;2>u;u++){var h=0==u?h=l.prefix:"";l.transition[h+"transition"]="all "+l.transitionSpeed+"ms ease-in-out",l.perspective[h+"perspective"]=l.perspectiveDistance+"px",l.perspective[h+"perspective-origin"]=l.perspectiveOrigin}for(var u=0;2>u;u++){var h=0==u?h=l.prefix:"";l.clean[h+"transition"]="none"}"list"==l.layoutMode?(d.addClass(l.listClass),l.origDisplay=l.targetDisplayList):(d.addClass(l.gridClass),l.origDisplay=l.targetDisplayGrid),l.origLayout=l.layoutMode;var f=l.showOnLoad.split(" ");e.each(f,function(){e(l.filterSelector+'[data-filter="'+this+'"]').addClass("active")}),d.find(l.targetSelector).addClass("mix_all"),"all"==f[0]&&(f[0]="mix_all",l.showOnLoad="mix_all");var g=e();e.each(f,function(){g=g.add(e("."+this))}),g.each(function(){var t=e(this);"list"==l.layoutMode?t.css("display",l.targetDisplayList):t.css("display",l.targetDisplayGrid),t.css(l.transition)});setTimeout(function(){l.mixing=!0,g.css("opacity","1");setTimeout(function(){if("list"==l.layoutMode?g.removeStyle(l.prefix+"transition, transition").css({display:l.targetDisplayList,opacity:1}):g.removeStyle(l.prefix+"transition, transition").css({display:l.targetDisplayGrid,opacity:1}),l.mixing=!1,"function"==typeof l.onMixLoad){var e=l.onMixLoad.call(this,l);l=e?e:l}},l.transitionSpeed)},10);l.filter=l.showOnLoad,e(l.sortSelector).bind(l.buttonEvent,function(){if(!l.mixing){var i=e(this),n=i.attr("data-sort"),s=i.attr("data-order");if(i.hasClass("active")){if("random"!=n)return!1}else e(l.sortSelector).removeClass("active"),i.addClass("active");d.find(l.targetSelector).each(function(){l.startOrder.push(e(this))}),t(l.filter,n,s,d,l)}}),e(l.filterSelector).bind(l.buttonEvent,function(){if(!l.mixing){var i=e(this);if(0==l.multiFilter)e(l.filterSelector).removeClass("active"),i.addClass("active"),l.filter=i.attr("data-filter"),e(l.filterSelector+'[data-filter="'+l.filter+'"]').addClass("active");else{var n=i.attr("data-filter");if(i.hasClass("active")){i.removeClass("active");var s=new RegExp("(\\s|^)"+n);l.filter=l.filter.replace(s,"")}else i.addClass("active"),l.filter=l.filter+" "+n}t(l.filter,null,null,d,l)}})})},toGrid:function(){return this.each(function(){var i=this.config;"grid"!=i.layoutMode&&(i.layoutMode="grid",t(i.filter,null,null,e(this),i))})},toList:function(){return this.each(function(){var i=this.config;"list"!=i.layoutMode&&(i.layoutMode="list",t(i.filter,null,null,e(this),i))})},filter:function(i){return this.each(function(){var n=this.config;n.mixing||(e(n.filterSelector).removeClass("active"),e(n.filterSelector+'[data-filter="'+i+'"]').addClass("active"),t(i,null,null,e(this),n))})},sort:function(i){return this.each(function(){var n=this.config,s=e(this);if(!n.mixing){if(e(n.sortSelector).removeClass("active"),e.isArray(i)){var o=i[0],a=i[1];e(n.sortSelector+'[data-sort="'+i[0]+'"][data-order="'+i[1]+'"]').addClass("active")}else{e(n.sortSelector+'[data-sort="'+i+'"]').addClass("active");var o=i,a="desc"}s.find(n.targetSelector).each(function(){n.startOrder.push(e(this))}),t(n.filter,o,a,s,n)}})},multimix:function(i){return this.each(function(){var n=this.config,s=e(this);multiOut={filter:n.filter,sort:null,order:"desc",layoutMode:n.layoutMode},e.extend(multiOut,i),n.mixing||(e(n.filterSelector).add(n.sortSelector).removeClass("active"),e(n.filterSelector+'[data-filter="'+multiOut.filter+'"]').addClass("active"),"undefined"!=typeof multiOut.sort&&(e(n.sortSelector+'[data-sort="'+multiOut.sort+'"][data-order="'+multiOut.order+'"]').addClass("active"),s.find(n.targetSelector).each(function(){n.startOrder.push(e(this))})),n.layoutMode=multiOut.layoutMode,t(multiOut.filter,multiOut.sort,multiOut.order,s,n))})},remix:function(i){return this.each(function(){var n=this.config,s=e(this);n.origOrder=[],s.find(n.targetSelector).each(function(){var t=e(this);t.addClass("mix_all"),n.origOrder.push(t)}),n.mixing||"undefined"==typeof i||(e(n.filterSelector).removeClass("active"),e(n.filterSelector+'[data-filter="'+i+'"]').addClass("active"),t(i,null,null,s,n))})}};e.fn.mixitup=function(e){return a[e]?a[e].apply(this,Array.prototype.slice.call(arguments,1)):"object"!=typeof e&&e?void 0:a.init.apply(this,arguments)},e.fn.removeStyle=function(t){return this.each(function(){var i=e(this);t=t.replace(/\s+/g,"");var n=t.split(",");e.each(n,function(){var e=new RegExp(this.toString()+"[^;]+;?","g");i.attr("style",function(t,i){return i?i.replace(e,""):void 0})})})}}(jQuery),function(e,t){"use strict";var i,n=e.document,s=e.Modernizr,o=function(e){return e.charAt(0).toUpperCase()+e.slice(1)},a="Moz Webkit O Ms".split(" "),r=function(e){var t,i=n.documentElement.style;if("string"==typeof i[e])return e;e=o(e);for(var s=0,r=a.length;r>s;s++)if(t=a[s]+e,"string"==typeof i[t])return t},l=r("transform"),d=r("transitionProperty"),c={csstransforms:function(){return!!l},csstransforms3d:function(){var e=!!r("perspective");if(e){var i=" -o- -moz- -ms- -webkit- -khtml- ".split(" "),n="@media ("+i.join("transform-3d),(")+"modernizr)",s=t("<style>"+n+"{#modernizr{height:3px}}</style>").appendTo("head"),o=t('<div id="modernizr" />').appendTo("html");e=3===o.height(),o.remove(),s.remove()}return e},csstransitions:function(){return!!d}};if(s)for(i in c)s.hasOwnProperty(i)||s.addTest(i,c[i]);else{s=e.Modernizr={_version:"1.6ish: miniModernizr for Isotope"};var p,u=" ";for(i in c)p=c[i](),s[i]=p,u+=" "+(p?"":"no-")+i;t("html").addClass(u)}if(s.csstransforms){var h=s.csstransforms3d?{translate:function(e){return"translate3d("+e[0]+"px, "+e[1]+"px, 0) "},scale:function(e){return"scale3d("+e+", "+e+", 1) "}}:{translate:function(e){return"translate("+e[0]+"px, "+e[1]+"px) "},scale:function(e){return"scale("+e+") "}},f=function(e,i,n){var s,o,a=t.data(e,"isoTransform")||{},r={},d={};r[i]=n,t.extend(a,r);for(s in a)o=a[s],d[s]=h[s](o);var c=d.translate||"",p=d.scale||"",u=c+p;t.data(e,"isoTransform",a),e.style[l]=u};t.cssNumber.scale=!0,t.cssHooks.scale={set:function(e,t){f(e,"scale",t)},get:function(e){var i=t.data(e,"isoTransform");return i&&i.scale?i.scale:1}},t.fx.step.scale=function(e){t.cssHooks.scale.set(e.elem,e.now+e.unit)},t.cssNumber.translate=!0,t.cssHooks.translate={set:function(e,t){f(e,"translate",t)},get:function(e){var i=t.data(e,"isoTransform");return i&&i.translate?i.translate:[0,0]}}}var g,m;s.csstransitions&&(g={WebkitTransitionProperty:"webkitTransitionEnd",MozTransitionProperty:"transitionend",OTransitionProperty:"oTransitionEnd otransitionend",transitionProperty:"transitionend"}[d],m=r("transitionDuration"));var v,y=t.event,w=t.event.handle?"handle":"dispatch";y.special.smartresize={setup:function(){t(this).bind("resize",y.special.smartresize.handler)},teardown:function(){t(this).unbind("resize",y.special.smartresize.handler)},handler:function(e,t){var i=this,n=arguments;e.type="smartresize",v&&clearTimeout(v),v=setTimeout(function(){y[w].apply(i,n)},"execAsap"===t?0:100)}},t.fn.smartresize=function(e){return e?this.bind("smartresize",e):this.trigger("smartresize",["execAsap"])},t.Isotope=function(e,i,n){this.element=t(i),this._create(e),this._init(n)};var x=["width","height"],b=t(e);t.Isotope.settings={resizable:!0,layoutMode:"masonry",containerClass:"isotope",itemClass:"isotope-item",hiddenClass:"isotope-hidden",hiddenStyle:{opacity:0,scale:.001},visibleStyle:{opacity:1,scale:1},containerStyle:{position:"relative",overflow:"hidden"},animationEngine:"best-available",animationOptions:{queue:!1,duration:800},sortBy:"original-order",sortAscending:!0,resizesContainer:!0,transformsEnabled:!0,itemPositionDataEnabled:!1},t.Isotope.prototype={_create:function(e){this.options=t.extend({},t.Isotope.settings,e),this.styleQueue=[],this.elemCount=0;var i=this.element[0].style;this.originalStyle={};var n=x.slice(0);for(var s in this.options.containerStyle)n.push(s);for(var o=0,a=n.length;a>o;o++)s=n[o],this.originalStyle[s]=i[s]||"";this.element.css(this.options.containerStyle),this._updateAnimationEngine(),this._updateUsingTransforms();var r={"original-order":function(e,t){return t.elemCount++,t.elemCount},random:function(){return Math.random()}};this.options.getSortData=t.extend(this.options.getSortData,r),this.reloadItems(),this.offset={left:parseInt(this.element.css("padding-left")||0,10),top:parseInt(this.element.css("padding-top")||0,10)};var l=this;setTimeout(function(){l.element.addClass(l.options.containerClass)},0),this.options.resizable&&b.bind("smartresize.isotope",function(){l.resize()}),this.element.delegate("."+this.options.hiddenClass,"click",function(){return!1})},_getAtoms:function(e){var t=this.options.itemSelector,i=t?e.filter(t).add(e.find(t)):e,n={position:"absolute"};return i=i.filter(function(e,t){return 1===t.nodeType}),this.usingTransforms&&(n.left=0,n.top=0),i.css(n).addClass(this.options.itemClass),this.updateSortData(i,!0),i},_init:function(e){this.$filteredAtoms=this._filter(this.$allAtoms),this._sort(),this.reLayout(e)},option:function(e){if(t.isPlainObject(e)){this.options=t.extend(!0,this.options,e);var i;for(var n in e)i="_update"+o(n),this[i]&&this[i]()}},_updateAnimationEngine:function(){var e,t=this.options.animationEngine.toLowerCase().replace(/[ _\-]/g,"");switch(t){case"css":case"none":e=!1;break;case"jquery":e=!0;break;default:e=!s.csstransitions}this.isUsingJQueryAnimation=e,this._updateUsingTransforms()},_updateTransformsEnabled:function(){this._updateUsingTransforms()},_updateUsingTransforms:function(){var e=this.usingTransforms=this.options.transformsEnabled&&s.csstransforms&&s.csstransitions&&!this.isUsingJQueryAnimation;e||(delete this.options.hiddenStyle.scale,delete this.options.visibleStyle.scale),this.getPositionStyles=e?this._translate:this._positionAbs},_filter:function(e){var t=""===this.options.filter?"*":this.options.filter;if(!t)return e;var i=this.options.hiddenClass,n="."+i,s=e.filter(n),o=s;if("*"!==t){o=s.filter(t);var a=e.not(n).not(t).addClass(i);this.styleQueue.push({$el:a,style:this.options.hiddenStyle})}return this.styleQueue.push({$el:o,style:this.options.visibleStyle}),o.removeClass(i),e.filter(t)},updateSortData:function(e,i){var n,s,o=this,a=this.options.getSortData;e.each(function(){n=t(this),s={};for(var e in a)s[e]=i||"original-order"!==e?a[e](n,o):t.data(this,"isotope-sort-data")[e];t.data(this,"isotope-sort-data",s)})},_sort:function(){var e=this.options.sortBy,t=this._getSorter,i=this.options.sortAscending?1:-1,n=function(n,s){var o=t(n,e),a=t(s,e);return o===a&&"original-order"!==e&&(o=t(n,"original-order"),a=t(s,"original-order")),(o>a?1:a>o?-1:0)*i};this.$filteredAtoms.sort(n)},_getSorter:function(e,i){return t.data(e,"isotope-sort-data")[i]},_translate:function(e,t){return{translate:[e,t]}},_positionAbs:function(e,t){return{left:e,top:t}},_pushPosition:function(e,t,i){t=Math.round(t+this.offset.left),i=Math.round(i+this.offset.top);var n=this.getPositionStyles(t,i);this.styleQueue.push({$el:e,style:n}),this.options.itemPositionDataEnabled&&e.data("isotope-item-position",{x:t,y:i})},layout:function(e,t){var i=this.options.layoutMode;if(this["_"+i+"Layout"](e),this.options.resizesContainer){var n=this["_"+i+"GetContainerSize"]();this.styleQueue.push({$el:this.element,style:n})}this._processStyleQueue(e,t),this.isLaidOut=!0},_processStyleQueue:function(e,i){var n,o,a,r,l=this.isLaidOut?this.isUsingJQueryAnimation?"animate":"css":"css",d=this.options.animationOptions,c=this.options.onLayout;if(o=function(e,t){t.$el[l](t.style,d)},this._isInserting&&this.isUsingJQueryAnimation)o=function(e,t){n=t.$el.hasClass("no-transition")?"css":l,t.$el[n](t.style,d)};else if(i||c||d.complete){var p=!1,u=[i,c,d.complete],h=this;if(a=!0,r=function(){if(!p){for(var t,i=0,n=u.length;n>i;i++)t=u[i],"function"==typeof t&&t.call(h.element,e,h);p=!0}},this.isUsingJQueryAnimation&&"animate"===l)d.complete=r,a=!1;else if(s.csstransitions){for(var f,v=0,y=this.styleQueue[0],w=y&&y.$el;!w||!w.length;){if(f=this.styleQueue[v++],!f)return;w=f.$el}var x=parseFloat(getComputedStyle(w[0])[m]);x>0&&(o=function(e,t){t.$el[l](t.style,d).one(g,r)},a=!1)}}t.each(this.styleQueue,o),a&&r(),this.styleQueue=[]},resize:function(){this["_"+this.options.layoutMode+"ResizeChanged"]()&&this.reLayout()},reLayout:function(e){this["_"+this.options.layoutMode+"Reset"](),this.layout(this.$filteredAtoms,e)},addItems:function(e,t){var i=this._getAtoms(e);this.$allAtoms=this.$allAtoms.add(i),t&&t(i)},insert:function(e,t){this.element.append(e);var i=this;this.addItems(e,function(e){var n=i._filter(e);i._addHideAppended(n),i._sort(),i.reLayout(),i._revealAppended(n,t)})},appended:function(e,t){var i=this;this.addItems(e,function(e){i._addHideAppended(e),i.layout(e),i._revealAppended(e,t)})},_addHideAppended:function(e){this.$filteredAtoms=this.$filteredAtoms.add(e),e.addClass("no-transition"),this._isInserting=!0,this.styleQueue.push({$el:e,style:this.options.hiddenStyle})},_revealAppended:function(e,t){var i=this;setTimeout(function(){e.removeClass("no-transition"),i.styleQueue.push({$el:e,style:i.options.visibleStyle}),i._isInserting=!1,i._processStyleQueue(e,t)},10)},reloadItems:function(){this.$allAtoms=this._getAtoms(this.element.children())},remove:function(e,t){this.$allAtoms=this.$allAtoms.not(e),this.$filteredAtoms=this.$filteredAtoms.not(e);var i=this,n=function(){e.remove(),t&&t.call(i.element)};e.filter(":not(."+this.options.hiddenClass+")").length?(this.styleQueue.push({$el:e,style:this.options.hiddenStyle}),this._sort(),this.reLayout(n)):n()},shuffle:function(e){this.updateSortData(this.$allAtoms),this.options.sortBy="random",this._sort(),this.reLayout(e)},destroy:function(){var e=this.usingTransforms,t=this.options;this.$allAtoms.removeClass(t.hiddenClass+" "+t.itemClass).each(function(){var t=this.style;t.position="",t.top="",t.left="",t.opacity="",e&&(t[l]="")});var i=this.element[0].style;for(var n in this.originalStyle)i[n]=this.originalStyle[n];this.element.unbind(".isotope").undelegate("."+t.hiddenClass,"click").removeClass(t.containerClass).removeData("isotope"),b.unbind(".isotope")},_getSegments:function(e){var t,i=this.options.layoutMode,n=e?"rowHeight":"columnWidth",s=e?"height":"width",a=e?"rows":"cols",r=this.element[s](),l=this.options[i]&&this.options[i][n]||this.$filteredAtoms["outer"+o(s)](!0)||r;t=Math.floor(r/l),t=Math.max(t,1),this[i][a]=t,this[i][n]=l},_checkIfSegmentsChanged:function(e){var t=this.options.layoutMode,i=e?"rows":"cols",n=this[t][i];return this._getSegments(e),this[t][i]!==n},_masonryReset:function(){this.masonry={},this._getSegments();var e=this.masonry.cols;for(this.masonry.colYs=[];e--;)this.masonry.colYs.push(0)},_masonryLayout:function(e){var i=this,n=i.masonry;e.each(function(){var e=t(this),s=Math.ceil(e.outerWidth(!0)/n.columnWidth);if(s=Math.min(s,n.cols),1===s)i._masonryPlaceBrick(e,n.colYs);else{var o,a,r=n.cols+1-s,l=[];for(a=0;r>a;a++)o=n.colYs.slice(a,a+s),l[a]=Math.max.apply(Math,o);i._masonryPlaceBrick(e,l)}})},_masonryPlaceBrick:function(e,t){for(var i=Math.min.apply(Math,t),n=0,s=0,o=t.length;o>s;s++)if(t[s]===i){n=s;break}var a=this.masonry.columnWidth*n,r=i;this._pushPosition(e,a,r);var l=i+e.outerHeight(!0),d=this.masonry.cols+1-o;for(s=0;d>s;s++)this.masonry.colYs[n+s]=l},_masonryGetContainerSize:function(){var e=Math.max.apply(Math,this.masonry.colYs);return{height:e}},_masonryResizeChanged:function(){return this._checkIfSegmentsChanged()},_fitRowsReset:function(){this.fitRows={x:0,y:0,height:0}},_fitRowsLayout:function(e){var i=this,n=this.element.width(),s=this.fitRows;e.each(function(){var e=t(this),o=e.outerWidth(!0),a=e.outerHeight(!0);0!==s.x&&o+s.x>n&&(s.x=0,s.y=s.height),i._pushPosition(e,s.x,s.y),s.height=Math.max(s.y+a,s.height),s.x+=o})},_fitRowsGetContainerSize:function(){return{height:this.fitRows.height}},_fitRowsResizeChanged:function(){return!0},_cellsByRowReset:function(){this.cellsByRow={index:0},this._getSegments(),this._getSegments(!0)},_cellsByRowLayout:function(e){var i=this,n=this.cellsByRow;e.each(function(){var e=t(this),s=n.index%n.cols,o=Math.floor(n.index/n.cols),a=(s+.5)*n.columnWidth-e.outerWidth(!0)/2,r=(o+.5)*n.rowHeight-e.outerHeight(!0)/2;i._pushPosition(e,a,r),n.index++})},_cellsByRowGetContainerSize:function(){return{height:Math.ceil(this.$filteredAtoms.length/this.cellsByRow.cols)*this.cellsByRow.rowHeight+this.offset.top}},_cellsByRowResizeChanged:function(){return this._checkIfSegmentsChanged()},_straightDownReset:function(){this.straightDown={y:0}},_straightDownLayout:function(e){var i=this;e.each(function(){var e=t(this);i._pushPosition(e,0,i.straightDown.y),i.straightDown.y+=e.outerHeight(!0)})},_straightDownGetContainerSize:function(){return{height:this.straightDown.y}},_straightDownResizeChanged:function(){return!0},_masonryHorizontalReset:function(){this.masonryHorizontal={},this._getSegments(!0);var e=this.masonryHorizontal.rows;for(this.masonryHorizontal.rowXs=[];e--;)this.masonryHorizontal.rowXs.push(0)},_masonryHorizontalLayout:function(e){var i=this,n=i.masonryHorizontal;e.each(function(){var e=t(this),s=Math.ceil(e.outerHeight(!0)/n.rowHeight);if(s=Math.min(s,n.rows),1===s)i._masonryHorizontalPlaceBrick(e,n.rowXs);else{var o,a,r=n.rows+1-s,l=[];for(a=0;r>a;a++)o=n.rowXs.slice(a,a+s),l[a]=Math.max.apply(Math,o);i._masonryHorizontalPlaceBrick(e,l)}})},_masonryHorizontalPlaceBrick:function(e,t){for(var i=Math.min.apply(Math,t),n=0,s=0,o=t.length;o>s;s++)if(t[s]===i){n=s;break}var a=i,r=this.masonryHorizontal.rowHeight*n;this._pushPosition(e,a,r);var l=i+e.outerWidth(!0),d=this.masonryHorizontal.rows+1-o;for(s=0;d>s;s++)this.masonryHorizontal.rowXs[n+s]=l},_masonryHorizontalGetContainerSize:function(){var e=Math.max.apply(Math,this.masonryHorizontal.rowXs);return{width:e}},_masonryHorizontalResizeChanged:function(){return this._checkIfSegmentsChanged(!0)},_fitColumnsReset:function(){this.fitColumns={x:0,y:0,width:0}},_fitColumnsLayout:function(e){var i=this,n=this.element.height(),s=this.fitColumns;e.each(function(){var e=t(this),o=e.outerWidth(!0),a=e.outerHeight(!0);0!==s.y&&a+s.y>n&&(s.x=s.width,s.y=0),i._pushPosition(e,s.x,s.y),s.width=Math.max(s.x+o,s.width),s.y+=a})},_fitColumnsGetContainerSize:function(){return{width:this.fitColumns.width}},_fitColumnsResizeChanged:function(){return!0},_cellsByColumnReset:function(){this.cellsByColumn={index:0},this._getSegments(),this._getSegments(!0)},_cellsByColumnLayout:function(e){var i=this,n=this.cellsByColumn;e.each(function(){var e=t(this),s=Math.floor(n.index/n.rows),o=n.index%n.rows,a=(s+.5)*n.columnWidth-e.outerWidth(!0)/2,r=(o+.5)*n.rowHeight-e.outerHeight(!0)/2;i._pushPosition(e,a,r),n.index++})},_cellsByColumnGetContainerSize:function(){return{width:Math.ceil(this.$filteredAtoms.length/this.cellsByColumn.rows)*this.cellsByColumn.columnWidth}},_cellsByColumnResizeChanged:function(){return this._checkIfSegmentsChanged(!0)},_straightAcrossReset:function(){this.straightAcross={x:0}},_straightAcrossLayout:function(e){var i=this;e.each(function(){var e=t(this);i._pushPosition(e,i.straightAcross.x,0),i.straightAcross.x+=e.outerWidth(!0)})},_straightAcrossGetContainerSize:function(){return{width:this.straightAcross.x}},_straightAcrossResizeChanged:function(){return!0}},t.fn.imagesLoaded=function(e){function i(){e.call(s,o)}function n(e){var s=e.target;s.src!==r&&-1===t.inArray(s,l)&&(l.push(s),--a<=0&&(setTimeout(i),o.unbind(".imagesLoaded",n)))}var s=this,o=s.find("img").add(s.filter("img")),a=o.length,r="",l=[];return a||i(),o.bind("load.imagesLoaded error.imagesLoaded",n).each(function(){var e=this.src;this.src=r,this.src=e}),s};var S=function(t){e.console&&e.console.error(t)};t.fn.isotope=function(e,i){if("string"==typeof e){var n=Array.prototype.slice.call(arguments,1);this.each(function(){var i=t.data(this,"isotope");return i?t.isFunction(i[e])&&"_"!==e.charAt(0)?(i[e].apply(i,n),void 0):(S("no such method '"+e+"' for isotope instance"),void 0):(S("cannot call methods on isotope prior to initialization; attempted to call method '"+e+"'"),void 0)})}else this.each(function(){var n=t.data(this,"isotope");n?(n.option(e),n._init(i)):t.data(this,"isotope",new t.Isotope(e,this,i))});return this}}(window,jQuery),function(e,t,i,n){"use strict";var s=i("html"),o=i(e),a=i(t),r=i.fancybox=function(){r.open.apply(this,arguments)},l=navigator.userAgent.match(/msie/i),d=null,c=t.createTouch!==n,p=function(e){return e&&e.hasOwnProperty&&e instanceof i},u=function(e){return e&&"string"===i.type(e)},h=function(e){return u(e)&&e.indexOf("%")>0},f=function(e){return e&&!(e.style.overflow&&"hidden"===e.style.overflow)&&(e.clientWidth&&e.scrollWidth>e.clientWidth||e.clientHeight&&e.scrollHeight>e.clientHeight)},g=function(e,t){var i=parseInt(e,10)||0;return t&&h(e)&&(i=r.getViewport()[t]/100*i),Math.ceil(i)},m=function(e,t){return g(e,t)+"px"};i.extend(r,{version:"2.1.5",defaults:{padding:15,margin:20,width:800,height:600,minWidth:100,minHeight:100,maxWidth:9999,maxHeight:9999,pixelRatio:1,autoSize:!0,autoHeight:!1,autoWidth:!1,autoResize:!0,autoCenter:!c,fitToView:!0,aspectRatio:!1,topRatio:.5,leftRatio:.5,scrolling:"auto",wrapCSS:"",arrows:!0,closeBtn:!0,closeClick:!1,nextClick:!1,mouseWheel:!0,autoPlay:!1,playSpeed:3e3,preload:3,modal:!1,loop:!0,ajax:{dataType:"html",headers:{"X-fancyBox":!0}},iframe:{scrolling:"auto",preload:!0},swf:{wmode:"transparent",allowfullscreen:"true",allowscriptaccess:"always"},keys:{next:{13:"left",34:"up",39:"left",40:"up"},prev:{8:"right",33:"down",37:"right",38:"down"},close:[27],play:[32],toggle:[70]},direction:{next:"left",prev:"right"},scrollOutside:!0,index:0,type:null,href:null,content:null,title:null,tpl:{wrap:'<div class="fancybox-wrap" tabIndex="-1"><div class="fancybox-skin"><div class="fancybox-outer"><div class="fancybox-inner"></div></div></div></div>',image:'<img class="fancybox-image" src="{href}" alt="" />',iframe:'<iframe id="fancybox-frame{rnd}" name="fancybox-frame{rnd}" class="fancybox-iframe" frameborder="0" vspace="0" hspace="0" webkitAllowFullScreen mozallowfullscreen allowFullScreen'+(l?' allowtransparency="true"':"")+"></iframe>",error:'<p class="fancybox-error">The requested content cannot be loaded.<br/>Please try again later.</p>',closeBtn:'<a title="Close" class="fancybox-item fancybox-close" href="javascript:;"></a>',next:'<a title="Next" class="fancybox-nav fancybox-next" href="javascript:;"><span></span></a>',prev:'<a title="Previous" class="fancybox-nav fancybox-prev" href="javascript:;"><span></span></a>'},openEffect:"fade",openSpeed:250,openEasing:"swing",openOpacity:!0,openMethod:"zoomIn",closeEffect:"fade",closeSpeed:250,closeEasing:"swing",closeOpacity:!0,closeMethod:"zoomOut",nextEffect:"elastic",nextSpeed:250,nextEasing:"swing",nextMethod:"changeIn",prevEffect:"elastic",prevSpeed:250,prevEasing:"swing",prevMethod:"changeOut",helpers:{overlay:!0,title:!0},onCancel:i.noop,beforeLoad:i.noop,afterLoad:i.noop,beforeShow:i.noop,afterShow:i.noop,beforeChange:i.noop,beforeClose:i.noop,afterClose:i.noop},group:{},opts:{},previous:null,coming:null,current:null,isActive:!1,isOpen:!1,isOpened:!1,wrap:null,skin:null,outer:null,inner:null,player:{timer:null,isActive:!1},ajaxLoad:null,imgPreload:null,transitions:{},helpers:{},open:function(e,t){return e&&(i.isPlainObject(t)||(t={}),!1!==r.close(!0))?(i.isArray(e)||(e=p(e)?i(e).get():[e]),i.each(e,function(s,o){var a,l,d,c,h,f,g,m={};"object"===i.type(o)&&(o.nodeType&&(o=i(o)),p(o)?(m={href:o.data("fancybox-href")||o.attr("href"),title:o.data("fancybox-title")||o.attr("title"),isDom:!0,element:o},i.metadata&&i.extend(!0,m,o.metadata())):m=o),a=t.href||m.href||(u(o)?o:null),l=t.title!==n?t.title:m.title||"",d=t.content||m.content,c=d?"html":t.type||m.type,!c&&m.isDom&&(c=o.data("fancybox-type"),c||(h=o.prop("class").match(/fancybox\.(\w+)/),c=h?h[1]:null)),u(a)&&(c||(r.isImage(a)?c="image":r.isSWF(a)?c="swf":"#"===a.charAt(0)?c="inline":u(o)&&(c="html",d=o)),"ajax"===c&&(f=a.split(/\s+/,2),a=f.shift(),g=f.shift())),d||("inline"===c?a?d=i(u(a)?a.replace(/.*(?=#[^\s]+$)/,""):a):m.isDom&&(d=o):"html"===c?d=a:c||a||!m.isDom||(c="inline",d=o)),i.extend(m,{href:a,type:c,content:d,title:l,selector:g}),e[s]=m}),r.opts=i.extend(!0,{},r.defaults,t),t.keys!==n&&(r.opts.keys=t.keys?i.extend({},r.defaults.keys,t.keys):!1),r.group=e,r._start(r.opts.index)):void 0},cancel:function(){var e=r.coming;e&&!1!==r.trigger("onCancel")&&(r.hideLoading(),r.ajaxLoad&&r.ajaxLoad.abort(),r.ajaxLoad=null,r.imgPreload&&(r.imgPreload.onload=r.imgPreload.onerror=null),e.wrap&&e.wrap.stop(!0,!0).trigger("onReset").remove(),r.coming=null,r.current||r._afterZoomOut(e))},close:function(e){r.cancel(),!1!==r.trigger("beforeClose")&&(r.unbindEvents(),r.isActive&&(r.isOpen&&e!==!0?(r.isOpen=r.isOpened=!1,r.isClosing=!0,i(".fancybox-item, .fancybox-nav").remove(),r.wrap.stop(!0,!0).removeClass("fancybox-opened"),r.transitions[r.current.closeMethod]()):(i(".fancybox-wrap").stop(!0).trigger("onReset").remove(),r._afterZoomOut())))},play:function(e){var t=function(){clearTimeout(r.player.timer)},i=function(){t(),r.current&&r.player.isActive&&(r.player.timer=setTimeout(r.next,r.current.playSpeed))},n=function(){t(),a.unbind(".player"),r.player.isActive=!1,r.trigger("onPlayEnd")},s=function(){r.current&&(r.current.loop||r.current.index<r.group.length-1)&&(r.player.isActive=!0,a.bind({"onCancel.player beforeClose.player":n,"onUpdate.player":i,"beforeLoad.player":t}),i(),r.trigger("onPlayStart"))
 +
};e===!0||!r.player.isActive&&e!==!1?s():n()},next:function(e){var t=r.current;t&&(u(e)||(e=t.direction.next),r.jumpto(t.index+1,e,"next"))},prev:function(e){var t=r.current;t&&(u(e)||(e=t.direction.prev),r.jumpto(t.index-1,e,"prev"))},jumpto:function(e,t,i){var s=r.current;s&&(e=g(e),r.direction=t||s.direction[e>=s.index?"next":"prev"],r.router=i||"jumpto",s.loop&&(0>e&&(e=s.group.length+e%s.group.length),e%=s.group.length),s.group[e]!==n&&(r.cancel(),r._start(e)))},reposition:function(e,t){var n,s=r.current,o=s?s.wrap:null;o&&(n=r._getPosition(t),e&&"scroll"===e.type?(delete n.position,o.stop(!0,!0).animate(n,200)):(o.css(n),s.pos=i.extend({},s.dim,n)))},update:function(e){var t=e&&e.type,i=!t||"orientationchange"===t;i&&(clearTimeout(d),d=null),r.isOpen&&!d&&(d=setTimeout(function(){var n=r.current;n&&!r.isClosing&&(r.wrap.removeClass("fancybox-tmp"),(i||"load"===t||"resize"===t&&n.autoResize)&&r._setDimension(),"scroll"===t&&n.canShrink||r.reposition(e),r.trigger("onUpdate"),d=null)},i&&!c?0:300))},toggle:function(e){r.isOpen&&(r.current.fitToView="boolean"===i.type(e)?e:!r.current.fitToView,c&&(r.wrap.removeAttr("style").addClass("fancybox-tmp"),r.trigger("onUpdate")),r.update())},hideLoading:function(){a.unbind(".loading"),i("#fancybox-loading").remove()},showLoading:function(){var e,t;r.hideLoading(),e=i('<div id="fancybox-loading"><div></div></div>').click(r.cancel).appendTo("body"),a.bind("keydown.loading",function(e){27===(e.which||e.keyCode)&&(e.preventDefault(),r.cancel())}),r.defaults.fixed||(t=r.getViewport(),e.css({position:"absolute",top:.5*t.h+t.y,left:.5*t.w+t.x}))},getViewport:function(){var t=r.current&&r.current.locked||!1,i={x:o.scrollLeft(),y:o.scrollTop()};return t?(i.w=t[0].clientWidth,i.h=t[0].clientHeight):(i.w=c&&e.innerWidth?e.innerWidth:o.width(),i.h=c&&e.innerHeight?e.innerHeight:o.height()),i},unbindEvents:function(){r.wrap&&p(r.wrap)&&r.wrap.unbind(".fb"),a.unbind(".fb"),o.unbind(".fb")},bindEvents:function(){var e,t=r.current;t&&(o.bind("orientationchange.fb"+(c?"":" resize.fb")+(t.autoCenter&&!t.locked?" scroll.fb":""),r.update),e=t.keys,e&&a.bind("keydown.fb",function(s){var o=s.which||s.keyCode,a=s.target||s.srcElement;return 27===o&&r.coming?!1:(s.ctrlKey||s.altKey||s.shiftKey||s.metaKey||a&&(a.type||i(a).is("[contenteditable]"))||i.each(e,function(e,a){return t.group.length>1&&a[o]!==n?(r[e](a[o]),s.preventDefault(),!1):i.inArray(o,a)>-1?(r[e](),s.preventDefault(),!1):void 0}),void 0)}),i.fn.mousewheel&&t.mouseWheel&&r.wrap.bind("mousewheel.fb",function(e,n,s,o){for(var a=e.target||null,l=i(a),d=!1;l.length&&!(d||l.is(".fancybox-skin")||l.is(".fancybox-wrap"));)d=f(l[0]),l=i(l).parent();0===n||d||r.group.length>1&&!t.canShrink&&(o>0||s>0?r.prev(o>0?"down":"left"):(0>o||0>s)&&r.next(0>o?"up":"right"),e.preventDefault())}))},trigger:function(e,t){var n,s=t||r.coming||r.current;if(s){if(i.isFunction(s[e])&&(n=s[e].apply(s,Array.prototype.slice.call(arguments,1))),n===!1)return!1;s.helpers&&i.each(s.helpers,function(t,n){n&&r.helpers[t]&&i.isFunction(r.helpers[t][e])&&r.helpers[t][e](i.extend(!0,{},r.helpers[t].defaults,n),s)}),a.trigger(e)}},isImage:function(e){return u(e)&&e.match(/(^data:image\/.*,)|(\.(jp(e|g|eg)|gif|png|bmp|webp|svg)((\?|#).*)?$)/i)},isSWF:function(e){return u(e)&&e.match(/\.(swf)((\?|#).*)?$/i)},_start:function(e){var t,n,s,o,a,l={};if(e=g(e),t=r.group[e]||null,!t)return!1;if(l=i.extend(!0,{},r.opts,t),o=l.margin,a=l.padding,"number"===i.type(o)&&(l.margin=[o,o,o,o]),"number"===i.type(a)&&(l.padding=[a,a,a,a]),l.modal&&i.extend(!0,l,{closeBtn:!1,closeClick:!1,nextClick:!1,arrows:!1,mouseWheel:!1,keys:null,helpers:{overlay:{closeClick:!1}}}),l.autoSize&&(l.autoWidth=l.autoHeight=!0),"auto"===l.width&&(l.autoWidth=!0),"auto"===l.height&&(l.autoHeight=!0),l.group=r.group,l.index=e,r.coming=l,!1===r.trigger("beforeLoad"))return r.coming=null,void 0;if(s=l.type,n=l.href,!s)return r.coming=null,r.current&&r.router&&"jumpto"!==r.router?(r.current.index=e,r[r.router](r.direction)):!1;if(r.isActive=!0,("image"===s||"swf"===s)&&(l.autoHeight=l.autoWidth=!1,l.scrolling="visible"),"image"===s&&(l.aspectRatio=!0),"iframe"===s&&c&&(l.scrolling="scroll"),l.wrap=i(l.tpl.wrap).addClass("fancybox-"+(c?"mobile":"desktop")+" fancybox-type-"+s+" fancybox-tmp "+l.wrapCSS).appendTo(l.parent||"body"),i.extend(l,{skin:i(".fancybox-skin",l.wrap),outer:i(".fancybox-outer",l.wrap),inner:i(".fancybox-inner",l.wrap)}),i.each(["Top","Right","Bottom","Left"],function(e,t){l.skin.css("padding"+t,m(l.padding[e]))}),r.trigger("onReady"),"inline"===s||"html"===s){if(!l.content||!l.content.length)return r._error("content")}else if(!n)return r._error("href");"image"===s?r._loadImage():"ajax"===s?r._loadAjax():"iframe"===s?r._loadIframe():r._afterLoad()},_error:function(e){i.extend(r.coming,{type:"html",autoWidth:!0,autoHeight:!0,minWidth:0,minHeight:0,scrolling:"no",hasError:e,content:r.coming.tpl.error}),r._afterLoad()},_loadImage:function(){var e=r.imgPreload=new Image;e.onload=function(){this.onload=this.onerror=null,r.coming.width=this.width/r.opts.pixelRatio,r.coming.height=this.height/r.opts.pixelRatio,r._afterLoad()},e.onerror=function(){this.onload=this.onerror=null,r._error("image")},e.src=r.coming.href,e.complete!==!0&&r.showLoading()},_loadAjax:function(){var e=r.coming;r.showLoading(),r.ajaxLoad=i.ajax(i.extend({},e.ajax,{url:e.href,error:function(e,t){r.coming&&"abort"!==t?r._error("ajax",e):r.hideLoading()},success:function(t,i){"success"===i&&(e.content=t,r._afterLoad())}}))},_loadIframe:function(){var e=r.coming,t=i(e.tpl.iframe.replace(/\{rnd\}/g,(new Date).getTime())).attr("scrolling",c?"auto":e.iframe.scrolling).attr("src",e.href);i(e.wrap).bind("onReset",function(){try{i(this).find("iframe").hide().attr("src","//about:blank").end().empty()}catch(e){}}),e.iframe.preload&&(r.showLoading(),t.one("load",function(){i(this).data("ready",1),c||i(this).bind("load.fb",r.update),i(this).parents(".fancybox-wrap").width("100%").removeClass("fancybox-tmp").show(),r._afterLoad()})),e.content=t.appendTo(e.inner),e.iframe.preload||r._afterLoad()},_preloadImages:function(){var e,t,i=r.group,n=r.current,s=i.length,o=n.preload?Math.min(n.preload,s-1):0;for(t=1;o>=t;t+=1)e=i[(n.index+t)%s],"image"===e.type&&e.href&&((new Image).src=e.href)},_afterLoad:function(){var e,t,n,s,o,a,l=r.coming,d=r.current,c="fancybox-placeholder";if(r.hideLoading(),l&&r.isActive!==!1){if(!1===r.trigger("afterLoad",l,d))return l.wrap.stop(!0).trigger("onReset").remove(),r.coming=null,void 0;switch(d&&(r.trigger("beforeChange",d),d.wrap.stop(!0).removeClass("fancybox-opened").find(".fancybox-item, .fancybox-nav").remove()),r.unbindEvents(),e=l,t=l.content,n=l.type,s=l.scrolling,i.extend(r,{wrap:e.wrap,skin:e.skin,outer:e.outer,inner:e.inner,current:e,previous:d}),o=e.href,n){case"inline":case"ajax":case"html":e.selector?t=i("<div>").html(t).find(e.selector):p(t)&&(t.data(c)||t.data(c,i('<div class="'+c+'"></div>').insertAfter(t).hide()),t=t.show().detach(),e.wrap.bind("onReset",function(){i(this).find(t).length&&t.hide().replaceAll(t.data(c)).data(c,!1)}));break;case"image":t=e.tpl.image.replace("{href}",o);break;case"swf":t='<object id="fancybox-swf" classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" width="100%" height="100%"><param name="movie" value="'+o+'"></param>',a="",i.each(e.swf,function(e,i){t+='<param name="'+e+'" value="'+i+'"></param>',a+=" "+e+'="'+i+'"'}),t+='<embed src="'+o+'" type="application/x-shockwave-flash" width="100%" height="100%"'+a+"></embed></object>"}p(t)&&t.parent().is(e.inner)||e.inner.append(t),r.trigger("beforeShow"),e.inner.css("overflow","yes"===s?"scroll":"no"===s?"hidden":s),r._setDimension(),r.reposition(),r.isOpen=!1,r.coming=null,r.bindEvents(),r.isOpened?d.prevMethod&&r.transitions[d.prevMethod]():i(".fancybox-wrap").not(e.wrap).stop(!0).trigger("onReset").remove(),r.transitions[r.isOpened?e.nextMethod:e.openMethod](),r._preloadImages()}},_setDimension:function(){var e,t,n,s,o,a,l,d,c,p,u,f,v,y,w,x=r.getViewport(),b=0,S=!1,C=!1,T=r.wrap,k=r.skin,M=r.inner,L=r.current,_=L.width,E=L.height,P=L.minWidth,A=L.minHeight,O=L.maxWidth,I=L.maxHeight,D=L.scrolling,z=L.scrollOutside?L.scrollbarWidth:0,H=L.margin,R=g(H[1]+H[3]),W=g(H[0]+H[2]);if(T.add(k).add(M).width("auto").height("auto").removeClass("fancybox-tmp"),e=g(k.outerWidth(!0)-k.width()),t=g(k.outerHeight(!0)-k.height()),n=R+e,s=W+t,o=h(_)?(x.w-n)*g(_)/100:_,a=h(E)?(x.h-s)*g(E)/100:E,"iframe"===L.type){if(y=L.content,L.autoHeight&&1===y.data("ready"))try{y[0].contentWindow.document.location&&(M.width(o).height(9999),w=y.contents().find("body"),z&&w.css("overflow-x","hidden"),a=w.outerHeight(!0))}catch(j){}}else(L.autoWidth||L.autoHeight)&&(M.addClass("fancybox-tmp"),L.autoWidth||M.width(o),L.autoHeight||M.height(a),L.autoWidth&&(o=M.width()),L.autoHeight&&(a=M.height()),M.removeClass("fancybox-tmp"));if(_=g(o),E=g(a),c=o/a,P=g(h(P)?g(P,"w")-n:P),O=g(h(O)?g(O,"w")-n:O),A=g(h(A)?g(A,"h")-s:A),I=g(h(I)?g(I,"h")-s:I),l=O,d=I,L.fitToView&&(O=Math.min(x.w-n,O),I=Math.min(x.h-s,I)),f=x.w-R,v=x.h-W,L.aspectRatio?(_>O&&(_=O,E=g(_/c)),E>I&&(E=I,_=g(E*c)),P>_&&(_=P,E=g(_/c)),A>E&&(E=A,_=g(E*c))):(_=Math.max(P,Math.min(_,O)),L.autoHeight&&"iframe"!==L.type&&(M.width(_),E=M.height()),E=Math.max(A,Math.min(E,I))),L.fitToView)if(M.width(_).height(E),T.width(_+e),p=T.width(),u=T.height(),L.aspectRatio)for(;(p>f||u>v)&&_>P&&E>A&&!(b++>19);)E=Math.max(A,Math.min(I,E-10)),_=g(E*c),P>_&&(_=P,E=g(_/c)),_>O&&(_=O,E=g(_/c)),M.width(_).height(E),T.width(_+e),p=T.width(),u=T.height();else _=Math.max(P,Math.min(_,_-(p-f))),E=Math.max(A,Math.min(E,E-(u-v)));z&&"auto"===D&&a>E&&f>_+e+z&&(_+=z),M.width(_).height(E),T.width(_+e),p=T.width(),u=T.height(),S=(p>f||u>v)&&_>P&&E>A,C=L.aspectRatio?l>_&&d>E&&o>_&&a>E:(l>_||d>E)&&(o>_||a>E),i.extend(L,{dim:{width:m(p),height:m(u)},origWidth:o,origHeight:a,canShrink:S,canExpand:C,wPadding:e,hPadding:t,wrapSpace:u-k.outerHeight(!0),skinSpace:k.height()-E}),!y&&L.autoHeight&&E>A&&I>E&&!C&&M.height("auto")},_getPosition:function(e){var t=r.current,i=r.getViewport(),n=t.margin,s=r.wrap.width()+n[1]+n[3],o=r.wrap.height()+n[0]+n[2],a={position:"absolute",top:n[0],left:n[3]};return t.autoCenter&&t.fixed&&!e&&o<=i.h&&s<=i.w?a.position="fixed":t.locked||(a.top+=i.y,a.left+=i.x),a.top=m(Math.max(a.top,a.top+(i.h-o)*t.topRatio)),a.left=m(Math.max(a.left,a.left+(i.w-s)*t.leftRatio)),a},_afterZoomIn:function(){var e=r.current;e&&(r.isOpen=r.isOpened=!0,r.wrap.css("overflow","visible").addClass("fancybox-opened"),r.update(),(e.closeClick||e.nextClick&&r.group.length>1)&&r.inner.css("cursor","pointer").bind("click.fb",function(t){i(t.target).is("a")||i(t.target).parent().is("a")||(t.preventDefault(),r[e.closeClick?"close":"next"]())}),e.closeBtn&&i(e.tpl.closeBtn).appendTo(r.skin).bind("click.fb",function(e){e.preventDefault(),r.close()}),e.arrows&&r.group.length>1&&((e.loop||e.index>0)&&i(e.tpl.prev).appendTo(r.outer).bind("click.fb",r.prev),(e.loop||e.index<r.group.length-1)&&i(e.tpl.next).appendTo(r.outer).bind("click.fb",r.next)),r.trigger("afterShow"),e.loop||e.index!==e.group.length-1?r.opts.autoPlay&&!r.player.isActive&&(r.opts.autoPlay=!1,r.play()):r.play(!1))},_afterZoomOut:function(e){e=e||r.current,i(".fancybox-wrap").trigger("onReset").remove(),i.extend(r,{group:{},opts:{},router:!1,current:null,isActive:!1,isOpened:!1,isOpen:!1,isClosing:!1,wrap:null,skin:null,outer:null,inner:null}),r.trigger("afterClose",e)}}),r.transitions={getOrigPosition:function(){var e=r.current,t=e.element,i=e.orig,n={},s=50,o=50,a=e.hPadding,l=e.wPadding,d=r.getViewport();return!i&&e.isDom&&t.is(":visible")&&(i=t.find("img:first"),i.length||(i=t)),p(i)?(n=i.offset(),i.is("img")&&(s=i.outerWidth(),o=i.outerHeight())):(n.top=d.y+(d.h-o)*e.topRatio,n.left=d.x+(d.w-s)*e.leftRatio),("fixed"===r.wrap.css("position")||e.locked)&&(n.top-=d.y,n.left-=d.x),n={top:m(n.top-a*e.topRatio),left:m(n.left-l*e.leftRatio),width:m(s+l),height:m(o+a)}},step:function(e,t){var i,n,s,o=t.prop,a=r.current,l=a.wrapSpace,d=a.skinSpace;("width"===o||"height"===o)&&(i=t.end===t.start?1:(e-t.start)/(t.end-t.start),r.isClosing&&(i=1-i),n="width"===o?a.wPadding:a.hPadding,s=e-n,r.skin[o](g("width"===o?s:s-l*i)),r.inner[o](g("width"===o?s:s-l*i-d*i)))},zoomIn:function(){var e=r.current,t=e.pos,n=e.openEffect,s="elastic"===n,o=i.extend({opacity:1},t);delete o.position,s?(t=this.getOrigPosition(),e.openOpacity&&(t.opacity=.1)):"fade"===n&&(t.opacity=.1),r.wrap.css(t).animate(o,{duration:"none"===n?0:e.openSpeed,easing:e.openEasing,step:s?this.step:null,complete:r._afterZoomIn})},zoomOut:function(){var e=r.current,t=e.closeEffect,i="elastic"===t,n={opacity:.1};i&&(n=this.getOrigPosition(),e.closeOpacity&&(n.opacity=.1)),r.wrap.animate(n,{duration:"none"===t?0:e.closeSpeed,easing:e.closeEasing,step:i?this.step:null,complete:r._afterZoomOut})},changeIn:function(){var e,t=r.current,i=t.nextEffect,n=t.pos,s={opacity:1},o=r.direction,a=200;n.opacity=.1,"elastic"===i&&(e="down"===o||"up"===o?"top":"left","down"===o||"right"===o?(n[e]=m(g(n[e])-a),s[e]="+="+a+"px"):(n[e]=m(g(n[e])+a),s[e]="-="+a+"px")),"none"===i?r._afterZoomIn():r.wrap.css(n).animate(s,{duration:t.nextSpeed,easing:t.nextEasing,complete:r._afterZoomIn})},changeOut:function(){var e=r.previous,t=e.prevEffect,n={opacity:.1},s=r.direction,o=200;"elastic"===t&&(n["down"===s||"up"===s?"top":"left"]=("up"===s||"left"===s?"-":"+")+"="+o+"px"),e.wrap.animate(n,{duration:"none"===t?0:e.prevSpeed,easing:e.prevEasing,complete:function(){i(this).trigger("onReset").remove()}})}},r.helpers.overlay={defaults:{closeClick:!0,speedOut:200,showEarly:!0,css:{},locked:!c,fixed:!0},overlay:null,fixed:!1,el:i("html"),create:function(e){e=i.extend({},this.defaults,e),this.overlay&&this.close(),this.overlay=i('<div class="fancybox-overlay"></div>').appendTo(r.coming?r.coming.parent:e.parent),this.fixed=!1,e.fixed&&r.defaults.fixed&&(this.overlay.addClass("fancybox-overlay-fixed"),this.fixed=!0)},open:function(e){var t=this;e=i.extend({},this.defaults,e),this.overlay?this.overlay.unbind(".overlay").width("auto").height("auto"):this.create(e),this.fixed||(o.bind("resize.overlay",i.proxy(this.update,this)),this.update()),e.closeClick&&this.overlay.bind("click.overlay",function(e){return i(e.target).hasClass("fancybox-overlay")?(r.isActive?r.close():t.close(),!1):void 0}),this.overlay.css(e.css).show()},close:function(){var e,t;o.unbind("resize.overlay"),this.el.hasClass("fancybox-lock")&&(i(".fancybox-margin").removeClass("fancybox-margin"),e=o.scrollTop(),t=o.scrollLeft(),this.el.removeClass("fancybox-lock"),o.scrollTop(e).scrollLeft(t)),i(".fancybox-overlay").remove().hide(),i.extend(this,{overlay:null,fixed:!1})},update:function(){var e,i="100%";this.overlay.width(i).height("100%"),l?(e=Math.max(t.documentElement.offsetWidth,t.body.offsetWidth),a.width()>e&&(i=a.width())):a.width()>o.width()&&(i=a.width()),this.overlay.width(i).height(a.height())},onReady:function(e,t){var n=this.overlay;i(".fancybox-overlay").stop(!0,!0),n||this.create(e),e.locked&&this.fixed&&t.fixed&&(n||(this.margin=a.height()>o.height()?i("html").css("margin-right").replace("px",""):!1),t.locked=this.overlay.append(t.wrap),t.fixed=!1),e.showEarly===!0&&this.beforeShow.apply(this,arguments)},beforeShow:function(e,t){var n,s;t.locked&&(this.margin!==!1&&(i("*").filter(function(){return"fixed"===i(this).css("position")&&!i(this).hasClass("fancybox-overlay")&&!i(this).hasClass("fancybox-wrap")}).addClass("fancybox-margin"),this.el.addClass("fancybox-margin")),n=o.scrollTop(),s=o.scrollLeft(),this.el.addClass("fancybox-lock"),o.scrollTop(n).scrollLeft(s)),this.open(e)},onUpdate:function(){this.fixed||this.update()},afterClose:function(e){this.overlay&&!r.coming&&this.overlay.fadeOut(e.speedOut,i.proxy(this.close,this))}},r.helpers.title={defaults:{type:"float",position:"bottom"},beforeShow:function(e){var t,n,s=r.current,o=s.title,a=e.type;if(i.isFunction(o)&&(o=o.call(s.element,s)),u(o)&&""!==i.trim(o)){switch(t=i('<div class="fancybox-title fancybox-title-'+a+'-wrap">'+o+"</div>"),a){case"inside":n=r.skin;break;case"outside":n=r.wrap;break;case"over":n=r.inner;break;default:n=r.skin,t.appendTo("body"),l&&t.width(t.width()),t.wrapInner('<span class="child"></span>'),r.current.margin[2]+=Math.abs(g(t.css("margin-bottom")))}t["top"===e.position?"prependTo":"appendTo"](n)}}},i.fn.fancybox=function(e){var t,n=i(this),s=this.selector||"",o=function(o){var a,l,d=i(this).blur(),c=t;o.ctrlKey||o.altKey||o.shiftKey||o.metaKey||d.is(".fancybox-wrap")||(a=e.groupAttr||"data-fancybox-group",l=d.attr(a),l||(a="rel",l=d.get(0)[a]),l&&""!==l&&"nofollow"!==l&&(d=s.length?i(s):n,d=d.filter("["+a+'="'+l+'"]'),c=d.index(this)),e.index=c,r.open(d,e)!==!1&&o.preventDefault())};return e=e||{},t=e.index||0,s&&e.live!==!1?a.undelegate(s,"click.fb-start").delegate(s+":not('.fancybox-item, .fancybox-nav')","click.fb-start",o):n.unbind("click.fb-start").bind("click.fb-start",o),this.filter("[data-fancybox-start=1]").trigger("click"),this},a.ready(function(){var t,o;i.scrollbarWidth===n&&(i.scrollbarWidth=function(){var e=i('<div style="width:50px;height:50px;overflow:auto"><div/></div>').appendTo("body"),t=e.children(),n=t.innerWidth()-t.height(99).innerWidth();return e.remove(),n}),i.support.fixedPosition===n&&(i.support.fixedPosition=function(){var e=i('<div style="position:fixed;top:20px;"></div>').appendTo("body"),t=20===e[0].offsetTop||15===e[0].offsetTop;return e.remove(),t}()),i.extend(r.defaults,{scrollbarWidth:i.scrollbarWidth(),fixed:i.support.fixedPosition,parent:i("body")}),t=i(e).width(),s.addClass("fancybox-lock-test"),o=i(e).width(),s.removeClass("fancybox-lock-test"),i("<style type='text/css'>.fancybox-margin{margin-right:"+(o-t)+"px;}</style>").appendTo("head")})}(window,document,jQuery);
 
         $(document).ready(function() {
 
         $(document).ready(function() {
 
              
 
              

Revision as of 08:27, 25 July 2018

Overview

Method And Materials

Results

Method And Materials

OD 600 Reference point

❏ Add 100μl LUDOX into wells A1, B1, C1, D1
❏ Add 100μl of dd H2O into wells A2, B2, C2, D2
❏ Measure absorbance at 600 nm of all samples in the measurement mode you plan to use for cell measurements
❏ Record the data in the table below or in your notebook
❏ Import data into Excel sheet provided (OD600 reference point tab)

Particle Standard Curve

❏ Obtain the tube labeled ”Silica Beads” from the InterLab test kit and vortex vigorously for 30 seconds.
❏ Immediately pipet 96 μL microspheres into a 1.5 mL eppendorf tube
❏ Add 904μL of ddH2O to the microspheres
❏ Vortex well. This is your Microsphere Stock Solution.
❏ Repeat dilution series for rows B, C, D
❏ Re-Mix (Pipette up and down) each row of plate immediately before putting in the plate reader
❏ Measure Abs600 of all samples in instrument
❏ Record the data in your notebook
❏ Import data into Excel sheet provided (particle standard curve tab)

Fluorescence standard curve

❏ Spin down fluorescein kit tube to make sure pellet is at the bottom of tube.
❏ Prepare 10x fluorescein stock solution (100 μM) by resuspending fluorescein in 1 mL of 1xPBS.
❏ Dilute the 10x fluorescein stock solution with 1xPBS to make a 1x fluorescein solution with concentration 10 μM: 100 μL of 10x fluorescein stock into 900 μL 1x PBS
❏ Add 100 μl of PBS into wells A2, B2, C2, D2....A12, B12, C12, D12
❏ Add 200 μl of fluorescein 1x stock solution into A1, B1, C1, D1
❏ Transfer 100 μl of fluorescein stock solution from A1 into A2.
❏ Mix A2 by pipetting up and down 3x and transfer 100 μl into A3…
❏ Mix A3 by pipetting up and down 3x and transfer 100 μl into A4...
❏ Mix A4 by pipetting up and down 3x and transfer 100 μl into A5...
❏ Mix A5 by pipetting up and down 3x and transfer 100 μl into A6...
❏ Mix A6 by pipetting up and down 3x and transfer 100 μl into A7...
❏ Mix A7 by pipetting up and down 3x and transfer 100 μl into A8...
❏ Mix A8 by pipetting up and down 3x and transfer 100 μl into A9...
❏ Mix A9 by pipetting up and down 3x and transfer 100 μl into A10...
❏ Mix A10 by pipetting up and down 3x and transfer 100 μl into A11...
❏ Mix A11 by pipetting up and down 3x and transfer 100 μl into liquid waste
❏ Repeat dilution series for rows B, C, D
❏ Measure fluorescence of all samples in instrument
❏ Record the data in your notebook
❏ Import data into Excel sheet provided (fluorescein standard curve tab)

Competent cells and Transformation

❏ Resuspend DNA in selected wells in the Distribution Kit with 10µl dH20.
❏ Thaw competent cells on ice
❏ Pipette 50µl of competent cells into 1.5ml tube
❏ Pipette 1µl of resuspended DNA into 1.5ml tube
❏ Pipette 1µl of control DNA into 2ml tube
❏ Close 1.5ml tubes, incubate on ice for 30min
❏ Heat shock tubes at 42°C for 45 sec
❏ Incubate on ice for 5min
❏ Pipette 950µl SOC media to each transformation
❏ Incubate at 37°C for 1 hours, shaking at 200-300rpm
❏ Pipette 100µL of each transformation onto petri plates
❏ Spin down cells at 6800g for 3mins and discard 800µL of the supernatant. Resuspend the cells in the remaining 100µL, and pipette each transformation onto petri plates
❏ Incubate transformations overnight (14-18hr) at 37°C
❏ Pick single colonies for PCR
❏ Count colonies for control transformation

Cell measurement

❏ Pick 2 colonies from each of the transformation plates and inoculate in 5-10 mL LB medium +Chloramphenicol. Grow the cells overnight (16-18 hours) at 37°C and 220 rpm
❏ Make a 1:10 dilution of each overnight culture in LB+Chloramphenicol (0.5mL of culture into 4.5mL of LB+Chlor)
❏ Measure Abs 600 of these 1:10 diluted cultures
❏ Record the data in your notebook
❏ Dilute the cultures further to a target Abs600 of 0.02 in a final volume of 12 ml LB medium + Chloramphenicol in 50 mL falcon tube (amber, or covered with foil to block light).
❏ Take 500 µL samples of the diluted cultures at 0 hours into 1.5 ml eppendorf tubes, prior to incubation. (At each time point 0 hours and 6 hours, you will take a sample from each of the 8 devices, two colonies per device, for a total of 16 eppendorf tubes with 500 µL samples per time point, 32 samples total). Place the samples on ice.
❏ Incubate the remainder of the cultures at 37°C and 220 rpm for 6 hours.
❏ Take 500 µL samples of the cultures at 6 hours of incubation into 1.5 ml eppendorf tubes. Place samples on ice.
❏ At the end of sampling point you need to measure your samples (Abs 600 and fluorescence measurement), see the below for details.
❏ Record data in your notebook
❏ Import data into Excel sheet provided (fluorescence measurement tab)

CFU per 0.1 OD600 E. coli cultures

❏ culture colonies for two Positive Control (BBa_I20270) cultures and your two Negative Control (BBa_R0040) cultures for 16-18 hours
❏ Dilute the overnight culture to OD600 = 0.1 in 1mL of LB + Cam media. Do this in triplicate for each culture. Check the OD600 and make sure it is 0.1
❏ Aseptically spead plate 100 μL on LB + Cam plates for those Final Dilution Factor is 8 x 104 or 8 x 105 or 8 x 106
❏ Incubate at 37°C overnight and count colonies after 18-20 hours of growth
❏ Count the colonies on each plate with fewer than 300 colonies. Multiple the colony count by the Final Dilution Factor on each plate.

HD Images

Competent cells (Escherichia coli strain DH5α)
1ml LUDOX CL-X (provided in kit)
300 μL Silica beads - Microsphere suspension (provided in kit, 4.7 x 10^8 microspheres)
LB (Luria Bertani) media
Fluorescein (provided in kit)
10ml 1xPBS pH 7.4-7.6 (phosphate buffered saline; provided by team)
Chloramphenicol (stock concentration 25 mg/mL dissolved in EtOH)
50 ml Falcon tube (or equivalent, preferably amber or covered in foil to block light)
Incubator at 37°C
1.5 ml eppendorf tubes for sample storage
Ice bucket with ice
Micropipettes and tips
96 well plate, black with clear flat bottom preferred (provided by team)

Devices (from Distribution Kit, all in pSB1C3 backbone):
Negative control BBa_R0040
Positive control BBa_I20270
Test Device 1 BBa_J364000
Test Device 2 BBa_J364001
Test Device 3 BBa_J364002
Test Device 4 BBa_J364007
Test Device 5 BBa_J364008
Test Device 6 BBa_J364009

Overview

Difficulty in taking reliable and reproducible measurements remains a key obstacle in establishing synthetic biology as an engineering discipline. The Measurement Committee, through the InterLab study, has been developing a robust measurement procedure for green fluorescent protein (GFP) over the last several years. Despite being one of the most commonly used markers in synthetic biology, labs often resort to making relative comparisons, which makes it difficult for labs to share and data and/or constructs.
The goal of the fifth iGEM InterLab Study is to identify and correct the sources of systematic variability in synthetic biology measurements by answering the question “Can we reduce lab-to-lab variability in fluorescence measurements by normalizing to absolute cell count or colony-forming units (CFUs) instead of OD? ”
As we know in the previous study, the fluorescence value measured by a plate reader is an aggregate measurement of an entire population of cells, we need to divide the total fluorescence by the number of cells in order to determine the mean expression level of GFP per cell. Due to the fact that the “optical density (OD) ” of the sample is an approximation of the number of cells varying from lab to lab, we decided to use a special silica beads that are roughly the same size and shape as a typical E. coli cell to set up a universal, standard “equivalent concentration of beads” measurement.

RESULTS

OD 600 Reference point

According to the Reference OD600, We calculate the final result:
OD600/Abs600=3.818
All cell density readings using this instrument with the same settings and volume can be converted to OD600, so that we can use this ratio to convert subsequent experimental data

Particle standard curve

We prepare a dilution series of monodisperse silica microspheres and measure the Abs 600 in plate reader. The size and optical characteristics of these microspheres are similar to cells, and there is a known amount of particles per volume. This measurement allows us to construct a standard curve of particle concentration which can be used to convert Abs 600 measurements to an estimated number of cells.
The final result:
mean of med-high levels=6.24E+08

Fluorescein standard curve

We prepare a dilution series of fluorescein in four replicates and measure the fluorescence in a 96 well plate in plate reader. By measuring these we generate a standard curve of fluorescence for fluorescein concentration. We will be able to use this to convert our cell based readings to an equivalent fluorescein concentration.
The final result:
Mean uM fluorescein / a.u.=3.60E-05
MEFL / a.u.=2.17E+08

Fluorescence Raw Readings

Abs600 Raw Readings