美文网首页
仿朋友圈特效

仿朋友圈特效

作者: 积_渐 | 来源:发表于2018-09-04 10:02 被阅读27次

    1.html代码

    <!DOCTYPE html>
    <html>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>我的朋友圈</title>
    <meta charset="utf-8">
    <meta name="viewport" content="initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no">
    
    <link type="text/css" rel="stylesheet" href="css/app.css">
    
    <script type="text/javascript" src="js/jquery.min.js"></script>
    <script type="text/javascript" src="js/rem.js"></script>
    
    <link rel="stylesheet" type="text/css" href="css/swiper.min.css"/>
    
    <script type="text/javascript" src="js/swiper.min.js"></script>
    
    </head>
    <body>
    <div id="main">
      <div id="list">
        <ul>
          <li>
            <div class="po-avt-wrap"> <img class="po-avt data-avt" src="picture/0.jpg"> </div>
            <div class="po-cmt">
              <div class="po-hd">
                <p class="po-name"><span class="data-name">张三</span></p>
                <div class="post">
                  <p>大家好,听说国内冻成狗🐶?我这边还挺热~</p>
                  <p> <img class="list-img" src="picture/jt1.jpg" style="height: 80px;"> <img class="list-img" src="picture/yt3.jpg" style="height: 80px;"> <img class="list-img data-avt" src="picture/0.jpg" style="height: 80px;"> <img class="list-img data-avt" src="picture/guide2.png" style="height: 80px;"> </p>
                </div>
                <p class="time">刚刚</p>
                <div class="tc1"> <img class="c-icon" src="picture/c.png">
                  <div class="tc2"><span class="zan"><span>赞</span></span> <span class="pinglun"><span>评论</span></span></div>
                </div>
              </div>
              <div class="r"></div>
              <div class="cmt-wrap">
                <div class="like"><img src="picture/l.png">空空空,陈冠希,杨幂,王思聪,陈赫,刘德华,马云...</div>
                <div class="cmt-list">
                  <p><span>wu世勋-EXO:</span>나는 서명~</p>
                  <p><span>鹿晗:</span>我们在国内冻成狗,我也想跟哥您去热热~</p>
                  <p><span>权志龙:</span>나는 서명~</p>
                  <p><span>王思聪:</span>去哪玩啊?那么爽</p>
                  <p> <span class="data-name">张三</span> 回复 <span> 王思聪 </span> <span> : </span> 澳洲大堡礁,这边刚好是夏季,挺适合避寒的。 </p>
                  <p><span>杨幂:</span>😘私人飞机出行,求带上我~</p>
                </div>
              </div>
            </div>
          </li>
          <li>
            <div class="po-avt-wrap"> <img class="po-avt" src="picture/n5.jpg"> </div>
            <div class="po-cmt">
              <div class="po-hd">
                <p class="po-name"> 王思聪 </p>
                <div class="post">
                  <p> 那一年这兄弟三人发誓一定要出人头地 <br>
                    以后有福同享有难同当 <br>
                    如今: <br>
                    大哥只手遮天万人之上 <br>
                    二哥黄金万两富甲一方 <br>
                    三弟淡泊名利为人低调 </p>
                  <img class="list-img" src="picture/xa1.jpg" style="height: 80px;"> <img class="list-img" src="picture/ma1.jpg" style="height: 80px;"> <img class="data-avt list-img" src="picture/0.jpg" style="height: 80px;"> </div>
                <p class="time"> 1分钟前 </p>
                <div class="tc1"> <img class="c-icon" src="picture/c.png">
                  <div class="tc2"><span class="zan"><span>赞</span></span> <span class="pinglun"><span>评论</span></span></div>
                </div>
              </div>
              <div class="r"> </div>
              <div class="cmt-wrap">
                <div class="like"> <img src="picture/l.png"> 鹿晗,林更新,杨幂,angelababy,范冰冰... </div>
                <div class="cmt-list">
                  <p> <span> 鹿晗: </span> 赞! </p>
                  <p> <span class="data-name">张三</span> <span> : </span> 低调低调。。 </p>
                  <p> <span> 王思聪 </span> 回复 <span class="data-name">张三</span> <span> : </span> 哥您就是太低调了 </p>
                  <p> <span> 习 </span> 回复 <span class="data-name">张三</span> <span> : </span> 好几天没见,我们该聚聚了 </p>
                  <p> <span> 马云 </span> 回复 <span class="data-name">张三</span> <span> : </span> 有笔大生意找你聊聊 </p>
                </div>
              </div>
            </div>
          </li>
          <li>
            <div class="po-avt-wrap"> <img class="po-avt" src="picture/a1.jpg"> </div>
            <div class="po-cmt">
              <div class="po-hd">
                <p class="po-name"> 空空空 </p>
                <p class="post"> 还是好困~ <img src="picture/c1.jpg"> </p>
                <p class="time"> 2分钟前 </p>
                <div class="tc1"> <img class="c-icon" src="picture/c.png">
                  <div class="tc2"><span class="zan"><span>赞</span></span> <span class="pinglun"><span>评论</span></span></div>
                </div>
                <div class="r"> </div>
                <div class="cmt-wrap">
                  <div class="like"> <img src="picture/l.png"> 陈赫,叫兽易小星,王思聪,陈冠希,余文乐... </div>
                  <div class="cmt-list">
                    <p> <span> 陈赫: </span> 怪我咯~ </p>
                    <p> <span> 陈冠希: </span> 怪我咯~ </p>
                    <p> <span class="data-name">张三</span> <span> : </span> 怪我咯~ </p>
                    <p> <span> 空空空 </span> 回复 <span class="data-name">张三</span> <span> : </span> 知道就好! </p>
                  </div>
                </div>
              </div>
            </div>
          </li>
          <li>
            <div class="po-avt-wrap"> <img class="po-avt" src="picture/a2.jpg"> </div>
            <div class="po-cmt">
              <div class="po-hd">
                <p class="po-name"> 周杰伦 </p>
                <div class="post">
                  <p> <b class="data-name">张三</b> ,决战夜你要加油!我们哎哟不错战队是最屌的! </p>
                  <img class="list-img" src="picture/c2.jpg" style="height: 80px;"> <img class="data-avt list-img" src="picture/0.jpg" style="height: 80px;"> </div>
                <p class="time"> 2分钟前 </p>
                <div class="tc1"> <img class="c-icon" src="picture/c.png">
                  <div class="tc2"><span class="zan"><span>赞</span></span> <span class="pinglun"><span>评论</span></span></div>
                </div>
              </div>
              <div class="r"> </div>
              <div class="cmt-wrap">
                <div class="like"> <img src="picture/l.png"> 汪峰,那英,庾澄庆 </div>
                <div class="cmt-list">
                  <p> <span class="data-name">张三</span> <span> : </span> 杰伦老师,决战夜小公举会来吗。~ </p>
                  <p> <span> 周杰伦 </span> 回复 <span class="data-name">张三</span> <span> : </span> 你拿冠军了,我让你当小公举的小王纸。 </p>
                </div>
              </div>
            </div>
          </li>
          <li>
            <div class="po-avt-wrap"> <img class="po-avt" src="picture/a5.jpg"> </div>
            <div class="po-cmt">
              <div class="po-hd">
                <p class="ads">推广<img src="picture/ads.png"></p>
                <p class="po-name">金猫银猫CSmall官方</p>
                <div class="post">金猫银猫CSmall情人节买珠宝赠永生花专场
                  <p><a class="ad-link" href="http://m.csmall.com/activity/3914.html">查看详情 <img src="picture/link.png"></a></p>
                  <a href="http://m.csmall.com/activity/3914.html"><img class="noplayimg" src="picture/asd888.jpg"></a></div>
                <p class="time">45分钟前</p>
                <div class="tc1"> <img class="c-icon" src="picture/c.png">
                  <div class="tc2"><span class="zan"><span>赞</span></span> <span class="pinglun"><span>评论</span></span></div>
                </div>
              </div>
              <div class="r"></div>
              <div class="cmt-wrap">
                <div class="like"><img src="picture/l.png">范冰冰,李晨,王思聪,王健林,...</div>
                <div class="cmt-list">
                  <p><span>范冰冰:</span>珠宝再加上永生花,花永生,爱永恒,想想都觉得好浪漫哦~<img class="bq" src="picture/bq1.png"></p>
                  <p><span>李晨</span>回复<span>范冰冰 :</span>小肥羊~初七情人节见!定格我们的爱情吧❤</p>
                  <p><span>王思聪:</span>我女朋友多,团购才能搞定啊!</p>
                </div>
              </div>
            </div>
          </li>
          <li>
            <div class="po-avt-wrap"> <img class="po-avt" src="picture/a3.jpg"> </div>
            <div class="po-cmt">
              <div class="po-hd">
                <p class="po-name"> 邓超 </p>
                <div class="post">
                  <p> we are伐木累!欢迎加入跑男第三季! </p>
                  <p> <img class="list-img" src="picture/c3.jpg" style="height: 80px;"> <img class="list-img" src="picture/c4.jpg" style="height: 80px;"> <img class="data-avt list-img" src="picture/0.jpg" style="height: 80px;"> </p>
                </div>
                <p class="time"> 50分钟前 </p>
                <div class="tc1"> <img class="c-icon" src="picture/c.png">
                  <div class="tc2"><span class="zan"><span>赞</span></span> <span class="pinglun"><span>评论</span></span></div>
                </div>
              </div>
              <div class="r"> </div>
              <div class="cmt-wrap">
                <div class="like"> <img src="picture/l.png"> <b class="data-name">张三</b> </div>
                <div class="cmt-list">
                  <p> <span class="data-name">张三</span> <span> : </span> 超哥,当初为什么要选我。 </p>
                  <p> <span> 邓超 </span> 回复 <span class="data-name">张三</span> <span> : </span> 你是我认识的人当中,最快的! </p>
                </div>
              </div>
            </div>
          </li>
          <li>
            <div class="po-avt-wrap"> <img class="po-avt" src="picture/a4.jpg"> </div>
            <div class="po-cmt">
              <div class="po-hd">
                <p class="po-name"> 范冰冰 </p>
                <p class="post"> 我的生日趴,你为什么不来 <img class="data-avt" src="picture/0.jpg"> </p>
                <p class="time"> 52分钟前 </p>
                <div class="tc1"> <img class="c-icon" src="picture/c.png">
                  <div class="tc2"><span class="zan"><span>赞</span></span> <span class="pinglun"><span>评论</span></span></div>
                </div>
              </div>
              <div class="r"> </div>
              <div class="cmt-wrap">
                <div class="like"> <img src="picture/l.png"> <b class="data-name">张三</b> ,李晨,李治廷,黎明... </div>
                <div class="cmt-list">
                  <p> <span> 李晨: </span> 呵呵。 </p>
                  <p> <span class="data-name">张三</span> <span> : </span> 最近忙,就酱。 </p>
                </div>
              </div>
            </div>
          </li>
          <li>
            <div class="po-avt-wrap"> <img class="po-avt" src="picture/a7.jpg"> </div>
            <div class="po-cmt">
              <div class="po-hd">
                <p class="po-name"> 金星 </p>
                <p class="post"> 完美! <img src="picture/c8.jpg"> </p>
                <p class="time"> 55分钟前 </p>
                <div class="tc1"> <img class="c-icon" src="picture/c.png">
                  <div class="tc2"><span class="zan"><span>赞</span></span> <span class="pinglun"><span>评论</span></span></div>
                </div>
              </div>
              <div class="r"> </div>
              <div class="cmt-wrap">
                <div class="cmt-list">
                  <p> <span class="data-name">张三</span> <span> : </span> 星姐,求虐! </p>
                  <p> <span> 金星 </span> 回复 <span class="data-name">张三</span> <span> : </span> 你呢,人长的挺好看,就是偏偏要靠才华。 </p>
                </div>
              </div>
            </div>
          </li>
        </ul>
      </div>
    </div>
    
    <div class="big_img">
        <div class="swiper-container2">
          <div class="swiper-wrapper">
           
          </div>
        </div>
        <div class="swiper-pagination2"></div>
    </div>
    
    <script>
    $(document).ready(function(){
      /*调起大图 S*/
       var mySwiper = new Swiper('.swiper-container2', {
            loop: false,
            pagination: '.swiper-pagination2',
            })
        $("#list").on("click", ".post img", 
        function() {
            var imgBox = $(this).parents(".post").find("img");
            var i = $(imgBox).index(this);
            $(".big_img .swiper-wrapper").html("")
    
            for(var j = 0 ,c = imgBox.length; j < c ;j++){
             $(".big_img .swiper-wrapper").append('<div class="swiper-slide"><div class="cell"><img src="' + imgBox.eq(j).attr("src") + '" / ></div></div>');
            }
            mySwiper.updateSlidesSize();
            mySwiper.updatePagination();
            $(".big_img").css({
                "z-index": 1001,
                "opacity": "1"
            });
            mySwiper.slideTo(i, 0, false);
            return false;
        });
      
        $(".big_img").on("click", 
        function() {
            $(this).css({
                "z-index": "-1",
                "opacity": "0"
            });
    
        });
      });
      /*调起大图 E*/
    </script>
    
    </body>
    </html>
    

    2.css代码
    (1)app.css

    /**
     * Created by Administrator on 2016/1/31.
     */
    body { font-size:14px; }
    #list, #list li, .po-hd, .post { overflow: hidden }
     .po-cmt, .post .list-img:nth-child(1), .time {
     float: left
    }
    #list li, .cmt-wrap, .r, .time { clear: both }
    .btn, a { cursor: pointer }
    blockquote, body, code, dd, div, dl, dt, fieldset, form, h1, h2, h3, h4, h5, h6, input, legend, li, ol, p, pre, td, textarea, th, ul { margin: 0; padding: 0 }
    table { border-collapse: collapse; border-spacing: 0 }
    fieldset, img { border: 0 }
    address, caption, cite, code, dfn, em, strong, th, var { font-style: normal; font-weight: 400 }
    ol, ul { list-style: none none }
    caption, th { text-align: left }
    h1, h2, h3, h4, h5, h6 { font-size: 100%; font-weight: 400 }
     q::after, q::before {
     content: ""
    }
    abbr, acronym { border: 0; font-variant: normal }
    sup { vertical-align: text-top }
    sub { vertical-align: text-bottom }
    input, select, textarea { font-family: inherit; font-size: inherit; font-weight: inherit }
    legend { color: #000 }
    a { text-decoration: none }
    input { -webkit-appearance: none }
    * { -webkit-tap-highlight-color: transparent }
    html { background-color: #fff; font-family: Arial, sans-serif; font-size: 13px }
    .top { width:100%; position:fixed; left:0; top:0; z-index:3; }
    .top a { font-size:14px; line-height:40px; color:#fff; padding-left:12px; }
    .back a { padding-left:12px; }
    .back a:before { font-family: "iconfont"; content: "\e613"; font-size:14px; line-height:40px; color:#fff; overflow:hidden; zoom:1; }
    .back a span { text-indent:-500px; display:inline-block; }
    .bg1 { width:100%; height:40px; background:#000; position:fixed; left:0; top:0; z-index:2; filter:alpha(opacity=60); -moz-opacity:0.6; -khtml-opacity: 0.6; opacity: 0.6; }
    .camera { float:right; padding-right:12px; }
    .camera a:before { font-family: "iconfont"; content: "\e62a"; font-size:14px; line-height:40px; color:#fff; overflow:hidden; zoom:1; }
    .camera a span { display:none; }
    .tc1 { position:relative; }
    .tc2 { position:absolute; right:-100px; bottom:-23px; width:100px; height:30px; background:#000; z-index:2; transition:200ms;
    -moz-transition:200ms;  /* Firefox 4 */
    -webkit-transition:200ms;   /* Safari 和 Chrome */
    -o-transition:200ms;    /* Opera */ }
    .po-hd .show { right:20px; }
    .zan span, .pinglun span { font-size:12px; line-height:30px; color:#fff; vertical-align:top; padding-left:5px; }
    .zan:before { font-family: "iconfont"; content: "\e690"; font-size:12px; line-height:30px; color:#fff; vertical-align:middle; padding-left:8px; }
    .pinglun:before { font-family: "iconfont"; content: "\e690"; font-size:12px; line-height:30px; color:#fff; vertical-align:top; }
    .nav1 { width:100%; font-size:12px; height:1.2rem; position:fixed; left:0; bottom:0; z-index:999999; background:#f5f5f5; border-top:1px #ddd solid; /* For IE 8 */ -ms-filter: "progid:DXImageTransform.Microsoft.Shadow(Strength=4, Direction=135, Color='#999999')";     /* For IE 5.5 - 7 */ filter: progid:DXImageTransform.Microsoft.Shadow(Strength=4, Direction=135, Color='#999999'); }
    .nav1 li { width:20%; float:left; text-align:center; padding-top:0.12rem; }
    .nav1 li a { font-size:0.26rem; line-height:0.4rem; color:#949494; }
    .nav1 li img { width:0.36rem; }
    .nav1 .li1 img { width:0.9rem; margin-top:-0.5rem; border:0.08rem #f5f5f5 solid; border-radius:0.555rem; -moz-box-shadow: 0 0 10px 0px #999;  /* For IE 8 */ -ms-filter: "progid:DXImageTransform.Microsoft.Shadow(Strength=4, Direction=135, Color='#999999')";     /* For IE 5.5 - 7 */ filter: progid:DXImageTransform.Microsoft.Shadow(Strength=4, Direction=135, Color='#999999'); }
     @media screen and (min-width:350px) {
     html {
     font-size: 15px
    }
     .cmt-wrap {
     font-size: 14px
    }
     .time {
     font-size: 13px
    }
    }
    .hide { display: none }
    header { position: relative }
    #avt, #user-name { position: absolute }
    #bg { width: 100% }
    #user-name { text-align: right; right: 114px; bottom: 15px; color: #fff; font-weight: 700; font-size: 15px; text-shadow: 0 1px .5px #000 }
    #share a, .btn { font-size: 14px }
    .btn, b { font-weight: 400 }
    #share a, #share p, .btn { text-align: center }
    #avt { width: 74px; height: 74px; border: 1px solid #dbdbdb; right: 15px; bottom: -22px; padding: 1px; background-color: #fff }
    #list li, .po-hd { position: relative; padding-bottom:3px; }
    #list { padding: 30px 0 10px }
    #list li { line-height: 1.5; border-bottom: 1px solid #e2e2e2; margin-top: 15px; padding-bottom: 15px }
     #share a:nth-child(2), .ads, .po-avt {
     position: absolute
    }
    .ads { color: #999; right: 5px; top: 0 }
    .ads img { width: 10px; padding-left: 8px }
    .ad-link { color: #3b5384 }
    .post .ad-link img { width: 11px; padding: 0; display: inline-block }
    .po-avt-wrap { padding-left: 10px }
    .po-avt { width: 40px; height: 40px; top: 0; left: 10px }
    .r { border-bottom: 8px solid #eee; border-left: 8px solid transparent; border-right: 8px solid transparent; width: 1px; margin-top: 5px; margin-left: 10px }
    .po-cmt { padding-left: 60px; padding-right: 10px; width: 100%; box-sizing: border-box }
    .po-name { color: #576b95 }
    .post { color: #252525; padding-bottom: 10px }
    .post img { padding: 10px 5px 0 0; display: block; max-height: 130px; max-width: 130px }
    #share a, .btn { display: inline-block }
    .post .list-img { width: 30%; max-height: 80px; max-width: 80px; padding-right: 5px; float: left; object-fit: cover }
    .post .list-img:last-child { padding-right: 0 }
    .time { color: #b1b1b1 }
    .c-icon { width: 20px; float: right; position:relative; z-index:3; }
    .cmt-wrap { width: 100%; background-color: #f8f8f8 }
    .like { color: #576b95; padding: 5px 5px 3px 12px }
    .like img { width: 12px; padding-right: 5px }
    .cmt-list { padding: 5px 12px; color: #454545 }
    .cmt-list p { padding-top: 3px }
    .cmt-list span { color: #3b5384 }
    #share a { border-radius: 5px; background-color: #26337e; color: #fff; line-height: 2.5; width: 138px; margin: 0 10px }
     #share a:nth-child(1) {
     position: absolute;
     left: 50%;
     margin-left: -148px
    }
     #share a:nth-child(2) {
     right: 50%;
     margin-right: -148px
    }
    #share p { padding: 45px 0 10px; color: #999 }
    #guide { position: fixed; left: 0; top: 0; bottom: 0; right: 0; width: 100%; height: 100%; z-index: 9999; background-image: url(../images/guide2.png); background-repeat: no-repeat; background-position: right top; background-color: #191919; background-size: contain; opacity: .9 }
    .btn { margin-bottom: 0; vertical-align: middle; -ms-touch-action: manipulation; touch-action: manipulation; background-image: none; border: 1px solid transparent; white-space: nowrap; padding: 6px 12px; line-height: 1.42857143; border-radius: 4px; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none }
    .btn-success { color: #fff; background-color: #5cb85c; border-color: #4cae4c }
    .btn-group-lg>.btn, .btn-lg { padding: 10px 16px; font-size: 18px; line-height: 1.3333333; border-radius: 6px }
    .btn-block { display: block; width: 100% }
    .bq { width: 13px; padding-left: 2px }
    .hidenone { display: none }
    
    .big_img{position: fixed;z-index: -1;opacity: 0;background: rgba(0,0,0,0.9);width: 100%;height: 100%;top:0;left:0;}
    .big_img .swiper-container2 {position: relative;width: 100%;height: 100%;}
    .big_img .swiper-container2  .swiper-wrapper{width: 100%;height: 100%;}
    .big_img .swiper-slide{width: 100%;height: 100%;display: table}
    .big_img .swiper-slide .cell{width: 100%;;height: 100%;display: table-cell;vertical-align: middle;text-align: center;}
    .big_img .swiper-slide img{max-width: 90%;max-height: 80%;margin:0 auto;}
    .big_img .swiper-pagination2{position: absolute; top:0.2rem;text-align: center;width: 100%;}
    .big_img .swiper-pagination2 span{margin:0 0.05rem;}
    

    (2)swiper.min.css

    /**
     * Swiper 3.3.1
     * Most modern mobile touch slider and framework with hardware accelerated transitions
     * 
     * http://www.idangero.us/swiper/
     * 
     * Copyright 2016, Vladimir Kharlampidi
     * The iDangero.us
     * http://www.idangero.us/
     * 
     * Licensed under MIT
     * 
     * Released on: February 7, 2016
     */
    .swiper-container {
        margin: 0 auto;
        position: relative;
        overflow: hidden;
        z-index: 1
    }
    
    .swiper-container-no-flexbox .swiper-slide {
        float: left
    }
    
    .swiper-container-vertical>.swiper-wrapper {
        -webkit-box-orient: vertical;
        -moz-box-orient: vertical;
        -ms-flex-direction: column;
        -webkit-flex-direction: column;
        flex-direction: column
    }
    
    .swiper-wrapper {
        position: relative;
        width: 100%;
        height: 100%;
        z-index: 1;
        display: -webkit-box;
        display: -moz-box;
        display: -ms-flexbox;
        display: -webkit-flex;
        display: flex;
        -webkit-transition-property: -webkit-transform;
        -moz-transition-property: -moz-transform;
        -o-transition-property: -o-transform;
        -ms-transition-property: -ms-transform;
        transition-property: transform;
        -webkit-box-sizing: content-box;
        -moz-box-sizing: content-box;
        box-sizing: content-box
    }
    
    .swiper-container-android .swiper-slide,.swiper-wrapper {
        -webkit-transform: translate3d(0,0,0);
        -moz-transform: translate3d(0,0,0);
        -o-transform: translate(0,0);
        -ms-transform: translate3d(0,0,0);
        transform: translate3d(0,0,0)
    }
    
    .swiper-container-multirow>.swiper-wrapper {
        -webkit-box-lines: multiple;
        -moz-box-lines: multiple;
        -ms-flex-wrap: wrap;
        -webkit-flex-wrap: wrap;
        flex-wrap: wrap
    }
    
    .swiper-container-free-mode>.swiper-wrapper {
        -webkit-transition-timing-function: ease-out;
        -moz-transition-timing-function: ease-out;
        -ms-transition-timing-function: ease-out;
        -o-transition-timing-function: ease-out;
        transition-timing-function: ease-out;
        margin: 0 auto
    }
    
    .swiper-slide {
        -webkit-flex-shrink: 0;
        -ms-flex: 0 0 auto;
        flex-shrink: 0;
        width: 100%;
        height: 100%;
        position: relative
    }
    
    .swiper-container-autoheight,.swiper-container-autoheight .swiper-slide {
        height: auto
    }
    
    .swiper-container-autoheight .swiper-wrapper {
        -webkit-box-align: start;
        -ms-flex-align: start;
        -webkit-align-items: flex-start;
        align-items: flex-start;
        -webkit-transition-property: -webkit-transform,height;
        -moz-transition-property: -moz-transform;
        -o-transition-property: -o-transform;
        -ms-transition-property: -ms-transform;
        transition-property: transform,height
    }
    
    .swiper-container .swiper-notification {
        position: absolute;
        left: 0;
        top: 0;
        pointer-events: none;
        opacity: 0;
        z-index: -1000
    }
    
    .swiper-wp8-horizontal {
        -ms-touch-action: pan-y;
        touch-action: pan-y
    }
    
    .swiper-wp8-vertical {
        -ms-touch-action: pan-x;
        touch-action: pan-x
    }
    
    .swiper-button-next,.swiper-button-prev {
        position: absolute;
        top: 50%;
        width: 27px;
        height: 44px;
        margin-top: -22px;
        z-index: 10;
        cursor: pointer;
        -moz-background-size: 27px 44px;
        -webkit-background-size: 27px 44px;
        background-size: 27px 44px;
        background-position: center;
        background-repeat: no-repeat
    }
    
    .swiper-button-next.swiper-button-disabled,.swiper-button-prev.swiper-button-disabled {
        opacity: .35;
        cursor: auto;
        pointer-events: none
    }
    
    .swiper-button-prev,.swiper-container-rtl .swiper-button-next {
        background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M0%2C22L22%2C0l2.1%2C2.1L4.2%2C22l19.9%2C19.9L22%2C44L0%2C22L0%2C22L0%2C22z'%20fill%3D'%23007aff'%2F%3E%3C%2Fsvg%3E");
        left: 10px;
        right: auto
    }
    
    .swiper-button-prev.swiper-button-black,.swiper-container-rtl .swiper-button-next.swiper-button-black {
        background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M0%2C22L22%2C0l2.1%2C2.1L4.2%2C22l19.9%2C19.9L22%2C44L0%2C22L0%2C22L0%2C22z'%20fill%3D'%23000000'%2F%3E%3C%2Fsvg%3E")
    }
    
    .swiper-button-prev.swiper-button-white,.swiper-container-rtl .swiper-button-next.swiper-button-white {
        background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M0%2C22L22%2C0l2.1%2C2.1L4.2%2C22l19.9%2C19.9L22%2C44L0%2C22L0%2C22L0%2C22z'%20fill%3D'%23ffffff'%2F%3E%3C%2Fsvg%3E")
    }
    
    .swiper-button-next,.swiper-container-rtl .swiper-button-prev {
        background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M27%2C22L27%2C22L5%2C44l-2.1-2.1L22.8%2C22L2.9%2C2.1L5%2C0L27%2C22L27%2C22z'%20fill%3D'%23007aff'%2F%3E%3C%2Fsvg%3E");
        right: 10px;
        left: auto
    }
    
    .swiper-button-next.swiper-button-black,.swiper-container-rtl .swiper-button-prev.swiper-button-black {
        background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M27%2C22L27%2C22L5%2C44l-2.1-2.1L22.8%2C22L2.9%2C2.1L5%2C0L27%2C22L27%2C22z'%20fill%3D'%23000000'%2F%3E%3C%2Fsvg%3E")
    }
    
    .swiper-button-next.swiper-button-white,.swiper-container-rtl .swiper-button-prev.swiper-button-white {
        background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20viewBox%3D'0%200%2027%2044'%3E%3Cpath%20d%3D'M27%2C22L27%2C22L5%2C44l-2.1-2.1L22.8%2C22L2.9%2C2.1L5%2C0L27%2C22L27%2C22z'%20fill%3D'%23ffffff'%2F%3E%3C%2Fsvg%3E")
    }
    
    .swiper-pagination {
        position: absolute;
        text-align: center;
        -webkit-transition: .3s;
        -moz-transition: .3s;
        -o-transition: .3s;
        transition: .3s;
        -webkit-transform: translate3d(0,0,0);
        -ms-transform: translate3d(0,0,0);
        -o-transform: translate3d(0,0,0);
        transform: translate3d(0,0,0);
        z-index: 10
    }
    
    .swiper-pagination.swiper-pagination-hidden {
        opacity: 0
    }
    
    .swiper-container-horizontal>.swiper-pagination-bullets,.swiper-pagination-custom,.swiper-pagination-fraction {
        bottom: 1px;
        left: 0;
        width: 100%
    }
    
    .swiper-pagination-bullet {
        width: 8px;
        height: 8px;
        display: inline-block;
        border-radius: 100%;
        border: 1px solid #fff;
    }
    
    button.swiper-pagination-bullet {
        border: none;
        margin: 0;
        padding: 0;
        box-shadow: none;
        -moz-appearance: none;
        -ms-appearance: none;
        -webkit-appearance: none;
        appearance: none
    }
    
    .swiper-pagination-clickable .swiper-pagination-bullet {
        cursor: pointer
    }
    
    .swiper-pagination-white .swiper-pagination-bullet {
        background: #fff
    }
    
    .swiper-pagination-bullet-active {
        opacity: 1;
        background: #fff
    }
    
    .swiper-pagination-white .swiper-pagination-bullet-active {
        background: #fff
    }
    
    .swiper-pagination-black .swiper-pagination-bullet-active {
        background: #000
    }
    
    .swiper-container-vertical>.swiper-pagination-bullets {
        right: 10px;
        top: 50%;
        -webkit-transform: translate3d(0,-50%,0);
        -moz-transform: translate3d(0,-50%,0);
        -o-transform: translate(0,-50%);
        -ms-transform: translate3d(0,-50%,0);
        transform: translate3d(0,-50%,0)
    }
    
    .swiper-container-vertical>.swiper-pagination-bullets .swiper-pagination-bullet {
        margin: 5px 0;
        display: block
    }
    
    .swiper-container-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet {
        margin: 0 5px
    }
    
    .swiper-pagination-progress {
        background: rgba(0,0,0,.25);
        position: absolute
    }
    
    .swiper-pagination-progress .swiper-pagination-progressbar {
        background: #007aff;
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        -webkit-transform: scale(0);
        -ms-transform: scale(0);
        -o-transform: scale(0);
        transform: scale(0);
        -webkit-transform-origin: left top;
        -moz-transform-origin: left top;
        -ms-transform-origin: left top;
        -o-transform-origin: left top;
        transform-origin: left top
    }
    
    .swiper-container-rtl .swiper-pagination-progress .swiper-pagination-progressbar {
        -webkit-transform-origin: right top;
        -moz-transform-origin: right top;
        -ms-transform-origin: right top;
        -o-transform-origin: right top;
        transform-origin: right top
    }
    
    .swiper-container-horizontal>.swiper-pagination-progress {
        width: 100%;
        height: 4px;
        left: 0;
        top: 0
    }
    
    .swiper-container-vertical>.swiper-pagination-progress {
        width: 4px;
        height: 100%;
        left: 0;
        top: 0
    }
    
    .swiper-pagination-progress.swiper-pagination-white {
        background: rgba(255,255,255,.5)
    }
    
    .swiper-pagination-progress.swiper-pagination-white .swiper-pagination-progressbar {
        background: #fff
    }
    
    .swiper-pagination-progress.swiper-pagination-black .swiper-pagination-progressbar {
        background: #000
    }
    
    .swiper-container-3d {
        -webkit-perspective: 1200px;
        -moz-perspective: 1200px;
        -o-perspective: 1200px;
        perspective: 1200px
    }
    
    .swiper-container-3d .swiper-cube-shadow,.swiper-container-3d .swiper-slide,.swiper-container-3d .swiper-slide-shadow-bottom,.swiper-container-3d .swiper-slide-shadow-left,.swiper-container-3d .swiper-slide-shadow-right,.swiper-container-3d .swiper-slide-shadow-top,.swiper-container-3d .swiper-wrapper {
        -webkit-transform-style: preserve-3d;
        -moz-transform-style: preserve-3d;
        -ms-transform-style: preserve-3d;
        transform-style: preserve-3d
    }
    
    .swiper-container-3d .swiper-slide-shadow-bottom,.swiper-container-3d .swiper-slide-shadow-left,.swiper-container-3d .swiper-slide-shadow-right,.swiper-container-3d .swiper-slide-shadow-top {
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        pointer-events: none;
        z-index: 10
    }
    
    .swiper-container-3d .swiper-slide-shadow-left {
        background-image: -webkit-gradient(linear,left top,right top,from(rgba(0,0,0,.5)),to(rgba(0,0,0,0)));
        background-image: -webkit-linear-gradient(right,rgba(0,0,0,.5),rgba(0,0,0,0));
        background-image: -moz-linear-gradient(right,rgba(0,0,0,.5),rgba(0,0,0,0));
        background-image: -o-linear-gradient(right,rgba(0,0,0,.5),rgba(0,0,0,0));
        background-image: linear-gradient(to left,rgba(0,0,0,.5),rgba(0,0,0,0))
    }
    
    .swiper-container-3d .swiper-slide-shadow-right {
        background-image: -webkit-gradient(linear,right top,left top,from(rgba(0,0,0,.5)),to(rgba(0,0,0,0)));
        background-image: -webkit-linear-gradient(left,rgba(0,0,0,.5),rgba(0,0,0,0));
        background-image: -moz-linear-gradient(left,rgba(0,0,0,.5),rgba(0,0,0,0));
        background-image: -o-linear-gradient(left,rgba(0,0,0,.5),rgba(0,0,0,0));
        background-image: linear-gradient(to right,rgba(0,0,0,.5),rgba(0,0,0,0))
    }
    
    .swiper-container-3d .swiper-slide-shadow-top {
        background-image: -webkit-gradient(linear,left top,left bottom,from(rgba(0,0,0,.5)),to(rgba(0,0,0,0)));
        background-image: -webkit-linear-gradient(bottom,rgba(0,0,0,.5),rgba(0,0,0,0));
        background-image: -moz-linear-gradient(bottom,rgba(0,0,0,.5),rgba(0,0,0,0));
        background-image: -o-linear-gradient(bottom,rgba(0,0,0,.5),rgba(0,0,0,0));
        background-image: linear-gradient(to top,rgba(0,0,0,.5),rgba(0,0,0,0))
    }
    
    .swiper-container-3d .swiper-slide-shadow-bottom {
        background-image: -webkit-gradient(linear,left bottom,left top,from(rgba(0,0,0,.5)),to(rgba(0,0,0,0)));
        background-image: -webkit-linear-gradient(top,rgba(0,0,0,.5),rgba(0,0,0,0));
        background-image: -moz-linear-gradient(top,rgba(0,0,0,.5),rgba(0,0,0,0));
        background-image: -o-linear-gradient(top,rgba(0,0,0,.5),rgba(0,0,0,0));
        background-image: linear-gradient(to bottom,rgba(0,0,0,.5),rgba(0,0,0,0))
    }
    
    .swiper-container-coverflow .swiper-wrapper,.swiper-container-flip .swiper-wrapper {
        -ms-perspective: 1200px
    }
    
    .swiper-container-cube,.swiper-container-flip {
        overflow: visible
    }
    
    .swiper-container-cube .swiper-slide,.swiper-container-flip .swiper-slide {
        pointer-events: none;
        -webkit-backface-visibility: hidden;
        -moz-backface-visibility: hidden;
        -ms-backface-visibility: hidden;
        backface-visibility: hidden;
        z-index: 1
    }
    
    .swiper-container-cube .swiper-slide .swiper-slide,.swiper-container-flip .swiper-slide .swiper-slide {
        pointer-events: none
    }
    
    .swiper-container-cube .swiper-slide-active,.swiper-container-cube .swiper-slide-active .swiper-slide-active,.swiper-container-flip .swiper-slide-active,.swiper-container-flip .swiper-slide-active .swiper-slide-active {
        pointer-events: auto
    }
    
    .swiper-container-cube .swiper-slide-shadow-bottom,.swiper-container-cube .swiper-slide-shadow-left,.swiper-container-cube .swiper-slide-shadow-right,.swiper-container-cube .swiper-slide-shadow-top,.swiper-container-flip .swiper-slide-shadow-bottom,.swiper-container-flip .swiper-slide-shadow-left,.swiper-container-flip .swiper-slide-shadow-right,.swiper-container-flip .swiper-slide-shadow-top {
        z-index: 0;
        -webkit-backface-visibility: hidden;
        -moz-backface-visibility: hidden;
        -ms-backface-visibility: hidden;
        backface-visibility: hidden
    }
    
    .swiper-container-cube .swiper-slide {
        visibility: hidden;
        -webkit-transform-origin: 0 0;
        -moz-transform-origin: 0 0;
        -ms-transform-origin: 0 0;
        transform-origin: 0 0;
        width: 100%;
        height: 100%
    }
    
    .swiper-container-cube.swiper-container-rtl .swiper-slide {
        -webkit-transform-origin: 100% 0;
        -moz-transform-origin: 100% 0;
        -ms-transform-origin: 100% 0;
        transform-origin: 100% 0
    }
    
    .swiper-container-cube .swiper-slide-active,.swiper-container-cube .swiper-slide-next,.swiper-container-cube .swiper-slide-next+.swiper-slide,.swiper-container-cube .swiper-slide-prev {
        pointer-events: auto;
        visibility: visible
    }
    
    .swiper-container-cube .swiper-cube-shadow {
        position: absolute;
        left: 0;
        bottom: 0;
        width: 100%;
        height: 100%;
        background: #000;
        opacity: .6;
        -webkit-filter: blur(50px);
        filter: blur(50px);
        z-index: 0
    }
    
    .swiper-container-fade.swiper-container-free-mode .swiper-slide {
        -webkit-transition-timing-function: ease-out;
        -moz-transition-timing-function: ease-out;
        -ms-transition-timing-function: ease-out;
        -o-transition-timing-function: ease-out;
        transition-timing-function: ease-out
    }
    
    .swiper-container-fade .swiper-slide {
        pointer-events: none;
        -webkit-transition-property: opacity;
        -moz-transition-property: opacity;
        -o-transition-property: opacity;
        transition-property: opacity
    }
    
    .swiper-container-fade .swiper-slide .swiper-slide {
        pointer-events: none
    }
    
    .swiper-container-fade .swiper-slide-active,.swiper-container-fade .swiper-slide-active .swiper-slide-active {
        pointer-events: auto
    }
    
    .swiper-scrollbar {
        border-radius: 10px;
        position: relative;
        -ms-touch-action: none;
        background: rgba(0,0,0,.1)
    }
    
    .swiper-container-horizontal>.swiper-scrollbar {
        position: absolute;
        left: 1%;
        bottom: 3px;
        z-index: 50;
        height: 5px;
        width: 98%
    }
    
    .swiper-container-vertical>.swiper-scrollbar {
        position: absolute;
        right: 3px;
        top: 1%;
        z-index: 50;
        width: 5px;
        height: 98%
    }
    
    .swiper-scrollbar-drag {
        height: 100%;
        width: 100%;
        position: relative;
        background: rgba(0,0,0,.5);
        border-radius: 10px;
        left: 0;
        top: 0
    }
    
    .swiper-scrollbar-cursor-drag {
        cursor: move
    }
    
    .swiper-lazy-preloader {
        width: 42px;
        height: 42px;
        position: absolute;
        left: 50%;
        top: 50%;
        margin-left: -21px;
        margin-top: -21px;
        z-index: 10;
        -webkit-transform-origin: 50%;
        -moz-transform-origin: 50%;
        transform-origin: 50%;
        -webkit-animation: swiper-preloader-spin 1s steps(12,end) infinite;
        -moz-animation: swiper-preloader-spin 1s steps(12,end) infinite;
        animation: swiper-preloader-spin 1s steps(12,end) infinite
    }
    
    .swiper-lazy-preloader:after {
        display: block;
        content: "";
        width: 100%;
        height: 100%;
        background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20viewBox%3D'0%200%20120%20120'%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20xmlns%3Axlink%3D'http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink'%3E%3Cdefs%3E%3Cline%20id%3D'l'%20x1%3D'60'%20x2%3D'60'%20y1%3D'7'%20y2%3D'27'%20stroke%3D'%236c6c6c'%20stroke-width%3D'11'%20stroke-linecap%3D'round'%2F%3E%3C%2Fdefs%3E%3Cg%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(30%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(60%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(90%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(120%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(150%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.37'%20transform%3D'rotate(180%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.46'%20transform%3D'rotate(210%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.56'%20transform%3D'rotate(240%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.66'%20transform%3D'rotate(270%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.75'%20transform%3D'rotate(300%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.85'%20transform%3D'rotate(330%2060%2C60)'%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E");
        background-position: 50%;
        -webkit-background-size: 100%;
        background-size: 100%;
        background-repeat: no-repeat
    }
    
    .swiper-lazy-preloader-white:after {
        background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20viewBox%3D'0%200%20120%20120'%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20xmlns%3Axlink%3D'http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink'%3E%3Cdefs%3E%3Cline%20id%3D'l'%20x1%3D'60'%20x2%3D'60'%20y1%3D'7'%20y2%3D'27'%20stroke%3D'%23fff'%20stroke-width%3D'11'%20stroke-linecap%3D'round'%2F%3E%3C%2Fdefs%3E%3Cg%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(30%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(60%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(90%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(120%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(150%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.37'%20transform%3D'rotate(180%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.46'%20transform%3D'rotate(210%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.56'%20transform%3D'rotate(240%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.66'%20transform%3D'rotate(270%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.75'%20transform%3D'rotate(300%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.85'%20transform%3D'rotate(330%2060%2C60)'%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E")
    }
    
    @-webkit-keyframes swiper-preloader-spin {
        100% {
            -webkit-transform: rotate(360deg)
        }
    }
    
    @keyframes swiper-preloader-spin {
        100% {
            transform: rotate(360deg)
        }
    }
    

    3.js
    (1)jquery.min.js

    /**
     * Created by Administrator on 2016/1/31.
     */
    /*! jQuery v1.11.0 | (c) 2005, 2014 jQuery Foundation, Inc. | jquery.org/license */
    !
    function(a, b) {
        "object" == typeof module && "object" == typeof module.exports ? module.exports = a.document ? b(a, !0) : function(a) {
            if (!a.document) throw new Error("jQuery requires a window with a document");
            return b(a)
        }: b(a)
    } ("undefined" != typeof window ? window: this,
    function(a, b) {
        var c = [],
        d = c.slice,
        e = c.concat,
        f = c.push,
        g = c.indexOf,
        h = {},
        i = h.toString,
        j = h.hasOwnProperty,
        k = "".trim,
        l = {},
        m = "1.11.0",
        n = function(a, b) {
            return new n.fn.init(a, b)
        },
        o = /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,
        p = /^-ms-/,
        q = /-([\da-z])/gi,
        r = function(a, b) {
            return b.toUpperCase()
        };
        n.fn = n.prototype = {
            jquery: m,
            constructor: n,
            selector: "",
            length: 0,
            toArray: function() {
                return d.call(this)
            },
            get: function(a) {
                return null != a ? 0 > a ? this[a + this.length] : this[a] : d.call(this)
            },
            pushStack: function(a) {
                var b = n.merge(this.constructor(), a);
                return b.prevObject = this,
                b.context = this.context,
                b
            },
            each: function(a, b) {
                return n.each(this, a, b)
            },
            map: function(a) {
                return this.pushStack(n.map(this,
                function(b, c) {
                    return a.call(b, c, b)
                }))
            },
            slice: function() {
                return this.pushStack(d.apply(this, arguments))
            },
            first: function() {
                return this.eq(0)
            },
            last: function() {
                return this.eq( - 1)
            },
            eq: function(a) {
                var b = this.length,
                c = +a + (0 > a ? b: 0);
                return this.pushStack(c >= 0 && b > c ? [this[c]] : [])
            },
            end: function() {
                return this.prevObject || this.constructor(null)
            },
            push: f,
            sort: c.sort,
            splice: c.splice
        },
        n.extend = n.fn.extend = function() {
            var a, b, c, d, e, f, g = arguments[0] || {},
            h = 1,
            i = arguments.length,
            j = !1;
            for ("boolean" == typeof g && (j = g, g = arguments[h] || {},
            h++), "object" == typeof g || n.isFunction(g) || (g = {}), h === i && (g = this, h--); i > h; h++) if (null != (e = arguments[h])) for (d in e) a = g[d],
            c = e[d],
            g !== c && (j && c && (n.isPlainObject(c) || (b = n.isArray(c))) ? (b ? (b = !1, f = a && n.isArray(a) ? a: []) : f = a && n.isPlainObject(a) ? a: {},
            g[d] = n.extend(j, f, c)) : void 0 !== c && (g[d] = c));
            return g
        },
        n.extend({
            expando: "jQuery" + (m + Math.random()).replace(/\D/g, ""),
            isReady: !0,
            error: function(a) {
                throw new Error(a)
            },
            noop: function() {},
            isFunction: function(a) {
                return "function" === n.type(a)
            },
            isArray: Array.isArray ||
            function(a) {
                return "array" === n.type(a)
            },
            isWindow: function(a) {
                return null != a && a == a.window
            },
            isNumeric: function(a) {
                return a - parseFloat(a) >= 0
            },
            isEmptyObject: function(a) {
                var b;
                for (b in a) return ! 1;
                return ! 0
            },
            isPlainObject: function(a) {
                var b;
                if (!a || "object" !== n.type(a) || a.nodeType || n.isWindow(a)) return ! 1;
                try {
                    if (a.constructor && !j.call(a, "constructor") && !j.call(a.constructor.prototype, "isPrototypeOf")) return ! 1
                } catch(c) {
                    return ! 1
                }
                if (l.ownLast) for (b in a) return j.call(a, b);
                for (b in a);
                return void 0 === b || j.call(a, b)
            },
            type: function(a) {
                return null == a ? a + "": "object" == typeof a || "function" == typeof a ? h[i.call(a)] || "object": typeof a
            },
            globalEval: function(b) {
                b && n.trim(b) && (a.execScript ||
                function(b) {
                    a.eval.call(a, b)
                })(b)
            },
            camelCase: function(a) {
                return a.replace(p, "ms-").replace(q, r)
            },
            nodeName: function(a, b) {
                return a.nodeName && a.nodeName.toLowerCase() === b.toLowerCase()
            },
            each: function(a, b, c) {
                var d, e = 0,
                f = a.length,
                g = s(a);
                if (c) {
                    if (g) {
                        for (; f > e; e++) if (d = b.apply(a[e], c), d === !1) break
                    } else for (e in a) if (d = b.apply(a[e], c), d === !1) break
                } else if (g) {
                    for (; f > e; e++) if (d = b.call(a[e], e, a[e]), d === !1) break
                } else for (e in a) if (d = b.call(a[e], e, a[e]), d === !1) break;
                return a
            },
            trim: k && !k.call("\ufeff\xa0") ?
            function(a) {
                return null == a ? "": k.call(a)
            }: function(a) {
                return null == a ? "": (a + "").replace(o, "")
            },
            makeArray: function(a, b) {
                var c = b || [];
                return null != a && (s(Object(a)) ? n.merge(c, "string" == typeof a ? [a] : a) : f.call(c, a)),
                c
            },
            inArray: function(a, b, c) {
                var d;
                if (b) {
                    if (g) return g.call(b, a, c);
                    for (d = b.length, c = c ? 0 > c ? Math.max(0, d + c) : c: 0; d > c; c++) if (c in b && b[c] === a) return c
                }
                return - 1
            },
            merge: function(a, b) {
                var c = +b.length,
                d = 0,
                e = a.length;
                while (c > d) a[e++] = b[d++];
                if (c !== c) while (void 0 !== b[d]) a[e++] = b[d++];
                return a.length = e,
                a
            },
            grep: function(a, b, c) {
                for (var d, e = [], f = 0, g = a.length, h = !c; g > f; f++) d = !b(a[f], f),
                d !== h && e.push(a[f]);
                return e
            },
            map: function(a, b, c) {
                var d, f = 0,
                g = a.length,
                h = s(a),
                i = [];
                if (h) for (; g > f; f++) d = b(a[f], f, c),
                null != d && i.push(d);
                else for (f in a) d = b(a[f], f, c),
                null != d && i.push(d);
                return e.apply([], i)
            },
            guid: 1,
            proxy: function(a, b) {
                var c, e, f;
                return "string" == typeof b && (f = a[b], b = a, a = f),
                n.isFunction(a) ? (c = d.call(arguments, 2), e = function() {
                    return a.apply(b || this, c.concat(d.call(arguments)))
                },
                e.guid = a.guid = a.guid || n.guid++, e) : void 0
            },
            now: function() {
                return + new Date
            },
            support: l
        }),
        n.each("Boolean Number String Function Array Date RegExp Object Error".split(" "),
        function(a, b) {
            h["[object " + b + "]"] = b.toLowerCase()
        });
        function s(a) {
            var b = a.length,
            c = n.type(a);
            return "function" === c || n.isWindow(a) ? !1 : 1 === a.nodeType && b ? !0 : "array" === c || 0 === b || "number" == typeof b && b > 0 && b - 1 in a
        }
        var t = function(a) {
            var b, c, d, e, f, g, h, i, j, k, l, m, n, o, p, q, r, s = "sizzle" + -new Date,
            t = a.document,
            u = 0,
            v = 0,
            w = eb(),
            x = eb(),
            y = eb(),
            z = function(a, b) {
                return a === b && (j = !0),
                0
            },
            A = "undefined",
            B = 1 << 31,
            C = {}.hasOwnProperty,
            D = [],
            E = D.pop,
            F = D.push,
            G = D.push,
            H = D.slice,
            I = D.indexOf ||
            function(a) {
                for (var b = 0,
                c = this.length; c > b; b++) if (this[b] === a) return b;
                return - 1
            },
            J = "checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",
            K = "[\\x20\\t\\r\\n\\f]",
            L = "(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+",
            M = L.replace("w", "w#"),
            N = "\\[" + K + "*(" + L + ")" + K + "*(?:([*^$|!~]?=)" + K + "*(?:(['\"])((?:\\\\.|[^\\\\])*?)\\3|(" + M + ")|)|)" + K + "*\\]",
            O = ":(" + L + ")(?:\\(((['\"])((?:\\\\.|[^\\\\])*?)\\3|((?:\\\\.|[^\\\\()[\\]]|" + N.replace(3, 8) + ")*)|.*)\\)|)",
            P = new RegExp("^" + K + "+|((?:^|[^\\\\])(?:\\\\.)*)" + K + "+$", "g"),
            Q = new RegExp("^" + K + "*," + K + "*"),
            R = new RegExp("^" + K + "*([>+~]|" + K + ")" + K + "*"),
            S = new RegExp("=" + K + "*([^\\]'\"]*?)" + K + "*\\]", "g"),
            T = new RegExp(O),
            U = new RegExp("^" + M + "$"),
            V = {
                ID: new RegExp("^#(" + L + ")"),
                CLASS: new RegExp("^\\.(" + L + ")"),
                TAG: new RegExp("^(" + L.replace("w", "w*") + ")"),
                ATTR: new RegExp("^" + N),
                PSEUDO: new RegExp("^" + O),
                CHILD: new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\(" + K + "*(even|odd|(([+-]|)(\\d*)n|)" + K + "*(?:([+-]|)" + K + "*(\\d+)|))" + K + "*\\)|)", "i"),
                bool: new RegExp("^(?:" + J + ")$", "i"),
                needsContext: new RegExp("^" + K + "*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\(" + K + "*((?:-\\d)?\\d*)" + K + "*\\)|)(?=[^-]|$)", "i")
            },
            W = /^(?:input|select|textarea|button)$/i,
            X = /^h\d$/i,
            Y = /^[^{]+\{\s*\[native \w/,
            Z = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,
            $ = /[+~]/,
            _ = /'|\\/g,
            ab = new RegExp("\\\\([\\da-f]{1,6}" + K + "?|(" + K + ")|.)", "ig"),
            bb = function(a, b, c) {
                var d = "0x" + b - 65536;
                return d !== d || c ? b: 0 > d ? String.fromCharCode(d + 65536) : String.fromCharCode(d >> 10 | 55296, 1023 & d | 56320)
            };
            try {
                G.apply(D = H.call(t.childNodes), t.childNodes),
                D[t.childNodes.length].nodeType
            } catch(cb) {
                G = {
                    apply: D.length ?
                    function(a, b) {
                        F.apply(a, H.call(b))
                    }: function(a, b) {
                        var c = a.length,
                        d = 0;
                        while (a[c++] = b[d++]);
                        a.length = c - 1
                    }
                }
            }
            function db(a, b, d, e) {
                var f, g, h, i, j, m, p, q, u, v;
                if ((b ? b.ownerDocument || b: t) !== l && k(b), b = b || l, d = d || [], !a || "string" != typeof a) return d;
                if (1 !== (i = b.nodeType) && 9 !== i) return [];
                if (n && !e) {
                    if (f = Z.exec(a)) if (h = f[1]) {
                        if (9 === i) {
                            if (g = b.getElementById(h), !g || !g.parentNode) return d;
                            if (g.id === h) return d.push(g),
                            d
                        } else if (b.ownerDocument && (g = b.ownerDocument.getElementById(h)) && r(b, g) && g.id === h) return d.push(g),
                        d
                    } else {
                        if (f[2]) return G.apply(d, b.getElementsByTagName(a)),
                        d;
                        if ((h = f[3]) && c.getElementsByClassName && b.getElementsByClassName) return G.apply(d, b.getElementsByClassName(h)),
                        d
                    }
                    if (c.qsa && (!o || !o.test(a))) {
                        if (q = p = s, u = b, v = 9 === i && a, 1 === i && "object" !== b.nodeName.toLowerCase()) {
                            m = ob(a),
                            (p = b.getAttribute("id")) ? q = p.replace(_, "\\$&") : b.setAttribute("id", q),
                            q = "[id='" + q + "'] ",
                            j = m.length;
                            while (j--) m[j] = q + pb(m[j]);
                            u = $.test(a) && mb(b.parentNode) || b,
                            v = m.join(",")
                        }
                        if (v) try {
                            return G.apply(d, u.querySelectorAll(v)),
                            d
                        } catch(w) {} finally {
                            p || b.removeAttribute("id")
                        }
                    }
                }
                return xb(a.replace(P, "$1"), b, d, e)
            }
            function eb() {
                var a = [];
                function b(c, e) {
                    return a.push(c + " ") > d.cacheLength && delete b[a.shift()],
                    b[c + " "] = e
                }
                return b
            }
            function fb(a) {
                return a[s] = !0,
                a
            }
            function gb(a) {
                var b = l.createElement("div");
                try {
                    return !! a(b)
                } catch(c) {
                    return ! 1
                } finally {
                    b.parentNode && b.parentNode.removeChild(b),
                    b = null
                }
            }
            function hb(a, b) {
                var c = a.split("|"),
                e = a.length;
                while (e--) d.attrHandle[c[e]] = b
            }
            function ib(a, b) {
                var c = b && a,
                d = c && 1 === a.nodeType && 1 === b.nodeType && (~b.sourceIndex || B) - (~a.sourceIndex || B);
                if (d) return d;
                if (c) while (c = c.nextSibling) if (c === b) return - 1;
                return a ? 1 : -1
            }
            function jb(a) {
                return function(b) {
                    var c = b.nodeName.toLowerCase();
                    return "input" === c && b.type === a
                }
            }
            function kb(a) {
                return function(b) {
                    var c = b.nodeName.toLowerCase();
                    return ("input" === c || "button" === c) && b.type === a
                }
            }
            function lb(a) {
                return fb(function(b) {
                    return b = +b,
                    fb(function(c, d) {
                        var e, f = a([], c.length, b),
                        g = f.length;
                        while (g--) c[e = f[g]] && (c[e] = !(d[e] = c[e]))
                    })
                })
            }
            function mb(a) {
                return a && typeof a.getElementsByTagName !== A && a
            }
            c = db.support = {},
            f = db.isXML = function(a) {
                var b = a && (a.ownerDocument || a).documentElement;
                return b ? "HTML" !== b.nodeName: !1
            },
            k = db.setDocument = function(a) {
                var b, e = a ? a.ownerDocument || a: t,
                g = e.defaultView;
                return e !== l && 9 === e.nodeType && e.documentElement ? (l = e, m = e.documentElement, n = !f(e), g && g !== g.top && (g.addEventListener ? g.addEventListener("unload",
                function() {
                    k()
                },
                !1) : g.attachEvent && g.attachEvent("onunload",
                function() {
                    k()
                })), c.attributes = gb(function(a) {
                    return a.className = "i",
                    !a.getAttribute("className")
                }), c.getElementsByTagName = gb(function(a) {
                    return a.appendChild(e.createComment("")),
                    !a.getElementsByTagName("*").length
                }), c.getElementsByClassName = Y.test(e.getElementsByClassName) && gb(function(a) {
                    return a.innerHTML = "<div class='a'></div><div class='a i'></div>",
                    a.firstChild.className = "i",
                    2 === a.getElementsByClassName("i").length
                }), c.getById = gb(function(a) {
                    return m.appendChild(a).id = s,
                    !e.getElementsByName || !e.getElementsByName(s).length
                }), c.getById ? (d.find.ID = function(a, b) {
                    if (typeof b.getElementById !== A && n) {
                        var c = b.getElementById(a);
                        return c && c.parentNode ? [c] : []
                    }
                },
                d.filter.ID = function(a) {
                    var b = a.replace(ab, bb);
                    return function(a) {
                        return a.getAttribute("id") === b
                    }
                }) : (delete d.find.ID, d.filter.ID = function(a) {
                    var b = a.replace(ab, bb);
                    return function(a) {
                        var c = typeof a.getAttributeNode !== A && a.getAttributeNode("id");
                        return c && c.value === b
                    }
                }), d.find.TAG = c.getElementsByTagName ?
                function(a, b) {
                    return typeof b.getElementsByTagName !== A ? b.getElementsByTagName(a) : void 0
                }: function(a, b) {
                    var c, d = [],
                    e = 0,
                    f = b.getElementsByTagName(a);
                    if ("*" === a) {
                        while (c = f[e++]) 1 === c.nodeType && d.push(c);
                        return d
                    }
                    return f
                },
                d.find.CLASS = c.getElementsByClassName &&
                function(a, b) {
                    return typeof b.getElementsByClassName !== A && n ? b.getElementsByClassName(a) : void 0
                },
                p = [], o = [], (c.qsa = Y.test(e.querySelectorAll)) && (gb(function(a) {
                    a.innerHTML = "<select t=''><option selected=''></option></select>",
                    a.querySelectorAll("[t^='']").length && o.push("[*^$]=" + K + "*(?:''|\"\")"),
                    a.querySelectorAll("[selected]").length || o.push("\\[" + K + "*(?:value|" + J + ")"),
                    a.querySelectorAll(":checked").length || o.push(":checked")
                }), gb(function(a) {
                    var b = e.createElement("input");
                    b.setAttribute("type", "hidden"),
                    a.appendChild(b).setAttribute("name", "D"),
                    a.querySelectorAll("[name=d]").length && o.push("name" + K + "*[*^$|!~]?="),
                    a.querySelectorAll(":enabled").length || o.push(":enabled", ":disabled"),
                    a.querySelectorAll("*,:x"),
                    o.push(",.*:")
                })), (c.matchesSelector = Y.test(q = m.webkitMatchesSelector || m.mozMatchesSelector || m.oMatchesSelector || m.msMatchesSelector)) && gb(function(a) {
                    c.disconnectedMatch = q.call(a, "div"),
                    q.call(a, "[s!='']:x"),
                    p.push("!=", O)
                }), o = o.length && new RegExp(o.join("|")), p = p.length && new RegExp(p.join("|")), b = Y.test(m.compareDocumentPosition), r = b || Y.test(m.contains) ?
                function(a, b) {
                    var c = 9 === a.nodeType ? a.documentElement: a,
                    d = b && b.parentNode;
                    return a === d || !(!d || 1 !== d.nodeType || !(c.contains ? c.contains(d) : a.compareDocumentPosition && 16 & a.compareDocumentPosition(d)))
                }: function(a, b) {
                    if (b) while (b = b.parentNode) if (b === a) return ! 0;
                    return ! 1
                },
                z = b ?
                function(a, b) {
                    if (a === b) return j = !0,
                    0;
                    var d = !a.compareDocumentPosition - !b.compareDocumentPosition;
                    return d ? d: (d = (a.ownerDocument || a) === (b.ownerDocument || b) ? a.compareDocumentPosition(b) : 1, 1 & d || !c.sortDetached && b.compareDocumentPosition(a) === d ? a === e || a.ownerDocument === t && r(t, a) ? -1 : b === e || b.ownerDocument === t && r(t, b) ? 1 : i ? I.call(i, a) - I.call(i, b) : 0 : 4 & d ? -1 : 1)
                }: function(a, b) {
                    if (a === b) return j = !0,
                    0;
                    var c, d = 0,
                    f = a.parentNode,
                    g = b.parentNode,
                    h = [a],
                    k = [b];
                    if (!f || !g) return a === e ? -1 : b === e ? 1 : f ? -1 : g ? 1 : i ? I.call(i, a) - I.call(i, b) : 0;
                    if (f === g) return ib(a, b);
                    c = a;
                    while (c = c.parentNode) h.unshift(c);
                    c = b;
                    while (c = c.parentNode) k.unshift(c);
                    while (h[d] === k[d]) d++;
                    return d ? ib(h[d], k[d]) : h[d] === t ? -1 : k[d] === t ? 1 : 0
                },
                e) : l
            },
            db.matches = function(a, b) {
                return db(a, null, null, b)
            },
            db.matchesSelector = function(a, b) {
                if ((a.ownerDocument || a) !== l && k(a), b = b.replace(S, "='$1']"), !(!c.matchesSelector || !n || p && p.test(b) || o && o.test(b))) try {
                    var d = q.call(a, b);
                    if (d || c.disconnectedMatch || a.document && 11 !== a.document.nodeType) return d
                } catch(e) {}
                return db(b, l, null, [a]).length > 0
            },
            db.contains = function(a, b) {
                return (a.ownerDocument || a) !== l && k(a),
                r(a, b)
            },
            db.attr = function(a, b) { (a.ownerDocument || a) !== l && k(a);
                var e = d.attrHandle[b.toLowerCase()],
                f = e && C.call(d.attrHandle, b.toLowerCase()) ? e(a, b, !n) : void 0;
                return void 0 !== f ? f: c.attributes || !n ? a.getAttribute(b) : (f = a.getAttributeNode(b)) && f.specified ? f.value: null
            },
            db.error = function(a) {
                throw new Error("Syntax error, unrecognized expression: " + a)
            },
            db.uniqueSort = function(a) {
                var b, d = [],
                e = 0,
                f = 0;
                if (j = !c.detectDuplicates, i = !c.sortStable && a.slice(0), a.sort(z), j) {
                    while (b = a[f++]) b === a[f] && (e = d.push(f));
                    while (e--) a.splice(d[e], 1)
                }
                return i = null,
                a
            },
            e = db.getText = function(a) {
                var b, c = "",
                d = 0,
                f = a.nodeType;
                if (f) {
                    if (1 === f || 9 === f || 11 === f) {
                        if ("string" == typeof a.textContent) return a.textContent;
                        for (a = a.firstChild; a; a = a.nextSibling) c += e(a)
                    } else if (3 === f || 4 === f) return a.nodeValue
                } else while (b = a[d++]) c += e(b);
                return c
            },
            d = db.selectors = {
                cacheLength: 50,
                createPseudo: fb,
                match: V,
                attrHandle: {},
                find: {},
                relative: {
                    ">": {
                        dir: "parentNode",
                        first: !0
                    },
                    " ": {
                        dir: "parentNode"
                    },
                    "+": {
                        dir: "previousSibling",
                        first: !0
                    },
                    "~": {
                        dir: "previousSibling"
                    }
                },
                preFilter: {
                    ATTR: function(a) {
                        return a[1] = a[1].replace(ab, bb),
                        a[3] = (a[4] || a[5] || "").replace(ab, bb),
                        "~=" === a[2] && (a[3] = " " + a[3] + " "),
                        a.slice(0, 4)
                    },
                    CHILD: function(a) {
                        return a[1] = a[1].toLowerCase(),
                        "nth" === a[1].slice(0, 3) ? (a[3] || db.error(a[0]), a[4] = +(a[4] ? a[5] + (a[6] || 1) : 2 * ("even" === a[3] || "odd" === a[3])), a[5] = +(a[7] + a[8] || "odd" === a[3])) : a[3] && db.error(a[0]),
                        a
                    },
                    PSEUDO: function(a) {
                        var b, c = !a[5] && a[2];
                        return V.CHILD.test(a[0]) ? null: (a[3] && void 0 !== a[4] ? a[2] = a[4] : c && T.test(c) && (b = ob(c, !0)) && (b = c.indexOf(")", c.length - b) - c.length) && (a[0] = a[0].slice(0, b), a[2] = c.slice(0, b)), a.slice(0, 3))
                    }
                },
                filter: {
                    TAG: function(a) {
                        var b = a.replace(ab, bb).toLowerCase();
                        return "*" === a ?
                        function() {
                            return ! 0
                        }: function(a) {
                            return a.nodeName && a.nodeName.toLowerCase() === b
                        }
                    },
                    CLASS: function(a) {
                        var b = w[a + " "];
                        return b || (b = new RegExp("(^|" + K + ")" + a + "(" + K + "|$)")) && w(a,
                        function(a) {
                            return b.test("string" == typeof a.className && a.className || typeof a.getAttribute !== A && a.getAttribute("class") || "")
                        })
                    },
                    ATTR: function(a, b, c) {
                        return function(d) {
                            var e = db.attr(d, a);
                            return null == e ? "!=" === b: b ? (e += "", "=" === b ? e === c: "!=" === b ? e !== c: "^=" === b ? c && 0 === e.indexOf(c) : "*=" === b ? c && e.indexOf(c) > -1 : "$=" === b ? c && e.slice( - c.length) === c: "~=" === b ? (" " + e + " ").indexOf(c) > -1 : "|=" === b ? e === c || e.slice(0, c.length + 1) === c + "-": !1) : !0
                        }
                    },
                    CHILD: function(a, b, c, d, e) {
                        var f = "nth" !== a.slice(0, 3),
                        g = "last" !== a.slice( - 4),
                        h = "of-type" === b;
                        return 1 === d && 0 === e ?
                        function(a) {
                            return !! a.parentNode
                        }: function(b, c, i) {
                            var j, k, l, m, n, o, p = f !== g ? "nextSibling": "previousSibling",
                            q = b.parentNode,
                            r = h && b.nodeName.toLowerCase(),
                            t = !i && !h;
                            if (q) {
                                if (f) {
                                    while (p) {
                                        l = b;
                                        while (l = l[p]) if (h ? l.nodeName.toLowerCase() === r: 1 === l.nodeType) return ! 1;
                                        o = p = "only" === a && !o && "nextSibling"
                                    }
                                    return ! 0
                                }
                                if (o = [g ? q.firstChild: q.lastChild], g && t) {
                                    k = q[s] || (q[s] = {}),
                                    j = k[a] || [],
                                    n = j[0] === u && j[1],
                                    m = j[0] === u && j[2],
                                    l = n && q.childNodes[n];
                                    while (l = ++n && l && l[p] || (m = n = 0) || o.pop()) if (1 === l.nodeType && ++m && l === b) {
                                        k[a] = [u, n, m];
                                        break
                                    }
                                } else if (t && (j = (b[s] || (b[s] = {}))[a]) && j[0] === u) m = j[1];
                                else while (l = ++n && l && l[p] || (m = n = 0) || o.pop()) if ((h ? l.nodeName.toLowerCase() === r: 1 === l.nodeType) && ++m && (t && ((l[s] || (l[s] = {}))[a] = [u, m]), l === b)) break;
                                return m -= e,
                                m === d || m % d === 0 && m / d >= 0
                            }
                        }
                    },
                    PSEUDO: function(a, b) {
                        var c, e = d.pseudos[a] || d.setFilters[a.toLowerCase()] || db.error("unsupported pseudo: " + a);
                        return e[s] ? e(b) : e.length > 1 ? (c = [a, a, "", b], d.setFilters.hasOwnProperty(a.toLowerCase()) ? fb(function(a, c) {
                            var d, f = e(a, b),
                            g = f.length;
                            while (g--) d = I.call(a, f[g]),
                            a[d] = !(c[d] = f[g])
                        }) : function(a) {
                            return e(a, 0, c)
                        }) : e
                    }
                },
                pseudos: {
                    not: fb(function(a) {
                        var b = [],
                        c = [],
                        d = g(a.replace(P, "$1"));
                        return d[s] ? fb(function(a, b, c, e) {
                            var f, g = d(a, null, e, []),
                            h = a.length;
                            while (h--)(f = g[h]) && (a[h] = !(b[h] = f))
                        }) : function(a, e, f) {
                            return b[0] = a,
                            d(b, null, f, c),
                            !c.pop()
                        }
                    }),
                    has: fb(function(a) {
                        return function(b) {
                            return db(a, b).length > 0
                        }
                    }),
                    contains: fb(function(a) {
                        return function(b) {
                            return (b.textContent || b.innerText || e(b)).indexOf(a) > -1
                        }
                    }),
                    lang: fb(function(a) {
                        return U.test(a || "") || db.error("unsupported lang: " + a),
                        a = a.replace(ab, bb).toLowerCase(),
                        function(b) {
                            var c;
                            do
                            if (c = n ? b.lang: b.getAttribute("xml:lang") || b.getAttribute("lang")) return c = c.toLowerCase(),
                            c === a || 0 === c.indexOf(a + "-");
                            while ((b = b.parentNode) && 1 === b.nodeType);
                            return ! 1
                        }
                    }),
                    target: function(b) {
                        var c = a.location && a.location.hash;
                        return c && c.slice(1) === b.id
                    },
                    root: function(a) {
                        return a === m
                    },
                    focus: function(a) {
                        return a === l.activeElement && (!l.hasFocus || l.hasFocus()) && !!(a.type || a.href || ~a.tabIndex)
                    },
                    enabled: function(a) {
                        return a.disabled === !1
                    },
                    disabled: function(a) {
                        return a.disabled === !0
                    },
                    checked: function(a) {
                        var b = a.nodeName.toLowerCase();
                        return "input" === b && !!a.checked || "option" === b && !!a.selected
                    },
                    selected: function(a) {
                        return a.parentNode && a.parentNode.selectedIndex,
                        a.selected === !0
                    },
                    empty: function(a) {
                        for (a = a.firstChild; a; a = a.nextSibling) if (a.nodeType < 6) return ! 1;
                        return ! 0
                    },
                    parent: function(a) {
                        return ! d.pseudos.empty(a)
                    },
                    header: function(a) {
                        return X.test(a.nodeName)
                    },
                    input: function(a) {
                        return W.test(a.nodeName)
                    },
                    button: function(a) {
                        var b = a.nodeName.toLowerCase();
                        return "input" === b && "button" === a.type || "button" === b
                    },
                    text: function(a) {
                        var b;
                        return "input" === a.nodeName.toLowerCase() && "text" === a.type && (null == (b = a.getAttribute("type")) || "text" === b.toLowerCase())
                    },
                    first: lb(function() {
                        return [0]
                    }),
                    last: lb(function(a, b) {
                        return [b - 1]
                    }),
                    eq: lb(function(a, b, c) {
                        return [0 > c ? c + b: c]
                    }),
                    even: lb(function(a, b) {
                        for (var c = 0; b > c; c += 2) a.push(c);
                        return a
                    }),
                    odd: lb(function(a, b) {
                        for (var c = 1; b > c; c += 2) a.push(c);
                        return a
                    }),
                    lt: lb(function(a, b, c) {
                        for (var d = 0 > c ? c + b: c; --d >= 0;) a.push(d);
                        return a
                    }),
                    gt: lb(function(a, b, c) {
                        for (var d = 0 > c ? c + b: c; ++d < b;) a.push(d);
                        return a
                    })
                }
            },
            d.pseudos.nth = d.pseudos.eq;
            for (b in {
                radio: !0,
                checkbox: !0,
                file: !0,
                password: !0,
                image: !0
            }) d.pseudos[b] = jb(b);
            for (b in {
                submit: !0,
                reset: !0
            }) d.pseudos[b] = kb(b);
            function nb() {}
            nb.prototype = d.filters = d.pseudos,
            d.setFilters = new nb;
            function ob(a, b) {
                var c, e, f, g, h, i, j, k = x[a + " "];
                if (k) return b ? 0 : k.slice(0);
                h = a,
                i = [],
                j = d.preFilter;
                while (h) { (!c || (e = Q.exec(h))) && (e && (h = h.slice(e[0].length) || h), i.push(f = [])),
                    c = !1,
                    (e = R.exec(h)) && (c = e.shift(), f.push({
                        value: c,
                        type: e[0].replace(P, " ")
                    }), h = h.slice(c.length));
                    for (g in d.filter) ! (e = V[g].exec(h)) || j[g] && !(e = j[g](e)) || (c = e.shift(), f.push({
                        value: c,
                        type: g,
                        matches: e
                    }), h = h.slice(c.length));
                    if (!c) break
                }
                return b ? h.length: h ? db.error(a) : x(a, i).slice(0)
            }
            function pb(a) {
                for (var b = 0,
                c = a.length,
                d = ""; c > b; b++) d += a[b].value;
                return d
            }
            function qb(a, b, c) {
                var d = b.dir,
                e = c && "parentNode" === d,
                f = v++;
                return b.first ?
                function(b, c, f) {
                    while (b = b[d]) if (1 === b.nodeType || e) return a(b, c, f)
                }: function(b, c, g) {
                    var h, i, j = [u, f];
                    if (g) {
                        while (b = b[d]) if ((1 === b.nodeType || e) && a(b, c, g)) return ! 0
                    } else while (b = b[d]) if (1 === b.nodeType || e) {
                        if (i = b[s] || (b[s] = {}), (h = i[d]) && h[0] === u && h[1] === f) return j[2] = h[2];
                        if (i[d] = j, j[2] = a(b, c, g)) return ! 0
                    }
                }
            }
            function rb(a) {
                return a.length > 1 ?
                function(b, c, d) {
                    var e = a.length;
                    while (e--) if (!a[e](b, c, d)) return ! 1;
                    return ! 0
                }: a[0]
            }
            function sb(a, b, c, d, e) {
                for (var f, g = [], h = 0, i = a.length, j = null != b; i > h; h++)(f = a[h]) && (!c || c(f, d, e)) && (g.push(f), j && b.push(h));
                return g
            }
            function tb(a, b, c, d, e, f) {
                return d && !d[s] && (d = tb(d)),
                e && !e[s] && (e = tb(e, f)),
                fb(function(f, g, h, i) {
                    var j, k, l, m = [],
                    n = [],
                    o = g.length,
                    p = f || wb(b || "*", h.nodeType ? [h] : h, []),
                    q = !a || !f && b ? p: sb(p, m, a, h, i),
                    r = c ? e || (f ? a: o || d) ? [] : g: q;
                    if (c && c(q, r, h, i), d) {
                        j = sb(r, n),
                        d(j, [], h, i),
                        k = j.length;
                        while (k--)(l = j[k]) && (r[n[k]] = !(q[n[k]] = l))
                    }
                    if (f) {
                        if (e || a) {
                            if (e) {
                                j = [],
                                k = r.length;
                                while (k--)(l = r[k]) && j.push(q[k] = l);
                                e(null, r = [], j, i)
                            }
                            k = r.length;
                            while (k--)(l = r[k]) && (j = e ? I.call(f, l) : m[k]) > -1 && (f[j] = !(g[j] = l))
                        }
                    } else r = sb(r === g ? r.splice(o, r.length) : r),
                    e ? e(null, g, r, i) : G.apply(g, r)
                })
            }
            function ub(a) {
                for (var b, c, e, f = a.length,
                g = d.relative[a[0].type], i = g || d.relative[" "], j = g ? 1 : 0, k = qb(function(a) {
                    return a === b
                },
                i, !0), l = qb(function(a) {
                    return I.call(b, a) > -1
                },
                i, !0), m = [function(a, c, d) {
                    return ! g && (d || c !== h) || ((b = c).nodeType ? k(a, c, d) : l(a, c, d))
                }]; f > j; j++) if (c = d.relative[a[j].type]) m = [qb(rb(m), c)];
                else {
                    if (c = d.filter[a[j].type].apply(null, a[j].matches), c[s]) {
                        for (e = ++j; f > e; e++) if (d.relative[a[e].type]) break;
                        return tb(j > 1 && rb(m), j > 1 && pb(a.slice(0, j - 1).concat({
                            value: " " === a[j - 2].type ? "*": ""
                        })).replace(P, "$1"), c, e > j && ub(a.slice(j, e)), f > e && ub(a = a.slice(e)), f > e && pb(a))
                    }
                    m.push(c)
                }
                return rb(m)
            }
            function vb(a, b) {
                var c = b.length > 0,
                e = a.length > 0,
                f = function(f, g, i, j, k) {
                    var m, n, o, p = 0,
                    q = "0",
                    r = f && [],
                    s = [],
                    t = h,
                    v = f || e && d.find.TAG("*", k),
                    w = u += null == t ? 1 : Math.random() || .1,
                    x = v.length;
                    for (k && (h = g !== l && g); q !== x && null != (m = v[q]); q++) {
                        if (e && m) {
                            n = 0;
                            while (o = a[n++]) if (o(m, g, i)) {
                                j.push(m);
                                break
                            }
                            k && (u = w)
                        }
                        c && ((m = !o && m) && p--, f && r.push(m))
                    }
                    if (p += q, c && q !== p) {
                        n = 0;
                        while (o = b[n++]) o(r, s, g, i);
                        if (f) {
                            if (p > 0) while (q--) r[q] || s[q] || (s[q] = E.call(j));
                            s = sb(s)
                        }
                        G.apply(j, s),
                        k && !f && s.length > 0 && p + b.length > 1 && db.uniqueSort(j)
                    }
                    return k && (u = w, h = t),
                    r
                };
                return c ? fb(f) : f
            }
            g = db.compile = function(a, b) {
                var c, d = [],
                e = [],
                f = y[a + " "];
                if (!f) {
                    b || (b = ob(a)),
                    c = b.length;
                    while (c--) f = ub(b[c]),
                    f[s] ? d.push(f) : e.push(f);
                    f = y(a, vb(e, d))
                }
                return f
            };
            function wb(a, b, c) {
                for (var d = 0,
                e = b.length; e > d; d++) db(a, b[d], c);
                return c
            }
            function xb(a, b, e, f) {
                var h, i, j, k, l, m = ob(a);
                if (!f && 1 === m.length) {
                    if (i = m[0] = m[0].slice(0), i.length > 2 && "ID" === (j = i[0]).type && c.getById && 9 === b.nodeType && n && d.relative[i[1].type]) {
                        if (b = (d.find.ID(j.matches[0].replace(ab, bb), b) || [])[0], !b) return e;
                        a = a.slice(i.shift().value.length)
                    }
                    h = V.needsContext.test(a) ? 0 : i.length;
                    while (h--) {
                        if (j = i[h], d.relative[k = j.type]) break;
                        if ((l = d.find[k]) && (f = l(j.matches[0].replace(ab, bb), $.test(i[0].type) && mb(b.parentNode) || b))) {
                            if (i.splice(h, 1), a = f.length && pb(i), !a) return G.apply(e, f),
                            e;
                            break
                        }
                    }
                }
                return g(a, m)(f, b, !n, e, $.test(a) && mb(b.parentNode) || b),
                e
            }
            return c.sortStable = s.split("").sort(z).join("") === s,
            c.detectDuplicates = !!j,
            k(),
            c.sortDetached = gb(function(a) {
                return 1 & a.compareDocumentPosition(l.createElement("div"))
            }),
            gb(function(a) {
                return a.innerHTML = "<a href='#'></a>",
                "#" === a.firstChild.getAttribute("href")
            }) || hb("type|href|height|width",
            function(a, b, c) {
                return c ? void 0 : a.getAttribute(b, "type" === b.toLowerCase() ? 1 : 2)
            }),
            c.attributes && gb(function(a) {
                return a.innerHTML = "<input/>",
                a.firstChild.setAttribute("value", ""),
                "" === a.firstChild.getAttribute("value")
            }) || hb("value",
            function(a, b, c) {
                return c || "input" !== a.nodeName.toLowerCase() ? void 0 : a.defaultValue
            }),
            gb(function(a) {
                return null == a.getAttribute("disabled")
            }) || hb(J,
            function(a, b, c) {
                var d;
                return c ? void 0 : a[b] === !0 ? b.toLowerCase() : (d = a.getAttributeNode(b)) && d.specified ? d.value: null
            }),
            db
        } (a);
        n.find = t,
        n.expr = t.selectors,
        n.expr[":"] = n.expr.pseudos,
        n.unique = t.uniqueSort,
        n.text = t.getText,
        n.isXMLDoc = t.isXML,
        n.contains = t.contains;
        var u = n.expr.match.needsContext,
        v = /^<(\w+)\s*\/?>(?:<\/\1>|)$/,
        w = /^.[^:#\[\.,]*$/;
        function x(a, b, c) {
            if (n.isFunction(b)) return n.grep(a,
            function(a, d) {
                return !! b.call(a, d, a) !== c
            });
            if (b.nodeType) return n.grep(a,
            function(a) {
                return a === b !== c
            });
            if ("string" == typeof b) {
                if (w.test(b)) return n.filter(b, a, c);
                b = n.filter(b, a)
            }
            return n.grep(a,
            function(a) {
                return n.inArray(a, b) >= 0 !== c
            })
        }
        n.filter = function(a, b, c) {
            var d = b[0];
            return c && (a = ":not(" + a + ")"),
            1 === b.length && 1 === d.nodeType ? n.find.matchesSelector(d, a) ? [d] : [] : n.find.matches(a, n.grep(b,
            function(a) {
                return 1 === a.nodeType
            }))
        },
        n.fn.extend({
            find: function(a) {
                var b, c = [],
                d = this,
                e = d.length;
                if ("string" != typeof a) return this.pushStack(n(a).filter(function() {
                    for (b = 0; e > b; b++) if (n.contains(d[b], this)) return ! 0
                }));
                for (b = 0; e > b; b++) n.find(a, d[b], c);
                return c = this.pushStack(e > 1 ? n.unique(c) : c),
                c.selector = this.selector ? this.selector + " " + a: a,
                c
            },
            filter: function(a) {
                return this.pushStack(x(this, a || [], !1))
            },
            not: function(a) {
                return this.pushStack(x(this, a || [], !0))
            },
            is: function(a) {
                return !! x(this, "string" == typeof a && u.test(a) ? n(a) : a || [], !1).length
            }
        });
        var y, z = a.document,
        A = /^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]*))$/,
        B = n.fn.init = function(a, b) {
            var c, d;
            if (!a) return this;
            if ("string" == typeof a) {
                if (c = "<" === a.charAt(0) && ">" === a.charAt(a.length - 1) && a.length >= 3 ? [null, a, null] : A.exec(a), !c || !c[1] && b) return ! b || b.jquery ? (b || y).find(a) : this.constructor(b).find(a);
                if (c[1]) {
                    if (b = b instanceof n ? b[0] : b, n.merge(this, n.parseHTML(c[1], b && b.nodeType ? b.ownerDocument || b: z, !0)), v.test(c[1]) && n.isPlainObject(b)) for (c in b) n.isFunction(this[c]) ? this[c](b[c]) : this.attr(c, b[c]);
                    return this
                }
                if (d = z.getElementById(c[2]), d && d.parentNode) {
                    if (d.id !== c[2]) return y.find(a);
                    this.length = 1,
                    this[0] = d
                }
                return this.context = z,
                this.selector = a,
                this
            }
            return a.nodeType ? (this.context = this[0] = a, this.length = 1, this) : n.isFunction(a) ? "undefined" != typeof y.ready ? y.ready(a) : a(n) : (void 0 !== a.selector && (this.selector = a.selector, this.context = a.context), n.makeArray(a, this))
        };
        B.prototype = n.fn,
        y = n(z);
        var C = /^(?:parents|prev(?:Until|All))/,
        D = {
            children: !0,
            contents: !0,
            next: !0,
            prev: !0
        };
        n.extend({
            dir: function(a, b, c) {
                var d = [],
                e = a[b];
                while (e && 9 !== e.nodeType && (void 0 === c || 1 !== e.nodeType || !n(e).is(c))) 1 === e.nodeType && d.push(e),
                e = e[b];
                return d
            },
            sibling: function(a, b) {
                for (var c = []; a; a = a.nextSibling) 1 === a.nodeType && a !== b && c.push(a);
                return c
            }
        }),
        n.fn.extend({
            has: function(a) {
                var b, c = n(a, this),
                d = c.length;
                return this.filter(function() {
                    for (b = 0; d > b; b++) if (n.contains(this, c[b])) return ! 0
                })
            },
            closest: function(a, b) {
                for (var c, d = 0,
                e = this.length,
                f = [], g = u.test(a) || "string" != typeof a ? n(a, b || this.context) : 0; e > d; d++) for (c = this[d]; c && c !== b; c = c.parentNode) if (c.nodeType < 11 && (g ? g.index(c) > -1 : 1 === c.nodeType && n.find.matchesSelector(c, a))) {
                    f.push(c);
                    break
                }
                return this.pushStack(f.length > 1 ? n.unique(f) : f)
            },
            index: function(a) {
                return a ? "string" == typeof a ? n.inArray(this[0], n(a)) : n.inArray(a.jquery ? a[0] : a, this) : this[0] && this[0].parentNode ? this.first().prevAll().length: -1
            },
            add: function(a, b) {
                return this.pushStack(n.unique(n.merge(this.get(), n(a, b))))
            },
            addBack: function(a) {
                return this.add(null == a ? this.prevObject: this.prevObject.filter(a))
            }
        });
        function E(a, b) {
            do a = a[b];
            while (a && 1 !== a.nodeType);
            return a
        }
        n.each({
            parent: function(a) {
                var b = a.parentNode;
                return b && 11 !== b.nodeType ? b: null
            },
            parents: function(a) {
                return n.dir(a, "parentNode")
            },
            parentsUntil: function(a, b, c) {
                return n.dir(a, "parentNode", c)
            },
            next: function(a) {
                return E(a, "nextSibling")
            },
            prev: function(a) {
                return E(a, "previousSibling")
            },
            nextAll: function(a) {
                return n.dir(a, "nextSibling")
            },
            prevAll: function(a) {
                return n.dir(a, "previousSibling")
            },
            nextUntil: function(a, b, c) {
                return n.dir(a, "nextSibling", c)
            },
            prevUntil: function(a, b, c) {
                return n.dir(a, "previousSibling", c)
            },
            siblings: function(a) {
                return n.sibling((a.parentNode || {}).firstChild, a)
            },
            children: function(a) {
                return n.sibling(a.firstChild)
            },
            contents: function(a) {
                return n.nodeName(a, "iframe") ? a.contentDocument || a.contentWindow.document: n.merge([], a.childNodes)
            }
        },
        function(a, b) {
            n.fn[a] = function(c, d) {
                var e = n.map(this, b, c);
                return "Until" !== a.slice( - 5) && (d = c),
                d && "string" == typeof d && (e = n.filter(d, e)),
                this.length > 1 && (D[a] || (e = n.unique(e)), C.test(a) && (e = e.reverse())),
                this.pushStack(e)
            }
        });
        var F = /\S+/g,
        G = {};
        function H(a) {
            var b = G[a] = {};
            return n.each(a.match(F) || [],
            function(a, c) {
                b[c] = !0
            }),
            b
        }
        n.Callbacks = function(a) {
            a = "string" == typeof a ? G[a] || H(a) : n.extend({},
            a);
            var b, c, d, e, f, g, h = [],
            i = !a.once && [],
            j = function(l) {
                for (c = a.memory && l, d = !0, f = g || 0, g = 0, e = h.length, b = !0; h && e > f; f++) if (h[f].apply(l[0], l[1]) === !1 && a.stopOnFalse) {
                    c = !1;
                    break
                }
                b = !1,
                h && (i ? i.length && j(i.shift()) : c ? h = [] : k.disable())
            },
            k = {
                add: function() {
                    if (h) {
                        var d = h.length; !
                        function f(b) {
                            n.each(b,
                            function(b, c) {
                                var d = n.type(c);
                                "function" === d ? a.unique && k.has(c) || h.push(c) : c && c.length && "string" !== d && f(c)
                            })
                        } (arguments),
                        b ? e = h.length: c && (g = d, j(c))
                    }
                    return this
                },
                remove: function() {
                    return h && n.each(arguments,
                    function(a, c) {
                        var d;
                        while ((d = n.inArray(c, h, d)) > -1) h.splice(d, 1),
                        b && (e >= d && e--, f >= d && f--)
                    }),
                    this
                },
                has: function(a) {
                    return a ? n.inArray(a, h) > -1 : !(!h || !h.length)
                },
                empty: function() {
                    return h = [],
                    e = 0,
                    this
                },
                disable: function() {
                    return h = i = c = void 0,
                    this
                },
                disabled: function() {
                    return ! h
                },
                lock: function() {
                    return i = void 0,
                    c || k.disable(),
                    this
                },
                locked: function() {
                    return ! i
                },
                fireWith: function(a, c) {
                    return ! h || d && !i || (c = c || [], c = [a, c.slice ? c.slice() : c], b ? i.push(c) : j(c)),
                    this
                },
                fire: function() {
                    return k.fireWith(this, arguments),
                    this
                },
                fired: function() {
                    return !! d
                }
            };
            return k
        },
        n.extend({
            Deferred: function(a) {
                var b = [["resolve", "done", n.Callbacks("once memory"), "resolved"], ["reject", "fail", n.Callbacks("once memory"), "rejected"], ["notify", "progress", n.Callbacks("memory")]],
                c = "pending",
                d = {
                    state: function() {
                        return c
                    },
                    always: function() {
                        return e.done(arguments).fail(arguments),
                        this
                    },
                    then: function() {
                        var a = arguments;
                        return n.Deferred(function(c) {
                            n.each(b,
                            function(b, f) {
                                var g = n.isFunction(a[b]) && a[b];
                                e[f[1]](function() {
                                    var a = g && g.apply(this, arguments);
                                    a && n.isFunction(a.promise) ? a.promise().done(c.resolve).fail(c.reject).progress(c.notify) : c[f[0] + "With"](this === d ? c.promise() : this, g ? [a] : arguments)
                                })
                            }),
                            a = null
                        }).promise()
                    },
                    promise: function(a) {
                        return null != a ? n.extend(a, d) : d
                    }
                },
                e = {};
                return d.pipe = d.then,
                n.each(b,
                function(a, f) {
                    var g = f[2],
                    h = f[3];
                    d[f[1]] = g.add,
                    h && g.add(function() {
                        c = h
                    },
                    b[1 ^ a][2].disable, b[2][2].lock),
                    e[f[0]] = function() {
                        return e[f[0] + "With"](this === e ? d: this, arguments),
                        this
                    },
                    e[f[0] + "With"] = g.fireWith
                }),
                d.promise(e),
                a && a.call(e, e),
                e
            },
            when: function(a) {
                var b = 0,
                c = d.call(arguments),
                e = c.length,
                f = 1 !== e || a && n.isFunction(a.promise) ? e: 0,
                g = 1 === f ? a: n.Deferred(),
                h = function(a, b, c) {
                    return function(e) {
                        b[a] = this,
                        c[a] = arguments.length > 1 ? d.call(arguments) : e,
                        c === i ? g.notifyWith(b, c) : --f || g.resolveWith(b, c)
                    }
                },
                i,
                j,
                k;
                if (e > 1) for (i = new Array(e), j = new Array(e), k = new Array(e); e > b; b++) c[b] && n.isFunction(c[b].promise) ? c[b].promise().done(h(b, k, c)).fail(g.reject).progress(h(b, j, i)) : --f;
                return f || g.resolveWith(k, c),
                g.promise()
            }
        });
        var I;
        n.fn.ready = function(a) {
            return n.ready.promise().done(a),
            this
        },
        n.extend({
            isReady: !1,
            readyWait: 1,
            holdReady: function(a) {
                a ? n.readyWait++:n.ready(!0)
            },
            ready: function(a) {
                if (a === !0 ? !--n.readyWait: !n.isReady) {
                    if (!z.body) return setTimeout(n.ready);
                    n.isReady = !0,
                    a !== !0 && --n.readyWait > 0 || (I.resolveWith(z, [n]), n.fn.trigger && n(z).trigger("ready").off("ready"))
                }
            }
        });
        function J() {
            z.addEventListener ? (z.removeEventListener("DOMContentLoaded", K, !1), a.removeEventListener("load", K, !1)) : (z.detachEvent("onreadystatechange", K), a.detachEvent("onload", K))
        }
        function K() { (z.addEventListener || "load" === event.type || "complete" === z.readyState) && (J(), n.ready())
        }
        n.ready.promise = function(b) {
            if (!I) if (I = n.Deferred(), "complete" === z.readyState) setTimeout(n.ready);
            else if (z.addEventListener) z.addEventListener("DOMContentLoaded", K, !1),
            a.addEventListener("load", K, !1);
            else {
                z.attachEvent("onreadystatechange", K),
                a.attachEvent("onload", K);
                var c = !1;
                try {
                    c = null == a.frameElement && z.documentElement
                } catch(d) {}
                c && c.doScroll && !
                function e() {
                    if (!n.isReady) {
                        try {
                            c.doScroll("left")
                        } catch(a) {
                            return setTimeout(e, 50)
                        }
                        J(),
                        n.ready()
                    }
                } ()
            }
            return I.promise(b)
        };
        var L = "undefined",
        M;
        for (M in n(l)) break;
        l.ownLast = "0" !== M,
        l.inlineBlockNeedsLayout = !1,
        n(function() {
            var a, b, c = z.getElementsByTagName("body")[0];
            c && (a = z.createElement("div"), a.style.cssText = "border:0;width:0;height:0;position:absolute;top:0;left:-9999px;margin-top:1px", b = z.createElement("div"), c.appendChild(a).appendChild(b), typeof b.style.zoom !== L && (b.style.cssText = "border:0;margin:0;width:1px;padding:1px;display:inline;zoom:1", (l.inlineBlockNeedsLayout = 3 === b.offsetWidth) && (c.style.zoom = 1)), c.removeChild(a), a = b = null)
        }),
        function() {
            var a = z.createElement("div");
            if (null == l.deleteExpando) {
                l.deleteExpando = !0;
                try {
                    delete a.test
                } catch(b) {
                    l.deleteExpando = !1
                }
            }
            a = null
        } (),
        n.acceptData = function(a) {
            var b = n.noData[(a.nodeName + " ").toLowerCase()],
            c = +a.nodeType || 1;
            return 1 !== c && 9 !== c ? !1 : !b || b !== !0 && a.getAttribute("classid") === b
        };
        var N = /^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,
        O = /([A-Z])/g;
        function P(a, b, c) {
            if (void 0 === c && 1 === a.nodeType) {
                var d = "data-" + b.replace(O, "-$1").toLowerCase();
                if (c = a.getAttribute(d), "string" == typeof c) {
                    try {
                        c = "true" === c ? !0 : "false" === c ? !1 : "null" === c ? null: +c + "" === c ? +c: N.test(c) ? n.parseJSON(c) : c
                    } catch(e) {}
                    n.data(a, b, c)
                } else c = void 0
            }
            return c
        }
        function Q(a) {
            var b;
            for (b in a) if (("data" !== b || !n.isEmptyObject(a[b])) && "toJSON" !== b) return ! 1;
            return ! 0
        }
        function R(a, b, d, e) {
            if (n.acceptData(a)) {
                var f, g, h = n.expando,
                i = a.nodeType,
                j = i ? n.cache: a,
                k = i ? a[h] : a[h] && h;
                if (k && j[k] && (e || j[k].data) || void 0 !== d || "string" != typeof b) return k || (k = i ? a[h] = c.pop() || n.guid++:h),
                j[k] || (j[k] = i ? {}: {
                    toJSON: n.noop
                }),
                ("object" == typeof b || "function" == typeof b) && (e ? j[k] = n.extend(j[k], b) : j[k].data = n.extend(j[k].data, b)),
                g = j[k],
                e || (g.data || (g.data = {}), g = g.data),
                void 0 !== d && (g[n.camelCase(b)] = d),
                "string" == typeof b ? (f = g[b], null == f && (f = g[n.camelCase(b)])) : f = g,
                f
            }
        }
        function S(a, b, c) {
            if (n.acceptData(a)) {
                var d, e, f = a.nodeType,
                g = f ? n.cache: a,
                h = f ? a[n.expando] : n.expando;
                if (g[h]) {
                    if (b && (d = c ? g[h] : g[h].data)) {
                        n.isArray(b) ? b = b.concat(n.map(b, n.camelCase)) : b in d ? b = [b] : (b = n.camelCase(b), b = b in d ? [b] : b.split(" ")),
                        e = b.length;
                        while (e--) delete d[b[e]];
                        if (c ? !Q(d) : !n.isEmptyObject(d)) return
                    } (c || (delete g[h].data, Q(g[h]))) && (f ? n.cleanData([a], !0) : l.deleteExpando || g != g.window ? delete g[h] : g[h] = null)
                }
            }
        }
        n.extend({
            cache: {},
            noData: {
                "applet ": !0,
                "embed ": !0,
                "object ": "clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"
            },
            hasData: function(a) {
                return a = a.nodeType ? n.cache[a[n.expando]] : a[n.expando],
                !!a && !Q(a)
            },
            data: function(a, b, c) {
                return R(a, b, c)
            },
            removeData: function(a, b) {
                return S(a, b)
            },
            _data: function(a, b, c) {
                return R(a, b, c, !0)
            },
            _removeData: function(a, b) {
                return S(a, b, !0)
            }
        }),
        n.fn.extend({
            data: function(a, b) {
                var c, d, e, f = this[0],
                g = f && f.attributes;
                if (void 0 === a) {
                    if (this.length && (e = n.data(f), 1 === f.nodeType && !n._data(f, "parsedAttrs"))) {
                        c = g.length;
                        while (c--) d = g[c].name,
                        0 === d.indexOf("data-") && (d = n.camelCase(d.slice(5)), P(f, d, e[d]));
                        n._data(f, "parsedAttrs", !0)
                    }
                    return e
                }
                return "object" == typeof a ? this.each(function() {
                    n.data(this, a)
                }) : arguments.length > 1 ? this.each(function() {
                    n.data(this, a, b)
                }) : f ? P(f, a, n.data(f, a)) : void 0
            },
            removeData: function(a) {
                return this.each(function() {
                    n.removeData(this, a)
                })
            }
        }),
        n.extend({
            queue: function(a, b, c) {
                var d;
                return a ? (b = (b || "fx") + "queue", d = n._data(a, b), c && (!d || n.isArray(c) ? d = n._data(a, b, n.makeArray(c)) : d.push(c)), d || []) : void 0
            },
            dequeue: function(a, b) {
                b = b || "fx";
                var c = n.queue(a, b),
                d = c.length,
                e = c.shift(),
                f = n._queueHooks(a, b),
                g = function() {
                    n.dequeue(a, b)
                };
                "inprogress" === e && (e = c.shift(), d--),
                e && ("fx" === b && c.unshift("inprogress"), delete f.stop, e.call(a, g, f)),
                !d && f && f.empty.fire()
            },
            _queueHooks: function(a, b) {
                var c = b + "queueHooks";
                return n._data(a, c) || n._data(a, c, {
                    empty: n.Callbacks("once memory").add(function() {
                        n._removeData(a, b + "queue"),
                        n._removeData(a, c)
                    })
                })
            }
        }),
        n.fn.extend({
            queue: function(a, b) {
                var c = 2;
                return "string" != typeof a && (b = a, a = "fx", c--),
                arguments.length < c ? n.queue(this[0], a) : void 0 === b ? this: this.each(function() {
                    var c = n.queue(this, a, b);
                    n._queueHooks(this, a),
                    "fx" === a && "inprogress" !== c[0] && n.dequeue(this, a)
                })
            },
            dequeue: function(a) {
                return this.each(function() {
                    n.dequeue(this, a)
                })
            },
            clearQueue: function(a) {
                return this.queue(a || "fx", [])
            },
            promise: function(a, b) {
                var c, d = 1,
                e = n.Deferred(),
                f = this,
                g = this.length,
                h = function() {--d || e.resolveWith(f, [f])
                };
                "string" != typeof a && (b = a, a = void 0),
                a = a || "fx";
                while (g--) c = n._data(f[g], a + "queueHooks"),
                c && c.empty && (d++, c.empty.add(h));
                return h(),
                e.promise(b)
            }
        });
        var T = /[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,
        U = ["Top", "Right", "Bottom", "Left"],
        V = function(a, b) {
            return a = b || a,
            "none" === n.css(a, "display") || !n.contains(a.ownerDocument, a)
        },
        W = n.access = function(a, b, c, d, e, f, g) {
            var h = 0,
            i = a.length,
            j = null == c;
            if ("object" === n.type(c)) {
                e = !0;
                for (h in c) n.access(a, b, h, c[h], !0, f, g)
            } else if (void 0 !== d && (e = !0, n.isFunction(d) || (g = !0), j && (g ? (b.call(a, d), b = null) : (j = b, b = function(a, b, c) {
                return j.call(n(a), c)
            })), b)) for (; i > h; h++) b(a[h], c, g ? d: d.call(a[h], h, b(a[h], c)));
            return e ? a: j ? b.call(a) : i ? b(a[0], c) : f
        },
        X = /^(?:checkbox|radio)$/i; !
        function() {
            var a = z.createDocumentFragment(),
            b = z.createElement("div"),
            c = z.createElement("input");
            if (b.setAttribute("className", "t"), b.innerHTML = "  <link/><table></table><a href='/a'>a</a>", l.leadingWhitespace = 3 === b.firstChild.nodeType, l.tbody = !b.getElementsByTagName("tbody").length, l.htmlSerialize = !!b.getElementsByTagName("link").length, l.html5Clone = "<:nav></:nav>" !== z.createElement("nav").cloneNode(!0).outerHTML, c.type = "checkbox", c.checked = !0, a.appendChild(c), l.appendChecked = c.checked, b.innerHTML = "<textarea>x</textarea>", l.noCloneChecked = !!b.cloneNode(!0).lastChild.defaultValue, a.appendChild(b), b.innerHTML = "<input type='radio' checked='checked' name='t'/>", l.checkClone = b.cloneNode(!0).cloneNode(!0).lastChild.checked, l.noCloneEvent = !0, b.attachEvent && (b.attachEvent("onclick",
            function() {
                l.noCloneEvent = !1
            }), b.cloneNode(!0).click()), null == l.deleteExpando) {
                l.deleteExpando = !0;
                try {
                    delete b.test
                } catch(d) {
                    l.deleteExpando = !1
                }
            }
            a = b = c = null
        } (),
        function() {
            var b, c, d = z.createElement("div");
            for (b in {
                submit: !0,
                change: !0,
                focusin: !0
            }) c = "on" + b,
            (l[b + "Bubbles"] = c in a) || (d.setAttribute(c, "t"), l[b + "Bubbles"] = d.attributes[c].expando === !1);
            d = null
        } ();
        var Y = /^(?:input|select|textarea)$/i,
        Z = /^key/,
        $ = /^(?:mouse|contextmenu)|click/,
        _ = /^(?:focusinfocus|focusoutblur)$/,
        ab = /^([^.]*)(?:\.(.+)|)$/;
        function bb() {
            return ! 0
        }
        function cb() {
            return ! 1
        }
        function db() {
            try {
                return z.activeElement
            } catch(a) {}
        }
        n.event = {
            global: {},
            add: function(a, b, c, d, e) {
                var f, g, h, i, j, k, l, m, o, p, q, r = n._data(a);
                if (r) {
                    c.handler && (i = c, c = i.handler, e = i.selector),
                    c.guid || (c.guid = n.guid++),
                    (g = r.events) || (g = r.events = {}),
                    (k = r.handle) || (k = r.handle = function(a) {
                        return typeof n === L || a && n.event.triggered === a.type ? void 0 : n.event.dispatch.apply(k.elem, arguments)
                    },
                    k.elem = a),
                    b = (b || "").match(F) || [""],
                    h = b.length;
                    while (h--) f = ab.exec(b[h]) || [],
                    o = q = f[1],
                    p = (f[2] || "").split(".").sort(),
                    o && (j = n.event.special[o] || {},
                    o = (e ? j.delegateType: j.bindType) || o, j = n.event.special[o] || {},
                    l = n.extend({
                        type: o,
                        origType: q,
                        data: d,
                        handler: c,
                        guid: c.guid,
                        selector: e,
                        needsContext: e && n.expr.match.needsContext.test(e),
                        namespace: p.join(".")
                    },
                    i), (m = g[o]) || (m = g[o] = [], m.delegateCount = 0, j.setup && j.setup.call(a, d, p, k) !== !1 || (a.addEventListener ? a.addEventListener(o, k, !1) : a.attachEvent && a.attachEvent("on" + o, k))), j.add && (j.add.call(a, l), l.handler.guid || (l.handler.guid = c.guid)), e ? m.splice(m.delegateCount++, 0, l) : m.push(l), n.event.global[o] = !0);
                    a = null
                }
            },
            remove: function(a, b, c, d, e) {
                var f, g, h, i, j, k, l, m, o, p, q, r = n.hasData(a) && n._data(a);
                if (r && (k = r.events)) {
                    b = (b || "").match(F) || [""],
                    j = b.length;
                    while (j--) if (h = ab.exec(b[j]) || [], o = q = h[1], p = (h[2] || "").split(".").sort(), o) {
                        l = n.event.special[o] || {},
                        o = (d ? l.delegateType: l.bindType) || o,
                        m = k[o] || [],
                        h = h[2] && new RegExp("(^|\\.)" + p.join("\\.(?:.*\\.|)") + "(\\.|$)"),
                        i = f = m.length;
                        while (f--) g = m[f],
                        !e && q !== g.origType || c && c.guid !== g.guid || h && !h.test(g.namespace) || d && d !== g.selector && ("**" !== d || !g.selector) || (m.splice(f, 1), g.selector && m.delegateCount--, l.remove && l.remove.call(a, g));
                        i && !m.length && (l.teardown && l.teardown.call(a, p, r.handle) !== !1 || n.removeEvent(a, o, r.handle), delete k[o])
                    } else for (o in k) n.event.remove(a, o + b[j], c, d, !0);
                    n.isEmptyObject(k) && (delete r.handle, n._removeData(a, "events"))
                }
            },
            trigger: function(b, c, d, e) {
                var f, g, h, i, k, l, m, o = [d || z],
                p = j.call(b, "type") ? b.type: b,
                q = j.call(b, "namespace") ? b.namespace.split(".") : [];
                if (h = l = d = d || z, 3 !== d.nodeType && 8 !== d.nodeType && !_.test(p + n.event.triggered) && (p.indexOf(".") >= 0 && (q = p.split("."), p = q.shift(), q.sort()), g = p.indexOf(":") < 0 && "on" + p, b = b[n.expando] ? b: new n.Event(p, "object" == typeof b && b), b.isTrigger = e ? 2 : 3, b.namespace = q.join("."), b.namespace_re = b.namespace ? new RegExp("(^|\\.)" + q.join("\\.(?:.*\\.|)") + "(\\.|$)") : null, b.result = void 0, b.target || (b.target = d), c = null == c ? [b] : n.makeArray(c, [b]), k = n.event.special[p] || {},
                e || !k.trigger || k.trigger.apply(d, c) !== !1)) {
                    if (!e && !k.noBubble && !n.isWindow(d)) {
                        for (i = k.delegateType || p, _.test(i + p) || (h = h.parentNode); h; h = h.parentNode) o.push(h),
                        l = h;
                        l === (d.ownerDocument || z) && o.push(l.defaultView || l.parentWindow || a)
                    }
                    m = 0;
                    while ((h = o[m++]) && !b.isPropagationStopped()) b.type = m > 1 ? i: k.bindType || p,
                    f = (n._data(h, "events") || {})[b.type] && n._data(h, "handle"),
                    f && f.apply(h, c),
                    f = g && h[g],
                    f && f.apply && n.acceptData(h) && (b.result = f.apply(h, c), b.result === !1 && b.preventDefault());
                    if (b.type = p, !e && !b.isDefaultPrevented() && (!k._default || k._default.apply(o.pop(), c) === !1) && n.acceptData(d) && g && d[p] && !n.isWindow(d)) {
                        l = d[g],
                        l && (d[g] = null),
                        n.event.triggered = p;
                        try {
                            d[p]()
                        } catch(r) {}
                        n.event.triggered = void 0,
                        l && (d[g] = l)
                    }
                    return b.result
                }
            },
            dispatch: function(a) {
                a = n.event.fix(a);
                var b, c, e, f, g, h = [],
                i = d.call(arguments),
                j = (n._data(this, "events") || {})[a.type] || [],
                k = n.event.special[a.type] || {};
                if (i[0] = a, a.delegateTarget = this, !k.preDispatch || k.preDispatch.call(this, a) !== !1) {
                    h = n.event.handlers.call(this, a, j),
                    b = 0;
                    while ((f = h[b++]) && !a.isPropagationStopped()) {
                        a.currentTarget = f.elem,
                        g = 0;
                        while ((e = f.handlers[g++]) && !a.isImmediatePropagationStopped())(!a.namespace_re || a.namespace_re.test(e.namespace)) && (a.handleObj = e, a.data = e.data, c = ((n.event.special[e.origType] || {}).handle || e.handler).apply(f.elem, i), void 0 !== c && (a.result = c) === !1 && (a.preventDefault(), a.stopPropagation()))
                    }
                    return k.postDispatch && k.postDispatch.call(this, a),
                    a.result
                }
            },
            handlers: function(a, b) {
                var c, d, e, f, g = [],
                h = b.delegateCount,
                i = a.target;
                if (h && i.nodeType && (!a.button || "click" !== a.type)) for (; i != this; i = i.parentNode || this) if (1 === i.nodeType && (i.disabled !== !0 || "click" !== a.type)) {
                    for (e = [], f = 0; h > f; f++) d = b[f],
                    c = d.selector + " ",
                    void 0 === e[c] && (e[c] = d.needsContext ? n(c, this).index(i) >= 0 : n.find(c, this, null, [i]).length),
                    e[c] && e.push(d);
                    e.length && g.push({
                        elem: i,
                        handlers: e
                    })
                }
                return h < b.length && g.push({
                    elem: this,
                    handlers: b.slice(h)
                }),
                g
            },
            fix: function(a) {
                if (a[n.expando]) return a;
                var b, c, d, e = a.type,
                f = a,
                g = this.fixHooks[e];
                g || (this.fixHooks[e] = g = $.test(e) ? this.mouseHooks: Z.test(e) ? this.keyHooks: {}),
                d = g.props ? this.props.concat(g.props) : this.props,
                a = new n.Event(f),
                b = d.length;
                while (b--) c = d[b],
                a[c] = f[c];
                return a.target || (a.target = f.srcElement || z),
                3 === a.target.nodeType && (a.target = a.target.parentNode),
                a.metaKey = !!a.metaKey,
                g.filter ? g.filter(a, f) : a
            },
            props: "altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "),
            fixHooks: {},
            keyHooks: {
                props: "char charCode key keyCode".split(" "),
                filter: function(a, b) {
                    return null == a.which && (a.which = null != b.charCode ? b.charCode: b.keyCode),
                    a
                }
            },
            mouseHooks: {
                props: "button buttons clientX clientY fromElement offsetX offsetY pageX pageY screenX screenY toElement".split(" "),
                filter: function(a, b) {
                    var c, d, e, f = b.button,
                    g = b.fromElement;
                    return null == a.pageX && null != b.clientX && (d = a.target.ownerDocument || z, e = d.documentElement, c = d.body, a.pageX = b.clientX + (e && e.scrollLeft || c && c.scrollLeft || 0) - (e && e.clientLeft || c && c.clientLeft || 0), a.pageY = b.clientY + (e && e.scrollTop || c && c.scrollTop || 0) - (e && e.clientTop || c && c.clientTop || 0)),
                    !a.relatedTarget && g && (a.relatedTarget = g === a.target ? b.toElement: g),
                    a.which || void 0 === f || (a.which = 1 & f ? 1 : 2 & f ? 3 : 4 & f ? 2 : 0),
                    a
                }
            },
            special: {
                load: {
                    noBubble: !0
                },
                focus: {
                    trigger: function() {
                        if (this !== db() && this.focus) try {
                            return this.focus(),
                            !1
                        } catch(a) {}
                    },
                    delegateType: "focusin"
                },
                blur: {
                    trigger: function() {
                        return this === db() && this.blur ? (this.blur(), !1) : void 0
                    },
                    delegateType: "focusout"
                },
                click: {
                    trigger: function() {
                        return n.nodeName(this, "input") && "checkbox" === this.type && this.click ? (this.click(), !1) : void 0
                    },
                    _default: function(a) {
                        return n.nodeName(a.target, "a")
                    }
                },
                beforeunload: {
                    postDispatch: function(a) {
                        void 0 !== a.result && (a.originalEvent.returnValue = a.result)
                    }
                }
            },
            simulate: function(a, b, c, d) {
                var e = n.extend(new n.Event, c, {
                    type: a,
                    isSimulated: !0,
                    originalEvent: {}
                });
                d ? n.event.trigger(e, null, b) : n.event.dispatch.call(b, e),
                e.isDefaultPrevented() && c.preventDefault()
            }
        },
        n.removeEvent = z.removeEventListener ?
        function(a, b, c) {
            a.removeEventListener && a.removeEventListener(b, c, !1)
        }: function(a, b, c) {
            var d = "on" + b;
            a.detachEvent && (typeof a[d] === L && (a[d] = null), a.detachEvent(d, c))
        },
        n.Event = function(a, b) {
            return this instanceof n.Event ? (a && a.type ? (this.originalEvent = a, this.type = a.type, this.isDefaultPrevented = a.defaultPrevented || void 0 === a.defaultPrevented && (a.returnValue === !1 || a.getPreventDefault && a.getPreventDefault()) ? bb: cb) : this.type = a, b && n.extend(this, b), this.timeStamp = a && a.timeStamp || n.now(), void(this[n.expando] = !0)) : new n.Event(a, b)
        },
        n.Event.prototype = {
            isDefaultPrevented: cb,
            isPropagationStopped: cb,
            isImmediatePropagationStopped: cb,
            preventDefault: function() {
                var a = this.originalEvent;
                this.isDefaultPrevented = bb,
                a && (a.preventDefault ? a.preventDefault() : a.returnValue = !1)
            },
            stopPropagation: function() {
                var a = this.originalEvent;
                this.isPropagationStopped = bb,
                a && (a.stopPropagation && a.stopPropagation(), a.cancelBubble = !0)
            },
            stopImmediatePropagation: function() {
                this.isImmediatePropagationStopped = bb,
                this.stopPropagation()
            }
        },
        n.each({
            mouseenter: "mouseover",
            mouseleave: "mouseout"
        },
        function(a, b) {
            n.event.special[a] = {
                delegateType: b,
                bindType: b,
                handle: function(a) {
                    var c, d = this,
                    e = a.relatedTarget,
                    f = a.handleObj;
                    return (!e || e !== d && !n.contains(d, e)) && (a.type = f.origType, c = f.handler.apply(this, arguments), a.type = b),
                    c
                }
            }
        }),
        l.submitBubbles || (n.event.special.submit = {
            setup: function() {
                return n.nodeName(this, "form") ? !1 : void n.event.add(this, "click._submit keypress._submit",
                function(a) {
                    var b = a.target,
                    c = n.nodeName(b, "input") || n.nodeName(b, "button") ? b.form: void 0;
                    c && !n._data(c, "submitBubbles") && (n.event.add(c, "submit._submit",
                    function(a) {
                        a._submit_bubble = !0
                    }), n._data(c, "submitBubbles", !0))
                })
            },
            postDispatch: function(a) {
                a._submit_bubble && (delete a._submit_bubble, this.parentNode && !a.isTrigger && n.event.simulate("submit", this.parentNode, a, !0))
            },
            teardown: function() {
                return n.nodeName(this, "form") ? !1 : void n.event.remove(this, "._submit")
            }
        }),
        l.changeBubbles || (n.event.special.change = {
            setup: function() {
                return Y.test(this.nodeName) ? (("checkbox" === this.type || "radio" === this.type) && (n.event.add(this, "propertychange._change",
                function(a) {
                    "checked" === a.originalEvent.propertyName && (this._just_changed = !0)
                }), n.event.add(this, "click._change",
                function(a) {
                    this._just_changed && !a.isTrigger && (this._just_changed = !1),
                    n.event.simulate("change", this, a, !0)
                })), !1) : void n.event.add(this, "beforeactivate._change",
                function(a) {
                    var b = a.target;
                    Y.test(b.nodeName) && !n._data(b, "changeBubbles") && (n.event.add(b, "change._change",
                    function(a) { ! this.parentNode || a.isSimulated || a.isTrigger || n.event.simulate("change", this.parentNode, a, !0)
                    }), n._data(b, "changeBubbles", !0))
                })
            },
            handle: function(a) {
                var b = a.target;
                return this !== b || a.isSimulated || a.isTrigger || "radio" !== b.type && "checkbox" !== b.type ? a.handleObj.handler.apply(this, arguments) : void 0
            },
            teardown: function() {
                return n.event.remove(this, "._change"),
                !Y.test(this.nodeName)
            }
        }),
        l.focusinBubbles || n.each({
            focus: "focusin",
            blur: "focusout"
        },
        function(a, b) {
            var c = function(a) {
                n.event.simulate(b, a.target, n.event.fix(a), !0)
            };
            n.event.special[b] = {
                setup: function() {
                    var d = this.ownerDocument || this,
                    e = n._data(d, b);
                    e || d.addEventListener(a, c, !0),
                    n._data(d, b, (e || 0) + 1)
                },
                teardown: function() {
                    var d = this.ownerDocument || this,
                    e = n._data(d, b) - 1;
                    e ? n._data(d, b, e) : (d.removeEventListener(a, c, !0), n._removeData(d, b))
                }
            }
        }),
        n.fn.extend({
            on: function(a, b, c, d, e) {
                var f, g;
                if ("object" == typeof a) {
                    "string" != typeof b && (c = c || b, b = void 0);
                    for (f in a) this.on(f, b, c, a[f], e);
                    return this
                }
                if (null == c && null == d ? (d = b, c = b = void 0) : null == d && ("string" == typeof b ? (d = c, c = void 0) : (d = c, c = b, b = void 0)), d === !1) d = cb;
                else if (!d) return this;
                return 1 === e && (g = d, d = function(a) {
                    return n().off(a),
                    g.apply(this, arguments)
                },
                d.guid = g.guid || (g.guid = n.guid++)),
                this.each(function() {
                    n.event.add(this, a, d, c, b)
                })
            },
            one: function(a, b, c, d) {
                return this.on(a, b, c, d, 1)
            },
            off: function(a, b, c) {
                var d, e;
                if (a && a.preventDefault && a.handleObj) return d = a.handleObj,
                n(a.delegateTarget).off(d.namespace ? d.origType + "." + d.namespace: d.origType, d.selector, d.handler),
                this;
                if ("object" == typeof a) {
                    for (e in a) this.off(e, b, a[e]);
                    return this
                }
                return (b === !1 || "function" == typeof b) && (c = b, b = void 0),
                c === !1 && (c = cb),
                this.each(function() {
                    n.event.remove(this, a, c, b)
                })
            },
            trigger: function(a, b) {
                return this.each(function() {
                    n.event.trigger(a, b, this)
                })
            },
            triggerHandler: function(a, b) {
                var c = this[0];
                return c ? n.event.trigger(a, b, c, !0) : void 0
            }
        });
        function eb(a) {
            var b = fb.split("|"),
            c = a.createDocumentFragment();
            if (c.createElement) while (b.length) c.createElement(b.pop());
            return c
        }
        var fb = "abbr|article|aside|audio|bdi|canvas|data|datalist|details|figcaption|figure|footer|header|hgroup|mark|meter|nav|output|progress|section|summary|time|video",
        gb = / jQuery\d+="(?:null|\d+)"/g,
        hb = new RegExp("<(?:" + fb + ")[\\s/>]", "i"),
        ib = /^\s+/,
        jb = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi,
        kb = /<([\w:]+)/,
        lb = /<tbody/i,
        mb = /<|&#?\w+;/,
        nb = /<(?:script|style|link)/i,
        ob = /checked\s*(?:[^=]|=\s*.checked.)/i,
        pb = /^$|\/(?:java|ecma)script/i,
        qb = /^true\/(.*)/,
        rb = /^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g,
        sb = {
            option: [1, "<select multiple='multiple'>", "</select>"],
            legend: [1, "<fieldset>", "</fieldset>"],
            area: [1, "<map>", "</map>"],
            param: [1, "<object>", "</object>"],
            thead: [1, "<table>", "</table>"],
            tr: [2, "<table><tbody>", "</tbody></table>"],
            col: [2, "<table><tbody></tbody><colgroup>", "</colgroup></table>"],
            td: [3, "<table><tbody><tr>", "</tr></tbody></table>"],
            _default: l.htmlSerialize ? [0, "", ""] : [1, "X<div>", "</div>"]
        },
        tb = eb(z),
        ub = tb.appendChild(z.createElement("div"));
        sb.optgroup = sb.option,
        sb.tbody = sb.tfoot = sb.colgroup = sb.caption = sb.thead,
        sb.th = sb.td;
        function vb(a, b) {
            var c, d, e = 0,
            f = typeof a.getElementsByTagName !== L ? a.getElementsByTagName(b || "*") : typeof a.querySelectorAll !== L ? a.querySelectorAll(b || "*") : void 0;
            if (!f) for (f = [], c = a.childNodes || a; null != (d = c[e]); e++) ! b || n.nodeName(d, b) ? f.push(d) : n.merge(f, vb(d, b));
            return void 0 === b || b && n.nodeName(a, b) ? n.merge([a], f) : f
        }
        function wb(a) {
            X.test(a.type) && (a.defaultChecked = a.checked)
        }
        function xb(a, b) {
            return n.nodeName(a, "table") && n.nodeName(11 !== b.nodeType ? b: b.firstChild, "tr") ? a.getElementsByTagName("tbody")[0] || a.appendChild(a.ownerDocument.createElement("tbody")) : a
        }
        function yb(a) {
            return a.type = (null !== n.find.attr(a, "type")) + "/" + a.type,
            a
        }
        function zb(a) {
            var b = qb.exec(a.type);
            return b ? a.type = b[1] : a.removeAttribute("type"),
            a
        }
        function Ab(a, b) {
            for (var c, d = 0; null != (c = a[d]); d++) n._data(c, "globalEval", !b || n._data(b[d], "globalEval"))
        }
        function Bb(a, b) {
            if (1 === b.nodeType && n.hasData(a)) {
                var c, d, e, f = n._data(a),
                g = n._data(b, f),
                h = f.events;
                if (h) {
                    delete g.handle,
                    g.events = {};
                    for (c in h) for (d = 0, e = h[c].length; e > d; d++) n.event.add(b, c, h[c][d])
                }
                g.data && (g.data = n.extend({},
                g.data))
            }
        }
        function Cb(a, b) {
            var c, d, e;
            if (1 === b.nodeType) {
                if (c = b.nodeName.toLowerCase(), !l.noCloneEvent && b[n.expando]) {
                    e = n._data(b);
                    for (d in e.events) n.removeEvent(b, d, e.handle);
                    b.removeAttribute(n.expando)
                }
                "script" === c && b.text !== a.text ? (yb(b).text = a.text, zb(b)) : "object" === c ? (b.parentNode && (b.outerHTML = a.outerHTML), l.html5Clone && a.innerHTML && !n.trim(b.innerHTML) && (b.innerHTML = a.innerHTML)) : "input" === c && X.test(a.type) ? (b.defaultChecked = b.checked = a.checked, b.value !== a.value && (b.value = a.value)) : "option" === c ? b.defaultSelected = b.selected = a.defaultSelected: ("input" === c || "textarea" === c) && (b.defaultValue = a.defaultValue)
            }
        }
        n.extend({
            clone: function(a, b, c) {
                var d, e, f, g, h, i = n.contains(a.ownerDocument, a);
                if (l.html5Clone || n.isXMLDoc(a) || !hb.test("<" + a.nodeName + ">") ? f = a.cloneNode(!0) : (ub.innerHTML = a.outerHTML, ub.removeChild(f = ub.firstChild)), !(l.noCloneEvent && l.noCloneChecked || 1 !== a.nodeType && 11 !== a.nodeType || n.isXMLDoc(a))) for (d = vb(f), h = vb(a), g = 0; null != (e = h[g]); ++g) d[g] && Cb(e, d[g]);
                if (b) if (c) for (h = h || vb(a), d = d || vb(f), g = 0; null != (e = h[g]); g++) Bb(e, d[g]);
                else Bb(a, f);
                return d = vb(f, "script"),
                d.length > 0 && Ab(d, !i && vb(a, "script")),
                d = h = e = null,
                f
            },
            buildFragment: function(a, b, c, d) {
                for (var e, f, g, h, i, j, k, m = a.length,
                o = eb(b), p = [], q = 0; m > q; q++) if (f = a[q], f || 0 === f) if ("object" === n.type(f)) n.merge(p, f.nodeType ? [f] : f);
                else if (mb.test(f)) {
                    h = h || o.appendChild(b.createElement("div")),
                    i = (kb.exec(f) || ["", ""])[1].toLowerCase(),
                    k = sb[i] || sb._default,
                    h.innerHTML = k[1] + f.replace(jb, "<$1></$2>") + k[2],
                    e = k[0];
                    while (e--) h = h.lastChild;
                    if (!l.leadingWhitespace && ib.test(f) && p.push(b.createTextNode(ib.exec(f)[0])), !l.tbody) {
                        f = "table" !== i || lb.test(f) ? "<table>" !== k[1] || lb.test(f) ? 0 : h: h.firstChild,
                        e = f && f.childNodes.length;
                        while (e--) n.nodeName(j = f.childNodes[e], "tbody") && !j.childNodes.length && f.removeChild(j)
                    }
                    n.merge(p, h.childNodes),
                    h.textContent = "";
                    while (h.firstChild) h.removeChild(h.firstChild);
                    h = o.lastChild
                } else p.push(b.createTextNode(f));
                h && o.removeChild(h),
                l.appendChecked || n.grep(vb(p, "input"), wb),
                q = 0;
                while (f = p[q++]) if ((!d || -1 === n.inArray(f, d)) && (g = n.contains(f.ownerDocument, f), h = vb(o.appendChild(f), "script"), g && Ab(h), c)) {
                    e = 0;
                    while (f = h[e++]) pb.test(f.type || "") && c.push(f)
                }
                return h = null,
                o
            },
            cleanData: function(a, b) {
                for (var d, e, f, g, h = 0,
                i = n.expando,
                j = n.cache,
                k = l.deleteExpando,
                m = n.event.special; null != (d = a[h]); h++) if ((b || n.acceptData(d)) && (f = d[i], g = f && j[f])) {
                    if (g.events) for (e in g.events) m[e] ? n.event.remove(d, e) : n.removeEvent(d, e, g.handle);
                    j[f] && (delete j[f], k ? delete d[i] : typeof d.removeAttribute !== L ? d.removeAttribute(i) : d[i] = null, c.push(f))
                }
            }
        }),
        n.fn.extend({
            text: function(a) {
                return W(this,
                function(a) {
                    return void 0 === a ? n.text(this) : this.empty().append((this[0] && this[0].ownerDocument || z).createTextNode(a))
                },
                null, a, arguments.length)
            },
            append: function() {
                return this.domManip(arguments,
                function(a) {
                    if (1 === this.nodeType || 11 === this.nodeType || 9 === this.nodeType) {
                        var b = xb(this, a);
                        b.appendChild(a)
                    }
                })
            },
            prepend: function() {
                return this.domManip(arguments,
                function(a) {
                    if (1 === this.nodeType || 11 === this.nodeType || 9 === this.nodeType) {
                        var b = xb(this, a);
                        b.insertBefore(a, b.firstChild)
                    }
                })
            },
            before: function() {
                return this.domManip(arguments,
                function(a) {
                    this.parentNode && this.parentNode.insertBefore(a, this)
                })
            },
            after: function() {
                return this.domManip(arguments,
                function(a) {
                    this.parentNode && this.parentNode.insertBefore(a, this.nextSibling)
                })
            },
            remove: function(a, b) {
                for (var c, d = a ? n.filter(a, this) : this, e = 0; null != (c = d[e]); e++) b || 1 !== c.nodeType || n.cleanData(vb(c)),
                c.parentNode && (b && n.contains(c.ownerDocument, c) && Ab(vb(c, "script")), c.parentNode.removeChild(c));
                return this
            },
            empty: function() {
                for (var a, b = 0; null != (a = this[b]); b++) {
                    1 === a.nodeType && n.cleanData(vb(a, !1));
                    while (a.firstChild) a.removeChild(a.firstChild);
                    a.options && n.nodeName(a, "select") && (a.options.length = 0)
                }
                return this
            },
            clone: function(a, b) {
                return a = null == a ? !1 : a,
                b = null == b ? a: b,
                this.map(function() {
                    return n.clone(this, a, b)
                })
            },
            html: function(a) {
                return W(this,
                function(a) {
                    var b = this[0] || {},
                    c = 0,
                    d = this.length;
                    if (void 0 === a) return 1 === b.nodeType ? b.innerHTML.replace(gb, "") : void 0;
                    if (! ("string" != typeof a || nb.test(a) || !l.htmlSerialize && hb.test(a) || !l.leadingWhitespace && ib.test(a) || sb[(kb.exec(a) || ["", ""])[1].toLowerCase()])) {
                        a = a.replace(jb, "<$1></$2>");
                        try {
                            for (; d > c; c++) b = this[c] || {},
                            1 === b.nodeType && (n.cleanData(vb(b, !1)), b.innerHTML = a);
                            b = 0
                        } catch(e) {}
                    }
                    b && this.empty().append(a)
                },
                null, a, arguments.length)
            },
            replaceWith: function() {
                var a = arguments[0];
                return this.domManip(arguments,
                function(b) {
                    a = this.parentNode,
                    n.cleanData(vb(this)),
                    a && a.replaceChild(b, this)
                }),
                a && (a.length || a.nodeType) ? this: this.remove()
            },
            detach: function(a) {
                return this.remove(a, !0)
            },
            domManip: function(a, b) {
                a = e.apply([], a);
                var c, d, f, g, h, i, j = 0,
                k = this.length,
                m = this,
                o = k - 1,
                p = a[0],
                q = n.isFunction(p);
                if (q || k > 1 && "string" == typeof p && !l.checkClone && ob.test(p)) return this.each(function(c) {
                    var d = m.eq(c);
                    q && (a[0] = p.call(this, c, d.html())),
                    d.domManip(a, b)
                });
                if (k && (i = n.buildFragment(a, this[0].ownerDocument, !1, this), c = i.firstChild, 1 === i.childNodes.length && (i = c), c)) {
                    for (g = n.map(vb(i, "script"), yb), f = g.length; k > j; j++) d = i,
                    j !== o && (d = n.clone(d, !0, !0), f && n.merge(g, vb(d, "script"))),
                    b.call(this[j], d, j);
                    if (f) for (h = g[g.length - 1].ownerDocument, n.map(g, zb), j = 0; f > j; j++) d = g[j],
                    pb.test(d.type || "") && !n._data(d, "globalEval") && n.contains(h, d) && (d.src ? n._evalUrl && n._evalUrl(d.src) : n.globalEval((d.text || d.textContent || d.innerHTML || "").replace(rb, "")));
                    i = c = null
                }
                return this
            }
        }),
        n.each({
            appendTo: "append",
            prependTo: "prepend",
            insertBefore: "before",
            insertAfter: "after",
            replaceAll: "replaceWith"
        },
        function(a, b) {
            n.fn[a] = function(a) {
                for (var c, d = 0,
                e = [], g = n(a), h = g.length - 1; h >= d; d++) c = d === h ? this: this.clone(!0),
                n(g[d])[b](c),
                f.apply(e, c.get());
                return this.pushStack(e)
            }
        });
        var Db, Eb = {};
        function Fb(b, c) {
            var d = n(c.createElement(b)).appendTo(c.body),
            e = a.getDefaultComputedStyle ? a.getDefaultComputedStyle(d[0]).display: n.css(d[0], "display");
            return d.detach(),
            e
        }
        function Gb(a) {
            var b = z,
            c = Eb[a];
            return c || (c = Fb(a, b), "none" !== c && c || (Db = (Db || n("<iframe frameborder='0' width='0' height='0'/>")).appendTo(b.documentElement), b = (Db[0].contentWindow || Db[0].contentDocument).document, b.write(), b.close(), c = Fb(a, b), Db.detach()), Eb[a] = c),
            c
        } !
        function() {
            var a, b, c = z.createElement("div"),
            d = "-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;display:block;padding:0;margin:0;border:0";
            c.innerHTML = "  <link/><table></table><a href='/a'>a</a><input type='checkbox'/>",
            a = c.getElementsByTagName("a")[0],
            a.style.cssText = "float:left;opacity:.5",
            l.opacity = /^0.5/.test(a.style.opacity),
            l.cssFloat = !!a.style.cssFloat,
            c.style.backgroundClip = "content-box",
            c.cloneNode(!0).style.backgroundClip = "",
            l.clearCloneStyle = "content-box" === c.style.backgroundClip,
            a = c = null,
            l.shrinkWrapBlocks = function() {
                var a, c, e, f;
                if (null == b) {
                    if (a = z.getElementsByTagName("body")[0], !a) return;
                    f = "border:0;width:0;height:0;position:absolute;top:0;left:-9999px",
                    c = z.createElement("div"),
                    e = z.createElement("div"),
                    a.appendChild(c).appendChild(e),
                    b = !1,
                    typeof e.style.zoom !== L && (e.style.cssText = d + ";width:1px;padding:1px;zoom:1", e.innerHTML = "<div></div>", e.firstChild.style.width = "5px", b = 3 !== e.offsetWidth),
                    a.removeChild(c),
                    a = c = e = null
                }
                return b
            }
        } ();
        var Hb = /^margin/,
        Ib = new RegExp("^(" + T + ")(?!px)[a-z%]+$", "i"),
        Jb,
        Kb,
        Lb = /^(top|right|bottom|left)$/;
        a.getComputedStyle ? (Jb = function(a) {
            return a.ownerDocument.defaultView.getComputedStyle(a, null)
        },
        Kb = function(a, b, c) {
            var d, e, f, g, h = a.style;
            return c = c || Jb(a),
            g = c ? c.getPropertyValue(b) || c[b] : void 0,
            c && ("" !== g || n.contains(a.ownerDocument, a) || (g = n.style(a, b)), Ib.test(g) && Hb.test(b) && (d = h.width, e = h.minWidth, f = h.maxWidth, h.minWidth = h.maxWidth = h.width = g, g = c.width, h.width = d, h.minWidth = e, h.maxWidth = f)),
            void 0 === g ? g: g + ""
        }) : z.documentElement.currentStyle && (Jb = function(a) {
            return a.currentStyle
        },
        Kb = function(a, b, c) {
            var d, e, f, g, h = a.style;
            return c = c || Jb(a),
            g = c ? c[b] : void 0,
            null == g && h && h[b] && (g = h[b]),
            Ib.test(g) && !Lb.test(b) && (d = h.left, e = a.runtimeStyle, f = e && e.left, f && (e.left = a.currentStyle.left), h.left = "fontSize" === b ? "1em": g, g = h.pixelLeft + "px", h.left = d, f && (e.left = f)),
            void 0 === g ? g: g + "" || "auto"
        });
        function Mb(a, b) {
            return {
                get: function() {
                    var c = a();
                    if (null != c) return c ? void delete this.get: (this.get = b).apply(this, arguments)
                }
            }
        } !
        function() {
            var b, c, d, e, f, g, h = z.createElement("div"),
            i = "border:0;width:0;height:0;position:absolute;top:0;left:-9999px",
            j = "-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;display:block;padding:0;margin:0;border:0";
            h.innerHTML = "  <link/><table></table><a href='/a'>a</a><input type='checkbox'/>",
            b = h.getElementsByTagName("a")[0],
            b.style.cssText = "float:left;opacity:.5",
            l.opacity = /^0.5/.test(b.style.opacity),
            l.cssFloat = !!b.style.cssFloat,
            h.style.backgroundClip = "content-box",
            h.cloneNode(!0).style.backgroundClip = "",
            l.clearCloneStyle = "content-box" === h.style.backgroundClip,
            b = h = null,
            n.extend(l, {
                reliableHiddenOffsets: function() {
                    if (null != c) return c;
                    var a, b, d, e = z.createElement("div"),
                    f = z.getElementsByTagName("body")[0];
                    if (f) return e.setAttribute("className", "t"),
                    e.innerHTML = "  <link/><table></table><a href='/a'>a</a><input type='checkbox'/>",
                    a = z.createElement("div"),
                    a.style.cssText = i,
                    f.appendChild(a).appendChild(e),
                    e.innerHTML = "<table><tr><td></td><td>t</td></tr></table>",
                    b = e.getElementsByTagName("td"),
                    b[0].style.cssText = "padding:0;margin:0;border:0;display:none",
                    d = 0 === b[0].offsetHeight,
                    b[0].style.display = "",
                    b[1].style.display = "none",
                    c = d && 0 === b[0].offsetHeight,
                    f.removeChild(a),
                    e = f = null,
                    c
                },
                boxSizing: function() {
                    return null == d && k(),
                    d
                },
                boxSizingReliable: function() {
                    return null == e && k(),
                    e
                },
                pixelPosition: function() {
                    return null == f && k(),
                    f
                },
                reliableMarginRight: function() {
                    var b, c, d, e;
                    if (null == g && a.getComputedStyle) {
                        if (b = z.getElementsByTagName("body")[0], !b) return;
                        c = z.createElement("div"),
                        d = z.createElement("div"),
                        c.style.cssText = i,
                        b.appendChild(c).appendChild(d),
                        e = d.appendChild(z.createElement("div")),
                        e.style.cssText = d.style.cssText = j,
                        e.style.marginRight = e.style.width = "0",
                        d.style.width = "1px",
                        g = !parseFloat((a.getComputedStyle(e, null) || {}).marginRight),
                        b.removeChild(c)
                    }
                    return g
                }
            });
            function k() {
                var b, c, h = z.getElementsByTagName("body")[0];
                h && (b = z.createElement("div"), c = z.createElement("div"), b.style.cssText = i, h.appendChild(b).appendChild(c), c.style.cssText = "-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;position:absolute;display:block;padding:1px;border:1px;width:4px;margin-top:1%;top:1%", n.swap(h, null != h.style.zoom ? {
                    zoom: 1
                }: {},
                function() {
                    d = 4 === c.offsetWidth
                }), e = !0, f = !1, g = !0, a.getComputedStyle && (f = "1%" !== (a.getComputedStyle(c, null) || {}).top, e = "4px" === (a.getComputedStyle(c, null) || {
                    width: "4px"
                }).width), h.removeChild(b), c = h = null)
            }
        } (),
        n.swap = function(a, b, c, d) {
            var e, f, g = {};
            for (f in b) g[f] = a.style[f],
            a.style[f] = b[f];
            e = c.apply(a, d || []);
            for (f in b) a.style[f] = g[f];
            return e
        };
        var Nb = /alpha\([^)]*\)/i,
        Ob = /opacity\s*=\s*([^)]*)/,
        Pb = /^(none|table(?!-c[ea]).+)/,
        Qb = new RegExp("^(" + T + ")(.*)$", "i"),
        Rb = new RegExp("^([+-])=(" + T + ")", "i"),
        Sb = {
            position: "absolute",
            visibility: "hidden",
            display: "block"
        },
        Tb = {
            letterSpacing: 0,
            fontWeight: 400
        },
        Ub = ["Webkit", "O", "Moz", "ms"];
        function Vb(a, b) {
            if (b in a) return b;
            var c = b.charAt(0).toUpperCase() + b.slice(1),
            d = b,
            e = Ub.length;
            while (e--) if (b = Ub[e] + c, b in a) return b;
            return d
        }
        function Wb(a, b) {
            for (var c, d, e, f = [], g = 0, h = a.length; h > g; g++) d = a[g],
            d.style && (f[g] = n._data(d, "olddisplay"), c = d.style.display, b ? (f[g] || "none" !== c || (d.style.display = ""), "" === d.style.display && V(d) && (f[g] = n._data(d, "olddisplay", Gb(d.nodeName)))) : f[g] || (e = V(d), (c && "none" !== c || !e) && n._data(d, "olddisplay", e ? c: n.css(d, "display"))));
            for (g = 0; h > g; g++) d = a[g],
            d.style && (b && "none" !== d.style.display && "" !== d.style.display || (d.style.display = b ? f[g] || "": "none"));
            return a
        }
        function Xb(a, b, c) {
            var d = Qb.exec(b);
            return d ? Math.max(0, d[1] - (c || 0)) + (d[2] || "px") : b
        }
        function Yb(a, b, c, d, e) {
            for (var f = c === (d ? "border": "content") ? 4 : "width" === b ? 1 : 0, g = 0; 4 > f; f += 2)"margin" === c && (g += n.css(a, c + U[f], !0, e)),
            d ? ("content" === c && (g -= n.css(a, "padding" + U[f], !0, e)), "margin" !== c && (g -= n.css(a, "border" + U[f] + "Width", !0, e))) : (g += n.css(a, "padding" + U[f], !0, e), "padding" !== c && (g += n.css(a, "border" + U[f] + "Width", !0, e)));
            return g
        }
        function Zb(a, b, c) {
            var d = !0,
            e = "width" === b ? a.offsetWidth: a.offsetHeight,
            f = Jb(a),
            g = l.boxSizing() && "border-box" === n.css(a, "boxSizing", !1, f);
            if (0 >= e || null == e) {
                if (e = Kb(a, b, f), (0 > e || null == e) && (e = a.style[b]), Ib.test(e)) return e;
                d = g && (l.boxSizingReliable() || e === a.style[b]),
                e = parseFloat(e) || 0
            }
            return e + Yb(a, b, c || (g ? "border": "content"), d, f) + "px"
        }
        n.extend({
            cssHooks: {
                opacity: {
                    get: function(a, b) {
                        if (b) {
                            var c = Kb(a, "opacity");
                            return "" === c ? "1": c
                        }
                    }
                }
            },
            cssNumber: {
                columnCount: !0,
                fillOpacity: !0,
                fontWeight: !0,
                lineHeight: !0,
                opacity: !0,
                order: !0,
                orphans: !0,
                widows: !0,
                zIndex: !0,
                zoom: !0
            },
            cssProps: {
                "float": l.cssFloat ? "cssFloat": "styleFloat"
            },
            style: function(a, b, c, d) {
                if (a && 3 !== a.nodeType && 8 !== a.nodeType && a.style) {
                    var e, f, g, h = n.camelCase(b),
                    i = a.style;
                    if (b = n.cssProps[h] || (n.cssProps[h] = Vb(i, h)), g = n.cssHooks[b] || n.cssHooks[h], void 0 === c) return g && "get" in g && void 0 !== (e = g.get(a, !1, d)) ? e: i[b];
                    if (f = typeof c, "string" === f && (e = Rb.exec(c)) && (c = (e[1] + 1) * e[2] + parseFloat(n.css(a, b)), f = "number"), null != c && c === c && ("number" !== f || n.cssNumber[h] || (c += "px"), l.clearCloneStyle || "" !== c || 0 !== b.indexOf("background") || (i[b] = "inherit"), !(g && "set" in g && void 0 === (c = g.set(a, c, d))))) try {
                        i[b] = "",
                        i[b] = c
                    } catch(j) {}
                }
            },
            css: function(a, b, c, d) {
                var e, f, g, h = n.camelCase(b);
                return b = n.cssProps[h] || (n.cssProps[h] = Vb(a.style, h)),
                g = n.cssHooks[b] || n.cssHooks[h],
                g && "get" in g && (f = g.get(a, !0, c)),
                void 0 === f && (f = Kb(a, b, d)),
                "normal" === f && b in Tb && (f = Tb[b]),
                "" === c || c ? (e = parseFloat(f), c === !0 || n.isNumeric(e) ? e || 0 : f) : f
            }
        }),
        n.each(["height", "width"],
        function(a, b) {
            n.cssHooks[b] = {
                get: function(a, c, d) {
                    return c ? 0 === a.offsetWidth && Pb.test(n.css(a, "display")) ? n.swap(a, Sb,
                    function() {
                        return Zb(a, b, d)
                    }) : Zb(a, b, d) : void 0
                },
                set: function(a, c, d) {
                    var e = d && Jb(a);
                    return Xb(a, c, d ? Yb(a, b, d, l.boxSizing() && "border-box" === n.css(a, "boxSizing", !1, e), e) : 0)
                }
            }
        }),
        l.opacity || (n.cssHooks.opacity = {
            get: function(a, b) {
                return Ob.test((b && a.currentStyle ? a.currentStyle.filter: a.style.filter) || "") ? .01 * parseFloat(RegExp.$1) + "": b ? "1": ""
            },
            set: function(a, b) {
                var c = a.style,
                d = a.currentStyle,
                e = n.isNumeric(b) ? "alpha(opacity=" + 100 * b + ")": "",
                f = d && d.filter || c.filter || "";
                c.zoom = 1,
                (b >= 1 || "" === b) && "" === n.trim(f.replace(Nb, "")) && c.removeAttribute && (c.removeAttribute("filter"), "" === b || d && !d.filter) || (c.filter = Nb.test(f) ? f.replace(Nb, e) : f + " " + e)
            }
        }),
        n.cssHooks.marginRight = Mb(l.reliableMarginRight,
        function(a, b) {
            return b ? n.swap(a, {
                display: "inline-block"
            },
            Kb, [a, "marginRight"]) : void 0
        }),
        n.each({
            margin: "",
            padding: "",
            border: "Width"
        },
        function(a, b) {
            n.cssHooks[a + b] = {
                expand: function(c) {
                    for (var d = 0,
                    e = {},
                    f = "string" == typeof c ? c.split(" ") : [c]; 4 > d; d++) e[a + U[d] + b] = f[d] || f[d - 2] || f[0];
                    return e
                }
            },
            Hb.test(a) || (n.cssHooks[a + b].set = Xb)
        }),
        n.fn.extend({
            css: function(a, b) {
                return W(this,
                function(a, b, c) {
                    var d, e, f = {},
                    g = 0;
                    if (n.isArray(b)) {
                        for (d = Jb(a), e = b.length; e > g; g++) f[b[g]] = n.css(a, b[g], !1, d);
                        return f
                    }
                    return void 0 !== c ? n.style(a, b, c) : n.css(a, b)
                },
                a, b, arguments.length > 1)
            },
            show: function() {
                return Wb(this, !0)
            },
            hide: function() {
                return Wb(this)
            },
            toggle: function(a) {
                return "boolean" == typeof a ? a ? this.show() : this.hide() : this.each(function() {
                    V(this) ? n(this).show() : n(this).hide()
                })
            }
        });
        function $b(a, b, c, d, e) {
            return new $b.prototype.init(a, b, c, d, e)
        }
        n.Tween = $b,
        $b.prototype = {
            constructor: $b,
            init: function(a, b, c, d, e, f) {
                this.elem = a,
                this.prop = c,
                this.easing = e || "swing",
                this.options = b,
                this.start = this.now = this.cur(),
                this.end = d,
                this.unit = f || (n.cssNumber[c] ? "": "px")
            },
            cur: function() {
                var a = $b.propHooks[this.prop];
                return a && a.get ? a.get(this) : $b.propHooks._default.get(this)
            },
            run: function(a) {
                var b, c = $b.propHooks[this.prop];
                return this.pos = b = this.options.duration ? n.easing[this.easing](a, this.options.duration * a, 0, 1, this.options.duration) : a,
                this.now = (this.end - this.start) * b + this.start,
                this.options.step && this.options.step.call(this.elem, this.now, this),
                c && c.set ? c.set(this) : $b.propHooks._default.set(this),
                this
            }
        },
        $b.prototype.init.prototype = $b.prototype,
        $b.propHooks = {
            _default: {
                get: function(a) {
                    var b;
                    return null == a.elem[a.prop] || a.elem.style && null != a.elem.style[a.prop] ? (b = n.css(a.elem, a.prop, ""), b && "auto" !== b ? b: 0) : a.elem[a.prop]
                },
                set: function(a) {
                    n.fx.step[a.prop] ? n.fx.step[a.prop](a) : a.elem.style && (null != a.elem.style[n.cssProps[a.prop]] || n.cssHooks[a.prop]) ? n.style(a.elem, a.prop, a.now + a.unit) : a.elem[a.prop] = a.now
                }
            }
        },
        $b.propHooks.scrollTop = $b.propHooks.scrollLeft = {
            set: function(a) {
                a.elem.nodeType && a.elem.parentNode && (a.elem[a.prop] = a.now)
            }
        },
        n.easing = {
            linear: function(a) {
                return a
            },
            swing: function(a) {
                return.5 - Math.cos(a * Math.PI) / 2
            }
        },
        n.fx = $b.prototype.init,
        n.fx.step = {};
        var _b, ac, bc = /^(?:toggle|show|hide)$/,
        cc = new RegExp("^(?:([+-])=|)(" + T + ")([a-z%]*)$", "i"),
        dc = /queueHooks$/,
        ec = [jc],
        fc = {
            "*": [function(a, b) {
                var c = this.createTween(a, b),
                d = c.cur(),
                e = cc.exec(b),
                f = e && e[3] || (n.cssNumber[a] ? "": "px"),
                g = (n.cssNumber[a] || "px" !== f && +d) && cc.exec(n.css(c.elem, a)),
                h = 1,
                i = 20;
                if (g && g[3] !== f) {
                    f = f || g[3],
                    e = e || [],
                    g = +d || 1;
                    do h = h || ".5",
                    g /= h,
                    n.style(c.elem, a, g + f);
                    while (h !== (h = c.cur() / d) && 1 !== h && --i)
                }
                return e && (g = c.start = +g || +d || 0, c.unit = f, c.end = e[1] ? g + (e[1] + 1) * e[2] : +e[2]),
                c
            }]
        };
        function gc() {
            return setTimeout(function() {
                _b = void 0
            }),
            _b = n.now()
        }
        function hc(a, b) {
            var c, d = {
                height: a
            },
            e = 0;
            for (b = b ? 1 : 0; 4 > e; e += 2 - b) c = U[e],
            d["margin" + c] = d["padding" + c] = a;
            return b && (d.opacity = d.width = a),
            d
        }
        function ic(a, b, c) {
            for (var d, e = (fc[b] || []).concat(fc["*"]), f = 0, g = e.length; g > f; f++) if (d = e[f].call(c, b, a)) return d
        }
        function jc(a, b, c) {
            var d, e, f, g, h, i, j, k, m = this,
            o = {},
            p = a.style,
            q = a.nodeType && V(a),
            r = n._data(a, "fxshow");
            c.queue || (h = n._queueHooks(a, "fx"), null == h.unqueued && (h.unqueued = 0, i = h.empty.fire, h.empty.fire = function() {
                h.unqueued || i()
            }), h.unqueued++, m.always(function() {
                m.always(function() {
                    h.unqueued--,
                    n.queue(a, "fx").length || h.empty.fire()
                })
            })),
            1 === a.nodeType && ("height" in b || "width" in b) && (c.overflow = [p.overflow, p.overflowX, p.overflowY], j = n.css(a, "display"), k = Gb(a.nodeName), "none" === j && (j = k), "inline" === j && "none" === n.css(a, "float") && (l.inlineBlockNeedsLayout && "inline" !== k ? p.zoom = 1 : p.display = "inline-block")),
            c.overflow && (p.overflow = "hidden", l.shrinkWrapBlocks() || m.always(function() {
                p.overflow = c.overflow[0],
                p.overflowX = c.overflow[1],
                p.overflowY = c.overflow[2]
            }));
            for (d in b) if (e = b[d], bc.exec(e)) {
                if (delete b[d], f = f || "toggle" === e, e === (q ? "hide": "show")) {
                    if ("show" !== e || !r || void 0 === r[d]) continue;
                    q = !0
                }
                o[d] = r && r[d] || n.style(a, d)
            }
            if (!n.isEmptyObject(o)) {
                r ? "hidden" in r && (q = r.hidden) : r = n._data(a, "fxshow", {}),
                f && (r.hidden = !q),
                q ? n(a).show() : m.done(function() {
                    n(a).hide()
                }),
                m.done(function() {
                    var b;
                    n._removeData(a, "fxshow");
                    for (b in o) n.style(a, b, o[b])
                });
                for (d in o) g = ic(q ? r[d] : 0, d, m),
                d in r || (r[d] = g.start, q && (g.end = g.start, g.start = "width" === d || "height" === d ? 1 : 0))
            }
        }
        function kc(a, b) {
            var c, d, e, f, g;
            for (c in a) if (d = n.camelCase(c), e = b[d], f = a[c], n.isArray(f) && (e = f[1], f = a[c] = f[0]), c !== d && (a[d] = f, delete a[c]), g = n.cssHooks[d], g && "expand" in g) {
                f = g.expand(f),
                delete a[d];
                for (c in f) c in a || (a[c] = f[c], b[c] = e)
            } else b[d] = e
        }
        function lc(a, b, c) {
            var d, e, f = 0,
            g = ec.length,
            h = n.Deferred().always(function() {
                delete i.elem
            }),
            i = function() {
                if (e) return ! 1;
                for (var b = _b || gc(), c = Math.max(0, j.startTime + j.duration - b), d = c / j.duration || 0, f = 1 - d, g = 0, i = j.tweens.length; i > g; g++) j.tweens[g].run(f);
                return h.notifyWith(a, [j, f, c]),
                1 > f && i ? c: (h.resolveWith(a, [j]), !1)
            },
            j = h.promise({
                elem: a,
                props: n.extend({},
                b),
                opts: n.extend(!0, {
                    specialEasing: {}
                },
                c),
                originalProperties: b,
                originalOptions: c,
                startTime: _b || gc(),
                duration: c.duration,
                tweens: [],
                createTween: function(b, c) {
                    var d = n.Tween(a, j.opts, b, c, j.opts.specialEasing[b] || j.opts.easing);
                    return j.tweens.push(d),
                    d
                },
                stop: function(b) {
                    var c = 0,
                    d = b ? j.tweens.length: 0;
                    if (e) return this;
                    for (e = !0; d > c; c++) j.tweens[c].run(1);
                    return b ? h.resolveWith(a, [j, b]) : h.rejectWith(a, [j, b]),
                    this
                }
            }),
            k = j.props;
            for (kc(k, j.opts.specialEasing); g > f; f++) if (d = ec[f].call(j, a, k, j.opts)) return d;
            return n.map(k, ic, j),
            n.isFunction(j.opts.start) && j.opts.start.call(a, j),
            n.fx.timer(n.extend(i, {
                elem: a,
                anim: j,
                queue: j.opts.queue
            })),
            j.progress(j.opts.progress).done(j.opts.done, j.opts.complete).fail(j.opts.fail).always(j.opts.always)
        }
        n.Animation = n.extend(lc, {
            tweener: function(a, b) {
                n.isFunction(a) ? (b = a, a = ["*"]) : a = a.split(" ");
                for (var c, d = 0,
                e = a.length; e > d; d++) c = a[d],
                fc[c] = fc[c] || [],
                fc[c].unshift(b)
            },
            prefilter: function(a, b) {
                b ? ec.unshift(a) : ec.push(a)
            }
        }),
        n.speed = function(a, b, c) {
            var d = a && "object" == typeof a ? n.extend({},
            a) : {
                complete: c || !c && b || n.isFunction(a) && a,
                duration: a,
                easing: c && b || b && !n.isFunction(b) && b
            };
            return d.duration = n.fx.off ? 0 : "number" == typeof d.duration ? d.duration: d.duration in n.fx.speeds ? n.fx.speeds[d.duration] : n.fx.speeds._default,
            (null == d.queue || d.queue === !0) && (d.queue = "fx"),
            d.old = d.complete,
            d.complete = function() {
                n.isFunction(d.old) && d.old.call(this),
                d.queue && n.dequeue(this, d.queue)
            },
            d
        },
        n.fn.extend({
            fadeTo: function(a, b, c, d) {
                return this.filter(V).css("opacity", 0).show().end().animate({
                    opacity: b
                },
                a, c, d)
            },
            animate: function(a, b, c, d) {
                var e = n.isEmptyObject(a),
                f = n.speed(b, c, d),
                g = function() {
                    var b = lc(this, n.extend({},
                    a), f); (e || n._data(this, "finish")) && b.stop(!0)
                };
                return g.finish = g,
                e || f.queue === !1 ? this.each(g) : this.queue(f.queue, g)
            },
            stop: function(a, b, c) {
                var d = function(a) {
                    var b = a.stop;
                    delete a.stop,
                    b(c)
                };
                return "string" != typeof a && (c = b, b = a, a = void 0),
                b && a !== !1 && this.queue(a || "fx", []),
                this.each(function() {
                    var b = !0,
                    e = null != a && a + "queueHooks",
                    f = n.timers,
                    g = n._data(this);
                    if (e) g[e] && g[e].stop && d(g[e]);
                    else for (e in g) g[e] && g[e].stop && dc.test(e) && d(g[e]);
                    for (e = f.length; e--;) f[e].elem !== this || null != a && f[e].queue !== a || (f[e].anim.stop(c), b = !1, f.splice(e, 1)); (b || !c) && n.dequeue(this, a)
                })
            },
            finish: function(a) {
                return a !== !1 && (a = a || "fx"),
                this.each(function() {
                    var b, c = n._data(this),
                    d = c[a + "queue"],
                    e = c[a + "queueHooks"],
                    f = n.timers,
                    g = d ? d.length: 0;
                    for (c.finish = !0, n.queue(this, a, []), e && e.stop && e.stop.call(this, !0), b = f.length; b--;) f[b].elem === this && f[b].queue === a && (f[b].anim.stop(!0), f.splice(b, 1));
                    for (b = 0; g > b; b++) d[b] && d[b].finish && d[b].finish.call(this);
                    delete c.finish
                })
            }
        }),
        n.each(["toggle", "show", "hide"],
        function(a, b) {
            var c = n.fn[b];
            n.fn[b] = function(a, d, e) {
                return null == a || "boolean" == typeof a ? c.apply(this, arguments) : this.animate(hc(b, !0), a, d, e)
            }
        }),
        n.each({
            slideDown: hc("show"),
            slideUp: hc("hide"),
            slideToggle: hc("toggle"),
            fadeIn: {
                opacity: "show"
            },
            fadeOut: {
                opacity: "hide"
            },
            fadeToggle: {
                opacity: "toggle"
            }
        },
        function(a, b) {
            n.fn[a] = function(a, c, d) {
                return this.animate(b, a, c, d)
            }
        }),
        n.timers = [],
        n.fx.tick = function() {
            var a, b = n.timers,
            c = 0;
            for (_b = n.now(); c < b.length; c++) a = b[c],
            a() || b[c] !== a || b.splice(c--, 1);
            b.length || n.fx.stop(),
            _b = void 0
        },
        n.fx.timer = function(a) {
            n.timers.push(a),
            a() ? n.fx.start() : n.timers.pop()
        },
        n.fx.interval = 13,
        n.fx.start = function() {
            ac || (ac = setInterval(n.fx.tick, n.fx.interval))
        },
        n.fx.stop = function() {
            clearInterval(ac),
            ac = null
        },
        n.fx.speeds = {
            slow: 600,
            fast: 200,
            _default: 400
        },
        n.fn.delay = function(a, b) {
            return a = n.fx ? n.fx.speeds[a] || a: a,
            b = b || "fx",
            this.queue(b,
            function(b, c) {
                var d = setTimeout(b, a);
                c.stop = function() {
                    clearTimeout(d)
                }
            })
        },
        function() {
            var a, b, c, d, e = z.createElement("div");
            e.setAttribute("className", "t"),
            e.innerHTML = "  <link/><table></table><a href='/a'>a</a><input type='checkbox'/>",
            a = e.getElementsByTagName("a")[0],
            c = z.createElement("select"),
            d = c.appendChild(z.createElement("option")),
            b = e.getElementsByTagName("input")[0],
            a.style.cssText = "top:1px",
            l.getSetAttribute = "t" !== e.className,
            l.style = /top/.test(a.getAttribute("style")),
            l.hrefNormalized = "/a" === a.getAttribute("href"),
            l.checkOn = !!b.value,
            l.optSelected = d.selected,
            l.enctype = !!z.createElement("form").enctype,
            c.disabled = !0,
            l.optDisabled = !d.disabled,
            b = z.createElement("input"),
            b.setAttribute("value", ""),
            l.input = "" === b.getAttribute("value"),
            b.value = "t",
            b.setAttribute("type", "radio"),
            l.radioValue = "t" === b.value,
            a = b = c = d = e = null
        } ();
        var mc = /\r/g;
        n.fn.extend({
            val: function(a) {
                var b, c, d, e = this[0]; {
                    if (arguments.length) return d = n.isFunction(a),
                    this.each(function(c) {
                        var e;
                        1 === this.nodeType && (e = d ? a.call(this, c, n(this).val()) : a, null == e ? e = "": "number" == typeof e ? e += "": n.isArray(e) && (e = n.map(e,
                        function(a) {
                            return null == a ? "": a + ""
                        })), b = n.valHooks[this.type] || n.valHooks[this.nodeName.toLowerCase()], b && "set" in b && void 0 !== b.set(this, e, "value") || (this.value = e))
                    });
                    if (e) return b = n.valHooks[e.type] || n.valHooks[e.nodeName.toLowerCase()],
                    b && "get" in b && void 0 !== (c = b.get(e, "value")) ? c: (c = e.value, "string" == typeof c ? c.replace(mc, "") : null == c ? "": c)
                }
            }
        }),
        n.extend({
            valHooks: {
                option: {
                    get: function(a) {
                        var b = n.find.attr(a, "value");
                        return null != b ? b: n.text(a)
                    }
                },
                select: {
                    get: function(a) {
                        for (var b, c, d = a.options,
                        e = a.selectedIndex,
                        f = "select-one" === a.type || 0 > e,
                        g = f ? null: [], h = f ? e + 1 : d.length, i = 0 > e ? h: f ? e: 0; h > i; i++) if (c = d[i], !(!c.selected && i !== e || (l.optDisabled ? c.disabled: null !== c.getAttribute("disabled")) || c.parentNode.disabled && n.nodeName(c.parentNode, "optgroup"))) {
                            if (b = n(c).val(), f) return b;
                            g.push(b)
                        }
                        return g
                    },
                    set: function(a, b) {
                        var c, d, e = a.options,
                        f = n.makeArray(b),
                        g = e.length;
                        while (g--) if (d = e[g], n.inArray(n.valHooks.option.get(d), f) >= 0) try {
                            d.selected = c = !0
                        } catch(h) {
                            d.scrollHeight
                        } else d.selected = !1;
                        return c || (a.selectedIndex = -1),
                        e
                    }
                }
            }
        }),
        n.each(["radio", "checkbox"],
        function() {
            n.valHooks[this] = {
                set: function(a, b) {
                    return n.isArray(b) ? a.checked = n.inArray(n(a).val(), b) >= 0 : void 0
                }
            },
            l.checkOn || (n.valHooks[this].get = function(a) {
                return null === a.getAttribute("value") ? "on": a.value
            })
        });
        var nc, oc, pc = n.expr.attrHandle,
        qc = /^(?:checked|selected)$/i,
        rc = l.getSetAttribute,
        sc = l.input;
        n.fn.extend({
            attr: function(a, b) {
                return W(this, n.attr, a, b, arguments.length > 1)
            },
            removeAttr: function(a) {
                return this.each(function() {
                    n.removeAttr(this, a)
                })
            }
        }),
        n.extend({
            attr: function(a, b, c) {
                var d, e, f = a.nodeType;
                if (a && 3 !== f && 8 !== f && 2 !== f) return typeof a.getAttribute === L ? n.prop(a, b, c) : (1 === f && n.isXMLDoc(a) || (b = b.toLowerCase(), d = n.attrHooks[b] || (n.expr.match.bool.test(b) ? oc: nc)), void 0 === c ? d && "get" in d && null !== (e = d.get(a, b)) ? e: (e = n.find.attr(a, b), null == e ? void 0 : e) : null !== c ? d && "set" in d && void 0 !== (e = d.set(a, c, b)) ? e: (a.setAttribute(b, c + ""), c) : void n.removeAttr(a, b))
            },
            removeAttr: function(a, b) {
                var c, d, e = 0,
                f = b && b.match(F);
                if (f && 1 === a.nodeType) while (c = f[e++]) d = n.propFix[c] || c,
                n.expr.match.bool.test(c) ? sc && rc || !qc.test(c) ? a[d] = !1 : a[n.camelCase("default-" + c)] = a[d] = !1 : n.attr(a, c, ""),
                a.removeAttribute(rc ? c: d)
            },
            attrHooks: {
                type: {
                    set: function(a, b) {
                        if (!l.radioValue && "radio" === b && n.nodeName(a, "input")) {
                            var c = a.value;
                            return a.setAttribute("type", b),
                            c && (a.value = c),
                            b
                        }
                    }
                }
            }
        }),
        oc = {
            set: function(a, b, c) {
                return b === !1 ? n.removeAttr(a, c) : sc && rc || !qc.test(c) ? a.setAttribute(!rc && n.propFix[c] || c, c) : a[n.camelCase("default-" + c)] = a[c] = !0,
                c
            }
        },
        n.each(n.expr.match.bool.source.match(/\w+/g),
        function(a, b) {
            var c = pc[b] || n.find.attr;
            pc[b] = sc && rc || !qc.test(b) ?
            function(a, b, d) {
                var e, f;
                return d || (f = pc[b], pc[b] = e, e = null != c(a, b, d) ? b.toLowerCase() : null, pc[b] = f),
                e
            }: function(a, b, c) {
                return c ? void 0 : a[n.camelCase("default-" + b)] ? b.toLowerCase() : null
            }
        }),
        sc && rc || (n.attrHooks.value = {
            set: function(a, b, c) {
                return n.nodeName(a, "input") ? void(a.defaultValue = b) : nc && nc.set(a, b, c)
            }
        }),
        rc || (nc = {
            set: function(a, b, c) {
                var d = a.getAttributeNode(c);
                return d || a.setAttributeNode(d = a.ownerDocument.createAttribute(c)),
                d.value = b += "",
                "value" === c || b === a.getAttribute(c) ? b: void 0
            }
        },
        pc.id = pc.name = pc.coords = function(a, b, c) {
            var d;
            return c ? void 0 : (d = a.getAttributeNode(b)) && "" !== d.value ? d.value: null
        },
        n.valHooks.button = {
            get: function(a, b) {
                var c = a.getAttributeNode(b);
                return c && c.specified ? c.value: void 0
            },
            set: nc.set
        },
        n.attrHooks.contenteditable = {
            set: function(a, b, c) {
                nc.set(a, "" === b ? !1 : b, c)
            }
        },
        n.each(["width", "height"],
        function(a, b) {
            n.attrHooks[b] = {
                set: function(a, c) {
                    return "" === c ? (a.setAttribute(b, "auto"), c) : void 0
                }
            }
        })),
        l.style || (n.attrHooks.style = {
            get: function(a) {
                return a.style.cssText || void 0
            },
            set: function(a, b) {
                return a.style.cssText = b + ""
            }
        });
        var tc = /^(?:input|select|textarea|button|object)$/i,
        uc = /^(?:a|area)$/i;
        n.fn.extend({
            prop: function(a, b) {
                return W(this, n.prop, a, b, arguments.length > 1)
            },
            removeProp: function(a) {
                return a = n.propFix[a] || a,
                this.each(function() {
                    try {
                        this[a] = void 0,
                        delete this[a]
                    } catch(b) {}
                })
            }
        }),
        n.extend({
            propFix: {
                "for": "htmlFor",
                "class": "className"
            },
            prop: function(a, b, c) {
                var d, e, f, g = a.nodeType;
                if (a && 3 !== g && 8 !== g && 2 !== g) return f = 1 !== g || !n.isXMLDoc(a),
                f && (b = n.propFix[b] || b, e = n.propHooks[b]),
                void 0 !== c ? e && "set" in e && void 0 !== (d = e.set(a, c, b)) ? d: a[b] = c: e && "get" in e && null !== (d = e.get(a, b)) ? d: a[b]
            },
            propHooks: {
                tabIndex: {
                    get: function(a) {
                        var b = n.find.attr(a, "tabindex");
                        return b ? parseInt(b, 10) : tc.test(a.nodeName) || uc.test(a.nodeName) && a.href ? 0 : -1
                    }
                }
            }
        }),
        l.hrefNormalized || n.each(["href", "src"],
        function(a, b) {
            n.propHooks[b] = {
                get: function(a) {
                    return a.getAttribute(b, 4)
                }
            }
        }),
        l.optSelected || (n.propHooks.selected = {
            get: function(a) {
                var b = a.parentNode;
                return b && (b.selectedIndex, b.parentNode && b.parentNode.selectedIndex),
                null
            }
        }),
        n.each(["tabIndex", "readOnly", "maxLength", "cellSpacing", "cellPadding", "rowSpan", "colSpan", "useMap", "frameBorder", "contentEditable"],
        function() {
            n.propFix[this.toLowerCase()] = this
        }),
        l.enctype || (n.propFix.enctype = "encoding");
        var vc = /[\t\r\n\f]/g;
        n.fn.extend({
            addClass: function(a) {
                var b, c, d, e, f, g, h = 0,
                i = this.length,
                j = "string" == typeof a && a;
                if (n.isFunction(a)) return this.each(function(b) {
                    n(this).addClass(a.call(this, b, this.className))
                });
                if (j) for (b = (a || "").match(F) || []; i > h; h++) if (c = this[h], d = 1 === c.nodeType && (c.className ? (" " + c.className + " ").replace(vc, " ") : " ")) {
                    f = 0;
                    while (e = b[f++]) d.indexOf(" " + e + " ") < 0 && (d += e + " ");
                    g = n.trim(d),
                    c.className !== g && (c.className = g)
                }
                return this
            },
            removeClass: function(a) {
                var b, c, d, e, f, g, h = 0,
                i = this.length,
                j = 0 === arguments.length || "string" == typeof a && a;
                if (n.isFunction(a)) return this.each(function(b) {
                    n(this).removeClass(a.call(this, b, this.className))
                });
                if (j) for (b = (a || "").match(F) || []; i > h; h++) if (c = this[h], d = 1 === c.nodeType && (c.className ? (" " + c.className + " ").replace(vc, " ") : "")) {
                    f = 0;
                    while (e = b[f++]) while (d.indexOf(" " + e + " ") >= 0) d = d.replace(" " + e + " ", " ");
                    g = a ? n.trim(d) : "",
                    c.className !== g && (c.className = g)
                }
                return this
            },
            toggleClass: function(a, b) {
                var c = typeof a;
                return "boolean" == typeof b && "string" === c ? b ? this.addClass(a) : this.removeClass(a) : this.each(n.isFunction(a) ?
                function(c) {
                    n(this).toggleClass(a.call(this, c, this.className, b), b)
                }: function() {
                    if ("string" === c) {
                        var b, d = 0,
                        e = n(this),
                        f = a.match(F) || [];
                        while (b = f[d++]) e.hasClass(b) ? e.removeClass(b) : e.addClass(b)
                    } else(c === L || "boolean" === c) && (this.className && n._data(this, "__className__", this.className), this.className = this.className || a === !1 ? "": n._data(this, "__className__") || "")
                })
            },
            hasClass: function(a) {
                for (var b = " " + a + " ",
                c = 0,
                d = this.length; d > c; c++) if (1 === this[c].nodeType && (" " + this[c].className + " ").replace(vc, " ").indexOf(b) >= 0) return ! 0;
                return ! 1
            }
        }),
        n.each("blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error contextmenu".split(" "),
        function(a, b) {
            n.fn[b] = function(a, c) {
                return arguments.length > 0 ? this.on(b, null, a, c) : this.trigger(b)
            }
        }),
        n.fn.extend({
            hover: function(a, b) {
                return this.mouseenter(a).mouseleave(b || a)
            },
            bind: function(a, b, c) {
                return this.on(a, null, b, c)
            },
            unbind: function(a, b) {
                return this.off(a, null, b)
            },
            delegate: function(a, b, c, d) {
                return this.on(b, a, c, d)
            },
            undelegate: function(a, b, c) {
                return 1 === arguments.length ? this.off(a, "**") : this.off(b, a || "**", c)
            }
        });
        var wc = n.now(),
        xc = /\?/,
        yc = /(,)|(\[|{)|(}|])|"(?:[^"\\\r\n]|\\["\\\/bfnrt]|\\u[\da-fA-F]{4})*"\s*:?|true|false|null|-?(?!0\d)\d+(?:\.\d+|)(?:[eE][+-]?\d+|)/g;
        n.parseJSON = function(b) {
            if (a.JSON && a.JSON.parse) return a.JSON.parse(b + "");
            var c, d = null,
            e = n.trim(b + "");
            return e && !n.trim(e.replace(yc,
            function(a, b, e, f) {
                return c && b && (d = 0),
                0 === d ? a: (c = e || b, d += !f - !e, "")
            })) ? Function("return " + e)() : n.error("Invalid JSON: " + b)
        },
        n.parseXML = function(b) {
            var c, d;
            if (!b || "string" != typeof b) return null;
            try {
                a.DOMParser ? (d = new DOMParser, c = d.parseFromString(b, "text/xml")) : (c = new ActiveXObject("Microsoft.XMLDOM"), c.async = "false", c.loadXML(b))
            } catch(e) {
                c = void 0
            }
            return c && c.documentElement && !c.getElementsByTagName("parsererror").length || n.error("Invalid XML: " + b),
            c
        };
        var zc, Ac, Bc = /#.*$/,
        Cc = /([?&])_=[^&]*/,
        Dc = /^(.*?):[ \t]*([^\r\n]*)\r?$/gm,
        Ec = /^(?:about|app|app-storage|.+-extension|file|res|widget):$/,
        Fc = /^(?:GET|HEAD)$/,
        Gc = /^\/\//,
        Hc = /^([\w.+-]+:)(?:\/\/(?:[^\/?#]*@|)([^\/?#:]*)(?::(\d+)|)|)/,
        Ic = {},
        Jc = {},
        Kc = "*/".concat("*");
        try {
            Ac = location.href
        } catch(Lc) {
            Ac = z.createElement("a"),
            Ac.href = "",
            Ac = Ac.href
        }
        zc = Hc.exec(Ac.toLowerCase()) || [];
        function Mc(a) {
            return function(b, c) {
                "string" != typeof b && (c = b, b = "*");
                var d, e = 0,
                f = b.toLowerCase().match(F) || [];
                if (n.isFunction(c)) while (d = f[e++])"+" === d.charAt(0) ? (d = d.slice(1) || "*", (a[d] = a[d] || []).unshift(c)) : (a[d] = a[d] || []).push(c)
            }
        }
        function Nc(a, b, c, d) {
            var e = {},
            f = a === Jc;
            function g(h) {
                var i;
                return e[h] = !0,
                n.each(a[h] || [],
                function(a, h) {
                    var j = h(b, c, d);
                    return "string" != typeof j || f || e[j] ? f ? !(i = j) : void 0 : (b.dataTypes.unshift(j), g(j), !1)
                }),
                i
            }
            return g(b.dataTypes[0]) || !e["*"] && g("*")
        }
        function Oc(a, b) {
            var c, d, e = n.ajaxSettings.flatOptions || {};
            for (d in b) void 0 !== b[d] && ((e[d] ? a: c || (c = {}))[d] = b[d]);
            return c && n.extend(!0, a, c),
            a
        }
        function Pc(a, b, c) {
            var d, e, f, g, h = a.contents,
            i = a.dataTypes;
            while ("*" === i[0]) i.shift(),
            void 0 === e && (e = a.mimeType || b.getResponseHeader("Content-Type"));
            if (e) for (g in h) if (h[g] && h[g].test(e)) {
                i.unshift(g);
                break
            }
            if (i[0] in c) f = i[0];
            else {
                for (g in c) {
                    if (!i[0] || a.converters[g + " " + i[0]]) {
                        f = g;
                        break
                    }
                    d || (d = g)
                }
                f = f || d
            }
            return f ? (f !== i[0] && i.unshift(f), c[f]) : void 0
        }
        function Qc(a, b, c, d) {
            var e, f, g, h, i, j = {},
            k = a.dataTypes.slice();
            if (k[1]) for (g in a.converters) j[g.toLowerCase()] = a.converters[g];
            f = k.shift();
            while (f) if (a.responseFields[f] && (c[a.responseFields[f]] = b), !i && d && a.dataFilter && (b = a.dataFilter(b, a.dataType)), i = f, f = k.shift()) if ("*" === f) f = i;
            else if ("*" !== i && i !== f) {
                if (g = j[i + " " + f] || j["* " + f], !g) for (e in j) if (h = e.split(" "), h[1] === f && (g = j[i + " " + h[0]] || j["* " + h[0]])) {
                    g === !0 ? g = j[e] : j[e] !== !0 && (f = h[0], k.unshift(h[1]));
                    break
                }
                if (g !== !0) if (g && a["throws"]) b = g(b);
                else try {
                    b = g(b)
                } catch(l) {
                    return {
                        state: "parsererror",
                        error: g ? l: "No conversion from " + i + " to " + f
                    }
                }
            }
            return {
                state: "success",
                data: b
            }
        }
        n.extend({
            active: 0,
            lastModified: {},
            etag: {},
            ajaxSettings: {
                url: Ac,
                type: "GET",
                isLocal: Ec.test(zc[1]),
                global: !0,
                processData: !0,
                async: !0,
                contentType: "application/x-www-form-urlencoded; charset=UTF-8",
                accepts: {
                    "*": Kc,
                    text: "text/plain",
                    html: "text/html",
                    xml: "application/xml, text/xml",
                    json: "application/json, text/javascript"
                },
                contents: {
                    xml: /xml/,
                    html: /html/,
                    json: /json/
                },
                responseFields: {
                    xml: "responseXML",
                    text: "responseText",
                    json: "responseJSON"
                },
                converters: {
                    "* text": String,
                    "text html": !0,
                    "text json": n.parseJSON,
                    "text xml": n.parseXML
                },
                flatOptions: {
                    url: !0,
                    context: !0
                }
            },
            ajaxSetup: function(a, b) {
                return b ? Oc(Oc(a, n.ajaxSettings), b) : Oc(n.ajaxSettings, a)
            },
            ajaxPrefilter: Mc(Ic),
            ajaxTransport: Mc(Jc),
            ajax: function(a, b) {
                "object" == typeof a && (b = a, a = void 0),
                b = b || {};
                var c, d, e, f, g, h, i, j, k = n.ajaxSetup({},
                b),
                l = k.context || k,
                m = k.context && (l.nodeType || l.jquery) ? n(l) : n.event,
                o = n.Deferred(),
                p = n.Callbacks("once memory"),
                q = k.statusCode || {},
                r = {},
                s = {},
                t = 0,
                u = "canceled",
                v = {
                    readyState: 0,
                    getResponseHeader: function(a) {
                        var b;
                        if (2 === t) {
                            if (!j) {
                                j = {};
                                while (b = Dc.exec(f)) j[b[1].toLowerCase()] = b[2]
                            }
                            b = j[a.toLowerCase()]
                        }
                        return null == b ? null: b
                    },
                    getAllResponseHeaders: function() {
                        return 2 === t ? f: null
                    },
                    setRequestHeader: function(a, b) {
                        var c = a.toLowerCase();
                        return t || (a = s[c] = s[c] || a, r[a] = b),
                        this
                    },
                    overrideMimeType: function(a) {
                        return t || (k.mimeType = a),
                        this
                    },
                    statusCode: function(a) {
                        var b;
                        if (a) if (2 > t) for (b in a) q[b] = [q[b], a[b]];
                        else v.always(a[v.status]);
                        return this
                    },
                    abort: function(a) {
                        var b = a || u;
                        return i && i.abort(b),
                        x(0, b),
                        this
                    }
                };
                if (o.promise(v).complete = p.add, v.success = v.done, v.error = v.fail, k.url = ((a || k.url || Ac) + "").replace(Bc, "").replace(Gc, zc[1] + "//"), k.type = b.method || b.type || k.method || k.type, k.dataTypes = n.trim(k.dataType || "*").toLowerCase().match(F) || [""], null == k.crossDomain && (c = Hc.exec(k.url.toLowerCase()), k.crossDomain = !(!c || c[1] === zc[1] && c[2] === zc[2] && (c[3] || ("http:" === c[1] ? "80": "443")) === (zc[3] || ("http:" === zc[1] ? "80": "443")))), k.data && k.processData && "string" != typeof k.data && (k.data = n.param(k.data, k.traditional)), Nc(Ic, k, b, v), 2 === t) return v;
                h = k.global,
                h && 0 === n.active++&&n.event.trigger("ajaxStart"),
                k.type = k.type.toUpperCase(),
                k.hasContent = !Fc.test(k.type),
                e = k.url,
                k.hasContent || (k.data && (e = k.url += (xc.test(e) ? "&": "?") + k.data, delete k.data), k.cache === !1 && (k.url = Cc.test(e) ? e.replace(Cc, "$1_=" + wc++) : e + (xc.test(e) ? "&": "?") + "_=" + wc++)),
                k.ifModified && (n.lastModified[e] && v.setRequestHeader("If-Modified-Since", n.lastModified[e]), n.etag[e] && v.setRequestHeader("If-None-Match", n.etag[e])),
                (k.data && k.hasContent && k.contentType !== !1 || b.contentType) && v.setRequestHeader("Content-Type", k.contentType),
                v.setRequestHeader("Accept", k.dataTypes[0] && k.accepts[k.dataTypes[0]] ? k.accepts[k.dataTypes[0]] + ("*" !== k.dataTypes[0] ? ", " + Kc + "; q=0.01": "") : k.accepts["*"]);
                for (d in k.headers) v.setRequestHeader(d, k.headers[d]);
                if (k.beforeSend && (k.beforeSend.call(l, v, k) === !1 || 2 === t)) return v.abort();
                u = "abort";
                for (d in {
                    success: 1,
                    error: 1,
                    complete: 1
                }) v[d](k[d]);
                if (i = Nc(Jc, k, b, v)) {
                    v.readyState = 1,
                    h && m.trigger("ajaxSend", [v, k]),
                    k.async && k.timeout > 0 && (g = setTimeout(function() {
                        v.abort("timeout")
                    },
                    k.timeout));
                    try {
                        t = 1,
                        i.send(r, x)
                    } catch(w) {
                        if (! (2 > t)) throw w;
                        x( - 1, w)
                    }
                } else x( - 1, "No Transport");
                function x(a, b, c, d) {
                    var j, r, s, u, w, x = b;
                    2 !== t && (t = 2, g && clearTimeout(g), i = void 0, f = d || "", v.readyState = a > 0 ? 4 : 0, j = a >= 200 && 300 > a || 304 === a, c && (u = Pc(k, v, c)), u = Qc(k, u, v, j), j ? (k.ifModified && (w = v.getResponseHeader("Last-Modified"), w && (n.lastModified[e] = w), w = v.getResponseHeader("etag"), w && (n.etag[e] = w)), 204 === a || "HEAD" === k.type ? x = "nocontent": 304 === a ? x = "notmodified": (x = u.state, r = u.data, s = u.error, j = !s)) : (s = x, (a || !x) && (x = "error", 0 > a && (a = 0))), v.status = a, v.statusText = (b || x) + "", j ? o.resolveWith(l, [r, x, v]) : o.rejectWith(l, [v, x, s]), v.statusCode(q), q = void 0, h && m.trigger(j ? "ajaxSuccess": "ajaxError", [v, k, j ? r: s]), p.fireWith(l, [v, x]), h && (m.trigger("ajaxComplete", [v, k]), --n.active || n.event.trigger("ajaxStop")))
                }
                return v
            },
            getJSON: function(a, b, c) {
                return n.get(a, b, c, "json")
            },
            getScript: function(a, b) {
                return n.get(a, void 0, b, "script")
            }
        }),
        n.each(["get", "post"],
        function(a, b) {
            n[b] = function(a, c, d, e) {
                return n.isFunction(c) && (e = e || d, d = c, c = void 0),
                n.ajax({
                    url: a,
                    type: b,
                    dataType: e,
                    data: c,
                    success: d
                })
            }
        }),
        n.each(["ajaxStart", "ajaxStop", "ajaxComplete", "ajaxError", "ajaxSuccess", "ajaxSend"],
        function(a, b) {
            n.fn[b] = function(a) {
                return this.on(b, a)
            }
        }),
        n._evalUrl = function(a) {
            return n.ajax({
                url: a,
                type: "GET",
                dataType: "script",
                async: !1,
                global: !1,
                "throws": !0
            })
        },
        n.fn.extend({
            wrapAll: function(a) {
                if (n.isFunction(a)) return this.each(function(b) {
                    n(this).wrapAll(a.call(this, b))
                });
                if (this[0]) {
                    var b = n(a, this[0].ownerDocument).eq(0).clone(!0);
                    this[0].parentNode && b.insertBefore(this[0]),
                    b.map(function() {
                        var a = this;
                        while (a.firstChild && 1 === a.firstChild.nodeType) a = a.firstChild;
                        return a
                    }).append(this)
                }
                return this
            },
            wrapInner: function(a) {
                return this.each(n.isFunction(a) ?
                function(b) {
                    n(this).wrapInner(a.call(this, b))
                }: function() {
                    var b = n(this),
                    c = b.contents();
                    c.length ? c.wrapAll(a) : b.append(a)
                })
            },
            wrap: function(a) {
                var b = n.isFunction(a);
                return this.each(function(c) {
                    n(this).wrapAll(b ? a.call(this, c) : a)
                })
            },
            unwrap: function() {
                return this.parent().each(function() {
                    n.nodeName(this, "body") || n(this).replaceWith(this.childNodes)
                }).end()
            }
        }),
        n.expr.filters.hidden = function(a) {
            return a.offsetWidth <= 0 && a.offsetHeight <= 0 || !l.reliableHiddenOffsets() && "none" === (a.style && a.style.display || n.css(a, "display"))
        },
        n.expr.filters.visible = function(a) {
            return ! n.expr.filters.hidden(a)
        };
        var Rc = /%20/g,
        Sc = /\[\]$/,
        Tc = /\r?\n/g,
        Uc = /^(?:submit|button|image|reset|file)$/i,
        Vc = /^(?:input|select|textarea|keygen)/i;
        function Wc(a, b, c, d) {
            var e;
            if (n.isArray(b)) n.each(b,
            function(b, e) {
                c || Sc.test(a) ? d(a, e) : Wc(a + "[" + ("object" == typeof e ? b: "") + "]", e, c, d)
            });
            else if (c || "object" !== n.type(b)) d(a, b);
            else for (e in b) Wc(a + "[" + e + "]", b[e], c, d)
        }
        n.param = function(a, b) {
            var c, d = [],
            e = function(a, b) {
                b = n.isFunction(b) ? b() : null == b ? "": b,
                d[d.length] = encodeURIComponent(a) + "=" + encodeURIComponent(b)
            };
            if (void 0 === b && (b = n.ajaxSettings && n.ajaxSettings.traditional), n.isArray(a) || a.jquery && !n.isPlainObject(a)) n.each(a,
            function() {
                e(this.name, this.value)
            });
            else for (c in a) Wc(c, a[c], b, e);
            return d.join("&").replace(Rc, "+")
        },
        n.fn.extend({
            serialize: function() {
                return n.param(this.serializeArray())
            },
            serializeArray: function() {
                return this.map(function() {
                    var a = n.prop(this, "elements");
                    return a ? n.makeArray(a) : this
                }).filter(function() {
                    var a = this.type;
                    return this.name && !n(this).is(":disabled") && Vc.test(this.nodeName) && !Uc.test(a) && (this.checked || !X.test(a))
                }).map(function(a, b) {
                    var c = n(this).val();
                    return null == c ? null: n.isArray(c) ? n.map(c,
                    function(a) {
                        return {
                            name: b.name,
                            value: a.replace(Tc, "\r\n")
                        }
                    }) : {
                        name: b.name,
                        value: c.replace(Tc, "\r\n")
                    }
                }).get()
            }
        }),
        n.ajaxSettings.xhr = void 0 !== a.ActiveXObject ?
        function() {
            return ! this.isLocal && /^(get|post|head|put|delete|options)$/i.test(this.type) && $c() || _c()
        }: $c;
        var Xc = 0,
        Yc = {},
        Zc = n.ajaxSettings.xhr();
        a.ActiveXObject && n(a).on("unload",
        function() {
            for (var a in Yc) Yc[a](void 0, !0)
        }),
        l.cors = !!Zc && "withCredentials" in Zc,
        Zc = l.ajax = !!Zc,
        Zc && n.ajaxTransport(function(a) {
            if (!a.crossDomain || l.cors) {
                var b;
                return {
                    send: function(c, d) {
                        var e, f = a.xhr(),
                        g = ++Xc;
                        if (f.open(a.type, a.url, a.async, a.username, a.password), a.xhrFields) for (e in a.xhrFields) f[e] = a.xhrFields[e];
                        a.mimeType && f.overrideMimeType && f.overrideMimeType(a.mimeType),
                        a.crossDomain || c["X-Requested-With"] || (c["X-Requested-With"] = "XMLHttpRequest");
                        for (e in c) void 0 !== c[e] && f.setRequestHeader(e, c[e] + "");
                        f.send(a.hasContent && a.data || null),
                        b = function(c, e) {
                            var h, i, j;
                            if (b && (e || 4 === f.readyState)) if (delete Yc[g], b = void 0, f.onreadystatechange = n.noop, e) 4 !== f.readyState && f.abort();
                            else {
                                j = {},
                                h = f.status,
                                "string" == typeof f.responseText && (j.text = f.responseText);
                                try {
                                    i = f.statusText
                                } catch(k) {
                                    i = ""
                                }
                                h || !a.isLocal || a.crossDomain ? 1223 === h && (h = 204) : h = j.text ? 200 : 404
                            }
                            j && d(h, i, j, f.getAllResponseHeaders())
                        },
                        a.async ? 4 === f.readyState ? setTimeout(b) : f.onreadystatechange = Yc[g] = b: b()
                    },
                    abort: function() {
                        b && b(void 0, !0)
                    }
                }
            }
        });
        function $c() {
            try {
                return new a.XMLHttpRequest
            } catch(b) {}
        }
        function _c() {
            try {
                return new a.ActiveXObject("Microsoft.XMLHTTP")
            } catch(b) {}
        }
        n.ajaxSetup({
            accepts: {
                script: "text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"
            },
            contents: {
                script: /(?:java|ecma)script/
            },
            converters: {
                "text script": function(a) {
                    return n.globalEval(a),
                    a
                }
            }
        }),
        n.ajaxPrefilter("script",
        function(a) {
            void 0 === a.cache && (a.cache = !1),
            a.crossDomain && (a.type = "GET", a.global = !1)
        }),
        n.ajaxTransport("script",
        function(a) {
            if (a.crossDomain) {
                var b, c = z.head || n("head")[0] || z.documentElement;
                return {
                    send: function(d, e) {
                        b = z.createElement("script"),
                        b.async = !0,
                        a.scriptCharset && (b.charset = a.scriptCharset),
                        b.src = a.url,
                        b.onload = b.onreadystatechange = function(a, c) { (c || !b.readyState || /loaded|complete/.test(b.readyState)) && (b.onload = b.onreadystatechange = null, b.parentNode && b.parentNode.removeChild(b), b = null, c || e(200, "success"))
                        },
                        c.insertBefore(b, c.firstChild)
                    },
                    abort: function() {
                        b && b.onload(void 0, !0)
                    }
                }
            }
        });
        var ad = [],
        bd = /(=)\?(?=&|$)|\?\?/;
        n.ajaxSetup({
            jsonp: "callback",
            jsonpCallback: function() {
                var a = ad.pop() || n.expando + "_" + wc++;
                return this[a] = !0,
                a
            }
        }),
        n.ajaxPrefilter("json jsonp",
        function(b, c, d) {
            var e, f, g, h = b.jsonp !== !1 && (bd.test(b.url) ? "url": "string" == typeof b.data && !(b.contentType || "").indexOf("application/x-www-form-urlencoded") && bd.test(b.data) && "data");
            return h || "jsonp" === b.dataTypes[0] ? (e = b.jsonpCallback = n.isFunction(b.jsonpCallback) ? b.jsonpCallback() : b.jsonpCallback, h ? b[h] = b[h].replace(bd, "$1" + e) : b.jsonp !== !1 && (b.url += (xc.test(b.url) ? "&": "?") + b.jsonp + "=" + e), b.converters["script json"] = function() {
                return g || n.error(e + " was not called"),
                g[0]
            },
            b.dataTypes[0] = "json", f = a[e], a[e] = function() {
                g = arguments
            },
            d.always(function() {
                a[e] = f,
                b[e] && (b.jsonpCallback = c.jsonpCallback, ad.push(e)),
                g && n.isFunction(f) && f(g[0]),
                g = f = void 0
            }), "script") : void 0
        }),
        n.parseHTML = function(a, b, c) {
            if (!a || "string" != typeof a) return null;
            "boolean" == typeof b && (c = b, b = !1),
            b = b || z;
            var d = v.exec(a),
            e = !c && [];
            return d ? [b.createElement(d[1])] : (d = n.buildFragment([a], b, e), e && e.length && n(e).remove(), n.merge([], d.childNodes))
        };
        var cd = n.fn.load;
        n.fn.load = function(a, b, c) {
            if ("string" != typeof a && cd) return cd.apply(this, arguments);
            var d, e, f, g = this,
            h = a.indexOf(" ");
            return h >= 0 && (d = a.slice(h, a.length), a = a.slice(0, h)),
            n.isFunction(b) ? (c = b, b = void 0) : b && "object" == typeof b && (f = "POST"),
            g.length > 0 && n.ajax({
                url: a,
                type: f,
                dataType: "html",
                data: b
            }).done(function(a) {
                e = arguments,
                g.html(d ? n("<div>").append(n.parseHTML(a)).find(d) : a)
            }).complete(c &&
            function(a, b) {
                g.each(c, e || [a.responseText, b, a])
            }),
            this
        },
        n.expr.filters.animated = function(a) {
            return n.grep(n.timers,
            function(b) {
                return a === b.elem
            }).length
        };
        var dd = a.document.documentElement;
        function ed(a) {
            return n.isWindow(a) ? a: 9 === a.nodeType ? a.defaultView || a.parentWindow: !1
        }
        n.offset = {
            setOffset: function(a, b, c) {
                var d, e, f, g, h, i, j, k = n.css(a, "position"),
                l = n(a),
                m = {};
                "static" === k && (a.style.position = "relative"),
                h = l.offset(),
                f = n.css(a, "top"),
                i = n.css(a, "left"),
                j = ("absolute" === k || "fixed" === k) && n.inArray("auto", [f, i]) > -1,
                j ? (d = l.position(), g = d.top, e = d.left) : (g = parseFloat(f) || 0, e = parseFloat(i) || 0),
                n.isFunction(b) && (b = b.call(a, c, h)),
                null != b.top && (m.top = b.top - h.top + g),
                null != b.left && (m.left = b.left - h.left + e),
                "using" in b ? b.using.call(a, m) : l.css(m)
            }
        },
        n.fn.extend({
            offset: function(a) {
                if (arguments.length) return void 0 === a ? this: this.each(function(b) {
                    n.offset.setOffset(this, a, b)
                });
                var b, c, d = {
                    top: 0,
                    left: 0
                },
                e = this[0],
                f = e && e.ownerDocument;
                if (f) return b = f.documentElement,
                n.contains(b, e) ? (typeof e.getBoundingClientRect !== L && (d = e.getBoundingClientRect()), c = ed(f), {
                    top: d.top + (c.pageYOffset || b.scrollTop) - (b.clientTop || 0),
                    left: d.left + (c.pageXOffset || b.scrollLeft) - (b.clientLeft || 0)
                }) : d
            },
            position: function() {
                if (this[0]) {
                    var a, b, c = {
                        top: 0,
                        left: 0
                    },
                    d = this[0];
                    return "fixed" === n.css(d, "position") ? b = d.getBoundingClientRect() : (a = this.offsetParent(), b = this.offset(), n.nodeName(a[0], "html") || (c = a.offset()), c.top += n.css(a[0], "borderTopWidth", !0), c.left += n.css(a[0], "borderLeftWidth", !0)),
                    {
                        top: b.top - c.top - n.css(d, "marginTop", !0),
                        left: b.left - c.left - n.css(d, "marginLeft", !0)
                    }
                }
            },
            offsetParent: function() {
                return this.map(function() {
                    var a = this.offsetParent || dd;
                    while (a && !n.nodeName(a, "html") && "static" === n.css(a, "position")) a = a.offsetParent;
                    return a || dd
                })
            }
        }),
        n.each({
            scrollLeft: "pageXOffset",
            scrollTop: "pageYOffset"
        },
        function(a, b) {
            var c = /Y/.test(b);
            n.fn[a] = function(d) {
                return W(this,
                function(a, d, e) {
                    var f = ed(a);
                    return void 0 === e ? f ? b in f ? f[b] : f.document.documentElement[d] : a[d] : void(f ? f.scrollTo(c ? n(f).scrollLeft() : e, c ? e: n(f).scrollTop()) : a[d] = e)
                },
                a, d, arguments.length, null)
            }
        }),
        n.each(["top", "left"],
        function(a, b) {
            n.cssHooks[b] = Mb(l.pixelPosition,
            function(a, c) {
                return c ? (c = Kb(a, b), Ib.test(c) ? n(a).position()[b] + "px": c) : void 0
            })
        }),
        n.each({
            Height: "height",
            Width: "width"
        },
        function(a, b) {
            n.each({
                padding: "inner" + a,
                content: b,
                "": "outer" + a
            },
            function(c, d) {
                n.fn[d] = function(d, e) {
                    var f = arguments.length && (c || "boolean" != typeof d),
                    g = c || (d === !0 || e === !0 ? "margin": "border");
                    return W(this,
                    function(b, c, d) {
                        var e;
                        return n.isWindow(b) ? b.document.documentElement["client" + a] : 9 === b.nodeType ? (e = b.documentElement, Math.max(b.body["scroll" + a], e["scroll" + a], b.body["offset" + a], e["offset" + a], e["client" + a])) : void 0 === d ? n.css(b, c, g) : n.style(b, c, d, g)
                    },
                    b, f ? d: void 0, f, null)
                }
            })
        }),
        n.fn.size = function() {
            return this.length
        },
        n.fn.andSelf = n.fn.addBack,
        "function" == typeof define && define.amd && define("jquery", [],
        function() {
            return n
        });
        var fd = a.jQuery,
        gd = a.$;
        return n.noConflict = function(b) {
            return a.$ === n && (a.$ = gd),
            b && a.jQuery === n && (a.jQuery = fd),
            n
        },
        typeof b === L && (a.jQuery = a.$ = n),
        n
    });
    //# sourceMappingURL=jquery.min.map
    

    (2)rem.js

    (function (doc, win) {
      var docEl = doc.documentElement,
        resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize',
        recalc = function () {
          var clientWidth = docEl.clientWidth;
          if (!clientWidth) return;
          docEl.style.fontSize = 100 * (clientWidth / 750) + 'px';
        };
    
      if (!doc.addEventListener) return;
      win.addEventListener(resizeEvt, recalc, false);
      doc.addEventListener('DOMContentLoaded', recalc, false);
      recalc();
    })(document, window);
    

    (3)swiper.min.js

    /**
     * Swiper 3.3.1
     * Most modern mobile touch slider and framework with hardware accelerated transitions
     * 
     * http://www.idangero.us/swiper/
     * 
     * Copyright 2016, Vladimir Kharlampidi
     * The iDangero.us
     * http://www.idangero.us/
     * 
     * Licensed under MIT
     * 
     * Released on: February 7, 2016
     */
    !
    function() {
        "use strict";
        function e(e) {
            e.fn.swiper = function(a) {
                var r;
                return e(this).each(function() {
                    var e = new t(this, a);
                    r || (r = e)
                }),
                r
            }
        }
        var a, t = function(e, i) {
            function s(e) {
                return Math.floor(e)
            }
            function n() {
                b.autoplayTimeoutId = setTimeout(function() {
                    b.params.loop ? (b.fixLoop(), b._slideNext(), b.emit("onAutoplay", b)) : b.isEnd ? i.autoplayStopOnLast ? b.stopAutoplay() : (b._slideTo(0), b.emit("onAutoplay", b)) : (b._slideNext(), b.emit("onAutoplay", b))
                },
                b.params.autoplay)
            }
            function o(e, t) {
                var r = a(e.target);
                if (!r.is(t)) if ("string" == typeof t) r = r.parents(t);
                else if (t.nodeType) {
                    var i;
                    return r.parents().each(function(e, a) {
                        a === t && (i = t)
                    }),
                    i ? t: void 0
                }
                if (0 !== r.length) return r[0]
            }
            function l(e, a) {
                a = a || {};
                var t = window.MutationObserver || window.WebkitMutationObserver,
                r = new t(function(e) {
                    e.forEach(function(e) {
                        b.onResize(!0),
                        b.emit("onObserverUpdate", b, e)
                    })
                });
                r.observe(e, {
                    attributes: "undefined" == typeof a.attributes ? !0 : a.attributes,
                    childList: "undefined" == typeof a.childList ? !0 : a.childList,
                    characterData: "undefined" == typeof a.characterData ? !0 : a.characterData
                }),
                b.observers.push(r)
            }
            function p(e) {
                e.originalEvent && (e = e.originalEvent);
                var a = e.keyCode || e.charCode;
                if (!b.params.allowSwipeToNext && (b.isHorizontal() && 39 === a || !b.isHorizontal() && 40 === a)) return ! 1;
                if (!b.params.allowSwipeToPrev && (b.isHorizontal() && 37 === a || !b.isHorizontal() && 38 === a)) return ! 1;
                if (! (e.shiftKey || e.altKey || e.ctrlKey || e.metaKey || document.activeElement && document.activeElement.nodeName && ("input" === document.activeElement.nodeName.toLowerCase() || "textarea" === document.activeElement.nodeName.toLowerCase()))) {
                    if (37 === a || 39 === a || 38 === a || 40 === a) {
                        var t = !1;
                        if (b.container.parents(".swiper-slide").length > 0 && 0 === b.container.parents(".swiper-slide-active").length) return;
                        var r = {
                            left: window.pageXOffset,
                            top: window.pageYOffset
                        },
                        i = window.innerWidth,
                        s = window.innerHeight,
                        n = b.container.offset();
                        b.rtl && (n.left = n.left - b.container[0].scrollLeft);
                        for (var o = [[n.left, n.top], [n.left + b.width, n.top], [n.left, n.top + b.height], [n.left + b.width, n.top + b.height]], l = 0; l < o.length; l++) {
                            var p = o[l];
                            p[0] >= r.left && p[0] <= r.left + i && p[1] >= r.top && p[1] <= r.top + s && (t = !0)
                        }
                        if (!t) return
                    }
                    b.isHorizontal() ? ((37 === a || 39 === a) && (e.preventDefault ? e.preventDefault() : e.returnValue = !1), (39 === a && !b.rtl || 37 === a && b.rtl) && b.slideNext(), (37 === a && !b.rtl || 39 === a && b.rtl) && b.slidePrev()) : ((38 === a || 40 === a) && (e.preventDefault ? e.preventDefault() : e.returnValue = !1), 40 === a && b.slideNext(), 38 === a && b.slidePrev())
                }
            }
            function d(e) {
                e.originalEvent && (e = e.originalEvent);
                var a = b.mousewheel.event,
                t = 0,
                r = b.rtl ? -1 : 1;
                if ("mousewheel" === a) if (b.params.mousewheelForceToAxis) if (b.isHorizontal()) {
                    if (! (Math.abs(e.wheelDeltaX) > Math.abs(e.wheelDeltaY))) return;
                    t = e.wheelDeltaX * r
                } else {
                    if (! (Math.abs(e.wheelDeltaY) > Math.abs(e.wheelDeltaX))) return;
                    t = e.wheelDeltaY
                } else t = Math.abs(e.wheelDeltaX) > Math.abs(e.wheelDeltaY) ? -e.wheelDeltaX * r: -e.wheelDeltaY;
                else if ("DOMMouseScroll" === a) t = -e.detail;
                else if ("wheel" === a) if (b.params.mousewheelForceToAxis) if (b.isHorizontal()) {
                    if (! (Math.abs(e.deltaX) > Math.abs(e.deltaY))) return;
                    t = -e.deltaX * r
                } else {
                    if (! (Math.abs(e.deltaY) > Math.abs(e.deltaX))) return;
                    t = -e.deltaY
                } else t = Math.abs(e.deltaX) > Math.abs(e.deltaY) ? -e.deltaX * r: -e.deltaY;
                if (0 !== t) {
                    if (b.params.mousewheelInvert && (t = -t), b.params.freeMode) {
                        var i = b.getWrapperTranslate() + t * b.params.mousewheelSensitivity,
                        s = b.isBeginning,
                        n = b.isEnd;
                        if (i >= b.minTranslate() && (i = b.minTranslate()), i <= b.maxTranslate() && (i = b.maxTranslate()), b.setWrapperTransition(0), b.setWrapperTranslate(i), b.updateProgress(), b.updateActiveIndex(), (!s && b.isBeginning || !n && b.isEnd) && b.updateClasses(), b.params.freeModeSticky ? (clearTimeout(b.mousewheel.timeout), b.mousewheel.timeout = setTimeout(function() {
                            b.slideReset()
                        },
                        300)) : b.params.lazyLoading && b.lazy && b.lazy.load(), 0 === i || i === b.maxTranslate()) return
                    } else {
                        if ((new window.Date).getTime() - b.mousewheel.lastScrollTime > 60) if (0 > t) if (b.isEnd && !b.params.loop || b.animating) {
                            if (b.params.mousewheelReleaseOnEdges) return ! 0
                        } else b.slideNext();
                        else if (b.isBeginning && !b.params.loop || b.animating) {
                            if (b.params.mousewheelReleaseOnEdges) return ! 0
                        } else b.slidePrev();
                        b.mousewheel.lastScrollTime = (new window.Date).getTime()
                    }
                    return b.params.autoplay && b.stopAutoplay(),
                    e.preventDefault ? e.preventDefault() : e.returnValue = !1,
                    !1
                }
            }
            function u(e, t) {
                e = a(e);
                var r, i, s, n = b.rtl ? -1 : 1;
                r = e.attr("data-swiper-parallax") || "0",
                i = e.attr("data-swiper-parallax-x"),
                s = e.attr("data-swiper-parallax-y"),
                i || s ? (i = i || "0", s = s || "0") : b.isHorizontal() ? (i = r, s = "0") : (s = r, i = "0"),
                i = i.indexOf("%") >= 0 ? parseInt(i, 10) * t * n + "%": i * t * n + "px",
                s = s.indexOf("%") >= 0 ? parseInt(s, 10) * t + "%": s * t + "px",
                e.transform("translate3d(" + i + ", " + s + ",0px)")
            }
            function c(e) {
                return 0 !== e.indexOf("on") && (e = e[0] !== e[0].toUpperCase() ? "on" + e[0].toUpperCase() + e.substring(1) : "on" + e),
                e
            }
            if (! (this instanceof t)) return new t(e, i);
            var m = {
                direction: "horizontal",
                touchEventsTarget: "container",
                initialSlide: 0,
                speed: 300,
                autoplay: !1,
                autoplayDisableOnInteraction: !0,
                autoplayStopOnLast: !1,
                iOSEdgeSwipeDetection: !1,
                iOSEdgeSwipeThreshold: 20,
                freeMode: !1,
                freeModeMomentum: !0,
                freeModeMomentumRatio: 1,
                freeModeMomentumBounce: !0,
                freeModeMomentumBounceRatio: 1,
                freeModeSticky: !1,
                freeModeMinimumVelocity: .02,
                autoHeight: !1,
                setWrapperSize: !1,
                virtualTranslate: !1,
                effect: "slide",
                coverflow: {
                    rotate: 50,
                    stretch: 0,
                    depth: 100,
                    modifier: 1,
                    slideShadows: !0
                },
                flip: {
                    slideShadows: !0,
                    limitRotation: !0
                },
                cube: {
                    slideShadows: !0,
                    shadow: !0,
                    shadowOffset: 20,
                    shadowScale: .94
                },
                fade: {
                    crossFade: !1
                },
                parallax: !1,
                scrollbar: null,
                scrollbarHide: !0,
                scrollbarDraggable: !1,
                scrollbarSnapOnRelease: !1,
                keyboardControl: !1,
                mousewheelControl: !1,
                mousewheelReleaseOnEdges: !1,
                mousewheelInvert: !1,
                mousewheelForceToAxis: !1,
                mousewheelSensitivity: 1,
                hashnav: !1,
                breakpoints: void 0,
                spaceBetween: 0,
                slidesPerView: 1,
                slidesPerColumn: 1,
                slidesPerColumnFill: "column",
                slidesPerGroup: 1,
                centeredSlides: !1,
                slidesOffsetBefore: 0,
                slidesOffsetAfter: 0,
                roundLengths: !1,
                touchRatio: 1,
                touchAngle: 45,
                simulateTouch: !0,
                shortSwipes: !0,
                longSwipes: !0,
                longSwipesRatio: .5,
                longSwipesMs: 300,
                followFinger: !0,
                onlyExternal: !1,
                threshold: 0,
                touchMoveStopPropagation: !0,
                uniqueNavElements: !0,
                pagination: null,
                paginationElement: "span",
                paginationClickable: !1,
                paginationHide: !1,
                paginationBulletRender: null,
                paginationProgressRender: null,
                paginationFractionRender: null,
                paginationCustomRender: null,
                paginationType: "bullets",
                resistance: !0,
                resistanceRatio: .85,
                nextButton: null,
                prevButton: null,
                watchSlidesProgress: !1,
                watchSlidesVisibility: !1,
                grabCursor: !1,
                preventClicks: !0,
                preventClicksPropagation: !0,
                slideToClickedSlide: !1,
                lazyLoading: !1,
                lazyLoadingInPrevNext: !1,
                lazyLoadingInPrevNextAmount: 1,
                lazyLoadingOnTransitionStart: !1,
                preloadImages: !0,
                updateOnImagesReady: !0,
                loop: !1,
                loopAdditionalSlides: 0,
                loopedSlides: null,
                control: void 0,
                controlInverse: !1,
                controlBy: "slide",
                allowSwipeToPrev: !0,
                allowSwipeToNext: !0,
                swipeHandler: null,
                noSwiping: !0,
                noSwipingClass: "swiper-no-swiping",
                slideClass: "swiper-slide",
                slideActiveClass: "swiper-slide-active",
                slideVisibleClass: "swiper-slide-visible",
                slideDuplicateClass: "swiper-slide-duplicate",
                slideNextClass: "swiper-slide-next",
                slidePrevClass: "swiper-slide-prev",
                wrapperClass: "swiper-wrapper",
                bulletClass: "swiper-pagination-bullet",
                bulletActiveClass: "swiper-pagination-bullet-active",
                buttonDisabledClass: "swiper-button-disabled",
                paginationCurrentClass: "swiper-pagination-current",
                paginationTotalClass: "swiper-pagination-total",
                paginationHiddenClass: "swiper-pagination-hidden",
                paginationProgressbarClass: "swiper-pagination-progressbar",
                observer: !1,
                observeParents: !1,
                a11y: !1,
                prevSlideMessage: "Previous slide",
                nextSlideMessage: "Next slide",
                firstSlideMessage: "This is the first slide",
                lastSlideMessage: "This is the last slide",
                paginationBulletMessage: "Go to slide {{index}}",
                runCallbacksOnInit: !0
            },
            h = i && i.virtualTranslate;
            i = i || {};
            var f = {};
            for (var g in i) if ("object" != typeof i[g] || null === i[g] || (i[g].nodeType || i[g] === window || i[g] === document || "undefined" != typeof r && i[g] instanceof r || "undefined" != typeof jQuery && i[g] instanceof jQuery)) f[g] = i[g];
            else {
                f[g] = {};
                for (var v in i[g]) f[g][v] = i[g][v]
            }
            for (var w in m) if ("undefined" == typeof i[w]) i[w] = m[w];
            else if ("object" == typeof i[w]) for (var y in m[w])"undefined" == typeof i[w][y] && (i[w][y] = m[w][y]);
            var b = this;
            if (b.params = i, b.originalParams = f, b.classNames = [], "undefined" != typeof a && "undefined" != typeof r && (a = r), ("undefined" != typeof a || (a = "undefined" == typeof r ? window.Dom7 || window.Zepto || window.jQuery: r)) && (b.$ = a, b.currentBreakpoint = void 0, b.getActiveBreakpoint = function() {
                if (!b.params.breakpoints) return ! 1;
                var e, a = !1,
                t = [];
                for (e in b.params.breakpoints) b.params.breakpoints.hasOwnProperty(e) && t.push(e);
                t.sort(function(e, a) {
                    return parseInt(e, 10) > parseInt(a, 10)
                });
                for (var r = 0; r < t.length; r++) e = t[r],
                e >= window.innerWidth && !a && (a = e);
                return a || "max"
            },
            b.setBreakpoint = function() {
                var e = b.getActiveBreakpoint();
                if (e && b.currentBreakpoint !== e) {
                    var a = e in b.params.breakpoints ? b.params.breakpoints[e] : b.originalParams,
                    t = b.params.loop && a.slidesPerView !== b.params.slidesPerView;
                    for (var r in a) b.params[r] = a[r];
                    b.currentBreakpoint = e,
                    t && b.destroyLoop && b.reLoop(!0)
                }
            },
            b.params.breakpoints && b.setBreakpoint(), b.container = a(e), 0 !== b.container.length)) {
                if (b.container.length > 1) {
                    var x = [];
                    return b.container.each(function() {
                        x.push(new t(this, i))
                    }),
                    x
                }
                b.container[0].swiper = b,
                b.container.data("swiper", b),
                b.classNames.push("swiper-container-" + b.params.direction),
                b.params.freeMode && b.classNames.push("swiper-container-free-mode"),
                b.support.flexbox || (b.classNames.push("swiper-container-no-flexbox"), b.params.slidesPerColumn = 1),
                b.params.autoHeight && b.classNames.push("swiper-container-autoheight"),
                (b.params.parallax || b.params.watchSlidesVisibility) && (b.params.watchSlidesProgress = !0),
                ["cube", "coverflow", "flip"].indexOf(b.params.effect) >= 0 && (b.support.transforms3d ? (b.params.watchSlidesProgress = !0, b.classNames.push("swiper-container-3d")) : b.params.effect = "slide"),
                "slide" !== b.params.effect && b.classNames.push("swiper-container-" + b.params.effect),
                "cube" === b.params.effect && (b.params.resistanceRatio = 0, b.params.slidesPerView = 1, b.params.slidesPerColumn = 1, b.params.slidesPerGroup = 1, b.params.centeredSlides = !1, b.params.spaceBetween = 0, b.params.virtualTranslate = !0, b.params.setWrapperSize = !1),
                ("fade" === b.params.effect || "flip" === b.params.effect) && (b.params.slidesPerView = 1, b.params.slidesPerColumn = 1, b.params.slidesPerGroup = 1, b.params.watchSlidesProgress = !0, b.params.spaceBetween = 0, b.params.setWrapperSize = !1, "undefined" == typeof h && (b.params.virtualTranslate = !0)),
                b.params.grabCursor && b.support.touch && (b.params.grabCursor = !1),
                b.wrapper = b.container.children("." + b.params.wrapperClass),
                b.params.pagination && (b.paginationContainer = a(b.params.pagination), b.params.uniqueNavElements && "string" == typeof b.params.pagination && b.paginationContainer.length > 1 && 1 === b.container.find(b.params.pagination).length && (b.paginationContainer = b.container.find(b.params.pagination)), "bullets" === b.params.paginationType && b.params.paginationClickable ? b.paginationContainer.addClass("swiper-pagination-clickable") : b.params.paginationClickable = !1, b.paginationContainer.addClass("swiper-pagination-" + b.params.paginationType)),
                (b.params.nextButton || b.params.prevButton) && (b.params.nextButton && (b.nextButton = a(b.params.nextButton), b.params.uniqueNavElements && "string" == typeof b.params.nextButton && b.nextButton.length > 1 && 1 === b.container.find(b.params.nextButton).length && (b.nextButton = b.container.find(b.params.nextButton))), b.params.prevButton && (b.prevButton = a(b.params.prevButton), b.params.uniqueNavElements && "string" == typeof b.params.prevButton && b.prevButton.length > 1 && 1 === b.container.find(b.params.prevButton).length && (b.prevButton = b.container.find(b.params.prevButton)))),
                b.isHorizontal = function() {
                    return "horizontal" === b.params.direction
                },
                b.rtl = b.isHorizontal() && ("rtl" === b.container[0].dir.toLowerCase() || "rtl" === b.container.css("direction")),
                b.rtl && b.classNames.push("swiper-container-rtl"),
                b.rtl && (b.wrongRTL = "-webkit-box" === b.wrapper.css("display")),
                b.params.slidesPerColumn > 1 && b.classNames.push("swiper-container-multirow"),
                b.device.android && b.classNames.push("swiper-container-android"),
                b.container.addClass(b.classNames.join(" ")),
                b.translate = 0,
                b.progress = 0,
                b.velocity = 0,
                b.lockSwipeToNext = function() {
                    b.params.allowSwipeToNext = !1
                },
                b.lockSwipeToPrev = function() {
                    b.params.allowSwipeToPrev = !1
                },
                b.lockSwipes = function() {
                    b.params.allowSwipeToNext = b.params.allowSwipeToPrev = !1
                },
                b.unlockSwipeToNext = function() {
                    b.params.allowSwipeToNext = !0
                },
                b.unlockSwipeToPrev = function() {
                    b.params.allowSwipeToPrev = !0
                },
                b.unlockSwipes = function() {
                    b.params.allowSwipeToNext = b.params.allowSwipeToPrev = !0
                },
                b.params.grabCursor && (b.container[0].style.cursor = "move", b.container[0].style.cursor = "-webkit-grab", b.container[0].style.cursor = "-moz-grab", b.container[0].style.cursor = "grab"),
                b.imagesToLoad = [],
                b.imagesLoaded = 0,
                b.loadImage = function(e, a, t, r, i) {
                    function s() {
                        i && i()
                    }
                    var n;
                    e.complete && r ? s() : a ? (n = new window.Image, n.onload = s, n.onerror = s, t && (n.srcset = t), a && (n.src = a)) : s()
                },
                b.preloadImages = function() {
                    function e() {
                        "undefined" != typeof b && null !== b && (void 0 !== b.imagesLoaded && b.imagesLoaded++, b.imagesLoaded === b.imagesToLoad.length && (b.params.updateOnImagesReady && b.update(), b.emit("onImagesReady", b)))
                    }
                    b.imagesToLoad = b.container.find("img");
                    for (var a = 0; a < b.imagesToLoad.length; a++) b.loadImage(b.imagesToLoad[a], b.imagesToLoad[a].currentSrc || b.imagesToLoad[a].getAttribute("src"), b.imagesToLoad[a].srcset || b.imagesToLoad[a].getAttribute("srcset"), !0, e)
                },
                b.autoplayTimeoutId = void 0,
                b.autoplaying = !1,
                b.autoplayPaused = !1,
                b.startAutoplay = function() {
                    return "undefined" != typeof b.autoplayTimeoutId ? !1 : b.params.autoplay ? b.autoplaying ? !1 : (b.autoplaying = !0, b.emit("onAutoplayStart", b), void n()) : !1
                },
                b.stopAutoplay = function(e) {
                    b.autoplayTimeoutId && (b.autoplayTimeoutId && clearTimeout(b.autoplayTimeoutId), b.autoplaying = !1, b.autoplayTimeoutId = void 0, b.emit("onAutoplayStop", b))
                },
                b.pauseAutoplay = function(e) {
                    b.autoplayPaused || (b.autoplayTimeoutId && clearTimeout(b.autoplayTimeoutId), b.autoplayPaused = !0, 0 === e ? (b.autoplayPaused = !1, n()) : b.wrapper.transitionEnd(function() {
                        b && (b.autoplayPaused = !1, b.autoplaying ? n() : b.stopAutoplay())
                    }))
                },
                b.minTranslate = function() {
                    return - b.snapGrid[0]
                },
                b.maxTranslate = function() {
                    return - b.snapGrid[b.snapGrid.length - 1]
                },
                b.updateAutoHeight = function() {
                    var e = b.slides.eq(b.activeIndex)[0];
                    if ("undefined" != typeof e) {
                        var a = e.offsetHeight;
                        a && b.wrapper.css("height", a + "px")
                    }
                },
                b.updateContainerSize = function() {
                    var e, a;
                    e = "undefined" != typeof b.params.width ? b.params.width: b.container[0].clientWidth,
                    a = "undefined" != typeof b.params.height ? b.params.height: b.container[0].clientHeight,
                    0 === e && b.isHorizontal() || 0 === a && !b.isHorizontal() || (e = e - parseInt(b.container.css("padding-left"), 10) - parseInt(b.container.css("padding-right"), 10), a = a - parseInt(b.container.css("padding-top"), 10) - parseInt(b.container.css("padding-bottom"), 10), b.width = e, b.height = a, b.size = b.isHorizontal() ? b.width: b.height)
                },
                b.updateSlidesSize = function() {
                    b.slides = b.wrapper.children("." + b.params.slideClass),
                    b.snapGrid = [],
                    b.slidesGrid = [],
                    b.slidesSizesGrid = [];
                    var e, a = b.params.spaceBetween,
                    t = -b.params.slidesOffsetBefore,
                    r = 0,
                    i = 0;
                    if ("undefined" != typeof b.size) {
                        "string" == typeof a && a.indexOf("%") >= 0 && (a = parseFloat(a.replace("%", "")) / 100 * b.size),
                        b.virtualSize = -a,
                        b.rtl ? b.slides.css({
                            marginLeft: "",
                            marginTop: ""
                        }) : b.slides.css({
                            marginRight: "",
                            marginBottom: ""
                        });
                        var n;
                        b.params.slidesPerColumn > 1 && (n = Math.floor(b.slides.length / b.params.slidesPerColumn) === b.slides.length / b.params.slidesPerColumn ? b.slides.length: Math.ceil(b.slides.length / b.params.slidesPerColumn) * b.params.slidesPerColumn, "auto" !== b.params.slidesPerView && "row" === b.params.slidesPerColumnFill && (n = Math.max(n, b.params.slidesPerView * b.params.slidesPerColumn)));
                        var o, l = b.params.slidesPerColumn,
                        p = n / l,
                        d = p - (b.params.slidesPerColumn * p - b.slides.length);
                        for (e = 0; e < b.slides.length; e++) {
                            o = 0;
                            var u = b.slides.eq(e);
                            if (b.params.slidesPerColumn > 1) {
                                var c, m, h;
                                "column" === b.params.slidesPerColumnFill ? (m = Math.floor(e / l), h = e - m * l, (m > d || m === d && h === l - 1) && ++h >= l && (h = 0, m++), c = m + h * n / l, u.css({
                                    "-webkit-box-ordinal-group": c,
                                    "-moz-box-ordinal-group": c,
                                    "-ms-flex-order": c,
                                    "-webkit-order": c,
                                    order: c
                                })) : (h = Math.floor(e / p), m = e - h * p),
                                u.css({
                                    "margin-top": 0 !== h && b.params.spaceBetween && b.params.spaceBetween + "px"
                                }).attr("data-swiper-column", m).attr("data-swiper-row", h)
                            }
                            "none" !== u.css("display") && ("auto" === b.params.slidesPerView ? (o = b.isHorizontal() ? u.outerWidth(!0) : u.outerHeight(!0), b.params.roundLengths && (o = s(o))) : (o = (b.size - (b.params.slidesPerView - 1) * a) / b.params.slidesPerView, b.params.roundLengths && (o = s(o)), b.isHorizontal() ? b.slides[e].style.width = o + "px": b.slides[e].style.height = o + "px"), b.slides[e].swiperSlideSize = o, b.slidesSizesGrid.push(o), b.params.centeredSlides ? (t = t + o / 2 + r / 2 + a, 0 === e && (t = t - b.size / 2 - a), Math.abs(t) < .001 && (t = 0), i % b.params.slidesPerGroup === 0 && b.snapGrid.push(t), b.slidesGrid.push(t)) : (i % b.params.slidesPerGroup === 0 && b.snapGrid.push(t), b.slidesGrid.push(t), t = t + o + a), b.virtualSize += o + a, r = o, i++)
                        }
                        b.virtualSize = Math.max(b.virtualSize, b.size) + b.params.slidesOffsetAfter;
                        var f;
                        if (b.rtl && b.wrongRTL && ("slide" === b.params.effect || "coverflow" === b.params.effect) && b.wrapper.css({
                            width: b.virtualSize + b.params.spaceBetween + "px"
                        }), (!b.support.flexbox || b.params.setWrapperSize) && (b.isHorizontal() ? b.wrapper.css({
                            width: b.virtualSize + b.params.spaceBetween + "px"
                        }) : b.wrapper.css({
                            height: b.virtualSize + b.params.spaceBetween + "px"
                        })), b.params.slidesPerColumn > 1 && (b.virtualSize = (o + b.params.spaceBetween) * n, b.virtualSize = Math.ceil(b.virtualSize / b.params.slidesPerColumn) - b.params.spaceBetween, b.wrapper.css({
                            width: b.virtualSize + b.params.spaceBetween + "px"
                        }), b.params.centeredSlides)) {
                            for (f = [], e = 0; e < b.snapGrid.length; e++) b.snapGrid[e] < b.virtualSize + b.snapGrid[0] && f.push(b.snapGrid[e]);
                            b.snapGrid = f
                        }
                        if (!b.params.centeredSlides) {
                            for (f = [], e = 0; e < b.snapGrid.length; e++) b.snapGrid[e] <= b.virtualSize - b.size && f.push(b.snapGrid[e]);
                            b.snapGrid = f,
                            Math.floor(b.virtualSize - b.size) - Math.floor(b.snapGrid[b.snapGrid.length - 1]) > 1 && b.snapGrid.push(b.virtualSize - b.size)
                        }
                        0 === b.snapGrid.length && (b.snapGrid = [0]),
                        0 !== b.params.spaceBetween && (b.isHorizontal() ? b.rtl ? b.slides.css({
                            marginLeft: a + "px"
                        }) : b.slides.css({
                            marginRight: a + "px"
                        }) : b.slides.css({
                            marginBottom: a + "px"
                        })),
                        b.params.watchSlidesProgress && b.updateSlidesOffset()
                    }
                },
                b.updateSlidesOffset = function() {
                    for (var e = 0; e < b.slides.length; e++) b.slides[e].swiperSlideOffset = b.isHorizontal() ? b.slides[e].offsetLeft: b.slides[e].offsetTop
                },
                b.updateSlidesProgress = function(e) {
                    if ("undefined" == typeof e && (e = b.translate || 0), 0 !== b.slides.length) {
                        "undefined" == typeof b.slides[0].swiperSlideOffset && b.updateSlidesOffset();
                        var a = -e;
                        b.rtl && (a = e),
                        b.slides.removeClass(b.params.slideVisibleClass);
                        for (var t = 0; t < b.slides.length; t++) {
                            var r = b.slides[t],
                            i = (a - r.swiperSlideOffset) / (r.swiperSlideSize + b.params.spaceBetween);
                            if (b.params.watchSlidesVisibility) {
                                var s = -(a - r.swiperSlideOffset),
                                n = s + b.slidesSizesGrid[t],
                                o = s >= 0 && s < b.size || n > 0 && n <= b.size || 0 >= s && n >= b.size;
                                o && b.slides.eq(t).addClass(b.params.slideVisibleClass)
                            }
                            r.progress = b.rtl ? -i: i
                        }
                    }
                },
                b.updateProgress = function(e) {
                    "undefined" == typeof e && (e = b.translate || 0);
                    var a = b.maxTranslate() - b.minTranslate(),
                    t = b.isBeginning,
                    r = b.isEnd;
                    0 === a ? (b.progress = 0, b.isBeginning = b.isEnd = !0) : (b.progress = (e - b.minTranslate()) / a, b.isBeginning = b.progress <= 0, b.isEnd = b.progress >= 1),
                    b.isBeginning && !t && b.emit("onReachBeginning", b),
                    b.isEnd && !r && b.emit("onReachEnd", b),
                    b.params.watchSlidesProgress && b.updateSlidesProgress(e),
                    b.emit("onProgress", b, b.progress)
                },
                b.updateActiveIndex = function() {
                    var e, a, t, r = b.rtl ? b.translate: -b.translate;
                    for (a = 0; a < b.slidesGrid.length; a++)"undefined" != typeof b.slidesGrid[a + 1] ? r >= b.slidesGrid[a] && r < b.slidesGrid[a + 1] - (b.slidesGrid[a + 1] - b.slidesGrid[a]) / 2 ? e = a: r >= b.slidesGrid[a] && r < b.slidesGrid[a + 1] && (e = a + 1) : r >= b.slidesGrid[a] && (e = a); (0 > e || "undefined" == typeof e) && (e = 0),
                    t = Math.floor(e / b.params.slidesPerGroup),
                    t >= b.snapGrid.length && (t = b.snapGrid.length - 1),
                    e !== b.activeIndex && (b.snapIndex = t, b.previousIndex = b.activeIndex, b.activeIndex = e, b.updateClasses())
                },
                b.updateClasses = function() {
                    b.slides.removeClass(b.params.slideActiveClass + " " + b.params.slideNextClass + " " + b.params.slidePrevClass);
                    var e = b.slides.eq(b.activeIndex);
                    e.addClass(b.params.slideActiveClass);
                    var t = e.next("." + b.params.slideClass).addClass(b.params.slideNextClass);
                    b.params.loop && 0 === t.length && b.slides.eq(0).addClass(b.params.slideNextClass);
                    var r = e.prev("." + b.params.slideClass).addClass(b.params.slidePrevClass);
                    if (b.params.loop && 0 === r.length && b.slides.eq( - 1).addClass(b.params.slidePrevClass), b.paginationContainer && b.paginationContainer.length > 0) {
                        var i, s = b.params.loop ? Math.ceil((b.slides.length - 2 * b.loopedSlides) / b.params.slidesPerGroup) : b.snapGrid.length;
                        if (b.params.loop ? (i = Math.ceil((b.activeIndex - b.loopedSlides) / b.params.slidesPerGroup), i > b.slides.length - 1 - 2 * b.loopedSlides && (i -= b.slides.length - 2 * b.loopedSlides), i > s - 1 && (i -= s), 0 > i && "bullets" !== b.params.paginationType && (i = s + i)) : i = "undefined" != typeof b.snapIndex ? b.snapIndex: b.activeIndex || 0, "bullets" === b.params.paginationType && b.bullets && b.bullets.length > 0 && (b.bullets.removeClass(b.params.bulletActiveClass), b.paginationContainer.length > 1 ? b.bullets.each(function() {
                            a(this).index() === i && a(this).addClass(b.params.bulletActiveClass)
                        }) : b.bullets.eq(i).addClass(b.params.bulletActiveClass)), "fraction" === b.params.paginationType && (b.paginationContainer.find("." + b.params.paginationCurrentClass).text(i + 1), b.paginationContainer.find("." + b.params.paginationTotalClass).text(s)), "progress" === b.params.paginationType) {
                            var n = (i + 1) / s,
                            o = n,
                            l = 1;
                            b.isHorizontal() || (l = n, o = 1),
                            b.paginationContainer.find("." + b.params.paginationProgressbarClass).transform("translate3d(0,0,0) scaleX(" + o + ") scaleY(" + l + ")").transition(b.params.speed)
                        }
                        "custom" === b.params.paginationType && b.params.paginationCustomRender && (b.paginationContainer.html(b.params.paginationCustomRender(b, i + 1, s)), b.emit("onPaginationRendered", b, b.paginationContainer[0]))
                    }
                    b.params.loop || (b.params.prevButton && b.prevButton && b.prevButton.length > 0 && (b.isBeginning ? (b.prevButton.addClass(b.params.buttonDisabledClass), b.params.a11y && b.a11y && b.a11y.disable(b.prevButton)) : (b.prevButton.removeClass(b.params.buttonDisabledClass), b.params.a11y && b.a11y && b.a11y.enable(b.prevButton))), b.params.nextButton && b.nextButton && b.nextButton.length > 0 && (b.isEnd ? (b.nextButton.addClass(b.params.buttonDisabledClass), b.params.a11y && b.a11y && b.a11y.disable(b.nextButton)) : (b.nextButton.removeClass(b.params.buttonDisabledClass), b.params.a11y && b.a11y && b.a11y.enable(b.nextButton))))
                },
                b.updatePagination = function() {
                    if (b.params.pagination && b.paginationContainer && b.paginationContainer.length > 0) {
                        var e = "";
                        if ("bullets" === b.params.paginationType) {
                            for (var a = b.params.loop ? Math.ceil((b.slides.length - 2 * b.loopedSlides) / b.params.slidesPerGroup) : b.snapGrid.length, t = 0; a > t; t++) e += b.params.paginationBulletRender ? b.params.paginationBulletRender(t, b.params.bulletClass) : "<" + b.params.paginationElement + ' class="' + b.params.bulletClass + '"></' + b.params.paginationElement + ">";
                            b.paginationContainer.html(e),
                            b.bullets = b.paginationContainer.find("." + b.params.bulletClass),
                            b.params.paginationClickable && b.params.a11y && b.a11y && b.a11y.initPagination()
                        }
                        "fraction" === b.params.paginationType && (e = b.params.paginationFractionRender ? b.params.paginationFractionRender(b, b.params.paginationCurrentClass, b.params.paginationTotalClass) : '<span class="' + b.params.paginationCurrentClass + '"></span> / <span class="' + b.params.paginationTotalClass + '"></span>', b.paginationContainer.html(e)),
                        "progress" === b.params.paginationType && (e = b.params.paginationProgressRender ? b.params.paginationProgressRender(b, b.params.paginationProgressbarClass) : '<span class="' + b.params.paginationProgressbarClass + '"></span>', b.paginationContainer.html(e)),
                        "custom" !== b.params.paginationType && b.emit("onPaginationRendered", b, b.paginationContainer[0])
                    }
                },
                b.update = function(e) {
                    function a() {
                        r = Math.min(Math.max(b.translate, b.maxTranslate()), b.minTranslate()),
                        b.setWrapperTranslate(r),
                        b.updateActiveIndex(),
                        b.updateClasses()
                    }
                    if (b.updateContainerSize(), b.updateSlidesSize(), b.updateProgress(), b.updatePagination(), b.updateClasses(), b.params.scrollbar && b.scrollbar && b.scrollbar.set(), e) {
                        var t, r;
                        b.controller && b.controller.spline && (b.controller.spline = void 0),
                        b.params.freeMode ? (a(), b.params.autoHeight && b.updateAutoHeight()) : (t = ("auto" === b.params.slidesPerView || b.params.slidesPerView > 1) && b.isEnd && !b.params.centeredSlides ? b.slideTo(b.slides.length - 1, 0, !1, !0) : b.slideTo(b.activeIndex, 0, !1, !0), t || a())
                    } else b.params.autoHeight && b.updateAutoHeight()
                },
                b.onResize = function(e) {
                    b.params.breakpoints && b.setBreakpoint();
                    var a = b.params.allowSwipeToPrev,
                    t = b.params.allowSwipeToNext;
                    b.params.allowSwipeToPrev = b.params.allowSwipeToNext = !0,
                    b.updateContainerSize(),
                    b.updateSlidesSize(),
                    ("auto" === b.params.slidesPerView || b.params.freeMode || e) && b.updatePagination(),
                    b.params.scrollbar && b.scrollbar && b.scrollbar.set(),
                    b.controller && b.controller.spline && (b.controller.spline = void 0);
                    var r = !1;
                    if (b.params.freeMode) {
                        var i = Math.min(Math.max(b.translate, b.maxTranslate()), b.minTranslate());
                        b.setWrapperTranslate(i),
                        b.updateActiveIndex(),
                        b.updateClasses(),
                        b.params.autoHeight && b.updateAutoHeight()
                    } else b.updateClasses(),
                    r = ("auto" === b.params.slidesPerView || b.params.slidesPerView > 1) && b.isEnd && !b.params.centeredSlides ? b.slideTo(b.slides.length - 1, 0, !1, !0) : b.slideTo(b.activeIndex, 0, !1, !0);
                    b.params.lazyLoading && !r && b.lazy && b.lazy.load(),
                    b.params.allowSwipeToPrev = a,
                    b.params.allowSwipeToNext = t
                };
                var T = ["mousedown", "mousemove", "mouseup"];
                window.navigator.pointerEnabled ? T = ["pointerdown", "pointermove", "pointerup"] : window.navigator.msPointerEnabled && (T = ["MSPointerDown", "MSPointerMove", "MSPointerUp"]),
                b.touchEvents = {
                    start: b.support.touch || !b.params.simulateTouch ? "touchstart": T[0],
                    move: b.support.touch || !b.params.simulateTouch ? "touchmove": T[1],
                    end: b.support.touch || !b.params.simulateTouch ? "touchend": T[2]
                },
                (window.navigator.pointerEnabled || window.navigator.msPointerEnabled) && ("container" === b.params.touchEventsTarget ? b.container: b.wrapper).addClass("swiper-wp8-" + b.params.direction),
                b.initEvents = function(e) {
                    var a = e ? "off": "on",
                    t = e ? "removeEventListener": "addEventListener",
                    r = "container" === b.params.touchEventsTarget ? b.container[0] : b.wrapper[0],
                    s = b.support.touch ? r: document,
                    n = b.params.nested ? !0 : !1;
                    b.browser.ie ? (r[t](b.touchEvents.start, b.onTouchStart, !1), s[t](b.touchEvents.move, b.onTouchMove, n), s[t](b.touchEvents.end, b.onTouchEnd, !1)) : (b.support.touch && (r[t](b.touchEvents.start, b.onTouchStart, !1), r[t](b.touchEvents.move, b.onTouchMove, n), r[t](b.touchEvents.end, b.onTouchEnd, !1)), !i.simulateTouch || b.device.ios || b.device.android || (r[t]("mousedown", b.onTouchStart, !1), document[t]("mousemove", b.onTouchMove, n), document[t]("mouseup", b.onTouchEnd, !1))),
                    window[t]("resize", b.onResize),
                    b.params.nextButton && b.nextButton && b.nextButton.length > 0 && (b.nextButton[a]("click", b.onClickNext), b.params.a11y && b.a11y && b.nextButton[a]("keydown", b.a11y.onEnterKey)),
                    b.params.prevButton && b.prevButton && b.prevButton.length > 0 && (b.prevButton[a]("click", b.onClickPrev), b.params.a11y && b.a11y && b.prevButton[a]("keydown", b.a11y.onEnterKey)),
                    b.params.pagination && b.params.paginationClickable && (b.paginationContainer[a]("click", "." + b.params.bulletClass, b.onClickIndex), b.params.a11y && b.a11y && b.paginationContainer[a]("keydown", "." + b.params.bulletClass, b.a11y.onEnterKey)),
                    (b.params.preventClicks || b.params.preventClicksPropagation) && r[t]("click", b.preventClicks, !0)
                },
                b.attachEvents = function() {
                    b.initEvents()
                },
                b.detachEvents = function() {
                    b.initEvents(!0)
                },
                b.allowClick = !0,
                b.preventClicks = function(e) {
                    b.allowClick || (b.params.preventClicks && e.preventDefault(), b.params.preventClicksPropagation && b.animating && (e.stopPropagation(), e.stopImmediatePropagation()))
                },
                b.onClickNext = function(e) {
                    e.preventDefault(),
                    (!b.isEnd || b.params.loop) && b.slideNext()
                },
                b.onClickPrev = function(e) {
                    e.preventDefault(),
                    (!b.isBeginning || b.params.loop) && b.slidePrev()
                },
                b.onClickIndex = function(e) {
                    e.preventDefault();
                    var t = a(this).index() * b.params.slidesPerGroup;
                    b.params.loop && (t += b.loopedSlides),
                    b.slideTo(t)
                },
                b.updateClickedSlide = function(e) {
                    var t = o(e, "." + b.params.slideClass),
                    r = !1;
                    if (t) for (var i = 0; i < b.slides.length; i++) b.slides[i] === t && (r = !0);
                    if (!t || !r) return b.clickedSlide = void 0,
                    void(b.clickedIndex = void 0);
                    if (b.clickedSlide = t, b.clickedIndex = a(t).index(), b.params.slideToClickedSlide && void 0 !== b.clickedIndex && b.clickedIndex !== b.activeIndex) {
                        var s, n = b.clickedIndex;
                        if (b.params.loop) {
                            if (b.animating) return;
                            s = a(b.clickedSlide).attr("data-swiper-slide-index"),
                            b.params.centeredSlides ? n < b.loopedSlides - b.params.slidesPerView / 2 || n > b.slides.length - b.loopedSlides + b.params.slidesPerView / 2 ? (b.fixLoop(), n = b.wrapper.children("." + b.params.slideClass + '[data-swiper-slide-index="' + s + '"]:not(.swiper-slide-duplicate)').eq(0).index(), setTimeout(function() {
                                b.slideTo(n)
                            },
                            0)) : b.slideTo(n) : n > b.slides.length - b.params.slidesPerView ? (b.fixLoop(), n = b.wrapper.children("." + b.params.slideClass + '[data-swiper-slide-index="' + s + '"]:not(.swiper-slide-duplicate)').eq(0).index(), setTimeout(function() {
                                b.slideTo(n)
                            },
                            0)) : b.slideTo(n)
                        } else b.slideTo(n)
                    }
                };
                var S, C, z, M, E, P, k, I, L, B, D = "input, select, textarea, button",
                H = Date.now(),
                A = [];
                b.animating = !1,
                b.touches = {
                    startX: 0,
                    startY: 0,
                    currentX: 0,
                    currentY: 0,
                    diff: 0
                };
                var G, O;
                if (b.onTouchStart = function(e) {
                    if (e.originalEvent && (e = e.originalEvent), G = "touchstart" === e.type, G || !("which" in e) || 3 !== e.which) {
                        if (b.params.noSwiping && o(e, "." + b.params.noSwipingClass)) return void(b.allowClick = !0);
                        if (!b.params.swipeHandler || o(e, b.params.swipeHandler)) {
                            var t = b.touches.currentX = "touchstart" === e.type ? e.targetTouches[0].pageX: e.pageX,
                            r = b.touches.currentY = "touchstart" === e.type ? e.targetTouches[0].pageY: e.pageY;
                            if (! (b.device.ios && b.params.iOSEdgeSwipeDetection && t <= b.params.iOSEdgeSwipeThreshold)) {
                                if (S = !0, C = !1, z = !0, E = void 0, O = void 0, b.touches.startX = t, b.touches.startY = r, M = Date.now(), b.allowClick = !0, b.updateContainerSize(), b.swipeDirection = void 0, b.params.threshold > 0 && (I = !1), "touchstart" !== e.type) {
                                    var i = !0;
                                    a(e.target).is(D) && (i = !1),
                                    document.activeElement && a(document.activeElement).is(D) && document.activeElement.blur(),
                                    i && e.preventDefault()
                                }
                                b.emit("onTouchStart", b, e)
                            }
                        }
                    }
                },
                b.onTouchMove = function(e) {
                    if (e.originalEvent && (e = e.originalEvent), !G || "mousemove" !== e.type) {
                        if (e.preventedByNestedSwiper) return b.touches.startX = "touchmove" === e.type ? e.targetTouches[0].pageX: e.pageX,
                        void(b.touches.startY = "touchmove" === e.type ? e.targetTouches[0].pageY: e.pageY);
                        if (b.params.onlyExternal) return b.allowClick = !1,
                        void(S && (b.touches.startX = b.touches.currentX = "touchmove" === e.type ? e.targetTouches[0].pageX: e.pageX, b.touches.startY = b.touches.currentY = "touchmove" === e.type ? e.targetTouches[0].pageY: e.pageY, M = Date.now()));
                        if (G && document.activeElement && e.target === document.activeElement && a(e.target).is(D)) return C = !0,
                        void(b.allowClick = !1);
                        if (z && b.emit("onTouchMove", b, e), !(e.targetTouches && e.targetTouches.length > 1)) {
                            if (b.touches.currentX = "touchmove" === e.type ? e.targetTouches[0].pageX: e.pageX, b.touches.currentY = "touchmove" === e.type ? e.targetTouches[0].pageY: e.pageY, "undefined" == typeof E) {
                                var t = 180 * Math.atan2(Math.abs(b.touches.currentY - b.touches.startY), Math.abs(b.touches.currentX - b.touches.startX)) / Math.PI;
                                E = b.isHorizontal() ? t > b.params.touchAngle: 90 - t > b.params.touchAngle
                            }
                            if (E && b.emit("onTouchMoveOpposite", b, e), "undefined" == typeof O && b.browser.ieTouch && (b.touches.currentX !== b.touches.startX || b.touches.currentY !== b.touches.startY) && (O = !0), S) {
                                if (E) return void(S = !1);
                                if (O || !b.browser.ieTouch) {
                                    b.allowClick = !1,
                                    b.emit("onSliderMove", b, e),
                                    e.preventDefault(),
                                    b.params.touchMoveStopPropagation && !b.params.nested && e.stopPropagation(),
                                    C || (i.loop && b.fixLoop(), k = b.getWrapperTranslate(), b.setWrapperTransition(0), b.animating && b.wrapper.trigger("webkitTransitionEnd transitionend oTransitionEnd MSTransitionEnd msTransitionEnd"), b.params.autoplay && b.autoplaying && (b.params.autoplayDisableOnInteraction ? b.stopAutoplay() : b.pauseAutoplay()), B = !1, b.params.grabCursor && (b.container[0].style.cursor = "move", b.container[0].style.cursor = "-webkit-grabbing", b.container[0].style.cursor = "-moz-grabbin", b.container[0].style.cursor = "grabbing")),
                                    C = !0;
                                    var r = b.touches.diff = b.isHorizontal() ? b.touches.currentX - b.touches.startX: b.touches.currentY - b.touches.startY;
                                    r *= b.params.touchRatio,
                                    b.rtl && (r = -r),
                                    b.swipeDirection = r > 0 ? "prev": "next",
                                    P = r + k;
                                    var s = !0;
                                    if (r > 0 && P > b.minTranslate() ? (s = !1, b.params.resistance && (P = b.minTranslate() - 1 + Math.pow( - b.minTranslate() + k + r, b.params.resistanceRatio))) : 0 > r && P < b.maxTranslate() && (s = !1, b.params.resistance && (P = b.maxTranslate() + 1 - Math.pow(b.maxTranslate() - k - r, b.params.resistanceRatio))), s && (e.preventedByNestedSwiper = !0), !b.params.allowSwipeToNext && "next" === b.swipeDirection && k > P && (P = k), !b.params.allowSwipeToPrev && "prev" === b.swipeDirection && P > k && (P = k), b.params.followFinger) {
                                        if (b.params.threshold > 0) {
                                            if (! (Math.abs(r) > b.params.threshold || I)) return void(P = k);
                                            if (!I) return I = !0,
                                            b.touches.startX = b.touches.currentX,
                                            b.touches.startY = b.touches.currentY,
                                            P = k,
                                            void(b.touches.diff = b.isHorizontal() ? b.touches.currentX - b.touches.startX: b.touches.currentY - b.touches.startY)
                                        } (b.params.freeMode || b.params.watchSlidesProgress) && b.updateActiveIndex(),
                                        b.params.freeMode && (0 === A.length && A.push({
                                            position: b.touches[b.isHorizontal() ? "startX": "startY"],
                                            time: M
                                        }), A.push({
                                            position: b.touches[b.isHorizontal() ? "currentX": "currentY"],
                                            time: (new window.Date).getTime()
                                        })),
                                        b.updateProgress(P),
                                        b.setWrapperTranslate(P)
                                    }
                                }
                            }
                        }
                    }
                },
                b.onTouchEnd = function(e) {
                    if (e.originalEvent && (e = e.originalEvent), z && b.emit("onTouchEnd", b, e), z = !1, S) {
                        b.params.grabCursor && C && S && (b.container[0].style.cursor = "move", b.container[0].style.cursor = "-webkit-grab", b.container[0].style.cursor = "-moz-grab", b.container[0].style.cursor = "grab");
                        var t = Date.now(),
                        r = t - M;
                        if (b.allowClick && (b.updateClickedSlide(e), b.emit("onTap", b, e), 300 > r && t - H > 300 && (L && clearTimeout(L), L = setTimeout(function() {
                            b && (b.params.paginationHide && b.paginationContainer.length > 0 && !a(e.target).hasClass(b.params.bulletClass) && b.paginationContainer.toggleClass(b.params.paginationHiddenClass), b.emit("onClick", b, e))
                        },
                        300)), 300 > r && 300 > t - H && (L && clearTimeout(L), b.emit("onDoubleTap", b, e))), H = Date.now(), setTimeout(function() {
                            b && (b.allowClick = !0)
                        },
                        0), !S || !C || !b.swipeDirection || 0 === b.touches.diff || P === k) return void(S = C = !1);
                        S = C = !1;
                        var i;
                        if (i = b.params.followFinger ? b.rtl ? b.translate: -b.translate: -P, b.params.freeMode) {
                            if (i < -b.minTranslate()) return void b.slideTo(b.activeIndex);
                            if (i > -b.maxTranslate()) return void(b.slides.length < b.snapGrid.length ? b.slideTo(b.snapGrid.length - 1) : b.slideTo(b.slides.length - 1));
                            if (b.params.freeModeMomentum) {
                                if (A.length > 1) {
                                    var s = A.pop(),
                                    n = A.pop(),
                                    o = s.position - n.position,
                                    l = s.time - n.time;
                                    b.velocity = o / l,
                                    b.velocity = b.velocity / 2,
                                    Math.abs(b.velocity) < b.params.freeModeMinimumVelocity && (b.velocity = 0),
                                    (l > 150 || (new window.Date).getTime() - s.time > 300) && (b.velocity = 0)
                                } else b.velocity = 0;
                                A.length = 0;
                                var p = 1e3 * b.params.freeModeMomentumRatio,
                                d = b.velocity * p,
                                u = b.translate + d;
                                b.rtl && (u = -u);
                                var c, m = !1,
                                h = 20 * Math.abs(b.velocity) * b.params.freeModeMomentumBounceRatio;
                                if (u < b.maxTranslate()) b.params.freeModeMomentumBounce ? (u + b.maxTranslate() < -h && (u = b.maxTranslate() - h), c = b.maxTranslate(), m = !0, B = !0) : u = b.maxTranslate();
                                else if (u > b.minTranslate()) b.params.freeModeMomentumBounce ? (u - b.minTranslate() > h && (u = b.minTranslate() + h), c = b.minTranslate(), m = !0, B = !0) : u = b.minTranslate();
                                else if (b.params.freeModeSticky) {
                                    var f, g = 0;
                                    for (g = 0; g < b.snapGrid.length; g += 1) if (b.snapGrid[g] > -u) {
                                        f = g;
                                        break
                                    }
                                    u = Math.abs(b.snapGrid[f] - u) < Math.abs(b.snapGrid[f - 1] - u) || "next" === b.swipeDirection ? b.snapGrid[f] : b.snapGrid[f - 1],
                                    b.rtl || (u = -u)
                                }
                                if (0 !== b.velocity) p = b.rtl ? Math.abs(( - u - b.translate) / b.velocity) : Math.abs((u - b.translate) / b.velocity);
                                else if (b.params.freeModeSticky) return void b.slideReset();
                                b.params.freeModeMomentumBounce && m ? (b.updateProgress(c), b.setWrapperTransition(p), b.setWrapperTranslate(u), b.onTransitionStart(), b.animating = !0, b.wrapper.transitionEnd(function() {
                                    b && B && (b.emit("onMomentumBounce", b), b.setWrapperTransition(b.params.speed), b.setWrapperTranslate(c), b.wrapper.transitionEnd(function() {
                                        b && b.onTransitionEnd()
                                    }))
                                })) : b.velocity ? (b.updateProgress(u), b.setWrapperTransition(p), b.setWrapperTranslate(u), b.onTransitionStart(), b.animating || (b.animating = !0, b.wrapper.transitionEnd(function() {
                                    b && b.onTransitionEnd()
                                }))) : b.updateProgress(u),
                                b.updateActiveIndex()
                            }
                            return void((!b.params.freeModeMomentum || r >= b.params.longSwipesMs) && (b.updateProgress(), b.updateActiveIndex()))
                        }
                        var v, w = 0,
                        y = b.slidesSizesGrid[0];
                        for (v = 0; v < b.slidesGrid.length; v += b.params.slidesPerGroup)"undefined" != typeof b.slidesGrid[v + b.params.slidesPerGroup] ? i >= b.slidesGrid[v] && i < b.slidesGrid[v + b.params.slidesPerGroup] && (w = v, y = b.slidesGrid[v + b.params.slidesPerGroup] - b.slidesGrid[v]) : i >= b.slidesGrid[v] && (w = v, y = b.slidesGrid[b.slidesGrid.length - 1] - b.slidesGrid[b.slidesGrid.length - 2]);
                        var x = (i - b.slidesGrid[w]) / y;
                        if (r > b.params.longSwipesMs) {
                            if (!b.params.longSwipes) return void b.slideTo(b.activeIndex);
                            "next" === b.swipeDirection && (x >= b.params.longSwipesRatio ? b.slideTo(w + b.params.slidesPerGroup) : b.slideTo(w)),
                            "prev" === b.swipeDirection && (x > 1 - b.params.longSwipesRatio ? b.slideTo(w + b.params.slidesPerGroup) : b.slideTo(w))
                        } else {
                            if (!b.params.shortSwipes) return void b.slideTo(b.activeIndex);
                            "next" === b.swipeDirection && b.slideTo(w + b.params.slidesPerGroup),
                            "prev" === b.swipeDirection && b.slideTo(w)
                        }
                    }
                },
                b._slideTo = function(e, a) {
                    return b.slideTo(e, a, !0, !0)
                },
                b.slideTo = function(e, a, t, r) {
                    "undefined" == typeof t && (t = !0),
                    "undefined" == typeof e && (e = 0),
                    0 > e && (e = 0),
                    b.snapIndex = Math.floor(e / b.params.slidesPerGroup),
                    b.snapIndex >= b.snapGrid.length && (b.snapIndex = b.snapGrid.length - 1);
                    var i = -b.snapGrid[b.snapIndex];
                    b.params.autoplay && b.autoplaying && (r || !b.params.autoplayDisableOnInteraction ? b.pauseAutoplay(a) : b.stopAutoplay()),
                    b.updateProgress(i);
                    for (var s = 0; s < b.slidesGrid.length; s++) - Math.floor(100 * i) >= Math.floor(100 * b.slidesGrid[s]) && (e = s);
                    return ! b.params.allowSwipeToNext && i < b.translate && i < b.minTranslate() ? !1 : !b.params.allowSwipeToPrev && i > b.translate && i > b.maxTranslate() && (b.activeIndex || 0) !== e ? !1 : ("undefined" == typeof a && (a = b.params.speed), b.previousIndex = b.activeIndex || 0, b.activeIndex = e, b.rtl && -i === b.translate || !b.rtl && i === b.translate ? (b.params.autoHeight && b.updateAutoHeight(), b.updateClasses(), "slide" !== b.params.effect && b.setWrapperTranslate(i), !1) : (b.updateClasses(), b.onTransitionStart(t), 0 === a ? (b.setWrapperTranslate(i), b.setWrapperTransition(0), b.onTransitionEnd(t)) : (b.setWrapperTranslate(i), b.setWrapperTransition(a), b.animating || (b.animating = !0, b.wrapper.transitionEnd(function() {
                        b && b.onTransitionEnd(t)
                    }))), !0))
                },
                b.onTransitionStart = function(e) {
                    "undefined" == typeof e && (e = !0),
                    b.params.autoHeight && b.updateAutoHeight(),
                    b.lazy && b.lazy.onTransitionStart(),
                    e && (b.emit("onTransitionStart", b), b.activeIndex !== b.previousIndex && (b.emit("onSlideChangeStart", b), b.activeIndex > b.previousIndex ? b.emit("onSlideNextStart", b) : b.emit("onSlidePrevStart", b)))
                },
                b.onTransitionEnd = function(e) {
                    b.animating = !1,
                    b.setWrapperTransition(0),
                    "undefined" == typeof e && (e = !0),
                    b.lazy && b.lazy.onTransitionEnd(),
                    e && (b.emit("onTransitionEnd", b), b.activeIndex !== b.previousIndex && (b.emit("onSlideChangeEnd", b), b.activeIndex > b.previousIndex ? b.emit("onSlideNextEnd", b) : b.emit("onSlidePrevEnd", b))),
                    b.params.hashnav && b.hashnav && b.hashnav.setHash()
                },
                b.slideNext = function(e, a, t) {
                    if (b.params.loop) {
                        if (b.animating) return ! 1;
                        b.fixLoop();
                        b.container[0].clientLeft;
                        return b.slideTo(b.activeIndex + b.params.slidesPerGroup, a, e, t)
                    }
                    return b.slideTo(b.activeIndex + b.params.slidesPerGroup, a, e, t)
                },
                b._slideNext = function(e) {
                    return b.slideNext(!0, e, !0)
                },
                b.slidePrev = function(e, a, t) {
                    if (b.params.loop) {
                        if (b.animating) return ! 1;
                        b.fixLoop();
                        b.container[0].clientLeft;
                        return b.slideTo(b.activeIndex - 1, a, e, t)
                    }
                    return b.slideTo(b.activeIndex - 1, a, e, t)
                },
                b._slidePrev = function(e) {
                    return b.slidePrev(!0, e, !0)
                },
                b.slideReset = function(e, a, t) {
                    return b.slideTo(b.activeIndex, a, e)
                },
                b.setWrapperTransition = function(e, a) {
                    b.wrapper.transition(e),
                    "slide" !== b.params.effect && b.effects[b.params.effect] && b.effects[b.params.effect].setTransition(e),
                    b.params.parallax && b.parallax && b.parallax.setTransition(e),
                    b.params.scrollbar && b.scrollbar && b.scrollbar.setTransition(e),
                    b.params.control && b.controller && b.controller.setTransition(e, a),
                    b.emit("onSetTransition", b, e)
                },
                b.setWrapperTranslate = function(e, a, t) {
                    var r = 0,
                    i = 0,
                    n = 0;
                    b.isHorizontal() ? r = b.rtl ? -e: e: i = e,
                    b.params.roundLengths && (r = s(r), i = s(i)),
                    b.params.virtualTranslate || (b.support.transforms3d ? b.wrapper.transform("translate3d(" + r + "px, " + i + "px, " + n + "px)") : b.wrapper.transform("translate(" + r + "px, " + i + "px)")),
                    b.translate = b.isHorizontal() ? r: i;
                    var o, l = b.maxTranslate() - b.minTranslate();
                    o = 0 === l ? 0 : (e - b.minTranslate()) / l,
                    o !== b.progress && b.updateProgress(e),
                    a && b.updateActiveIndex(),
                    "slide" !== b.params.effect && b.effects[b.params.effect] && b.effects[b.params.effect].setTranslate(b.translate),
                    b.params.parallax && b.parallax && b.parallax.setTranslate(b.translate),
                    b.params.scrollbar && b.scrollbar && b.scrollbar.setTranslate(b.translate),
                    b.params.control && b.controller && b.controller.setTranslate(b.translate, t),
                    b.emit("onSetTranslate", b, b.translate)
                },
                b.getTranslate = function(e, a) {
                    var t, r, i, s;
                    return "undefined" == typeof a && (a = "x"),
                    b.params.virtualTranslate ? b.rtl ? -b.translate: b.translate: (i = window.getComputedStyle(e, null), window.WebKitCSSMatrix ? (r = i.transform || i.webkitTransform, r.split(",").length > 6 && (r = r.split(", ").map(function(e) {
                        return e.replace(",", ".")
                    }).join(", ")), s = new window.WebKitCSSMatrix("none" === r ? "": r)) : (s = i.MozTransform || i.OTransform || i.MsTransform || i.msTransform || i.transform || i.getPropertyValue("transform").replace("translate(", "matrix(1, 0, 0, 1,"), t = s.toString().split(",")), "x" === a && (r = window.WebKitCSSMatrix ? s.m41: 16 === t.length ? parseFloat(t[12]) : parseFloat(t[4])), "y" === a && (r = window.WebKitCSSMatrix ? s.m42: 16 === t.length ? parseFloat(t[13]) : parseFloat(t[5])), b.rtl && r && (r = -r), r || 0)
                },
                b.getWrapperTranslate = function(e) {
                    return "undefined" == typeof e && (e = b.isHorizontal() ? "x": "y"),
                    b.getTranslate(b.wrapper[0], e)
                },
                b.observers = [], b.initObservers = function() {
                    if (b.params.observeParents) for (var e = b.container.parents(), a = 0; a < e.length; a++) l(e[a]);
                    l(b.container[0], {
                        childList: !1
                    }),
                    l(b.wrapper[0], {
                        attributes: !1
                    })
                },
                b.disconnectObservers = function() {
                    for (var e = 0; e < b.observers.length; e++) b.observers[e].disconnect();
                    b.observers = []
                },
                b.createLoop = function() {
                    b.wrapper.children("." + b.params.slideClass + "." + b.params.slideDuplicateClass).remove();
                    var e = b.wrapper.children("." + b.params.slideClass);
                    "auto" !== b.params.slidesPerView || b.params.loopedSlides || (b.params.loopedSlides = e.length),
                    b.loopedSlides = parseInt(b.params.loopedSlides || b.params.slidesPerView, 10),
                    b.loopedSlides = b.loopedSlides + b.params.loopAdditionalSlides,
                    b.loopedSlides > e.length && (b.loopedSlides = e.length);
                    var t, r = [],
                    i = [];
                    for (e.each(function(t, s) {
                        var n = a(this);
                        t < b.loopedSlides && i.push(s),
                        t < e.length && t >= e.length - b.loopedSlides && r.push(s),
                        n.attr("data-swiper-slide-index", t)
                    }), t = 0; t < i.length; t++) b.wrapper.append(a(i[t].cloneNode(!0)).addClass(b.params.slideDuplicateClass));
                    for (t = r.length - 1; t >= 0; t--) b.wrapper.prepend(a(r[t].cloneNode(!0)).addClass(b.params.slideDuplicateClass))
                },
                b.destroyLoop = function() {
                    b.wrapper.children("." + b.params.slideClass + "." + b.params.slideDuplicateClass).remove(),
                    b.slides.removeAttr("data-swiper-slide-index")
                },
                b.reLoop = function(e) {
                    var a = b.activeIndex - b.loopedSlides;
                    b.destroyLoop(),
                    b.createLoop(),
                    b.updateSlidesSize(),
                    e && b.slideTo(a + b.loopedSlides, 0, !1)
                },
                b.fixLoop = function() {
                    var e;
                    b.activeIndex < b.loopedSlides ? (e = b.slides.length - 3 * b.loopedSlides + b.activeIndex, e += b.loopedSlides, b.slideTo(e, 0, !1, !0)) : ("auto" === b.params.slidesPerView && b.activeIndex >= 2 * b.loopedSlides || b.activeIndex > b.slides.length - 2 * b.params.slidesPerView) && (e = -b.slides.length + b.activeIndex + b.loopedSlides, e += b.loopedSlides, b.slideTo(e, 0, !1, !0))
                },
                b.appendSlide = function(e) {
                    if (b.params.loop && b.destroyLoop(), "object" == typeof e && e.length) for (var a = 0; a < e.length; a++) e[a] && b.wrapper.append(e[a]);
                    else b.wrapper.append(e);
                    b.params.loop && b.createLoop(),
                    b.params.observer && b.support.observer || b.update(!0)
                },
                b.prependSlide = function(e) {
                    b.params.loop && b.destroyLoop();
                    var a = b.activeIndex + 1;
                    if ("object" == typeof e && e.length) {
                        for (var t = 0; t < e.length; t++) e[t] && b.wrapper.prepend(e[t]);
                        a = b.activeIndex + e.length
                    } else b.wrapper.prepend(e);
                    b.params.loop && b.createLoop(),
                    b.params.observer && b.support.observer || b.update(!0),
                    b.slideTo(a, 0, !1)
                },
                b.removeSlide = function(e) {
                    b.params.loop && (b.destroyLoop(), b.slides = b.wrapper.children("." + b.params.slideClass));
                    var a, t = b.activeIndex;
                    if ("object" == typeof e && e.length) {
                        for (var r = 0; r < e.length; r++) a = e[r],
                        b.slides[a] && b.slides.eq(a).remove(),
                        t > a && t--;
                        t = Math.max(t, 0)
                    } else a = e,
                    b.slides[a] && b.slides.eq(a).remove(),
                    t > a && t--,
                    t = Math.max(t, 0);
                    b.params.loop && b.createLoop(),
                    b.params.observer && b.support.observer || b.update(!0),
                    b.params.loop ? b.slideTo(t + b.loopedSlides, 0, !1) : b.slideTo(t, 0, !1)
                },
                b.removeAllSlides = function() {
                    for (var e = [], a = 0; a < b.slides.length; a++) e.push(a);
                    b.removeSlide(e)
                },
                b.effects = {
                    fade: {
                        setTranslate: function() {
                            for (var e = 0; e < b.slides.length; e++) {
                                var a = b.slides.eq(e),
                                t = a[0].swiperSlideOffset,
                                r = -t;
                                b.params.virtualTranslate || (r -= b.translate);
                                var i = 0;
                                b.isHorizontal() || (i = r, r = 0);
                                var s = b.params.fade.crossFade ? Math.max(1 - Math.abs(a[0].progress), 0) : 1 + Math.min(Math.max(a[0].progress, -1), 0);
                                a.css({
                                    opacity: s
                                }).transform("translate3d(" + r + "px, " + i + "px, 0px)")
                            }
                        },
                        setTransition: function(e) {
                            if (b.slides.transition(e), b.params.virtualTranslate && 0 !== e) {
                                var a = !1;
                                b.slides.transitionEnd(function() {
                                    if (!a && b) {
                                        a = !0,
                                        b.animating = !1;
                                        for (var e = ["webkitTransitionEnd", "transitionend", "oTransitionEnd", "MSTransitionEnd", "msTransitionEnd"], t = 0; t < e.length; t++) b.wrapper.trigger(e[t])
                                    }
                                })
                            }
                        }
                    },
                    flip: {
                        setTranslate: function() {
                            for (var e = 0; e < b.slides.length; e++) {
                                var t = b.slides.eq(e),
                                r = t[0].progress;
                                b.params.flip.limitRotation && (r = Math.max(Math.min(t[0].progress, 1), -1));
                                var i = t[0].swiperSlideOffset,
                                s = -180 * r,
                                n = s,
                                o = 0,
                                l = -i,
                                p = 0;
                                if (b.isHorizontal() ? b.rtl && (n = -n) : (p = l, l = 0, o = -n, n = 0), t[0].style.zIndex = -Math.abs(Math.round(r)) + b.slides.length, b.params.flip.slideShadows) {
                                    var d = b.isHorizontal() ? t.find(".swiper-slide-shadow-left") : t.find(".swiper-slide-shadow-top"),
                                    u = b.isHorizontal() ? t.find(".swiper-slide-shadow-right") : t.find(".swiper-slide-shadow-bottom");
                                    0 === d.length && (d = a('<div class="swiper-slide-shadow-' + (b.isHorizontal() ? "left": "top") + '"></div>'), t.append(d)),
                                    0 === u.length && (u = a('<div class="swiper-slide-shadow-' + (b.isHorizontal() ? "right": "bottom") + '"></div>'), t.append(u)),
                                    d.length && (d[0].style.opacity = Math.max( - r, 0)),
                                    u.length && (u[0].style.opacity = Math.max(r, 0))
                                }
                                t.transform("translate3d(" + l + "px, " + p + "px, 0px) rotateX(" + o + "deg) rotateY(" + n + "deg)")
                            }
                        },
                        setTransition: function(e) {
                            if (b.slides.transition(e).find(".swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left").transition(e), b.params.virtualTranslate && 0 !== e) {
                                var t = !1;
                                b.slides.eq(b.activeIndex).transitionEnd(function() {
                                    if (!t && b && a(this).hasClass(b.params.slideActiveClass)) {
                                        t = !0,
                                        b.animating = !1;
                                        for (var e = ["webkitTransitionEnd", "transitionend", "oTransitionEnd", "MSTransitionEnd", "msTransitionEnd"], r = 0; r < e.length; r++) b.wrapper.trigger(e[r])
                                    }
                                })
                            }
                        }
                    },
                    cube: {
                        setTranslate: function() {
                            var e, t = 0;
                            b.params.cube.shadow && (b.isHorizontal() ? (e = b.wrapper.find(".swiper-cube-shadow"), 0 === e.length && (e = a('<div class="swiper-cube-shadow"></div>'), b.wrapper.append(e)), e.css({
                                height: b.width + "px"
                            })) : (e = b.container.find(".swiper-cube-shadow"), 0 === e.length && (e = a('<div class="swiper-cube-shadow"></div>'), b.container.append(e))));
                            for (var r = 0; r < b.slides.length; r++) {
                                var i = b.slides.eq(r),
                                s = 90 * r,
                                n = Math.floor(s / 360);
                                b.rtl && (s = -s, n = Math.floor( - s / 360));
                                var o = Math.max(Math.min(i[0].progress, 1), -1),
                                l = 0,
                                p = 0,
                                d = 0;
                                r % 4 === 0 ? (l = 4 * -n * b.size, d = 0) : (r - 1) % 4 === 0 ? (l = 0, d = 4 * -n * b.size) : (r - 2) % 4 === 0 ? (l = b.size + 4 * n * b.size, d = b.size) : (r - 3) % 4 === 0 && (l = -b.size, d = 3 * b.size + 4 * b.size * n),
                                b.rtl && (l = -l),
                                b.isHorizontal() || (p = l, l = 0);
                                var u = "rotateX(" + (b.isHorizontal() ? 0 : -s) + "deg) rotateY(" + (b.isHorizontal() ? s: 0) + "deg) translate3d(" + l + "px, " + p + "px, " + d + "px)";
                                if (1 >= o && o > -1 && (t = 90 * r + 90 * o, b.rtl && (t = 90 * -r - 90 * o)), i.transform(u), b.params.cube.slideShadows) {
                                    var c = b.isHorizontal() ? i.find(".swiper-slide-shadow-left") : i.find(".swiper-slide-shadow-top"),
                                    m = b.isHorizontal() ? i.find(".swiper-slide-shadow-right") : i.find(".swiper-slide-shadow-bottom");
                                    0 === c.length && (c = a('<div class="swiper-slide-shadow-' + (b.isHorizontal() ? "left": "top") + '"></div>'), i.append(c)),
                                    0 === m.length && (m = a('<div class="swiper-slide-shadow-' + (b.isHorizontal() ? "right": "bottom") + '"></div>'), i.append(m)),
                                    c.length && (c[0].style.opacity = Math.max( - o, 0)),
                                    m.length && (m[0].style.opacity = Math.max(o, 0))
                                }
                            }
                            if (b.wrapper.css({
                                "-webkit-transform-origin": "50% 50% -" + b.size / 2 + "px",
                                "-moz-transform-origin": "50% 50% -" + b.size / 2 + "px",
                                "-ms-transform-origin": "50% 50% -" + b.size / 2 + "px",
                                "transform-origin": "50% 50% -" + b.size / 2 + "px"
                            }), b.params.cube.shadow) if (b.isHorizontal()) e.transform("translate3d(0px, " + (b.width / 2 + b.params.cube.shadowOffset) + "px, " + -b.width / 2 + "px) rotateX(90deg) rotateZ(0deg) scale(" + b.params.cube.shadowScale + ")");
                            else {
                                var h = Math.abs(t) - 90 * Math.floor(Math.abs(t) / 90),
                                f = 1.5 - (Math.sin(2 * h * Math.PI / 360) / 2 + Math.cos(2 * h * Math.PI / 360) / 2),
                                g = b.params.cube.shadowScale,
                                v = b.params.cube.shadowScale / f,
                                w = b.params.cube.shadowOffset;
                                e.transform("scale3d(" + g + ", 1, " + v + ") translate3d(0px, " + (b.height / 2 + w) + "px, " + -b.height / 2 / v + "px) rotateX(-90deg)")
                            }
                            var y = b.isSafari || b.isUiWebView ? -b.size / 2 : 0;
                            b.wrapper.transform("translate3d(0px,0," + y + "px) rotateX(" + (b.isHorizontal() ? 0 : t) + "deg) rotateY(" + (b.isHorizontal() ? -t: 0) + "deg)")
                        },
                        setTransition: function(e) {
                            b.slides.transition(e).find(".swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left").transition(e),
                            b.params.cube.shadow && !b.isHorizontal() && b.container.find(".swiper-cube-shadow").transition(e)
                        }
                    },
                    coverflow: {
                        setTranslate: function() {
                            for (var e = b.translate,
                            t = b.isHorizontal() ? -e + b.width / 2 : -e + b.height / 2, r = b.isHorizontal() ? b.params.coverflow.rotate: -b.params.coverflow.rotate, i = b.params.coverflow.depth, s = 0, n = b.slides.length; n > s; s++) {
                                var o = b.slides.eq(s),
                                l = b.slidesSizesGrid[s],
                                p = o[0].swiperSlideOffset,
                                d = (t - p - l / 2) / l * b.params.coverflow.modifier,
                                u = b.isHorizontal() ? r * d: 0,
                                c = b.isHorizontal() ? 0 : r * d,
                                m = -i * Math.abs(d),
                                h = b.isHorizontal() ? 0 : b.params.coverflow.stretch * d,
                                f = b.isHorizontal() ? b.params.coverflow.stretch * d: 0;
                                Math.abs(f) < .001 && (f = 0),
                                Math.abs(h) < .001 && (h = 0),
                                Math.abs(m) < .001 && (m = 0),
                                Math.abs(u) < .001 && (u = 0),
                                Math.abs(c) < .001 && (c = 0);
                                var g = "translate3d(" + f + "px," + h + "px," + m + "px)  rotateX(" + c + "deg) rotateY(" + u + "deg)";
                                if (o.transform(g), o[0].style.zIndex = -Math.abs(Math.round(d)) + 1, b.params.coverflow.slideShadows) {
                                    var v = b.isHorizontal() ? o.find(".swiper-slide-shadow-left") : o.find(".swiper-slide-shadow-top"),
                                    w = b.isHorizontal() ? o.find(".swiper-slide-shadow-right") : o.find(".swiper-slide-shadow-bottom");
                                    0 === v.length && (v = a('<div class="swiper-slide-shadow-' + (b.isHorizontal() ? "left": "top") + '"></div>'), o.append(v)),
                                    0 === w.length && (w = a('<div class="swiper-slide-shadow-' + (b.isHorizontal() ? "right": "bottom") + '"></div>'), o.append(w)),
                                    v.length && (v[0].style.opacity = d > 0 ? d: 0),
                                    w.length && (w[0].style.opacity = -d > 0 ? -d: 0)
                                }
                            }
                            if (b.browser.ie) {
                                var y = b.wrapper[0].style;
                                y.perspectiveOrigin = t + "px 50%"
                            }
                        },
                        setTransition: function(e) {
                            b.slides.transition(e).find(".swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left").transition(e)
                        }
                    }
                },
                b.lazy = {
                    initialImageLoaded: !1,
                    loadImageInSlide: function(e, t) {
                        if ("undefined" != typeof e && ("undefined" == typeof t && (t = !0), 0 !== b.slides.length)) {
                            var r = b.slides.eq(e),
                            i = r.find(".swiper-lazy:not(.swiper-lazy-loaded):not(.swiper-lazy-loading)"); ! r.hasClass("swiper-lazy") || r.hasClass("swiper-lazy-loaded") || r.hasClass("swiper-lazy-loading") || (i = i.add(r[0])),
                            0 !== i.length && i.each(function() {
                                var e = a(this);
                                e.addClass("swiper-lazy-loading");
                                var i = e.attr("data-background"),
                                s = e.attr("data-src"),
                                n = e.attr("data-srcset");
                                b.loadImage(e[0], s || i, n, !1,
                                function() {
                                    if (i ? (e.css("background-image", 'url("' + i + '")'), e.removeAttr("data-background")) : (n && (e.attr("srcset", n), e.removeAttr("data-srcset")), s && (e.attr("src", s), e.removeAttr("data-src"))), e.addClass("swiper-lazy-loaded").removeClass("swiper-lazy-loading"), r.find(".swiper-lazy-preloader, .preloader").remove(), b.params.loop && t) {
                                        var a = r.attr("data-swiper-slide-index");
                                        if (r.hasClass(b.params.slideDuplicateClass)) {
                                            var o = b.wrapper.children('[data-swiper-slide-index="' + a + '"]:not(.' + b.params.slideDuplicateClass + ")");
                                            b.lazy.loadImageInSlide(o.index(), !1)
                                        } else {
                                            var l = b.wrapper.children("." + b.params.slideDuplicateClass + '[data-swiper-slide-index="' + a + '"]');
                                            b.lazy.loadImageInSlide(l.index(), !1)
                                        }
                                    }
                                    b.emit("onLazyImageReady", b, r[0], e[0])
                                }),
                                b.emit("onLazyImageLoad", b, r[0], e[0])
                            })
                        }
                    },
                    load: function() {
                        var e;
                        if (b.params.watchSlidesVisibility) b.wrapper.children("." + b.params.slideVisibleClass).each(function() {
                            b.lazy.loadImageInSlide(a(this).index())
                        });
                        else if (b.params.slidesPerView > 1) for (e = b.activeIndex; e < b.activeIndex + b.params.slidesPerView; e++) b.slides[e] && b.lazy.loadImageInSlide(e);
                        else b.lazy.loadImageInSlide(b.activeIndex);
                        if (b.params.lazyLoadingInPrevNext) if (b.params.slidesPerView > 1 || b.params.lazyLoadingInPrevNextAmount && b.params.lazyLoadingInPrevNextAmount > 1) {
                            var t = b.params.lazyLoadingInPrevNextAmount,
                            r = b.params.slidesPerView,
                            i = Math.min(b.activeIndex + r + Math.max(t, r), b.slides.length),
                            s = Math.max(b.activeIndex - Math.max(r, t), 0);
                            for (e = b.activeIndex + b.params.slidesPerView; i > e; e++) b.slides[e] && b.lazy.loadImageInSlide(e);
                            for (e = s; e < b.activeIndex; e++) b.slides[e] && b.lazy.loadImageInSlide(e)
                        } else {
                            var n = b.wrapper.children("." + b.params.slideNextClass);
                            n.length > 0 && b.lazy.loadImageInSlide(n.index());
                            var o = b.wrapper.children("." + b.params.slidePrevClass);
                            o.length > 0 && b.lazy.loadImageInSlide(o.index())
                        }
                    },
                    onTransitionStart: function() {
                        b.params.lazyLoading && (b.params.lazyLoadingOnTransitionStart || !b.params.lazyLoadingOnTransitionStart && !b.lazy.initialImageLoaded) && b.lazy.load()
                    },
                    onTransitionEnd: function() {
                        b.params.lazyLoading && !b.params.lazyLoadingOnTransitionStart && b.lazy.load()
                    }
                },
                b.scrollbar = {
                    isTouched: !1,
                    setDragPosition: function(e) {
                        var a = b.scrollbar,
                        t = b.isHorizontal() ? "touchstart" === e.type || "touchmove" === e.type ? e.targetTouches[0].pageX: e.pageX || e.clientX: "touchstart" === e.type || "touchmove" === e.type ? e.targetTouches[0].pageY: e.pageY || e.clientY,
                        r = t - a.track.offset()[b.isHorizontal() ? "left": "top"] - a.dragSize / 2,
                        i = -b.minTranslate() * a.moveDivider,
                        s = -b.maxTranslate() * a.moveDivider;
                        i > r ? r = i: r > s && (r = s),
                        r = -r / a.moveDivider,
                        b.updateProgress(r),
                        b.setWrapperTranslate(r, !0)
                    },
                    dragStart: function(e) {
                        var a = b.scrollbar;
                        a.isTouched = !0,
                        e.preventDefault(),
                        e.stopPropagation(),
                        a.setDragPosition(e),
                        clearTimeout(a.dragTimeout),
                        a.track.transition(0),
                        b.params.scrollbarHide && a.track.css("opacity", 1),
                        b.wrapper.transition(100),
                        a.drag.transition(100),
                        b.emit("onScrollbarDragStart", b)
                    },
                    dragMove: function(e) {
                        var a = b.scrollbar;
                        a.isTouched && (e.preventDefault ? e.preventDefault() : e.returnValue = !1, a.setDragPosition(e), b.wrapper.transition(0), a.track.transition(0), a.drag.transition(0), b.emit("onScrollbarDragMove", b))
                    },
                    dragEnd: function(e) {
                        var a = b.scrollbar;
                        a.isTouched && (a.isTouched = !1, b.params.scrollbarHide && (clearTimeout(a.dragTimeout), a.dragTimeout = setTimeout(function() {
                            a.track.css("opacity", 0),
                            a.track.transition(400)
                        },
                        1e3)), b.emit("onScrollbarDragEnd", b), b.params.scrollbarSnapOnRelease && b.slideReset())
                    },
                    enableDraggable: function() {
                        var e = b.scrollbar,
                        t = b.support.touch ? e.track: document;
                        a(e.track).on(b.touchEvents.start, e.dragStart),
                        a(t).on(b.touchEvents.move, e.dragMove),
                        a(t).on(b.touchEvents.end, e.dragEnd)
                    },
                    disableDraggable: function() {
                        var e = b.scrollbar,
                        t = b.support.touch ? e.track: document;
                        a(e.track).off(b.touchEvents.start, e.dragStart),
                        a(t).off(b.touchEvents.move, e.dragMove),
                        a(t).off(b.touchEvents.end, e.dragEnd)
                    },
                    set: function() {
                        if (b.params.scrollbar) {
                            var e = b.scrollbar;
                            e.track = a(b.params.scrollbar),
                            b.params.uniqueNavElements && "string" == typeof b.params.scrollbar && e.track.length > 1 && 1 === b.container.find(b.params.scrollbar).length && (e.track = b.container.find(b.params.scrollbar)),
                            e.drag = e.track.find(".swiper-scrollbar-drag"),
                            0 === e.drag.length && (e.drag = a('<div class="swiper-scrollbar-drag"></div>'), e.track.append(e.drag)),
                            e.drag[0].style.width = "",
                            e.drag[0].style.height = "",
                            e.trackSize = b.isHorizontal() ? e.track[0].offsetWidth: e.track[0].offsetHeight,
                            e.divider = b.size / b.virtualSize,
                            e.moveDivider = e.divider * (e.trackSize / b.size),
                            e.dragSize = e.trackSize * e.divider,
                            b.isHorizontal() ? e.drag[0].style.width = e.dragSize + "px": e.drag[0].style.height = e.dragSize + "px",
                            e.divider >= 1 ? e.track[0].style.display = "none": e.track[0].style.display = "",
                            b.params.scrollbarHide && (e.track[0].style.opacity = 0)
                        }
                    },
                    setTranslate: function() {
                        if (b.params.scrollbar) {
                            var e, a = b.scrollbar,
                            t = (b.translate || 0, a.dragSize);
                            e = (a.trackSize - a.dragSize) * b.progress,
                            b.rtl && b.isHorizontal() ? (e = -e, e > 0 ? (t = a.dragSize - e, e = 0) : -e + a.dragSize > a.trackSize && (t = a.trackSize + e)) : 0 > e ? (t = a.dragSize + e, e = 0) : e + a.dragSize > a.trackSize && (t = a.trackSize - e),
                            b.isHorizontal() ? (b.support.transforms3d ? a.drag.transform("translate3d(" + e + "px, 0, 0)") : a.drag.transform("translateX(" + e + "px)"), a.drag[0].style.width = t + "px") : (b.support.transforms3d ? a.drag.transform("translate3d(0px, " + e + "px, 0)") : a.drag.transform("translateY(" + e + "px)"), a.drag[0].style.height = t + "px"),
                            b.params.scrollbarHide && (clearTimeout(a.timeout), a.track[0].style.opacity = 1, a.timeout = setTimeout(function() {
                                a.track[0].style.opacity = 0,
                                a.track.transition(400)
                            },
                            1e3))
                        }
                    },
                    setTransition: function(e) {
                        b.params.scrollbar && b.scrollbar.drag.transition(e)
                    }
                },
                b.controller = {
                    LinearSpline: function(e, a) {
                        this.x = e,
                        this.y = a,
                        this.lastIndex = e.length - 1;
                        var t, r;
                        this.x.length;
                        this.interpolate = function(e) {
                            return e ? (r = i(this.x, e), t = r - 1, (e - this.x[t]) * (this.y[r] - this.y[t]) / (this.x[r] - this.x[t]) + this.y[t]) : 0
                        };
                        var i = function() {
                            var e, a, t;
                            return function(r, i) {
                                for (a = -1, e = r.length; e - a > 1;) r[t = e + a >> 1] <= i ? a = t: e = t;
                                return e
                            }
                        } ()
                    },
                    getInterpolateFunction: function(e) {
                        b.controller.spline || (b.controller.spline = b.params.loop ? new b.controller.LinearSpline(b.slidesGrid, e.slidesGrid) : new b.controller.LinearSpline(b.snapGrid, e.snapGrid))
                    },
                    setTranslate: function(e, a) {
                        function r(a) {
                            e = a.rtl && "horizontal" === a.params.direction ? -b.translate: b.translate,
                            "slide" === b.params.controlBy && (b.controller.getInterpolateFunction(a), s = -b.controller.spline.interpolate( - e)),
                            s && "container" !== b.params.controlBy || (i = (a.maxTranslate() - a.minTranslate()) / (b.maxTranslate() - b.minTranslate()), s = (e - b.minTranslate()) * i + a.minTranslate()),
                            b.params.controlInverse && (s = a.maxTranslate() - s),
                            a.updateProgress(s),
                            a.setWrapperTranslate(s, !1, b),
                            a.updateActiveIndex()
                        }
                        var i, s, n = b.params.control;
                        if (b.isArray(n)) for (var o = 0; o < n.length; o++) n[o] !== a && n[o] instanceof t && r(n[o]);
                        else n instanceof t && a !== n && r(n)
                    },
                    setTransition: function(e, a) {
                        function r(a) {
                            a.setWrapperTransition(e, b),
                            0 !== e && (a.onTransitionStart(), a.wrapper.transitionEnd(function() {
                                s && (a.params.loop && "slide" === b.params.controlBy && a.fixLoop(), a.onTransitionEnd())
                            }))
                        }
                        var i, s = b.params.control;
                        if (b.isArray(s)) for (i = 0; i < s.length; i++) s[i] !== a && s[i] instanceof t && r(s[i]);
                        else s instanceof t && a !== s && r(s)
                    }
                },
                b.hashnav = {
                    init: function() {
                        if (b.params.hashnav) {
                            b.hashnav.initialized = !0;
                            var e = document.location.hash.replace("#", "");
                            if (e) for (var a = 0,
                            t = 0,
                            r = b.slides.length; r > t; t++) {
                                var i = b.slides.eq(t),
                                s = i.attr("data-hash");
                                if (s === e && !i.hasClass(b.params.slideDuplicateClass)) {
                                    var n = i.index();
                                    b.slideTo(n, a, b.params.runCallbacksOnInit, !0)
                                }
                            }
                        }
                    },
                    setHash: function() {
                        b.hashnav.initialized && b.params.hashnav && (document.location.hash = b.slides.eq(b.activeIndex).attr("data-hash") || "")
                    }
                },
                b.disableKeyboardControl = function() {
                    b.params.keyboardControl = !1,
                    a(document).off("keydown", p)
                },
                b.enableKeyboardControl = function() {
                    b.params.keyboardControl = !0,
                    a(document).on("keydown", p)
                },
                b.mousewheel = {
                    event: !1,
                    lastScrollTime: (new window.Date).getTime()
                },
                b.params.mousewheelControl) {
                    try {
                        new window.WheelEvent("wheel"),
                        b.mousewheel.event = "wheel"
                    } catch(N) { (window.WheelEvent || b.container[0] && "wheel" in b.container[0]) && (b.mousewheel.event = "wheel")
                    } ! b.mousewheel.event && window.WheelEvent,
                    b.mousewheel.event || void 0 === document.onmousewheel || (b.mousewheel.event = "mousewheel"),
                    b.mousewheel.event || (b.mousewheel.event = "DOMMouseScroll")
                }
                b.disableMousewheelControl = function() {
                    return b.mousewheel.event ? (b.container.off(b.mousewheel.event, d), !0) : !1
                },
                b.enableMousewheelControl = function() {
                    return b.mousewheel.event ? (b.container.on(b.mousewheel.event, d), !0) : !1
                },
                b.parallax = {
                    setTranslate: function() {
                        b.container.children("[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y]").each(function() {
                            u(this, b.progress)
                        }),
                        b.slides.each(function() {
                            var e = a(this);
                            e.find("[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y]").each(function() {
                                var a = Math.min(Math.max(e[0].progress, -1), 1);
                                u(this, a)
                            })
                        })
                    },
                    setTransition: function(e) {
                        "undefined" == typeof e && (e = b.params.speed),
                        b.container.find("[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y]").each(function() {
                            var t = a(this),
                            r = parseInt(t.attr("data-swiper-parallax-duration"), 10) || e;
                            0 === e && (r = 0),
                            t.transition(r)
                        })
                    }
                },
                b._plugins = [];
                for (var R in b.plugins) {
                    var W = b.plugins[R](b, b.params[R]);
                    W && b._plugins.push(W)
                }
                return b.callPlugins = function(e) {
                    for (var a = 0; a < b._plugins.length; a++) e in b._plugins[a] && b._plugins[a][e](arguments[1], arguments[2], arguments[3], arguments[4], arguments[5])
                },
                b.emitterEventListeners = {},
                b.emit = function(e) {
                    b.params[e] && b.params[e](arguments[1], arguments[2], arguments[3], arguments[4], arguments[5]);
                    var a;
                    if (b.emitterEventListeners[e]) for (a = 0; a < b.emitterEventListeners[e].length; a++) b.emitterEventListeners[e][a](arguments[1], arguments[2], arguments[3], arguments[4], arguments[5]);
                    b.callPlugins && b.callPlugins(e, arguments[1], arguments[2], arguments[3], arguments[4], arguments[5])
                },
                b.on = function(e, a) {
                    return e = c(e),
                    b.emitterEventListeners[e] || (b.emitterEventListeners[e] = []),
                    b.emitterEventListeners[e].push(a),
                    b
                },
                b.off = function(e, a) {
                    var t;
                    if (e = c(e), "undefined" == typeof a) return b.emitterEventListeners[e] = [],
                    b;
                    if (b.emitterEventListeners[e] && 0 !== b.emitterEventListeners[e].length) {
                        for (t = 0; t < b.emitterEventListeners[e].length; t++) b.emitterEventListeners[e][t] === a && b.emitterEventListeners[e].splice(t, 1);
                        return b
                    }
                },
                b.once = function(e, a) {
                    e = c(e);
                    var t = function() {
                        a(arguments[0], arguments[1], arguments[2], arguments[3], arguments[4]),
                        b.off(e, t)
                    };
                    return b.on(e, t),
                    b
                },
                b.a11y = {
                    makeFocusable: function(e) {
                        return e.attr("tabIndex", "0"),
                        e
                    },
                    addRole: function(e, a) {
                        return e.attr("role", a),
                        e
                    },
                    addLabel: function(e, a) {
                        return e.attr("aria-label", a),
                        e
                    },
                    disable: function(e) {
                        return e.attr("aria-disabled", !0),
                        e
                    },
                    enable: function(e) {
                        return e.attr("aria-disabled", !1),
                        e
                    },
                    onEnterKey: function(e) {
                        13 === e.keyCode && (a(e.target).is(b.params.nextButton) ? (b.onClickNext(e), b.isEnd ? b.a11y.notify(b.params.lastSlideMessage) : b.a11y.notify(b.params.nextSlideMessage)) : a(e.target).is(b.params.prevButton) && (b.onClickPrev(e), b.isBeginning ? b.a11y.notify(b.params.firstSlideMessage) : b.a11y.notify(b.params.prevSlideMessage)), a(e.target).is("." + b.params.bulletClass) && a(e.target)[0].click())
                    },
                    liveRegion: a('<span class="swiper-notification" aria-live="assertive" aria-atomic="true"></span>'),
                    notify: function(e) {
                        var a = b.a11y.liveRegion;
                        0 !== a.length && (a.html(""), a.html(e))
                    },
                    init: function() {
                        b.params.nextButton && b.nextButton && b.nextButton.length > 0 && (b.a11y.makeFocusable(b.nextButton), b.a11y.addRole(b.nextButton, "button"), b.a11y.addLabel(b.nextButton, b.params.nextSlideMessage)),
                        b.params.prevButton && b.prevButton && b.prevButton.length > 0 && (b.a11y.makeFocusable(b.prevButton), b.a11y.addRole(b.prevButton, "button"), b.a11y.addLabel(b.prevButton, b.params.prevSlideMessage)),
                        a(b.container).append(b.a11y.liveRegion)
                    },
                    initPagination: function() {
                        b.params.pagination && b.params.paginationClickable && b.bullets && b.bullets.length && b.bullets.each(function() {
                            var e = a(this);
                            b.a11y.makeFocusable(e),
                            b.a11y.addRole(e, "button"),
                            b.a11y.addLabel(e, b.params.paginationBulletMessage.replace(/{{index}}/, e.index() + 1))
                        })
                    },
                    destroy: function() {
                        b.a11y.liveRegion && b.a11y.liveRegion.length > 0 && b.a11y.liveRegion.remove()
                    }
                },
                b.init = function() {
                    b.params.loop && b.createLoop(),
                    b.updateContainerSize(),
                    b.updateSlidesSize(),
                    b.updatePagination(),
                    b.params.scrollbar && b.scrollbar && (b.scrollbar.set(), b.params.scrollbarDraggable && b.scrollbar.enableDraggable()),
                    "slide" !== b.params.effect && b.effects[b.params.effect] && (b.params.loop || b.updateProgress(), b.effects[b.params.effect].setTranslate()),
                    b.params.loop ? b.slideTo(b.params.initialSlide + b.loopedSlides, 0, b.params.runCallbacksOnInit) : (b.slideTo(b.params.initialSlide, 0, b.params.runCallbacksOnInit), 0 === b.params.initialSlide && (b.parallax && b.params.parallax && b.parallax.setTranslate(), b.lazy && b.params.lazyLoading && (b.lazy.load(), b.lazy.initialImageLoaded = !0))),
                    b.attachEvents(),
                    b.params.observer && b.support.observer && b.initObservers(),
                    b.params.preloadImages && !b.params.lazyLoading && b.preloadImages(),
                    b.params.autoplay && b.startAutoplay(),
                    b.params.keyboardControl && b.enableKeyboardControl && b.enableKeyboardControl(),
                    b.params.mousewheelControl && b.enableMousewheelControl && b.enableMousewheelControl(),
                    b.params.hashnav && b.hashnav && b.hashnav.init(),
                    b.params.a11y && b.a11y && b.a11y.init(),
                    b.emit("onInit", b)
                },
                b.cleanupStyles = function() {
                    b.container.removeClass(b.classNames.join(" ")).removeAttr("style"),
                    b.wrapper.removeAttr("style"),
                    b.slides && b.slides.length && b.slides.removeClass([b.params.slideVisibleClass, b.params.slideActiveClass, b.params.slideNextClass, b.params.slidePrevClass].join(" ")).removeAttr("style").removeAttr("data-swiper-column").removeAttr("data-swiper-row"),
                    b.paginationContainer && b.paginationContainer.length && b.paginationContainer.removeClass(b.params.paginationHiddenClass),
                    b.bullets && b.bullets.length && b.bullets.removeClass(b.params.bulletActiveClass),
                    b.params.prevButton && a(b.params.prevButton).removeClass(b.params.buttonDisabledClass),
                    b.params.nextButton && a(b.params.nextButton).removeClass(b.params.buttonDisabledClass),
                    b.params.scrollbar && b.scrollbar && (b.scrollbar.track && b.scrollbar.track.length && b.scrollbar.track.removeAttr("style"), b.scrollbar.drag && b.scrollbar.drag.length && b.scrollbar.drag.removeAttr("style"))
                },
                b.destroy = function(e, a) {
                    b.detachEvents(),
                    b.stopAutoplay(),
                    b.params.scrollbar && b.scrollbar && b.params.scrollbarDraggable && b.scrollbar.disableDraggable(),
                    b.params.loop && b.destroyLoop(),
                    a && b.cleanupStyles(),
                    b.disconnectObservers(),
                    b.params.keyboardControl && b.disableKeyboardControl && b.disableKeyboardControl(),
                    b.params.mousewheelControl && b.disableMousewheelControl && b.disableMousewheelControl(),
                    b.params.a11y && b.a11y && b.a11y.destroy(),
                    b.emit("onDestroy"),
                    e !== !1 && (b = null)
                },
                b.init(),
                b
            }
        };
        t.prototype = {
            isSafari: function() {
                var e = navigator.userAgent.toLowerCase();
                return e.indexOf("safari") >= 0 && e.indexOf("chrome") < 0 && e.indexOf("android") < 0
            } (),
            isUiWebView: /(iPhone|iPod|iPad).*AppleWebKit(?!.*Safari)/i.test(navigator.userAgent),
            isArray: function(e) {
                return "[object Array]" === Object.prototype.toString.apply(e)
            },
            browser: {
                ie: window.navigator.pointerEnabled || window.navigator.msPointerEnabled,
                ieTouch: window.navigator.msPointerEnabled && window.navigator.msMaxTouchPoints > 1 || window.navigator.pointerEnabled && window.navigator.maxTouchPoints > 1
            },
            device: function() {
                var e = navigator.userAgent,
                a = e.match(/(Android);?[\s\/]+([\d.]+)?/),
                t = e.match(/(iPad).*OS\s([\d_]+)/),
                r = e.match(/(iPod)(.*OS\s([\d_]+))?/),
                i = !t && e.match(/(iPhone\sOS)\s([\d_]+)/);
                return {
                    ios: t || i || r,
                    android: a
                }
            } (),
            support: {
                touch: window.Modernizr && Modernizr.touch === !0 ||
                function() {
                    return !! ("ontouchstart" in window || window.DocumentTouch && document instanceof DocumentTouch)
                } (),
                transforms3d: window.Modernizr && Modernizr.csstransforms3d === !0 ||
                function() {
                    var e = document.createElement("div").style;
                    return "webkitPerspective" in e || "MozPerspective" in e || "OPerspective" in e || "MsPerspective" in e || "perspective" in e
                } (),
                flexbox: function() {
                    for (var e = document.createElement("div").style, a = "alignItems webkitAlignItems webkitBoxAlign msFlexAlign mozBoxAlign webkitFlexDirection msFlexDirection mozBoxDirection mozBoxOrient webkitBoxDirection webkitBoxOrient".split(" "), t = 0; t < a.length; t++) if (a[t] in e) return ! 0
                } (),
                observer: function() {
                    return "MutationObserver" in window || "WebkitMutationObserver" in window
                } ()
            },
            plugins: {}
        };
        for (var r = (function() {
            var e = function(e) {
                var a = this,
                t = 0;
                for (t = 0; t < e.length; t++) a[t] = e[t];
                return a.length = e.length,
                this
            },
            a = function(a, t) {
                var r = [],
                i = 0;
                if (a && !t && a instanceof e) return a;
                if (a) if ("string" == typeof a) {
                    var s, n, o = a.trim();
                    if (o.indexOf("<") >= 0 && o.indexOf(">") >= 0) {
                        var l = "div";
                        for (0 === o.indexOf("<li") && (l = "ul"), 0 === o.indexOf("<tr") && (l = "tbody"), (0 === o.indexOf("<td") || 0 === o.indexOf("<th")) && (l = "tr"), 0 === o.indexOf("<tbody") && (l = "table"), 0 === o.indexOf("<option") && (l = "select"), n = document.createElement(l), n.innerHTML = a, i = 0; i < n.childNodes.length; i++) r.push(n.childNodes[i])
                    } else for (s = t || "#" !== a[0] || a.match(/[ .<>:~]/) ? (t || document).querySelectorAll(a) : [document.getElementById(a.split("#")[1])], i = 0; i < s.length; i++) s[i] && r.push(s[i])
                } else if (a.nodeType || a === window || a === document) r.push(a);
                else if (a.length > 0 && a[0].nodeType) for (i = 0; i < a.length; i++) r.push(a[i]);
                return new e(r)
            };
            return e.prototype = {
                addClass: function(e) {
                    if ("undefined" == typeof e) return this;
                    for (var a = e.split(" "), t = 0; t < a.length; t++) for (var r = 0; r < this.length; r++) this[r].classList.add(a[t]);
                    return this
                },
                removeClass: function(e) {
                    for (var a = e.split(" "), t = 0; t < a.length; t++) for (var r = 0; r < this.length; r++) this[r].classList.remove(a[t]);
                    return this
                },
                hasClass: function(e) {
                    return this[0] ? this[0].classList.contains(e) : !1
                },
                toggleClass: function(e) {
                    for (var a = e.split(" "), t = 0; t < a.length; t++) for (var r = 0; r < this.length; r++) this[r].classList.toggle(a[t]);
                    return this
                },
                attr: function(e, a) {
                    if (1 === arguments.length && "string" == typeof e) return this[0] ? this[0].getAttribute(e) : void 0;
                    for (var t = 0; t < this.length; t++) if (2 === arguments.length) this[t].setAttribute(e, a);
                    else for (var r in e) this[t][r] = e[r],
                    this[t].setAttribute(r, e[r]);
                    return this
                },
                removeAttr: function(e) {
                    for (var a = 0; a < this.length; a++) this[a].removeAttribute(e);
                    return this
                },
                data: function(e, a) {
                    if ("undefined" != typeof a) {
                        for (var t = 0; t < this.length; t++) {
                            var r = this[t];
                            r.dom7ElementDataStorage || (r.dom7ElementDataStorage = {}),
                            r.dom7ElementDataStorage[e] = a
                        }
                        return this
                    }
                    if (this[0]) {
                        var i = this[0].getAttribute("data-" + e);
                        return i ? i: this[0].dom7ElementDataStorage && e in this[0].dom7ElementDataStorage ? this[0].dom7ElementDataStorage[e] : void 0
                    }
                },
                transform: function(e) {
                    for (var a = 0; a < this.length; a++) {
                        var t = this[a].style;
                        t.webkitTransform = t.MsTransform = t.msTransform = t.MozTransform = t.OTransform = t.transform = e
                    }
                    return this
                },
                transition: function(e) {
                    "string" != typeof e && (e += "ms");
                    for (var a = 0; a < this.length; a++) {
                        var t = this[a].style;
                        t.webkitTransitionDuration = t.MsTransitionDuration = t.msTransitionDuration = t.MozTransitionDuration = t.OTransitionDuration = t.transitionDuration = e
                    }
                    return this
                },
                on: function(e, t, r, i) {
                    function s(e) {
                        var i = e.target;
                        if (a(i).is(t)) r.call(i, e);
                        else for (var s = a(i).parents(), n = 0; n < s.length; n++) a(s[n]).is(t) && r.call(s[n], e)
                    }
                    var n, o, l = e.split(" ");
                    for (n = 0; n < this.length; n++) if ("function" == typeof t || t === !1) for ("function" == typeof t && (r = arguments[1], i = arguments[2] || !1), o = 0; o < l.length; o++) this[n].addEventListener(l[o], r, i);
                    else for (o = 0; o < l.length; o++) this[n].dom7LiveListeners || (this[n].dom7LiveListeners = []),
                    this[n].dom7LiveListeners.push({
                        listener: r,
                        liveListener: s
                    }),
                    this[n].addEventListener(l[o], s, i);
                    return this
                },
                off: function(e, a, t, r) {
                    for (var i = e.split(" "), s = 0; s < i.length; s++) for (var n = 0; n < this.length; n++) if ("function" == typeof a || a === !1)"function" == typeof a && (t = arguments[1], r = arguments[2] || !1),
                    this[n].removeEventListener(i[s], t, r);
                    else if (this[n].dom7LiveListeners) for (var o = 0; o < this[n].dom7LiveListeners.length; o++) this[n].dom7LiveListeners[o].listener === t && this[n].removeEventListener(i[s], this[n].dom7LiveListeners[o].liveListener, r);
                    return this
                },
                once: function(e, a, t, r) {
                    function i(n) {
                        t(n),
                        s.off(e, a, i, r)
                    }
                    var s = this;
                    "function" == typeof a && (a = !1, t = arguments[1], r = arguments[2]),
                    s.on(e, a, i, r)
                },
                trigger: function(e, a) {
                    for (var t = 0; t < this.length; t++) {
                        var r;
                        try {
                            r = new window.CustomEvent(e, {
                                detail: a,
                                bubbles: !0,
                                cancelable: !0
                            })
                        } catch(i) {
                            r = document.createEvent("Event"),
                            r.initEvent(e, !0, !0),
                            r.detail = a
                        }
                        this[t].dispatchEvent(r)
                    }
                    return this
                },
                transitionEnd: function(e) {
                    function a(s) {
                        if (s.target === this) for (e.call(this, s), t = 0; t < r.length; t++) i.off(r[t], a)
                    }
                    var t, r = ["webkitTransitionEnd", "transitionend", "oTransitionEnd", "MSTransitionEnd", "msTransitionEnd"],
                    i = this;
                    if (e) for (t = 0; t < r.length; t++) i.on(r[t], a);
                    return this
                },
                width: function() {
                    return this[0] === window ? window.innerWidth: this.length > 0 ? parseFloat(this.css("width")) : null
                },
                outerWidth: function(e) {
                    return this.length > 0 ? e ? this[0].offsetWidth + parseFloat(this.css("margin-right")) + parseFloat(this.css("margin-left")) : this[0].offsetWidth: null
                },
                height: function() {
                    return this[0] === window ? window.innerHeight: this.length > 0 ? parseFloat(this.css("height")) : null
                },
                outerHeight: function(e) {
                    return this.length > 0 ? e ? this[0].offsetHeight + parseFloat(this.css("margin-top")) + parseFloat(this.css("margin-bottom")) : this[0].offsetHeight: null
                },
                offset: function() {
                    if (this.length > 0) {
                        var e = this[0],
                        a = e.getBoundingClientRect(),
                        t = document.body,
                        r = e.clientTop || t.clientTop || 0,
                        i = e.clientLeft || t.clientLeft || 0,
                        s = window.pageYOffset || e.scrollTop,
                        n = window.pageXOffset || e.scrollLeft;
                        return {
                            top: a.top + s - r,
                            left: a.left + n - i
                        }
                    }
                    return null
                },
                css: function(e, a) {
                    var t;
                    if (1 === arguments.length) {
                        if ("string" != typeof e) {
                            for (t = 0; t < this.length; t++) for (var r in e) this[t].style[r] = e[r];
                            return this
                        }
                        if (this[0]) return window.getComputedStyle(this[0], null).getPropertyValue(e)
                    }
                    if (2 === arguments.length && "string" == typeof e) {
                        for (t = 0; t < this.length; t++) this[t].style[e] = a;
                        return this
                    }
                    return this
                },
                each: function(e) {
                    for (var a = 0; a < this.length; a++) e.call(this[a], a, this[a]);
                    return this
                },
                html: function(e) {
                    if ("undefined" == typeof e) return this[0] ? this[0].innerHTML: void 0;
                    for (var a = 0; a < this.length; a++) this[a].innerHTML = e;
                    return this
                },
                text: function(e) {
                    if ("undefined" == typeof e) return this[0] ? this[0].textContent.trim() : null;
                    for (var a = 0; a < this.length; a++) this[a].textContent = e;
                    return this
                },
                is: function(t) {
                    if (!this[0]) return ! 1;
                    var r, i;
                    if ("string" == typeof t) {
                        var s = this[0];
                        if (s === document) return t === document;
                        if (s === window) return t === window;
                        if (s.matches) return s.matches(t);
                        if (s.webkitMatchesSelector) return s.webkitMatchesSelector(t);
                        if (s.mozMatchesSelector) return s.mozMatchesSelector(t);
                        if (s.msMatchesSelector) return s.msMatchesSelector(t);
                        for (r = a(t), i = 0; i < r.length; i++) if (r[i] === this[0]) return ! 0;
                        return ! 1
                    }
                    if (t === document) return this[0] === document;
                    if (t === window) return this[0] === window;
                    if (t.nodeType || t instanceof e) {
                        for (r = t.nodeType ? [t] : t, i = 0; i < r.length; i++) if (r[i] === this[0]) return ! 0;
                        return ! 1
                    }
                    return ! 1
                },
                index: function() {
                    if (this[0]) {
                        for (var e = this[0], a = 0; null !== (e = e.previousSibling);) 1 === e.nodeType && a++;
                        return a
                    }
                },
                eq: function(a) {
                    if ("undefined" == typeof a) return this;
                    var t, r = this.length;
                    return a > r - 1 ? new e([]) : 0 > a ? (t = r + a, new e(0 > t ? [] : [this[t]])) : new e([this[a]])
                },
                append: function(a) {
                    var t, r;
                    for (t = 0; t < this.length; t++) if ("string" == typeof a) {
                        var i = document.createElement("div");
                        for (i.innerHTML = a; i.firstChild;) this[t].appendChild(i.firstChild)
                    } else if (a instanceof e) for (r = 0; r < a.length; r++) this[t].appendChild(a[r]);
                    else this[t].appendChild(a);
                    return this
                },
                prepend: function(a) {
                    var t, r;
                    for (t = 0; t < this.length; t++) if ("string" == typeof a) {
                        var i = document.createElement("div");
                        for (i.innerHTML = a, r = i.childNodes.length - 1; r >= 0; r--) this[t].insertBefore(i.childNodes[r], this[t].childNodes[0])
                    } else if (a instanceof e) for (r = 0; r < a.length; r++) this[t].insertBefore(a[r], this[t].childNodes[0]);
                    else this[t].insertBefore(a, this[t].childNodes[0]);
                    return this
                },
                insertBefore: function(e) {
                    for (var t = a(e), r = 0; r < this.length; r++) if (1 === t.length) t[0].parentNode.insertBefore(this[r], t[0]);
                    else if (t.length > 1) for (var i = 0; i < t.length; i++) t[i].parentNode.insertBefore(this[r].cloneNode(!0), t[i])
                },
                insertAfter: function(e) {
                    for (var t = a(e), r = 0; r < this.length; r++) if (1 === t.length) t[0].parentNode.insertBefore(this[r], t[0].nextSibling);
                    else if (t.length > 1) for (var i = 0; i < t.length; i++) t[i].parentNode.insertBefore(this[r].cloneNode(!0), t[i].nextSibling)
                },
                next: function(t) {
                    return new e(this.length > 0 ? t ? this[0].nextElementSibling && a(this[0].nextElementSibling).is(t) ? [this[0].nextElementSibling] : [] : this[0].nextElementSibling ? [this[0].nextElementSibling] : [] : [])
                },
                nextAll: function(t) {
                    var r = [],
                    i = this[0];
                    if (!i) return new e([]);
                    for (; i.nextElementSibling;) {
                        var s = i.nextElementSibling;
                        t ? a(s).is(t) && r.push(s) : r.push(s),
                        i = s
                    }
                    return new e(r)
                },
                prev: function(t) {
                    return new e(this.length > 0 ? t ? this[0].previousElementSibling && a(this[0].previousElementSibling).is(t) ? [this[0].previousElementSibling] : [] : this[0].previousElementSibling ? [this[0].previousElementSibling] : [] : [])
                },
                prevAll: function(t) {
                    var r = [],
                    i = this[0];
                    if (!i) return new e([]);
                    for (; i.previousElementSibling;) {
                        var s = i.previousElementSibling;
                        t ? a(s).is(t) && r.push(s) : r.push(s),
                        i = s
                    }
                    return new e(r)
                },
                parent: function(e) {
                    for (var t = [], r = 0; r < this.length; r++) e ? a(this[r].parentNode).is(e) && t.push(this[r].parentNode) : t.push(this[r].parentNode);
                    return a(a.unique(t))
                },
                parents: function(e) {
                    for (var t = [], r = 0; r < this.length; r++) for (var i = this[r].parentNode; i;) e ? a(i).is(e) && t.push(i) : t.push(i),
                    i = i.parentNode;
                    return a(a.unique(t))
                },
                find: function(a) {
                    for (var t = [], r = 0; r < this.length; r++) for (var i = this[r].querySelectorAll(a), s = 0; s < i.length; s++) t.push(i[s]);
                    return new e(t)
                },
                children: function(t) {
                    for (var r = [], i = 0; i < this.length; i++) for (var s = this[i].childNodes, n = 0; n < s.length; n++) t ? 1 === s[n].nodeType && a(s[n]).is(t) && r.push(s[n]) : 1 === s[n].nodeType && r.push(s[n]);
                    return new e(a.unique(r))
                },
                remove: function() {
                    for (var e = 0; e < this.length; e++) this[e].parentNode && this[e].parentNode.removeChild(this[e]);
                    return this
                },
                add: function() {
                    var e, t, r = this;
                    for (e = 0; e < arguments.length; e++) {
                        var i = a(arguments[e]);
                        for (t = 0; t < i.length; t++) r[r.length] = i[t],
                        r.length++
                    }
                    return r
                }
            },
            a.fn = e.prototype,
            a.unique = function(e) {
                for (var a = [], t = 0; t < e.length; t++) - 1 === a.indexOf(e[t]) && a.push(e[t]);
                return a
            },
            a
        } ()), i = ["jQuery", "Zepto", "Dom7"], s = 0; s < i.length; s++) window[i[s]] && e(window[i[s]]);
        var n;
        n = "undefined" == typeof r ? window.Dom7 || window.Zepto || window.jQuery: r,
        n && ("transitionEnd" in n.fn || (n.fn.transitionEnd = function(e) {
            function a(s) {
                if (s.target === this) for (e.call(this, s), t = 0; t < r.length; t++) i.off(r[t], a)
            }
            var t, r = ["webkitTransitionEnd", "transitionend", "oTransitionEnd", "MSTransitionEnd", "msTransitionEnd"],
            i = this;
            if (e) for (t = 0; t < r.length; t++) i.on(r[t], a);
            return this
        }), "transform" in n.fn || (n.fn.transform = function(e) {
            for (var a = 0; a < this.length; a++) {
                var t = this[a].style;
                t.webkitTransform = t.MsTransform = t.msTransform = t.MozTransform = t.OTransform = t.transform = e
            }
            return this
        }), "transition" in n.fn || (n.fn.transition = function(e) {
            "string" != typeof e && (e += "ms");
            for (var a = 0; a < this.length; a++) {
                var t = this[a].style;
                t.webkitTransitionDuration = t.MsTransitionDuration = t.msTransitionDuration = t.MozTransitionDuration = t.OTransitionDuration = t.transitionDuration = e
            }
            return this
        })),
        window.Swiper = t
    } (),
    "undefined" != typeof module ? module.exports = window.Swiper: "function" == typeof define && define.amd && define([],
    function() {
        "use strict";
        return window.Swiper
    });
    //# sourceMappingURL=maps/swiper.min.js.map
    
    

    相关文章

      网友评论

          本文标题:仿朋友圈特效

          本文链接:https://www.haomeiwen.com/subject/azzwwftx.html